Многоуровневая организация вычислительных процессов. Понятия архитектуры вычислительной машины, аппаратного и программного обеспечения
Базовая функциональная схема компьютера PC
Базовая функциональная схема компьютера PC (рис. 2) содержит четыре основных функциональных устройства: процессор, основную память, устройства ввода-вывода (УВВ или периферийные устройства), системную шину (СШ). СШ содержит три группы соединительных линий, которые называются шиной адреса (ША), шиной данных (ШД) и шиной управления (ШУ). Разрядность ША, ШД, ШУ, порядок взаимодействия устройств, уровни и последовательности сигналов в СШ стандартизированы.
К основным УВВ относятся: клавиатура, мышь, монитор (дисплей), винчестер – накопитель на жестком магнитном диске (НЖМД или ЖД) Hard Disk Drive (HDD), дисковод для гибких магнитных дисков Floppy Disk Drive (FDD), принтер.
Компьютеры PC построены с использованием основных принципов Дж.фон Неймана, изложенных выше. Управление вычислительным процессом осуществляет процессор – Central Processing Unit (CPU). ОП имеет линейно-адресную организацию. Адреса являются именами данных, которые используются в командах программ. Множество адресов, используемых в командах, образует адресное пространство (АП). Обмен информацией между устройствами по СШ называют внутримашинным обменом. В любом обмене участвуют как минимум два устройства: активное (источник) и пассивное (приемник). В PC для организации внутримашинных обменов используют два адресных пространства: АП ОП и АП УВВ.
Шиной (магистралью) в ВМ называют совокупность линий передачи сигналов, к которым параллельно может подключаться несколько блоков. По шине передаются адреса, данные и управляющие сигналы. Физически шина представляет собой печатные проводники, к которым подключаются одноименные входы-выходы различных блоков ВС.
ША служит для адресации ячеек памяти и регистров (портов) внешних устройств, с которыми взаимодействует процессор. Адрес по шине подается во все подключенные к ней устройства. Все устройства содержат селекторы адреса, с помощью которых распознают собственный адрес. На обращение по шине реагирует только адресуемое устройство. Именно оно по сигналу от селектора адреса воспринимает управляющие сигналы, передаваемые по ШУ, и реализует соответствующие операции.
Различают два типа информационного обмена по СШ: ввод (чтение) и вывод (запись). Передача данных в процессор называется вводом, а от процессора – выводом. При обмене активное устройство (чаще всего процессор) формирует код адреса, соответствующий номеру ячейки в ОП либо номеру порта, используемого для временного хранения одного слова данных.
По ШД производится обмен данными между процессором, памятью и УВВ, подключенными к шине. ШД – двунаправленная. По этой шине процессор имеет возможность как передавать информацию в другие устройства, так и получать информацию от других устройств.
В каждый конкретный момент времени информация по двунаправленной ШД может передаваться только в одном направлении, поэтому необходимо иметь специальные сигналы, указывающие это направление. Такие управляющие сигналы вырабатывает процессор. Эти сигналы определяют «режим обмена» по шине.
Все управляющие сигналы передаются по ШУ, в которой большинство линий – однонаправленные, а некоторые – двунаправленные. Управляющие сигналы передаются во все блоки ВМ, подключенные к шине, настраивая их на нужный режим работы.
Для уменьшения затрат времени на информационный обмен между ОП и процессором включают буферную кэш-память. Первый уровень кэш-памяти расположен на кристалле современного процессора, второй уровень – на кристалле процессора или в непосредственной близости от этого кристалла. При этом обмен с ОП происходит не отдельными словами, а пакетами слов, что позволяет более эффективно использовать разделяемый ресурс – шину.
Применительно к задачам информационного взаимодействия различных устройств используется понятие «интерфейс»
Под интерфейсом (Interface – сопряжение) понимается совокупность аппаратных, программных и конструктивных средств, используемых для реализации информационного взаимодействия функциональных блоков в ВМ (ПК). Понятие «интерфейс» используется во всех устройствах ВМ: процессора, СШ, ОП, периферийных устройств.
Для согласования интерфейсов СШ и периферийных устройств используют аппаратные средства (адаптеры или контроллеры), размещаемые на печатных платах расширения. Контроллер отличается от адаптера тем, что он является активным устройством, т.е. устройством, способным к самостоятельным действиям без участия процессора после получения команд от обслуживающих его программ.
Интерфейсные блоки (адаптеры, контроллеры, интерфейсные карты) являются буфером между периферийными устройствами и процессором. Они содержат регистры (порты), которым соответствуют определенные адреса в АП ввода-вывода. Буфер требуется для преобразования форматов представления данных и скорости передачи, свойственных периферийным устройствам, в форматы и скорости, с которыми работает процессор компьютера.
Для организации информационного обмена с периферийными устройствами используются три способа:
- программный опрос, в этом случае инициатором обмена выступает процессор, который при необходимости обращается к регистрам периферийных устройств (портам) по соответствующим адресам;
- обмен с прерыванием программы (он реализуется с помощью механизма аппаратных прерываний, который обеспечивает реакцию компьютера на асинхронные события по запросам периферийных устройств);
- передача информации в режиме прямого доступа к памяти – Direct Memory Access (DMA).
Прямой доступ к памяти используется, когда требуется высокая скорость обмена между внешними устройствами и памятью. В режиме DMA процессор отключается от СШ. Передача данных производится не одиночными словами, а пакетами. Обменом управляет специальный контроллер DMA, который осуществляет формирование управляющих сигналов в ШУ и адресов в ША. Контроллер DMA можно рассматривать как сопроцессор ввода-вывода, освобождающий центральный процессор от задач управления обменом при передаче массива между периферийными устройствами и ОП.
ВМ и ВС, являясь сложными системами, содержат большое число взаимодействующих аппаратных и программных модулей. Сложные системы не имеют простых описаний. Это связано со следующими особенностями: большое число и разнородность элементов системы (модулей), разнообразие и нерегулярность связей между ними, отсутствие единого аппарата для описания поведения различных модулей.
Для описания, проектирования и организации управления в ВС используется иерархический подход. Рассмотрим уровни организации вычислительных процессов (рис. 3) в ВМ и ВС, а также категории специалистов, использующие соответствующие уровни представления в своей профессиональной деятельности, и процессы, реализующие взаимодействие уровней.
На концептуальном уровне пользователь анализирует задачу, выбирает метод ее решения, разрабатывает алгоритм. Для сложных задач выполняется функциональная декомпозиция, определяются структуры данных, выделяются программные модули, определяются связи между ними.
Далее пишется программа на одном из языков высокого уровня. Такое представление программы является машинно-независимым, то есть независимым от архитектуры ВС и от особенностей аппаратного обеспечения.
На уровне машинных команд обеспечивается связь программных и аппаратных средств. На этом уровне разрабатывается список команд, определяются способы кодирования операций и адресов, число адресных полей в команде и другие параметры, заложенные в структуру ВМ. Перевод программы с языка высокого уровня в машинные коды осуществляет специальная программа – компилятор. Для одной программы, написанной на языке высокого уровня, можно породить много программ на уровне машинных команд, которые по выполняемым функциям эквивалентны, но различаются по использованию ресурсов ВМ (памяти, процессорного времени). Поэтому актуальна задача построения оптимизирующего компилятора. Чем ближе состав операторов языка высокого уровня к списку команд ВМ, тем проще компилятор и эффективнее полученная для исполнения программа. При программировании часто используют язык Ассемблера. Ассемблер – машинно-зависимый язык программирования. Представление задачи на языке Ассемблера занимает промежуточное положение в иерархии представлений между языками высокого уровня и машинными командами. Язык Ассемблера используют при написании системных программ, кратность исполнения которых существенно выше, чем у прикладных программ, например для МК (микроконтроллеров), ресурсы которых ограничены, а прикладные программы для них - это, как правило, программы управления оборудованием, которые также исполняются многократно.
Следует отметить, что связь между языками высокого уровня и машинными командами может осуществляться как методом компиляции, так и методом интерпретации. При компиляции программа на языке высокого уровня сначала преобразуется полностью в программу в машинных кодах, а затем может поступать для исполнения с использованием более низких уровней вычислительного процесса. При работе компилятора программа пользователя на языке высокого уровня – это входные данные, а соответствующая программа на языке машинных команд – выходные данные, результат работы компилятора. При исполнении полученная программа в машинных кодах уже используется не как данные, а как программа, управляющая вычислительным процессом.
При интерпретации программа пользователя на языке высокого уровня непосредственно используется для управления вычислительным процессом с использованием системной программы – интерпретатора. Интерпретатор выбирает очередную команду программы на языке высокого уровня, заменяет ее последовательностью машинных команд, выполняющих требуемые функции, и сразу передает эту последовательность машинных команд на исполнение. Затем с учетом признаков, характеризующих результат выполненных преобразований, выбирается следующая команда программы на языке высокого уровня и т.д.
При компиляции требуется более сложная системная программа – компилятор. В процессе компиляции требуется больший объем памяти, но зато исполнение пользовательской программы происходит существенно быстрее. В связи с этим в современных ВМ в основном используется метод компиляции.
На уровне регистровых передач осуществляются микрооперации, выполняемые аппаратурой ВМ. Это операции передачи, запоминания и преобразования кодов, выполняемые пересылкой сигналов между регистрами через комбинационные (логические) схемы (рис. 4). Микрооперация – это операция над кодами, выполняемая одной регистровой передачей (за такт). Для настройки схем на выполнение требуемой микрооперации при регистровой передаче требуется сформировать соответствующий набор управляющих сигналов. Код набора управляющих сигналов называют микрокомандой. Последовательность микрокоманд, соответствующая исполнению машинной команды, называют микропрограммой. Каждой машинной команде соответствует своя микропрограмма. Связь между уровнями машинных команд и регистровых передач осуществляется методом интерпретации. Выборкой команд из программы в машинных кодах и интерпретации выбранной команды управляет аппаратное устройство управления центрального процессора. Уровень регистровых передач называют также микропрограммным.
На уровне логических вентилей рассматриваются логические схемы при логическом проектировании аппаратуры ВМ. Если на уровне регистровых передач рассматриваются операции с n-разрядными кодами, то на уровне вентилей – с отдельными двоичными переменными.
Многоуровневая организация упрощает реализацию ВМ и управление вычислительным процессом, но снижает эффективность работы за счет «накладных расходов» на управление. В процессе работы происходит «челночное» взаимодействие между уровнями: выборка очередной команды на уровне машинных команд, интерпретация команды на уровне регистровых передач, реализация регистровой передачи передачей сигналов в сети логических элементов, фиксация признаков, характеризующих результат выполнения операции, использование признаков для разветвления при выборке следующей команды, и т.д.
В управлении вычислительным процессом с иерархической организацией участвуют как программные, так и аппаратные средства. Функционирование ВМ и ВС заключается в тесном и неразрывном взаимодействии аппаратуры и программ. Грань разделения функций, реализуемых аппаратно и программно, по мере развития архитектуры ВМ и технологии их изготовления смещается в сторону аппаратной реализации.
Определим понятие «архитектура ВМ». С точки зрения пользователя архитектура – это совокупность системы команд, способов организации памяти, система адресации, организация ввода и вывода и т.п. С точки зрения разработчика – это структура аппаратного обеспечения, зависящая от элементной базы, конфигурация и взаимодействие основных узлов, распределение функций по уровням иерархической организации вычислительных процессов, определение границ и интерфейсов.
ПО принято подразделять на две части: системное и прикладное.
Системное ПО (system software) – это совокупность системных программ, необходимых для эксплуатации и технического обслуживания ВМ, для организации вычислительных процессов и автоматизации разработки прикладных программ. Важнейшей составляющей системного ПО является операционная система.
Прикладное ПО – пользовательское. Оно включает прикладные программы и пакеты, предназначенные для решения на ВМ задачи или класса задач в определенной области науки, техники, экономики, искусства.
По функциональному признаку программы системного ПО делят на транслирующие, служебные, управляющие. Транслирующие программы преобразуют программы, представленные на языках программирования, в машинные коды. Транслирующие программы входят в состав так называемых систем программирования. Служебные программы – динамично изменяемая часть системного ПО, зависящая от назначения ВМ, состава аппаратного обеспечения. К ним относятся драйверы (программы работы с периферийными устройствами), тесты, диагностические программы и некоторые другие. Управляющие программы используются при организации вычислительных процессов для распределения ресурсов и для диспетчеризации процессов.
Управление вычислительными процессами в ВМ и ВС организовано по иерархическому принципу. Верхний уровень иерархии занимает ОС. Под ОС понимают систему программ, предназначенную для обеспечения определенного уровня эффективности ВС за счет автоматизированного управления ее работой и предоставляемых пользователям определенного рода услуг. ОС обеспечивает взаимодействие ВС с пользователем и координацию работы всех ее подсистем: запуск программ, разделение ОП и других ресурсов между ними, связь с внешними устройствами.
Используя многоуровневое представление вычислительных процессов можно отметить, что ОС управляет вводом программы на языке высокого уровня, трансляцией ее в машинные коды, предоставлением необходимых ресурсов и инициированием исполнения.
Часть системного ПО, называемая базовой системой ввода-вывода BIOS (Basic Input Output System), необходима для инициализации работы ВС и управления выполнением ряда системных функций. BIOS – это система программ на машинном языке, управляющая передачей данных между устройствами ВМ (процессором, памятью, дисками, монитором), а также выполняющая рад дополнительных функций при включении компьютера.
Программы BIOS записаны на энергонезависимой памяти (ROM или FLASH). В компьютерах PC соответствующая микросхема энергонезависимой памяти с записанными на ней программами устанавливается на материнской плате. В ней хранятся тестовые, загрузочные программы, базовая система ввода-вывода. Использование флэш-памяти для хранения BIOS позволяет обновлять версию. Перечислим основные функции BIOS в компьютерах PC:
· инициализация и начальное тестирование аппаратных средств, эти функции выполняет программа POST – Power On Self Test;
· настройка и конфигурирование аппаратных средств и системных ресурсов – BIOS Setup;
· загрузка ОС с дискового носителя – Bootstrap Loader;
· обслуживание аппаратных прерываний – BIOS Hardware Interrupts;
· отработка базовых функций программных обращений (сервисов) к системным устройствам – ROM BIOS Services.