Арифметико-логическое устройство
Программный счетчик
Регистр инструкций
Процессорное ядро
Каждый производитель микроконтроллеров для серии выпускаемых изделий разрабатывает и патентует свое оригинальное ядро (MCU – Microprocessor Core Unit). Однако в большинстве из них присутствуют одни и те же элементы:
Ø регистр инструкций,
Ø программный счетчик,
Ø арифметическо-логическое устройство,
Ø регистры общего назначения,
Ø регистр состояния,
Ø регистры ввода/вывода,
Ø стек.
Регистр инструкций (IR – Instruction Register) – регистр, предназначенный для хранения считанной из памяти программ инструкции. Считанная из памяти программ инструкция декодируется дешифратором команд и исполняется микропрограммным автоматом ядра. Разрядность регистра инструкций определяется разрядностью памяти программ.
Программный счетчик (PC – Program Counter) - регистр, предназначенный для хранения адреса ячейки памяти программ, в которой находится выполняемая в данный момент инструкция. Разрядность программного счетчика определяется количеством ячеек в памяти программы. При выполнении команды содержимое программного счетчика изменяется. В простейшем случае оно увеличивается на единицу. Но некоторые команды сами способны записывать данные в программный счетчик. В этом случае новое содержимое программного счетчика и определяется данными, заложенными в выполняемой инструкции.
|
|
Арифметико-логическое устройство (ALU – Arithmetic Logic Unit) – логическая схема, непосредственно осуществляющая преобразование одной или двух переменных в соответствии с инструкцией, занесенной в регистр команд. Стандартное ALU способно выполнять простейшие арифметические и логические операции над оной или двумя переменными.
Типовые функции ALU:
Ø сложение (addition),
Ø вычитание (subtract),
Ø инкремент (increment);
Ø декремент (decrement),
Ø Типовые логические операции:
Ø инверсия (NOT),
Ø логическое сложение (OR),
Ø логическое умножение (AND),
Ø исключающее ИЛИ (exclusive OR).
Некоторые производители интегрируют на кристалл также встроенный умножитель двух переменных.
8-битное арифметико-логическое устройство (ALU) может выполнять арифметические операции сложения, вычитания, умножения и деления; логические операции И, ИЛИ, исключающее ИЛИ, а также операции циклического сдвига, сброса, инвертирования и т.п. К входам подключены программно-недоступные регистры T1 и T2, предназначенные для временного хранения операндов, схема десятичной коррекции (DCU) и схема формирования признаков результата операции (PSW).
Рисунок 1.2 Структурная схема микроконтроллера 8051
|
|
Простейшая операция сложения используется в ALU для инкрементирования содержимого регистров, продвижения регистра-указателя данных (RAR) и автоматического вычисления следующего адреса резидентной памяти программ. Простейшая операция вычитания используется в ALU для декрементирования регистров и сравнения переменных.
Простейшие операции автоматически образуют “тандемы” для выполнения таких операций, как, например, инкрементирование 16-битных регистровых пар. В ALU реализуется механизм каскадного выполнения простейших операций для реализации сложных команд. Так, например, при выполнении одной из команд условной передачи управления по результату сравнения в ALU трижды инкрементируется счётчик команд (PC), дважды производится чтение из RDM, выполняется арифметическое сравнение двух переменных, формируется 16-битный адрес перехода и принимается решение о том, делать или не делать переход по программе. Все перечисленные операции выполняются всего лишь за 2 мкс.
Важной особенностью ALU является его способность оперировать не только байтами, но и битами. Отдельные программно-доступные биты могут быть установлены, сброшены, инвертированы, переданы, проверены и использованы в логических операциях. Эта способность достаточно важна, поскольку для управления объектами часто применяются алгоритмы, содержащие операции над входными и выходными булевыми переменными, реализация которых средствами обычных микропроцессоров сопряжена с определенными трудностями.
Таким образом, ALU может оперировать четырьмя типами информационных объектов:
Ø булевыми объектами (1 бит),
Ø цифровыми объектами (4 бита),
Ø байтными объектами (8 бит),
Ø адресными объектами (16 бит).
В ALU выполняется 51 различная операция пересылки или преобразования этих данных. Так как используется 11 режимов адресации (7 для данных и 4 для адресов), то путем комбинирования операции и режима адресации базовое число команд 111 расширяется до 255 из 256 возможных при однобайтном коде операции.