# Микроконтроллеры AVR семейства Classic фирмы ATMEL

3-е издание, стереотипное



УДК 004.312 (035.5) ББК 32.844.1я2 Е263

#### Евстифеев А.В.

E263 Микроконтроллеры AVR семейства Classic фирмы ATMEL — 3-е изд., стер. — М.: Издательский дом «Додэка-ХХІ», 2006. — 288 с.: ил. (Серия «Мировая электроника»)

ISBN 5-94120-127-3

Книга представляет собой справочное издание по применению микроконтроллеров AVR семейства Classic фирмы ATMEL. Рассмотрены особенности архитектуры, приведены основные электрические параметры. Подробно описаны система команл. периферия. а также способы программирования.

Предназначена для разработчиков радиоэлектронной аппаратуры, инженеров, студентов технических вузов.

УДК 004.312 (035.5) ББК 32.844.1я2

Ответственный редактор В. Я. Симонов Научный редактор В. Б. Стешенко Художественный редактор М. С. Коршунова Выпускающий редактор Е. Е. Граблевская Корректоры С. И. Шишкина, Л. Р. Попова Графики А. Ю. Анненков, А. Н. Клочков Верстка Е. М. Илюшина

Издательский дом «Додэка-ХХІ» ОКП 95 3000 105318 Москва, а/я 70 Тел./факс: (095) 366-24-29, 366-81-45 E-mail: books@dodeca.ru; red@dodeca.ru

# ОГЛАВЛЕНИЕ

| ПРЕДИСЛОВИЕ                                   |
|-----------------------------------------------|
| ГЛАВА 1. ЗНАКОМСТВО С СЕМЕЙСТВОМ CLASSIC      |
| 1.1. ОБЩИЕ СВЕДЕНИЯ                           |
| 1.2. ОТЛИЧИТЕЛЬНЫЕ ОСОБЕННОСТИ                |
|                                               |
| 1.3. ХАРАКТЕРИСТИКИ ЯДРА МИКРОКОНТРОЛЛЕРА     |
| 1.4. ХАРАКТЕРИСТИКИ ПОДСИСТЕМЫ ВВОДА/ВЫВОДА10 |
| 1.5. ПЕРИФЕРИЙНЫЕ УСТРОЙСТВА11                |
| 1.6. АРХИТЕКТУРА ЯДРА11                       |
| 1.7. ЦОКОЛЕВКА И ОПИСАНИЕ ВЫВОДОВ             |
|                                               |
| ГЛАВА 2. АРХИТЕКТУРА МИКРОКОНТРОЛЛЕРОВ        |
| <b>СЕМЕЙСТВА CLASSIC</b>                      |
| 2.1. ОБЩИЕ СВЕДЕНИЯ27                         |
| 2.2. ОРГАНИЗАЦИЯ ПАМЯТИ                       |
| 2.2.1. Память программ                        |
| 2.2.2. Память данных                          |
| 2.2.2.1. Статическое ОЗУ                      |
| 2.2.2.2. Регистры общего назначения           |
| 2.2.2.3. Регистры воощего назначения          |
|                                               |
| 2.2.2.4. Способы адресации памяти данных      |
| 2.2.3. Энергонезависимая память данных        |
| 2.2.3.1. Организация доступа                  |
| 2.2.3.2. Меры предосторожности при работе     |
| 2.3. СЧЕТЧИК КОМАНД И ВЫПОЛНЕНИЕ ПРОГРАММЫ    |
| 2.3.1. Функционирование конвейера             |

# СОДЕРЖАНИЕ———

| 2.3.2. Задержки в конвейере                              | 69  |
|----------------------------------------------------------|-----|
| 2.3.3. Счетчик команд                                    | 70  |
| 2.3.4. Команды типа «проверка/пропуск»                   | 70  |
| 2.3.5. Команды условного перехода                        | 71  |
| 2.3.6. Команды безусловного перехода                     | 71  |
| 2.3.7. Команды вызова подпрограмм                        | 73  |
| 2.3.8. Команды возврата из подпрограмм                   | 74  |
| 2.4. CTEK                                                | 74  |
| 2.4.1. Стек в микроконтроллере AT90S1200                 | 74  |
| 2.4.2. Стек в старших моделях микроконтроллеров          | 76  |
| ГЛАВА 3. СИСТЕМА КОМАНД                                  |     |
| 3.1. ОБЩИЕ СВЕДЕНИЯ                                      |     |
| 3.2. ОПЕРАНДЫ                                            |     |
| 3.3. ТИПЫ КОМАНД                                         | 79  |
| 3.3.1. Команды логических операций                       | 79  |
| 3.3.2. Команды арифметических операций и команды сдвига  | 80  |
| 3.3.3. Команды операций с битами                         | 80  |
| 3.3.4. Команды пересылки данных                          | 81  |
| 3.3.5. Команды передачи управления                       | 81  |
| 3.3.6. Команды управления системой                       |     |
| 3.4. СВОДНЫЕ ТАБЛИЦЫ КОМАНД                              |     |
| 3.5. ОПИСАНИЕ КОМАНД                                     | 89  |
| ГЛАВА 4. УСТРОЙСТВО УПРАВЛЕНИЯ                           | 147 |
| 4.1. ОБЩИЕ СВЕДЕНИЯ                                      | 147 |
| 4.2. ТАКТОВЫЙ ГЕНЕРАТОР                                  | 148 |
| 4.3. РЕЖИМЫ ПОНИЖЕННОГО ЭНЕРГОПОТРЕБЛЕНИЯ                | 150 |
| 4.3.1. Режим Idle                                        | 151 |
| 4.3.2 Режим Power Down                                   | 151 |
| 4.3.3 Режим Power Save                                   | 152 |
| 4.4. СБРОС                                               |     |
| 4.4.1. Сброс по включении питания                        | 154 |
| 4.4.2. Аппаратный сброс                                  |     |
| 4.4.3. Сброс от сторожевого таймера                      |     |
| 4.4.4. Сброс при снижении напряжения питания (Brown-Out) |     |
| 4.4.5. Управление схемой сброса                          |     |
| 4.5. ПРЕРЫВАНИЯ                                          |     |
| 4.5.1. Таблица векторов прерываний                       |     |
| 4.5.2. Обработка прерываний                              |     |
| 4.5.3. Внешние прерывания; регистры GIMSK и GIFR         |     |
| 4.5.4. Прерывания от таймеров; регистры TIMSK и TIFR     | 172 |

# - СОДЕРЖАНИЕ

| ГЛАВА 5. ПОРТЫ ВВОДА/ВЫВОДА                |     |
|--------------------------------------------|-----|
| 5.1. ОБЩИЕ СВЕДЕНИЯ                        |     |
| 5.2. ОБРАЩЕНИЕ К ПОРТАМ ВВОДА/ВЫВОДА       | 178 |
| 5.3. КОНФИГУРИРОВАНИЕ ПОРТОВ ВВОДА/ВЫВОДА  | 182 |
| ГЛАВА 6. ТАЙМЕРЫ                           |     |
| 6.1. ОБЩИЕ СВЕДЕНИЯ                        |     |
| 6.2. НАЗНАЧЕНИЕ ВЫВОДОВ ТАЙМЕРОВ/СЧЕТЧИКОВ |     |
| 6.3. ТАЙМЕР/СЧЕТЧИК ТО                     |     |
| 6.4. ТАЙМЕР/СЧЕТЧИК Т1                     |     |
| 6.4.1. Выбор источника тактового сигнала   | 192 |
| 6.4.2. Режим таймера                       |     |
| 6.4.2.1. Функция захвата (Capture)         | 193 |
| 6.4.2.2. Функция сравнения (Compare)       |     |
| 6.4.3. Режим ШИМ                           |     |
| 6.5. ТАЙМЕР/СЧЕТЧИК Т2                     |     |
| 6.5.1. Управление тактовым сигналом        |     |
| 6.5.2. Режим таймера                       |     |
| 6.5.3. Режим ШИМ                           |     |
| 6.5.4. Асинхронный режим работы            |     |
| 6.6. СТОРОЖЕВОЙ ТАЙМЕР                     | 208 |
| ГЛАВА 7. АНАЛОГОВЫЙ КОМПАРАТОР             |     |
| 7.1. ОБЩИЕ СВЕДЕНИЯ                        |     |
| 7.2. ФУНКЦИОНИРОВАНИЕ КОМПАРАТОРА          | 212 |
| ГЛАВА 8. АНАЛОГО-ЦИФРОВОЙ ПРЕОБРАЗОВАТЕЛЬ  | 215 |
| 8.1. ОБЩИЕ СВЕДЕНИЯ                        |     |
| 8.2. ФУНКЦИОНИРОВАНИЕ МОДУЛЯ АЦП           |     |
| 8.3. ПОВЫШЕНИЕ ТОЧНОСТИ ПРЕОБРАЗОВАНИЯ     |     |
| 8.4. ПАРАМЕТРЫ АЦП                         |     |
| ГЛАВА 9. УНИВЕРСАЛЬНЫЙ АСИНХРОННЫЙ         |     |
| ПРИЕМОПЕРЕДАТЧИК                           |     |
| 9.1. ОБЩИЕ СВЕДЕНИЯ                        |     |
| 9.2. УПРАВЛЕНИЕ РАБОТОЙ UART               |     |
| 9.3. ПЕРЕДАЧА ДАННЫХ                       |     |
| 9.4. ПРИЕМ ДАННЫХ                          |     |
| 9.5. МУЛЬТИПРОЦЕССОРНЫЙ РЕЖИМ РАБОТЫ UART  |     |
| 9.6. СКОРОСТЬ ПРИЕМА/ПЕРЕЛАЧИ              | 234 |

# СОДЕРЖАНИЕ——

| ГЛАВА 10. | ПОСЛЕДОВАТЕЛЬНЫЙ ПЕРИФЕРИЙНЫЙ                          |     |
|-----------|--------------------------------------------------------|-----|
|           | ИНТЕРФЕЙС SPI                                          | 237 |
|           | ЦИЕ СВЕДЕНИЯ                                           |     |
| 10.2. ФУ  | НКЦИОНИРОВАНИЕ МОДУЛЯ SPI                              | 238 |
|           | КИМЫ ПЕРЕДАЧИ ДАННЫХ                                   |     |
|           | ПОЛЬЗОВАНИЕ ВЫВОДА F65                                 |     |
| ГЛАВА 11. | ПРОГРАММИРОВАНИЕ МИКРОКОНТРОЛЛЕРОВ                     | 245 |
| 11.1. ОБІ | ЦИЕ СВЕДЕНИЯ                                           | 245 |
| 11.2. 3AL | ЦИТА КОДА И ДАННЫХ                                     | 246 |
|           | НФИГУРАЦИОННЫЕ ЯЧЕЙКИ                                  |     |
|           | ЕНТИФИКАТОР                                            |     |
| 11.5. PEX | КИМ ПАРАЛЛЕЛЬНОГО ПРОГРАММИРОВАНИЯ                     | 248 |
|           | Переключение в режим параллельного программирования    |     |
|           | Стирание кристалла                                     |     |
| 11.5.3.   | Программирование FLASH-памяти                          | 254 |
| 11.5.4.   | Программирование EEPROM-памяти                         | 256 |
| 11.5.5.   | Конфигурирование микроконтроллера                      | 256 |
| 11.6. PEX | КИМЫ ПОСЛЕДОВАТЕЛЬНОГО ПРОГРАММИРОВАНИЯ                | 258 |
| 11.6.1.   | Режим последовательного программирования при высоком   |     |
| напрях    | кении (модели AT90S/LS2323 и AT90S/LS2343)             | 258 |
| 11.6.2.   | Программирование по последовательному каналу           | 264 |
| ПРИЛОЖІ   | винз                                                   | 271 |
| Приложе   | ние I. Сводная таблица микроконтроллеров AVR           |     |
| семейств  | a Classic                                              | 272 |
| Приложе   | ние II. Чертежи корпусов микроконтроллеров AVR         |     |
| семейств  | a Classic                                              | 276 |
| Приложе   | ние III. Электрические параметры микроконтроллеров AVR |     |
|           | a Classic                                              | 279 |
| ПРЕДМЕТ   | НЫЙ УКАЗАТЕЛЬ                                          | 282 |

## ПРЕДИСЛОВИЕ

Российские специалисты, занимающиеся разработкой электронной аппаратуры, несомненно, знакомы с продукцией фирмы «Atmel». Основанная в 1984 г., фирма «Atmel Corp.» (США) на данный момент является одним из признанных лидеров в области производства широкого спектра микроэлектронных компонентов: микросхем энергонезависимой памяти, микроконтроллеров общего назначения и микросхем программируемой логики.

Начиная с середины 90-х годов, фирма «Atmel» начала активно развивать новое направление в своей деятельности — производство высокопроизводительных 8-разрядных RISC-микроконтроллеров для встраиваемых приложений, объединенных общим названием AVR. Книга, которую вы держите сейчас в руках, является первой из серии, посвященной этим микроконтроллерам.

За последние годы микроконтроллеры AVR приобрели большую популярность, привлекая разработчиков достаточно выгодным соотношением показателей «цена/быстродействие/энергопотребление», удобными режимами программирования, доступностью программино-аппаратных средств поддержки и широкой номенклатурой выпускаемых кристаллов. Микроконтроллеры этой серии представляют собой удобный инструмент для создания современных высокопроизводительных и экономичных встраиваемых контроллеров многоцелевого назначения. В частности, они используются в автомобильной электронике, бытовой технике, сетевых картах и материнских платах компьютеров, в мобильных телефонах нового поколения и т.д.

В рамках единой базовой архитектуры AVR-микроконтроллеры подразделяются на три семейства:

- Classic AVR базовая линия микроконтроллеров;
- Mega AVR микроконтроллеры для сложных приложений, требующих большого объема памяти программ и данных;
- $\bullet$  Tiny AVR низкостоимостные микроконтроллеры в 8-выводном исполнении.

Данная книга посвящена первому из них — семейству Classic. В составе этого семейства имеются микроконтроллеры с различным сочетанием периферийных узлов, различными объемами встроенной памяти и различным количеством выводов. Это дает разработчику возможность выбрать именно то, что ему нужно, и не переплачивать за неиспользуемые узлы. При этом все микроконтроллеры семейства поддерживают несколько режимов пониженного энергопотребления, имеют блок прерываний, сторожевой таймер и допускают программирование непосредственно в готовом устройстве через последовательный интерфейс SPI (к модели AT90C8534 последнее не относится).

В предлагаемой вашему вниманию книге представлена вся информация, необходимая для изучения микроконтроллеров AVR семейства Classic. Однако следует заметить, что справочником данная книга не является, хотя и написана на основе документации, предоставленной фирмой «Atmel». Поэтому, прежде чем приступить к практическому использованию рассматриваемых микроконтроллеров, настоятельно рекомендуется обратиться к официальной информации, расположенной на Web-сайтах фирмы (www.atmel.com, www.atmel.ru).

# Глава 1. Знакомство с семейством CLASSIC

#### 1.1. Общие сведения

Микроконтроллеры этого семейства (впрочем, как и все микроконтроллеры AVR фирмы «Atmel») являются 8-разрядными микроконтроллерами, предназначенными для встраиваемых приложений. Микроконтроллеры изготавливаются по малопотребляющей КМОП-технологии, которая в сочетании с усовершенствованной RISC-архитектурой позволяет достичь наилучшего соотношения показателей быстродействие/энергопотребление. Благодаря тому, что подавляющее большинство команд выполняется за один такт, быстродействие этих микроконтроллеров может достигать значения 1 MIPS (миллионов операций в секунду) на 1 МГц тактовой частоты. В семейство Classic входят микроконтроллеры с различным сочетанием периферийных устройств, различными объемами встроенной памяти и различным количеством выводов. Такое разнообразие дает разработчику возможность сделать оптимальный выбор и использовать именно тот микроконтроллер, который наилучшим образом подходит для его нужд.

#### 1.2. Отличительные особенности

Основные особенности микроконтроллеров данного семейства:

- возможность вычислений со скоростью до 1 MIPS/МГц;
- FLASH-память программ объемом от 1 до 8 Кбайт (число циклов стирания/записи не менее 1000);
- память данных на основе статического ОЗУ (SRAM) объемом до 512 байт;
- память данных на основе ЭСППЗУ (EEPROM) объемом от 64 до 512 байт (число циклов стирания/записи не менее 100000);

- возможность защиты от чтения и модификации памяти программ и данных (в EEPROM);
- программирование в параллельном (с использованием программатора) либо в последовательном (непосредственно в системе через последовательный SPI-интерфейс) режимах<sup>1</sup>;
- различные способы синхронизации: встроенный *RC*-генератор, внешний сигнал синхронизации или внешний резонатор (пьезокерамический или кварцевый)<sup>2</sup>;
- наличие нескольких режимов пониженного энергопотребления.

# 1.3. Характеристики ядра контроллера

Основными характеристиками центрального процессора микроконтроллеров рассматриваемого семейства являются:

- полностью статическая архитектура; минимальная тактовая частота равна нулю;
- АЛУ подключено непосредственно к регистрам общего назначения;
- большинство команд выполняется за один машинный цикл;
- многоуровневая система прерываний; поддержка очереди прерываний;
- от 3 до 16 источников прерываний<sup>3</sup> (из них до 2 внешних);
- наличие программного стека<sup>4</sup>.

# 1.4. Характеристики подсистемы ввода/вывода

Основными характеристиками подсистемы ввода/вывода являются:

- программное конфигурирование и выбор портов ввода/вывода;
- каждый вывод может быть запрограммирован как входной или как выходной независимо от других;
- входные буферы с триггером Шмитта на всех выводах;
- возможность подключения ко всем входам внутренних подтягивающих резисторов (сопротивление резисторов составляет 35...120 кОм);
- нагрузочная способность всех выходов составляет до 20 мА, что позволяет непосредственно управлять светодиодными индикаторами.

<sup>&</sup>lt;sup>1</sup> Кроме AT90C8534; эта модель допускает программирование только в параллельном режиме.

 $<sup>^{2}</sup>$  Зависит от конкретной модели микроконтроллера.

<sup>&</sup>lt;sup>3</sup> Зависит от конкретной модели микроконтроллера.

<sup>&</sup>lt;sup>4</sup> Кроме AT90S1200, в этой модели имеется 3-уровневый аппаратный стек.

## 1.5. Периферийные устройства

Микроконтроллеры семейства Classic обладают достаточно развитой периферией. Набор периферийных устройств, имеющихся в составе того или иного микроконтроллера, зависит от конкретной модели и может быть определен по сводной таблице **Приложения 1**. Перечислим все периферийные устройства, так или иначе встречающиеся в микроконтроллерах семейства:

- 8-разрядный таймер/счетчик с предделителем (таймер T0)<sup>1</sup>;
- 16-разрядный таймер/счетчик с предделителем (таймер Т1);
- 8-разрядный таймер/счетчик с возможностью работы в асинхронном режиме (таймер T2);
- сторожевой таймер (WDT)<sup>1</sup>;
- одно- или двухканальный 8...10-разрядный генератор сигнала с широтно-импульсной модуляцией (ШИМ)<sup>2</sup>;
- одноканальный 8-разрядный генератор сигнала с ШИМ<sup>3</sup>;
- аналоговый компаратор;
- 10-разрядный АЦП (6 или 8 каналов);
- полнодуплексный универсальный асинхронный приемопередатчик (UART);
- последовательный синхронный интерфейс SPI.

# 1.6. Архитектура ядра

Ядро микроконтроллеров AVR выполнено по усовершенствованной RISC (enhanced RISC) архитектуре (**Puc. 1.1**), в которой используется ряд решений, направленных на повышение быстродействия микроконтроллеров.

Арифметико-логическое устройство (АЛУ), выполняющее все вычисления, непосредственно подключено к 32 рабочим регистрам, объединенным в регистровый файл. Благодаря этому АЛУ выполняет одну операцию (чтение содержимого регистров, выполнение операции и запись результата обратно в регистровый файл) за один машинный цикл.

В микроконтроллерах AVR практически все команды (за исключением команд, у которых одним из операндов является 16-разрядный адрес) занимают одну ячейку памяти программ.

<sup>&</sup>lt;sup>1</sup> Присутствует во всех моделях.

<sup>&</sup>lt;sup>2</sup> Один из режимов работы таймера Т1.

<sup>&</sup>lt;sup>3</sup> Один из режимов работы таймера Т2.



Рис. 1.1. Архитектура ядра микроконтроллеров AVR

Микроконтроллеры AVR построены по Гарвардской архитектуре, которая характеризуется раздельной памятью программ и данных, каждая из которых имеет собственные шины доступа к ним. Такая организация позволяет одновременно работать как с памятью программ, так и с памятью данных. Разделение шин доступа (см. Рис. 1.1) позволяет использовать для каждого типа памяти шины данных различной разрядности, а также реализовать конвейеризацию. Конвейеризация заключается в том, что во время исполнения текущей команды производится выборка из памяти и дешифрация кода следующей команды.

В отличие от RISC-микроконтроллеров других фирм, в микроконтроллерах AVR используется 2-уровневый конвейер, а длительность машинного цикла составляет всего один период колебаний кварцевого резонатора. В результате они могут обеспечивать ту же производительность, что и RISC-микроконтроллеры других фирм, при более низкой тактовой частоте.

## 1.7. Цоколевка и описание выводов

В семейство Classic входит в общей сложности 17 моделей микроконтроллеров. Все они выпускаются в корпусах различных типов, что позволяет выбрать модель, наилучшим образом отвечающую требованиям по компоновке. Все модели микроконтроллеров можно условно разделить на 7 групп (модели, входящие в одну группу, имеют одинаковый набор периферийных устройств, но разные объемы памяти программ и данных):

- AT90S1200 (**Puc. 1.2**) имеет FLASH-память программ объемом 1 Кбайт и EEPROM-память данных объемом 64 байта. Количество контактов ввода/вывода равно 15;
- AT90S2313 (**Puc. 1.3**) имеет FLASH-память программ объемом 2 Кбайт, EEPROM-память данных объемом 128 байт и O3У объемом 128 байт. Количество контактов ввода/вывода равно 15;
- AT90S2323/AT90LS2323, AT90S2343/AT90LS2343 (**Puc. 1.4**) имеют FLASH-память программ объемом 2 Кбайт, EEPROM-память данных объемом 128 байт и O3У объемом 128 байт. Количество контактов ввода/вывода равно 3 (AT90xx2323) или 5 (AT90xx2343);
- AT90S2333/AT90LS2333, AT90S4433/AT90LS4433 (**Рис. 1.5**) имеют FLASH-память программ объемом 2 или 4 Кбайт, EEPROM-память данных объемом 128 или 256 байт и ОЗУ объемом 128 байт. Количество контактов ввода/вывода равно 20;
- AT90S4434/AT90LS4434, AT90S8535/AT90LS8535 (Рис. 1.6) имеют FLASH-память программ объемом 4 или 8 Кбайт, EEPROM-память данных объемом 256 или 512 байт и ОЗУ объемом 256 или 512 байт. Количество контактов ввода/вывода равно 32;
- AT90S4414, AT90S8515 (**Рис. 1.7**) имеют FLASH-память программ объемом 4 или 8 Кбайт, EEPROM-память данных объемом 256 или 512 байт и ОЗУ объемом 256 или 512 байт. Количество контактов ввода/вывода равно 32;
- AT90C8534 (**Puc. 1.8**) имеют FLASH-память программ объемом 8 Кбайт, EEPROM-память данных объемом 512 байт и O3У объемом 256 байт. Количество контактов ввода/вывода равно 15.

Для сравнения различных моделей вашему вниманию предлагается **Табл. 1.1**, в которой приводятся такие основные параметры микроконтроллеров, как объем памяти (программ и данных), количество контактов ввода/вывода, тип корпуса, диапазон рабочих частот и напряжение питания.

#### 1. Знакомство с семейством Classic

Полная информация по каждой модели приведена в **Приложении I**. Дополнительно следует отметить, что все микроконтроллеры семейства Classic выпускаются как в коммерческом (диапазон рабочих температур 0...+70°C), так и в промышленном (диапазон рабочих температур -40...+85°C) исполнениях.

Таблица 1.1. Основные параметры микроконтроллеров AVR семейства Classic

| Обозначение | Память программ (FLASH) | Память дан-<br>ных (ЕЕР-<br>ROM)<br>[байт] | Объем<br>ОЗУ<br>[байт] | Количество<br>контактов<br>ввода/<br>вывода | Напряжение<br>питания<br>[В] | Тактовая<br>частота<br>[МГц] | Тип<br>корпуса              |
|-------------|-------------------------|--------------------------------------------|------------------------|---------------------------------------------|------------------------------|------------------------------|-----------------------------|
|             | [Коаит]                 | . ,                                        | [оаит]                 |                                             |                              |                              | DIP-20, SOIC-20,            |
| AT90S1200   | 1                       | 64                                         | _                      | 15                                          | 2.76.0                       | 012                          | SSOP-20                     |
| AT90S2313   | 2                       | 128                                        | 128                    | 15                                          | 2.7 6.0                      | 010                          | DIP-20, SOIC-20             |
| AT90S2323   | 2                       | 128                                        | 128                    | 3                                           | 4.06.0                       | 010                          | DIP-8, SOIC-8               |
| AT90LS2323  | 2                       | 128                                        | 128                    | 3                                           | 2.76.0                       | 04                           | DIP-8, SOIC-8               |
| AT90S2343   | 2                       | 128                                        | 128                    | 5                                           | 4.06.0                       | 010                          | DIP-8, SOIC-8               |
| AT90LS2343  | 2                       | 128                                        | 128                    | 5                                           | 2.76.0                       | 04                           | DIP-8, SOIC-8               |
| AT90S2333   | 2                       | 128                                        | 128                    | 20                                          | 4.06.0                       | 08                           | DIP-28, TQFP-32             |
| AT90LS2333  | 2                       | 128                                        | 128                    | 20                                          | 2.76.0                       | 04                           | DIP-28, TQFP-32             |
| AT90S4433   | 4                       | 256                                        | 128                    | 20                                          | 4.06.0                       | 08                           | DIP-28, TQFP-32             |
| AT90LS4433  | 4                       | 256                                        | 128                    | 20                                          | 2.76.0                       | 04                           | DIP-28, TQFP-32             |
| AT90S4434   | 4                       | 256                                        | 256                    | 32                                          | 4.06.0                       | 08                           | DIP-40, PLCC-44,<br>TQFP-44 |
| AT90LS4434  | 4                       | 256                                        | 256                    | 32                                          | 2.76.0                       | 04                           | DIP-40, PLCC-44,<br>TQFP-44 |
| AT90S8535   | 8                       | 512                                        | 512                    | 32                                          | 4.06.0                       | 08                           | DIP-40, PLCC-44,<br>TQFP-44 |
| AT90LS8535  | 8                       | 512                                        | 512                    | 32                                          | 2.76.0                       | 04                           | DIP-40, PLCC-44,<br>TQFP-44 |
| AT90S4414   | 4                       | 256                                        | 256                    | 32                                          | 2.76.0                       | 08                           | DIP-40, PLCC-44,<br>TQFP-44 |
| AT90S8515   | 8                       | 512                                        | 512                    | 32                                          | 2.76.0                       | 08                           | DIP-40, PLCC-44,<br>TQFP-44 |
| AT90C8534   | 8                       | 512                                        | 256                    | 15                                          | 3.36.0                       | 01.5                         | VQFP-48                     |

В Табл. 1.2...1.8 для каждой группы микроконтроллеров приведены названия выводов и указаны их функции (как основные, так и дополнительные). Кроме того, для каждого вывода в таблицах указан его тип (вход, выход, вход/выход, вывод питания).

В таблицах использованы следующие обозначения:

I — вход:

O — выход;

I/O — вход/выход;

Р — выволы питания.

#### AT90S1200

| RESET        | 1  | 20 | b v <sub>cc</sub> |
|--------------|----|----|-------------------|
| PD0 □        | 2  |    | □ PB7 (SCK)       |
| PD1 🗆        | 3  | 18 | □ PB6 (MISO)      |
| XTAL2 □      | 4  | 17 | PB5 (MOSI)        |
| XTAL1 □      | 5  | 16 | □ PB4             |
| (INT0) PD2 □ | 6  | 15 | □ PB3             |
| PD3 🗆        | 7  | 14 | □ PB2             |
| (TO) PD4 □   | 8  | 13 | □ PB1 (AIN1)      |
| PD5 □        | 9  | 12 | □ PB0 (AIN0)      |
| GND □        | 10 | 11 | □ PD6             |

PDIP/SOIC/SSOP

Рис. 1.2. Расположение выводов модели AT90S1200

Таблица 1.2. Описание выводов модели AT90S1200

| Обозначение         | Номер<br>вывода | Тип<br>вывода | Описание                                                                                           |
|---------------------|-----------------|---------------|----------------------------------------------------------------------------------------------------|
| XTAL1               | 5               | I             | Вход инвертора генератора и вход внешнего тактового сигнала                                        |
| XTAL2               | 4               | 0             | Выход инвертора генератора                                                                         |
| RESET               | 1               | I             | Вход сброса. При удержании на входе НИЗКОГО уровня<br>в течение 50 нс выполняется сброс устройства |
| Порт В. 8-ра        | зрядный д       | вунаправле    | енный порт ввода/вывода с внутренними подтягивающими резисторами                                   |
| PB0 (AIN0)          | 12              | I/O           | В0 (Положительный вход компаратора)                                                                |
| PB1 (AIN1)          | 13              | I/O           | В1 (Отрицательный вход компаратора)                                                                |
| PB2                 | 14              | I/O           | B2                                                                                                 |
| PB3                 | 15              | I/O           | B3                                                                                                 |
| PB4                 | 16              | I/O           | B4                                                                                                 |
| PB5 (MOSI)          | 17              | I/O           | В5 (Вход данных при последовательном программировании (SPI))                                       |
| PB6 (MISO)          | 18              | I/O           | В6 (Выход данных при последовательном программировании (SPI))                                      |
| PB7 (SCK)           | 19              | I/O           | В7 (Вход тактового сигнала при последовательном программировании (SPI))                            |
| <b>Порт D.</b> 7-ра | зрядный д       | вунаправл     | енный порт ввода/вывода с внутренними подтягивающими резисторами                                   |
| PD0                 | 2               | I/O           | D0                                                                                                 |
| PD1                 | 3               | I/O           | D1                                                                                                 |
| PD2 (INT0)          | 6               | I/O           | D2 (Вход внешнего прерывания)                                                                      |
| PD3                 | 7               | I/O           | D3                                                                                                 |
| PD4 (T0)            | 8               | I/O           | D4 (Вход внешнего тактового сигнала таймера/счетчика T0)                                           |
| PD5                 | 9               | I/O           | D5                                                                                                 |
| PD6                 | 11              | I/O           | D6                                                                                                 |
| GND                 | 10              | P             | Общий вывод                                                                                        |
| $V_{CC}$            | 20              | P             | Вывод источника питания                                                                            |

# 

Рис. 1.3. Расположение выводов модели AT90S2313

Таблица 1.3. Описание выводов модели AT90S2313

| Обозначение         | Номер<br>вывода | Тип<br>вывода | Описание                                                                                        |
|---------------------|-----------------|---------------|-------------------------------------------------------------------------------------------------|
| XTAL1               | 5               | I             | Вход инвертора генератора и вход внешнего тактового сигнала                                     |
| XTAL2               | 4               | 0             | Выход инвертора генератора                                                                      |
| RESET               | 1               | I             | Вход сброса. При удержании на входе НИЗКОГО уровня в течение 50 нс выполняется сброс устройства |
| Порт В. 8-ра        | зрядный д       | вунаправл     | енный порт ввода/вывода с внутренними подтягивающими резисторами                                |
| PB0 (AIN0)          | 12              | I/O           | В0 (Положительный вход компаратора)                                                             |
| PB1 (AIN1)          | 13              | I/O           | В1 (Отрицательный вход компаратора)                                                             |
| PB2                 | 14              | I/O           | B2                                                                                              |
| PB3 (OC1)           | 15              | I/O           | ВЗ (Выход таймера/счетчика Т1 (режимы сравнения, ШИМ))                                          |
| PB4                 | 16              | I/O           | B4                                                                                              |
| PB5 (MOSI)          | 17              | I/O           | В5 (Вход данных при последовательном программировании (SPI))                                    |
| PB6 (MISO)          | 18              | I/O           | В6 (Выход данных при последовательном программировании (SPI))                                   |
| PB7 (SCK)           | 19              | I/O           | В7 (Вход тактового сигнала при последовательном программировании (SPI))                         |
| <b>Порт D.</b> 7-ра | азрядный д      | вунаправл     | енный порт ввода/вывода с внутренними подтягивающими резисторами                                |
| PD0 (RXD)           | 2               | I/O           | D0 (Вход UART)                                                                                  |
| PD1 (TXD)           | 3               | I/O           | D1 (Выход UART)                                                                                 |
| PD2 (INT0)          | 6               | I/O           | D2 Вход внешнего прерывания                                                                     |
| PD3 (INT1)          | 7               | I/O           | D3 (Вход внешнего прерывания)                                                                   |
| PD4 (T0)            | 8               | I/O           | D4 (Вход внешнего тактового сигнала таймера/счетчика T0)                                        |
| PD5 (T1)            | 9               | I/O           | D5 (Вход внешнего тактового сигнала таймера/счетчика T1)                                        |
| PD6 (ICP)           | 11              | I/O           | D6 (Вход захвата таймера/счетчика T1 (режим захвата))                                           |
| GND                 | 10              | P             | Общий вывод                                                                                     |
| $V_{CC}$            | 20              | P             | Вывод источника питания                                                                         |



Puc. 1.4. Расположение выводов моделей AT90S/LS2323 и AT90S/LS2343

Таблица 1.4. Описание выводов моделей AT90S/LS2323

| Обозначение        | Номер<br>вывода | Тип<br>вывода | Описание                                                                                                                     |  |  |
|--------------------|-----------------|---------------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| XTAL1              | 2               | I             | Вход инвертора генератора и вход внешнего тактового сигнала                                                                  |  |  |
| XTAL2              | 3               | 0             | Выход инвертора генератора                                                                                                   |  |  |
| RESET              | 1               | I             | ход сброса. При удержании на входе НИЗКОГО уровня в течение 50 нс<br>ыполняется сброс устройства                             |  |  |
| Порт В. 3-ра       | зрядный ,       | двунапран     | вленный порт ввода/вывода с внутренними подтягивающими резисторами                                                           |  |  |
| PB0 (MOSI)         | 5               | I/O           | В0 (Вход данных при последовательном программировании (SPI))                                                                 |  |  |
| PB1<br>(MISO/INT0) | 6               | I/O           | В1 (Выход данных при последовательном программировании (SPI);<br>вход внешнего прерывания)                                   |  |  |
| PB2<br>(SCK/T0)    | 7               | I/O           | В2 (Вход тактового сигнала при последовательном программировании (SPI); вход внешнего тактового сигнала таймера/счетчика Т0) |  |  |
| GND                | 4               | P             | Общий вывод                                                                                                                  |  |  |
| $V_{CC}$           | 8               | P             | Вывод источника питания                                                                                                      |  |  |

Таблица 1.5. Описание выводов моделей AT90S/LS2343

| Обозначение         | Номер<br>вывода | Тип<br>вывода | Описание                                                                                                                     |  |
|---------------------|-----------------|---------------|------------------------------------------------------------------------------------------------------------------------------|--|
| RESET               | 1               | I             | Вход сброса. При удержании на входе НИЗКОГО уровня в течение 50 нс выполняется сброс устройства                              |  |
| <b>Порт В.</b> 5-ра | зрядный ,       | двунаправ     | вленный порт ввода/вывода с внутренними подтягивающими резисторами                                                           |  |
| PB0 (MOSI)          | 5               | I/O           | В0 (Вход данных при последовательном программировании (SPI))                                                                 |  |
| PB1<br>(MISO/INT0)  | 6               | I/O           | В1 (Выход данных при последовательном программировании (SPI); вход внешнего прерывания)                                      |  |
| PB2<br>(SCK/T0)     | 7               | I/O           | В2 (Вход тактового сигнала при последовательном программировании (SPI); вход внешнего тактового сигнала таймера/счетчика T0) |  |
| PB3 (CLOCK)         | 2               | I/O           | ВЗ (Вход внешнего тактового сигнала)                                                                                         |  |
| PB4                 | 3               | I/O           | В4 (Вход тактового сигнала при последовательном программировании (SPI); вход внешнего тактового сигнала таймера/счетчика T0) |  |
| GND                 | 4               | P             | Общий вывод                                                                                                                  |  |
| V <sub>CC</sub>     | 8               | P             | Вывод источника питания                                                                                                      |  |



Puc. 1.5. Расположение выводов моделей AT90S/LS2333 и AT90S/LS4433

Таблица 1.6. Описание выводов моделей AT90S/LS2333 и AT90S/LS4433

| Обозначение  | Номер вывода |          | Тип      | Описание                                                                                        |
|--------------|--------------|----------|----------|-------------------------------------------------------------------------------------------------|
| Ооозпачение  | DIP          | TQFP     | вывода   | Olincanne                                                                                       |
| XTAL1        | 9            | 7        | I        | Вход инвертора генератора и вход внешнего тактового сигнала                                     |
| XTAL2        | 10           | 8        | 0        | Выход инвертора генератора                                                                      |
| RESET        | 1            | 29       | I        | Вход сброса. При удержании на входе НИЗКОГО уровня в течение 50 нс выполняется сброс устройства |
| Порт В. 6-ра | ізрядныі     | й двунап | равленні | ый порт ввода/вывода с внутренними подтягивающими резисторами                                   |
| PB0 (ICP)    | 14           | 12       | I/O      | В0 (Вход захвата таймера/счетчика Т1 (режим захвата))                                           |
| PB1 (OC1)    | 15           | 13       | I/O      | В1 (Выход таймера/счетчика Т1 (режимы сравнения, ШИМ))                                          |
| PB2 (SS)     | 16           | 14       | I/O      | В2 (Выбор Slave-устройства на шине SPI)                                                         |
| PB3 (MOSI)   | 17           | 15       | I/O      | ВЗ (Выход (Master) или вход (Slave) данных модуля SPI)                                          |
| PB4 (MISO)   | 18           | 16       | I/O      | В4 (Вход (Master) или выход (Slave) данных модуля SPI)                                          |
| PB5 (SCK)    | 19           | 17       | I/O      | В5 (Выход (Master) или вход (Slave) тактового сигнала модуля SPI)                               |

#### 1. Знакомство с семейством Classic

Таблица 1.6 (окончание)

| 05                                                                                           | Номер   | вывода   | Тип      | 0                                                              |  |  |  |
|----------------------------------------------------------------------------------------------|---------|----------|----------|----------------------------------------------------------------|--|--|--|
| Обозначение                                                                                  | DIP     | TQFP     | вывода   | Описание                                                       |  |  |  |
| Порт С. 6-разрядный двунаправленный порт ввода/вывода с внутренними подтягивающими резистора |         |          |          |                                                                |  |  |  |
| PC0 (ADC0)                                                                                   | 23      | 23       | I/O      | С0 (Вход 0 АЦП; отключаемый входной буфер)                     |  |  |  |
| PC1 (ADC1)                                                                                   | 24      | 24       | I/O      | С1 (Вход 1 АЦП; отключаемый входной буфер)                     |  |  |  |
| PC2 (ADC2)                                                                                   | 25      | 25       | I/O      | С2 (Вход 2 АЦП; отключаемый входной буфер)                     |  |  |  |
| PC3 (ADC3)                                                                                   | 26      | 26       | I/O      | СЗ (Вход З АЦП; отключаемый входной буфер)                     |  |  |  |
| PC4 (ADC4)                                                                                   | 27      | 27       | I/O      | С4 (Вход 4 АЦП; отключаемый входной буфер)                     |  |  |  |
| PC5 (ADC5)                                                                                   | 28      | 28       | I/O      | С5 (Вход 5 АЦП; отключаемый входной буфер)                     |  |  |  |
| <b>Порт D.</b> 8-ра                                                                          | зрядныі | і двунап | равленні | ый порт ввода/вывода с внутренними подтягивающими резисторами  |  |  |  |
| PD0 (RXD)                                                                                    | 2       | 30       | I/O      | D0 (Вход UART)                                                 |  |  |  |
| PD1 (TXD)                                                                                    | 3       | 31       | I/O      | D1 (Выход UART)                                                |  |  |  |
| PD2 (INT0)                                                                                   | 4       | 32       | I/O      | D2 (Вход 0 внешнего прерывания)                                |  |  |  |
| PD3 (INT1)                                                                                   | 5       | 1        | I/O      | D3 (Вход 1 внешнего прерывания)                                |  |  |  |
| PD4 (T0)                                                                                     | 6       | 2        | I/O      | D4 (Вход внешнего тактового сигнала таймера/счетчика T0)       |  |  |  |
| PD5 (T1)                                                                                     | 11      | 9        | I/O      | D5 (Вход внешнего тактового сигнала таймера/счетчика T1)       |  |  |  |
| PD6 (AIN0)                                                                                   | 12      | 10       | I/O      | D6 (Положительный вход компаратора; отключаемый входной буфер) |  |  |  |
| PD7 (AIN1)                                                                                   | 13      | 11       | I/O      | D7 (Отрицательный вход компаратора; отключаемый входной буфер) |  |  |  |
| AREF                                                                                         | 21      | 20       | P        | Вход опорного напряжения для АЦП                               |  |  |  |
| AGND                                                                                         | 22      | 21       | P        | Общий вывод (аналоговый)                                       |  |  |  |
| $AV_{CC}$                                                                                    | 20      | 18       | P        | Вывод источника питания АЦП                                    |  |  |  |
| GND                                                                                          | 8       | 5        | P        | Общий вывод                                                    |  |  |  |
| $V_{CC}$                                                                                     | 7       | 4        | P        | Вывод источника питания                                        |  |  |  |

#### AT90S44334/AT90LS4434 AT90S8535/AT90LS8535





Puc. 1.6. Расположение выводов моделей AT90S/LS4434 и AT90S/LS8535

*Таблица 1.7.* Описание выводов моделей AT90S/LS4434 и AT90S/LS8535

| Обозначение Номер                                                                              |                    | мер выв  | ер вывода |         | Ormonius                                                                                           |
|------------------------------------------------------------------------------------------------|--------------------|----------|-----------|---------|----------------------------------------------------------------------------------------------------|
| Ооозначение                                                                                    | DIP PLCC TQFP Bыво | вывода   | Описание  |         |                                                                                                    |
| XTAL1                                                                                          | 13                 | 14       | 8         | I       | Вход инвертора генератора и вход внешнего тактового сигнала                                        |
| XTAL2                                                                                          | 12                 | 13       | 7         | 0       | Выход инвертора генератора                                                                         |
| RESET                                                                                          | 1                  | 10       | 4         | I       | Вход сброса. При удержании на входе НИЗКОГО уровня<br>в течение 50 нс выполняется сброс устройства |
| Порт А. 8-ра                                                                                   | зрядны             | й двунаі | правлен   | ный пор | г ввода/вывода с внутренними подтягивающими резисторами                                            |
| PA0 (ADC0)                                                                                     | 40                 | 43       | 37        | I/O     | А0 (Вход 0 АЦП; отключаемый входной буфер)                                                         |
| PA1 (ADC1)                                                                                     | 39                 | 42       | 36        | I/O     | А1 (Вход 1 АЦП; отключаемый входной буфер)                                                         |
| PA2 (ADC2)                                                                                     | 38                 | 41       | 35        | I/O     | А2 (Вход 2 АЦП; отключаемый входной буфер)                                                         |
| PA3 (ADC3)                                                                                     | 37                 | 40       | 34        | I/O     | АЗ (Вход З АЦП; отключаемый входной буфер)                                                         |
| PA4 (ADC4)                                                                                     | 36                 | 39       | 33        | I/O     | А4 (Вход 4 АЦП; отключаемый входной буфер)                                                         |
| PA5 (ADC5)                                                                                     | 35                 | 38       | 32        | I/O     | А5 (Вход 5 АЦП; отключаемый входной буфер)                                                         |
| PA6 (ADC6)                                                                                     | 34                 | 37       | 31        | I/O     | Аб (Вход 6 АЦП; отключаемый входной буфер)                                                         |
| PA7 (ADC7)                                                                                     | 33                 | 36       | 30        | I/O     | А7 (Вход 7 АЦП; отключаемый входной буфер)                                                         |
| Порт В. 8-разрядный двунаправленный порт ввода/вывода с внутренними подтягивающими резисторами |                    |          |           |         |                                                                                                    |
| PB0 (T0)                                                                                       | 1                  | 2        | 40        | I/O     | ВО (Вход внешнего тактового сигнала таймера/счетчика ТО)                                           |
| PB1 (T1)                                                                                       | 2                  | 3        | 41        | I/O     | В1 (Вход внешнего тактового сигнала таймера/счетчика Т1)                                           |
| PB2 (AIN0)                                                                                     | 3                  | 4        | 42        | I/O     | В2 (Положительный вход компаратора; отключаемый входной буфер)                                     |
| PB3 (AIN1)                                                                                     | 4                  | 5        | 43        | I/O     | ВЗ (Отрицательный вход компаратора; отключаемый<br>входной буфер)                                  |
| PB4 (SS)                                                                                       | 5                  | 6        | 44        | I/O     | В4 (Выбор Slave-устройства на шине SPI)                                                            |
| PB5 (MOSI)                                                                                     | 6                  | 7        | 1         | I/O     | В5 (Выход (Master) или вход (Slave) данных модуля SPI)                                             |
| PB6 (MISO)                                                                                     | 7                  | 8        | 2         | I/O     | В6 (Вход (Master) или выход (Slave) данных модуля SPI)                                             |
| PB7 (SCK)                                                                                      | 8                  | 9        | 3         | I/O     | B7 (Выход (Master) или вход (Slave) тактового сигнала модуля SPI)                                  |
| Порт С. 8-разрядный двунаправленный порт ввода/вывода с внутренними подтягивающими резисторами |                    |          |           |         |                                                                                                    |
| PC0                                                                                            | 22                 | 25       | 19        | I/O     | C0                                                                                                 |
| PC1                                                                                            | 23                 | 26       | 20        | I/O     | Cl                                                                                                 |
| PC2                                                                                            | 24                 | 27       | 21        | I/O     | C2                                                                                                 |
| PC3                                                                                            | 25                 | 28       | 22        | I/O     | C3                                                                                                 |
| PC4                                                                                            | 26                 | 29       | 23        | I/O     | C4                                                                                                 |
| PC5                                                                                            | 27                 | 30       | 24        | I/O     | C5                                                                                                 |
| PC6 (TOSC1)                                                                                    | 28                 | 31       | 25        | I/O     | С6 (Вход для подключения резонатора к таймеру/счетчику Т2)                                         |
| PC7 (TOSC2)                                                                                    | 29                 | 32       | 26        | I/O     | С7 (Выход для подключения резонатора к таймеру/счетчику Т2)                                        |

#### 1. Знакомство с семейством Classic

Таблица 1.7 (окончание)

| Обозначение  |         | Іомер выво | да        | Тип       | Описание                                                 |
|--------------|---------|------------|-----------|-----------|----------------------------------------------------------|
| Ооозначение  | DIP     | PLCC       | TQFP      | вывода    | Описание                                                 |
| Порт D. 8-ра | зрядный | двунапра   | вленный і | порт ввод | да/вывода с внутренними подтягивающими резисторами       |
| PD0 (RXD)    | 14      | 15         | 9         | I/O       | D0 (Bxoд UART)                                           |
| PD1 (TXD)    | 15      | 16         | 10        | I/O       | D1 (Выход UART)                                          |
| PD2 (INT0)   | 16      | 17         | 11        | I/O       | D2 (Вход внешнего прерывания)                            |
| PD3 (INT1)   | 17      | 18         | 12        | I/O       | D3 (Вход внешнего прерывания)                            |
| PD4 (OC1B)   | 18      | 19         | 13        | I/O       | D4 (Выход В таймера/счетчика T1 (режимы сравнения, ШИМ)) |
| PD5 (OC1A)   | 19      | 20         | 14        | I/O       | D5 (Выход А таймера/счетчика Т1 (режимы сравнения, ШИМ)) |
| PD6 (ICP)    | 20      | 21         | 15        | I/O       | D6 (Вход захвата таймера/счетчика Т1 (режим захвата))    |
| PD7 (OC2)    | 21      | 22         | 16        | I/O       | D7 (Выход таймера/счетчика Т2 (режимы сравнения, ШИМ))   |
| AREF         | 32      | 35         | 29        | P         | Вход опорного напряжения для АЦП                         |
| AGND         | 31      | 34         | 28        | P         | Общий вывод (аналоговый)                                 |
| $AV_{CC}$    | 30      | 33         | 27        | P         | Вывод источника питания АЦП                              |
| GND          | 11      | 1, 12, 24  | 6, 18, 39 | P         | Общий вывод                                              |
| $V_{CC}$     | 10      | 11, 23, 44 | 5, 17, 38 | P         | Вывод источника питания                                  |

Таблица 1.8. Описание выводов моделей AT90S4414 и AT90S8515

| Обозначение                                                                                    | Н   | Гомер выво | да   | Тип<br>вывода | Описание                                                                                        |  |  |
|------------------------------------------------------------------------------------------------|-----|------------|------|---------------|-------------------------------------------------------------------------------------------------|--|--|
|                                                                                                | DIP | PLCC       | TQFP |               |                                                                                                 |  |  |
| XTAL1                                                                                          | 19  | 21         | 15   | I             | Вход инвертора генератора и вход внешнего тактового сигнала                                     |  |  |
| XTAL2                                                                                          | 18  | 20         | 14   | 0             | Выход инвертора генератора                                                                      |  |  |
| RESET                                                                                          | 9   | 10         | 4    | I             | Вход сброса. При удержании на входе НИЗКОГО уровня в течение 50 нс выполняется сброс устройства |  |  |
| Порт А. 8-разрядный двунаправленный порт ввода/вывода с внутренними подтягивающими резисторами |     |            |      |               |                                                                                                 |  |  |
| PA0 (AD0)                                                                                      | 39  | 43         | 37   | I/O           | А0 (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |
| PA1 (AD1)                                                                                      | 38  | 42         | 36   | I/O           | А1 (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |
| PA2 (AD2)                                                                                      | 37  | 41         | 35   | I/O           | А2 (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |
| PA3 (AD3)                                                                                      | 36  | 40         | 34   | I/O           | АЗ (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |
| PA4 (AD4)                                                                                      | 35  | 39         | 33   | I/O           | А4 (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |
| PA5 (AD5)                                                                                      | 34  | 38         | 32   | I/O           | А5 (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |
| PA6 (AD6)                                                                                      | 33  | 37         | 31   | I/O           | Аб (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |
| PA7 (AD7)                                                                                      | 32  | 36         | 30   | I/O           | А7 (Мультиплексная ША/ШД для внешнего ОЗУ)                                                      |  |  |

#### AT90S4414/AT90S8515





Puc. 1.7. Расположение выводов моделей AT90S4414 и AT90S8515

#### 1. Знакомство с семейством Classic

Таблица 1.8 (окончание)

| Обозначение Номер вывода |                                                                                                | Тип              | 0                |           |                                                                   |  |
|--------------------------|------------------------------------------------------------------------------------------------|------------------|------------------|-----------|-------------------------------------------------------------------|--|
| Ооозначение              | DIP                                                                                            | PLCC             | TQFP             | вывода    | Описание                                                          |  |
| Порт В. 8-ра             | Порт В. 8-разрядный двунаправленный порт ввода/вывода с внутренними подтягивающими резисторами |                  |                  |           |                                                                   |  |
| PB0 (T0)                 | 1                                                                                              | 2                | 40               | I/O       | ВО (Вход внешнего тактового сигнала таймера/счетчика ТО)          |  |
| PB1 (T1)                 | 2                                                                                              | 3                | 41               | I/O       | В1 (Вход внешнего тактового сигнала таймера/счетчика Т1)          |  |
| PB2 (AIN0)               | 3                                                                                              | 4                | 42               | I/O       | В2 (Положительный вход компаратора)                               |  |
| PB3 (AIN1)               | 4                                                                                              | 5                | 43               | I/O       | ВЗ (Отрицательный вывод компаратора)                              |  |
| PB4 (SS)                 | 5                                                                                              | 6                | 44               | I/O       | В4 (Выбор Slave-устройства на шине SPI)                           |  |
| PB5 (MOSI)               | 6                                                                                              | 7                | 1                | I/O       | В5 (Выход (Master) или вход (Slave) данных модуля SPI)            |  |
| PB6 (MISO)               | 7                                                                                              | 8                | 2                | I/O       | В6 (Вход (Master) или выход (Slave) данных модуля SPI)            |  |
| PB7 (SCK)                | 8                                                                                              | 9                | 3                | I/O       | В7 (Выход (Master) или вход (Slave) тактового сигнала модуля SPI) |  |
| Порт С. 8-ра             | зрядный                                                                                        | і двунапр        | завленни         | ый порт в | вода/вывода с внутренними подтягивающими резисторами              |  |
| PC0 (A8)                 | 21                                                                                             | 24               | 18               | I/O       | С0 (ША для внешнего ОЗУ)                                          |  |
| PC1 (A9)                 | 22                                                                                             | 25               | 19               | I/O       | С1 (ША для внешнего ОЗУ)                                          |  |
| PC2 (A10)                | 23                                                                                             | 26               | 20               | I/O       | С2 (ША для внешнего ОЗУ)                                          |  |
| PC3 (A11)                | 24                                                                                             | 27               | 21               | I/O       | СЗ (ША для внешнего ОЗУ)                                          |  |
| PC4 (A12)                | 25                                                                                             | 28               | 22               | I/O       | С4 (ША для внешнего ОЗУ)                                          |  |
| PC5 (A13)                | 26                                                                                             | 29               | 23               | I/O       | С5 (ША для внешнего ОЗУ)                                          |  |
| PC6 (A14)                | 27                                                                                             | 30               | 24               | I/O       | С6 (ША для внешнего ОЗУ)                                          |  |
| PC7 (A15)                | 28                                                                                             | 31               | 25               | I/O       | С7 (ША для внешнего ОЗУ)                                          |  |
| <b>Порт D.</b> 8-ра      | зрядный                                                                                        | і двунапр        | равленні         | ый порт в | вода/вывода с внутренними подтягивающими резисторами              |  |
| PD0 (RXD)                | 10                                                                                             | 11               | 5                | I/O       | D0 (Вход UART)                                                    |  |
| PD1 (TXD)                | 11                                                                                             | 13               | 7                | I/O       | D1 (Выход UART)                                                   |  |
| PD2 (INT0)               | 12                                                                                             | 14               | 8                | I/O       | D2 (Вход 0 внешнего прерывания)                                   |  |
| PD3 (INT1)               | 13                                                                                             | 15               | 9                | I/O       | D3 (Вход 1 внешнего прерывания)                                   |  |
| PD4                      | 14                                                                                             | 16               | 10               | I/O       | D4                                                                |  |
| PD5 (OC1A)               | 15                                                                                             | 17               | 11               | I/O       | D5 (Выход А таймера/счетчика Т1 (режимы сравнения, ШИМ))          |  |
| PD6 (WR)                 | 16                                                                                             | 18               | 12               | I/O       | D6 (Строб записи во внешнее ОЗУ)                                  |  |
| PD7 (RD)                 | 17                                                                                             | 19               | 13               | I/O       | D7 (Строб чтения во внешнее ОЗУ)                                  |  |
| OC1B                     | 32                                                                                             | 32               | 26               | 0         | Выход В таймера/счетчика Т1 (режимы сравнения, ШИМ)               |  |
| ICP                      | 31                                                                                             | 35               | 29               | I         | Вход захвата таймера/счетчика Т1 (режим захвата)                  |  |
| ALE                      | 30                                                                                             | 33               | 27               | 0         | Строб адреса внешнего ОЗУ                                         |  |
| GND                      | 20                                                                                             | 22               | 16               | P         | Общий вывод                                                       |  |
| $V_{CC}$                 | 40                                                                                             | 44               | 38               | P         | Вывод источника питания                                           |  |
| NC                       | -                                                                                              | 1, 12,<br>23, 34 | 6, 17,<br>28, 39 | _         | Не используются                                                   |  |

#### AT90C8534 Ключ ADIN0 36 NC NC I 35 INT0 NC E 34 INT1 33 PA6 NC E NC р ис NC GND NC NC I NC E 29 NC NC E 28 NC NC 10 27 D NC 26 NC 25 NC AGND [11 NC E ADIN1 I ADIN2 I ADIN3 I ADIN4 I

Рис. 1.8. Расположение выводов модели АТ90С8534

VQFP-48

Таблица 1.9. Описание выводов модели АТ90С8534

| Обозначение | Номер<br>вывода     | Тип<br>вывода | Описание                                                                                        |
|-------------|---------------------|---------------|-------------------------------------------------------------------------------------------------|
| XTAL1       | <b>вывода</b><br>24 | вывода<br>I   | Вход инвертора генератора и вход внешнего тактового сигнала                                     |
| XTAL1       | 23                  | 0             | Выход инвертора генератора                                                                      |
| ATAL2       | 23                  | 0             |                                                                                                 |
| RESET       | 20                  | I             | Вход сброса. При удержании на входе НИЗКОГО уровня в течение 50 нс выполняется сброс устройства |
|             |                     | Порт А. 7-ра  | зрядный однонаправленный порт вывода                                                            |
| PA0         | 47                  | 0             | A0                                                                                              |
| PA1         | 46                  | 0             | A1                                                                                              |
| PA2         | 45                  | 0             | A2                                                                                              |
| PA3         | 44                  | 0             | A3                                                                                              |
| PA4         | 39                  | 0             | A4                                                                                              |
| PA5         | 38                  | 0             | A5                                                                                              |
| PA6         | 33                  | 0             | A6                                                                                              |
| ADIN0       | 1                   | I             | Вход 0 АЦП                                                                                      |
| ADIN1       | 13                  | I             | Вход 1 АЦП                                                                                      |
| ADIN2       | 14                  | I             | Вход 2 АЦП                                                                                      |
| ADIN3       | 15                  | I             | Вход 3 АЦП                                                                                      |
| ADIN4       | 16                  | I             | Вход 4 АЦП                                                                                      |
| ADIN5       | 17                  | I             | Вход 5 АЦП                                                                                      |

#### 1. Знакомство с семейством Classic

Таблица 1.9 (окончание)

| Обозначение | Номер<br>вывода                                  | Тип<br>вывода | Описание                         |
|-------------|--------------------------------------------------|---------------|----------------------------------|
| INT0        | 35                                               | I             | Вход 0 внешнего прерывания       |
| INT1        | 34                                               | I             | Вход 1 внешнего прерывания       |
| PEN         | 21                                               | I             | Вход разрешения программирования |
| AGND        | 11                                               | P             | Общий вывод (аналоговый)         |
| $AV_{CC}$   | 18                                               | P             | Вывод источника питания АЦП      |
| GND         | 31                                               | P             | Общий вывод                      |
| $V_{CC}$    | 22                                               | P             | Вывод источника питания          |
| NC          | 210, 12,<br>19, 2530,<br>31, 36, 37,<br>4043, 48 | _             | Не используются                  |

# Глава 2. **Архитектура микроконтроллеров семейства CLASSIC**

#### 2.1. Общие сведения

Микроконтроллеры AVR семейства Classic являются 8-разрядными микроконтроллерами с RISC-архитектурой. Они имеют электрически стираемую память программ (FLASH) и данных (EEPROM), а также разнообразные периферийные устройства. Состав этих устройств меняется от модели к модели, более того, одно и то же устройство в разных моделях использует различные ресурсы микроконтроллера (в частности, различные выводы). Разумеется, существует ряд периферийных устройств, присутствующих во всех микроконтроллерах семейства: сторожевой таймер, 8-разрядный таймер/счетчик реального времени (таймер Т0) и, естественно, порты ввода/вывода.

Структурная схема микроконтроллера AT90S1200 приведена на **Рис. 2.1**. Его отличительные особенности:

- 2 порта ввода/вывода: В (8-разрядный) и D (7-разрядный);
- 3-уровневый аппаратный стек;
- встроенный тактовый *RC*-генератор;
- аналоговый компаратор;
- возможность подключения внешнего кварцевого резонатора.

Структурная схема микроконтроллера AT90S2313 приведена на **Рис. 2.2**. Его отличительные особенности:

- 2 порта ввода/вывода: В (8-разрядный) и D (7-разрядный);
- встроенный тактовый кварцевый генератор;
- 16-разрядный таймер/счетчик (таймер Т1);
- аналоговый компаратор;
- универсальный асинхронный приемопередатчик UART.



Puc. 2.1. Структурная схема микроконтроллера AT90S1200



Puc. 2.2. Структурная схема микроконтроллера AT90S2313

Структурная схема микроконтроллеров AT90S2323/AT90LS2323, AT90S2343/AT90LS2343 приведена на **Рис. 2.3**. Их отличительные особенности:

- 1 порт ввода/вывода: 3-разрядный для AT90S/LS2323 и 5-разрядный для AT90S/LS2343;
- встроенный тактовый кварцевый генератор (AT90S/LS2323);
- встроенный тактовый *RC*-генератор (AT90S/LS2343).

Структурная схема микроконтроллеров AT90S2333/AT90LS2333, AT90S4433/AT90LS4433 приведена на **Рис. 2.4**. Их отличительные особенности:

- 3 порта ввода/вывода: порт В (6-разрядный), порт С (6-разрядный) и порт D (8-разрядный);
- встроенный тактовый кварцевый генератор;
- 16-разрядный таймер/счетчик (таймер Т1);
- аналоговый компаратор;
- 6-канальный АЦП;
- SPI-интерфейс;
- UART.

Структурная схема микроконтроллеров AT90S4434/AT90LS4434, AT90S8535/AT90LS8535 приведена на **Puc. 2.5**. Их отличительные особенности:

- 4 порта ввода/вывода: порт A (8-разрядный), порт B (8-разрядный), порт С (8-разрядный) и порт D (8-разрядный);
- встроенный тактовый кварцевый генератор;
- 16-разрядный таймер/счетчик (таймер Т1);
- 8-разрядный таймер/счетчик реального времени (таймер Т2)
- аналоговый компаратор;
- 8-канальный АЦП;
- SPI-интерфейс;
- UART.

Структурная схема микроконтроллеров AT90S4414 и AT90S8515 приведена на **Рис. 2.6**. Их отличительные особенности:

- 4 порта ввода/вывода: порт A (8-разрядный), порт B (8-разрядный), порт С (8-разрядный) и порт D (8-разрядный);
- встроенный тактовый кварцевый генератор;
- 16-разрядный таймер/счетчик (таймер Т1);
- аналоговый компаратор;
- SPI-интерфейс;
- UART.



*Puc. 2.3.* Структурная схема микроконтроллеров AT90S2323/AT90LS2323, AT90S2343/AT90LS2343



Puc. 2.4. Структурная схема микроконтроллеров AT90S2333/AT90LS2333, AT90S4433/AT90LS4433



Puc. 2.5. Структурная схема микроконтроллеров AT90S4434/AT90LS4434, AT90S8535/AT90LS8535



Рис. 2.6. Структурная схема микроконтроллеров AT90S4414 и AT90S8515

Структурная схема микроконтроллера AT90C8534 приведена на **Рис. 2.7**. В отличие от других микроконтроллеров семейства в AT90C8534 имеются один цифровой выходной порт и один аналоговый входной порт. Благодаря такой структуре данный микроконтроллер удобно использовать в интеллектуальных зарядных устройствах. Его отличительные особенности:



Рис. 2.7. Структурная схема микроконтроллера АТ90С8534

- 1 порт вывода: порт А (7-разрядный);
- 2 входа для внешних прерываний;
- встроенный тактовый кварцевый генератор;
- 16-разрядный таймер/счетчик (таймер Т1);
- 6-канальный АЦП.

# 2.2. Организация памяти

Организация памяти микроконтроллеров AVR семейства Classic выполнена по Гарвардской архитектуре, в которой разделены не только адресные пространства памяти программ и памяти данных, но также и шины доступа к ним. Причем память данных состоит из трех областей: регистровая память, статическое ОЗУ и память на основе EEPROM. В связи с тем, что регистровая память находится в адресном пространстве ОЗУ, об этих двух областях памяти обычно говорят как об одной. Каждая из областей (ОЗУ и EEPROM) расположена в своем адресном пространстве.

Заметим, что модель AT90S1200 не имеет внутреннего ОЗУ (хотя регистровая память, естественно, присутствует). Также несколько особняком стоят микроконтроллеры AT90S4414 и AT90S8515, которые имеют возможность подключения внешнего ОЗУ.

Обобщенная карта памяти микроконтроллеров AVR семейства Classic приведена на **Рис. 2.8**.

Следует заметить, что:

- 1) поскольку микроконтроллеры AVR имеют 16-разрядную систему команд, объем памяти программ на рисунке указан не в байтах, а в 16-разрядных словах;
- 2) символ «\$» перед числом означает, что это число записано в шестнадцатеричной системе счисления.

#### 2.2.1. Память программ

Память программ предназначена для хранения команд, управляющих функционированием микроконтроллера. В памяти программ хранятся также различные константы, не меняющиеся во время работы программы. Память программ в микроконтроллерах семейства Classic представляет собой электрически стираемое ППЗУ (FLASH-ПЗУ). Поскольку все команды занимают в памяти 16 бит (некоторые — 32 бита), память программ имеет 16-разрядную организацию. Соответственно, объем памяти составляет от 512 16-разрядных слов для модели АТ90S1200 до 4096 слов для старших моделей.



Puc. 2.8. Карта памяти микроконтроллеров AVR семейства Classic

Для адресации памяти программ используется счетчик команд (PC — Program Counter). Размер счетчика команд составляет от 9 до 12 разрядов в зависимости от объема адресуемой памяти.

По адресу \$000 памяти программ находится вектор сброса. После инициализации (сброса) микроконтроллера выполнение программы начинается с этого адреса (фирма «Atmel» рекомендует размещать по этому адресу команду относительного перехода к инициализационной части программы). Начиная с адреса \$001 располагается таблица векторов прерываний. Ее размер зависит от модели микроконтроллера и составляет от 2 (адреса \$001, \$002) до 16 (адреса \$001...\$010) векторов. При возникновении прерывания после сохранения в стеке текущего значения счетчика команд происходит выполнение команды, расположенной по адресу соответствующего вектора. Поэтому по этим адресам располагаются команды относительного перехода к подпрограммам обработки прерываний. Ниже приведен типичный листинг начала программы для молели AT90S2323:

| Address | Labels | Code             | Comments                    |
|---------|--------|------------------|-----------------------------|
| \$000   |        | rjmp RESET       | ; Обработчик сброса         |
| \$001   |        | rjmp EXT_INTO    | ; Обработчик вн.            |
|         |        |                  | ; прерывания                |
| \$002   |        | rjmp TIM_OVF0    | ; Обработчик прерывания от  |
|         |        |                  | ; Таймера 0                 |
| \$003   | MAIN:  | ldi r16,         |                             |
|         |        | low(RAMEND)      | ; Начало основной программы |
|         |        | out SPL, r16     |                             |
|         |        | <инструкция> ххх |                             |

Если в программе прерывания не используются (запрещены), то основная программа может начинаться непосредственно с адреса \$001.

В заключение следует отметить, что FLASH-ПЗУ, используемое в микроконтроллерах AVR, рассчитано как минимум на 1000 циклов стирания/записи.

# 2.2.2. Память данных

Память данных микроконтроллеров семейства Classic разделена на три части: регистровая память, оперативная память (статическое ОЗУ) и энергонезависимое ЭСППЗУ (EEPROM).

Регистровая память включает в себя 32 регистра общего назначения (РОН), объединенных в регистровый файл и служебные регистры ввода/вывода (РВВ). Размер регистровой памяти фиксирован и для всех моделей составляет 96 байт, соответственно под РОН отводится 32 байта, а под РВВ — 64 байта.

В области регистров ввода/вывода расположены различные служебные регистры (регистр указателя стека, регистр состояния и т.п.), а также регистры управления периферийными устройствами, входящими в состав микроконтроллера. Общее количество PBB зависит от конкретной модели микроконтроллера.

Для хранения переменных программ вместе с регистрами также может использоваться статическое O3V объемом от 128 до 512 байт. Кроме того, микроконтроллеры AT90S4414 и AT90S8515 имеют возможность подключения внешнего статического O3V объемом до 64 Кбайт.

Для хранения данных, которые могут изменяться в процессе настройки и функционирования готовой системы (калибровочные константы, се-

рийные номера, ключи и т.п.), может быть использована EEPROM-память. Ее объем составляет для различных моделей от 64 до 512 байт. Эта память расположена в отдельном адресном пространстве, а доступ к ней осуществляется с помощью определенных PBB.

#### 2.2.2.1. Статическое ОЗУ

Прежде всего следует отметить, что в отличие от микроконтроллеров других производителей, в которых адресное пространство памяти разбивается на несколько банков, в микроконтроллерах AVR семейства Classic используется линейная организация памяти. Объем статического ОЗУ для различных моделей семейства составляет от 128 до 512 байт (см. Табл. 1.1).

В адресном пространстве ОЗУ также расположены все регистры микроконтроллеров, под них отведены младшие 96 адресов (см. **Рис. 2.9**). Остальные адреса отведены под 128/256/512...64К ячеек статического ОЗУ.

#### Использование внешнего ОЗУ

Микроконтроллеры AT90S4414 и AT90S8515 имеют возможность подключения внешнего статического O3У объемом до 64 Кбайт. Для разрешения работы с внешним O3У необходимо установить в «1» разряд SRE регистра MCUCR (см. п. 2.2.2.3). При этом микроконтроллер начинает сам управлять режимом работы порта A (вход/выход), т.е. содержимое регистра DDRA (регистр направления передачи данных порта A) игнорируется.

Для подключения внешнего ОЗУ используются следующие выводы микроконтроллера:

- порт A (RA0...RA7) мультиплексированная шина адреса (младшие 8 разрядов)/шина данных;
- порт C (RC0...RC7) шина адреса (старшие 8 разрядов);
- АLЕ сигнал строба адреса;
- RD(RC7) сигнал строба чтения;
- $\overline{WR}$  (RC6) сигнал строба записи.

При обращении по адресу, который находится вне границы внутреннего ОЗУ, автоматически происходит обращение к внешнему ОЗУ (разумеется, если работа с внешним ОЗУ разрешена). После формирования на выводах порта А требуемого адреса вывод ALE меняет свое состояние с лог. «1» на лог. «0» и остается в этом состоянии в течение всего цикла чтения /записи. При обращении к внутреннему ОЗУ выводы сигналов стробов чтения  $(\overline{RD})$  и записи  $(\overline{WR})$  находятся в неактивном состоянии. При этом на выводе ALE возможны короткие импульсы, не влияющие на работу схемы.

| Регистровый<br>файл   |   | Адресное пространство<br>памяти данных |
|-----------------------|---|----------------------------------------|
| R0                    |   | \$0000                                 |
| R1                    |   | \$001                                  |
| R2                    |   | \$002                                  |
|                       |   |                                        |
| R29                   |   | \$001D                                 |
| R30                   |   | \$001E                                 |
| R31                   |   | \$001F                                 |
| Регистры ввода/вывода |   |                                        |
| \$00                  |   | \$0020                                 |
| \$01                  |   | \$021                                  |
| \$02                  |   | \$022                                  |
|                       |   |                                        |
| \$3D                  |   | \$005D                                 |
| \$3E                  |   | \$005E                                 |
| \$3F                  |   | \$005F                                 |
|                       |   | Внутреннее ОЗУ                         |
|                       |   | \$0060                                 |
|                       |   | \$061                                  |
|                       |   |                                        |
|                       |   | \$00DE/\$015E/\$025E                   |
|                       |   | \$00DF/\$015F/\$025F                   |
|                       |   | Внешнее ОЗУ                            |
|                       |   | \$0160/\$0260                          |
|                       |   | \$0161/\$0261                          |
|                       |   |                                        |
|                       | I | \$FFFE                                 |
|                       | ļ | \$FFFF                                 |

Рис. 2.9. Организация статического ОЗУ



Рис. 2.10. Подключение внешнего ОЗУ к микроконтроллеру

Как показано на **Рис. 2.10**, для подключения внешнего ОЗУ к микро-контроллеру дополнительно потребуется регистр-защелка. В качестве защелки можно использовать микросхему 74...373 (отечественные аналоги 1533ИР22, 1564ИР22, 1594ИР22 и др.) с потенциальным управлением или 74...374 (...ИР23) с динамическим управлением.

По умолчанию длительность каждого обращения к внешней памяти составляет 3 машинных цикла, как показано на **Puc. 2.11a**. При необходимости время обращения можно увеличить на 1 машинный цикл установкой в «1» бита SRW регистра MCUCR. Временная диаграмма для этого случая показана на **Puc. 2.116**.

Необходимо помнить, что обращение к внешнему O3V увеличивает время выполнения команды на 1 или 2 (в зависимости от режима обращения к внешнему O3V) машинных цикла для каждого байта данных, обрабатываемого командой. Таким образом, время выполнения команд передачи данных (LD, ST, LDS, STS, PUSH и POP) увеличивается на 1 (2) цикла. Если стек расположен во внешнем O3V, то время перехода к обработке прерываний, вызова и возврата из подпрограмм увеличивается на 2 (4) машинных цикла. Это связано с тем, что во время выполнения указанных операций происходит сохранение и восстановление 16-разрядного счетчика команд.

Полная временная диаграмма обращения к внешнему ОЗУ с указанием всех параметров сигналов приведена на **Рис. 2.12**. Значения этих параметров приведены в **Табл. 2.1**.





*Рис. 2.11.* Временная диаграмма обращения к внешнему ОЗУ: a — без ожидания; б — c дополнительным циклом ожидания



Примечание: Такт ТЗ присутствует только при использовании дополнительного цикла ожидания.

Рис. 2.12. Временная диаграмма обращения к внешнему ОЗУ

Таблица 2.1. Параметры сигналов при обращении к внешнему ОЗУ

|    | Обозн.               | Параметр                                                                      | $V_{CC} = 4$ .              | 06.0 B | $V_{\rm CC} = 2$ .          | 74.0 B | Ед.  |
|----|----------------------|-------------------------------------------------------------------------------|-----------------------------|--------|-----------------------------|--------|------|
|    | Ouosn.               | Параметр                                                                      | min max                     |        | min                         | max    | изм. |
| 0  | $1/t_{\text{CLCL}}$  | Тактовая частота                                                              | 0                           | 8      | 0                           | 4      | МΓц  |
| 1  | $t_{ m LHLL}$        | Длительность сигнала ALE                                                      | $0.5t_{\text{CLCL}} - 30.0$ |        | $0.5t_{\text{CLCL}} - 55.0$ |        | нс   |
| 2  | t <sub>AVLL</sub>    | Задержка сигнала ALE<br>относительно сигналов<br>адреса A[70]                 | $0.5t_{\rm CLCL} - 40.0$    |        | $0.5t_{\text{CLCL}} - 65.0$ |        | нс   |
| 3a | t <sub>LLAX_ST</sub> | Задержка сигналов адреса А [70] относительно сигнала ALE (команды ST/STD/STS) | $0.5t_{\text{CLCL}} + 5.0$  |        | $0.5t_{\rm CLCL} + 5.0$     |        | нс   |
| 3b | t <sub>LLAX_LD</sub> | Задержка сигналов адреса А [70] относительно сигнала ALE (команды LT/LDD/LDS) | 15.0                        |        | 15.0                        |        | нс   |
| 4  | t <sub>AVLLC</sub>   | Задержка сигнала ALE<br>относительно сигналов<br>адреса A[158]                | $0.5t_{\rm CLCL} - 40.0$    |        | $0.5t_{\text{CLCL}} - 65.0$ |        | нс   |
| 5  | t <sub>AVRL</sub>    | Задержка сигнала RD относительно сигналов адреса                              | $1.0t_{\text{CLCL}} - 30.0$ |        | $1.0t_{\text{CLCL}} - 50.0$ |        | нс   |
| 6  | $t_{ m AVWL}$        | Задержка сигнала WR относительно сигналов адреса                              | $1.5t_{\text{CLCL}} - 30.0$ |        | $1.5t_{\rm CLCL} - 50.0$    |        | нс   |

Таблица 2.1 (окончание)

| №    | Обозн.              | Параметр                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | $V_{\rm CC} = 4$ .          | 06.0 B                      | $V_{CC} = 2$ .              | Ед.                         |      |
|------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------|
| 3 12 | 000311.             | Параметр                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | min                         | max                         | min                         | max                         | изм. |
| 7    | $t_{ m LLWL}$       | Задержка сигнала WR относительно сигнала ALE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | $1.0t_{\rm CLCL} - 20.0$    | $1.0t_{\text{CLCL}} + 20.0$ | $1.0t_{\rm CLCL} - 20.0$    | $1.0t_{\text{CLCL}} + 20.0$ | нс   |
| 8    | $t_{\rm LLRL}$      | Задержка сигнала RD относительно сигнала ALE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | $0.5t_{\text{CLCL}} - 20.0$ | $0.5t_{\text{CLCL}} + 20.0$ | $0.5t_{\text{CLCL}} - 20.0$ | $0.5t_{\text{CLCL}} + 20.0$ | нс   |
| 9    | $t_{ m DVRH}$       | Задержка сигнала RD относительно момента установления сигнала данных                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 60.0                        |                             | 95.0                        |                             | нс   |
| 1.0  | ,                   | Время установления                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                             | $1.0t_{\text{CLCL}} - 55.0$ |                             | $1.0t_{\text{CLCL}} - 80.0$ |      |
| 10   | $t_{\mathrm{RLDV}}$ | сигналов данных относительно сигнала RD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                             | $2.0t_{\rm CLCL} - 55.0$    |                             | $2.0t_{\text{CLCL}} - 80.0$ | нс   |
| 11   | $t_{ m RHDX}$       | Время сохранения сигналов данных относительно сигнала RD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0.0                         |                             | 0.0                         |                             | нс   |
| 12   | $t_{\rm RLRH}$      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $1.0t_{\text{CLCL}} - 20.0$ |                             | $1.0t_{\text{CLCL}} - 20.0$ |                             | нс   |
| 12   | *KLKH               | Длительность сигнала RD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | $2.0t_{\rm CLCL} - 20.0$    |                             | $2.0t_{\rm CLCL} - 20.0$    |                             | 110  |
| 13   | $t_{ m DVWL}$       | Задержка сигнала WR относительно момента установления сигнала данных                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | $0.5t_{\text{CLCL}} - 35.0$ |                             | $0.5t_{\text{CLCL}} - 55.0$ |                             | нс   |
| 14   | $t_{ m WHDX}$       | Время сохранения сигналов данных относительно сигнала WR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0.0                         |                             | 0.0                         |                             | нс   |
| 1.5  | ,                   | Задержка сигнала WR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | $1.0t_{\text{CLCL}} - 30.0$ |                             | $1.0t_{\text{CLCL}} - 40.0$ |                             |      |
| 15   | $t_{\rm DVWH}$      | относительно момента<br>установления сигнала данных                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | $2.0t_{\text{CLCL}} - 30.0$ |                             | $2.0t_{\text{CLCL}} - 40.0$ |                             | нс   |
| 16   | $t_{ m WLWH}$       | The state of the s | $0.5t_{\text{CLCL}} - 20.0$ |                             | $0.5t_{\rm CLCL} - 20.0$    |                             | нс   |
| 10   | ·WLWH               | Длительность сигнала WR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | $1.5t_{\text{CLCL}} - 20.0$ |                             | $1.5t_{\text{CLCL}} - 20.0$ |                             | 110  |

#### Примечание:

Для параметров, имеющих в таблице две строки, в первой указано значение параметра при обращении к O3V без использования цикла ожидания, во второй — при использовании цикла ожидания.

### 2.2.2.2. Регистры общего назначения

Все регистры общего назначения объединены в файл, структура которого показана на Рис. 2.13. Как уже было сказано, в микроконтроллерах AVR все 32 РОН непосредственно доступны АЛУ в отличие от микроконтроллеров других фирм, в которых имеется только один такой регистр — рабочий регистр W (аккумулятор). Благодаря этому любой РОН может использоваться во всех командах и как операнд-источник и как операнд-приемник. Исключение составляют лишь пять арифметических и логических команд, вы-



Рис. 2.13. Структура файла регистров общего назначения

полняющих действия между константой и регистром (SBCI, SUBI, CPI, ANDI, ORI), а также команда загрузки константы в регистр (LDI). Эти команды могут обращаться только ко второй половине регистров (R16...R31).

Ряд регистров общего назначения используется в качестве указателей при косвенной адресации памяти данных. В модели AT90S1200 таким регистром является регистр R30 (регистр Z). Поскольку объем адресуемой памяти данных этой модели составляет всего 96 байт, для хранения адреса достаточно одного 8-разрядного регистра. Во всех других моделях для косвенной адресации используются три 16-разрядных регистра (регистры X, Y и Z), каждый из которых получается объединением двух РОН (Рис. 2.14). Более подробно использование этих регистров будет описано в п. 3.2.2.4.



Рис. 2.14. Регистры-указатели X, Y и Z

Как показано на **Рис. 2.13**, каждый регистр файла имеет свой собственный адрес в пространстве памяти данных (кроме AT90S1200). Поэтому к ним можно обращаться как к памяти, несмотря на то, что физически эти регистры не являются ячейками O3У.

### 2.2.2.3. Регистры ввода/вывода

Регистры ввода/вывода располагаются в так называемом пространстве ввода/вывода размером 64 байта. Все PBB можно разделить на две группы: служебные регистры микроконтроллера и регистры, относящиеся к периферийным устройствам (в т.ч. порты ввода/вывода). Размер каждого регистра — 8 разрядов.

Распределение адресов пространства ввода/вывода зависит от конкретной модели микроконтроллера, т.к. разные модели имеют различный состав периферийных устройств и, соответственно, разное количество регистров. Размещение РВВ в адресном пространстве ввода/вывода для всех моделей семейства приведено в Табл. 2.2...2.5. В этой главе будут рассмотрены только некоторые служебные регистры, общие для всех микроконтроллеров семейства. Остальные регистры ввода/вывода будут подробно рассмотрены в соответствующих разделах книги.

Общее замечание к таблицам: если адрес в таблице не указан, это означает, что для данной модели он зарезервирован, и запись по этому адресу запрещена (крайне не рекомендуется).

К любому регистру ввода/вывода можно обратиться с помощью команд IN и OUT, выполняющих пересылку данных между одним из 32 POH и пространством ввода/вывода. Кроме того, имеются 4 команды поразрядного доступа, использующие в качестве операндов регистры ввода/вывода: команды установки/сброса отдельного разряда (SBI и CBI) и команды

Таблица 2.2. PBB моделей AT90S1200, AT90S2313, AT90S/LS2323 и AT90S/LS2343

| Название |                                                        | Адрес     |             |                              |  |  |
|----------|--------------------------------------------------------|-----------|-------------|------------------------------|--|--|
| Название | Функция                                                | AT90S1200 | AT90S2313   | AT90S/LS2323<br>AT90S/LS2343 |  |  |
| ACSR     | Регистр управления и состояния аналогового компаратора | \$08      | \$08 (\$28) | _                            |  |  |
| DDRB     | Регистр направления данных порта В                     | \$17      | \$17 (\$37) | \$17 (\$37)                  |  |  |
| DDRD     | Регистр направления данных порта D                     | \$11      | \$11 (\$31) | _                            |  |  |
| EEAR     | Регистр адреса EEPROM                                  | \$1E      | \$1E (\$3E) | \$1E (\$3E)                  |  |  |
| EECR     | Регистр управления EEPROM                              | \$1C      | \$1C (\$3C) | \$1C (\$3C)                  |  |  |
| EEDR     | Регистр данных EEPROM                                  | \$1D      | \$1D (\$3D) | \$1D (\$3D)                  |  |  |
| GIFR     | Общий регистр флагов прерываний                        | _         | \$3A (\$5A) | \$3A (\$5A)                  |  |  |
| GIMSK    | Общий регистр маски прерываний                         | \$3B      | \$3B (\$5B) | \$3B (\$5B)                  |  |  |
| ICR1H    | Регистр захвата таймера/счетчика 1 (старший байт)      | _         | \$25 (\$45) | _                            |  |  |
| ICR1L    | Регистр захвата таймера/счетчика 1 (младший байт)      | _         | \$24 (\$44) | _                            |  |  |
| MCUCR    | Общий регистр управления микроконтроллером             | \$35      | \$35 (\$55) | \$35 (\$55)                  |  |  |
| MCUSR    | Регистр состояния микроконтроллера                     | _         | _           | \$34 (\$54)                  |  |  |
| OCR1AH   | Регистр совпадения выхода 1 (старший байт)             | _         | \$2B (\$4B) | _                            |  |  |
| OCR1AL   | Регистр совпадения выхода 1 (младший байт)             | _         | \$2A (\$4A) | _                            |  |  |
| PINB     | Выводы порта В                                         | \$16      | \$16 (\$36) | \$16 (\$36)                  |  |  |
| PIND     | Выводы порта D                                         | \$10      | \$10 (\$30) | _                            |  |  |
| PORTB    | Регистр данных порта В                                 | \$18      | \$18 (\$38) | \$18 (\$38)                  |  |  |
| PORTD    | Регистр данных порта D                                 | \$12      | \$12 (\$32) | _                            |  |  |
| SPL      | Указатель стека                                        | _         | \$3D (\$5D) | \$3D (\$5D)                  |  |  |
| SREG     | Регистр состояния                                      | \$3F      | \$3F (\$5F) | \$3F (\$5F)                  |  |  |
| TCCR0    | Регистр управления таймером/счетчиком 0                | \$33      | \$33 (\$53) | \$33 (\$53)                  |  |  |
| TCCR1A   | Регистр управления А таймером/счетчиком 1              | _         | \$2F (\$4F) | _                            |  |  |
| TCCR1B   | Регистр управления В таймером/счетчиком 1              | _         | \$2E (\$4E) | _                            |  |  |
| TCNT0    | Счетный регистр таймера/счетчика 0 (8-разрядный)       | \$32      | \$32 (\$52) | \$32 (\$52)                  |  |  |
| TCNT1H   | Счетный регистр таймера/счетчика 1                     | _         | \$2D (\$4D) | -                            |  |  |
| TCNT1L   | Счетный регистр таймера/счетчика 1 (младший байт)      | _         | \$2C (\$4C) | _                            |  |  |
| TIFR     | Регистр флагов прерываний от таймера/счетчика          | \$38      | \$38 (\$58) | \$38 (\$58)                  |  |  |
| TIMSK    | Регистр маски прерываний от таймера/счетчика           | \$39      | \$39 (\$59) | \$39 (\$59)                  |  |  |
| UBRR     | Регистр скорости передачи UART                         | _         | \$09 (\$29) | _                            |  |  |
| UCR      | Регистр управления UART                                | _         | \$0A (\$2A) | _                            |  |  |
| UDR      | Регистр данных UART                                    | _         | \$0C (\$2C) | _                            |  |  |
| USR      | Регистр состояния UART                                 | _         | \$0B (\$2B) | _                            |  |  |
| WDTCR    | Регистр управления сторожевым таймером                 | \$21      | \$21 (\$41) | _                            |  |  |

*Таблица 2.3.* PBB моделей AT90S/LS2333 и AT90S/LS4433

|          |                                                        | Адрес        |
|----------|--------------------------------------------------------|--------------|
| Название | Функция                                                | AT90S/LS2333 |
|          |                                                        | AT90S/LS4433 |
| ACSR     | Регистр управления и состояния аналогового компаратора | \$08 (\$28)  |
| ADCH     | Регистр данных АЦП (старший байт)                      | \$05 (\$25)  |
| ADCL     | Регистр данных АЦП (младший байт)                      | \$04 (\$24)  |
| ADCSR    | Регистр управления и состояния АЦП                     | \$06 (\$26)  |
| ADMUX    | Регистр управления мультиплексором АЦП                 | \$07 (\$27)  |
| DDRB     | Регистр направления данных порта В                     | \$17 (\$37)  |
| DDRC     | Регистр направления данных порта С                     | \$14 (\$37)  |
| DDRD     | Регистр направления данных порта D                     | \$11 (\$31)  |
| EEAR     | Регистр адреса EEPROM                                  | \$1E (\$3E)  |
| EECR     | Регистр управления EEPROM                              | \$1C (\$3C)  |
| EEDR     | Регистр данных EEPROM                                  | \$1D (\$3D)  |
| GIFR     | Общий регистр флагов прерываний                        | \$3A (\$5A)  |
| GIMSK    | Общий регистр маски прерываний                         | \$3B (\$5B)  |
| ICR1H    | Регистр захвата таймера/счетчика 1 (старший байт)      | \$27 (\$47)  |
| ICR1L    | Регистр захвата таймера/счетчика 1 (младший байт)      | \$26 (\$46)  |
| MCUCR    | Общий регистр управления микроконтроллером             | \$35 (\$55)  |
| OCR1H    | Регистр совпадения выхода 1 (старший байт)             | \$2B (\$4B)  |
| OCR1L    | Регистр совпадения выхода 1 (младший байт)             | \$2A (\$4A)  |
| PINB     | Выводы порта В                                         | \$16 (\$36)  |
| PINC     | Выводы порта С                                         | \$13 (\$36)  |
| PIND     | Выводы порта D                                         | \$10 (\$30)  |
| PORTB    | Регистр данных порта В                                 | \$18 (\$38)  |
| PORTC    | Регистр данных порта С                                 | \$15 (\$38)  |
| PORTD    | Регистр данных порта D                                 | \$12 (\$32)  |
| SP       | Указатель стека                                        | \$3D (\$5D)  |
| SPCR     | Регистр управления SPI                                 | \$0D (\$2D)  |
| SPDR     | Регистр данных SPI                                     | \$0F (\$2F)  |
| SPSR     | Регистр состояния SPI                                  | \$0E (\$2E)  |
| SREG     | Регистр состояния                                      | \$3F (\$5F)  |
| TCCR0    | Регистр управления таймером/счетчиком 0                | \$33 (\$53)  |
| TCCR1A   | Регистр управления А таймером/счетчиком 1              | \$2F (\$4F)  |
| TCCR1B   | Регистр управления В таймером/счетчиком 1              | \$2E (\$4E)  |
| TCNT0    | Счетный регистр таймера/счетчика 0 (8-разрядный)       | \$32 (\$52)  |
| TCNT1H   | Счетный регистр таймера/счетчика 1                     | \$2D (\$4D)  |
| TCNT1L   | Счетный регистр таймера/счетчика 1 (младший байт)      | \$2C (\$4C)  |
| TIFR     | Регистр флагов прерываний от таймера/счетчика          | \$38 (\$58)  |
| TIMSK    | Регистр маски прерываний от таймера/счетчика           | \$39 (\$59)  |
| UBRR     | Регистр скорости передачи UART (младший байт)          | \$09 (\$29)  |
| UBRRHI   | Регистр скорости передачи UART (старший байт)          | \$03 (\$23)  |
| UCR      | Регистр управления UART                                | \$0A (\$2A)  |

Таблица 2.3 (окончание)

| Название | Функция                                | Адрес<br>AT90S/LS2333<br>AT90S/LS4433 |
|----------|----------------------------------------|---------------------------------------|
| UDR      | Регистр данных UART                    | \$0C (\$2C)                           |
| USR      | Регистр состояния UART                 | \$0B (\$2B)                           |
| WDTCR    | Регистр управления сторожевым таймером | \$21 (\$41)                           |

Таблица 2.4. PBB моделей AT90S/LS4434, AT90S/LS8535, AT90S4414 и AT90S8515

| **       |                                                        | Адрес                        |                        |  |  |
|----------|--------------------------------------------------------|------------------------------|------------------------|--|--|
| Название | Функция                                                | AT90S/LS4434<br>AT90S/LS8535 | AT90S4414<br>AT90S8515 |  |  |
| ACSR     | Регистр управления и состояния аналогового компаратора | \$08 (\$28)                  | \$08 (\$28)            |  |  |
| ADCH     | Регистр данных АЦП (старший байт)                      | \$05 (\$25)                  | _                      |  |  |
| ADCL     | Регистр данных АЦП (младший байт)                      | \$04 (\$24)                  | _                      |  |  |
| ADCSR    | Регистр управления и состояния АЦП                     | \$06 (\$26)                  | _                      |  |  |
| ADMUX    | Регистр управления мультиплексором АЦП                 | \$07 (\$27)                  | _                      |  |  |
| ASSR     | Регистр состояния асинхронного режима                  | \$22 (\$42)                  | _                      |  |  |
| DDRA     | Регистр направления данных порта А                     | \$1A (\$3A)                  | \$1A (\$3A)            |  |  |
| DDRB     | Регистр направления данных порта В                     | \$17 (\$37)                  | \$17 (\$37)            |  |  |
| DDRC     | Регистр направления данных порта С                     | \$14 (\$37)                  | \$14 (\$37)            |  |  |
| DDRD     | Регистр направления данных порта D                     | \$11 (\$31)                  | \$11 (\$31)            |  |  |
| EEARH    | Регистр адреса EEPROM (старший байт)                   | \$1F (\$3F)                  | \$1F (\$3F)            |  |  |
| EEARL    | Регистр адреса EEPROM (младший байт)                   | \$1E (\$3E)                  | \$1E (\$3E)            |  |  |
| EECR     | Регистр управления EEPROM                              | \$1C (\$3C)                  | \$1C (\$3C)            |  |  |
| EEDR     | Регистр данных EEPROM                                  | \$1D (\$3D)                  | \$1D (\$3D)            |  |  |
| GIFR     | Общий регистр флагов прерываний                        | \$3A (\$5A)                  | \$3A (\$5A)            |  |  |
| GIMSK    | Общий регистр маски прерываний                         | \$3B (\$5B)                  | \$3B (\$5B)            |  |  |
| ICR1H    | Регистр захвата таймера/счетчика 1 (старший байт)      | \$27 (\$47)                  | \$25 (\$45)            |  |  |
| ICR1L    | Регистр захвата таймера/счетчика 1 (младший байт)      | \$26 (\$46)                  | \$24 (\$44)            |  |  |
| MCUCR    | Общий регистр управления микроконтроллером             | \$35 (\$55)                  | \$35 (\$55)            |  |  |
| MCUSR    | Регистр состояния микроконтроллера                     | \$34 (\$54)                  | _                      |  |  |
| OCR1AH   | Регистр совпадения выхода А (старший байт)             | \$2B (\$4B)                  | \$2B (\$4B)            |  |  |
| OCR1AL   | Регистр совпадения выхода А (младший байт)             | \$2A (\$4A)                  | \$2A (\$4A)            |  |  |
| OCR1BH   | Регистр совпадения выхода В (старший байт)             | \$29 (\$49)                  | \$29 (\$49)            |  |  |
| OCR1BL   | Регистр совпадения выхода В (младший байт)             | \$28 (\$48)                  | \$28 (\$48)            |  |  |
| OCR2     | Регистр совпадения выхода таймера/счетчика 2           | \$23 (\$43)                  |                        |  |  |
| PINA     | Выводы порта А                                         | \$19 (\$39)                  | \$19 (\$39)            |  |  |
| PINB     | Выводы порта В                                         | \$16 (\$36)                  | \$16 (\$36)            |  |  |
| PINC     | Выводы порта С                                         | \$13 (\$36)                  | \$13 (\$36)            |  |  |
| PIND     | Выводы порта D                                         | \$10 (\$30)                  | \$10 (\$30)            |  |  |
| PORTA    | Регистр данных порта А                                 | \$1B (\$3B)                  | \$1B (\$3B)            |  |  |
| PORTB    | Регистр данных порта В                                 | \$18 (\$38)                  | \$18 (\$38)            |  |  |
| PORTC    | Регистр данных порта С                                 | \$15 (\$38)                  | \$15 (\$38)            |  |  |

Таблица 2.4 (окончание)

|          |                                                   | Адј          | Адрес       |  |  |  |
|----------|---------------------------------------------------|--------------|-------------|--|--|--|
| Название | Функция                                           | AT90S/LS4434 | AT90S4414   |  |  |  |
|          |                                                   | AT90S/LS8535 | AT90S8515   |  |  |  |
| PORTD    | Регистр данных порта D                            | \$12 (\$32)  | \$12 (\$32) |  |  |  |
| SPCR     | Регистр управления SPI                            | \$0D (\$2D)  | \$0D (\$2D) |  |  |  |
| SPDR     | Регистр данных SPI                                | \$0F (\$2F)  | \$0F (\$2F) |  |  |  |
| SPH      | Указатель стека (старший байт)                    | \$3E (\$5E)  | \$3E (\$5E) |  |  |  |
| SPL      | Указатель стека (младший байт)                    | \$3D (\$5D)  | \$3D (\$5D) |  |  |  |
| SPSR     | Регистр состояния SPI                             | \$0E (\$2E)  | \$0E (\$2E) |  |  |  |
| SREG     | Регистр состояния                                 | \$3F (\$5F)  | \$3F (\$5F) |  |  |  |
| TCCR0    | Регистр управления таймером/счетчиком 0           | \$33 (\$53)  | \$33 (\$53) |  |  |  |
| TCCR1A   | Регистр управления А таймером/счетчиком 1         | \$2F (\$4F)  | \$2F (\$4F) |  |  |  |
| TCCR1B   | Регистр управления В таймером/счетчиком 1         | \$2E (\$4E)  | \$2E (\$4E) |  |  |  |
| TCCR2    | Счетный регистр таймера/счетчика 2                | \$25 (\$45)  | _           |  |  |  |
| TCNT0    | Счетный регистр таймера/счетчика 0 (8-разрядный)  | \$32 (\$52)  | \$32 (\$52) |  |  |  |
| TCNT1H   | Счетный регистр таймера/счетчика 1                | \$2D (\$4D)  | \$2D (\$4D) |  |  |  |
| TCNT1L   | Счетный регистр таймера/счетчика 1 (младший байт) | \$2C (\$4C)  | \$2C (\$4C) |  |  |  |
| TCNT2    | Счетный регистр таймера/счетчика 2 (8-разрядный)  | \$24 (\$44)  | _           |  |  |  |
| TIFR     | Регистр флагов прерываний от таймера/счетчика     | \$38 (\$58)  | \$38 (\$58) |  |  |  |
| TIMSK    | Регистр маски прерываний от таймера/счетчика      | \$39 (\$59)  | \$39 (\$59) |  |  |  |
| UBRR     | Регистр скорости передачи UART                    | \$09 (\$29)  | \$09 (\$29) |  |  |  |
| UCR      | Регистр управления UART                           | \$0A (\$2A)  | \$0A (\$2A) |  |  |  |
| UDR      | Регистр данных UART                               | \$0C (\$2C)  | \$0C (\$2C) |  |  |  |
| USR      | Регистр состояния UART                            | \$0B (\$2B)  | \$0B (\$2B) |  |  |  |
| WDTCR    | Регистр управления сторожевым таймером            | \$21 (\$41)  | \$21 (\$41) |  |  |  |

*Таблица 2.5.* PBB модели AT90C8534

| Название | Функция                                    | Адрес<br>АТ90С8534 |
|----------|--------------------------------------------|--------------------|
| ADCH     | Регистр данных АЦП (старший байт)          | \$05 (\$25)        |
| ADCL     | Регистр данных АЦП (младший байт)          | \$04 (\$24)        |
| ADCSR    | Регистр управления и состояния АЦП         | \$06 (\$26)        |
| ADMUX    | Регистр управления мультиплексором АЦП     | \$07 (\$27)        |
| DDRA     | Регистр направления данных порта А         | \$1A (\$3A)        |
| EEARH    | Регистр адреса EEPROM (старший байт)       | \$1F (\$3F)        |
| EEARL    | Регистр адреса EEPROM (младший байт)       | \$1E (\$3E)        |
| EECR     | Регистр управления EEPROM                  | \$1C (\$3C)        |
| EEDR     | Регистр данных EEPROM                      | \$1D (\$3D)        |
| GIFR     | Общий регистр флагов прерываний            | \$3A (\$5A)        |
| GIMSK    | Общий регистр маски прерываний             | \$3B (\$5B)        |
| GIPR     | Регистр входов внешних прерываний          | \$10 (\$30)        |
| MCUCR    | Общий регистр управления микроконтроллером | \$35 (\$55)        |
| PORTA    | Регистр данных порта А                     | \$1B (\$3B)        |
| SPH      | Указатель стека (старший байт)             | \$3E (\$5E)        |

| Название | Функция                                           | Адрес<br>АТ90С8534 |
|----------|---------------------------------------------------|--------------------|
| SPL      | Указатель стека (младший байт)                    | \$3D (\$5D)        |
| SREG     | Регистр состояния                                 | \$3F (\$5F)        |
| TCCR0    | Регистр управления таймером/счетчиком 0           | \$33 (\$53)        |
| TCCR1    | Регистр управления таймером/счетчиком 1           | \$2E (\$4E)        |
| TCNT0    | Счетный регистр таймера/счетчика 0 (8-разрядный)  | \$32 (\$52)        |
| TCNT1H   | Счетный регистр таймера/счетчика 1                | \$2D (\$4D)        |
| TCNT1L   | Счетный регистр таймера/счетчика 1 (младший байт) | \$2C (\$4C)        |
| TIFR     | Регистр флагов прерываний от таймера/счетчика     | \$38 (\$58)        |
| TIMSK    | Регистр маски прерываний от таймера/счетчика      | \$39 (\$59)        |

Таблица 2.5 (окончание)

проверки состояния отдельного разряда (SBIS и SBIC). Обратите внимание, что эти команды могут обращаться только к 1-й половине регистров ввода/вывода (адреса \$00...\$1F).

Так же, как и к РОН, к регистрам ввода/вывода можно обращаться двумя способами: как собственно к регистрам (с помощью команд IN и ОUТ) и как к ячейкам ОЗУ (кроме AT90S1200). В первом случае используются адреса РВВ, принадлежащие пространству ввода/вывода (\$00...\$3F). Во втором случае адрес РВВ необходимо увеличить на \$20 (в таблицах и далее в книге при указании адресов РВВ в скобках указываются соответствующие им адреса ячеек ОЗУ).

А теперь рассмотрим служебные регистры микроконтроллера. Все служебные регистры перечислены в **Табл. 2.6**, знак « $\diamond$ » в таблице означает, что тот или иной регистр присутствует в данной модели микроконтроллера. Обратите внимание, что адреса служебных регистров не меняются от модели к модели (т.е. регистр SREG всегда расположен по адресу \$3F (\$5F), регистр GIMSK — по адресу \$3B (\$5B) и т.д.).

# SREG (регистр состояния)

Регистр состояния располагается по адресу \$3F (\$5F). Этот регистр представляет собой набор флагов, показывающих текущее состояние микроконтроллера. Эти флаги автоматически устанавливаются в «1» или в «0» при наступлении определенных событий (в соответствии с результатом выполнения команд). Все разряды этого регистра доступны как для чтения, так и для записи в любой момент времени; после сброса микроконтроллера все разряды регистра сбрасываются в «0». Содержимое этого регистра показано ниже на Рис. 2.15, а его описание приведено в Табл. 2.7.

Таблица 2.6. Служебные регистры микроконтроллеров семейства Classic

| Название<br>регистра | Адрес       | AT90S1200          | AT90S2313              | AT90S/LS2323       | AT90S/LS2343           | AT90S/LS2333 | AT90S/LS4433           | AT90S/LS4434           | AT90S/LS8535       | AT90S4414              | AT90S8515 | AT90C8534      |
|----------------------|-------------|--------------------|------------------------|--------------------|------------------------|--------------|------------------------|------------------------|--------------------|------------------------|-----------|----------------|
| SREG                 | \$3F (\$5F) | <b>\lambda</b>     | <b>♦</b>               | <b>\lambda</b>     | <b>\rightarrow</b>     | <b>\</b>     | <b>♦</b>               | <b>\</b>               | <b>\rightarrow</b> | <b>\lambda</b>         | <b>\</b>  |                |
| SPH                  | \$3E (\$5E) |                    |                        |                    |                        |              |                        | ♦                      | ◊                  | 0                      | 0         |                |
| SPL                  | \$3D (\$5D) |                    | <b>\lambda</b>         | <b>\lambda</b>     | <b>\lambda</b>         | 0            | <b>\rightarrow</b>     | <b>\lambda</b>         | <b>\rightarrow</b> | <b>\lambda</b>         | 0         | <b>◊</b>       |
| GIMSK                | \$3B (\$5B) | <b>◊</b>           | <b>\lambda</b>         | <b>\lambda</b>     | <b>\(\rightarrow\)</b> | 0            | <b>\lambda</b>         | <b>\lambda</b>         | <b>\lambda</b>     | <b>\(\rightarrow\)</b> | 0         | <b>◊</b>       |
| GIFR                 | \$3A (\$5A) |                    | <b>\(\rightarrow\)</b> | <b>\lambda</b>     | <b>\(\rightarrow\)</b> | 0            | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> | <b>\lambda</b>     | <b>\(\rightarrow\)</b> | 0         | <b>\lambda</b> |
| TIMSK                | \$39 (\$59) | <b>\lambda</b>     | <b>\lambda</b>         | <b>◊</b>           | <b>\lambda</b>         | 0            | <b>\lambda</b>         | <b>\lambda</b>         | <b>\rightarrow</b> | <b>\lambda</b>         | 0         | <b>◊</b>       |
| TIFR                 | \$38 (\$58) | <b>◊</b>           | <b>\lambda</b>         | <b>\lambda</b>     | <b>\lambda</b>         | 0            | <b>\lambda</b>         | <b>\lambda</b>         | <b>\rightarrow</b> | <b>\lambda</b>         | 0         | <b>◊</b>       |
| MCUCR                | \$35 (\$55) | <b>\rightarrow</b> | <b>\lambda</b>         | <b>\rightarrow</b> | <b>\lambda</b>         | 0            | <b>\(\rightarrow\)</b> | <b>\lambda</b>         | <b>\lambda</b>     | <b>\(\rightarrow\)</b> | 0         | <b>\lambda</b> |
| MCUSR                | \$34 (\$54) |                    |                        | <b>\( \)</b>       | <b>\(\rightarrow\)</b> |              |                        | <b>\( \)</b>           | <b>\( \)</b>       |                        |           |                |

|                     | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|---------------------|-----|-----|-----|-----|-----|-----|-----|-----|
|                     | I   | Т   | Н   | S   | V   | N   | Z   | С   |
| Чтение(R)/Запись(W) | R/W |
| Начальное значение  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Puc. 2.15. Регистр состояния SREG

Таблица 2.7. Регистр состояния SREG

| Разряд | Название | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | I        | Общее разрешение прерываний. Для разрешения прерываний этот флаг должен быть установлен в «1». Разрешение/запрещение отдельных прерываний производится установкой или сбросом соответствующих разрядов регистров масок прерываний (см. Главу 4). Если флаг сброшен (0), то прерывания запрещены независимо от состояния этих регистров. Флаг сбрасывается аппаратно после входа в прерывание и восстанавливается командой RETI для разрешения обработки следующих прерываний |
| 6      | Т        | Хранение копируемого бита. Этот разряд регистра используется в качестве источника или приемника командами копирования битов BLD (Bit LoaD) и BST (Bit STore). Заданный разряд любого РОН может быть скопирован в этот разряд командой BST или установлен в соответствии с содержимым данного разряда командой BLD                                                                                                                                                            |
| 5      | Н        | Флаг половинного переноса. Этот флаг устанавливается в «1», если имел место перенос из младшей половины байта (из 3-го разряда в 4-й) или заем из старшей половины байта при выполнении некоторых арифметических операций                                                                                                                                                                                                                                                    |
| 4      | S        | Флаг знака. Этот флаг равен результату операции «Исключающее ИЛИ» (ХОR) между флагами N (отрицательный результат) и V (переполнение числа в дополнительном коде). Соответственно этот флаг устанавливается в «1», если результат выполнения арифметической операции меньше нуля                                                                                                                                                                                              |
| 3      | V        | Флаг переполнения дополнительного кода. Этот флаг устанавливается в «1» при переполнении разрядной сетки знакового результата. Используется при работе со знаковыми числами (представленными в дополнительном коде). Более подробно см. описание системы команд                                                                                                                                                                                                              |

Таблица 2.7 (окончание)

| Разряд | Название | Описание                                                                                                                                                  |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | 1 1      | Флаг отрицательного значения. Этот флаг устанавливается в «1», если старший разряд (7-й) результата операции равен «1». В противном случае флаг равен «0» |
| 1      | l L      | Флаг нуля. Этот флаг устанавливается в «1», если результат выполнения операции равен нулю                                                                 |
| 0      | l (:     | Флаг переноса. Этот флаг устанавливается в «1», если в результате выполнения операции произошел выход за границы байта                                    |

#### SP (указатель стека)

В моделях, имеющих объем ОЗУ до 128 байт (адресное пространство ОЗУ — \$000...\$0DF), указатель стека реализован на одном регистре SPL, расположенном по адресу \$3D (\$5D). В остальных моделях указатель стека реализован на паре регистров SPH:SPL, расположенных по адресам \$3E (\$5E) и \$3D (\$5D) соответственно. Причем для всех моделей, кроме AT90S4414 и AT90S8515, в регистре SPH (старший байт указателя стека) используются только 1 (объем ОЗУ — 256 байт) или 2 (объем ОЗУ — 512 байт) младших разряда, остальные разряды доступны только для чтения и содержат «0». В моделях AT90S4414 и AT90S8515 оба регистра SPH:SPL используются полностью, т.к. максимальный объем памяти в этих моделях равен 64 Кбайт. Все используемые разряды регистров доступны как для чтения, так и для записи в любой момент времени. После сброса микроконтроллера содержимое регистров равно 0, поэтому в самом начале программы указатель стека необходимо проинициализировать каким-либо значением (как правило, это наибольший для конкретного микроконтроллера адрес памяти данных).

# GIMSK, TIMSK, GIFR, TIFR (регистры управления прерываниями)

Эти четыре регистра предназначены для управления внешними прерываниями (регистры GIMSK и GIFR) и прерываниями от таймеров (регистры TIMSK и TIFR). Регистры масок GIMSK (общий регистр маски прерываний) и TIMSK (регистр маски прерываний от таймеров) используются для разрешения/запрещения отдельных прерываний, а регистры флагов GIFR (общий регистр флагов прерываний) и TIFR (регистр флагов прерываний от таймеров) содержат флаги, показывающие, произошло или нет соответствующее прерывание. Подробно эти регистры будут рассмотрены в разделе 4.5 книги, посвященном прерываниям.

# MCUCR (регистр управления микроконтроллером)

Регистр управления микроконтроллером расположен по адресу \$35 (\$55). Этот регистр содержит ряд флагов, используемых для общего управ-

ления микроконтроллером. Состав флагов, размещенных в регистре MCUCR, несколько меняется от модели к модели, соответственно в некоторых моделях некоторые разряды не используются. Неиспользуемые разряды регистра доступны только для чтения и содержат «0». Все используемые разряды регистра доступны как для чтения, так и для записи в любой момент времени. После сброса микроконтроллера во всех разрядах регистра записано «0».

Содержимое этого регистра показано ниже на **Рис. 2.16**, а его описание для разных моделей приведено в **Табл. 2.8...2.10**.

|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        | AT90S1200                    |
|-------------------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|------------------------------|
|                                           | _        | _        | SE       | SM       | _        | _        | ISC01    | ISC00    | AT90S/LS2323                 |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0   | R<br>0   | R/W<br>0 | R/W<br>0 | R<br>0   | R<br>0   | R/W<br>0 | R/W<br>0 | AT90S/LS2343                 |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        | AT90S2313                    |
|                                           | _        | _        | SE       | SM       | ISC11    | ISC10    | ISC01    | ISC00    | AT90S/LS2333                 |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0   | R<br>0   | R/W<br>0 | R/W<br>0 | R/W<br>0 | R/W<br>0 | R/W<br>0 | R/W<br>0 | AT90S/LS4433                 |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |                              |
|                                           | SRE      | SRW      | SE       | SM       | ISC11    | ISC10    | ISC01    | ISC00    | AT90S4414<br>AT90S8515       |
| Чтение(R)/Запись(W)<br>Начальное значение | R/W<br>0 |                              |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |                              |
|                                           | _        | SE       | SM1      | SM0      | ISC11    | ISC10    | ISC01    | ISC00    | AT90S/LS4434<br>AT90S/LS8535 |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0   | R/W<br>0 |                              |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |                              |
|                                           | _        | SE       | SM       | _        | _        | ISC1     | _        | ISC0     | AT90C8534                    |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0   | R/W<br>0 | R/W<br>0 | R<br>0   | R<br>0   | R/W<br>0 | R<br>0   | R/W<br>0 |                              |

*Puc. 2.16.* Регистр управления микроконтроллером MCUCR

*Таблица 2.8.* Регистр MCUCR моделей AT90S1200, AT90S2313, AT90S/LS2323, AT90S/LS2343, AT90S/LS2333, AT90S/LS4433, AT90S4414 и AT90S8515

| Разр. | Назв.           |                                                                          |                                                                                                                                                                                                                                                                                                                              | Описание                                                                                                                | Модель     |  |  |  |  |
|-------|-----------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------|--|--|--|--|
| 7     | SRE             | Разрешен внешнего прещено, руют как пользова                             | AT90S4414<br>AT90S8515                                                                                                                                                                                                                                                                                                       |                                                                                                                         |            |  |  |  |  |
|       | _               | Не испол                                                                 | ьзуется, ч                                                                                                                                                                                                                                                                                                                   | итается как «0».                                                                                                        | Прочие     |  |  |  |  |
| 6     | SRW             | ние к вне<br>ния). Есл<br>машиннь                                        | Режим обращения к внешнему ОЗУ. Если этот разряд установлен в «1», обращение к внешнему ОЗУ выполняется за 4 машинных цикла (с одним циклом ожидания). Если этот разряд сброшен, обращение к внешнему ОЗУ выполняется за 3 машинных цикла. За более полной информацией об использовании внешнего ОЗУ обратитесь к п. 2.2.2.1 |                                                                                                                         |            |  |  |  |  |
|       | _               | Не испол                                                                 | ьзуется, ч                                                                                                                                                                                                                                                                                                                   | итается как «0»                                                                                                         | Прочие     |  |  |  |  |
| 5     | SE              |                                                                          |                                                                                                                                                                                                                                                                                                                              | да в режим пониженного энергопотребления. Если этот разряд<br>о по команде «SLEEP» микроконтроллер переходит в «спящий» | Все модели |  |  |  |  |
| 4     | SM              | Выбор ре<br>деляет, в<br>«SLEEP»<br>«Power Do<br>мацией о                | Все модели                                                                                                                                                                                                                                                                                                                   |                                                                                                                         |            |  |  |  |  |
|       | _               | Не испол                                                                 | Не используются, читаются как «0»                                                                                                                                                                                                                                                                                            |                                                                                                                         |            |  |  |  |  |
|       |                 | Определя                                                                 | ют услови                                                                                                                                                                                                                                                                                                                    | е генерации внешнего прерывания INT1 следующим образом:                                                                 |            |  |  |  |  |
| 3,2   |                 | ISC11                                                                    | ISC10                                                                                                                                                                                                                                                                                                                        | Условие                                                                                                                 |            |  |  |  |  |
| 3,2   |                 | 0                                                                        | 0                                                                                                                                                                                                                                                                                                                            | по НИЗКОМУ уровню на выводе INT1                                                                                        |            |  |  |  |  |
|       | ISC11,<br>ISC10 | 0                                                                        | 1                                                                                                                                                                                                                                                                                                                            | при любом изменении уровня на выводе INT1 (для AT90S2333/4433); зарезервировано для остальных                           | Прочие     |  |  |  |  |
|       |                 | 1                                                                        | 0                                                                                                                                                                                                                                                                                                                            | по спадающему фронту сигнала на выводе INT1                                                                             |            |  |  |  |  |
|       |                 | 1                                                                        | 1                                                                                                                                                                                                                                                                                                                            | по нарастающему фронту сигнала на выводе INT1                                                                           |            |  |  |  |  |
|       |                 | Определяют условие генерации внешнего прерывания INT0 следующим образом: |                                                                                                                                                                                                                                                                                                                              |                                                                                                                         |            |  |  |  |  |
|       |                 | ISC01                                                                    | ISC00                                                                                                                                                                                                                                                                                                                        | Условие                                                                                                                 |            |  |  |  |  |
|       | 10001           | 0                                                                        | 0                                                                                                                                                                                                                                                                                                                            | по НИЗКОМУ уровню на выводе INT0                                                                                        |            |  |  |  |  |
| 1,0   | ISC01,<br>ISC00 | 0                                                                        | 1                                                                                                                                                                                                                                                                                                                            | при любом изменении уровня на выводе INT0 (для AT90S2333/4433); зарезервировано для остальных                           | Все модели |  |  |  |  |
|       |                 | 1                                                                        | 0                                                                                                                                                                                                                                                                                                                            | по спадающему фронту сигнала на выводе INT0                                                                             |            |  |  |  |  |
|       |                 | 1                                                                        | 1                                                                                                                                                                                                                                                                                                                            | по нарастающему фронту сигнала на выводе INT0                                                                           |            |  |  |  |  |

*Таблица 2.9.* Perистр MCUCR моделей AT90S/LS4434 и AT90S/LS8535

| Разр. | Назв.           | Описание                                                                 |                                                                                                                                                                    |                                                                                                                                          |            |  |  |  |
|-------|-----------------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|------------|--|--|--|
| 7     | _               | Не испол                                                                 | Не используется, читается как «0»                                                                                                                                  |                                                                                                                                          |            |  |  |  |
| 6     | SE              |                                                                          | Разрешение перехода в режим пониженного энергопотребления. Если этот разряд установлен<br>з «1», то по команде «SLEEP» микроконтроллер переходит в «спящий» режим. |                                                                                                                                          |            |  |  |  |
|       |                 |                                                                          |                                                                                                                                                                    | иженного энергопотребления. Состояние этих разрядов определяет, в какой кроконтроллер после выполнения команды «SLEEP» (см. раздел 4.3): |            |  |  |  |
|       | CM1             | SM1                                                                      | SM0                                                                                                                                                                | Режим                                                                                                                                    |            |  |  |  |
| 5, 4  | SM1,<br>SM0     | 0                                                                        | 0                                                                                                                                                                  | Idle                                                                                                                                     |            |  |  |  |
|       | Sivio           | 0                                                                        | 1                                                                                                                                                                  | зарезервировано                                                                                                                          |            |  |  |  |
|       |                 |                                                                          | 1                                                                                                                                                                  | 0                                                                                                                                        | Power Down |  |  |  |
|       |                 | 1                                                                        | 1                                                                                                                                                                  | Power Save                                                                                                                               |            |  |  |  |
|       | ISC11,<br>ISC10 | Определяют условие генерации внешнего прерывания INT1 следующим образом: |                                                                                                                                                                    |                                                                                                                                          |            |  |  |  |
|       |                 | ISC11                                                                    | ISC10                                                                                                                                                              | Условие                                                                                                                                  |            |  |  |  |
| 3, 2  |                 | 0                                                                        | 0                                                                                                                                                                  | по НИЗКОМУ уровню на выводе INT1                                                                                                         |            |  |  |  |
| 3, 2  |                 | 0                                                                        | 1                                                                                                                                                                  | зарезервировано                                                                                                                          |            |  |  |  |
|       |                 | 1                                                                        | 0                                                                                                                                                                  | по спадающему фронту сигнала на выводе INT1                                                                                              |            |  |  |  |
|       |                 | 1                                                                        | 1                                                                                                                                                                  | по нарастающему фронту сигнала на выводе INT1                                                                                            |            |  |  |  |
|       |                 | Определя                                                                 | ют услови                                                                                                                                                          | е генерации внешнего прерывания INT0 следующим образом:                                                                                  |            |  |  |  |
|       |                 | ISC01                                                                    | ISC00                                                                                                                                                              | Условие                                                                                                                                  |            |  |  |  |
| 1.0   | ISC01,          | 0                                                                        | 0                                                                                                                                                                  | по НИЗКОМУ уровню на выводе INT0                                                                                                         |            |  |  |  |
| 1, 0  | ISC00           | 0                                                                        | 1                                                                                                                                                                  | зарезервировано                                                                                                                          |            |  |  |  |
|       |                 | 1                                                                        | 0                                                                                                                                                                  | по спадающему фронту сигнала на выводе INT0                                                                                              |            |  |  |  |
|       |                 | 1                                                                        | 1                                                                                                                                                                  | по нарастающему фронту сигнала на выводе INT0                                                                                            |            |  |  |  |

*Таблица 2.10.* Регистр MCUCR модели AT90C8534

| Разр. | Назв. | Описание                                                                                                                                                                                                                                                                                                                                         |
|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | _     | Не используется, читается как «0»                                                                                                                                                                                                                                                                                                                |
| 6     | SE    | Разрешение перехода в режим пониженного энергопотребления. Если этот разряд установлен в «1», то по команде «SLEEP» микроконтроллер переходит в «спящий» режим                                                                                                                                                                                   |
| 5     | SM    | Выбор режима пониженного энергопотребления. Состояние этого разряда определяет,<br>в какой режим перейдет микроконтроллер после выполнения команды «SLEEP». Если этот<br>разряд установлен в «1», «спящим» режимом является режим «Power Down». Если этот<br>разряд сброшен — режим «Idle». За более полной информацией обратитесь к разделу 4.3 |
| 4, 3  | _     | Не используются, читаются как «0»                                                                                                                                                                                                                                                                                                                |
| 2     | ISC1  | Определяет условие генерации внешнего прерывания INT1. Если этот разряд установлен в «1», прерывание генерируется по нарастающему фронту сигнала на выводе INT1. Если этот разряд сброшен, прерывание генерируется по спадающему фронту сигнала на выводе INT1. Генерация прерывания гарантируется для импульсов длительностью не менее 40 нс    |
| 1     | _     | Не используется, читается как «0»                                                                                                                                                                                                                                                                                                                |

*Таблица 2.10* (окончание)

| Разр. | Назв. | Описание                                                                                                                                                                                                                                                                                                                                      |
|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | ISC0  | Определяет условие генерации внешнего прерывания INT0. Если этот разряд установлен в «1», прерывание генерируется по нарастающему фронту сигнала на выводе INT0. Если этот разряд сброшен, прерывание генерируется по спадающему фронту сигнала на выводе INT0. Генерация прерывания гарантируется для импульсов длительностью не менее 40 нс |

#### Примечание:

При изменении состояния разрядов ISC1 и ISC0 возможна ложная генерация соответствующего прерывания. Чтобы этого избежать, рекомендуется следующая последовательность лействий:

- запретить прерывание, соответствующее изменяемому разряду;
- изменить состояние разряда;
- сбросить флаг прерывания;
- разрешить прерывание.

#### MCUSR (регистр состояния микроконтроллера)

Регистр управления микроконтроллером расположен по адресу \$34 (\$54). Этот регистр содержит флаги, состояние которых позволяет определить причину, по которой произошел сброс микроконтроллера. Подробно этот регистр будет рассмотрен в разделе 4.4.

### 2.2.2.4. Способы адресации памяти данных

Все микроконтроллеры AVR семейства Classic, за исключением модели AT90S1200, поддерживают 8 способов адресации для доступа к различным областям памяти данных (РОН, РВВ, ОЗУ). Модель AT90S1200 в связи с отсутствием у нее встроенного ОЗУ и из-за наличия единственного индексного регистра поддерживает только 4 способа адресации из восьми.

В действительности способов адресации всего два: прямая адресация и косвенная. Однако каждый способ адресации имеет несколько разновидностей в зависимости от того, к какой области памяти производится обращение (для прямой адресации) или какие дополнительные действия выполняются над индексным регистром (для косвенной адресации).

На рисунках этого раздела, а также далее в книге, встречается аббревиатура КОП. Эта аббревиатура обозначает часть (или части) слова команды, содержащую значение кода операции.

### Прямая адресация

При прямой адресации адреса операндов содержатся непосредственно в слове команды. В соответствии со структурой памяти данных существуют следующие разновидности прямой адресации: прямая адресация одного РОН, прямая адресация двух РОН, прямая адресация РВВ, прямая адресация ОЗУ.

#### Прямая адресация одного регистра общего назначения

Этот способ адресации используется в командах, оперирующих с одним из регистров общего назначения. При этом адрес регистра-операнда (его номер) содержится в разрядах 8...4 (5 бит) слова команды (см. **Рис. 2.17**).



Рис. 2.17. Прямая адресация одного регистра общего назначения

Примером команд, использующих этот способ адресации, являются команды работы со стеком (PUSH, POP), команды инкремента (INC), декремента (DEC), а также некоторые команды арифметических операций.

#### Прямая адресация двух регистров общего назначения

Этот способ адресации используется в командах, оперирующих одновременно с двумя регистрами общего назначения. При этом адрес регистра-источника содержится в разрядах 9, 3...0 (5 бит), а адрес регистра-приемника в разрядах 8...4 (5 бит) слова команды (см. **Рис. 2.18**).

K командам, использующим этот способ адресации, относятся команда пересылки данных из регистра в регистр (MOV), а также большинство команд арифметических операций.



Рис. 2.18. Прямая адресация двух регистров общего назначения

Здесь необходимо сделать одно замечание. Дело в том, что некоторые команды, имеющие только один регистр-операнд, тем не менее используют рассматриваемый способ адресации. Просто в этом случае источником и приемником является один и тот же регистр. В качестве примера можно привести команду очистки регистра (CLR Rd), которая в действительности выполняет операцию «Исключающее ИЛИ» регистра с самим собой (EOR Rd, Rd).

#### Прямая адресация регистра ввода/вывода

Данный способ адресации используется командами пересылки данных между регистром ввода/вывода и регистровым файлом — IN и OUT. В этом случае адрес регистра ввода/вывода содержится в разрядах 10, 9, 3...0 (6 бит), а адрес POH — в разрядах 8...4 (5 бит) слова команды (см. **Рис. 2.19**).



Рис. 2.19. Прямая адресация регистра ввода/вывода

#### Прямая адресация ОЗУ

Как следует из названия, данный способ используется при обращении ко всему адресному пространству памяти данных. Естественно, этот способ адресации не поддерживается микроконтроллером AT90S1200.

В системе команд микроконтроллеров семейства имеется только две команды, использующие этот способ адресации. Это команды пересылки байта между одним из РОН и ячейкой ОЗУ — LDS и STS. Каждая из этих команд занимает в памяти программ два слова (32 бита). В первом слове содержится код операции и адрес регистра общего назначения (в разрядах с 8-го по 4-й). Во втором слове находится адрес ячейки памяти, к которой происходит обращение (см. **Рис. 2.20**).



Рис. 2.20. Прямая адресация ОЗУ

Еще раз обращаем ваше внимание, что по адресам \$00...\$1F расположен файл регистров общего назначения, а по адресам \$20...\$5F расположены регистры ввода/вывода.

#### Косвенная адресация

При косвенной адресации адрес ячейки памяти (для AT90S1200 — регистра) находится в одном из индексных регистров X, Y и Z. В зависимости от дополнительных манипуляций, которые производятся над содержимым индексного регистра, различают следующие разновидности косвенной адресации: простая косвенная адресация, относительная косвенная адресация, косвенная адресация с преддекрементом и косвенная адресация с постинкрементом.

### Простая косвенная адресация

Сразу отметим, что AT90S1200 поддерживает только этот вид косвенной адресации. При использовании команд простой косвенной адресации обращение производится по адресу (регистра — для AT90S1200, ячейки памяти — для остальных моделей), который находится в индексном регистре (см. **Рис. 2.21**). Никаких действий с содержимым индексного регистра при этом не производится.

Микроконтроллеры поддерживают 6 команд (по 2 для каждого индексного регистра) простой косвенной адресации: LD Rd, X/Y/Z (пересылка байта из O3У в POH) и ST X/Y/Z, Rd (пересылка байта из POH в O3У). Адрес регистра общего назначения содержится в разрядах 8...4 слова команды.



Рис. 2.21. Простая косвенная адресация

#### Относительная косвенная адресация

При использовании команд относительной косвенной адресации адрес ячейки памяти, к которой производится обращение, получается суммированием содержимого индексного регистра (Y или Z) и константы, задаваемой в команде. Другими словами, производится обращение по адресу, указанному в команде, относительно адреса, находящегося в индексном регистре. Иллюстрация данного способа адресации приведена на Рис. 2.22.

Соответственно микроконтроллеры поддерживают 4 команды относительной косвенной адресации (две для регистра Y и две для регистра Z): LDD Rd, Y+q/Z+q (пересылка байта из O3V в POH) и ST Y+q/Z+q, Rr (пересылка байта из POH в O3V). Адрес регистра общего назначения содержится в разрядах 8...4 слова команды, а величина смещения — в разрядах 13, 11, 10, 2...0. Поскольку под значение смещения отводится только 6 бит, оно не может превышать 64.



<sup>\*</sup> Положение разрядов n и а показано условно

Рис. 2.22. Относительная косвенная адресация

#### Косвенная адресация с преддекрементом

При использовании команд косвенной адресации с преддекрементом содержимое индексного регистра сначала увеличивается на 1, а затем производится обращение по полученному адресу (Рис. 2.23).

Микроконтроллеры семейства поддерживают 6 команд (по 2 для каждого индексного регистра) косвенной адресации с преддекрементом: LD Rd, -X/-Y/-Z (пересылка байта из O3У в POH) и ST -X/-Y/-Z, Rd (пересылка байта из POH в O3У). Адрес регистра общего назначения содержится в разрядах 8...4 слова команды.



Рис. 2.23. Косвенная адресация с преддекрементом

### Косвенная адресация с постинкрементом

При использовании команд косвенной адресации с постинкрементом после обращения по адресу, который находится в индексном регистре, содержимое индексного регистра уменьшается на 1 (**Puc. 2.24**).

Микроконтроллеры семейства поддерживают 6 команд (по 2 для каждого индексного регистра) косвенной адресации с постинкрементом: LD Rd, X+/Y+/Z+ (пересылка байта из O3У в POH) и ST X+/Y+/Z+, Rd (пересылка байта из POH в O3У). Адрес регистра общего назначения содержится в разрядах 8...4 слова команды.



Рис. 2.24. Косвенная адресация с постинкрементом

### 2.2.3. Энергонезависимая память данных

Как уже было сказано, микроконтроллеры AVR семейства Classic имеют в своем составе энергонезависимую память (EEPROM). Объем этой памяти колеблется от 64 байт в модели AT90S1200 до 512 байт в старших моделях. EEPROM-память расположена в своем адресном пространстве и так же, как и ОЗУ, организована линейно.

#### 2.2.3.1. Организация доступа

Для обращения к EEPROM-памяти используются три регистра: регистр адреса, регистр данных и регистр управления. Все эти регистры, а также их использование подробно рассматриваются в этом пункте.

#### Регистр адреса

В регистр адреса загружается адрес ячейки, к которой будет производиться обращение. В моделях микроконтроллеров с объемом EEPROM-памяти до 256 байт регистр адреса реализован на одном PBB (регистр ввода/вывода) — EEAR (EEPROM Address Register), расположенном по адресу \$1E (\$3E). В моделях микроконтроллеров с объемом EEPROM-памяти, равным 512 байт, для адресации всего адресного пространства требуется уже девять разрядов, поэтому регистр адреса в них реализован на двух PBB — EEARH (старший байт адреса) и EEARL (младший байт адреса). Эти регистры расположены по адресам \$1F (\$3F) и \$1E (\$3E) соответственно.

Все перечисленные регистры доступны как для записи, так и для чтения. При этом содержимое разрядов 7...1 регистра EEARH, разумеется, игнорируется.

### Регистр данных

Регистр ввода/вывода, являющийся регистром данных EEPROM-памяти, называется EEDR (EEPROM Data Register), а расположен он по адресу \$1D (\$3D). При записи в этот регистр загружаются данные, которые должны быть помещены в EEPROM по адресу, находящемуся в регистре EEAR (регистрах EEARH:EEARL). При чтении в этом регистре находятся данные, считанные из EEPROM по адресу, находящемуся в регистре EEAR (регистрах EEARH:EEARL).

# Регистр управления

Как следует из названия, данный регистр используется для управления доступом к EEPROM-памяти. Этот регистр, который называется EECR

(EEPROM Control Register), расположен по адресу \$1C (\$3C). Разные модели предоставляют неодинаковые возможности по управлению процессами записи/чтения в EEPROM, поэтому состав управляющих разрядов в регистре EECR зависит от конкретной модели микроконтроллера. Содержимое этого регистра показано ниже на **Puc. 2.25**, а его описание приведено в **Табл. 2.11**.



Puc. 2.25. Регистр EECR

*Таблица 2.11.* Регистр EECR

| Разр. | Назв. | Описание                                                                                                                                                                                                                                                                                                                                                                                        |                        |
|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| 74    | _     | Не используются, читаются как «0»                                                                                                                                                                                                                                                                                                                                                               | Все модели             |
| 3     | EERIE | Разрешение прерывания от EEPROM. Данный разряд управляет генерацией прерывания, возникающего при завершении цикла записи в EEPROM. Если этот разряд установлен в «1», прерывания разрешены (если флаг I регистра SREG также установлен в «1»). При сброшенном разряде EEWE (см. далее в таблице) прерывание генерируется постоянно                                                              | AT90S4433<br>AT90S4434 |
|       | _     | Не используется, читается как «0»                                                                                                                                                                                                                                                                                                                                                               | Прочие                 |
|       | _     | Не используется, читается как «0»                                                                                                                                                                                                                                                                                                                                                               | AT90S1200              |
| 2     | EEMWE | Управление разрешением записи в EEPROM. Состояние этого разряда определяет функционирование флага разрешения записи EEWE. Если данный разряд установлен в «1», то при записи в разряд EEWE «1» происходит запись данных в EEPROM. В противном случае установка EEWE в «1» не производит никакого эффекта. После программной установки этот разряд сбрасывается аппаратно через 4 машинных цикла | Прочие                 |
| 1     | EEWE  | Разрешение записи в EEPROM. При установке этого разряда в «1» происходит запись данных в EEPROM (если EEMWE равен «1»)                                                                                                                                                                                                                                                                          | Все модели             |
| 0     | EERE  | Разрешение чтения из EEPROM. После установки этого разряда в «1» выполняется чтение данных из EEPROM. По окончании чтения этот разряд сбрасывается аппаратно                                                                                                                                                                                                                                    | Все модели             |

Таким образом, процедура записи одного байта в EEPROM-память состоит из следующих этапов:

- 1. Дождаться готовности EEPROM к приему новых данных (ждать, пока не сбросится флаг EEWE регистра EECR).
- 2. Загрузить байт данных в регистр EEDR, а требуемый адрес в регистр EEAR (EEARH: EEARL).
- 3. Установить в «1» флаг EEMWE регистра EECR. Причем для выполнения этой операции необходимо в том же машинном цикле записать «0» в разряд EEWE.
- 4. В течение 4 машинных циклов после установки флага EEMWE записать в разряд EEWE регистра EECR лог. «1».

Для микроконтроллера AT90S1200, в регистре EECR которого отсутствует флаг EEMWE, пункты 3 и 4 сводятся к простой установке разряда EEWE. Обратите внимание, что после установки этого разряда в «1» процессор пропускает 2 машинных цикла перед началом выполнения следующей инструкции.

Длительность цикла записи составляет 2...4 мс, в зависимости от напряжения питания микроконтроллера (2 мс при  $V_{\rm CC}$  = 5 B; 4 мс при  $V_{\rm CC}$  = 2.7 B). По окончании цикла записи разряд EEWE аппаратно сбрасывается, после чего программа может начать запись следующего байта.

При записи в EEPROM могут возникнуть некоторые проблемы, вызванные прерываниями:

- 1) При возникновении прерывания между 3-м и 4-м этапами описанной последовательности запись в EEPROM будет сорвана, т.к. за время обработки прерывания флаг EEMWE сбросится в «0».
- 2) Если в подпрограмме обработки прерывания, возникшего во время записи в EEPROM-память, также происходит обращение к ней, то будет изменено содержимое регистров адреса и данных EEPROM. В результате первая запись (прерванная) будет сорвана.

Для избежания описанных проблем настоятельно рекомендуется запрещать все прерывания (сбрасывать бит I регистра SREG) при выполнении пунктов 2...4 описанной выше последовательности.

С учетом сказанного фрагмент программы, осуществляющей запись в EEPROM, выглядит следующим образом (на примере модели AT90S1200):

```
EEWrite:
   sbic
           EECR, EEWE
                            ; ждать, пока флаг EEWE не
   rjmp
           EEWrite
                            ; будет сброшен
   sli
                            ; запретить прерывания
   out
          EEAR,AddrReg
                           ; загрузить адрес (AddrReg - POH)
                            ; загрузить данные (DataReg - POH)
   out
          EEDR, DataReg
           EECR, EEWE
                            ; выдать строб записи в EEPROM
   sbi
   sli
                            ; разрешить прерывания
                            ; (если необходимо)
```

Процедура чтения данных из EEPROM гораздо проще, чем процедура записи. После загрузки требуемого адреса в регистр EEAR (EEARH:EEARL) программа должна установить в «1» разряд EERE регистра EECR. Когда запрошенные данные будут находиться в регистре данных EEDR, произойдет аппаратный сброс этого разряда.

Операция чтения из EEPROM всегда выполняется за один машинный цикл. Кроме того, после установки разряда EERE в «1» процессор пропускает 4 машинных цикла перед началом выполнения следующей инструкции. Поэтому следить в программе за состоянием разряда EERE нет никакой необходимости.

Единственное, на что нужно обратить внимание при чтении из EEP-ROM, — это состояние флага EEWE. Перед выполнением чтения необходимо убедиться, что этот флаг сброшен. В противном случае в результате загрузки в регистры новых значений адреса и данных во время записи в EEPROM, процедура записи будет прервана, а результат этой записи — не определен.

С учетом сказанного фрагмент программы, осуществляющей чтение из EEPROM, выглядит следующим образом (на примере модели AT90S1200):

```
EERead:
sbic EECR, EEWE ; ждать окончания текущей записи
rjmp EERead ; (пока флаг EEWE не станет равным «0»)
out EEDR, AddrReg ; загрузить адрес (AddrReg – POH)
sbi EECR, EERE ; выдать строб чтения из EEPROM
in DataReg, EEDR ; прочитанный байт – в POH DataReg
```

#### 2.2.3.2. Меры предосторожности при работе с EEPROM

К сожалению, у EEPROM-памяти есть один недостаток: во время работы при пониженном напряжении питания хранящиеся в ней данные могут быть повреждены. Это может произойти по двум причинам:

- 1. Обычная процедура записи в EEPROM требует некоторого минимального напряжения питания; если напряжение питания ниже этой величины, запись не может быть выполнена.
- 2. Микроконтроллер сам может выполнять команды некорректно, если напряжение питания будет ниже некоторой величины.

Чтобы избежать повреждения данных, хранящихся в EEPROM, достаточно воспользоваться одним из трех следующих решений:

- 1. Удерживать микроконтроллер в состоянии сброса все время, пока напряжение питания находится ниже нормы. Это решение реализуется внешней схемой защитного сброса, называемой также детектором пониженного напряжения питания (Brown-out Detector). Заметим, что в моделях AT90S/LS2333 и AT90S/LS4433 имеется встроенный детектор пониженного напряжения питания. Более подробно об этом будет рассказано в п. 4.4.4.
- 2. Удерживать микроконтроллер в «спящем» режиме (Power Down), пока напряжение питания находится ниже нормы. Поскольку в этом режиме микроконтроллер не может выполнять никаких команд, такое решение эффективно защищает служебные регистры EEPROM от непреднамеренной записи.
- 3. Хранить константы во FLASH-памяти программ, если они не должны меняться во время работы программы. Микроконтроллер не может самостоятельно производить запись в FLASH-память, соответственно, при понижении напряжения питания ее содержимое не будет повреждено.

# 2.3. Счетчик команд и выполнение программы

# 2.3.1. Функционирование конвейера

Одной из причин, обуславливающих большое быстродействие микроконтроллеров семейства AVR, является использование двухуровневого конвейера при выполнении программы. Работа этого конвейера показана на Рис. 2.26.

Во время первого машинного цикла происходит выборка команды из памяти программ и ее декодирование. Во время второго цикла эта команда выполняется, а параллельно происходит выборка и декодирование вто-



Рис. 2.26. Последовательность выполнения команд в конвейере

рой команды, и так далее. В результате фактическое время выполнения каждой команды получается равным одному машинному циклу. Такое решение позволяет достигать производительности до 1 MIPS на МГц.

Благодаря подключению АЛУ непосредственно к регистровому файлу оно выполняет одну команду (чтение содержимого двух регистров, выполнение операции и запись результата в регистр-приемник) за один такт (машинный цикл), как показано на **Рис. 2.27**.

А вот обращение к внутреннему ОЗУ выполняется за два машинных цикла, как показано на **Рис. 2.28**.

В заключение необходимо отметить, что тактовым сигналом для функционирования микроконтроллеров AVR семейства Classic является непосредственно сигнал от тактового генератора либо внешний сигнал синхронизации. Никакого внутреннего деления частоты для получения системного тактового сигнала не производится.



Рис. 2.27. Функционирование АЛУ



Рис. 2.28. Цикл доступа к внутреннему ОЗУ

# 2.3.2. Задержки в конвейере

Выше была описана последовательность выполнения команд программы в идеальном случае. Однако в действительности очень часто происходит нарушение нормального функционирования конвейера. Наиболее ярким примером команд, вызывающих подобное нарушение, являются команды условного перехода, а также команды типа Test & Skip (проверка и пропуск следующей команды, если результат проверки положительный). В случае истинности условия, проверяемого командой условного перехода, выполнение программы должно быть продолжено с некоторого адреса. А поскольку в конвейере уже произошла выборка команды, расположенной за командой перехода, время выполнения команды перехода увеличивается на один машинный цикл, во время которого происходит выборка команды, расположенной по требуемому адресу.

Во втором случае, при выполнении команд типа Test & Skip, следующая команда не выполняется в случае истинности проверяемого условия. Однако выборка пропускаемой команды уже произошла. Вследствие того, что команда не выполняется, в конвейере образуется «дырка», которая заключается в пропуске одного или двух (в зависимости от пропускаемой команды) машинных циклов. Соответственно команды типа Test & Skip выполняются за один машинный цикл, если результат проверки условия отрицателен, и за два или три цикла, если он положителен.

Аналогично, команды безусловного перехода (RJMP и IJMP), команды вызова подпрограммы (RCALL и ICALL) и команды возврата из подпрограмм (RET и RETI) также изменяют содержимое счетчика команд (PC),

вызывая тем самым переход в памяти программ. В результате выполнения этих команд происходит «разрыв» в работе конвейера, вследствие чего происходит задержка выполнения программы на несколько машинных циклов. Длительность задержки составляет от двух до четырех машинных циклов в зависимости от команды. Для получения более подробной информации обратитесь к описанию команд (глава 3).

По той же причине нарушение нормального функционирования конвейера происходит и при возникновении прерывания. Минимальная задержка при этом составляет 4 машинных цикла.

#### 2.3.3. Счетчик команд

Размер счетчика команд составляет от 9 до 12 разрядов в зависимости от объема адресуемой памяти. При этом счетчик команд недоступен из программы напрямую (как регистр).

При нормальном выполнении программы содержимое счетчика команд автоматически увеличивается на 1 (или на 2, в зависимости от выполняемой команды) в каждом машинном цикле. Этот порядок нарушается при выполнении команд перехода, вызова и возврата из подпрограмм, а также при возникновении прерываний.

После включения питания, а также после сброса микроконтроллера в счетчик программ автоматически загружается значение \$000. Как правило, по этому адресу располагается команда относительного перехода (RJMP) к инициализационной части программы.

При возникновении прерывания в счетчик команд загружается адрес соответствующего вектора прерывания (\$001...\$010). Если прерывания используются в программе, по этим адресам должны размещаться команды относительного перехода к подпрограммам обработки прерываний. В противном случае основная программа может начинаться непосредственно с адреса \$001.

# 2.3.4. Команды типа «проверка/пропуск»

В командах этого типа производится проверка условия, результат которой влияет на выполнение следующей команды. Если условие истинно, следующая команда игнорируется. Например, команда SBRS Rd.b проверяет разряд b регистра Rd и игнорирует следующую команду, если этот разряд равен «1». В действительности переход к следующей инструкции производится увеличением счетчика команд на 1, а пропуск команды требует загрузки нового значения в счетчик команд. Следовательно, когда

проверяемое условие истинно, в конвейере возникает задержка. Длительность задержки зависит от пропускаемой команды и составляет от одного до двух машинных циклов.

### 2.3.5. Команды условного перехода

В этих командах производится проверка условия, результат которой влияет на состояние счетчика команд. Если условие истинно, происходит переход по заданному адресу. Если же условие ложно, выполняется следующая команда.

Команды условного перехода имеют ограничение по области действия. В действительности новое значение счетчика команд получается прибавлением к нему или вычитанием из него некоторого смещения. А поскольку под значение смещения в слове команды отводится всего 7 бит, максимальная величина перехода составляет от -64 до +64 слов.

Так как переход по заданному адресу осуществляется загрузкой нового значения в счетчик команд, то в случае истинности проверяемого условия в конвейере возникает задержка длительностью в один машинный цикл.

# 2.3.6. Команды безусловного перехода

Для безусловного перехода по требуемому адресу в памяти программ используются команды относительного (RJMP) и косвенного (IJMP) переходов, т.к. микроконтроллеры AVR семейства Classic не имеют команды абсолютного перехода (такая команда имеется в микроконтроллерах других семейств, Tiny и Mega). Сразу отметим, что модель AT90S1200 поддерживает только относительную адресацию памяти программ, т.е. в системе команд этой модели отсутствует команда IJMP.

### Относительный переход — команда RJMP

Деятельность команды заключается в изменении содержимого счетчика команд путем прибавления к нему или вычитания из него некоторого значения, являющегося операндом команды, как показано на **Puc. 2.29**.

Следует помнить, что данная команда имеет ограничение по области действия. Так как операнд представляет собой 12-разрядное число, максимальная величина перехода составляет от -2047 до +2048 слов ( $\pm 4$  Кбайт).

В программах в качестве операндов этой команды вместо констант используются метки. Ассемблер сам вычисляет величину перехода и подставляет это значение в слово команды. Проиллюстрируем сказанное следующим примером:

```
срі r16,$42 ; Сравниваем регистр R16 с числом $42
```

brne error ; Переход, если R16 <> \$42

rjmp ok ; Безусловный переход

error:

. . .

ok: nop ; Место перехода по команде RJMP

Поскольку команда относительного перехода изменяет содержимое счетчика команд, она выполняется за 2 машинных цикла.



<sup>\*</sup> Положение разрядов к показано условно

Рис. 2.29. Относительная адресация памяти программ

#### Косвенный переход — команда ІЈМР

В результате выполнения этой команды программа продолжает выполняться с адреса, находящегося в индексном регистре Z. Таким образом, деятельность команды сводится к загрузке содержимого индексного регистра в счетчик команд.

В отличие от команды относительного перехода данная команда не имеет ограничений по области действия. Действительно, поскольку индексный регистр 16-разрядный, максимально возможная величина перехода составляет 64 Кслов (128 Кбайт), а наибольший объем памяти программ микроконтроллеров семейства — всего 8 Кбайт.

Как и команда относительного перехода, команда косвенного перехола выполняется за 2 машинных пикла.

#### 2.3.7. Команды вызова подпрограмм

С командами вызова подпрограмм в микроконтроллерах AVR семейства Classic дело обстоит так же, как и с командами безусловного перехода. Для вызова подпрограмм имеется две команды: команда относительного вызова (RCALL) и команда косвенного вызова (ICALL). В системе команд модели AT90S1200, разумеется, присутствует только команда RCALL.

#### Относительный вызов подпрограммы — команда RCALL

Если не принимать во внимание некоторые отличия, описанные ниже, эта команда работает так же, как и команда относительного безусловного перехода  ${\tt RJMP}.$ 

Команда RCALL сохраняет в стеке значение счетчика команд. Затем содержимое счетчика команд увеличивается или уменьшается на некоторое значение, являющееся операндом команды (см. **Рис. 2.29**). Поскольку операнд представляет собой 12-разрядное число, максимальная величина перехода составляет от -2047 до +2048 слов ( $\pm 4$  Кбайт).

В программах в качестве операндов этой команды, как и в случае команды RJMP, используются метки. Ассемблер сам вычисляет величину перехода и подставляет это значение в слово команды.

Команда относительного вызова подпрограмм выполняется за 3 машинных цикла, два из которых затрачиваются на сохранение в стеке двух байт счетчика команд.

#### Косвенный вызов подпрограммы — команда ICALL

Если не принимать во внимание некоторые отличия, описанные ниже, эта команда работает так же, как и команда косвенного безусловного перехода IJMP.

Команда ICALL сохраняет в стеке значение счетчика команд. Затем в счетчик команд загружается содержимое индексного регистра. Поскольку индексный регистр 16-разрядный, максимально возможная величина перехода составляет 64 Кслов (128 Кбайт). Поэтому данная команда не имеет ограничений по области действия, т.к. наибольший объем памяти программ микроконтроллеров семейства — всего 8 Кбайт.

Как и команда RCALL, команда косвенного вызова подпрограмм выполняется за 3 машинных цикла.

#### 2.3.8. Команды возврата из подпрограмм

В конце каждой подпрограммы обязательно должна находиться команда возврата из нее. В системе команд микроконтроллеров семейства имеется две таких команды. Для возврата из обычной подпрограммы, вызываемой командами RCALL и ICALL, используется команда RET. Для возврата из подпрограммы обработки прерывания используется команда RETI.

Обе команды восстанавливают из стека содержимое счетчика команд, сохраненное там перед переходом к подпрограмме. Команда возврата из подпрограммы RETI дополнительно устанавливает в «1» флаг общего разрешения прерываний I регистра SREG, сбрасываемый аппаратно при возникновении прерывания.

На выполнение каждой из команд возврата из подпрограммы требуется 4 машинных цикла.

#### 2.4. Стек

Как известно, существует две разновидности стека — аппаратный стек и программный стек. В микроконтроллерах AVR семейства Classic встречаются обе разновидности стека (в зависимости от модели). В самом младшем представителе семейства, микроконтроллере AT90S1200, стек реализован аппаратно, а во всех остальных моделях — программно.

### 2.4.1. Стек в микроконтроллере АТ90S1200

В микроконтроллере AT90S1200 стек реализован аппаратно. Глубина стека равна трем уровням, а размер равен размеру счетчика команд (9 разрядов). Стек расположен в собственной области памяти и имеет организацию LIFO (значение, записанное последним, будет прочитано первым).

При вызове подпрограмм адрес команды, расположенной за командой RCALL, сохраняется в стеке. При возврате из подпрограммы этот адрес извлекается из стека и загружается в счетчик команд. То же происходит и во время прерывания. При генерации прерывания адрес следующей команды сохраняется в стеке, а при возврате из подпрограммы обработки прерывания он восстанавливается из стека.

Непосредственно из программы стек недоступен, т.к. в наборе команд микроконтроллера отсутствуют команды занесения в стек и извлечения из стека. Указатель стека также недоступен из программы, т.е. он не может быть явно прочитан или модифицирован. Поэтому микроконтроллер сам

управляет перемещением данных по стеку. Чтобы лучше понять работу стека, обратитесь к Рис. 2.30 и 2.31.

Рассмотрим выполнение команды RCALL (**Рис. 2.30**): содержимое счетчика команд пересылается на 1-й уровень стека, а предыдущие значения предварительно «сползают» на один уровень (значение, находившееся на первом уровне, перемещается на второй уровень и т.д.). Заметим, что в результате этой операции будет потеряно значение, расположенное на 3-м уровне стека.

При выполнении команды возврата из подпрограммы RET или RETI (**Puc. 2.31**) значение, хранящееся на 1-м уровне стека, заносится в счетчик команд. Во время этой операции все значения «поднимаются» на один уровень вверх (значение, находившееся на втором уровне, перемещается на первый уровень и т.д.). При этом значение, находящееся на 3-м уровне, остается неизменным.



Puc. 2.30. Работа стека при выполнении команды CALL



Рис. 2.31. Работа стека при выполнении команды RET

#### 2. Архитектура микроконтроллеров семейства Classic

#### 2.4.2. Стек в старших моделях микроконтроллеров

Во всех моделях микроконтроллеров, за исключением AT90S1200, используется программный стек. В этом случае стек размещается в памяти данных, и его глубина определяется только размером свободной области памяти программ. В зависимости от объема памяти данных в качестве указателя стека используется либо один регистр ввода/вывода SPL, расположенный по адресу \$3D (\$5D), либо пара регистров SPH:SPL, расположенных по адресам \$3E (\$5E) и \$3D (\$5D) соответственно (см. Табл. 2.2...2.5).

Регистры — указатели стека являются обычными регистрами ввода/вывода и, соответственно, полностью доступны из программы. Кроме того, в наборе команд микроконтроллеров имеются команды занесения в стек (PUSH) и извлечения из стека (POP), что позволяет программе использовать стек для своих нужд. Так как после подачи напряжения питания (или после сброса) указатель стека равен нулю, в самом начале программы его необходимо проинициализировать, записав в него значение верхнего адреса памяти данных.

При вызове подпрограмм адрес команды, расположенной за командой RCALL или ICALL, сохраняется в стеке. Значение указателя стека при этом уменьшается на 2, т.к. для хранения счетчика команд требуется 2 байта. При возврате из подпрограммы этот адрес извлекается из стека и загружается в счетчик команд. Значение указателя стека соответственно увеличивается на 2. То же происходит и во время прерывания. При генерации прерывания адрес следующей команды сохраняется в стеке, а при возврате из подпрограммы обработки прерывания он восстанавливается из стека.

# Глава 3. **Система КОМАНД**

# 3.1. Общие сведения

Микроконтроллеры AVR семейства Classic являются микроконтроллерами с RISC-архитектурой. Основным преимуществом этой архитектуры является увеличение быстродействия за счет сокращения количества операций обмена с памятью программ. В соответствии с этим принципом в микроконтроллерах AVR практически все команды занимают одну ячейку памяти. Исключение составляют команды, у которых одним из операндов является 16-разрядный адрес программ. Причем такой результат достигнут не за счет сокращения количества команд процессора, а за счет увеличения разрядности памяти программ до 16.

Большинство команд выполняется за один машинный цикл.

# 3.2. Операнды

Программа для любого микроконтроллера представляет собой последовательность команд, записанных в памяти программ. Большинство команд при выполнении изменяют содержимое одного или нескольких регистров общего назначения, регистров ввода/вывода или ячеек ОЗУ.

Для обращения к различным областям адресного пространства памяти данных используются различные команды, реализующие, в свою очередь, различные способы адресации. Подробно способы адресации памяти данных были рассмотрены в главе 2.

Доступ к регистрам ввода/вывода осуществляется по их адресам, являющимся операндами команды. Вместе с тем при написании ассемблерных программ гораздо удобнее обращаться к регистрам, используя вместо числовых значений адресов их стандартные символические имена, принятые

в фирменной документации. Чтобы задать соответствие этих имен реальным адресам, необходимо подключить в начале программы (при помощи директивы ассемблера . INCLUDE) файл определения адресов регистров ввода/вывода. Такой подход позволяет облегчить перенос программного обеспечения с одного типа кристалла на другой.

Эти файлы (для каждой модели микроконтроллеров семейства) свободно распространяются фирмой «Atmel» вместе с документацией на микроконтроллеры (в частности, они находятся на Web-сайте фирмы). Для РОН, входящих в состав индексных регистров, в этих файлах определяются также дополнительные символические имена (см. Табл. 3.1).

| Регистр | Символическое имя |  |
|---------|-------------------|--|
| R26     | XL                |  |
| R27     | XH                |  |
| R28     | YL                |  |
| R29     | YH                |  |
| R30     | ZL                |  |
| R31     | 7.H               |  |

Таблица 3.1. Дополнительные символические имена индексных регистров

#### Примечание:

Для AT90S1200 определены только два регистра-указателя: R30 — ZL и R31 — ZH.

Названия этих включаемых файлов унифицированы и определяются следующим образом:

<номер модели>def.inc

Например, программа для микроконтроллера AT90S8515 должна содержать следующую директиву ассемблера:

.include "8515def.inc"

Необходимо только помнить, что если для обращения к регистру ввода/вывода используются команды обмена с ОЗУ, то к символическому имени требуется прибавить число \$20.

Как уже было упомянуто, в микроконтроллерах семейства память программ является 16-разрядной. Соответственно большинство команд описывается 16-разрядным словом, которое называется также кодом операции (КОП). Код операции — это число, расположенное в памяти программ и определяющее действие, которое необходимо произвести между источником и приемником. Ряд команд, у которых один из операндов является 16-разрядным адресом, занимает две ячейки памяти программ. Соответственно код операции таких команд является 4-байтным числом.

В ряде случаев значение операнда-источника может содержаться непосредственно в коде операции, а не в регистре. Это происходит в том случае, когда операндом-источником является непосредственное значение (константа). Использование констант позволяет повысить удобочитаемость программы, а также упростить ее отладку и дальнейшее развитие. В упомянутых включаемых файлах описано несколько констант, которые могут быть полезны при написании программ:

RAMEND — значение верхнего адреса внутреннего ОЗУ (для AT90S1200 эта константа не определена);
 XRAMEND — значение верхнего адреса внешнего ОЗУ (для всех

моделей, кроме AT90S4414 и AT90S8515, эта

константа равна нулю);

=2 END — значение верхнего адреса EEPROM;

FLASHEND — значение верхнего адреса памяти программ.

# 3.3. Типы команд

Все множество команд микроконтроллеров AVR семейства Classic можно разбить на несколько групп:

- команды логических операций;
- команды арифметических операций и команды сдвига;
- команды операций с битами;
- команды пересылки данных;
- команды передачи управления;
- команды управления системой.

Каждая группа подробно описана в следующих параграфах.

#### 3.3.1. Команды логических операций

Эти команды позволяют выполнять стандартные логические операции над байтами, такие как «логическое умножение» (И), «логическое сложение» (ИЛИ), операцию «исключающее ИЛИ», а также вычисление обратного и дополнительного кодов числа. К этой группе можно отнести также команды очистки/установки регистров и команду перестановки тетрад. Все операции производятся над регистрами общего назначения, результат сохраняется в одном из РОН. Все логические операции выполняются за один машинный цикл.

# 3.3.2. Команды арифметических операций и команды сдвига

К данной группе относятся команды, выполняющие такие базовые операции, как сложение, вычитание, сдвиг (вправо и влево), инкремент и декремент. Все операции производятся только над регистрами общего назначения. При этом микроконтроллеры AVR позволяют легко оперировать как знаковыми, так и беззнаковыми числами, а также работать с числами, представленными в дополнительном коде.

Все команды рассматриваемой группы выполняются за один машинный цикл, за исключением команд, оперирующих двухбайтовыми значениями, которые выполняются за два цикла.

#### 3.3.3. Команды операций с битами

К данной группе относятся команды, выполняющие установку или сброс заданного разряда РОН или PBB. Причем для изменения состояния разрядов регистра состояния SREG имеются также дополнительные команды (точнее, эквивалентные мнемонические обозначения общих команд), т.к. проверка состояния разрядов именно этого регистра производится чаще всего. Условно к этой группе можно отнести также две команды передачи управления типа «проверка/пропуск», которые пропускают следующую команду в зависимости от состояния разряда РОН или РВВ.

Все задействованные разряды PBB имеют свои символические имена. Определения этих имен описаны в том же включаемом файле, что и определения символических имен адресов регистров (см. параграф 3.2). Таким образом, после включения в программу указанного файла в командах вместо числовых значений номеров разрядов можно будет указывать их символические имена.

Следует помнить, что в командах CBR и SBR операндом является битовая маска, а не номер разряда. Для получения битовой маски из номера разряда следует воспользоваться ассемблерным оператором «сдвиг влево» (<<), как показано в следующем примере:

```
sbr r16,(1<<SE)+(1<<SM) out MCUCR,r16 ; Установить флаги SE и SM ; регистра MCUCR
```

Следует обратить внимание, что приоритет оператора «+» выше, чем оператора «<<», для получения требуемого результата слагаемые заключены в скобки.

Всем командам данной группы требуется один машинный цикл для выполнения, за исключением случаев, когда в результате проверки происходит пропуск команды. В этом случае команда выполняется за два или три машинных цикла в зависимости от пропускаемой команды.

#### 3.3.4. Команды пересылки данных

Команды этой группы предназначены для пересылки содержимого ячеек, находящихся в адресном пространстве памяти данных. Разделение адресного пространства на три части (РОН, РВВ, ОЗУ) предопределило разнообразие команд данной группы. Пересылка данных, выполняемая командами группы, может производиться в следующих направлениях:

- POH ⇔ POH;
- POH ⇔ PBB;
- РОН  $\Leftrightarrow$  память данных (3 вида адресации).

Также к данной группе можно отнести стековые команды PUSH и POP (отсутствуют в AT90S1200), позволяющие сохранять в стеке и восстанавливать из стека содержимое POH.

На выполнение команд данной группы требуется от одного до трех машинных циклов в зависимости от команды.

#### 3.3.5. Команды передачи управления

В эту группу входят команды перехода, вызова подпрограмм и возврата из них и команды типа «проверка/пропуск», пропускающие следующую за ними команду при выполнении некоторого условия. Также к этой группе относятся команды сравнения, формирующие флаги регистра SREG и предназначенные, как правило, для работы совместно с командами условного перехода.

В системе команд микроконтроллеров семейства имеются команды как безусловного, так и условного переходов. Команды косвенного (ІЈМР) и относительного (RJMP) безусловного перехода являются самыми простыми в этой группе. Их функция заключается только в записи нового адреса в счетчик команд. Команды условного перехода также изменяют содержимое счетчика команд, однако это изменение происходит только при выполнении некоторого условия или, точнее, при определенном состоянии различных флагов регистра SREG.

Все команды условного перехода можно разбить на две подгруппы. Первая подгруппа — команды условного перехода общего назначения. В эту подгруппу входят две команды BRBS  $\,$ s ,  $\,$ k и BRBC  $\,$ s ,  $\,$ k, в которых явно задается номер тестируемого флага регистра SREG. Соответственно переход осуществляется при SREG.s = 0 (BRBC) или SREG.s = 1 (BRBS). Другую подгруппу составляют 18 специализированных команд, каждая из которых выполняет переход по какому-либо конкретному условию («равно», «больше или равно», «был перенос» и т.п.). Причем одни команды используются после сравнения беззнаковых чисел, другие — после сравнения чисел со знаком. Возможные проверяемые условия, а также соответствующие им команды условного перехода приведены в **Табл. 3.2**.

Таблица 3.2. Сводная таблица команд условного перехода

| Проверка            | Логич.<br>условие            | Команда   | Обратная<br>проверка    | Логич.<br>условие            | Команда   | Тип<br>данных |
|---------------------|------------------------------|-----------|-------------------------|------------------------------|-----------|---------------|
| Rd > Rr             | $Z \bullet (N \oplus V) = 0$ | BRLT*     | Rd = Rr                 | $Z + (N \oplus V) = 1$       | BRGE*     | Со знаком     |
| Rd = Rr             | $(N \oplus V) = 0$           | BRGE      | Rd < Rr                 | $(N \oplus V) = 1$           | BRLT      | Со знаком     |
| Rd = Rr             | Z = 1                        | BREQ      | Rd ≠ Rr                 | Z = 0                        | BRNE      | Со знаком     |
| Rd = Rr             | $Z + (N \oplus V) = 1$       | BRGE*     | Rd > Rr                 | $Z \bullet (N \oplus V) = 0$ | BRLT*     | Со знаком     |
| Rd < Rr             | (N ⊕ V) = 1                  | BRLT      | Rd = Rr                 | $(N \oplus V) = 0$           | BRGE      | Со знаком     |
| Rd > Rr             | C + Z = 0                    | BRLO*     | Rd = Rr                 | C + Z = 1                    | BRSH*     | Без знака     |
| Rd = Rr             | C = 0                        | BRHS/BRCC | Rd < Rr                 | C = 1                        | BRLO/BRCS | Без знака     |
| Rd = Rr             | Z = 1                        | BREQ      | Rd ≠ Rr                 | Z = 0                        | BRNE      | Без знака     |
| Rd = Rr             | C = Z = 1                    | BRSH*     | Rd > Rr                 | C = Z = 0                    | BRLO*     | Без знака     |
| Rd < Rr             | C = 1                        | BRLO/BRCS | Rd = Rr                 | C = 0                        | BRSH/BRCC | Без знака     |
| «Перенос»           | C = 1                        | BRCS      | «Нет переноса»          | C = 0                        | BRCC      | _             |
| «Меньше<br>нуля»    | N = 1                        | BRMI      | «Больше нуля»           | N = 0                        | BRPL      | _             |
| «Переполне-<br>ние» | V = 1                        | BRVS      | «Нет переполне-<br>ния» | V = 0                        | BRVC      | -             |
| «Ноль»              | Z = 1                        | BREQ      | «Не ноль»               | Z = 0                        | BRNE      | _             |

<sup>\*</sup> Для перехода по этому условию операнды предшествующей команды сравнения должны быть записаны в обратном порядке, т.е. вместо CP Rd, Rr  $\rightarrow$  CP Rr, Rd.

Команды, указанные в **Табл. 3.2**, являются всего лишь эквивалентными мнемоническими обозначениями команд BRBS s, k и BRBC s, k c определенными значениями операнда s. Команда BREQ k имеет, например, такой же код операции, что и команда BRBS 1, k, а команда BRGE k— такой же, что и BRBC 4, k.

Команды вызова подпрограммы (ICALL, RCALL) работают практически так же, как и команды безусловного перехода. Отличие заключается в том, что перед тем как выполнить переход, значение счетчика команд сохраняется в стеке. Кроме того, подпрограмма должна заканчиваться командой возврата RET, как показано в следующем примере:

```
rcall sp_test ; вызов подпрограммы «sp_test»
... ; текст основной программы
...
sp_test ; метка подпрограммы
push r2 ; сохранить r2 в стеке
... ; выполнение подпрограммы
...
pop r2 ; восстановить r2 из стека
ret ; возврат из подпрограммы
```

В приведенном выше примере команда RET заменяет адрес, находящийся в счетчике команд, адресом команды, следующей за командой CALL.

Очевидно, что команды передачи управления нарушают нормальное (линейное) выполнение основной программы. Каждый раз, когда выполняется команда из этой группы (кроме команд сравнения), нормальное функционирование конвейера нарушается. Перед загрузкой в конвейер нового адреса производятся остановка и очистка выполняемой последовательности команд. Соответственно реинициализация конвейера приводит к необходимости использования нескольких машинных циклов для выполнения таких команд. Чтобы получить более точную информацию, обратитесь к таблицам, приведенным в разделе 3.4.

# 3.3.6 Команды управления системой

В эту группу входят всего 3 команды:

• NOP — пустая команда;

- SLEEP перевод микроконтроллера в режим пониженного энергопотребления;
  - WDR сброс сторожевого таймера

Команды NOP и WDR выполняются за один машинный цикл, а команда SLEEP — за четыре машинных цикла.

#### 3.4. Сводные таблицы команд

В Табл. 3.3...3.8 указаны все команды, которыми располагают микроконтроллеры AVR семейства Classic. В каждой таблице команды сгруппированы по функциональному признаку. В таблицах приведены такие основные сведения о командах, как мнемоническое обозначение команды, ее описание, число машинных циклов, необходимых для ее выполнения, а также флаги регистра SREG, на которые воздействует эта команда. Информация в таблицах изложена в сжатом виде, а детальное описание всех команд приведено в разделе 3.5.

Необходимо сказать несколько слов о микроконтроллере AT90S1200. Дело в том, что эта модель поддерживает только 89 команд из 118, входящих в систему команд микроконтроллеров семейства. В таблицах команды, не поддерживаемые микроконтроллером AT90S1200, выделены серым цветом.

| Таблица 3.3. | Группа | команд логических | операций |
|--------------|--------|-------------------|----------|
|--------------|--------|-------------------|----------|

| Мнемоника | Описание                                              | Операция                            | Циклы | Флаги     |
|-----------|-------------------------------------------------------|-------------------------------------|-------|-----------|
| AND Rd,Rr | «Логическое И» двух РОН                               | Rd = Rd • Rr                        | 1     | Z,N,V     |
| ANDI Rd,K | «Логическое И» РОН и константы                        | Rd = Rd • K                         | 1     | Z,N,V     |
| EOR Rd,Rr | «Исключающее ИЛИ» двух РОН                            | $Rd = Rd \oplus Rr$                 | 1     | Z,N,V     |
| OR Rd,Rr  | «Логическое ИЛИ» двух РОН                             | $Rd = Rd \vee Rr$                   | 1     | Z,N,V     |
| ORI Rd,K  | «Логическое ИЛИ» РОН и константы                      | $Rd = Rd \vee K$                    | 1     | Z,N,V     |
| COM Rd    | Перевод в обратный код                                | Rd = FF - Rd                        | 1     | Z,C,N,V   |
| NEG Rd    | Перевод в дополнительный код                          | Rd = \$00 - Rd                      | 1     | Z,C,N,V,H |
| CLR Rd    | Сброс всех разрядов РОН                               | $Rd = Rd \oplus Rd$                 | 1     | Z,N,V     |
| SER Rd    | Установка всех разрядов РОН                           | Rd = \$FF                           | 1     | _         |
| TST Rd    | Проверка РОН на отрицательное<br>или нулевое значение | Rd • Rd                             | 1     | Z,N,V     |
| SWAP Rd   | Обмен местами тетрад в РОН                            | Rd(30) = Rd(74),<br>Rd(74) = Rd(30) | 1     | _         |

Таблица 3.4. Группа команд арифметических операций

| Мнемоника | Описание                                | Операция                                | Циклы | Флаги     |
|-----------|-----------------------------------------|-----------------------------------------|-------|-----------|
| ADD Rd,Rr | Сложение двух РОН                       | Rd = Rd + Rr                            | 1     | Z,C,N,V,H |
| ADC Rd,Rr | Сложение двух РОН с переносом           | Rd = Rd + Rr + C                        | 1     | Z,C,N,V,H |
| ADIW Rd,K | Сложение регистровой пары с константой  | Rdh:Rdl = Rdh:Rdl + K                   | 2     | Z,C,N,V,S |
| SUB Rd,Rr | Вычитание двух РОН                      | Rd = Rd - Rr                            | 1     | Z,C,N,V,H |
| SUBI Rd,K | Вычитание константы из РОН              | Rd = Rd - K                             | 1     | Z,C,N,V,H |
| SBC Rd,Rr | Вычитание двух РОН с заемом             | Rd = Rd - Rr - C                        | 1     | Z,C,N,V,H |
| SBCI Rd,K | Вычитание константы из РОН с заемом     | Rd = Rd - K - C                         | 1     | Z,C,N,V,H |
| SBIW Rd,K | Вычитание константы из регистровой пары | Rdh:Rdl = Rdh:Rdl - K                   | 2     | Z,C,N,V,S |
| DEC Rd    | Декремент РОН                           | Rd = Rd - 1                             | 1     | Z,N,V     |
| INC Rd    | Инкремент РОН                           | Rd = Rd + 1                             | 1     | Z,N,V     |
| ASR Rd    | Арифметический сдвиг вправо             | Rd(n) = Rd(n+1), n=06                   | 1     | Z,C,N,V   |
| LSL Rd    | Логический сдвиг влево                  | Rd(n+1) = Rd(n), Rd(0) = 0              | 1     | Z,C,N,V   |
| LSR Rd    | Логический сдвиг вправо                 | Rd(n) = Rd(n+1), $Rd(7) = 0$            | 1     | Z,C,N,V   |
| ROL Rd    | Сдвиг влево через перенос               | Rd(0) = C, Rd(n+1) = Rd(n), $C = Rd(7)$ | 1     | Z,C,N,V   |
| ROR Rd    | Сдвиг вправо через перенос              | Rd(7) = C, Rd(n) = Rd(n+1), $C = Rd(0)$ | 1     | Z,C,N,V   |

Таблица 3.5. Группа команд операций с разрядами

| Мнемоника | Описание                               | Операция                     | Циклы | Флаги  |
|-----------|----------------------------------------|------------------------------|-------|--------|
| CBR Rd,K  | Сброс разряда(ов) РОН                  | $Rd = Rd \bullet (\$FF - K)$ | 1     | Z, N,V |
| SBR Rd,K  | Установка разряда(ов) РОН              | $Rd = Rd \vee K$             | 1     | Z, N,V |
| CBI A,b   | Сброс разряда РВВ                      | A.b = 0                      | 2     | _      |
| SBI A,b   | Установка разряда РВВ                  | A.b = 1                      | 2     | _      |
| BCLR s    | Сброс флага                            | SREG.s = 0                   | 1     | SREG.s |
| BSET s    | Установка флага                        | SREG.s = 1                   | 1     | SREG.s |
| BLD Rd,b  | Загрузка разряда РОН из флага Т (SREG) | Rd.b = T                     | 1     | _      |
| BST Rr,b  | Запись разряда РОН в флаг Т (SREG)     | T = Rr.b                     | 1     | T      |
| CLC       | Сброс флага переноса                   | C = 0                        | 1     | С      |
| SEC       | Установка флага переноса               | C = 1                        | 1     | С      |
| CLN       | Сброс флага отр. числа                 | N = 0                        | 1     | N      |
| SEN       | Установка флага отр. числа             | N = 1                        | 1     | N      |
| CLZ       | Сброс флага нуля                       | Z = 0                        | 1     | Z      |
| SEZ       | Установка флага нуля                   | Z = 1                        | 1     | Z      |
| CLI       | Общее запрещение прерываний            | I = 0                        | 1     | I      |
| SEI       | Общее разрешение прерываний            | I = 1                        | 1     | I      |

Таблица 3.5 (окончание)

| Мнемоника | Описание                               | Операция | Циклы | Флаги |
|-----------|----------------------------------------|----------|-------|-------|
| CLS       | Сброс флага знака                      | S = 0    | 1     | S     |
| SES       | Установка флага знака                  | S = 1    | 1     | S     |
| CLV       | Сброс флага переполнения доп. кода     | V = 0    | 1     | V     |
| SEV       | Установка флага переполнения доп. кода | V = 1    | 1     | V     |
| CLT       | Сброс флага Т                          | T = 0    | 1     | T     |
| SET       | Установка флага Т                      | T = 1    | 1     | T     |
| CLH       | Сброс флага половинного переноса       | H = 0    | 1     | Н     |
| SEH       | Установка флага половинного переноса   | H = 1    | 1     | Н     |

Таблица 3.6. Группа команд пересылки данных

| Мнемоника  | Описание                           | Операция              | Циклы | Флаги |
|------------|------------------------------------|-----------------------|-------|-------|
| MOV Rd,Rr  | Пересылка между РОН                | Rd = Rr               | 1     | _     |
| LDI Rd,K   | Загрузка константы в РОН           | Rd = K                | 1     | -     |
| LD Rd,X    | Косвенное чтение                   | Rd = [X]              | 2     | _     |
| LD Rd,X+   | Косвенное чтение с постинкрементом | Rd = [X], X = X + 1   | 2     | _     |
| LD Rd,-X   | Косвенное чтение с преддекрементом | X = X - 1, $Rd = [X]$ | 2     | _     |
| LD Rd,Y    | Косвенное чтение                   | Rd = [Y]              | 2     | _     |
| LD Rd,Y+   | Косвенное чтение с постинкрементом | Rd = [Y], Y = Y + 1   | 2     | _     |
| LD Rd,-Y   | Косвенное чтение с преддекрементом | Y = Y - 1, $Rd = [Y]$ | 2     | _     |
| LDD Rd,Y+q | Косвенное относительное чтение     | Rd = [Y+q]            | 2     | _     |
| LD Rd,Z    | Косвенное чтение                   | Rd = [Z]              | 2     | _     |
| LD Rd,Z+   | Косвенное чтение с постинкрементом | Rd = [Z], Z = Z + 1   | 2     | _     |
| LD Rd,-Z   | Косвенное чтение с преддекрементом | Z = Z - 1, $Rd = [Z]$ | 2     | _     |
| LDD Rd,Z+q | Косвенное относительное чтение     | Rd = [Z+q]            | 2     | _     |
| LDS Rd,k   | Непосредственное чтение из ОЗУ     | Rd = [k]              | 2     | _     |
| ST X,Rr    | Косвенная запись                   | [X] = Rr              | 2     | _     |
| ST X+,Rr   | Косвенная запись с постинкрементом | [X] = Rr, X = X + 1   | 2     | _     |
| ST -X,Rr   | Косвенная запись с преддекрементом | X = X - 1, [X] = Rr   | 2     | _     |
| ST Y,Rr    | Косвенная запись                   | [Y] = Rr              | 2     | _     |
| ST Y+,Rr   | Косвенная запись с постинкрементом | [Y] = Rr, Y = Y + 1   | 2     | _     |
| ST -Y,Rr   | Косвенная запись с преддекрементом | Y = Y - 1, [X] = Rr   | 2     | _     |
| STD Y+q,Rr | Косвенная относительная запись     | [Y+q] = Rr            | 2     | _     |
| ST Z,Rr    | Косвенная запись                   | [Z] = Rr              | 2     | _     |
| ST Z+,Rr   | Косвенная запись с постинкрементом | [Z] = Rr, Z = Z + 1   | 2     | _     |
| ST -Z,Rr   | Косвенная запись с преддекрементом | Z = Z - 1, [Z] = Rr   | 2     | _     |
| STD Z+q,Rr | Косвенная относительная запись     | [Z+q] = Rr            | 2     | _     |
| STS k,Rr   | Непосредственная запись в ОЗУ      | [k] = Rr              | 2     | _     |

Таблица 3.6 (окончание)

| Мнемоника | Описание                           | Операция     | Циклы | Флаги |
|-----------|------------------------------------|--------------|-------|-------|
| LPM       | Загрузка данных из памяти программ | $R0 = \{Z\}$ | 3     | _     |
| IN Rd,A   | Пересылка из РВВ в РОН             | Rd = A       | 1     | _     |
| OUT A,Rr  | Пересылка из РОН в РВВ             | A = Rr       | 1     | _     |
| PUSH Rr   | Сохранение байта в стеке           | STACK = Rr   | 2     | _     |
| POP Rd    | Извлечение байта из стека          | Rd = STACK   | 2     | _     |

Таблица 3.7. Группа команд передачи управления

| Мнемоника  | Описание                                             | Операция                               | Циклы | Флаги     |
|------------|------------------------------------------------------|----------------------------------------|-------|-----------|
| RJMP k     | Относительный безусловный переход                    | PC = PC + k + 1                        | 2     | _         |
| IJMP       | Косвенный безусловный переход                        | PC = Z                                 | 2     | _         |
| RCALL      | Относительный вызов подпрограммы                     | PC = PC + k + 1                        | 3     | _         |
| ICALL      | Косвенный вызов подпрограммы                         | PC = Z                                 | 3     | _         |
| RET        | Возврат из подпрограммы                              | PC = STACK                             | 4     | _         |
| RETI       | Возврат из подпрограммы обработки прерывания         | PC = STACK                             | 4     | I         |
| CP Rd,Rr   | Сравнение РОН                                        | Rd – Rr                                | 1     | Z,N,V,C,H |
| CPC Rd,Rr  | Сравнение РОН с учетом переноса                      | Rd - Rr - C                            | 1     | Z,N,V,C,H |
| CPI Rd,K   | Сравнение РОН с константой                           | Rd – K                                 | 1     | Z,N,V,C,H |
| CPSE Rd,Rr | Сравнение и пропуск следующей команды при равенстве  | Если Rd = Rr,<br>то PC = PC + 2 (3)    | 1/2/3 | _         |
| SBRC Rr,b  | Пропуск след. команды, если разряд РОН сброшен       | Если Rr.b = 0,<br>то PC = PC + 2 (3)   | 1/2/3 | _         |
| SBRS Rr,b  | Пропуск след. команды, если разряд РОН установлен    | Если Rr.b = 1,<br>то PC = PC + 2 (3)   | 1/2/3 | _         |
| SBIC A,b   | Пропуск след. команды, если разряд РВВ сброшен       | Если A.b = 0,<br>то PC = PC + 2 (3)    | 1/2/3 | _         |
| SBIS A,b   | Пропуск след. команды, если разряд РВВ<br>установлен | Если A.b = 1,<br>то PC = PC + 2 (3)    | 1/2/3 | _         |
| BRBC s,k   | Переход, если флаг s регистра SREG сброшен           | Если SREG.s = 0,<br>то PC = PC + k + 1 | 1/2   | _         |
| BRBS s,k   | Переход, если флаг s регистра SREG установлен        | Если SREG.s = 1,<br>то PC = PC + k + 1 | 1/2   | _         |
| BRCS k     | Переход по переносу                                  | Если $C = 1$ ,<br>то $PC = PC + k + 1$ | 1/2   | _         |
| BRCC k     | Переход, если нет переноса                           | Если C = 0,<br>то PC = PC + k + 1      | 1/2   | _         |
| BREQ k     | Переход по условию «равно»                           | Если $Z = 1$ ,<br>то $PC = PC + k + 1$ | 1/2   | _         |

Таблица 3.7 (окончание)

| Мнемоника | Описание                                                | Операция                                          | Циклы | Флаги |
|-----------|---------------------------------------------------------|---------------------------------------------------|-------|-------|
| BRNE k    | Переход по условию «не равно»                           | Если $Z = 0$ ,<br>то $PC = PC + k + 1$            | 1/2   | _     |
| BRSH k    | Переход по условию «выше или равно»                     | Если $C = 0$ ,<br>то $PC = PC + k + 1$            | 1/2   | _     |
| BRLO k    | Переход по условию «меньше»                             | Если $C = 1$ ,<br>то $PC = PC + k + 1$            | 1/2   | _     |
| BRMI      | Переход по условию «отрицательное значение»             | Если N = 1,<br>то PC = PC + k + 1                 | 1/2   | _     |
| BRPL      | Переход по условию «положительное значение»             | Если $N = 0$ ,<br>то $PC = PC + k + 1$            | 1/2   | _     |
| BRGE      | Переход по условию «больше или равно» (числа со знаком) | Если $(N \oplus V) = 0$ ,<br>то $PC = PC + k + 1$ | 1/2   | _     |
| BRLT      | Переход по условию «меньше нуля» (числа со знаком)      | Если $(N \oplus V) = 1$ ,<br>то $PC = PC + k + 1$ | 1/2   | _     |
| BRHS      | Переход по половинному переносу                         | Если H = 1,<br>то PC = PC + k + 1                 | 1/2   | _     |
| BRHC      | Переход, если нет половинного переноса                  | Если $H = 0$ ,<br>то $PC = PC + k + 1$            | 1/2   | _     |
| BRTS      | Переход, если флаг Т установлен                         | Если T = 1,<br>то PC = PC + k + 1                 | 1/2   | _     |
| BRTC      | Переход, если флаг Т сброшен                            | Если $T = 0$ ,<br>то $PC = PC + k + 1$            | 1/2   | _     |
| BRVS      | Переход по переполнению доп. кода                       | Если V = 1,<br>то PC = PC + k + 1                 | 1/2   | _     |
| BRVC      | Переход, если нет переполнения доп. кода                | Если $V = 0$ ,<br>то $PC = PC + k + 1$            | 1/2   | _     |
| BRID      | Переход, если прерывания запрещены                      | Если I = 0,<br>то PC = PC + k + 1                 | 1/2   | _     |
| BRIE      | Переход, если прерывания разрешены                      | Если I = 1,<br>то PC = PC + k + 1                 | 1/2   | _     |

Таблица 3.8. Группа команд управления системой

| Мнемоника | Описание                  | Операция       | Циклы | Флаги |
|-----------|---------------------------|----------------|-------|-------|
| NOP       | Нет операции              |                | 1     | _     |
| SLEEP     | Переход в «спящий» режим  | См. раздел 4.3 | 3     | _     |
| WDR       | Сброс сторожевого таймера | См. раздел 6.6 | 1     | _     |

# 3.5. Описание команд

В этом разделе в алфавитном порядке перечислены все команды, поддерживаемые микроконтроллерами семейства. Для каждой команды приводится ее детальное описание. При описании команд используются обозначения, приведенные в **Табл. 3.9**.

ADC Rd, Rr Сложение двух РОН с переносом

| Операция     | Rd = Rd + 1         | Rd = Rd + Rr + C                                                                                                       |             |              |           |              |       |   |  |  |
|--------------|---------------------|------------------------------------------------------------------------------------------------------------------------|-------------|--------------|-----------|--------------|-------|---|--|--|
| Код операции | 0001 11rd           | d dddd rr                                                                                                              | rr          |              |           | 1 слово (2 б | айта) |   |  |  |
| Операнды     | $0 \le d \le 31, 0$ | ≤d≤31,0≤r≤31                                                                                                           |             |              |           |              |       |   |  |  |
| 1 ()писание  |                     | кладывает содержимое двух регистров Rr и Rd и прибавляет содержимое флага переноса C. езультат помещается в регистр Rd |             |              |           |              |       |   |  |  |
| Downson CDEC | I                   | T                                                                                                                      | Н           | S            | V         | N            | Z     | C |  |  |
| Peructp SREG | _                   | _                                                                                                                      | ⇔           | ⇔            | ⇔         | ⇔            | ⇔     | ⇔ |  |  |
| Маш. циклов  | 1                   |                                                                                                                        |             |              |           |              | •     |   |  |  |
| AT90S1200    | да                  |                                                                                                                        |             |              |           |              |       |   |  |  |
|              | Сложение д          | цвух регистр                                                                                                           | овых пар R1 | 1:R0 и R3:R2 | 2         |              |       |   |  |  |
| Пример       |                     | add r2,r0 ; Сложить младшие байты                                                                                      |             |              |           |              |       |   |  |  |
|              | ado                 | r3,r1 ;                                                                                                                | Сложить     | старшие б    | айты с уч | нетом пер    | еноса |   |  |  |

#### ADD Rd, Rr Сложение двух РОН

| (2.5                                |             | d = Rd + Rr |  |  |  |  |  |  |  |  |
|-------------------------------------|-------------|-------------|--|--|--|--|--|--|--|--|
| 00 11rd dddd rrrr 1 слово (2 байта) |             |             |  |  |  |  |  |  |  |  |
| $\leq d \leq 31, 0 \leq r \leq 31$  |             |             |  |  |  |  |  |  |  |  |
| мещается                            | я в регистр | Rd          |  |  |  |  |  |  |  |  |
| N                                   | Z           | С           |  |  |  |  |  |  |  |  |
| ⇔                                   | ⇔           | <b>⇔</b>    |  |  |  |  |  |  |  |  |
|                                     |             |             |  |  |  |  |  |  |  |  |
|                                     |             |             |  |  |  |  |  |  |  |  |
| (r28=r2                             | 28+r28)     |             |  |  |  |  |  |  |  |  |
|                                     | N<br>⇔      |             |  |  |  |  |  |  |  |  |

Таблица 3.9. Обозначения, используемые при описании команд

| Обозначение, символ | Описание                                                              |
|---------------------|-----------------------------------------------------------------------|
|                     | Регистр состояния                                                     |
| SREG                | Регистр состояния микроконтроллера                                    |
| С                   | Флаг переноса (0-й разряд регистра SREG)                              |
| Z                   | Флаг нуля (1-й разряд регистра SREG)                                  |
| N                   | Флаг отрицательного значения (2-й разряд регистра SREG)               |
| V                   | Флаг переполнения дополнительного кода (3-й разряд регистра SREG)     |
| S                   | Флаг знака (4-й разряд регистра SREG); S = N $\oplus$ V               |
| Н                   | Флаг половинного переноса (5-й разряд регистра SREG)                  |
| T                   | Пользовательский флаг (6-й разряд регистра SREG)                      |
| I                   | Флаг общего разрешения прерываний (7-й разряд регистра SREG)          |
|                     | Регистры и операнды                                                   |
| Rd                  | Регистр-приемник (иногда также регистр-источник) в регистровом файле  |
| Rr                  | Регистр-источник в регистровом файле                                  |
| K                   | Константа (данные)                                                    |
| k                   | Адрес — константа                                                     |
| b                   | Номер разряда РОН или РВВ (07)                                        |
| S                   | Номер разряда регистра состояния SREG (07)                            |
| X, Y, Z             | Регистры-указатели (X = R27:R26, Y = R29:R28, Z = R31:R30)            |
| I/O                 | Регистр ввода/вывода                                                  |
| A                   | Адрес в пространстве ввода/вывода                                     |
| q                   | Смещение при относительной косвенной адресации (6-разрядное значение) |
|                     | Разделитель между названием (адресом) регистра и номером разряда      |
| [XX]                | Содержимое ячейки памяти данных по адресу XX                          |
| {XX}                | Содержимое ячейки памяти программ по адресу XX                        |
|                     | Операции                                                              |
| _                   | Инверсия                                                              |
| •                   | Логическое И                                                          |
| V                   | Логическое ИЛИ                                                        |
| 0                   | Исключающее ИЛИ                                                       |
|                     | Система                                                               |
| PC                  | Счетчик команд                                                        |
| STACK               | Текущий уровень стека                                                 |
| SP                  | Указатель стека                                                       |
|                     | Флаги                                                                 |
| ⇔                   | Команда воздействует на флаг                                          |
| 0                   | Флаг сбрасывается командой в «0»                                      |
| 1                   | Флаг устанавливается командой в «1»                                   |
|                     | Команда не влияет на состояние флага                                  |

# ADIW Rd, K

# Сложение регистровой пары с константой

| Операция     | Rd+1:Rd =    | d+1:Rd = Rd+1:Rd + K                                                                                                    |    |                       |   |               |       |   |  |  |
|--------------|--------------|-------------------------------------------------------------------------------------------------------------------------|----|-----------------------|---|---------------|-------|---|--|--|
| Код операции | 1001 0110    | ) kkdd kk                                                                                                               | kk |                       |   | 1 слово (2 ба | ійта) |   |  |  |
| Операнды     | d ∈ {24, 26, | {24, 26, 28, 30}, K = 063                                                                                               |    |                       |   |               |       |   |  |  |
| Описание     |              | сладывает содержимое регистровой пары Rd+1:Rd с 6-разрядным числом. Результат поме-<br>ается обратно в регистровую пару |    |                       |   |               |       |   |  |  |
| Danwarn CDEC | I            | T                                                                                                                       | Н  | S                     | V | N             | Z     | C |  |  |
| Peructp SREG | _            | _                                                                                                                       | _  | ⇔                     | ⇔ | ⇔             | ⇔     | ⇔ |  |  |
| Маш. циклов  | 2            |                                                                                                                         |    | •                     |   |               |       |   |  |  |
| AT90S1200    | нет          | ет                                                                                                                      |    |                       |   |               |       |   |  |  |
| Пример       | ı            |                                                                                                                         | -  | ть 1 к r2<br>ить 63 к |   | z(r31:r       | 30)   | · |  |  |

#### AND Rd, Rr

# «Логическое И» двух РОН

| Операция     | Rd = Rd AN          | ND Rr                                                                                                      |                       |   |   |               |      |   |  |  |
|--------------|---------------------|------------------------------------------------------------------------------------------------------------|-----------------------|---|---|---------------|------|---|--|--|
| Код операции | 0010 00rd           | d dddd rr                                                                                                  | rr                    |   |   | 1 слово (2 ба | йта) |   |  |  |
| Операнды     | $0 \le d \le 31, 0$ | ≤d≤31,0≤r≤31                                                                                               |                       |   |   |               |      |   |  |  |
| Описание     | 1                   | ыполняет операцию «Логическое И» между содержимым регистров Rd и Rr. Результат поме-<br>ается в регистр Rd |                       |   |   |               |      |   |  |  |
| Peructp SREG | I                   | T                                                                                                          | Н                     | S | V | N             | Z    | C |  |  |
| Perucip SkeG | -                   | _                                                                                                          | _                     | ⇔ | 0 | ⇔             | ⇔    | _ |  |  |
| Маш. циклов  | 1                   |                                                                                                            |                       |   |   |               |      |   |  |  |
| AT90S1200    | да                  |                                                                                                            |                       |   |   |               |      |   |  |  |
| Пример       | 1                   |                                                                                                            | Загрузит<br>;Выделить | _ |   | в r16         |      |   |  |  |

#### ANDI Rd, K

#### «Логическое И» РОН и константы

| Операция     | Rd = Rd AN   | ND K              |           |                           |           |               |        |                        |
|--------------|--------------|-------------------|-----------|---------------------------|-----------|---------------|--------|------------------------|
| Код операции | 0111 kkk     | k dddd kk         | kk        |                           |           | 1 слово (2 ба | ійта)  |                        |
| Операнды     | 16 ≤ d ≤ 31, | $0 \le K \le 255$ |           |                           |           |               |        |                        |
| Описание     | I            |                   |           | И» между со<br>Команда пр |           |               |        | ым числом.<br>(R16R31) |
| Perистр SREG | I            | T                 | Н         | S                         | V         | N             | Z      | C                      |
| Perucip SkeG | _            | _                 | _         | ⇔                         | 0         | ⇔             | ⇔      | _                      |
| Маш. циклов  | 1            |                   |           |                           |           |               |        |                        |
| AT90S1200    | да           |                   |           |                           |           |               |        |                        |
| Пример       | and          | li r17,\$01       | 🛚 ;Обнули | ть старши                 | й полубай | т регистр     | oa r17 |                        |
| Пример       | and          | li r18,\$10       | ) ;Выдели | ть 4-й ра                 | зряд в ре | егистре г     | 18     |                        |

# ASR Rd Арифметический сдвиг вправо

| Операция     |                  | b7 b0 C                                                                                                                                                                                                |                |         |   |           |   |   |  |  |  |
|--------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------|---|-----------|---|---|--|--|--|
| Код операции | 1001 0100        | 010d dddd 0101 1 слово (2 байта)                                                                                                                                                                       |                |         |   |           |   |   |  |  |  |
| Операнды     | $0 \le d \le 31$ | ≤31                                                                                                                                                                                                    |                |         |   |           |   |   |  |  |  |
| Описание     | Значение 0       | вигает содержимое регистра Rd на 1 разряд вправо. Состояние 7-го разряда не изменяется.<br>чение 0-го разряда помещается в флаг С регистра SREG. Часто используется для деления<br>ел со знаком на два |                |         |   |           |   |   |  |  |  |
| Peructp SREG | I                | T                                                                                                                                                                                                      | Н              | S       | V | N         | Z | С |  |  |  |
| reincip Sked | -                | -                                                                                                                                                                                                      | _              | ⇔       | ⇔ | ⇔         | ⇔ | ⇔ |  |  |  |
| Маш. циклов  | 1                |                                                                                                                                                                                                        |                |         |   | •         |   |   |  |  |  |
| AT90S1200    | да               |                                                                                                                                                                                                        |                |         |   |           |   |   |  |  |  |
| Пример       | asr<br>1di       | r16,\$10<br>r16<br>r17,\$FC                                                                                                                                                                            | ; r16<br>; 3aı | 6=r16/2 |   | регистр п |   |   |  |  |  |

### BCLR s

# Сброс разряда регистра SREG

| Операция     | SREG.s = 0      | REG.s = 0                                                                                            |                        |    |   |               |       |           |  |  |
|--------------|-----------------|------------------------------------------------------------------------------------------------------|------------------------|----|---|---------------|-------|-----------|--|--|
| Код операции | 1001 0100       | ) 1sss 10                                                                                            | 00                     |    |   | 1 слово (2 ба | ійта) |           |  |  |
| Операнды     | $0 \le s \le 7$ | §s≤7                                                                                                 |                        |    |   |               |       |           |  |  |
| Описание     |                 | брасывает в «0» заданный разряд регистра SREG. Остальные разряды регистра SREG остатся без изменения |                        |    |   |               |       |           |  |  |
| Peructp SREG | I               | T                                                                                                    | Н                      | S  | V | N             | Z     | С         |  |  |
| Perucip SkeG | ⇔               | ⇔                                                                                                    | ⇔                      | \$ | ⇔ | ⇔             | ⇔     | <b>\$</b> |  |  |
| Маш. циклов  | 1               |                                                                                                      |                        |    |   |               |       |           |  |  |
| AT90S1200    | да              |                                                                                                      |                        |    |   |               |       |           |  |  |
| Пример       |                 |                                                                                                      | росить фл<br>претить п | -  |   |               |       | ·         |  |  |

# **BLD Rd, b** Пересылка флага Т в разряд РОН

| Операция      | Rd.b = T            | l.b = T             |            |              |          |               |       |  |  |  |  |
|---------------|---------------------|---------------------|------------|--------------|----------|---------------|-------|--|--|--|--|
| Код операции  | 1111 1000           | d dddd 0b           | bb         |              |          | 1 слово (2 ба | ійта) |  |  |  |  |
| Операнды      | $0 \le d \le 31, 0$ | ≤d≤31,0≤b≤7         |            |              |          |               |       |  |  |  |  |
| Описание      | Копирует ф          | лаг Т регис         | гра SREG в | разряд b рег | истра Rd |               |       |  |  |  |  |
| Perистр SREG  | I                   | I T H S V N Z C     |            |              |          |               |       |  |  |  |  |
| 1 cincip Sked | _                   |                     |            |              |          |               |       |  |  |  |  |
| Маш. циклов   | 1                   |                     |            |              |          |               |       |  |  |  |  |
| AT90S1200     | да                  |                     |            |              |          |               |       |  |  |  |  |
|               | Копирован           | опирование разряда: |            |              |          |               |       |  |  |  |  |
| Пример        | bst                 | r1,2 ;              | Сохранить  | 2-й разр     | яд регис | гра r1 в      | T     |  |  |  |  |
|               | blo                 | l r0,4 ;            | Записать   | флаг Т в     | 4-й разр | яд регист     | pa rO |  |  |  |  |

# BRBC s, k Переход, если разряд регистра SREG сброшен

| Операция      | Если SREG                  | s.s = 0, to PC                                                                                                                                                                   | C = PC + k +          | <ul> <li>1, иначе Р</li> </ul> | C = PC + 1 |               |       |  |  |  |  |
|---------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------------------|------------|---------------|-------|--|--|--|--|
| Код операции  | 1111 01k                   | kkkk ks                                                                                                                                                                          | SS                    |                                |            | 1 слово (2 ба | айта) |  |  |  |  |
| Операнды      | $0 \le s \le 7, -6$        | $\leq s \leq 7, -64 \leq k \leq +63$                                                                                                                                             |                       |                                |            |               |       |  |  |  |  |
| Описание      | 1                          | ловный относительный переход. Проверяет заданный разряд регистра SREG и выполняет реход, если этот разряд сброшен. Величина смещения k представляется числом в дополнильном коде |                       |                                |            |               |       |  |  |  |  |
| Регистр SREG  | I                          | I T H S V N Z C                                                                                                                                                                  |                       |                                |            |               |       |  |  |  |  |
| T CINCIP SKEO | _                          |                                                                                                                                                                                  |                       |                                |            |               |       |  |  |  |  |
| Маш. циклов   | 1, если SRE<br>2, если SRE |                                                                                                                                                                                  |                       |                                |            |               |       |  |  |  |  |
| AT90S1200     | да                         |                                                                                                                                                                                  |                       |                                |            |               |       |  |  |  |  |
| Пример        |                            | oc 1,noted                                                                                                                                                                       | Сравнить<br>д ; Перех |                                |            |               |       |  |  |  |  |

# BRBS s, k

# Переход, если разряд регистра SREG установлен

| Операция      | Если SREG                  | CЛИ $SREG.s = 1$ , то $PC = PC + k + 1$ , иначе $PC = PC + 1$                                                                                                                       |  |   |  |                        |  |  |  |  |
|---------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|---|--|------------------------|--|--|--|--|
| Код операции  | 1111 00k                   | 111 00kk kkkk ksss 1 слово (2 байта)                                                                                                                                                |  |   |  |                        |  |  |  |  |
| Операнды      | $0 \le s \le 7, -6$        | $s \le 7, -64 \le k \le +63$                                                                                                                                                        |  |   |  |                        |  |  |  |  |
| Описание      | переход, ес                | повный относительный переход. Проверяет заданный разряд регистра SREG и выполняет реход, если этот разряд установлен. Величина смещения k представляется числом в дополтельном коде |  |   |  |                        |  |  |  |  |
| Perистр SREG  | I                          | I T H S V N Z C                                                                                                                                                                     |  |   |  |                        |  |  |  |  |
| T CINCIP SKEO | _                          |                                                                                                                                                                                     |  |   |  |                        |  |  |  |  |
| Маш. циклов   | 1, если SRE<br>2, если SRE |                                                                                                                                                                                     |  |   |  |                        |  |  |  |  |
| AT90S1200     | да                         |                                                                                                                                                                                     |  |   |  |                        |  |  |  |  |
| Пример        |                            | os 1,bitse                                                                                                                                                                          |  | - |  | -м разряд<br>I установ |  |  |  |  |

# BRCC k

#### Переход, если не было переноса

| Операция     | Если флаг (                | C = 0, to PC                                                                                                                                                                                         | = PC + k +           | 1, иначе РС | C = PC + 1 |               |       |  |  |  |
|--------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------|------------|---------------|-------|--|--|--|
| Код операции | 1111 01k                   | kkkk k0                                                                                                                                                                                              | 00                   |             |            | 1 слово (2 ба | айта) |  |  |  |
| Операнды     | $-64 \le k \le +$          | 4 ≤ k ≤ +63                                                                                                                                                                                          |                      |             |            |               |       |  |  |  |
| Описание     | этот разряд                | повный относительный переход. Проверяет флаг переноса (C) и выполняет переход, если от разряд сброшен. Величина смещения k представляется числом в дополнительном коде. вывалентна команде BRBC 0, k |                      |             |            |               |       |  |  |  |
| Peructp SREG | I                          | I T H S V N Z C                                                                                                                                                                                      |                      |             |            |               |       |  |  |  |
| Ternery Sked | _                          |                                                                                                                                                                                                      |                      |             |            |               |       |  |  |  |
| Маш. циклов  | 1, если C =<br>2, если C = |                                                                                                                                                                                                      |                      |             |            |               |       |  |  |  |
| AT90S1200    | да                         |                                                                                                                                                                                                      |                      |             |            |               |       |  |  |  |
| Пример       | ı                          | cc nocarry                                                                                                                                                                                           | ; Приба<br>/ ; Перей |             |            | переполне     | кин   |  |  |  |

# BRCS k

# Переход по переносу

| Операция     | Если флаг (                | С = 1, то РС                                                                                                                                                                                                  | = PC + k +           | 1, иначе РС | C = PC + 1 |               |       |   |  |
|--------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------|------------|---------------|-------|---|--|
| Код операции | 1111 00k                   | kkkk k0                                                                                                                                                                                                       | 00                   |             |            | 1 слово (2 ба | айта) |   |  |
| Операнды     | $-64 \le k \le +$          | 4 ≤ k ≤ +63                                                                                                                                                                                                   |                      |             |            |               |       |   |  |
| Описание     | этот разряд                | овный относительный переход. Проверяет флаг переноса (C) и выполняет переход, если г разряд установлен. Величина смещения $k$ представляется числом в дополнительном ко-Эквивалентна команде $BRBS = 0$ , $k$ |                      |             |            |               |       |   |  |
| Регистр SREG | I                          | T                                                                                                                                                                                                             | Н                    | S           | V          | N             | Z     | С |  |
| reincip Sked | _                          | _                                                                                                                                                                                                             | _                    | _           | _          |               |       |   |  |
| Маш. циклов  | 1, если C =<br>2, если C = |                                                                                                                                                                                                               |                      |             |            |               |       |   |  |
| AT90S1200    | да                         |                                                                                                                                                                                                               |                      |             |            |               |       |   |  |
| Пример       | 1 -                        | s greate                                                                                                                                                                                                      | ; Сравн<br>r ; Перей |             |            |               |       |   |  |

# BREQ k

# Переход по условию «равно»

| Операция       | Если Rd = 1                                             | Rr(Z=1), T                                                                                                                                                                                                                                                                                                                                                                                                                                    | o PC = PC -            | ⊦ k + 1, инач | e PC = PC | + 1           |       |   |
|----------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------|-----------|---------------|-------|---|
| Код операции   | 1111 00k                                                | kkkk k0                                                                                                                                                                                                                                                                                                                                                                                                                                       | 01                     |               |           | 1 слово (2 ба | ійта) |   |
| Операнды       | $-64 \le k \le +$                                       | 63                                                                                                                                                                                                                                                                                                                                                                                                                                            |                        |               |           |               |       |   |
| Описание       | разряд устан<br>выполнени<br>изойдет тол<br>будет равно | ловный относительный переход. Проверяет флаг нуля (Z) и выполняет переход, если этот зряд установлен. Величина смещения к представляется числом в дополнительном коде. При полнении данной команды сразу же после команды СР, СРІ, SUB или SUBI переход проойдет только в том случае, если число (со знаком или без знака), находящееся в регистре Rd, дет равно числу (со знаком или без знака), находящеет Rr. Эквивалентна конде BRBS 1, k |                        |               |           |               |       |   |
| Регистр SREG   | I T H S V N Z                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |               |           |               |       |   |
| T CINCIP SILEG | _                                                       | _                                                                                                                                                                                                                                                                                                                                                                                                                                             | _                      | _             | _         | _             | _     | _ |
| Маш. циклов    | 1 ′                                                     | , если Z = 0<br>, если Z = 1                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |               |           |               |       |   |
| AT90S1200      | да                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |               |           |               |       |   |
| Пример         |                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                               | ; Сравнит<br>; Перейти |               |           |               |       |   |

#### **BRGE** k

# Переход по условию «больше или равно» (для знаковых данных)

| Операция     | Если Rd≥I                               | $Rr(N \oplus V =$                                                                                                                                                                                                                                                                                                                                                                                                                             | 0), то PC =          | PC + k + 1, | иначе РС = | PC + 1        |       |   |  |  |
|--------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------|------------|---------------|-------|---|--|--|
| Код операции | 1111 01k                                | k kkkk k1                                                                                                                                                                                                                                                                                                                                                                                                                                     | 00                   |             |            | 1 слово (2 ба | ійта) |   |  |  |
| Операнды     | $-64 \le k \le +6$                      | 63                                                                                                                                                                                                                                                                                                                                                                                                                                            |                      |             |            |               |       |   |  |  |
| Описание     | разряд сбро<br>выполнени<br>изойдет тол | повный относительный переход. Проверяет флаг знака (S) и выполняет переход, если этот вряд сброшен. Величина смещения к представляется числом в дополнительном коде. При полнении данной команды сразу же после команды СР, СРІ, SUB или SUBI переход про-<br>ройдет только в том случае, если число со знаком, находящееся в регистре Rd, будет больше пи равно) числа со знаком, находящегося в регистре Rr. Эквивалентна команде BRBC 4, к |                      |             |            |               |       |   |  |  |
| Регистр SREG | I                                       | I T H S V N Z C                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |             |            |               |       |   |  |  |
| Маш. циклов  | 1, если S =<br>2, если S =              |                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |             |            |               |       | l |  |  |
| AT90S1200    | да                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |             |            |               |       |   |  |  |
| Пример       | -                                       | ge greaten                                                                                                                                                                                                                                                                                                                                                                                                                                    | ; Сравн<br>r ; Перей |             |            |               |       |   |  |  |

# BRHC k

# Переход, если не было половинного переноса

| Операция     | Если флаг І        | H = 0, to PC                                                                                                                                                                                               | C = PC + k + | 1, иначе РС | C = PC + 1 |              |   |   |  |
|--------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|------------|--------------|---|---|--|
| Код операции | 1111 01kk          | kkkk k1                                                                                                                                                                                                    | 01           |             | 1 слов     | во (2 байта) |   |   |  |
| Операнды     | $-64 \le k \le +6$ | 63                                                                                                                                                                                                         |              |             |            |              |   |   |  |
| Описание     | переход, есл       | вный относительный переход. Проверяет флаг половинного переноса (H) и выполняет ход, если этот разряд сброшен. Величина смещения k представляется числом в дополнином коде. Эквивалентна команде BRBC 5, k |              |             |            |              |   |   |  |
| Регистр SREG | I                  | I T H S V N Z C                                                                                                                                                                                            |              |             |            |              |   |   |  |
| Perucip SkeG | _                  | _                                                                                                                                                                                                          | _            | _           | _          | _            | _ | _ |  |
| Маш. циклов  | 1, если Н =        |                                                                                                                                                                                                            |              |             |            |              |   |   |  |
| тишт, циклов | 2, если Н =        | 0                                                                                                                                                                                                          |              |             |            |              |   |   |  |
| AT90S1200    |                    |                                                                                                                                                                                                            |              | Д           | a          |              |   |   |  |
|              | brn                | e hclear                                                                                                                                                                                                   | ; Перейт     | и, если ф   | лаг Н сбр  | ошен         |   |   |  |
| Пример       |                    |                                                                                                                                                                                                            |              |             |            |              |   |   |  |
| Пример       | hclear             | :                                                                                                                                                                                                          |              |             |            |              |   |   |  |
|              |                    |                                                                                                                                                                                                            |              |             |            |              |   |   |  |

#### **BRHS** k

# Переход по половинному переносу

| Операция      | Если флаг I                | H = 1, то РС                                                                                                                                                                                                             | = PC + $k$ + | 1, иначе РС | C = PC + 1 |              |       |  |  |
|---------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|------------|--------------|-------|--|--|
| Код операции  | 1111 00k                   | k kkkk k1                                                                                                                                                                                                                | 01           |             |            | 1 слово (2 б | айта) |  |  |
| Операнды      | $-64 \le k \le +6$         | 63                                                                                                                                                                                                                       |              |             |            |              |       |  |  |
| Описание      | переход, ес.               | повный относительный переход. Проверяет флаг половинного переноса (H) и выполняет реход, если этот разряд установлен. Величина смещения k представляется числом в допол-<br>тельном коде. Эквивалентна команде BRBS 5, k |              |             |            |              |       |  |  |
| Peructp SREG  | I                          | I T H S V N Z C                                                                                                                                                                                                          |              |             |            |              |       |  |  |
| T CINCIP SKEO |                            |                                                                                                                                                                                                                          |              |             |            |              |       |  |  |
| Маш. циклов   | 1, если H =<br>2, если H = |                                                                                                                                                                                                                          |              |             |            |              |       |  |  |
| AT90S1200     | да                         |                                                                                                                                                                                                                          |              |             |            |              |       |  |  |
| Пример        | brh<br><br>hset:           | ·                                                                                                                                                                                                                        | Перейти,     | если флаг   | Н устано   | влен         |       |  |  |

#### **BRID** k

# Переход, если прерывания запрещены

| Операция     | Если флаг I                    | = 0, TO PC                                                                                                                                                                                                               | = PC + k + | 1, иначе РС | = PC + 1  |               |       |   |  |
|--------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|-----------|---------------|-------|---|--|
| Код операции | 1111 01k                       | k kkkk k1                                                                                                                                                                                                                | 11         |             |           | 1 слово (2 ба | ійта) |   |  |
| Операнды     | $-64 \le k \le +6$             | 63                                                                                                                                                                                                                       |            |             |           |               |       |   |  |
| Описание     | полняет пер                    | повный относительный переход. Проверяет флаг общего разрешения прерываний (I) и выпинет переход, если этот разряд сброшен. Величина смещения k представляется числом в полнительном коде. Эквивалентна команде BRBC 7, k |            |             |           |               |       |   |  |
| Perистр SREG | I                              | I T H S V N Z C                                                                                                                                                                                                          |            |             |           |               |       |   |  |
| Ternery Sked |                                |                                                                                                                                                                                                                          |            |             |           |               |       | _ |  |
| Маш. циклов  | 1, если I = 1<br>2, если I = 0 |                                                                                                                                                                                                                          |            |             |           |               |       |   |  |
| AT90S1200    | да                             |                                                                                                                                                                                                                          |            |             |           |               |       |   |  |
| Пример       | bri<br><br>intdis:             | :                                                                                                                                                                                                                        | ; Перейт   | и, если п   | рерывания | запрещен      | НЫ    | _ |  |

#### **BRIE** k

# Переход, если прерывания разрешены

| Операция      | Если флаг I                    | = 1, TO PC                                                                                                                                                                                                                        | = PC + $k$ + | 1, иначе РС | = PC + 1 |               |       |   |  |
|---------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|----------|---------------|-------|---|--|
| Код операции  | 1111 00k                       | kkkk k1                                                                                                                                                                                                                           | 11           |             |          | 1 слово (2 ба | айта) |   |  |
| Операнды      | $-64 \le k \le +6$             | 63                                                                                                                                                                                                                                |              |             |          |               |       |   |  |
| Описание      | полняет пер                    | овный относительный переход. Проверяет флаг общего разрешения прерываний (I) и вы-<br>іняет переход, если этот разряд установлен. Величина смещения к представляется числом<br>ополнительном коде. Эквивалентна команде BRBS 7, k |              |             |          |               |       |   |  |
| Perистр SREG  | I                              | Z                                                                                                                                                                                                                                 | С            |             |          |               |       |   |  |
| T CINCIP SKEG | <sup>3</sup> – – – – – –       |                                                                                                                                                                                                                                   |              |             |          |               |       | _ |  |
| Маш. циклов   | 1, если I = 0<br>2, если I = 1 |                                                                                                                                                                                                                                   |              |             |          |               |       |   |  |
| AT90S1200     | да                             |                                                                                                                                                                                                                                   |              |             |          |               |       |   |  |
|               | bri                            | brie inten ; Перейти, если прерывания разрешены                                                                                                                                                                                   |              |             |          |               |       |   |  |
| Пример        | inten:                         |                                                                                                                                                                                                                                   |              |             |          |               |       |   |  |

#### BRLO k

# Переход по условию «меньше» (для беззнаковых данных)

| Операция     | Если Rd < I                             | Rr(C=1), T                                | o PC = PC +                              | - k + 1, инач                                | ie PC = PC                                | + 1                                   |                                                                         |                                           |  |
|--------------|-----------------------------------------|-------------------------------------------|------------------------------------------|----------------------------------------------|-------------------------------------------|---------------------------------------|-------------------------------------------------------------------------|-------------------------------------------|--|
| Код операции | 1111 00kk                               | kkkk k0                                   | 00                                       |                                              |                                           | 1 слово (2 ба                         | айта)                                                                   |                                           |  |
| Операнды     | $-64 \le k \le +6$                      | 63                                        |                                          |                                              |                                           |                                       |                                                                         |                                           |  |
| Описание     | этот разряд<br>При выполи<br>произойдет | установлен.<br>нении данно<br>только в то | Величина с<br>ой команды<br>ом случае, е | мещения к пос<br>сразу же пос<br>сли беззнак | представляе<br>сле команды<br>овое число, | тся числом і<br>СР, СРІ,<br>находящее | ыполняет пе<br>в дополните.<br>SUB или SU<br>ся в регистр<br>команде BR | льном коде.<br>ЈВІ переход<br>е Rd, будет |  |
| Peructp SREG | I                                       | I T H S V N Z C                           |                                          |                                              |                                           |                                       |                                                                         |                                           |  |
|              | _                                       |                                           | _                                        | _                                            | _                                         | _                                     | _                                                                       | _                                         |  |
| Маш. циклов  | 1, если C = 2, если C =                 |                                           |                                          |                                              |                                           |                                       |                                                                         |                                           |  |
| AT90S1200    | да                                      |                                           |                                          |                                              |                                           |                                       |                                                                         |                                           |  |
| Пример       | loop: ir<br>cj                          | nc r19<br><br>pi r19,\$                   | 19 ; Our<br>; r19<br>10 ; Cpa<br>; Nep   | 9 = r19 +<br>авнить r1;                      | 1<br>9 c \$10                             | \$10                                  |                                                                         |                                           |  |

**BRLT k** Переход по условию «меньше» (для знаковых данных)

| Операция     | Если Rd < I                              | $Rr(N \oplus V =$                                                                                                                                                                                                                                                                                                                                                                                                              | 1), to PC =          | PC + k + 1, | иначе РС = | PC + 1        |       |  |  |  |
|--------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------|------------|---------------|-------|--|--|--|
| Код операции | 1111 00k                                 | k kkkk k1                                                                                                                                                                                                                                                                                                                                                                                                                      | 00                   |             |            | 1 слово (2 ба | ійта) |  |  |  |
| Операнды     | $-64 \le k \le +6$                       | 63                                                                                                                                                                                                                                                                                                                                                                                                                             |                      |             |            |               |       |  |  |  |
| Описание     | разряд устаі<br>выполнени<br>изойдет тол | ловный относительный переход. Проверяет флаг знака (S) и выполняет переход, если этот зряд установлен. Величина смещения к представляется числом в дополнительном коде. При полнении данной команды сразу же после команды СР, СРІ, SUB или SUBI переход проойдет только в том случае, если число со знаком, находящееся в регистре Rd, будет меньше сла со знаком, находящегося в регистре Rr. Эквивалентна команде BRBS 4, k |                      |             |            |               |       |  |  |  |
| Регистр SREG | I                                        | I T H S V N Z C                                                                                                                                                                                                                                                                                                                                                                                                                |                      |             |            |               |       |  |  |  |
| Маш. циклов  | 1, если S =<br>2, если S =               |                                                                                                                                                                                                                                                                                                                                                                                                                                |                      |             |            |               |       |  |  |  |
| AT90S1200    | да                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                |                      |             |            |               |       |  |  |  |
| Пример       | cp<br>brl<br><br>less:                   | ,                                                                                                                                                                                                                                                                                                                                                                                                                              | ; Сравни<br>; Перейт |             |            |               |       |  |  |  |

#### BRMI k

# Переход по условию «отрицательное значение»

| Операция      | Если флаг 1                | N = 1, to PC                                                                                                                                                                                                                  | C = PC + k + | 1, иначе РО | C = PC + 1 |               |       |  |  |
|---------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|------------|---------------|-------|--|--|
| Код операции  | 1111 00k                   | k kkkk k0                                                                                                                                                                                                                     | 10           |             |            | 1 слово (2 ба | айта) |  |  |
| Операнды      | $-64 \le k \le +$          | 63                                                                                                                                                                                                                            |              |             |            |               |       |  |  |
| Описание      | ет переход,                | овный относительный переход. Проверяет флаг отрицательного значения (N) и выполня-<br>переход, если этот разряд установлен. Величина смещения k представляется числом в до-<br>нительном коде. Эквивалентна команде BRBS 2, k |              |             |            |               |       |  |  |
| Peructp SREG  | I                          | I T H S V N Z C                                                                                                                                                                                                               |              |             |            |               |       |  |  |
| I cincip Sked | " -                        |                                                                                                                                                                                                                               |              |             |            |               |       |  |  |
| Маш. циклов   | 1, если N =<br>2, если N = |                                                                                                                                                                                                                               |              |             |            |               |       |  |  |
| AT90S1200     | да                         |                                                                                                                                                                                                                               |              |             |            |               |       |  |  |
| Пример        | ı                          | minus:                                                                                                                                                                                                                        |              |             |            |               |       |  |  |

#### **BRNE** k

# Переход по условию «не равно»

| Операция     | Если Rd ≠ I                             | Rr(Z=0), $Te$                                                                                                                                                                                                                                                                                                                                                                                              | $_{0}$ PC = PC + | · k + 1, инач                                   | e PC = PC - | + 1           |       |   |  |
|--------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------|-------------|---------------|-------|---|--|
| Код операции | 1111 01k                                | kkkk k0                                                                                                                                                                                                                                                                                                                                                                                                    | 01               |                                                 |             | 1 слово (2 ба | айта) |   |  |
| Операнды     | $-64 \le k \le +6$                      | 63                                                                                                                                                                                                                                                                                                                                                                                                         |                  |                                                 |             |               |       |   |  |
| Описание     | разряд сбро<br>выполнени<br>изойдет тол | кловный относительный переход. Проверяет флаг нуля (Z) и выполняет переход, если этот изряд сброшен. Величина смещения к представляется числом в дополнительном коде. При мполнении данной команды сразу же после команды СР, СРІ, SUB или SUBI переход проюйдет только в том случае, если числа (со знаком или без знака), находящиеся в регистрах d и Rr, не будут равны. Эквивалентна команде BRBC 1, k |                  |                                                 |             |               |       |   |  |
| Регистр SREG | I                                       | I T H S V N Z C                                                                                                                                                                                                                                                                                                                                                                                            |                  |                                                 |             |               |       |   |  |
| тегистр ысь  | _                                       | _                                                                                                                                                                                                                                                                                                                                                                                                          | _                | _                                               | _           | _             | _     | _ |  |
| Маш. циклов  | 1, если Z =<br>2, если Z =              |                                                                                                                                                                                                                                                                                                                                                                                                            |                  |                                                 |             |               |       |   |  |
| AT90S1200    | да                                      |                                                                                                                                                                                                                                                                                                                                                                                                            |                  |                                                 |             |               |       |   |  |
| Пример       | loop: ir<br>c                           | nc r27<br><br>pi r27,5                                                                                                                                                                                                                                                                                                                                                                                     | ; r27            | мстить r2<br>= r27 +:<br>авнить r2<br>рейти, ес | 1<br>7 c 5  | 5             |       |   |  |

#### **BRPL** k

### Переход по условию «положительное значение»

| Операция      | Если флаг 1                | N = 0, to PC                                                                                                                                                                                                                | C = PC + k +         | 1, иначе РС | C = PC + 1 |               |        |  |  |  |
|---------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------|------------|---------------|--------|--|--|--|
| Код операции  | 1111 01k                   | k kkkk k0                                                                                                                                                                                                                   | 10                   |             |            | 1 слово (2 ба | айта)  |  |  |  |
| Операнды      | $-64 \le k \le +6$         | 63                                                                                                                                                                                                                          |                      |             |            |               |        |  |  |  |
| Описание      | ет переход,                | овный относительный переход. Проверяет флаг отрицательного значения (N) и выполня-<br>переход, если этот разряд сброшен. Величина смещения k представляется числом в допол-<br>гельном коде. Эквивалентна команде BRBC 2, k |                      |             |            |               |        |  |  |  |
| Perистр SREG  | I                          | I T H S V N Z C                                                                                                                                                                                                             |                      |             |            |               |        |  |  |  |
| 1 cincip Sked | ·                          |                                                                                                                                                                                                                             |                      |             |            |               |        |  |  |  |
| Маш. циклов   | 1, если N =<br>2, если N = | если N = 1<br>если N = 0                                                                                                                                                                                                    |                      |             |            |               |        |  |  |  |
| AT90S1200     | да                         |                                                                                                                                                                                                                             |                      |             |            |               |        |  |  |  |
| Пример        | 1                          | ol plus                                                                                                                                                                                                                     | 0 ; r26 =<br>; Перей |             |            | г положите    | ельный |  |  |  |

**BRSH k** Переход по условию «выше или равно» (для беззнаковых данных)

| Операция     | Если Rd≥ I                                            | Rr(C=0), T                                                                                                                                                                                                                                                                                                                                                                                                                                   | o PC = PC + | - k + 1, инач | PC = PC | + 1           |       |   |  |
|--------------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------|---------|---------------|-------|---|--|
| Код операции | 1111 01k                                              | kkkk k0                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00          |               |         | 1 слово (2 ба | айта) |   |  |
| Операнды     | $-64 \le k \le +6$                                    | 53                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |               |         |               |       |   |  |
| Описание     | этот разряд<br>При выпол<br>ход произоі<br>дет больше | повный относительный переход. Проверяет флаг переноса (С) и выполняет переход, если от разряд сброшен. Величина смещения к представляется числом в дополнительном коде. Выполнении данной команды сразу же после команды СР, СРІ, SUB или SUBI перец произойдет только в том случае, если беззнаковое число, находящееся в регистре Rd, буго больше (или равно) беззнакового числа, находящегося в регистре Rr. Эквивалентна конде BRBC 0, k |             |               |         |               |       |   |  |
| Perистр SREG | EG I T H S V N Z                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |               |         |               |       | С |  |
|              | _                                                     | _                                                                                                                                                                                                                                                                                                                                                                                                                                            | _           | _             | _       | _             | _     | _ |  |
| Маш. циклов  | 1, если С =<br>2, если С =                            |                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |               |         |               |       |   |  |
| AT90S1200    | да                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |               |         |               |       |   |  |
| Пример       | ı                                                     | subi r19,4 ; r19 = r19 - 4<br>brsh hgsm ; Перейти, если r19 ≥ 4<br><br>ngsm:                                                                                                                                                                                                                                                                                                                                                                 |             |               |         |               |       |   |  |

#### BRTC k

# Переход, если флаг Т сброшен

| Операция      | Если флаг         | $\Gamma = 0$ , to PC                                                                                                                                                                          | = PC + k + | 1, иначе РС | C = PC + 1        |   |   |   |  |
|---------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|-------------------|---|---|---|--|
| Код операции  | 1111 01k          | k kkkk k1                                                                                                                                                                                     | 10         |             | 1 слово (2 байта) |   |   |   |  |
| Операнды      | $-64 \le k \le +$ | 63                                                                                                                                                                                            |            |             |                   |   |   |   |  |
| Описание      | сброшен. В        | повный относительный переход. Проверяет флаг T и выполняет переход, если этот разряд рошен. Величина смещения k представляется числом в дополнительном коде. Эквивалент-<br>команде BRBC 6, k |            |             |                   |   |   |   |  |
| Регистр SREG  | I                 | T                                                                                                                                                                                             | Н          | S           | V                 | N | Z | C |  |
| T CINCIP SKEO |                   |                                                                                                                                                                                               |            |             |                   |   |   |   |  |
| Маш. циклов   | 1 ′               | , если T = 1<br>, если T = 0                                                                                                                                                                  |            |             |                   |   |   |   |  |
| AT90S1200     | да                |                                                                                                                                                                                               |            |             |                   |   |   |   |  |
| Пример        | brt<br><br>tclear | bst r3,5 ; Сохранить 5-й разряд r3 в флаге T<br>brtc tclear ; Перейти, если этот разряд был сброшен                                                                                           |            |             |                   |   |   |   |  |

#### BRTS k

# Переход, если флаг Т установлен

| Операция       | Если флаг                  | Г = 1, то РС                                                                                                                                                                              | = PC + k +           | 1, иначе РС | t = PC + 1 |               |        |   |
|----------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------|------------|---------------|--------|---|
| Код операции   | 1111 00k                   | k kkkk k1                                                                                                                                                                                 | 10                   |             |            | 1 слово (2 ба | ійта)  |   |
| Операнды       | $-64 \le k \le +6$         | 63                                                                                                                                                                                        |                      |             |            |               |        |   |
| Описание       | установлен.                | овный относительный переход. Проверяет флаг T и выполняет переход, если этот разряд ановлен. Величина смещения k представляется числом в дополнительном коде. Эквиватна команде BRBS 6, k |                      |             |            |               |        |   |
| Perистр SREG   | I                          | T                                                                                                                                                                                         | Н                    | S           | V          | N             | Z      | C |
| T CINCIP SICEO | _                          | _                                                                                                                                                                                         | _                    | _           | _          | _             | _      | _ |
| Маш. циклов    | 1, если T =<br>2, если T = |                                                                                                                                                                                           |                      |             |            |               |        |   |
| AT90S1200      | да                         |                                                                                                                                                                                           |                      |             |            |               |        |   |
| Пример         |                            | s tset ;                                                                                                                                                                                  | Сохранит<br>Перейти, | ~           |            | _             | новлен |   |

#### BRVC k

#### Переход, если нет переполнения дополнительного кода

| Операция      | Если флаг У                | / = 0, TO PC                                                                                                                                                                                                                | = PC + k + | 1, иначе РС | P = PC + 1 |               |       |   |  |
|---------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|------------|---------------|-------|---|--|
| Код операции  | 1111 01k                   | kkkk k0                                                                                                                                                                                                                     | 11         |             |            | 1 слово (2 ба | айта) |   |  |
| Операнды      | $-64 \le k \le +6$         | 63                                                                                                                                                                                                                          |            |             |            |               |       |   |  |
| Описание      | и выполняє                 | овный относительный переход. Проверяет флаг переполнения дополнительного кода (V) ыполняет переход, если этот разряд сброшен. Величина смещения k представляется чиси в дополнительном коде. Эквивалентна команде BRBC 3, k |            |             |            |               |       |   |  |
| Регистр SREG  | I                          | I T H S V N Z C                                                                                                                                                                                                             |            |             |            |               |       |   |  |
| T CINCIP SKEO |                            |                                                                                                                                                                                                                             |            |             |            |               |       | _ |  |
| Маш. циклов   | 1, если V =<br>2, если V = |                                                                                                                                                                                                                             |            |             |            |               |       |   |  |
| AT90S1200     | да                         |                                                                                                                                                                                                                             |            |             |            |               |       |   |  |
| Пример        | rvo<br><br>nover:          | add r3,r4 ; r3 = r3 + r4<br>rvc nover ; Перейти, если этот разряд был сброшен<br>                                                                                                                                           |            |             |            |               |       |   |  |

BRVS k

# Переход по переполнению дополнительного кода

| Операция      | Если флаг V                | / = 1, то PC                                                                                                                                                                                                                   | = PC + k + | 1, иначе РС | C = PC + 1 |               |       |   |  |
|---------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|------------|---------------|-------|---|--|
| Код операции  | 1111 00k                   | kkkk k0                                                                                                                                                                                                                        | 11         |             |            | 1 слово (2 ба | айта) |   |  |
| Операнды      | $-64 \le k \le +6$         | 4 ≤ k ≤ +63                                                                                                                                                                                                                    |            |             |            |               |       |   |  |
| Описание      | и выполняе                 | овный относительный переход. Проверяет флаг переполнения дополнительного кода (V) ыполняет переход, если этот разряд установлен. Величина смещения k представляется чиси в дополнительном коде. Эквивалентна команде BRBS 3, k |            |             |            |               |       |   |  |
| Perистр SREG  | I                          | T                                                                                                                                                                                                                              | Н          | S           | V          | N             | Z     | С |  |
| T CINCIP SKEO |                            |                                                                                                                                                                                                                                |            |             |            |               |       |   |  |
| Маш. циклов   | 1, если V =<br>2, если V = |                                                                                                                                                                                                                                |            |             |            |               |       |   |  |
| AT90S1200     | да                         |                                                                                                                                                                                                                                |            |             |            |               |       |   |  |
| Пример        | brv<br>                    | overfl:                                                                                                                                                                                                                        |            |             |            |               |       |   |  |

#### BSET s

#### Установка разряда регистра SREG

| Операция     | SREG.s = 1      | EG.s = 1                                                    |    |   |           |               |       |   |  |
|--------------|-----------------|-------------------------------------------------------------|----|---|-----------|---------------|-------|---|--|
| Код операции | 1001 0100       | 0 0sss 10                                                   | 00 |   |           | 1 слово (2 ба | айта) |   |  |
| Операнды     | $0 \le s \le 7$ | 3≤7                                                         |    |   |           |               |       |   |  |
| Описание     | Устанавлив      | танавливает заданный разряд регистра SREG                   |    |   |           |               |       |   |  |
| Peructp SREG | I               | T                                                           | Н  | S | V         | N             | Z     | C |  |
| reincip Sked | ⇔               | ⇔                                                           | ⇔  | ⇔ | <b>\$</b> | ⇔             | ⇔     | ⇔ |  |
| Маш. циклов  | 1               |                                                             |    |   |           |               |       |   |  |
| AT90S1200    | да              |                                                             |    |   |           |               |       |   |  |
| Пример       | ı               | bset 6 ; Установить флаг Т<br>bset 7 ; Разрешить прерывания |    |   |           |               |       |   |  |

# BST Rd, b

# Запись разряда РОН в флаг Т

| Операция     | T = Rd.b                                        | = Rd.b                                              |          |          |          |           |       |  |  |  |
|--------------|-------------------------------------------------|-----------------------------------------------------|----------|----------|----------|-----------|-------|--|--|--|
| Код операции | 1111 1010                                       | 111 101d dddd 0bbb 1 слово (2 байта)                |          |          |          |           |       |  |  |  |
| Операнды     | $0 \le d \le 31, 0$                             | $\leq d \leq 31, 0 \leq b \leq 7$                   |          |          |          |           |       |  |  |  |
| Описание     | Копирует р                                      | опирует разряд b регистра Rd в флаг T регистра SREG |          |          |          |           |       |  |  |  |
| Peructo SREG | I                                               | I T H S V N Z C                                     |          |          |          |           |       |  |  |  |
| reincip Sked | _                                               | - <del>+</del>                                      |          |          |          |           |       |  |  |  |
| Маш. циклов  | 1                                               |                                                     |          |          |          |           |       |  |  |  |
| AT90S1200    | да                                              | a                                                   |          |          |          |           |       |  |  |  |
|              | Копиро                                          | Копирование бита:                                   |          |          |          |           |       |  |  |  |
| Пример       | bst r1,2 ; Сохранить 2-й разряд регистра r1 в T |                                                     |          |          |          |           |       |  |  |  |
|              | blo                                             | d r0,4 ;                                            | Записать | флаг Т в | 4-й разр | яд регист | pa rO |  |  |  |

# CBI A, b

# Сбросить разряд РВВ

| Операция      | I/O(A).b = 0         | $/\mathrm{O}(\mathrm{A}).\mathrm{b} = 0$                                                                                                                            |          |          |          |               |       |   |  |
|---------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|---------------|-------|---|--|
| Код операции  | 1001 1000            | AAAA Ab                                                                                                                                                             | bb       |          | 1        | І слово (2 ба | айта) |   |  |
| Операнды      | $0 \le A \le 31$ , ( | ) ≤ b ≤ 7                                                                                                                                                           |          |          |          |               |       |   |  |
| Описание      | 1 ^                  | брасывает разряд b регистра ввода/вывода, расположенного по адресу A пространства вво-<br>/вывода. Эта команда применима только к младшим 32 регистрам (адреса 031) |          |          |          |               |       |   |  |
| Peructp SREG  | I                    | T                                                                                                                                                                   | Н        | S        | V        | N             | Z     | С |  |
| T CINCIP SKEG | _                    | _                                                                                                                                                                   | _        | _        | _        | ı             | _     | _ |  |
| Маш. циклов   | 2                    |                                                                                                                                                                     |          |          |          |               |       |   |  |
| AT90S1200     | да                   | a                                                                                                                                                                   |          |          |          |               |       |   |  |
| Пример        | cbi                  | \$12,7 ;                                                                                                                                                            | Сбросить | 7-й разр | яд порта | D             |       |   |  |

# CBR Rd, K

# Сброс разрядов РОН

| Операция     | Rd = Rd AN         | d = Rd AND (\$FF - K)                                                                                              |   |   |   |               |       |   |  |
|--------------|--------------------|--------------------------------------------------------------------------------------------------------------------|---|---|---|---------------|-------|---|--|
| Код операции | 0111 F31           | dddd F32                                                                                                           |   |   | 1 | І слово (2 ба | ійта) |   |  |
| Операнды     | $16 \le d \le 31,$ | $0 \le K \le 255$                                                                                                  |   |   |   |               |       |   |  |
| Описание     | 1 *                | брасывает разряды в регистре Rd в соответствии с маской, задаваемой константой К. езультат помещается в регистр Rd |   |   |   |               |       |   |  |
| Danwarn CDEC | I                  | T                                                                                                                  | Н | S | V | N             | Z     | С |  |
| Perистр SREG | _                  | _                                                                                                                  | _ | ⇔ | 0 | \$            | ⇔     | - |  |
| Маш. циклов  | 1                  |                                                                                                                    |   |   |   |               |       | , |  |
| AT90S1200    | да                 | a                                                                                                                  |   |   |   |               |       |   |  |
| Пример       |                    | 177 1 7 11 21 11 12 11 12 11 12 11 12 11                                                                           |   |   |   |               |       |   |  |

# CLC

# Сброс флага переноса

| Операция                                  | C = 0      | = 0                                                                       |          |          |       |               |       |   |  |
|-------------------------------------------|------------|---------------------------------------------------------------------------|----------|----------|-------|---------------|-------|---|--|
| Код операции                              | 1001 0100  | 1000 10                                                                   | 00       |          |       | 1 слово (2 ба | айта) |   |  |
| Операнды                                  | Нет операн | дов                                                                       |          |          |       |               |       |   |  |
| Описание                                  | Сбрасывает | расывает в «0» флаг переноса С регистра SREG. Эквивалентна команде BCLR 0 |          |          |       |               |       |   |  |
| Peructp SREG                              | I          | T                                                                         | Н        | S        | V     | N             | Z     | С |  |
| I CINCIP SKEG                             | _          | _                                                                         | _        | -        | _     | _             | _     | 0 |  |
| Маш. циклов                               | 1          |                                                                           |          |          | •     |               |       |   |  |
| AT90S1200                                 | да         |                                                                           |          |          |       |               |       |   |  |
| Пример add r0,r0 ; Сложить r0 сам с собой |            |                                                                           |          |          |       |               |       |   |  |
| Пример                                    | clo        | ;                                                                         | Сбросить | флаг пер | еноса |               |       |   |  |

#### CLH

# Сброс флага половинного переноса

| Операция     | H = 0               | [=0                                                                                 |    |   |   |             |       |   |  |
|--------------|---------------------|-------------------------------------------------------------------------------------|----|---|---|-------------|-------|---|--|
| Код операции | 1001 0100           | 1101 10                                                                             | 00 |   | 1 | слово (2 ба | ійта) |   |  |
| Операнды     | Нет операн          | ет операндов                                                                        |    |   |   |             |       |   |  |
| Описание     | <b>Сбрасывает</b> 5 | расывает в «0» флаг половинного переноса Н регистра SREG. Эквивалентна команде BCLR |    |   |   |             |       |   |  |
| Peructp SREG | I                   | T                                                                                   | Н  | S | V | N           | Z     | C |  |
| refucip Sked | _                   | _                                                                                   | 0  | _ | _ | _           | _     | _ |  |
| Маш. циклов  | 1                   |                                                                                     |    |   |   |             |       |   |  |
| AT90S1200    | да                  | a                                                                                   |    |   |   |             |       |   |  |
| Пример       | clh                 | clh ; Сбросить флаг половинного переноса                                            |    |   |   |             |       |   |  |

# CLI

# Общее запрещение прерываний

| Операция     | I = 0                                     | = 0                                                                                         |          |           |       |              |       |   |  |
|--------------|-------------------------------------------|---------------------------------------------------------------------------------------------|----------|-----------|-------|--------------|-------|---|--|
| Код операции | 1001 0100                                 | 1111 10                                                                                     | 00       |           |       | 1 слово (2 б | айта) |   |  |
| Операнды     | Нет операн                                | дов                                                                                         |          |           |       |              |       |   |  |
| Описание     | 1 ^                                       | расывает в «0» флаг общего разрешения прерываний I регистра SREG. Эквивалентна конде BCLR 7 |          |           |       |              |       |   |  |
| Регистр SREG | I                                         | T                                                                                           | Н        | S         | V     | N            | Z     | C |  |
| reincip Sked | 0                                         | _                                                                                           | _        | _         | _     | _            | _     | _ |  |
| Маш. циклов  | 1                                         |                                                                                             |          | •         | •     |              |       |   |  |
| AT90S1200    | да                                        |                                                                                             |          |           |       |              |       |   |  |
|              | cli                                       | cli ; Запретить прерывания                                                                  |          |           |       |              |       |   |  |
| Пример       | in r11,\$16 ; Прочитать состояние порта В |                                                                                             |          |           |       |              |       |   |  |
|              | sei                                       |                                                                                             | ; Разрег | шить прер | вания |              |       |   |  |

#### CLN

# Сброс флага отрицательного значения

| Операция     | N = 0                | $\bar{N} = 0$                                                                                 |                     |                     |            |            |       |   |  |  |
|--------------|----------------------|-----------------------------------------------------------------------------------------------|---------------------|---------------------|------------|------------|-------|---|--|--|
| Код операции | 1001 0100            | 001 0100 1010 1000 1 слово (2 байта)                                                          |                     |                     |            |            |       |   |  |  |
| Операнды     | Нет операн           | ет операндов                                                                                  |                     |                     |            |            |       |   |  |  |
| Описание     | Сбрасывает<br>BCLR 2 | Сбрасывает в «0» флаг отрицательного значения N регистра SREG. Эквивалентна команде<br>BCLR 2 |                     |                     |            |            |       |   |  |  |
| Peructo SREG | I                    | T                                                                                             | Н                   | S                   | V          | N          | Z     | С |  |  |
| Ternery Sked | _                    | _                                                                                             | _                   | _                   | _          | 0          | _     | _ |  |  |
| Маш. циклов  | 1                    |                                                                                               |                     |                     |            |            |       |   |  |  |
| AT90S1200    | да                   |                                                                                               |                     |                     |            |            |       |   |  |  |
| Пример       | add<br>clr           |                                                                                               | Сложить<br>Сбросить | r2 и r3<br>флаг отр | оицательно | ого резули | ьтата |   |  |  |

#### CLR Rd

#### Очистка РОН

| Операция     | $Rd = Rd \oplus 1$             | Rd = Rd ⊕ Rd                                                                                                              |                                                |                  |        |               |       |   |  |  |  |
|--------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------------|--------|---------------|-------|---|--|--|--|
| Код операции | 0010 01dd                      | 0010 01dd dddd dddd                                                                                                       |                                                |                  |        | 1 слово (2 ба | айта) |   |  |  |  |
| Операнды     | $0 \le d \le 31$               | ≤d≤31                                                                                                                     |                                                |                  |        |               |       |   |  |  |  |
| Описание     |                                | Сбрасывает все разряды регистра общего назначения путем выполнения операции «Исключа-<br>ощее ИЛИ» регистра с самим собой |                                                |                  |        |               |       |   |  |  |  |
| Регистр SREG | I                              | T                                                                                                                         | Н                                              | S                | V      | N             | Z     | С |  |  |  |
| reincip Sked | _                              | _                                                                                                                         | _                                              | 0                | 0      | 0             | 1     | _ |  |  |  |
| Маш. циклов  | 1                              |                                                                                                                           |                                                |                  |        |               |       |   |  |  |  |
| AT90S1200    | да                             |                                                                                                                           |                                                |                  |        |               |       |   |  |  |  |
| Пример       | clr<br>loop:<br>inc<br><br>cpi | r18<br>r18                                                                                                                | аданным чи<br>; Очисти<br>; r18=r1<br>; Заверш | ть регис:<br>8+1 | rp r18 |               |       |   |  |  |  |

**CLS** Сброс флага знака

| Операция      | S = 0      | i = 0                                                                    |   |   |   |   |   |               |  |  |
|---------------|------------|--------------------------------------------------------------------------|---|---|---|---|---|---------------|--|--|
| Код операции  | 1001 0100  | 001 0100 1100 1000 1 слово                                               |   |   |   |   |   | ово (2 байта) |  |  |
| Операнды      | Нет операн | ет операндов                                                             |   |   |   |   |   |               |  |  |
| Описание      | Сбрасывает | Сбрасывает в «0» флаг знака S регистра SREG. Эквивалентна команде BCLR 4 |   |   |   |   |   |               |  |  |
| Регистр SREG  | I          | T                                                                        | Н | S | V | N | Z | С             |  |  |
| I cincip Sked | _          | _                                                                        | _ | 0 | - | _ | _ | _             |  |  |
| Маш. циклов   | 1          |                                                                          |   |   |   |   |   |               |  |  |
| AT90S1200     | да         |                                                                          |   |   |   |   |   |               |  |  |
| Пример        | ı          | add r2,r3 ; Сложить r2 и r3<br>cls ; Сбросить флаг знака                 |   |   |   |   |   |               |  |  |

# **СLТ** Сброс флага Т

| Операция      | T = 0      | $\Gamma = 0$                                                       |          |                   |   |   |   |   |  |  |
|---------------|------------|--------------------------------------------------------------------|----------|-------------------|---|---|---|---|--|--|
| Код операции  | 1001 0100  | 1110 10                                                            | 00       | 1 слово (2 байта) |   |   |   |   |  |  |
| Операнды      | Нет операн | Нет операндов                                                      |          |                   |   |   |   |   |  |  |
| Описание      | Сбрасывает | Сбрасывает в «0» флаг T регистра SREG. Эквивалентна команде BCLR 6 |          |                   |   |   |   |   |  |  |
| Регистр SREG  | I          | T                                                                  | Н        | S                 | V | N | Z | C |  |  |
| T CINCIP SKEG | _          | 0                                                                  | _        | _                 | _ | _ | _ | _ |  |  |
| Маш. циклов   | 1          | 1                                                                  |          |                   |   |   |   |   |  |  |
| AT90S1200     | да         | Tg .                                                               |          |                   |   |   |   |   |  |  |
| Пример        | clt        | ; Сбросі                                                           | ить флаг | Т                 |   |   |   |   |  |  |

# **CLV** Сброс флага переполнения дополнительного кода

| Операция     | V = 0      |                                                                                                      |                     |   |           |    |   |   |  |
|--------------|------------|------------------------------------------------------------------------------------------------------|---------------------|---|-----------|----|---|---|--|
| Код операции | 1001 0100  | 001 0100 1011 1000 1 слово (2 байта)                                                                 |                     |   |           |    |   |   |  |
| Операнды     | Нет операн | Іет операндов                                                                                        |                     |   |           |    |   |   |  |
| Описание     | 1 *        | Сбрасывает в «0» флаг переполнения дополнительного кода V регистра SREG. Эквивалентна команде BCLR 3 |                     |   |           |    |   |   |  |
| Perистр SREG | I          | T                                                                                                    | Н                   | S | V         | N  | Z | C |  |
| reincip Sked | _          | _                                                                                                    | _                   | _ | 0         | _  | _ | _ |  |
| Маш. циклов  | 1          |                                                                                                      |                     |   |           |    |   |   |  |
| AT90S1200    | да         | ца                                                                                                   |                     |   |           |    |   |   |  |
| Пример       | add<br>clv |                                                                                                      | Сложить<br>Сбросить |   | еполнения | ī. |   |   |  |

**CLZ** Сброс флага нуля

| Операция     | Z = 0                                                                   | Z = 0                                 |                     |                     |    |   |   |   |  |  |
|--------------|-------------------------------------------------------------------------|---------------------------------------|---------------------|---------------------|----|---|---|---|--|--|
| Код операции | 1001 0100                                                               | 1001 0100 1001 1000 1 слово (2 байта) |                     |                     |    |   |   |   |  |  |
| Операнды     | Нет операн                                                              | Нет операндов                         |                     |                     |    |   |   |   |  |  |
| Описание     | Сбрасывает в «0» флаг нуля Z регистра SREG. Эквивалентна команде BCLR 1 |                                       |                     |                     |    |   |   |   |  |  |
| Регистр SREG | I                                                                       | T                                     | Н                   | S                   | V  | N | Z | С |  |  |
| reincip sked | _                                                                       | _                                     | _                   | _                   | _  | _ | 0 | _ |  |  |
| Маш. циклов  | 1                                                                       | 1                                     |                     |                     |    |   |   |   |  |  |
| AT90S1200    | да                                                                      | да                                    |                     |                     |    |   |   |   |  |  |
| Пример       | ı                                                                       |                                       | Сложить<br>Сбросить | r2 и r3<br>флаг нул | RI |   |   |   |  |  |

#### COM Rd

# Вычисление обратного кода

| Операция     | Rd = FF -            | Rd = \$FF - Rd                                                                                      |           |           |            |       |   |   |  |  |
|--------------|----------------------|-----------------------------------------------------------------------------------------------------|-----------|-----------|------------|-------|---|---|--|--|
| Код операции | 1001 0100            | 001 010d dddd dddd 1 слово (2 байта)                                                                |           |           |            |       |   |   |  |  |
| Операнды     | 0 ≤ d ≤ 31           | ≤d≤31                                                                                               |           |           |            |       |   |   |  |  |
| Описание     | Вычисляет peгистр Rd | Вычисляет обратный код числа, находящегося в регистре Rd. Результат помещается обратно в регистр Rd |           |           |            |       |   |   |  |  |
| Downers CDEC | I                    | T                                                                                                   | Н         | S         | v          | N     | Z | С |  |  |
| Perистр SREG | _                    | _                                                                                                   | _         | ⇔         | 0          | ⇔     | ⇔ | 1 |  |  |
| Маш. циклов  | 1                    | 1                                                                                                   |           |           |            |       |   |   |  |  |
| AT90S1200    | да                   |                                                                                                     |           |           |            |       |   |   |  |  |
| Пример       | con                  | n r4 ; Вы                                                                                           | числить д | оп. код с | содержимо: | го r4 |   |   |  |  |

## CP Rd, Rr

## Сравнение РОН

| Операция     | Rd – Rr                                  |                                                                                                                                                                                                                                                                                                                                                                                            |    |   |   |              |       |   |  |  |
|--------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|--------------|-------|---|--|--|
| Код операции | 0001 01rd                                | d dddd rr                                                                                                                                                                                                                                                                                                                                                                                  | rr |   |   | 1 слово (2 б | айта) |   |  |  |
| Операнды     | $0 \le d \le 31, 0$                      | ≤d≤31,0≤r≤31                                                                                                                                                                                                                                                                                                                                                                               |    |   |   |              |       |   |  |  |
| Описание     | регистра Rr<br>стояния SR<br>мое регистр | авнивает содержимое двух регистров общего назначения путем вычитания содержимого<br>гистра Rr из содержимого регистра Rd. Данная команда влияет только на флаги регистра со-<br>ояния SREG, которые устанавливаются в соответствии с результатом вычитания. Содержи-<br>е регистров не изменяется. Как правило, данная команда используется совместно с одной<br>команд условного перехода |    |   |   |              |       |   |  |  |
| D CDEC       | I                                        | T                                                                                                                                                                                                                                                                                                                                                                                          | Н  | S | V | N            | Z     | С |  |  |
| Peructp SREG | _                                        | _                                                                                                                                                                                                                                                                                                                                                                                          | ⇔  | ⇔ | ⇔ | ⇔            | ⇔     | ⇔ |  |  |
| Маш. циклов  | 1                                        |                                                                                                                                                                                                                                                                                                                                                                                            |    |   |   | •            | '     |   |  |  |
| AT90S1200    | да                                       |                                                                                                                                                                                                                                                                                                                                                                                            |    |   |   |              |       |   |  |  |
| Пример       | brr<br><br>noteq:                        | cp r4,r19 ; Сравнить r4 с r19 (R=r4-r19)<br>brne noteq ; Перейти, если r4 <> r19                                                                                                                                                                                                                                                                                                           |    |   |   |              |       |   |  |  |

# CPC Rd, Rr

# Сравнение РОН с учетом переноса

| Операция     | Rd - Rr - C                                | 1 - Rr - C                                                                                                                                                                                                                                                                                                                                                                                                 |                                                 |                        |                    |              |       |   |  |  |  |
|--------------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|------------------------|--------------------|--------------|-------|---|--|--|--|
| Код операции | 0000 01rd                                  | d dddd rr                                                                                                                                                                                                                                                                                                                                                                                                  | rr                                              |                        |                    | 1 слово (2 б | айта) |   |  |  |  |
| Операнды     | $0 \le d \le 31, 0$                        | ≤ r ≤ 31                                                                                                                                                                                                                                                                                                                                                                                                   |                                                 |                        |                    |              |       |   |  |  |  |
| Описание     | регистра Rr<br>яет только в<br>зультатом в | равнивает содержимое двух регистров общего назначения путем вычитания содержимого гистра Rr и значения флага переноса (С) из содержимого регистра Rd. Данная команда влит только на флаги регистра состояния SREG, которые устанавливаются в соответствии с репытатом вычитания. Содержимое регистров не изменяется. Как правило, данная команда пользуется совместно с одной из команд условного перехода |                                                 |                        |                    |              |       |   |  |  |  |
| Danwarn CDEC | I                                          | T                                                                                                                                                                                                                                                                                                                                                                                                          | Н                                               | S                      | V                  | N            | Z     | С |  |  |  |
| Peructp SREG | _                                          |                                                                                                                                                                                                                                                                                                                                                                                                            |                                                 |                        |                    |              |       |   |  |  |  |
| Маш. циклов  | 1                                          |                                                                                                                                                                                                                                                                                                                                                                                                            |                                                 |                        |                    |              |       |   |  |  |  |
| AT90S1200    | да                                         |                                                                                                                                                                                                                                                                                                                                                                                                            |                                                 |                        |                    |              |       |   |  |  |  |
| Пример       | cp<br>cpc                                  | r2,r0<br>r3,r1                                                                                                                                                                                                                                                                                                                                                                                             | овых пар<br>; Сравнит<br>; Сравнит<br>; Перейти | ь младшие<br>ь старшие | е байты<br>е байты | 1:r0         |       |   |  |  |  |

## CPI Rd, K

# Сравнение содержимого РОН с константой

| Операция     | Rd – K                           |                                                                                                                                                                                                                                                                                                                                                                                                 |      |   |   |               |       |   |  |  |
|--------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---|---|---------------|-------|---|--|--|
| Код операции | 0011 KKK                         | K dddd K                                                                                                                                                                                                                                                                                                                                                                                        | KKKK |   |   | 1 слово (2 ба | ійта) |   |  |  |
| Операнды     | $0 \le d \le 31, 0$              | ≤ d ≤ 31, 0 ≤ K ≤ 255                                                                                                                                                                                                                                                                                                                                                                           |      |   |   |               |       |   |  |  |
| Описание     | константы стояния SR мое регистр | оавнивает содержимое регистра общего назначения Rd с константой К путем вычитания<br>нстанты из содержимого регистра Rd. Данная команда влияет только на флаги регистра со-<br>ояния SREG, которые устанавливаются в соответствии с результатом вычитания. Содержи-<br>ре регистра Rd не изменяется. Как правило, данная команда используется совместно с од-<br>й из команд условного перехода |      |   |   |               |       |   |  |  |
| D CDEC       | I                                | T                                                                                                                                                                                                                                                                                                                                                                                               | Н    | S | V | N             | Z     | С |  |  |
| Perистр SREG | _                                | _                                                                                                                                                                                                                                                                                                                                                                                               | ⇔    | ⇔ | ⇔ | ⇔             | ⇔     | ⇔ |  |  |
| Маш. циклов  | 1                                |                                                                                                                                                                                                                                                                                                                                                                                                 |      |   |   |               |       | • |  |  |
| AT90S1200    | да                               |                                                                                                                                                                                                                                                                                                                                                                                                 |      |   |   |               |       |   |  |  |
| Пример       | brr                              | cpi r19,3 ; Сравнить r19 с числом 3 (R=r19-3) brne noteq ; Перейти, если r19 <> 3 noteq:                                                                                                                                                                                                                                                                                                        |      |   |   |               |       |   |  |  |

## CPSE Rd, Rr

# Пропуск команды при равенстве двух РОН

| Операция      | Если Rd = 1         | Если Rd = Rr, то PC = PC +2 (или 3), иначе PC = PC + 1                                                                                     |                                             |             |          |                 |   |   |  |  |
|---------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-------------|----------|-----------------|---|---|--|--|
| Код операции  | 0001 00rd           | d dddd rr                                                                                                                                  | rr                                          |             | 1 слов   | во (2 байта)    |   |   |  |  |
| Операнды      | $0 \le d \le 31, 0$ | $\leq d \leq 31, 0 \leq r \leq 31$                                                                                                         |                                             |             |          |                 |   |   |  |  |
| Описание      |                     | равнивает содержимое двух регистров общего назначения Rr и Rd и пропускает следующую оманду, если в регистрах записаны одинаковые значения |                                             |             |          |                 |   |   |  |  |
| Регистр SREG  | I                   | T                                                                                                                                          | Н                                           | S           | V        | N               | Z | С |  |  |
| I cincip Sked | _                   |                                                                                                                                            |                                             |             |          |                 |   |   |  |  |
| Маш. циклов   | 2, если Rd =        | = Rr (размер                                                                                                                               | опуска кома<br>о пропускаем<br>о пропускаем | иой команді |          |                 |   |   |  |  |
| AT90S1200     | да                  |                                                                                                                                            |                                             |             |          |                 |   |   |  |  |
| Пример        | cps                 | se r4,r0<br>r4                                                                                                                             | ; Увеличи<br>; Сравнит<br>; Проинве         | ь содержи   | мое r4 и | r0<br>u r4 ≠ r0 |   |   |  |  |

## **DEC Rd** Декремент РОН

| Операция      | Rd = Rd - 1                                                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |   |   |               |       |   |  |  |
|---------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|
| Код операции  | 1001 0100                                                            | d dddd 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 10 |   |   | 1 слово (2 ба | ійта) |   |  |  |
| Операнды      | $0 \le d \le 31$                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |   |   |               |       |   |  |  |
| Описание      | носа С, она нении вычи выполнени ваться толь тельном кол Флаг V уста | меньшает содержимое регистра Rd на единицу. Так как эта команда не влияет на флаг пере-<br>оса C, она идеально подходит для организации счетчика числа итераций цикла при выпол-<br>ении вычислений над многоразрядными числами. При работе с беззнаковыми числами для<br>ыполнения перехода в соответствии с результатом выполнения команды могут использо-<br>аться только команды условного перехода BREQ и BRNE. При работе с числами в дополни-<br>ельном коде могут использоваться все команды условного перехода для знаковых проверок.<br>Глаг V устанавливается в «1» только в том случае, если до выполнения операции в регистре<br>аходилось значение \$80 |    |   |   |               |       |   |  |  |
| Perистр SREG  | I                                                                    | T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Н  | S | V | N             | Z     | C |  |  |
| I cincip Sked | _                                                                    | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | _  | ⇔ | ⇔ | ⇔             | ⇔     | _ |  |  |
| Маш. циклов   | 1                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |   |   |               |       |   |  |  |
| AT90S1200     | да                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |   |   |               |       |   |  |  |
| Пример        | loop:<br>add<br>dec<br>brn                                           | ldi r17,\$10 ; Записать число 16 в регистр r17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |   |   |               |       |   |  |  |

# EOR Rd, Rr

# «Исключающее ИЛИ» двух РОН

| Операция     | $Rd = Rd \oplus 1$  | $d = Rd \oplus Rr$                                                                                |                        |   |   |               |          |   |  |
|--------------|---------------------|---------------------------------------------------------------------------------------------------|------------------------|---|---|---------------|----------|---|--|
| Код операции | 0010 01rd           | dddd rr                                                                                           | rr                     |   | 1 | І слово (2 ба | ійта)    |   |  |
| Операнды     | $0 \le d \le 31, 0$ | 3 d ≤ 31, 0 ≤ r ≤ 31                                                                              |                        |   |   |               |          |   |  |
| 1 Описание   | 1                   | полняет операцию «Исключающее ИЛИ» между регистрами Rd и Rr. Результат помеща-<br>ся в регистр Rd |                        |   |   |               |          |   |  |
| Danwarn CDEC | I                   | T                                                                                                 | Н                      | S | V | N             | Z        | C |  |
| Peructp SREG | _                   | _                                                                                                 | _                      | ⇔ | 0 | \$            | \$       | - |  |
| Маш. циклов  | 1                   |                                                                                                   |                        |   |   |               |          |   |  |
| AT90S1200    | да                  |                                                                                                   |                        |   |   |               |          |   |  |
| Пример       | 1                   |                                                                                                   | ; Очистка<br>; Побитов |   |   | И" между      | г0 и г22 |   |  |

#### **ICALL**

# Косвенный вызов подпрограммы

| Операция     | STACK = P  | STACK = PC + 1; PC = Z; SP = SP - 2                                                                                                                                     |   |   |                   |           |           |     |  |  |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-------------------|-----------|-----------|-----|--|--|
| Код операции | 1001 0101  | 1 слово (2 байта)                                                                                                                                                       |   |   |                   |           |           |     |  |  |
| Операнды     | Нет операн | Нет операндов                                                                                                                                                           |   |   |                   |           |           |     |  |  |
| Описание     |            | освенный вызов подпрограммы. Выполняет переход к подпрограмме, адрес которой нахо-<br>ится в регистре Z. Адрес следующей за ICALL команды (2 байта) сохраняется в стеке |   |   |                   |           |           |     |  |  |
| Peructp SREG | I          | T                                                                                                                                                                       | Н | S | v                 | N         | Z         | С   |  |  |
| reincip Sked | _          |                                                                                                                                                                         |   |   |                   |           |           |     |  |  |
| Маш. циклов  | 3          |                                                                                                                                                                         |   |   |                   |           |           |     |  |  |
| AT90S1200    | нет        |                                                                                                                                                                         |   |   |                   |           |           |     |  |  |
| Пример       | ı          | ,                                                                                                                                                                       |   |   | амму, адр<br>:r30 | оес котор | ой находи | тся |  |  |

#### IJMP

# Косвенный переход

| Операция     | PC = Z     | C = Z                                                                                 |                       |                      |            |   |   |   |  |
|--------------|------------|---------------------------------------------------------------------------------------|-----------------------|----------------------|------------|---|---|---|--|
| Код операции | 1001 0100  | 001 0100 0000 1001 1 слово (2 байта)                                                  |                       |                      |            |   |   |   |  |
| Операнды     | Нет операн | ет операндов                                                                          |                       |                      |            |   |   |   |  |
| Описание     | Косвенны   | Косвенный безусловный переход. Выполняет переход по адресу, находящемуся в регистре Z |                       |                      |            |   |   |   |  |
| Peructo SREG | I          | Т                                                                                     | Н                     | S                    | v          | N | Z | С |  |
| refucip Sked | _          | _                                                                                     | _                     | _                    | _          | _ | _ | _ |  |
| Маш. циклов  | 2          | ,                                                                                     |                       |                      |            |   |   |   |  |
| AT90S1200    | нет        |                                                                                       |                       |                      |            |   |   |   |  |
| Пример       | ı          |                                                                                       | ; Задать<br>; Перейти | смещение<br>по адрес | ry r31:r30 | ) |   |   |  |

**IN Rd, A** Пересылка значения из PBB в POH

| Операция     | Rd = I/O(A)                   | d = I/O(A)                                                                   |         |                                     |         |                      |    |   |  |  |  |
|--------------|-------------------------------|------------------------------------------------------------------------------|---------|-------------------------------------|---------|----------------------|----|---|--|--|--|
| Код операции | 1011 0AAd                     | 011 0AAd dddd AAAA                                                           |         |                                     |         |                      |    |   |  |  |  |
| Операнды     | $0 \le d \le 31, 0$           | ≤d≤31,0≤A≤63                                                                 |         |                                     |         |                      |    |   |  |  |  |
| Описание     | Пересылает                    | lepecылает содержимое регистра ввода/вывода А в регистр общего назначения Rd |         |                                     |         |                      |    |   |  |  |  |
| Регистр SREG | I                             | T                                                                            | Н       | S                                   | V       | N                    | Z  | С |  |  |  |
| reincip Sked | _                             | _                                                                            | _       | _                                   | _       | _                    | _  | _ |  |  |  |
| Маш. циклов  | 1                             |                                                                              |         |                                     |         |                      |    |   |  |  |  |
| AT90S1200    | да                            |                                                                              |         |                                     |         |                      |    |   |  |  |  |
| Пример       | in<br>cpi<br>bre<br><br>exit: | r25,4                                                                        | ; Сравн | тать соде<br>ить содер<br>ити, если | жимое с | орта В<br>константой | Ĭ. |   |  |  |  |

## INC Rd Инкремент РОН

| Операция     | Rd = Rd + 1                                                                         | I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |               |       |   |  |  |  |
|--------------|-------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|--|
| Код операции | 1001 0100                                                                           | dddd 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 11 |   |   | 1 слово (2 ба | айта) |   |  |  |  |
| Операнды     | $0 \le d \le 31$                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |   |   |               |       |   |  |  |  |
| Описание     | реноса С, о<br>нении вычи<br>выполнени<br>ваться толь<br>тельном ко,<br>Флаг V уста | величивает содержимое регистра Rd на единицу. Так как эта команда не влияет на флаг пе-<br>носа C, она идеально подходит для организации счетчика числа итераций цикла при выпол-<br>ении вычислений над многоразрядными числами. При работе с беззнаковыми числами для<br>иполнения перехода в соответствии с результатом выполнения команды могут использо-<br>ться только команды условного перехода BREQ и BRNE. При работе с числами в дополни-<br>льном коде могут использоваться все команды условного перехода для знаковых проверок.<br>лаг V устанавливается в «1» только в том случае, если до выполнения операции в регистре<br>кходилось значение \$7F |    |   |   |               |       |   |  |  |  |
| Peructp SREG | I                                                                                   | T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Н  | S | V | N             | Z     | С |  |  |  |
| refucip Sked | _                                                                                   | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | _  | ⇔ | ⇔ | ⇔             | ⇔     | _ |  |  |  |
| Маш. циклов  | 1                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | •  |   |   |               |       |   |  |  |  |
| AT90S1200    | да                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |   |   |               |       |   |  |  |  |
| Пример       | loop:<br>ind<br><br>cpi                                                             | inc r22 ; r22=r22+1<br><br>cpi r22,\$4F ;<br>brne loop ; Продолжать цикл, если r22≠\$4F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |   |   |               |       |   |  |  |  |

## LD Rd, X

## Косвенное чтение памяти данных

| Операция     | Rd = [X]         | Rd = [X]                                                                                                                                                                                |   |          |                        |   |       |   |  |
|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------|------------------------|---|-------|---|--|
| Код операции | 1001 0000        | 001 000d dddd 1100                                                                                                                                                                      |   |          |                        |   |       |   |  |
| Операнды     | $0 \le d \le 31$ | ≤d≤31                                                                                                                                                                                   |   |          |                        |   |       |   |  |
| Описание     |                  | Загружает один байт из адресного пространства памяти данных в регистр общего назначения Rd.<br>Адрес ячейки памяти, к которой производится обращение, содержится в индексном регистре X |   |          |                        |   |       |   |  |
| Peructp SREG | I                | T                                                                                                                                                                                       | Н | S        | V                      | N | Z     | С |  |
| Ternery Sked | _                | -                                                                                                                                                                                       | _ | _        | _                      | _ | _     | _ |  |
| Маш. циклов  | 2                |                                                                                                                                                                                         |   |          |                        |   |       |   |  |
| AT90S1200    | нет              |                                                                                                                                                                                         |   |          |                        |   |       |   |  |
| Пример       | 1di              |                                                                                                                                                                                         |   | вить мл. | айт индек<br>байт адре | _ | истра |   |  |

# LD Rd, X+

## Косвенное чтение памяти данных с постинкрементом

| Операция     | Rd = [X], X   | Rd = [X], X = X + 1                                                                                                                                                                                                                                       |                                              |                       |  |               |       |  |  |
|--------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-----------------------|--|---------------|-------|--|--|
| Код операции | 1001 0000     | d dddd 11                                                                                                                                                                                                                                                 | 01                                           |                       |  | 1 слово (2 ба | айта) |  |  |
| Операнды     | 0 ≤ d ≤ 31, д | ≤ d ≤ 31, для d = 26 или 27 результат операции не определен                                                                                                                                                                                               |                                              |                       |  |               |       |  |  |
| Описание     | Rd. Адрес я   | агружает один байт из адресного пространства памяти данных в регистр общего назначения<br>d. Адрес ячейки памяти, к которой производится обращение, содержится в индексном реги-<br>гре X. После пересылки байта содержимое регистра X увеличивается на 1 |                                              |                       |  |               |       |  |  |
| Peructp SREG | I –           | I T H S V N Z C                                                                                                                                                                                                                                           |                                              |                       |  |               |       |  |  |
| Маш. циклов  | 2             |                                                                                                                                                                                                                                                           |                                              |                       |  |               | 1     |  |  |
| AT90S1200    | нет           |                                                                                                                                                                                                                                                           |                                              |                       |  |               |       |  |  |
| Пример       | ldi<br>ld     | r1,X+                                                                                                                                                                                                                                                     | ; Очисти<br>; Загруз<br>; r1 = [<br>; В реги | ить мл. 6<br>[\$0060] |  | -             | истра |  |  |

**LD Rd, –X** Косвенное чтение памяти данных с преддекрементом

| Операция     | X = X - 1, I  | Rd = [X]                                                                                                                                                                                                                                                            |                                |              |              |                 |        |   |  |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------|--------------|-----------------|--------|---|--|
| Код операции | 1001 0000     | 001 000d dddd 1110 <b>1 слово (2 байта)</b>                                                                                                                                                                                                                         |                                |              |              |                 |        |   |  |
| Операнды     | 0 ≤ d ≤ 31, д | ля d = 26 ил                                                                                                                                                                                                                                                        | и 27 резулы                    | гат операциі | и не определ | тен             |        |   |  |
| Описание     | Rd. Адрес я   | вагружает один байт из адресного пространства памяти данных в регистр общего назначения Rd. Адрес ячейки памяти, к которой производится обращение, содержится в индексном регисре X, причем перед обращением к памяти данных содержимое регистра X уменьшается на 1 |                                |              |              |                 |        |   |  |
| Peructp SREG | I             | T<br>_                                                                                                                                                                                                                                                              | H<br>-                         | S<br>_       | v<br>_       | N<br>_          | Z<br>_ | C |  |
| Маш. циклов  | 2             |                                                                                                                                                                                                                                                                     |                                |              |              |                 |        | 1 |  |
| AT90S1200    | нет           | нет                                                                                                                                                                                                                                                                 |                                |              |              |                 |        |   |  |
| Пример       | ldi           |                                                                                                                                                                                                                                                                     | ; Очисти<br>; Загруз<br>; r3 = | ить мл. б    |              | сного рег<br>са | истра  |   |  |

# **LD Rd, Y** Косвенное чтение памяти данных

| Операция     | Rd = [Y]         |                                                                                                                                                                                        |    |                                      |   |               |       |   |  |
|--------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------------------------------------|---|---------------|-------|---|--|
| Код операции | 1000 0000        | d dddd 10                                                                                                                                                                              | 00 |                                      |   | 1 слово (2 ба | ійта) |   |  |
| Операнды     | $0 \le d \le 31$ | ≤d≤31                                                                                                                                                                                  |    |                                      |   |               |       |   |  |
| Описание     | 1.               | агружает один байт из адресного пространства памяти данных в регистр общего назначения Rd.<br>удрес ячейки памяти, к которой производится обращение, содержится в индексном регистре Y |    |                                      |   |               |       |   |  |
| Регистр SREG | I                | T                                                                                                                                                                                      | Н  | S                                    | V | N             | Z     | С |  |
| reincip Sked | _                | _                                                                                                                                                                                      | _  | _                                    | _ | _             | _     | _ |  |
| Маш. циклов  | 2                |                                                                                                                                                                                        |    |                                      | • |               |       |   |  |
| AT90S1200    | нет              |                                                                                                                                                                                        |    |                                      |   |               |       |   |  |
| Пример       | ldi              |                                                                                                                                                                                        |    | ить ст. ба<br>вить мл. (<br>[\$0060] |   | _             | истра |   |  |

## LD Rd, Y+

## Косвенное чтение памяти данных с постинкрементом

| Операция     | Rd = [Y], Y   | = Y + 1                                                                                                                                                                                                                                           |   |   |   |   |   |   |  |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|--|
| Код операции | 1001 0000     | 001 000d dddd 1001 1 слово (2 байта)                                                                                                                                                                                                              |   |   |   |   |   |   |  |
| Операнды     | 0 ≤ d ≤ 31, д | $\leq$ d $\leq$ 31, для d = 28 или 29 результат операции не определен                                                                                                                                                                             |   |   |   |   |   |   |  |
| Описание     | Rd. Адрес я   | агружает один байт из адресного пространства памяти данных в регистр общего назначения d. Адрес ячейки памяти, к которой производится обращение, содержится в индексном регитре Y. После пересылки байта содержимое регистра Y увеличивается на 1 |   |   |   |   |   |   |  |
| Регистр SREG | I             | T                                                                                                                                                                                                                                                 | Н | S | V | N | Z | С |  |
| Perucip SkeG | _             | _                                                                                                                                                                                                                                                 | _ | _ | _ | _ | _ | _ |  |
| Маш. циклов  | 2             |                                                                                                                                                                                                                                                   |   |   |   |   | • | • |  |
| AT90S1200    | нет           |                                                                                                                                                                                                                                                   |   |   |   |   |   |   |  |
| Пример       | ldi<br>ld     | ct clr r29 ; Очистить ст. байт индексного регистра ldi r28,\$60 ; Загрузить мл. байт адреса ld r1,Y+ ; r1 = [\$0060] in r2,r28 ; В регистре r2 — \$61                                                                                             |   |   |   |   |   |   |  |

#### LD Rd, -Y

## Косвенное чтение памяти данных с преддекрементом

| Операция     | Y = Y - 1, I                                                                                                            | Rd = [Y]                                                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|
| Код операции | 1001 0000                                                                                                               | d dddd 10                                                                                                                                                                                                                                                                 | 10 |   |   | 1 слово (2 ба | ійта) |   |  |
| Операнды     | 0 ≤ d ≤ 31, д                                                                                                           | $\leq$ d $\leq$ 31, для d = 28 или 29 результат операции не определен                                                                                                                                                                                                     |    |   |   |               |       |   |  |
| Описание     | Rd. Адрес я                                                                                                             | агружает один байт из адресного пространства памяти данных в регистр общего назначения<br>d. Адрес ячейки памяти, к которой производится обращение, содержится в индексном регис-<br>ре Y, причем перед обращением к памяти данных содержимое регистра Y уменьшается на 1 |    |   |   |               |       |   |  |
| Perистр SREG | I –                                                                                                                     | I T H S V N Z C                                                                                                                                                                                                                                                           |    |   |   |               |       |   |  |
| Маш. циклов  | 2                                                                                                                       |                                                                                                                                                                                                                                                                           | 1  | ' | ' |               | '     | , |  |
| AT90S1200    | нет                                                                                                                     |                                                                                                                                                                                                                                                                           |    |   |   |               |       |   |  |
| Пример       | clr r29 ; Очистить ст. байт индексного регистра<br>ldi r28,\$63 ; Загрузить мл. байт адреса<br>ld r3,-Y ; r3 = [\$0062] |                                                                                                                                                                                                                                                                           |    |   |   |               |       |   |  |

 ${f LD}$   ${f Rd}$ ,  ${f Z}$  Косвенное чтение памяти данных

| Операция      | Rd = [Z]                   |                                                                                                                                                                                                                                                                                                                                                      |                                |            |                        |               |       |   |  |  |
|---------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|------------|------------------------|---------------|-------|---|--|--|
| Код операции  | 1000 0000                  | dddd 00                                                                                                                                                                                                                                                                                                                                              | 00                             |            |                        | 1 слово (2 ба | ійта) |   |  |  |
| Операнды      | $0 \le d \le 31$           | ≤d≤31                                                                                                                                                                                                                                                                                                                                                |                                |            |                        |               |       |   |  |  |
| Описание      | Rd. Для мод<br>вый файл, д | гружает один байт из адресного пространства памяти данных в регистр общего назначения<br>1. Для модели AT90S1200 в адресное пространство памяти данных входит только регистро-<br>ій файл, для остальных — регистровый файл, память ввода/вывода и ОЗУ. Адрес ячейки па-<br>іти, к которой производится обращение, содержится в индексном регистре Z |                                |            |                        |               |       |   |  |  |
| Peructp SREG  | I                          | T                                                                                                                                                                                                                                                                                                                                                    | Н                              | S          | V                      | N             | Z     | C |  |  |
| I cincip sked | _                          | _                                                                                                                                                                                                                                                                                                                                                    | _                              | _          | _                      | _             | _     | _ |  |  |
| Маш. циклов   | 2                          |                                                                                                                                                                                                                                                                                                                                                      |                                |            |                        |               |       |   |  |  |
| AT90S1200     | да                         |                                                                                                                                                                                                                                                                                                                                                      |                                |            |                        |               |       |   |  |  |
| Пример        | ldi                        |                                                                                                                                                                                                                                                                                                                                                      | ; Очисти<br>; Загруз<br>; r1 = | вить мл. 6 | айт индек<br>байт адре | _             | истра |   |  |  |

# **LD Rd, Z+** Косвенное чтение памяти данных с постинкрементом

| Операция     | Rd = [Z], Z   | = Z + 1                                                                                                                                                                                                                                           |    |   |   |               |       |   |  |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|
| Код операции | 1001 0000     | dddd 00                                                                                                                                                                                                                                           | 01 |   | 1 | 1 слово (2 ба | айта) |   |  |
| Операнды     | 0 ≤ d ≤ 31, д | $\leq$ d $\leq$ 31, для d = 30 или 31 результат операции не определен                                                                                                                                                                             |    |   |   |               |       |   |  |
| Описание     | Rd. Адрес я   | агружает один байт из адресного пространства памяти данных в регистр общего назначения d. Адрес ячейки памяти, к которой производится обращение, содержится в индексном регитре Z. После пересылки байта содержимое регистра Z увеличивается на 1 |    |   |   |               |       |   |  |
| Peructp SREG | I             | T                                                                                                                                                                                                                                                 | Н  | S | V | N             | Z     | С |  |
| Perucip Skeg | _             | _   _   _   _   _   _   _                                                                                                                                                                                                                         |    |   |   |               |       |   |  |
| Маш. циклов  | 2             |                                                                                                                                                                                                                                                   |    |   |   |               |       | _ |  |
| AT90S1200    | нет           |                                                                                                                                                                                                                                                   |    |   |   |               |       |   |  |
| Пример       | ldi<br>ld     | clr r31 ; Очистить ст. байт индексного регистра ldi r30,\$60 ; Загрузить мл. байт адреса ld r1,Z+ ; r1 = [\$0060] in r2,r30 ; В регистре r2 — \$61                                                                                                |    |   |   |               |       |   |  |

LD Rd, -Z

## Косвенное чтение памяти данных с преддекрементом

| Операция      | Z = Z - 1, I  | Rd = [Z]                                                                                                                                                                                                                                                                   |                                  |             |              |                 |       |   |  |
|---------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------|--------------|-----------------|-------|---|--|
| Код операции  | 1001 0000     | 1 cлово (2 байта)                                                                                                                                                                                                                                                          |                                  |             |              |                 |       |   |  |
| Операнды      | 0 ≤ d ≤ 31, д | ля d = 30 ил                                                                                                                                                                                                                                                               | и 31 результ                     | ат операциі | и не определ | іен             |       |   |  |
| Описание      | Rd. Адрес я   | агружает один байт из адресного пространства памяти данных в регистр общего назначения<br>dd. Адрес ячейки памяти, к которой производится обращение, содержится в индексном регис-<br>ре Z. причем перед обрашением к памяти данных содержимое регистра Z уменьшается на 1 |                                  |             |              |                 |       |   |  |
| Регистр SREG  | I             | T                                                                                                                                                                                                                                                                          | Н                                | S           | V            | N               | Z     | С |  |
| T CINCIP SKEO | _             | ı                                                                                                                                                                                                                                                                          | _                                | _           | _            | _               | _     | _ |  |
| Маш. циклов   | 2             |                                                                                                                                                                                                                                                                            |                                  |             |              |                 |       |   |  |
| AT90S1200     | нет           |                                                                                                                                                                                                                                                                            |                                  |             |              |                 |       |   |  |
| Пример        | ldi           |                                                                                                                                                                                                                                                                            | ; Очисти<br>; Загруз<br>; r3 = [ | ить мл. б   |              | сного рег<br>са | истра |   |  |

#### LDD Rd, Y+q

## Косвенное относительное чтение памяти данных

| Операция       | Rd = [Y + q]                                                                                                              |                                                                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|
| Код операции   | 10q0 qq0d                                                                                                                 | d dddd 1q                                                                                                                                                                                                                                                                        | qq |   |   | 1 слово (2 ба | ійта) |   |  |  |
| Операнды       | $0 \le d \le 31$ , (                                                                                                      | $\leq d \leq 31, \ 0 \leq q \leq 63$                                                                                                                                                                                                                                             |    |   |   |               |       |   |  |  |
| Описание       | Rd. Адрес я                                                                                                               | агружает один байт из адресного пространства памяти данных в регистр общего назначения<br>d. Адрес ячейки памяти, к которой производится обращение, получается суммированием<br>одержимого индексного регистра Y и константы q. Содержимое индексного регистра не из-<br>еняется |    |   |   |               |       |   |  |  |
| Регистр SREG   | I                                                                                                                         | T                                                                                                                                                                                                                                                                                | Н  | S | V | N             | Z     | C |  |  |
| T CINCIP SICEO | _                                                                                                                         | -                                                                                                                                                                                                                                                                                | _  | _ | _ | _             | _     | _ |  |  |
| Маш. циклов    | 2                                                                                                                         |                                                                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |  |
| AT90S1200      | нет                                                                                                                       |                                                                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |  |
| Пример         | clr r29 ; Очистить ст. байт индексного регистра<br>ldi r28,\$63 ; Загрузить мл. байт адреса<br>ldd r4,Y+2 ; r4 = [\$0065] |                                                                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |  |

## LDD Rd, Z+q

#### Косвенное относительное чтение памяти данных

| Операция      | Rd = [Z + q]         | ]                                                                                                                                                                                                                                                                   |    |          |                        |                 |       |   |  |  |
|---------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----------|------------------------|-----------------|-------|---|--|--|
| Код операции  | 10q0 qq0d            | d dddd 0g                                                                                                                                                                                                                                                           | qq |          |                        | 1 слово (2 ба   | ійта) |   |  |  |
| Операнды      | $0 \le d \le 31$ , ( | $\leq d \leq 31, \ 0 \leq q \leq 63$                                                                                                                                                                                                                                |    |          |                        |                 |       |   |  |  |
| Описание      | Rd. Адрес я          | пружает один байт из адресного пространства памяти данных в регистр общего назначения<br>d. Адрес ячейки памяти, к которой производится обращение, получается суммированием<br>держимого индексного регистра Z и константы q. Содержимое индексного регистра не из- |    |          |                        |                 |       |   |  |  |
| Регистр SREG  | I                    | T                                                                                                                                                                                                                                                                   | Н  | S        | V                      | N               | Z     | C |  |  |
| 1 cincip Sked | _                    | _                                                                                                                                                                                                                                                                   | _  | _        | _                      | _               | _     | _ |  |  |
| Маш. циклов   | 2                    |                                                                                                                                                                                                                                                                     |    |          |                        |                 |       |   |  |  |
| AT90S1200     | нет                  |                                                                                                                                                                                                                                                                     |    |          |                        |                 |       |   |  |  |
| Пример        | ldi                  |                                                                                                                                                                                                                                                                     | ,  | вить мл. | айт индек<br>байт адре | сного рег<br>са | истра |   |  |  |

# LDI Rd, K

## Загрузка константы в РОН

| Операция     | Rd = K             |                                                                                                                                  |     |   |   |               |       |   |  |  |
|--------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------|-----|---|---|---------------|-------|---|--|--|
| Код операции | 1110 KKK           | K dddd K                                                                                                                         | KKK |   |   | 1 слово (2 ба | айта) |   |  |  |
| Операнды     | $16 \le d \le 31,$ | 6 ≤ d ≤ 31, 0 ≤ k ≤ 255                                                                                                          |     |   |   |               |       |   |  |  |
| Описание     | 1.0                | агружает 8-разрядное число в регистр общего назначения Rd. Данная команда применима<br>лъко к старшей половине РОН (адреса 1631) |     |   |   |               |       |   |  |  |
| Регистр SREG | I                  | T                                                                                                                                | Н   | S | V | N             | Z     | C |  |  |
| reincip Sked | _                  |                                                                                                                                  |     |   |   |               |       |   |  |  |
| Маш. циклов  | 1                  |                                                                                                                                  |     | • | • |               |       |   |  |  |
| AT90S1200    | да                 |                                                                                                                                  |     |   |   |               |       |   |  |  |
|              | clr                | clr r31 ; Очистить ст. байт индексного регистра Z                                                                                |     |   |   |               |       |   |  |  |
| Пример       | 1                  | ldi r30,\$F0 ; Загрузить адрес в регистр Z lpm ; Загрузить константу из памяти программ ; по адресу \$00F0                       |     |   |   |               |       |   |  |  |
|              | lpn                |                                                                                                                                  |     |   |   |               |       |   |  |  |

## LDS Rd, k

# Непосредственная загрузка из памяти данных

| Операция     | Rd = [k]            |                                                                                                                                                                         |           |           |          |         |             |    |  |
|--------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|----------|---------|-------------|----|--|
| Код операции | 1001 0000           | dddd 00                                                                                                                                                                 | 00 kkkk k | kkk kkkk  | kkkk     | 2 сл    | юва (4 байт | a) |  |
| Операнды     | $0 \le d \le 31, 0$ | ≤ d ≤ 31, 0 ≤ k ≤ 65535                                                                                                                                                 |           |           |          |         |             |    |  |
| Описание     |                     | агружает один байт из адресного пространства памяти данных в регистр общего назначения Rd. Адрес ячейки памяти, к которой производится обращение, задается константой К |           |           |          |         |             |    |  |
| Peructp SREG | I                   | T                                                                                                                                                                       | Н         | S         | V        | N       | Z           | С  |  |
| Perucip SkeG | _                   | _                                                                                                                                                                       | _         | _         | _        | _       | _           | _  |  |
| Маш. циклов  | 2                   |                                                                                                                                                                         |           |           |          |         |             |    |  |
| AT90S1200    | нет                 |                                                                                                                                                                         |           |           |          |         |             |    |  |
|              |                     |                                                                                                                                                                         | ) ; r2 =  |           |          |         |             |    |  |
| Пример       |                     |                                                                                                                                                                         | ; r2 =    |           |          |         |             |    |  |
|              | sts                 | \$FF000,1                                                                                                                                                               | r2 ; Запи | сать резу | льтат по | тому же | адресу      |    |  |

#### **LPM**

## Загрузка данных из памяти программ

| Операция     | $R0 = \{Z\}$                                                                                                           |                                                                                                                                                                                             |    |   |   |               |       |   |  |
|--------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|
| Код операции | 1001 0101                                                                                                              | 1100 10                                                                                                                                                                                     | 00 |   |   | 1 слово (2 ба | ійта) |   |  |
| Операнды     | Нет операн                                                                                                             | ет операндов                                                                                                                                                                                |    |   |   |               |       |   |  |
| Описание     |                                                                                                                        | агружает один байт из адресного пространства памяти программ в регистр общего назначе-<br>ия R0. Адрес ячейки памяти, к которой производится обращение, содержится в индексном<br>егистре Z |    |   |   |               |       |   |  |
| Регистр SREG | I                                                                                                                      | T                                                                                                                                                                                           | Н  | S | V | N             | Z     | C |  |
| Ternery Sked | _                                                                                                                      | -                                                                                                                                                                                           | _  | _ | _ | _             | _     | _ |  |
| Маш. циклов  | 3                                                                                                                      |                                                                                                                                                                                             |    |   |   |               |       |   |  |
| AT90S1200    | нет                                                                                                                    |                                                                                                                                                                                             |    |   |   |               |       |   |  |
| Пример       | clr r31 ; Очистить ст. байт индексного регистра Z<br>ldi r30,\$F0 ; Загрузить адрес в регистр Z<br>lpm ; r0 = {\$00F0} |                                                                                                                                                                                             |    |   |   |               |       |   |  |

LSL Rd Логический сдвиг влево

| Операция     |                                                  | C ← b7 b0 ← 0                                                                                                                                         |    |   |   |               |       |   |  |  |
|--------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|
| Код операции | 1000 11da                                        | dddd dd                                                                                                                                               | dd |   |   | 1 слово (2 ба | ійта) |   |  |  |
| Операнды     | $0 \le d \le 31$                                 | ≤31                                                                                                                                                   |    |   |   |               |       |   |  |  |
| Описание     |                                                  | вигает все разряды регистра Rd влево. Разряд b0 сбрасывается в «0», а разряд b7 загружает-<br>в флаг C регистра SREG. Эквивалентна команде ADD Rd, Rd |    |   |   |               |       |   |  |  |
| Danuara CDEC | I                                                | T                                                                                                                                                     | Н  | S | V | N             | Z     | С |  |  |
| Peructp SREG | _                                                | _                                                                                                                                                     | _  | ⇔ | ⇔ | 0             | ⇔     | ⇔ |  |  |
| Маш. циклов  | 1                                                |                                                                                                                                                       |    |   |   |               |       |   |  |  |
| AT90S1200    | да                                               |                                                                                                                                                       |    |   |   |               |       |   |  |  |
| Пример       | add r0,r4 ; r0 = r0 + r4<br>lsl r0 ; r0 = r0 * 2 |                                                                                                                                                       |    |   |   |               |       |   |  |  |

LSR Rd Логический сдвиг вправо

| Операция     |                                                | 0 → b7 b0 → C                                                                                                            |  |  |  |  |   |   |  |  |
|--------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|---|---|--|--|
| Код операции | 1001 0100                                      | 01 010d dddd 0110                                                                                                        |  |  |  |  |   |   |  |  |
| Операнды     | $0 \le d \le 31$                               | d≤31                                                                                                                     |  |  |  |  |   |   |  |  |
| Описание     |                                                | двигает все разряды регистра Rd вправо. Разряд b7 сбрасывается в «0», а разряд b0 загружа-<br>тся в флаг С регистра SREG |  |  |  |  |   |   |  |  |
| Peructp SREG | G                                              |                                                                                                                          |  |  |  |  |   |   |  |  |
| reincip sked |                                                |                                                                                                                          |  |  |  |  |   |   |  |  |
| Маш. циклов  | 1                                              |                                                                                                                          |  |  |  |  | • | , |  |  |
| AT90S1200    | да                                             |                                                                                                                          |  |  |  |  |   |   |  |  |
| Пример       | add r0,r4 ; r0 = r0 + r4<br>lsr r0 ; r0 = r0/2 |                                                                                                                          |  |  |  |  |   |   |  |  |

## MOV Rd, Rr

## Пересылка между РОН

| Операция     | Rd = Rr                                    | Rd = Rr                                                                           |                    |           |                       |  |  |  |  |  |  |  |
|--------------|--------------------------------------------|-----------------------------------------------------------------------------------|--------------------|-----------|-----------------------|--|--|--|--|--|--|--|
| Код операции | 0010 11rd                                  | 0010 11rd dddd rrrr 1 слово (2 байта)                                             |                    |           |                       |  |  |  |  |  |  |  |
| Операнды     | $0 \le d \le 31, 0$                        | $\leq d \leq 31, 0 \leq r \leq 31$                                                |                    |           |                       |  |  |  |  |  |  |  |
| Описание     | Копирует с                                 | Копирует содержимое регистра Rr в регистр Rd. Регистр-источник (Rr) не изменяется |                    |           |                       |  |  |  |  |  |  |  |
| Регистр SREG | I                                          | I T H S V N Z C                                                                   |                    |           |                       |  |  |  |  |  |  |  |
| Perucip SkeG | _                                          |                                                                                   |                    |           |                       |  |  |  |  |  |  |  |
| Маш. циклов  | 1                                          |                                                                                   |                    |           |                       |  |  |  |  |  |  |  |
| AT90S1200    | да                                         | a                                                                                 |                    |           |                       |  |  |  |  |  |  |  |
| Пример       | mov<br>cal<br><br>check:<br>cpi<br><br>ret | 1 check<br>r16, \$:                                                               | ; Выз<br>r11 ; Сра | вать подг | программу<br>5 с \$11 |  |  |  |  |  |  |  |

#### **NEG Rd**

#### Вычисление дополнительного кода

| Операция     | Rd = \$00 -      | Rd                                                                                                      |           |           |          |                                       |         |  |  |  |  |  |
|--------------|------------------|---------------------------------------------------------------------------------------------------------|-----------|-----------|----------|---------------------------------------|---------|--|--|--|--|--|
| Код операции | 1001 0100        | d dddd 00                                                                                               | 01        |           |          | 1 слово (2 ба                         | ійта)   |  |  |  |  |  |
| Операнды     | $0 \le d \le 31$ | $\leq d \leq 31$                                                                                        |           |           |          |                                       |         |  |  |  |  |  |
| Описание     |                  | ычисляет дополнительный код числа, находящегося в регистре Rd. Результат помещается братно в регистр Rd |           |           |          |                                       |         |  |  |  |  |  |
| Downson CDEC | I                | I T H S V N Z C                                                                                         |           |           |          |                                       |         |  |  |  |  |  |
| Peructp SREG | _                | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \                                                                       |           |           |          |                                       |         |  |  |  |  |  |
| Маш. циклов  | 1                |                                                                                                         |           |           |          |                                       |         |  |  |  |  |  |
| AT90S1200    | да               |                                                                                                         |           |           |          |                                       |         |  |  |  |  |  |
| Пример       | brp              | ol positiv<br>g r11<br>ve:                                                                              | ле ; Пере | йти, если | результа | 1 = r11 -<br>ат положиз<br>ный код чі | гельный |  |  |  |  |  |

## NOP

#### Пустая команда

| Операция     | Нет операц | Нет операции                             |          |            |          |   |   |   |  |  |  |  |
|--------------|------------|------------------------------------------|----------|------------|----------|---|---|---|--|--|--|--|
| Код операции | 0000 0000  | 0000 0000 0000 0000 1 слово (2 байта)    |          |            |          |   |   |   |  |  |  |  |
| Операнды     | Нет операн | ет операндов                             |          |            |          |   |   |   |  |  |  |  |
| Описание     | Выполняет  | Выполняет пустой машинный цикл           |          |            |          |   |   |   |  |  |  |  |
| Регистр SREG | I          | I T H S V N Z C                          |          |            |          |   |   |   |  |  |  |  |
| reincip Sked | _          | _                                        | _        | _          | _        | _ | _ | _ |  |  |  |  |
| Маш. циклов  | 1          |                                          |          |            |          |   |   |   |  |  |  |  |
| AT90S1200    | да         | Ia                                       |          |            |          |   |   |   |  |  |  |  |
|              | clr        | clr r16 ; Очистить регистр r16           |          |            |          |   |   |   |  |  |  |  |
|              | ser        | ser r17 ; Установить регистр r17         |          |            |          |   |   |   |  |  |  |  |
| Пример       | out        | \$18,r16                                 | ; Записа | ать нули в | в порт В |   |   |   |  |  |  |  |
|              | nop        | nop ; Ждать один машинный цикл           |          |            |          |   |   |   |  |  |  |  |
|              | out        | out \$18,r17 ; Записать единицы в порт В |          |            |          |   |   |   |  |  |  |  |

## OR Rd, Rr

# «Логическое ИЛИ» двух РОН

| Операция     | $Rd = Rd \vee I$        | $Rd = Rd \vee Rr$                                                                                |                                  |           |           |           |          |  |  |  |  |  |
|--------------|-------------------------|--------------------------------------------------------------------------------------------------|----------------------------------|-----------|-----------|-----------|----------|--|--|--|--|--|
| Код операции | 0010 10rd               | 0010 10rd dddd rrrr 1 слово (2 байта)                                                            |                                  |           |           |           |          |  |  |  |  |  |
| Операнды     | $0 \le d \le 31, 0$     | $\leq$ d $\leq$ 31, 0 $\leq$ r $\leq$ 31                                                         |                                  |           |           |           |          |  |  |  |  |  |
| Описание     | Выполняет<br>регистр Rd | ыполняет операцию «Логическое ИЛИ» между регистрами Rd и Rr. Результат помещается в<br>егистр Rd |                                  |           |           |           |          |  |  |  |  |  |
| D CDEC       | I                       | I T H S V N Z C                                                                                  |                                  |           |           |           |          |  |  |  |  |  |
| Peructp SREG | _                       | ⇔ 0 ⇔ -                                                                                          |                                  |           |           |           |          |  |  |  |  |  |
| Маш. циклов  | 1                       |                                                                                                  |                                  |           |           |           |          |  |  |  |  |  |
| AT90S1200    | да                      |                                                                                                  |                                  |           |           |           |          |  |  |  |  |  |
| Пример       | bst                     | r15,6<br>s ok                                                                                    | ; Поразр<br>; Записа<br>; Перейт | ть 6-й ра | азряд рег | истра r15 | в флаг Т |  |  |  |  |  |

## ORI Rd, K

#### «Логическое ИЛИ» РОН и константы

| Операция     | $Rd = Rd \vee I$   | ζ                                                                                                                                                             |     |  |  |               |       |  |  |  |
|--------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|---------------|-------|--|--|--|
| Код операции | 0110 KKK           | K dddd K                                                                                                                                                      | KKK |  |  | 1 слово (2 ба | айта) |  |  |  |
| Операнды     | $16 \le d \le 31,$ | $0 \le K \le 255$                                                                                                                                             |     |  |  |               |       |  |  |  |
| 1 (Эписание  |                    | полняет операцию «Логическое ИЛИ» между регистром Rd и константой К. Результат по-<br>цается в регистр Rd. Команда применима только к 16 старшим РОН (R16R31) |     |  |  |               |       |  |  |  |
| Регистр SREG | I                  | Z                                                                                                                                                             | С   |  |  |               |       |  |  |  |
| reincip Sked |                    |                                                                                                                                                               |     |  |  |               |       |  |  |  |
| Маш. циклов  | 1                  |                                                                                                                                                               |     |  |  |               |       |  |  |  |
| AT90S1200    | да                 |                                                                                                                                                               |     |  |  |               |       |  |  |  |
| Пример       |                    | ori r17,\$0F ; Установить старший полубайт регистра r17<br>ori r18,1  ; Установить 0-й разряд регистра r18                                                    |     |  |  |               |       |  |  |  |

## OUT A, Rr

## Пересылка значения из РОН в РВВ

| Операция     | $I/O(A) = R_1$                 | O(A) = Rr                                                                    |                          |                          |  |  |  |  |  |  |  |  |
|--------------|--------------------------------|------------------------------------------------------------------------------|--------------------------|--------------------------|--|--|--|--|--|--|--|--|
| Код операции | 1011 1AA1                      | 011 1ААг гггг АААА 1 слово (2 байта)                                         |                          |                          |  |  |  |  |  |  |  |  |
| Операнды     | $0 \le r \le 31, 0$            | $\leq r \leq 31, 0 \leq A \leq 63$                                           |                          |                          |  |  |  |  |  |  |  |  |
| Описание     | Пересылает                     | Іересылает содержимое регистра общего назначения Rr в регистр ввода/вывода А |                          |                          |  |  |  |  |  |  |  |  |
| Peructp SREG | I                              | I T H S V N Z C                                                              |                          |                          |  |  |  |  |  |  |  |  |
| reincip Sked | _                              |                                                                              |                          |                          |  |  |  |  |  |  |  |  |
| Маш. циклов  | 1                              |                                                                              |                          |                          |  |  |  |  |  |  |  |  |
| AT90S1200    | да                             | да                                                                           |                          |                          |  |  |  |  |  |  |  |  |
|              | clr r16 ; Очистить регистр r16 |                                                                              |                          |                          |  |  |  |  |  |  |  |  |
|              | ser                            | ser r17 ; Установить регистр r17                                             |                          |                          |  |  |  |  |  |  |  |  |
| Пример       | out                            | \$18,r16                                                                     | ; Записать нули в порт В |                          |  |  |  |  |  |  |  |  |
|              | nop                            | )                                                                            | ;                        | Ждать один машинный цикл |  |  |  |  |  |  |  |  |
|              | out                            | out \$18,r17 ; Записать единицы в порт В                                     |                          |                          |  |  |  |  |  |  |  |  |

#### POOP Rd

## Извлечение байта из стека

| Операция      | SP = SP + 1      | , Rd = STAC                                            | CK                            |                                                |                                     |                                                |         |   |  |  |  |  |
|---------------|------------------|--------------------------------------------------------|-------------------------------|------------------------------------------------|-------------------------------------|------------------------------------------------|---------|---|--|--|--|--|
| Код операции  | 1001 000d        | dddd 11                                                | 11                            |                                                |                                     | 1 слово (2 ба                                  | ійта)   |   |  |  |  |  |
| Операнды      | $0 \le d \le 31$ |                                                        |                               |                                                |                                     |                                                |         |   |  |  |  |  |
| Описание      | Загружает 1      | гружает 1 байт из стека в регистр общего назначения Rd |                               |                                                |                                     |                                                |         |   |  |  |  |  |
| Perистр SREG  | I                | T                                                      | Н                             | S                                              | V                                   | N                                              | Z       | C |  |  |  |  |
| T CINCIP SKEO | _                | _                                                      | _                             | _                                              | _                                   | _                                              | _       | _ |  |  |  |  |
| Маш. циклов   | 2                |                                                        |                               |                                                |                                     |                                                |         |   |  |  |  |  |
| AT90S1200     | нет              | Т                                                      |                               |                                                |                                     |                                                |         |   |  |  |  |  |
| Пример        | routine<br>pus   | e:<br>h r14<br>h r15<br>r15<br>r14                     | ; Coxpa<br>; Bocci<br>; Bocci | анить сод<br>анить сод<br>гановить<br>гановить | ержимое r<br>ержимое r<br>содержимо | 14 в стек<br>15 в стек<br>е r15 из<br>е r14 из | е стека |   |  |  |  |  |

#### **PUSH Rr**

# Сохранение байта в стеке

| Операция      | STACK = R        | r, SP = SP                                                                              | - 1     |           |           |               |       |   |  |  |  |  |
|---------------|------------------|-----------------------------------------------------------------------------------------|---------|-----------|-----------|---------------|-------|---|--|--|--|--|
| Код операции  | 1001 0011        | rrrr 11                                                                                 | 11      |           |           | 1 слово (2 ба | ійта) |   |  |  |  |  |
| Операнды      | $0 \le r \le 31$ |                                                                                         |         |           |           |               |       |   |  |  |  |  |
| Описание      | Сохраняет        | охраняет содержимое регистра общего назначения Rr в стеке                               |         |           |           |               |       |   |  |  |  |  |
| Регистр SREG  | I                | T                                                                                       | Н       | S         | V         | N             | Z     | С |  |  |  |  |
| I cincip Sked | _                |                                                                                         |         |           |           |               |       |   |  |  |  |  |
| Маш. циклов   | 2                |                                                                                         |         |           |           |               |       |   |  |  |  |  |
| AT90S1200     | нет              | Т                                                                                       |         |           |           |               |       |   |  |  |  |  |
|               | cal              | call routine ; Вызов подпрограммы                                                       |         |           |           |               |       |   |  |  |  |  |
|               | routine          | ···                                                                                     |         |           |           |               |       |   |  |  |  |  |
|               |                  | h r14                                                                                   | ; Coxpa | нить соле | ержимое г | 14 в стек     | е     |   |  |  |  |  |
| Пример        | 1 -              | push r14 ; Сохранить содержимое r14 в стеке push r15 ; Сохранить содержимое r15 в стеке |         |           |           |               |       |   |  |  |  |  |
|               |                  |                                                                                         |         |           |           |               |       |   |  |  |  |  |
|               | pop              | pop r15 ; Восстановить содержимое r15 из стека                                          |         |           |           |               |       |   |  |  |  |  |
|               | pop              | r14                                                                                     | ; Bocci | ановить ( | содержимо | e r14 из      | стека |   |  |  |  |  |
|               | ret              | ret ; Возврат из подпрограммы                                                           |         |           |           |               |       |   |  |  |  |  |

## RCALL k

# Относительный вызов подпрограммы

| Операция     | STACK = P                | C + 1; PC =                                                                                                                                                                                                                                                                                                        | PC + k + 1; | SP = SP - 2 | 2 |               |       |   |  |  |  |
|--------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|---|---------------|-------|---|--|--|--|
| Код операции | 1101 kkk                 | kkkk kk                                                                                                                                                                                                                                                                                                            | kk          |             |   | 1 слово (2 ба | ійта) |   |  |  |  |
| Операнды     | -2047 ≤ k ≤              | 2047                                                                                                                                                                                                                                                                                                               |             |             |   |               |       |   |  |  |  |
| Описание     | получается<br>RCALL кома | тносительный вызов подпрограммы. Выполняет переход к подпрограмме, адрес которой<br>олучается сложением содержимого счетчика команд с константой к. Адрес следующей за<br>CALL команды (2 байта) сохраняется в стеке. На практике вместо числовых значений смеще-<br>ия указываются метки подпрограмм (см. пример) |             |             |   |               |       |   |  |  |  |
| Peructp SREG | I                        | T                                                                                                                                                                                                                                                                                                                  | Н           | S           | V | N             | Z     | С |  |  |  |
| reincip Sked | _                        | -   -   -   -   -   -   -                                                                                                                                                                                                                                                                                          |             |             |   |               |       |   |  |  |  |
| Маш. циклов  | 3                        | 3                                                                                                                                                                                                                                                                                                                  |             |             |   |               |       |   |  |  |  |
| AT90S1200    | да                       |                                                                                                                                                                                                                                                                                                                    |             |             |   |               |       |   |  |  |  |
| Пример       | routing                  | rcall routine ; Вызвать подпрограмму routine: push r14 ; Сохранить содержимое r14 pop r14 ; Восстановить содержимое r14                                                                                                                                                                                            |             |             |   |               |       |   |  |  |  |

#### **RET**

# Возврат из подпрограммы

| Регистр SREG       I       T       H       S       V       N       Z       C         —       —       —       —       —       —       —         Маш. циклов       4         AT90S1200       да         гсаll routine; Вызвать подпрограмму         гоиtine:         пример       ризh r14       ; Сохранить содержимое r14                                                                          | Операция      | SP = SP + 2               | SP = SP + 2; $PC = STACK$                                                              |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------|----------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| Описание         Возврат из подпрограммы. Выполняет возврат в то место, откуда подпрограмма была вызван           Perистр SREG         I         T         H         S         V         N         Z         C           Маш. циклов         4           AT90S1200         да           гсаll routine ; Вызвать подпрограмму routine:           пример         ризh r14 ; Сохранить содержимое r14 | Код операции  | 1001 0101                 | 001 0101 0000 1000 1000 1 слово (2 байта)                                              |  |  |  |  |  |  |  |  |  |  |  |
| Регистр SREG         I         T         H         S         V         N         Z         C           Маш. циклов         4           AT90S1200         да           Пример         rcall routine ; вызвать подпрограмму routine: push r14 ; Сохранить содержимое r14                                                                                                                             | Операнды      | Нет операн                | ет операндов                                                                           |  |  |  |  |  |  |  |  |  |  |  |
| Регистр SREG                                                                                                                                                                                                                                                                                                                                                                                       | Описание      | Возврат из                | озврат из подпрограммы. Выполняет возврат в то место, откуда подпрограмма была вызвана |  |  |  |  |  |  |  |  |  |  |  |
| Маш. циклов       4         AT90S1200       да         Пример       rcall routine ; Вызвать подпрограмму routine:         пример       push r14 ; Сохранить содержимое r14                                                                                                                                                                                                                         | Portern SPEC  | I                         | I T H S V N Z C                                                                        |  |  |  |  |  |  |  |  |  |  |  |
| AT90S1200 да  rcall routine ; Вызвать подпрограмму routine: пример push r14 ; Сохранить содержимое r14                                                                                                                                                                                                                                                                                             | I CINCIP SKEO | _                         | _   -   -   -   -   -   -                                                              |  |  |  |  |  |  |  |  |  |  |  |
| rcall routine ; Вызвать подпрограмму routine: Пример push r14 ; Сохранить содержимое r14                                                                                                                                                                                                                                                                                                           | Маш. циклов   | 4                         |                                                                                        |  |  |  |  |  |  |  |  |  |  |  |
| routine: Пример push r14 ; Сохранить содержимое r14                                                                                                                                                                                                                                                                                                                                                | AT90S1200     | да                        |                                                                                        |  |  |  |  |  |  |  |  |  |  |  |
| ret ; Возврат из подпрограммы                                                                                                                                                                                                                                                                                                                                                                      | Пример        | routine<br>pus<br><br>por | rcall routine ; Вызвать подпрограмму routine: push r14 ; Сохранить содержимое r14      |  |  |  |  |  |  |  |  |  |  |  |

**RETI** Возврат из подпрограммы обработки прерывания

| Операция      | SP = SP + 2                    | SP = SP + 2; $PC = STACK$                                                                                                                                                                                                                                                                                                                                                                                                                         |    |   |   |               |       |   |  |  |
|---------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|
| Код операции  | 1001 0101                      | . 0001 10                                                                                                                                                                                                                                                                                                                                                                                                                                         | 00 |   | 1 | 1 слово (2 ба | ійта) |   |  |  |
| Операнды      | Нет операн                     | ДОВ                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |   |   |               |       |   |  |  |
| Описание      | выполнени внимание, подпрограм | озврат из подпрограммы обработки прерывания. Выполняет возврат в то место, в котором ыполнение программы было прервано в результате возникновения прерывания. Обратите нимание, что контекст программы (регистр состояния SREG) не сохраняется при вызове одпрограммы обработки прерывания и, соответственно, не восстанавливается при выходе из ее. В связи с этим сохранение и восстановление этого регистра необходимо выполнять самогоятельно |    |   |   |               |       |   |  |  |
| Peructp SREG  | I                              | T                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Н  | S | V | N             | Z     | C |  |  |
| I cincip sked | _                              | _   _   _   _   _   _                                                                                                                                                                                                                                                                                                                                                                                                                             |    |   |   |               |       |   |  |  |
| Маш. циклов   | 4                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |               |       |   |  |  |
| AT90S1200     | да                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |               |       |   |  |  |
| Пример        | pus<br><br>pop                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |   |   |               |       |   |  |  |

#### RJMP k

# Относительный безусловный переход

| Операция      | PC = PC +                   | k + 1;                                                                                                                                                                                                               |                                                    |                                     |                                   |               |       |   |  |  |  |
|---------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------|-----------------------------------|---------------|-------|---|--|--|--|
| Код операции  | 1100 kkk                    | k kkkk kk                                                                                                                                                                                                            | kk                                                 |                                     |                                   | 1 слово (2 ба | айта) |   |  |  |  |
| Операнды      | -2047 ≤ k ≤                 | 047 ≤ k ≤ 2047                                                                                                                                                                                                       |                                                    |                                     |                                   |               |       |   |  |  |  |
| Описание      | ме содержи                  | манда относительного безусловного перехода. Выполняет переход по адресу, равному сум-<br>содержимого счетчика команд и константы k. На практике вместо числовых значений сме-<br>ния используются метки (см. пример) |                                                    |                                     |                                   |               |       |   |  |  |  |
| Peructp SREG  | I                           | T                                                                                                                                                                                                                    | Н                                                  | S                                   | V                                 | N             | Z     | C |  |  |  |
| T CINCIP SKEO | _                           | ı                                                                                                                                                                                                                    | _                                                  | _                                   | _                                 | _             | _     | _ |  |  |  |
| Маш. циклов   | 2                           |                                                                                                                                                                                                                      |                                                    |                                     |                                   |               |       |   |  |  |  |
| AT90S1200     | да                          |                                                                                                                                                                                                                      |                                                    |                                     |                                   |               |       |   |  |  |  |
| Пример        | brn<br>rjm<br>error:<br>add | e error<br>p ok<br>l r16, r                                                                                                                                                                                          | 2 ; Срав<br>; Пере<br>; Безу<br>17 ; Приб<br>; r16 | йти, если<br>словный г<br>авить r16 | r r16 ≠ \$4<br>переход<br>Б к r17 |               |       |   |  |  |  |

ROL Rd Сдвиг влево через перенос

| Операция      |                                           | C ← b7 b0 ← C                                                                                                                                                                                                                                                                                                                                                                            |                                     |     |           |   |   |   |  |  |
|---------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-----|-----------|---|---|---|--|--|
| Код операции  | 0001 11dd                                 | 01 11dd dddd dddd 1 слово (2 байта)                                                                                                                                                                                                                                                                                                                                                      |                                     |     |           |   |   |   |  |  |
| Операнды      | $0 \le d \le 31$                          | ≤d ≤ 31                                                                                                                                                                                                                                                                                                                                                                                  |                                     |     |           |   |   |   |  |  |
| Описание      | флага С рег<br>данная ком<br>так и беззна | цвигает содержимое регистра Rd влево на один разряд. В разряд b0 заносится содержимое нага С регистра SREG, а разряд b7 загружается в флаг С. В комбинации с командой LSL нная команда может использоваться для умножения многобайтных чисел (как знаковых, к и беззнаковых) на два. Эквивалентна команде ADC Rd, Rd. Значение флага V равно «Исночающему ИЛИ» флагов N и С после сдвига |                                     |     |           |   |   |   |  |  |
| Peructp SREG  | I                                         | T                                                                                                                                                                                                                                                                                                                                                                                        | Н                                   | S   | V         | N | Z | С |  |  |
| 1 cincip Sked | _                                         | _                                                                                                                                                                                                                                                                                                                                                                                        | ⇔                                   | ⇔   | ⇔         | ⇔ | ⇔ | ⇔ |  |  |
| Маш. циклов   | 1                                         |                                                                                                                                                                                                                                                                                                                                                                                          |                                     |     |           |   |   |   |  |  |
| AT90S1200     | да                                        |                                                                                                                                                                                                                                                                                                                                                                                          |                                     |     |           |   |   |   |  |  |
| Пример        | lsl                                       | r18 ; r                                                                                                                                                                                                                                                                                                                                                                                  | лару r19:r1<br>18 = r18<br>19:r18 — | * 2 | дное цело | e |   |   |  |  |

#### **ROR Rd**

Сдвиг вправо через перенос

| Операция      |                                       | C ← b7 b0 ← C                                                                                                                                                                                                                                                                                                                                                                                                |                      |                                                  |                      |                         |            |   |  |  |
|---------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------------------------------------|----------------------|-------------------------|------------|---|--|--|
| Код операции  | 1001 0100                             | 01 010d dddd 0111 1 слово (2 байта)                                                                                                                                                                                                                                                                                                                                                                          |                      |                                                  |                      |                         |            |   |  |  |
| Операнды      | $0 \le d \le 31$                      | d≤31                                                                                                                                                                                                                                                                                                                                                                                                         |                      |                                                  |                      |                         |            |   |  |  |
| Описание      | флага С ре<br>данная ком<br>комбинаци | вигает содержимое регистра Rd вправо на один разряд. В разряд b7 заносится содержимое ага С регистра SREG, а разряд b0 загружается в флаг С. В комбинации с командой ASR ная команда может использоваться для деления многобайтных знаковых чисел на два. А в ибинации с командой LSR — для деления многобайтных беззнаковых чисел на два. Значее флага V равно «Исключающему ИЛИ» флагов N и С после сдвига |                      |                                                  |                      |                         |            |   |  |  |
| Регистр SREG  | I                                     | T                                                                                                                                                                                                                                                                                                                                                                                                            | Н                    | S                                                | V                    | N                       | Z          | C |  |  |
| T CINCIP SKEO | _                                     | _                                                                                                                                                                                                                                                                                                                                                                                                            | _                    | ⇔                                                | ⇔                    | ⇔                       | ⇔          | ⇔ |  |  |
| Маш. циклов   | 1                                     |                                                                                                                                                                                                                                                                                                                                                                                                              |                      |                                                  |                      |                         |            |   |  |  |
| AT90S1200     | да                                    |                                                                                                                                                                                                                                                                                                                                                                                                              |                      |                                                  |                      |                         |            |   |  |  |
| Пример        | ron<br>ası                            | r18 ; r<br>r17 ; P                                                                                                                                                                                                                                                                                                                                                                                           | 19:r18 —<br>азделить | регистров<br>16-разря,<br>регистров<br>16-разря, | цное цело<br>ую пару | ое без зна<br>r17:r16 н | aka<br>a 2 |   |  |  |

## SBC Rd, Rr

#### Вычитание с заемом

| Операция     | Rd = Rd - 1         | d = Rd - Rr - C                                                                                                                                                                                                                                                                |                                  |           |   |               |           |   |  |  |  |
|--------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------|---|---------------|-----------|---|--|--|--|
| Код операции | 0000 10rd           | d dddd rr                                                                                                                                                                                                                                                                      | rr                               |           |   | 1 слово (2 ба | йта)      |   |  |  |  |
| Операнды     | $0 \le d \le 31, 0$ | $\leq r \leq 31$                                                                                                                                                                                                                                                               |                                  |           |   |               |           |   |  |  |  |
| Описание     | ная разност         | мчитает из регистра Rd содержимое регистра Rr. Если флаг переноса С установлен, полученя разность уменьшается на 1. Результат помещается в регистр Rd. Если результат вычитаня не равен нулю, флаг нуля $Z$ сбрасывается в « $0$ », в противном случае он остается без измений |                                  |           |   |               |           |   |  |  |  |
| n cnec       | I                   | T                                                                                                                                                                                                                                                                              | Н                                | S         | V | N             | Z         | C |  |  |  |
| Peructp SREG | _                   | _                                                                                                                                                                                                                                                                              | ⇔                                | ⇔         | ⇔ | ⇔             | <b>\$</b> | ⇔ |  |  |  |
| Маш. циклов  | 1                   |                                                                                                                                                                                                                                                                                |                                  |           |   |               |           |   |  |  |  |
| AT90S1200    | да                  |                                                                                                                                                                                                                                                                                |                                  |           |   |               |           |   |  |  |  |
| Пример       | sub                 | r2,r0;                                                                                                                                                                                                                                                                         | вой пары R<br>Вычесть<br>Вычесть | младшие б |   | нетом пере    | еноса     |   |  |  |  |

#### SBCI Rd, K

#### Вычитание константы из РОН с заемом

| Операция     | Rd = Rd - 1        | i = Rd - K - C                                                                                                                                                                                                                                                                    |           |           |         |                               |         |   |  |  |  |
|--------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|---------|-------------------------------|---------|---|--|--|--|
| Код операции | 0100 KKK           | K dddd K                                                                                                                                                                                                                                                                          | KKK       |           |         | 1 слово (2 ба                 | ійта)   |   |  |  |  |
| Операнды     | $16 \le d \le 31,$ | $\leq d \leq 31, 0 \leq K \leq 255$                                                                                                                                                                                                                                               |           |           |         |                               |         |   |  |  |  |
| Описание     | ная разност        | ичитает из регистра Rd значение константы K. Если флаг переноса С установлен, получен-<br>я разность уменьшается на 1. Результат помещается в регистр Rd. Если результат вычитания<br>равен нулю, флаг нуля Z сбрасывается в «0», в противном случае он остается без измене-<br>й |           |           |         |                               |         |   |  |  |  |
| D CDEC       | I                  | T                                                                                                                                                                                                                                                                                 | Н         | S         | V       | N                             | Z       | C |  |  |  |
| Peructp SREG | _                  | _                                                                                                                                                                                                                                                                                 | ⇔         | ⇔         | ⇔       | ⇔                             | ⇔       | ⇔ |  |  |  |
| Маш. циклов  | 1                  |                                                                                                                                                                                                                                                                                   |           |           |         |                               |         |   |  |  |  |
| AT90S1200    | да                 |                                                                                                                                                                                                                                                                                   |           |           |         |                               |         |   |  |  |  |
| Пример       |                    | i r16,\$23                                                                                                                                                                                                                                                                        | 3 ; Вычес | ть младши | ій байт | <b>ы R17:R16</b><br>учетом пе | ереноса |   |  |  |  |

**SBI A, b** Установить разряд PBB

| Операция     | I/O(A).b =           | 1                                                                                                                                                                  |         |           |            |      |   |   |  |  |
|--------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|------------|------|---|---|--|--|
| Код операции | 1001 1010            | 001 1010 AAAA Abbb 1 слово (2 байта)                                                                                                                               |         |           |            |      |   |   |  |  |
| Операнды     | $0 \le A \le 31$ , ( | $\leq A \leq 31,  0 \leq b \leq 7$                                                                                                                                 |         |           |            |      |   |   |  |  |
| Описание     | ı                    | станавливает разряд в регистра ввода/вывода, расположенного по адресу А пространства вода/вывода. Эта команда применима только к младшим 32 регистрам (адреса 031) |         |           |            |      |   |   |  |  |
| Регистр SREG | I                    | T                                                                                                                                                                  | Н       | S         | V          | N    | Z | С |  |  |
| reincip Sked | _                    | _   _   _   _   _   _                                                                                                                                              |         |           |            |      |   |   |  |  |
| Маш. циклов  | 2                    |                                                                                                                                                                    |         |           |            |      |   |   |  |  |
| AT90S1200    | да                   |                                                                                                                                                                    |         |           |            |      |   |   |  |  |
|              | out                  | \$1E,r0                                                                                                                                                            | ; Задат | ь адрес я | нчейки EEI | PROM |   |   |  |  |
| Пример       | ı                    | sbi \$1C,0 ; Установить запрос на чтение                                                                                                                           |         |           |            |      |   |   |  |  |
|              | in                   | r1,\$1D                                                                                                                                                            | ; Счита | ть данные | е из EEPRO | MC   |   |   |  |  |

## SBIC A, b

Пропустить команду, если разряд РВВ сброшен

| Операция      | Если І/О(А             | ).b = 0, TO P                                                                                                                                                                          | C = PC + 2 (                               | 3), иначе РО | C = PC + 1 |               |       |   |  |
|---------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------|------------|---------------|-------|---|--|
| Код операции  | 1001 1001              | L AAAA Ab                                                                                                                                                                              | bb                                         |              |            | 1 слово (2 ба | ійта) |   |  |
| Операнды      | $0 \le A \le 31$ , $0$ | ) ≤ b ≤ 7                                                                                                                                                                              |                                            |              |            |               |       |   |  |
| Описание      | следующая              | роверяет состояние разряда b регистра ввода/вывода А. Если разряд сброшен, команда, едующая за SBIC A, b, пропускается. Эта команда применима только к младшим 32 регирам (адреса 031) |                                            |              |            |               |       |   |  |
| Perистр SREG  | I                      | T                                                                                                                                                                                      | Н                                          | S            | V          | N             | Z     | C |  |
| T CINCIP SKEO | _                      |                                                                                                                                                                                        |                                            |              |            |               |       |   |  |
| Маш. циклов   | 2, если І/О(           | (A).b = 0  (pa                                                                                                                                                                         | т пропуска в<br>змер пропус<br>змер пропус | скаемой ком  |            |               |       |   |  |
| AT90S1200     | да                     |                                                                                                                                                                                        |                                            |              |            |               |       |   |  |
| Пример        | ı                      | c \$1C,1<br>np e2wait                                                                                                                                                                  | ; Пропус<br>; Запись                       |              |            | -             | -     | H |  |

SBIS A, b Пропустить команду, если разряд PBB установлен

| Операция      | Если І/О(А           | ).b = 1, то <b>Р</b>                                                                                                                                                                               | C = PC + 2 (                               | 3), иначе РО | C = PC + 1 |               |       |   |  |
|---------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--------------|------------|---------------|-------|---|--|
| Код операции  | 1001 1011            | AAAA Ab                                                                                                                                                                                            | bb                                         |              | 1          | 1 слово (2 ба | ійта) |   |  |
| Операнды      | $0 \le A \le 31$ , ( | $\leq A \leq 31, 0 \leq b \leq 7$                                                                                                                                                                  |                                            |              |            |               |       |   |  |
|               | следующая            | роверяет состояние разряда b регистра ввода/вывода A. Если разряд установлен, команда,<br>ведующая за SBIS A, b, пропускается. Эта команда применима только к младшим 32 реги-<br>рам (адреса 031) |                                            |              |            |               |       |   |  |
| Peructo SREG  | I                    | T                                                                                                                                                                                                  | Н                                          | S            | V          | N             | Z     | C |  |
| T CINCIP SKEO | _                    |                                                                                                                                                                                                    |                                            |              |            |               |       |   |  |
| Маш. циклов   | 2, если I/O          | (A). $b = 1$ (pa                                                                                                                                                                                   | т пропуска і<br>змер пропус<br>змер пропус | каемой ком   |            |               |       |   |  |
| AT90S1200     | да                   |                                                                                                                                                                                                    |                                            |              |            |               |       |   |  |
| Пример        |                      | s \$1D,0                                                                                                                                                                                           | ; Пропу<br>; порт<br>; Ждать               | а D устан    | ювлен      |               |       | Д |  |

## SBIW Rd, K

#### Вычитание константы из регистровой пары

| Операция     | Rd+1:Rd =    | Rd+1:Rd -                                                                                                                                                                                     | K                                     |           |         |               |       |   |  |  |
|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------|---------|---------------|-------|---|--|--|
| Код операции | 1001 0111    | KKdd K                                                                                                                                                                                        | KKK                                   |           |         | 1 слово (2 ба | айта) |   |  |  |
| Операнды     | d ∈ {24, 26, | $28, 30$ , $0 \le 1$                                                                                                                                                                          | K ≤ 63                                |           |         |               |       |   |  |  |
| Описание     | но в регист  | ычитает из регистровой пары Rd+1:Rd значение константы К. Результат помещается обратов регистровую пару. Команда применима только к 4 старшим регистровым парам из регигров общего назначения |                                       |           |         |               |       |   |  |  |
| D CDEC       | I            | T                                                                                                                                                                                             | Н                                     | S         | V       | N             | Z     | С |  |  |
| Peructp SREG | _            |                                                                                                                                                                                               |                                       |           |         |               |       |   |  |  |
| Маш. циклов  | 2            |                                                                                                                                                                                               | 1                                     |           |         | 1             |       | ' |  |  |
| AT90S1200    | нет          |                                                                                                                                                                                               |                                       |           |         |               |       |   |  |  |
| Пример       | sbi          | w r24,1                                                                                                                                                                                       | ого числа \$4<br>; Вычест<br>; Вычест | ь единицу | из г25: |               | a Y   |   |  |  |

## SBR Rd, K

## Установка разрядов РОН

| Операция     | $Rd = Rd \vee I$   | K                                                                                                                                                                                            |     |   |   |                          |      |   |  |  |
|--------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---|---|--------------------------|------|---|--|--|
| Код операции | 0110 KKK           | K dddd K                                                                                                                                                                                     | KKK |   |   | 1 слово (2 ба            | йта) |   |  |  |
| Операнды     | $16 \le d \le 31,$ | $0 \le K \le 255$                                                                                                                                                                            |     |   |   |                          |      |   |  |  |
| Описание     | ИЛИ» межд          | танавливает отдельные разряды регистра Rd путем выполнения операции «Логическое<br>ПИ» между содержимым регистра Rd и маской, задаваемой константой К. Результат поме-<br>вется в регистр Rd |     |   |   |                          |      |   |  |  |
| Downson CDEC | I                  | T                                                                                                                                                                                            | Н   | S | V | N                        | Z    | C |  |  |
| Peructp SREG | _                  | _                                                                                                                                                                                            | _   | ⇔ | 0 | ⇔                        | \$   | _ |  |  |
| Маш. циклов  | 1                  |                                                                                                                                                                                              |     | • |   |                          |      |   |  |  |
| AT90S1200    | да                 |                                                                                                                                                                                              |     |   |   |                          |      |   |  |  |
| Пример       | sbr<br>sbr         |                                                                                                                                                                                              |     | _ |   | і 1 регист<br>да регисті | -    |   |  |  |

## SBRC Rr, b

#### Пропустить команду, если разряд РОН сброшен

| Операция     | Если Rr.b =         | Ссли Rr.b = 0, то PC = PC +2 (3), иначе PC = PC + 1                                                                            |                           |           |           |                        |      |   |  |  |
|--------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------|---------------------------|-----------|-----------|------------------------|------|---|--|--|
| Код операции | 1111 110ı           | rrrr 0b                                                                                                                        | bb                        |           | 1         | 1 слово (2 ба          | йта) |   |  |  |
| Операнды     | $0 \le r \le 31, 0$ | $\leq r \leq 31, 0 \leq b \leq 7$                                                                                              |                           |           |           |                        |      |   |  |  |
| Описание     | 1 * *               | роверяет состояние разряда b регистра общего назначения Rr. Если разряд сброшен, комана, следующая за SBRC Rr, b, пропускается |                           |           |           |                        |      |   |  |  |
| Peructp SREG | I                   | T                                                                                                                              | Н                         | S         | V         | N                      | Z    | C |  |  |
| Ternery Sked | _                   |                                                                                                                                |                           |           |           |                        |      |   |  |  |
| Маш. циклов  | I ′                 | , ,                                                                                                                            | опуска кома<br>пропускаем | ,         | т 1 споро |                        |      |   |  |  |
| таш. циклов  | 1 ′                 | (I I                                                                                                                           | пропускаем                |           | ,         |                        |      |   |  |  |
| AT90S1200    | да                  | a                                                                                                                              |                           |           |           |                        |      |   |  |  |
| Пример       | sbr                 | c r0,7;                                                                                                                        |                           | ть команд | 4 /       | 0.7 = «0»<br>0.7 = «1» |      |   |  |  |

## SBRS Rr, b

## Пропустить команду, если разряд РОН установлен

| Операция      | Если Rr.b =         | 1, TO PC =                                                                                                                       | РС +2 (3), и                            | наче РС = Б | PC + 1 |                         |      |   |  |  |
|---------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------|--------|-------------------------|------|---|--|--|
| Код операции  | 1111 1111           | rrrr 0b                                                                                                                          | bb                                      |             | 1      | l слово (2 ба           | йта) |   |  |  |
| Операнды      | $0 \le r \le 31, 0$ | $\leq r \leq 31, 0 \leq b \leq 7$                                                                                                |                                         |             |        |                         |      |   |  |  |
| Описание      |                     | ооверяет состояние разряда b регистра общего назначения Rr. Если разряд установлен, манда, следующая за SBRS Rr, b, пропускается |                                         |             |        |                         |      |   |  |  |
| Регистр SREG  | I                   | T                                                                                                                                | Н                                       | S           | V      | N                       | Z    | C |  |  |
| 1 CINCIP SKEO | _                   |                                                                                                                                  |                                         |             |        |                         |      |   |  |  |
| Маш. циклов   | 2, если Rr.b        | = 1 (размер                                                                                                                      | опуска кома<br>пропускаем<br>пропускаем | юй команды  |        |                         |      |   |  |  |
| AT90S1200     | да                  | 1                                                                                                                                |                                         |             |        |                         |      |   |  |  |
| Пример        | sbr                 | s r0,7 ;                                                                                                                         |                                         | гь след.    |        | если r0.7<br>r0.7 = «1» |      |   |  |  |

#### SEC

# Установка флага переноса

| Операция      | C = 1      | C = 1                                                                         |    |   |   |               |       |   |  |  |
|---------------|------------|-------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|
| Код операции  | 1001 0100  | 0000 10                                                                       | 00 |   | İ | І слово (2 ба | ійта) |   |  |  |
| Операнды      | Нет операн | ет операндов                                                                  |    |   |   |               |       |   |  |  |
| Описание      | Устанавлив | станавливает в «1» флаг переноса С регистра SREG. Эквивалентна команде BSET 0 |    |   |   |               |       |   |  |  |
| Регистр SREG  | I          | T                                                                             | Н  | S | V | N             | Z     | С |  |  |
| T CINCIP SKEO | _          | 1                                                                             |    |   |   |               |       |   |  |  |
| Маш. циклов   | 1          |                                                                               |    |   |   |               |       |   |  |  |
| AT90S1200     | да         |                                                                               |    |   |   |               |       |   |  |  |
| Пример        |            | sec ; Установить флаг переноса<br>addc r0,r1 ; r0 = r0 + r1 + 1               |    |   |   |               |       |   |  |  |

**SEH** 

## Установка флага половинного переноса

| Операция      | H = 1                       | H = 1                                                                                        |           |           |           |               |       |   |  |  |
|---------------|-----------------------------|----------------------------------------------------------------------------------------------|-----------|-----------|-----------|---------------|-------|---|--|--|
| Код операции  | 1001 0100                   | 0101 10                                                                                      | 00        |           |           | 1 слово (2 ба | айта) |   |  |  |
| Операнды      | Нет операн                  | Нет операндов                                                                                |           |           |           |               |       |   |  |  |
| Описание      | <b>Устанавлив</b><br>BSET 5 | станавливает в «1» флаг половинного переноса Н регистра SREG. Эквивалентна команде<br>ISET 5 |           |           |           |               |       |   |  |  |
| Регистр SREG  | I                           | T                                                                                            | Н         | S         | V         | N             | Z     | С |  |  |
| I cincip Sked | _                           | _                                                                                            | 1         | _         | _         | _             | _     | _ |  |  |
| Маш. циклов   | 1                           |                                                                                              |           |           |           |               |       |   |  |  |
| AT90S1200     | да                          | ıa .                                                                                         |           |           |           |               |       |   |  |  |
| Пример        | slh                         | і ; Устано                                                                                   | овить фла | г половин | ного пере | еноса         |       |   |  |  |

#### **SEI**

## Общее разрешение прерываний

| Операция     | I = 1                    | = 1                                  |              |                                     |           |              |            |             |  |
|--------------|--------------------------|--------------------------------------|--------------|-------------------------------------|-----------|--------------|------------|-------------|--|
| Код операции | 1001 0100                | 001 0100 0111 1000 1 слово (2 байта) |              |                                     |           |              |            |             |  |
| Операнды     | Нет операн               | Іет операндов                        |              |                                     |           |              |            |             |  |
| Описание     | Устанавлив<br>манде BSET |                                      | аг общего ра | зрешения п                          | рерываний | I регистра S | REG. Эквив | алентна ко- |  |
| Peructo SREG | I                        | T                                    | Н            | S                                   | V         | N            | Z          | С           |  |
| reincip Sked | 1                        | 1                                    |              |                                     |           |              |            |             |  |
| Маш. циклов  | 1                        |                                      |              |                                     |           |              |            |             |  |
| AT90S1200    | да                       |                                      |              |                                     |           |              |            |             |  |
| Пример       | 1                        | , ,                                  | ; Прочит     | ить преры<br>ать состо<br>ить преры | яние пор  | та В         |            |             |  |

#### **SEN**

## Установка флага отрицательного значения

| Операция     | N = 1                                                                            | i=1                                                                                            |           |           |           |            |          |   |  |  |
|--------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------|-----------|-----------|------------|----------|---|--|--|
| Код операции | 1001 0100                                                                        | 001 0100 0010 1000 1 слово (2 байта)                                                           |           |           |           |            |          |   |  |  |
| Операнды     | Нет операн                                                                       | ет операндов                                                                                   |           |           |           |            |          |   |  |  |
| 1 Списание   | Устанавлив<br>BSET 2                                                             | станавливает в «1» флаг отрицательного значения N регистра SREG. Эквивалентна команде<br>SET 2 |           |           |           |            |          |   |  |  |
| Peructp SREG | I                                                                                | T                                                                                              | Н         | S         | V         | N          | Z        | C |  |  |
| reincip Sked | _                                                                                | _                                                                                              | _         | _         | _         | 1          | _        | _ |  |  |
| Маш. циклов  | 1                                                                                |                                                                                                |           |           |           |            |          |   |  |  |
| AT90S1200    | да                                                                               |                                                                                                |           |           |           |            |          |   |  |  |
| Пример       | add r2,r19 ; Сложить r2 и r19<br>sln ; Установить флаг отрицательного результата |                                                                                                |           |           |           |            |          |   |  |  |
|              | 511.                                                                             | ı                                                                                              | , установ | мть Анат. | отрицател | remore hes | рупртата |   |  |  |

#### SER Rd

#### Установка РОН

| Операция     | Rd = \$FF   |                                                                                                                                        |            |             |          |               |       |   |  |  |
|--------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|----------|---------------|-------|---|--|--|
| Код операции | 1110 1111   | dddd 11                                                                                                                                | 11         |             |          | 1 слово (2 ба | айта) |   |  |  |
| Операнды     | 16 ≤ d ≤ 31 | 5 ≤ d ≤ 31                                                                                                                             |            |             |          |               |       |   |  |  |
| Описание     |             | танавливает все разряды регистра общего назначения в «1». Команда применима только к<br>гистрам из старшей половины регистрового файла |            |             |          |               |       |   |  |  |
| Peructp SREG | I           | T                                                                                                                                      | H          | S           | V        | N             | Z     | C |  |  |
| reincip Sked | _           | _   _   _   _   _   _                                                                                                                  |            |             |          |               |       |   |  |  |
| Маш. циклов  | 1           |                                                                                                                                        |            |             |          |               |       |   |  |  |
| AT90S1200    | да          |                                                                                                                                        |            |             |          |               |       |   |  |  |
|              | Организаци  | ия цикла с за                                                                                                                          | аданным чи | слом повтор | ений     |               |       |   |  |  |
|              | clr         | r16                                                                                                                                    | ; Очисти   | ть регист   | p r16    |               |       |   |  |  |
| Пример       | ser         | r17                                                                                                                                    | ; Устано   | вить реги   | стр r17  |               |       |   |  |  |
| Пример       | out         | out \$18,r16 ; Записать в порт В нули                                                                                                  |            |             |          |               |       |   |  |  |
|              | nop         | )                                                                                                                                      |            |             |          |               |       |   |  |  |
|              | out         | \$18,r17                                                                                                                               | ; Записа   | ть в порт   | В единиі | ДЫ            |       |   |  |  |

#### SES

## Установка флага знака

| Операция     | S = 1              | = [                                                                       |    |  |  |               |       |  |  |  |
|--------------|--------------------|---------------------------------------------------------------------------|----|--|--|---------------|-------|--|--|--|
| Код операции | 1001 0100          | 0100 10                                                                   | 00 |  |  | 1 слово (2 ба | айта) |  |  |  |
| Операнды     | Нет операн         | гоперандов                                                                |    |  |  |               |       |  |  |  |
| Описание     | Устанавлив         | танавливает в «1» флаг знака S регистра SREG. Эквивалентна команде BSET 4 |    |  |  |               |       |  |  |  |
| Регистр SREG | CDEC I T H S V N Z |                                                                           |    |  |  |               |       |  |  |  |
| reincip Sked | _                  | 1                                                                         |    |  |  |               |       |  |  |  |
| Маш. циклов  | 1                  | ,                                                                         |    |  |  |               |       |  |  |  |
| AT90S1200    | да                 |                                                                           |    |  |  |               |       |  |  |  |
| Пример       | add                | add r2,r19 ; Сложить r2 и r19                                             |    |  |  |               |       |  |  |  |
| ттример      | ses                | ses ; Установить флаг знака                                               |    |  |  |               |       |  |  |  |

#### **SET**

# Установка флага Т

| Операция     | T = 1      | Γ = 1                                                                |           |    |   |   |   |   |  |  |  |
|--------------|------------|----------------------------------------------------------------------|-----------|----|---|---|---|---|--|--|--|
| Код операции | 1001 0100  | 001 0100 0110 1000 1 слово (2 байта)                                 |           |    |   |   |   |   |  |  |  |
| Операнды     | Нет операн | ет операндов                                                         |           |    |   |   |   |   |  |  |  |
| Описание     | Устанавлив | станавливает в «1» флаг T регистра SREG. Эквивалентна команде BSET 6 |           |    |   |   |   |   |  |  |  |
| Peructo SREG | I          | I T H S V N Z C                                                      |           |    |   |   |   |   |  |  |  |
| reincip Sked | _          | 1                                                                    | _         | _  | _ | _ | _ | _ |  |  |  |
| Маш. циклов  | 1          |                                                                      |           |    |   |   |   |   |  |  |  |
| AT90S1200    | да         | ia                                                                   |           |    |   |   |   |   |  |  |  |
| Пример       | set        | ; Устан                                                              | овить фла | гТ |   |   |   |   |  |  |  |

#### SEV

## Установка флага переполнения дополнительного кода

| Операция     | V = 1                                                               | = 1                                                                                                   |    |   |   |               |       |   |  |
|--------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|
| Код операции | 1001 0100                                                           | 0011 10                                                                                               | 00 |   |   | 1 слово (2 ба | ійта) |   |  |
| Операнды     | Нет операн                                                          | ет операндов                                                                                          |    |   |   |               |       |   |  |
| Описание     | ı                                                                   | станавливает в «1» флаг переполнения дополнительного кода V регистра SREG. Эквивалента команде BSET 3 |    |   |   |               |       |   |  |
| Peructp SREG | I                                                                   | T                                                                                                     | Н  | S | V | N             | Z     | С |  |
| reincip Sked | _                                                                   | _                                                                                                     | _  | _ | 1 | _             | _     | _ |  |
| Маш. циклов  | 1                                                                   |                                                                                                       |    |   |   |               |       |   |  |
| AT90S1200    | да                                                                  |                                                                                                       |    |   |   |               |       |   |  |
| Пример       | add r2,r19 ; Сложить r2 и r19<br>sev ; Установить флаг переполнения |                                                                                                       |    |   |   |               |       |   |  |

SEZ

## Установка флага нуля

| Операция     | Z = 1                                                       | =1                                  |              |            |            |             |           |   |  |  |
|--------------|-------------------------------------------------------------|-------------------------------------|--------------|------------|------------|-------------|-----------|---|--|--|
| Код операции | 1001 0100                                                   | 01 0100 0001 1000 1 слово (2 байта) |              |            |            |             |           |   |  |  |
| Операнды     | Нет операн                                                  | ет операндов                        |              |            |            |             |           |   |  |  |
| Описание     | Устанавлив                                                  | ает в «1» фл                        | аг нуля Z ре | гистра SRE | G. Эквивал | ентна коман | де BSET 1 |   |  |  |
| Регистр SREG | I                                                           | T                                   | Н            | S          | V          | N           | Z         | C |  |  |
| reincip Sked | _                                                           | _                                   | _            | _          | _          | _           | 1         | _ |  |  |
| Маш. циклов  | 1                                                           |                                     |              |            |            |             |           |   |  |  |
| AT90S1200    | да                                                          |                                     |              |            |            |             |           |   |  |  |
| Пример       | add r2,r19 ; Сложить r2 и r19<br>sez ; Установить флаг нуля |                                     |              |            |            |             |           |   |  |  |
| Пример       |                                                             |                                     |              |            |            |             |           |   |  |  |

#### SLEEP

## Перевод микроконтроллера в режим пониженного энергопотребления

| Операция     | См. описан         | ие режимов                                                                                                                                                                                                    | пониженно | ого энергопо | требления | в параграфе   | 4.3.  |  |  |  |
|--------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------|-----------|---------------|-------|--|--|--|
| Код операции | 1001 0101          | 1000 10                                                                                                                                                                                                       | 00        |              |           | 1 слово (2 ба | айта) |  |  |  |
| Операнды     | Нет операн         | дов                                                                                                                                                                                                           |           |              |           |               |       |  |  |  |
| Описание     | вия зависят        | ереводит микроконтроллер в режим пониженного энергопотребления. Конкретные дейстия зависят от модели микроконтроллера и от выбранного режима. Для получения более пообной информации обратитесь к разделу 4.3 |           |              |           |               |       |  |  |  |
| Регистр SREG | SPEC I T H S V N Z |                                                                                                                                                                                                               |           |              |           |               |       |  |  |  |
| reincip Sked | _                  |                                                                                                                                                                                                               |           |              |           |               |       |  |  |  |
| Маш. циклов  | 1                  |                                                                                                                                                                                                               |           |              |           |               |       |  |  |  |
| AT90S1200    | да                 |                                                                                                                                                                                                               |           |              |           |               |       |  |  |  |
| Пример       | ldi<br>out         | mov r0,r11 ; Скопировать регистр r11 в r0 ldi r16,(1< <se) ;="" mcucr,r16="" out="" sleep="" th="" «спящий»="" в="" переключиться="" переход="" разрешить="" режим="" режим<=""></se)>                        |           |              |           |               |       |  |  |  |

## ST X, Rr

## Косвенная запись в память данных

| Операция     | [X] = Rr                                 | X] = Rr                                                                                                                                                         |          |            |           |               |       |   |  |
|--------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|-----------|---------------|-------|---|--|
| Код операции | 1001 0011                                | rrrr 11                                                                                                                                                         | 00       |            |           | 1 слово (2 ба | айта) |   |  |
| Операнды     | $0 \le r \le 31$                         | ≤r≤31                                                                                                                                                           |          |            |           |               |       |   |  |
| Описание     | 1 *                                      | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>и, к которой производится обращение, содержится в индексном регистре X |          |            |           |               |       |   |  |
| Peructo SREG | I                                        | I T H S V N Z C                                                                                                                                                 |          |            |           |               |       |   |  |
| reincip Sked | _                                        | _                                                                                                                                                               | _        | _          | _         | _             | _     | _ |  |
| Маш. циклов  | 2                                        |                                                                                                                                                                 |          |            |           |               |       |   |  |
| AT90S1200    | нет                                      |                                                                                                                                                                 |          |            |           |               |       |   |  |
|              | clr                                      | r27                                                                                                                                                             | ; Очисти | ить ст. ба | эйт индек | сного рег     | истра |   |  |
| Пример       | ldi r26,\$60 ; Загрузить мл. байт адреса |                                                                                                                                                                 |          |            |           |               |       |   |  |
|              | st                                       | X,r1                                                                                                                                                            | ; Загруз | вить r1 по | о адресу  | \$0060        |       |   |  |

## ST X+, Rr

## Косвенная запись в память данных с постинкрементом

| Операция     | [X] = Rr, X    | = X+1                                                                                                                                                                                                                            |    |   |   |               |       |   |  |  |
|--------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|
| Код операции | 1001 0011      | rrrr 11                                                                                                                                                                                                                          | 01 |   |   | 1 слово (2 ба | айта) |   |  |  |
| Операнды     | 0 ≤ r ≤ 31, д. | $\leq$ r $\leq$ 31, для r = 26 или 27 результат операции не определен                                                                                                                                                            |    |   |   |               |       |   |  |  |
| Описание     | ти, к которо   | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>, к которой производится обращение, содержится в индексном регистре X. После пересыл-<br>байта содержимое регистра X увеличивается на 1 |    |   |   |               |       |   |  |  |
| Peructp SREG | I              | T                                                                                                                                                                                                                                | Н  | S | V | N             | Z     | С |  |  |
| reincip Sked | _              |                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |  |
| Маш. циклов  | 2              |                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |  |
| AT90S1200    | нет            |                                                                                                                                                                                                                                  |    |   |   |               |       |   |  |  |
| Пример       | ldi<br>st      | clr r27 ; Очистить ст. байт индексного регистра<br>ldi r26,\$60 ; Загрузить мл. байт адреса                                                                                                                                      |    |   |   |               |       |   |  |  |

ST –X, Rr Косвенная запись в память данных с преддекрементом

| Операция     | X = X - 1, [X | (] = Rr                                                                                                                                                                                                                                           |               |                                      |             |               |       |  |  |  |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------|-------------|---------------|-------|--|--|--|
| Код операции | 1001 0011     | rrrr 11                                                                                                                                                                                                                                           | 10            |                                      | 1           | 1 слово (2 ба | ійта) |  |  |  |
| Операнды     | 0 ≤ r ≤ 31, д | ля r = 26 илі                                                                                                                                                                                                                                     | и 27 результа | ат операции                          | не определе | ен            |       |  |  |  |
| 1            | ти, к котор   | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>п, к которой производится обращение, содержится в индексном регистре X, причем перед<br>пращением к памяти данных содержимое регистра X уменьшается на 1 |               |                                      |             |               |       |  |  |  |
| Perистр SREG | I –           | I T H S V N Z C                                                                                                                                                                                                                                   |               |                                      |             |               |       |  |  |  |
| Маш. циклов  | 2             |                                                                                                                                                                                                                                                   |               |                                      |             |               | ı     |  |  |  |
| AT90S1200    | нет           |                                                                                                                                                                                                                                                   |               |                                      |             |               |       |  |  |  |
| Пример       | ldi           |                                                                                                                                                                                                                                                   | ; Загруз      | ить ст. ба<br>ить мл. б<br>ить r3 по | байт адрес  | ca            | истра |  |  |  |

#### ST Y, Rr Косвенная запись в память данных

| Операция     | [Y] = Rr         |                                                                                                                                                                 |          |           |           |               |       |   |  |  |  |
|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------|-----------|---------------|-------|---|--|--|--|
| Код операции | 1000 0011        | rrrr 10                                                                                                                                                         | 00       |           |           | 1 слово (2 ба | йта)  |   |  |  |  |
| Операнды     | $0 \le r \le 31$ |                                                                                                                                                                 |          |           |           |               |       |   |  |  |  |
| Описание     | · •              | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>и, к которой производится обращение, содержится в индексном регистре Y |          |           |           |               |       |   |  |  |  |
| Dawyama CDEC | I                | T                                                                                                                                                               | Н        | S         | V         | N             | Z     | C |  |  |  |
| Peructp SREG | _                |                                                                                                                                                                 |          |           |           |               |       |   |  |  |  |
| Маш. циклов  | 2                |                                                                                                                                                                 |          |           |           |               |       |   |  |  |  |
| AT90S1200    | нет              |                                                                                                                                                                 |          |           |           |               |       |   |  |  |  |
|              | clr              | r29                                                                                                                                                             | ; Очисти | ть ст. ба | эйт индек | сного рег     | истра |   |  |  |  |
| Пример       | 1di              | ldi r28,\$60 ; Загрузить мл. байт адреса                                                                                                                        |          |           |           |               |       |   |  |  |  |
|              | st               | Y,r1                                                                                                                                                            | ; Пересл | ать r1 по | о адресу  | \$0060        |       |   |  |  |  |

## ST Y+, Rr

## Косвенная запись в память данных с постинкрементом

| Операция     | [Y] = Rr, Y    | = Y+1                                                                                                                                                                                                                              |              |             |            |               |       |   |  |  |
|--------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|------------|---------------|-------|---|--|--|
| Код операции | 1001 0011      | rrrr 11                                                                                                                                                                                                                            | 01           |             |            | 1 слово (2 ба | ійта) |   |  |  |
| Операнды     | 0 ≤ r ≤ 31, д. | ля r = 28 ил                                                                                                                                                                                                                       | и 29 результ | ат операции | не определ | ен            |       |   |  |  |
| Описание     | ти, к котор    | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>, к которой производится обращение, содержится в индексном регистре Y. После пересыл-<br>в байта содержимое регистра Y увеличивается на 1 |              |             |            |               |       |   |  |  |
| Регистр SREG | I              | T                                                                                                                                                                                                                                  | Н            | S           | V          | N             | Z     | С |  |  |
| reincip Sked | _              |                                                                                                                                                                                                                                    |              |             |            |               |       |   |  |  |
| Маш. циклов  | 2              |                                                                                                                                                                                                                                    |              |             |            |               |       |   |  |  |
| AT90S1200    | нет            |                                                                                                                                                                                                                                    |              |             |            |               |       |   |  |  |
| Пример       | ldi<br>st      | clr r29 ; Очистить ст. байт индексного регистра<br>ldi r28,\$60 ; Загрузить мл. байт адреса                                                                                                                                        |              |             |            |               |       |   |  |  |

## ST -Y, Rr

## Косвенная запись в память данных с преддекрементом

| Операция     | Y = Y - 1, [Y] | ] = Rr                                                                                                                                                                                                                                            |                                   |           |           |               |       |   |  |
|--------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|-----------|---------------|-------|---|--|
| Код операции | 1001 0011      | rrrr 10                                                                                                                                                                                                                                           | 10                                |           |           | 1 слово (2 ба | ійта) |   |  |
| Операнды     | 0 ≤ r ≤ 31, д. | $\leq$ r $\leq$ 31, для r = 28 или 29 результат операции не определен                                                                                                                                                                             |                                   |           |           |               |       |   |  |
| Описание     | ти, к котор    | Охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>и, к которой производится обращение, содержится в индексном регистре Y, причем перед<br>бращением к памяти данных содержимое регистра Y уменьшается на 1 |                                   |           |           |               |       |   |  |
| Peructp SREG | I              | T                                                                                                                                                                                                                                                 | Н                                 | S         | V         | N             | Z     | С |  |
|              | _              | _                                                                                                                                                                                                                                                 | _                                 | _         | _         | _             | _     | _ |  |
| Маш. циклов  | 2              |                                                                                                                                                                                                                                                   |                                   |           |           |               |       |   |  |
| AT90S1200    | нет            |                                                                                                                                                                                                                                                   |                                   |           |           |               |       |   |  |
| Пример       | 1di            |                                                                                                                                                                                                                                                   | ; Очисти<br>; Загруз:<br>; Пересл | ить мл. б | айт адрес |               | истра |   |  |

ST Z, Rr Косвенная запись в память данных

| Операция     | [Z] = Rr                 |                                                                                                                                                                                                                                                                                                                  |          |                                     |           |               |       |   |  |  |
|--------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------------------------|-----------|---------------|-------|---|--|--|
| Код операции | 1000 0011                | rrrr 00                                                                                                                                                                                                                                                                                                          | 00       |                                     |           | 1 слово (2 ба | ійта) |   |  |  |
| Операнды     | $0 \le r \le 31$         |                                                                                                                                                                                                                                                                                                                  |          |                                     |           |               |       |   |  |  |
| Описание     | AT90S1200 :<br>тальных — | охраняет содержимое регистра общего назначения Rr в памяти данных. Для модели T90S1200 в адресное пространство памяти данных входит только регистровый файл, для ословных — регистровый файл, память ввода/вывода и ОЗУ. Адрес ячейки памяти, к которой роизводится обращение, содержится в индексном регистре Z |          |                                     |           |               |       |   |  |  |
| Perистр SREG | I                        | T                                                                                                                                                                                                                                                                                                                | Н        | S                                   | V         | N             | Z     | С |  |  |
| reincip Sked | _                        | _                                                                                                                                                                                                                                                                                                                | _        | _                                   | _         | _             | _     | - |  |  |
| Маш. циклов  | 2                        |                                                                                                                                                                                                                                                                                                                  |          |                                     |           |               |       |   |  |  |
| AT90S1200    | да                       |                                                                                                                                                                                                                                                                                                                  |          |                                     |           |               |       |   |  |  |
| Пример       | 1di                      |                                                                                                                                                                                                                                                                                                                  | ; Загруз | ть ст. ба<br>ить мл. б<br>ать r1 по | айт адрес | ca            | истра |   |  |  |

ST Z+, Rr Косвенная запись в память данных с постинкрементом

| Операция     | [Z] = Rr, Z           | = Z+1                                                                                                                                                                                                                               |    |   |   |               |       |   |  |  |
|--------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---------------|-------|---|--|--|
| Код операции | 1001 001ı             | rrrr 10                                                                                                                                                                                                                             | 01 |   |   | 1 слово (2 ба | ійта) |   |  |  |
| Операнды     | $0 \le r \le 31$ , д. | ≤ r ≤ 31, для r = 30 или 31 результат операции не определен                                                                                                                                                                         |    |   |   |               |       |   |  |  |
| 1            | ти, к которо          | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>1, к которой производится обращение, содержится в индексном регистре Z. После пересыл-<br>1 байта содержимое регистра Z увеличивается на 1 |    |   |   |               |       |   |  |  |
| Регистр SREG | I                     | T                                                                                                                                                                                                                                   | Н  | S | V | N             | Z     | С |  |  |
| reincip Sked | _                     | _                                                                                                                                                                                                                                   | _  | _ | _ | _             | _     | _ |  |  |
| Маш. циклов  | 2                     |                                                                                                                                                                                                                                     |    |   |   |               |       |   |  |  |
| AT90S1200    | нет                   |                                                                                                                                                                                                                                     |    |   |   |               |       |   |  |  |
| Пример       | ldi<br>st             | clr r31 ; Очистить ст. байт индексного регистра<br>ldi r30,\$60 ; Загрузить мл. байт адреса<br>st Z+,r1 ; Переслать r1 по адресу \$0060<br>in r2,r30 ; В регистре r2 — \$61                                                         |    |   |   |               |       |   |  |  |

## ST -Z, Rr

## Косвенная запись в память данных с преддекрементом

| Операция      | Z = Z - 1, [         | z = Z - 1, $[Z] = Rr$                                                                                                                                                                                                                          |    |   |                         |               |       |   |  |  |
|---------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|-------------------------|---------------|-------|---|--|--|
| Код операции  | 1001 0011            | rrrr 10                                                                                                                                                                                                                                        | 10 |   |                         | 1 слово (2 ба | ійта) |   |  |  |
| Операнды      | $0 \le r \le 31$ , д | $\leq$ r $\leq$ 31, для r = 30 или 31 результат операции не определен                                                                                                                                                                          |    |   |                         |               |       |   |  |  |
| Описание      | ти, к котор          | храняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>, к которой производится обращение, содержится в индексном регистре Z, причем перед<br>рашением к памяти данных содержимое регистра Z уменьшается на 1 |    |   |                         |               |       |   |  |  |
| Peructo SREG  | I                    | T                                                                                                                                                                                                                                              | Н  | S | V                       | N             | Z     | С |  |  |
| T CINCIP SKEG | _                    | _                                                                                                                                                                                                                                              | _  | _ | _                       | _             | _     | _ |  |  |
| Маш. циклов   | 2                    |                                                                                                                                                                                                                                                |    |   |                         |               |       |   |  |  |
| AT90S1200     | нет                  |                                                                                                                                                                                                                                                |    |   |                         |               |       |   |  |  |
|               |                      | clr r31 ; Очистить ст. байт индексного регистра<br>ldi r30,\$63 ; Загрузить мл. байт адреса                                                                                                                                                    |    |   |                         |               |       |   |  |  |
| Пример        | ı                    |                                                                                                                                                                                                                                                |    |   | аит адрес<br>о адресу : |               |       |   |  |  |

## STD Y+q, Rr

#### Косвенная относительная запись в память данных

| Операция     | [Y+q]=R             | r                                                                                                                                                                                                                                                      |                                   |           |           |               |       |  |  |  |  |
|--------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-----------|-----------|---------------|-------|--|--|--|--|
| Код операции | 10q0 qq1ı           | rrrr 1q                                                                                                                                                                                                                                                | dd                                |           |           | 1 слово (2 ба | ійта) |  |  |  |  |
| Операнды     | $0 \le r \le 31, 0$ | $\leq r \leq 31,  0 \leq q \leq 63$                                                                                                                                                                                                                    |                                   |           |           |               |       |  |  |  |  |
| Описание     | ти, к котор         | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>и, к которой производится обращение, получается суммированием содержимого индексно-<br>регистра Y и константы q. Содержимое индексного регистра не изменяется |                                   |           |           |               |       |  |  |  |  |
| Регистр SREG | I                   | I T H S V N Z C                                                                                                                                                                                                                                        |                                   |           |           |               |       |  |  |  |  |
| Маш. циклов  | 2                   |                                                                                                                                                                                                                                                        |                                   |           |           |               |       |  |  |  |  |
| AT90S1200    | нет                 |                                                                                                                                                                                                                                                        |                                   |           |           |               |       |  |  |  |  |
| Пример       | ldi                 |                                                                                                                                                                                                                                                        | ; Очисти<br>; Загруз:<br>; Пересл | ить мл. б | айт адрес |               | истра |  |  |  |  |

## STD Z+q, Rd

#### Косвенная относительная запись в память данных

| Операция      | [Z+q]=R             | r                                                                                                                                                                                                                                                      |                                  |           |          |               |       |   |  |  |
|---------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------|----------|---------------|-------|---|--|--|
| Код операции  | 10q0 qq1:           | rrrr 0q                                                                                                                                                                                                                                                | qq                               |           |          | 1 слово (2 ба | йта)  |   |  |  |
| Операнды      | $0 \le r \le 31, 0$ | ≤ q ≤ 63                                                                                                                                                                                                                                               |                                  |           |          |               |       |   |  |  |
| Описание      | ти, к котор         | охраняет содержимое регистра общего назначения Rr в памяти данных. Адрес ячейки памя-<br>1, к которой производится обращение, получается суммированием содержимого индексно-<br>регистра Z и константы q. Содержимое индексного регистра не изменяется |                                  |           |          |               |       |   |  |  |
| Регистр SREG  | I                   | T                                                                                                                                                                                                                                                      | Н                                | S         | V        | N             | Z     | С |  |  |
| I cincip Sked | _                   | -                                                                                                                                                                                                                                                      | _                                | _         | _        | _             | _     | _ |  |  |
| Маш. циклов   | 2                   |                                                                                                                                                                                                                                                        |                                  |           |          |               |       |   |  |  |
| AT90S1200     | нет                 |                                                                                                                                                                                                                                                        |                                  |           |          |               |       |   |  |  |
| Пример        | ldi                 |                                                                                                                                                                                                                                                        | ; Очисти<br>; Загруз<br>; Пересл | ить мл. б | айт адре |               | истра |   |  |  |

## STS k, Rd Непосредственная запись в память данных

| Операция     | [k] = Rd            |                                                                                                                                                     |           |           |          |           |              |    |  |  |
|--------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|----------|-----------|--------------|----|--|--|
| Код операции | 1001 0016           | dddd 00                                                                                                                                             | 00 kkkk k | kkk kkkk  | kkkk     | 2 cJ      | юва (4 байта | a) |  |  |
| Операнды     | $0 \le d \le 31, 0$ | $\leq d \leq 31, 0 \leq k \leq 65535$                                                                                                               |           |           |          |           |              |    |  |  |
| Описание     |                     | охраняет содержимое регистра общего назначения Rd в памяти данных. Адрес ячейки памя-<br>и, к которой производится обращение, задается константой К |           |           |          |           |              |    |  |  |
| Регистр SREG | I                   | I T H S V N Z C                                                                                                                                     |           |           |          |           |              |    |  |  |
| refucip SkeG | _                   | _                                                                                                                                                   | _         | _         | _        | _         | _            | _  |  |  |
| Маш. циклов  | 2                   |                                                                                                                                                     |           |           |          |           |              |    |  |  |
| AT90S1200    | нет                 |                                                                                                                                                     |           |           |          |           |              |    |  |  |
|              | lds                 | r2,\$FF00                                                                                                                                           | ; r2 =    | [\$FF00]  |          |           |              |    |  |  |
| Пример       | 1                   | r2,r1                                                                                                                                               |           |           |          |           |              |    |  |  |
|              | sts                 | \$FF000,1                                                                                                                                           | 2 ; Запи  | сать резу | льтат по | тому же а | адресу       |    |  |  |

## SUB Rd, Rr

## Вычитание двух РОН

| Операция     | Rd = Rd - 1         | Rr                                |                      |             |                       |             |              |    |  |  |  |
|--------------|---------------------|-----------------------------------|----------------------|-------------|-----------------------|-------------|--------------|----|--|--|--|
| Код операции | 0001 10rd           | d dddd rr                         | rr                   |             | 1                     | слово (2 ба | йта)         |    |  |  |  |
| Операнды     | $0 \le d \le 31, 0$ | ) ≤ d ≤ 31, 0 ≤ r ≤ 31            |                      |             |                       |             |              |    |  |  |  |
| Описание     | Вычитает и          | з регистра Б                      | Rd содержим          | ое регистра | Rr. Результа          | т помещает  | ся в регистр | Rd |  |  |  |
| Downson CDEC | I                   | I T H S V N Z C                   |                      |             |                       |             |              |    |  |  |  |
| Peructp SREG | -                   | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ |                      |             |                       |             |              |    |  |  |  |
| Маш. циклов  | 1                   |                                   |                      |             |                       |             |              |    |  |  |  |
| AT90S1200    | да                  |                                   |                      |             |                       |             |              |    |  |  |  |
| Пример       |                     | ne noteq                          | ; Вычест<br>; Перейт |             | r13 (r13=<br>12 ≠ r13 | r13-r12)    |              |    |  |  |  |

## SUBI Rd, K

## Вычитание константы из регистра

| Операция     | Rd = Rd - K                                                                                                                                                             |   |   |   |   |   |   |   |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|
| Код операции | 1010 KKKK dddd KKKK 1 слово (2 байта)                                                                                                                                   |   |   |   |   |   |   |   |
| Операнды     | $16 \le d \le 31, K = 0255$                                                                                                                                             |   |   |   |   |   |   |   |
| 1 иписание   | Вычитает из регистра Rd значение константы К. Результат помещается обратно в регистр.<br>Данная команда применима только к старшей половине регистров общего назначения |   |   |   |   |   |   |   |
| Регистр SREG | I                                                                                                                                                                       | T | Н | S | V | N | Z | С |
|              | _                                                                                                                                                                       | _ | ⇔ | ⇔ | ⇔ | ⇔ | ⇔ | ⇔ |
| Маш. циклов  | 1                                                                                                                                                                       |   |   |   |   |   |   |   |
| AT90S1200    | да                                                                                                                                                                      |   |   |   |   |   |   |   |
| Пример       | subi r22,\$11 ; Вычесть \$11 из r22<br>brne noteq ; Перейти, если r22 ≠ \$11<br><br>noteq:                                                                              |   |   |   |   |   |   |   |

# SWAP Rd

# Перестановка тетрад РОН

| Операция      | Rd(7:4) = R      | d(3:0), Rd(3                                                                        | S:0) = Rd(7:4) | )         |         |               |      |  |  |  |  |  |
|---------------|------------------|-------------------------------------------------------------------------------------|----------------|-----------|---------|---------------|------|--|--|--|--|--|
| Код операции  | 1001 0100        | dddd 00                                                                             | 10             |           |         | 1 слово (2 ба | йта) |  |  |  |  |  |
| Операнды      | $0 \le d \le 31$ | d≤31                                                                                |                |           |         |               |      |  |  |  |  |  |
| Описание      | Команда пр       | манда производит перестановку старшего и младшего полубайта содержимого регистра Rd |                |           |         |               |      |  |  |  |  |  |
| Perистр SREG  | I                | I T H S V N Z C                                                                     |                |           |         |               |      |  |  |  |  |  |
| I CINCIP SKEO | _                |                                                                                     |                |           |         |               |      |  |  |  |  |  |
| Маш. циклов   | 1                |                                                                                     |                |           |         |               |      |  |  |  |  |  |
| AT90S1200     | да               |                                                                                     |                |           |         |               |      |  |  |  |  |  |
|               | inc              | r1 ; M                                                                              | нкременти      | ровать r1 |         |               |      |  |  |  |  |  |
| Пример        | SWa              | ър r1 ; П                                                                           | ереставит      | ь тетрады |         |               |      |  |  |  |  |  |
| Пример        | inc              | inc r1 ; Инкрементировать старший полубайт r1                                       |                |           |         |               |      |  |  |  |  |  |
|               | SWa              | ър r1 ; П                                                                           | ереставит      | ь тетрады | обратно |               |      |  |  |  |  |  |

# TST Rd

# Проверка РОН на нулевое или отрицательное значение

| Операция     | Rd = Rd • R      | Rd                                                                                                                                                                      |                      |   |     |               |       |  |  |  |  |  |
|--------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|---|-----|---------------|-------|--|--|--|--|--|
| Код операции | 0010 00dd        | d dddd dd                                                                                                                                                               | dd                   |   | 1   | 1 слово (2 ба | айта) |  |  |  |  |  |
| Операнды     | $0 \le d \le 31$ | ≤ d ≤ 31                                                                                                                                                                |                      |   |     |               |       |  |  |  |  |  |
| Описание     |                  | роверяет содержимое регистра на нулевое или отрицательное значение путем выполнения перации «Логическое И» регистра с самим собой. Содержимое регистра Rd не изменяется |                      |   |     |               |       |  |  |  |  |  |
| Регистр SREG | I T H S V N Z C  |                                                                                                                                                                         |                      |   |     |               |       |  |  |  |  |  |
| Perucip SkeG | ↔ 0 ↔ -          |                                                                                                                                                                         |                      |   |     |               |       |  |  |  |  |  |
| Маш. циклов  | 1                |                                                                                                                                                                         |                      | • | •   | •             |       |  |  |  |  |  |
| AT90S1200    | да               |                                                                                                                                                                         |                      |   |     |               |       |  |  |  |  |  |
| Пример       | 1                | eq zero ;                                                                                                                                                               | Проверит<br>Перейти, |   | = 0 |               |       |  |  |  |  |  |

# 3. Система команд -

# WDR

# Сброс сторожевого таймера

| Операция     | Рестарт сто               | рожевого та                                                                                                                                                                                                                                                              | ймера     |          |       |              |   |   |  |  |  |  |
|--------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------|-------|--------------|---|---|--|--|--|--|
| Код операции | 1001 0101                 | 1 1010 10                                                                                                                                                                                                                                                                | 00        |          | 1 сло | во (2 байта) |   |   |  |  |  |  |
| Операнды     | Нет операн                | дов                                                                                                                                                                                                                                                                      |           |          |       |              |   |   |  |  |  |  |
| Описание     | да должна в<br>ентом деле | ыполняет сброс сторожевого таймера. При включенном сторожевом таймере данная комана должна выполняться через определенный промежуток времени, определяемый коэффицингом деления предделителя сторожевого таймера. Для получения подробной информации братитесь к главе 6 |           |          |       |              |   |   |  |  |  |  |
| Регистр SREG | I                         | T                                                                                                                                                                                                                                                                        | Н         | S        | V     | N            | Z | С |  |  |  |  |
| Маш. циклов  | _                         | _                                                                                                                                                                                                                                                                        | _         | _        | _     | _            | _ | _ |  |  |  |  |
| таш. циклов  | 1                         |                                                                                                                                                                                                                                                                          |           |          |       |              |   |   |  |  |  |  |
| AT90S1200    | да                        |                                                                                                                                                                                                                                                                          |           |          |       |              |   |   |  |  |  |  |
| Пример       | wdr                       | ; сброс                                                                                                                                                                                                                                                                  | ить сторо | жевой та | ймер  |              | · |   |  |  |  |  |

# Глава 4. **Устройство управления**

# 4.1. Общие сведения

Как известно, микроконтроллеру для работы требуется сигнал синхронизации (тактовый сигнал). В качестве источника тактового сигнала в микроконтроллерах AVR семейства Classic может использоваться встроенный кварцевый генератор или внешний сигнал синхронизации. В некоторых моделях имеется также внутренний RC-генератор.

Непременным атрибутом современных микроконтроллеров является наличие одного или нескольких режимов, обеспечивающих уменьшение энергии, потребляемой микроконтроллером от источника питания. Этот момент особенно актуален при разработке автономных устройств. Микроконтроллеры AVR семейства Classic поддерживают до трех различных режимов пониженного энергопотребления: Idle, Power Down и Power Save. Все эти режимы часто называют одним словом — «спящий» режим. Каждый из этих режимов позволяет значительно сократить энергопотребление в периоды бездействия микроконтроллера. В зависимости от используемого режима отключается различное количество систем микроконтроллера. Соответственно различным будет и уменьшение потребляемой энергии. Вход в этот режим осуществляется путем использования команды SLEEP. При «пробуждении» микроконтроллера (при выходе из «спящего» режима) производится его реинициализация.

Вообще реинициализация микроконтроллера (сброс) может произойти по различным причинам: подача напряжения питания, выход из «спящего» режима, уменьшение напряжения питания ниже минимально допустимого уровня (Brown Out Reset), срабатывание сторожевого таймера, появление на выводе RESET логического сигнала НИЗКОГО уровня. Фактическое число возможных источников сброса из перечисленных зависит от конкретной модели.

В качестве источников прерывания в микроконтроллерах семейства могут выступать периферийные устройства, а также некоторые выводы (входы внешних прерываний). Так как состав периферийных устройств зависит от модели, то и число источников прерываний в каждой модели различно.

# 4.2. Тактовый генератор

Микроконтроллеры AVR семейства Classic могут работать с внутренним *RC*-генератором, керамическим либо кварцевым резонатором или с сигналом внешней синхронизации. Возможность выбора того или иного источника тактового сигнала зависит от модели микроконтроллера. Возможные варианты для каждой модели указаны в **Табл. 4.1**.

| Источник тактового сигнала      | AT90S1200              | AT90S2313              | AT90S/LS2323           | AT90S/LS2343           | AT90S/LS2333           | AT90S/LS4433           | AT90S/LS4434           | AT90S/LS8535           | AT90S4414    | AT90S8515              | AT90C8534              |
|---------------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|------------------------|--------------|------------------------|------------------------|
| Резонатор                       | 0                      | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> |                        | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> | <b>\( \)</b> | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> |
| Внешний сигнал синхронизации    | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> | <b>\(\rightarrow\)</b> | <b>\rightarrow</b>     | <b>\rightarrow</b>     | <b>\rightarrow</b>     | <b>\rightarrow</b>     | <b>\( \)</b> | <b>◊</b>               | <b>\( \)</b>           |
| Внутренний <i>RC</i> -генератор | <b>\(\rightarrow\)</b> |                        |                        | <b>\( \)</b>           |                        |                        |                        |                        |              |                        |                        |

Таблица 4.1. Источники тактового сигнала

# Кварцевый генератор

Резонатор подключается к выводам XTAL1 и XTAL2 микроконтроллеров, как показано на **Рис. 4.1**. Эти выводы являются соответственно входом и выходом инвертора тактового генератора. При необходимости тактовый сигнал микроконтроллера можно использовать для управления ка-



Рис. 4.1. Подключение кварцевого или керамического резонатора

кими-либо внешними устройствами. Этот сигнал снимается с вывода XTAL2, причем между выводом и внешней схемой обязательно должен быть буфер (см. **Рис. 4.1**).

Емкости конденсаторов  $C_1$  и  $C_2$ , подключаемых между выводами резонатора и общим проводом, зависят от частоты и типа резонатора. Для кварцевого резонатора на частоту 4 МГц, например, емкость каждого конденсатора составляет порядка 30 пФ.

#### Внешний сигнал синхронизации

При использовании сигнала от внешнего источника возможны два варианта его подключения в зависимости от модели микроконтроллера. Для микроконтроллера AT90S/LS2343 сигнал от внешнего источника подается на вывод PB3 (Puc. 4.2a), при этом внутренний *RC*-генератор должен быть выключен (см. ниже). В остальных моделях микроконтроллеров сигнал от внешнего источника подается на вывод XTAL1, как показано на Puc. 4.2б. Вывод XTAL2 при этом оставляют неподключенным.



*Рис. 4.2.* Подключение внешнего источника тактового сигнала: a - AT90S/LS2343, 6 - прочие модели

# Внутренний *RC*-генератор

Использование внутреннего RC-генератора (резистор/конденсатор) является прежде всего наиболее экономичным решением, т.к. при этом не требуется никаких внешних компонентов. Вместе с тем это решение пригодно только для низкопроизводительных приложений, не требующих высокой временной точности. В частности, категорически не рекомендуется использовать внутренний RC-генератор при построении систем реального времени.

Частота сигнала внутреннего *RC*-генератора фиксирована и равна 1 МГц (при напряжении питания  $V_{\rm CC}$  = 5 B).

Для использования внутреннего *RC*-генератора необходимо запрограммировать (записать «0») конфигурационную ячейку (fuse bit) RCEN, расположенную в выделенной области FLASH-памяти. Программирование этой ячейки может быть произведено только в параллельном режиме. Если внутренний *RC*-генератор предполагается использовать для самозагрузки программы в микроконтроллер из ПЗУ (по последовательному каналу), ячейка RCEN должна быть перед этим запрограммирована с использованием параллельного режима. Подробно различные режимы программирования будут рассмотрены в главе 11.

При использовании внутреннего *RC*-генератора выводы XTAL1 и XTAL2 оставляют неподключенными (для микроконтроллера AT90S1200), а вывод PB3 может использоваться как обычный контакт ввода/вывода (для микроконтроллеров AT90S/LS2343).

# 4.3. Режимы пониженного энергопотребления

Все модели микроконтроллеров семейства Classic поддерживают два различных «спящих» режима: Idle и Power Down. Микроконтроллеры AT90S/LS4434 и AT90S/LS8535 дополнительно поддерживают третий режим — Power Save.

Переключение в один из режимов пониженного потребления осуществляется командой SLEEP. При этом флаг SE регистра управления MCUCR должен быть установлен в «1». Чтобы избежать непреднамеренного переключения микроконтроллера в «спящий» режим, рекомендуется устанавливать этот флаг непосредственно перед выполнением команды SLEEP. Выбор конкретного режима определяется состоянием флагов SM1 и SM0 для моделей AT90S/LS4434 и AT90S/LS8535 или флага SM для всех остальных моделей. Эти флаги также расположены в регистре MCUCR. Соответствие между содержимым этих флагов и режимом приведено в Табл. 4.2.

|     | /LS4434<br>/LS8535 | Прочие | Режим           |
|-----|--------------------|--------|-----------------|
| SM1 | SM0                | SM     |                 |
| 0   | 0                  | 0      | Idle            |
| 0   | 1                  | _      | Зарезервировано |
| 1   | 0                  | 1      | Power Down      |
| 1   | 1                  | _      | Power Save      |

Таблица 4.2. Выбор режима пониженного энергопотребления

Выход из «спящего режима может быть осуществлен:

- В результате прерывания. При этом микроконтроллер переходит в рабочий режим, выполняет подпрограмму обработки прерывания, и выполнение программы возобновляется с инструкции, следующей за командой SLEEP. Содержимое РОН, ОЗУ и РВВ при этом не изменяется.
- 2. В результате сброса. При этом микроконтроллер переходит в рабочий режим, и выполнение программы начинается с адреса вектора сброса (\$000). Более подробно процесс сброса будет рассмотрен в разделе 4.4.

#### 4.3.1. **Pewum Idle**

В этом режиме прекращает работу ЦПУ микроконтроллера, а все остальные периферийные устройства (SPI, UART, таймеры/счетчики, аналоговый компаратор, АЦП, сторожевой таймер), а также подсистема прерываний продолжают функционировать. За счет этого выход из режима Idle возможен как по внешнему прерыванию, так и по внутреннему, например при переполнении таймера. Для еще большего уменьшения энергопотребления в режиме Idle рекомендуется отключать встроенный аналоговый компаратор, если не требуется выход из «спящего» режима по прерыванию от компаратора. Аналоговый компаратор отключается установкой в «1» флага ACD регистра ACSR. Подробно этот регистр будет рассмотрен в главе 7.

Основным преимуществом режима Idle является быстрая реакция на события, приводящие к «пробуждению» микроконтроллера. Другими словами, выполнение программы начинается сразу же после перехода из режима Idle в рабочий режим.

#### 4.3.2. Pewum Power Down

В режиме Power Down функционирование всех систем микроконтроллера, включая тактовый генератор, прекращается. Единственными узлами, продолжающими работать в этом режиме, являются сторожевой таймер (если он включен) и подсистема обработки внешних прерываний. Соответственно выход из режима Power Down возможен только при возникновении одного из трех событий:

- внешний (аппаратный) сброс;
- сброс от сторожевого таймера (при наступлении тайм-аута сторожевого таймера);
- возникновение внешнего прерывания (для AT90S90C8534 по фронту, для остальных моделей по уровню).

Следует заметить, что при нахождении микроконтроллера в режиме Power Down прерывание может быть сгенерировано только в результате установки НИЗКОГО уровня на входах внешних прерываний либо в результате изменения уровня на этих входах (для AT90S/LS2333 и AT90S/LS4433). Сказанное справедливо для всех моделей микроконтроллеров за исключением модели AT90C8534. В этой модели генерация внешних прерываний всегда происходит только по фронту сигнала на входе внешнего прерывания.

Для выхода микроконтроллера из режима Power Down по внешнему прерыванию длительность активного сигнала должна удовлетворять следующим условиям:

- AT90S1200, AT90S2313, AT90S/LS4434, AT90S/LS8535, AT90S4414 и AT90S8515: длительность импульса НИЗКОГО уровня на входе внешнего прерывания должна превышать величину задержки сброса  $t_{\text{TOUT}}$  (см. раздел 4.4);
- остальные модели: длительность активного сигнала должна быть не меньше двух периодов сигнала тактового генератора сторожевого таймера (типовые значения:  $\geq 2$  мкс при  $V_{\rm CC}=5$  В и  $\geq 5.4$  мкс при  $V_{\rm CC}=3$  В). Для получения более полной информации по сторожевому таймеру обратитесь к главе 6.

Между наступлением события, приводящего к выходу микроконтроллера из режима Power Down, и началом работы микроконтроллера проходит некоторое время, в течение которого тактовый генератор микроконтроллера выходит на рабочий режим. По длительности эта задержка равна задержке сброса  $t_{TOUT}$  (см. раздел 4.4).

И, наконец, последнее замечание по поводу прерываний. Если сигнал, вызвавший «пробуждение» микроконтроллера, исчезнет раньше, чем микроконтроллер перейдет в рабочий режим, обработчик соответствующего прерывания вызван не будет.

#### 4.3.3. Pewum Power Save

Этот режим присутствует только в моделях AT90S/LS4434 и AT90S/LS8535. Он идентичен режиму Power Down за одним исключением: если таймер/счетчик T2 сконфигурирован для работы в асинхронном режиме (флаг AS2 регистра ASSR установлен в «1»), то он может продолжать работать в режиме Power Save. Таким образом, выход из режима Power Save возможен не только в результате событий, рассмотренных в предыдущем параграфе (аппаратный сброс, сброс от сторожевого таймера, внешнее прерывание), но также и по прерываниям от таймера/счетчика T2 — при

переполнении таймера/счетчика (Timer Overflow Interrupt) и при равенстве содержимого счетчика и регистра сравнения (Output Compare Interrupt). Разумеется, для этого указанные прерывания должны быть разрешены (соответствующие разряды регистра TIMSK так же, как и флаг общего разрешения прерываний I регистра SREG, должны быть установлены в «1»).

Вообще при возникновении прерывания от таймера/счетчика Т2 микроконтроллер выйдет из режима Power Save независимо от состояния флага I. Однако если этот флаг сброшен в «0» (все прерывания запрещены), обработчик соответствующего прерывания вызван не будет.

При выходе микроконтроллера из режима Power Save по прерыванию между началом работы микроконтроллера и установкой флага соответствующего прерывания проходит некоторое время. Длительность этой задержки зависит от прерывания, вызвавшего «пробуждение» микроконтроллера, и составляет 2 машинных цикла для внешнего прерывания и 3 машинных цикла для прерывания от асинхронного таймера. Во время этих циклов микроконтроллер выполняет команды, однако запуск подпрограмм обработки прерываний происходит только после окончания этих циклов.

# 4.4. Сброс

Сброс микроконтроллера (другое название — реинициализация), переводит микроконтроллер в определенное устойчивое состояние. Сброс может быть вызван следующими событиями:

- подача напряжения питания микроконтроллера;
- падение напряжения питания ниже заданной величины (только для AT90S/LS2333 и AT90S/LS4433);
- тайм-аут сторожевого таймера;
- подача напряжения НИЗКОГО уровня на вывод  $\overline{\text{RESET}}$  .

При наступлении одного из перечисленных событий во все регистры ввода/вывода заносятся их начальные значения (см. описания конкретных регистров), а в счетчик команд загружается значение \$000 (адрес вектора сброса). Если в программе используются какие-либо прерывания, то по этому адресу должна находиться команда относительного перехода RJMP на начало программы (к ее инициализационной части). Если же прерывания в программе не используются, то программа может начинаться непосредственно с адреса \$000.

Необходимо сразу же сказать, что разные модели микроконтроллеров семейства не только имеют различное число источников сброса, но также

предоставляют различные возможности по управлению самим процессом сброса. Однако логика работы схемы сброса одинакова для всех моделей.

При наступлении какого-либо из поддерживаемых событий формируется внутренний сигнал сброса ВЫСОКОГО уровня. В ряде моделей при этом устанавливаются флаги в регистре MCUSR, соответствующие этому событию. Одновременно запускается таймер формирования задержки сброса. По истечении определенного промежутка времени (предполагается, что за это время микроконтроллер перейдет в определенное устойчивое состояние) внутренний сигнал сброса переводится в НИЗКИЙ уровень. Структурные схемы подсистемы сброса будут приведены далее при обсуждении особенностей, присущих конкретным моделям.

# 4.4.1. Сброс по включении питания

При включении питания наибольшее внимание уделяется такому параметру, как время нарастания напряжения питания. Временем нарастания называется промежуток времени, за который используемое напряжение изменится от 0 до установившегося значения. Это время может быть различным в зависимости от типа источника питания (батарея, линейный стабилизатор, импульсный преобразователь и т.п.). Во избежание различных проблем, связанных со временем нарастания, все микроконтроллеры AVR семейства Classic имеют в своем составе схему сброса по включении питания (схема POR, Power-on Reset). Эта схема удерживает микроконтроллер в состоянии сброса до тех пор, пока напряжение питания не достигнет своего номинального значения и не станет стабильным.

При достижении напряжения питания порогового значения  $V_{\rm POT}$  начинает работать таймер задержки сброса. По окончании счета (после формирования задержки  $t_{\rm TOUT}$ ) внутренний сигнал сброса снимается и происходит запуск микроконтроллера.

Существует два способа управления состоянием вывода  $\overline{RESET}$ . В первом случае напряжение на выводе  $\overline{RESET}$  «повторяет» напряжение питания. Соответствующие данному способу временные диаграммы показаны на **Рис. 4.3**. Для реализации этого способа вывод  $\overline{RESET}$  можно либо подключить к источнику питания, либо оставить неподключенным, т.к. этот вывод уже подтянут к источнику питания внутренним резистором сопротивлением 100...500 кОм (это справедливо для всех моделей, кроме AT90C8534).

Однако использование этого способа таит в себе некоторую опасность. Речь идет о ситуации, когда время нарастания напряжения питания очень

велико и превышает длительность задержки  $t_{\rm TOUT}$ . В этом случае, как показано на **Puc. 4.4**, процесс запуска микроконтроллера может начаться до того, как напряжение питания достигнет своего номинального значения. В таких условиях надежный запуск микроконтроллера не гарантируется.



*Рис. 4.3.* Временные диаграммы сигналов при сбросе по включении питания; вывод  $\overline{\text{RESET}}$  подключен к  $V_{\text{DD}}$ 



 $Puc. \ 4.4. \$ Временные диаграммы сигналов при сбросе по включении питания; вывод  $\overline{\text{RESET}}$  подключен к  $V_{\text{DD}}$  (время нарастания напряжения питания очень велико)

Таким образом, данный способ должен использоваться только при условии, когда время нарастания напряжения источника питания известно и не превышает величины  $t_{\text{TOUT}}$  для конкретной схемы.

Второй способ управления состоянием вывода RESET является классическим: напряжение ВЫСОКОГО уровня подается на вывод только после установления напряжения питания. Временные диаграммы, соответствующие этому способу, показаны на **Рис. 4.5**.



Рис. 4.5. Временные диаграммы сигналов при сбросе по включении питания; вывод RESET управляется внешней схемой

В этом случае работой таймера задержки сброса управляет схема аппаратного сброса, о которой будет рассказано чуть позже. Соответственно этот таймер начинает работать при достижении напряжения на выводе  $\overline{\text{RESET}}$  порогового значения  $V_{\text{RST}}$ .

Данное решение является более дорогим, т.к. требует применения внешних компонентов. С другой стороны, при использовании этого способа время запуска устройства будет достаточно большим, что гарантирует надежный и корректный запуск микроконтроллера. Забегая несколько вперед, скажем, что в модели AT90C8534 можно использовать только такой способ управления выводом RESET для реализации сброса по питанию.

Для управления выводом RESET можно рекомендовать схему, представленную на **Puc. 4.6**. Разумеется, можно также использовать и специализированную схему слежения за напряжением питания, функционирующую подобным образом.

В предложенной схеме (**Puc. 4.6**) задержка между сигналами  $\overline{\text{RESET}}$  и  $V_{\text{DD}}$  определяется постоянной времени заряда конденсатора (*RC*). Сопротивление резистора *R* не превышает 40 кОм. Диод *VD* служит для быстро-



 $\it Puc.~4.6.~$ Вариант схемы сброса (задержка сигнала  $\,\overline{
m RESET}\,$  относительно  $\it V_{
m CC}$ )

го разряда конденсатора при отключении напряжения питания. Резистор  $R_1$  сопротивлением 100 Ом...1 кОм предназначен для ограничения входного тока вывола  $\overline{\text{RESET}}$ .

# 4.4.2. Аппаратный сброс

Аппаратный (или внешний) сброс микроконтроллера реализуется подачей на вывод  $\overline{\text{RESET}}$  напряжения НИЗКОГО уровня. Микроконтроллер остается в состоянии сброса до тех пор, пока на выводе  $\overline{\text{RESET}}$  будет присутствовать сигнал НИЗКОГО уровня. Длительность импульса сброса должна быть не менее 50 нс (100 нс для AT90C8534), в противном случае сброс микроконтроллера не гарантируется. При достижении напряжения на выводе  $\overline{\text{RESET}}$  порогового значения  $V_{\text{RST}}$  запускается таймер задержки сброса. По окончании счета (после формирования задержки  $t_{\text{ТООТ}}$ ) внутренний сигнал сброса снимается и происходит запуск микроконтроллера. Последовательность сигналов при аппаратном сбросе показана на **Рис. 4.7**.



Рис. 4.7. Временные диаграммы сигналов при аппаратном сбросе

Если вывод  $\overline{\text{RESET}}$  не предполагается использовать для аппаратного сброса, его можно оставить неподключенным.

# 4.4.3. Сброс от сторожевого таймера

По тайм-ауту сторожевого таймера (если он включен) генерируется короткий положительный импульс сброса, длительность которого равна одному периоду тактового сигнала микроконтроллера. По спадающему фронту этого импульса запускается таймер задержки сброса. По окончании счета (после формирования задержки  $t_{\rm TOUT}$ ) внутренний сигнал сброса снимается и происходит запуск микроконтроллера. Временные диаграммы, соответствующие

этому событию, показаны на **Рис. 4.8**. Для получения более подробной информации, касающейся работы сторожевого таймера, обратитесь к главе 6.



Рис. 4.8. Временные диаграммы сигналов при сбросе от сторожевого таймера

# 4.4.4. Сброс при снижении напряжения питания (Brown-Out)

Модели микроконтроллеров AT90S/LS2333 и AT90S/LS4433 имеют в своем составе схему BOD (Brown-Out Detection), которая отслеживает напряжение источника питания. Если эта схема включена, то при снижении напряжения питания ниже некоторого значения она переводит микроконтроллер в состояние сброса. Когда напряжение питания вновь увеличится до порогового значения, запускается таймер задержки сброса. После формирования задержки  $t_{\rm TOUT}$  внутренний сигнал сброса снимается и происходит запуск микроконтроллера. Временные диаграммы, соответствующие данному виду сброса, показаны на **Рис. 4.9**.

Работой схемы BOD управляет конфигурационная ячейка BODEN, расположенная в выделенной области FLASH-памяти. Для разрешения работы схемы в этой ячейке должен быть записан «0». Порог срабатывания ( $V_{\rm BOT}$ ) определяется состоянием конфигурационной ячейки BODLEVEL, которая расположена в той же области. Если в ней записана лог. «1», порог срабатывания равен 2.7 В. Если же в ней записан лог. «0» (после его программирования), порог срабатывания равен 4.0 В. Для уменьшения вероятности ложных срабатываний порог переключения схемы имеет гистерезис, равный 50 мВ.

Обратите внимание, что срабатывание схемы BOD произойдет только в том случае, если длительность нахождения напряжения питания ниже порога переключения превысит 3 мкс (для  $V_{\rm BOT} = 4.0$  В) или 7 мкс (для  $V_{\rm BOT} = 2.7$  В).



Puc. 4.9. Временные диаграммы сигналов при сбросе по снижении напряжения питания

# 4.4.5. Управление схемой сброса

В данном параграфе рассмотрены возможности микроконтроллеров семейства Classic по управлению схемой сброса. Все модели предоставляют различные возможности как по управлению процессом сброса, так и по его контролированию.

#### AT90S1200

Структурная схема подсистемы сброса микроконтроллера AT90S1200 приведена на **Рис. 4.10**. Как видно из рисунка, таймер задержки сброса работает от *RC*-генератора сторожевого таймера, независимого от основного тактового генератора микроконтроллера. Сразу отметим, что такое решение используется во всех моделях, кроме AT90C8534.



Рис. 4.10. Структурная схема подсистемы сброса микроконтроллера AT90S1200

Данный микроконтроллер не предоставляет пользователю никакой возможности по управлению процессом сброса. Длительность задержки сброса  $t_{\rm TOUT}$  фиксирована и равна  $16\pm5$  мс (16K периодов тактового генератора сторожевого таймера).

Максимальная величина порогового напряжения для вывода  $\overline{\text{RESET}}$   $V_{\text{RST}}$  составляет 0.85 $V_{\text{CC}}$ . Типовое значение пороговой величины напряжения питания  $V_{\text{POT}}$  составляет 1.2 В.

#### AT90S2313

Структурная схема подсистемы сброса микроконтроллера AT90S2313 приведена на **Рис. 4.11**.



Puc. 4.11. Структурная схема подсистемы сброса микроконтроллера AT90S2313

В этой модели величина  $t_{\rm TOUT}$  может принимать одно из двух значений. Длительность задержки сброса  $t_{\rm TOUT}$  определяется состоянием конфигурационной ячейки FSTRT, расположенной в выделенной области FLASH-памяти. Если эта ячейка установлена в «1» (не запрограммирована),  $t_{\rm TOUT}=16\pm 5$  мс (16К периодов тактового генератора сторожевого таймера). Если же она сброшена в «0» (запрограммирована),  $t_{\rm TOUT}=1.1\pm 0.1$  мс (1К периодов тактового генератора сторожевого таймера).

Максимальная величина порогового напряжения для вывода  $\overline{\text{RESET}}$   $V_{\text{RST}}$  составляет  $0.85V_{\text{CC}}$ . Типовое значение пороговой величины напряжения питания  $V_{\text{POT}}$  составляет 1.4~B.

#### AT90S/LS2323, AT90S/LS2343

Структурная схема подсистемы сброса микроконтроллеров AT90S/LS2323 и AT90S/LS2343 приведена на **Puc. 4.12**.



Рис. 4.12. Структурная схема подсистемы сброса микроконтроллеров AT90S/LS2323 и AT90S/LS2343

В моделях AT90S/LS2323 длительность задержки сброса  $t_{\rm TOUT}$  определяется состоянием конфигурационной ячейки FSTRT, а также зависит от напряжения питания микроконтроллера. Если эта ячейка установлена в «1» (не запрограммирована),  $t_{\rm TOUT}=16\pm 5$  мс и  $32\pm 10$ , соответственно для  $V_{\rm CC}=5.0$  и 3.0 В (только модели с индексом LS). Если же ячейка FSTRT сброшена в «0» (запрограммирована),  $t_{\rm TOUT}=1.1\pm 0.1$  и  $2.2\pm 0.2$  мс соответственно. А вот в моделях AT90S/LS2343 длительность задержки сброса  $t_{\rm TOUT}$  фиксирована и равна  $16\pm 5$  и  $32\pm 10$  мкс для  $V_{\rm CC}=5.0$  и 3.0 В соответственно.

Максимальная величина порогового напряжения для вывода  $\overline{\text{RESET}}$   $V_{\text{RST}}$  составляет  $0.6V_{\text{CC}}$ . Типовое значение пороговой величины напряжения питания  $V_{\text{POT}}$  составляет 1.4 В.

Микроконтроллеры AT90S/LS2323 и AT90S/LS2343 позволяют также определить событие, в результате которого произошел сброс устройства. Для этой цели они имеют в своем составе служебный регистр состояния микроконтроллера MCUSR, расположенный по адресу \$34 (\$54). Содержимое этого регистра показано на **Puc. 4.13**.

Как видно из рисунка, в этом регистре задействовано всего два разряда, состояние которых зависит от события, вызвавшего сброс устройства.



Puc. 4.13. Регистр MCUSR

Флаг PORF (Power-on Reset Flag, 0-й разряд) устанавливается в «1» в результате сброса по питанию. При всех остальных событиях, вызывающих сброс микроконтроллера, состояние этого флага не меняется. А флаг EXTRF (External Reset Flag, 1-й разряд) устанавливается в «1» после аппаратного сброса. После сброса от сторожевого таймера состояние этого флага не меняется, а после сброса по питанию его состояние не определено.

Чтобы определить с помощью этих флагов источник сброса, в программе необходимо как можно раньше сбросить оба разряда регистра. При очистке этих разрядов до наступления сброса микроконтроллера источник сброса можно определить согласно **Табл. 4.3**.

| тиолици 4.5. Определение и | сточника сороса |                              |
|----------------------------|-----------------|------------------------------|
| PORF                       | EXTRF           | Источник сброса              |
| 0                          | 0               | Сброс от сторожевого таймера |
| 0                          | 1               | Аппаратный сброс             |
| 1                          | 0               | Сброс по питанию             |
| 1                          | 1               | Сброс по питанию             |

Таблица 4.3. Определение источника сброса

# AT90S/LS2333, AT90S/LS4433

Структурная схема подсистемы сброса микроконтроллеров AT90S/LS2333 и AT90S/LS4433 приведена на **Puc. 4.14**.

В этих моделях микроконтроллеров длительность задержки сброса  $t_{\rm TOUT}$  определяется состоянием конфигурационных разрядов CKSEL2...CKSEL0, а также зависит от напряжения питания микроконтроллера. Зависимость задержки от состояния этих разрядов приведена в **Табл. 4.4**. По умолчанию состояние этих разрядов равно «010».

Максимальная величина порогового напряжения для вывода  $\overline{\text{RESET}}$   $V_{\text{RST}}$  составляет  $0.6V_{\text{CC}}$ . Типовое значение пороговой величины напряжения питания  $V_{\text{POT}}$  составляет 1.4~B.

Микроконтроллеры AT90S/LS233 и AT90S/LS4433 предоставляют наибольшие возможности по определению события, в результате которого произошел сброс устройства. Как и в других моделях, для этого используется регистр состояния микроконтроллера MCUSR, расположенный по адресу \$34 (\$54). Содержимое этого регистра показано на **Рис. 4.15**.



Puc. 4.14. Структурная схема подсистемы сброса микроконтроллеров AT90S/LS2333 и AT90S/LS4433

 $\it Taблица~4.4.$  Определение задержки сброса  $\it t_{TOUT}$  в моделях AT90S/LS2333 и AT90S/LS4433

| CKSEL[2:0] | 2:0]                             |                              | Применение                                                           |
|------------|----------------------------------|------------------------------|----------------------------------------------------------------------|
| CKSEL[2:0] | $V_{\rm CC} = 2.7 \; \mathrm{B}$ | $V_{\rm CC} = 5.0 \text{ B}$ | Применение                                                           |
| 000        | 16 мс + 6 СК                     | 4 mc + 6 CK                  | Внешний тактовый сигнал, большое время нарастания напряжения питания |
| 001        | 6 CK                             | 6 CK                         | Внешний тактовый сигнал, схема ВОО включена                          |
| 010        | 256 мс + 16K СК                  | 64 мс + 16K СК               | Кварцевый резонатор                                                  |
| 011        | 16 мс + 16K СК                   | 4 мс + 16K CK                | Кварцевый резонатор, малое время нарастания напряжения питания       |
| 100        | 16K CK                           | 16K CK                       | Кварцевый резонатор, схема ВОД включена                              |
| 101        | 256 мс + 1К СК                   | 64 мс + 1К СК                | Керамический резонатор                                               |
| 110        | 16 мс + 1К СК                    | 4 мс + 1K CK                 | Керамический резонатор, малое время нарастания напряжения питания    |
| 111        | 1K CK                            | 1K CK                        | Керамический резонатор, схема ВОД включена                           |

#### Примечание:

СК — 1 период тактового сигнала микроконтроллера.

Как видно из рисунка, в этом регистре задействовано четыре разряда, состояние которых зависит от события, вызвавшего сброс устройства. Описание этих разрядов приведено в **Табл. 4.5**.

|                     | 7 | 6 | 5 | 4 | 3    | 2     | 1       | 0    |
|---------------------|---|---|---|---|------|-------|---------|------|
|                     | _ | _ | - | _ | WDRF | BORF  | EXTRF   | PORF |
| Чтение(R)/Запись(W) | R | R | R | R | R/W  | R/W   | R/W     | R/W  |
| Начальное значение  | 0 | 0 | 0 | 0 |      | См. о | писание |      |

Puc. 4.15. Регистр MCUSR моделей AT90S/LS2333 и AT90S/LS4433

Таблица 4.5. Описание регистра MCUSR моделей AT90S/LS2333 и AT90S/LS4433

| Разряд | Название | Описание                                                                                                                                                                                                                               |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 74     | _        | Не используются, читаются как «0»                                                                                                                                                                                                      |
| 3      | WDRF     | Флаг сброса от сторожевого таймера. Устанавливается в «1», если источником сброса был сторожевой таймер. Разряд сбрасывается в результате сброса МК по питанию или непосредственной записью в него лог. «0»                            |
| 2      | BORF     | Флаг сброса по снижении питания. Устанавливается в «1», если источником сброса была подсистема ВОD. Разряд сбрасывается в результате сброса МК по питанию или непосредственной записью в него лог. «0»                                 |
| 1      | EXTRF    | Флаг аппаратного сброса. Устанавливается в «1», если сброс произошел в результате подачи на вывод сброса напряжения НИЗКОГО уровня. Разряд сбрасывается в результате сброса МК по питанию или непосредственной записью в него лог. «0» |
| 0      | PORF     | Флаг сброса по включении питания. Устанавливается в «1» после подачи напряжения питания на микроконтроллер. Разряд сбрасывается только непосредственной записью в него лог. «0»                                                        |

# AT90S/LS4434, AT90S/LS8535

Структурная схема подсистемы сброса микроконтроллеров AT90S/LS4434 и AT90S/LS8535 приведена на **Puc. 4.16**.

Параметры схемы сброса в этих микроконтроллерах такие же, как в моделях AT90S/LS2323 (см. выше). Причем это касается как управления таймером задержки сброса, так и использования регистра состояния MCUSR.

#### AT90S4414, AT90S8515

Структурная схема подсистемы сброса микроконтроллеров AT90S4414 и AT90S8515 приведена на **Рис. 4.17**.

Управление таймером задержки сброса в этих микроконтроллерах такое же, как в модели AT90S2313 (см. выше). Единственное отличие в подсистемах сброса — различные значения пороговых напряжений. В микроконтроллерах AT90S4414 и AT90S8515 максимальная величина порогового напряжения для вывода  $\overline{\text{RESET}}\ V_{\text{RST}}$  составляет  $0.9V_{\text{CC}}$ , а типовое значение пороговой величины напряжения питания  $V_{\text{POT}}$  составляет  $1.2\ \text{B}$ .



Рис. 4.16. Структурная схема подсистемы сброса микроконтроллеров AT90S/LS4434 и AT90S/LS8535



Рис. 4.17. Структурная схема подсистемы сброса микроконтроллеров AT90S4414 и AT90S8515

#### AT90C8534

Структурная схема подсистемы сброса микроконтроллера AT90C8534 приведена на **Рис. 4.18**.

В отличие от остальных моделей таймер задержки сброса микроконтроллера АТ90С8534 работает от тактового генератора микроконтроллера. Кроме того, этот микроконтроллер имеет всего один источник сброса, а



*Рис. 4.18.* Структурная схема подсистемы сброса микроконтроллера AT90C8534

именно — аппаратный сброс. В связи с этим для реализации других событий сброса (сброс при подаче питания и при понижении напряжения питания) необходимо использовать внешние схемы, которые будут управлять состоянием вывода RESET. Для реализации сброса при подаче напряжения питания можно, в частности, использовать схему, показанную на **Puc. 4.6**. При этом вывод RESET должен удерживаться в активном состоянии в течение 100 нс или больше после достижения напряжением питания минимального рабочего значения. Это же требование предъявляется и к внешней схеме BOD.

Как и в случае микроконтроллера AT90S1200, в данной модели пользователю не предоставляется никакой возможности по управлению процессом сброса. Длительность задержки сброса  $t_{\rm TOUT}$  фиксирована и равна 1024 периодам тактового генератора микроконтроллера. Максимальная величина порогового напряжения для вывода  $\overline{\rm RESET}\ V_{\rm RST}$  составляет  $0.6V_{\rm CC}$ .

# 4.5. Прерывания

Прерывание прекращает нормальный ход программы для выполнения приоритетной задачи, определяемой внутренним или внешним событием микроконтроллера. При возникновении прерывания микроконтроллер сохраняет в стеке содержимое счетчика команд РС и загружает в него адрес соответствующего вектора прерывания. По этому адресу должна находиться команда относительного перехода к подпрограмме обработки прерывания. Кроме того, последней командой подпрограммы обработки прерывания должна быть команда RETI, которая обеспечивает возврат в основную программу и восстановление предварительно сохраненного счетчика команд.

Поскольку источниками прерываний являются различные периферийные устройства микроконтроллеров, количество прерываний (2...16) зависит от конкретной модели.

### 4.5.1. Таблица векторов прерываний

Микроконтроллеры AVR семейства Classic имеют многоуровневую систему приоритетных прерываний. Младшие адреса памяти программ начиная с адреса \$001 отведены под таблицу векторов прерывания. Каждому прерыванию соответствует свой адрес в этой таблице, и именно этот адрес загружается в счетчик команд при возникновении прерывания. Положение вектора в таблице определяет также и приоритет соответствующего прерывания: чем меньше адрес, тем выше приоритет прерывания. Размер таблицы зависит от модели микроконтроллера и составляет от 2 (адреса \$001, \$002) до 16 (адреса \$001...\$010) векторов. Распределение таблицы векторов прерываний для всех микроконтроллеров семейства приведено в Табл. 4.6.

Таблица 4.6. Таблица векторов прерываний

| Источник        | Описание                            |   | AT90S1200 |   | AT90S2313 | AT90S/LS2323 | AT90S/LS2343 | AT90S/LS2333 | AT90S/LS4433 | AT90S/1.S4434 | AT90S/LS8535 | AT90S4414 | AT90S8515 |   | AT90C8534 |
|-----------------|-------------------------------------|---|-----------|---|-----------|--------------|--------------|--------------|--------------|---------------|--------------|-----------|-----------|---|-----------|
|                 |                                     | № | Адр.      | № | Адр.      | №            | Адр.         | №            | Адр.         | №             | Адр.         | №         | Адр.      | № | Адр.      |
| INT0            | Внешнее<br>прерывание 0             | 1 | \$001     | 1 | \$001     | 1            | \$001        | 1            | \$001        | 1             | \$001        | 1         | \$001     | 1 | \$001     |
| INT1            | Внешнее прерывание 1                |   |           | 2 | \$002     |              |              | 2            | \$002        | 2             | \$002        | 2         | \$002     | 2 | \$002     |
| TIMER2<br>COMP  | Совпадение<br>таймера/счетчика Т2   |   |           |   |           |              |              |              |              | 3             | \$003        |           |           |   |           |
| TIMER2 OVF      | Переполнение таймера/счетчика Т2    |   |           |   |           |              |              |              |              | 4             | \$004        |           |           |   |           |
| TIMER1<br>CAPT  | Захват<br>таймера/счетчика Т1       |   |           | 3 | \$003     |              |              | 3            | \$003        | 5             | \$005        | 3         | \$003     |   |           |
| TIMER1<br>COMP  | Совпадение<br>таймера/счетчика Т1   |   |           | 4 | \$004     |              |              | 4            | \$004        |               |              |           |           |   |           |
| TIMER1<br>COMPA | Совпадение «А» таймера/счетчика Т1  |   |           |   |           |              |              |              |              | 6             | \$006        | 4         | \$004     |   |           |
| TIMER1<br>COMPB | Совпадение «В» таймера/счетчика Т1  |   |           |   |           |              |              |              |              | 7             | \$007        | 5         | \$005     |   |           |
| TIMER1<br>OVF   | Переполнение<br>таймера/счетчика Т1 |   |           | 5 | \$005     |              |              | 5            | \$005        | 8             | \$008        | 6         | \$006     | 3 | \$003     |
| TIMER0<br>OVF   | Переполнение<br>таймера/счетчика Т0 | 2 | \$002     | 6 | \$006     | 2            | \$002        | 6            | \$006        | 9             | \$009        | 7         | \$007     | 4 | \$004     |
| SPI, STC        | Передача по SPI завершена           |   |           |   |           |              |              | 7            | \$007        | 10            | \$00A        | 8         | \$008     |   |           |

Таблица 4.6 (окончание)

| Источник      | Описание                        | AT90S1200 |       | AT90S2313 |       | AT90S/LS2323<br>AT90S/LS2343 |      | AT90S/LS2333<br>AT90S/LS4433 |       | AT90S/1.S4434 | AT90S/LS8535 | AT90S4414<br>AT90S8515 |       | AT90C8534 |       |
|---------------|---------------------------------|-----------|-------|-----------|-------|------------------------------|------|------------------------------|-------|---------------|--------------|------------------------|-------|-----------|-------|
|               |                                 | №         | Адр.  | №         | Адр.  | №                            | Адр. | №                            | Адр.  | №             | Адр.         | №                      | Адр.  | №         | Адр.  |
| UART,<br>RX   | UART, прием<br>завершен         |           |       | 7         | \$007 |                              |      | 8                            | \$008 | 11            | \$00B        | 9                      | \$009 |           |       |
| UART,<br>UDRE | Регистр данных<br>UART пуст     |           |       | 8         | \$008 |                              |      | 9                            | \$009 | 12            | \$00C        | 10                     | \$00A |           |       |
| UART,<br>TX   | UART, передача<br>завершена     |           |       | 9         | \$009 |                              |      | 10                           | \$00A | 13            | \$00D        | 11                     | \$00B |           |       |
| ADC           | Преобразование<br>АЦП завершено |           |       |           |       |                              |      | 11                           | \$00B | 14            | \$00E        |                        |       | 5         | \$005 |
| EE_RDY        | EEPROM, готово                  |           |       |           |       |                              |      | 12                           | \$00C | 15            | \$00F        |                        |       | 6         | \$006 |
| ANA_COMP      | Аналоговый компаратор           | 3         | \$003 | 10        | \$00A |                              |      | 13                           | \$00D | 16            | \$010        | 12                     | \$00C |           |       |

Если в программе прерывания никогда не используются, то на месте таблицы векторов прерываний может быть размещена основная программа.

# 4.5.2. Обработка прерываний

Для разрешения прерываний флаг I регистра SREG должен быть установлен в «1». А разрешение или запрещение (маскирование) отдельных прерываний производится установкой или сбросом соответствующих разрядов регистров масок прерываний, рассматриваемых ниже.

Обработка прерываний осуществляется следующим образом:

- при выполнении условий, необходимых для генерации прерывания, соответствующий этому прерыванию флаг устанавливается в «1», а флаг I аппаратно сбрасывается, запрещая тем самым обработку следующих прерываний. Однако в подпрограмме обработки прерывания этот флаг можно будет установить в «1» для разрешения вложенных прерываний;
- если прерывание разрешено (флаг разрешения прерывания установлен), в счетчик команд загружается адрес вектора соответствующего прерывания (\$002...\$010). При этом флаг прерывания аппаратно сбрасывается. Ряд флагов прерываний может быть также сброшен записью лог. «1» в разряд регистра, соответствующий флагу. Если же прерывание запрещено (флаг разрешения прерывания сброшен), флаг прерывания остается в состоянии лог. «1» до разрешения прерывания (в этом случае он будет сброшен аппаратно), либо до программного сброса этого флага;

- выполняется подпрограмма обработки прерывания;
- выполняется команда возврата из прерывания RETI, при этом флаг I аппаратно устанавливается в «1», разрешая обработку последующих прерываний;
- центральный процессор автоматически восстанавливает содержимое счетчика команд. Затем основная программа продолжает свое выполнение с того места, где она была прервана.

При вызове подпрограмм обработки прерываний содержимое регистра состояния SREG не сохраняется. Поэтому пользователь должен самостоятельно запоминать содержимое этого регистра при входе в подпрограмму обработки прерывания (если это необходимо) и восстанавливать его значение перед вызовом команды RETI.

Следует помнить, что для прерываний, вызванных статическими событиями (например, для прерывания, генерируемого при равенстве содержимого счетного регистра и регистра сравнения таймера), флаг прерывания устанавливается только в момент возникновения события. Если флаг прерывания сброшен, а условия генерации прерывания присутствуют, флаг будет установлен только в момент возникновения следующего события.

С другой стороны, для внешних прерываний, генерируемых по уровню, флаги не предусмотрены, поэтому информация об этих прерываниях будет храниться до тех пор, пока присутствует событие, вызывающее прерывание.

Микроконтроллеры AVR семейства Classic поддерживают очередь прерываний. Она работает следующим образом: если условия генерации одного или более прерываний возникают в то время, когда флаг общего разрешения прерываний сброшен (все прерывания запрещены), соответствующие флаги устанавливаются в «1» и остаются в этом состоянии до установки флага общего разрешения прерываний. После разрешения прерываний выполняется их обработка в соответствии с приоритетом.

Время отклика для любого прерывания составляет 4 машинных цикла. В течение первых двух машинных циклов происходит сохранение счетчика команд в стеке, а в течение следующих двух циклов выполняется команда перехода к подпрограмме обработки прерывания. Причем если прерывание произойдет во время выполнения команды, длящейся несколько циклов, то генерация прерывания произойдет только после выполнения этой команды. Под временем отклика здесь понимается время, прошедшее от наступления события (от установки флага прерывания) до выполнения первой команды подпрограммы обработки прерывания.

Возврат в основную программу также занимает 4 машинных цикла. После выхода из прерывания процессор всегда выполняет одну команду основной программы, прежде чем обслужить любое отложенное прерывание.

# 4.5.3. Внешние прерывания; регистры GIMSK и GIFR

Регистр GIMSK (General Interrupt Mask Register — общий регистр маски прерываний) предназначен для управления внешними прерываниями. Он расположен по адресу \$3B (\$5B). Содержимое этого регистра для различных моделей показано на **Рис. 4.19**, а описание его разрядов приведено в **Табл. 4.7**.

|                     | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0 | AT90S1200                    |
|---------------------|------|------|---|---|---|---|---|---|------------------------------|
|                     | 1    | INT0 | _ | - | ı | _ | - | - | AT90S/LS2323<br>AT90S/LS2343 |
| Чтение(R)/Запись(W) | R    | R/W  | R | R | R | R | R | R | - A1903/L32343               |
| Начальное значение  | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0 |                              |
|                     | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0 | _                            |
|                     | INT1 | INT0 | _ | _ | - | _ | _ | _ | Прочие                       |
| Чтение(R)/Запись(W) | R/W  | R/W  | R | R | R | R | R | R | •                            |
| Начальное значение  | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0 |                              |

Рис. 4.19. Общий регистр маски прерываний GIMSK

| Таблииа 4.7. | Обший | регистр | маски | прерываний | GIMSK |
|--------------|-------|---------|-------|------------|-------|
|              |       |         |       |            |       |

| Разряд | Название | Описание                                                                                                                                                                                                                                                                                                          | Модель                              |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
|        | _        | Не используется, читается как «0»                                                                                                                                                                                                                                                                                 | AT90S1200<br>AT90S2323<br>AT90S2343 |
| 7      | INT1     | Флаг разрешения внешнего прерывания INT1. Если в этом разряде записана лог. «1» и флаг I регистра SREG также установлен в «1», то разрешаются внешние прерывания с вывода INT1. Условия генерации прерывания определяются содержимым разрядов ISC11 и ISC10 (ISC1 для AT90C8534) регистра MCUCR (см. п. 2.2.2.3)  | Прочие                              |
| 6      | INT0     | Флаг разрешения внешнего прерывания INT0. Если в этом разряде записана лог. «1» и флаг I регистра SREG также установлен в «1», то разрешаются внешние прерывания с вывода INT01. Условия генерации прерывания определяются содержимым разрядов ISC01 и ISC00 (ISC0 для AT90C8534) регистра MCUCR (см. п. 2.2.2.3) | Все модели                          |
| 50     | _        | Не используются, читаются как «0»                                                                                                                                                                                                                                                                                 | Все модели                          |

Соответственно регистр GIFR (General Interrupt Flag Register — общий регистр флагов прерываний) предназначен для индикации наступления внешних прерываний. Он расположен по адресу \$3A (\$5A). Содержимое этого регистра для различных моделей показано на **Рис. 4.20**, а описание его разрядов приведено в **Табл. 4.8**.

|                     | 7     | 6     | 5 | 4 | 3 | 2 | 1 | 0 |           |
|---------------------|-------|-------|---|---|---|---|---|---|-----------|
|                     | _     | INTF0 | _ | _ | _ | _ | _ | _ | AT90S2313 |
| Чтение(R)/Запись(W) | R     | R/W   | R | R | R | R | R | R |           |
| Начальное значение  | 0     | 0     | 0 | 0 | 0 | 0 | 0 | 0 |           |
|                     | 7     | 6     | 5 | 4 | 3 | 2 | 1 | 0 |           |
|                     | INTF1 | INTF0 | _ | _ | _ | _ | _ | _ | Прочие *  |
| Чтение(R)/Запись(W) | R/W   | R/W   | R | R | R | R | R | R |           |
| Начальное значение  | 0     | 0     | 0 | 0 | 0 | 0 | 0 | 0 |           |
|                     |       |       |   |   |   |   |   |   |           |

<sup>\*</sup> Кроме AT90S1200; в этой модели регистр GIFR отсутствует

Puc. 4.20. Общий регистр флагов прерываний GIFR

Таблица 4.8. Общий регистр флагов прерываний GIFR

| Разряд | Название | Описание                                                                                                                                                                                                                                                                  | Модель                 |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
|        | _        | Не используется, читается как «0»                                                                                                                                                                                                                                         | AT90S2323<br>AT90S2343 |
| 7      | INTF1    | Флаг внешнего прерывания INT1. Если в результате события на выводе INT1 сформировался запрос на внешнее прерывание, этот разряд устанавливается в «1». Флаг сбрасывается аппаратно при запуске подпрограммы обработки прерывания или программно — записью в него лог. «1» | Прочие                 |
| 6      | INTF0    | Флаг внешнего прерывания INT0. Если в результате события на выводе INT0 сформировался запрос на внешнее прерывание, этот разряд устанавливается в «1». Флаг сбрасывается аппаратно при запуске подпрограммы обработки прерывания или программно — записью в него лог. «1» | Все модели             |
| 50     | _        | Не используются, читаются как «0»                                                                                                                                                                                                                                         | Все модели             |

Что касается самих внешних прерываний, то здесь необходимо сделать три замечания:

- 1. Прерывания генерируются даже в том случае, когда выводы внешних прерываний сконфигурированы как выходы. Благодаря этой особенности можно генерировать программные прерывания.
- 2. В модели AT90S1200 пользователь не имеет непосредственного доступа к флагу прерывания. Если ожидается внешнее прерывание по фронту импульса, этот флаг можно сбросить следующим способом:
  - запретить внешние прерывания, очистив флаг INT0 в регистре GIMSK;
  - выбрать прерывание по уровню;
  - выбрать активный фронт прерывания;
  - повторно разрешить внешние прерывания, установив INT0 в GIMSK.

3. В модели AT90C8534 имеется один дополнительный регистр GIPR (General Interrupt Pin Register — регистр состояния входов внешних прерываний), расположенный по адресу \$10 (\$30). Два его разряда отражают состояние входов внешних прерываний INT1 и INT2. Содержимое этого регистра показано на Рис. 4.21, а описание его разрядов приведено в Табл. 4.9.

| _                   | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0 |
|---------------------|---|---|---|---|-------|-------|---|---|
|                     | - | _ | _ | _ | IPIN1 | IPIN0 | _ | _ |
| Чтение(R)/Запись(W) | R | R | R | R | R     | R     | R | R |
| Начальное значение  | 0 | 0 | 0 | 0 | Χ     | Χ     | 0 | 0 |

Puc. 4.21. Регистр состояния входов внешних прерываний GIPR

| ,      |          |                                                                                                                    |
|--------|----------|--------------------------------------------------------------------------------------------------------------------|
| Разряд | Название | Описание                                                                                                           |
| 74     | _        | Не используются, читаются как «0»                                                                                  |
| 3      | IPIN1    | Флаг состояния вывода INT1. При чтении этого разряда возвращается логический уровень, присутствующий на входе INT1 |
| 2      | IPIN0    | Флаг состояния вывода INT0. При чтении этого разряда возвращается логический уровень, присутствующий на входе INT0 |
| 1, 0   | _        | Не используются, читаются как «0»                                                                                  |

Таблица 4.9. Регистр состояния входов внешних прерываний GIPR

# 4.5.4. Прерывания от таймеров; регистры TIMSK и TIFR

Регистр TIMSK (Timer/Counter Interrupt Mask Register — регистр маски прерываний от таймеров/счетчиков) предназначен для управления прерываниями от таймеров. Он расположен по адресу \$39 (\$59). Содержимое этого регистра для различных моделей показано на **Рис. 4.22**, а описание его разрядов приведено в **Табл. 4.10**. Для разрешения какого-либо прерывания от таймера необходимо установить в «1» соответствующий разряд регистра TIMSK и, разумеется, флаг I регистра SREG.

Соответственно регистр TIFR (Timer/Counteer Interrupt Flag Register — регистр флагов прерываний от таймеров/счетчиков) предназначен для индикации наступления прерываний от таймеров. Он расположен по адресу \$38 (\$58). Содержимое этого регистра для различных моделей показано на **Рис. 4.23**, а описание его разрядов приведено в **Табл. 4.11**.

|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        | AT90S1200                    |
|-------------------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|------------------------------|
|                                           | _        | _        | _        | _        | _        | _        | TOIE0    | _        | AT90S/LS2323                 |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0   | R<br>0   | R<br>0   | R<br>0   | R<br>0   | R<br>0   | R/W<br>0 | R<br>0   | AT90S/LS2343                 |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        | AT90S2313                    |
|                                           | TOIE1    | OCIE1A   | _        | _        | TICIE1   | _        | TOIE0    | -        | AT90S/LS2333<br>AT90S/LS4433 |
| Чтение(R)/Запись(W)<br>Начальное значение | R/W<br>0 | R/W<br>0 | R<br>0   | R<br>0   | R/W<br>0 | R<br>0   | R/W<br>0 | R<br>0   | A1905/L54433                 |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |                              |
|                                           | OCIE2    | TOIE2    | TICIE1   | OCIE1A   | OCIE1B   | TOIE1    | -        | TOIE0    | AT90S/LS4434<br>AT90S/LS8535 |
| Чтение(R)/Запись(W)<br>Начальное значение | R/W<br>0 | R/W<br>0 | R/W<br>0 | R/W<br>0 | R/W<br>0 | R/W<br>0 | R<br>0   | R/W<br>0 |                              |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |                              |
|                                           | TOIE1    | OCIE1A   | OCIE1B   | _        | TICIE1   | _        | TOIE0    | _        | AT90S4414<br>AT90S8515       |
| Чтение(R)/Запись(W)<br>Начальное значение | R/W<br>0 | R/W<br>0 | R/W<br>0 | R<br>0   | R/W<br>0 | R<br>0   | R/W<br>0 | R<br>0   |                              |
|                                           | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |                              |
|                                           | _        | _        | _        | _        | _        | TOIE1    | _        | TOIE0    | AT90C8534                    |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0   | R<br>0   | R<br>0   | R<br>0   | R<br>0   | R/W<br>0 | R<br>0   | R/W<br>0 |                              |

*Рис. 4.22.* Регистр маски прерываний от таймеров/счетчиков TIMSK

*Таблица 4.10.* Регистр маски прерываний от таймеров/счетчиков TIMSK

| Разряд | Название                                                                                                                                                              | Описание                                                                                     | Модель                                                        |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| 7      | TOIE1                                                                                                                                                                 | Флаг разрешения прерывания по переполнению таймера /счетчика Т1                              | AT90S2313<br>AT90S2333<br>AT90S4433<br>AT90S4414<br>AT90S8515 |
|        | OCIE2                                                                                                                                                                 | AT90S4434<br>AT90S8535                                                                       |                                                               |
|        | _                                                                                                                                                                     | Не используется, читается как «0»                                                            | Прочие                                                        |
|        | OCIE1A                                                                                                                                                                | Флаг разрешения прерывания по событию «Compare Match A» («совпадение А») таймера/счетчика Т1 | AT90S2313<br>AT90S4414<br>AT90S8515                           |
| 6      | ОСІЕ1 Флаг разрешения прерывания по событию «Сотраге Match» («совпадение») таймера/счетчика Т1  ТОІЕ2 Флаг разрешения прерывания по переполнению таймера /счетчика Т2 |                                                                                              | AT90S2333<br>AT90S4433                                        |
|        |                                                                                                                                                                       |                                                                                              | AT90S4434<br>AT90S8535                                        |
|        | _                                                                                                                                                                     | Не используется, читается как «0»                                                            | Прочие                                                        |

Таблица 4.10 (окончание)

| Разряд | Название | Описание                                                                                     | Модель                                                        |
|--------|----------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------|
|        | OCIE1B   | Флаг разрешения прерывания по событию «Compare Match В» («совпадение В») таймера/счетчика Т1 | AT90S4414<br>AT90S8515                                        |
| 5      | TICIE1   | Флаг разрешения прерывания по событию «Input Capture» («захват») таймера/счетчика Т1         | AT90S4434<br>AT90S8535                                        |
|        | _        | Не используется, читается как «0»                                                            | Прочие                                                        |
| 4      | OCIE1A   | Флаг разрешения прерывания по событию «Compare Match A» («совпадение А») таймера/счетчика Т1 | AT90S4434<br>AT90S8535                                        |
|        | _        | Не используется, читается как «0»                                                            | Прочие                                                        |
| 3      | TICIE1   | Флаг разрешения прерывания по событию «Input Capture» («захват») таймера/счетчика Т1         | AT90S2313<br>AT90S2333<br>AT90S4433<br>AT90S4414<br>AT90S8515 |
|        | OCIE1B   | Флаг разрешения прерывания по событию «Compare Match В» («совпадение В») таймера/счетчика Т1 | AT90S4434<br>AT90S8535                                        |
|        | _        | Не используется, читается как «0»                                                            | Прочие                                                        |
| 2      | TOIE1    | Флаг разрешения прерывания по переполнению таймера /счетчика Т1                              | AT90S4434<br>AT90S8535<br>AT90C8534                           |
|        | _        | Не используется, читается как «0»                                                            | Прочие                                                        |
| 1      | _        | Не используется, читается как «0»                                                            | AT90S4434<br>AT90S8535<br>AT90C8534                           |
|        | TOIE0    | Флаг разрешения прерывания по переполнению таймера /счетчика T0                              | Прочие                                                        |
| 0      | TOIE0    | Флаг разрешения прерывания по переполнению таймера /счетчика T0                              | AT90S4434<br>AT90S8535<br>AT90C8534                           |
|        |          | Не используется, читается как «0»                                                            | Прочие                                                        |

Таблица 4.11. Регистр флагов прерываний от таймеров/счетчиков TIFR

| Разряд | Название | Описание                                                                                                                  | Модель                                                        |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| 7      | TOV1     | Флаг устанавливается в «1» при переполнении таймера /счетчика Т1                                                          | AT90S2313<br>AT90S2333<br>AT90S4433<br>AT90S4414<br>AT90S8515 |
|        | OCF2     | Флаг устанавливается в «1» при совпадении значения таймера/ счетчика Т2 с содержимым регистра ОСR2 (событие «совпадение») | AT90S4434<br>AT90S8535                                        |
|        | _        | Не используется, читается как «0»                                                                                         | Прочие                                                        |

Таблица 4.11 (окончание)

| Разряд | Название                                                                                                                          | Описание                                                                                                                    | Модель                                                        |  |  |  |  |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--|--|--|--|--|
|        | OCF1A                                                                                                                             | Флаг устанавливается в «1» при совпадении значения таймера/счетчика T1 с содержимым регистра OCR1A (событие «совпадение А») | AT90S2313<br>AT90S4414<br>AT90S8515                           |  |  |  |  |  |
| 6      | OCF1 Флаг устанавливается в «1» при совпадении значения таймера/счетчика Т1 с содержимым регистра OCR1 (событие «совпадение»)     |                                                                                                                             |                                                               |  |  |  |  |  |
|        | TOV2                                                                                                                              | Флаг устанавливается в «1» при переполнении таймера /счетчика Т2                                                            | AT90S4434<br>AT90S8535                                        |  |  |  |  |  |
|        | _                                                                                                                                 | Не используется, читается как «0»                                                                                           | Прочие                                                        |  |  |  |  |  |
|        | OCF1B                                                                                                                             | Флаг устанавливается в «1» при совпадении значения таймера/счетчика Т1 с содержимым регистра ОСR1В (событие «совпадение В») | AT90S4414<br>AT90S8515                                        |  |  |  |  |  |
| 5      | ICF1                                                                                                                              | Флаг устанавливается в «1» при загрузке содержимого таймера/счетчика Т1 в регистр ICR1 (событие «захват»)                   | AT90S4434<br>AT90S8535                                        |  |  |  |  |  |
|        | _                                                                                                                                 | Не используется, читается как «0»                                                                                           | Прочие                                                        |  |  |  |  |  |
| 4      | OCF1A                                                                                                                             | Флаг устанавливается в «1» при совпадении значения таймера/счетчика Т1 с содержимым регистра OCR1A (событие «совпадение А») | AT90S4434<br>AT90S8535                                        |  |  |  |  |  |
|        | _                                                                                                                                 | Не используется, читается как «0»                                                                                           | Прочие                                                        |  |  |  |  |  |
| 3      | ICF1                                                                                                                              | Флаг устанавливается в «1» при загрузке содержимого таймера/счетчика Т1 в регистр ICR1 (событие «захват»)                   | AT90S2313<br>AT90S2333<br>AT90S4433<br>AT90S4414<br>AT90S8515 |  |  |  |  |  |
|        | ОСF1В Флаг устанавливается в «1» при совпадении значения таймера/счетчика Т1 с содержимым регистра ОСR1В (событие «совпадение В») |                                                                                                                             |                                                               |  |  |  |  |  |
|        | _                                                                                                                                 | Не используется, читается как «0»                                                                                           | Прочие                                                        |  |  |  |  |  |
| 2      | TOV1                                                                                                                              | Флаг устанавливается в «1» при переполнении таймера /счетчика Т1                                                            | AT90S4434<br>AT90S8535<br>AT90C8534                           |  |  |  |  |  |
|        | _                                                                                                                                 | Не используется, читается как «0»                                                                                           | Прочие                                                        |  |  |  |  |  |
| 1      | _                                                                                                                                 | Не используется, читается как «0»                                                                                           | AT90S4434<br>AT90S8535<br>AT90C8534                           |  |  |  |  |  |
|        | TOV0                                                                                                                              | Флаг устанавливается в «1» при переполнении таймера /счетчика Т0                                                            | Прочие                                                        |  |  |  |  |  |
| 0      | ТОV0 Флаг устанавливается в «1» при переполнении таймера /счетчика Т0                                                             |                                                                                                                             |                                                               |  |  |  |  |  |
|        | _                                                                                                                                 | Не используется, читается как «0»                                                                                           | Прочие                                                        |  |  |  |  |  |

#### Примечание:

Каждый флаг этого регистра сбрасывается аппаратно при запуске подпрограммы обработки соответствующего прерывания или программно — записью в него лог. «1».

|                                           | 7        | 6        | 5      | 4      | 3        | 2      | 1        | 0      | AT90S1200                    |
|-------------------------------------------|----------|----------|--------|--------|----------|--------|----------|--------|------------------------------|
|                                           | _        | _        | _      | _      | _        | _      | TOV0     | _      | AT90S/LS2323                 |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0   | R<br>0   | R<br>0 | R<br>0 | R<br>0   | R<br>0 | R/W<br>0 | R<br>0 | AT90S/LS2343                 |
|                                           | 7        | 6        | 5      | 4      | 3        | 2      | 1        | 0      | AT90S2313                    |
|                                           | TOV1     | OCF1A    | _      | _      | ICF1     | _      | TOV0     | -      | AT90S/LS2333                 |
| Чтение(R)/Запись(W)<br>Начальное значение | R/W<br>0 | R/W<br>0 | R<br>0 | R<br>0 | R/W<br>0 | R<br>0 | R/W<br>0 | R<br>0 | AT90S/LS4433                 |
|                                           | 7        | 6        | 5      | 4      | 3        | 2      | 1        | 0      | 1                            |
|                                           | OCF2     | TOV2     | ICF1   | OCF1A  | OCF1B    | TOV1   | _        | TOV0   | AT90S/LS4434<br>AT90S/LS8535 |
| Чтение(R)/Запись(W)                       | R/W      | R/W      | R/W    | R/W    | R/W      | R/W    | R        | R/W    |                              |
| Начальное значение                        | 0        | 0        | 0      | 0      | 0        | 0      | 0        | 0      |                              |
|                                           | 7        | 6        | 5      | 4      | 3        | 2      | 1        | 0      |                              |
|                                           | TOV1     | OCF1A    | OCF1B  | _      | ICF1     | _      | TOV0     | -      | AT90S4414<br>AT90S8515       |
| Чтение(R)/Запись(W)                       | R/W      | R/W      | R/W    | R      | R/W      | R      | R/W      | R      |                              |
| Начальное значение                        | 0        | 0        | 0      | 0      | 0        | 0      | 0        | 0      |                              |
|                                           | 7        | 6        | 5      | 4      | 3        | 2      | 1        | 0      |                              |
|                                           | _        | _        | _      | _      | -        | TOV1   | _        | TOV0   | AT90C8534                    |
| Чтение(R)/Запись(W)                       | R        | R        | R      | R      | R        | R/W    | R        | R/W    |                              |
| Начальное значение                        | 0        | 0        | 0      | 0      | 0        | 0      | 0        | 0      |                              |

Рис. 4.23. Регистр флагов прерываний от таймеров/счетчиков TIFR

Для получения более подробной информации о функционировании таймеров и о событиях, вызываемых ими, обратитесь к главе 6.

# Глава 5. **Порты ввода/вывода**

# 5.1. Общие сведения

Как и любые другие микроконтроллеры, микроконтроллеры AVR семейства Classic имеют порты ввода/вывода. Каждый порт состоит из определенного числа выводов, через которые микроконтроллер может принимать или передавать цифровые сигналы. Конфигурирование каждой лини порта (задание направления передачи данных) может быть произведено программно в любой момент времени. Входные буферы портов построены по схеме триггера Шмитта. Для линий, сконфигурированных как входные, также имеется возможность подключения внутреннего подтягивающего резистора сопротивлением 35...120 кОм между входом и проводом питания  $V_{\rm DD}$ . Кроме того, если вывод (вход) с подключенным внутренним подтягивающим резистором подключить к общему проводу, он может служить источником тока.

Максимальная нагрузочная способность выходных буферов портов ввода/вывода при лог. «0» на выходе составляет 20 мА. Благодаря этому микроконтроллер может непосредственно управлять светодиодными индикаторами.

Количество доступных портов, или, если точнее, количество контактов ввода/вывода, является одним из основных параметров, влияющих на выбор конкретной модели микроконтроллера.

- АТ90S1200 имеет два порта ввода/вывода: В (8-разрядный) и D (7разрядный). Общее количество контактов ввода/вывода равно 15;
- AT90S2313 также имеет два порта ввода/вывода: В (8-разрядный) и D (7-разрядный). Общее количество контактов ввода/вывода равно 15;
- AT90S/LS2323 имеет один 3-разрядный порт ввода/вывода В;

- AT90S/LS2343 имеет один 5-разрядный порт ввода/вывода В;
- AT90S/LS2333, AT90S/LS4433 имеют по три порта ввода/вывода: В (6-разрядный), С (6-разрядный) и D (8-разрядный). Общее количество контактов ввода/вывода равно 20;
- AT90S/LS4434, AT90S/LS8535 имеют по четыре 8-разрядных порта ввода/вывода A, B, C и D. Общее количество контактов ввода/вывода равно 32;
- AT90S4414, AT90S8515 также имеют по четыре 8-разрядных порта ввода/вывода А, В, С и D. Общее количество контактов ввода/вывода в этих моделях равно 32;
- AT90C8534 имеет один 7-разрядный порт вывода A и два входа внешних прерываний. В данном микроконтроллере присутствует также и 6-разрядный аналоговый входной порт. Таким образом, общее количество контактов ввода/вывода в этой модели равно 15;

Во всех микроконтроллерах семейства, за исключением модели AT90C8534, большинство контактов ввода/вывода имеет дополнительные функции, поскольку эти выводы также используются периферийными устройствами микроконтроллера.

# 5.2. Обращение к портам ввода/вывода

Обращение к портам производится через регистры ввода/вывода, причем под каждый порт в адресном пространстве ввода/вывода зарезервировано по 3 адреса. По этим адресам размещаются три регистра: регистр данных порта PORTx, регистр направления данных DDRx и регистр выводов порта PINx. Разряды этих регистров имеют названия: Px7...Px0 — для регистров PORTx, DDx7...DDx0 — для регистров DDRx и PINx7...PINx0 — для регистров PINx. Действительные названия регистров (и их разрядов) получаются подстановкой названия порта вместо символа «х», соответственно для порта А регистры называются PORTA, DDRA, PINA, для порта В — PORTB, DDRB, PINB и т.д. Положение этих регистров в адресном пространстве ввода/вывода приведено в Табл. 5.1. При сбросе микроконтроллера регистры DDRx и PORTx очищаются, а все выводы портов после сброса устанавливаются в третье состояние.

| Порт | Название<br>регистра | Адрес       | AT90S1200 | AT90S2313              | AT90S/LS2323<br>AT90S/LS2343 | AT90S/LS2333<br>AT90S/LS4433 | AT90S/LS4434<br>AT90S/LS8535 | AT90S4414<br>AT90S8515 | AT90C8534 |
|------|----------------------|-------------|-----------|------------------------|------------------------------|------------------------------|------------------------------|------------------------|-----------|
| A    | PORTA                | \$1B (\$3B) |           |                        |                              |                              | <b>◊</b>                     | ♦                      | <b>◊</b>  |
|      | DDRA                 | \$1A (\$3A) |           |                        |                              |                              | <b>\(\rightarrow\)</b>       | <b>\lambda</b>         | <b>◊</b>  |
|      | PINA                 | \$19 (\$39) |           |                        |                              |                              | <b>◊</b>                     | <b>◊</b>               |           |
| В    | PORTB                | \$18 (\$38) | <b>◊</b>  | <b>\(\rightarrow\)</b> | <b>\lambda</b>               | <b>\lambda</b>               | <b>◊</b>                     | <b>◊</b>               |           |
|      | DDRB                 | \$17 (\$37) | <b>◊</b>  | <b>\(\rightarrow\)</b> | <b>\lambda</b>               | <b>\lambda</b>               | <b>\( \)</b>                 | <b>◊</b>               |           |
|      | PINB                 | \$16 (\$36) | <b>◊</b>  | <b>\(\rightarrow\)</b> | <b>\lambda</b>               | <b>\lambda</b>               | <b>◊</b>                     | <b>◊</b>               |           |
| С    | PORTC                | \$15 (\$38) |           |                        |                              | <b>\(\rightarrow\)</b>       | <b>◊</b>                     | <b>◊</b>               |           |
|      | DDRC                 | \$14 (\$37) |           |                        |                              | <b>◊</b>                     | <b>◊</b>                     | <b>◊</b>               |           |
|      | PINC                 | \$13 (\$36) |           |                        |                              | <b>◊</b>                     | <b>◊</b>                     | <b>◊</b>               |           |
| D    | PORTD                | \$12 (\$32) | <b>◊</b>  | <b>◊</b>               |                              | <b>◊</b>                     | <b>◊</b>                     | <b>◊</b>               |           |
|      | DDRD                 | \$11 (\$31) | <b>◊</b>  | <b>◊</b>               |                              | <b>\lambda</b>               | <b>◊</b>                     | <b>◊</b>               |           |
|      | PIND                 | \$10 (\$30) | <b>◊</b>  | <b>\lambda</b>         |                              | <b>\lambda</b>               | <b>◊</b>                     | <b>◊</b>               |           |

Таблица. 5.1. Регистры портов ввода/вывода

Следует заметить, что «регистры» PINх на самом деле регистрами не являются, по этим адресам осуществляется доступ к физическим значениям сигналов на выводах порта. Соответственно, они доступны только для чтения, тогда как регистры PORTх и DDRх доступны и для чтения, и для записи. А в микроконтроллере AT90C8534 регистр выводов порта вообще отсутствует, т.к. единственный порт этой модели является только портом вывода.

Порядковый номер вывода порта соответствует, разумеется, порядковому номеру разряда регистров этого порта. Поэтому если разрядность порта меньше восьми, в регистрах порта используется соответствующее число младших разрядов. Незадействованные старшие разряды регистров доступны только для чтения и всегда содержат «0».

Таким образом, запись в порт означает запись требуемого состояния для каждого вывода порта в соответствующий регистр данных порта PORTx. А чтение состояния порта выполняется чтением либо регистра данных порта PORTx, либо регистра выводов порта PINx. При чтении регистра выводов порта PINx происходит считывание логических уровней сигналов, присутствующих на выводах порта. А при чтении регистра данных порта PORTx происходит считывание данных, находящихся в регистре-защелке порта. Причем сказанное справедливо как для входных, так и для выходных контактов.

Предположим, что все выводы 8-разрядного порта A определены как выходы и требуется установить младшие 4 разряда в «1», а старшие 4 разряда — в «0». Это можно осуществить путем записи в этот порт соответствующего значения, как показано ниже. Необходимо только предварительно задать конфигурацию выводов этого порта.

```
LDI r0,$0F ;запись числа 0Fh в регистр r0

OUT $1B,r0 ;запись числа 0Fh в порт A (0..3=«1»,
;4..7=«0»)
```

Теперь предположим, что все выводы порта А определены как входы и требуется узнать их состояние. Это осуществляется следующим образом:

IN r0,\$1B; в регистре r0 - сигналы на выводах порта А

Приведенные примеры сознательно упрощены. Все выводы используются либо только как входы, либо только как выходы. Разумеет-



Рис. 5.1. Упрощенная схема одного канала порта ввода/вывода

ся, можно задать конфигурацию каждого вывода независимо от остальных, так что в одном порту будут находиться одновременно как входы, так и выходы. Подробно об этом будет рассказано в разделе 5.3.

Чтобы лучше понять, как функционируют порты ввода/вывода, на **Рис. 5.1** приведена структурная схема одного из каналов порта ввода/вывода, работающего только в качестве порта ввода/вывода общего назначения (не имеющего дополнительных функций). В то же время логические связи, показанные на **Рис. 5.1**, присутствуют во всех каналах любого порта ввода/вывода, поэтому данную схему можно считать упрощенной схемой любого канала ввода/вывода. Для сравнения на **Рис. 5.2** показана полная структурная схема 1-го канала порта D (вывод PD1) микроконтроллера AT90S4434, являющегося также выходом данных UART.



Рис. 5.2. Полная структурная схема канала PD1 микроконтроллера AT90S4434

# 5.3. Конфигурирование портов ввода/вывода

Как уже было отмечено, порты имеют всего две возможности по конфигурированию:

- задание направления передачи данных (вход или выход);
- подключение/отключение внутреннего подтягивающего резистора.

Направление передачи данных определяется содержимым регистра передачи данных DDRx. Если разряд DDxn этого регистра установлен в «1», соответствующий n-й вывод порта является выходом. Если же разряд DDxn этого регистра сброшен в «0», соответствующий вывод порта является входом.

А вот управление подтягивающим резистором осуществляется с помощью регистра данных порта PORTx. Если разряд Pxn регистра PORTx установлен в «1» и соответствующий вывод порта является входом, между этим выводом и проводом питания подключается подтягивающий резистор. Чтобы отключить подтягивающий резистор, необходимо либо сбросить соответствующий разряд регистра PORTx, либо сделать вывод порта выходом.

В Табл. 5.2 приведены все возможные конфигурации выводов портов ввода/вывода. Кроме того, рекомендуем еще раз обратить внимание на схему, представленную на Рис. 5.1.

| DDxn | Pxn | Функция вывода | Резистор    | Примечания                                                             |
|------|-----|----------------|-------------|------------------------------------------------------------------------|
| 0    | 0   | вход           | отключен    | Третье состояние (Hi-Z)                                                |
| 0    | 1   | вход           | 1 полключен | При подключении вывода к общему проводу<br>он является источником тока |
| 1    | 0   | выход          | отключен    | Выход установлен в «0»                                                 |
| 1    | 1   | выход          | отключен    | Выход установлен в «1»                                                 |

*Таблица. 5.2.* Влияние регистров DDRх и PORTх на конфигурацию выводов портов

#### Примечание:

n = 7...0 — номер вывода (разряд порта).

И в заключение небольшое замечание по поводу конфигурирования выводов портов. Если вывод используется каким-либо периферийным устройством микроконтроллера, то соответствующие этому выводу разряды регистров DDRх и PORTx, как правило, должны быть установлены в соответствии с дополнительной функцией вывода. Однако некоторые периферийные устройства при активизации самостоятельно переопределяют конфигурацию используемых выводов. Об этом будет упомянуто далее при описании конкретных периферийных устройств.

# глава 6. Таймеры

# 6.1. Общие сведения

Микроконтроллеры семействас Classic, в зависимости от модели, имеют в своем составе от одного до трех таймеров/счетчиков общего назначения (см. Табл. 6.1).

Таблица 6.1. Таймеры/счетчики реального времени

| Таймер/счетчик    | AT90S1200 | AT90S2313 | AT90S/LS2323<br>AT90S/LS2343 | AT90S/LS2333<br>AT90S/LS4433 | AT90S/LS4434<br>AT90S/LS8535 | AT90S4414<br>AT90S8515 | AT90C8534 |
|-------------------|-----------|-----------|------------------------------|------------------------------|------------------------------|------------------------|-----------|
| Таймер/счетчик Т0 | ♦         | <b>◊</b>  | ♦                            | <b>◊</b>                     | <b>\lambda</b>               | <b>\Q</b>              | <b>◊</b>  |
| Таймер/счетчик Т1 |           | <b>◊</b>  |                              | <b>◊</b>                     | <b>◊</b>                     | <b>◊</b>               | ◊         |
| Таймер/счетчик Т2 |           |           |                              |                              | <b>\lambda</b>               |                        |           |

Первый таймер (Т0, 8-разрядный), имеющийся во всех моделях, может использоваться только для отсчета и измерения временных интервалов или как счетчик внешних событий. При переполнении счетного регистра таймера генерируется запрос на прерывание. Два других таймера (16-разрядный Т1 и 8-разрядный Т2) вводят дополнительные по отношению к таймеру Т0 функции. Оба таймера могут генерировать запрос на прерывание не только при переполнении счетного регистра, но и при наступлении ряда других событий. Также оба таймера могут использоваться в качестве широтно-импульсных модуляторов. Таймер Т2, кроме того, может работать в асинхронном (относительно тактового сигнала микроконтроллера) режиме.

А вот для модели AT90C8534 сказанное не совсем справедливо. Дело в том, что оба таймера/счетчика этого микроконтроллера (8-разрядный T0

и 16-разрядный Т1) функционально идентичны и к тому же могут использоваться только для формирования временных интервалов.

В составе всех микроконтроллеров семейства имеется также сторожевой таймер, который является непременным атрибутом всех современных микроконтроллеров. Этот таймер используется для предотвращения зацикливания программы.

# 6.2. Назначение выводов таймеров/счетчиков

Каждый таймер/счетчик (кроме таймеров/счетчиков в AT90C8534) использует один или более выводов микроконтроллера. Как правило, эти выводы — линии портов ввода/вывода общего назначения, а функции, реализуемые этими выводами при работе совместно с таймерами/счетчиками, являются их альтернативными функциями.

Все выводы микроконтроллеров, относящиеся к таймерам/счетчикам общего назначения, сведены в **Табл. 6.2**. Также в этой таблице приводятся функции этих выводов.

| Название | AT90S1200 | AT90S2313 | AT90S/LS2323<br>AT90S/LS2343 | AT90S/LS2333<br>AT90S/LS4433 | AT90S/LS4434<br>AT90S/LS8535 | AT90S4414<br>AT90S8515 | Описание                         |
|----------|-----------|-----------|------------------------------|------------------------------|------------------------------|------------------------|----------------------------------|
| T0       | PD4       | PD4       | PB2                          | PD4                          | PB0                          | PB0                    | Вход внешнего сигнала таймера Т0 |
| T1       | _         | PD5       | _                            | PD5                          | PB1                          | PB1                    | Вход внешнего сигнала таймера Т1 |
| ICP      | _         | PD6       | _                            | PB0                          | PD6                          | ICP*                   | Вход захвата таймера Т1          |
| OC1      | _         | PB3       | _                            | PB1                          | _                            | _                      | Выход схемы сравнения таймера Т1 |
| OC1A     | _         | _         | _                            | _                            | PD5                          | PD5                    | То же                            |
| OC1B     | _         | _         | _                            | _                            | PD4                          | OC1B*                  | То же                            |
| OC2      | _         | _         | _                            | _                            | PD7                          | _                      | Выход схемы сравнения таймера Т2 |
| TOSC1    | _         | _         | _                            | _                            | PC6                          | _                      | Вход для подключения резонатора  |
| TOSC2    | _         | _         | _                            | _                            | PC7                          | _                      | Выход для подключения резонатора |

Таблица 6.2. Выводы, используемые таймерами/счетчиками общего назначения

Не забывайте о том, что при использовании альтернативных функций линий портов ввода/вывода необходимо, как правило, самостоятельно сконфигурировать эти выводы в соответствии с их функциональным назначением (вход/выход).

<sup>\*</sup> Выделенный вывод микроконтроллера (не линия порта ввода/вывода).

# 6.3. Таймер/счетчик Т0

Таймер/счетчик Т0 (8-разрядный) может использоваться для формирования временных интервалов или для подсчета числа внешних событий (кроме AT90C8534). Структурная схема таймера/счетчика Т0 приведена на Рис. 6.1. Как видно из рисунка, в его состав входят 2 регистра (регистр управления TCCR0 и счетный регистр TCNT0), а также блок управления таймером. Флаг переполнения счетного регистра таймера TOV0 находится в регистре флагов прерываний от таймеров TIFR. Разрешение и запрещение прерываний от таймера осуществляются установкой/сбросом флага TOIE0 регистра TIMSK.



Рис. 6.1. Структурная схема таймера/счетчика Т0

Счетный регистр таймера/счетчика TCNTO расположен по адресу \$32 (\$52) и доступен в любой момент времени как для чтения, так и для записи. При записи в регистр TCNT0 во время работы таймера счет будет продолжен в следующем за командой записи машинном цикле. После подачи напряжения питания в регистре TCNT0 находится нулевое значение.

При переходе таймера/счетчика из состояния «\$FF» в состояние «\$00» устанавливается флаг TOV0 регистра TIFR и генерируется запрос на прерывание. Разрешение прерывания осуществляется установкой в «1» разряда TOIE0 регистра TIMSK (разумеется, флаг общего разрешения прерываний I регистра SREG также должен быть установлен в «1»).

Таймер/счетчик Т0 может работать в двух режимах:

- 1. Режим таймера. В этом режиме на вход таймера/счетчика поступают импульсы тактового сигнала микроконтроллера (непосредственно или через предделитель);
- 2. Режим счетчика событий. В этом режиме инкремент содержимого счетного регистра производится по активному фронту сигнала на входе Т0 микроконтроллера. В модели AT90C8534 данный режим отсутствует.

Выбор режима работы (источника тактового сигнала), а также запуск и остановка таймера/счетчика осуществляются с помощью разрядов CS02...CS00 регистра управления таймером TCCR0 (Рис. 6.2), расположенного по адресу \$33 (\$53). Соответствие между состоянием этих разрядов и режимом работы таймера/счетчика приведено в Табл. 6.3. Остальные разряды регистра доступны только для чтения и содержат «0».

|                     | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0    |
|---------------------|---|---|---|---|---|------|------|------|
|                     | _ | _ | _ | _ | _ | CS02 | CS01 | CS00 |
| Чтение(R)/Запись(W) | R | R | R | R | R | R/W  | R/W  | R/W  |
| Начальное значение  | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 0    |

Puc. 6.2. Формат регистра TCCR0

Таблица 6.3. Выбор источника тактового сигнала для таймера/счетчика Т0

| CS02 | CS01 | CS00 | Источник тактового сигнала                                                  |
|------|------|------|-----------------------------------------------------------------------------|
| 0    | 0    | 0    | Таймер/счетчик остановлен                                                   |
| 0    | 0    | 1    | СК (тактовый сигнал микроконтроллера)                                       |
| 0    | 1    | 0    | CK/8                                                                        |
| 0    | 1    | 1    | CK/64                                                                       |
| 1    | 0    | 0    | CK/256                                                                      |
| 1    | 0    | 1    | CK/1024                                                                     |
| 1    | 1    | 0    | Вывод Т0, инкремент счетчика производится по спадающему фронту импульсов*   |
| 1    | 1    | 1    | Вывод Т0, инкремент счетчика производится по нарастающему фронту импульсов* |

<sup>\*</sup> В модели АТ90С8534 значения «110» и «111» разрядов CS02...CS00 зарезервированы (режим счета внешних событий отсутствует).

При использовании таймера/счетчика в режиме счета внешних событий необходимо помнить, что сигнал, присутствующий на выводе Т0, синхронизируется с частотой тактового генератора микроконтроллера (состояние вывода Т0 считывается по нарастающему фронту внутреннего тактового сигнала). Поэтому для обеспечения корректной работы таймера от

внешнего сигнала промежуток времени между соседними импульсами должен быть больше периода тактового сигнала микроконтроллера.

Обратите внимание, что инкремент содержимого счетного регистра таймера/счетчика при работе в режиме счета внешних событий производится даже в том случае, если вывод Т0 сконфигурирован как выход. Эта особенность дает пользователю возможность программно управлять процессом счета.

# 6.4. Таймер/счетчик Т1

Таймер/счетчик Т1 (16-разрядный) имеет гораздо больше функций, чем таймер/счетчик Т0 (во всех моделях, кроме АТ90С8534). Прежде всего, как и таймер/счетчик Т0, он может использоваться для формирования временных интервалов или для подсчета числа внешних событий. Во-вторых, таймер/счетчик Т1 может по внешнему сигналу сохранять свое текущее состояние в отдельном РВВ. В-третьих, он может выполнять определенные действия при равенстве содержимого счетного регистра заданному значению. И наконец, он может работать как широтно-импульсный модулятор. Причем генерация сигнала с ШИМ «вынесена» в отдельный режим работы таймера/счетчика, в котором недоступны остальные функции (кроме генерации прерываний). Режим генерации сигнала с ШИМ будем называть «режим ШИМ», а режим, в котором доступны остальные функции таймера/счетчика, — «режим таймера».

Существует три варианта рассматриваемого таймера/счетчика в зависимости от модели микроконтроллера. Структурные схемы всех трех вариантов приведены на **Рис. 6.3...6.5**.

Из рисунков видно, что в состав первого варианта таймера/счетчика входят три 16-разрядных регистра (счетный регистр TCNT1, регистр захвата ICR1 и регистр сравнения OCR1 или OCR1A), 16-разрядный компаратор, два 8-разрядных управляющих регистра TCCR1A и TCCR1B, а также блок управления таймером. Второй вариант отличается наличием дополнительного компаратора и регистра сравнения; регистры сравнения в этом варианте называются OCR1A и OCR1B. А в модели AT90C8534 таймер/счетчик T1 идентичен таймеру/счетчику T0 (только счетный регистр TCNT1 — 16-разрядный).

Все флаги состояния таймера/счетчика (переполнения, совпадения и захвата) находятся в регистре флагов прерываний от таймеров TIFR, а разрешение/запрещение прерываний от таймера осуществляется установкой/сбросом соответствующих флагов регистра TIMSK.



Примечание: Позиции разрядов регистров TIMSK и TIFR показаны условно

Puc. 6.3. Структурная схема таймера/счетчика T1 моделей AT90S2313, AT90S/LS2333 и AT90S/LS4433



Рис. 6.4. Структурная схема таймера/счетчика Т1 моделей AT90S/LS4434, AT90S/LS8535 и AT90S4414/8515



Рис. 6.5. Структурная схема таймера/счетчика Т1 модели АТ90С8534

Счетный регистр таймера/счетчика Т1 реализован как суммирующий (в режиме ШИМ — как суммирующий/вычитающий) счетчик и доступен в любой момент времени как для чтения, так и для записи. При записи в регистр TCNT1 во время работы таймера счет будет продолжен по следующему за операцией записи импульсу тактового сигнала таймера/счетчика. После подачи напряжения питания в регистре TCNT1 находится нулевое значение.

Физически регистр TCNT1 размещен в двух регистрах TCNT1H:TCNT1L, расположенных по адресам \$2D:\$2C (адреса в адресном пространстве ОЗУ, соответственно, \$4D:\$4C). Чтобы при обращении ЦПУ микроконтроллера к этим регистрам запись или чтение обоих байтов содержимого счетного регистра происходило одновременно, обращение производится с использованием специального 8-разрядного регистра ТЕМР (этот регистр используется только процессором и программно недоступен). Этот же регистр используется и при обращении к остальным 16-разрядным регистрам таймера/счетчика Т1: OCR1 (OCR1A и OCR1B) и ICR1. Прерывания на время обращения к любому из этих регистров должны быть запрещены.

Собственно запись и чтение регистра TCNT1 происходят следующим образом:

#### Запись в регистр TCNT1

При записи старшего байта значения в регистр TCNT1H он помещается в регистр TEMP. Далее, при записи младшего байта в регистр TCNT1L он объединяется с содержимым регистра TEMP и оба байта записываются в регистр TCNT1 одновременно. Из сказанного видно, что для выполнения полного цикла записи в 16-разрядный регистр первым должен быть загружен старший байт (регистр TCNT1H).

### Чтение регистра TCNT1

При чтении регистра TCNT1L (младший байт) содержимое регистра TCNT1H пересылается в регистр TEMP. А при последующем чтении регистра TCNT1H возвращается значение, сохраненное в регистре TEMP. Следовательно, для выполнения полной операции чтения 16-разрядного регистра первым должен быть прочитан младший байт (регистр TCNT1L).

Управление таймером/счетчиком T1 осуществляется с помощью двух регистров управления TCCR1A и TCCR1B (в модели AT90C8534 — с помощью одного регистра TCCR1). Эти регистры расположены по адресам \$2F (\$4F) (регистр TCCR1A) и \$2E (\$4E) (регистры TCCR1B, TCCR1).

Формат регистра TCCR1A приведен на **Puc. 6.6**, а регистров TCCR1B и TCCR1 — на **Puc. 6.7**. Значение отдельных разрядов этих регистров будет описано далее в этой главе. Неиспользуемые разряды регистров доступны только для чтения и содержат «0».

|                     | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     | _                            |
|---------------------|--------|--------|--------|--------|---|---|-------|-------|------------------------------|
|                     | COM1A1 | COM1A0 | _      | -      | _ | _ | PWM11 | PWM10 | AT90S2313                    |
| Чтение(R)/Запись(W) | R/W    | R/W    | R      | R      | R | R | R/W   | R/W   |                              |
| Начальное значение  | 0      | 0      | 0      | 0      | 0 | 0 | 0     | 0     |                              |
|                     | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     | _                            |
|                     | COM11  | COM10  | _      | _      | _ | _ | PWM11 | PWM10 | AT90S/LS2323<br>AT90S/LS2343 |
| Чтение(R)/Запись(W) | R/W    | R/W    | R      | R      | R | R | R/W   | R/W   |                              |
| Начальное значение  | 0      | 0      | 0      | 0      | 0 | 0 | 0     | 0     |                              |
|                     |        |        |        |        |   |   |       |       |                              |
|                     | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     | AT90S/LS4434                 |
|                     | COM1A1 | COM1A0 | COM1B1 | COM1B0 | _ | _ | PWM11 | PWM10 | AT90S/LS8535<br>AT90S4414    |
| Чтение(R)/Запись(W) | R/W    | R/W    | R/W    | R/W    | R | R | R/W   | R/W   | AT90S8515                    |
| Начальное значение  | 0      | 0      | 0      | 0      | 0 | 0 | 0     | 0     |                              |

Рис. 6.6. Формат регистра TCCR1A

|                     | 7     | 6     | 5 | 4 | 3    | 2    | 1    | 0    |
|---------------------|-------|-------|---|---|------|------|------|------|
|                     | ICNC1 | ICES1 | _ | _ | CTC1 | CS12 | CS11 | CS10 |
| Чтение(R)/Запись(W) | R/W   | R/W   | R | R | R/W  | R/W  | R/W  | R/W  |
| Начальное значение  | 0     | 0     | 0 | 0 | 0    | 0    | 0    | 0    |
|                     | 7     | 6     | 5 | 4 | 3    | 2    | 1    | 0    |
|                     | _     | -     | _ | _ | _    | CS12 | CS11 | CS10 |
| Чтение(R)/Запись(W) | R     | R     | R | R | R    | R/W  | R/W  | R/W  |
| Начальное значение  | 0     | 0     | 0 | 0 | 0    | U    | 0    | 0    |

Puc. 6.7. Формат регистров: а — TCCR1B; б — TCCR1

# 6.4.1. Выбор источника тактового сигнала

По отношению к тактовому сигналу таймер/счетчик T1 может работать в двух режимах:

- 1. Режим таймера. В этом режиме на вход таймера/счетчика поступают импульсы тактового сигнала микроконтроллера (непосредственно или через предделитель).
- 2. Режим счетчика событий. В этом режиме инкремент содержимого счетного регистра производится по активному фронту сигнала на входе Т1 микроконтроллера. В модели AT90C8534 данный режим отсутствует.

Выбор источника тактового сигнала, а также запуск и остановка таймера/счетчика осуществляются с помощью разрядов CS12...CS10 регистра управления таймером TCCR1B. Соответствие между состоянием этих разрядов и режимом работы таймера/счетчика приведено в **Табл. 6.4**.

| Регистр | Peгистр TCCR1B (TCCR1) |      | Источник тактового сигнала                                                  |  |  |  |  |  |
|---------|------------------------|------|-----------------------------------------------------------------------------|--|--|--|--|--|
| CS12    | CS11                   | CS10 | тсточник тактового сигнала                                                  |  |  |  |  |  |
| 0       | 0                      | 0    | Таймер/счетчик остановлен                                                   |  |  |  |  |  |
| 0       | 0                      | 1    | СК (тактовый сигнал микроконтроллера)                                       |  |  |  |  |  |
| 0       | 1                      | 0    | CK/8                                                                        |  |  |  |  |  |
| 0       | 1                      | 1    | CK/64                                                                       |  |  |  |  |  |
| 1       | 0                      | 0    | CK/256                                                                      |  |  |  |  |  |
| 1       | 0                      | 1    | CK/1024                                                                     |  |  |  |  |  |
| 1       | 1                      | 0    | Вывод Т1, инкремент счетчика производится по спадающему фронту импульсов*   |  |  |  |  |  |
| 1       | 1                      | 1    | Вывод Т1, инкремент счетчика производится по нарастающему фронту импульсов* |  |  |  |  |  |

*Таблица 6.4*. Выбор источника тактового сигнала для таймера/счетчика T1

<sup>\*</sup> В модели AT90C8534 значения «110» и «111» разрядов CS12...CS10 зарезервированы (режим счета внешних событий отсутствует).

При использовании внешнего тактового сигнала необходимо помнить, что он синхронизируется с частотой тактового генератора микроконтроллера (состояние вывода Т1 считывается по нарастающему фронту внутреннего тактового сигнала). Поэтому для обеспечения корректной работы таймера от внешнего сигнала промежуток времени между соседними импульсами должен быть больше периода тактового сигнала микроконтроллера.

Обратите внимание, что при использовании внешнего тактового сигнала инкремент содержимого счетного регистра таймера/счетчика производится даже в том случае, если вывод Т1 сконфигурирован как выход. Эта особенность дает пользователю возможность программно управлять процессом счета.

## 6.4.2. Режим таймера

Принцип работы таймера/счетчика Т1 в этом режиме такой же, как и таймера/счетчика Т0. По каждому импульсу, поступающему на тактовый вход таймера/счетчика, производится инкремент содержимого счетного регистра TCNT1. При переходе таймера/счетчика из состояния «\$FFFF» в состояние «\$0000» устанавливается флаг TOV1 регистра TIFR и генерируется запрос на прерывание. Разрешение прерывания осуществляется установкой в «1» разряда TOIE1 регистра TIMSK (разумеется, флаг общего разрешения прерываний I регистра SREG также должен быть установлен в «1»). Однако, как уже было сказано, для всех моделей, кроме AT90C8534, в этом режиме таймера/счетчика Т1 доступны и дополнительные функции.

# 6.4.2.1. Функция захвата (Capture)

Данная функция заключается в сохранении в определенный момент времени состояния таймера/счетчика в регистре захвата ICR1. Это действие может производиться либо по активному фронту сигнала на выводе ICP микроконтроллера, либо по сигналу от аналогового компаратора (см. описание аналогового компаратора в главе 7). При этом устанавливается флаг ICF1 регистра TIFR и генерируется запрос на прерывание. Разрешение прерывания осуществляется установкой в «1» разряда TICIE1 регистра TIMSK.

Упрощенная структурная схема узла, выполняющего данную функцию, приведена на **Рис. 6.8**.



Рис. 6.8. Структурная схема узла захвата

Для управления схемой захвата используются два разряда регистра TCCR1B: ICNC1 и ICES1. Разряд ICNC1 управляет схемой подавления помех. Если этот разряд сброшен в «0», схема подавления помех выключена и захват производится по первому же активному фронту на выводе ICP микроконтроллера. Если же этот разряд установлен в «1», то при появлении активного фронта на выводе ICP производится 4 выборки с частотой, равной тактовой частоте микроконтроллера. Захват будет выполнен только в том случае, если все выборки имеют уровень, соответствующий активному фронту сигнала (лог. «1» для нарастающего и лог. «0» для спадающего).

Активный фронт сигнала, т.е. фронт, по которому будет выполнено сохранение содержимого счетного регистра в регистре захвата, определяется состоянием разряда ICES1. Если этот разряд сброшен в «0», то активным является спадающий фронт. Если же этот разряд установлен в «1», то активным является нарастающий фронт. Разумеется, вывод ICP должен быть сконфигурирован как входной, т.е. разряд регистра управления портом DDRx, соответствующий данному выводу, должен быть сброшен в «0».

Физически регистр захвата ICR1 размещен в двух регистрах ICR1H:ICR1L, расположенных по адресам \$27:\$26 (адреса в адресном пространстве ОЗУ соответственно \$47:\$46) и доступных только для чтения. Поскольку регистр захвата является 16-разрядным, при его чтении, как уже было сказано, используется специальный временный регистр TEMP. При чтении регистра ICR1L (младший байт) содержимое этого регистра пересылается в ЦПУ, а содержимое регистра ICR1H (старший байт) сохраняется в регистре TEMP. При чтении регистра ICR1H возвращается значение, сохраненное в регистре TEMP. Следовательно, при чтении регистра ICR1 первым должен быть прочитан регистр ICR1L. Прерывания на время обращения к регистру ICR1 должны быть запрещены.

## 6.4.2.2. Функция сравнения (Compare)

Данная функция заключается в непрерывном (каждый машинный цикл) сравнении содержимого счетного регистра таймера/счетчика с числом, находящемся в регистре сравнения. При совпадении содержимого этих регистров устанавливается флаг соответствующего прерывания, а также могут выполняться другие действия.

Количество регистров сравнения, а также их названия отличаются в различных моделях микроконтроллеров (см. **Табл. 6.5**). Причем в моделях, имеющих по два регистра сравнения, операция сравнения производится независимо для каждого регистра.

| Модель                       | Регистр сравнения |        |  |  |  |  |
|------------------------------|-------------------|--------|--|--|--|--|
| тутодель                     | первый            | второй |  |  |  |  |
| AT90S2313                    | OCR1A             | _      |  |  |  |  |
| AT90S/LS2333<br>AT90S/LS4433 | OCR1              | _      |  |  |  |  |
| AT90S/LS4434<br>AT90S/LS8535 | OCR1A             | OCRIB  |  |  |  |  |
| AT90S4414/8515               | OCR1A             | OCR1B  |  |  |  |  |

*Таблица 6.5.* Регистры сравнения таймера/счетчика T1

Если состояние таймера/счетчика становится равным числу, находящемуся в регистре сравнения, то в следующем машинном цикле устанавливается соответствующий этому регистру флаг прерывания в регистре TIFR (для регистра OCR1 — флаг OCF1, для регистра OCR1A — флаг OCF1A, для регистра OCR1B — флаг OCF1B) и генерируется запрос на прерывание. Разрешение прерываний осуществляется установкой в «1» соответствующих флагов регистра TIMSK (OCIE1, OCIE1A и OCIE1B для регистров OCR1, OCR1A и OCR1B соответственно).

Наряду с установкой флага в регистре TIFR при равенстве счетного регистра и регистра сравнения могут выполняться и другие действия:

- сброс таймера/счетчика (только для регистров OCR1 и OCR1A);
- изменение состояния определенного вывода микроконтроллера (для всех регистров).

Поведение микроконтроллера, т.е. выполнение или невыполнение указанных действий, определяется несколькими разрядами регистров управления TCCR1A и TCCR1B. Названия этих разрядов и их описание приведены в **Табл. 6.6**.

*Таблица 6.6.* Управление работой схемы сравнения таймера/счетчика T1

| Регистр Название Модель Описание |      |                   |                                                                                            | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |                                                                       |  |  |
|----------------------------------|------|-------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------------------------------------------------------|--|--|
|                                  |      | COM1A1,<br>COM1A0 | AT90S2313<br>AT90S4434<br>AT90LS4434<br>AT90S8535<br>AT90LS8535<br>AT90S4414<br>AT90S8515  | Управление выводом OC1A (OC1)* микроконтроллера Состояние этих разрядов определяет поведение вывода ОС1А при совпадении содержимого счетного регистра и регистра сравн OCR1A (OCR1). При изменении состояния этих разрядов соотвеющее прерывание от компаратора таймера/счетчика рекомендует претить (во избежание ложной генерации прерывания).  Чтобы таймер/счетчик мог управлять этим выводом, он должен                                                                                                                                                      |           |                                                                       |  |  |
|                                  | 7, 6 |                   |                                                                                            | 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ие вывода | к выходной.<br>задается следующим образом:                            |  |  |
|                                  |      |                   | AT90S2333                                                                                  | (COM11)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           | Описание                                                              |  |  |
|                                  |      | COM11,<br>COM10   | AT90LS2333<br>AT90S4433<br>AT90LS4433                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0         | Таймер/счетчик Т1 отключен от вывода ОС1А (ОС1)                       |  |  |
| ١.                               |      |                   |                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1         | Состояние вывода меняется на противоположное                          |  |  |
| RIA                              |      |                   |                                                                                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0         | Вывод сбрасывается в «0»                                              |  |  |
| rccr1A                           |      |                   |                                                                                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1         | Вывод устанавливается в «1»                                           |  |  |
|                                  | 5, 4 | COM1B1,<br>COM1B0 | AT90S4434<br>AT90LS4434<br>AT90S8535<br>AT90LS8535<br>AT90LS8535<br>AT90S4414<br>AT90S8515 | Управление выводом ОС1В микроконтроллера Состояние этих разрядов определяет поведение вывода ОС1В при совпадении содержимого счетного регистра и регистра сравнения ОСR1В. При изменении состояния этих разрядов соответствующее прерывание от компаратора таймера/счетчика рекомендуется запретить (во избежание ложной генерации прерывания).  Чтобы таймер/счетчик мог управлять этим выводом, он должен быть сконфигурирован как выходной.  Поведение вывода задается следующим образом:  СОМ1В1 СОМ1В0 Описание  0 Паймер/счетчик Т1 отключен от вывода ОС1В |           |                                                                       |  |  |
|                                  |      |                   |                                                                                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0         | Состояние вывода меняется на противоположное Вывод сбрасывается в «0» |  |  |
|                                  |      |                   |                                                                                            | 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           | Вывод устанавливается в «1»                                           |  |  |
| TCCR1B                           | 3    | CTC1              | Bce                                                                                        | Сброс таймера/счетчика Если этот разряд установлен в «1», то при совпадении содержимого счетного регистра и регистра сравнения ОСR1A (ОСR1) производится сброс таймера/счетчика в состояние «\$0000»**                                                                                                                                                                                                                                                                                                                                                            |           |                                                                       |  |  |

<sup>\*</sup> Для AT90S2313, AT90S/LS2333 и AT90S/LS2343 — OC1, для AT90S/LS4434, AT90S/LS8535 и AT90S4414/8515 — OC1A.

$$... o C-2 o C-1 o C o 0 o 1 o ...$$
 а при коэффициенте деления, не равном 1:  $... o (C-2, ..., C-2) o (C-1, ..., C-1) o (C, 0, ..., 0) o ...,$  где  $C$  — число, находящееся в регистре сравнения.

<sup>\*\*</sup> Поскольку сброс выполняется в машинном цикле, следующем за тем, во время которого произошло совпадение, поведение таймера/счетчика зависит от установленного коэффициента деления предделителя таймера (см. Табл. 6.4). При коэффициенте деления, равном 1, состояние таймера/счетчика меняется следующим образом:

Каждый регистр сравнения физически размещается в двух регистрах ввода-вывода PBB:

OCR1 — OCR1H:OCR1L, адреса \$2B:\$2A (\$4B:\$4A);

OCR1A — OCR1AH:OCR1AL, адреса \$2B:\$2A (\$4B:\$4A);

OCR1B — OCR1BH:OCR1BL, адреса \$29:\$28 (\$49:\$48).

Поскольку регистры сравнения являются 16-разрядными, при их чтении и записи используется специальный временный регистр ТЕМР. Подробно процесс записи и чтения 16-разрядных регистров описан выше на примере регистра ТСNТ1. Здесь повторим только, что при записи регистра сравнения первым должен записываться регистр OCR1xH (старший байт), а при чтении первым должен считываться регистр OCR1xL (младший байт). Прерывания на время обращения к регистру сравнения должны быть запрещены.

#### 6.4.3. Режим ШИМ

В этом режиме таймер/счетчик Т1 представляет собой одинарный или сдвоенный, в зависимости от модели, широтно-импульсный модулятор. Широтно-импульсная модуляция является одним из видов непрерывной импульсной модуляции, при котором ширина импульса пропорциональна значению модулирующего сигнала. Соответственно в данном случае широтно-импульсная модуляция заключается в генерировании сигнала с программируемыми частотой и скважностью.

Для перевода таймера/счетчика Т1 в режим ШИМ и задания частоты ШИМ-сигнала используются разряды PWM11:PWM10 регистра управления таймером TCCR1A. Соответствие между состоянием этих разрядов и режимом работы таймера/счетчика Т1 приведено в **Табл. 6.7**.

| Регист | p TCCR1A | Описание                                  |
|--------|----------|-------------------------------------------|
| PWM11  | PWM10    | Описание                                  |
| 0      | 0        | Режим ШИМ таймера/счетчика Т1 выключен    |
| 0      | 1        | 8-разрядный широтно-импульсный модулятор  |
| 1      | 0        | 9-разрядный широтно-импульсный модулятор  |
| 1      | 1        | 10-разрядный широтно-импульсный модулятор |

*Таблица 6.7.* Управление режимом ШИМ таймера/счетчика T1

Для генерации сигнала с ШИМ используется схема сравнения таймера/счетчика, поэтому в моделях AT90S2313, AT90S/LS2333 и AT90S/LS4433 модулятор является одинарным (один регистр сравнения),

а в моделях AT90S/LS4434, AT90S/LS8535 и AT90S4414/8515 — сдвоенным (два регистра сравнения). Названия регистров сравнения, их адреса и правила обращения к ним были описаны в предыдущем параграфе. Соответственно сигнал снимается с выхода схемы сравнения таймера/счетчика.

В рассматриваемом режиме счетный регистр таймера/счетчика функционирует как реверсивный счетчик, модуль счета которого (ТОР) зависит от режима работы модулятора. Значение модуля счета и соответствующая частота ШИМ-сигнала для каждого режима работы модулятора приведены в Табл. 6.8.

Таблица 6.8. Модуль счета счетного регистра и частота ШИМ-сигнала

| Разрешение модулятора | Модуль счета (ТОР) | Частота ШИМ-сигнала    |  |  |
|-----------------------|--------------------|------------------------|--|--|
| 8 разрядов            | \$00FF (255)       | f <sub>TCK1</sub> /510 |  |  |
| 9 разрядов            | \$01FF (511)       | $f_{\rm TCK1}/1022$    |  |  |
| 10 разрядов           | \$03FF (1023)      | $f_{\rm TCK1}/2046$    |  |  |

#### Примечание:

 $f_{
m TCK1}$  — частота тактового сигнала таймера/счетчика Т1.

При работе таймера/счетчика Т1 в режиме ШИМ состояние счетного регистра изменяется от \$000 до значения ТОР, а затем снова до \$000, после чего цикл повторяется. При равенстве состояния счетчика и содержимого регистра сравнения состояние соответствующего этому регистру вывода микроконтроллера изменяется согласно Табл. 6.9 (см. также Рис. 6.9). Таким образом, длительность импульса равна удвоенному значению содержимого регистра сравнения.

Таблица 6.9. Поведение выходов схемы сравнения в режиме ШИМ

| Регистр TCCR1A    |                   | Поведение вывода OC1x (OC1)                                                                                   |
|-------------------|-------------------|---------------------------------------------------------------------------------------------------------------|
| COM1x1<br>(COM11) | COM1x0<br>(COM10) |                                                                                                               |
| 0                 | 0                 | Таймер/счетчик Т1 отключен от вывода                                                                          |
| 0                 | 1                 | Таймер/счетчик Т1 отключен от вывода                                                                          |
| 1                 | 0                 | Сбрасывается в «0» при прямом счете и устанавливается в «1» при обратном счете (неинвертированный ШИМ-сигнал) |
| 1                 | 1                 | Устанавливается в «1» при прямом счете и сбрасывается в «0» при обратном счете (инвертированный ШИМ-сигнал)   |

#### Примечание:

х — А или В.



Рис. 6.9. Формирование ШИМ-сигнала

Соответственно если в счетный регистр записать значение \$000 или ТОР, то при следующем совпадении состояния счетчика и содержимого регистра сравнения выход схемы сравнения переключится в устойчивое состояние согласно Табл. 6.10.

| ,                                           |   | *                       |                                |
|---------------------------------------------|---|-------------------------|--------------------------------|
| Pericty TCCR1A   COM1x0   (COM11)   (COM10) |   | Pегистр OCR1x<br>(OCR1) | Состояние вывода ОС1х<br>(ОС1) |
| 1                                           | 0 | \$000                   | 0                              |
| 1                                           | 0 | TOP                     | 1                              |
| 1                                           | 1 | \$000                   | 1                              |
| 1                                           | 1 | TOP                     | 0                              |

Таблица 6.10. Устойчивые состояния выхода схемы сравнения

#### Примечание:

х — А или В.

Особенностью работы таймера/счетчика Т1 в режиме ШИМ является то, что при записи в регистр сравнения младшие 10 разрядов записываемого числа на самом деле сохраняются в специальном временном регистре (не путать с регистром ТЕМР). А изменение содержимого регистра сравнения происходит только в момент достижения счетчиком максимального значения (ТОР). Благодаря такому решению исключается появление несимметричных выбросов сигнала на выходе модулятора (помех), которые были бы неизбежны при непосредственной записи в регистр сравнения.

Соответственно при чтении регистра сравнения в промежутке между записью в него и его действительным изменением возвращается содержимое временного регистра. То есть всегда возвращается значение, записанное последним.

И несколько слов о прерываниях. При работе таймера/счетчика T1 в режиме ШИМ может генерироваться прерывание по переполнению счетного регистра таймера/счетчика, а также прерывания от схемы

сравнения. Флаги прерываний устанавливаются в «1» при изменении счетчиком направления счета: флаг TOV1 — в точке \$000, а флаги OCF1 (для регистра OCR1), OCF1A (для регистра OCR1A) и OCF1B (для регистра OCR1B) — в точке TOP. Разрешение и обработка соответствующих прерываний выполняются как обычно.

# 6.5 Таймер/счетчик Т2

Таймер/счетчик Т2 (8-разрядный) присутствует только в моделях AT90S/LS4434 и AT90S8535 микроконтроллеров семейства. Он может работать в двух режимах:

- режим таймера; в этом режиме таймер/счетчик T2 может использоваться для формирования временных интервалов, а также выполнять определенные действия при равенстве содержимого счетного регистра заданному значению;
- режим ШИМ; в этом режиме таймер/счетчик Т2 работает как широтно-импульсный модулятор.

Основным отличием таймера/счетчика T2 от рассмотренных ранее является его возможность работать в асинхронном режиме (от дополнительного кварцевого резонатора).

Структурная схема таймера/счетчика Т2 приведена на Рис. 6.10.

Как видно из рисунка, в состав таймера/счетчика Т2 входят два рабочих регистра (счетный регистр TCNT2 и регистр сравнения OCR2), 8-разрядный компаратор, регистр управления TCCR2, регистр состояния для асинхронного режима ASSR, а также блоки управления таймером и синхронизации.

Все флаги состояния таймера/счетчика (переполнения, совпадения и захвата) находятся в регистре флагов прерываний от таймеров TIFR, а разрешение/запрещение прерываний от таймера осуществляется установкой/сбросом соответствующих флагов регистра TIMSK.

Счетный регистр таймера/счетчика T2 реализован как суммирующий (в режиме ШИМ — как суммирующий/вычитающий) счетчик и доступен в любой момент времени как для чтения, так и для записи. Расположен он по адресу \$24 (\$44). При записи в регистр TCNT2 во время работы таймера счет будет продолжен по следующему за операцией записи импульсу тактового сигнала таймера/счетчика. После подачи напряжения питания в регистре TCNT2 находится нулевое значение.



Рис. 6.10. Структурная схема таймера/счетчика Т2

Для управления таймером/счетчиком Т2 предназначен регистр управления TCCR2, расположенный по адресу \$25 (\$45). Формат этого регистра приведен на **Puc. 6.11**. Значение отдельных разрядов этих регистров будет описано далее. Неиспользуемые разряды регистров доступны только для чтения и содержат «0».

|                     | 7 | 6    | 5     | 4     | 3    | 2    | 1    | 0    |
|---------------------|---|------|-------|-------|------|------|------|------|
|                     | _ | PWM2 | COM21 | СОМ20 | CTC2 | CS22 | CS21 | CS20 |
| Чтение(R)/Запись(W) | R | R/W  | R/W   | R/W   | R/W  | R/W  | R/W  | R/W  |
| Начальное значение  | 0 | 0    | 0     | 0     | 0    | 0    | 0    | 0    |

Рис. 6.11. Формат регистра TCCR2

## 6.5.1. Управление тактовым сигналом

Таймер/счетчик работает от тактового сигнала, который поступает на вход счетчика с предделителя, входящего в состав блока управления. А на предделитель, в свою очередь, может подаваться либо тактовый сигнал микроконтроллера, либо сигнал от дополнительного кварцевого резонатора (асинхронный режим работы).

Выбор коэффициента деления предделителя, а также запуск и остановка таймера/счетчика осуществляются с помощью разрядов CS22...CS20 регистра управления таймером TCCR2. Соответствие между состоянием этих разрядов и режимом работы таймера/счетчика приведено в **Табл. 6.11**.

|      | Регистр TCCR2 |      | Коэффициент деления предделителя |  |  |
|------|---------------|------|----------------------------------|--|--|
| CS22 | CS21          | CS20 | Коэффициент деления предделителя |  |  |
| 0    | 0             | 0    | Таймер/счетчик остановлен        |  |  |
| 0    | 0             | 1    | 1                                |  |  |
| 0    | 1             | 0    | 8                                |  |  |
| 0    | 1             | 1    | 32                               |  |  |
| 1    | 0             | 0    | 64                               |  |  |
| 1    | 0             | 1    | 128                              |  |  |
| 1    | 1             | 0    | 256                              |  |  |
| 1    | 1             | 1    | 1024                             |  |  |

Таблица 6.11. Управление предделителем таймера/счетчика Т2

## 6.5.2. Режим таймера

Принцип работы таймера/счетчика Т2 в этом режиме такой же, как и у рассмотренных ранее. По каждому импульсу, поступающему на тактовый вход таймера/счетчика, производится инкремент содержимого счетного регистра TCNT2. При переходе таймера/счетчика из состояния «\$FF» в состояние «\$00» устанавливается флаг TOV2 регистра TIFR и генерируется запрос на прерывание. Разрешение прерывания осуществляется установкой в «1» разряда TOIE2 регистра TIMSK (разумеется, флаг общего разрешения прерываний I регистра SREG также должен быть установлен в «1»).

Таймер/счетчик Т2 имеет также функцию сравнения, которая заключается в непрерывном (каждый машинный цикл) сравнении содержимого счетного регистра таймера/счетчика с содержимым регистра сравнения OCR2, расположенного по адресу \$23 (\$43). При совпадении содержимого этих регистров в следующем машинном цикле устанавливается флаг OCF2

регистра TIFR и генерируется запрос на прерывание. Разрешение прерывания осуществляется установкой в «1» разряда OCIE2 регистра TIMSK.

Наряду с установкой флага в регистре TIFR при равенстве счетного регистра и регистра сравнения могут выполняться и другие действия:

- сброс таймера/счетчика;
- изменение состояния вывода ОС2.

Поведение микроконтроллера, т.е. выполнение или невыполнение указанных действий, определяется состоянием разрядов COM21:COM20 и СТС2 регистра управления TCCR2 согласно **Табл. 6.12**.

| Таблица 6.12. Управление работой схемы сравнения таймера/счетчика | 1. | 2 |
|-------------------------------------------------------------------|----|---|
|-------------------------------------------------------------------|----|---|

| Название разряда | Описание                                                                           |                                              |                                                        |  |  |  |  |
|------------------|------------------------------------------------------------------------------------|----------------------------------------------|--------------------------------------------------------|--|--|--|--|
|                  | Управление выводом ОС2 микроконтроллера                                            |                                              |                                                        |  |  |  |  |
|                  | 1                                                                                  |                                              | определяет поведение вывода ОС2 при совпадении содер-  |  |  |  |  |
|                  |                                                                                    |                                              | регистра сравнения OCR2.                               |  |  |  |  |
|                  | Чтобы тайме                                                                        | р/счетчик мог                                | г управлять этим выводом, он должен быть сконфигуриро- |  |  |  |  |
|                  | ван как выході                                                                     | ной.                                         |                                                        |  |  |  |  |
| COM21,           | Поведение в                                                                        | Поведение вывода задается следующим образом: |                                                        |  |  |  |  |
| COM20            | COM21                                                                              | COM20                                        | Описание                                               |  |  |  |  |
|                  | 0                                                                                  | 0                                            | Таймер/счетчик Т2 отключен от вывода ОС2               |  |  |  |  |
|                  | 0                                                                                  | 1                                            | Состояние вывода меняется на противоположное           |  |  |  |  |
|                  | 1                                                                                  | 0                                            | Вывод сбрасывается в «0»                               |  |  |  |  |
|                  | 1                                                                                  | 1                                            | Вывод устанавливается в «1»                            |  |  |  |  |
|                  | Сброс таймера/счетчика                                                             |                                              |                                                        |  |  |  |  |
| CTC1             | Если этот разряд установлен в «1», то при совпадении содержимого счетного          |                                              |                                                        |  |  |  |  |
| CTC2             | регистра и регистра сравнения OCR2 производится сброс таймера/счетчика в состояние |                                              |                                                        |  |  |  |  |
|                  | «\$00»*                                                                            | 1                                            | F                                                      |  |  |  |  |

\* Поскольку сброс выполняется в машинном цикле, следующем за тем, во время которого произошло совпадение, поведение таймера/счетчика зависит от установленного коэффициента деления предделителя таймера (см. **Табл. 6.12**). При коэффициенте деления, равном 1, состояние таймера/счетчика меняется следующим образом: ...  $\rightarrow$  C-2  $\rightarrow$  C-1  $\rightarrow$  C  $\rightarrow$  0  $\otimes$  1  $\rightarrow$ ...

$$... \rightarrow (C-2, ..., C-2) \xrightarrow{1} (C-1, ..., C-1) \rightarrow (C, 0, ..., 0) \rightarrow ...,$$

где С — число, находящееся в регистре сравнения.

# 6.5.3. Режим ШИМ

В этом режиме таймер/счетчик Т2 представляет собой одинарный 8-разрядный широтно-импульсный модулятор. Для перевода таймера/счетчика Т2 в этот режим необходимо установить в «1» разряд PWM2 регистра TCCR2.

### 6. Таймеры

Счетный регистр таймера/счетчика в рассматриваемом режиме функционирует как реверсивный счетчик с модулем счета, равным «\$FF» (255). Частота сигнала соответственно равна  $f_{\rm TCK2}/510$ , где  $f_{\rm TCK2}$  — частота тактового сигнала. Состояние счетчика изменяется от \$00 до \$FF, а затем снова до \$00, после чего цикл повторяется. При равенстве состояния счетчика и содержимого регистра сравнения состояние вывода ОС2 микроконтроллера изменяется согласно Табл. 6.13 (см. также Рис. 6.9).

| Perucrp TCCR2  COM21 COM20 |   | Пополению вуполе ОСЭ                                                                                          |  |  |  |  |
|----------------------------|---|---------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                            |   | Поведение вывода ОС2                                                                                          |  |  |  |  |
| 0                          | 0 | Таймер/счетчик Т2 отключен от вывода                                                                          |  |  |  |  |
| 0                          | 1 | Таймер/счетчик Т2 отключен от вывода                                                                          |  |  |  |  |
| 1                          | 0 | Сбрасывается в «0» при прямом счете и устанавливается в «1» при обратном счете (неинвертированный ШИМ-сигнал) |  |  |  |  |
| 1                          | 1 | Устанавливается в «1» при прямом счете и сбрасывается в «0» при обратном счете (инвертированный ШИМ-сигнал)   |  |  |  |  |

Таблица 6.13. Поведение выходов схемы сравнения в режиме ШИМ

Соответственно если в счетный регистр записать значение \$00 или \$FF, то при следующем совпадении состояния счетчика и содержимого регистра сравнения выход схемы сравнения переключится в устойчивое состояние согласно Табл. 6.14.

| Регист | TCCR2 | D 00004      | g 0.55               |
|--------|-------|--------------|----------------------|
| COM21  | COM20 | Perистр OCR2 | Состояние вывода ОС2 |
| 1      | 0     | \$00         | 0                    |
| 1      | 0     | \$FF         | 1                    |
| 1      | 1     | \$00         | 1                    |
| 1      | 1     | \$FF         | 0                    |

Таблица 6.14. Устойчивые состояния выхода схемы сравнения

Как и в случае таймера/счетчика T1, при записи значения в регистр OCR2 записываемое число на самом деле сохраняется в специальном временном регистре. А изменение содержимого регистра OCR2 про-исходит только в момент достижения счетчиком значения \$FF.

Соответственно при чтении регистра OCR2 в промежутке между записью в него и его действительным изменением возвращается содержимое временного регистра. То есть всегда возвращается значение, записанное последним.

И несколько слов о прерываниях. При работе таймера/счетчика Т2 в режиме ШИМ может генерироваться как прерывание по переполнению счетного регистра таймера/счетчика, так и прерывание от схемы сравнения. Флаги прерываний устанавливаются в «1» при изменении счетчиком направления счета: флаг TOV2 — в точке \$00, а флаг OCF2 — в точке \$FF. Разрешение и обработка соответствующих прерываний выполняется как обычно.

## 6.5.4 Асинхронный режим работы

Отличительной особенностью таймера/счетчика Т2 является его возможность работать в асинхронном режиме. В этом режиме на вход предделителя поступает сигнал с вывода TOSC1, что позволяет использовать таймер/счетчик в качестве часов реального времени. Источником сигнала может быть как кварцевый резонатор частотой 32768 Гц, подключаемый к выводам TOSC1 и TOSC2 микроконтроллера, так и внешняя схема. Несмотря на то, что тактовый генератор таймера/счетчика настроен на частоту 32768 Гц, частота сигнала от внешней схемы может лежать в пределах 0...256 кГц. При этом частота внешнего сигнала должна быть в четыре раза меньше частоты тактового сигнала микроконтроллера.

Непосредственная запись в регистры TCNT2, OCR2 и TCCR2 в асинхронном режиме синхронизируется с тактовым сигналом таймера/счетчика. При записи числа в любой из указанных регистров оно сохраняется в специальном временном регистре, своем для каждого регистра таймера/счетчика. А пересылка содержимого временного регистра в рабочий регистр таймера/счетчика осуществляется по третьему после записи положительному фронту сигнала на выводе TOSC1. Соответственно запись нового значения можно производить только после пересылки содержимого временного регистра в регистр таймера/счетчика.

Для определения момента действительного изменения регистров TCNT2, OCR2 и TCCR2, а также для переключения таймера/счетчика в асинхронный режим предназначен регистр ASSR, расположенный по адресу \$22 (\$42). Формат этого регистра приведен на **Puc. 6.12**, а описание отдельных его разрядов приведено в **Табл. 6.15**.

|                     | 7 | 6 | 5 | 4 | 3   | 2      | 1      | 0      |  |
|---------------------|---|---|---|---|-----|--------|--------|--------|--|
|                     | 1 | _ | 1 | 1 | AS2 | TCN2UB | OCR2UB | TCR2UB |  |
| Чтение(R)/Запись(W) | R | R | R | R | R/W | R      | R      | R      |  |
| Начальное значение  | 0 | 0 | 0 | 0 | 0   | 0      | 0      | 0      |  |

Рис. 6.12. Формат регистра ASSR

Таблица 6.15. Регистр состояния асинхронного режима ASSR

| Разряд | Название | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 74     | _        | Зарезервированы, читаются как «0»                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3      | AS2      | Переключение режима работы Если разряд установлен в «1», на вход предделителя таймера/счетчика Т2 поступают импульсы с вывода TOSC1 микроконтроллера (асинхронный режим). В этом режиме выводы TOSC1 и TOSC2 используются для подключения кварцевого резонатора и, соответственно, не могут использоваться как контакты ввода/вывода общего назначения.  Если разряд сброшен в «0», на вход предделителя поступает внутренний тактовый сигнал микроконтроллера. В этом случае выводы TOSC1 и TOSC2 являются контактами ввода/вывода общего назначения.  При изменении состояния этого разряда содержимое регистров TCNT2, OCR2 и TCCR2 может быть повреждено |
| 2      | TCN2UB   | Состояние обновления регистра TCNT2 При записи в регистр TCNT2 этот флаг устанавливается в «1», а после пересылки записываемого значения в этот регистр флаг аппаратно сбрасывается в «0». Таким образом, сброшенный флаг TCN2UB означает, что регистр TCNT2 готов для записи в него нового значения.  Запись в регистр TCNT2 при установленном флаге TCN2UB может привести к повреждению прежнего содержимого регистра и к генерации прерывания                                                                                                                                                                                                             |
| 1      | OCR2UB   | Состояние обновления регистра ОСR2 При записи в регистр ОСR2 этот флаг устанавливается в «1», а после пересылки записываемого значения в этот регистр флаг аппаратно сбрасывается в «0». Таким образом, сброшенный флаг ОСR2UB означает, что регистр ОСR2 готов для записи в него нового значения.  Запись в регистр ОСR2 при установленном флаге ОСR2UB может привести к повреждению прежнего содержимого регистра и к генерации прерывания                                                                                                                                                                                                                 |
| 0      | TCR2UB   | Состояние обновления регистра ТССR2 При записи в регистр ТССR2 этот флаг устанавливается в «1», а после пересылки записываемого значения в этот регистр флаг аппаратно сбрасывается в «0». Таким образом, сброшенный флаг TCR2UB означает, что регистр ТССR2 готов для записи в него нового значения.  Запись в регистр ТССR2 при установленном флаге TCR2UB может привести к повреждению прежнего содержимого регистра и к генерации прерывания                                                                                                                                                                                                             |

Необходимо отметить, что при переключении между синхронным и асинхронным режимами содержимое регистров таймера/счетчика может быть повреждено. Чтобы этого избежать, рекомендуется придерживаться следующей последовательности действий:

- 1. Запретить прерывания от таймера/счетчика T2 (разряды TOIE2 и OCIE2 регистра TIMSK).
- 2. Переключить таймер/счетчик в требуемый режим.
- 3. Записать новые значения в регистры TCNT2, OCR2 и TCCR2.

- 4. В случае переключения в асинхронный режим ждать, пока флаги TCN2UB, OCR2UB и TCR2UB не будут сброшены.
- 5. Разрешить прерывания (если требуется).

При работе таймера/счетчика T2 в асинхронном режиме установка флагов прерываний от него производится синхронно с тактовым сигналом микроконтроллера. Для синхронизации требуется 3 машинных цикла плюс один период тактового сигнала таймера/счетчика. Поэтому к моменту, когда микроконтроллер сможет прочитать состояние счетчика, вызвавшее установку флага прерывания, оно изменится по меньшей мере на единицу. Изменение состояния вывода ОС2 производится по тактовому сигналу таймера/счетчика и не синхронизируется с тактовым сигналом микроконтроллера.

Отдельно следует сказать о «взаимодействии» асинхронного режима таймера/счетчика Т2 с режимами пониженного энергопотребления микроконтроллера Power Down и Power Save.

Первое замечание касается использования прерываний от таймера/счетчика Т2 для «пробуждения» микроконтроллера. В этом случае при переводе микроконтроллера в режим Power Save после записи в регистры таймера/счетчика необходимо убедиться, что операция записи завершена (флаги TCN2UB, OCR2UB и TCR2UB сброшены). Наиболее важно это в случае, когда для «пробуждения» микроконтроллера используется прерывание от схемы сравнения. Дело в том, что во время записи в регистры TCNT2 и OCR2 функция сравнения выключена. Соответственно если переход в режим Power Save произойдет до окончания операции записи в указанные регистры, прерывания от схемы сравнения никогда не произойдет и микроконтроллер не сможет выйти из спящего режима.

Вторая особенность связана с синхронизацией установки флагов прерываний от таймера/счетчика. При выходе микроконтроллера из режима Power Save по прерыванию от таймера/счетчика флаг соответствующего прерывания устанавливается только спустя 3 машинных цикла после запуска тактового генератора микроконтроллера. Во время этих циклов процессор выполняет команды, следующие за командой SLEEP, и только потом переходит к обработке прерывания (если оно разрешено).

Кроме того, необходимо быть осторожным при повторном переходе в режим Power Save после выхода из него по прерыванию от таймера/счетчика Т2. Дело в том, что в этом случае для запуска схемы прерываний требуется промежуток времени, равный одному периоду

сигнала на выводе TOSC1. Если же промежуток времени между «пробуждением» и повторным переходом в режим Power Save будет меньше указанного, генерации прерывания и, соответственно, «пробуждения» микроконтроллера не произойдет. Для формирования задержки требуемой длительности рекомендуется после «пробуждения» микроконтроллера выполнить запись в какой-либо из регистров таймера/счетчика и дождаться завершения этой операции.

После подачи напряжения питания, а также после «пробуждения» микроконтроллера из режима Power Down таймер/счетчик рекомендуется использовать только спустя секунду после указанных событий. Эта задержка необходима для запуска тактового генератора таймера/счетчика. Соответственно при выходе из режима Power Down содержимое всех регистров таймера/счетчика Т2 можно считать потерянным (из-за нестабильности тактового сигнала во время запуска генератора).

# 6.6. Сторожевой таймер

Основная функция сторожевого таймера — защита устройства от сбоев. Благодаря сторожевому таймеру можно прервать выполнение зациклившейся программы или выйти из других непредвиденных ситуаций, препятствующих нормальному выполнению программы.

Структурная схема сторожевого таймера приведена на Рис. 6.13.



Рис. 6.13. Структурная схема сторожевого таймера

Сторожевой таймер имеет независимый генератор, поэтому он работает даже во время нахождения микроконтроллера в режиме Power Down. Частота этого генератора зависит от напряжения питания устройства, температуры, технологического разброса. Типовое значение частоты равно 1 МГц при  $V_{\rm CC} = 5.0$  В и 350 кГц при  $V_{\rm CC} = 3.0$  В.

Если сторожевой таймер включен, то через определенные промежутки времени (при наступлении тайм-аута) выполняется сброс микроконтроллера. Подробнее процесс сброса описан в Главе 4. Чтобы избежать сброса микроконтроллера при нормальном выполнении программы, сторожевой таймер необходимо регулярно сбрасывать через промежутки времени, меньше его периода. Сброс сторожевого таймера осуществляется командой WDR.

Для управления сторожевым таймером предназначен регистр WDTCR, расположенный по адресу \$21 (\$41). Формат этого регистра приведен на **Рис. 6.14.** 



Рис. 6.14. Формат регистра WDTCR

Для включения/выключения сторожевого таймера используются два разряда регистра WDTCR — WDE и WDTOE. Если разряд WDE установлен в «1», сторожевой таймер включен, если сброшен в «0» — выключен. Непосредственно перед включением таймера рекомендуется также выполнять его сброс командой WDR.

Чтобы избежать непреднамеренного выключения таймера счетчика, предназначен разряд WDTOE. Дело в том, что выключение сторожевого таймера (сброс разряда WDE) можно осуществить только при установленном разряде WDTOE. Причем через 4 машинных цикла после установки в «1» этот разряд аппаратно сбрасывается, благодаря чему практически исчезает возможность случайного выключения сторожевого таймера.

Исходя из сказанного, для выключения сторожевого таймера рекомендуется следующая последовательность действий:

- 1. Одной командой записать лог. «1» в разряды WDE и WDTOE.
- 2. В течение следующих четырех машинных циклов записать лог. «0» в разряд WDE.

## 6. Таймеры

Период наступления тайм-аута сторожевого таймера задается с помощью разрядов WDP2...WDP0 регистра WDTCR согласно **Табл. 6.17**.

Таблица 6.16. Задание периода сторожевого таймера

| WDP2 | WDP1 | WDP0 | Число тактов ге- | Период наступления тайм      | и-аута (типовое значение)    |
|------|------|------|------------------|------------------------------|------------------------------|
| WDF2 | WDF1 | WDFU | нератора         | $V_{\rm CC} = 3.0 \text{ B}$ | $V_{\rm CC} = 5.0 \text{ B}$ |
| 0    | 0    | 0    | 16·1024          | 47 мс                        | 15 мс                        |
| 0    | 0    | 1    | 32·1024          | 91 мс                        | 30 мс                        |
| 0    | 1    | 0    | 64·1024          | 0.19 с                       | 60 мс                        |
| 0    | 1    | 1    | 128·1024         | 0.38 c                       | 0.12 c                       |
| 1    | 0    | 0    | 256·1024         | 0.75 c                       | 0.24 c                       |
| 1    | 0    | 1    | 512·1024         | 1.5 c                        | 0.49 c                       |
| 1    | 1    | 0    | 1024-1024        | 3.0 c                        | 0.97 с                       |
| 1    | 1    | 1    | 2048·1024        | 6.0 c                        | 1.9 с                        |

Чтобы избежать непреднамеренного сброса микроконтроллера при изменении периода сторожевого таймера, необходимо перед записью разрядов WDP2:WDP0 либо запретить работу сторожевого таймера, либо сбросить его.

# Глава 7. **Аналоговый компаратор**

# 7.1. Общие сведения

Все микроконтроллеры семейства за исключением моделей AT90S/LS2323, AT90S/LS2343 и AT90C8534 содержат в своем составе аналоговый компаратор. Будучи включенным, этот компаратор позволяет сравнивать значения напряжений, присутствующих на двух выводах микроконтроллера. Результатом сравнения является логическое значение, которое может быть прочитано из программы. По результату сравнения может быть сгенерировано прерывание, а также выполнена функция захвата таймера/счетчика T1.

Используемые компаратором выводы являются контактами портов ввода/вывода общего назначения. Какими именно — зависит от модели микроконтроллера (см. **Табл. 7.1**).

| Название | AT90S1200 | AT90S2313 |     | AT90S/LS4434<br>AT90S/LS8535 |     | Назначение           |
|----------|-----------|-----------|-----|------------------------------|-----|----------------------|
| AIN0     | PB0       | PB0       | PD6 | PB2                          | PB2 | Неинвертирующий вход |
| AIN1     | PB1       | PB1       | PD7 | PB3                          | PB3 | Инвертирующий вход   |

Чтобы указанные линии портов ввода/вывода могли использоваться аналоговым компаратором, они, разумеется, должны быть сконфигурированы как входы (соответствующий разряд регистра DDRх установлен в «1»). Кроме того, необходимо отключить внутренние подтягивающие резисторы записью лог. «0» в соответствующий разряд регистра PORTх.

# 7.2. Функционирование компаратора

Структурная схема аналогового компаратора приведена на **Рис. 7.1**. Обратите внимание, что источник опорного напряжения и мультиплексор, показанные на схеме, имеются только в моделях AT90S/LS2333 и AT90S/LS4433.



Рис. 7.1. Структурная схема аналогового компаратора

Управление компаратором и контроль его состояния осуществляются с помощью регистра ACSR, расположенного по адресу \$08 (\$28). Формат этого регистра приведен на **Рис. 7.2**. Краткое описание функций разрядов регистра приведено в **Табл. 7.2**.

|                     | ACD | _     | ACO | ACI | ACIE | _    | ACIS1 | ACIS0 | AT90S1200                    |
|---------------------|-----|-------|-----|-----|------|------|-------|-------|------------------------------|
| Чтение(R)/Запись(W) | R/W | R     | R   | R/W | R/W  | R    | R/W   | R/W   | •                            |
| Начальное значение  | 0   | 0     | N/A | 0   | 0    | 0    | 0     | 0     |                              |
|                     | 7   | 6     | 5   | 4   | 3    | 2    | 1     | 0     | AT90S2313                    |
|                     | ACD | _     | ACO | ACI | ACIE | ACIC | ACIS1 | ACIS0 | AT90S/LS4434<br>AT90S/LS8535 |
| Чтение(R)/Запись(W) | R/W | R     | R   | R/W | R/W  | R/W  | R/W   | R/W   | AT90S4414                    |
| Начальное значение  | 0   | 0     | N/A | 0   | 0    | 0    | 0     | 0     | AT90S8515                    |
|                     | 7   | 6     | 5   | 4   | 3    | 2    | 1     | 0     | -                            |
|                     | ACD | AINBG | ACO | ACI | ACIE | ACIC | ACIS1 | ACIS0 | AT90S/LS2323<br>AT90S/LS2343 |
| Чтение(R)/Запись(W) | R/W | R/W   | R   | R/W | R/W  | R/W  | R/W   | R/W   |                              |
| Начальное значение  | 0   | 0     | N/A | 0   | 0    | 0    | 0     | 0     |                              |

Рис. 7.2. Формат регистра ACSR

| Разряд | Название    | Описание                                                                                           | Модель                       |  |
|--------|-------------|----------------------------------------------------------------------------------------------------|------------------------------|--|
| 7      | ACD         | Выключение компаратора (0 — включен, 1 — выключен)                                                 | Bce                          |  |
| 6      | AINBG       | Подключение к неинвертирующему входу компаратора внутреннего ИОН (0 — не подключен, 1 — подключен) | AT90S/LS2333<br>AT90S/LS4433 |  |
| 5      | ACO         | Результат сравнения (выход компаратора)                                                            | Bce                          |  |
| 4      | ACI         | Флаг прерывания от компаратора                                                                     | Bce                          |  |
| 3      | ACIE        | Разрешение прерывания от компаратора                                                               | Bce                          |  |
| 2      | ACIC        | Подключение компаратора к схеме захвата таймера/счетчика Т1 (1 — подключен, 0 — отключен)          | Кроме<br>AT90S1200           |  |
| 1, 0   | ACIS1:ACIS0 | Условие возникновения прерывания от компаратора                                                    | Bce                          |  |

Таблица. 7.2. Регистр ACSR

По своему действию рассматриваемый узел микроконтроллера является обычным компаратором. Если напряжение на выводе AIN0 (неинвертирующий вход) больше напряжения на выводе AIN1(инвертирующий вход), то результат сравнения будет равен «1». В противном случае результат сравнения будет равен «0». Этот результат (состояние выхода компаратора) сохраняется в разряде ACO регистра ACSR.

Разряд ACD отвечает за включение и выключение компаратора. При включении напряжения питания все разряды регистра ACSR сбрасываются в «0», поэтому компаратор автоматически включается при подаче напряжения питания на микроконтроллер. Чтобы его выключить, разряд ACD следует установить в «1». При изменении состояния этого разряда необходимо запретить прерывание от компаратора.

Как уже было сказано, в соответствии с результатом сравнения схема компаратора может генерировать запрос на прерывание. Если состояние выхода компаратора (разряд ACO) изменилось заданным образом, устанавливается флаг прерывания ACI регистра ACSR и генерируется запрос на прерывание. Как и для других прерываний, этот флаг сбрасывается аппаратно при запуске подпрограммы обработки прерывания или программно — записью в него лог. «1». Для разрешения прерывания необходимо установить в «1» разряд ACIE регистра ACSR и, разумеется, флаг I регистра SREG.

Условие генерации запроса на прерывание от компаратора определяется состоянием разрядов ACIS1:ACIS0 регистра ACSR в соответствии с **Табл. 7.3**. При изменении этих разрядов прерывание от компаратора (как и для разряда ACD) должно быть запрещено.

#### 7. Аналоговый компаратор

| ACIS1 | ACIS0 | Условие                                             |
|-------|-------|-----------------------------------------------------|
| 0     | 0     | Любое изменение состояния выхода компаратора        |
| 0     | 1     | Зарезервировано                                     |
| 1     | 0     | Изменение состояния выхода компаратора с «1» на «0» |
| 1     | 1     | Изменение состояния выхода компаратора с «0» на «1» |

Таблица. 7.3. Условия генерации запроса на прерывание от компаратора

Помимо генерации прерывания компаратор также может управлять схемой захвата таймера/счетчика T1. Эта возможность определяется состоянием разряда ACIC регистра ACSR (в модели AT90S1200 таймер/счетчик T1 отсутствует, соответственно данный разряд регистра зарезервирован). Чтобы выход аналогового компаратора мог управлять схемой захвата таймера/счетчика T1, разряд ACIC следует установить в «1». При этом выход компаратора подключается к схеме захвата вместо вывода ICP микроконтроллера. Если же разряд ACIC сброшен в «0», компаратор полностью отключен от схемы сравнения таймера/счетчика.

В микроконтроллерах AT90S/LS2333 и AT90S/LS4433 аналоговый компаратор имеет одну дополнительную возможность. Если включена схема BOD (см. п. 4.4.4), то к неинвертирующему входу компаратора вместо вывода AIN0 микроконтроллера может быть подключен внутренний источник опорного напряжения величиной 1.22  $\pm 0.05$  В. Для этого необходимо установить в «1» разряд AINBG регистра ACSR.

И в заключение предлагаем вашему вниманию **Табл. 7.4**, в которой представлены основные параметры аналогового компаратора.

| Обозначение    | Параметр                    | Условия                                                      | min   | typ | max        | Ед. изм. |
|----------------|-----------------------------|--------------------------------------------------------------|-------|-----|------------|----------|
| $V_{\rm ACIO}$ | Входное напряжение смещения | $V_{\rm CC} = 5 \text{ B},$<br>$V_{\rm IN} = V_{\rm CC}/2$   |       |     | 40.0       | мВ       |
| $I_{ m ACLK}$  | Ток утечки на входе         | $V_{\rm CC} = 5 \text{ B},$ $V_{\rm IN} = V_{\rm CC}/2$      | -50.0 |     | 50.0       | нА       |
| $t_{ m ACPD}$  | Время отклика               | $V_{\rm CC} = 2.7 \text{ B}$<br>$V_{\rm CC} = 4.0 \text{ B}$ |       |     | 750<br>500 | нс       |

Таблица. 7.4. Параметры аналогового компаратора

# глава 8. **Аналого-цифровой** преобразователь

## 8.1. Общие сведения

Ряд моделей микроконтроллеров семейства, а именно AT90S/LS2333, AT90S/LS4433, AT90S/LS4434, AT90S/LS8535 и AT90C8534, имеет в своем составе многоканальный 10-разрядный АЦП последовательного приближения. Число каналов зависит от модели и равно 6 (AT90S/LS2333, AT90S/LS4433 и AT90C8534) или 8 (AT90S/LS4434 и AT90S/LS8535). В качестве входов модуля АЦП в моделях AT90S/LS2333 и AT90S/LS4433 используются выводы порта C, а в моделях AT90S/LS4434 и AT90S/LS8535 — выводы порта A. Входы АЦП в микроконтроллере AT90C8534 вообще являются единственными входными контактами устройства, если не считать двух входов внешних прерываний.

Для питания модуля АЦП в микроконтроллере предусмотрены 2 вывода:  $AV_{CC}$  (напряжение питания) и AGND (аналоговая «земля»). Напряжение на выводе  $AV_{CC}$  не должно отличаться от напряжения питания микроконтроллера больше чем на  $\pm 0.3$  В, а аналоговая «земля» соединена с цифровой в одной точке. Все модели, кроме AT90C8534, также имеют вывод AREF для подключения к АЦП внешнего источника опорного напряжения. Напряжение, подаваемое на этот вывод, должно находиться в диапазоне  $0...V_{CC}$ .

АЦП всех моделей могут работать в двух режимах:

- режим одиночного преобразования: в этом режиме запуск каждого преобразования инициируется пользователем;
- режим непрерывного преобразования: в этом режиме запуск преобразований выполняется непрерывно через определенные интервалы времени.

# 8.2. Функционирование модуля АЦП

Структурная схема модуля АЦП приведена на **Рис. 8.1**. Обратите внимание, что источник опорного напряжения, показанный на схеме, имеется только в моделях AT90S/LS2333 и AT90S/LS4433.



Рис. 8.1. Структурная схема модуля АЦП

Управление модулем АЦП и контроль его состояния осуществляется с помощью регистра ADCSR, расположенного по адресу \$06 (\$26). Формат этого регистра приведен на **Рис. 8.2**, а краткое описание функций разрядов регистра приведено в **Табл. 8.1**. Подробно использование различных разрядов регистра будет описано далее.



Рис. 8.2. Формат регистра ADCSR

Таблица. 8.1. Регистр ADCSR

| Разряд | Название    | Описание                                          |
|--------|-------------|---------------------------------------------------|
| 7      | ADEN        | Разрешение АЦП (1 — включено, 0 — выключено)      |
| 6      | ADSC        | Запуск преобразования (1 — начать преобразование) |
| 5      | ADFR        | Выбор режима работы АЦП (0 — одиночное преобр.)   |
| 4      | ADIF        | Флаг прерывания от компаратора                    |
| 3      | ADIE        | Разрешение прерывания от компаратора              |
| 20     | ADPS2:ADPS0 | Выбор частоты преобразования                      |

Перед началом использования АЦП требуется разрешить его работу. Для этого необходимо записать лог. «1» в разряд ADEN регистра ADCSR, а для запрета соответственно лог. «0». Причем если АЦП будет заблокировано во время цикла преобразования, то преобразование завершено не будет (в регистре данных АЦП останется результат предыдущего преобразования).

Режим работы АЦП определяется состоянием разряда ADFR. Если он установлен в «1», АЦП работает в режиме непрерывного преобразования. В этом режиме запуск каждого следующего преобразования осуществляется автоматически после окончания текущего. Если же разряд ADFR сброшен в «0», АЦП работает в режиме одиночного преобразования и запуск каждого преобразования осуществляется по команде пользователя.

Запуск преобразования осуществляется установкой в «1» разряда ADSC регистра ADCSR, а сам цикл преобразования начинается по первому нарастающему фронту тактового сигнала после установки этого разряда. Длительность цикла составляет 13 тактов; выборка и запоминание входного сигнала осуществляется в течение первых 1.5 такта. Через 13 тактов преобразование завершается, разряд ADSC аппаратно сбрасывается в «0» (в режиме одиночного преобразования), и результат преобразования сохраняется в регистре данных АЦП. Одновременно устанавливается флаг прерывания ADIF регистра ADCSR и генерируется запрос на прерывание. Как и флаги остальных прерываний, флаг ADIF сбрасывается аппаратно при запуске подпрограммы обработки прерывания от АЦП или программно— записью в него лог. «1». Разрешение прерывания осуществляется установкой в «1» разряда ADIE регистра ADCSR (разумеется, флаг I регистра SREG также должен быть установлен в «1»).

Если АЦП работает в режиме непрерывного преобразования, новый цикл начнется сразу же после записи результата. В режиме одиночного преобразования новое преобразование может быть запущено сразу же после сброса разряда ADSC (до сохранения результата текущего преобразования). Однако реально цикл преобразования начнется не ранее чем через один такт после окончания текущего преобразования. Временные диаграммы, иллюстрирующие сказанное, приведены на **Рис. 8.3**.

При написании программ необходимо учитывать одну особенность: для первого после включения АЦП преобразования требуется на 12 тактов больше, чем для всех последующих. Это связано с тем, что при запуске первого преобразования сначала выполняется одно «холостое» преобразование, инициализирующее АЦП (см. **Рис. 8.4**). Разряд ADSC в этом случае сбрасывается только после окончания рабочего преобразования.

Таким образом, длительность преобразования зависит от режима работы АЦП и от порядкового номера преобразования. Соответствующие данные приведены в **Табл. 8.2** (нумерация циклов — согласно **Рис. 8.3** и **8.4**).

Тактовым сигналом модуля АЦП является сигнал с предделителя, на вход которого, в свою очередь, поступает тактовый сигнал микроконтроллера. Коэффициент деления предделителя и, соответственно, длительность преобразования определяется состоянием разрядов ADPS2...ADPS0 регистра ADCSR (см. Табл. 8.3).



*Рис. 8.3.* Временные диаграммы работы АЦП:
 а — режим одиночного преобразования,
 б — режим непрерывного преобразования



*Рис. 8.4.* Временные диаграммы работы АЦП при первом преобразовании (режим одиночного преобразования)

| Условия                           | Выборка сигнала<br>(номер такта) | Готовность результата<br>(номер такта) | Общее время преобра-<br>зования (тактов) |  |
|-----------------------------------|----------------------------------|----------------------------------------|------------------------------------------|--|
| Непрерывный, 1-е преобразование   | 14                               | 25                                     | 25                                       |  |
| Одиночный, 1-е преобразование     | 14                               | 25                                     | 26                                       |  |
| Режим непрерывного преобразования | 2                                | 13                                     | 13                                       |  |
| Режим одиночного преобразования   | 2                                | 13                                     | 14                                       |  |

Таблица. 8.3. Задание коэффициента деления предделителя АЦП

| ADPS2 | ADPS1 | ADPS0 | Коэффициент деления |
|-------|-------|-------|---------------------|
| 0     | 0     | 0     | 2                   |
| 0     | 0     | 1     | 2                   |
| 0     | 1     | 0     | 4                   |
| 0     | 1     | 1     | 8                   |
| 1     | 0     | 0     | 16                  |
| 1     | 0     | 1     | 32                  |
| 1     | 1     | 0     | 64                  |
| 1     | 1     | 1     | 128                 |

Наибольшая точность преобразования достигается, если тактовая частота модуля АЦП находится в определенном диапазоне:  $80...170~\rm k\Gamma \mu$  для АТ90С8534 и  $50...200~\rm k\Gamma \mu$  для остальных моделей. Соответственно коэффициент деления предделителя рекомендуется выбирать таким, чтобы тактовая частота модуля АЦП находилась в указанном диапазоне.

Как уже было сказано, результат преобразования сохраняется в регистре данных АЦП. Поскольку АЦП — 10-разрядный, этот регистр физически размещен в двух регистрах ввода/вывода ADCH:ADCL, доступных только для чтения. Эти регистры расположены по адресам \$05:\$04 (адреса в адресном пространстве O3V соответственно \$25:\$24) и при включении питания содержат значение «\$0000». Обращение к этим регистрам (для получения результата преобразования) должно выполняться в определенной последовательности: сначала необходимо прочитать регистр ADCL, а затем ADCH. Это требование связано с тем, что после обращения к регистру ADCL процессор блокирует доступ к регистрам данных со стороны АЦП до тех пор, пока не будет прочитан регистр ADCH. Благодаря этому можно быть уверенным, что при чтении регистров в них будут находиться составляющие одного и того же результата. Соответственно, если очередное преобразование завершится до обращения к регистру ADCH, результат преобразования будет потерян.

Управление входным мультиплексором модуля АЦП осуществляется с помощью регистра ADMUX, расположенного по адресу \$07 (\$27). Формат этого регистра приведен на **Рис. 8.5**.



Рис. 8.5. Формат регистра ADMUX

Разряды MUX2...MUX0 этого регистра определяют номер активного канала (номер аналогового входа, подключенного к входу АЦП). Состояние этих разрядов можно изменить в любой момент, однако, если это будет сделано во время цикла преобразования, смена канала произойдет только после завершения преобразования. Благодаря этому в режиме непрерывного преобразования можно легко реализовать сканирование каналов. Под этим термином в данном случае понимается последовательное преобразование сигналов нескольких каналов.

В микроконтроллерах AT90S/LS2333 и AT90S/LS4433 имеется дополнительная функция, связанная с наличием в этих моделях схемы BOD (см. п. 4.4.4). Если схема BOD включена, к входу АЦП можно подключить внутренний источник опорного напряжения величиной  $1.22\pm0.05$  В. Для этого необходимо установить в «1» разряд ADCBG регистра ADMUX. Состояние разрядов MUX2...MUX0 при этом не имеет значения.

#### 8.3. Повышение точности преобразования

Как уже было сказано, для минимизации погрешности самого АЦП необходимо правильно выбрать тактовую частоту модуля. Вторым фактором, влияющим на точность преобразования, являются различного рода помехи и шумы. Их влияние особенно заметно при обработке слабых сигналов.

Известно, что работающий микроконтроллер является источником электромагнитных помех. Чтобы свести к минимуму помехи, наводимые ядром процессора, в АЦП реализована возможность работы в ре-

жиме Idle. Для этого необходимо выполнить следующее:

- 1. Убедиться, что АЦП включен и не занят преобразованием. Затем переключить АЦП в режим одиночного преобразования и разрешить прерывание от АЦП.
- 2. Перевести микроконтроллер в режим Idle. Сразу же после остановки процессора начнется цикл преобразования.
- 3. При завершении преобразования будет сгенерировано прерывание от АЦП, которое переведет микроконтроллер в рабочий режим, и начнется выполнение подпрограммы обработки этого прерывания.

Однако помехи генерируются не только ядром процессора, но и другими схемами, в том числе расположенными вне микроконтроллера. Для уменьшения этих помех при разработке конструкции и разводке печатной платы рекомендуется придерживаться следующих правил:

- 1. На печатной плате необходимо предусмотреть область (или даже слой) сплошной металлизации под аналоговую «землю». Аналоговая часть микроконтроллера и аналоговая часть всего устройства должны располагаться над этой областью. Аналоговая и цифровая «земли» должны соединяться друг с другом в единственной точке печатной платы.
- 2. Проводники, по которым распространяются аналоговые сигналы, должны быть как можно короче и располагаться над аналоговой «землей». Кроме того, они должны быть размещены как можно дальше от быстродействующих цифровых цепей.
- 3. Вывод AV<sub>CC</sub> должен быть подключен к источнику питания  $V_{\rm CC}$  через LC—фильтр, как показано на **Рис. 8.6** (расположение выводов показано условно).
- 4. Если какие-либо выводы порта используются как цифровые выходы, они не должны переключаться во время преобразования (это замечание не относится к модели АТ90С8534). Показанный на рисунке *LC*-фильтр в этом случае должен быть исключен.



Рис. 8.6. Подключение цепей питания АЦП

#### 8.4. Параметры АЦП

Основные параметры АЦП приведены в **Табл. 8.4**. Все значения указаны для диапазона температур окружающей среды -40...+80°C.

Таблица. 8.4. Параметры АЦП

| Обозначение | Параметр                     | Условия                                                            | min | typ | max | Ед. изм. | Модель              |
|-------------|------------------------------|--------------------------------------------------------------------|-----|-----|-----|----------|---------------------|
|             | Разрешение                   |                                                                    |     | 10  |     | бит      | Bce                 |
|             |                              | $V_{\text{REF}} = 4 \text{ B}$ $f_{\text{ADC}} = 200 \text{ кГц}$  |     | 1   | 2   | МЗР      |                     |
|             | Абсолютная                   | $V_{\text{REF}} = 4 \text{ B}$ $f_{\text{ADC}} = 1 \text{ МГц}$    |     | 4   |     | МЗР      | AT90S <sup>1)</sup> |
|             | погрешность                  | $V_{\text{REF}} = 4 \text{ B}$<br>$f_{\text{ADC}} = 2 \text{ МГц}$ |     | 16  |     | МЗР      |                     |
|             |                              | AV <sub>CC</sub> = 3.36.0 B                                        |     |     | 2   | МЗР      | AT90C8534           |
| INL         | Интегральная<br>нелинейность | $V_{\rm REF} > 2 \text{ B}$                                        |     | 0.5 |     | МЗР      | AT90S <sup>1)</sup> |
| INL         |                              | AV <sub>CC</sub> = 3.36.0 B                                        |     | 1   |     | МЗР      | AT90C8534           |
| DMI         | Дифференциальная             | $V_{\rm REF} > 2  \rm B$                                           |     | 0.5 |     | МЗР      | AT90S1)             |
| DNL         | нелинейность                 | AV <sub>CC</sub> = 3.36.0 B                                        |     | 2   |     | МЗР      | AT90C8534           |
|             | Ошибка смещения              |                                                                    |     | 1   |     | МЗР      | AT90S <sup>1)</sup> |
|             |                              | AV <sub>CC</sub> = 3.36.0 B                                        |     | 0.5 |     | МЗР      | AT90C8534           |
|             | Время                        |                                                                    | 65  |     | 260 | мкс      | AT90S <sup>1)</sup> |
|             | преобразования               |                                                                    | 76  |     | 175 | MKC      | AT90C8534           |

#### 8. Аналого-цифровой преобразователь

Таблица. 8.4 (окончание)

| Обозначение        | Параметр                                         | Условия | min                     | typ | max                       | Ед. изм. | Модель              |
|--------------------|--------------------------------------------------|---------|-------------------------|-----|---------------------------|----------|---------------------|
| $f_{ m ADC}$       | Тактовая частота                                 |         | 50                      |     | 200                       | кГц      | AT90S1)             |
|                    | тактовая частота                                 |         | 80                      |     | 170                       | кГц      | AT90C8534           |
| $AV_{CC}$          | Напряжение питания                               |         | $V_{\rm CC} - 0.3^{2)}$ |     | $V_{\rm CC} + 0.3^{\ 2)}$ | В        | Bce                 |
| $V_{\mathrm{REF}}$ | Опорное напряжение                               |         | AGND                    |     | $AV_{CC}$                 |          | AT90S <sup>1)</sup> |
| $R_{\mathrm{REF}}$ | Входное сопротивление канала опорного напряжения |         | 6                       | 10  | 13                        | кОм      | Bce                 |
| $R_{ m AIN}$       | Входное<br>сопротивление<br>аналогового входа    |         |                         | 100 |                           | МОм      | Bce                 |

 $<sup>^{-1)}</sup>$  Все модели с АЦП, кроме АТ90С8534.  $^{2)}$  Диапазон допустимых значений для AV $_{\rm CC}$  тот же, что и для  $V_{\rm CC}$ .

#### 9.1. Общие сведения

Все микроконтроллеры семейства Classic, за исключением моделей AT90S1200, AT90S/LS2323, AT90S/LS2343 и AT90C8534, имеют в своем составе модуль полнодуплексного универсального асинхронного приемопередатчика (UART). Через него осуществляется прием и передача информации, представленной последовательным кодом, поэтому модуль UART часто называют также последовательным портом. С помощью этого модуля микроконтроллер может обмениваться данными с различными внешними устройствами.

Скорость передачи данных может варьироваться в широких пределах, причем высокие скорости передачи могут быть достигнуты даже при относительно низкой тактовой частоте микроконтроллера.

Известно, что при передаче данных могут происходить различные сбои. Модуль UART, реализованный в микроконтроллерах семейства Classic, может обнаруживать и сигнализировать о следующих внештатных ситуациях:

- переполнение;
- ошибка кадрирования;
- неверный старт-бит.

Для уменьшения вероятности сбоев в модуле реализована такая полезная функция, как фильтрация помех.

Для взаимодействия с программой в модуле предусмотрены 3 раздельных прерывания, запрос на которые генерируется при наступлении следующих событий: «передача завершена», «регистр данных передатчика пуст» и «прием завершен».

Выводы микроконтроллера, используемые модулем UART, являются линиями порта D. В качестве входа приемника (RXD) используется вывод PD0, а в качестве выхода передатчика (TXD) — вывод PD1.

#### 9.2. Управление работой UART

Управление работой приемопередатчика осуществляется с помощью регистра управления UCR (в моделях AT90S/LS233 и AT90S/LS4433 — UCSRB), расположенного по адресу \$0A (\$2A). А текущее состояние приемопередатчика определяется с помощью регистра состояния USR (в моделях AT90S/LS233 и AT90S/LS4433 — UCSRA), расположенного по адресу \$0A (\$2A). Формат регистра UCR (UCSRB) приведен на Рис. 9.1, а регистра USR (UCSRA) — на Рис. 9.2. Значение разрядов этих регистров описано в Табл. 9.1 и 9.2 соответственно. Неиспользуемые разряды регистров доступны только для чтения и содержат «0».



Рис. 9.1. Формат регистра UCR (UCSRB)

Таблица 9.1. Описание регистра UCR (UCSRB)

| Разряд | Название | Описание                                                                                                                                                                                                                                               |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | RXCIE    | Разрешение прерывания по завершении приема  Если данный разряд установлен в «1», то при установке флага RXC в регистре USR (UCSRA) происходит запуск подпрограммы обработки прерывания «прием завершен» (если прерывания разрешены)                    |
| 6      | TXCIE    | Разрешение прерывания по завершении передачи  Если данный разряд установлен в «1», то при установке флага ТХС в регистре USR  (UCSRA) происходит запуск подпрограммы обработки прерывания «передача завершена» (если прерывания разрешены)             |
| 5      | UDRIE    | Разрешение прерывания при очистке регистра данных UART  Если данный разряд установлен в «1», то при установке флага UDRE в регистре USR  (UCSRA) происходит запуск подпрограммы обработки прерывания «регистр данных пуст» (если прерывания разрешены) |
| 4      | RXEN     | Разрешение приема При установке данного разряда в «1» разрешается работа приемника UART. Если приемник выключен, флаги ТХС, OR и FE не могут быть установлены. При сбросе разряда RXEN эти флаги не сбрасываются                                       |

Таблица 9.1 (окончание)

| Разряд | Название | Описание                                                                                                                                                                                                                                                                                          |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3      | TXEN     | Разрешение передачи При установке данного разряда в «1» разрешается работа передатчика UART. Если разряд сбрасывается в «0» во время передачи, выключение передатчика произойдет только после завершения передачи текущего слова и слова, находящегося на момент выключения в регистре данных UDR |
| 2      | CHR9     | Формат посылок     Если разряд установлен в «1», производится передача и прием 9-разрядных данных. При передаче значение старшего (8-го) разряда берется из разряда ТХВ8 регистра, а при приеме записывается в разряд RXВ8                                                                        |
| 1      | RXB8     | 8-й разряд принимаемых данных Если флаг СНR9 установлен в «1», этот разряд содержит значение старшего разряда принятого слова                                                                                                                                                                     |
| 0      | TXB8     | 8-й разряд передаваемых данных Если флаг СНR9 установлен в «1», содержимое этого разряда передается как старший разряд слова                                                                                                                                                                      |

|                                           |        |          |        | U       | ISR      |        |        |          |                              |
|-------------------------------------------|--------|----------|--------|---------|----------|--------|--------|----------|------------------------------|
|                                           | 7      | 6        | 5      | 4       | 3        | 2      | 1      | 0        | AT90S2313                    |
|                                           | RXC    | TXC      | UDRE   | FE      | OR       | _      | -      | _        | AT90S/LS4434<br>AT90S/LS8535 |
| Чтение(R)/Запись(W)                       | R      | R/W      | R      | R       | R        | R      | R      | R        | AT90S4414                    |
| Начальное значение                        | 0      | 0        | 1      | 0       | 0        | 0      | 0      | 0        | AT90S8515                    |
|                                           | 7      | 6        | 5      | UC<br>4 | SRA<br>3 | 2      | 1      | 0        |                              |
|                                           | RXC    | TXC      | UDRE   | FE      | OR       | _      | _      | MPCM     | AT90S/LS2333<br>AT90S/LS4433 |
| Чтение(R)/Запись(W)<br>Начальное значение | R<br>0 | R/W<br>0 | R<br>1 | R<br>0  | R<br>0   | R<br>0 | R<br>0 | R/W<br>0 | •                            |

Рис. 9.2. Формат регистра USR (UCSRA)

Таблица 9.2. Описание регистра USR (UCSRA)

| Разряд | Название | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | RXC      | Флаг завершения приема Данный флаг устанавливается при пересылке принятого слова из сдвигового регистра приемника в регистр данных UDR (установка происходит даже при обнаружении ошибок кадрирования).  Если разряд RXCIE регистра UCR (UCSRB) установлен, то при установке флага RXC генерируется запрос на прерывание «прием завершен». Сбрасывается флаг аппаратно, при чтении регистра UDR. Соответственно, если прерывание используется, этот регистр обязательно должен быть прочитан в обработчике прерывания |

Таблица 9.2 (окончание)

| Разряд | Название | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6      | TXC      | Флаг завершения передачи Данный флаг устанавливается в «1» после передачи всех разрядов слова (включая стоп-бит) из сдвигового регистра передатчика, при условии, что в регистр данных UDR не было загружено новое значение. Этот флаг наиболее полезен при полудуплексной связи, при которой передающее устройство должно освободить линию и перейти в режим приема сразу же после окончания передачи.  Если разряд TXCIE регистра UCR (UCSRB) установлен, то при установке флага TXC генерируется запрос на прерывание «передача завершена». Флаг сбрасывается аппаратно при выполнении подпрограммы обработки прерывания или программно записью в него лог. «1» |
| 5      | UDRE     | Регистр данных пуст Данный флаг устанавливается в «1» после пересылки байта из регистра данных UDR в сдвиговый регистр передатчика. Установка этого флага означает, что передатчик готов к получению нового значения для передачи.  Если разряд UDRIE регистра UCR (UCSRB) установлен, генерируется запрос на прерывание «регистр данных пуст». Сбрасывается флаг аппаратно при записи регистра UDR. Соответственно, если прерывание используется, в обработчике прерывания следует обязательно произвести запись в этот регистр. В противном случае после окончания обработки прерывания оно будет вызвано снова                                                  |
| 4      | FE       | Флаг ошибки кадрирования Данный флаг устанавливается в «1», при обнаружении ошибки кадрирования, т.е. если стоп-бит принятого слова равен «0». Флаг сбрасывается при приеме стоп-бита, равного «1»                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3      | OR       | Флаг переполнения  Данный флаг устанавливается в «1», если в сдвиговом регистре приемника находится новое принятое слово, а старое содержимое регистра UDR не прочитано. Флаг остается установленным до тех пор, пока не будет прочитано содержимое регистра UDR.  Флаг сбрасывается при пересылке принятых данных из сдвигового регистра приемника в регистр UDR                                                                                                                                                                                                                                                                                                  |
| 2, 1   | _        | Зарезервированы, читаются как «0»                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0      | MPCM     | Флаг режима мультипроцессорного обмена Данный разряд используется для перехода в режим мультипроцессорного обмена. Этот флаг устанавливается в «1», когда ведомый микроконтроллер ожидает приема адресного байта. При распознавании ведомым микроконтроллером своего адреса он должен сбросить флаг МРСМ и начать прием данных. Для получения более подробной информации обратитесь к разделу 9.5. Только в моделях AT90S/LS2333 и AT90S/LS4433                                                                                                                                                                                                                    |

Принимаемые и передаваемые данные (младшие 8 разрядов) хранятся в регистре данных UDR, который расположен по адресу \$0C (\$2C). Физически регистр UDR состоит из двух отдельных регистров, один из которых используется для передачи данных, другой — для приема. При чтении регистра UDR выполняется обращение к регистру приемника, при записи — к регистру передатчика.

#### 9.3. Передача данных

Структурная схема передатчика модуля UART приведена на **Рис. 9.3**. Работа передатчика разрешается установкой в «1» разряда TXEN регистра UCR (UCSRB). Если этот разряд сброшен (передатчик выключен), вывод PD1 (TXD) может использоваться как контакт ввода/вывода общего назначения. При установке разряда TXEN этот вывод подключается к передатчику UART и начинает функционировать как выход независимо от состояния разряда DDD1 регистра DDRD.



Рис. 9.3. Структурная схема передатчика UART

Передача инициируется записью передаваемых данных в регистр данных UART — UDR. После этого данные пересылаются из регистра UDR в сдвиговый регистр передатчика. При этом возможны два варианта:

- новое значение записывается в регистр UDR после того, как был передан стоп-бит предыдущего слова. В этом случае данные пересылаются в сдвиговый регистр сразу же после записи в регистр UDR;
- новое значение записывается в регистр UDR во время передачи. В этом случае данные пересылаются в сдвиговый регистр после передачи стоп-бита текущего слова.

После пересылки содержимого регистра UDR в сдвиговый регистр флаг UDRE регистра USR (UCSRA) устанавливается в «1», что означает готовность передатчика к получению нового значения. В этом состоянии флаг остается до новой записи в регистр UDR. Одновременно с пересылкой формируется служебная информация: 0-й разряд сдвигового регистра сбрасывается в «0» (старт-бит), а 9-й (10-й) разряд устанавливается в «1» (стоп-бит). Если включен режим передачи 9-разрядных данных (разряд CHR9 регистра UCR (UCSRB) установлен в «1»), то значение разряда TXB8 регистра UCR (UCSRB) копируется в 9-й разряд сдвигового регистра.

После загрузки сдвигового регистра его содержимое начинает сдвигаться вправо и поступать на вывод TXD в следующем порядке: старт-бит, данные (начиная с младшего разряда), стоп-бит. Сдвиг осуществляется по тактовому сигналу, вырабатываемому контроллером скорости передачи. Если во время передачи в регистр UDR было записано новое значение, то после передачи стоп-бита оно пересылается в сдвиговый регистр. Если же к моменту окончания передачи стоп-бита такой записи выполнено не было, устанавливается флаг завершения передачи TXC регистра USR (UCSRA).

#### 9.4. Прием данных

Структурная схема приемника модуля UART приведена на Рис. 9.4.

Прием данных разрешается установкой разряда RXEN регистра UCR (UCSRB). Если этот разряд сброшен (приемник выключен), вывод PD0 (RXD) может использоваться как контакт ввода/вывода общего назначения. При установке разряда RXEN этот вывод подключается к приемнику UART и начинает функционировать как вход независимо от состояния разряда DDD0 регистра DDRD.



*Рис. 9.4.* Структурная схема приемника UART

Работает приемник следующим образом. Схема предварительной обработки опрашивает вход приемника с частотой, в 16 раз превышающей скорость передачи данных (для обработки одного разряда принимаемой последовательности производится 16 выборок входного сигнала). Обнаружение лог. «0» в режиме ожидания интерпретируется как появление переднего (спадающего) фронта старт-бита. После этого проверяется значение 8-й, 9-й и 10-й выборок входного сигнала. Если значение хотя бы двух выборок из указанных равно лог. «1», старт-бит считается ложным (помеха), а приемник переходит к ожиданию следующего изменения входного сигнала с лог. «1» на лог. «0». В противном случае считается, что обнаружен старт-бит новой последовательности.

После обнаружения старт-бита начинается обработка разрядов слова данных. Решение о значении принятого разряда принимается также по результатам 8-й, 9-й и 10-й выборок входного сигнала (см. Рис. 9.5). Состоянием разряда считается логическое значение, которое было получено по меньшей мере в двух из трех выборок. По мере распознавания разрядов принимаемой последовательности они помещаются, сдвигаясь влево, в сдвиговый регистр приемника.

Распознавание стоп-бита производится также по трем выборкам входного сигнала. Стоп-бит считается принятым, если значение хотя бы двух из трех выборок входного сигнала равно лог. «1». В противном случае фиксируется ошибка кадрирования и флаг FE регистра USR (UCSRA) устанавливается «1». Перед чтением регистра данных UDR следует всегда проверять состояние этого флага.



Рис. 9.5. Обработка принимаемых данных

Независимо от того был или не был обнаружен стоп-бит в конце принимаемой посылки, принятое слово пересылается в регистр данных UDR и устанавливается флаг RXC регистра USR (UCSRA). При обмене 9-разрядными данными 9-й разряд принятого слова загружается в разряд RXB8 регистра UCR (UCSRB) при пересылке содержимого сдвигового регистра приемника в регистр данных.

Если новое слово будет принято до того, как из регистра UDR будут считаны предыдущие данные, возникает переполнение. Об этом сигнализирует флаг OR регистра USR (UCSRA), который в этом случае устанавливается в «1». Установка этого флага означает, что принятые данные не могут быть пересланы из сдвигового регистра в регистр данных и, соответственно, являются потерянными. Сбрасывается указанный флаг только после обращения к регистру данных. Поэтому при высоких скоростях передачи либо при большой загрузке процессора пользователь после каждого чтения содержимого регистра UDR должен проверять состояние флага OR регистра USR (UCSRA) для обнаружения возможного переполнения.

#### 9.5. Мультипроцессорный режим работы UART

Сразу следует сказать, что данный режим реализован только в микроконтроллерах AT90S/LS2333 и AT90S/LS4433.

Режим многопроцессорного обмена позволяет осуществлять связь между несколькими ведомыми микроконтроллерами и одним ведущим. В этом режиме каждый ведомый микроконтроллер имеет свой уникальный адрес. Если ведущий микроконтроллер хочет что-либо передать, он посылает адресный байт, определяющий, к какому из микроконтроллеров он собирается обратиться. Если какой-либо из ведомых микроконтроллеров распознал свой адрес, он переходит в режим приема данных и, соответственно, принимает последующие байты как данные. Остальные ведомые микроконтроллеры игнорируют принимаемые байты до посылки ведущим нового адресного байта.

В модуле UART микроконтроллера, являющегося ведущим, должен быть установлен режим передачи 9-разрядных данных (разряд CHR9 регистра UCR установлен в «1»). При передаче адресного байта девятый разряд должен устанавливаться в «1», а при передаче байтов данных он должен сбрасываться в «0».

В ведомых микроконтроллерах механизм приема слегка отличается в зависимости от режима работы приемника. При приеме 8-разрядных данных (разряд CHR9 регистра UCR (UCSRB) сброшен в «0») стоп-бит адресного байта равен «1», а байта данных — «0». При приеме 9-разрядных данных 9-й разряд равен «1» для адресного байта и «0» для байта данных. Стоп-бит всегда будет равен «1».

Для осуществления обмена данными в многопроцессорном режиме необходимо выполнить следующую последовательность действий.

- 1. Все ведомые микроконтроллеры переключаются в режим мультипроцессорного обмена установкой в «1» разряда MPCM регистра USR (UCSRA).
- 2. Ведущий микроконтроллер посылает адресный байт, а все ведомые микроконтроллеры его принимают. Соответственно в каждом из ведомых микроконтроллеров устанавливается флаг RXC регистра USR (UCSRA).
- 3. Каждый из ведомых микроконтроллеров считывает содержимое регистра UDR. Микроконтроллер, адрес которого совпал с адресом, посланным ведущим, сбрасывает флаг MPCM регистра USR (UCSRA).

- 4. Для каждого принятого байта данных в ведомом микроконтроллере устанавливается флаг завершения приема RXC регистра USR (UCSRA). Кроме того, если UART ведомого микроконтроллера работает в режиме приема 8-разрядных данных, будет генерироваться ошибка кадрирования, поскольку стоп-бит будет равен «0». В других ведомых микроконтроллерах флаг MPCM установлен, поэтому байты данных будут игнорироваться. Содержимое регистра UDR и состояние флагов RXC и FE регистра USR (UCSRA) не изменяется.
- После передачи последнего байта данных процесс повторяется с пункта № 2.

#### 9.6. Скорость приема/передачи

Управление скоростью приема и передачи данных осуществляется контроллером скорости передачи, который является обыкновенным делителем частоты. Скорость передачи зависит от содержимого регистра контроллера. В моделях AT90S/LS2333 и AT90S/LS4433 этот регистр является 12-разрядным и физически размещается в двух PBB UBRRHI:UBRR, расположенных по адресам \$03:\$09 (\$23:\$29). В остальных моделях он размещается в одном регистре UBRR, расположенном по адресу \$09 (\$29). Собственно скорость передачи определяется следующим выражением:

$$BAUD = \frac{f_{CLK}}{16 \cdot (UBR + 1)}$$

где BAUD — скорость передачи (в бодах);

 $f_{\rm CLK}$  — тактовая частота микроконтроллера, Гц;

UBR — содержимое регистра контроллера скорости передачи (0...4095 для моделей AT90S/LS2333 и AT90S/LS4433 и 0...255 для остальных моделей).

Как известно, существует ряд значений скорости передачи данных, являющихся, по сути дела, стандартными. Значения регистра UBR, позволяющие получить эти скорости передачи при использовании различных резонаторов, а также величины ошибок получаемых значений относительно их теоретического значения приведены в Табл. 9.3.

*Таблица 9.3.* Значения регистра UBR для различных значений тактовой частоты микроконтроллера

| Скорость<br>[бод] | 1 МГц      | Ошибка<br>[%] | 1.8432 МГц | Ошибка<br>[%] | 2 МГц     | Ошибка<br>[%] | 2.4576 МГц | Ошибка<br>[%] |
|-------------------|------------|---------------|------------|---------------|-----------|---------------|------------|---------------|
| 2400              | UBR = 25   | 0.2           | UBR = 47   | 0.0           | UBR = 51  | 0.2           | UBR = 63   | 0.0           |
| 4800              | UBR = 12   | 0.2           | UBR = 23   | 0.0           | UBR = 25  | 0.2           | UBR = 31   | 0.0           |
| 9600              | UBR = 6    | 7.5           | UBR = 11   | 0.0           | UBR = 12  | 0.2           | UBR = 15   | 0.0           |
| 14400             | UBR = 3    | 7.8           | UBR = 7    | 0.0           | UBR = 8   | 3.7           | UBR = 10   | 3.1           |
| 19200             | UBR = 2    | 7.8           | UBR = 5    | 0.0           | UBR = 6   | 7.5           | UBR = 7    | 0.0           |
| 28800             | UBR = 1    | 7.8           | UBR = 3    | 0.0           | UBR = 3   | 7.8           | UBR = 4    | 6.3           |
| 38400             | UBR = 1    | 22.9          | UBR = 2    | 0.0           | UBR = 2   | 7.8           | UBR = 3    | 0.0           |
| 57600             | UBR = 0    | 7.8           | UBR = 1    | 0.0           | UBR = 1   | 7.8           | UBR = 2    | 12.5          |
| 76800             | UBR = 0    | 22.9          | UBR = 1    | 33.3          | UBR = 1   | 22.9          | UBR = 1    | 0.0           |
| 115200            | UBR = 0    | 84.3          | UBR = 0    | 0.0           | UBR = 0   | 7.8           | UBR = 0    | 25.0          |
| Скорость<br>[бод] | 3.2768 МГц | Ошибка<br>[%] | 3.6864 МГц | Ошибка<br>[%] | 4 МГц     | Ошибка<br>[%] | 4.608 МГц  | Ошибка<br>[%] |
| 2400              | UBR = 84   | 0.4           | UBR = 95   | 0.0           | UBR = 103 | 0.2           | UBR = 119  | 0.0           |
| 4800              | UBR = 42   | 0.8           | UBR = 47   | 0.0           | UBR = 51  | 0.2           | UBR = 59   | 0.0           |
| 9600              | UBR = 20   | 1.6           | UBR = 23   | 0.0           | UBR = 25  | 0.2           | UBR = 29   | 0.0           |
| 14400             | UBR = 13   | 1.6           | UBR = 15   | 0.0           | UBR = 16  | 2.1           | UBR = 19   | 0.0           |
| 19200             | UBR = 10   | 3.1           | UBR = 11   | 0.0           | UBR = 12  | 0.2           | UBR = 14   | 0.0           |
| 28800             | UBR = 6    | 1.6           | UBR = 7    | 0.0           | UBR = 8   | 3.7           | UBR = 9    | 0.0           |
| 38400             | UBR = 4    | 6.3           | UBR = 5    | 0.0           | UBR = 6   | 7.5           | UBR = 7    | 6.7           |
| 57600             | UBR = 3    | 12.5          | UBR = 3    | 0.0           | UBR = 3   | 7.8           | UBR = 4    | 0.0           |
| 76800             | UBR = 2    | 12.5          | UBR = 2    | 0.0           | UBR = 2   | 7.8           | UBR = 3    | 6.7           |
| 115200            | UBR = 4    | 12.5          | UBR = 1    | 0.0           | UBR = 1   | 7.8           | UBR = 2    | 20.0          |
| Скорость<br>[бод] | 7.3728 МГц | Ошибка<br>[%] | 8 МГц      | Ошибка<br>[%] | 9.216 МГц | Ошибка<br>[%] | 11.059 МГц | Ошибка<br>[%] |
| 2400              | UBR = 191  | 0.0           | UBR = 207  | 0.2           | UBR = 239 | 0.0           | UBR = 287  | _             |
| 4800              | UBR = 95   | 0.0           | UBR = 103  | 0.2           | UBR = 119 | 0.0           | UBR = 143  | 0.0           |
| 9600              | UBR = 47   | 0.0           | UBR = 51   | 0.2           | UBR = 59  | 0.0           | UBR = 71   | 0.0           |
| 14400             | UBR = 31   | 0.0           | UBR = 34   | 0.8           | UBR = 39  | 0.0           | UBR = 47   | 0.0           |
| 19200             | UBR = 23   | 0.0           | UBR = 25   | 0.2           | UBR = 29  | 0.0           | UBR = 35   | 0.0           |
| 28800             | UBR = 15   | 0.0           | UBR = 16   | 2.1           | UBR = 19  | 0.0           | UBR = 23   | 0.0           |
| 38400             | UBR = 11   | 0.0           | UBR = 12   | 0.2           | UBR = 14  | 0.0           | UBR = 17   | 0.0           |
| 57600             | UBR = 7    | 0.0           | UBR = 8    | 3.7           | UBR = 9   | 0.0           | UBR = 11   | 0.0           |
| 76800             | UBR = 5    | 0.0           | UBR = 6    | 7.5           | UBR = 7   | 6.7           | UBR = 8    | 0.0           |
| 115200            | UBR = 3    | 0.0           | UBR = 3    | 7.8           | UBR = 4   | 0.0           | UBR = 5    | 0.0           |

Значения регистра UBR, при которых получаемая скорость передачи отличается от требуемого значения меньше чем на 2%, выделены в таблице жирным шрифтом. Однако поскольку при увеличении ошибки помехозащищенность линии передачи снижается, скорости передачи, имеющие ошибку установки более 1%, использовать не рекомендуется.

## глава 10. Последовательный периферийный интерфейс SPI

#### 10.1. Общие сведения

Последовательный периферийный интерфейс SPI (Serial Peripheral Interface), реализованный в микроконтроллерах семейства, имеет два назначения. Прежде всего через него может быть осуществлено программирование микроконтроллера (так называемый режим последовательного программирования). Использование интерфейса SPI в этом качестве будет описано в следующей главе.

Вторым назначением интерфейса является организация высокоскоростного обмена данными между микроконтроллером и различными периферийными устройствами, такими как цифровые потенциометры ЦАП/АЦП, Flash-ПЗУ и др. Посредством этого интерфейса также может производиться обмен данными между несколькими микроконтроллерами AVR. Использование интерфейса SPI в качестве высокоскоростного канала связи и рассматривается в данной главе. Однако такой возможностью обладают не все модели, а только AT90S/LS2333, AT90S/LS4433, AT90S/LS4434, AT90S/LS8535, AT90S4414 и AT90S8515.

При обмене данными по интерфейсу SPI микроконтроллер AVR может работать как в режиме Master, так и в режиме Slave. При этом пользователь может задать следующие параметры:

- скорость передачи (четыре программируемых значения);
- формат передачи (от младшего разряда к старшему или наоборот);

Дополнительной возможностью подсистемы SPI является «пробуждение» микроконтроллера из режима Idle при поступлении данных.

#### 10.2. Функционирование модуля SPI

Структурная схема модуля SPI приведена на **Рис. 10.1**.

Модуль SPI использует четыре вывода микроконтроллера. Как и для большинства прочих периферийных устройств, эти выводы являются линиями порта ввода/вывода общего назначения (см. Табл. 10.1).



Puc. 10.1. Структурная схема модуля SPI

Таблица. 10.1. Выводы, используемые модулем SPI

| Название | AT90S/LS2333<br>AT90S/LS4433 | AT90S/LS4434<br>AT90S/LS8535 | AT90S4414<br>AT90S8515 | Описание                                      |  |  |
|----------|------------------------------|------------------------------|------------------------|-----------------------------------------------|--|--|
| SCK      | PB5                          | PB7                          | PB7                    | Выход (master)/вход (slave) тактового сигнала |  |  |
| MISO     | PB4                          | PB6                          | PB6                    | Вход (master)/выход (slave) данных            |  |  |
| MOSI     | PB3                          | PB5                          | PB5                    | Выход (master)/вход (slave) данных            |  |  |
| SS       | PB2                          | PB4                          | PB4                    | Выбор ведомого устройства                     |  |  |

Вход

При включенном модуле SPI режим работы указанных выводов (направление передачи данных) переопределяется согласно Табл. 10.2.

| Tuomuna. 10.2. Tiepenasna i | иомица. 10.2. Перепазна тепне режима расоты выводов модули вт |                             |  |  |  |  |  |  |  |
|-----------------------------|---------------------------------------------------------------|-----------------------------|--|--|--|--|--|--|--|
| Вывод                       | Режим Master                                                  | Режим Slave                 |  |  |  |  |  |  |  |
| MOSI                        | Определяется пользователем*                                   | Вход                        |  |  |  |  |  |  |  |
| MISO                        | Вход                                                          | Определяется пользователем* |  |  |  |  |  |  |  |
| SCK                         | Определяется пользователем*                                   | Вхол                        |  |  |  |  |  |  |  |

Таблица 10.2 Переназначение режима работы выволов молуля SPI

Как видно из таблицы, в некоторых случаях пользователь должен самостоятельно задать режим работы вывода, используемого модулем SPI, в соответствии с его назначением (см. далее по тексту). Причем возможность управления внутренними подтягивающими резисторами выводов, работающих как входы, сохраняется независимо от способа управления их режимом работы.

Для управления модулем SPI предназначен регистр управления SPCR, расположенный по адресу \$0D (\$2D). Формат этого регистра приведен на Рис. 10.2, а краткое описание функций разрядов регистра приведено в Табл. 10.2. Подробно использование различных разрядов регистра будет описано далее.

|                     | 7    | 6   | 5    | 4    | 3    | 2    | 1    | 0    |
|---------------------|------|-----|------|------|------|------|------|------|
|                     | SPIE | SPE | DORD | MSTR | CPOL | CPHA | SPR1 | SPR0 |
| Чтение(R)/Запись(W) | R/W  | R/W | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Начальное значение  | 0    | 0   | 0    | 0    | 0    | 0    | 0    | 0    |

*Puc. 10.2.* Формат регистра SPCR

| Таблица. | 10 | 3 | Peructn | SI | $^{\circ}$ R |
|----------|----|---|---------|----|--------------|
|          |    |   |         |    |              |

SS

| Разряд | Название  | Описание                           |  |  |  |  |  |
|--------|-----------|------------------------------------|--|--|--|--|--|
| 7      | SPIE      | Разрешение прерывания от SPI       |  |  |  |  |  |
| 6      | SPE       | Включение/выключение SPI           |  |  |  |  |  |
| 5      | DORD      | Порядок передачи данных            |  |  |  |  |  |
| 4      | MSTR      | Выбор режима работы (Master/Slave) |  |  |  |  |  |
| 3      | CPOL      | Полярность тактового сигнала       |  |  |  |  |  |
| 2      | СРНА      | Фаза тактового сигнала             |  |  |  |  |  |
| 1, 0   | SPR1:SPR0 | Скорость передачи                  |  |  |  |  |  |

Определяется пользователем\* \* Направление передачи данных определяется состоянием соответствующего разряда регистра DDRB.

Контроль состояния модуля осуществляется с помощью регистра состояния SPSR (доступен только для чтения), расположенного по адресу \$0E (\$2E). Формат этого регистра приведен на **Puc. 10.3**, а назначение его разрядов описано в **Табл. 10.4**.

|                     | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|------|------|---|---|---|---|---|---|
|                     | SPIF | WCOL | - | - | 1 | _ | 1 | _ |
| Чтение(R)/Запись(W) | R    | R    | R | R | R | R | R | R |
| Начальное значение  | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0 |

Рис. 10.3. Формат регистра SPSR

Таблица. 10.3. Описание регистра SPSR

| Разряд | Название | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | SPIF     | Флаг прерывания от SPI Данный флаг устанавливается в «1» по окончании передачи очередного байта. Если флаг SPIE регистра SPCR установлен в «1» и прерывания разрешены, одновременно с установкой флага генерируется прерывание от SPI. Также флаг SPIF устанавливается в «1» при переводе микроконтроллера из режима Master в режим Slave посредством вывода SS (см. раздел 10.3). Флаг сбрасывается аппаратно либо при старте подпрограммы обработки прерывания, либо после чтения регистра состояния SPI с последующим обращением к регистру данных SPI (SPDR) |
| 6      | WCOL     | Флаг конфликта записи Данный флаг устанавливается в «1» при попытке записи в регистр данных (SPDR) во время передачи очередного байта. Флаг сбрасывается аппаратно после чтения регистра состояния SPI с последующим обращением к регистру данных SPI                                                                                                                                                                                                                                                                                                            |
| 50     | _        | Зарезервированы, читаются как «0»                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Передаваемые данные записываются, а принимаемые — считываются из регистра данных SPDR, расположенного по адресу \$0F (\$2F). Запись в этот регистр инициирует начало передачи, а при его чтении считывается содержимое приемного буфера сдвигового регистра. Поэтому этот регистр можно назвать буфером между регистровым файлом микроконтроллера и сдвиговым регистром модуля SPI.

Соединение двух микроконтроллеров (ведущий—ведомый) по интерфейсу SPI показано на **Puc. 10.4**. Вывод SCK ведущего микроконтроллера является выходом тактового сигнала, а ведомого микроконтроллера — входом.



*Рис. 10.4.* Соединение микроконтроллеров по интерфейсу SPI

Перед выполнением обмена необходимо прежде всего разрешить работу модуля SPI. Для этого следует установить в «1» разряд SPE регистра SPCR. Режим работы определяется состоянием разряда MSTR этого регистра: если разряд установлен в «1», микроконтроллер работает в режиме Master (ведущий), если сброшен в «0» — в режиме Slave (ведомый).

Передача данных осуществляется следующим образом. При записи в регистр данных SPI ведущего микроконтроллера запускается генератор тактового сигнала модуля SPI, и данные начинают поразрядно выдаваться на вывод MOSI и, соответственно, поступать на вывод MOSI ведомого микроконтроллера. Порядок передачи разрядов данных определяется состоянием разряда DORD регистра SPCR. Если разряд установлен в «1», первым передается младший разряд байта, если же сброшен в «0» — старший разряд. После выдачи последнего разряда текущего байта генератор тактового сигнала останавливается с одновременной установкой в «1» флага «Конец передачи» (SPIF). Если прерывания от модуля SPI разрешены (флаг SPIE регистра SPCR установлен в «1»), генерируется запрос на прерывание. При подключении к ведущему устройству нескольких ведомых, что разрешено спецификацией SPI, выбор конкретного ведомого устройства осуществляется подачей на его вход  $\overline{\text{SS}}$  сигнала НИЗКОГО уровня.

Образно говоря, два сдвиговых регистра ведомого и ведущего устройств можно считать одним распределенным 16-разрядным циклическим сдвиговым регистром, как показано на **Puc. 10.4**. Одновременно с передачей данных от ведущего к ведомому происходит передача и в обратном направлении. Таким образом, в каждом цикле сдвига происходит обмен данными между устройствами.

В модуле используется одинарная буферизация при передаче и двойная — при приеме. Это означает, что готовый для передачи байт данных не может быть записан в регистр данных SPI до окончания предыдущего цикла обмена. При попытке изменить содержимое регистра данных во время передачи устанавливается в «1» флаг WCOL регистра SPSR. Сбрасывается этот флаг после чтения регистра SPSR с последующим обращением к регистру данных SPI.

Соответственно во время приема принятый байт должен быть прочитан из регистра данных SPI до того, как в сдвиговый регистр поступит последний разряд следующего байта. В противном случае первый байт будет потерян.

#### 10.3. Режимы передачи данных

Спецификация интерфейса SPI предусматривает 4 режима передачи данных. Эти режимы различаются соответствием между фазой (момент считывания сигнала) тактового сигнала SCK, его полярностью и передаваемыми данными. Всего существует 4 такие комбинации, определяемые состоянием разрядов СРНА и СРОL регистра SPCR (см. Табл. 10.4).

| Разряд | Описание                                                                                                                                                                                                                                                               |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPOL   | Полярность тактового сигнала  0 — генерируются импульсы положительной полярности, при отсутствии импульсов на выводе присутствует НИЗКИЙ уровень;  1 — генерируются импульсы отрицательной полярности, при отсутствии импульсов на выводе присутствует ВЫСОКИЙ уровень |
| СРНА   | Фаза тактового сигнала  0 — обработка данных производится по переднему фронту импульсов сигнала SCK (для CPOL = 0 — по нарастающему, а для CPOL = 1 — по спадающему фронту).  1 — обработка производится по заднему фронту импульсов сигнала SCK                       |

Таблица. 10.4. Задание режима передачи данных

Соответствующие этим режимам форматы обмена данными через SPI приведены на **Рис. 10.5** и **10.6** (передача ведется от старшего разряда к младшему).

Частота тактового сигнала SCK и, соответственно, скорость передачи данных по интерфейсу определяются состоянием разрядов SPR1:SPR0 регистра SPCR (см. Табл. 10.5). Разумеется, речь идет о микроконтроллере, работающем в режиме Master, т.к. именно он является источником тактового сигнала. Для устройства, находящегося в режиме Slave, состояние этих разрядов безразлично.



*Puc. 10.5.* Передача данных при CPHA = 0 и DORD = 0



*Puc. 10.6.* Передача данных при CPHA = 1 и DORD = 0

Таблица. 10.5. Задание частоты тактового сигнала SCK

| SPR1 | SPR0 | Частота сигнала SCK   |
|------|------|-----------------------|
| 0    | 0    | F <sub>CLK</sub> /4*  |
| 0    | 1    | F <sub>CLK</sub> /16  |
| 1    | 0    | F <sub>CLK</sub> /64  |
| 1    | 1    | F <sub>CLK</sub> /128 |

<sup>\*</sup>  $F_{\rm CLK}$  — тактовая частота микроконтроллера.

#### 10.4. Использование вывода F65

Вообще этот вывод предназначен для выбора активного ведомого устройства и в режиме Slave всегда является входом. При подаче на него напряжения НИЗКОГО уровня модуль SPI активируется и вывод MOSI переключается в режим вывода данных (если это задано пользователем). Остальные выводы модуля SPI являются в этом режиме входами. А при подаче на вывод  $\overline{SS}$  напряжения ВЫСОКОГО уровня все выводы модуля SPI переключаются в режим ввода данных. При этом модуль переходит в неактивное состояние и прием данных не производится.

Следует помнить, что каждый раз, когда на вывод  $\overline{SS}$  подается напряжение ВЫСОКОГО уровня, происходит сброс модуля SPI. Соответственно, если изменение состояния этого вывода произойдет во время передачи данных, и прием и передача немедленно прекратятся, а передаваемый и принимаемый байты будут потеряны.

Если же микроконтроллер находится в режиме Master (разряд MSTR регистра SPCR установлен в «1»), направление передачи данных через вывод SS определяется пользователем. Если вывод сконфигурирован как выход, он работает как линия вывода общего назначения и не влияет на работу модуля SPI. Если же он сконфигурирован как вход, то для обеспечения нормальной работы модуля SPI на него должен быть подан сигнал ВЫСОКОГО уровня. Дело в том, что подача на этот вход сигнала НИЗКОГО уровня от какой-либо внешней схемы будет воспринята модулем SPI как выбор данного микроконтроллера в качестве ведомого и, соответственно, начало передачи ему данных. Во избежание конфликта на шине система SPI в таких случаях выполняет следующие действия:

- 1. Флаг MSTR регистра SPCR сбрасывается, и микроконтроллер переключается в режим Slave. Как следствие, выводы MOSI и SCK начинают функционировать как входы.
- 2. Устанавливается флаг SPIF регистра SPSR, генерируя запрос на прерывание от SPI. Если прерывания от SPI разрешены и флаг I регистра SREG установлен в «1», происходит запуск подпрограммы обработки прерывания.

Таким образом, если ведущий микроконтроллер использует передачу данных, управляемую прерыванием, и существует вероятность подачи на вход  $\overline{SS}$  сигнала НИЗКОГО уровня, в подпрограмме обработки прерывания от SPI обязательно должна осуществляться проверка состояния флага MSTR. При обнаружении сброса этого флага он должен быть программно установлен обратно в «1» для обратного перевода микроконтроллера в режим Master.

### Глава 11. **Программирование** микроконтроллеров

#### 11.1. Общие сведения

При программировании микроконтроллера полученный в результате компиляции программы машинный код загружается в память программ, а требуемые данные заносятся в ЭСППЗУ (ЕЕРROM-память). Подавляющее большинство микроконтроллеров семейства поддерживает 2 режима программирования:

- режим параллельного программирования при высоком напряжении;
- режим программирования по последовательному каналу.

Исключение составляют лишь модели AT90S/LS2323 и AT90S/LS2343, в которых вместо режима параллельного программирования используется режим последовательного программирования при высоком напряжении, а также модель AT90C8534, программирование которой может быть произведено только в параллельном режиме. Под «высоким» напряжением здесь понимается управляющее напряжение (12B), подаваемое на вывод RESET микроконтроллера для перевода последнего в режим программирования. При этом независимо от режима программирование FLASH- и EEPROM-памяти осуществляется всегда побайтно.

В процессе программирования могут выполняться следующие операции:

- стирание кристалла (Chip erase);
- чтение/запись Flash-памяти программ;
- чтение/запись EEPROM-памяти данных;
- чтение/запись конфигурационных ячеек;
- чтение/запись ячеек защиты;
- чтение ячеек идентификатора;

Все модели микроконтроллеров поставляются со стертой памятью программ и памятью данных (во всех ячейках находится число \$FF) и пригодны к немедленному программированию.

#### 11.2. Защита кода и данных

Содержимое FLASH-памяти (памяти программ), а также содержимое EEPROM-памяти (память данных) может быть защищено от записи и/или чтения посредством программирования ячеек защиты (Lock Bits) LB1 и LB2. Возможные режимы защиты, соответствующие различным состояниям этих ячеек, приведены в Табл. 11.1.

|          | working 11.1. I OMINIO SUMITION |   |                                             |  |  |  |  |  |  |  |  |
|----------|---------------------------------|---|---------------------------------------------|--|--|--|--|--|--|--|--|
| Ячейкі   | і защиты                        |   | Ormonius                                    |  |  |  |  |  |  |  |  |
| № режима | ıa LB1 LB2                      |   | Описание                                    |  |  |  |  |  |  |  |  |
| 1        | 1                               | 1 | Защита кода и данных отключена              |  |  |  |  |  |  |  |  |
| 2        | 0                               | 1 | Последующая запись ЕГАSH и ЕЕРВОМ запрешена |  |  |  |  |  |  |  |  |

Запрещена как запись, так и чтение FLASH и EEPROM

Таблица 11.1. Режимы защиты

При использовании параллельного режима программирования (для AT90S/LS2323 и AT90S/LS2343 — последовательного программирования при высоком напряжении) в режимах 2 и 3 запрещается также изменение конфигурационных ячеек (см. далее). Поэтому включение защиты следует выполнять в самую последнюю очередь, после программирования остальных областей памяти микроконтроллера.

В исходном (незапрограммированном) состоянии в этих ячейках содержится «1», после программирования — «0». Стирание ячеек защиты (запись в них лог. «1») может быть произведено только при выполнении команды «Стирание кристалла», уничтожающей также содержимое FLASH- и EEPROM-памяти.

#### 11.3. Конфигурационные ячейки

Как следует из названия, конфигурационные ячейки (Fuse Bits) определяют ряд параметров конфигурации микроконтроллера. Эти ячейки расположены в отдельном адресном пространстве, доступном только при программировании. Состав этих ячеек зависит от конкретной модели микроконтроллера (в модели АТ90С8534 они вообще отсутствуют). Наличие той или иной ячейки в конкретном микроконтроллере можно определить по Табл. 11.2, в которой указаны состояния конфигурационных ячеек по умолчанию для всех моделей семейства (кроме АТ090С8534). Соответственно пустая ячейка таблицы означает, что в данном микроконтроллере эта конфигурационная ячейка отсутствует.

| Название | AT90S1200 1) | AT90S2313 <sup>1)</sup> | AT90S/LS2323 2) | AT90S/LS2343 2) | AT90S/LS2333 <sup>3)</sup><br>AT90S/LS4433 <sup>3)</sup> | AT90S/LS4434 <sup>3)</sup><br>AT90S/LS8535 <sup>3)</sup> | AT90S8414 <sup>1)</sup><br>AT90S8515 <sup>1)</sup> | Описание                                                           |
|----------|--------------|-------------------------|-----------------|-----------------|----------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------|
| SPIEN    | 0            | 0                       | 0               | 0               | 0                                                        | 0                                                        | 0                                                  | Разрешение/запрещение программирования по последовательному каналу |
| FSTRT    |              | 1                       | 0               |                 |                                                          | 1                                                        | 1                                                  | Управление таймером задержки сброса (см. главу 3)                  |
| RCEN     | 1            |                         |                 | 0               |                                                          |                                                          |                                                    | Разрешение/запрещение встроенного <i>RC</i> -генератора            |
| BODLEVEL |              |                         |                 |                 | 1                                                        |                                                          |                                                    | Уровень срабатывания схемы BOD (см. главу 3)                       |
| BODEN    |              |                         |                 |                 | 1                                                        |                                                          |                                                    | Включение/выключение схемы ВОD (см. главу 3)                       |
| CKSEL20  |              |                         |                 |                 | 010                                                      |                                                          |                                                    | Управление таймером задержки сброса (см. главу 3)                  |

Таблица 11.2. Конфигурационные ячейки микроконтроллеров семейства Classic

Для изменения содержимого конфигурационных ячеек используются специальные команды программирования. Команда «Стирание кристалла» (Chip Erase) на состояние этих ячеек не влияет.

#### 11.4. Идентификатор

Все микроконтроллеры фирмы «Atmel» имеют три 8-разрядные ячейки, содержимое которых позволяет идентифицировать устройство. Как и конфигурационные ячейки, ячейки идентификатора расположены в отдельном адресном пространстве, доступ к которому возможен только в режиме программирования. Однако в отличие от конфигурационных ячеек ячейки идентификатора, по понятным причинам, доступны только для чтения. Содержимое ячеек идентификатора для всех микроконтроллеров семейства приведено в Табл. 11.3.

<sup>1)</sup> Все конфигурационные ячейки доступны только в режиме параллельного программирования.

рования. <sup>2)</sup> Ячейка SPIEN недоступна в режиме программирования по последовательному каналу при низком напряжении.

<sup>3)</sup> Ячейка SPIEN недоступна в режиме программирования по последовательному каналу.

| Адрес | AT90S1200 | AT90S2313 | AT90S/LS2323 | AT90S/LS2343 | AT90S/LS2333 | AT90S/LS4433 | AT90S/LS4434 | AT90S/LS8535 | AT90S8414 | AT90S8515 | AT90C8534 | Описание                    |
|-------|-----------|-----------|--------------|--------------|--------------|--------------|--------------|--------------|-----------|-----------|-----------|-----------------------------|
| \$00  | \$1E      | \$1E      | \$1E         | \$1E         | \$1E         | \$1E         | \$1E         | \$1E         | \$1E      | \$1E      | \$1E      | Код производителя («Atmel») |
| \$01  | \$90      | \$91      | \$91         | \$91         | \$91         | \$92         | \$92         | \$93         | \$92      | \$93      | \$93      | Код объема FLASH-памяти*    |
| \$02  | \$01      | \$01      | \$02         | \$03         | \$05         | \$03         | \$02         | \$03         | \$01      | \$01      | \$04      | Код устройства              |

Таблица 11.3. Ячейки идентификатора микроконтроллеров семейства Classic

Как видно из таблицы, значение кода устройства (ячейка \$02) может совпадать для различных моделей семейства. Поэтому устройство можно идентифицировать только по совокупности значений ячеек \$01 и \$02, т.к. именно эта пара чисел является уникальной для каждого микроконтроллера.

Следует обратить внимание на то, что в режиме защиты № 3 (обе ячей-ки защиты запрограммированы) идентификатор доступен только в режиме параллельного программирования. При чтении ячеек \$00, \$01 и \$02 идентификатора в режиме последовательного программирования возвращаются значения \$00, \$01 и \$02 соответственно.

#### 11.5. Режим параллельного программирования

В этом режиме, как следует из его названия, от программатора к микроконтроллеру передаются одновременно все разряды кода команды или байта данных. Этот режим задействует большое число выводов микроконтроллера и, кроме того, требует использования дополнительного источника повышенного напряжения (12 В). В связи с этим программирование в параллельном режиме осуществляется специализированными программаторами. Основное применение этого режима — «прошивка» микроконтроллеров перед установкой их на плату в условиях массового производства.

Схема включения микросхем в режиме параллельного программирования приведена на **Puc. 11.1**. Назначение сигналов, присутствующих на выводах микроконтроллера в этом режиме, приведено в **Табл. 11.4** и **11.5**. Обращаем ваше внимание, что при последующем рассмотрении режима параллельного программирования выводы, указанные в **Табл. 11.4**, будут называться именами сигналов, присутствующих на этих выводах.

<sup>\*</sup> \$90 - 1 Кбайт, \$91 - 2 Кбайт, \$92 - 4 Кбайт, \$93 - 8 Кбайт



*Рис. 11.1.* Включение микроконтроллеров в режиме параллельного программирования

*Таблица 11.4.* Обозначение и функции выводов, используемых при программировании в параллельном режиме

| Сигнал  | Вывод  | Вх./Вых. | Назначение                                                                                                    |  |
|---------|--------|----------|---------------------------------------------------------------------------------------------------------------|--|
| RDY/BSY | PD1    | Вых.     | Состояние устройства:<br>0 — занято (выполняется предыдущая команда)<br>1 — готово к приему следующей команды |  |
| ŌĒ      | PD2    | Bx.      | Управление режимом работы шины данных PB7PB0: 0 — выход, 1 — вход                                             |  |
| WR      | PD3    | Bx.      | Сигнал записи (активный уровень — лог. «0»)                                                                   |  |
| BS      | PD4    | Bx.      | Выбор байта (0 — младший байт, 1 — старший байт)                                                              |  |
| XA0     | PD5    | Bx.      | Определяют действие, выполняемое по положительному                                                            |  |
| XA1     | PD6    | Bx.      | импульсу на выводе XTAL1 (см. Табл. 11.5)                                                                     |  |
| DATA    | PB7PB0 | Вх./Вых. | Двунаправленная шина данных                                                                                   |  |

Таблица 11.5. Функции сигналов ХАО и ХА1

| XA1 | XA0 | Действие, выполняемое по тактовому импульсу                                                     |  |
|-----|-----|-------------------------------------------------------------------------------------------------|--|
| 0   | 0   | Загрузка адреса ячейки памяти (младшего или старшего байта, в зависимости от уровня сигнала BS) |  |
| 0   | 1   | Загрузка данных                                                                                 |  |
| 1   | 0   | Загрузка команды                                                                                |  |
| 1   | 1   | Нет действия                                                                                    |  |

Временные диаграммы сигналов при программировании микроконтроллера в параллельном режиме представлены на **Рис. 11.2**, а значения параметров сигналов приведены в **Табл. 11.6**.



Puc. 11.2. Временная диаграмма сигналов при программировании в параллельном режиме

Таблица 11.6. Параметры сигналов при программировании в параллельном режиме

| Обозначение         | Параметр                                                                                              | min  | max | typ  | Ед.<br>изм. |
|---------------------|-------------------------------------------------------------------------------------------------------|------|-----|------|-------------|
| $V_{\mathrm{PP}}$   | Напряжение разрешения программирования                                                                | 11.5 |     | 12.5 | В           |
| $I_{\mathrm{PP}}$   | Ток, потребляемый от источника $+$ 12 В ( $V_{\rm PP}$ )                                              |      |     | 250  | мкА         |
| $t_{ m DVXH}$       | Задержка сигнала XTAL1 относительно момента установления сигналов управления и данных                 | 67   |     |      | нс          |
| $t_{ m XHXL}$       | Длительность сигнала XTAL1                                                                            | 67   |     |      | нс          |
| $t_{ m XLDX}$       | Время сохранения сигналов управления и данных относительно сигнала XTAL1                              | 67   |     |      | нс          |
| $t_{ m XLWL}$       | Задержка сигнала WR относительно сигнала XTAL1                                                        | 67   |     |      | нс          |
| $t_{ m BVWL}$       | Задержка сигнала $\overline{\mathrm{WR}}$ относительно момента установления сигнала BS                | 67   |     |      | нс          |
| $t_{\mathrm{RHBX}}$ | Время сохранения сигнала BS относительно заднего фронта сигнала RDY/BSY                               | 67   |     |      | нс          |
| $t_{ m WLWH}$       | Длительность сигнала WR                                                                               | 67   |     |      | нс          |
| $t_{ m WHRL}$       | Задержка появления сигнала $RDY/\overline{BSY}$ относительно заднего фронта сигнала $\overline{WR}^*$ |      | 20  |      | нс          |

Таблица 11.6 (окончание)

| Обозначение           | Параметр                                                                                                        | min | max | typ | Ед.<br>изм. |
|-----------------------|-----------------------------------------------------------------------------------------------------------------|-----|-----|-----|-------------|
| $t_{ m WLRH}$         | Задержка снятия сигнала $RDY/\overline{BSY}$ относительно переднего фронта сигнала $\overline{WR}^*$            | 0.5 | 0.7 | 0.9 | мс          |
| $t_{ m XLOL}$         | Задержка сигнала                                                                                                | 67  |     |     | нс          |
| $t_{ m OLDV}$         | Время установления сигналов данных относительно переднего фронта сигнала $\overline{\text{OE}}$                 |     | 20  |     | нс          |
| $t_{ m OHDZ}$         | Задержка переключения шины данных в третье состояние относительно заднего фронта сигнала $\overline{\text{OE}}$ |     |     | 20  | нс          |
| t <sub>WLWH_CE</sub>  | Длительность сигнала $\overline{ m WR}$ для команды «Стирание кристалла»                                        | 5   | 10  | 15  | МС          |
| t <sub>WLWH_PFB</sub> | Длительность сигнала WR при программировании конфигурационных ячеек                                             | 1.0 | 1.5 | 1.8 | мс          |

<sup>\*</sup> Если длительность импульса  $\overline{WR}$  больше величины  $f_{WLRH}$ , то сигнал  $RDY/\overline{BSY}$  не вырабатывается.

Собственно процесс программирования, в общих чертах, состоит из многократного выполнения следующих операций:

- загрузка команды;
- загрузка адреса ячейки (два байта);
- загрузка содержимого ячейки;
- выполнение команды.

Последовательность подачи сигналов на выводы микроконтроллера для выполнения каждой из перечисленных операций приведена в **Табл. 11.7**.

Таблица 11.7. Базовые операции программирования в параллельном режиме

| №№ | Название операции                   | Действия                                                                                                                                                                                                                                                 |
|----|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1  | Загрузка команды                    | <ol> <li>Установить выводы XA1, XA0 в состояние «10» (загрузка команды).</li> <li>Подать на вывод BS напряжение лог. «0».</li> <li>Выставить на шину DATA код команды (см. Табл. 11.7).</li> <li>Подать на вывод XTAL1 положительный импульс.</li> </ol> |
| 2  | Загрузка адреса (млад-<br>ший байт) | <ol> <li>Установить выводы XA1, XA0 в состояние «00» (загрузка адреса).</li> <li>Подать на вывод BS напряжение лог. «0».</li> <li>Выставить на шину DATA младший байт адреса.</li> <li>Подать на вывод XTAL1 положительный импульс.</li> </ol>           |
|    | Загрузка адреса (старший байт)      | <ol> <li>Установить выводы XA1, XA0 в состояние «00» (загрузка адреса).</li> <li>Подать на вывод BS напряжение лог. «1».</li> <li>Выставить на шину DATA старший байт адреса.</li> <li>Подать на вывод XTAL1 положительный импульс.</li> </ol>           |

Таблица 11.7 (окончание)

| №№ | Название операции                                  | Действия                                                                                                                                                                                                          |  |  |
|----|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 3  | Загрузка данных<br>(младший или стар-<br>ший байт) | <ol> <li>Установить выводы XA1, XA0 в состояние «01» (загрузка данных).</li> <li>Выставить на шину DATA содержимое байта данных.</li> <li>Подать на вывод XTAL1 положительный импульс.</li> </ol>                 |  |  |
| 4  | Запись ячейки памяти (младший байт)                | Подать на вывод BS напряжение лог. «0».     Подать на вывод WR отрицательный импульс; при этом на выводе RDY/BSY появляется сигнал НИЗКОГО уровня.     Ждать появления на выводе RDY/BSY сигнала ВЫСОКОГО уровня. |  |  |
|    | Запись ячейки памяти (старший байт)                | Подать на вывод BS напряжение лог. «1».     Подать на вывод WR отрицательный импульс; при этом на выводе RDY/BSY появляется сигнал НИЗКОГО уровня.     Ждать появления на выводе RDY/BSY сигнала ВЫСОКОГО уровня. |  |  |

В рассматриваемом режиме используется 9 команд, коды которых приведены в Табл. 11.8.

Таблица 11.8. Команды программирования в параллельном режиме

| Код команды | Описание                                     |
|-------------|----------------------------------------------|
| 1000 0000   | Стирание кристалла                           |
| 0100 0000   | Запись конфигурационных ячеек                |
| 0010 0000   | Запись ячеек защиты                          |
| 0001 0000   | Запись FLASH-памяти                          |
| 0001 0001   | Запись EEPROM-памяти                         |
| 0000 1000   | Чтение идентификатора                        |
| 0000 0100   | Чтение конфигурационных ячеек и ячеек защиты |
| 0000 0010   | Чтение FLASH-памяти                          |
| 0000 0011   | Чтение EEPROM-памяти                         |

### 11.5.1. Переключение в режим параллельного программирования

Перед началом программирования необходимо перевести микроконтроллер в режим программирования. Для этого необходимо выполнить следующие действия (см. **Рис. 11.3**):

- 1. Подать на микроконтроллер напряжение питания (диапазон допустимых значений см. Приложение III).
- 2. Подать на выводы RESET и BS напряжение НИЗКОГО уровня на время не менее 100 нс.



Puc. 11.3. Переключение микроконтроллера в режим параллельного программирования

3. Подать напряжение 11.5...12.5 В на вывод RESET и удерживать сигнал НИЗКОГО уровня на выводе BS в течение, как минимум, 100 нс. Любая активность на выводе BS в течение этого времени приведет к тому, что микроконтроллер не перейдет в режим программирования.

#### 11.5.2. Стирание кристалла

Команда «Стирание кристалла» (Chip Erase) должна выполняться перед каждым перепрограммированием микроконтроллера. Данная команда полностью уничтожает содержимое FLASH- и EEPROM-памяти, а затем сбрасывает ячейки защиты (записывает в них «1»). Однако на состояние конфигурационных ячеек данная команда не влияет. Другой особенностью выполнения этой команды является отсутствие генерации сигнала RDY/BSY.

Для выполнения команды «Стирание кристалла» необходимо выполнить следующие действия (см. **Рис. 11.4**):

- 1. Установить выводы XA1, XA0 в состояние «10» (загрузка команды).
- 2. Подать на вывод BS напряжение лог. «0».
- 3. Выставить на шину DATA код команды « $1000\ 0000$ ».
- 4. Подать на вывод XTAL1 положительный импульс.
- 5. Подать на вывод  $\overline{\text{WR}}$  отрицательный импульс длительностью  $t_{\text{WLWH CE}}$  (значение параметра  $t_{\text{WLWH CE}}$  приведено в **Табл. 11.6**).



Рис. 11.4. Временные диаграммы при выполнении команды «Стирание кристалла»

#### 11.5.3. Программирование FLASH-памяти

#### Запись FLASH-памяти

Запись FLASH-памяти производится в следующей последовательности (реализация каждого этапа приведена в **Табл. 11.7**):

- 1. Загрузить команду «Запись FLASH-памяти» (Write FLASH) (код «0001 0000»).
- 2. Загрузить старший байт адреса.
- 3. Загрузить младший байт адреса.
- 4. Загрузить младший байт данных.
- 5. Записать младший байт данных.
- 6. Загрузить старший байт данных.
- 7. Записать старший байт данных.

Временные диаграммы, иллюстрирующие процесс записи ячейки Flash-памяти, приведены на **Рис. 11.5**.

Помните, что загруженные код команды и адрес ячейки сохраняются в микроконтроллере до следующей загрузки новой команды или, соответственно, нового адреса. Из этого следует, что:

- 1. При программировании участка памяти команду необходимо загружать только один раз.
- 2. Старший байт адреса необходимо загружать только при переходе к новому 256-байтному блоку памяти.

Кроме того, не требуется записывать значение «\$FF», поскольку оно уже находится в ячейках памяти после выполнения команды «Стирание кристалла».



Puc. 11.5. Запись ячейки FLASH-памяти

Следование этим рекомендациям позволит значительно ускорить процесс программирования.

#### Чтение FLASH-памяти

Для чтения содержимого FLASH-памяти необходимо выполнить следующие действия (реализация каждого этапа приведена в **Табл. 11.7**):

1. Загрузить команду «Чтение FLASH-памяти» (Read FLASH) (код «0000 0010»).

- 2. Загрузить старший байт адреса.
- 3. Загрузить младший байт адреса.
- 4. Установить ОЕ и BS в «0», после этого с шины данных DATA можно будет считать значение младшего байта содержимого ячейки памяти.
- 5. Установить BS в «1», после этого с шины данных DATA можно будет считать значение старшего байта содержимого ячейки памяти.
- 6. Установить F100 в «1».

#### 11.5.4. Программирование EEPROM-памяти

#### Запись EEPROM-памяти

Запись EEPROM-памяти выполняется аналогично записи FLASH-памяти (реализация каждого этапа приведена в **Табл. 11.7**):

- 1. Загрузить команду «Запись EEPROM-памяти» (Write EEPROM) (код «0001 0001»).
- 2. Загрузить старший байт адреса (только при программировании моделей с объемом EEPROM-памяти, равным 512 байт).
- 3. Загрузить младший байт адреса.
- 4. Загрузить младший байт данных.
- 5. Записать младший байт данных.

#### Чтение EEPROM-памяти

Для чтения содержимого EEPROM-памяти необходимо выполнить следующие действия (реализация каждого этапа приведена в **Табл. 11.7**):

- 1. Загрузить команду «Чтение EEPROM-памяти» (Read EEPROM) (код « $0000\ 0011$ »).
- 2. Загрузить старший байт адреса (только при программировании моделей с объемом EEPROM-памяти, равным 512 байт).
- 3. Загрузить младший байт адреса.
- 4. Установить  $\overline{\rm OE}$  и BS в «0», после этого с шины данных DATA можно будет считать содержимое ячейки памяти.
- 5. Установить ОЕ в «1».

#### 11.5.5. Конфигурирование микроконтроллера

#### Программирование конфигурационных ячеек

Программирование конфигурационных ячеек выполняется в следующей последовательности (реализация каждого этапа приведена в **Табл. 11.7**):

- 1. Загрузить команду «Запись конфигурационных ячеек» (Write fise bits) (код «0100 0000»).
- 2. Загрузить байт данных. Каждой конфигурационной ячейке соответствует определенный разряд этого байта. Это соответствие для всех имеющихся в моделях семейства конфигурационных ячеек приведено в Табл. 11.9. Если в разряде содержится «0», выполняется программирование соответствующей ячейки, если «1» ее сброс. Неиспользуемые разряды при программировании должны быть установлены в «1».
- 3. Подать на вывод  $\overline{\text{WR}}$  отрицательный импульс длительностью  $t_{\text{WLWH\_PFB}}$  (значение параметра  $t_{\text{WLWH\_PFB}}$  приведено в **Табл. 11.6**).

При программировании конфигурационных ячеек так же, как и при выполнении команды «Стирание кристалла» (Chip Erase), отсутствует генерация сигнала  $RDY/\overline{BSY}$ .

| Ячейки   |   |   |   | Разряды ба | йта данных |   |   |   |
|----------|---|---|---|------------|------------|---|---|---|
| лчеики   | 7 | 6 | 5 | 4          | 3          | 2 | 1 | 0 |
| SPIEN    |   |   | • |            |            |   |   |   |
| FSTRT    |   |   |   |            |            |   |   | • |
| RCEN     |   |   |   |            |            |   |   | • |
| BODLEVEL |   |   |   | •          |            |   |   |   |
| BODEN    |   |   |   |            | •          |   |   |   |
| CKSEL2   |   |   |   |            |            | • |   |   |
| CKSEL1   |   |   |   |            |            |   | • |   |
| CKSEL0   |   |   |   |            |            |   |   | • |

Таблица 11.9. Соответствие разрядов байта данных конфигурационным ячейкам

#### Программирование ячеек защиты

Программирование ячеек защиты выполняется аналогично программированию конфигурационных ячеек (реализация каждого этапа приведена в **Табл. 11.7**):

- 1. Загрузить команду «Запись ячеек защиты» (Write lock bits) (код «0010 0000»).
- 2. Загрузить байт данных. Ячейке LB1 соответствует 1-й разряд этого байта, а ячейке LB2 2-й разряд. Для программирования ячейки соответствующий разряд должен быть сброшен в «0». Неиспользуемые разряды должны быть всегда установлены в «1».
- 3. Записать младший байт данных.

#### Чтение конфигурационных ячеек и ячеек защиты

Для выполнения этой операции необходимо выполнить следующие действия (реализация каждого этапа приведена в **Табл. 11.7**):

- 1. Загрузить команду «Чтение конфигурационных ячеек и ячеек защиты» (Read fusc and lock bits) (код «0000 0100»).
- 2. Установить OE и BS в «0», после этого с шины данных DATA можно будет считать 8-разрядное число, состояние разрядов которого соответствует состоянию ячеек:
  - 7-й разряд ячейка защиты LB1;
  - 6-й разряд ячейка защиты LB2;
  - остальные разряды конфигурационные ячейки согласно Табл. 11.9.
- 3. Установить ОЕ в «1».

#### Чтение ячеек идентификатора

Чтение ячеек идентификатора осуществляется в следующей последовательности (реализация каждого этапа приведена в **Табл. 11.7**):

- 1. Загрузить команду «Чтение ячеек идентификатора» (Read signature) (код « $0000\ 1000$ »).
- 2. Загрузить младший байт адреса (\$00 \$02).
- 3. Установить  $\overline{OE}$  и BS в «0», после этого с шины данных DATA можно будет считать содержимое выбранной ячейки идентификатора.
- 4. Установить  $\overline{OE}$  в «1».

# 11.6. Режимы последовательного программирования

Как уже было сказано, микроконтроллерами AVR поддерживаются два режима последовательного программирования. При этом первый — режим последовательного программирования при высоком напряжении — поддерживается только моделями AT90S/LS2323 и AT90S/LS2343 и является аналогом режима параллельного программирования остальных моделей. Второй же режим, называемый также режимом программирования по последовательному каналу, поддерживается всеми моделями семейства (за исключением AT90C8534).

# 11.6.1. Режим последовательного программирования при высоком напряжении (модели AT90S/LS2323 и AT90S/LS2343)

Этот режим является аналогом режима параллельного программирования остальных моделей, требует дополнительного источника повышенно-

го напряжения (12 В) и применяется для программирования микроконтроллеров перед установкой их на плату.

Схема включения микросхем в этом режиме приведена на Рис. 11.6.



Puc. 11.6. Включение моделей AT90S/LS2323 и AT90S/LS2343 в режиме последовательного программирования при высоком напряжении

Временные диаграммы сигналов микроконтроллера при программировании представлены на **Рис. 11.7**, а значения параметров сигналов приведены в **Табл. 11.10**.



Puc. 11.7. Временные диаграммы сигналов в режиме последовательного программирования при высоком напряжении

*Таблица 11.10.* Параметры сигналов в режиме последовательного программирования при высоком напряжении

| Обозначение       | Параметр                                                                                                           | min | typ | max | Ед. изм. |
|-------------------|--------------------------------------------------------------------------------------------------------------------|-----|-----|-----|----------|
| t <sub>SHSL</sub> | Длительность положительного импульса сигнала SCI (XTAL1/PB3)                                                       | 100 |     |     | нс       |
| t <sub>SLSH</sub> | Длительность отрицательного импульса сигнала SCI (XTAL1/PB3)                                                       | 100 |     |     | нс       |
| t <sub>IVSH</sub> | Задержка переднего фронта сигнала SCI (XTAL1/PB3) относительно момента установления сигналов SDI (PB0) и SII (PB1) | 50  |     |     | нс       |
| $t_{ m SHIX}$     | Время удержания сигналов SDI (РВ0) и SII (РВ1) относительно переднего фронта сигнала SCI (ХТАL1/РВ3)               | 50  |     |     | нс       |

Таблица 11.10 (окончание)

| Обозначение           | Параметр                                                                                              | min | typ | max | Ед. изм. |
|-----------------------|-------------------------------------------------------------------------------------------------------|-----|-----|-----|----------|
| $t_{ m SHOV}$         | Задержка момента установления сигнала SDO (PB2) относительно переднего фронта сигнала SCI (XTAL1/PB3) | 10  | 16  | 32  | нс       |
| t <sub>WLWH_CE</sub>  | Период ожидания после 3-й посылки команды «Стирание кристалла»                                        | 5   | 10  | 15  | мс       |
| t <sub>WLWH_PFB</sub> | Период ожидания после 3-й посылки команды «Запись конфигурационных ячеек»                             | 1.0 | 1.5 | 1.8 | МС       |

Для перевода микроконтроллера в режим программирования необходимо выполнить следующие действия:

- 1. Подать напряжение питания (4.5...5.5 В) на микроконтроллер.
- 2. Подать на выводы RESET и BS сигнал НИЗКОГО уровня на время не менее 100 нс.
- 3. Если конфигурационная ячейка RCEN не запрограммирована («1»), то:
  - подать на вывод XTAL1/PB3 не менее 4 импульсов длительностью больше или равной 100 нс.
  - подать на вывод XTAL1/РВ3 сигнал НИЗКОГО уровня;
  - выждать не менее 100 нс.
  - В противном случае («0») просто подать на вывод XTAL1/ PB3 сигнал НИЗКОГО уровня и выждать не менее 4 мкс.
- 4. Подать напряжение 12 В на вывод RESET и выждать не менее 100 нс перед изменением состояния вывода PB3. Первую команду можно будет посылать не ранее чем через 8 мкс.

Выключение микроконтроллера после его программирования выполняется в следующей последовательности:

- 1. Подать на вывод XTAL1/ РВ3 сигнал НИЗКОГО уровня.
- 2. Подать на вывод  $\overline{\text{RESET}}$  сигнал ВЫСОКОГО уровня.
- 3. Отключить напряжение питания от микроконтроллера.

Всего в этом режиме имеется 15 команд, каждая из которых содержит от двух до четырех 11-разрядных посылок. Передача команд, а также вывод результатов их выполнения осуществляется от старшего разряда к младшему. Как входные, так и выходные данные «защелкиваются» по нарастающему фронту тактового сигнала (см. **Рис. 11.8**).

Формат всех команд приведен в **Табл. 11.11**. Там же помещены пояснения по применению той или иной команды.

Таблица 11.11. Команды режима последовательного программирования при высоком напряжении

|                                              |     |                                 | Формат                        | Формат команды         |                | !                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------|-----|---------------------------------|-------------------------------|------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Название команды                             |     | 1-я посылка                     | 2-я посылка                   | 3-я посылка            | 4-я посылка    | Замечания                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                              | PB0 | 0_1000_0000_00                  | 00_0000_0000_0                | 0_0000_0000_0          | 00_0000_0000_0 | 0_0000_0000_00 Между 3-й и 4-й посылками требуется                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Стирание кристалла                           | PB1 | 0_0100_1100_00                  | 0_0110_0100_00                | 0_0110_1100_00         | 0_0100_1100_00 | 0_0100_1100_00 выдержать паузу длительностью                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                              | PB2 | xx_xxxx_xxxx_x                  | xx_xxxx_xxxx_x                | xx_xxxx_xxxx_x         | X_XXXX_XXX XX  | <sup>t</sup> wlwH_CE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Загрузка адреса ячейки                       | PB0 | 0_0001_0000_00                  | 0_0000_00aa_00                | 00 <b>~qqqq~qqqq</b> 0 |                | Повторить 2-ю посылку при переходе                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| FLASH-памяти                                 | PB1 | 0_0100_1100_00                  | 0_0001_1100_00                | 0_0000_1100_00         |                | к новому 226-оаитному олоку памяти.<br>Повторить 3-ю посылку для кажлого                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| при записи                                   | PB2 | xx_xxxx_xxxx_x                  | xx_xxxx_xxxx_x                | xx_xxxx_xxxx_x         |                | нового адреса                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| i c                                          | PB0 | 0-1111-111-00                   | 00_0000_0000_0                | 00_0000_0000_0         |                | После 3-й посылки ждать появления на                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| запись младшего оаита<br>ячейки FLASH-памяти | PB1 | 0_0010_1100_00                  | 0_0110_0100_00                | 0_0110_1100_00         |                | выводе ГВ2 лог: «1».<br>Лля кажлой ячейки необхолимо повторить                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                              | PB2 | xx_xxxx_xxxx_x                  | xx_xxxx_xxxx_x                | 00_0000_0000_0         |                | команду полностью (все три посылки)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| i c                                          | PB0 | 00_1111_1111_0                  | 00_0000_0000_0                | 00_0000_0000_0         |                | После 3-й посылки ждать появления на                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| запись старшего оаита<br>ячейки FLASH-памяти | PB1 | 0_0010_1100_00                  | 0_0111_0100_00                | 0_0111_1100_00         |                | выводе РВ2 лог. «1».<br>Полностью (все три посылки) повторить                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                              | PB2 | xx_xxxx_xxxx_x                  | xx_xxxx_xxxx_x                | 00_0000_0000_0         |                | команду для каждой ячейки                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Загрузка адреса ячейки                       | PB0 | 0_0001_0010_00                  | 0_0000_00 <b>aa</b> _00       | 00 <b>~qqqq~qqqq</b> 0 |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| FLASH-памяти                                 | PB1 |                                 | 0_0100_1100_00 0_0001_1100_00 | 0_0000_1100_00         |                | повторить 2-ю и 3-ю посытки                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| при чтении                                   | PB2 | x_xxxx_xxxx_x                   | x_xxxx_xxxx_x                 | x_xxxx_xxxx_xx         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Птотпо м отпотитор                           | PB0 | 00_0000_0000_0                  | 00_0000_00000_0               |                        |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ттение младшего оаита<br>вчейки FLASH-памяти | PB1 | 0_0110_1000_00 00110_1100_00    | 0_0110_1100_00                |                        |                | полноствю (оос посылки) повторить команту пля кажпой ячейки                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                              | PB2 | x_xxxx_xxxx_xx                  | o_0000_000x_xx                |                        |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Отапиа станива байта                         | PB0 | 0_0000_0000_00                  | 0_0000_0000_00                |                        |                | присотаси (идпитоси едо) се тостиноп                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ячейки FLASH-памяти                          | PB1 | 0_0111_1000_00                  | 0_0111_1100_00                |                        |                | ттолноствю (оос посвятия) повторитв команлу пля кажпой ячейки                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                              | PB2 | xx_xxxx_xxxx_x                  | o_0000_000x_xx                |                        |                | The state of the s |
| Загрузка адреса ячейки                       | PB0 | PB0 0_0001_0001_00              | 00 <b>~qqqq~qqq</b> 0~0       |                        |                | Повтомит 7 го посттики над комполо                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| EEPROM-памяти                                | PB1 | 0_0100_1100_00   0_0000_1100_00 | 0_0000_1100_00                |                        |                | HOBOTO SITUECES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| при записи                                   | PB2 | PB2 x_xxxx_xxx xx xxx_xx        | x_xxxx_xxxx_x                 |                        |                | no de la constitución de la cons |

Таблица 11.11 (продолжение)

|                                  | Γ   |                                                |                                                  |                                                                                        |                      |                                                                                                                                |
|----------------------------------|-----|------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Незвение комент                  |     |                                                | Формат                                           | Формат команды                                                                         |                      | Зомоношия                                                                                                                      |
| пазвание команды                 |     | 1-я посылка                                    | 2-я посылка                                      | 3-я посылка                                                                            | 4-я посылка          | Самстания                                                                                                                      |
| :                                | PB0 | PB0 0_1111_111_00                              | 00_0000_0000_0                                   | 00_0000_0000_0                                                                         |                      | :                                                                                                                              |
| Запись ячейки<br>ЕЕ DP ОМ-намети | PB1 | 0_0010_1100_00                                 | 0_0110_0100_00                                   | 0_0110_1100_00                                                                         |                      | После 5-и посылки ждать появления                                                                                              |
| LLI NOW-HAMAIN                   | PB2 | xx_xxxx_xxxx_x                                 | xx_xxxx_xxxx_x                                   | 00_0000_0000_0                                                                         |                      | nd bbibogo i bz iroi. «I.»                                                                                                     |
| Загрузка адреса ячейки           | PB0 | 0_0000_0011_00                                 | 00 <b>qqqqqqq</b> 000                            |                                                                                        |                      | ·                                                                                                                              |
| EEPROM-памяти                    | PB1 | 0_0100_1100_00                                 | 0_0000_1100_00                                   |                                                                                        |                      | Повторить 2-ю посылку для каждого                                                                                              |
| при чтении                       | PB2 | xx_xxxx_xxx_x                                  | xx_xxxx_xxxx_x                                   |                                                                                        |                      |                                                                                                                                |
| Чтение содержимого               | PB0 | PB0 0_0000_0000_00                             | 00_0000_0000_0                                   |                                                                                        |                      | ·                                                                                                                              |
| ячейки                           | PB1 | 0_0110_1000_00 0_0110_1100_00                  | 0_0110_1100_00                                   |                                                                                        |                      | Повторить 2-ю посылку для каждого нового апреса                                                                                |
| EEPROM-памяти                    | PB2 | xx_xxxx_xxxx_x                                 | xx_x000_0000_0                                   |                                                                                        |                      | משליסים                                                                                                                        |
| Запись                           | PB0 | PB0 0_0100_0000_00 0_11S1_111F_00              | 0_11 <b>S</b> 1_111 <b>F</b> _00                 | 00-0000-0000-0                                                                         | 00_0000_0000_0       | 0_0000_0000_00 Между 3-й и 4-й посылками требуется                                                                             |
| конфигурационных                 | PB1 | 0_0100_1100_00                                 | 0_0100_1100_00 0_0010_1100_00                    | 0_0110_0100_00                                                                         | 0_0110_1100_00       | 0_0110_0100_00 0_01110_1100_00 выдержать паузу длительностью                                                                   |
| ячеек (АТ90S/LS2323)             | PB2 | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx         | x_xxxx_xxxx_x                                    | ANDWH_PPB XX_XXXX_XXXX_X XXXX_XXXX_XXXX_X XXXX_XXXX_XXXX_XXXX_XXXX_XXXX_XXXX_XXXX_XXXX | xx_xxxx_xxxx_x       | fwlwh_PFB                                                                                                                      |
| Запись                           | PB0 | 0_0100_0000_00                                 | 0_11 <b>S</b> 1_111 <b>R</b> _00                 | 00_0000_0000_0                                                                         | 00_0000_0000_0       | PB0   0_0100_0000_00   0_11 <b>s</b> 1_111 <b>R_</b> 00   0_0000_0000_00   0_0000_000_00   Между 3-й и 4-й посылками требуется |
| конфигурационных                 | PB1 | 0_0100_1100_00                                 | 0_0010_1100_00                                   | 0_0110_0100_00                                                                         | 0_0110_1100_00       | 0_0110_1100_00 выдержать паузу длительностью                                                                                   |
| ячеек (АТ90S/LS2343)             | PB2 | PB2 x_xxxx_xxxx_xx                             | xx_xxxx_xxxx_x                                   | xx_xxxx_xxxx_x                                                                         | X_XXXX_XXX /WLWH_PFB | fwlwh_PFB                                                                                                                      |
|                                  | PB0 | PB0 0_0010_0000_00 0 0_1111_1121_00 0_0000_000 | 0_1111_1121_00                                   | 00_0000_0000_0                                                                         | 00_0000_0000_0       | , A                                                                                                                            |
| Запись ячеек защиты              | PB1 | 0_0100_1100_00                                 | 0_0100_1100_00   0_0010_1100_00   0_0110_0100_00 | 0_0110_0100_00                                                                         | 0_0110_1100_00       | После 4-и посылки ждать появления на въвсе РВ2 пог «1»                                                                         |
|                                  | PB2 | PB2 x_xxxx_xxxx_xx x_xxxx_xxxx_xx xxxx_xxx     | x_xxxx_xxxx_x                                    | xx_xxxx_xxxx_x                                                                         | 00_0000_0000_0       |                                                                                                                                |
| Чтение конфиг. ячеек             | PB0 | PB0 0_0000_0100_00 0_0000_0000_00              | 0_0000_0000_0                                    | 00_0000_0000_0                                                                         |                      |                                                                                                                                |
| и ячеек защиты                   | PB1 | PB1 0_0100_1100_00 0_0111_1000_00              | 0_0111_1000_00                                   | 0_0111_1100_00                                                                         |                      |                                                                                                                                |
| (AT90S/LS2323)                   | PB2 | xx_xxxx_xxx_x                                  | xx_xxxx_xxxx_x                                   | $1_2Sxx_xxFx_x$                                                                        |                      |                                                                                                                                |
| Чтение конфиг. ячеек             | PB0 | 0_0000_0100_00                                 | 00_0000_0000_0                                   | 00-0000-0000-0                                                                         |                      |                                                                                                                                |
| и ячеек защиты                   | PB1 | 0_0100_1100_00                                 | 0_0111_1000_00                                   | 0_0111_1100_00                                                                         |                      |                                                                                                                                |
| (AT90S/LS2343)                   | PB2 | PB2 x_xxxx_xxxx_xx                             | xx_xxxx_xxxx_x                                   | 1_2Sxx_xxRx_xx                                                                         |                      |                                                                                                                                |

# Таблица 11.11 (окончание)

| типомол опповось Н                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |                                                                | Формат                  | Оормат команды                                                                                                        |                | Замонония                                                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------------------------------------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------|
| ттазвание моманды                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     | 1-я посылка                                                    | 2-я посылка             | 3-я посылка                                                                                                           | 4-я посылка    | Оаметания                                                |
| ļ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PB0 | 0_0001000_00                                                   | 00 <b>~qq</b> 00~0000~0 | 0 00 <sup>-</sup> 0000 <sup>-</sup> 0000 <sup>-</sup> 0 00 <sup>-</sup> <b>qq</b> 00 <sup>-</sup> 0000 <sup>-</sup> 0 | 00_0000_0000_0 | 7                                                        |
| чтение ячеек<br>илентификатора                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PB1 | PB1 0_0100_1100_00 0                                           | 0_0000_1100_00          | 0_0000_1100_00  0_0110_1000_00  0_0110_1100_0                                                                         | 0_0110_1100_00 | повторить посылки 24 для каждои<br>вчейки илентификатора |
| a Journal of the Control of the Cont | PB2 | PB2 xxxxx_xxxx_xx xxxx_xx xxxx_xx xxxx_xx xxxx_xx 0_0000000xxx | x_xxxx_xxxx_xx          | xx_xxxx_xxxx_x                                                                                                        | o_0000_000x_xx |                                                          |

Расшифровка условных обозначений, используемых в таблице:

а — разряды старшего байта адреса;

b — разряды младшего байта адреса;

і — посылаемые в микроконтроллер данные;

о — считываемые из микроконтроллера данные;

I, 2 — ячейки защиты LB1 и LB2 соответственно; x -состояние разряда безразлично;

 $\mathbf{F}-$  конфигурационная ячейка FSTRT;  ${f R}-$ конфигурационная ячейка RCEN;  ${f S}-$ конфигурационная ячейка SPIEN.



Рис. 11.8. Синхронизация данных при программировании

#### 11.6.2. Программирование по последовательному каналу

В этом режиме программирование памяти программ и данных осуществляется через последовательный интерфейс SPI. Данный режим используется, как правило, для программирования (перепрограммирования) микроконтроллера непосредственно в системе (ISP, In System Programming). Наличие этого режима является одним из важнейших достоинств микроконтроллеров AVR, т.к. он позволяет значительно упростить и удешевить модернизацию программного обеспечения.

Схема включения микросхем в режиме программирования по последовательному каналу приведена на **Puc. 11.9**.



Puc. 11.9. Включение микроконтроллеров в режиме программирования по последовательному каналу

Временные диаграммы сигналов при программировании микроконтроллеров в рассматриваемом режиме представлены на **Рис. 11.10** значения параметров сигналов приведены в **Табл. 11.12**.



Puc. 11.10. Синхронизация данных при программировании по последовательному каналу

*Таблица 11.12.* Параметры сигналов при программировании по последовательному каналу

| Обозначение           | Параметр                                                                      |                               | min                     | typ | max | Ед. изм. |
|-----------------------|-------------------------------------------------------------------------------|-------------------------------|-------------------------|-----|-----|----------|
| $1/t_{\rm CLCL}$      | Частота тактового сигнала ( $V_{\rm CC} = 2.76.0$                             | B)                            | 0                       |     | 4   | МГц      |
| $t_{\rm CLCL}$        | Период тактового сигнала ( $V_{\rm CC} = 2.76.0$                              | B)                            | 250                     |     |     | нс       |
| 1/t <sub>CLCL</sub>   | Частота тактового сигнала                                                     | AT90S1200                     | 0                       |     | 12  | МГш      |
| 1/1CLCL               | $(V_{\rm CC} = 4.06.0 \text{ B})$                                             | остальные                     | 0                       |     | 8   | WIII     |
| t <sub>CLCL</sub>     | Период тактового сигнала                                                      | AT90S1200                     | 83.3                    |     |     | нс       |
| *CLCL                 | $(V_{\rm CC} = 4.06.0 \text{ B})$                                             | остальные                     | 125                     |     |     | пс       |
| t <sub>SHSL</sub>     | Длительность положительного импульса                                          | AT90S1200                     | 4t <sub>CLCL</sub>      |     |     | нс       |
| 'SHSL                 | сигнала SCK                                                                   | остальные                     | $2t_{CLCL}$             |     |     | пс       |
| $t_{\rm SLSH}$        | Длительность отрицательного импульса                                          | AT90S1200                     | $t_{\rm CLCL}$          |     |     | нс       |
| <sup>1</sup> SLSH     | сигнала SCK                                                                   | остальные                     | $2t_{CLCL}$             |     |     | nc nc    |
| t <sub>OVSH</sub>     | Задержка нарастающего фронта сигнала<br>SCK относительно установления сигнала | AT90S1200                     | $1.25t_{\mathrm{CLCL}}$ |     |     | нс       |
| <sup>1</sup> OVSH     | MOSI                                                                          | остальные                     | $t_{\mathrm{CLCL}}$     |     |     | пс       |
| t                     | Время удержания сигнала MOSI<br>относительно нарастающего фронта              | AT90S1200                     | $2.5t_{\mathrm{CLCL}}$  |     |     | 110      |
| t <sub>SHOX</sub>     | сигнала SCK                                                                   | остальные                     | $2t_{\mathrm{CLCL}}$    |     |     | нс       |
| t <sub>SLIV</sub>     | Задержка установления сигнала MISO отн<br>спадающего фронта сигнала SCK       | осительно                     | 10                      | 16  | 32  | нс       |
|                       |                                                                               | $V_{\rm CC} = 3.2 \; {\rm B}$ | 18                      |     |     |          |
|                       | Период ожидания после команды                                                 | $V_{\rm CC} = 3.6 \; \rm B$   | 14                      |     |     | ] ,,,    |
| t <sub>WD_ERASE</sub> | Стирание кристалла                                                            | $V_{\rm CC} = 4.0 \; {\rm B}$ | 12                      |     |     | MC       |
|                       |                                                                               | $V_{\rm CC} = 5.0 \; \rm B$   | 8                       |     |     | ]        |
|                       |                                                                               | $V_{\rm CC} = 3.2 \; \rm B$   | 9                       |     |     |          |
| t                     | Период ожидания после записи ячейки                                           | $V_{\rm CC} = 3.6 \; \rm B$   | 7                       |     |     | 1 ,,,    |
| t <sub>WD_PROG</sub>  | FLASH- или EEPROM-памяти                                                      | $V_{\rm CC} = 4.0 \; {\rm B}$ | 6                       |     |     | МС       |
|                       |                                                                               | $V_{\rm CC} = 5.0 \; \rm B$   | 4                       |     |     | ]        |

Как и в рабочем режиме, при программировании по последовательному каналу микроконтроллеру требуется источник тактового сигнала. Соответственно этим источником может быть внешняя схема, выход которой подключен к выводу XTAL1 микроконтроллера, кварцевый резонатор, подключенный к выводам XTAL1 и XTAL2, либо встроенный RC-генератор. При этом обязательно должно выполняться следующее условие: длительность импульсов как НИЗКОГО, так и ВЫСОКОГО уровня сигнала SCK должна быть больше 2 периодов тактового сигнала микроконтроллера (для модели AT90S1200 — 1 и 4 периода соответственно).

Программирование осуществляется путем посылки 4-байтовых команд на вывод MOSI микроконтроллера. Результат выполнения команд чтения снимается с вывода MISO микроконтроллера. Передача команд и вывод результатов их выполнения осуществляется от старшего разряда к младшему. При этом «защелкивание» входных данных выполняется по нарастающему фронту сигнала SCK, а «защелкивание» выходных данных — по спадающему (см. Рис. 11.11).



Puc. 11.11. Временные диаграммы сигналов при программировании по последовательному каналу

Формат всех команд, используемых в этом режиме для программирования различных микроконтроллеров семейства, приведен в **Табл. 11.13**.

Таблица 11.13. Команды режима программирования по последовательному каналу

| Команта                                                  |                   | Формат    | Формат команды                    |                                         | Отисопио комопис                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------|-------------------|-----------|-----------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOMATIKA                                                 | 1-й байт          | 2-й байт  | 3-й байт                          | 4-й байт                                | Описание моманды                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Разрешение программирования                              | 1010 1100         | 0101 0011 | XXXX XXXX                         | XXXX XXXX                               | 1010         1100         0101         0011         xxxx         xxxx         xxxx         на выволе RESET присутствует сигнал НИЗКОГО           Уровня         уровня                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Стирание кристалла                                       | 1010 1100         | 100x xxxx | XXXX XXXX                         | 1010 1100 100x xxxx xxxx xxxx xxxx xxxx | Очистка содержимого Flash- и EEPROM-памяти. После посылки команды необходимо: 1. Выдержать паузу длительностью б <sub>мо. Евля</sub> в. 2. Подать на вывод RESET положительный импульс. 3. Выждать не менее 20 мс. 4. Послать команду Разрешение программирования.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Чтение FLASH-памяти                                      | 0010 <b>H</b> 000 | xxxx aaaa | वववव वववव                         | 0010 H000 xxxx aaaa bbbb bbbb oooo oooo | Чтение младшего ( $\mathbf{H}=0$ ) или старшего ( $\mathbf{H}=1$ ) байта памяти программ ( $0$ ), расположенного по апресу $\mathbf{a}.\mathbf{b}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Запись FLASH-памяти                                      | 0100 <b>H</b> 000 | xxxx aaaa | वववव वववव                         | 0100 H000 xxxx aaaa bbbb bbbb iiii iiii | Запись младшего ( $\mathbf{H}=0$ ) или старшего ( $\mathbf{H}=1$ ) байта ( $\mathbf{i}$ ) в память программ по адресу $\mathbf{a}$ : $\mathbf{b}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Чтение EEPROM-памяти                                     | 1010 0000         | XXXX XXX  | वववव वववव                         | 1010 0000 xxxx xxxa bbbb bbbb oooo oooo | Чтение содержимого ячейки (о) ЕЕРROМ-памяти по адресу а:b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Запись ЕЕРКОМ-памяти                                     | 1100 0000         | XXXX XXX  | वववव वववव                         | 1100 0000 xxxx xxxa bbbb bbbb iiii iiii | Запись значения (i) в ячейку EEPROM-памяти по апресу a:b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Чтение конфигурац.   AT90S/LS2323                        | 0101 1000         | XXXX XXXX | XXXX XXXX                         | 12Sx xxxF                               | A790S/LS233 0101 1000 $xxxx xxxx$ $xxxx xxxx$ 125x $xxx$ $Yxxx$ $Yxx$ $Yxxx$ $Yxx$ $Yx$ $Y$ |
| ячеек и ячеек защиты   AT90S/LS2343                      | 0101 1000         | xxxx xxxx |                                   | XXXX XXXX 12SX XXXR OHHBIX SPECK        | онных ячеек                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Чтение конфигурац. ячеек<br>(AT90S/LS2333, AT90S/LS4433) | 0101 0000         | XXXX XXXX | 0101 0000 xxxx xxxx xxxx xxxx 543 | xxS7 6543                               | Чтение состояния конфигурационных ячеек<br>(см. примечание к таблице)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Запись ячеек защиты                                      | 1010 1100         | 1111 1211 | XXXX XXXX                         | XXXX XXXX                               | 3апись ячеек защиты LB1 и LB2. Для программирования   3апись ячеек защиты LB1 и LB2. Для программирования   1111 1211   xxxx xxxx   xxxx xxxx   xyeйки соответствующий разряд 2-го байта должен быть   сброшен                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

Таблица 11.13 (окончание)

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                      |                                    |        |          |              |                |          |                  |      | (                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------|--------|----------|--------------|----------------|----------|------------------|------|------------------------------------------------------|
| 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                      |                                    |        | Φ        | ормат        | Формат команды | _        |                  |      |                                                      |
| NOMAHAA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                      | 1-й байт 2-й байт                  | йт     | 2-й б    | айт          | 3-й байт       |          | 4-й байт         | ийт  | Описание команды                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | AT90S/LS2323                                         |                                    |        |          |              |                |          |                  |      |                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | AT90S/LS4434 1010 1100 1011 111F xxxx xxxx xxxx xxxx | 1010                               | 100    | 1011     | 111 <b>F</b> | XXXX           | XXXX     | XXXX             | XX   |                                                      |
| Запись                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | AT90S/LS8535                                         |                                    |        |          |              |                |          |                  | ,, ( | озпись конфигурационных мчеек. Соответствие разрядов |
| конфиі урационных диеек                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | AT90S/LS2343                                         | 1010                               | 100    | 1011     | 111 <b>R</b> | XXXX           | XXXX     | XXXX             | XXX  | AT90S/LS2343 1010 1100 1101 1111 xxxx xxxx xxxx xxx  |
| NOO! W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | AT90S/LS2333                                         | 1010 1100 1017 6643 2000           | 100    | 7101     | 6513         | 22.22          | 22.22    | 22222            | 7    |                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | AT90S/LS4433                                         | 1 0 1 0 1                          | )<br>) | ,<br>TOT | 1<br>1<br>1  | <b>X</b>       | <b>Y</b> | \<br>\<br>\<br>\ | 3    |                                                      |
| Uтение ипентификатопа                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 80                                                   | 0011 0000 xxxx xxxx xxxx 0000 1100 | 000    | XXXX     | XXXX         | XXXX           | vyhh     |                  |      | Чтение ячейки идентификатора (0) с адресом b (только |
| To manufatting the control of the co |                                                      | H<br>H<br>D                        |        |          |              |                |          |                  | 8    | в режимах защиты №1 и №2, см. <b>Табл. 11.1</b> )    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                      |                                    |        |          |              |                |          |                  |      |                                                      |

Расшифровка условных обозначений, используемых в таблице:

- ${f a}$  разряды старшего байта адреса;
- $\mathbf{b}$  разряды младшего байта адреса;
- посылаемые в микроконтроллер данные;
- ${f 0}-{f c}$ читываемые из микроконтроллера данные;
  - х состояние разряда безразлично;
- I, 2 ячейки защиты LB1 и LB2 соответственно; F конфигурационная ячейка FSTRT;
  - $\mathbf{R}-$  конфигурационная ячейка RCEN;  $\mathbf{S}-$  конфигурационная ячейка SPIEN;
- 3 конфигурационная ячейка СКSEL0;
- 4 конфигурационная ячейка CKSELI;
- 5 конфигурационная ячейка СКЅЕL2;6 конфигурационная ячейка BODEN;
- 7 конфигурационная ячейка BODLEVEL.

#### Переключение в режим программирования

Для перевода микроконтроллера в режим программирования по последовательному каналу необходимо выполнить следующие действия:

- 1. Подать на микроконтроллер напряжение питания, при этом на выводах SCK и RESET должен присутствовать сигнал НИЗКОГО уровня. В некоторых случаях (если программатор не гарантирует установку сигнала SCK в «0» при подаче питания) после установки сигнала SCK в «0» необходимо подать на вывод RESET положительный импульс длительностью не менее двух периодов тактового сигнала микроконтроллера.
- 2. Если тактирование микроконтроллера осуществляется от внешней схемы, подать тактовый сигнал на вывод XTAL1.
- 3. Выждать не менее 20 мс.
- 4. Послать на вывод MOSI команду «Разрешение программирования» (Programming enable).

Для контроля прохождения команды при посылке 3-го байта возвращается значение 2-го байта (\$53). Если возвращаемое значение отлично от указанного, необходимо подать на вывод SCK положительный импульс и снова послать команду «Разрешение программирования» (Programming enable). Причем необходимо передавать все 4 байта команды. Отсутствие возврата числа \$53 после 32 попыток указывает на отсутствие связи между программатором и микросхемой либо на неисправность микросхемы.

После завершения программирования на вывод  $\overline{\text{RESET}}$  можно подать напряжение ВЫСОКОГО уровня для перевода микроконтроллера в рабочий режим либо выключить его. В последнем случае необходимо выполнить следующие действия:

- 1. Подать на вывод XTAL1 напряжение НИЗКОГО уровня, если тактирование микроконтроллера осуществляется от внешней схемы.
- 2. Подать на вывод  $\overline{\text{RESET}}$  напряжение ВЫСОКОГО уровня.
- 3. Отключить напряжение питания от микроконтроллера.

#### Управление процессом программирования

Программирование памяти программ и данных осуществляется побайтно путем посылки команд «Запись FLASH» (Write FLASH) и «Запись EEPROM» (Write EEPROM). В каждой команде одновременно содержится адрес изменяемой ячейки и записываемое значение.

При записи в ячейку памяти следует быть уверенным, что программирование предыдущей ячейки завершилось. Для этого существует два спосо-

ба. Первый (наиболее универсальный) способ — выдерживать между посылкой команд паузу длительностью не меньше  $t_{\rm WD\_PROG}$  (см. **Табл. 11.6**). Недостаток этого способа очевиден — увеличение времени программирования.

Второй способ заключается в контролировании содержимого ячейки после посылки команды записи:

- FLASH-память. До завершения записи ячейки при ее чтении возвращается значение «\$FF», а после завершения записанное значение;
- 2. EEPROM-память. Перед записью ячейки EEPROM-памяти автоматически выполняется стирание ее содержимого. Поэтому при чтении ячейки после посылки команды записи возвращаются значения:
  - Р1 до завершения цикла стирания;
  - Р2 после завершения цикла стирания;
  - записанное значение после завершения операции записи.

Значения P1 и P2 для различных моделей микроконтроллеров семейства приведены в **Табл. 11.14**.

*Таблица 11.14*. Значения, возвращаемые при записи EEPROM-памяти

| Модель                              | P1   | P2   |
|-------------------------------------|------|------|
| AT90S2313<br>AT90S4414<br>AT90S8515 | \$80 | \$7F |
| Остальные                           | \$00 | \$FF |

### Приложения

Приложение I. Сводная таблица микроконтроллеров AVR семейства Classic
Приложение II. Чертежи корпусов микроконтроллеров AVR семейства Classic
Приложение III. Электрические параметры микроконтроллеров AVR семейства

Classic

Приложение I. Сводная таблица микроконтроллеров AVR

|                                   | грамм<br>3У)                 | дан    | иять<br>ных<br>йт] | Ħ             |                              | источ  | 1-во<br>ников<br>ваний |         | Таймеры  |            |
|-----------------------------------|------------------------------|--------|--------------------|---------------|------------------------------|--------|------------------------|---------|----------|------------|
| Обозначение <sup>1)</sup>         | Память программ (FLASH-IIЗУ) | EEPROM | SRAM               | Кол-во команд | Кол-во линий<br>ввода/вывода | внутр. | внешн.                 | 8-pasp. | 16-pa3p. | сторожевой |
| AT90S1200-xxPw                    | 1                            | 64     | _                  | 89            | 15                           | 2      | 1                      | 1       | _        | •          |
| AT90S1200-xxSw                    | 1                            | 64     | _                  | 89            | 15                           | 2      | 1                      | 1       | _        | •          |
| AT90S1200-xxYw                    | 1                            | 64     | _                  | 89            | 15                           | 2      | 1                      | 1       | _        | •          |
| AT90S2313-xxPw                    | 2                            | 128    | 128                | 120           | 15                           | 8      | 2                      | 1       | 1        | •          |
| AT90S2313-xxSw                    | 2                            | 128    | 128                | 120           | 15                           | 8      | 2                      | 1       | 1        | •          |
| AT90LS2323-xxPw                   | 2                            | 128    | 128                | 120           | 3                            | 8      | 2                      | 1       | _        | •          |
| AT90LS2323-xxSw                   |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S2323-xxPw                    | 2                            | 128    | 128                | 120           | 3                            | 8      | 2                      | 1       | _        | •          |
| AT90S2323-xxSw                    |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90LS2343-xxPw                   | 2                            | 128    | 128                | 120           | 5                            | 1      | 1                      | 1       | _        | •          |
| AT90LS2343-xxSw                   |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S2343-xxPw                    | 2                            | 128    | 128                | 120           | 5                            | 1      | 1                      | 1       | _        | •          |
| AT90S2343-xxSw                    |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90LS2333-xxPw                   | 2                            | 128    | 128                | 120           | 20                           | 11     | 2                      | 1       | 1        | •          |
| AT90LS2323-xxAw                   |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S2333-xxPw<br>AT90S2333-xxAw  | 2                            | 128    | 128                | 120           | 20                           | 11     | 2                      | 1       | 1        | •          |
| AT90S2333-XXAW<br>AT90LS4433-XXPW |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90LS4433-xxAw                   | 4                            | 256    | 128                | 120           | 20                           | 11     | 2                      | 1       | 1        | •          |
| AT90LS4433-xxAw<br>AT90S4433-xxPw |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S4433-xxAw                    | 4                            | 256    | 128                | 120           | 20                           | 11     | 2                      | 1       | 1        | •          |
| AT90LS4434-xxPw                   |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90LS4434-xxJw                   | 4                            | 256    | 256                | 120           | 32                           | 14     | 2                      | 2       | 1        | •          |
| AT90LS4434-xxAw                   | '                            | 230    | 250                | 120           | 32                           | 11     | _                      | _       | 1        |            |
| AT90S4434-xxPw                    |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S4434-xxJw                    | 4                            | 256    | 256                | 120           | 32                           | 14     | 2                      | 2       | 1        | •          |
| AT90S4434-xxAw                    |                              |        |                    |               |                              |        | -                      | _       |          |            |

#### семейства Classic

|     | Интер | фейсы |                          | 10-разр.        |                                    |           | го<br>ания                                        | іая                             | 4)                    | Кор               | пус                  |
|-----|-------|-------|--------------------------|-----------------|------------------------------------|-----------|---------------------------------------------------|---------------------------------|-----------------------|-------------------|----------------------|
| ШИМ | SPI   | UART  | Аналоговый<br>компаратор | АЦП<br>[каналы] | Встроенный<br><i>RC</i> -генератор | Схема ВОD | Возможность<br>внутрисхемного<br>программирования | Макс. рабочая<br>д частота (хх) | Напряжение<br>питания | Усл. обозн.       | № рис.<br>(Прил. II) |
|     |       |       |                          | [капалы]        |                                    |           |                                                   | 4                               | 2.76.0                |                   |                      |
| -   | _     | _     | •                        | _               | •                                  |           | •                                                 | 12                              | 4.06.0                | DIP-20            | 2                    |
|     |       |       |                          |                 |                                    |           |                                                   | 4                               | 2.76.0                |                   |                      |
| -   | _     | _     | •                        | _               | •                                  |           | •                                                 | 12                              | 4.06.0                | SOIC-20           | 6                    |
|     |       |       |                          |                 |                                    |           |                                                   | 4                               | 2.76.0                |                   |                      |
| -   | _     | _     | •                        | _               | •                                  |           | •                                                 | 12                              | 4.06.0                | SSOP-20           | 7                    |
|     |       |       |                          |                 |                                    |           |                                                   | 4                               | 2.76.0                |                   |                      |
| 1   | _     | 1     | •                        | _               |                                    |           | •                                                 | 10                              | 4.06.0                | DIP-20            | 2                    |
|     |       |       |                          |                 |                                    |           |                                                   | 4                               | 2.76.0                |                   |                      |
| 1   | _     | 1     | •                        | _               |                                    |           | •                                                 | 10                              | 4.06.0                | SOIC-20           | 6                    |
|     |       |       |                          |                 |                                    |           |                                                   | 4                               | 27 (0                 | DIP-8             | 1                    |
| -   | _     | _     |                          | _               |                                    |           | •                                                 | 4                               | 2.76.0                | SOIC-8            | 5                    |
|     |       |       |                          |                 |                                    |           | •                                                 | 10                              | 4.06.0                | DIP-8             | 1                    |
| -   | _     | _     |                          | _               |                                    |           | •                                                 | 10                              | 4.00.0                | SOIC-8            | 5                    |
|     |       |       |                          |                 | •                                  |           |                                                   | 4                               | 2.76.0                | DIP-8             | 1                    |
|     |       |       |                          |                 |                                    |           |                                                   | +                               | 2.70.0                | SOIC-8            | 5                    |
| _   | _     | _     |                          | _               |                                    |           |                                                   | 10                              | 4.06.0                | DIP-8             | 1                    |
|     |       |       |                          |                 | _                                  |           |                                                   | 10                              | 1.00.0                | SOIC-8            | 5                    |
| 1   | 1     | 1     | •                        | 6               |                                    | •         |                                                   | 4                               | 2.76.0                | DIP-28            | 3                    |
|     |       |       |                          |                 |                                    |           |                                                   |                                 |                       | LQFP-32           | 9                    |
| 1   | 1     | 1     | •                        | 6               |                                    | •         | •                                                 | 8                               | 4.06.0                | DIP-28            | 3                    |
|     |       |       |                          |                 |                                    |           |                                                   |                                 |                       | LQFP-32           | 9                    |
| 1   | 1     | 1     | •                        | 6               |                                    | •         | •                                                 | 4                               | 2.76.0                | DIP-28            | 3                    |
|     |       |       |                          |                 |                                    |           |                                                   |                                 |                       | LQFP-32<br>DIP-28 | 9                    |
| 1   | 1     | 1     | •                        | 6               |                                    | •         | •                                                 | 8                               | 4.06.0                | LQFP-32           | 9                    |
|     |       |       |                          |                 |                                    |           |                                                   |                                 |                       | DIP-40            | 4                    |
| 3   | 1     | 1     | •                        | 8               |                                    |           |                                                   | 4                               | 2.76.0                | PLCC-44           | 8                    |
|     | 1     | 1     |                          |                 |                                    |           |                                                   | т                               | 2.70.0                | TQFP-44           | 10                   |
|     |       |       |                          |                 |                                    |           |                                                   |                                 |                       | DIP-40            | 4                    |
| 3   | 1     | 1     | •                        | 8               |                                    |           |                                                   | 8                               | 4.06.0                | PLCC-44           | 8                    |
|     |       |       |                          |                 |                                    |           |                                                   |                                 |                       | TQFP-44           | 10                   |

|                           | грамм<br>ЗУ)                 | дан    | иять<br>ных<br>йт] |               |                              | источ  | I-во<br>ников<br>ваний |         | Таймеры  |            |
|---------------------------|------------------------------|--------|--------------------|---------------|------------------------------|--------|------------------------|---------|----------|------------|
| Обозначение <sup>1)</sup> | Память программ (FLASH-II3У) | EEPROM | SRAM               | Кол-во команд | Кол-во линий<br>ввода/вывода | внутр. | внешн.                 | 8-pa3p. | 16-pa3p. | сторожевой |
| AT90LS8535-xxPw           |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90LS8535-xxJw           | 8                            | 512    | 512                | 120           | 32                           | 14     | 2                      | 2       | 1        | •          |
| AT90LS8535-xxAw           |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S8535-xxPw            |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S8535-xxJw            | 8                            | 512    | 512                | 120           | 32                           | 14     | 2                      | 2       | 1        | •          |
| AT90S8535-xxAw            |                              |        |                    |               |                              |        |                        |         |          |            |
| AT90S4414-xxPw            | 4                            | 256    | 256                | 120           | 32                           | 10     | 2                      | 1       | 1        | •          |
| AT90S4414-xxJw            | 4                            | 256    | 256                | 120           | 32                           | 10     | 2                      | 1       | 1        | •          |
| AT90S4414-xxAw            | 4                            | 256    | 256                | 120           | 32                           | 10     | 2                      | 1       | 1        | •          |
| AT90S8515-xxPw            | 8                            | 512    | 512                | 120           | 32                           | 10     | 2                      | 1       | 1        | •          |
| AT90S8515-xxJw            | 8                            | 512    | 512                | 120           | 32                           | 10     | 2                      | 1       | 1        | •          |
| AT90S8515-xxAw            | 8                            | 512    | 512                | 120           | 32                           | 10     | 2                      | 1       | 1        | •          |
| AT90C8534-xxPw            | 8                            | 512    | 256                | 120           | 15                           | 4      | 2                      | 1       | 1        | •          |

 $<sup>^{1)}</sup>$  w — температурный диапазон: «С» = 0...70°С (коммерческое исполнение); «І» = -40...+85°С (промышленное исполнение).

Например:

AT90S4434-8AC: модель AT90S4434, частота — 0...8 МГц, коммерческое исполнение, корпус TQFP;

AT90LS2323-4SI: модель AT90LS2323, частота — 0...4 МГц, промышленное исполнение, корпус SOIC.

 $<sup>{</sup>f xx}$  — максимальная тактовая частота (значения, возможные для каждой модели, приведены в соответствующей колонке таблицы):

<sup>«12» — 12</sup> МГц; «10» — 10 МГц; «8» — 8 МГц; «4» — 4 МГц; «1» — 1.5 МГц.

#### Приложения

#### (окончание)

|     | Интер | офейсы | Аналоговый<br>компаратор | 10-разр. |                                    |           | Э                                                 | )<br>()                       | 16                 | Кор         | опус                 |
|-----|-------|--------|--------------------------|----------|------------------------------------|-----------|---------------------------------------------------|-------------------------------|--------------------|-------------|----------------------|
| ШИМ | SPI   | UART   |                          | АЦП      | Встроенный<br><i>RC</i> -генератор | Схема ВОD | Возможность<br>внутрисхемного<br>программирования | Макс. рабочая<br>частота (xx) | Напряжение питания | Усл. обозн. | № рис.<br>(Прил. II) |
|     | S     | 1      | < ×                      | [каналы] | M ×                                |           | M M H                                             | [МГц]                         | [B]                |             |                      |
|     |       |        |                          |          |                                    |           |                                                   |                               |                    | DIP-40      | 4                    |
| 3   | 1     | 1      | •                        | 8        |                                    |           | •                                                 | 4                             | 2.76.0             | PLCC-44     | 8                    |
|     |       |        |                          |          |                                    |           |                                                   |                               |                    | TQFP-44     | 10                   |
|     |       |        |                          |          |                                    |           |                                                   |                               |                    | DIP-40      | 4                    |
| 3   | 1     | 1      | •                        | 8        |                                    |           | •                                                 | 8                             | 4.06.0             | PLCC-44     | 8                    |
|     |       |        |                          |          |                                    |           |                                                   |                               |                    | TQFP-44     | 10                   |
| 2   | 1     | 1      | •                        | _        |                                    |           | •                                                 | 4                             | 2.76.0             | DIP-40      | 4                    |
| 2   | 1     | 1      | •                        | _        |                                    |           | •                                                 | 4                             | 2.76.0             | PLCC-44     | 8                    |
| 2   | 1     | 1      | •                        | _        |                                    |           | •                                                 | 4                             | 2.76.0             | TQFP-44     | 10                   |
| 2   | 1     | 1      | •                        | _        |                                    |           | •                                                 | 4                             | 2.76.0             | DIP-40      | 4                    |
| 2   | 1     | 1      | •                        | _        |                                    |           | •                                                 | 4                             | 2.76.0             | PLCC-44     | 8                    |
| 2   | 1     | 1      | •                        | _        |                                    |           | •                                                 | 4                             | 2.76.0             | TQFP-44     | 10                   |
| _   | _     | _      |                          | 6        |                                    |           |                                                   | 1.5                           | 3.36.0             | LQFP-48     | 11                   |

Приложение II. Чертежи корпусов микроконтроллеров AVR семейства Classic









# Приложение III. Электрические параметры микроконтроллеров AVR семейства Classic

#### Максимально допустимые значения

| Параметр                                                                                         | Предельные значения                                                                                                                                                            |
|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Рабочая температура                                                                              | <ul><li>−40+105°С (модель АТ90С8534)</li><li>−55+125°С (остальные модели)</li></ul>                                                                                            |
| Температура хранения                                                                             | −65+150°C                                                                                                                                                                      |
| $\frac{\text{Напряжение на любом выводе (кроме вывода}}{\text{RESET}}$ ) относительно вывода GND | $-1.0V_{CC} + 0.5 \text{ B}$                                                                                                                                                   |
| Напряжение на выводе RESET относительно вывода GND                                               | -1.0 <i>V</i> <sub>CC</sub> + 0.5 В (модель АТ90С8534)<br>-1.0+13 В (остальные модели)                                                                                         |
| Напряжение питания                                                                               | 6.6 B                                                                                                                                                                          |
| Максимальный ток канала ввода/вывода                                                             | 20 мА (модель АТ90С8534)<br>40 мА (остальные модели)                                                                                                                           |
| Максимальный ток выводов $V_{CC}$ и GND                                                          | 100 мА (модель AT90C8534)<br>300 мА (модели AT90S/LS2333 и AT90S/LS4433)<br>400 мА (модели AT90S/LS4434 и AT90S/LS8535<br>в корпусах TQFP и PLCC)<br>200 мА (остальные модели) |

#### Статические параметры (DC)

| Обозначение                       | Параметр                                    | Условия          | Модель                                                                                 | min                | typ                | max                | Ед.<br>изм. |
|-----------------------------------|---------------------------------------------|------------------|----------------------------------------------------------------------------------------|--------------------|--------------------|--------------------|-------------|
| <i>V</i> <sub>IL</sub> напря НИЗК | Входное<br>напряжение<br>НИЗКОГО            | Вывод XTAL1      | AT90S1200<br>AT90S2313<br>AT90S/LS2323<br>AT90S/LS2343<br>AT90S/LS2333<br>AT90S/LS4433 | -0.5               |                    | 0.1                | В           |
|                                   | уровня                                      |                  | AT90S/LS4434<br>AT90S/LS853<br>AT90S4414/8515<br>AT90C8534                             | -0.5               | 0.2V <sub>CC</sub> |                    |             |
|                                   |                                             | Остальные выводы | все модели                                                                             | -0.5               |                    | $0.3V_{\rm CC}$    | В           |
|                                   | Входное<br>напряжение<br>ВЫСОКОГО<br>уровня | Вывод XTAL1      | AT90S/LS4434<br>AT90S/LS8535<br>AT90S4414/8515<br>AT90C8534                            | 0.8V <sub>CC</sub> |                    | $V_{\rm CC} + 0.5$ | В           |
|                                   |                                             |                  | остальные                                                                              | 0.7V <sub>CC</sub> |                    | $V_{\rm CC} + 0.5$ |             |
| $V_{ m IH}$                       |                                             | Вывод RESET      | AT90S/LS4434<br>AT90S/LS8535<br>AT90S4414/8515<br>AT90C8534                            | 0.9V <sub>CC</sub> |                    | $V_{\rm CC} + 0.5$ | В           |
|                                   |                                             |                  | остальные                                                                              |                    |                    | $V_{\rm CC} + 0.5$ |             |
|                                   |                                             | Остальные выводы | все модели                                                                             | 0.6V <sub>CC</sub> |                    | $V_{\rm CC} + 0.5$ | В           |

(продолжение)

| Обозначение             | Параметр                                                  | Условия                                                              | Модель                                                       | min  | typ | max | Ед.<br>изм. |
|-------------------------|-----------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------|------|-----|-----|-------------|
|                         |                                                           | $I_{\rm OI} = 20 \text{ MA}, V_{\rm CC} = 5 \text{ B}$               | AT90S/LS2323<br>AT90S/LS2343                                 |      |     | 0.5 | В           |
|                         | Выходное напряжение                                       | TOL 20 MA, PCC 3 B                                                   | остальные (кроме<br>AT90C8534)                               |      |     | 0.6 |             |
| $V_{\rm OL}$            | НИЗКОГО<br>уровня линий<br>портов                         | $I_{\rm OL} = 10 \text{ MA}, V_{\rm CC} = 3 \text{ B}$               | AT90S/LS2323<br>AT90S/LS2343                                 |      |     | 0.4 |             |
|                         | ввода/вывода                                              | ,                                                                    | остальные (кроме<br>AT90C8534)                               |      |     | 0.5 |             |
|                         |                                                           | $I_{\rm OL} = 1 \text{ mA}, V_{\rm CC} = 2.5 \text{ B}$              | AT90C8534                                                    |      |     | 0.1 |             |
|                         |                                                           | $I_{\rm OH} = -3 \text{ MA}, V_{\rm CC} = 5 \text{ B}$               | AT90S/LS2323<br>AT90S/LS2343                                 | 4.2  |     |     |             |
|                         | Выходное на-                                              | 10Н — – 3 мм, усс – 3 в                                              | остальные (кроме<br>AT90C8534)                               | 4.3  |     |     |             |
| $V_{\mathrm{OH}}$       | ВЫСОКОГО<br>уровня линий<br>портов                        | $I_{OH} = -1.5 \text{ MA}, V_{CC} = 3 \text{ B}$                     | AT90S/LS2323<br>AT90S/LS2343                                 | 2.4  |     |     | В В         |
| 1                       | ввода/вывода                                              |                                                                      | остальные (кроме<br>AT90C8534)                               | 2.3  |     |     |             |
|                         |                                                           | $I_{\rm OH} = -1 \text{ MA}, V_{\rm CC} = 2.5 \text{ B}$             | AT90C8534                                                    | 1.44 |     |     |             |
| $I_{\rm IL}$ Ток утечки |                                                           | $V_{\rm CC} = 6 {\rm B},$ на выводе — лог. «0» (абсолютное значение) | AT90S2313                                                    |      |     | 1.5 | мкА         |
| IL.                     | на входе                                                  |                                                                      | остальные                                                    |      |     | 8   |             |
| $I_{ m IH}$             | Ток утечки<br>на входе                                    | V <sub>CC</sub> = 6 В,<br>на выводе — лог. «1»                       | AT90S1200<br>AT90S2313<br>AT90S4414/8515                     |      |     | 980 | нА          |
|                         |                                                           | (абсолютное значение)                                                | остальные                                                    |      |     | 8   | мкА         |
| RRST                    | Сопротивление подтягивающего резистора в цепи сброса      |                                                                      | все                                                          | 100  |     | 500 | кОм         |
| $R_{\mathrm{I/O}}$      | Сопротивление подтягивающего резистора линии порта ввода/ |                                                                      | все модели,<br>за исключением<br>AT90C8534                   | 35   |     | 120 | кОм         |
|                         | Ток<br>потребления                                        | Рабочий режим,                                                       | AT90S1200<br>AT90S2313<br>AT90S/LS2343<br>AT90S4414/8515     |      |     | 3.0 |             |
| $I_{\rm CC}$            | (все модели                                               | $V_{\rm CC} = 3 \text{ B}, 4 \text{ МГц}$                            | AT90S/LS2323                                                 |      |     | 4.0 | мА          |
|                         | кроме<br>АТ90С8534)                                       | t                                                                    | AT90S/LS2333<br>AT90S/LS4433<br>AT90S/LS4434<br>AT90S/LS8535 |      |     | 5.0 |             |

(окончание)

| Обозначение   | Параметр                                | Условия                                                 | Модель                                                   | min | typ  | max  | Ед.<br>изм. |
|---------------|-----------------------------------------|---------------------------------------------------------|----------------------------------------------------------|-----|------|------|-------------|
|               |                                         |                                                         | AT90S1200<br>AT90S2313                                   |     |      | 1.0  | мА          |
|               |                                         |                                                         | AT90S/LS2343                                             |     |      | 1.1  |             |
|               |                                         | Режим Idle,<br>V <sub>CC</sub> = 3 B, 4 МГц             | AT90S/LS2323<br>AT90S4414/8515                           |     |      | 1.2  |             |
|               |                                         | VCC - 3 B, 4 MIII                                       | AT90S/LS2333<br>AT90S/LS4433                             |     |      | 2.0  |             |
|               |                                         |                                                         | AT90S/LS4434<br>AT90S/LS8535                             |     |      | 3.0  |             |
|               | Ток                                     | Daniel Daniel                                           | AT90S1200<br>AT90S2313<br>AT90S/LS2323<br>AT90S4414/8515 |     | 9.0  | 15.0 | мкА         |
|               | потребления                             | Режим Power Down WDT — вкл., $V_{CC} = 3$ В             | AT90S/LS2343                                             |     |      | 25.0 |             |
| $I_{\rm CC}$  | (все модели кроме                       | WD1 - BKJI., VCC - 3B                                   | AT90S/LS2333<br>AT90S/LS4433                             |     |      | 20.0 |             |
|               | AT90C8534)                              |                                                         | AT90S/LS4434<br>AT90S/LS8535                             |     |      | 15.0 |             |
|               |                                         | Режим Power Down WDT — выкл., $V_{\rm CC}$ = 3 В        | AT90S1200<br>AT90S2313<br>AT90S/LS2323<br>AT90S4414/8515 |     | <1.0 | 2.0  | мкА         |
|               |                                         |                                                         | AT90S/LS2343                                             |     |      | 20.0 |             |
|               |                                         |                                                         | AT90S/LS2333<br>AT90S/LS4433                             |     |      | 10.0 |             |
|               |                                         |                                                         | AT90S/LS4434<br>AT90S/LS8535                             |     |      | 5.0  |             |
|               |                                         | Режим Power Save WDT — выкл., $V_{CC} = 3$ В            | AT90S/LS4434<br>AT90S/LS8535                             |     |      | 15.0 | мкА         |
|               | Ток<br>потребления<br>(АТ90С8534)       | Рабочий режим, $V_{\rm CC}$ = 3.6 B, 1 МГц, АЦП — выкл. | AT90C8534                                                |     | 1.5  | 2.0  | мА          |
|               |                                         | Рабочий режим, $V_{\rm CC}$ = 3.6 B, 1 МГц, АЦП — вкл.  | AT90C8534                                                |     | 1.9  | 2.7  | мА          |
| $I_{\rm CC}$  |                                         | Режим Idle, $V_{CC} = 3.6$ В, 1 МГц, АЦП — выкл.        | AT90C8534                                                |     | 0.25 | 1.0  | мА          |
|               | (A1 30 C6554)                           | Режим Idle, $V_{CC} = 3.6$ В, 1 МГц , АЦП — вкл.        | AT90C8534                                                |     | 0.7  | 1.7  | мА          |
|               |                                         | Режим Power Down $V_{\rm CC} = 3.6 \; \rm B$            | AT90C8534                                                |     | 1.0  | 10.0 | мкА         |
| $V_{\rm CCP}$ |                                         | Программирование при<br>высоком напряжении              | все модели                                               | 4.5 |      | 5.5  | В           |
|               | Напряжение питания при программировании | Программирование при низком напряжении                  | AT90S1200<br>AT90S2313<br>AT90S4414/8515<br>AT90LSxxxx   | 2.7 |      | 6.0  |             |
|               |                                         |                                                         | остальные                                                | 4.0 |      | 6.0  |             |

| A              | BRHC96         |
|----------------|----------------|
| ACD213         | BRHS97         |
| ACI213         | BRID97         |
| ACIC214        | BRIE98         |
| ACIE213        | BRLO98         |
| ACIS1:ACIS0213 | BRLT99         |
| ACO213         | BRMI99         |
| ACSR212        | BRNE100        |
| ADC89          | BRPL100        |
| ADCBG221       | BRSH101        |
| ADCH:ADCL220   | BRTC101        |
| ADCS218        | BRTS102        |
| ADCSR217       | BRVC102        |
| ADD89          | BRVS103        |
| ADEN217        | BSET103        |
| ADFR217        | BST104         |
| ADIE218        |                |
| ADIF218        | C              |
| ADIW91         | CBI104         |
| ADMUX221       | CBR            |
| ADPS2ADPS0218  | CHR9227        |
| AINBG214       | CLC105         |
| AND91          | CLH105         |
| ANDI91         | CLI105         |
| AS2206         | CLN106         |
| ASR92          | CLR106         |
| ASSR205        | CLS107         |
|                | CLT107         |
| В              | CLV107         |
| BCLR92         | CLZ108         |
| BLD93          | COM108         |
| BORF164        | COM11:COM10196 |
| BRBC93         | COM1A196       |
| BRBS94         | COM1B196       |
| BRCC94         | COM21:COM20203 |
| BRCS95         | CP109          |
| BREQ95         | CPC109         |
| BRGE96         | CPHA242        |

| CPI110           | IPIN0172                               |
|------------------|----------------------------------------|
| CPOL             | IPIN1                                  |
| CPSE             | 11 11 11 11 11 11 11 11 11 11 11 11 11 |
| CS02CS00         | L                                      |
| CS12CS10         | LD114118                               |
| CS22CS20         | LDD                                    |
| CTC1             | LDI119                                 |
| CTC2             | LDS                                    |
|                  | LPM                                    |
| D                | LSL                                    |
| DDRADDRD178, 182 | LSR                                    |
| DEC111           | 121                                    |
| DORD241          | M                                      |
| DOIAD241         | MCUCR53                                |
| E                | MOV                                    |
| EEAR             | MPCM                                   |
| EEARH            | MUX2MUX0                               |
| EEARL 63         | 141 0742141 0740                       |
| EECR             | N                                      |
| EEDR             | NEG122                                 |
| EEMWE            | NOP 123                                |
| EERE 64          | NOI123                                 |
| EERIE            | 0                                      |
| EEWE             | OCF1175, 195                           |
| EOR111           | OCF1                                   |
| EXTRF            | OCF1B                                  |
| 2.1114           | OCF2                                   |
| F                | OCIE1                                  |
| FE               | OCIEIA                                 |
| 1 2220, 232      | OCIE1B                                 |
| ī                | OCIE2                                  |
| ICALL112         | OCR1                                   |
| ICES1            | OCR1A197                               |
| ICF1             | OCR1B197                               |
| ICNC1            | OCR2202                                |
| ICR1             | OCR2UB                                 |
| IJMP             | OR123, 228, 232                        |
| IN               | ORI124                                 |
| INC              | OUT124                                 |
| INT0             |                                        |
| INT1170          | P                                      |
| INTF0171         | DINIA DINID                            |
|                  | PINAPIND178                            |

| PORF162, 164       | SPIF240, 241   |
|--------------------|----------------|
| PORTAPORTD178, 182 | SPR1:SPR0242   |
| PUSH125            | SPSR240        |
| PWM11:PWM10        | SREG51         |
|                    | ST138142       |
| R                  | STD142, 143    |
| RCALL126           | STS143         |
| RET                | SUB144         |
| RETI               | SUBI144        |
| RJMP127            | SWAP145        |
| ROL128             |                |
| ROR128             | T              |
| RXB8227            | TCCR1191       |
| RXC227, 232        | TCCR1A191      |
| RXCIE226           | TCCR1B191      |
| RXEN226, 230       | TCCR2201       |
|                    | TCN2UB206      |
| S                  | TCNT1190       |
| SBC129             | TCNT2200       |
| SBCI129            | TCNTO185       |
| SBI                | TCR2UB206      |
| SBIC130            | TEMP190        |
| SBIS131            | TICIE1174, 193 |
| SBIW131            | TOIE0174, 185  |
| SBR132             | TOIE1174, 193  |
| SBRC132            | TOIE2173, 202  |
| SBRS133            | TOV0175, 185   |
| SEC133             | TOV1174, 193   |
| SEH134             | TOV2175, 202   |
| SEI134             | TST145         |
| SEN135             | TXB8227        |
| SER135             | TXC228, 230    |
| SES136             | TXCIE226       |
| SET136             | TXEN227, 229   |
| SEV136             |                |
| SEZ137             | U              |
| SLEEP137           | UART225        |
| SP53               | UBRR234        |
| SPCR239            | UBRRHI:UBRR234 |
| SPDR240            | UCR226         |
| SPE241             | UCSRA226       |
| SPH:SPL53, 76      | UCSRB226       |
| SPI237             | UDR228         |
| SPIE241            | UDRE228        |
|                    |                |

| UDRIE226                            | 0                                   |
|-------------------------------------|-------------------------------------|
| USR                                 | ОЗУ внешнее                         |
| W                                   | П                                   |
| WCOL240                             | Параметры электрические279          |
| WDE209                              | Переход                             |
| WDP2WDP0210                         | косвенный72                         |
| WDR146                              | относительный71                     |
| WDRF164                             | Порты ввода/вывода177               |
| WDTCR209                            | Последовательный интерфейс (SPI)237 |
| WDTOE209                            | Последовательный порт225            |
|                                     | Прерывания166                       |
| A                                   | Программирование245                 |
| Адресация косвенная                 | параллельное248                     |
| относительная61                     | последовательное258                 |
| простая60                           |                                     |
| с постинкрементом62                 | P                                   |
| с преддекрементом62                 | Регистр                             |
| Адресация прямая                    | GIFR170                             |
| ОЗУ59                               | GIMSK170                            |
| PBB59                               | GIPR172                             |
| POH58                               | MCUSR162, 164                       |
| Аналоговый компаратор211            | TIFR174                             |
| Аналого-цифровой преобразователь215 | TIMSK172                            |
| Архитектура27                       | Регистровый файл44                  |
|                                     | Режим                               |
| B                                   | Idle151                             |
| Вызов подпрограмы                   | Power Down151                       |
| косвенный73                         | Power Save152                       |
| относительный73                     |                                     |
|                                     | C                                   |
| 3                                   | Сброс153                            |
| Защита кода и данных246             | Стек74                              |
|                                     | Сторожевой таймер208                |
| И                                   |                                     |
| Идентификация247                    | T                                   |
|                                     | Таймер                              |
| K                                   | T0185                               |
| Конвейер                            | T1187                               |
| Корпуса (размеры)                   | T2200                               |
| M                                   | ц                                   |
| Маркировка                          | Цоколевка13                         |