Регистры специальных функций
К адресному пространству памяти данных примыкает адресное пространство регистров специальных функций РСФ или, на английском языке, SFR (Special Function Register).
Регистры с символическими именами IP, IE, TMOD, TCON, SCON и PCON используются для фиксации и программного изменения управляющих бит и бит состояния схемы прерывания, таймера/счетчика, приемопередатчика последовательного порта и для управления энергопотреблением.
Адрес прямо адресуемых битов может быть записан либо в виде выражения (НазваниеРегистра).(Разряд), либо в виде номера бита (Табл. 1.2). Адреса регистров специальных функций приведены в табл. 1.3.
Карта адресуемых битов в блоке регистров SFR
Таблица 1.2
| Адрес байта | Адреса битов по разрядам | Имя регистра | |||||||
| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | ||
| F0H | F7 | F6 | F5 | F4 | F3 | F2 | F1 | F0 | B |
| ... | … | ... | |||||||
| E0H | E7 | E6 | E5 | E4 | E3 | E2 | E1 | E0 | ACC |
| ... | … | ... | |||||||
| D0H | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | PSW |
| ... | … | ... | |||||||
| B8H | - | - | - | BC | BB | BA | B9 | B8 | IP |
| ... | … | ... | |||||||
| B0 | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 | P3 |
| ... | … | ... | |||||||
| A8H | AF | - | - | AC | AB | AA | A9 | A8 | IE |
| ... | … | ... | |||||||
| A0H | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 | P2 |
| ... | … | ... | |||||||
| 98H | 9F | 9E | 9D | 9C | 9B | 9A | SCON | ||
| ... | … | ... | |||||||
| 90H | P1 | ||||||||
| ... | … | ... | |||||||
| 88H | 8F | 8E | 8D | 8C | 8B | 8A | TCON | ||
| ... | … | ... | |||||||
| 80H | P0 |
Размещение регистров специальных функций
Таблица 1.3
| Адрес | Символ | Наименование |
| 0E0h | *АСС | Аккумулятор (Accumulator) |
| 0F0h | *В | Регистр расширитель аккумулятора (Multiplication Register) |
| 0D0h | *PSW | Слово состояния программы (Program Status Word) |
| 080Н | *P0 | Порт 0 (SFR P0) |
| 090h | *Р1 | Порт 1 (SFR P1) |
| 0A0h | *P2 | Порт 2 (SFR P2) |
| 0B0h | *P3 | Порт 3 (SFR РЗ) |
| 081h | SP | Регистр указатель стека (Stack Pointer) |
| 083h | DPР | Старший байт регистра указателя данных DPTR (Data Pointer High) |
| 082h | DPL | Младший байт регистра указателя данных DPTR (Data Pointer Low) |
| 08Ch | TH0 | Старший байт таймера 0 |
| 08Ah | TL0 | Младший байт таймера 0 |
| 08Dh | TР1 | Старший байт таймера 1 |
| 08Bh | TL1 | Младший байт таймера 1 |
| 089h | TMOD | Регистр режимов таймеров счетчиков (Timer/Counter Mode Control Register) |
| 088h | *TCON | Регистр управления статуса таймеров (Timer/Counter Control Register) |
| 0B8h | *IP | Регистр приоритетов (Interrupt Priority Control Register) |
| 0A8h | *IE | Регистр маски прерывания (Interrupt Enable Register) |
| 087h | PCON | Регистр управления мощностью (Power Control Register) |
| 098h | *SCON | Регистр управления приемопередатчиком (Serial Port Control Register) |
| 099h | SBUF | Буфер приемопередатчика (Serial Data Buffer) |
* Примечание. Регистры, символ которых отмечен знаком (*), допускают адресацию своих отдельных бит при использовании команд из группы команд операций над битами.
Отметим, что регистры занимают только часть 128-байтового адресного пространства. Те ячейки памяти с адресами 80H-0FFH, которые не заняты регистрами, физически отсутствуют, на кристаллах микроконтроллеров семейства 8051 при обращении к ним можно прочитать лишь случайные данные.
Регистры специальных функций управляют работой блоков, входящих в микроконтроллер.
· Регистры-защелки SFR параллельных портов P0...P3 - служат для ввода-вывода информации.
· Две регистровые пары с именами TH0, TL0 и TH1, TL1 представляют собой регистры, двух программно-управляемых 16-битных таймеров-счетчиков (Рис.1).
· Режимы таймеров-счетчиков задаются с использованием регистра TMOD, а управление ими осуществляется с помощью регистра TCON.
· Для управления режимами энергопотребления микро-ЭВМ используется регистр PMOD.
· Регистры IP и IE управляют работой системы прерываний микро-ЭВМ,
· регистры SBUF и SCON — работой приемопередатчика последовательного порта.
· Регистр-указатель стека SP в микро-ЭВМ рассматриваемого семейства — восьми битный. Он может адресовать любую область внутренней памяти данных. У микро-ЭВМ семейства 8051 стек «растет вверх», т.е. перед выполнением команды PUSH или CALL содержимое SP инкрементируется, после чего производится запись информации в стек. Соответственно при извлечении информации из стека регистр SP декрементируется после извлечения информации.
· Регистр-указатель данных DPTR чаще всего используют для фиксации 16-битного адреса в операциях обращения к внешней памяти программ и данных. С точки зрения программиста он может выступать как в виде одного 16-битного регистра, так и в виде двух независимых регистров DPL и DPH
· Аккумулятор (АСС) является источником операнда и местом фиксации результата при выполнении арифметических, логических операций и ряда операций передачи данных. Кроме того, только с использованием аккумулятора могут быть выполнены операции сдвигов, проверка на нуль, формирование флага паритета и т.п. В распоряжении пользователя имеются 8 регистров общего назначения R0–R7 одного из четырёх возможных банков.
· Регистр В используется как источник и как приемник при операциях умножения и деления, обращение к нему, как к регистру SFR, производится аналогично аккумулятору.
· При выполнении ряда команд в арифметико-логическом устройстве (АЛУ) формируются признаки операций — флаги, которые фиксируются в регистре PSW (табл. 1.4).
Дата добавления: 2015-10-09; просмотров: 2825;
