Арифметико-логическое устройство микроконтроллера 8051

Арифметико-логическое устройство

Программный счетчик

Регистр инструкций

Процессорное ядро

Каждый производитель микроконтроллеров для серии выпускаемых изделий разрабатывает и патентует свое оригинальное ядро (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 возможных при однобайтном коде операции.


Понравилась статья? Добавь ее в закладку (CTRL+D) и не забудь поделиться с друзьями:  



double arrow
Сейчас читают про: