

# Двухъядерный процессор цифровой обработки сигналов с фиксированной запятой

# 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4



ГГ – год выпуска НН – неделя выпуска

# Основные параметры микросхемы:

- 32-разрядная RISC-архитектура;
- 16-разрядная DSP-архитектура;
- Встроенная память программ 128 Кбайт;
- Внешняя шина 32 разряда;
- 16-канальный 12 разрядный АЦП;
- Два 12-разрядных ЦАП;
- Три интерфейса UART;
- Интерфейс I2C;
- Аудиокодек;
- Блок поддержки шифрования ГОСТ 28147-89;
- Компаратор;
- Напряжение источника питания, (3,3 ± 10%) В;
- Температурный диапазон:

| Обозначение | Диапазон, °С  |
|-------------|---------------|
| 1901ВЦ1Т    | от – 60 до 85 |
| К1901ВЦ1Т   | от – 60 до 85 |
| К1901ВЦ1ТК  | от 0 до 70    |
| К1901ВЦ1Н4  | от 0 до 70    |

# Тип корпуса:

- 132-выводной металлокерамический корпус 4229.132-3;
- микросхемы К1901ВЦ1Н4 поставляются в бескорпусном исполнении.

# Основные характеристики

## Особенности ядра и памяти RISC:

- 32-битное RISC-ядро, тактовая частота до 100 МГц, производительность 1,25 DMIPS/МГц (Dhrystone 2.1) при нулевой задержке памяти;
- Блок аппаратной защиты памяти MPU;
- Умножение за один цикл, аппаратная реализация деления;
- Встроенная энергонезависимая память программ FLASH типа размером 128 Кбайт;
- Встроенное ОЗУ размером 32 Кбайт;
- Контроллер внешней системной шины с поддержкой микросхем памяти СОЗУ, ПЗУ, NAND Flash.

#### Особенности ядра и памяти DSP:

- 16-битное DSP-ядро аналог TMS320C54, тактовая частота до 100 МГц;
- встроенная память программ ОЗУ размером 128 Кбайт;
- встроенная память данных ОЗУ размером 128 Кбайт;
- максимальное быстродействие при одновременной работе RISC и DSPядер с памятью DSP-подсистемы;
- отображение в адресное пространство RISC.

### Особенности периферии и режима отладки:

- контроллер прямого доступа в память с функциями передачи Периферия-Память, Память-Память;
- контроллер USB интерфейса с функциями работы Device и Host;
- контроллеры интерфейсов UART, SPI, I2C;
- до 96 пользовательский линий ввода-вывода;
- блок аппаратной поддержки шифрования ГОСТ 28147-89;
- контроллер SDIO интерфейса;
- последовательные отладочные интерфейсы SWD и JTAG.

#### Особенности аналоговых модулей:

- два 12-ти разрядных АЦП (до 16 каналов);
- измеряемый диапазон напряжений от 0 до 3,6 В;
- температурный датчик;
- двух канальный 12-ти разрядный ЦАП;
- встроенный компаратор;
- аудиокодек.

## Особенности питания и тактовой частоты:

- внешнее питание 3,0...3,6 В;
- встроенный регулятор напряжения на 1,8 В для питания ядра;
- встроенные схемы контроля питания;
- встроенный домен с батарейный питанием;
- встроенный подстраиваемый RC-генератор 8 МГц;
- встроенный подстраиваемый RC-генератор 40 КГц;
- внешние два кварцевых резонатора на 2÷16 МГц и 32 кГц;
- встроенный умножитель тактовой частоты PLL для RISC-ядра;
- встроенный умножитель тактовой частоты PLL для DSP-ядра;
- встроенный умножитель тактовой частоты PLL для контроллера USB.

### Специализированные особенности:

- режимы SLEEP, DEEPSLEEP и STANDBY;
- батарейный домен с часами реального времени и регистрами аварийного сохранения.

# Содержание

| 1 | Вве | едение   |                                                            | 20 |
|---|-----|----------|------------------------------------------------------------|----|
| 2 |     |          | рафическое изображение                                     |    |
| 3 | Опи | исание в | выводов                                                    | 23 |
| 4 | Стр | уктурна  | я блок-схема микросхемы                                    | 30 |
| 5 | Ука | зания п  | о применению и эксплуатации                                | 31 |
| 6 |     |          | рункционирования микросхемы                                |    |
|   | 6.1 | Систе    | ма питания                                                 | 33 |
|   | 6.2 | Структ   | урная схема подачи питания                                 | 34 |
|   | 6.3 | Схема    | сброса при включении и выключении основного питания        | 35 |
|   | 6.4 |          | изация памяти                                              |    |
|   |     | 6.4.1    | Структурная схема                                          | 36 |
|   |     | 6.4.2    | Карта памяти DSP                                           | 50 |
|   |     | 6.4.3    | Отображение памяти DSP в памяти RISC                       | 55 |
|   | 6.5 | Загруз   | очное ПЗУ и режимы работы микроконтроллера                 |    |
|   | 6.6 |          | загрузчик                                                  |    |
|   |     | 6.6.1    | Синхронизация с внешним устройством                        |    |
| 7 | Кон | троллер  | э FLASH памяти программ                                    |    |
|   | 7.1 |          | а Flash памяти программ в обычном режиме                   |    |
|   | 7.2 |          | а Flash памяти программ в режиме программирования          |    |
|   |     | 7.2.1    | Стирание всей памяти                                       |    |
|   |     | 7.2.2    | Стирание страницы памяти размером 4 Кбайт                  |    |
|   |     | 7.2.3    | Запись 32-х битного слова в память                         | 69 |
|   |     | 7.2.4    | Чтение 32-х битного слова из памяти                        |    |
|   | 7.3 | Описа    | ние регистров управления контроллера Flash памяти программ |    |
|   |     | 7.3.1    | MDR EEPROM->ADR                                            |    |
|   |     | 7.3.2    | MDR_EEPROM->DI                                             | 72 |
|   |     | 7.3.3    | MDR_EEPROM->DO                                             |    |
|   |     | 7.3.4    | MDR_EEPROM->KEY                                            | 73 |
|   |     | 7.3.5    | MDR_EEPROM-> CTRL                                          |    |
| 8 | Про | цессорі  |                                                            |    |
|   | 8.1 |          | урная схема процессорного ядра RISC                        |    |
|   | 8.2 |          | аммная модель                                              |    |
|   | 8.3 |          |                                                            |    |
|   | 8.4 | Регист   | ры ядра                                                    | 78 |
|   |     | 8.4.1    | Регистры общего назначения R0-R12                          | 79 |
|   |     | 8.4.2    | Указатель стека SP R13                                     |    |
|   |     | 8.4.3    | Регистр связи LR R14                                       |    |
|   |     | 8.4.4    | Счетчик команд РС R15                                      |    |
|   |     | 8.4.5    | Программный регистр состояния PSR                          | 79 |
|   |     | 8.4.6    | Программный регистр состояния приложения APSR              | 80 |
|   |     | 8.4.7    | Программный регистр состояния прерываний IPSR              |    |
|   |     | 8.4.8    | Программный регистр состояния выполнения EPSR              |    |
|   |     | 8.4.9    | Регистр маски исключений Exception mask                    |    |
|   |     | 8.4.10   | Регистр маски приоритетов Priority Mask                    |    |
|   |     | 8.4.11   | Регистр маски сбоев Fault Mask                             | 83 |
|   |     |          | Регистр базового приоритета маски Base Priority Mask       |    |
|   |     |          | Регистр управления CONTROL                                 |    |
|   | 8.5 |          | чения и прерывания                                         |    |
| 9 |     |          | манд RISC                                                  |    |
|   | 9.1 |          | енные функции                                              |    |
|   |     | •        | • •                                                        |    |

| 9.2 | Описа  | ние инструкций                                 |     |
|-----|--------|------------------------------------------------|-----|
|     | 9.2.1  | Операнды                                       | 91  |
|     | 9.2.2  | Ограничения на использование РС и SP           | 91  |
|     | 9.2.3  | Формат второго операнда                        | 91  |
|     | 9.2.4  | Операции сдвига                                |     |
|     | 9.2.5  | Выравнивание адресов                           |     |
|     | 9.2.6  | Адресация относительно счетчика команд РС      |     |
|     | 9.2.7  | Условное исполнение                            |     |
|     | 9.2.8  | Выбор размера кода инструкции                  |     |
| 9.3 | Коман  | ды доступа к памяти                            |     |
|     | 9.3.1  | ADR                                            |     |
|     | 9.3.2  | LDR и STR, непосредственно заданное смещение   |     |
|     | 9.3.3  | LDR и STR, смещение задано в регистре          |     |
|     | 9.3.4  | LDR and STR, непривилегированный доступ        |     |
|     | 9.3.5  | LDR, адресация относительно счетчика команд РС |     |
|     | 9.3.6  | PUSH и POP                                     | 108 |
|     | 9.3.7  | LDREX u STREX                                  |     |
|     | 9.3.8  | CLREX                                          |     |
| 9.4 |        | укции обработки данных                         |     |
| 5.4 | 9.4.1  | ADD, ADC, SUB, SBC и RSB                       |     |
|     | 9.4.1  | AND, ORR, EOR, BIC и ORN                       |     |
|     | 9.4.3  | ASR, LSL, LSR, ROR и RRX                       |     |
|     | 9.4.4  | CLZ                                            |     |
|     | 9.4.4  | CMP и CMN                                      |     |
|     |        |                                                |     |
|     | 9.4.6  | MOV и MVN                                      |     |
|     | 9.4.7  | MOVT                                           |     |
|     | 9.4.8  | REV, REV16, REVSH и RBIT                       |     |
| 0.5 | 9.4.9  | TST и TEQ                                      |     |
| 9.5 |        | укции умножения и деления                      |     |
|     | 9.5.1  | MUL, MLA и MLS                                 |     |
|     | 9.5.2  | UMULL, UMLAL, SMULL и SMLAL                    |     |
|     | 9.5.3  | SDIV и UDIV                                    |     |
| 9.6 |        | укции преобразования данных с насыщением       |     |
| _   | 9.6.1  | SSAT и USAT                                    |     |
| 9.7 |        | ды работы с битовыми полями                    |     |
|     | 9.7.1  | BFC и BFI                                      |     |
|     | 9.7.2  | SBFX и UBFX                                    |     |
|     | 9.7.3  | SXT и UXT                                      |     |
| 9.8 | Инстру | укции передачи управления                      |     |
|     | 9.8.1  | B, BL, BX и BLX                                | 129 |
|     | 9.8.2  | CBZ и CBNZ                                     | 130 |
|     | 9.8.3  | IT 131                                         |     |
|     | 9.8.4  | ТВВ и ТВН                                      | 133 |
| 9.9 | Прочи  | е инструкции                                   | 134 |
|     | 9.9.1  | CPS                                            | 134 |
|     | 9.9.2  | DMB                                            | 135 |
|     | 9.9.3  | DSB                                            |     |
|     | 9.9.4  | ISB                                            |     |
|     | 9.9.5  | MRS                                            |     |
|     | 9.9.6  | MSR                                            |     |
|     | 9.9.7  | NOP                                            |     |
|     | 9.9.8  | SEV                                            |     |
|     |        | -                                              |     |

|    | 9.9.9       | SVC                                               |            |
|----|-------------|---------------------------------------------------|------------|
|    |             | WFE                                               |            |
|    |             | WFI                                               |            |
| 10 |             | таймер SysTick                                    |            |
|    |             | ние регистров системного таймера SysTick          |            |
|    |             | SysTick->CTRL                                     |            |
|    |             | SysTick->LOAD                                     |            |
|    |             | SysTick->VAL                                      |            |
|    |             | SysTick->CAL                                      |            |
|    |             | ы и особенности при применении системного таймера |            |
| 11 |             | циты памяти                                       |            |
|    |             | ние регистров MPU                                 |            |
|    |             | MPU->TYPE                                         |            |
|    |             | MPU->CTRL                                         |            |
|    |             | MPU->RNR                                          |            |
|    |             | MPU->RBAR                                         |            |
|    | 11.1.5      | MPU->RASR                                         |            |
|    | 11.1.6      | Атрибуты разрешения доступа MPU                   |            |
|    |             | Несоответствие МР                                 |            |
|    |             | Обновление MPU региона                            |            |
|    |             | ы и особенности применения MPU                    |            |
| 12 |             | ктовой частоты                                    |            |
|    |             | ние регистров блока контроллера тактовой частоты  |            |
|    |             | MDR_RST_CLK->CLOCK_STATUS                         |            |
|    |             | MDR_RST_CLK->PLL_CONTROL                          |            |
|    |             | MDR_RST_CLK->HS_CONTROL                           |            |
|    | 12.1.4      | MDR_RST_CLK->CPU_CLOCK                            |            |
|    |             | MDR_RST_CLK->USB_CLOCK                            |            |
|    |             | MDR_RST_CLK->ADC_MCO_CLOCK                        |            |
|    | 12.1.7      | MDR_RST_CLK->RTC_CLOCK                            |            |
|    | 12.1.8      | MDR_RST_CLK->PER_CLOCK                            |            |
|    |             | MDR_RST_CLK->TIM_CLOCK                            |            |
|    |             | MDR_RST_CLK->UART_CLOCK                           |            |
|    |             | MDR_RST_CLK->SSP_CLOCK                            |            |
|    |             | MDR_RST_CLK->DSP_CLOCK                            |            |
| 40 |             | MDR_RST_CLK->SSP_CLOCK2MDDMDDMDD                  |            |
| 13 |             | й домен и часы реального времени MDR_BKP          |            |
|    | 13.1 Часы р | еального времениры аварийного сохранения          | 109<br>170 |
|    |             |                                                   |            |
|    |             | ние регистров блока батарейного домена            |            |
|    |             | MDR_BKP-> REG_[000D]                              |            |
|    |             | MDR_BKP->REG_0F                                   |            |
|    |             | MDR_BKP->RTC_CNT                                  |            |
|    |             | MDR_BKP->RTC_DIV                                  |            |
|    |             | MDR_BKP->RTC_DIV                                  |            |
|    |             |                                                   |            |
|    |             | MDR_BKP->RTC_ALRM                                 |            |
| 14 |             | MDR_BKP->RTC_CS<br>µа-вывода                      |            |
| 14 |             | ние регистров портов ввода-вывода                 |            |
|    |             | мdr_Portx->RXTX                                   |            |
|    |             | MDR_PORTX->RATA                                   |            |
|    | 14.1.2      | ווטוז_ו טוז וא־>טב                                | 101        |

|    | 14.1.3 MDR_PORTx->FUNC                                           | 181 |
|----|------------------------------------------------------------------|-----|
|    | 14.1.4 MDR PORTx->ANALOG                                         |     |
|    | 14.1.5 MDR_PORTx->PULL                                           |     |
|    | 14.1.6 MDR PORTx->PD                                             |     |
|    | 14.1.7 MDR PORTx->PWR                                            |     |
|    | 14.1.8 MDR_PORTx->FWR                                            |     |
|    |                                                                  |     |
|    | 14.1.9 MDR_PORTx->SET                                            |     |
|    | 14.1.10 MDR_PORTx->CLR                                           |     |
|    | 14.1.11 MDR_PORTx->RD                                            |     |
| 15 | Детектор напряжения питания MDR_POWER                            |     |
|    | 15.1 MDR_POWER->PVDCS                                            | 186 |
| 16 | Внешняя системная шина MDR_EBC                                   | 188 |
|    | 16.1 Работа с внешними статическими ОЗУ, ПЗУ и периферийными     |     |
|    | устройствами                                                     | 188 |
|    | 16.2 Работа с внешней NAND Flash-памятью                         | 190 |
|    | 16.3 Описание регистров блока контроллера внешней системной шины | 194 |
|    | 16.3.1 MDR_EBC->NAND_CYCLES                                      | 194 |
|    | 16.3.2 MDR_EBC->CONTROL                                          |     |
| 17 | Контроллер прямого доступа в память MDR_DMA                      |     |
| •  | 17.1 Основные свойства контроллера DMA                           |     |
|    | 17.2 Термины и определения                                       |     |
|    | 17.3 Функциональное описание                                     |     |
|    | 17.3.1 Распределение каналов DMA                                 |     |
|    | 17.3.2 Блок, подключенный к шине АРВ                             |     |
|    | 17.3.3 Блок, подключенный к шине АГВ                             |     |
|    |                                                                  |     |
|    | 17.3.4 Управляющий блок DMA                                      |     |
|    | 17.3.5 Типы передач                                              |     |
|    | 17.3.6 Разрядность передач данных                                |     |
|    | 17.3.7 Управление защитой данных                                 |     |
|    | 17.3.8 Инкремент адреса                                          |     |
|    | 17.4 Управление DMA                                              |     |
|    | 17.4.1 Правила обмена данными                                    |     |
|    | 17.4.2 Диаграммы работы контроллера DMA                          |     |
|    | 17.4.3 Правила арбитража DMA                                     | 210 |
|    | 17.4.4 Приоритет                                                 | 210 |
|    | 17.4.5 Типы циклов DMA                                           | 212 |
|    | 17.4.6 Индикация ошибок                                          |     |
|    | 17.5 Структура управляющих данных канала                         | 224 |
|    | 17.6 Описание регистров контроллера DMA                          |     |
|    | 17.6.1 MDR_DMA->STATUS                                           |     |
|    | 17.6.2 MDR_DMA->CFG                                              |     |
|    | 17.6.3 MDR_DMA->CTRL_BASE_PTR                                    |     |
|    | 17.6.4 MDR_DMA->ALT_CTRL_BASE_PTR                                | 238 |
|    | 17.6.5 MDR_DMA->WAITONREQ_STATUS                                 |     |
|    | 17.6.6 MDR_DMA->CHNL_SW_REQUEST                                  |     |
|    | 17.6.7 MDR_DMA->CHNL_USEBURST_SET                                |     |
|    | 17.6.8 MDR_DMA->CHNL_USEBURST_CLR                                |     |
|    | 17.6.9 MDR_DMA->CHNL_GSEBORST_CER                                |     |
|    | 17.6.10 MDR_DMA->CHNL_REQ_MASK_CLR                               |     |
|    | 17.6.11 MDR_DMA->CHNL_REQ_MASK_CER                               |     |
|    | 17.6.17 MDR_DMA->CHNL_ENABLE_SET                                 |     |
|    | 17.6.12 MDR_DMA->CHNL_ENABLE_CLR                                 |     |
|    | 17.0.13 NIDN_DINA->011NL_FRI_ALT_3ET                             | ∠4/ |

|    |      | 17.6.14          | MDR_DMA->CHNL_PRI_ALT_CLR                                                       | . 248 |
|----|------|------------------|---------------------------------------------------------------------------------|-------|
|    |      | 17.6.15          | DFMDR_DMA->CHNL_PRIORITY_SET                                                    | .249  |
|    |      |                  | MDR_DMA->CHNL_PRIORITY_CLR                                                      |       |
|    |      |                  | 'MDR_DMA->ERR_CLR                                                               |       |
| 18 | Орга |                  | ля управления DSP-подсистемой                                                   |       |
|    |      |                  | ва управления подсистемой DSP                                                   |       |
|    |      |                  | осигналы DSP-подсистемы                                                         |       |
|    |      |                  | Режимы отключения синхросигналов DSP-подсистемы (IDLE1,                         |       |
|    |      |                  | IDLE2, IDLE3)                                                                   | .254  |
|    | 18.3 | Сбрось           | ы DSP подсистемы                                                                |       |
|    |      | •                | вания и запросы DMA между подсистмемами                                         |       |
|    |      |                  | альные возможности управления                                                   |       |
|    | 18.6 | Работа           | моста пересинхронизации RISC – DSP                                              | . 257 |
|    |      |                  | бы управления подсистемой DSP                                                   |       |
|    |      |                  | Нормальная работа DSP                                                           |       |
|    |      |                  | Динамическое изменение программного обеспечения DSP-ядра.                       |       |
|    |      |                  | Работа с периферийными модулями и памятью DSP без участия                       |       |
|    |      | 10.7.0           | ядра DSP                                                                        |       |
|    | 18.8 | Регист           | ры управления подсистемой DSP                                                   | 260   |
|    | 10.0 |                  | Регистр управления синхронизацией CLKMD                                         |       |
|    |      |                  | Регистр прерываний от DSP к RISC                                                |       |
| 19 | Ппо  |                  | ное ядро DSP                                                                    |       |
|    |      |                  | ные особенности ядра DSP                                                        |       |
|    |      |                  | ктура ядра DSP                                                                  |       |
|    | 10.2 | 19 2 1           | Шинная структура DSP                                                            | 265   |
|    |      | 10.2.1           | Устройство управления выполнением программ                                      | 266   |
|    |      |                  | Арифметико-логическое устройство                                                |       |
|    |      |                  | Аккумуляторы А и В                                                              |       |
|    |      |                  | Циклическое сдвиговое устройство                                                |       |
|    |      |                  | Устройство умножения/сложения                                                   |       |
|    |      |                  | Устройство умножения спожения<br>Устройство сравнения, выбора и хранения (CSSU) |       |
|    |      |                  | Шифратор показателя                                                             |       |
|    | 10.3 |                  | зация конвейера                                                                 |       |
|    | 13.5 |                  | Стадии конвейера                                                                |       |
|    |      | 19.3.1           | •                                                                               |       |
|    |      |                  | Инструкции перехода в конвейереИнструкции вызова функций в конвейере            | 203   |
|    |      | 19.3.4           |                                                                                 |       |
|    |      |                  | Условная инструкция в конвейере                                                 |       |
|    |      | 19.3.6           | ·                                                                               |       |
|    |      |                  | Команды условного вызова и условного перехода в конвейере Прерывания и конвейер |       |
|    | 10.4 |                  | • •                                                                             |       |
|    | 19.4 | Адреса<br>19.4.1 | иция данных                                                                     |       |
|    |      |                  | Непосредственная адресация                                                      |       |
|    |      |                  | Абсолютная адресация                                                            |       |
|    |      |                  | Аккумуляторная адресация                                                        |       |
|    |      | 19.4.4           | 1 '4 '                                                                          |       |
|    |      |                  | Косвенная Адресация                                                             |       |
|    |      |                  | Адресация регистра отображенного в памяти                                       |       |
|    |      |                  | Стековая адресация                                                              |       |
|    | 40.5 |                  | Типы Данных                                                                     |       |
|    | 19.5 |                  | ация программ                                                                   |       |
|    |      |                  | Генерация адреса программной памяти                                             |       |
|    |      | 19.5.2           | Программный Счетчик (РС)                                                        | .318  |

| 19.5.4 Вызов процедур. 19.5.5 Возвраты                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 318 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 19.5.6 Условные операции.  19.6 Функционирование DSP-ядра после сброса.  19.7 Прерывания DSP.  19.7.1 Регистры управления прерываниями ядра.  19.7.2 Регистр Маски Прерывания (IMR-interrupt mask register)  19.7.3 Обработка прерываний.  19.8 Регистры управления и состояния ядра.  19.8.1 Регистры Статуса (ST0 и ST1).  20 Система команд DSP.  20.1 Обзор набора команд.  20.1.1 Арифметические операции.  20.1.2 Логические операции.  20.1.3 Команды управления программой.  20.1.4 Команды загрузки и сохранения.  20.1.5 Повторения одной команды.  20.3 Классы и циклы команд.  20.3 Команды на языке ассемблера.  20.3.1 Обозначения и сокращения.  20.3.2 ABDST Хмет, Утет.  20.3.3 ABS src [, dst ].  20.3.4 ADD.  20.3.5 ADDC Smem, src.  20.3.6 ADDM #lk, Smem.  20.3.7 ADDS Smem, src.  20.3.8 AND.  20.3.1 BACZ[D] prad, cond [, cond ]].  20.3.14 BIT Xmem, BITC.  20.3.15 BITF Smem, #lk  20.3.15 BITF Smem, #lk  20.3.16 CMPS src, Lord [, cond ]].  20.3.2 CMPS src, Cond.  20.3.2 CMPS src, Cond.  20.3.2 CMPS src, Smem.  20.3.2 CMPS src, Smem.  20.3.2 DADD Lmem, src.  20.3.2 DADD Lmem, src [, dst ].  20.3.3 DADD Lmem, src [, dst ].  20.3.3 DADD Lmem, src [, dst ]. |     |
| 19.5.6 Условные операции.  19.6 Функционирование DSP-ядра после сброса.  19.7 Прерывания DSP.  19.7.1 Регистры управления прерываниями ядра.  19.7.2 Регистр Маски Прерывания (IMR-interrupt mask register)  19.7.3 Обработка прерываний.  19.8 Регистры управления и состояния ядра.  19.8.1 Регистры Статуса (ST0 и ST1).  20 Система команд DSP.  20.1 Обзор набора команд.  20.1.1 Арифметические операции.  20.1.2 Логические операции.  20.1.3 Команды загрузки и сохранения.  20.1.4 Команды загрузки и сохранения.  20.1.5 Повторения одной команды.  20.2 Классы и циклы команд.  20.3 Команды на языке ассемблера.  20.3.1 Обозначения и сокращения.  20.3.2 ABDST Xmem, Ymem.  20.3.3 ABS src [, dst ].  20.3.4 ADD.  20.3.5 ADDC Smem, src.  20.3.6 ADDM #lk, Smem.  20.3.7 ADDS Smem, src.  20.3.8 AND.  20.3.9 ANDM #lk, Smem.  20.3.10 B[D] pmad.  20.3.11 BACC[D] src.  20.3.12 BANZ[D] pmad, Sind.  20.3.14 BIT Xmem, BITC.  20.3.16 BITT Smem, #lk.  20.3.16 C[D] pmad, cond [, cond [].  20.3.17 CALA[D] src.  20.3.18 CALL[D] pmad, cond [, cond ]].  20.3.20 CMPL src [, dst ].  20.3.21 CMPM Srem, #lk.  20.3.22 CMPR CC, ARx.  20.3.25 DADST Lmem, dst.  20.3.29 DSADT Lmem, dst.  20.3.29 DSADT Lmem, dst.  20.3.30 DST src, Lmem.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 19.6 Функционирование DSP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |
| 19.7 Прерывания DSP 19.7.1 Регистры управления прерываниями ядра 19.7.2 Регистр Маски Прерывания (IMR-interrupt mask register) 19.7.3 Обработка прерываний                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 19.7.1       Регистры Маски Прерывания (IMR-interrupt mask register)         19.7.3       Обработка прерываний (IMR-interrupt mask register)         19.8       Регистры управления и состояния ядра         19.8.1       Регистры Статуса (ST0 и ST1)         20       Система команд DSP         20.1       Обзор набора команд         20.1.1       Арифметические операции         20.1.2       Логические операции         20.1.3       Команды загрузки и сохранения         20.1.4       Команды загрузки и сохранения         20.1.5       Повторения одной команды         20.2       Классы и циклы команд         20.3       Команды на языке ассемблера         20.3.1       Обозначения и сокращения         20.3.2       АВОST Хмет, Ymem         20.3.3       ABS src [, dst ]         20.3.4       ADD         20.3.5       ADDC Smem, src         20.3.6       ADDM #lk, Smem         20.3.7       ADDS Smem, src         20.3.8       AND         20.3.9       ANDM#lk, Smem         20.3.10 EID pmad       20.3.11 BACC[D] src         20.3.12 BANZ[D] pmad, cond [, cond [, cond ]]         20.3.14 BIT Xmem, BITC         20.3.15 BITF Smem         20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| 19.7.2 Регистр Маски Прерывания (IMR-interrupt mask register) 19.7.3 Обработка прерываний                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |
| 19.7.3 Обработка прерываний.  19.8 Регистры управления и состояния ядра 19.8.1 Регистры Статуса (ST0 и ST1).  20 Система команд DSP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| 19.8 Регистры управления и состояния ядра 19.8.1 Регистры Статуса (ST0 и ST1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
| 19.8.1 Регистры Статуса (ST0 и ST1)  20 Система команд DSP  20.1 Обзор набора команд 20.1.1 Арифметические операции 20.1.2 Логические операции 20.1.3 Команды управления программой 20.1.4 Команды загрузки и сохранения 20.1.5 Повторения одной команды 20.2 Классы и циклы команд 20.3 Команды на языке ассемблера 20.3.1 Обозначения и сокращения 20.3.2 ABDST Xmem, Ymem 20.3.3 ABS src [, dst ] 20.3.4 ADD 20.3.5 ADDC Smem, src 20.3.6 ADDM #lk, Smem 20.3.7 ADDS Smem, src 20.3.8 AND 20.3.9 ANDM #lk, Smem 20.3.10 B[D] pmad 20.3.11 BACC[D] src 20.3.12 BANZ[D] pmad, Sind 20.3.13 BC[D] pmad, cond [, cond ]] 20.3.14 BIT Xmem, BITC 20.3.15 BITF Smem 20.3.16 BITT Smem 20.3.17 CALA[D] src 20.3.18 CALL[D] pmad. 20.3.19 CC[D] pmad, cond [, cond [, cond ]] 20.3.20 CMPL src [, dst ] 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARx 20.3.23 CMPS src, Smem 20.3.25 DADST Lmem, src 20.3.26 DELAY Smem 20.3.27 DLD Lmem, dst 20.3.29 DSADT Lmem, dst 20.3.29 DSADT Lmem, dst 20.3.39 DST src, Lmem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| 20 Система команд DSP 20.1 Обзор набора команд. 20.1.1 Арифметические операции. 20.1.2 Логические операции 20.1.3 Команды управления программой 20.1.4 Команды загрузки и сохранения 20.1.5 Повторения одной команды 20.1 Команды на языке ассемблера. 20.3 Команды на языке ассемблера. 20.3.1 Обозначения и сокращения 20.3.2 ABDST Xmem, Ymem 20.3.3 ABS src [, dst ] 20.3.4 ADD 20.3.5 ADDC Smem, src 20.3.6 ADDM #lk, Smem 20.3.7 ADDS Smem, src 20.3.8 AND 20.3.9 ANDM #lk, Smem 20.3.10 B[D] pmad 20.3.11 BACC[D] src 20.3.12 BANZ[D] pmad, Sind 20.3.13 BC[D] pmad, cond [, cond [] cond ]] 20.3.14 BIT Xmem, BITC 20.3.15 BITF Smem, #lk 20.3.16 BITT Smem 20.3.17 CALA[D] src 20.3.18 CALL[D] pmad, cond [, cond [, cond ]] 20.3.20 CMPL src [, dst ] 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARx 20.3.23 CMPS src, Smem 20.3.25 DADST Lmem, dst 20.3.29 DSADT Lmem, dst 20.3.29 DSADT Lmem, src 20.3.29 DSADT Lmem, src 20.3.29 DSADT Lmem, src 20.3.29 DSADT Lmem, dst 20.3.39 DST src, Lmem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| 20.1 Обзор набора команд 20.1.1 Арифметические операции. 20.1.2 Логические операции. 20.1.3 Команды управления программой. 20.1.4 Команды управления программой. 20.1.5 Повторения одной команды. 20.2 Классы и циклы команд. 20.3 Команды на языке ассемблера. 20.3.1 Обозначения и сокращения. 20.3.2 ABDST Xmem, Ymem. 20.3.3 ABS src [, dst ]. 20.3.4 ADD. 20.3.5 ADDC Smem, src. 20.3.6 ADDM #lk, Smem. 20.3.7 ADDS Smem, src. 20.3.8 AND. 20.3.9 ANDM #lk, Smem. 20.3.10 B[D] pmad. 20.3.10 B[D] pmad. 20.3.11 BACC[D] src. 20.3.12 BANZ[D] pmad, Sind. 20.3.13 BC[D] pmad, cond [, cond []. 20.3.14 BIT Xmem, BITC. 20.3.15 BITF Smem, #lk. 20.3.16 BITT Smem. 20.3.17 CALA[D] src. 20.3.18 CALL[D] pmad, cond [, cond []. 20.3.19 CC[D] pmad, cond [, cond []. 20.3.20 CMPL src [, dst ]. 20.3.21 CMPM Smem, #lk. 20.3.22 CMPR CC, ARx. 20.3.23 CMPS src, Smem. 20.3.24 DADD Lmem, src [, dst ]. 20.3.25 DADST Lmem, dst. 20.3.28 DRSUB Lmem, src. 20.3.29 DSADT Lmem, dst. 20.3.30 DST src, Lmem.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |
| 20.1.1 Арифметические операции         20.1.2 Логические операции         20.1.3 Команды управления программой         20.1.5 Повторения одной команды         20.2 Классы и циклы команд         20.3 Команды на языке ассемблера         20.3.1 Обозначения и сокращения         20.3.2 ABDST Xmem, Ymem         20.3.3 ABS src [, dst ]         20.3.4 ADD         20.3.5 ADDC Smem, src         20.3.6 ADDM #lk, Smem         20.3.7 ADDS Smem, src         20.3.8 AND         20.3.9 ANDM #lk, Smem         20.3.10 B[D] pmad         20.3.11 BACC[D] src         20.3.12 BANZ[D] pmad, Sind         20.3.13 BC[D] pmad, cond [, cond [, cond ]]         20.3.14 BIT Xmem, BITC         20.3.15 BITF Smem         20.3.17 CALA[D] src         20.3.18 CALL[D] pmad         20.3.19 CC[D] pmad, cond [, cond [, cond ]]         20.3.20 CMPL src [, dst ]         20.3.21 CMPM Smem, #lk         20.3.22 CMPR CC, ARx         20.3.23 CMPS src, Smem         20.3.24 DADD Lmem, src [, dst ]         20.3.25 DADST Lmem, dst         20.3.29 DSADT Lmem, src         20.3.29 DSADT Lmem, dst         20.3.30 DST src, Lmem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |
| 20.1.2 Логические операции 20.1.3 Команды управления программой 20.1.4 Команды загрузки и сохранения 20.1.5 Повторения одной команды 20.2 Классы и циклы команд 20.3 Команды на языке ассемблера 20.3.1 Обозначения и сокращения 20.3.2 ABDST Xmem, Ymem 20.3.3 ABS src [, dst ] 20.3.4 ADD 20.3.5 ADDC Smem, src. 20.3.6 ADDM #lk, Smem 20.3.7 ADDS Smem, src 20.3.8 AND 20.3.9 ANDM #lk, Smem 20.3.10 B[D] pmad 20.3.10 B[D] pmad 20.3.11 BACC[D] src 20.3.12 BANZ[D] pmad, Sind 20.3.13 BC[D] pmad, cond [, cond [] 20.3.14 BIT Xmem, BITC 20.3.15 BITF Smem, #lk 20.3.16 BITT Smem 20.3.17 CALA[D] src 20.3.18 CALL[D] pmad 20.3.19 CC[D] pmad, cond [, cond [, cond ]] 20.3.20 CMPL src [, dst ] 20.3.20 CMPL src [, dst ] 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARX 20.3.23 CMPS src, Smem 20.3.24 DADD Lmem, src [, dst ] 20.3.25 DADST Lmem, dst 20.3.29 DSADT Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |
| 20.1.3 Команды управления программой                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |
| 20.1.4 Команды загрузки и сохранения. 20.1.5 Повторения одной команды.  20.2 Классы и циклы команд. 20.3 Команды на языке ассемблера. 20.3.1 Обозначения и сокращения. 20.3.2 ABDST Xmem, Ymem 20.3.3 ABS src [, dst ]. 20.3.4 ADD. 20.3.5 ADDC Smem, src. 20.3.6 ADDM #lk, Smem. 20.3.7 ADDS Smem, src. 20.3.8 AND. 20.3.9 ANDM #lk, Smem. 20.3.10 B[D] pmad. 20.3.11 BACC[D] src. 20.3.12 BANZ[D] pmad, Sind. 20.3.13 BC[D] pmad, cond [, cond []. 20.3.14 BIT Xmem, BITC. 20.3.15 BITF Smem, #lk. 20.3.16 BITT Smem. 20.3.17 CALA[D] src. 20.3.18 CALL[D] pmad. 20.3.19 CC[D] pmad, cond [, cond [, cond ]]. 20.3.20 CMPL src [, dst ]. 20.3.21 CMPM Smem, #lk. 20.3.22 CMPR CC, ARx. 20.3.23 CMPS src, Smem. 20.3.24 DADD Lmem, src [, dst ]. 20.3.25 DADST Lmem, dst. 20.3.28 DRSUB Lmem, src. 20.3.29 DSADT Lmem, dst.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| 20.1.5 Повторения одной команды 20.2 Классы и циклы команд 20.3 Команды на языке ассемблера 20.3.1 Обозначения и сокращения 20.3.2 ABDST Xmem, Ymem 20.3.3 ABS src [, dst ] 20.3.4 ADD 20.3.5 ADDC Smem, src 20.3.6 ADDM #lk, Smem 20.3.7 ADDS Smem, src 20.3.8 AND 20.3.9 ANDM #lk, Smem 20.3.10 B[D] pmad 20.3.11 BACC[D] src 20.3.12 BANZ[D] pmad, Sind 20.3.13 BC[D] pmad, cond [, cond ]] 20.3.14 BIT Xmem, BITC 20.3.15 BITF Smem, #lk 20.3.16 BITT Smem 20.3.17 CALA[D] src 20.3.18 CALL[D] pmad 20.3.19 CC[D] pmad, cond [, cond [, cond ]] 20.3.12 CMPL src [, dst ] 20.3.20 CMPL src [, dst ] 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARx 20.3.23 CMPS src, Smem 20.3.24 DADD Lmem, src [, dst ] 20.3.25 DADST Lmem, dst 20.3.28 DRSUB Lmem, src 20.3.29 DSADT Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 20.2 Классы и циклы команд                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 20.3 Команды на языке ассемблера                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| 20.3.1 Обозначения и сокращения                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 20.3.2 ABDST Xmem, Ymem 20.3.3 ABS src [, dst ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| 20.3.3 ABS src [, dst ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
| 20.3.4 ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 20.3.5 ADDC Smem, src 20.3.6 ADDM #lk, Smem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
| 20.3.6 ADDM #lk, Smem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 20.3.7 ADDS Smem, src 20.3.8 AND 20.3.9 ANDM #lk, Smem 20.3.10 B[D] pmad 20.3.11 BACC[D] src 20.3.12 BANZ[D] pmad, Sind 20.3.13 BC[D] pmad, cond [, cond [, cond ]] 20.3.14 BIT Xmem, BITC 20.3.15 BITF Smem, #lk 20.3.16 BITT Smem 20.3.17 CALA[D] src 20.3.18 CALL[D] pmad 20.3.19 CC[D] pmad, cond [, cond [, cond ]] 20.3.20 CMPL src [, dst ] 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARx 20.3.23 CMPS src, Smem 20.3.24 DADD Lmem, src [, dst ] 20.3.25 DADST Lmem, dst 20.3.26 DELAY Smem 20.3.27 DLD Lmem, dst 20.3.28 DRSUB Lmem, src 20.3.29 DSADT Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| 20.3.8 AND 20.3.9 ANDM #lk, Smem. 20.3.10 B[D] pmad. 20.3.11 BACC[D] src. 20.3.12 BANZ[D] pmad, Sind. 20.3.13 BC[D] pmad, cond [, cond [, cond ]] 20.3.14 BIT Xmem, BITC. 20.3.15 BITF Smem, #lk. 20.3.16 BITT Smem. 20.3.17 CALA[D] src. 20.3.18 CALL[D] pmad. 20.3.19 CC[D] pmad, cond [, cond [, cond ]] 20.3.20 CMPL src [, dst ]. 20.3.21 CMPM Smem, #lk. 20.3.22 CMPR CC, ARx. 20.3.23 CMPS src, Smem. 20.3.24 DADD Lmem, src [, dst ]. 20.3.25 DADST Lmem, dst. 20.3.26 DELAY Smem. 20.3.27 DLD Lmem, dst. 20.3.29 DSADT Lmem, dst. 20.3.29 DSADT Lmem, dst. 20.3.29 DSADT Lmem, dst.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| 20.3.9 ANDM #lk, Smem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 20.3.10 B[D] pmad                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 418 |
| 20.3.12 BANZ[D] pmad, Sind                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 20.3.12 BANZ[D] pmad, Sind                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 420 |
| 20.3.14 BIT Xmem, BITC 20.3.15 BITF Smem, #lk 20.3.16 BITT Smem 20.3.17 CALA[D] src 20.3.18 CALL[D] pmad. 20.3.19 CC[D] pmad, cond [, cond ]] 20.3.20 CMPL src [, dst ]. 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARx 20.3.23 CMPS src, Smem. 20.3.24 DADD Lmem, src [, dst ]. 20.3.25 DADST Lmem, dst 20.3.26 DELAY Smem 20.3.27 DLD Lmem, dst 20.3.28 DRSUB Lmem, src. 20.3.29 DSADT Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 421 |
| 20.3.14 BIT Xmem, BITC 20.3.15 BITF Smem, #lk 20.3.16 BITT Smem 20.3.17 CALA[D] src 20.3.18 CALL[D] pmad. 20.3.19 CC[D] pmad, cond [, cond ]] 20.3.20 CMPL src [, dst ]. 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARx 20.3.23 CMPS src, Smem. 20.3.24 DADD Lmem, src [, dst ]. 20.3.25 DADST Lmem, dst 20.3.26 DELAY Smem 20.3.27 DLD Lmem, dst 20.3.28 DRSUB Lmem, src. 20.3.29 DSADT Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 422 |
| 20.3.16 BITT Smem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| 20.3.17 CALA[D] src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 426 |
| 20.3.18 CALL[D] pmad                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 427 |
| 20.3.19 CC[D] pmad, cond [, cond [, cond ]] 20.3.20 CMPL src [, dst ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 428 |
| 20.3.20 CMPL src [, dst ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 429 |
| 20.3.21 CMPM Smem, #lk 20.3.22 CMPR CC, ARx. 20.3.23 CMPS src, Smem. 20.3.24 DADD Lmem, src [, dst ] 20.3.25 DADST Lmem, dst 20.3.26 DELAY Smem. 20.3.27 DLD Lmem, dst 20.3.28 DRSUB Lmem, src. 20.3.29 DSADT Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 430 |
| 20.3.22 CMPR CC, ARx                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 433 |
| 20.3.23 CMPS src, Smem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 433 |
| 20.3.24 DADD Lmem, src [, dst ]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 434 |
| 20.3.25 DADST Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 435 |
| 20.3.26 DELAY Smem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |
| 20.3.27 DLD Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 20.3.28 DRSUB Lmem, src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
| 20.3.29 DSADT Lmem, dst<br>20.3.30 DST src, Lmem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| 20.3.30 DST src, Lmem                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 20.3.31 DSUB I mem_src                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
| · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| 20.3.32 DSUBT Lmem, dst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 448 |

| 20.3.33 EXP src                               | 449            |
|-----------------------------------------------|----------------|
| 20.3.34 FB[D] extpmad                         | 450            |
| 20.3.35 FBACC[D] src                          | 451            |
| 20.3.36 FCALA[D] src                          |                |
| 20.3.37 FCALL[D] extpmad                      |                |
| 20.3.38 FIRS Xmem, Ymem, pmad                 |                |
| 20.3.39 FRAME K                               |                |
| 20.3.40 FRET[D]                               |                |
| 20.3.41 FRETE[D]                              |                |
| 20.3.411 KETE[D]                              |                |
|                                               |                |
| 20.3.43 INTR K                                |                |
| 20.3.44 LD                                    |                |
| 20.3.45 LDM MMR, dst                          |                |
| 20.3.46 LD Xmem, dst    MAC[R] Ymem [, dst_]  |                |
| 20.3.47 LD Xmem, dst    MAS[R] Ymem [, dst_ ] |                |
| 20.3.48 LDR Smem, dst                         |                |
| 20.3.49 LDU Smem, dst                         |                |
| 20.3.50 LMS Xmem, Ymem                        | 471            |
| 20.3.51 LTD Smem                              | 472            |
| 20.3.52 MAC[R]                                | 473            |
| 20.3.53 MACA[R]                               | 476            |
| 20.3.54 MACD Smem, pmad, src                  | 478            |
| 20.3.55 MACP Smem, pmad, src                  |                |
| 20.3.56 MACSU Xmem, Ymem, src                 |                |
| 20.3.57 MAR Smem                              |                |
| 20.3.58 MAS[R]                                |                |
| 20.3.59 MASA                                  |                |
| 20.3.60 MAX dst                               |                |
| 20.3.61 MIN dst                               |                |
| 20.3.62 MPY[R]                                |                |
| 20.3.63 MPYA                                  |                |
| 20.3.64 MPYU Smem, dst                        |                |
| 20.3.65 MVDD Xmem, Ymem                       |                |
| 20.3.66 MVDK Smem, dmad                       |                |
|                                               |                |
| 20.3.67 MVDM dmad, MMR                        |                |
| 20.3.68 MVDP Smem, pmad                       |                |
| 20.3.69 MVKD dmad, Smem                       |                |
| 20.3.70 MVMD MMR, dmad                        |                |
| 20.3.71 MVMM MMRx, MMRy                       |                |
| 20.3.72 MVPD pmad, Smem                       |                |
| 20.3.73 NEG src [, dst ]                      |                |
| 20.3.74 NOP                                   |                |
| 20.3.75 NORM src [, dst ]                     |                |
| 20.3.76 OR                                    | 505            |
| 20.3.77 ORM #lk, Smem                         |                |
| 20.3.78 POLY Smem                             | 507            |
| 20.3.79 POPD Smem                             | 508            |
| 20.3.80 POPM MMR                              |                |
| 20.3.81 PORTR PA, Smem                        |                |
| 20.3.82 PORTW Smem, PA                        |                |
| 20.3.83 PSHD Smem                             |                |
| 20.3.84 PSHM MMR                              |                |
| -                                             | · <del>-</del> |

|    |               | C[D] cond [, cond [, cond ] ]    |     |
|----|---------------|----------------------------------|-----|
|    | 20.3.86 R     | EADA Smem                        | 514 |
|    | 20.3.87 R     | ESET                             | 515 |
|    |               | ET[D]                            |     |
|    |               | ETE[D]                           |     |
|    |               | ETF[D]                           |     |
|    |               | ND src [, dst ]                  |     |
|    |               | OL src                           |     |
|    |               | OLTC src                         |     |
|    |               |                                  |     |
|    |               | OR src                           |     |
|    |               | PT                               |     |
|    |               | PTB[D] pmad                      |     |
|    |               | PTZ dst, #lk                     |     |
|    |               | SBX N, SBIT                      |     |
|    |               | ACCD src, Xmem, cond             |     |
|    |               | SAT src                          |     |
|    | 20.3.101      | SFTA src, SHIFT [, dst ]         | 528 |
|    | 20.3.102      | SFTC src                         | 529 |
|    | 20.3.103      | SFTL src, SHIFT [, dst ]         | 530 |
|    | 20.3.104      |                                  |     |
|    | 20.3.105      | SQURA Smem, src                  |     |
|    |               | SQURS Smem, src                  |     |
|    | 20.3.107      |                                  |     |
|    |               | SSBX N, SBIT                     |     |
|    |               | ST                               |     |
|    | 20.3.110      | STH                              |     |
|    |               |                                  |     |
|    | 20.3.111      | STL M. are MMAD                  |     |
|    |               | STLM src, MMR                    |     |
|    |               | STM #lk, MMR                     |     |
|    |               | ST src, Ymem    ADD Xmem, dst    |     |
|    |               | ST  LD                           |     |
|    |               | ST src, Ymem                     |     |
|    | 20.3.117      | ST src, Ymem    MAS[R] Xmem, dst | 549 |
|    | 20.3.118      | ST src, Ymem    MPY Xmem, dst    | 551 |
|    | 20.3.119      | ST src, Ymem    SUB Xmem, dst    | 552 |
|    |               | STRCD Xmem, cond                 |     |
|    | 20.3.121      | SUB                              | 554 |
|    | 20.3.122      | SUBB Smem, src                   | 557 |
|    |               | SUBC Smem, src                   |     |
|    |               | SUBS Smem, src                   |     |
|    |               | TRAP K                           |     |
|    |               | WRITA Smem                       |     |
|    | 20.3.127      |                                  |     |
|    |               | XOR                              |     |
|    |               |                                  |     |
| 04 |               | XORM #lk, Smem                   |     |
| 21 |               | IcBSP (DSP)                      |     |
|    |               | писание McBSP                    |     |
|    |               | McBSP                            |     |
|    |               | cBSP1                            |     |
|    |               | cBSP2                            |     |
|    |               | cBSP3                            |     |
|    | 21.3 Конфигур | ирование последовательного порта | 573 |
|    |               |                                  |     |

| 21.3.1 SPCRH                                                          | 573 |
|-----------------------------------------------------------------------|-----|
| 21.3.2 SPCRL                                                          | 574 |
| 21.3.3 SPSRH                                                          | 575 |
| 21.3.4 PCRL                                                           | 577 |
| 21.4 Управление приемом и передачей                                   | 578 |
| 21.4.1 RCRH, XCRH                                                     |     |
| 21.4.2 RCRL, XCRL                                                     |     |
| 21.5 Порядок приема и передачи данных                                 |     |
| 21.6 Сброс последовательного порта                                    |     |
| 21.7 Программный внутренний сброс (биты управления регистра SPCR)     |     |
| 21.8 Обработка статусов                                               |     |
| 21.9 Состояние приемника: RRDY, RRINT, RFULL, RSYNCERR                | 580 |
| 21.10 Состояние передатчика                                           |     |
| 21.11 События и прерывания                                            |     |
| 21.12 Настройка битовой и кадровой синхронизации                      |     |
| 21.12.1 Фазы кадровой синхронизации                                   |     |
| 21.12.2 Упаковка данных заданием размеров кадра и слова               |     |
| 21.13 Задержка данных                                                 |     |
| 21.14 Пример многофазного кадра (АС97)                                |     |
| 21.15 Штатный режим работы McBSP                                      |     |
| 21.16 Режим игнорирования кадровой синхронизации                      |     |
|                                                                       | 500 |
| 21.17 Упаковка данных при помощи режима пропуска кадровой             | 588 |
| синхронизации                                                         |     |
| 21.18 Пропуск нежелательных кадров при помощи режима пропуска кадрово |     |
| синхронизации                                                         |     |
| 21.19 Особые ситуации работы последовательного порта                  |     |
| 21.20 Переполнение приемника (RFULL)                                  |     |
| 21.21 Перезапись передаваемых данных                                  |     |
| 21.22 Выравнивание данных и расширение знака                          |     |
| 21.23 Кодирование/декодирование данных                                |     |
| 21.24 Компадирование/декомпадирование по u- и A-законам               |     |
| 21.25 Кодирование/декодирование кодом Манчестер-2                     |     |
| 21.26 Порядок передачи бит в словах                                   |     |
| 21.27 Программируемые кадровая и битовая синхронизации                |     |
| 21.28 Внутренний генератора кадровой и битовой синхронизации          |     |
| 21.28.1 SRGRH                                                         |     |
| 21.28.2 SRGRL                                                         |     |
| 21.29 Сброс генератора кадровой и битовой синхронизации               |     |
| 21.30 Генератор битовой синхронизации                                 |     |
| 21.31 Полярность тактового сигнала генератора                         |     |
| 21.32 Битовая и кадровая синхронизация                                | 599 |
| 21.33 Режим КЗ                                                        |     |
| 21.34 Генератор кадровой синхронизации                                | 601 |
| 21.35 Период и длина кадрового синхроимпульса                         |     |
| 21.36 Примеры битовой и кадровой синхронизации в различных форматах   | 602 |
| 21.36.1 ST-BUS                                                        | 602 |
| 21.36.2 ST-BUS с удвоенной частотой                                   | 603 |
| 21.37 Работа в многоканальном режиме с выбором каналов                |     |
| 21.37.1 MCRH, MCRL, XMCR, RMCR                                        |     |
| 21.38 Включение многоканального режима                                |     |
| 21.39 Регистр управления активностью каналов                          |     |
| 21.39.1 XCERH, RCERH                                                  |     |
| ,                                                                     |     |

|    |      | 21.39.2 | XCERL, RCERL                                                               | 606 |
|----|------|---------|----------------------------------------------------------------------------|-----|
|    |      | 21.39.3 | Интерфейс A-bis                                                            | 606 |
| 22 | Сис  |         | Таймер (DSP)                                                               |     |
|    |      |         | ры таймера (DSP)                                                           |     |
|    |      |         | Регистры таймера (TIM)                                                     |     |
|    |      |         | Регистр периода таймера (PRD)                                              |     |
|    |      |         | Управляющий регистр таймера (TCR)                                          |     |
| 23 | Раб  |         | лера (DSP)                                                                 |     |
| 24 |      |         | DMA (DSP)                                                                  |     |
|    |      |         | ности контроллера DMA(DSP)                                                 |     |
|    |      |         | кности доступа DMA(DSP)                                                    |     |
|    |      |         | ры контроллера DMÀ(DSP)                                                    |     |
|    |      |         | деление аппаратных запросов по каналам DMA(DSP)                            |     |
| 25 |      |         | AudioCodec (DSP)                                                           |     |
|    |      |         | е рабочей частоты аудиокодека                                              |     |
|    |      |         | ктура модуля                                                               |     |
|    | 25.3 | Анапого | овые площадки ввода-вывода                                                 | 616 |
|    | 20.0 |         | Вход микрофона                                                             |     |
|    |      |         | Входы INP и INM                                                            |     |
|    |      |         | Аналоговые выходы                                                          |     |
|    | 25 4 |         | с модулем                                                                  |     |
|    | 20.7 |         | Воспроизведение звука (ЦАП)                                                |     |
|    |      | 25.4.1  | Оцифровка входного потока (АЦП)                                            | 619 |
|    |      |         | Запросы DMA                                                                |     |
|    |      |         | Прерывания модуля                                                          |     |
|    | 25.5 |         | ы управления                                                               |     |
|    | 20.0 | •       | Регистр общего управления кодеком                                          |     |
|    |      |         | Регистр управления АЦП                                                     |     |
|    |      |         | Регистр управления ЦАП                                                     |     |
|    |      |         | Флаги прерываний                                                           |     |
| 26 | Кош  |         | блока шифрования ГОСТ 28147-89 (DSP)                                       |     |
| 20 |      |         | ие регистров                                                               |     |
|    | 20.1 |         | Регистр управления CRPT_CWR                                                |     |
|    |      |         | Регистр состояния CRPT SR                                                  |     |
|    |      | 26.1.2  | Регистр данных шифрации CRPT_DATA                                          | 627 |
|    |      | 26.1.3  | Регистр ключа шифрации CRPT KR                                             | 627 |
|    |      | 20.1.4  | Регистр ключа шифрации СКРТ_КК<br>Регистр синхропосылки CRPT_SYNR          | 620 |
|    |      | 20.1.5  | Регистр констант замены CRPT CR                                            | 620 |
|    |      |         | Регистр имитовставки CRPT_IMIT                                             |     |
|    |      |         | Регистр числа итераций CRPT_ITER                                           |     |
|    | 26.2 |         | блока по шифрованию и дешифрованию данных                                  |     |
|    | 20.2 |         |                                                                            |     |
|    |      |         | Шифрование данных. Режим простой замены                                    |     |
|    |      |         | Дешифрование данных. Режим простой замены                                  |     |
|    |      |         | Шифрование данных. Режим гаммирования                                      |     |
|    |      |         | Дешифрование данных. Режим гаммирования                                    |     |
|    |      |         | Шифрование данных. Режим гаммирования с обратной связью                    |     |
|    |      |         | Дешифрование данных. Режим гаммирования с обратной связью                  |     |
|    |      |         | Режим самопроверки                                                         | 032 |
|    |      | ∠0.∠.ၓ  | Порядок занесения констант замены и ключа в соответствии с ГОСТ Р 34.11-94 | 632 |
| 27 | Кон  | гроллер | интерфейса MDR_USB                                                         |     |
|    |      |         | лизация контроллера при включении                                          |     |
|    |      |         |                                                                            |     |

|    | 27.2 Задание параметров шины USB и события подключения/отключения | 634        |
|----|-------------------------------------------------------------------|------------|
|    | 27.3 Задание адреса и инициализация оконечных точек               |            |
|    | 27.4 Транзакция IN (USB Device)                                   |            |
|    | 27.5 Транзакция SETUP/OUT (USB Device)                            |            |
|    | 27.6 Транзакция SETUP/OUT (USB Host)                              |            |
|    | 27.7 Транзакция IN (USB Host)                                     |            |
|    | 27.8 Отправка SOF пакетов и отсчет времени (USB Host)             | 640<br>6/1 |
|    | 27.9 Описание регистров управление контроллером USB интерфейса    |            |
|    | 27.9.1 MDR_USB->HSCR                                              |            |
|    |                                                                   |            |
|    | 27.9.2 MDR_USB->HSVR                                              |            |
|    | 27.9.3 MDR_USB->HTXC                                              |            |
|    | 27.9.4 MDR_USB->HTXT                                              |            |
|    | 27.9.5 MDR_USB->HTXLC                                             |            |
|    | 27.9.6 MDR_USB->HTXSE                                             |            |
|    | 27.9.7 MDR_USB->HTXA                                              |            |
|    | 27.9.8 MDR_USB->HTXE                                              |            |
|    | 27.9.9 MDR_USB->HFN                                               | 647        |
|    | 27.9.10 MDR_USB->HIS                                              | 648        |
|    | 27.9.11 MDR_USB->HIM                                              | 648        |
|    | 27.9.12 MDR USB->HRXS                                             | 649        |
|    | 27.9.13 MDR_USB->HRXP                                             |            |
|    | 27.9.14 MDR USB->HRXA                                             |            |
|    | 27.9.15 MDR_USB->HRXE                                             |            |
|    | 27.9.16 MDR_USB->HRXCS                                            |            |
|    | 27.9.17 MDR_USB->HSTM                                             |            |
|    | 27.9.18 MDR_USB->HRXFD                                            |            |
|    | 27.9.19 MDR_USB->HRXDC                                            |            |
|    | 27.9.20 MDR_USB->HRXFC                                            |            |
|    |                                                                   |            |
|    | 27.9.21 MDR_USB->HTXFD                                            |            |
|    | 27.9.22 MDR_USB->HTXFC                                            |            |
|    | 27.9.23 MDR_USB->SEP[x].CTRL                                      | 652        |
|    | 27.9.24 MDR_USB->SEP[x].STS                                       |            |
|    | 27.9.25 MDR_USB->SEP[x].TS                                        |            |
|    | 27.9.26 MDR_USB->SEP[x].NTS                                       |            |
|    | 27.9.27 MDR_USB->SC                                               |            |
|    | 27.9.28 MDR_USB->SLS                                              |            |
|    | 27.9.29 MDR_USB->SIS                                              | 655        |
|    | 27.9.30 MDR_USB->SIM                                              | 656        |
|    | 27.9.31 MDR_USB->SA                                               | 656        |
|    | 27.9.32 MDR_USB->SFN                                              | 657        |
|    | 27.9.33 MDR_USB->SEP[x].RXFD                                      |            |
|    | 27.9.34 MDR_USB->SEP[x].RXFDC                                     |            |
|    | 27.9.35 MDR_USB->SEP[x].RXFC                                      |            |
|    | 27.9.36 MDR_USB->SEP[x].TXFD                                      |            |
|    | 27.9.37 MDR_USB->SEP[x].TXFDC                                     | 658        |
| 28 |                                                                   |            |
| 20 |                                                                   |            |
|    | 28.1 Функционирование                                             |            |
|    | 28.1.1 Структурная схема                                          |            |
|    | 28.1.2 Инициализация таймера                                      |            |
|    | 28.1.3 Режим таймера                                              |            |
|    | 28.2 Режимы счета                                                 |            |
|    | 28.3 Источник событий для счета                                   | 665        |

|    |      |         | Внутренний тактовый сигнал (TIM_CLK)                       |       |
|----|------|---------|------------------------------------------------------------|-------|
|    |      | 28.3.2  | События в других счетчиках (CNT==ARR в таймере X)          | . 667 |
|    |      | 28.3.3  | Внешний тактовый сигнал «Режим 1». События на линиях ТхСНС | )     |
|    |      |         | данного счетчика                                           | .668  |
|    |      | 28.3.4  | Внешний тактовый сигнал «Режим 2». События на входе ETR    |       |
|    |      |         | данного счетчика                                           | .670  |
|    | 28.4 | Режим   | захвата                                                    |       |
|    |      |         | ШИМ                                                        |       |
|    |      |         | DЫ                                                         |       |
|    | _0.0 |         | Обычный счетчик                                            |       |
|    |      |         | Режим захвата                                              |       |
|    |      |         | Режим ШИМ                                                  |       |
|    | 28.7 |         | ние регистров блока таймера                                |       |
|    | 20.1 |         | MDR TIMERx->CNT                                            |       |
|    |      |         | MDR TIMERx->PSG                                            |       |
|    |      |         | MDR TIMERx->ARR                                            |       |
|    |      |         | MDR_TIMERx->ARR                                            |       |
|    |      |         | MDR_TIMERx->CNTRL                                          |       |
|    |      |         |                                                            |       |
|    |      |         | MDR_TIMERx -> CCRy1                                        |       |
|    |      |         | MDR_TIMERx->CHy_CNTRL                                      |       |
|    |      |         | MDR_TIMERx->CHy_CNTRL1                                     |       |
|    |      |         | MDR_TIMERx->CHy_CNTRL2                                     |       |
|    |      |         | MDR_TIMERx->CHy_DTG                                        |       |
|    |      |         | MDR_TIMERx->BRKETR_CNTRL                                   |       |
|    |      |         | MDR_TIMERx->STATUS                                         |       |
|    |      |         | MDR_TIMERx->IE                                             |       |
| ~~ | 16   |         | MDR_TIMERx->DMA_RE                                         |       |
| 29 |      |         | MDR_ADC                                                    |       |
|    |      |         | разование внешнего канала                                  |       |
|    |      |         | цовательное преобразование нескольких каналов              |       |
|    |      |         | разование с контролем границ                               |       |
|    |      |         | нний источник опорного напряжения                          |       |
|    |      |         | температуры                                                |       |
|    |      |         | онный запуск двух АЦП                                      |       |
|    |      |         | заряда внутренней емкости                                  |       |
|    | 29.8 |         | ние регистров блока контроллера АЦП                        |       |
|    |      |         | MDR_ADC->ADC1_CFG                                          |       |
|    |      |         | MDR_ADC->ADC2_CFG                                          |       |
|    |      |         | MDR_ADC->ADCx_H_LEVEL                                      |       |
|    |      |         | MDR_ADC->ADCx_L_LEVEL                                      |       |
|    |      |         | MDR_ADC->ADCx_RESULT                                       |       |
|    |      |         | MDR_ADC->ADCx_STATUS                                       |       |
|    |      | 29.8.7  | MDR_ADC->ADCx_CHSEL                                        | .703  |
| 30 |      |         | MDR_DAC                                                    |       |
|    | 30.1 |         | ние регистров блока контроллера ЦАП                        |       |
|    |      | 30.1.1  | MDR_DAC->CFG                                               | .705  |
|    |      | 30.1.2  | MDR_DAC->DAC1_DATA                                         | .705  |
|    |      | 30.1.3  | MDR_DAC->DAC2_DATA                                         | .706  |
| 31 | Кон  | гроллер | схемы компаратора MDR_COMP                                 | . 707 |
|    | 31.1 | Сравне  | ение внешних сигналов                                      | .708  |
|    |      |         | ение сигнала с внутренним источником опорного напряжения   |       |
|    |      |         | ение внешних сигналов с внутренней шкалой напряжений       |       |
|    |      |         |                                                            |       |

|    | 31.4 | Формирование внутренней шкалы напряжений7                            | <b>7</b> 08     |
|----|------|----------------------------------------------------------------------|-----------------|
|    |      | Описание регистров блока контроллера компаратора7                    | <b>710</b>      |
|    |      | 31.5.1 MDR_COMP->CFG7                                                | <b>'</b> 10     |
|    |      | 31.5.2 MDR_COMP->RESULT7                                             | <b>'</b> 11     |
|    |      | 31.5.3 MDR_COMP->RESULT_LATCH7                                       | <b>'</b> 11     |
| 32 | Кон  | роллер интерфейса MDR_I2C7                                           | <b>'</b> 12     |
|    | 32.1 | Конфигурация системы7                                                | <b>7</b> 12     |
|    |      | Протокол I2С                                                         |                 |
|    | 32.3 | Сигнал START7                                                        | <sup>7</sup> 13 |
|    | 32.4 | Передача адреса7                                                     | <sup>7</sup> 13 |
|    |      | Передача данных7                                                     |                 |
|    | 32.6 | Сигнал STOP7                                                         | <sup>7</sup> 14 |
|    | 32.7 | Описание регистров контроллера I2C7                                  | <sup>7</sup> 14 |
|    |      | 32.7.1 MDR_I2C->PRL7                                                 | <b>'</b> 14     |
|    |      | 32.7.2 MDR_I2C->PRH7                                                 | <b>'</b> 14     |
|    |      | 32.7.3 MDR_I2C->CTR7                                                 | <b>'</b> 15     |
|    |      | 32.7.4 MDR_I2C->RXD7                                                 | <b>'</b> 15     |
|    |      | 32.7.5 MDR_I2C->STA7                                                 | <b>'</b> 15     |
|    |      | 32.7.6 MDR_I2C->TXD7                                                 | <b>'</b> 16     |
|    |      | 32.7.7 MDR_I2C->CMD7                                                 | <b>'</b> 17     |
| 33 | Кон  | роллер MDR_SSP7                                                      | <b>7</b> 18     |
|    | 33.1 | Основные характеристики модуля SSP7                                  | <b>7</b> 18     |
|    | 33.2 | Программируемые параметры7                                           | <b>'</b> 18     |
|    | 33.3 | Характеристики интерфейса SPI7                                       | <b>'</b> 19     |
|    | 33.4 | Характеристики интерфейса Microwire7                                 | <b>′</b> 20     |
|    | 33.5 | Характеристики интерфейса SSI7                                       | <b>′</b> 20     |
|    | 33.6 | Общий обзор модуля SSP7                                              | <b>7</b> 20     |
|    |      | 33.6.1 Блок формирования тактового сигнала7                          | ′21             |
|    |      | 33.6.2 Буфер FIFO передатчика7                                       |                 |
|    |      | 33.6.3 Буфер FIFO приемника7                                         | ′21             |
|    |      | 33.6.4 Блок приема и передачи данных7                                |                 |
|    |      | 33.6.5 Блок формирования прерываний7                                 |                 |
|    |      | 33.6.6 Интерфейс прямого доступа к памяти7                           | ′22             |
|    |      | 33.6.7 Конфигурирование приемопередатчика7                           |                 |
|    |      | 33.6.8 Разрешение работы приемопередатчика7                          |                 |
|    |      | 33.6.9 Соотношения между тактовыми сигналами7                        |                 |
|    |      | 33.6.10 Программирование регистра управления CR07                    |                 |
|    |      | 33.6.11 Программирование регистра управления CR17                    |                 |
|    |      | 33.6.12 Формирование тактового сигнала обмена данными7               |                 |
|    |      | 33.6.13 Формат информационного кадра7                                |                 |
|    |      | 33.6.14 Формат синхронного обмена SSI фирмы Texas Instruments7       |                 |
|    |      | 33.6.15 Формат синхронного обмена SPI фирмы Motorola7                |                 |
|    |      | 33.6.16 Формат синхронного обмена SPI фирмы Motorola, SPO=0, SPH=0 7 |                 |
|    |      | 33.6.17 Формат синхронного обмена SPI фирмы Motorola, SPO=0, SPH=17  |                 |
|    |      | 33.6.18 Формат синхронного обмена SPI фирмы Motorola, SPO=1, SPH=07  |                 |
|    |      | 33.6.19 Формат синхронного обмена SPI фирмы Motorola, SPO=1, SPH=17  | ′30             |
|    |      | 33.6.20 Формат синхронного обмена Microwire фирмы National           |                 |
|    |      | Semiconductor                                                        |                 |
|    |      | 33.6.21 Примеры конфигурации модуля в ведущем и ведомом режимах7     |                 |
|    |      | 33.6.22 Интерфейс прямого доступа к памяти                           |                 |
|    | 33.7 | Программное управление модулем                                       |                 |
|    |      | 33.7.1 Общая информация7                                             | ′37             |

|    |      |         | Описание регистров контроллера SSP                   |     |
|----|------|---------|------------------------------------------------------|-----|
|    |      | 33.7.3  | MDR_SSPx->CR0                                        | 739 |
|    |      | 33.7.4  | MDR_SSPx->CR1                                        | 740 |
|    |      | 33.7.5  | MDR_SSPx->DR                                         | 740 |
|    |      | 33.7.6  | MDR_SSPx->SR                                         | 741 |
|    |      | 33.7.7  | MDR_SSPx->CPSR                                       | 742 |
|    |      | 33.7.8  | MDR_SSPx->IMSC                                       | 742 |
|    |      | 33.7.9  | MDR_SSPx->RIS                                        | 743 |
|    |      | 33.7.10 | ) MDR_SSPx->MIS                                      | 743 |
|    |      | 33.7.11 | MDR_SSPx->ICR                                        | 743 |
|    |      | 33.7.12 | MDR_SSPx->DMACR                                      | 744 |
|    | 33.8 | Преры   | вания                                                | 744 |
|    |      | 33.8.1  | SSPRXINTR                                            | 745 |
|    |      | 33.8.2  | SSPTXINTR                                            | 745 |
|    |      | 33.8.3  | SSPRORINTR                                           | 745 |
|    |      | 33.8.4  | SSPRTINTR                                            | 745 |
|    |      | 33.8.5  | SSPINTR                                              | 745 |
| 34 | Кон  | троллер | ) MDR_UART                                           | 746 |
|    |      |         | ные сведения                                         |     |
|    |      | 34.1.1  | Основные характеристики модуля UART                  | 746 |
|    |      |         | Программируемые параметры                            |     |
|    |      |         | Отличия от контроллера UART 16C650                   |     |
|    | 34.2 |         | юнальные возможности                                 |     |
|    | 34.3 | Описан  | ние функционирования блока UART                      | 749 |
|    |      |         | Генератор тактового сигнала приемопередатчика        |     |
|    |      |         | Буфер FIFO передатчика                               |     |
|    |      |         | Буфер FIFO приемника                                 |     |
|    |      |         | Блок передатчика                                     |     |
|    |      |         | Блок приемника                                       |     |
|    |      |         | Блок формирования прерываний                         |     |
|    |      | 34.3.7  |                                                      |     |
|    |      | 34.3.8  | Блок и регистры синхронизации                        |     |
|    | 34.4 |         | ние функционирования ИК кодека IrDA SIR              |     |
|    |      |         | Кодер ИК передатчика                                 |     |
|    |      |         | Декодер ИК приемника                                 |     |
|    | 34.5 | Описан  | ние работы UART                                      | 753 |
|    |      |         | Сброс модуля                                         |     |
|    |      |         | Тактовые сигналы                                     |     |
|    |      | 34.5.3  | Работа универсального асинхронного приемопередатчика | 753 |
|    |      |         | Коэффициент деления частоты                          |     |
|    |      |         | Передача и прием данных                              |     |
|    |      | 34.5.6  | Биты ошибки                                          | 755 |
|    |      | 34.5.7  | Бит переполнения буфера                              | 755 |
|    |      | 34.5.8  | Запрет буфера FIFO                                   |     |
|    |      | 34.5.9  | Работа кодека ИК обмена данными IrDA SIR             |     |
|    |      |         | ) Модуляция данных IrDA                              |     |
|    | 34.6 |         | управления модемом                                   |     |
|    |      |         | Аппаратное управление потоком данных                 |     |
|    |      |         | Управление потоком данных по линии RTS               |     |
|    |      |         | Управление потоком данных по линии CTS               |     |
|    | 34.7 |         | рейс прямого доступа к памяти                        |     |
|    |      |         | вания                                                |     |
|    |      |         |                                                      |     |

|    |                  | 34.8.1         | UARTMSINTR                                                               | 763 |
|----|------------------|----------------|--------------------------------------------------------------------------|-----|
|    |                  | 34.8.2         | UARTRXINTR                                                               | 763 |
|    |                  | 34.8.3         | UARTTXINTR                                                               | 763 |
|    |                  | 34.8.4         | UARTRTINTR                                                               | 764 |
|    |                  | 34.8.5         | UARTEINTR                                                                | 764 |
|    |                  | 34.8.6         | UARTINTR                                                                 | 764 |
|    | 34.9             | Програ         | ммное управление модулем                                                 | 764 |
|    |                  |                | Общая информация                                                         |     |
|    |                  |                | Обобщенные данные о регистрах устройства                                 |     |
|    |                  |                | MDR_UARTx->DR                                                            |     |
|    |                  | 34.9.4         | MDR_UARTx->RSR_ECR                                                       | 767 |
|    |                  |                | MDR_UARTx->FR                                                            |     |
|    |                  |                | MDR UARTx->ILPR                                                          |     |
|    |                  |                | MDR_UARTx->IBRD                                                          |     |
|    |                  |                | MDR_UARTx->FBRD                                                          |     |
|    |                  |                | MDR_UARTx->LCR_H                                                         |     |
|    |                  |                | MDR_UARTx->CR                                                            |     |
|    |                  |                | MDR UARTx->IFLS                                                          |     |
|    |                  |                | MDR_UARTx->IMSC                                                          |     |
|    |                  |                | MDR_UARTx->RIS                                                           |     |
|    |                  |                | MDR_UARTx->MIS                                                           |     |
|    |                  |                | MDR_UARTx->ICR                                                           |     |
|    |                  |                | MDR_UARTx->DMACR                                                         |     |
| 35 | Конт             |                | SDIO                                                                     |     |
| 00 |                  |                | ие функционирования контроллера                                          |     |
|    | 55.1             |                | Передача команды (по спецификации SDIO)                                  |     |
|    |                  |                | Прием команды (по спецификации SDIO)Прием команды (по спецификации SDIO) |     |
|    |                  |                | Передача данных (по спецификации SDIO)                                   |     |
|    |                  |                | Прием данных (по спецификации SDIO)                                      |     |
|    | 35.2             |                | зания                                                                    |     |
|    |                  |                | включения контроллера                                                    |     |
|    | 55.5             |                | Подключение SD card к контроллеру                                        |     |
|    | 35 /             |                | ы SD                                                                     |     |
|    | JJ. <del>4</del> |                | Регистр управления                                                       |     |
|    |                  |                | Регистр состояния                                                        |     |
|    |                  |                | •                                                                        |     |
|    |                  |                | Регистр команд                                                           |     |
|    |                  |                | Регистр данных                                                           |     |
|    |                  |                | Регистр контрольной суммы линии команд                                   |     |
|    |                  |                | Регистры контрольных сумм линий данных                                   |     |
|    |                  |                | Регистр-счётчик принимаемых/ передаваемых бит линии команд.              |     |
| 26 | Про              |                | Регистр-счётчик принимаемых/ передаваемых бит линий данных               |     |
| 36 |                  |                | я и исключения RISC                                                      |     |
|    | 30.1             |                | СКЛЮЧЕНИЙ                                                                |     |
|    |                  |                | RESET                                                                    |     |
|    |                  |                | NON MASKABLE INTERRUPT (NMI)                                             |     |
|    |                  |                | Hard Fault                                                               |     |
|    |                  |                | Memory Management fault                                                  |     |
|    |                  |                | Bus Fault                                                                |     |
|    |                  |                | Usage Fault                                                              |     |
|    |                  |                | SVCall                                                                   |     |
|    |                  |                | PendSV                                                                   |     |
|    |                  | <i>3</i> 6.1.9 | SysTick                                                                  | 794 |

|                | 36.2 | Преры  | вания (IRQ)                                               | 795 |
|----------------|------|--------|-----------------------------------------------------------|-----|
|                |      |        | отчики исключений                                         |     |
|                |      | •      | ца векторов                                               |     |
|                | 36.5 | ПаоиаП | итеты исключений                                          | 796 |
|                |      |        | Группировка приоритетов прерываний                        |     |
|                | 36.6 |        | обработчик и выход из обработчика                         |     |
|                | 00.0 |        | Приоритетное прерывание                                   |     |
|                |      |        |                                                           |     |
|                |      |        | Возврат                                                   |     |
|                |      | 30.0.3 | Передача управления без восстановления контекста (tail-cl |     |
|                |      | 00.0.4 | 0                                                         |     |
|                |      |        | Запоздавшее исключение (late-arriving exception)          |     |
|                |      | 36.6.5 | Вход в процедуру обработки исключения                     |     |
|                |      |        | Возврат из обработчика исключения                         |     |
|                | 36.7 |        | отка отказов                                              |     |
|                |      | 36.7.1 | Типы отказов                                              | 800 |
|                |      | 36.7.2 | Эскалация отказов и тяжелые отказы                        | 801 |
|                |      | 36.7.3 | Регистры состояния и адреса отказа                        | 801 |
|                |      |        | Блокировка                                                |     |
|                | 36.8 |        | ление электропитанием                                     |     |
|                |      |        | Переход в режим пониженного энергопотребления             |     |
|                |      |        | Ожидание прерывания                                       |     |
|                |      | 36.8.3 |                                                           |     |
|                |      |        | Переход в режим ожидания по выходу из обработчика искг    |     |
|                |      | 30.0.4 | (режим Sleep)                                             |     |
|                |      | 26 0 E |                                                           |     |
|                |      | 36.8.5 | ,,                                                        |     |
|                |      | 30.8.6 | Рекомендации по программированию режима энергопотре       |     |
| · <del>-</del> | 16   |        | × N/ (0 (DIOO)                                            |     |
| 37             |      |        | о прерываний NVIC (RISC)                                  |     |
|                |      |        | работы прерываний контроллера NVIC                        |     |
|                | 37.2 |        | енный доступ к регистрам контроллера прерываний           |     |
|                |      | 37.2.1 | NVIC->ISER[x]                                             | 811 |
|                |      | 37.2.2 | NVIC->ICER[x]                                             | 811 |
|                |      | 37.2.3 | NVIC->ISPR[x]                                             | 812 |
|                |      |        | NVIC->ICPR[x]                                             |     |
|                |      |        | NVIC->IABR[x]                                             |     |
|                |      |        | NVIC->IP[x]                                               |     |
|                |      |        | NVIC->STIR                                                |     |
|                | 37 3 |        | вания, срабатывающие по уровню сигнала                    |     |
|                |      |        | атное и программное управление прерываниями               |     |
|                |      |        | ендации по работе с контроллером прерываний               |     |
| 20             |      |        |                                                           |     |
| 38             |      |        | пения системой RISC                                       |     |
|                | 38.1 |        | енный доступ к регистрам блока управления системой        |     |
|                |      |        | InterrupType->ACTLR                                       |     |
|                |      |        | SCB->CPUID                                                |     |
|                |      |        | SCB->ICSR                                                 |     |
|                |      |        | SCB->VTOR                                                 |     |
|                |      |        | SCB->AIRCR                                                |     |
|                |      | 38.1.6 | SCB->SCR                                                  | 823 |
|                |      | 38.1.7 | SCB->CCR                                                  | 824 |
|                |      | 38.1.8 | SCB->SHP[x]                                               |     |
|                |      |        | SCB->SHCSR                                                |     |
|                |      |        | SCB->CFSR                                                 |     |
|                |      | •      | = =                                                       |     |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|    | 38.1.11 Поле MMFSR                                | 829 |
|----|---------------------------------------------------|-----|
|    | 38.1.12 Поле BFSR                                 | 830 |
|    | 38.1.13 Поле UFSR                                 |     |
|    | 38.1.14 SCB->HFSR                                 |     |
|    | 38.1.15 SCB->MMFAR                                |     |
|    | 38.1.16 SCB->BFAR                                 |     |
| 39 |                                                   |     |
|    | 39.1 Описание регистров блока сторожевых таймеров |     |
|    | 39.1.1 IWDG_KR                                    |     |
|    | 39.1.2 IWDG_PR                                    |     |
|    | 39.1.3 IWDG_RLR                                   |     |
|    | 39.1.4 IWDG_SR                                    | 837 |
|    | 39.1.5 WWDG_CR                                    | 837 |
|    | 39.1.6 WWDG_CFR                                   | 838 |
|    | 39.1.7 WWDG_SR                                    | 838 |
| 40 | Типовая схема включения                           | 839 |
| 41 | Типовые зависимости                               | 840 |
| 42 | Предельные и предельно-допустимые режимы работы   | 842 |
| 43 | Электрические параметры микросхемы                | 845 |
| 44 | Справочные данные                                 | 848 |
| 45 | Габаритный чертеж микросхемы                      |     |
| 46 | Информация для заказа                             | 856 |

## 1 Введение

Двухъядерный микропроцессор является системой, основанной на двух вычислительных ядрах: RISC (32 разряда) и DSP (аналог TMS320C54). В микросхеме реализована встроенная Flash память программ, размером 128 Кбайт, ОЗУ RISC размером 32 Кбайт и две ОЗУ DSP (память программ размером 128 Кбайт и память данных размером 128 Кбайт). Ядро RISC работает на тактовой частоте до 100 МГц, ядро DSP работает на частоте до 100 МГц. Набор интерфейсных периферийных модулей включает в себя контроллер USB интерфейса со встроенным аналоговым приемопередатчиком (12 Мбит/c Full Speed, либо 1,5 Мбит/c Low Speed), стандартные интерфейсы UART(x3), SPI(x4), I2C(x1) и McBSP(x3). Контроллер внешней системной шины позволяет работать с внешними микросхемами статического ОЗУ и ПЗУ, Flash памятью и другими периферийными устройствами. Также в микросхеме имеется интерфейс SDIO. Микроконтроллеры содержат три 16-ти разрядных таймера с 4-мя каналами схем захвата и интегрированными модулями ШИМ с функциями формирования «мертвой зоны» и аппаратной блокировки, системный 24-х разрядный таймер (RISC), системный таймер (DSP) и два сторожевых таймера. Для работы с аналоговыми устройствами микроконтроллер имеет два 12-ти разрядных высокоскоростных (до 0,5 Мвыб/с) АЦП с возможностью оцифровки информации из 16 каналов, встроенные датчики температуры и опорного напряжения, 12-ти разрядный ЦАП и схему встроенного компаратора с тремя входами и внутренней шкалой напряжений.

Встроенные RC-генераторы HSI (8 МГц) и LSI (40 кГц) и внешние генераторы HSE (2...16 МГц) и LSE (32 кГц) и три схемы умножения тактовой частоты PLL отдельно для ядра RISC, USB интерфейса и всей DSP части устройства позволяют гибко настраивать скорость работы микроконтроллера.

Архитектура доступа к памяти и периферийным устройствам при помощи матрицы системных шин позволяет минимизировать возможные конфликты при работе системы и повысить общую производительность. В систему включены два DMA контроллера. Контроллер DMA RISC части позволяет организовать обмен между любыми блоками памяти и периферийными устройствами (включая устройства домена DSP) без участи процессорного ядра RISC. Также в системе имеется отдельный контроллер DMA для DSP части, который может управлятся как при помощи ядра RISC, так и при помощи ядра DSP и имеет доступ ко всему домену DSP (память программ DSP, память данных DSP, таймер DSP, блоки McBSP, модуль шифрования и аудиокодек).

В систему включен внутренний регулятор напряжения питания для цифровой части на 1,8 В. Таким образом, для питания микросхемы достаточно подать внешнее напряжение в диапазоне от 2.2 до 3.6 В.

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

# 2 Условное графическое изображение

| 132           |                                       |           |            | 67                       |
|---------------|---------------------------------------|-----------|------------|--------------------------|
| 131           | PA[0]                                 | 400451147 | PD[0]      | 68                       |
| 130           | PA[1]                                 | 1901ВЦ1Т  | PD[1]      | 73                       |
| 129           | PA[2]                                 |           | PD[2]      | 74                       |
| 128           | PA[3]                                 |           | PD[3]      | 72                       |
| 127           | PA[4]                                 |           | PD[4]      | 75                       |
|               | PA[5]                                 |           | PD[5]      |                          |
| 126           | PA[6]                                 |           | PD[6]      | 76<br>71                 |
| 125           | PA[7]                                 |           | PD[7]      |                          |
| 124           | PA[8]                                 |           | PD[8]      | 70                       |
| 123           | PA[9]                                 |           | PD[9]      | 77                       |
| 122           | PA[10]                                |           | PD[10]     | 69                       |
| 121           | PA[11]                                |           | PD[11]     | 66                       |
| 120           | PA[12]                                |           | PD[12]     | 65                       |
| 119           | PA[13]                                |           | PD[13]     | 64                       |
| 118           | PA[14]                                |           | PD[14]     | 63                       |
| 117           | PA[15]                                |           | PD[15]     | 62                       |
| 115           | PB[0]                                 |           | PE[0]      | 59                       |
| 114           | PB[1]                                 |           | PE[1]      | 58                       |
| 113           | PB[2]                                 |           | PE[2]      | 51                       |
| 112           | PB[3]                                 |           |            | 50                       |
| 111           |                                       |           | PE[3]      | 53                       |
| 110           | PB[4]                                 |           | PE[4]      | 52                       |
| 109           | PB[5]                                 |           | PE[5]      | 35                       |
| 108           | PB[6]                                 |           | PE[6]      | 34                       |
| 107           | PB[7]                                 |           | PE[7]      | 49                       |
| 106           | PB[8]                                 |           | PE[8]      | 57                       |
| 105           | PB[9]                                 |           | PE[9]      | 56                       |
| 101           | PB[10]                                |           | PE[10]     | 23                       |
| 100           | PB[11]                                |           | PE[11]     | 22                       |
| 99            | PB[12]                                |           | PE[12]     | 21                       |
| 98            | PB[13]                                |           | PE[13]     | 48                       |
| 97            | PB[14]                                |           | PE[14]     | 20                       |
| 96            | PB[15]                                |           | PE[15]     | 4                        |
| 95            | PC[0]                                 |           | PF[0]      | 5                        |
| 94            | PC[1]                                 |           | PF[1]      | 6                        |
| 93            | PC[2]                                 |           | PF[2]      | 7                        |
| 92            | PC[3]                                 |           | PF[3]      | 8                        |
| 91            | PC[4]                                 |           | PF[4]      | 9                        |
| 90            | PC[5]                                 |           | PF[5]      | 10                       |
| 89            | PC[6]                                 |           | PF[6]      | 11                       |
| 88            | PC[7]                                 |           | PF[7]      | 12                       |
| 87            | PC[8]                                 |           | PF[8]      | 13                       |
| 86            | PC[9]                                 |           | PF[9]      | 14                       |
| 85            | PC[10]                                |           | PF[10]     | 15                       |
| 84            | PC[11]                                |           | PF[11]     | 16                       |
| 83            | PC[12]                                |           | PF[12]     | 17                       |
| 82            | PC[13]                                |           | PF[13]     | 18                       |
| 81            | PC[14]                                |           | PF[14]     | 19                       |
|               | PC[15]                                |           | PF[15]     |                          |
| 32            | OSC_IN                                |           | OSC_OUT    | 33                       |
| 43            | INP1                                  |           | OUTP1      | 38                       |
| 44            | INM1                                  |           | OUTM1      | 39                       |
| 45            | INP2                                  |           | BIAS       | 40                       |
| 46            | INM2                                  |           | טותט       |                          |
| 47            | MICIN                                 |           |            |                          |
|               | mart                                  |           | 7.0        | 27                       |
| 25            | _                                     |           | DP         | 28                       |
|               | RESET                                 |           | DN         | 37                       |
| 36            | WAKEUP                                |           | STANDBY    |                          |
| 24            | SHDN                                  |           |            |                          |
| 3,31,78,102   | Ucc                                   |           | GND        | 2, 30, 55,<br>60, 79,103 |
| 54, 61        | U <sub>CCA</sub>                      |           |            | 42                       |
| 26            | U <sub>CCAU</sub><br>U <sub>CCB</sub> |           | $GND_{AU}$ |                          |
| 1, 29, 80,104 | U <sub>CCD</sub>                      |           | NC         | 116                      |
|               | -000                                  | •         |            |                          |

Рисунок 2-1 - Условное графическое обозначение микросхемы



Рисунок 2-2 - Диаграмма расположения выводов

# 3 Описание выводов

Таблица 3-1 - Описание выводов

| Номер<br>вывода | Номер<br>контактной<br>площадки (КП) | Обозначение<br>вывода | Назначение вывода                               |  |  |
|-----------------|--------------------------------------|-----------------------|-------------------------------------------------|--|--|
|                 |                                      |                       | Питание 1,8 (тестовый), подключить через        |  |  |
| 1               | 1                                    | $U_{\mathtt{CCD}}$    | конденсатор 0,1 мкФ на шину "Общий", соединить  |  |  |
|                 |                                      |                       | с выводами цепи U <sub>CCD</sub>                |  |  |
| 2               | 4                                    | GND                   | Общий                                           |  |  |
| 3               | 2, 3                                 | Ucc                   | Питание 3,0 — 3,6 В                             |  |  |
| 4               | 5                                    | PF0                   | Входной-выходной порт F                         |  |  |
| 5               | 6                                    | PF1                   | Входной-выходной порт F                         |  |  |
| 6               | 7                                    | PF2                   | Входной-выходной порт F                         |  |  |
| 7               | 8                                    | PF3                   | Входной-выходной порт F                         |  |  |
| 8               | 9                                    | PF4                   | Входной-выходной порт F                         |  |  |
| 9               | 10                                   | PF5                   | Входной-выходной порт F                         |  |  |
| 10              | 11                                   | PF6                   | Входной-выходной порт F                         |  |  |
| 11              | 12                                   | PF7                   | Входной-выходной порт F                         |  |  |
| 12              | 13                                   | PF8                   | Входной-выходной порт F                         |  |  |
| 13              | 14                                   | PF9                   | Входной-выходной порт F                         |  |  |
| 14              | 15                                   | PF10                  | Входной-выходной порт F                         |  |  |
| 15              | 16                                   | PF11                  | Входной-выходной порт F                         |  |  |
| 16              | 17                                   | PF12                  | Входной-выходной порт F                         |  |  |
| 17              | 18                                   | PF13                  | Входной-выходной порт F                         |  |  |
| 18              | 19                                   | PF14                  | Входной-выходной порт F                         |  |  |
| 19              | 20                                   | PF15                  | Входной-выходной порт F                         |  |  |
| 20              | 21                                   | PE15                  | Входной-выходной порт Е                         |  |  |
| 21              | 22                                   | PE13                  | Входной-выходной порт Е                         |  |  |
| 22              | 23                                   | PE12                  | Входной-выходной порт Е                         |  |  |
| 23              | 25                                   | PE11                  | Входной-выходной порт Е                         |  |  |
|                 |                                      |                       | Вывод отключения внутреннего регулятора         |  |  |
| 24              | 24                                   | SHDN                  | питания 1,8 В. Используется для тестовых целей. |  |  |
|                 |                                      | _                     | Оставлять неподключенным                        |  |  |
|                 | 00                                   | EVT DEOET             | Тестовый вывод. Рекомендуется не                |  |  |
| _               | 26                                   | EXT_RESET             | подсоединять                                    |  |  |
| 25              | 28                                   | RESET                 | Вход Сброс                                      |  |  |
| 26              | 27                                   | U <sub>CCB</sub>      | Питание батарейного домена                      |  |  |
| 27              | 32                                   | DP                    | Входной-выходной USB интерфейс                  |  |  |
| 28              | 29                                   | DN                    | Входной-выходной USB интерфейс                  |  |  |
|                 |                                      |                       | Питание 1,8 (тестовый), подключить через        |  |  |
| 29              | 35, 36                               | $U_{CCD}$             | конденсатор 0,1 мкФ на шину "Общий", соединить  |  |  |
|                 |                                      |                       | с выводами цепи U <sub>CCD</sub>                |  |  |
| 30              | 33, 34                               | GND                   | Общий                                           |  |  |
| 31              | 38, 39                               | Ucc                   | Питание 3,0 — 3,6 B                             |  |  |
| 32              | 37                                   | OSC_IN                | Входной генератор HSE                           |  |  |
| 33              | 40                                   | OSC_OUT               | Выходной генератор HSE                          |  |  |
| 34              | 42                                   | PE7                   | Входной-выходной порт Е                         |  |  |
| 35              | 43                                   | PE6                   | Входной-выходной порт Е                         |  |  |
| 36              | 44                                   | WAKEUP                | Входной сигнал WakeUP                           |  |  |
| 37              | 45                                   | STANDBY               | Входной сигнал StandBy                          |  |  |
| 38              | 46                                   | OUTP1                 | Вход Аудиокодек                                 |  |  |
| 39              | 47                                   | OUTM1                 | Выход Аудиокодек                                |  |  |
| 40              | 48                                   | BIAS                  | Вход на задающий резистор                       |  |  |

| Намар                              |                                                           |                    |                                                |  |  |
|------------------------------------|-----------------------------------------------------------|--------------------|------------------------------------------------|--|--|
| Номер                              | Номер<br>контактной                                       | Обозначение        | Назначение вывода                              |  |  |
| вывода                             | площадки (КП)                                             | вывода             | пазпачение вывода                              |  |  |
| 41                                 | 49                                                        | Uccau              | Питание Аудиокодека 3,0 — 3,6 В                |  |  |
| 42                                 | 50                                                        | GND <sub>AU</sub>  | Общий Аудиокодека                              |  |  |
| 43                                 | 51                                                        | INP1               | Вход Аудиокодека 1                             |  |  |
| 44                                 | 52                                                        | INM1               | Вход Аудиокодека 1                             |  |  |
| 45                                 | 53                                                        | INP2               | Вход Аудиокодека 2                             |  |  |
| 46                                 | 54                                                        | INM2               | Вход Аудиокодека 2                             |  |  |
| 47                                 | 55                                                        | MICIN              | Вход микрофона Аудиокодека                     |  |  |
| 48                                 | 56                                                        | PE14               | Входной-выходной порт Е                        |  |  |
| 49                                 | 57                                                        | PE8                | Входной-выходной порт Е                        |  |  |
| 50                                 | 58                                                        | PE3                | Входной-выходной порт Е                        |  |  |
| 51                                 | 59                                                        | PE2                | Входной-выходной порт Е                        |  |  |
| 52                                 | 60                                                        | PE5                | Входной выходной порт Е                        |  |  |
| 53                                 | 61                                                        | PE4                | Входной-выходной порт Е                        |  |  |
| 54                                 | 62, 63                                                    | U <sub>CCA</sub>   | Питание аналоговое 3,0 — 3,6 В                 |  |  |
| 55                                 | 64, 65                                                    | GND                | Общий                                          |  |  |
| 56                                 | 66                                                        | PE10               | Входной-выходной порт Е                        |  |  |
| 57                                 | 67                                                        | PE9                |                                                |  |  |
| 58                                 | 68                                                        | PE1                | Входной-выходной порт Е                        |  |  |
| 59                                 | 69                                                        | PE0                | Входной-выходной порт Е                        |  |  |
|                                    | 60 70, 71 GND Общий                                       |                    |                                                |  |  |
|                                    | 61 72, 73 U <sub>CCA</sub> Питание аналоговое 3,0 — 3,6 В |                    |                                                |  |  |
|                                    | 62 74 PD15 Входной-выходной порт D                        |                    |                                                |  |  |
|                                    |                                                           |                    |                                                |  |  |
| 63                                 | 75<br>76                                                  | PD14               | Входной-выходной порт D                        |  |  |
| 64                                 |                                                           | PD13               | Входной-выходной порт D                        |  |  |
| 65                                 | 77                                                        | PD12               | Входной-выходной порт D                        |  |  |
| 66                                 | 78                                                        | PD11               | Входной-выходной порт D                        |  |  |
| 67                                 | 79                                                        | PD0                | Входной-выходной порт D                        |  |  |
| 68                                 | 81                                                        | PD1                | Входной-выходной порт D                        |  |  |
| 69                                 | 80                                                        | PD10               | Входной-выходной порт D                        |  |  |
| 70                                 | 83                                                        | PD8                | Входной-выходной порт D                        |  |  |
| 71                                 | 82                                                        | PD7                | Входной-выходной порт D                        |  |  |
| 72                                 | 85                                                        | PD4                | Входной-выходной порт D                        |  |  |
| 73                                 | 84                                                        | PD2                | Входной-выходной порт D                        |  |  |
| 74                                 | 86                                                        | PD3                | Входной-выходной порт D                        |  |  |
| 75                                 | 87                                                        | PD5                | Входной-выходной порт D                        |  |  |
| 76                                 | 88                                                        | PD6                | Входной-выходной порт D                        |  |  |
| 77                                 | 89                                                        | PD9                | Входной-выходной порт D                        |  |  |
| 78                                 | 90, 91                                                    | U <sub>CC</sub>    | Питание 3,0 — 3,6 В                            |  |  |
| 79                                 | 92                                                        | GND                | Общий                                          |  |  |
|                                    |                                                           |                    | Питание 1,8 (тестовый), подключить через       |  |  |
| 80                                 | 93                                                        | $U_{\mathtt{CCD}}$ | конденсатор 0,1 мкФ на шину "Общий", соединить |  |  |
|                                    |                                                           |                    | с выводами цепи U <sub>CCD</sub>               |  |  |
| 81                                 | 94                                                        | PC15               | Входной-выходной порт С                        |  |  |
| 82                                 | 95                                                        | PC14               | Входной-выходной порт С                        |  |  |
| 83                                 | 96                                                        | PC13               | Входной-выходной порт С                        |  |  |
| 84                                 | 97                                                        | PC12               |                                                |  |  |
| 85                                 | 99                                                        | PC11               | Входной-выходной порт С                        |  |  |
| 86                                 | 98                                                        | PC10               | Входной-выходной порт С                        |  |  |
| 87                                 | 101                                                       | PC9                | Входной-выходной порт С                        |  |  |
| 88                                 | 100                                                       | PC8                | Входной-выходной порт С                        |  |  |
| 89                                 | 103                                                       | PC7                | Входной-выходной порт С                        |  |  |
| 90 102 РС6 Входной-выходной порт С |                                                           |                    |                                                |  |  |

| Номер<br>вывода | Номер<br>контактной<br>площадки (КП) | Обозначение<br>вывода | Назначение вывода                                   |
|-----------------|--------------------------------------|-----------------------|-----------------------------------------------------|
| 91              | 105                                  | PC5                   | Входной-выходной порт С                             |
| 92              | 104                                  | PC4                   | Входной-выходной порт С                             |
| 93              | 108                                  | PC3                   | Входной-выходной порт С                             |
| 94              | 106                                  | PC2                   | Входной-выходной порт С                             |
| 95              | 109                                  | PC1                   | Входной-выходной порт С                             |
| 96              | 107                                  | PC0                   | Входной-выходной порт С                             |
| 97              | 111                                  | PB15                  | Входной-выходной порт В                             |
| 98              | 110                                  | PB14                  | Входной-выходной порт В                             |
| 99              | 112                                  | PB13                  | Входной-выходной порт В                             |
| 100             | 113                                  | PB12                  | Входной-выходной порт В                             |
| 101             | 114                                  | PB11                  | Входной-выходной порт В                             |
| 102             | 115, 116                             | Ucc                   | Питание 3,0 — 3,6 В                                 |
| 103             | 118                                  | GND                   | Общий                                               |
|                 |                                      |                       | Питание 1,8 (тестовый), подключить через            |
| 104             | 119                                  | $U_{\mathtt{CCD}}$    | конденсатор 0,1 мкФ на шину "Общий", соединить      |
|                 |                                      |                       | с выводами цепи U <sub>CCD</sub>                    |
| 105             | 120                                  | PB10                  | Входной-выходной порт В                             |
| 106             | 121                                  | PB9                   | Входной-выходной порт В                             |
| 107             | 122                                  | PB8                   | Входной-выходной порт В                             |
| 108             | 123                                  | PB7                   | Входной-выходной порт В                             |
| 109             | 124                                  | PB6                   | Входной-выходной порт В                             |
| 110             | 125                                  | PB5                   | Входной-выходной порт В                             |
| 111             | 126                                  | PB4                   | Входной-выходной порт В                             |
| 112             | 127                                  | PB3                   | Входной-выходной порт В                             |
| 113             | 128                                  | PB2                   | Входной-выходной порт В                             |
| 114             | 129                                  | PB1                   | Входной-выходной порт В                             |
| 115             | 130                                  | PB0                   | Входной-выходной порт В                             |
| 116             | _                                    | NC                    | Подключить на шину "Общий"                          |
| 117             | 134                                  | PA15                  | Входной-выходной порт А                             |
| 118             | 135                                  | PA14                  | Входной-выходной порт А                             |
| 119             | 136                                  | PA13                  | Входной-выходной порт А                             |
| 120             | 137                                  | PA12                  | Входной-выходной порт А                             |
| 121             | 138                                  | PA11                  | Входной-выходной порт А                             |
| 122             | 139                                  | PA10                  | Входной-выходной порт А                             |
| 123             | 140                                  | PA9                   | Входной-выходной порт А                             |
| 124             | 141                                  | PA8                   | Входной-выходной порт А                             |
| 125             | 142                                  | PA7                   | Входной-выходной порт А                             |
| 126             | 143                                  | PA6                   | Входной-выходной порт А                             |
| 127             | 144                                  | PA5                   | Входной-выходной порт А                             |
| 128             | 145                                  | PA4                   | Входной-выходной порт А                             |
| 129             | 147                                  | PA3                   | Входной-выходной порт А                             |
| 130             | 148                                  | PA2                   | Входной-выходной порт А                             |
| 131             | 149                                  | PA1                   | Входной-выходной порт А                             |
| 132             | 150                                  | PA0                   | Входной-выходной порт А                             |
| -               | 26, 30, 31, 41,<br>131-133, 146      | -                     | Не развариваются                                    |
| -               | 117                                  | JTAG_EN               | Тестовый. Рекомендуется подключать к выводу «Общий» |

Таблица 3-2 - Описание выводов по блокам

| Обозначание     | Номер  | Номер КП | Дополнительные функции вывода |          |            |               |  |
|-----------------|--------|----------|-------------------------------|----------|------------|---------------|--|
| вывода          | вывода | помер кп | Аналог.                       | Основ.   | Альтер.    | Переопр & DSP |  |
|                 |        |          | По                            | рт А     |            |               |  |
| PA0             | 132    | 150      | -                             | DATA0    | SDIO_CLK   | TMR1_CH1      |  |
| PA1             | 131    | 149      | -                             | DATA1    | SDIO_CMD   | TMR1_CH1n     |  |
| PA2             | 130    | 148      | -                             | DATA2    | SDIO_DATA0 | TMR1_CH2      |  |
| PA3             | 129    | 147      | -                             | DATA3    | SDIO_DATA1 | TMR1_CH2n     |  |
| PA4             | 128    | 145      | -                             | DATA4    | SDIO_DATA2 | TMR1_CH3      |  |
| PA5             | 127    | 144      | -                             | DATA5    | SDIO_DATA3 | TMR1_CH3n     |  |
| PA6             | 126    | 143      | -                             | DATA6    | UART1_RXD  | TMR1_CH4      |  |
| PA7             | 125    | 142      | -                             | DATA7    | UART1_TXD  | TMR1_CH4n     |  |
| PA8             | 124    | 141      | -                             | DATA8    | SSP2_CLK   | BSP1_RTCLK    |  |
| PA9             | 123    | 140      | -                             | DATA9    | SSP2_FSS   | BSP1_RTFR     |  |
| PA10            | 122    | 139      | -                             | DATA10   | SSP2_TXD   | BSP1_TX       |  |
| PA11            | 121    | 138      | -                             | DATA11   | SSP2_RXD   | BSP1_RX       |  |
| PA12            | 120    | 137      | -                             | DATA12   | SSP1_RXD   | TMR1_ETR      |  |
| PA13            | 119    | 136      | -                             | DATA13   | SSP1_TXD   | TMR1_BLK      |  |
| PA14            | 118    | 135      | -                             | DATA14   | SSP1_CLK   | TMR2_CH1      |  |
| PA15            | 117    | 134      | -                             | DATA15   | SSP1_FSS   | EXT_INT1/XF   |  |
|                 |        |          | По                            | рт В     |            |               |  |
| PB0/<br>JA_TDO  | 115    | 130      | -                             | DATA16   | UART2_TXD  | TMR2_CH1n     |  |
| PB1/<br>JA_TMS  | 114    | 129      | -                             | DATA17   | TMR1_ETR   | TMR2_CH2      |  |
| PB2/<br>JA_TCK  | 113    | 128      | -                             | DATA18   | TMR1_BLK   | TMR2_CH2n     |  |
| PB3/<br>JA_TDI  | 112    | 127      | -                             | DATA19   | UART2_RXD  | TMR2_CH3      |  |
| PB4/<br>JA_TRST | 111    | 126      | -                             | DATA20   | TMR1_CH1   | TMR2_CH3n     |  |
| PB5             | 110    | 125      | -                             | DATA21   | SSP3_TXD   | BSP1_TX       |  |
| PB6             | 109    | 124      | -                             | DATA22   | SSP3_FSS   | BSP1_TFR      |  |
| PB7             | 108    | 123      | -                             | DATA23   | SSP3_RXD   | BSP1_RX       |  |
| PB8             | 107    | 122      | -                             | DATA24   | SSP3_CLK   | BSP1_TCLK     |  |
| PB9             | 106    | 121      | -                             | DATA25   | TMR1_CH1n  | TMR2_ETR      |  |
| PB10            | 105    | 120      | -                             | DATA26   | TMR1_CH2   | TMR2_BLK      |  |
| PB11            | 101    | 114      | -                             | DATA27   | TMR1_CH2n  | EXT_INT2      |  |
| PB12            | 100    | 113      | -                             | DATA28   | SSP2_CLK   | BSP1_RCLK     |  |
| PB13            | 99     | 112      | -                             | DATA29   | SSP2_FSS   | BSP1_RFR      |  |
| PB14            | 98     | 110      | -                             | DATA30   | SSP2_TXD   | BSP1_TX       |  |
| PB15            | 97     | 111      | <u> </u>                      | DATA31   | SSP2_RXD   | BSP1_RX       |  |
|                 |        | <u> </u> | По                            | рт С     |            |               |  |
| PC0             | 96     | 107      | -                             | COMP_OUT | SSP4_FSS   | SDIO_CLK      |  |
| PC1             | 95     | 109      | -                             | OE       | UART1_TXD  | SDIO_CMD      |  |
| PC2             | 94     | 106      | -                             | WE       | UART1_RXD  | SDIO_DATA0    |  |
| PC3             | 93     | 108      | -                             | BE0      | SSP4_RXD   | SDIO_DATA1    |  |
| PC4             | 92     | 104      | -                             | BE1      | SSP4_TXD   | SDIO_DATA2    |  |
| PC5             | 91     | 105      | -                             | BE2      | SSP4_CLK   | SDIO_DATA3    |  |

| Обозначание     | Номер  | Номер КП | Дополнительные функции вывода |            |              |               |  |
|-----------------|--------|----------|-------------------------------|------------|--------------|---------------|--|
| вывода          | вывода |          | Аналог.                       | Основ.     | Альтер.      | Переопр & DSP |  |
| PC6             | 90     | 102      | -                             | BE3        | TMR1_CH3     | UART2_TXD     |  |
| PC7             | 89     | 103      | -                             | CLOCK      | TMR1_CH3n    | UART2_RXD     |  |
| PC8             | 88     | 100      | -                             | SDIO_CLK   | SSP3_TXD     | BSP2_TX       |  |
| PC9             | 87     | 101      | -                             | SDIO_CMD   | SSP3_FSS     | BSP2_RTFR     |  |
| PC10            | 86     | 98       | -                             | SDIO_DATA0 | SSP3_RXD     | BSP2_RX       |  |
| PC11            | 85     | 99       | -                             | SDIO_DATA1 | SSP3_CLK     | BSP2_RTCLK    |  |
| PC12            | 84     | 97       | -                             | SDIO_DATA2 | SSP4_FSS     | BSP3_RTFR     |  |
| PC13            | 83     | 96       | -                             | SDIO_DATA3 | SSP4_CLK     | BSP3_RTCLK    |  |
| PC14            | 82     | 95       | -                             | I2C1_SCK   | SSP4_TXD     | BSP3_TX       |  |
| PC15            | 81     | 94       | -                             | I2C_SDA    | SSP4_RXD     | BSP3_RX       |  |
|                 |        | •        | По                            | рт D       |              |               |  |
| PD0/<br>JB_TMS  | 67     | 79       | ADC0_REF+                     | TMR1_BLK   | I2C1_SCK     | BSP3_RX       |  |
| PD1/<br>JB_TCK  | 68     | 81       | ADC1_REF-                     | TMR1_ETR   | I2C1_SDA     | BSP3_TX       |  |
| PD2/<br>JB_TRST | 73     | 84       | ADC2                          | BUSY1      | SSP1_TXD     | BSP2_TX       |  |
| PD3/<br>JB_TDI  | 74     | 86       | ADC3                          | TMR1_CH1   | SSP1_FSS     | BSP2_TFR      |  |
| PD4/<br>JB_TDO  | 72     | 85       | ADC4                          | TMR1_CH1n  | SSP1_RXD     | BSP2_RX       |  |
| PD5             | 75     | 87       | ADC5                          | CLE        | SSP1_CLK     | BSP2_TCKL     |  |
| PD6             | 76     | 88       | ADC6                          | ALE        | TMR1_CH4     | BSP3_TCLK     |  |
| PD7             | 71     | 82       | ADC7                          | TMR1_CH2   | UART1_SIROUT | BSP3_TFR      |  |
| PD8             | 70     | 83       | ADC8                          | TMR1_CH2n  | UART1_SIRIN  | BSP3_TX       |  |
| PD9             | 77     | 89       | ADC9                          | TMR1_CH3   | TMR1_CH4n    | BSP3_RFR      |  |
| PD10            | 69     | 80       | ADC10                         | TMR1_CH3n  | TMR2_BLK     | BSP3_RX       |  |
| PD11            | 66     | 78       | ADC11                         | TMR1_CH4   | TMR2_ETR     | BSP3_RCLK     |  |
| PD12            | 65     | 77       | ADC12                         | TMR1_CH4n  | SSP2_FSS     | BSP2_RFR      |  |
| PD13            | 64     | 76       | ADC13                         | UART3_TXD  | SSP2_RXD     | BSP2_RX       |  |
| PD14            | 63     | 75       | ADC14                         | UART3_RXD  | SSP2_CLK     | BSP2_RCKL     |  |
| PD15            | 62     | 74       | ADC15                         | EXT_INT1   | SSP2_TXD     | BSP2_TX       |  |
|                 |        |          | По                            | рт Е       |              |               |  |
| PE0             | 59     | 69       | DAC2_OUT                      | ADDR16     | SSP4_FSS     | BSP1_RTFR     |  |
| PE1             | 58     | 68       | DAC2_REF                      | ADDR17     | SSP4_CLK     | BSP1_RTCLK    |  |
| PE2             | 51     | 59       | COMP_IN1                      | ADDR18     | SSP4_TXD     | BSP1_TX       |  |
| PE3             | 50     | 58       | COMP_IN2                      | ADDR19     | SSP4_RXD     | BSP1_RX       |  |
| PE4             | 53     | 61       | COMP_REF+                     | ADDR20     | SSP2_TXD     | UART1_TXD     |  |
| PE5             | 52     | 60       | COMP_REF-                     | ADDR21     | SSP2_FSS     | UART1_RXD     |  |
| PE6             | 35     | 43       | OSC_IN32                      | ADDR22     | SSP2_RXD     | EXT_INT3      |  |
| PE7             | 34     | 42       | OSC_OUT32                     | ADDR23     | SSP2_CLK     | TMR2_CH4      |  |
| PE8             | 49     | 57       | COMP_IN3                      | ADDR24     | TMR2_CH4     | TMR2_CH4n     |  |
| PE9             | 57     | 67       | DAC1_OUT                      | ADDR25     | TMR2_CH4n    | TMR3_CH1      |  |
| PE10            | 56     | 66       | DAC1_REF                      | ADDR26     | UART2_TXD    | TMR3_ETR      |  |
| PE11            | 23     | 25       | -                             | ADDR27     | UART2_RXD    | TMR3_BLK      |  |
| PE12            | 22     | 23       | -                             | ADDR28     | SSP1_RXD     | BSP2_RTFR     |  |
| PE13            | 21     | 22       | -                             | ADDR29     | SSP1_TXD     | BSP2_RTCLK    |  |
| PE14            | 48     | 56       | -                             | ADDR30     | SSP1_CLK     | BSP2_TX       |  |

| Обозначание<br>вывода | Номер<br>вывода | Номер КП                       | Дополнительные функции вывода                                        |            |           |               |  |  |  |  |
|-----------------------|-----------------|--------------------------------|----------------------------------------------------------------------|------------|-----------|---------------|--|--|--|--|
|                       |                 |                                | Аналог.                                                              | Основ.     | Альтер.   | Переопр & DSP |  |  |  |  |
| PE15                  | 20              | 21                             | -                                                                    | ADDR31     | SSP1_FSS  | BSP2_RX       |  |  |  |  |
|                       |                 |                                | По                                                                   | рт F       | ·         | •             |  |  |  |  |
| PF0                   | 4               | 5                              | -                                                                    | ADDR0      | UART3_RXD | TMR3_CH1n     |  |  |  |  |
| PF1                   | 5               | 6                              | -                                                                    | ADDR1      | UART3_TXD | TMR3_CH2      |  |  |  |  |
| PF2                   | 6               | 7                              | -                                                                    | ADDR2      | SSP4_RXD  | BSP3_RX       |  |  |  |  |
| PF3                   | 7               | 8                              | -                                                                    | ADDR3      | SSP4_TXD  | BSP3_TX       |  |  |  |  |
| PF4/<br>MODE[0]       | 8               | 9                              | -                                                                    | ADDR4      | SSP4_CLK  | BSP3_TCKL     |  |  |  |  |
| PF5/<br>MODE[1]       | 9               | 10                             | -                                                                    | ADDR5      | SSP4_FSS  | BSP3_TFR      |  |  |  |  |
| PF6/<br>MODE[2]       | 10              | 11                             | -                                                                    | ADDR6      | TMR2_CH3n | TMR3_CH2n     |  |  |  |  |
| PF7                   | 11              | 12                             | -                                                                    | ADDR7      | TMR2_CH3  | TMR3_CH3      |  |  |  |  |
| PF8                   | 12              | 13                             | -                                                                    | ADDR8      | TMR2_CH2n | TMR3_CH3n     |  |  |  |  |
| PF9                   | 13              | 14                             | -                                                                    | ADDR9      | TMR2_CH2  | TMR3_CH4      |  |  |  |  |
| PF10                  | 14              | 15                             | -                                                                    | ADDR10     | TMR2_CH1n | TMR3_CH4n     |  |  |  |  |
| PF11                  | 15              | 16                             | -                                                                    | ADDR11     | TMR2_CH1  | EXT_INT4      |  |  |  |  |
| PF12                  | 16              | 17                             | -                                                                    | ADDR12     | SSP3_TXD  | BSP3_TX       |  |  |  |  |
| PF13                  | 17              | 18                             | -                                                                    | ADDR13     | SSP3_FSS  | BSP3_RFR      |  |  |  |  |
| PF14                  | 18              | 19                             | -                                                                    | ADDR14     | SSP3_RXD  | BSP3_RX       |  |  |  |  |
| PF15                  | 19              | 20                             | -                                                                    | ADDR15     | SSP3_CLK  | BSP3_RCKL     |  |  |  |  |
|                       |                 |                                | Аудио и                                                              | нтерфейс   |           | 1             |  |  |  |  |
| MICIN                 | 47              | 55                             | -                                                                    |            |           |               |  |  |  |  |
| INP2                  | 45              | 53                             | -                                                                    |            |           |               |  |  |  |  |
| INM2                  | 46              | 54                             | -                                                                    |            |           |               |  |  |  |  |
| INP1                  | 43              | 51                             | -                                                                    |            |           |               |  |  |  |  |
| INM1                  | 44              | 52                             | -                                                                    |            |           |               |  |  |  |  |
| OUTP1                 | 38              | 46                             | -                                                                    |            |           |               |  |  |  |  |
| OUTM1                 | 39              | 47                             | -                                                                    |            |           |               |  |  |  |  |
| BIAS                  | 40              | 48                             | -                                                                    |            |           |               |  |  |  |  |
|                       |                 | l                              | Системное                                                            | управление |           | <b>1</b>      |  |  |  |  |
| RESET                 | 25              | 28                             |                                                                      |            |           |               |  |  |  |  |
| WAKEUP                | 36              | 44                             | Сигнал внешнего выхода из режима Standby                             |            |           |               |  |  |  |  |
| STANDBY               | 37              | 45                             | Флаг режима Standby                                                  |            |           |               |  |  |  |  |
| OSC_IN                | 32              | 37                             | Вход генератора HSE                                                  |            |           |               |  |  |  |  |
| OSC_OUT               | 33              | 40                             | Выход генератора НSE                                                 |            |           |               |  |  |  |  |
|                       |                 |                                | USB интерфейс                                                        |            |           |               |  |  |  |  |
| DP                    | 27              | 32                             | Шина USB D+                                                          | •          |           |               |  |  |  |  |
| DN                    | 28              | 29                             | Шина USB D-                                                          |            |           |               |  |  |  |  |
|                       |                 | I                              | Пит                                                                  | гание      |           |               |  |  |  |  |
| Ucc                   | 102,3,<br>78,31 | 115,116,<br>2,3,90,91<br>38,39 | Питание 3,03,6 В                                                     |            |           |               |  |  |  |  |
| Ucca                  | 54,61           | 62, 63, 72,<br>73              | Аналоговое питание АЦП и ЦАП 3,03,6 В (должно совпадать с Ucc)       |            |           |               |  |  |  |  |
| Uccau                 | 41              | 49                             | Аналоговое питание аудиокодека 3,0…3,6 В<br>(должно совпадать с Ucc) |            |           |               |  |  |  |  |
| Uccв                  | 26              | 27                             | Батарейное питание 1,83,6 В                                          |            |           |               |  |  |  |  |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Обозначание<br>вывода                  | Номер<br>вывода              | Номер КП                                         | Дополнительные функции вывода                                                                                                 |        |         |               |  |  |  |
|----------------------------------------|------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------|---------|---------------|--|--|--|
|                                        |                              |                                                  | Аналог.                                                                                                                       | Основ. | Альтер. | Переопр & DSP |  |  |  |
| GND                                    | 2, 30, 55,<br>60, 79,<br>103 | 4, 33, 34,<br>64, 65, 70,<br>71, 92,<br>117, 118 | Общий                                                                                                                         |        |         |               |  |  |  |
| GND <sub>AU</sub>                      | 42                           | 50                                               | Общий                                                                                                                         |        |         |               |  |  |  |
| Выводы для тестирования и исследования |                              |                                                  |                                                                                                                               |        |         |               |  |  |  |
| SHDN                                   | 24                           | 24                                               | Вывод отключения внутреннего регулятора питания 1,8 В. Используется для тестовых целей. Рекомендуется оставить неподключенным |        |         |               |  |  |  |
| Uccd                                   | 1,29, 80,<br>104             |                                                  | Питание 1,8 В (тестовый), рекомендуется оставить неподключенным                                                               |        |         |               |  |  |  |
| Не используются                        |                              |                                                  |                                                                                                                               |        |         |               |  |  |  |
| NC                                     | 116                          | -                                                | Не используется                                                                                                               |        |         |               |  |  |  |
| -                                      | -                            | 26, 30,<br>31, 41,<br>131-133,<br>146            | Не развариваются                                                                                                              |        |         |               |  |  |  |

# 4 Структурная блок-схема микросхемы



Рисунок 4-1 - Структурная блок-схема

## 5 Указания по применению и эксплуатации

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

Инструмент для пайки (сварки) и монтажа не должен иметь потенциал, превышающий 0,3 В относительно шины "Общий".

Запрещается подведение каких-либо электрических сигналов (в том числе шин "Питание", "Общий") к выводам микросхем, не используемым согласно схеме электрической.

Обратная сторона кристалла электрически соединена с крышкой корпуса и выводом 116. Вывод 116 необходимо соединить с шиной «Общий».

Неиспользуемые пользовательские выводы PA – PF, nRESET, WAKEUP в цифровом режиме должны быть доопределены до допустимых логических уровней напряжения (высокого или низкого) с помощью внутренних программируемых резисторов доопределения или через внешние резисторы номиналом (1 – 100) кОм, или должны быть переведены в аналоговый режим.

Между выводами  $U_{CC}$  и GND устанавливается фильтрующая емкость не менее 0,1 мк $\Phi$ .

Выводы питания 1,8 В U<sub>CCD</sub> рекомендуется подключать в соответствии с типовой схемой включения, допускается оставлять эти выводы не подключёнными.

Типовая схема включения приведена в разделе «Типовая схема включения» (Рисунок 40–1).

Порядок подачи и снятия напряжении питания и входных сигналов на микросхему:

- подача (включение микросхемы) общий, питание батарейного домена Uccв, напряжение питания Ucc, входные сигналы или одновременно;
- снятие (выключение микросхемы) в обратном порядке или одновременно.

# 6 Описание функционирования микросхемы

#### 6.1 Система питания

Микропроцессор имеет несколько типов выводов питания:

- **Ucc** выводы: Основное питание микросхемы включает питание пользовательских выводов, встроенного регулятора напряжения, USB PHY и генераторов. Входное напряжение должно быть в пределах от 3,0 до 3,6 В.
- **U**<sub>CCD</sub> **выводы:** Питание внутренней цифровой части, памяти ОЗУ и Flash памяти. В нормальном режиме работы это питание формируется внутренним регулятором напряжения из U<sub>CC</sub>. Выводы питания U<sub>CCD</sub> рекомендуется подключать в соответствии с типовой схемой включения, допускается оставлять эти выводы неподключёнными. Напряжение на выводе U<sub>CCD</sub> должно быть в пределах от 1,62 до 1,98 В.
- **U**ссв **вывод**: Питание батарейного домена используется при отсутствии основного питания Ucc для питания батарейного домена и LSE генератора. Переключение с основного питания на батарейное происходит автоматически при снижении ниже 2,0 В уровня основного питания Ucc. Переключение с батарейного питания на основное происходит автоматически, спустя примерно 4 мс, после повышения питания Ucc выше уровня 2,0 В. Входное напряжение должно быть в пределах от 1,8 до 3,6 В. Если в системе не требуется батарейного питания, вывод Uccв должен быть объединен с Ucc.
- **U**CCA **выводы**: Питание аналоговых блоков выведено на отдельные выводы для уменьшения помех, создаваемых работой других блоков. На данные выводы рекомендуется подавать напряжение с того же источника, что и Ucc, но при этом на печатной плате должны быть применены меры по снижению наводки помех. Допускается использование отдельного источника для питания аналоговых блоков, но при этом его выходное напряжение не должно отличаться от Ucc более чем на ± 0,2 В.
- **U**ссаи **выводы**: Питание аналоговой части аудиокодека выведено на отдельные выводы для уменьшения помех, создаваемых работой других блоков. На данные выводы рекомендуется подавать напряжение с того же источника, что и Ucc, но при этом на печатной плате должны быть применены меры по снижению наводки помех. Допускается использование отдельного источника для питания аудиокодека, но при этом его выходное напряжение не должно отличаться от Ucc более чем на ± 0,2 В.
- **GND выводы:** Основная земля питания.
- **GND**<sub>AU</sub> **выводы:** Земля аналогового питания U<sub>CCAU</sub>. Данные выводы должны соединяться с GND, но при этом на печатной плате должны быть применены меры по снижению наводки помех.

#### $U_{\text{CCD}}$ Микроконтроллер Источник Ucc Регулятор напряжения Цифровое напряжения питания ядро 3,3 -> 1,8 3,0...3,6B ÷ Площадки ввода/вывода USB PHY, блоки генераторов HSI, LSI и HSE Блок PVD LSE Детектор генератор напряжения питания Батарейный Блок SW U<sub>CCB</sub> домен и Батарея переключения часы 1,8...3,6B батарейного реального питания времени GND U<sub>CCA</sub> Аналоговые блоки C4 $U_{CCAU}$ Анапоговая часть модуля аудиокодек **GND**<sub>AU</sub> C5

## 6.2 Структурная схема подачи питания

Рисунок 6-1 - Структурная блок-схема

Примечания

- \* Конденсаторы должны быть установлены у каждого вывода питания.
- 1 Конденсаторы:
  - $C1 = 22 \text{ MK}\Phi \pm 5\%, 16 \text{ B},$
  - $C2 = C3 = C4 = C5 = 0.1 \text{ MK}\Phi \pm 5\%, 16 \text{ B}.$
- 2 Если не используется батарейное питание, то вывод  $U_{\text{CCB}}$  должен быть объединен с Ucc.
- 3 Допускается использование отдельного источника для питания АЦП, ЦАП и аудиокодека, но при этом его выходное напряжение не должно отличаться от  $U_{\rm CC}$  более чем на  $\pm$  0,2 B.

Микроконтроллер имеет несколько режимов энергопотребления, подробнее смотри раздел «Управление электропитанием».

Микроконтроллер имеет встроенный детектор напряжения питания, подробнее смотри раздел детектор напряжения питания.

#### 6.3 Схема сброса при включении и выключении основного питания

При включении питания, пока питание Ucc не превысило уровень Upor (2,0В) вырабатывается внутренний сигнал сброса POR для цифровой части. После превышения уровня Upor, сигнал POR выдается еще на протяжении tpor (~4 мс) для того что бы гарантировано установилось напряжение питания, после чего сигнал POR снимается и схема может начать работать.



Рисунок 6-2 - Диаграмма формирования сигнала POR

При снижении напряжения питания Ucc ниже уровня Upor сигнал POR вырабатывается без задержки.

Сигнал POR также служит для переключения питания батарейного домена между Uccs и Ucc.

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

Микроконтроллер также может быть сброшен внешним сигналом сброса nRESET, внутренними сигналами сброса сторожевых таймеров или программным сбросом. При этом сигнал сброса формируется специальной схемой сброса, содержащий фильтр «иголок» по сигналу сброса и одновибратор для увеличения длительности сигнала сброса.



Рисунок 6-3 - Структурная блок-схема сброса

При подаче на вход nRESET импульсов сброса длительностью менее 10 нс эти импульсы отфильтровываются и не приводят к сбросу процессора. Если длительность импульса больше 200 нс, вырабатывается сигнал сброса. При этом длительность сформированного сигнала сброса будет не менее 20 мкс.



Рисунок 6-4 - Формирование сигнала сброса

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

## 6.4.1 Структурная схема



Рисунок 6-5 - Структурная схема микроконтроллера

Вся система структурно разделена на две подсистемы: RISC и DSP. В подсистему DSP входят память программ (128 кБ), память данных (128 кБ), периферийные модули McBSP, Аудиокодек, Криптомодуль, таймер, некоторые отдельные специальные управляющие регистры. Все перечисленные устройства отображены в памяти DSP и памяти RISC. Кроме того, в память RISC отбражены и

другие устройства: Flash память, RAM (RISC), внешние устройства, другие периферийные модули. Таким образом, DSP-ядро имеет доступ к DSP-подсистеме микроконтроллера, RISC-ядро является ведущим в системе и имеет доступ ко всем частям системы и к внешним устройствам через 32-х разрядную внешнюю шину.

В подсистеме RISC реализован контроллер прямого доступа в память (DMA) осуществляющий выборку через шину DMA Bus. Он может работать с память RAM (RISC), внешней шиной, всей подсистемой DSP и всеми периферийными устройствами системы. В подсистеме DSP также реализован контроллер прямого доступа в память (DMA) осуществляющий выборку ко всем элементам подсистемы DSP.

## Блок RISC-DSP BRIDGE

Подсистемы RISC и DSP работают на независимых синхросигналах. Для обеспечения их синхронизации в системы введен модуль RISC-DSP BRIDGE. За счет использования асинхронного FIFO данный модуль обеспечивает запись без потери скорости на пересинхронизацию на наименьшей из двух (RISC или DSP) частоте.

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

# Блоки BUS MATRIX (RISC и DSP)

В системе содержится два модуля BUS MATRIX. BUS MATRIX RISC предназначен для переключения системных шин I Code, D Code, System Bus и DMA Bus между различными областями памяти. BUS MATRIX DSP выполняет аналогичные операции для шин DSP-подсистемы (Pbus, Cbus, Dbus, Ebus, DMADSPbus и RISCbus). Переключение производится автоматически на основании адреса запроса каждой конкретной шины. Если адреса запросов не пересекаются, то они могут быть выполнены одновременно. Если адреса запросов пересекаются, то они выполняются в порядке приоритета. Приоритеты обращений заданы аппаратно. Наивысшим приоритетом в RISC-подсистеме обладает запрос по шине SYSTEM BUS, затем следует запрос D Code, затем I Code и наименьшим приоритетом обладает запрос DMA Bus. Если два запроса пришли одновременно, то выполняется запрос с большим приоритетом, а запрос с меньшим задерживается до окончания запроса с большим приоритетом. При переключении между шинами возникает дополнительная задержка в один цикл. Если запросы идут непосредственно друг за другом, то дополнительных задержек не возникает.

#### Память BOOT ROM

Память области BOOT ROM реализована в виде MASK ROM, с занесением информации одним из технологических слоев при изготовлении кристалла микроконтроллера. Скорость доступа к памяти BOOT ROM – 1 цикл системной частоты.

#### Память EEPROM

Память области EEPROM реализована в виде перепрограммируемой энергонезависимой памяти. Скорость доступа к памяти EEPROM – порядка 40 нс. При работе микроконтроллера на скорости до 100 МГц, скорость доступа к памяти может составлять до 5 циклов системной частоты. При последовательной выборке за счет упреждающего чтения задержка может быть сокращена до 1 цикла системной

частоты. Более подробная информация о работе контроллера EEPROM памяти программ представлена в разделе «Контроллер FLASH памяти программ».

## Память SRAM

Память области SRAM реализована в виде блока статической памяти. Скорость доступа к памяти SRAM – 1 цикл системной частоты.

# Память Program Memory (DSP)

Память области Program Memory (DSP) реализована в виде блока статической расслоеной памяти. Скорость доступа к памяти Program Memory (DSP) – 1 цикл системной частоты DSP.

# Память DATA Memory (DSP)

Память области Program Memory (DSP) реализована в виде блока статической расслоеной памяти. Скорость доступа к памяти Program Memory (DSP) – 1 цикл системной частоты DSP.

# Карта памяти RISC

Все адресное пространство RISC едино и имеет максимальный объем 4 Гбайта (Рисунок 6–6). В данное адресное пространство отображаются все модули памяти и периферии микроконтроллера, в том числе и все компоненты DSP-подсистемы (кроме регистров DSP-ядра).



Рисунок 6-6 - Карта памяти RISC

Процессорное ядро RISC имеет три системных шины (Рисунок 6-5):

- I Code шина выборки инструкций;
- D Code шина выборки данных, расположенный в коде программы;
- S Bus шина выборки данных, расположенный в области ОЗУ.

Также в подсистеме RISC реализован шина контроллера прямого доступа в память (Рисунок 6–5) :

- M Bus.

#### Секция CODE:

#### Область BOOT ROM:

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

#### Область EEPROM PROGRAM:

Основная область энергонезависимой памяти программы доступной для перепрограммирования пользователем. Память предназначена для хранения основной рабочей программы.

#### Область EXTERNAL BUS:

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

#### Секция DATA:

# Область Internal SRAM (Data):

Основная область ОЗУ предназначенная для хранения данных программы. В данной область также располагается стек (stack) и «куча» (heap) программы. Адресные диапазоны стека и «кучи» задаются пользователем при написании программы.

# Область BIT BAND REGION TO SRAM (Data):

Виртуальная Область памяти данных, предназначенная для осуществления побитного доступа к область Internal SRAM. Работа с BIT DAND REGION позволяет осуществлять операции «Чтение-Модификация-Запись», «Установка бита» и «Сброс Бита» одной инструкцией.

# Область DSP MEMORY:

Область отображения адресного пространства DSP-подсистемы в адресное пространство RISC Предназначена для обмена данными с DSP-ядром и периферией и задания программ для работы DSP.

#### Секция PERIPHERAL:

# Область PERIPHERAL (Data):

Область отображения регистров периферии в общее адресное пространство памяти.

#### Область BIT BAND REGION TO PERIPHERAL (Data):

Виртуальная Область памяти данных, предназначенная для осуществления побитного доступа к область PERIPHERAL. Работа с BIT DAND REGION позволяет осуществлять операции «Чтение-Модификация-Запись», «Установка бита» и «Сброс Бита» одной инструкцией.

# Область EXTERNAL BUS:

Область отображения внешней системной шины в адресное пространство области периферии. Предназначена для хранения данных во внешних микросхемах памяти или работы с периферийными устройствами подсоединенными к внешней системной шине.

#### Секция EXTERNAL RAM:

#### Область EXTERNAL BUS:

Область отображения внешней системной шины в адресное пространство области внешней памяти и периферии. Предназначена для хранения данных во внешних микросхемах памяти или работы с периферийными устройствами подсоединенными к внешней системной шине.

#### Секция SYSTEM:

Предназначена для отображения системных регистров ядра и системной периферии.

#### 6.4.1.1 Регионы памяти, типы и атрибуты RISC

Отображение памяти и программирования блока MPU разбивает все адресное пространство на регионы. Каждый регион имеет определенный тип памяти, а некоторые регионы имеют дополнительные атрибуты. Тип памяти и атрибуты определяют поведение системы при доступе к этим регионам. Подробнее смотри раздел Модуль защиты памяти.

# Normal

Процессор может переопределить последовательность обращений для большей эффективности или проведения спекулятивного считывания

#### Device

Процессор сохраняет последовательность обращений по отношению к другим обращениям в области Device и Strongly-ordered памяти

# Strongly-ordered

Процессор сохраняет последовательность обращений по отношению ко всем обращениям. Отличие последовательности для Device и Strongly-Ordered памяти означает что система памяти может буферизировать запись в Device, но никогда не буферизирует запись в Stronly-ordered память.

#### Shareable

Для shareable регионов система памяти обеспечивает синхронизацию между различными мастерами на шине, например DMA и само ядро. Strongly-ordered память всегда shareable. При наличии работе нескольких мастеров в не shareable памяти, программное обеспечение должно отслеживать когерентность данных различных мастеров.

#### Execution Never (XN)

Область памяти из которой не могут извлекаться инструкции. Любая попытка извлечь инструкцию из XN региона приведет в исключению memory management fault.

#### Последовательность обращений в память

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

Однако, система памяти гарантирует однозначную последовательность доступа в регионы памяти Device и Strongly-ordered. Для двух инструкций доступа в память A1 и A2, если A1 выполняется перед A2 в коде программы, последовательность обращений двух инструкций будет такой как показано ниже (Таблица 6–1).

Таблица 6–1 – Последовательность обращений инструкций к памяти

| A2<br>A1         | Доступ в Normal | Доступ в Device<br>He shareable | Доступ в Device shareable | Strongly-ordered |
|------------------|-----------------|---------------------------------|---------------------------|------------------|
| Доступ в Normal  | -               | -                               | -                         | -                |
| Доступ в Device  | -               | <                               | -                         | <                |
| He shareable     |                 |                                 |                           |                  |
| Доступ в Device  | -               | -                               | <                         | <                |
| shareable        |                 |                                 |                           |                  |
| Strongly-ordered | -               | <                               | <                         | <                |

Где « - » означает, что система памяти не гарантирует последовательность выполнения обращений, а « < » означает что обращение инструкции А1 всегда будет выполнено перед инструкций А2.

# Поведение обращений к памяти

Поведение обращений описано ниже (Таблица 6-2).

Таблица 6-2 - Последовательность обращений инструкций к памяти

| Адресный    | Регион         | Тип       | XN   | Описание                                                        |
|-------------|----------------|-----------|------|-----------------------------------------------------------------|
| диапазон    | памяти         | памяти    |      |                                                                 |
| 0x00000000- | Code           | Normal    | -    | Область памяти для кода программы,                              |
| 0x1FFFFFF   |                |           |      | данные также могут храниться здесь.                             |
| 0x20000000- | SRAM           | Normal    | -    | Область памяти для данных. Код                                  |
| 0x2FFFFFF   |                |           |      | программы также может располагаться                             |
|             |                |           |      | здесь.                                                          |
|             |                |           |      | Этот регион содержит области bit-band                           |
|             |                |           |      | доступа                                                         |
| 0x30000000- | DSP            | Normal    | -    | Область DSP-памяти и регистров                                  |
| 0x3FFFFFF   |                |           |      | DSP-периферии. Не рекомендуется                                 |
|             |                |           |      | использовать память DSP для                                     |
|             |                |           |      | расположения кодов команд RISC. При                             |
|             |                |           |      | записи и чтения этой области памяти                             |
|             |                |           |      | возможны задержки вследствии пересинхронизации обращений.       |
|             |                |           |      | пересинхронизации обращений. Подробнее см. раздел "Работа моста |
|             |                |           |      | пересинхронизации RISC – DSP".                                  |
| 0x40000000- | Peripheral     | Device    | XN   | Этот регион содержит области bit-band                           |
| 0x5FFFFFF   | Tempricial     | Device    | 7(1) | доступа                                                         |
| 0x60000000- | External RAM   | Normal    | _    | Область памяти для данных и кода                                |
| 0x9FFFFFF   | External row   | Noma      |      | Осласть намини дли данных и кода                                |
| 0xA0000000- | External       | Deivce    | XN   | Область памяти для внешних устройств                            |
| 0xDFFFFFF   | Device         | 2000      | 7    |                                                                 |
| 0xE0000000- | Private        | Strongly- | XN   | Этот регион содержит регистры NVIC,                             |
| 0xE00FFFF   | Peripheral Bus | ordered   |      | system timer и регистры блока                                   |
|             | '              |           |      | управления ядра                                                 |
| 0xE0100000- | Зарезервирова  | Device    | XN   | Зарезервировано                                                 |
| 0xFFFFFFF   | НО             |           |      |                                                                 |

Области Code, SRAM и External RAM могут содержать код программы. Однако рекомендуется что бы код программы располагался в секции Code. Так как процессор

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

Блок MPU может влиять на стандартное поведения при доступе в память. Для большей информации обратитесь в раздел блок защиты памяти

# Дополнительные условия доступа в shared память

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

Таблица 6-3 – Поведение обращений к памяти

| Адресный<br>диапазон     | Секция памяти          | Тип памяти       | Возможность<br>совместного<br>использования |
|--------------------------|------------------------|------------------|---------------------------------------------|
| 0x00000000-<br>0x1FFFFFF | Code                   | Normal           | -                                           |
| 0x20000000-<br>0x2FFFFFF | SRAM                   | Normal           | -                                           |
| 0x30000000-<br>0x3FFFFFF | DSP                    | Normal           | -                                           |
| 0x40000000-<br>0x5FFFFFF | Peripheral             | Device           | -                                           |
| 0x60000000-<br>0x7FFFFFF | External RAM           | Normal           |                                             |
| 0x80000000-<br>0x9FFFFFF | External NAIVI         | Noma             | -                                           |
| 0xA0000000-<br>0xBFFFFFF | External device        | Device           | Shareable                                   |
| 0xC0000000-<br>0xDFFFFFF | External device        | Device           | "non-shareable"                             |
| 0xE0000000-<br>0xE00FFFF | Private peripheral bus | Strongly-ordered | Shareable                                   |
| 0xE0100000-<br>0xFFFFFFF | Vendor-specific device | Device           | -                                           |

#### Программное определение последовательности доступов в память

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

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

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

#### **DMB**

Инструкция Data Memory Barrier (DMB) позволяет быть уверенным, что выполняемая инструкция транзакции в память будет завершена до следующей транзакции в память. Смотри описание инструкции DMB.

#### DSB

Инструкция Data Synchronization Barrier позволяет быть уверенным, что выполняемая инструкция транзакции в память будет завершена до начала выполнения следующей инструкции. Смотри описание инструкции DSB.

#### ISB

Инструкция Instruction Synchronization Barrier (ISB) позволяет быть уверенным, что эффект от выполнения всех завершённых обращений к памяти будет распространяться на последующие команды. Смотрите описание инструкции ISB.

Инструкции барьерной синхронизации используются, например, в таких случаях:

- Программирование MPU:
  - используйте DSB инструкцию для уверенности в том, что изменение настроек MPU будет иметь эффект немедленно вслед за изменением контекста;
  - используйте ISB инструкцию для уверенности в том, что изменение настроек MPU эффект будет иметь немедленно программирования новых MPU регионов, если конфигурационный код вызывается через переход или вызов функции. Если конфигурационный код MPU вызывается через механизм исключений (прерывания), то ISB инструкция не требуется.
- Таблица векторов прерывания. Если программа изменяет таблицу векторов прерывания и затем разрешает прерывания, то перед разрешением должна быть поставлена инструкция DMB. Это гарантирует, что в случае прерывания процессор уйдет на обработчик по новому адресу таблицы.
- Самомодифицируемый код. Если программа содержит самомодифицируемый код, используйте ISB инструкцию сразу после модификации кода программы. Это гарантирует, что после этого будет выполняться уже модифицированный код.
- Переключение карты памяти. Если система содержит механизм переключения карты памяти, то используйте инструкцию DSB после переключения карты памяти в программе. Это гарантирует, что дальнейшее выполнение инструкций будет идти с новой картой памяти.
- Динамическое изменение приоритетов исключений. Когда приоритеты исключений изменяются во время обработки исключения, используйте DSB инструкцию после изменения. Это гарантирует, что изменение произойдет при завершении DSB инструкции.
- Использование семафоров в системе с несколькими устройствами управления передачей данных по шине. Если система содержит несколько таких устройств управления, например, другой процессор, то оба процессора должны использовать DMB инструкции после каждой инструкции работы с семафорами. Это гарантирует, что другой мастер будет видеть обращения к памяти в той последовательности, в которой они выполняются.

Обращения к памяти типа Strongly-ordered, например, к системному блоку управления ядра (NVIC, System Timer и так далее) не требуют использовать DMB инструкции.

# Bit-band регионы

Механизм bit-band отображает каждый бит в bit-band региона в слово в bit-band alias регионе. Bit-band регион занимает младший 1 Мбайт области SRAM и области периферийных устройств им соответствуют области по 32 Мбайта bit-band alias как показано в таблице ниже.

Таблица 6-4 - Описание bit-band регионов

| Адресный     | Регион памяти       | Доступ инструкций и данных                   |
|--------------|---------------------|----------------------------------------------|
| диапазон     |                     |                                              |
| 0x2000_0000- | SRAM bit-band       | Доступ к словам                              |
| 0x200F_FFFF  |                     |                                              |
| 0x2200_0000- | SRAM bit-band alias | Доступ к битам в области SRAM bit-band       |
| 0x23FF_FFFF  |                     | через доступ к словам в области SRAM bit-    |
|              |                     | band alias                                   |
| 0x4000_0000- | Peripheral bit-band | Доступ к словам                              |
| 0x400F_FFFF  |                     |                                              |
| 0x4200_0000- | Peripheral bit-band | Доступ к битам в области Peripheral bit-band |
| 0x43FF_FFFF  | alias               | через доступ к словам в области Peripheral   |
|              |                     | bit-band alias                               |

Следующая формула показывает как регион bit-band alias отображается в bit-band region:

```
bit_word_offset = (byte_offset * 32) + (bit_number * 4)
bit_word_addr = bit_band_base + bit_word_offset
```

# Где:

bit word offset – позиция необходимого бита в bit-band регионе

bit\_word\_addr – адрес слова в bit-band alias регионе отображающего необходимый бит в bit-band регионе

bit\_band\_base – начальный адрес bit-band alias региона

byte\_offset – номер байта с необходимым битом в bit-band регионе

bit\_number – номер необходимого бита в байте



Рисунок 6–7 – Схема отображения региона bit-band alias в регионе bit-band region

Запись в слово в alias регионе обновляет бит в bit-band регионе.

Bit[0] записываемого слова будет определять значение устанавливаемого бита. Bit[31:1] слова в bit-band alias регионе не имеют значения для бита в bit-band регионе. Запись 0x01 имеет тот же эффект что и запись 0xFF, а запись 0x00 имеет тот же эффект что и запись 0x0E.

Процессор имеет little-endian организацию расположения байтов. Т.е. байт с меньшей значимостью храниться по меньшему адресу, например:



Рисунок 6-8 - Организация расположения байтов в 32-х битной памяти

# 6.4.1.2 Примитивы синхронизации

Система команд ядра RISC включает в себя несколько парных *примитивов* синхронизации. Это позволяет реализовать неблокирующий механизм, который поток или процесс могут использовать для эксклюзивного доступа в память. Программное обеспечение может использовать их для гарантированного выполнения последовательности read-modify-write или реализации механизма семафоров.

В каждую пару команд (инструкций) примитива синхронизаций входят:

- команда Load-Exclusive;
- команда Store-Exclusive.

# Команда Load-Exlusive

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

# Команда Store-Exlusive

Используется для попытки записи в тот же самый адрес памяти; возвращает бит статуса. Этот бит принимает значения:

- 0 если поток или процесс получил эксклюзивный доступ к памяти и запись выполнена;
- 1 если поток или процесс не получил эксклюзивного доступа в память и запись не выполнена.

Команды Load Exclusive и Store-Exclusive образуют следующие пары:

- LDREX и STREX работа с словами;
- LDREXH и STREXH работа с полусловами;
- LDREXB и STREXB работа с байтами.

Программное обеспечение должно использовать инструкцию Load Exclusive с соответствующей инструкций Store-Exclusive.

Чтобы гарантировать чтение-модификацию-запись по какому-либо адресу памяти, программа должна:

- инструкцией Load-Exclusive считать значение из памяти;
- изменить значение;
- инструкцией Store-Exclusive попытаться записать новое значение обратно в память; проверить возвращаемый статусный бит.

Если этот бит – 0, то процедура «чтение-модификация-запись» выполнена успешно.

Если этот бит – 1, то запись не была выполнена. Это означает, что значение, считанное первоначально, возможно устарело и программа должна повторить цикл «чтение-модификация-запись».

Программное обеспечение может использовать примитивы синхронизации для реализации семафоров, как это описано ниже:

- использовать команду Load-Exclusive для чтения из адреса семафора, чтобы определить, свободен ли семафор;
- если семафор свободен, использовать Store-Exclusive для записи в семафор требуемого значения (признака захвата);
- если возвращаемый статусный бит указывает на успешное выполнение инструкции Store-Exclusive, то это означает, что семафор захвачен. Если же команда Store-Exclusive не была выполнена, то это означает, что другой процесс мог захватить семафор ранее.

Ядро RISC имеет монитор эксклюзивных доступов, который отмечает, что процессор выполнил команду Load-Exclusive. Если процессор является частью многопроцессорной системы, то система также отмечает на глобальном уровне адреса памяти, для которых имел место эксклюзивный доступ со стороны каждого процессора.

Процессор удаляет свою отметку об эксклюзивном доступе в тех случаях, когда:

- процессор выполняет команду CLREX;
- процессор выполняет команду Store-Exclusive, при этом не имеет значения, была ли запись успешна;
- происходит исключение. Это означает, что процессор может разрешить конфликт между семафорами в различных потоках.

# В многопроцессорной реализации:

- выполнение инструкции CLREX удаляет только локальную отметку об эксклюзивном доступе для данного процессора;
- выполнение инструкции Store-Exlusive или же обработка исключения удаляют локальную и все глобальные отметки об эксклюзивном доступе для данного процессора.

Подробнее см. описание инструкций LDREX, STREX и CLREX.

#### Указания по программированию синхронизационных примитивов

ANSI С не может создавать инструкции эксклюзивного доступа. Некоторые С компиляторы предлагают встроенные функции для создания этих инструкций:

LDREX, LDREXH, LDREXB - unsigned int \_\_ldrex(volatile void \*ptr);

STREX, STREXH, STREXB - int \_\_strex(unsigned int val, volatile void \*ptr);

CLREX - void \_\_clrex(void).

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

\_\_ldrex((volatile char \*) 0xFF);

#### 6.4.1.3 Базовые адреса RISC

# Таблица 6-5 - Базовые адреса процессора

| Адрес       | Размер          | Блок                                           | Примечание                               |  |  |  |  |
|-------------|-----------------|------------------------------------------------|------------------------------------------|--|--|--|--|
|             | Память программ |                                                |                                          |  |  |  |  |
| 0x0000_0000 |                 | BOOT ROM                                       | Загрузочная программа                    |  |  |  |  |
| 0x0800_0000 |                 | EEPROM                                         | Область Flash памяти программ с          |  |  |  |  |
|             |                 |                                                | пользовательской программой              |  |  |  |  |
| 0x1000_0000 |                 | EXTERNAL BUS Область доступа к внешней системн |                                          |  |  |  |  |
|             |                 | Памя                                           | ть данных                                |  |  |  |  |
| 0x2000_0000 |                 | SYSTEM RAM                                     | Область внутреннего ОЗУ                  |  |  |  |  |
| 0x2200_0000 |                 | SYSTEM RAM Bit Band Region                     | Область битового доступа внутреннего ОЗУ |  |  |  |  |

| Адрес       | Размер        | Блок                          | Примечание                                       |  |
|-------------|---------------|-------------------------------|--------------------------------------------------|--|
| 0x3000_0000 |               | DSP_SUBSYSTEM                 | Область доступа к подсистеме DSP (в т.ч. и       |  |
|             |               |                               | периферийные модули DSP-подситемы:               |  |
|             |               |                               | Timer(DSP), DMA(DSP), АудиоКодек,                |  |
|             |               | <br>Периферийные              | СтурtoUnit, McBSP) устройства RISC               |  |
| 0x4000_0000 |               | SSP3                          | Регистры контроллера интерфейса SSP3             |  |
| 0x4000_8000 |               | SSP4                          | Регистры контроллера интерфейса SSP4             |  |
| 0x4000_0000 |               | USB                           | Регистры контроллера интерфейса USB              |  |
| 0x4001_8000 |               | EEPROM_CNTRL                  | Регистры контроллера Flash памяти программ       |  |
| 0x4002 0000 |               | RST CLK                       | - Регистры контроллера сигналов тактовой         |  |
| 0.002_0000  |               | INOT_OLIN                     | частоты.<br>- Регистр управления DSP.            |  |
| 0x4002_8000 |               | DMA                           | Регистры контроллера прямого доступа в           |  |
|             |               |                               | память RISC-подсистемы.                          |  |
| 0x4003_0000 |               | UART1                         | Регистры контроллера интерфейса UART1            |  |
| 0x4003_8000 |               | UART2                         | Регистры контроллера интерфейса UART2            |  |
| 0x4004_0000 |               | SSP1                          | Регистры контроллера интерфейса SSP1             |  |
| 0x4004_8000 |               | SDIO                          | Регистры контроллера интерфейса SDIO             |  |
| 0x4005_0000 |               | I2C1                          | Регистры контроллера интерфейса I2C1             |  |
| 0x4005_8000 |               | POWER                         | Регистры детектора напряжения питания            |  |
| 0x4006_0000 |               | WWDT                          | Регистры контроллера сторожевого таймера WWDT    |  |
| 0x4006_8000 |               | IWDT                          | Регистры контроллера сторожевого таймера IWDT    |  |
| 0x4007_0000 |               | TIMER1                        | Регистры управления Таймер 1                     |  |
| 0x4007_8000 |               | TIMER2                        | Регистры управления Таймер 2                     |  |
| 0x4008_0000 |               | TIMER3                        | Регистры управления Таймер 3                     |  |
| 0x4008_8000 |               | ADC                           | Регистры управления АЦП                          |  |
| 0x4009_0000 |               | DAC                           | Регистры управления ЦАП                          |  |
| 0x4009_8000 |               | COMP                          | Регистры управления Компаратора                  |  |
| 0x400A_0000 |               | SSP2                          | Регистры контроллера интерфейса SSP2             |  |
| 0x400A_8000 |               | PORTA                         | Регистры управления порта А                      |  |
| 0x400B_0000 |               | PORTB                         | Регистры управления порта В                      |  |
| 0x400B_8000 | <u> </u>      | PORTC                         | Регистры управления порта С                      |  |
| 0x400C_0000 |               | PORTD                         | Регистры управления порта D                      |  |
| 0x400C_8000 |               | PORTE                         | Регистры управления порта Е                      |  |
| 0x400D_0000 |               | UART3                         | Регистры контроллера интерфейса UART3            |  |
| 0x400D_8000 |               | ВКР                           | Регистры доступа и управления батарейным доменом |  |
| 0x400E_8000 | <u> </u>      | PORTF                         | Регистры управления порта F                      |  |
| 0x400F_0000 | <u> </u>      | EXT_BUS_CNTRL                 | Область доступа к внешней системной шине         |  |
| 0x4200_0000 |               | PERIPHERAL<br>Bit Band Region | Область битового доступа к регистрам периферии   |  |
| 0x5000_0000 |               | EXTERNAL BUS                  | Область доступа к внешней системной шине         |  |
|             |               |                               | стемная шина                                     |  |
| 0x6000_0000 |               | EXTERNAL BUS                  | Область доступа к внешней системной шине         |  |
| 0xA000_0000 |               | EXTERNAL BUS                  | Область доступа к внешней системной шине         |  |
|             | SYSTEM REGION |                               |                                                  |  |
| 0xE000_0000 |               |                               | Системные регистры ядра RISC                     |  |

# 6.4.2 Карта памяти DSP

Процессорное ядро DSP имеет 4 системные шины:

- Pbus шина выборки инструкций.
- Cbus шина выборки первого операнда.
- Dbus шина выборки второго операнда.
- Ebus шина записи результата.

Память DSP микропроцессора организована в два индивидуальные отдельные пространства: программ и данных. Оба простанства представляют собой расслоеные ОЗУ размером по 128 Кбайт каждое, с организацией 64К х 16.

Программное пространство памяти содержит инструкции для исполнения, а также таблицы, используемые при выполнении программ. Пространство памяти данных хранит данные используемые инструкциями. Биты OVLY расположен в регистре статуса режима процессора (PMST).

Для DSP-ядра открыт полный доступ ко всему адресному пространству памяти данных и закрыт доступ на запись в программную область памяти. Для изменения программной области со стороны DSP необходимо использовать встроенный DMA контроллер DSP-подсистемы. Кроме того, к области программ открыт полный доступ со стороны ядра RISC и DMA RISC-подсистемы.

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

| 0x0000 | Память программ                                                                      | 0x0000           | Память данных<br>Регистры ядра<br>0x0000-0x001F                   |
|--------|--------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------|
|        | OVLY=0 0x0000-0x3FFF<br>Память программ                                              | 00000            | Регистры периферии<br>0x0020-0x007F                               |
| 0x4000 | OVLY=1 0x0000-0x007F<br>Не реализовано<br>0x0080-0x3FFF<br>Отображение Памяти данных | 0x0080<br>0x4000 | 0x0080-0x3FFF                                                     |
|        | 0х4000-0хFFFF<br>Память программ                                                     |                  | DROM = 0 0x4000-0xFFFF<br>Память данных<br>DROM = 1 0x4000-0xFFFF |
|        | 0xFF00-0xFF7F<br>Зарезервировано<br>0xFF80-0xFFFF<br>Вектора прерываний              |                  | Отображение Памяти<br>программ                                    |
| 0xFFFF | Воктора прорывании                                                                   | 0xFFFF           |                                                                   |

Рисунок 6-9 - Карта памяти DSP

# 6.4.2.1 Регистры, отображенные в памяти DSP

64К слов пространства памяти данных включает аппаратные регистры, отображаемые в памяти, которые находятся на странице данных 0 (адреса данных 0000h-007Fh). Страница данных состоит из следующих частей:

- Регистры CPU (всего 26), доступны без состояний ожидания. Занимаемый диапазон 0020h-001F.
  - Периферийные регистры, использованные как управляющие регистры и регистры данных в периферийных цепях. Эти регистры занимают диапазон адресов 0020h-007F.

# Perucmpы CPU DSP

# Регистры прерывания (IMR, IFR)

Регистр маски прерывания (IMR) маскирует индивидуальные специфические прерывания в необходимое времени. Регистр флага прерывания (IFR), указывает текущий статус прерываний.

# Регистры состояния (ST0, ST1)

Регистры состояния ST0 и ST1 содержат статус различных условий и мод для микропроцессора. ST0 содержит флаги (OVA, OVB, C, и TC) результатов арифметических и битовых операций, в дополнение к полям DP и ARP. ST1 отражает статус способов и инструкций, выполненных процессором.

#### Аккумуляторы (А, В)

Микропроцессор имеет два 40- битовых аккумулятора: аккумулятор A и аккумулятор B. Каждый аккумулятор отображен в память и разделен в младшее слово аккумулятора (AL, BL), старшее слово аккумулятора (AX, BH), и биты охраны (AG, BG).

# Временный регистр (Т)

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

- Один из сомножителей для операций умножения и умножения с накоплением.
- Счётчик динамического сдвига (программируемый во время выполнения) для инструкций с операцией сдвига, как например, ADD, LD, и SUB инструкции.
- Динамический адрес бита для инструкции ВІТТ.
- Метрика перехода используется инструкциями DADST и DSADT для операции ACS декодирования по Витерби.

Кроме того, инструкция EXP загружает вычисленную величину показателя в регистр T, и затем инструкция NORM использует величину регистра T для нормализации числа.

## Регистр перехода (TRN)

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

#### Вспомогательные регистры (AR0 – AR7)

Восемь 16-битовых вспомогательных регистра (AR0 AR7) могут быть доступны ЦПУ и модифицируются арифметическим устройством вспомогательного регистра (ARAUs). Первичная функция вспомогательных регистров заключается в генерации 16-битовых адресов пространства данных. Тем не менее, эти регистры могут быть также задействованы как регистры общего назначения или счетчики.

# Регистр указателя стека (SP)

16-битовый регистр указателя стека (SP), содержит адрес верхушки системного стека. SP всегда указывает на последний элемент, вытолкнутый в стек.

Стек изменяется прерываниями, перехватами, вызовами, возвратами, и инструкциями PSHD, PSHM, POPD, и POPM. Вталкивание и выталкивание осуществляется соответственно предекрементом и постинкрементом указателя стека, являющейся 16-битовой величиной.

#### Регистр размера циклического буфера (ВК)

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

#### Регистры повторения блока (BRC, RSA, REA)

16-битовый счетчик повторения блока (BRC) определяет количество повторений программного блока тогда, когда выполняется повторение блока. 16-битовый регистр адреса начала (RSA) содержит стартовый адрес блока программной

памяти, который должен повторяться. 16-битовый регистр адреса конца (REA) содержит адрес окончания блока программной памяти, которое нужно повторять.

# <u>Регистр состояния моды процессора (PMST)</u>

Регистр состояния моды процессора (PMST) управляет конфигурацией памяти микропроцессора. PMST описывается подробно в разделе о регистре статуса и управления ЦПУ.

Таблица 6-6 - Регистры процессора, отображенные в памяти

| Адрес (DSP)   | РМЯ  | Описание                                 |
|---------------|------|------------------------------------------|
| 0x0000        | IMR  | Регистр маски прерывания                 |
| 0x0001        | IFR  | Регистр флага прерывания                 |
| 0x0002 0x0005 | -    | Зарезервировано                          |
| 0x0006        | ST0  | Регистр состояния 0                      |
| 0x0007        | ST1  | Регистр состояния 1                      |
| 0x0008        | AL   | Аккумулятор А, младшая часть(биты 15-0)  |
| 0x0009        | AH   | Аккумулятор А, старшая часть(биты 31-16) |
| 0x000A        | AG   | Аккумулятор А, биты защиты(биты 39-32)   |
| 0x000B        | BL   | Аккумулятор В, младшая часть(биты 15-0)  |
| 0x000C        | BH   | Аккумулятор В, старшая часть(биты 31-16) |
| 0x000D        | BG   | Аккумулятор В, биты защиты(биты 39-32)   |
| 0x000E        | Т    | Временный регистр                        |
| 0x000F        | TRN  | Регистр перехода                         |
| 0x0010        | AR0  | Вспомогательный регистр 0                |
| 0x0011        | AR1  | Вспомогательный регистр 1                |
| 0x0012        | AR2  | Вспомогательный регистр 2                |
| 0x0013        | AR3  | Вспомогательный регистр 3                |
| 0x0014        | AR4  | Вспомогательный регистр 4                |
| 0x0015        | AR5  | Вспомогательный регистр 5                |
| 0x0016        | AR6  | Вспомогательный регистр 6                |
| 0x0017        | AR7  | Вспомогательный регистр 7                |
| 0x0018        | SP   | Указатель стека                          |
| 0x0019        | BK   | Регистр размера циклического буфера      |
| 0x001A        | BRC  | Счётчик повторения блока                 |
| 0x001B        | RSA  | Начальный адрес повторяемого блока       |
| 0x001C        | REA  | Конечный адрес повторяемого блока        |
| 0x001D        | PMST | Регистр состояния моды процессора        |
| 0x001E        | XPC  | Регистр расширения счётчика команд       |
| 0x001E0x001F  | -    | Зарезервировано                          |

# Периферийные регистры DSP

В DSP части содержатся периферийный модули DMA (DSP), System timer (DSP), Audio Codec, 3 модуля McBSP, Crypto модуль. Также в таблицу адресов включены регистр управления синхросигналами CLKMD, регистры прерываний (AIRQ, DIRQ). Адреса всех периферийных модулей представлены в области данных DSP в диапазоне с адреса 0x0020 по 0x007F. Подробное описание регистров периферийных модулей приведены в соответсвующих разделах. Адреса регистров DSP части для ядер DSP и RISC представлены в таблице ниже (Таблица 6–7).

Таблица 6-7 - Регистры периферийных модулей DSP-подсистемы

| Адрес DSP        | Адрес RISC               | Наименование<br>регистра     | Модуль, к которому принадлежит регистр |
|------------------|--------------------------|------------------------------|----------------------------------------|
| 0x0020           | 0x30000040               | DDRL1                        | BSP1                                   |
| 0x0021           | 0x30000042               | DDRH1                        | BSP1                                   |
| 0x0022           | 0x30000044               | DXRL1                        | BSP1                                   |
| 0x0023           | 0x30000046               | DXRH1                        | BSP1                                   |
| 0x0024           | 0x30000048               | SPSA1                        | BSP1                                   |
| 0x0025           | 0x3000004A               | зарезервировано              |                                        |
| 0x0026           | 0x3000004C               | SPCRL1                       | BSP1                                   |
| 0x0027           | 0x3000004E               | SPCRH1                       | BSP1                                   |
| 0x0028           | 0x30000050               | DDRL2                        | BSP2                                   |
| 0x0029           | 0x30000052               | DDRH2                        | BSP2                                   |
| 0x002A           | 0x30000054               | DXRL2                        | BSP2                                   |
| 0x002B           | 0x30000056               | DDRH2                        | BSP2                                   |
| 0x002C           | 0x30000058               | SPSA2                        | BSP2                                   |
| 0x002D           | 0x3000005A               | зарезервировано              |                                        |
| 0x002E           | 0x3000005C               | SPCRL2                       | BSP2                                   |
| 0x002F           | 0x3000005E               | SPCRH2                       | BSP2                                   |
| 0x0030           | 0x30000060               | DDRL3                        | BSP3                                   |
| 0x0031           | 0x30000062               | DDRH3                        | BSP3                                   |
| 0x0032           | 0x30000064               | DXRL3                        | BSP3                                   |
| 0x0033           | 0x30000066               | DDRH3                        | BSP3                                   |
| 0x0034           | 0x30000068               | SPSA3                        | BSP3                                   |
| 0x0035           | 0x3000006A               | зарезервировано              | BSP3                                   |
| 0x0036           | 0x3000006C               | SPCRL3                       | BSP3                                   |
| 0x0037           | 0x3000006E               | SPCRH3                       | BSP3                                   |
| 0x0038           | 0x30000002               | TIM                          | Timer                                  |
| 0x0039           | 0x30000070               | PRD                          | Timer                                  |
| 0x0039           | 0x30000072               | TCR                          | Timer                                  |
| 0x003A           | 0x30000074               | зарезервировано              | Timer                                  |
| 0x003C           | 0x30000076               | DIRQ                         | DIRQ                                   |
| 0x003D           | 0x30000078               | AIRQ                         | AIRQ                                   |
| 0x003E           | 0x3000007A               | зарезервировано              | Alive                                  |
| 0x003L           | 0x3000007C               | CRPT CWR                     | Crypto                                 |
| 0x0040<br>0x0041 | 0x30000080               | _                            | Crypto                                 |
| 0x0041           |                          | зарезервировано<br>CRPT SR   | Crypto                                 |
| 0x0042           | 0x30000084<br>0x30000086 | _                            | Crypto                                 |
|                  | 0x30000088               | зарезервировано<br>CRPT DATA | Crinto                                 |
| 0x0044           | 0x3000008A               | _                            | Crypto                                 |
| 0x0045           |                          | зарезервировано              | Crunto                                 |
| 0x0046           | 0x3000008C               | CRPT_KR                      | Crypto                                 |
| 0x0047           | 0x3000008E               | зарезервировано              | Om into                                |
| 0x0048           | 0x30000090               | CRPT_SYNR                    | Crypto                                 |
| 0x0049           | 0x30000092               | зарезервировано              | 0.000                                  |
| 0x004A           | 0x30000094               | CRPT_CR                      | Crypto                                 |
| 0x004B           | 0x30000096               | зарезервировано              | 0,,,,,,,,,                             |
| 0x004C           | 0x30000098               | CRPT_IMIT                    | Crypto                                 |
| 0x004D           | 0x3000009A               | зарезервировано              |                                        |
| 0x004E           | 0x3000009C               | CRPT_ITER                    | Crypto                                 |
| 0x004F           | 0x3000009E               | зарезервировано              |                                        |
| 0x0050           | 0x300000A0               | POWCTL                       | Codec                                  |
| 0x0051           | 0x300000A2               | зарезервировано              |                                        |
| 0x0052           | 0x300000A4               | ADCCTL                       | Codec                                  |

| Адрес DSP | Адрес RISC | Наименование<br>регистра | Модуль, к которому принадлежит регистр |
|-----------|------------|--------------------------|----------------------------------------|
| 0x0053    | 0x300000A6 | зарезервировано          |                                        |
| 0x0054    | 0x300000A8 | DACCTL                   | Codec                                  |
| 0x0055    | 0x300000AA | зарезервировано          |                                        |
| 0x0056    | 0x300000AC | MASKCTL                  | Codec                                  |
| 0x0057    | 0x300000AE | зарезервировано          |                                        |
| 0x0058    | 0x300000B0 | IRQFLAG                  | Codec                                  |
| 0x0059    | 0x300000B2 | зарезервировано          |                                        |
| 0x005A    | 0x300000B4 | ADCREG                   | Codec                                  |
| 0x005B    | 0x300000B6 | зарезервировано          |                                        |
| 0x005C    | 0x300000B8 | DACREG                   | Codec                                  |
| 0x005D    | 0x300000BA | зарезервировано          |                                        |
| 0x005E    | 0x300000BC | CLKMD                    | CLKMD                                  |
| 0x005F    | 0x300000BE | зарезервировано          |                                        |
| 0x0060    | 0x300000C0 | dma_statusL              | DMA                                    |
| 0x0061    | 0x300000C2 | dma_statusH              | DMA                                    |
| 0x0062    | 0x300000C4 | dma_configL              | DMA                                    |
| 0x0063    | 0x300000C6 | dma_configH              | DMA                                    |
| 0x0064    | 0x300000C8 | ctrl_base_ptrL           | DMA                                    |
| 0x0065    | 0x300000CA | ctrl_base_ptrH           | DMA                                    |
| 0x0066    | 0x300000CC | alt_ctrl_base_ptrL       | DMA                                    |
| 0x0067    | 0x300000CE | alt_ctrl_base_ptrH       | DMA                                    |
| 0x0068    | 0x300000D0 | dma_waitonreq_statusL    | DMA                                    |
| 0x0069    | 0x300000D2 | dma_waitonreq_statusH    | DMA                                    |
| 0x006A    | 0x300000D4 | chnl_sw_requestL         | DMA                                    |
| 0x006B    | 0x300000D6 | chnl_sw_requestH         | DMA                                    |
| 0x006C    | 0x300000D8 | chnl_useburst_setL       | DMA                                    |
| 0x006D    | 0x300000DA | chnl_useburst_setH       | DMA                                    |
| 0x006E    | 0x300000DC | chnl_useburst_clrL       | DMA                                    |
| 0x006F    | 0x300000DE | chnl_useburst_clrH       | DMA                                    |
| 0x0070    | 0x300000E0 | chnl_req_mask_setL       | DMA                                    |
| 0x0071    | 0x300000E2 | chnl_req_mask_setH       | DMA                                    |
| 0x0072    | 0x300000E4 | chnl_req_mask_clrL       | DMA                                    |
| 0x0073    | 0x300000E6 | chnl_req_mask_clrH       | DMA                                    |
| 0x0074    | 0x300000E8 | chnl_enable_setL         | DMA                                    |
| 0x0075    | 0x300000EA | chnl_enable_setH         | DMA                                    |
| 0x0076    | 0x300000EC | chnl_enable_clrL         | DMA                                    |
| 0x0077    | 0x300000EE | chnl_enable_clrH         | DMA                                    |
| 0x0078    | 0x300000F0 | chnl_pri_alt_setL        | DMA                                    |
| 0x0079    | 0x300000F2 | chnl_pri_alt_setH        | DMA                                    |
| 0x007A    | 0x300000F4 | chnl_pri_alt_clrL        | DMA                                    |
| 0x007B    | 0x300000F6 | chnl_pri_alt_clrH        | DMA                                    |
| 0x007C    | 0x300000F8 | chnl_priority_setL       | DMA                                    |
| 0x007D    | 0x300000FA | chnl_priority_setH       | DMA                                    |
| 0x007E    | 0x300000FC | chnl_priority_clrL       | DMA                                    |
| 0x007F    | 0x300000FE | chnl_priority_clrH       | DMA                                    |

# 6.4.3 Отображение памяти DSP в памяти RISC

Память DSP-подсистемы (включая периферийные блоки) отображается в адресное пространство RISC в область DATA с адреса 0x30000000 по адрес 0x30040000. DMA RISC также имеет доступ к памяти DSP по тем же адресам.

RISC-ядро и DMA RISC доступно все адресное пространство DSP-подсистемы, кроме регистров ядра DSP. Соответстие карты памяти DSP и RISC показано на рисунке ниже. Ядро RISC использует байтовую адресацию, ядро DSP полусловную (16 бит). В таблице ниже показано подробное отображение регистров периферийных модулей DSP-подсистемы в памяти RISC.



Рисунок 6-10 - Отображение памяти DSP в адресное пространство RISC

Таблица 6-8 - Отображение памяти DSP в адресное пространство RISC

| Область<br>памяти | Сектор памяти | Адреса RISC и тип доступа       | RISC | Адреса DSP и<br>доступа DS |    |
|-------------------|---------------|---------------------------------|------|----------------------------|----|
| Память            | Регистры ядра |                                 |      |                            |    |
| данных            | DSP           | <b>0x3000_0000</b> -0x3000_003F | NA   | <b>0x0000</b> -0x001F      | RW |
|                   | Регистры      |                                 |      |                            |    |
|                   | периферийных  |                                 |      |                            |    |
|                   | модулей       | 0x3000_0040-0x3000_00FF         | RW   | 0x0020-0x007F              | RW |
|                   | ОЗУ данных    | 0x3000_0100- <b>0x3001_FFFF</b> | RW   | 0x0080- <b>0xFFFF</b>      | RW |
| Память            | Программы     |                                 |      |                            |    |
| программ          | пользователя  | <b>0x3002_0000</b> -0x3003_FEFF | RW   | <b>0x0000</b> -0xFF7F      | RO |
|                   | Таблица       |                                 |      |                            |    |
|                   | векторов      |                                 |      |                            |    |
|                   | прерывания    | 0x3003_FF00- <b>0x3003_FFFF</b> | RW   | 0xFF80- <b>0xFFFF</b>      | RO |

Примечание – NA – нет доступа, RO – только чтение, RW – чтение и запись.

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

данных) одним из устройств системы (ядром RISC, DMA RISC, ядром DSP или DMA DSP) не будет задержано, в случае, если все другие обращение в этот момент используют другие блоки ОЗУ DSP.

Например, если ядро DSP выполняет программу из первой четверти своей памяти программ, ядро RISC может без каких либо торможений системы записать новые функции для DSP во вторую четверть памяти программ. Одновременные обращения различных устройств к одному и тому же сектору ОЗУ программ или данных возможны, но приводят к необходимости ожидания освобождения доступа к ОЗУ, и, как следствие, к общему уменьшеннию быстродействия системы.

# 6.5 Загрузочное ПЗУ и режимы работы микроконтроллера

После включения питания и снятия внутренних (POR) и внешних (RESET) сигналов сброса, микроконтроллер начинает выполнять программу из загрузочной области ПЗУ BOOT ROM. В загрузочной программе микроконтроллер определяет, в каком из режимов он будет функционировать, и переходит в этот режим. Режим функционирования определяется внешними выводами MODE[2:0] (PF[6:4]), при этом перед опросом состояния этих выводов, для них включается внутренняя подтяжка к земле (встроенные резисторы подтяжки к земле имеют сопротивление ~50 кОм). Также устанавливается бит FPOR в регистре BKP REG 0E, который может быть сброшен только при отключении основного питания Ucc. После перезапуска микроконтроллера уровни на выводах MODE[2:0] не влияют на функционирование микроконтроллера, если установлен бит FPOR. пользовательской программе выводы PF[6:4] могут использоваться пользователем.

Таблица 6-9 - Режимы первоначального запуска микроконтроллера

| MODE[2:0] | Режим                               | Стартовый<br>адрес/таблица<br>векторов<br>прерываний | Описание                                                                                                                                                                                                                                  |
|-----------|-------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000       | Микроконтроллер в<br>режиме отладки | 0x0800_0000                                          | Процессор начинает выполняет программу из внутренней FLASH памяти программ. При этом установлен отладочный интерфейс JTAG_В                                                                                                               |
| 001       | Микроконтроллер в<br>режиме отладки | 0x0800_0000                                          | Процессор начинает выполняет программу из внутренней FLASH памяти программ. При этом разрешается работа отладочного интерфейса JTAG_A                                                                                                     |
| 010-011   | Микропроцессор в<br>режиме отладки  | 0x1000_0000                                          | Процессор конфигурирует внешнюю системную шину в режим работы ROM с Wait_States = 0xF и начинает выполняет программу из внешней памяти установленной на внешней системной шине. При этом разрешается работа отладочного интерфейса JTAG_B |
| 100       | Зарезервировано                     | -                                                    | -                                                                                                                                                                                                                                         |
| 101       | Зарезервировано                     | -                                                    | -                                                                                                                                                                                                                                         |
| 110       | UART загрузчик без<br>отладки       | Определяется<br>пользователем                        | Микроконтроллер через интерфейс UART3 на выводах PF[1:0] получает код программы в ОЗУ для исполнения. При этом отладочный интерфейс JTAG/SW заблокирован                                                                                  |
| 111       | Зарезервировано                     | -                                                    | -                                                                                                                                                                                                                                         |

При работе в режиме отладки разрешается работа отладочного интерфейса JTAG/SW. При этом к микроконтроллеру может быть подключен JTAG/SW адаптер, с помощью которого программные средства разработки позволяют работать с микроконтроллером в отладочном режиме. Линии JTAG должны быть подтянуты к питанию сопротивлениями не менее 10 К с учетом, чтобы эти подтяжки не влияли на работу системы (Рисунок 6–11).



Рисунок 6-11 - Схема работы в режиме отладки

В отладочном режиме можно:

- стирать, записывать, считывать внутреннюю FLASH память программ RISC;
- считывать и записывать содержимое ОЗУ и периферии;
- выполнять программу в пошаговом режиме;
- запускать программу в нормальном режиме;
- останавливать программу по точкам остановки;
- просматривать переменные выполняемой программы;
- проводить трассировку хода выполнения программного обеспечения.

В зависимости от режима работы выводы интерфейса JTAG/SW переопределяются на различные выводы микроконтроллера представленные в таблице ниже.

Таблица 6-10 - Переопределение выводов интерфейса JTAG/SW

| Вывод<br>JTAG/SW | Вывод микроконтроллера            | Описание                       |
|------------------|-----------------------------------|--------------------------------|
|                  | JTAG_A                            |                                |
| TRST             | PB4/DATA20/JA_TRST                | В качестве выводов интерфейса  |
| TCK              | PB2/DATA18/JA_TCK                 | используются выводы порта В    |
| TMS              | PB1/DATA17/JA_TMS                 | совмещенные с данными внешней  |
| TDI              | PB3/DATA19/JA_TDI                 | системной шины, использование  |
| TDO              | PB0/DATA16/JA_TDO                 | который при отладке запрещено  |
|                  | JTAG_B                            |                                |
| TRST             | PD2/ADC2/BUSY/SSP2RXD/JB_TRST     | В качестве выводов интерфейса  |
| TCK              | PD1/ADC1_REF-/TMR1_CH1/           | используются выводы порта D    |
|                  | UART2_TXD/JB_TCK                  | совмещенные с каналами АЦП,    |
| TMS              | PD0/ADC0_REF+/TMR1_CH1N/          | выводами каналов Таймера 1,    |
|                  | UART2_RXD/JB_TMS                  | UART2 и SSP2, использование    |
| TDI              | PD3/ADC3/CE/SSP2FSS/JB_TDI        | который при отладке запрещено. |
| TDO              | PD4/ADC4/TMR1_ETR/nSIROUT2/JB_TDO |                                |

# 6.6 UART загрузчик

Для загрузки программ в режиме UART загрузчика используется реализованный на периферийный модуль UART3 специальный протокол обмена. При этом для работы модуля используется выводы в соответствии с Таблица 6–11.

Таблица 6–11 – Используемые порты ввода/вывода UART загрузчиком

| Режим | Rx  | Tx  |
|-------|-----|-----|
| 110b  | PF0 | PF1 |

Данные режимы предоставляют и достаточный набор операций, необходимых для записи в ОЗУ какой-либо программы (в частности программатора Flash-памяти), верификации ее и запуска на выполнение. Кроме того, существует возможность задания внешним устройством скорости обмена. В качестве источника тактовой частоты UART3 используется внутренний RC-генератор HSI с частотой 8 МГц. Так как разброс значений частоты HSI (для различных образцов микроконтроллеров) весьма велик (от 6 до 10 МГц), то требуется этап подбора значения делителя частоты UART3 для синхронизации с внешним устройством.

### Параметры связи по UART

Для связи по UART выбраны следующие параметры канала связи:

Начальная скорость, [бод] - 13363 (BRDI = 4; BRDF = 40;)

Количество бит данных — 8 Четность — нет Количество Stop бит — 1

Загрузчик не использует FIFO UART3.

Загрузчик всегда выступает в качестве Slave, а внешнее устройство, подающее команды – в качестве Master.

Данные передаются младшим битом вперед.

#### Протокол обмена по UART

После синхронизации с внешним устройством, подающим команды (Master), загрузчик переходит в диспетчер команд. Набор команд протокола представлен в Таблица 6–12.

Таблица 6-12 - Команды UART загрузчика

| Команда  | Код  | ASCII<br>Символ | Описание                                    |  |
|----------|------|-----------------|---------------------------------------------|--|
| CMD_SYNC | 0x00 |                 | Пустая команда.                             |  |
|          |      |                 | Загрузчик ее принимает, но ничего по ней не |  |
|          |      |                 | делает                                      |  |
| CMD_CR   | 0x0D |                 | Выдача приглашения Master-y                 |  |
| CMD_BAUD | 0x42 | 'B'             | Установка скорости обмена                   |  |
| CMD_LOAD | 0x4C | 'L'             | Загрузка массива байт                       |  |
| CMD_VFY  | 0x59 | 'Υ'             | Выдача массива байт                         |  |
| CMD_RUN  | 0x52 | 'R'             | Запуск программы на выполнение              |  |

# 6.6.1 Синхронизация с внешним устройством

#### Начальные условия

На этапе синхронизации с внешним устройством (Master) вывод Rx используется как вход.

Маster постоянно посылает в канал синхросимвол – 0. Загрузчик подстраивает свою скорость таким образом что бы минимизировать ощибки обмена. Как только Загрузчик настроил скорость он переходит в диспетчер команд и выдает приглашение (3 байта 0х0D (перевод строки), 0х0A (возврат каретки), 0х3E ('>'),) Master-y.

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

# 6.6.1.1 Команда CMD\_SYNC

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

Загрузчик (Slave) ее принимает, но ничего по ней не делает. Код команды соответствует символу синхронизации.

# Таблица 6-13 - Команда CMD SYNC

| Код команды               | CMD_SYNC = 0x00                                      |
|---------------------------|------------------------------------------------------|
| ASCII символ,             | нет                                                  |
| соответствующий коду      |                                                      |
| команды                   |                                                      |
| Количество параметров     | 0                                                    |
| команды                   |                                                      |
| Формат команды:           |                                                      |
| Master Выдает код команды | Slave Если команда принята с ошибками, то выдает код |
| CMD_SYNC.                 | ошибки ERR_CHN или ERR_CMD и завершает обработку     |
|                           | текущей команды                                      |

# 6.6.1.2 Команда CMD\_CR

Выдача приглашения Master-y

# Таблица 6-14 - Команда CMD\_CR

| Код команды                        | $CMD\_CR = 0x0D$                                                                                                                                                                                     |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ASCII символ, соответствующий коду | нет                                                                                                                                                                                                  |
| команды                            |                                                                                                                                                                                                      |
| Количество параметров команды      | 0                                                                                                                                                                                                    |
| Формат команды:                    |                                                                                                                                                                                                      |
| Master Выдает код команды CMD_CR.  | Slave Если команда принята с ошибками, то выдает код ошибки ERR_CHN или ERR_CMD и завершает обработку текущей команды. Выдает код команды CMD_CR. Выдает код 0x0A Выдает код 0x3E (ASCII символ '>') |

# 6.6.1.3 Команда CMD\_BAUD

Установка скорости обмена

#### Таблица 6-15 - Команда CMD BAUD

| Код команды                        | CMD_BAUD = 0x42                      |
|------------------------------------|--------------------------------------|
| ASCII символ, соответствующий коду | 'B'                                  |
| команды                            |                                      |
| Количество параметров команды      | 1                                    |
| Параметр                           | Новое значение скорости обмена [бод] |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Формат команды:                    |                                                                                                                                                                                             |  |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Master Выдает код команды CMD_BAUD | Slave Если команда принята с ошибками, то выдает код ошибки ERR_CHN или ERR_CMD и завершает обработку текущей команды                                                                       |  |
| Master Выдает параметр             | Если параметр принят с ошибками, то выдает код ошибки ERR_CHN или ERR_BAUD и завершает обработку текущей команды. Выдает код команды CMD_BAUD. Устанавливает новое значение скорости обмена |  |

# 6.6.1.4 Команда CMD\_LOAD

Загрузка массива байт в память микроконтроллера

# Таблица 6-16 - Команда CMD\_LOAD

| Код команды                        | CMD_LOAD = 0x4C                              |  |
|------------------------------------|----------------------------------------------|--|
| ASCII символ, соответствующий коду | 'L'                                          |  |
| команды                            |                                              |  |
| Количество параметров команды      | 2                                            |  |
| Параметр 1.                        | Адрес памяти приемника данных.               |  |
| Параметр 2.                        | Размер массива в байтах                      |  |
| Формат команды:                    |                                              |  |
| Master Выдает код команды CMD_LOAD | Slave Если команда принята с ошибками, то    |  |
|                                    | выдает код ошибки ERR_CHN или ERR_CMD и      |  |
|                                    | завершает обработку текущей команды          |  |
| Master Выдает параметр 1.          | Slave Если хотя бы один из параметров принят |  |
|                                    | с ошибками, то выдает код ошибки ERR_CHN и   |  |
|                                    | завершает обработку текущей команды          |  |
| Master Выдает параметр 2.          | Slave Если хотя бы один из параметров принят |  |
|                                    | с ошибками, то выдает код ошибки ERR_CHN и   |  |
|                                    | завершает обработку текущей команды.         |  |
|                                    | Выдает код команды CMD_LOAD                  |  |
| Master Выдает массив байт младшим  | Slave Принимает массив байт. Если хотя бы    |  |
| байтом вперед.                     | один байт принят с ошибками, то выдает код   |  |
|                                    | ошибки ERR_CHN и завершает обработку         |  |
|                                    | текущей команды, не дожидаясь окончания      |  |
|                                    | принятия всего массива. По окончании         |  |
|                                    | принятия массива выдает код ответа           |  |
|                                    | $REPLY\_OK = 0x4B ('K')$                     |  |

# 6.6.1.5 Команда CMD\_VFY

Выдача массива байт из памяти микроконтроллера

# Таблица 6-17 - Команда CMD\_VFY

| Код команды                        | CMD_VFY = 0x59                                                                                                                                                                                                                                                           |  |  |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ASCII символ, соответствующий коду | 'Y'                                                                                                                                                                                                                                                                      |  |  |
| команды                            | ·                                                                                                                                                                                                                                                                        |  |  |
| Количество параметров команды      | 2                                                                                                                                                                                                                                                                        |  |  |
| Параметр 1                         | Адрес памяти источника данных                                                                                                                                                                                                                                            |  |  |
| Параметр 2                         | Размер массива в байтах                                                                                                                                                                                                                                                  |  |  |
| Формат команды:                    |                                                                                                                                                                                                                                                                          |  |  |
| Master Выдает код команды CMD_VFY  | VFY Slave Если команда принята с ошибками, то выдает код ошибки ERR_CHN или ERR_CMD и завершает обработку текущей команды                                                                                                                                                |  |  |
| Master Выдает параметр 1           | Slave Если хотя бы один из параметров принят с ошибками, то выдает код ошибки ERR_CHN и завершает обработку текущей команды                                                                                                                                              |  |  |
| Master Выдает параметр 2           | Slave Если хотя бы один из параметров принят с ошибками, то выдает код ошибки ERR_CHN и завершает обработку текущей команды. Выдает код команды CMD_VFY. Выдает массив байт младшим байтом вперед. По окончании передачи массива выдает код ответа REPLY_OK = 0x4B ('K') |  |  |

# 6.6.1.6 Команда CMD\_RUN

Запуск программы на выполнение.

# Таблица 6-18 - Команда CMD\_RUN

| Код команды                        | $CMD_RUN = 0x52$                                                                                                                                                                                                                                                           |  |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ASCII символ, соответствующий коду | 'R'                                                                                                                                                                                                                                                                        |  |
| команды                            |                                                                                                                                                                                                                                                                            |  |
| Количество параметров команды      | 1                                                                                                                                                                                                                                                                          |  |
| Параметр.                          | Адрес таблицы векторов загруженной программы                                                                                                                                                                                                                               |  |
| Формат команды:                    |                                                                                                                                                                                                                                                                            |  |
| Master Выдает код команды CMD_RUN. | Slave Если команда принята с ошибками, то выдает код ошибки ERR_CHN или ERR_CMD и завершает обработку текущей команды                                                                                                                                                      |  |
| Master Выдает параметр.            | Если параметр принят с ошибками, то выдает код ошибки ERR_CHN и завершает обработку текущей команды. Выдает код команды CMD_RUN. Устанавливает значение MSP и PC согласно таблице векторов (NVIC не перепрограммируется) и, таким образом, Slave завершает свое выполнение |  |

#### 6.6.1.7 Прием параметров команды

Параметры команд – это 4-х байтные числа.

Параметры передаются младшим байтом вперед.

В качестве значения параметра запрещено использовать число 0xFFFFFFF.

Если при приеме параметра обнаружена аппаратная ошибка (UART установил в '1' какой-либо из флагов ошибки), то прием параметров не прекращается.

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

#### 6.6.1.8 Сообщения об ошибках

Сообщения об ошибках — это 2-х байтные последовательности символов. Первый символ всегда 0х45 ('E'). Второй символ определяет тип ошибки.

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

После принятия сообщения об ошибке Master должен подавать команду CMD\_CR до тех пор, пока не получит корректный ответ, соответствующий этой команде.

Возможны следующие сообщения об ошибках: ERR\_CHN, ERR\_CMD, ERR\_BAUD.

#### Ошибка ERR CHN

Аппаратная ошибка UART.

Код ошибки 0х69 ('i').

Выдается, если UART установил в '1' один из аппаратных флагов ошибки при приеме очередного байта.

# Ошибка ERR\_CMD

Принята неизвестная команда.

Код ошибки 0х63 ('c').

Выдается диспетчером команд, если принят неизвестный код команды.

# Ошибка ERR\_BAUD

Принята неизвестная команда.

Код ошибки 0x62 ('b').

Выдается диспетчером команд, если по принятому от Master-а значению скорости обмена невозможно вычислить корректное значение делителя частоты UART.

# 7 Контроллер FLASH памяти программ

Микроконтроллер содержит встроенную Flash-память программ для ядра RISC объемом 128 Кбайт основной памяти программ и 4 Кбайта информационной памяти.

В обычном режиме (бит CON = 0, регистр EEPROM\_CMD) доступна основная память программ через системные шины I Code и D code для выборки инструкций и данных кода программы.

В режиме программирования (бит CON=1, регистр EEPROM\_CMD) основная и информационная память доступны как периферийные устройства и могут быть использованы для нужд разработчика приложения. В режиме программирования программный код должен выполняться из области системной шины или ОЗУ. Выполнение программного кода из Flash-памяти программ в режиме программирования невозможно.

# 7.1 Работа Flash памяти программ в обычном режиме

Скорость доступа во Flash память ограничена и составляет порядка 40 нс. в результате выдача новых значений из Flash памяти может происходить с частотой не более 25 МГц. Для того, что бы процессорное ядро могло получать новые инструкции на больших частотах в микроконтроллере реализуется Flash память с физической организацией 8К на 128 разрядов. Таким образом, за 40 нс из Flash памяти извлекается 16 байт, в которых может быть закодировано от 4 до 8 инструкций процессора. И пока ядро выполняет эти инструкции из памяти извлекается следующая порция данных. Таким образом, тактовая частота может превышать частоты извлечения данных из памяти в несколько раз при линейном выполнении программы. При возникновении переходов в выполнении программы, когда из памяти программ не выбраны нужные инструкции возникает пауза в несколько тактов процессора для того что бы данные успели считаться из Flash. Число тактов паузы зависит от тактовой частоты процессора, так при работе с частотой ниже 25 МГц пауза не требуется, так как Flash память успевает выдать новые данные за один такт, при частоте от 25 до 50 МГц требуется один такт паузы, и так далее. Число тактов паузы задается в регистре EEPROM CMD битами Delay[2:0]. В таблице приведены характеристики необходимой паузы для работы Flash памяти программ.

| Delay[2:0] | Тактов паузы | Тактовая частота | Примечание                                                     |
|------------|--------------|------------------|----------------------------------------------------------------|
| 0x00       | 0            | До 25 МГц        |                                                                |
| 0x01       | 1            | До 50 МГц        |                                                                |
| 0x02       | 2            | До 75 МГц        |                                                                |
| 0x03       | 3            | До 100 МГц       | Работа микросхемы с частотой более<br>100 МГц не гарантируется |
| 0x04       | 4            | До 125 МГц       |                                                                |
| 0x05       | 5            | До 150 МГц       |                                                                |
| 0x06       | 6            | До 175 МГц       |                                                                |
| 0x07       | 7            | До 200 МГц       | Установлено по умолчанию после сброса                          |

Таблица 7–1 – Дополнительная пауза для работы Flash-памяти

Число тактов паузы устанавливается до момента повышения тактовой частоты или после снижения тактовой частоты.

Также в контроллере EEPROM реализованы раздельные кэш для данных и для инструкций, объемом 16 x 4 32-битных слов каждый. В том случае, если запрашиваемая по шине I-bus команда или запрашиваемые по шине D-bus данные содержаться в кэш команд или данных соответственно, ядро получает требуемое слово без задержек.

Кэши команд и данных могут быть включены битами DCEN и ICEN регистра EEPROM\_CTRL сответственно. После сброса значение обоих бит равно 0 (кэш выключен). В том случае, если кэш выключен, он никак не влияет на работу механизма доступа к данным flash-памяти.

#### 7.2 Работа Flash памяти программ в режиме программирования

В режиме программирования Flash-память программ не может выдавать инструкции и данные процессору, поэтому перевод памяти в режим программирования (установка бита CON = 1) возможен только программой, исполняемой из памяти, установленной на внешней системной шине, или ОЗУ. Перед переводом памяти в режим программирования необходимо в регистр EERPOM\_KEY записать комбинацию 0x8AAA5551.

В режиме программирования возможны следующие операции как с основной (бит IFREN = 0, регистр EEPROM\_CON), так и с информационной (бит IFREN = 1) памятью:

- стирание всей памяти;
- стирание страницы памяти размером 4 Кбайт;
- запись 32-битного слова в память;
- чтение 32-битного слова из памяти.

**Внимание!** Нельзя повторять циклы стирания – записи и стирания – стирания одной ячейки памяти с периодом менее 4 мс.

| Страница 31         | 0x0801_FFFC | 0x0801_FFF8     | 0x0801_FFF4     | 0x0801_FFF0 |
|---------------------|-------------|-----------------|-----------------|-------------|
| 256 x 128<br>4K x 8 | 0x0801_F00C | <br>0x0801_F008 | <br>0x0801_F004 | 0x0801_F000 |
|                     | ***         | • • •           | • • •           |             |
| Страница 1          | 0x0800_1FFC | 0x0800_1FF8     | 0x0800_1FF4     | 0x0800_1FF0 |
|                     |             |                 |                 |             |
| 256 x 128<br>4K x 8 | 0x0800_100C | 0x0800_1008     | 0x0800_1004     | 0x0800_1000 |
| Страница 0          | 0x0800_0FFC | 0x0800_0FF8     | 0x0800_0FF4     | 0x0800_0FF0 |
| -                   |             |                 |                 |             |
| 256 x 128           | 0x0800_001C | 0x0800_0018     | 0x0800_0014     | 0x0800_0010 |
| 4K x 8              | 0x0800_000C | 0x0800_0008     | 0x0800_0004     | 0x0800_0000 |
|                     | Sector_D    | Sector_C        | Sector_B        | Sector_A    |
|                     |             |                 |                 |             |
|                     | 256 x 32    | 256 x 32        | 256 x 32        | 256 x 32    |
|                     | 1K x 8      | 1K x 8          | 1K x 8          | 1K x 8      |

Основная память (IFREN=0)

| Страница 0          | 0x0800_0FFC                | 0x0800_0FF8                    | 0x0800_0FF4                | 0x0800_0FF0                    |
|---------------------|----------------------------|--------------------------------|----------------------------|--------------------------------|
| 256 x 128<br>4K x 8 | 0x0800_001C<br>0x0800_000C | <br>0x0800_0018<br>0x0800_0008 | 0x0800_0014<br>0x0800_0004 | <br>0x0800_0010<br>0x0800_0000 |
|                     | Sector_D                   | Sector_C                       | Sector_B                   | Sector_A                       |
|                     | 256 x 32<br>1K x 8         | 256 x 32<br>1K x 8             | 256 x 32<br>1K x 8         | 256 x 32<br>1K x 8             |

Информационная память (IFREN=1)

Рисунок 7-1 - Структура Flash памяти

# 7.2.1 Стирание всей памяти

Стирание всей памяти выполняется в 4 этапа:

- 1 этап стирание Sector\_A для всей памяти;
- 2 этап стирание Sector\_В для всей памяти;
- 3 этап стирание Sector\_C для всей памяти;
- 4 этап стирание Sector D для всей памяти.

Стирание одного сектора памяти возможно только режиме программирования. Для стирания одного сектора памяти надо установить необходимое значение в бит IFREN (1 – для основной и информационной памяти и 0 – для основной памяти), и номер сектора EEPROM ADR[3:2] (00 – Sector A, 01 – Sector\_B, 10 – Sector\_C и 11 – Sector\_D) затем установить биты XE, MAS1 и ERASE в единицу, и спустя время tnvs = 5 мкс установить бит NVSTR в единицу. Полное стирание памяти длится время tme = 40 мс. Спустя это время необходимо очистить бит ERASE, и спустя время tnvh1 = 100 мкс очистить биты XE, MAS1 и Последующие операции С онжом NVSTR. памятью выполнять время trcv = 1 мкс. Временная диаграмма стирания памяти представлена далее (см. Рисунок 7-2). При стирании информационной области, автоматически стирается и основная. Для стирания всей памяти необходимо осуществить стирание всех секторов памяти.



Рисунок 7-2 - Временная диаграмма стирания памяти

# 7.2.2 Стирание страницы памяти размером 4 Кбайт

Стирание одной страницы выполняется в 4 этапа:

1 этап - стирание Sector А для одной страницы;

2 этап - стирание Sector В для одной страницы;

3 этап - стирание Sector С для одной страницы;

4 этап - стирание Sector D для одной страницы.

Стирание одного сектора страницы памяти возможно только в режиме программирования. Для стирания страницы памяти надо установить необходимое значение в бит IFREN (1 - для информационной памяти и 0 - для основной памяти), затем установить адрес стираемой страницы в регистре EEPROM\_ADR[16:12] и номер сектора EEPROM\_ADR[3:2] (00 – Sector\_A, 01 – Sector\_B, 10 – Sector\_C и 11 – Sector\_D) и установить биты XE и ERASE в единицу, и спустя время tnvs = 5 мкс установить бит NVSTR в единицу. Стирание страницы памяти длится время terase = 40 мс. Спустя это время необходимо очистить бит ERASE, и спустя время tnvh = 5 мкс очистить биты XE и NVSTR. Последующие операции с памятью можно выполнять спустя время trcv = 1 мкс. Временная диаграмма стирания страницы памяти представлена далее (см. Рисунок 7–3). Для стирания всей страницы необходимо осуществить стирание всех секторов страницы.



Рисунок 7-3 – Временная диаграмма стирания банка памяти

#### 7.2.3 Запись 32-х битного слова в память

Запись в память возможна только в режиме программирования.

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

Для записи в память надо установить необходимое значение в бит IFREN (1 — для информационной памяти и 0 — для основной памяти), затем установить адрес, по которому производится запись, в регистре EEPROM\_ADR, в регистр EEPROM\_DI поместить записываемое в память слово и установить биты XE и PROG в единицу, и спустя время tnvs = 5 мкс установить бит NVSTR в единицу. Спустя время tpgs = 10 мкс установить бит YE в единицу. Запись в память длится время tprog = 40 мкс. Спустя это время необходимо очистить бит YE, и через tadh = 20 нс установить новый адрес (в пределах того же сектора и той же страницы) и значение для записи в другую ячейку памяти; затем через tads = 20 нс установить YE в единицу и записать следующее слово.

Примечание — В одном цикле допускается запись в пределах одного сектора одной страницы.

Если запись больше не требуется, то спустя время tpgh = 20 нс после очистки бита YE необходимо очистить бит PROG и спустя время tnvh = 5 мкс очистить биты XE и NVSTR. Последующие операции с памятью можно выполнять спустя время trcv = 1 мкс.

Временная диаграмма записи памяти представлена ниже (см. Рисунок 7-4).



Рисунок 7-4 - Временная диаграмма записи памяти

#### 7.2.4 Чтение 32-х битного слова из памяти

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

режиме программирования для чтения доступна основная, информационная память. Для чтения из памяти надо установить необходимое значение в бит IFREN (1 – для информационной памяти и 0 – для основной памяти), считать адрес, ИЗ которого необходимо установить данные, регистре EEPROM\_ADR и установить биты XE, YE и SE в единицу, и спустя время txa = 30 нс из регистра EEPROM DO можно считать данные. Если необходимо считать следующее слово, то в регистр EEPROM\_ADR следует записать новый адрес и, спустя время txa = 30 нс, из регистра EEPROM\_DO можно считать следующие данные. Если чтение больше не требуется, то можно очистить все биты управления. Временная диаграмма чтения памяти в режиме программирования представлена далее (см. Рисунок 7-5).



# Рисунок 7-5 - Временная диаграмма чтения памяти

# 7.3 Описание регистров управления контроллера Flash памяти программ

Таблица 7–2 предоставляет перечень регистров управления контроллера Flash-памяти программ.

Таблица 7-2 - Регистры управления контроллера Flash-памяти программ

| Базовый<br>адрес | Название   | Описание                                   |
|------------------|------------|--------------------------------------------|
| 0x4001_8000      | MDR_EEPROM | Регистры контроллера Flash-памяти программ |
| Смещение         |            |                                            |
| 0x00             | CMD        | Регистр команды                            |
| 0x04             | ADR        | Регистр адреса                             |
| 0x08             | DI         | Регистр данных на запись                   |
| 0x0C             | DO         | Регистр данных считанных                   |
| 0x10             | KEY        | Регистр ключа                              |
| 0x14             | CTRL       | Регистр управления                         |

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

#### Обозначения:

SE

R/W – бит доступен на чтение и запись;

RO – бит доступен только на чтение;

U – бит физически не реализован или зарезервирован.

Таблица 7-3 - Регистр команды EERPOM\_CMD

| Номер           | 3114     | 13                                     | 12   | 11        | 10     | 9        |
|-----------------|----------|----------------------------------------|------|-----------|--------|----------|
| Доступ          | U        | R/W                                    | R/W  | R/W       | R/W    | R/W      |
| Сброс           | 0        | 0                                      | 0    | 0         | 0      | 0        |
|                 |          | NVSTR                                  | PROG | MAS1      | ERASE  | IFREN    |
|                 |          | 1110111                                |      | 1117 (0 1 |        |          |
|                 |          | i iii ii | 1100 |           | LIVAGE | 11 11214 |
| Номер           | 8        | 7                                      | 6    | 53        | 2, 1   | 0        |
| Номер<br>Доступ | 8<br>R/W | 7<br>R/W                               |      |           |        | 0<br>R/W |

XΕ

**Delay[2:0]** 

Таблица 7-4 - Описание бит регистра EEPROM\_CMD

ΥE

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3114      | -                       | Зарезервировано                                                                            |
| 13        | NVSTR                   | Операции записи или стирания:<br>0 – при чтении;<br>1 – при записи или стирании            |
| 12        | PROG                    | Записать данные по ADR[16:2] из регистра EERPOM_DI:<br>0 – нет записи;<br>1 – есть запись  |

CON

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 11        | MAS1                    | Стереть весь блок, при ERASE = 1:                                                          |
|           |                         | 0 – стирается страница с адресом ADR[16:12] в секторе с                                    |
|           |                         | адресом ADR[3:2];                                                                          |
|           |                         | 1 – стирается весь сектор с адресом ADR[3:2]                                               |
| 10        | ERASE                   | Стереть строку с адресом ADR[16:9], ADR[8:0] значения не имеет:                            |
|           |                         | 0 – нет стирания;                                                                          |
|           |                         | 1 – стирание                                                                               |
| 9         | IFREN                   | Работа с блоком информации:                                                                |
|           |                         | 0 – основная память;                                                                       |
|           |                         | 1 – информационный блок                                                                    |
| 8         | SE                      | Усилитель считывания:                                                                      |
|           |                         | 0 – не включен;                                                                            |
|           |                         | 1 – включен                                                                                |
| 7         | YE                      | Выдача адреса ADR[8:2]:                                                                    |
|           |                         | 0 – не разрешено;                                                                          |
|           |                         | 1 – разрешено                                                                              |
| 6         | XE                      | Выдача адреса ADR[16:9]:                                                                   |
|           |                         | 0 – не разрешено;                                                                          |
|           |                         | 1 – разрешено                                                                              |
| 53        | Delay[2:0]              | Задержка памяти программ при чтении в циклах (в рабочем                                    |
|           |                         | режиме):                                                                                   |
|           |                         | 000 — 0 цикл                                                                               |
|           |                         | 001 — 1 цикл                                                                               |
|           |                         | 111 – 7 циклов                                                                             |
| 2, 1      | -                       | Зарезервированно                                                                           |
| 0         | CON                     | Переключение контроллера памяти EEPROM на регистровое                                      |
|           |                         | управление, не может производиться при исполнении программы                                |
|           |                         | из области EERPOM:                                                                         |
|           |                         | 0 – управление EERPOM от ядра, рабочий режим;                                              |
|           |                         | 1 – управление от регистров, режим программирования                                        |

# 7.3.1 MDR\_EEPROM->ADR

Таблица 7-5 - Регистр адреса EERPOM\_ADR

| Номер  | 310        |
|--------|------------|
| Доступ | R/W        |
| Сброс  | 0          |
|        | ADR [31:0] |

# Таблица 7-6 - Описание бит регистра адреса EEPROM\_ADR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое описание      |
|------|----------------|---------------------------------------------------------------|
| бита | имя бита       | назначения и принимаемых значений                             |
| 310  | ADR[31:0]      | Адрес обращения в память:                                     |
|      |                | ADR[1:0] – не имеет значения, минимально адресуемая ячейка 32 |
|      |                | бита                                                          |

# 7.3.2 MDR\_EEPROM->DI

# Таблица 7-7 - Регистр записываемых данных EERPOM\_DI

| Номер  | 310 |
|--------|-----|
| Доступ | R/W |

| Сброс | 0           |  |  |  |
|-------|-------------|--|--|--|
|       | DATA [31:0] |  |  |  |

# Таблица 7-8 - Описание бит регистра записываемых данных EERPOM\_DI

| №<br>бита | _          | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|------------|--------------------------------------------------------------------------------------------|
| 310       | DATA[31:0] | Данные для записи в EERPOM                                                                 |

# 7.3.3 MDR\_EEPROM->DO

# Таблица 7-9 - Регистр считываемых данных EERPOM\_DO

| Номер  | 310         |
|--------|-------------|
| Доступ | R/W         |
| Сброс  | 0           |
|        | DATA [31:0] |

# Таблица 7-10 - Описание бит регистра считываемых данных EERPOM\_DO

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|--|
| 310       |                         | Данные, считанные из EERPOM                                                                |  |

# 7.3.4 MDR EEPROM->KEY

# Таблица 7-11 - Регистр ключа EEPROM\_KEY

| Номер  | 310        |
|--------|------------|
| Доступ | R/W        |
| Сброс  | 0          |
|        | KEY [31:0] |

# Таблица 7-12 - Описание бит регистра ключа EEPROM\_KEY

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                          |  |  |  |
|-----------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 310       | KEY[31:0]               | Ключ для разрешения доступа к Flash-памяти через регистровый доступ. Перед переводом памяти в режим программирования необходимо в регистр EERPOM_KEY записать комбинацию 0x8AAA5551 |  |  |  |

# 7.3.5 MDR EEPROM-> CTRL

# Таблица 7-13 - Регистр управления EERPOM\_CTRL

| Номер  | 313 | 1   | 0   |
|--------|-----|-----|-----|
| Доступ | U   | R/W | R/W |
| Сброс  | 0   | 0   | 0   |

# Таблица 7-14 - Описание бит регистра EEPROM\_CTRL

| Nº   |          | Расшифровка функционального имени бита, краткое описание |
|------|----------|----------------------------------------------------------|
| бита | имя бита | назначения и принимаемых значений                        |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| 312 | -    | Зарезервировано          |  |
|-----|------|--------------------------|--|
| 1   | DCEN | Включение кеш данных     |  |
|     |      | 0 – выключено;           |  |
|     |      | 1 – включено;            |  |
| 0   | ICEN | Включение кеш инструкций |  |
|     |      | 0 – выключено;           |  |
|     |      | 1 – включено;            |  |

# 8 Процессорное ядро RISC

# 8.1 Структурная схема процессорного ядра RISC

- Процессорное ядро RISC высокопроизводительный 32-разрядный процессор, разработанный для микроконтроллерных систем;
- Высокая производительность скомбинирована с быстрой обработкой прерываний;
- Расширенная система отладки с точками остановки и трассировки;
- Эффективное процессорное ядро для работы системы и памяти;
- Сверхнизкое потребление с встроенными режимами sleep;
- Защищенная система с интегрированными блоком защиты памяти MPU.



Рисунок 8-1 - Структурная схема процессорного ядра

Процессор построен на высокопроизводительном ядре с 3-х стадийным конвейером и Гарвардской архитектурой, что делает его идеальным для микроконтроллерных приложений. Процессор предлагает превосходную энергоэффективность, эффективный набор инструкций, оптимальный дизайн аппаратных средств, включающих однотактную инструкцию умножения 32х32 и аппаратное деление. Процессор содержит интегрированный контроллер прерываний и встроенные средства отладки. Процессор реализует набор инструкций Thumb2, обеспечивающих высокую плотность кода и более экономное использование памяти программ. Процессор обеспечивает производительность 32-х битных архитектур с размером кода, сравнимым с 8-ми и 16-ти битными микроконтроллерами.

Процессор содержит контроллер прерываний NVIC, обеспечивающий высокоскоростную обработку прерываний. NVIC обеспечивает до 16-ти уровней приоритетов прерываний. Интеграция контроллера прерываний в ядро позволяет реализовать быстрое исполнение обработчиков прерываний (interrupt service routines

– ISR), эффективно снижающее задержку обработки прерываний. Это обеспечивается аппаратным сохранением в стеке регистров, выполняемым одной инструкций множественной записи и считывания памяти. Реализация обработчиков прерываний не требует их описания на ассемблере и позволяет удалить из обработчика код по перегрузке контекста. Оптимизация сцепления концов обработчиков позволяет снизить затраты при переключении с одного обработчика на другой.

Оптимизированный для пониженного энергопотребления контроллер NVIC обеспечивает режимы Sleep и Deep Sleep, которые позволяют быстро снизить потребление.

Ядро RISC обеспечивает большую скорость и низкую задержку обращения в память. Также поддерживаются невыровненные обращения и битовые манипуляции с областью ОЗУ и регистрами периферии.

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

Ядро RISC реализует аппаратную поддержку функций отладки. Отладка позволяет отображать состояние системы и памяти через стандартный JTAG разъем или 2-х проводной интерфейс SWD.

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

Периферийными блоками ядра являются:

- контроллер прерываний NVIC Реализует высокоскоростную обработку прерываний
- блок системного управления SBC Программный интерфейс процессора, реализует отображение информации о системной реализации, а также управление системой, включая конфигурирование, управление и отображение событий в системе
- системный таймер SysTick 24-х битный счетчик, считающий вниз, используется операционными системами реального времени для подсчета тактов или как обычный счетчик
- блок защиты памяти MPU Используется для повышения надежности системы путем задания различных атрибутов для регионов памяти. Поддерживает до 8-ми различных регионов и один опциональный предопределенный регион.

# 8.2 Программная модель

Процессор может функционировать в режимах:

- Thread
   Используется для исполнения приложений, процессор находится в этом режиме сразу после сброса
- Handler Используется для обработки исключений. После обработки исключения процессор переходит в Thread режим.

Уровни привилегий при исполнении программ:

# Unprivileged

Программное обеспечение:

- имеет ограниченный доступ к MSR и MRS инструкциям, и не может использовать CPS инструкцию;
- не имеет доступа к системному таймеру, NVIC и блоку системного управления;
- может иметь пониженный уровень доступа к памяти или периферии.

Непривилегированное программное обеспечение исполняется с уровнем unprivileged.

# Privileged Программное обеспечение имеет полный доступ ко всем инструкциям и ресурсам.

Привилегированное программное обеспечение исполняется с уровнем privileged.

В *Thread* режиме регистр CONTROL определяет уровень исполнения программы *unprivileged* или *privileged*. Подробнее в описании регистра CONTROL. В *handler* режиме программное обеспечение всегда выполняется на *privileged* уровне.

Только привилегированное программное обеспечение может писать в регистр CONTROL для изменения уровня исполнения программы в *Thread* режиме. Непривилегированное программное обеспечение может использовать инструкцию SVC для выполнения *supervisor call* для передачи управления привилегированной программе.

# 8.3 Стек

Процессор использует нисходящий стек. Это означает, что указатель стека обозначает последний сохраненный в стеке элемент в стековой области памяти. Когда процессор записывает новый элемент в стек, сначала декрементируется указатель и затем записывается новый элемент в память. Процессор реализует два стека — main и process с независимыми указателями стеков, подробнее смотрите указатели стека.

В *Thread* режиме регистр CONTROL определяет, какой стек используется – *main* или *process*, подробнее в описании CONTROL регистра. В *Handler* режиме процессор всегда использует *main* стек.

Таблица 8–1 – Режимы работы процессора при выполнении программы

| Режим<br>процессора | Использование | Уровни привилегии<br>для программного<br>обеспечения | Используемый стек |  |
|---------------------|---------------|------------------------------------------------------|-------------------|--|
| Thread              | Выполнение    | Privileged или                                       | Main или          |  |
| Tilleau             | приложений    | Unprivileged (1)                                     | Process (1)       |  |
| Handler             | Обработка     | Всегда <i>Privileged</i>                             | Main стек         |  |
| riailulei           | исключений    | всегда РПипедеи                                      | <i>Main</i> Crek  |  |

1 – Подробнее см. описание регистра CONTROL.

# 8.4 Регистры ядра



Рисунок 8-2 - Регистры ядра

Таблица 8-2 - Сводная таблица регистров ядра

| Название | Тип <sup>1)</sup> | Требуемый<br>уровень<br>привилегий | Значение<br>после<br>сброса | Описание                                                                     |
|----------|-------------------|------------------------------------|-----------------------------|------------------------------------------------------------------------------|
| R0-R12   | RW                | Оба <sup>2)</sup>                  | Неизвестно                  | Регистры общего назначения                                                   |
| MSP      | RW                | Privileged                         | См. описание                | Указатель стека <i>main</i><br>Stack Pointer                                 |
| PSP      | RW                | Оба <sup>2)</sup>                  | Неизвестно                  | Указатель стека <i>process</i><br>Stack Pointer                              |
| LR       | RW                | Оба <sup>2)</sup>                  | 0xFFFFFFF                   | Регистр связи<br>Link Register                                               |
| PC       | RW                | Оба <sup>2)</sup>                  | См. описание                | Счетчик команд<br>Program Counter                                            |
| PSR      | RW                | Privileged                         | 0x01000000                  | Программный регистр состояния<br>Program Status Register                     |
| ASPR     | RW                | Оба <sup>2)</sup>                  | 0x00000000                  | Программный регистр состояния приложения Application Program Status Register |
| IPSR     | RO                | Privileged                         | 0x00000000                  | Программный регистр состояния прерываний Interrupt Program Status Register   |

| Название  | Тип <sup>1)</sup> | Требуемый уровень привилегий | Значение<br>после<br>сброса | Описание                                                                   |  |
|-----------|-------------------|------------------------------|-----------------------------|----------------------------------------------------------------------------|--|
| ESPR      | RO                | Privileged                   | 0x01000000                  | Программный регистр состояния выполнения Execution Program Status Register |  |
| PRIMASK   | RW                | Privileged                   | 0x00000000                  | Регистр маски приоритетов<br>Priority Mask Register                        |  |
| FAULTMASK | RW                | Privileged                   | 0x00000000                  | Регистр маски сбоев<br>Fault Mask Register                                 |  |
| BASEPRI   | RW                | Privileged                   | 0x00000000                  | Регистр базового приоритета маски Base Priority Mask Register              |  |
| CONTROL   | RW                | Privileged                   | 0x00000000                  | , ,                                                                        |  |

<sup>1) –</sup> Определяет режим доступа при исполнении программы в *thread* и *handler* режимах. В режиме отладки может отличаться;

# 8.4.1 Регистры общего назначения R0-R12

R0-R12 – это 32-х разрядные регистры для данных при выполнении операций.

# 8.4.2 Указатель стека SP R13

Stack Pointer Register (SP) – это регистр R13. В Thread режиме бит 1 регистра CONTROL обозначает, какой указатель стека используется:

- 0 Main Stack Pointer (MSP). Сразу после сброса;
- 1 Process Stack Pointer (PSP).

При сбросе в MSP устанавливается 0x00000000.

# 8.4.3 Регистр связи LR R14

Link Register — это регистр R14. Регистр используется для сохранения информации об адресе возврата при уходе на обработку прерываний, вызовах функций и обработке исключений. При сбросе устанавливается в 0xFFFFFFFF.

## 8.4.4 Счетчик команд РС R15

Program Counter – это регистр R15. Он содержит адрес текущей инструкции. Бит 0 всегда 0, так как все инструкции выровнены на полуслово. При сбросе процессор считывает в этот регистр вектор сброса, который расположен по адресу 0x00000004.

# 8.4.5 Программный регистр состояния PSR

Регистр Program Status Register (PSR) объединяет регистры:

Application Program Status Register (APSR)

Interrupt Program Status Register (IPSR)

Execution Program Status Register (EPSR)

Эти регистры разделяют различные битовые поля в 32-х разрядном PSR. Описание регистров приведено ниже. Доступ к этим регистрам может быть как

<sup>2) –</sup> Регистр доступен при исполнении программы с обоими уровнями привилегий

индивидуальный, так и комбинированный к двум или всем трем разом, с использованием имен регистров в качестве аргументов инструкций MSR или MRS.

# Например:

- читать все регистры, используя PSR с MRS инструкцией;
- записать только в APSR, используя APSR с MSR инструкцией.

Таблица 8-3 - Комбинация PSR и их атрибуты

| Регистр | Тип        | Комбинация        |
|---------|------------|-------------------|
| PSR     | RW (1),(2) | APSR, EPSR и IPSR |
| IEPSR   | RO         | EPSR и IPSR       |
| IAPSR   | RW(1)      | APSR и IPSR       |
| EAPSR   | RW(2)      | APSR и EPSR       |

- 1 Игнорируется запись в IPSR биты
- 2 При чтении EPSR бит читаются нули, и запись в них игнорируется.

Подробнее в описании инструкции MRS и MSR.

# 8.4.6 Программный регистр состояния приложения APSR

Perистр APSR содержит текущие флаги состояния выполнения предыдущей инструкции.

Таблица 8-4 - Регистр APSR

| Номер  | 31  | 30  | 29  | 28  | 27  | 260 |
|--------|-----|-----|-----|-----|-----|-----|
| Доступ | R/W | R/W | R/W | R/W | R/W |     |
| Сброс  | 0   | 0   | 0   | 0   | 0   |     |
|        | N   | Z   | С   | V   | Q   | -   |

# Таблица 8-5 - Описание бит регистра APSR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое           |  |
|------|----------------|-----------------------------------------------------------|--|
| бита | имя бита       | описание назначения и принимаемых значений                |  |
| 31   | N              | Negative                                                  |  |
|      |                | 0 – результат операции положительный или нулевой, либо    |  |
|      |                | «больше чем или равно»;                                   |  |
|      |                | 1 – результат операции отрицательный, либо «меньше чем».  |  |
| 30   | Z              | Zero:                                                     |  |
|      |                | 0 – результат операции не нулевой;                        |  |
|      |                | 1 – результат операции нулевой.                           |  |
| 29   | С              | Carry:                                                    |  |
|      |                | 0 – при суммировании не было переноса, либо при вычитании |  |
|      |                | не было заема;                                            |  |
|      |                | 1 – при суммировании был перенос, либо при вычитании был  |  |
|      |                | заем.                                                     |  |
| 28   | V              | Overflow:                                                 |  |
|      |                | 0 – в результате операции не было переполнения;           |  |
|      |                | 1 – в результате операции было переполнение.              |  |
| 27   | Q              | Saturation:                                               |  |
|      |                | 0 – обозначает, что не было накопления с момента сброса   |  |
|      |                | либо с момента установки бита в ноль;                     |  |

|     |   | 1 – обозначает, что в результате выполнения инструкций SSAT и USAT было накопление. |  |
|-----|---|-------------------------------------------------------------------------------------|--|
|     |   | Флаг сбрасывается в ноль программно инструкцией MRS.                                |  |
| 260 | - | Зарезервировано                                                                     |  |

# 8.4.7 Программный регистр состояния прерываний IPSR

Perистр IPSR содержит номер типа исключения для текущего обработчика прерывания.

# Таблица 8-6 - Регистр IPSR

| Номер  | 319 | 80         |
|--------|-----|------------|
| Доступ | -   | RO         |
| Сброс  | -   | 0          |
|        | -   | ISR_NUMBER |

# Таблица 8-7 - Описание бит регистра IPSR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое    |
|------|----------------|----------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений         |
| 319  | -              | Зарезервировано                                    |
| 80   | ISR_NUMBER     | Номер текущего исключения                          |
|      |                | 0 – Thread режим;                                  |
|      |                | 1 – зарезервировано;                               |
|      |                | 2 – NMI;                                           |
|      |                | 3 – Hard Fault;                                    |
|      |                | 4 – Memory Management Fault;                       |
|      |                | 5 – Bus Fault;                                     |
|      |                | 6 – Usage Fault;                                   |
|      |                | 710 – зарезервировано;                             |
|      |                | 11 – SVCall;                                       |
|      |                | 12 – зарезервировано для отладки;                  |
|      |                | 13 – PendSV;                                       |
|      |                | 15 – SysTick;                                      |
|      |                | 16 – IRQ0;                                         |
|      |                |                                                    |
|      |                | 48 – IRQ31.                                        |
|      |                |                                                    |
|      |                | Более подробно в разделе «Прерывания и исключения» |

# 8.4.8 Программный регистр состояния выполнения EPSR

Perистр EPSR содержит бит состояния Thumb инструкции, и биты состояния выполнения для инструкций:

- If-Then (IT) блок инструкций;
- Interruptible-Continuable Instruction (ICI) поле для прерываемых инструкций множественного сохранения и считывания

# Таблица 8-8 - Регистр EPSR

| Номер  | 3127 | 2625   | 24 | 2316 | 1510   | 90 |
|--------|------|--------|----|------|--------|----|
| Доступ |      | RO     | RO |      | RO     |    |
| Сброс  |      | 0      | 1  |      | 0      |    |
|        | -    | ICI/IT | Т  | -    | ICI/IT | -  |

| Таблица 8-9 - | Описание бит | регистра EPSR |
|---------------|--------------|---------------|
|---------------|--------------|---------------|

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|--|
| 3127      | -                       | Варезервировано                                                                            |  |
| 2625      | ICI/IT                  | ICI: Биты Interruptible-Continuable Instruction                                            |  |
|           |                         | IT: Обозначает выполнение инструкции IT                                                    |  |
| 24        | T                       | Всегда 1                                                                                   |  |
| 2316      | -                       | Зарезервировано                                                                            |  |
| 1510      | ICI/IT                  | ICI: Биты Interruptible-Continuable Instruction                                            |  |
|           |                         | IT: Обозначает выполнение инструкции IT                                                    |  |
| 90        | -                       | Зарезервировано                                                                            |  |

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

# Interruptible-Continuable Instruction

Когда происходит прерывание при выполнении инструкций LDM или STM, то процессор:

временно останавливает операцию множественного чтения или записи;

сохраняет номер следующий регистр операнда в множественной операции в битах EPSR[15:12].

После обработки прерывания процессор:

возвращает номер регистра для сохранения из бит EPSR[15:12];

возобновляет выполнение операции множественного чтения или записи.

Когда EPSR содержит состояние выполнения ICI инструкции, то биты [26:25] и [11:10] содержат нули.

# If-Then блок инструкций

Блок If-Then содержит до 4 инструкций, следующих за 16-ти битной инструкцией IT. Каждая инструкция в этом блоке условная. Условие для инструкций может быть одним либо обратным для некоторых из них. Подробнее смотрите в разделе инструкция IT.

# 8.4.9 Регистр маски исключений Exception mask

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

Для доступа к регистру маски исключений используются инструкции MSR и MRS, или инструкция CPS для изменения значения PRIMASK и FAULTMASK. Подробнее в разделе инструкции MSR, MRS и CPS.

# 8.4.10 Регистр маски приоритетов Priority Mask

Регистр PRIMASK предотвращает активацию всех исключений с конфигурируемым приоритетом.

# Таблица 8-10 - Регистр PRIMASK

| Номер  | 311 | 0       |
|--------|-----|---------|
| Доступ | U   | R/W     |
| Сброс  | 0   | 0       |
|        | -   | PRIMASK |

# Таблица 8-11 - Описание бит регистра PRIMASK

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 311  | -              | Зарезервировано                                 |
| 0    | PRIMASK        | 0 – не влияет                                   |
|      |                | 1 – предотвращает активацию всех исключений с   |
|      |                | конфигурируемым приоритетом                     |

# 8.4.11 Регистр маски сбоев Fault Mask

Регистр FAULTMASK предотвращает активацию всех исключений.

Таблица 8-12 - Регистр FAULTMASK

| Номер  | 311 | 0         |
|--------|-----|-----------|
| Доступ | U   | R/W       |
| Сброс  | 0   | 0         |
|        | •   | FAULTMASK |

# Таблица 8-13 - Описание бит регистра FAULTMASK

| <b>№</b><br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------------------|----------------------------|--------------------------------------------------------------------------------------------|
| 311              | -                          | Зарезервировано                                                                            |
| 0                | FAULTMASK                  | 0 – не влияет                                                                              |
|                  |                            | 1 – предотвращает активацию всех исключений                                                |

Процессор устанавливает в ноль бит FAULTMASK при выходе из всех обработчиков за исключением NMI обработчика.

# 8.4.12 Регистр базового приоритета маски Base Priority Mask

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

Таблица 8-14 - Регистр BASEPRI

| Номер  | 318 | 70      |
|--------|-----|---------|
| Доступ | U   | R/W     |
| Сброс  | 0   | 0       |
|        | -   | BASEPRI |

| Таблица 8-15 - 0 | Описание бит | регистра | <b>BASEPRI</b> |
|------------------|--------------|----------|----------------|
|------------------|--------------|----------|----------------|

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------------------|-------------------------|--------------------------------------------------------------------------------------------|
| 318              | -                       | Зарезервировано                                                                            |
| 70               | BASEPRI                 | 0 – не влияет.                                                                             |
|                  |                         | Ненулевое – задает базовый приоритет для процесса                                          |
|                  |                         | обработки исключений                                                                       |

Процессор не обрабатывает какие-либо исключения со значением приоритета, большим или равным BASEPRI.

Это поле подобно полю приоритета в регистре приоритетов прерываний. Процессор анализирует только биты [7:4] этого поля, биты [3:0] читаются как нули и игнорируются при записи. Для более полной информации смотрите Таблицу 34–8 – Регистры приоритета прерываний. Помните, что большее значение в поле приоритета соответствует меньшему приоритету обработчика.

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

Регистр CONTROL задает текущий стек и уровень привилегий выполняемой процессором программы в Thread режиме. Смотрите описание регистров процессорного ядра для атрибутов. Описание бит приведено ниже.

Таблица 8-16 - Регистр CONTROL

| Номер  | 312 | 1                    | 0                           |
|--------|-----|----------------------|-----------------------------|
| Доступ | U   | R/W                  | R/W                         |
| Сброс  | 0   | 0                    | 0                           |
|        | -   | Active Stack Pointer | Thread Mode Privilige Level |

Таблица 8-17 - Описание бит регистра CONTROL

| Nº   | Функциональное         | Расшифровка функционального имени бита, краткое |
|------|------------------------|-------------------------------------------------|
| бита | имя бита               | описание назначения и принимаемых значений      |
| 312  | -                      | Зарезервировано                                 |
| 4    | 1 Active Stack Pointer | 0 – MSP текущий указатель стека.                |
| 1    |                        | 1 – PSP текущий указатель стека                 |
| 0    | Thread Mode            | 0 – привелегирован.                             |
| U    | Privilige Level        | 1 – непривелегирован                            |

Handler режим всегда использует указатель стека MSP, таким образом процессор игнорирует прямые записи в бит Active Stack Pointer регистра CONTROL в handler режиме. Вход и выход в обработчик исключений обновляют регистр CONTROL.

При работе с операционными средами рекомендуется, чтобы потоки, запущенные в Thread режиме, использовали PSP стек, а ядро и обработчики исключений использовали MSP стек.

По определению, режим Thread использует MSP. Для переключения указателя стека в Thread режиме на PSP используется MSR инструкция для установки бита Active Stack Pointer в 1, смотрите описание инструкции MSR

Когда изменяется указатель стека, программное обеспечение должно использовать ISB инструкцию немедленно за MSR инструкцией. Это позволяет быть уверенным, что инструкции, следующие за выполнением ISB, будут использовать новый указатель стека. Смотрите описание инструкции ISB.

# 8.5 Исключения и прерывания

Процессорное ядро RISC поддерживает прерывания и системные исключения. Процессор и контроллер прерываний NVIC устанавливают приоритеты и обрабатывают все исключения. Исключение изменяет нормальный поток выполнения программы. Процессор использует handler режим для обработки всех исключений кроме сброса. Смотрите вход в исключение и выход из исключения для большей информации.

Регистры NVIC управляют обработкой прерываний. Смотрите п. «Контроллер прерываний NVIC (RISC)» для более подробной информации.

# Типы данных

Процессор поддерживает следующие типы данных:

- 32-бита words;
- 16-бит halfwords;
- 8-бит bytes.

Процессор поддерживает 64-битную инструкцию передачи.

Процессор манипулирует всеми данными в little-endian режиме. Доступ в память инструкций и Private Peripheral Bus (PPB) всегда в little-endian режиме.

# 9 Система команд RISC

В процессоре реализована версия системы команд Thumb. Поддерживаемые команды представлены в Таблица 9–1.

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

- в угловых скобках <> записываются альтернативные формы представления операндов;
- в фигурных скобках {} указываются необязательные операнды;
- информация в столбце "операнды" может быть неполной;
- второй операнд Op2 может быть либо регистром, либо константой;
- большинство команд могут содержать суффикс кода условного выполнения.
- более подробная информация представлена в детальном описании команд.

Таблица 9-1 - Система команд процессорного ядра RISC

| Мнемокод<br>команды | Операнды                | Краткое описание             | Флаги   | Прим. |
|---------------------|-------------------------|------------------------------|---------|-------|
| ADC, ADCS           | {Rd,} Rn, Op2           | Сложение с переносом         | N,Z,C,V |       |
| ADD, ADDS           | {Rd,} Rn, Op2           | Сложение                     | N,Z,C,V |       |
| ADD, ADDW           | {Rd,} Rn, #imm12        | Сложение                     | N,Z,C,V |       |
| ADR                 | Rd, label               | Загрузка адреса, заданного   | -       |       |
|                     |                         | относительно счетчика команд |         |       |
| AND, ANDS           | {Rd,} Rn, Op2           | Логическое И                 | N,Z,C   |       |
| ASR, ASRS           | Rd, Rm, <rs #n></rs #n> | Арифметический сдвиг вправо  | N,Z,C   |       |
| В                   | label                   | Переход                      | -       |       |
| BFC                 | Rd, #lsb, #width        | Сброс элемента битового поля | -       |       |
| BFI                 | Rd,Rn,#lsb,#width       | Запись заданного значения    | -       |       |
|                     |                         | битового поля                |         |       |
| BIC, BICS           | {Rd,} Rn, Op 2          | Сброс бит по маске           | N,Z,C   |       |
| BKPT                | #imm                    | Точка останова               | -       |       |
| BL                  | label                   | Переход со связью            | -       |       |
| BLX                 | Rm                      | Косвенный переход со связью  | -       |       |
| BX                  | Rm                      | Косвенный переход            | -       |       |
| CBNZ                | Rn, label               | Сравнение с нулем и переход  | -       |       |
|                     |                         | по неравенству               |         |       |
| CBZ                 | Rn, label               | Сравнение с нулем и переход  | -       |       |
|                     |                         | по равенству                 |         |       |
| CLREX               | -                       | Сброс эксклюзивного доступа  | -       |       |
| CLZ                 | Rd, Rm                  | Определить количество        | -       |       |
|                     |                         | ведущих нулей                |         |       |
| CMN, CMNS           | Rn, Op2                 | Сравнить с противоположным   | N,Z,C,V |       |
|                     |                         | знаком                       |         |       |
| CMP, CMPS           | Rn, Op2                 | Сравнить                     | N,Z,C,V |       |
| CPSID               | iflags                  | Изменить состояние процессо- | -       |       |
|                     |                         | ра, запретить прерывания     |         |       |
| CPSIE               | iflags                  | Изменить состояние процессо- | -       |       |
|                     |                         | ра, разрешить прерывания     |         |       |
| DMB                 | -                       | Барьер синхронизации доступа | -       |       |
|                     |                         | к памяти данных              |         |       |
| DSB                 | -                       | Барьер синхронизации доступа | -       |       |
|                     |                         | к памяти данных              |         |       |
| EOR, EORS           | {Rd,} Rn, Op2           | Исключающее ИЛИ              | N,Z,C   |       |

| Мнемокод<br>команды | Операнды                | Краткое описание                                          | Флаги   | Прим. |
|---------------------|-------------------------|-----------------------------------------------------------|---------|-------|
| ISB                 | -                       | Барьер синхронизации доступа<br>к инструкциям             | -       |       |
| IT                  | -                       | Начало блока условно исполняемых инструкций               | -       |       |
| LDM                 | Rn{!}, reglist          | Загрузка множества регистров, инкремент после доступа     | -       |       |
| LDMDB,<br>LDMEA     | Rn{!}, reglist          | Загрузка множества регистров,<br>декремент перед доступом | -       |       |
| LDMFD,<br>LDMIA     | Rn{!}, reglist          | Загрузка множества регистров,<br>инкремент после доступа  | -       |       |
| LDR                 | Rt, [Rn, #offset]       | Загрузка слова в регистр                                  | _       |       |
| LDRB,<br>LDRBT      | Rt, [Rn, #offset]       | Загрузка байта в регистр                                  | -       |       |
| LDRD                | Rt,Rt2,[Rn,#offset]     | Загрузка двойного слова в пару регистров                  | -       |       |
| LDREX               | Rt, [Rn, #offset]       | Эксклюзивное чтение регистра                              | -       |       |
| LDREXB              | Rt, [Rn]                | Эксклюзивное чтение регистра,<br>байт                     | -       |       |
| LDREXH              | Rt, [Rn]                | Эксклюзивное чтение регистра, полуслово                   | -       |       |
| LDRH,<br>LDRHT      | Rt, [Rn, #offset]       | Загрузка полуслова в регистр                              | -       |       |
| LDRSB,<br>LDRSBT    | Rt, [Rn, #offset]       | Загрузка в регистр байта со<br>знаком                     | -       |       |
| LDRSH,<br>LDRSHT    | Rt, [Rn, #offset]       | Загрузка в регистр полуслова со знаком                    | -       |       |
| LDRT                | Rt, [Rn, #offset]       | Загрузка в регистр слова                                  | -       |       |
| LSL, LSLS           | Rd, Rm, <rs #n></rs #n> | Логический сдвиг влево                                    | N,Z,C   |       |
| LSR, LSRS           | Rd, Rm, <rs #n></rs #n> | Логический сдвиг вправо                                   | N,Z,C   |       |
| MLA                 | Rd, Rn, Rm, Ra          | Умножение и сложение, 32-<br>битный результат             | -       |       |
| MLS                 | Rd, Rn, Rm, Ra          | Умножение и вычитание, 32-<br>битный результат            | -       |       |
| MOV, MOVS           | Rd, Op2                 | Загрузка                                                  | N,Z,C   |       |
| MOVT                | Rd, #imm16              | Загрузка в старшее полуслово                              | _       |       |
| MOVW,<br>MOV        | Rd, #imm16              | Загрузка 16-битной константы                              | N,Z,C   |       |
| MRS                 | Rd, spec_reg            | Считать специальный регистр в регистр общего назначения   | -       |       |
| MSR                 | spec_reg, Rm            | Записать регистр общего назначения в специальный регистр  | N,Z,C,V |       |
| MUL, MULS           | {Rd,} Rn, Rm            | Умножение, 32-разрядный результат                         | N,Z     |       |
| MVN,<br>MVNS        | Rd, Op2                 | Загрузка инверсного значения                              | N,Z,C   |       |
| NOP                 | -                       | Нет операции                                              | -       |       |
| ORN, ORNS           | {Rd,} Rn, Op2           | Логическое ИЛИ-НЕ                                         | N,Z,C   |       |
| ORR, ORRS           | {Rd,} Rn, Op2           | Логическое ИЛИ                                            | N,Z,C   |       |
| POP                 | reglist                 | Извлечь регистры из стека                                 | -       |       |
| PUSH                | reglist                 | Занести регистры в стек                                   | -       |       |
| RBIT                | Rd, Rn                  | Изменить на обратный порядок бит в слове                  | -       |       |

| Мнемокод<br>команды | Операнды                  | Краткое описание                                                                                           | Флаги          | Прим. |
|---------------------|---------------------------|------------------------------------------------------------------------------------------------------------|----------------|-------|
| REV                 | Rd, Rn                    | Изменить на обратный порядок байтов в слове                                                                | -              |       |
| REV16               | Rd, Rn                    | Изменить на обратный порядок байтов в полусловах                                                           | -              |       |
| REVSH               | Rd, Rn                    | Изменить на обратный порядок байт в младшем полуслове, произвести распространение знакового бита в старшее | -              |       |
| ROR, RORS           | Rd, Rm, <rs #n></rs #n>   | полуслово Циклический сдвиг вправо                                                                         | NZC            |       |
| RRX, RRXS           | Rd, Rm                    | циклический сдвиг вправо на один бит с учетом переноса                                                     | N,Z,C<br>N,Z,C |       |
| RSB, RSBS           | {Rd,} Rn, Op2             | Вычитание с противоположным порядком аргументов                                                            | N,Z,C,V        |       |
| SBC, SBCS           | {Rd,} Rn, Op2             | Вычитание с учетом переноса                                                                                | N,Z,C,V        |       |
| SBFX                | Rd,Rn,#lsb, #width        | Чтение значения битового поля, интерпретируемого как число со знаком                                       | -              |       |
| SDIV                | {Rd,} Rn, Rm              | Деление чисел со знаком                                                                                    | -              |       |
| SEV                 | -                         | Установить признак события                                                                                 | -              |       |
| SMLAL               | RdLo, RdHi, Rn,<br>Rm     | Умножение чисел со знаком с накоплением, 64-битный результат                                               | -              |       |
| SMULL               | RdLo, RdHi, Rn,<br>Rm     | Умножение чисел со знаком,<br>64-битный результат                                                          | -              |       |
| SSAT                | Rd,#n,Rm{,shift#s}        | Преобразование 32-разрядного числа в n-разрядное со знаком, с насыщением                                   | Q              |       |
| STM                 | Rn{!}, reglist            | Сохранение множества<br>регистров, инкремент после<br>доступа                                              | -              |       |
| STMDB,<br>STMEA     | Rn{!}, reglist            | Сохранение множества<br>регистров, декремент перед<br>доступом                                             | -              |       |
| STMFD,<br>STMIA     | Rn{!}, reglist            | Сохранение множества регистров, инкремент после доступа                                                    | -              |       |
| STR                 | Rt, [Rn, #offset]         | Сохранение регистра                                                                                        | -              |       |
| STRB,<br>STRBT      | Rt, [Rn, #offset]         | Сохранение регистра, байт                                                                                  | -              |       |
| STRD                | Rt, Rt2, [Rn,<br>#offset] | Сохранение пары регистров, двойное слово                                                                   | -              |       |
| STREX               | Rd, Rt, [Rn,<br>#offset]  | Эксклюзивная запись регистра                                                                               | -              |       |
| STREXB              | Rd, Rt, [Rn]              | Эксклюзивная запись регистра, байт                                                                         | -              |       |
| STREXH              | Rd, Rt, [Rn]              | Эксклюзивная запись регистра, полуслово                                                                    | -              |       |
| STRH,<br>STRHT      | Rt, [Rn, #offset]         | Сохранение регистра, полуслово                                                                             | -              |       |
| STRT                | Rt, [Rn, #offset]         | Сохранение регистра, слово                                                                                 | -              |       |
| SUB, SUBS           | {Rd,} Rn, Op2             | Вычитание                                                                                                  | N,Z,C,V        |       |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Мнемокод<br>команды | Операнды                | Краткое описание                                                            | Флаги   | Прим. |
|---------------------|-------------------------|-----------------------------------------------------------------------------|---------|-------|
| SUB, SUBW           | {Rd,} Rn, #imm12        | Вычитание                                                                   | N,Z,C,V |       |
| SVC                 | #imm                    | Вызов супервизора                                                           | -       |       |
| SXTB                | {Rd,}Rm{,ROR#n}         | Преобразовать байт со знаком в слово                                        | -       |       |
| SXTH                | {Rd,}Rm{,ROR#n}         | Преобразовать полуслово со<br>знаком в слово                                | -       |       |
| TBB                 | [Rn, Rm]                | Табличный переход по индексу,<br>смещения - байты                           | -       |       |
| ТВН                 | [Rn, Rm, LSL #1]        | Табличный переход по индексу,<br>смещения - полуслова                       | -       |       |
| TEQ                 | Rn, Op2                 | Проверка равенства                                                          | N,Z,C   |       |
| TST                 | Rn, Op2                 | Проверка значения бит по маске                                              | N,Z,C   |       |
| UBFX                | Rd, Rn, #lsb,<br>#width | Чтение значения битового поля, интерпретируемого как число без знака        | -       |       |
| UDIV                | {Rd,} Rn, Rm            | Деление числе без знака                                                     | -       |       |
| UMLAL               | RdLo, RdHi, Rn,<br>Rm   | Умножение чисел без знака с накоплением, 64-битный результат                | -       |       |
| UMULL               | RdLo, RdHi, Rn,<br>Rm   | Умножение чисел без знака, 64-<br>битный результат                          | -       |       |
| USAT                | Rd,#n,Rm{,shift#s}      | Преобразование 32-разрядного число в n-разрядное со без знака, с насыщением | Q       |       |
| UXTB                | {Rd,}Rm{,ROR#n}         | Преобразовать байт без знака в слово                                        | -       |       |
| UXTH                | {Rd,}Rm{,ROR#n}         | Преобразовать полуслово без<br>знака в слово                                | -       |       |
| WFE                 | -                       | Ожидать событие                                                             | -       |       |
| WFI                 | -                       | Ожидать прерывание                                                          | -       |       |

# 9.1 Встроенные функции

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

В CMSIS предусмотрены следующие встроенные функции, расширяющие возможности стандарта ANSI C.

Таблица 9–2 – Встроенные функции CMSIS, позволяющие генерировать некоторые инструкции процессора RISC

| Мнемокод команды процессора | Описание встроенной функции       |
|-----------------------------|-----------------------------------|
| CPSIE I                     | voidenable_irq(void)              |
| CPSID I                     | voiddisable_irq(void)             |
| CPSIE F                     | voidenable_fault_irq(void)        |
| CPSID F                     | voiddisable_fault_irq(void)       |
| ISB                         | voidISB(void)                     |
| DSB                         | voidDSB(void)                     |
| DMB                         | voidDMB(void)                     |
| REV                         | uint32_tREV(uint32_t int value)   |
| REV16                       | uint32_tREV16(uint32_t int value) |
| REVSH                       | uint32_tREVSH(uint32_t int value) |
| RBIT                        | uint32_tRBIT(uint32_t int value)  |
| SEV                         | voidSEV(void)                     |
| WFE                         | voidWFE(void)                     |
| WFI                         | voidWFI(void)                     |

Кроме того, CMSIS также обеспечивает возможность чтения и записи специальных регистров процессора, доступных с помощью команд MRS и MSR.

Таблица 9–3 – Встроенные функции CMSIS для доступа к специальным регистрам процессора

| Наименование<br>специального<br>регистра | Режим доступа | Описание встроенной функции           |
|------------------------------------------|---------------|---------------------------------------|
| PRIMASK                                  | Чтение        | uint32_tget_PRIMASK (void)            |
| FRIIVIAGN                                | Запись        | voidset_PRIMASK (uint32_t value)      |
| FAULTMASK                                | Чтение        | uint32_tget_FAULTMASK (void)          |
| FAULTWASK                                | Запись        | voidset_FAULTMASK (uint32_t value)    |
| BASEPRI                                  | Чтение        | uint32_tget_BASEPRI (void)            |
| DASEPRI                                  | Запись        | voidset_BASEPRI (uint32_t value)      |
| CONTROL                                  | Чтение        | uint32_tget_CONTROL (void)            |
| CONTROL                                  | Запись        | voidset_CONTROL (uint32_t value)      |
| MSP                                      | Чтение        | uint32_tget_MSP (void)                |
| IVISP                                    | Запись        | voidset_MSP (uint32_t TopOfMainStack) |
| PSP                                      | Чтение        | uint32_tget_PSP (void)                |
| FOF                                      | Запись        | voidset_PSP (uint32_t TopOfProcStack) |

# 9.2 Описание инструкций

В разделе представлена подробная информация об инструкциях процессора:

- операнды;
- ограничения на использование счетчика команд РС и указателя стека SP;
- формат второго операнда;
- операции сдвига;
- выравнивание адресов;
- выражения с участием счетчика команд;
- условное исполнение;
- выбор размера кода инструкции.

# 9.2.1 Операнды

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

Операнды в некоторых инструкциях допускают гибкий формат представления, то есть могут быть как регистром, так и константой. Подробнее см. п. "Формат второго операнда".

# 9.2.2 Ограничения на использование РС и SP

Многие инструкции не позволяют использовать регистры счетчика команд (PC) и указателя стека (SP) в качестве регистра-получателя. Подробная информация содержится в описании конкретных инструкций.

Бит [0] адреса, загружаемого в РС с помощью одной из команд ВХ, BLX, LDM, LDR или POP должен быть равен 1, так как этот бит указывает на требуемый набор команд, а процессор RISC поддерживает только инструкции из набора Thumb.

# 9.2.3 Формат второго операнда

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

- константа;
- регистр с необязательным параметров сдвига.

# 9.2.3.1 Константа

Данный тип второго операнда задается в формате:

#constant

где constant может быть:

- любой константой, которая может быть получена путем сдвига восьмиразрядного числа влево на любое количество разрядов в пределах 32-разрядного слова;
- любая константа в виде 0x00XY00XY;
- любая константа в виде 0xXY00XY00;

• любая константа в виде 0хХҮХҮХҮХҮ.

Во всех вышеописанных случаях Х и У представляют шестнадцатеричные цифры.

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

При использовании константного операнда Operand2 в командах MOVS, MVNS, ANDS, ORRS, ORNS, EORS, BICS, TEQ и TST в случае, если константа больше 255 и может быть получена путем сдвига восьмиразрядного числа, значение бита [31] константы влияет на значение флага переноса. Для всех остальных значений Operand2 изменения флага переноса не происходит.

Замена инструкций

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

Например, команда CMP Rd, #0xFFFFFFE может быть преобразована в эквивалентную команду CMN Rd, #0x2.

# 9.2.3.2 Регистр с необязательным параметром сдвига

В данном случае операнд Operand2 задается в форме:

Rm {, shift}

где

Rm – регистр, содержащий данные для второго операнда инструкции;

shift – необязательный параметр, определяющий сдвиг данных регистра Rm. Он может принимать одно из следующих значений:

ASR #n – арифметический сдвиг вправо на n бит, 1 ≤ n ≤ 32;

LSL #n – логический сдвиг влево на n бит, 1 ≤ n ≤ 31;

LSR #n – логический сдвиг вправо на n бит,  $1 \le n \le 32$ ;

ROR #n – циклический сдвиг вправо на n бит, 1 ≤ n ≤ 31;

RRX – циклический сдвиг вправо на один бит, с учетом переноса.

Случай, когда сдвиг не указан, эквивалентен заданию сдвига LSL #0. При этом в качестве операнда используется непосредственно значение регистра Rm без какихлибо дополнительных преобразований.

При указании параметра сдвига в качестве операнда используется преобразованное соответствующим образом 32-разрядное значение регистра Rm, однако содержимое самого регистра Rm не меняется.

Использование операнда со сдвигом в некоторых инструкциях влияет на значение флага переноса. Более подробно действие операций сдвига и их влияние на флаг переноса рассмотрено в разделе "Операции сдвига".

# 9.2.4 Операции сдвига

Операции сдвига переносят значение бит содержимого регистра влево или вправо на заданное количество позиций - длина сдвига. Сдвиг может выполняться:

• непосредственно с помощью инструкций ASR, LSR, LSL, ROR и RRX, при этом результат сдвига заносится в регистр-получатель;

• во время вычисления значения второго операнда Operand2 команд, при этом результат сдвига используется как один из операндов инструкции.

Допустимая длина сдвига зависит от типа сдвига и инструкции, в которой он был применен (см. стр. 95). В случае, если этот параметр равен 0, фактически сдвиг не производится. Операции сдвига регистра влияют на значение флага переноса, за исключением случая, когда длина сдвига равна 0. Различные варианты сдвига и их влияние на флаг переноса описаны в следующем подразделе (Rm — сдвигаемый регистр, n — длина сдвига).

#### 9.2.4.1 ASR

Арифметический сдвиг вправо на n бит переносит крайние слева 32-n бит регистра Rm вправо на n позиций, то есть на место крайних справа 32-n. Бит [31] исходного значения регистра записывается в n крайних слева бит результата. Смотрите Рисунок 9–1.

Операцию ASR # n можно использовать для деления значения регистра Rm на  $2^n$ , с округлением результата в меньшую сторону (в направлении минус бесконечности).

При использовании инструкции ASRS, а также в случае, если сдвиг ASR #n используется при вычислении второго операнда команд MOVS, MVNS, ANDS, ORRS, ORNS, EORS, BICS, TEQ или TST, флаг переноса принимает значение последнего бита, вытесненного в результате операции сдвига, то есть бита [n-1] регистра Rm.

В случае, если n ≥ 32, все биты результата устанавливаются в значение бита [31] регистра Rm. Если при этом операция влияет на флаг переноса, то значение этого флага устанавливается равным значению бита [31] регистра Rm.



Рисунок 9-1 - Инструкция ASR # 3

#### 9.2.4.2 LSR

Логический сдвиг вправо на n бит переносит крайние слева 32-n бит регистра Rm вправо на n позиций, то есть на место крайних справа 32-n. При этом в n крайних слева бит результата записывается 0. Смотрите Рисунок 9–3.

Операцию LSR # n можно использовать для деления значения регистра Rm на 2n в случае, если значение интерпретируется как целое число без знака.

При использовании инструкции LSRS, а также в случае, если сдвиг LSR #n используется при вычислении второго операнда команд MOVS, MVNS, ANDS, ORRS, ORNS, EORS, BICS, TEQ или TST, флаг переноса принимает значение последнего бита, вытесненного в результате операции сдвига, то есть бита [n-1] регистра Rm.

В случае, если n ≥ 32, все биты результата устанавливаются в 0. Если n ≥ 33 и операция влияет на флаг переноса, то значение этого флага устанавливается равным 0.



Рисунок 9-2 - Инструкция LSR # 3

#### 9.2.4.3 LSL

Логический сдвиг влево на n бит переносит крайние справа 32-n бит регистра Rm влево на n позиций, то есть на место крайних слева 32-n. При этом в n крайних слева бит результата записывается 0. Смотрите Рисунок 9–3.

Операцию LSL # n можно использовать для умножения значения регистра Rm на  $2^n$  в случае, если значение интерпретируется как целое число без знака, либо как целое число со знаком, записанное в дополнительном коде. Переполнение при выполнении умножения не диагностируется.

При использовании инструкции LSLS, а также в случае, если сдвиг LSL #n используется при вычислении второго операнда команд MOVS, MVNS, ANDS, ORRS, ORNS, EORS, BICS, TEQ или TST, флаг переноса принимает значение последнего бита, вытесненного в результате операции сдвига, то есть бита [32-n] регистра Rm. Инструкция LSL #0 не влияет на значение флага переноса.

В случае, если  $n \ge 32$ , все биты результата устанавливаются в 0. Если  $n \ge 33$  и операция влияет на флаг переноса, то значение этого флага устанавливается равным 0.



Рисунок 9-3 - Инструкция LSL # 3

#### 9.2.4.4 ROR

Циклический сдвиг вправо на n бит переносит крайние слева 32-n бит регистра Rm вправо на n позиций, то есть на место крайних справа 32-n. При этом n крайних справа разрядов регистра переносятся в n крайних слева разрядов результата. Смотрите Рисунок 9–4.

При использовании инструкции RORS, а также в случае, если сдвиг ROR #n используется при вычислении второго операнда команд MOVS, MVNS, ANDS, ORRS, ORNS, EORS, BICS, TEQ или TST, флаг переноса принимает значение последнего сдвинутого бита, то есть бита [n-1] регистра Rm.

В случае, если n = 32, результат совпадает с исходным значением регистра. Если n = 32 и операция влияет на флаг переноса, то значение этого флага устанавливается равным биту [31] регистра Rm.

Операция циклического сдвига ROR с параметром, большим 32, эквивалентна циклическому сдвигу с параметром n-32.



Рисунок 9-4 - Инструкция ROR # 3

#### 9.2.4.5 RRX

Циклический сдвиг вправо на один бит с переносом переносит разряды регистра Rm вправо на одну позицию, при этом в позицию [31] результата записывается значение флага переноса. Смотрите Рисунок 9–5.

При использовании инструкции RRXS, а также в случае, если сдвиг RRX #n используется при вычислении второго операнда команд MOVS, MVNS, ANDS, ORRS, ORNS, EORS, BICS, TEQ или TST, флаг переноса принимает значение бита [0] регистра Rm.



Рисунок 9-5 - Инструкция RRX

# 9.2.5 Выравнивание адресов

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

Процессор поддерживает доступ по невыровненным адресам только для следующих инструкций:

- LDR, LDRT;
- LDRH, LDRHT:
- LDRSH, LDRSHT;
- STR, STRT;
- STRH, STRHT.

Все остальные инструкции при попытке доступа по невыровненному адресу генерируют исключение (usage fault). Более подробно данный вопрос рассмотрен в разделе "Обработка отказов".

Невыровненный доступ к данным, как правило, осуществляется медленнее, чем выровненный. Кроме того, некоторые области адресного пространства могут не поддерживать доступ по невыровненному адресу. В связи с этим рекомендуется обеспечивать необходимое выравнивание данных. Для того, чтобы избежать случаев, в которых невыровненный доступ осуществляется непреднамеренно, следует установить в 1 бит UNALIGN\_TRP регистра конфигурации и управления ССR, что приведет тогда к формированию процессором исключительной ситуации (см. п. «SCB->CCR»).

# 9.2.6 Адресация относительно счетчика команд РС

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

- для инструкций B, BL, CBNZ и CBZ текущий адрес определяется как адрес этой инструкции плюс 4 байта;
- для всех остальных инструкций текущий адрес определяется как адрес инструкции плюс 4 байта, при этом бит [1] результата должен быть установлен в 0 для обеспечения выравнивания адреса по границе слова.
- ассемблер может поддерживать расширенные варианты синтаксиса для адресации относительно PC, например, "метка плюс/минус число" или выражения типа [PC, #number].

#### 9.2.7 Условное исполнение

Большая часть команд обработки данных способна изменять значения флагов в регистре состояния прикладной программы (APSR) в зависимости от результата выполнения (см. «Программный регистр состояния приложения APSR»).

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

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

При наличии одного из указанных суффиксов процессор проверяет значение флагов на соответствие заданному условию. Если условие не выполняется, то инструкция:

- не исполняется;
- не записывает значение операции в регистр-получатель;
- не влияет на флаги;
- не генерирует исключений.

Условные инструкции, за исключением условных переходов, должны располагаться внутри блока условно исполняемых инструкций (далее по тексту – IT-блок). Ассемблеры некоторых поставщиков могут самостоятельно вставлять инструкцию IT в случае, если программист разместит условную инструкцию за пределами IT-блока.

Для сравнения регистра с нулем и условного перехода по результату рекомендуется использовать команды CBZ и CBNZ.

Ниже в разделе рассматриваются:

- флаги условий;
- суффиксы условного исполнения.

# 9.2.7.1 Флаги условий

Регистр состояния прикладной программы APSR содержит следующие флаги:

- N=1 в случае, если результат операции меньше нуля, 0 в противном случае.
- Z=1 в случае, если результат равен нулю, 0 в противном случае.
- С=1 в случае, если при выполнении операции возник перенос, 0 в противном случае.
- V=1 в случае, если при выполнении операции возникло переполнение, 0 в противном случае.

Более подробно регистр APSR рассмотрен в разделе «Программный регистр состояния PSR».

Перенос возникает в следующих случаях:

- результат сложения оказался больше или равен 2<sup>32</sup>;
- результат вычитания больше или равен нулю;
- в результате работы внутренней логики процессора при операциях загрузки данных и логических операций.

Переполнение возникает в случае, если результат сложения, вычитания или сравнения больше или равен  $2^{31}$ , либо меньше  $-2^{31}$ .

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

# 9.2.7.2 Суффиксы условного исполнения

В мнемокодах команд, допускающих условное исполнение, предусмотрена возможность указания необязательного кода условия. В описании синтаксиса это обозначается как {cond}. Исполнению условной инструкции должна предшествовать инструкция IT.

Если код условия указан, инструкция выполняется только при удовлетворении соответствующему условию флагов регистра APSR. Используемые коды представлены далее (Таблица 9–4). Там же указаны соответствующие логические выражения для значений флагов.

Условные команды рекомендуется использовать для снижения количества ветвлений в программе.

Таблица 9-4 - Суффиксы условного исполнения

| Суффикс   | Флаги             | Значение                                |
|-----------|-------------------|-----------------------------------------|
| EQ        | Z = 1             | Равенство                               |
| NE        | Z = 0             | Неравенство                             |
| CS или HS | C = 1             | Больше или равно, беззнаковое сравнение |
| CC или LO | C = 0             | Меньше, беззнаковое сравнение           |
| MI        | N = 1             | Меньше нуля                             |
| PL        | N = 0             | Больше или равно нулю                   |
| VS        | V = 1             | Переполнение                            |
| VC        | V = 0             | Нет переполнения                        |
| HI        | C = 1 and $Z = 0$ | Больше, беззнаковое сравнение           |
| LS        | C = 0  or  Z = 1  | Меньше или равно, беззнаковое сравнение |
| GE        | N = V             | Больше или равно, знаковое сравнение    |
| LT        | N != V            | Меньше, знаковое сравнение              |
| GT        | Z = 0 and $N = V$ | Больше, знаковое сравнение              |
| LE        | Z = 1 and N != V  | Меньше или равно, знаковое сравнение    |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Суффикс | Флаги | Значение               |  |
|---------|-------|------------------------|--|
| AL      | 1     | Безусловное исполнение |  |

# Пример. Вычисление абсолютного значения

В данном примере проиллюстрировано использование условных инструкций для вычисления абсолютного значения числа: R0 = ABS(R1).

MOVS R0, R1; R0 = R1, установка флагов IT MI; IT инструкция для условия отрицательного результата RSBMI R0, R1, #0; если результат был меньше нуля, присвоить R0 = -R1

# Пример. Сравнение и изменение значения регистра

В данном примере условные инструкции используются во фрагменте кода, изменяющего значение регистра R4 в случае, если число со знаком в регистр R0 больше числа в R1 и R2 больше R3.

СМР R0, R1; Сравнение R0 и R1, установка флагов ITT GT; IT инструкция для двух условий "больше" СМРGT R2, R3; если R0>R1, сравнить R2 и R3, установить флаги MOVGT R4, R5; если условие "больше" все еще выполняется, присвоить R4 = R5

# 9.2.8 Выбор размера кода инструкции

Многие команды процессора RISC могут быть представлены как 16-разрядными, так и 32-разрядными кодами инструкции. Во многих случаях выбор формата зависит от операндов и регистра-получателя результата.

Нередко существует возможность принудительно задать размер инструкции с помощью суффикса размера команды. Суффикс .W задает кодирование команды в 32-битном формате, суффикс .N- в 16-битном формате.

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

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

BCS.W label; формирует 32-битный код команды, даже для коротких переходов

ADDS.W R0, R0, R1; формирует 32-битный код команды, ; хотя данная операция может быть закодирована 16 битами

# 9.3 Команды доступа к памяти

Обобщенные данные о командах доступа к памяти представлены ниже (Таблица 9–5).

Таблица 9-5 - Команды доступа к памяти

| Мнемокод    | Краткое описание                                      | Прим. |  |
|-------------|-------------------------------------------------------|-------|--|
| ADR         | Загрузка адреса, заданного относительно счетчика      |       |  |
|             | команд                                                |       |  |
| CLREX       | Сброс эксклюзивного доступа                           |       |  |
| LDM{mode}   | Загрузка множества регистров                          |       |  |
| LDR{type}   | Загрузка регистра, непосредственно указанное смещение |       |  |
| LDR{type}   | Загрузка регистра, смещение в регистре                |       |  |
| LDR{type}T  | Загрузка регистра с непривилегированным доступом      |       |  |
| LDR         | Загрузка регистра по относительному адресу            |       |  |
| LDREX{type} | Эксклюзивное чтение регистра                          |       |  |
| POP         | Извлечение регистров из стека                         |       |  |
| PUSH        | Загрузка регистров в стек                             |       |  |
| STM{mode}   | Сохранение множества регистров                        |       |  |
| STR{type}   | Сохранение регистра, непосредственно указанное        |       |  |
|             | смещение                                              |       |  |
| STR{type}   | Сохранение регистра, смещение в регистре              |       |  |
| STR{type}T  | Сохранение регистра с непривилегированным доступом    |       |  |
| STREX{type} | Эксклюзивная запись регистра                          |       |  |

#### 9.3.1 ADR

Загрузка адреса, заданного относительно счетчика команд.

## Синтаксис

ADR(cond) Rd, label

где:

cond – необязательный код условия, см. "Условное исполнение".

Rd – регистр-получатель.

label – относительный адрес, см. "Адресация относительно счетчика команд".

#### Описание

Инструкция ADR вычисляет адрес доступа к памяти путем сложения текущего значения счетчика команд PC и непосредственно заданного смещения, после чего записывает результат в регистр-получатель.

Благодаря использованию относительной адресации, код команды не зависит от ее размещения в физической памяти.

При формировании с помощью команды ADR адреса перехода для команд BX или BLX программисту необходимо убедиться, что бит [0] формируемого адреса установлен в 1.

Значения смещения относительно РС должны находиться в пределах – 4095...+4095. Для того, чтобы использовать максимально широкий диапазон относительных адресов, а также чтобы иметь возможность генерировать адреса, не выровненные по границе слова, может потребоваться задать суффикс .W (см. «Выбор размера кода инструкции»).

# Ограничения

В качестве регистра Rd нельзя использовать указатель стека SP и счетчик команд PC.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

ADR R1, TextMessage ; Загрузить адрес позиции, указанный ; меткой TextMessage, в регистр R1.

# 9.3.2 LDR и STR, непосредственно заданное смещение

Загрузка или сохранение регистра в режиме адресации со смещением, адресации с преиндексированием или адресации с постиндексированием.

#### Синтаксис

op{type}{cond} Rt, [Rn {, #offset}] ; адресация со смещением op{type}{cond} Rt, [Rn, #offset]! ; преиндексирование op{type}{cond} Rt, [Rn], #offset ; постиндексирование opD{cond} Rt, Rt2, [Rn {, #offset}] ; адресация со смещением, двойное слово opD{cond} Rt, Rt2, [Rn, #offset]! преиндексирование, двойное слово opD{cond} Rt, Rt2, [Rn], #offset постиндексирование, двойное слово где:

ор – один из кодов операций:

- LDR загрузить регистр;
- STR сохранить регистр.

type – один из суффиксов размера данных:

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

cond – необязательный код условия, см. "Условное исполнение".

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

Rn – регистр, содержащий базовый адрес памяти.

Offset – смещение относительно базового адреса Rn. В случае, если смещение не указано, оно подразумевается равным нулю.

Rt2 – дополнительный регистр, предназначенный для двухсловных операций чтения или записи.

#### Описание

LDR – загружает один или два регистра значением из памяти.

STR – сохраняет значение одного или двух регистров в память.

Инструкции с непосредственно заданным смещением могут функционировать в одном из следующих режимов адресации:

Адресация со смещением Значение смещения добавляется к или вычитается из

содержимого регистра Rn. Результат используется в качества адреса чтения или записи. Значение регистра

Rn остается неизменным.

Синтаксис задания данного режима:

[Rn, #offset]

Адресация

с преиндексированием

Значение смещения добавляется к или вычитается из содержимого регистра Rn. Результат используется в качества адреса чтения или записи, а также

записывается обратно в регистр Rn. Синтаксис задания данного режима:

[Rn, #offset]!

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

Содержимое регистра Rn используется в качества адреса чтения или записи. Значение смещения добавляется к или вычитается из содержимого регистра Rn, после чего записывается обратно в регистр Rn.

Синтаксис задания данного режима:

[Rn], #offset

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

Таблица 9–6 показывает диапазоны значений смещения для различных форм адресации.

Таблица 9-6 - Диапазон значений смещения

| Тип инструкции            | Смещение                                          | Преиндексирование | Постиндексирование |
|---------------------------|---------------------------------------------------|-------------------|--------------------|
| Слово, полуслово,<br>байт | от -255 до 4095                                   | от -255 до 255    | от -255 до 255     |
| Двойное слово             | Значения, кратные 4, в диапазоне от -1020 до 1020 |                   |                    |

#### Ограничения

Для команд загрузки регистров:

- использовать в качестве Rt регистры PC и SP можно только в командах загрузки слова;
- при загрузке двойных слов регистры Rt и Rt2 не должны совпадать
- в режимах адресации с пре- и постиндексированием регистр Rn не должен совпадать с регистрами Rt или Rt2.

В случае, если в команде загрузки слова в качестве регистра Rt используется счетчик команд PC:

- бит [0] загружаемого значения должен быть равен 1;
- передача управления происходит по адресу, соответствующему значению бита [0] в 0;

• если инструкция является условной, то она должна быть последней инструкцией в IT-блоке.

Для команд сохранения регистров:

- использовать в качестве Rt регистры SP можно только в командах записи слова:
- в качестве регистров Rt и Rn нельзя использовать счетчик команд PC;
- в режимах адресации с пре- и постиндексированием регистр Rn не должен совпадать с регистрами Rt или Rt2.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

LDR R8, [R10] ; Загрузка регистра R8 из ячейки по адресу,

; содержащемуся в R10.

LDRNE R2, [R5, #960]! ; Условная загрузка R2 из слова памяти,

; расположенного на 960 байт выше адреса в регистре

; R5, увеличение регистра R5 на 960.

STR R2, [R9,#const-struc] ; const-struc - выражение с постоянным значением,

лежащим в диапазоне 0 – 4095.

STRH R3, [R4], #4 ; Записать содержимое R3, интерпретируемое как

полуслово, по адресу, содержащемуся в R4, после чего

; увеличить R4 на 4

LDRD R8, R9, [R3, #0x20] ; Загрузить R8 словом данных, расположенным на 32

байта выше адреса в R3, загрузить R9 словом данных,

расположенным на 36 байта выше адреса в R3

STRD R0, R1, [R8], #-16 ; Сохранить R0 по адресу, содержащемуся в R8,

; сохранить R1 по адресу, расположенному на 4 байта ; выше адреса в R8, уменьшить значение R8 на 16.

# 9.3.3 LDR и STR, смещение задано в регистре

Загрузка или сохранение регистра в режиме адресации со смещением, заданным в регистре.

# Синтаксис

op{type}{cond} Rt, [Rn, Rm {, LSL #n}]

где:

ор – один из кодов операций:

- LDR загрузить регистр.
- STR сохранить регистр.

type – один из суффиксов размера данных:

- В байт без знака, при загрузке старшие байты устанавливаются в нуль.
- SB байт со знаком, при загрузке происходит распространение знакового бита в старшие байты (только LDR).
- Н беззнаковое полуслово, при загрузке старшие байты устанавливаются в нуль.
- SH полуслово со знаком, при загрузке происходит распространение знакового бита в старшие байты (только LDR).
- без суффикса 32-разрядное слово.

cond – необязательный код условия, см. "Условное исполнение".

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

Rn – регистр, содержащий базовый адрес памяти.

Rm – регистр, содержащий смещение относительно базового адреса.

LSL #n – необязательный параметр сдвига, в диапазоне от 0 до 3.

#### Описание

LDR – загружает регистра значением из памяти.

STR – сохраняет значение регистра в памяти.

Адрес области памяти, в которую будет производиться обращение, вычисляется на основании значения базового адреса в регистре Rn и смещения. Смещение определяется значением регистра Rm и параметром сдвига влево значения этого регистра.

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

# Ограничения

Для данных команд:

- Rn не может быть счетчиком команд PC;
- Rm не может быть SP или PC;
- использовать в качестве Rt регистр SP можно только в командах чтения и записи слова;
- использовать в качестве Rt регистр PC можно только в командах чтения слова.

В случае, если в команде загрузки слова в качестве регистра Rt используется счетчик команд PC:

- бит [0] загружаемого значения должен быть равен 1, передача управления при этом осуществляется по выровненному по границе полуслова адресу;
- если инструкция является условной, то она должна быть последней инструкцией в IT-блоке.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

STR R0, [R5, R1] ; Записать значение R0 по адресу, равному сумме R5 и R1 LDRSB R0, [R5, R1, LSL #1]

; Считать байт по адресу, равному сумме R5 и R1,

; умноженному на два, распространить значение знакового ; бита на старшие значащие байты слова, загрузить результат

; в регистр R0

STR R0, [R1, R2, LSL #2]

; Сохранить значение регистра R0 по адресу, равному R1+4\*R2.

# 9.3.4 LDR and STR, непривилегированный доступ

Загрузка или сохранение регистра в режиме непривилегированного доступа.

#### Синтаксис

op{type}T{cond} Rt, [Rn {, #offset}]

где:

- ор один из кодов операций:
  - LDR загрузить регистр.
  - STR сохранить регистр.

type – один из суффиксов размера данных:

- В байт без знака, при загрузке старшие байты устанавливаются в нуль.
- SB байт со знаком, при загрузке происходит распространение знакового бита в старшие байты (только LDR).
- Н беззнаковое полуслово, при загрузке старшие байты устанавливаются в нуль.
- SH полуслово со знаком, при загрузке происходит распространение знакового бита в старшие байты (только LDR).
- без суффикса 32-разрядное слово.

cond – необязательный код условия, см. "Условное исполнение".

- Rt регистр, в который должна производиться загрузка или значение которого должно быть сохранено.
- Rn регистр, содержащий базовый адрес памяти.
- offset смещение относительно базового адреса Rn в диапазоне от 0 до 255. В случае, если смещение не указано, оно подразумевается равным нулю.

#### Описание

Описываемые инструкции загрузки и сохранения данных функционируют также, как и инструкции доступа к памяти с непосредственно задаваемым смещением, см. "LDR и STR, непосредственно заданное смещение".

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

При использовании в непривилегированном приложении какие-либо отличия от команд нормального доступа к памяти с непосредственно задаваемым смещением отсутствуют.

# Ограничения

В данных инструкциях:

- Rn не может быть счетчиком команд PC;
- Rt не может быть SP или PC.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

STRBTEQ R4, [R7] ; Условная запись младшего значащего байта в регистр R4 по

; адресу, хранящемуся в R7, с непривилегированным доступом;

LDRHT R2, [R2, #8] ; Загрузка полуслова из памяти по адресу, равному сумме ре-

; гистра R2 и 8 в регистр R2, с непривилегированным доступом.

# 9.3.5 LDR, адресация относительно счетчика команд PC

Загрузка регистра из памяти.

#### Синтаксис

LDR{type}{cond} Rt, label LDRD{cond} Rt, Rt2, label ; Load two words

где:

type – один из суффиксов размера данных:

- В байт без знака, при загрузке старшие байты устанавливаются в нуль.
- SB байт со знаком, при загрузке происходит распространение знакового бита в старшие байты (только для LDR).
- Н беззнаковое полуслово, при загрузке старшие байты устанавливаются в нуль.
- SH полуслово со знаком, при загрузке происходит распространение знакового бита в старшие байты (только для LDR).
- без суффикса 32-разрядное слово.

cond – необязательный код условия, см. "Условное исполнение".

Rt – регистр, в который должна производиться загрузка.

Rt2 – второй регистр, в который должна производиться загрузка.

label – относительный адрес, см. "Адресация относительно счетчика команд PC".

# Описание

LDR – загружает регистр значением из памяти с адресом относительно счетчика команд PC, заданным в виде метки.

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

Метка должна располагаться на ограниченном расстоянии от текущей инструкции. Таблица 9–7 показывает возможные значения смещений между меткой данных и текущим значением счетчика команд. Для использования больших смещений, возможно, придется указать суффикс .W размера команды (см. "Выбор размера кода инструкции").

Таблица 9-7 - Диапазон значений смещения

| Тип инструкции                            | Диапазон значений смещения |  |
|-------------------------------------------|----------------------------|--|
| Слово, полуслово со знаком или без знака, | от -4095 до 4095           |  |
| байт со знаком или без знака              |                            |  |
| Двойное слово                             | от -1020 до 1020           |  |

# Ограничения

В данной инструкции:

- использовать в качестве Rt регистры PC или SP можно только в командах чтения слова;
- нельзя использовать в качестве Rt2 регистры PC и SP;

• при загрузке двойных слов регистры Rt и Rt2 не должны совпадать.

В случае, если в команде загрузки слова в качестве регистра Rt используется счетчик команд PC:

- бит [0] загружаемого значения должен быть равен 1, передача управления при этом осуществляется по выровненному по границе полуслова адресу;
- если инструкция является условной, то она должна быть последней инструкцией в IT-блоке.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

LDR R0, LookUpTable ; Загрузить R0 словом данных по адресу

; с меткой LookUpTable;

LDRSB R7, localdata ; Загрузить байт данных по адресу с меткой localdata,

; распространить значение знакового бита в старшие

; байты слова данных, сохранить результат в R7.

#### LDM u STM

Загрузка или сохранение множества регистров.

#### Синтаксис

op{addr\_mode}{cond} Rn{!}, reglist

где:

ор – один из кодов операций:

- LDM загрузить множество регистров.
- STM сохранить множество регистров.

addr\_mode - один из режимов адресации:

- IA с увеличением адреса после каждого доступа. Этот режим используется по умолчанию.
- DB с уменьшением адреса перед каждым доступом.
- cond необязательный код условия, см. "Условное исполнение".
- Rn регистр, содержащий базовый адрес памяти.
  - необязательный суффикс обратной записи значения базового регистра. В случае, если он присутствует в команде, последний адрес, по которому осуществлялся доступ, будет записан обратно в регистр Rn.
- reglist заключенный в фигурные скобки список из одного или нескольких регистров, которые должны быть записаны или считаны. В списке можно указывать диапазон номеров регистров. Начальный и конечный регистр диапазона разделены знаком "-". Элементы списка (отдельные регистры или диапазоны) разделяются запятыми.

Мнемокоды LDM и LDMFD являются синонимами LDMIA. Наименование LDMFD обусловлено использованием данной команды для организации извлечения данных из стека, растущего вниз, с указателем на последний загруженный элемент (Full Descending stack).

Мнемокод LDMEA является синонимом LDMDB, его наименование обусловлено использованием данной команды для организации извлечения данных из стека, растущего вверх, с указателем на последнюю свободную ячейку (Empty Ascending stack).

Мнемокоды STM и STMEA являются синонимами STMIA. Наименование STMEA обусловлено использованием данной команды для организации записи данных из стека, растущего вверх, с указателем на последнюю свободную ячейку.

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

#### Описание

Инструкции LDM загружают регистры, перечисленные в списке reglist, значениями слов данных из памяти с базовым адресом, указанным в регистре Rn.

Инструкции STM записывают слова данных, содержащиеся в регистрах, перечисленных в списке reglist, в память с базовым адресом, указанным в регистре Rn.

Команды LDM, LDMIA, LDMFD, STM, STMIA и STMEA для доступа используют адреса памяти в интервале от Rn до Rn+4\*(n-1), где n - количество регистров в списке reglist. Доступ осуществляется в порядке увеличения номера регистра, при этом регистр с наименьшим номером соответствует наименьшему адресу памяти, а регистр с наибольшим номером - наибольшему адресу. В случае, если в команде указан суффикс "!", значение Rn+4\*(n-1) записывается обратно в регистр Rn.

Команды LDMDB, LDMEA, STMDB и STMFD для доступа используют адреса памяти в интервале от Rn до Rn-4\*(n-1), где n - количество регистров в списке reglist. Доступ осуществляется в порядке уменьшения номера регистра, при этом регистр с наибольшим номером соответствует наибольшему адресу памяти, а регистр с наименьшим номером - наименьшему адресу. В случае, если в команде указан суффикс "!", значение Rn-4\*(n-1) записывается обратно в регистр Rn.

Инструкции PUSH и POP могут быть выражены через инструкции LDM и STM. Подробности см. в разделе "PUSH и POP".

# Ограничения

В описываемых в разделе командах:

- в качестве регистра Rn нельзя использовать счетчик команд PC;
- список регистров reglist не может содержать указатель стека SP:
- в любой инструкции STM в списке регистров reglist нельзя указывать PC;
- в любой инструкции LDM в reglist нельзя указывать одновременно PC и LR;
- список reglist не может содержать Rn в случае, если указан суффикс "!".

В случае, если инструкция LDM содержит в списке reglist счетчик команд PC:

- бит [0] загружаемого значения должен быть равен 1, передача управления при этом осуществляется по выровненному по границе полуслова адресу;
- если инструкция является условной, то она должна быть последней инструкцией в IT-блоке.

#### Флаги

Данная инструкция не влияет на состояние флагов.

#### Примеры

LDM R8,{R0,R2,R9} ; LDMIA – синоним LDM STMDB R1!,{R3-R6,R11,R12}

# Примеры неправильного использования

STM R5!,{R5,R4,R9} ; Сохраненное значение R5 является непредсказуемым;

LDM R2, {} ; Список должен содержать хотя бы один регистр.

# 9.3.6 PUSH u POP

Загружает или считывает регистры в стек или из стека, растущего вниз, с указателем на последний загруженный элемент (full-descending stack).

#### Синтаксис

PUSH{cond} reglist POP{cond} reglist

где:

cond – необязательный код условия, см. "Условное исполнение".

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

Команды PUSH и POP являются синонимами команд STMDB и LDM (LDMIA) в которых базовый адрес памяти содержится в регистре указателя стека SP, а режим записи обратной записи значения базового регистра включен.

Мнемокоды PUSH и POP являются предпочтительными вариантами записи.

#### Описание

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

POP – восстанавливает значения регистров из стека в порядке увеличения номеров регистров, при этом регистр с меньшим номеров считывается из памяти с меньшим значением адресом.

Подробности см. в разделе "LDM и STM".

# Ограничения

В данных инструкциях:

- список регистров reglist не должен содержать указатель стека SP;
- в инструкции PUSH список регистров не должен содержать счетчик команд PC;
- в инструкции POP список регистров не должен одновременно содержать регистры PC и LR.

В случае, если инструкция РОР содержит в списке reglist счетчик команд РС:

- бит [0] загружаемого значения должен быть равен 1, передача управления при этом осуществляется по выровненному по границе полуслова адресу;
- если инструкция является условной, то она должна быть последней инструкцией в IT-блоке.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

PUSH {R0,R4-R7} PUSH {R2,LR} POP {R0,R10,PC}

### 9.3.7 LDREX u STREX

Эксклюзивное чтение и запись регистров.

### Синтаксис

LDREX{cond} Rt, [Rn {, #offset}]
STREX{cond} Rd, Rt, [Rn {, #offset}]
LDREXB{cond} Rt, [Rn]
STREXB{cond} Rd, Rt, [Rn]
LDREXH{cond} Rt, [Rn]
STREXH{cond} Rt, [Rn]

где:

cond - необязательный код условия, см. "Условное исполнение".

Rd – регистр-приемник, содержащий признак успешного выполнения операции.

Rt – записываемый (считываемый) регистр.

Rn – регистр, содержащий базовый адрес памяти.

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

#### Описание

Команды LDREX, LDREXB и LDREXH позволяют загрузить соответственно слово, байт или полуслово данных из области памяти с заданным адресом.

Команды STREX, STREXB и STREXH осуществляют попытку записи соответственно слова, байта или полуслова данных в область памяти с заданным адресом.

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

В случае, если инструкция эксклюзивной записи успешно выполнила операцию, она записывает в регистр-получатель значение 0. В противном случае она возвращает 1. Запись в регистр-получатель значения 0 гарантирует, что никакие другие процессы не смогут получить доступ к данной ячейке памяти в промежутке времени между выполнением команд эксклюзивного чтения и эксклюзивной записи.

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

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

# Ограничения

В рассматриваемых командах:

- нельзя использовать счетчик команд РС;
- нельзя использовать указатель стека SP в качестве регистров Rd и Rt;
- в инструкции STREX регистр Rd должен не совпадать с регистрами Rt и Rn;

• значение смещения offset должно быть кратно 4 и лежать в диапазоне от 0 до 1020.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

MOV R1, #0x1 ; Записать в регистр R1 значение,

; соответствующее блокировке ресурса

try:

LDREX R0, [LockAddr] ; Считать значение признака блокировки

СМР R0, #0 ; ресурс свободен?

ITT EQ ; блок IT для инструкций STREXEQ и CMPEQ

STREXEQ R0, R1, [LockAddr] ; пытаемся заблокировать ресурс

CMPEQ R0, #0 ; получилось?

BNE try ; нет – попробовать еще раз ; да – мы заблокировали ресурс.

# 9.3.8 CLREX

Сброс эксклюзивного доступа.

# Синтаксис

CLREX{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

# Описание

Инструкция CLREX заставляет процессор при выполнении очередной команды STREX, STREXB или STREXH не выполнять операцию записи и вернуть 1 как признак отказа.

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

## Флаги

Данная инструкция не влияет на состояние флагов.

### Примеры

**CLREX** 

# 9.4 Инструкции обработки данных

Таблица 9-8 представляет инструкции обработки данных.

# Таблица 9-8 - Команды обработки данных

| Мнемокод | Краткое описание                                                                                                     | Прим. |
|----------|----------------------------------------------------------------------------------------------------------------------|-------|
| ADC      | Сложение с учетом переноса                                                                                           |       |
| ADD      | Сложение                                                                                                             |       |
| ADDW     | Сложение                                                                                                             |       |
| AND      | Логическое И                                                                                                         |       |
| ASR      | Арифметический сдвиг вправо                                                                                          |       |
| BIC      | Сброс бит по маске                                                                                                   |       |
| CLZ      | Определить количество ведущих нулей                                                                                  |       |
| CMN      | Сравнить с противоположным знаком                                                                                    |       |
| CMP      | Сравнить                                                                                                             |       |
| EOR      | Исключающее ИЛИ                                                                                                      |       |
| LSL      | Логический сдвиг влево                                                                                               |       |
| LSR      | Логический сдвиг вправо                                                                                              |       |
| MOV      | Загрузка                                                                                                             |       |
| MOVT     | Загрузка в старшее полуслово                                                                                         |       |
| MOVW     | Загрузка 16-битной константы                                                                                         |       |
| MVN      | Загрузка инверсного значения                                                                                         |       |
| ORN      | Логическое ИЛИ-НЕ                                                                                                    |       |
| ORR      | Логическое ИЛИ                                                                                                       |       |
| RBIT     | Обратить порядок бит                                                                                                 |       |
| REV      | Изменить на обратный порядок байтов в слове                                                                          |       |
| REV16    | Изменить на обратный порядок байтов в полусловах                                                                     |       |
| REVSH    | Изменить на обратный порядок байт в младшем полуслове, произвести распространение знакового бита в старшее полуслово |       |
| ROR      | Циклический сдвиг вправо                                                                                             |       |
| RRX      | Циклический сдвиг вправо на один бит с учетом переноса                                                               |       |
| RSB      | Вычитание с противоположным порядком аргументов                                                                      |       |
| SBC      | Вычитание с учетом переноса                                                                                          |       |
| SUB      | Вычитание                                                                                                            |       |
| SUBW     | Вычитание                                                                                                            |       |
| TEQ      | Проверка равенства                                                                                                   |       |
| TST      | Проверка значения бит по маске                                                                                       |       |

# 9.4.1 ADD, ADC, SUB, SBC u RSB

Сложение, сложение с переносом, вычитание, вычитание с переносом, вычитание с противоположным порядком аргументов.

# Синтаксис

op{S}{cond} {Rd,} Rn, Operand2 op{cond} {Rd,} Rn, #imm12 ; только для команд ADD и SUB.

где:

ор – один из кодов операции:

- ADD сложение;
- ADC сложение с учетом переноса;
- SUB вычитание;
- SBC вычитание с учетом переноса;
- RSB вычитание с противоположным порядком аргументов;
- необязательный суффикс. Если он указан, результат выполнения операции приводит к установке соответствующих флагов, см. "Условное исполнение".
- cond необязательный суффикс условного исполнения, см. "Условное исполнение".
- Rd регистр-получатель результата. В случае, если регистр Rd не указан, результат записывается в Rn.
- Rn регистр, содержащий значение первого операнда.

Operand2 – второй операнд. См. "Формат второго операнда".

imm12 – любое число в диапазоне от 0 до 4095.

#### Описание

Команда ADD складывает значение Operand2 или imm12 со значением регистра Rn.

Команда ADC складывает вместе значения Rn и Operand2, а также флага переноса.

Команда SUB вычитает значение Operand2 или imm12 из значения регистра Rn.

Команда SBC вычитает значение Operand2 из значения регистра Rn. Если флаг переноса не установлен, результат дополнительно уменьшается на единицу.

Команда RSB вычитает значение регистра Rn из значения Operand2. Этот вариант команды полезен, так как существует широкий выбор вариантов построения Operand2.

Инструкции ADC и SBC полезны при реализации вычислений с повышенной разрядностью, см. "Арифметика с повышенной разрядностью".

См. также описание команды ADR.

Команда ADDW эквивалентна команде ADD, однако использует 12-разрядный непосредственный операнд imm12. Команда SUBW эквивалентна команде SUB, однако использует 12-разрядный непосредственный операнд imm12.

# Ограничения

Для рассматриваемых инструкций:

- в качестве Operand2 нельзя использовать SP или PC;
- использовать SP в качестве регистра Rd допустимо только в командах ADD и SUB, со следующими дополнительными ограничениями:
  - в качестве Rn также должен использоваться SP;
  - сдвиг в Operand2 должен быть не более 3 бит в режиме LSL;
- указатель стека SP может использоваться в качестве Rn только в командах ADD и SUB;
- счетчик команд PC может использоваться в качестве Rd только в команде:
  - ADD{cond} PC, PC, Rm
  - причем:
  - не допускается использование суффикса S;
  - в качестве Rm не допускается использовать PC и SP;

- если инструкция условная, то она должна быть последней в IT-блоке.
- в качестве регистра Rn можно использовать счетчик команд PC только в инструкциях ADD и SUB (за исключением команды ADD(cond) PC, PC, Rm) с дополнительными ограничениями:
  - не допускается использование суффикса S;
  - второй операнд должен находится в интервале от 0 до 4095.
  - при использовании РС в операциях сложения или вычитания биты [1:0] счетчика команд округляются до 0b00 перед выполнением операции, обеспечивая выравнивание адреса по границе слова;
  - при необходимости сформировать адрес инструкции, необходимо скорректировать значение смещения относительно РС. Рекомендуется использовать вместо этого инструкцию ADR, так как в этом случае ассемблер автоматически сгенерирует правильное смещение;
  - в случае, если РС используется в качестве Rd в команде ADD{cond} PC, PC, Rm бит[0] значения, записываемого в PC, будет проигнорирован, передача управления будет осуществляться по адресу, соответствующему нулевому значению этого бита.

### Флаги

В случае, если в команде указан суффикс S, процессор устанавливает флаги N, Z, C и V в соответствии с результатом выполнения операции.

# Примеры

ADD R2, R1, R3

SUBS R8, R6, #240 ; установить флаги по результату операции вычитания

RSB R4, R4, #1280 ; вычесть содержимое регистра R4 из 1280

ADCHI R11, R0, R3 ; операция выполняется только в случае, если флаг

; С установлен, а флаг Z сброшен

# Арифметика с повышенной разрядностью

# 64-разрядное сложение

Следующий пример показывает, как осуществить сложение 64-разрядного целого числа, записанного в паре регистров R2 и R3, с другим 64-разрядным числом, записанным в паре регистров R0 и R1, после чего записывает результат в пару регистров R4 и R5.

ADDS R4, R0, R2; сложить младшие значащие слова

ADC R5, R1, R3 ; сложить старшие значащие слова с учетом переноса

# 96-разрядное вычитание

Данные с повышенной разрядностью не обязательно содержать в смежных регистрах. В примере, приведенном ниже, показан фрагмент кода, осуществляющий вычитание 96-разрядного целого числа, записанного в регистрах R9, R1 и R11, из другого числа, содержащегося в R6, R2 и R8. Результат записывается в регистрах R6, R9 и R2.

SUBS R6, R6, R9; вычитание младших значащих слов

SBCS R9, R2, R1; вычитание средних значащих слов с переносом SBC R2, R8, R11; вычитание старших значащих слов с переносом.

# 9.4.2 AND, ORR, EOR, BIC u ORN

Логические операции: И, ИЛИ, Исключающее ИЛИ, сброс бит по маске, ИЛИ-НЕ.

### Синтаксис

op{S}{cond}{Rd,} Rn, Operand2

где:

- ор один из кодов операции:
  - AND логическое И.
  - ORR логическое ИЛИ.
  - EOR логическое Исключающее ИЛИ.
  - BIC сброс бит по маске.
  - ORN логическое ИЛИ-НЕ.
- необязательный суффикс. Если он указан, результат выполнения операции приводит к установке соответствующих флагов, см. "Условное исполнение".
- cond необязательный суффикс условного исполнения, см. "Условное исполнение".
- Rd регистр-получатель результата.
- Rn регистр, содержащий значение первого операнда.

Operand2 – второй операнд, см. "Формат второго операнда".

#### Описание

Инструкции AND, ORR и EOR осуществляют, соответственно, логические операции И, ИЛИ и исключающего ИЛИ между первым операндом, содержащимся в регистре Rn, и вторым операндом Operand2.

Инструкция BIC выполняет операцию логического И между первым операндом, содержащимся в регистре Rn, и инверсным значением второго операнда Operand2.

Инструкция ORN выполняет операцию логического ИЛИ между первым операндом Rn и инверсным значением второго операнда Operand2

### Ограничения

Не допускается использованием указателя стека SP и счетчика команд PC.

# Флаги

В случае, если в команде указан суффикс S, процессор:

- устанавливает флаги N и Z в соответствии с результатом выполнения операции;
- может изменить флаг С в ходе вычисления значения второго операнда, см. "Формат второго операнда";
- не влияет на значение флага V.

# Примеры

AND R9, R2,#0xFF00 ORREQ R2, R0,R5 ANDS R9, R8, #0x19 EORS R7, R11, #0x18181818 BIC R0, R1, #0xab ORN R7, R11, R14, ROR #4 ORNS R7, R11, R14, ASR #32

# 9.4.3 ASR, LSL, LSR, ROR u RRX

Арифметический сдвиг вправо, логический сдвиг влево, логический сдвиг вправо, циклический сдвиг вправо и циклический сдвиг вправо с переносом.

#### Синтаксис

op{S}{cond} Rd, Rm, Rs op{S}{cond} Rd, Rm, #n RRX{S}{cond} Rd, Rm

где:

- ор один из кодов операции:
  - ASR арифметический сдвиг вправо;
  - LSL логический сдвиг влево;
  - LSR логический сдвиг вправо;
  - ROR циклический сдвиг вправо.
- S необязательный суффикс. Если он указан, результат выполнения операции приводит к установке соответствующих флагов, см. "Условное исполнение".
- cond необязательный суффикс условного исполнения, см. "Условное исполнение".
- Rd регистр-получатель результата.
- Rm регистр, значение которого должно быть подвергнуто сдвигу.
- Rs регистр, содержащий параметр сдвига. Процессор анализирует только младший значащий байт регистра, таким образом, параметр сдвига может принимать значения от 0 до 255.
- n параметр сдвига. Диапазон допустимых значений параметра зависит от инструкции:
  - ASR от 1 до 32;
  - LSL от 0 до 31;
  - LSR от 1 до 32;
  - ROR от 1 до 31.

# Команду

LSL{S}{cond} Rd, Rm, #0 рекомендуется записывать в формате MOV{S}{cond} Rd, Rm.

#### Описание

Команда ASR, LSL, LSR и ROR сдвигает биты регистра Rm влево или вправо на заданное количество позиций, определяемое константой n или содержимым регистра Rs.

Команда RRX осуществляет сдвиг Rm вправо на одну позицию с учетом переноса.

Во всех указанных инструкциях результат записывается в регистр Rd, при этом содержание регистра Rm остается неизменным. Детальное описание операций сдвига представлено в разделе "Операции сдвига".

### Ограничения

Не допускается использованием указателя стека SP и счетчика команд PC.

### Флаги

В случае, если в команде указан суффикс S, процессор:

- устанавливает флаги N и Z в соответствии с результатом выполнения операции;
- флаг С устанавливается в значение последнего сдвинутого бита, за исключением случая параметра сдвига, равного нулю. См. "Операции сдвига".

# Примеры

ASR R7, R8, #9 ; Арифметический сдвиг вправо на 9 бит

LSLS R1, R2, #3 ; Логический сдвиг влево на 3 бита с установкой флагов

LSR R4, R5, #6 ; Логический сдвиг вправо на 6 бит

ROR R4, R5, R6 ; Циклический сдвиг вправо на количество бит, указанное

; в младшем байте регистра R6

RRX R4, R5 ; Циклический сдвиг вправо через бит переноса.

### 9.4.4 *CLZ*

Определить количество ведущих нулей.

### Синтаксис

CLZ{cond} Rd, Rm

где:

cond - необязательный суффикс условного исполнения, см. "Условное исполнение".

Rd - регистр-получатель результата.

Rm - регистр операнда.

### Описание

Инструкция CLZ выполняет подсчет количества ведущих нулей в двоичной записи значения, записанного в регистре Rm, и возвращает результат в регистр Rd. Результат, равный 32, возвращается в случае, если в регистре Rm нет установленных бит, а результат, равный 0 - в случае, если установлен только бит [31].

# Ограничения

Не допускается использование указателя стека SP и счетчика команд PC.

## Флаги

Данная инструкция не влияет на состояние флагов.

### Примеры

CLZ R4,R9 CLZNE R2,R3.

### 9.4.5 CMP u CMN

Сравнение и сравнение с противоположным знаком.

#### Синтаксис

CMP{cond} Rn, Operand2 CMN{cond} Rn, Operand2

где:

cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

R – регистр, содержащий первый операнд.

Operand2 – второй операнд. См. "Формат второго операнда".

### Описание

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

Команда CMP вычитает из регистра Rn значение второго операнда Operand2. Она аналогична инструкции SUBS, за исключением того, что не сохраняет результат вычитания.

Команда CMN складывает значения регистра Rn и второго операнда Operand2. Она аналогична инструкции ADDS, за исключением того, что не сохраняет результат вычитания.

# Ограничения

В данных инструкциях:

- не допускается использованием РС;
- в качестве второго операнда Operand2 нельзя использовать SP.

#### Флаги

Процессор устанавливает флаги N, Z, C и V в соответствии с результатом сравнения.

# Примеры

CMP R2, R9 CMN R0, #6400 CMPGT SP, R7, LSL #2

# 9.4.6 *MOV u MVN*

Загрузка в регистр прямого или инверсного значения второго операнда.

## Синтаксис

MOV{S}{cond} Rd, Operand2 MOV{cond} Rd, #imm16 MVN{S}{cond} Rd, Operand2

где:

 - необязательный суффикс. Если он указан, результат выполнения операции приводит к установке соответствующих флагов, см. "Условное исполнение".

Cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

Rd – регистр-получатель результата.

Operand2 – второй операнд. См. "Формат второго операнда".

imm16 – любое значение в диапазоне от 0 до 65535.

### Описание

Инструкция MOV копирует значение второго операнда Operand2 в регистр Rd. В случае, если Operand2 является регистром с параметром сдвига, отличным от LSL

#0, рекомендуется использовать вместо команды MOV соответствующую команду сдвига:

- ASR{S}{cond} Rd, Rm, #n вместо MOV{S}{cond} Rd, Rm, ASR #n;
- LSL{S}{cond} Rd, Rm, #п вместо MOV{S}{cond} Rd, Rm, LSL #п при п != 0;
- LSR{S}{cond} Rd, Rm, #п вместо MOV{S}{cond} Rd, Rm, LSR #n;
- ROR{S}{cond} Rd, Rm, #п вместо MOV{S}{cond} Rd, Rm, ROR #п;
- RRX{S}{cond} Rd, Rm вместо MOV{S}{cond} Rd, Rm, RRX.

Кроме того, допускается использовать дополнительные формы построения второго операнда Operand2 в инструкции MOV как синонимы соответствующих операций сдвига:

- MOV{S}{cond} Rd, Rm, ASR Rs является синонимом ASR{S}{cond} Rd, Rm, Rs:
- MOV{S}{cond} Rd, Rm, LSL Rs является синонимом LSL{S}{cond} Rd, Rm, Rs
- MOV{S}{cond} Rd, Rm, LSR Rs является синонимом LSR{S}{cond} Rd, Rm, Rs
- MOV{S}{cond} Rd, Rm, ROR Rs является синонимом ROR{S}{cond} Rd, Rm, Rs.

См. также описание инструкций ASR, LSL, LSR, ROR и RRX.

Инструкция MVN считывает значение второго операнда Operand2, производит его побитную инверсию, после чего помещает результат в регистр Rd.

Инструкция MOVW функционирует также, как и инструкция MOV, однако в качестве второго операнда в ней можно использовать только непосредственно задаваемое значение imm16.

# Ограничения

Регистры SP и PC допускается использовать только с инструкцией MOV, при следующих ограничениях:

- второй операнд должен быть регистром без указания параметра сдвига;
- суффикс S не должен быть указан.

В случае, если в качестве Rd используется счетчик команд PC:

- бит [0] значения, загружаемого в РС, игнорируется;
- передача управления осуществляется по адресу, соответствующему загруженному значению с битом [0], принудительно установленным в 0.

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

### Флаги

В случае, если в команде указан суффикс S, процессор:

- устанавливает флаги N и Z в соответствии с результатом выполнения операции;
- может изменить флаг С в ходе вычисления значения второго операнда, см. "Формат второго операнда";
- не влияет на значение флага V.

# Примеры

MOVS R11, #0x000B ;Записать значение 0x000B в R11, флаги устанавливаются MOV R1, #0xFA05 ; Записать значение 0xFA05 в R1, флаги не устанавливаются

MOVS R10, R12 ; Записать регистр R12 в R10, флаги устанавливаются

MOV R3, #23 ; Записать значение 23 в R3

MOV R8, SP ; Записать значение указателя стека в регистр R8

MVNS R2, #0xF ; Записать значение 0xFFFFFF0 (инверсия значения 0x0F)

; в регистр R2, установить флаги.

### 9.4.7 *MOVT*

Записать в старшее полуслово регистра.

#### Синтаксис

MOVT(cond) Rd, #imm16

где:

cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

Rd – регистр-получатель результата.

imm16- любое значение в диапазоне от 0 до 65535.

#### Описание

Инструкция MOVT записывает 16-разрядное непосредственное значение imm16 в старшее полуслово регистра-приемника Rd[31:16]. Младшее полуслово Rd[15:0] остается неизменным.

Комбинация команд MOV и MOVT позволяет загрузить в регистр любую 32-битную константу.

# Ограничения

В качестве Rd нельзя использовать указатель стека SP и счетчик команд PC.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

MOVT R3, #0xF123 ; Загрузить 0xF123 в старшее полуслово R3, младшее

; полуслово и регистр состояния APSR остаются неизменными

# 9.4.8 REV, REV16, REVSH u RBIT

Изменение порядка бит или байтов в слове.

#### Синтаксис

op{cond} Rd, Rn

где:

ор – один из кодов операции:

- REV изменить на обратный порядок байтов в слове;
- REV16 изменить на обратный порядок байтов в полусловах;
- REVSH изменить на обратный порядок байт в младшем полуслове, произвести распространение знакового бита в старшее полуслово.
- RBIT изменить порядок бит в 32-разрядном слове.

cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

Rd – регистр-получатель результата.

Rn – регистр, содержащий операнд.

### Описание

Инструкции предназначены для изменения формата представления (endianness) данных:

- REV преобразует 32-разрядное число в формате big-endian в число в формате little-endian и наоборот.
- REV16 преобразует 32-разрядное число в формате big-endian в число в формате little-endian и наоборот.
- REVSH выполняет одно из следующих преобразований:
  - 16-разрядное число со знаком в формате big-endian в 32-разрядное число со знаком в формате little-endian;
  - 16-разрядное число со знаком в формате little-endian в 32-bit 32разрядное число со знаком в формате big-endian.
- RBIT изменяет на обратный порядок бит в 32-разрядном слове.

# Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

REV R3, R7 ; Обратить порядок следования байтов в R7, записать в R3 REV16 R0, R0 ; Обратить порядок байтов в каждом 16-битном полуслове R0

REVSH R0, R5 ; Обратить полуслово со знаком

REVHS R3, R7 ; Обратить порядок при условии "больше или равно" (HS) RBIT R7, R8 ; Обратить порядок бит в R8, записать результат в R7

## 9.4.9 *TST u TEQ*

Проверить значение бит по маске, проверить равенство.

### Синтаксис

TST{cond} Rn, Operand2 TEQ{cond} Rn, Operand2

где:

cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

Rn – регистр, содержащий первый операнд.

Operand2 – второй операнд. См. "Формат второго операнда".

### Описание

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

Команда TST выполняет побитную операцию логического И между значениями Rn и Operand2. Она совпадает с инструкцией ANDS, за исключением того, что не сохраняет результат. Для того, чтобы проверить, что заданный бит регистра Rn

равен 0 или 1, рекомендуется использовать команду TST со вторым операндом Operand2 в виде константы, в которой соответствующий бит равен 1, а все остальные - равны 0.

Команда TEQ выполняет побитную операцию Исключающее ИЛИ между значениями Rn и Operand2. Она совпадает с инструкцией EORS, за исключением того, что не сохраняет результат. Команда TEQ позволяет проверить равенство двух величин, не меняя значения флагов V и C. Кроме того, эта инструкция полезна для проверки знака числа. После сравнения флаг N является результатом операции Исключающее ИЛИ знаковых разрядов двух операндов.

# Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

#### Флаги

В случае, если в команде указан суффикс S, процессор:

- устанавливает флаги N и Z в соответствии с результатом выполнения операции;
- может изменить флаг С в ходе вычисления значения второго операнда, см. "Формат второго операнда";
- не влияет на значение флага V.

# Примеры

TST R0, #0x3F8 ; Побитное И между R0 и числом 0x3F8,

; устанавливаются флаги, результат не сохраняется

TEQEQ R10, R9 ; Условное исполнение проверки равенства регистров R10

; и R9, устанавливаются флаги, результат не сохраняется.

# 9.5 Инструкции умножения и деления

В следующей таблице представлена информация о командах умножения и деления.

Таблица 9-9 - Инструкции умножения и деления

| Мнемокод | Краткое описание                                        |
|----------|---------------------------------------------------------|
| MLA      | Умножение и сложение, 32-битный результат               |
| MLS      | Умножение и вычитание, 32-битный результат              |
| MUL      | Умножение, 32-разрядный результат                       |
| SDIV     | Деление чисел со знаком                                 |
| SMLAL    | Умножение чисел со знаком с накоплением (32 х 32 + 64), |
|          | 64-битный результат                                     |
| SMULL    | Умножение чисел со знаком, 64-битный результат          |
| UDIV     | Деление чисел без знака                                 |
| UMLAL    | Умножение чисел без знака с накоплением (32 x 32 + 64), |
|          | 64-битный результат                                     |
| UMULL    | Умножение чисел без знака, 64-битный результат          |

# 9.5.1 *MUL, MLA u MLS*

Умножение или умножение с накоплением (сложением, вычитанием) с использованием 32-разрядных операндов и выдающее 32-разрядный результат.

### Синтаксис

MUL{S}{cond} {Rd,} Rn, Rm ; Умножение

MLA{cond} Rd, Rn, Rm, Ra ; Умножение и сложение MLS{cond} Rd, Rn, Rm, Ra ; Умножение и вычитание

где:

 - необязательный суффикс. Если он указан, результат выполнения операции приводит к установке соответствующих флагов, см. "Условное исполнение".

cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

Rd – регистр-получатель результата. Если регистр Rd не указан, то в качестве получателя используется регистр Rn.

Rn, Rm – регистры, содержащий значения первого и второго сомножителей.

Ra – регистр, содержащий значение, к которому должно быть прибавлено или вычтено произведение.

# Описание

Команда MUL выполняет перемножение значений, содержащихся в регистрах Rn и Rm, после чего сохраняет 32 младших значащих бита произведения в Rd.

Команда MLA перемножает содержимое регистров Rn и Rm, прибавляет к произведению значение Ra, после чего сохраняет 32 младших значащих бита результата в Rd.

Команда MLS перемножает содержимое регистров Rn и Rm, вычитает произведение из регистра Ra, после чего сохраняет 32 младших значащих бита результата в Rd.

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

### Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

В случае, если инструкция MUL используется с суффиксом установки флагов S:

- регистры Rd, Rn и Rm должны находиться в диапазоне от R0 до R7;
- регистр Rd должен совпадать с Rm;
- не допускается использование суффикса условного исполнения cond.

#### Флаги

В случае, если в команде указан суффикс S, процессор:

- устанавливает флаги N и Z в соответствии с результатом выполнения операции;
- не влияет на значение флагов С и V.

### Примеры

MUL R10, R2, R5 ; R10 = R2 x R5

MLA R10, R2, R1, R5 ; R10 =  $(R2 \times R1) + R5$ 

MULS R0, R2, R2 ; R0 = R2 x R2, установить флаги MULLT R2, R3, R2 ; условное исполнение R2 = R3 x R2

MLS R4, R5, R6, R7 ; R4 = R7 - (R5 x R6)

# 9.5.2 UMULL, UMLAL, SMULL u SMLAL

Умножение чисел со знаком или без знака, с возможностью накопления, 32-битные операнды, 64-битный результат.

### Синтаксис

op{cond} RdLo, RdHi, Rn, Rm

где:

ор – один из кодов операции:

- UMULL умножение чисел без знака.
- UMLAL умножение чисел без знака с накоплением.
- SMULL умножение чисел со знаком.
- SMLAL умножение чисел со знаком с накоплением.

Cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

RdLo, RdHi — регистры-получатели младшей и старшей частей результата, соответственно. Для инструкций UMLAL и SMLAL они также содержат накапливаемое значение.

Rn, Rm — регистры, содержащие значения первого и второго сомножителей.

#### Описание

Инструкция UMULL перемножает значения регистров Rn и Rm, интерпретируя их как целые числа без знака. Результат умножения размещается в паре регистров RdHi (старшие 32 бита) и RdLo (младшие 32 бита).

Инструкция UMLAL перемножает значения регистров Rn и Rm, интерпретируя их как целые числа без знака. Результат прибавляется к 64-разрядному целому числу без знака, записанному в паре регистров RdHi и RdLo, после чего сохраняется обратно в паре регистров RdHi и RdLo.

Инструкция SMULL перемножает значения регистров Rn и Rm, интерпретируя их как целые числа со знаком, записанные в дополнительном коде. Результат умножения размещается в паре регистров RdHi (старшие 32 бита) и RdLo (младшие 32 бита).

Инструкция SMLAL перемножает значения регистров Rn и Rm, интерпретируя их как целые числа со знаком, записанные в дополнительном коде. Результат прибавляется к 64-разрядному целому числу со знаком, записанному в паре регистров RdHi и RdLo, после чего сохраняется обратно в паре регистров RdHi и RdLo.

### Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC. Пара регистров RdHi и RdLo должна состоять из разных регистров.

### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

UMULL R0, R4, R5, R6 ; Беззнаковое умножение (R4,R0) = R5 x R6 SMLAL R4, R5, R3, R8 ; Операция со знаком (R5,R4) = (R5,R4) + R3 x R8

#### 9.5.3 SDIV u UDIV

Деление чисел со знаком или без знака.

#### Синтаксис

SDIV{cond} {Rd,} Rn, Rm UDIV{cond} {Rd,} Rn, Rm

где:

- cond необязательный суффикс условного исполнения, см. "Условное исполнение".
- Rd регистр-получатель результата. Если Rd не указан, результат сохраняется в Rn.
- Rn регистр, содержащий значение делимого.
- Rm регистр, содержащий значение делителя.

### Описание

Команда SDIV осуществляет деление целого числа со знаком, содержащегося в регистре Rn, на целое число со знаком, содержащееся в регистре Rm.

Команда UDIV осуществляет деление целого числа без знака, содержащегося в регистре Rn, на целое число без знака, содержащееся в регистре Rm.

В случае, если число в Rn не делится нацело на число в Rm, результат округляется в сторону нуля.

# Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

SDIV R0, R2, R4 ; Деление чисел со знаком, R0 = R2/R4 UDIV R8, R8, R1 ; Деление чисел без знака, R8 = R8/R1.

# 9.6 Инструкции преобразования данных с насыщением

В разделе рассмотрены инструкции преобразования данных с насыщением SSAT и USAT.

### 9.6.1 SSAT u USAT

Преобразование 32-разрядного числа в n-разрядное со знаком или без знака с насыщением.

### Синтаксис

op{cond} Rd, #n, Rm {, shift #s}

где:

ор – один из кодов операции:

- SSAT преобразует число со знаком в число со знаком, лежащее в заданном диапазоне значений, с насыщением.
- USAT преобразует число со знаком в число без знака, лежащее в заданном диапазоне значений, с насыщением.
- Cond необязательный суффикс условного исполнения, см. "Условное исполнение".
- Rd регистр-получатель результата.
- Rm регистр, содержащий преобразуемое значение.
- N определяет разрядность данных после преобразования с насыщением:
  - п находится в диапазоне от 1 до 32 для инструкции SSAT
  - п находится в диапазоне от 0 до 31 для инструкции USAT.

shift #s – необязательный параметр сдвига, применяемый к регистру Rm перед преобразованием с насыщением. Он может принимать следующие значения:

- ASR #s, где s находится в диапазоне от 1 до 31;
- LSL #s, где s находится в диапазоне от 0 до 31.

#### Описание

Инструкции преобразуют 32-разрядное число в n-разрядное число со знаком или без знака. Преобразование осуществляется с насыщением.

Команда SSAT подвергает операнд заданной операции сдвига, после чего приводит его к диапазону значений -2<sup>(n-1)</sup>≤х≤2<sup>(n-1)</sup>-1 в соответствии со следующими правилами:

- если значение после сдвига меньше -2<sup>(n-1)</sup>, сохраняется результат -2<sup>(n-1)</sup>;
- если значение после сдвига больше  $2^{(n-1)}$ -1, сохраняется результат  $2^{(n-1)}$ -1;
- в противном случае, результат сохраняется без изменений.

Команда USAT подвергает операнд заданной операции сдвига, после чего приводит его к диапазону значений 0≤х≤2<sup>n</sup>-1 в соответствии со следующими правилами:

- если значение после сдвига меньше 0, сохраняется результат 0;
- если значение после сдвига больше 2<sup>n</sup>-1, сохраняется результат 2<sup>n</sup>-1;
- в противном случае, результат сохраняется без изменений.

В случае если значение операнда после сдвига отличается от сохраненного результата, возникает ситуация, называемая насыщением, при этом процессор устанавливает в слове состояния приложения APSR флаг Q в 1. В случае если в ходе преобразования данных насыщения не возникло, флаг Q сохраняет свое прежнее значение.

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

Проверить состояние флага Q можно с помощью команды MRS.

### Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

#### Флаги

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

# Примеры

SSAT R7, #16, R7, LSL #4 ; Логический сдвиг R7 влево на 4 бита, далее

; приведение его к 16-разрядному числу со знаком

; с насыщением, сохранить результат в R7

USATNE R0, #7, R5 ; Условная операция: преобразовать с насыщением

; значение R5 к семиразрядному числу без знака,

; сохранить результат в R0/

# 9.7 Команды работы с битовыми полями

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

Таблица 9–10 – Инструкции упаковки и распаковки данных

| Мнемокод команд | Краткое описание                                                     |  |
|-----------------|----------------------------------------------------------------------|--|
| BFC             | Запись нуля в битовое поле                                           |  |
| BFI             | Запись заданного значения битового поля                              |  |
| SBFX            | Чтение значения битового поля, интерпретируемого как число со знаком |  |
| SXTB            | Преобразовать байт со знаком в слово                                 |  |
| SXTH            | Преобразовать полуслово со знаком в слово                            |  |
| UBFX            | Чтение значения битового поля, интерпретируемого как число без знака |  |
| UXTB            | Преобразовать байт без знака в слово                                 |  |
| UXTH            | Преобразовать полуслово без знака в слово                            |  |

## 9.7.1 *BFC u BFI*

Сброс в ноль и запись заданного значения битового поля.

## Синтаксис

BFC{cond} Rd, #lsb, #width BFI{cond} Rd, Rn, #lsb, #width

где:

cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

Rd – регистр-получатель результата.

Rm – регистр-источник данных.

Lsb — позиция младшего значащего разряда битового поля. Значение lsb должно находиться в интервале от 0 до 31.

Width – ширина битового поля, значение которой должно находиться в интервале от 1 до 32-lsb.

### Описание

Инструкция BFC очищает битовое поле, размещенное в регистре Rd, имеющее длину width бит и расположенное, начиная с бита с номером lsb. Остальные биты регистра Rd сохраняются без изменений.

Инструкция BFI копирует битовое поле шириной в width бит, расположенное в регистре Rn, начиная с позиции 0, в битовое поле шириной в width бит, расположенное в регистре Rd, начиная с позиции lsb. Остальные биты регистра Rd сохраняются без изменений.

# Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

BFC R4, #8, #12 BFI R9, R2, #8, #12 ; Очистить 12-битовое поле, расположенное с 8-го по 19-й бит R4.

; Записать в 12-битовое поле, расположенное с 8-го по 19-й бит R9.

; значение из 12-битового поля, расположенного с 0-го по 11-й бит.

; регистра R2.

### 9.7.2 SBFX u UBFX

Чтение значения битового поля, интерпретируемого как число со знаком или без знака.

#### Синтаксис

SBFX{cond} Rd, Rn, #lsb, #width UBFX{cond} Rd, Rn, #lsb, #width

где:

cond – необязательный суффикс условного исполнения, см. "Условное исполнение".

Rd – регистр-получатель результата.

Rn – регистр-источник данных.

Lsb — позиция младшего значащего разряда битового поля. Значение lsb должно находиться в интервале от 0 до 31.

Width – ширина битового поля, значение которой должно находиться в интервале от 1 до 32-lsb.

### Описание

Инструкция SBFX считывает значение битового поля из регистра-источника, производит распространение знакового бита в старшие биты 32-разрядного слова, сохраняет результат в регистр-получатель.

Инструкция UBFX считывает значение битового поля из регистра-источника, заполняет нулями старшие биты 32-разрядного слова, сохраняет результат в регистрполучатель.

### Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

# Флаги

Данная инструкция не влияет на состояние флагов.

### Примеры

SBFX R0, R1, #20, #4 ; Извлечь 4 бита (с 20 по 23) из R1, интерпретируя их

; как число со знаком, записать в R0

UBFX R8, R11, #9, #10 ; Извлечь 10 бит (с 9 по 18) из R11, интерпретируя их

; как число без знака, записать в R8.

# 9.7.3 SXT u UXT

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

### Синтаксис

SXTextend{cond} {Rd,} Rm {, ROR #n} UXTextend{cond} {Rd}, Rm {, ROR #n}

где:

Суффикс *extend* может принимать одно из следующих значений:

- В преобразование 8-битного числа в 32-битное;
- Н преобразование 16-битного числа в 32-битное.

Cond – необязательный суффикс условного исполнения, см. "Условное

исполнение".

Rd – регистр-получатель результата.

Rm – регистр-источник данных.

ROR #n - параметр сдвига, который может принимать одно из значений:

- ROR #8 значение в Rm циклически сдвигается вправо на 8 бит;
- ROR #16 значение в Rm циклически сдвигается вправо на 16 бит;
- ROR #24 значение в Rm циклически сдвигается вправо на 24 бит;
- если параметр не указан, сдвиг не производится.

### Описание

Команда SXTB осуществляет циклический сдвиг содержимого регистра Rm вправо на заданное число бит, извлекает из результата младшие восемь бит [7:0], преобразует их в 32-разрядное число со знаком путем копирования знакового разряда [7] в биты [31:8], сохраняет результат в регистре Rd.

Команда UXTB осуществляет циклический сдвиг содержимого регистра Rm вправо на заданное число бит, извлекает из результата младшие восемь бит [7:0], преобразует их в 32-разрядное число без знака путем копирования нуля в биты [31:8], сохраняет результат в регистре Rd.

Команда SXTH осуществляет циклический сдвиг содержимого регистра Rm вправо на заданное число бит, извлекает из результата младшие восемь бит [15:0], преобразует их в 32-разрядное число со знаком путем копирования знакового разряда [15] в биты [31:16], сохраняет результат в регистре Rd.

Команда UXTH осуществляет циклический сдвиг содержимого регистра Rm вправо на заданное число бит, извлекает из результата младшие восемь бит [15:0], преобразует их в 32-разрядное число без знака путем копирования нуля в биты [31:16], сохраняет результат в регистре Rd.

# Ограничения

Нельзя использовать указатель стека SP и счетчик команд PC.

## Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

SXTH R4, R6, ROR #16; сдвинуть R6 вправо на 16 бит, извлечь из результата

; младшее полуслово, преобразовать в 32-разрядное

; число с распространением знака, записать в R4.

UXTB R3, R10 ; извлечь младший байт из R10, преобразовать в 32-

разрядное число,

; старшие байты заполнить нулями, записать результат в R3.

# 9.8 Инструкции передачи управления

В таблице ниже представлен список инструкций передачи управления.

# Таблица 9-11 - Инструкции передачи управления

| Мнемокод команды | Краткое описание                           |  |
|------------------|--------------------------------------------|--|
| В                | Переход                                    |  |
| BL               | Переход со связью                          |  |
| BLX              | Косвенный переход со связью                |  |
| BX               | Косвенный переход                          |  |
| CBNZ             | Сравнение с нулем и переход по неравенству |  |

| CBZ | Сравнение с нулем и переход по равенству           |
|-----|----------------------------------------------------|
| CBZ | роравнение с нулем и переход по равенству          |
| IT  | Начало блока условно исполняемых инструкций        |
| TBB | Табличный переход по индексу, смещения – байты     |
| TBH | Табличный переход по индексу, смещения – полуслова |

# 9.8.1 B, BL, BX u BLX

Команды ветвления.

#### Синтаксис

B{cond} label

BL{cond} label

BX{cond} Rm

BLX{cond} Rm

где:

В – переход по непосредственно заданному адресу;

BL – переход со связью по непосредственно заданному адресу;

ВХ – косвенный переход по адресу, заданному значением регистра;

BLX – косвенный переход со связью.

Cond – необязательный код условия, см. "Условное исполнение".

Label – относительный адрес, см. "LDR, адресация относительно счетчика команд PC".

Rm – регистр, содержащий адрес, на который необходимо передать управления. Бит [0] этого регистра должен быть установлен в 1, однако передача управления будет выполнена по адресу, соответствующему нулевому значению бита [0].

## Описание

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

- команды BL и BLX записывают адрес следующей инструкции в регистр связи LR (R14);
- команды BX и BLX формируют отказ (usage fault) в случае, если bit[0] регистра Rm равен 0.

Инструкция вида В cond label - это единственный тип команды, который может находится за пределами IT-блока. Все остальные условно исполняемые инструкции передачи управления должны располагаться внутри IT-блока, а за пределами этого блока должны использоваться только в безусловной форме. Подробности см. в разделе "IT".

Ниже (Таблица 9–12) представлен диапазон адресуемых переходов для различных команд ветвления. Для достижения максимального диапазона может потребоваться указать суффикс .W размера инструкции. Подробности см. в разделе "Выбор размера кода инструкции".

Таблица 9–12 – Диапазон адресуемых переходов для команд ветвления

| Инструкция                     | Диапазон адресации                                     |
|--------------------------------|--------------------------------------------------------|
| B label                        | от -16 Мбайт до +16 Мбайт относительно текущей позиции |
| B cond label (вне IT-блока)    | от -1 Мбайт до +1 Мбайт относительно текущей позиции   |
| B cond label (внутри IT-блока) | от -16 Мбайт до +16 Мбайт относительно текущей позиции |
| BL{cond} label                 | от -16 Мбайт до +16 Мбайт относительно текущей позиции |

| BX{cond} Rm  | любое значение, записанное в регистре |
|--------------|---------------------------------------|
| BLX{cond} Rm | любое значение, записанное в регистре |

# Ограничения

- в команде BLX не допускается использование регистра PC;
- в командах ВХ и ВLХ, бит [0] регистра Rm должен быть установлен в 1, при этом передача управления будет, тем не менее, осуществлена по адресу, соответствующему нулевому значению бита [0];
- внутри IT-блока любая из инструкций ветвления должна располагаться последней.
- В cond единственная условно исполняемая команда, которую допустимо использовать за пределами ІТ-блока. Тем не менее, внутри ІТ-блока она обеспечивает более широкий диапазон адресуемых переходов.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

В loopA ; передача управления на метку loopA

BLE ng ; условная передача управления на метку ng

B.W target ; переход на метку target, расположенную в пределах |+/- 16Мбайт

BEQ target ; условный переход на метку target

BEQ.W target ; условный переход на метку target в пределах |+/- 1 Мбайт

BL funC ; переход со связью (вызов функции) funC, адрес возврата будет

; записан в регистре LR

BX LR ; возврат из функции

BXNE R0 ; условный переход по адресу, записанному в R0

BLX R0 ; переход со связью (вызов функции) по адресу, записанному в R0.

### 9.8.2 CBZ u CBNZ

Сравнение и условная передача управления, по равенству или неравенству нулю.

## Синтаксис

CBZ Rn, label CBNZ Rn, label

где:

Rn – регистр, содержащий операнд.

label – метка, на которую должен быть осуществлен переход.

## Описание

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

Команда CBZ Rn, label не влияет на флаги, а в остальном эквивалентна следующей последовательности инструкций:

CMP Rn, #0

BEQ label

Команда CBNZ Rn, label не влияет на флаги, а в остальном эквивалентна следующей последовательности инструкций:

CMP Rn, #0 BNE label

# Ограничения

- в качестве Rn допустимо использовать регистры с R0 по R7;
- адрес перехода должен быть расположен после инструкции на расстоянии от 4 до 130 байт;
- данные команды нельзя использовать внутри ІТ-блока.

## Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

CBZ R5, target ; Условный переход вперед при R5 = 0 CBNZ R0, target ; Условный переход вперед при R0! = 0.

# 9.8.3 *IT*

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

### Синтаксис

 $IT{x{y{z}}} cond$ 

где:

х определяет выбор условия для второй инструкции в IT-блоке; у определяет выбор условия для третьей инструкции в IT-блоке; z определяет выбор условия для четвертой инструкции в IT-блоке; cond определяет условие для первой инструкции в IT-блоке.

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

- T Then. Инструкция выполняется, если условие cond истинно;
- E Else. Инструкция выполняется, если условие cond ложно.

Существует возможность использовать в IT-блоке на месте cond условие AL (всегда истинное). В этом случае все инструкции в IT-блоке должны быть безусловными, а суффиксы выбора условия x, y и z должны быть равны T, либо опущены.

#### Описание

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

Мнемокоды команд внутри IT-блока, в том числе и команд ветвления, должны включать в себя суффикс условного исполнения {cond}.

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

Команда ВКРТ внутри IT-блока всегда выполняется, вне зависимости от истинности или ложности условия.

Обработка исключений внутри IT-блока, а также непосредственно после инструкции IT допускается. При этом осуществляется переход на соответствующий

обработчик с предварительным сохранением регистра PSR в стеке и необходимой для корректного возврата информации в регистре LR. Возврат из обработчика осуществляется стандартным образом, при этом корректное выполнение IT-блока продолжается с прерванной позиции. Это единственный допустимый способ передачи управления внутрь IT-блока с помощью команд, модифицирующих счетчик команд PC.

# Ограничения

Следующие инструкции нельзя использовать внутри IT-блока: IT, CBZ и CBNZ, CPSI D и CPSI E.

Кроме того, существуют следующие ограничения при использовании ITблоков:

- ветвление, а также любая другая команда, модифицирующая счетчик команд РС, должны передавать управление либо за пределы ІТ-блока, либо на последнюю инструкцию ІТ-блока.
- Инструкции, модифицирующие счетчик команд:
  - ADD PC, PC, Rm;
  - MOV PC, Rm;
  - B, BL, BX, BLX;
  - любая инструкция LDM, LDR или POP, приводящая к записи значения в PC;
  - TBB and TBH.
- не допускается передача управления на инструкцию внутри ІТ-блока, за исключением случая возврата из обработчика исключения;
- все условные инструкции, за исключением В cond, должны находится внутри IT-блока. Команда В cond может быть расположена как внутри, так и вне IT-блока, однако внутри IT-блока она обеспечивает более широкий диапазон адресуемых переходов;
- каждая инструкция внутри IT-блока должна быть снабжена суффиксом условного исполнения с кодом, либо совпадающим, либо противоположным коду условия IT-блока.

Ассемблер конкретного производителя может накладывать дополнительные ограничения, например, возможен запрет на использование директив внутри IT-блока.

# Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

ITTE NE ; Следующие три инструкции - условные ANDNE R0, R0, R1 ; ANDNE не изменяет состояние флагов ; ADDSNE R2, R2, #1 ; ADDSNE изменяет состояние флагов

MOVEQ R2, R3 ; условное копирование

СМР R0, #9 ; преобразование R0 (от 0 до 15) в код ASCII

; шестнадцатеричного числа ('0'-'9', 'A'-'F')

ITE GT ; следующие две инструкции - условные ADDGT R1, R0, #55 ; [R0 > 9] преобразуем число 0хА -> в код 'A' ADDLE R1, R0, #48 ; [R0 <= 9] преобразуем число 0х0 -> в код '0'

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

IT GT ; IT-блок с одной единственной условной инструкцией

ADDGT R1, R1, #1 ; условное увеличение R1 на единицу

ITTEE EQ ; следующие четыре инструкции - условные

 MOVEQ R0, R1
 ; условное копирование

 ADDEQ R2, R2, #10
 ; условное сложение

 ANDNE R3, R3, #1
 ; условное логическое И

BNE.W dloop ; условный переход. должен быть последним в блоке

IT NE ; следующая инструкция - условная

ADD R0, R0,R1 ; синтаксическая ошибка: не указан код условия в IT-блоке.

### 9.8.4 TBB u TBH

Табличный переход по индексу.

### Синтаксис

TBB [Rn, Rm] TBH [Rn, Rm, LSL #1]

где:

- Rn регистр, содержащий адрес таблицы длин переходов. Если в качестве регистра Rn используется PC, то первый байт таблицы переходов следует непосредственно после инструкции TBB или TBH.
- Rm регистр, содержащий индекс в таблице переходов. Для таблиц, содержащих полуслова, добавляется операция сдвига LSL #1, что обеспечивает корректную адресацию по смещению в таблице.

## Описание

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

Регистр Rn содержит указатель на начало таблицы, а регистр Rm – индекс требуемого элемента.

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

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

Передача управления по соответствующему смещению осуществляется немедленно после выполнения инструкции ТВВ или ТВН.

# Ограничения

- в качестве регистра Rn нельзя использовать SP;
- в качестве регистра Rm нельзя использовать SP и PC;
- при использовании инструкций ТВВ или ТВН внутри ІТ-блока они должны быть последней командой блока.

### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

ADR.W R0, BranchTable\_Byte

ТВВ [R0, R1] ; R1 – индекс, R0 – базовый адрес таблицы переходов

Case1

; код для варианта R1 = 0

Case2

; код для варианта R1 = 1

Case3

; код для варианта R1 = 2

BranchTable\_Byte

DCB 0 ; смещение для Case1 DCB ((Case2-Case1)/2) ; смещение для Case2 DCB ((Case3-Case1)/2) ; смещение для Case3

ТВН [PC, R1, LSL #1] ; R1 – индекс, таблица переходов расположена

; непосредственно после команды ТВН

BranchTable\_H

DCI ((CaseA - BranchTable\_H)/2); смещение для CaseA DCI ((CaseB - BranchTable\_H)/2); смещение для CaseB DCI ((CaseC - BranchTable\_H)/2); смещение для CaseC

CaseA

; код для CaseA

CaseB

; код для CaseB

CaseC

; код для CaseC

# 9.9 Прочие инструкции

В таблице ниже представлен список инструкций процессора RISC, не рассмотренных в предыдущих разделах.

Таблица 9–13 – Прочие инструкции

| Мнемокод | Краткое описание                                              |
|----------|---------------------------------------------------------------|
| BKPT     | Точка останова                                                |
| CPSID    | Изменить состояние процессора, запретить прерывания           |
| CPSIE    | Изменить состояние процессора, разрешить прерывания           |
| DMB      | Барьер синхронизации доступа к памяти данных                  |
| DSB      | Барьер синхронизации доступа к памяти данных                  |
| ISB      | Барьер синхронизации доступа к инструкциям                    |
| MRS      | Загрузка из специального регистра в регистр общего назначения |
| MSR      | Записать регистр общего назначения в специальный регистр      |
| NOP      | Нет операции                                                  |
| SEV      | Установить признак события                                    |
| SVC      | Вызов супервизора                                             |
| WFE      | Ожидать событие                                               |
| WFI      | Ожидать прерывание                                            |

### 9.9.1 *CPS*

Изменить состояние процессора.

### Синтаксис

CPSeffect iflags

где:

effect - один из возможных суффиксов:

- IE сбрасывает специальный регистр в 0;
- ID устанавливает специальный регистр в 1.

iflags – последовательность флагов:

- i сбрасывает или устанавливает регистр PRIMASK;
- f сбрасывает или устанавливает регистр FAULTMASK.

# Описание

Команда CPS позволяет изменить значение специальных регистров PRIMASK и FAULTMASK. Подробности см. в разделе "Регистр маски исключений Exception mask".

# Ограничения

- команда CPS доступна только из привилегированного приложения, при вызове из непривилегированного приложения она игнорируется;
- команда CPS не допускает условного исполнения и, таким образом, не должна использоваться внутри IT-блока.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

CPSID і ; Запретить прерывания и конфигурируемые обработчики отказов

CPSID f ; Запретить прерывания и все обработчики отказов

CPSIE і ; Разрешить прерывания и конфигурируемые обработчики отказов

CPSIE f ; Разрешить прерывания и все обработчики отказов.

### 9.9.2 DMB

Барьер синхронизации доступа к памяти данных.

## Синтаксис

DMB{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

#### Описание

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

Команда DMB не влияет на очередность и порядок выполнения инструкций, не выполняющих доступа к памяти.

#### Флаги

Данная инструкция не влияет на состояние флагов.

### Примеры

DMB ; Барьер синхронизации доступа к памяти данных.

# 9.9.3 DSB

Барьер синхронизации доступа к памяти данных.

### Синтаксис

DSB{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

#### Описание

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

### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

DSB ; Data Synchronisation Barrier.

# 9.9.4 ISB

Барьер синхронизации доступа к инструкциям.

### Синтаксис

ISB{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

# Описание

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

### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

ISB ; Барьер синхронизации доступа к инструкциям.

#### 9.9.5 *MRS*

Считать содержимое специального регистра в регистр общего назначения.

### Синтаксис

MRS(cond) Rd, spec\_reg

где:

cond – необязательный код условия, см. "Условное исполнение".

Rd регистр-получатель результата.

spec reg – один из специальных регистров: APSR, IPSR, EPSR, IEPSR, IAPSR, EAPSR, PSR, MSP, PSP, PRIMASK, BASEPRI, BASEPRI\_MAX, FAULTMASK или CONTROL.

#### Описание

MRS MSR Инструкции совместно С используются ДЛЯ чтения/модификации/записи элементов PSR, например, для сброса флага Q.

В коде, отвечающем за переключение процессов, необходимо обеспечить сохранение состояния приостановленного процесса, и восстановление состояния активизированного процесса. Необходимой составной частью сохраняемой (восстанавливаемой) информации является значение регистра PSR. При этом на этапе сохранения состояния используется команда MRS, а на этапе восстановления – команда MSR.

При использовании команды MRS регистр BASEPRI MAX является синонимом регистра BASEPRI. См. также описание инструкции MSR.

# Ограничения

В качестве регистра-получателя Rd нельзя использовать SP или PC.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

MRS R0, PRIMASK; Считать значение PRIMASK и записать значение в R0.

#### 9.9.6 **MSR**

Записать регистр общего назначения в специальный регистр.

# Синтаксис

MSR{cond} spec\_reg, Rn

где:

- необязательный код условия, см. "Условное исполнение". cond

Rn – регистр-источник данных.

spec\_reg — один из специальных регистров: APSR, IPSR, EPSR, IEPSR, IAPSR,

EAPSR. PSR. MSP. PSP. PRIMASK. BASEPRI. BASEPRI MAX.

FAULTMASK или CONTROL.

# Описание

Доступ к специальным регистрам в команде MSR различен привилегированных и непривилегированных приложений. Непривилегированному приложению доступен только регистр APSR (см. "Программный регистр состояния приложения APSR"). При этом попытки записи в нераспределенные биты, а также в EPSR игнорируются.

Привилегированное приложение имеет доступ ко всем специальным регистрам.

При записи данных в регистр BASEPRI MAX инструкция записывает данные в регистр BASEPRI только при выполнении одного из условий:

- Rn не равен нулю и текущее значение BASEPRI равно 0;
- Rn не равен нулю и меньше текущего значения BASEPRI.

См. также описание инструкции MRS.

# Ограничения

В качестве регистра-источника данных Rn нельзя использовать SP или PC.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

MSR CONTROL, R1 ; Записать значение регистра R1 в регистр CONTROL

#### 9.9.7 *NOP*

Нет операции.

#### Синтаксис

NOP{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

### Описание

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

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

NOP ; нет операции

#### 9.9.8 SEV

Установить признак события.

# Синтаксис

SEV{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

# Описание

Инструкция SEV используется для передачи информации о событии всем процессорам в составе многопроцессорной системы. Кроме того, он устанавливает собственный регистр события в 1.

См. также раздел «Управление электропитанием».

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

SEV ; Послать признак события.

# 9.9.9 SVC

Вызов супервизора.

#### Синтаксис

SVC{cond} #imm

где:

cond – необязательный код условия, см. "Условное исполнение".

Imm — константное выражение, целое число в диапазоне от 0 до 255 (8-битное число).

# Описание

Инструкция SVC вызывает формирование исключения SVC. Параметр imm игнорируется процессором. При необходимости он может быть получен обработчиком исключения для определения запрошенного приложением варианта обслуживания.

#### Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

SVC 0x32

; Вызов супервизора

; (обработчик SVC может извлечь параметр по сохраненному в стеке,

; адресу РС приложения.

## 9.9.10 WFE

Ожидать событие.

# Синтаксис

WFE{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

### Описание

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

- исключение, не запрещенное путем установки маски или текущим уровнем приоритета;
- перевод исключения в состояние ожидания обслуживания при установленном в 1 бите SEVONPEND регистра управления системой SCR;
- получение запроса на переход в режим отладки, в случае, если отладка разрешена;
- получение сигнала о событии от периферийного устройства или от другого процессора (по команде SEV) в многопроцессорной системе.

В случае, если регистр события равен 1, команда WFE сбрасывает его в 0, после чего завершает свое функционирование без приостановки процессора.

Более подробная информация отражена в разделе "Управление электропитанием".

# Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

WFE

; Ожидание события.

# 9.9.11 WFI

Ожидание прерывание.

## Синтаксис

WFI{cond}

где:

cond – необязательный код условия, см. "Условное исполнение".

### Описание

Команда WFI приостанавливает процессор до тех пор, пока не произойдет одно из следующих событий:

- исключение;
- запрос на перевод в режим отладки, вне зависимости от того, разрешён или запрещён этот режим.

# Флаги

Данная инструкция не влияет на состояние флагов.

# Примеры

WFI ; Ожидание прерывания.

# 10 Системный таймер SysTick

Процессор имеет 24-х разрядный системный таймер, SysTick, который считает вниз от загруженного в него значения до нуля; перезагрузка (возврат в начало) значения в регистр LOAD происходит по следующему фронту синхросигнала, затем счёт продолжается по последующему фронту.

Когда процессор остановлен для отладки, таймер не декрементируется.

# 10.1 Описание регистров системного таймера SysTick

Таблица 10-1 - Описание регистров системного таймера SysTick

| Адрес      | Название | Тип | Доступ            | Значение<br>после сброса | Описание                    |
|------------|----------|-----|-------------------|--------------------------|-----------------------------|
| 0xE000E000 | SysTick  |     |                   |                          | Системный таймер<br>SYSTICK |
| 0x000      | CTRL     | RW  | привилегированный | 0x00000004               | SysTick->CTRL               |
| 0x004      | LOAD     | RW  | привилегированный | 0x00000000               | SysTick->LOAD               |
| 0x008      | VAL      | RW  | привилегированный | 0x00000000               | SysTick->VAL                |
| 0x00C      | CALIB    | RO  | привилегированный | 0x00002904 <sup>1)</sup> | SysTick->CAL                |

<sup>1)</sup> Калибровочное значение системного таймера.

# 10.1.1 SysTick->CTRL

Регистр CTRL разрешает основные функции системного таймера. Назначение бит:

Таблица 10-2 - Регистр контроля и статуса CTRL

| Номер  | 3117 | 16        | 153 | 2         | 1       | 0      |
|--------|------|-----------|-----|-----------|---------|--------|
| Доступ | U    | RO        | U   | R/W       | R/W     | R/W    |
| Сброс  |      | 0         |     | 0         | 0       | 0      |
|        | -    | COUNTFLAG | -   | CLKSOURCE | TICKINT | ENABLE |

### **COUNTFLAG**

Возвращает 1, если таймер досчитал до нуля с последнего момента чтения.

### **CLKSOURCE**

Указывает источник синхросигнала:

0 - LSI

1 - HCLK

# **TCKINT**

Разрешает запрос на прерывание от системного таймера:

0 – таймер досчитает до нуля и прерывание не возникнет;

1 – таймер досчитывает до нуля и возникает запрос на прерывание.

Программное обеспечение может использовать бит COUNTFLAG, чтобы определить, досчитал таймер до нуля или нет.

## **ENABLE**

Разрешает работу таймера:

0 – работа таймера запрещена;

1 – работа таймера разрешена.

Когда ENABLE установлен в единицу, таймер загружает значение RELOAD из регистра LOAD и затем начинает декрементироваться. По достижению значения 0 таймер устанавливает бит COUNTFLAG и в зависимости от TCKINT генерирует запрос на прерывание. Затем загружается значение RELOAD и продолжается счёт.

# 10.1.2 SysTick->LOAD

Регистр LOAD устанавливает стартовое значение, загружаемое в регистр VAL.

Таблица 10-3 - Регистр перегружаемого значения LOAD

| Номер  | 3124 | 230    |
|--------|------|--------|
| Доступ |      |        |
| Сброс  |      |        |
|        | -    | RELOAD |

### RELOAD

Значение, загружаемое в регистр VAL, когда таймер разрешён и когда достигается значение нуля.

# Расчёт значения RELOAD

Значение RELOAD может быть любым в диапазоне 0x00000001-0x00FFFFF. Значение 0 допустимо, но не оказывает эффекта, потому что запрос на прерывание и активизация бита COUNTFLAG происходит только при переходе таймера из состояния 1 в 0.

Расчёт значения RELOAD происходит в соответствии с использованием таймера:

- Для формирования мультикороткого таймера с периодом N процессорных циклов применяется значение RELOAD, равное N-1. Например, если требуется прерывание каждые 100 циклов, то устанавливается значение RELOAD, равное 99;
- Для формирования одиночного прерывания после задержки в N тактов процессора используется значение N. Например, если требуется прерывание после 400 тактов процессора, то устанавливается RELOAD, равное 400.

# 10.1.3 *SysTick->VAL*

Регистр VAL содержит текущее значение системного таймера.

Таблица 10-4 - Регистр текущего значения таймера VAL

| Номер  | 3124 | 230     |
|--------|------|---------|
| Доступ |      |         |
| Сброс  |      |         |
|        | -    | CURRENT |

### **CURRENT**

Чтение возвращает текущее значение системного таймера.

Запись любого значения очищает регистр в ноль, и также очищает бит COUNTFLAG регистра CTRL.

# 10.1.4 SysTick->CAL

Регистр CALIB показывает калибровочное значение системного таймера.

# Таблица 10-5 - Регистр калибровочного значения таймера CAL

| Номер  | 31    | 30   | 2924 | 230   |
|--------|-------|------|------|-------|
| Доступ |       |      |      |       |
| Сброс  |       |      |      |       |
|        | NOREF | SKEW | -    | TENMS |

# **NOREF**

Читается как ноль.

# **SKEW**

Читается как ноль.

# **TENMS**

Читается как 0х0002904.

Калибровочное значение фиксировано и равно 0х0002904 (10500), что позволяет генерировать базовое время 1 мс с частотой 10,5 МГц (84/8=10,5 МГц).

# 10.2 Советы и особенности при применении системного таймера

Системный таймер работает от процессорного синхросигнала. Если синхросигнал останавливается в режиме пониженного энергопотребления, то системный таймер останавливается.

Гарантируйте, чтобы программа использовала доступ к регистрам системного таймера, выровненный по словам.

# 11 Модуль защиты памяти

Этот раздел описывает модуль защиты памяти (MPU).

MPU делит карту памяти на регионы, и определяет положение, размер, разрешение на доступ и атрибуты памяти для каждого из них. Поддерживается:

- независимая установка атрибута для каждого региона;
- наложение (перекрытие) регионов;
- экспортирование атрибутов памяти в систему.

Атрибуты памяти влияют на доступ к памяти в регионе. В ядре RISC определено:

- восемь независимых регионов, 0–7;
- фоновый регион.

Если регионы памяти перекрываются, на доступ к памяти влияют атрибуты региона с большим номером. Например, атрибуты региона 7 получают первенство над атрибутами любых других регионов, перекрывающихся с 7.

Фоновый регион имеет такие же атрибуты доступа к памяти, как и default карта памяти, но доступен только через привилегированные инструкции программы.

Карта памяти RISC унифицированная. Это означает, что атрибуты доступа к инструкциям и данным одинаковые.

Если происходит программный запрос в запрещённую область памяти MPU, процессор генерирует ошибку управления памятью. Это вызывает прерывание по ошибке и может вызвать прерывание процессов в переменном окружении OS.

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

Конфигурация MPU регионов основывается на типе памяти, см. раздел "Регионы памяти, типы и атрибуты RISC".

Таблица 11–1 показывает возможные атрибуты MPU регионов. Здесь включены такие атрибуты памяти, как *shareable* и кэшируемость, которые не существенны во многих реализациях микроконтроллеров.

Таблица 11–1 – Обзор атрибутов памяти

| Тип памяти    | Атрибут<br>shareable | Другие<br>атрибуты | Описание                                    |
|---------------|----------------------|--------------------|---------------------------------------------|
| Строго        | -                    | -                  | Весь доступ к строго упорядоченной памяти   |
| упорядоченная |                      |                    | осуществляется под программным управлением. |
|               |                      |                    | Все строго упорядоченные регионы могут быть |
|               |                      |                    | общими                                      |
| Устройство    | Общая                | -                  | Общая периферийная память для нескольких    |
| -             |                      |                    | процессоров                                 |
|               | Не общая             | -                  | Периферийная память только для одного       |
|               |                      |                    | процессора                                  |
| Обычная       | Общая                |                    | Обычная общая память для нескольких         |
|               |                      |                    | процессоров                                 |
|               | Не общая             |                    | Обычная память только для одного процессора |

### 11.1 Описание регистров MPU

Применяются следующие MPU регистры для определения регионов и их атрибутов.

Таблица 11-2 - Обзор регистров MPU

| Адрес      | Обозначение | Тип | Доступ            | Значение<br>после сброса | Описание                    |
|------------|-------------|-----|-------------------|--------------------------|-----------------------------|
| 0xE000ED90 | MPU         |     |                   |                          | Модуль защиты<br>памяти MPU |
| 0x000      | TYPE        | RO  | привилегированный | 0x00000800               | MPU->TYPE                   |
| 0x004      | CTRL        | RW  | привилегированный | 0x00000000               | MPU->CTRL                   |
| 0x008      | RNR         | RW  | привилегированный | 0x00000000               | MPU->RNR                    |
| 0x00C      | RBAR        | RW  | привилегированный | 0x00000000               | MPU->RBAR                   |
| 0x010      | RASR        | RW  | привилегированный | 0x00000000               | MPU->RASR                   |
| 0x014      | RBAR_A1     | RW  | привилегированный | 0x00000000               | Обозначение<br>RBAR         |
| 0x018      | RASR_A1     | RW  | привилегированный | 0x00000000               | Обозначение<br>RASR         |
| 0x01C      | RBAR_A2     | RW  | привилегированный | 0x00000000               | Обозначение<br>RBAR         |
| 0x020      | RASR_A2     | RW  | привилегированный | 0x00000000               | Обозначение<br>RASR         |
| 0x24       | RBAR_A3     | RW  | привилегированный | 0x00000000               | Обозначение<br>RBAR         |
| 0x28       | RASR_A3     | RW  | привилегированный | 0x00000000               | Обозначение<br>RASR         |

### 11.1.1 *MPU->TYPE*

Регистр TYPE показывает, присутствует или нет MPU, и как много регионов поддерживается.

#### Таблица 11-3 - Регистр ТҮРЕ

| Номер<br>Доступ<br>Сброс | 3124 | 2316    | 158     | 71 | 0        |
|--------------------------|------|---------|---------|----|----------|
|                          | -    | IREGION | DREGION | -  | SEPARATE |

#### IREGION

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

Всегда содержит 0x00. Карта памяти MPU унифицированная и описывается полем DREGION.

### **DREGION**

Указывает количество поддерживаемых MPU регионов данных. 0x08 – Восемь MPU регионов.

#### **SEPARATE**

Указывает, поддерживается унифицированная или раздельная карта памяти для инструкций и данных:

0 – унифицированная.

#### 11.1.2 MPU->CTRL

Регистр CTRL:

- разрешает MPU;
- разрешает default карту памяти как фоновый регион;
- разрешает применение MPU, при возникновении аппаратной ошибки, немаскируемое прерывание (NMI), FAULTMASK вызываемый обработчик.

### Таблица 11-4 - Регистр CTRL

| Номер  | 314 | 3     | 2     | 1        | 0      |
|--------|-----|-------|-------|----------|--------|
| Доступ |     |       |       |          |        |
| Сброс  |     |       |       |          |        |
|        | -   | PRIVD | EFENA | HFNMIENA | ENABLE |

#### **PRIVDEFENA**

Разрешает привилегированный программный доступ к default карте памяти:

- 0 если MPU разрешён, запрещение применяется к default карте памяти. Любой доступ к памяти, не покрываемой разрешённым регионом, вызывает ошибку;
- 1 если MPU разрешён, разрешает применение default карты памяти как фонового региона для привилегированного программного доступа.

Когда разрешено, фоновый регион считается как номер региона -1. Любой регион, который определён и разрешен, имеет приоритет выше этой default памяти. Если MPU запрещён, то процессор игнорирует этот бит.

#### **HFNMIENA**

Разрешает операции MPU во время возникновения аппаратной ошибки, NMI, и FAULTMASK обработчик.

Если MPU разрешён:

- 0 MPU запрещён во время возникновения аппаратной ошибки, NMI, FAULTMASK обработчик, несмотря на значения бита ENABLE;
- 1 MPU разрешён во время возникновения аппаратной ошибки, NMI, FAULTMASK обработчик.

Если MPU запрещён и этот бит устанавливается в единицу, то поведение непредсказуемо.

#### **ENABLE**

Разрешает MPU:

- 0 MPU запрещён;
- 1 MPU разрешён.

Если ENABLE и PRIVDEFENA одновременно установлены в единицу:

Любой неадресованый доступ привилегированным программным обеспечением к разрешённому региону, ведёт себя как определено default картой памяти. Любой неадресованый доступ непривилегированным программным обеспечением к разрешённому региону вызывает ошибку управления памятью.

XN и строго упорядоченные правила всегда применяются к управляющему системному пространству несмотря на значение бита ENABLE.

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

Когда ENABLE установлен в ноль, система использует default карту памяти. Это аналогично памяти с атрибутами, как если бы MPU не применялся. К default карте памяти доступ осуществляется как с помощью привилегированного, так и непривилегированного программного обеспечения.

Когда MPU разрешён, доступ к системному пространству управления и таблице векторов всегда разрешён. К другим областям доступ базируется на регионах и состоянии бита PRIVDEFENA.

За исключением случая HFNMIENA установленного в 1, MPU не разрешает процессору выполнять обработчики прерываний с приоритетом -1 или -2. Эти приоритеты допустимы только когда обрабатывается прерывание аппаратной ошибки или NMI, или когда FAULTMASK разрешён. Установка бита HFNMIENA в единицу разрешает действовать этим двум приоритетам.

#### 11.1.3 *MPU->RNR*

Perucтp RNR выбирает, на какой регион памяти ссылаются регистры RBAR и RASR.

Таблица 11-5 - Регистр номера региона RNR

| Номер  | 318 | 70     |
|--------|-----|--------|
| Доступ |     |        |
| Сброс  |     |        |
|        | -   | REGION |

#### REGION

Указывает MPU регион, на который ссылаются регистры RBAR и RASR.

MPU поддерживает 8 регионов памяти, поэтому разрешённое значение для этого поля от 0 до 7.

Обычно вы записываете требуемое значение номера региона в этот регистр перед обращением в RBAR и RASR. Однако вы можете изменить номер региона записью в RBAR с установленным в единицу битом VALID. Эта запись обновляет значение поля REGION.

#### 11.1.4 *MPU->RBAR*

Регистр RBAR определяет базовый адрес MPU региона, выбранного RNR, вы можете изменить значение RNR. Запись RBAR с битом VALID установленным в единицу изменяет текущий номер региона и обновляет RNR.

Таблица 11-6 - Регистр базового адреса региона RBAR

| Номер  | 31N  | N-16 | 5  | 4   | 30     |
|--------|------|------|----|-----|--------|
| Доступ |      |      |    |     |        |
| Сброс  |      |      |    |     |        |
|        | ADDR | -    | VA | LID | REGION |

#### **ADDR**

Поле базового адреса региона. Значение N зависит от размера региона. Для более подробной информации смотрите раздел "Поле ADDR".

#### **VALID**

Бит верности номера региона MPU:

Запись:

- 0 RNR не изменяется, и процессор:
  - обновляет базовый адрес для региона, определённого в RNR;
  - игнорирует значение поля REGION.
- 1 процессор:
  - обновляет значение RNR на значение из поля REGION;
  - обновляет базовый адрес региона, определённого в поле REGION.

Всегда читается как ноль.

#### REGION

Поле MPU региона:

- поведение при записи описано выше (см. описание бита VALID);
- при чтении возвращает текущий номер региона, который определён в регистре RNR.

#### Поле ADDR

Поле ADDR это [31:N] бит регистра RBAR. Размер региона определяется полем SIZE в регистре RASR, как

N = Log2 (Размер региона в байтах),

Если размер региона сконфигурирован равным 4 ГБ, в RASR, то значение поля ADDR неверно. В этом случае, регион занимает всю карту памяти, и базовый адрес его равен 0x00000000.

Базовый адрес выравнивается под размер региона. Например, 64 КБ регион должен быть кратно 64 КБ, например, 0х00010000 или 0х00020000.

#### 11.1.5 *MPU->RASR*

Регистр RASR определяет размер и атрибуты памяти MPU региона, выбранного RNR, а также разрешает регион и любые подрегионы.

RASR доступен в режиме слова или полуслова:

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

#### Таблица 11-7 - Назначение бит регистра RASR

| Номер  | 31 | 30 | 29 | 28 | 27 | 26 | 24 | 23 | 22 | 21 | 19 |
|--------|----|----|----|----|----|----|----|----|----|----|----|
| Доступ |    |    |    |    |    |    |    |    |    |    |    |
| Сброс  |    |    |    |    |    |    |    |    |    |    |    |

|                          |    | -  | N<br>X | -  |     | AP |   | - |      | ТЕХ    |  |
|--------------------------|----|----|--------|----|-----|----|---|---|------|--------|--|
| Номер<br>Доступ<br>Сброс | 18 | 17 | 16     | 15 | 8   | 7  | 6 | 5 | 1    | 0      |  |
|                          | ဟ  | ၁  | В      |    | SRD |    | - | 1 | 9126 | ENABLE |  |

#### XN

Бит запрещения доступа инструкций:

- 0 выборка инструкций разрешена;
- 1 выборка инструкций запрещена.

#### AP

Поле разрешения доступа, см. Таблица 11–11 – Кодирование привилегий доступа в поле AP.

#### TEX, C, B

Атрибуты доступа к памяти, см. Таблица 11–9 – Кодирование бит разрешения доступа.

S

Бит общего доступа, см. Таблица 11–8 – Пример значений поля SIZE.

### SRD

Бит запрещения подрегиона. Для каждого бита в этом поле:

- 0 соответствующий подрегион разрешён;
- 1 соответствующий подрегион запрещён.

Для более подробной информации см. раздел "Подрегионы".

Регион размером 128 байт и менее не поддерживает подрегионы. Когда записываются атрибуты для такого региона, записывайте поле SRD равным 0x00.

#### SIZE

Определяет размер MPU региона. Минимальное разрешённое значение 3(b00010), для более подробной информации см. раздел "Значения поля SIZE".

#### **ENABLE**

Бит разрешения региона.

Для более подробной информации о разрешении доступа, см. раздел "Атрибуты разрешения доступа MPU".

#### Значения поля SIZE

Поле SIZE определяет размер памяти MPU региона выбранного регистром RNR следующим образом:

(Region size in bytes)= 2(SIZE+1)

Наименьший разрешенный размер региона 32 байт, соответствует значению SIZE, равному 4. Таблица 11–8 представляет примеры значений SIZE, соответствующие размеру региона и значению N регистра RBAR.

Таблица 11-8 - Пример значений поля SIZE

| Значение SIZE | Размер региона | Значение N <sup>(1)</sup> | Комментарий                     |
|---------------|----------------|---------------------------|---------------------------------|
| b00100 (4)    | 32 байт        | 5                         | Минимальный разрешённый размер  |
| b01001 (9)    | 1 кбайт        | 10                        | -                               |
| b10011 (19)   | 1 Мбайт        | 20                        | -                               |
| b11101 (29)   | 1 Гбайт        | 30                        | -                               |
| b11111 (31)   | 4 Гбайт        | b01100                    | Максимальный разрешённый размер |

<sup>1).</sup> Содержится в RBAR, см. раздел "MPU->RBAR".

### 11.1.6 Атрибуты разрешения доступа МРИ

Раздел описывает атрибуты разрешения доступа. Биты разрешения доступа TEX, C, B, S, AP и XN регистра RASR контролируют доступ к соответствующему региону памяти. Если происходит доступ к области памяти без разрешения доступа, то MPU генерирует ошибку доступа.

Таблица 11-9 - Кодирование бит разрешения доступа TEX, C, B, S

| TEX  | C | В                | S                | Тип памяти    | Возможность<br>общего<br>доступа | Другие атрибуты           |
|------|---|------------------|------------------|---------------|----------------------------------|---------------------------|
|      |   | 0                | X <sup>(1)</sup> | Строго        | Общий доступ                     |                           |
|      | 0 |                  |                  | упорядоченная |                                  |                           |
|      |   | 1                | X <sup>(1)</sup> | Устройство    | Общий доступ                     |                           |
|      |   |                  | 0                | Обычная       | Не общий                         | Внешний и внутренний кэш, |
|      |   | 0                |                  |               | доступ                           | синхронное обновление     |
| b000 |   |                  | 1                |               | Общий доступ                     | памяти.                   |
|      | 1 |                  | '                |               |                                  | Запись без кэширования    |
|      | • |                  | 0                | Обычная       | Не общий                         | Внешний и внутренний кэш, |
|      |   | 1                |                  |               | доступ                           | отложенное обновление     |
|      |   | •                | 1                |               | Общий доступ                     | памяти.                   |
|      |   |                  |                  |               |                                  | Запись без кэширования    |
|      |   | _                | 0                | Обычная       | Не общий                         |                           |
|      | 0 | 0                |                  |               | доступ                           |                           |
|      | Ů | _                | 1                |               | Общий доступ                     |                           |
|      |   | 1                | X <sup>(1)</sup> |               | рвировано                        | -                         |
| b001 |   | 0                | X <sup>(1)</sup> |               | деляется атрибутами              | -                         |
|      |   |                  | 0                | Обычная       | Не общий                         | Внешний и внутренний кэш, |
|      | 1 | 1                | •                |               | доступ                           | отложенное обновление     |
|      |   |                  | 1                |               | Общий доступ                     | памяти.                   |
|      |   |                  |                  |               |                                  | Запись и чтение пакетные  |
|      | _ | 0                | X <sup>(1)</sup> | Устройство    | Не общий                         | Индивидуальное устройство |
| b010 | 0 |                  |                  |               | доступ                           |                           |
|      |   | 1                | X <sup>(1)</sup> |               | рвировано                        | -                         |
|      | 1 | X <sup>(1)</sup> | X <sup>(1)</sup> |               | рвировано                        | -                         |
|      |   |                  | 0                | Обычное       | Не общий                         |                           |
| b1BB | Α | Α                |                  |               | доступ                           |                           |
|      |   |                  | 1                |               | общий доступ                     |                           |

1) MPU игнорирует значение этих бит.

Таблица 11–10 поясняет кодирование режима кэша атрибутом ТЕХ в диапазоне значений атрибута от 4 до 7.

Таблица 11-10 - Кодирование режима кэша атрибутом ТЕХ

| Значение АА или ВВ при<br>ТЕХ=1хх | Соответствующий режим кэша                      |
|-----------------------------------|-------------------------------------------------|
| 00                                | Не кэшируемая                                   |
| 01                                | Отложенное обновление, запись и чтение пакетные |
| 10                                | Синхронное обновление, запись без кэширования   |
| 11                                | Отложенное обновление, запись без кэширования   |

Таблица 11–11 поясняет кодирование бит AP, определяющих разрешение на доступ для привилегированного и непривилегированного программного обеспечения (ПО).

Таблица 11-11 - Кодирование привилегий доступа в поле АР

| AP[2:0] | Привилегированный | Непривилегированный | Описание                  |
|---------|-------------------|---------------------|---------------------------|
|         | доступ            | доступ              |                           |
| 000     | нет доступа       | нет доступа         | Любой доступ приводит к   |
|         |                   |                     | ошибке доступа            |
| 001     | RW                | нет доступа         | Доступ только для         |
|         |                   |                     | привилегированного ПО     |
| 010     | RW                | RO                  | Запись                    |
|         |                   |                     | непривилегированным ПО    |
|         |                   |                     | приводит к ошибке доступа |
| 011     | RW                | RW                  | Полный доступ             |
| 100     | непредсказуемо    | непредсказуемо      | Зарезервировано           |
| 101     | RO                | нет доступа         | Чтение только             |
|         |                   |                     | привилегированным ПО      |
| 110     | RO                | RO                  | Только чтение и           |
|         |                   |                     | привилегированным, и      |
|         |                   |                     | непривилегированным ПО    |
| 111     | RO                | RO                  | Только чтение и           |
|         |                   |                     | привилегированным, и      |
|         |                   |                     | непривилегированным ПО    |

#### 11.1.7 Hecoomsemcmsue MP

Когда происходит нарушение разрешения доступа MPU, процессор генерирует ошибку управления памятью, см. раздел «Прерывания и исключения RISC». Регистр MMFSR указывает причину ошибки. Для более подробной информации см. пункт «Поле MMFSR».

#### 11.1.8 Обновление МРИ региона

Атрибуты для MPU региона обновляют через регистры RNR, RBAR и RASR. Вы можете программировать каждый регистр независимо или использовать для программирования возможность множественной записи всех этих регистров. Вы можете использовать обозначения RBAR и RASR, чтобы запрограммировать до 4 регионов одновременно, используя инструкцию STM.

### Обновление MPU региона через отдельные регистры

Простой код для одного региона:

; R1 = номер региона

; R2 = размер/разрешение

; R3 = атрибуты

; R4 = адрес

LDR R0,=MPU\_RNR ; 0хE000ED98, регистр номера региона MPU

STR R1, [R0, #0x0] ; номер региона

STR R4, [R0, #0x4] ; базовый адрес региона STRH R2, [R0, #0x8] ; размер региона и разрешение

STRH R3, [R0, #0xA] ; атрибуты региона

Запрещение региона перед записью новых настроек в MPU, если этот регион перед этим был разрешён. Например:

; R1 = номер региона

; R2 = размер/разрешение

; R3 = атрибуты

; R4 = адрес

LDR R0,=MPU\_RNR; 0xE000ED98, регистр номера региона MPU

STR R1, [R0, #0x0]; номер региона

BIC R2, R2, #1; запрещение

STRH R2, [R0, #0x8]; размер региона и разрешение

STR R4, [R0, #0x4] ; базовый адрес региона

STRH R3, [R0, #0xA]; атрибуты региона

ORR R2, #1 ; разрешение

STRH R2, [R0, #0x8]; размер региона и разрешение.

Программное обеспечение должно применить barrier инструкции:

- если перед установкой MPU будет невыполненная пересылка в память, такая как буферная запись, то это может повлиять на изменение настроек MPU:
- после установки MPU, если это включает пересылку в память, должны использоваться новые настройки MPU.

Однако не требуются barrier инструкции памяти, если процесс установки MPU начинается с помощью входа в обработчик прерывания, или сопровождается возвращением из прерывания, потому что вход и выход из прерывания сопровождается механизмом barrier для памяти.

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

Например, если вы хотите, чтобы все изменения доступа к памяти имели место непосредственно после программной последовательности, используйте инструкции DSR и ISB. Инструкции DSB требуются после изменения настроек MPU, в конце переключения контекста. Инструкции ISB требуются, если код, который программирует MPU регион или регионы вызывается с использованием инструкций перехода (branch) или вызова подпрограммы (call). Если программная последовательность вызывается инструкцией выхода из прерывания (return), или прерыванием, то ISB не требуется.

Обновление MPU региона через множественную запись регистров

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

; R1 = номер региона

; R2 = адрес

; R3 = размер, атрибуты

LDR R0, =MPU\_RNR; 0xE000ED98, регистр номера региона MPU

STR R1, [R0, #0x0]; номер региона

STR R2, [R0, #0x4] ; базовый адрес региона

STR R3, [R0, #0x8]; атрибут региона, размер и разрешение.

Оптимизация при использовании STM инструкции:

; R1 = номер региона

; R2 = адрес

; R3 = размер, атрибуты

LDR R0, =MPU RNR; 0xE000ED98, регистр номера региона MPU

STM R0, {R1-R3}; номер региона, адрес, атрибут, размер и разрешение.

Вы можете использовать два слова для предварительной упаковки информации. Это значит, что RBAR содержит требуемый номер региона и имеет бит VALID, установленный в единицу, см. раздел "MPU->RBAR". Это применимо, если данные упакованы статически, например, в начальном загрузчике:

; R1 = адрес и номер региона;

; R2 = размер и атрибуты;

LDR R0, =MPU RBAR; 0xE000ED9C, регистр базового адреса MPU

STR R1, [R0, #0x0] ; базовый адрес и номер региона,

; совмещённые с битом VALID, установленным в 1

STR R2, [R0, #0x4]; атрибут региона, размер и разрешение.

Оптимизация при использовании STM инструкции:

; R1 = адрес и номер региона

; R2 = размер и атрибуты

LDR R0,=MPU RBAR ; 0хE000ED9C, регистр базового адреса MPU

STM R0, {R1-R2}; базовый адрес региона, номер региона и бит VALID,

; и атрибут региона, размер и разрешение.

### Подрегионы

Регионы величиной в 256 байт или более делятся на восемь равных подрегионов. Установите соответствующий бит в поле SRD регистра RASR для запрещения подрегиона, см. раздел "MPU->RASR". Младший значащий бит SRD контролирует первый подрегион, и старший значащий бит контролирует последний подрегион. Запрещение подрегиона означает, что другой регион перекрывает запрещённую область. Если другой разрешённый регион не перекрывает запрещённый регион, то MPU вырабатывает ошибку.

Регионы размером 32, 64 и 128 не поддерживают подрегионы, с этими регионами вы должны установить поле SRD равным 0x00, иначе поведение MPU непредсказуемо.

#### Пример применения SRD

Два региона с одинаковым базовым адресом перекрываются. Регион размером 128 Кбайт и регион размером 512 Кбайт. Убедитесь, что атрибуты для региона один установлены для первых 128 Кбайт, установите SRD поле для региона два в значение b00000011 для запрещения первых двух подрегионов, как показано на рисунке ниже.



Рисунок 11-1 - Применение SRD

#### 11.2 Советы и особенности применения MPU

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

Убедитесь, что программное обеспечение использует корректный доступ, соответствующий размеру регистров MPU:

- за исключением RASR, необходимо использовать доступ по словам;
- для RASR может использоваться доступ по байтам, полусловам или словам.

Процессор не поддерживает невыровненный доступ к регистрам MPU.

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

#### Конфигурация МРИ для микроконтроллера

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

Таблица 11–12 – Атрибуты регионов памяти для микроконтроллера

| Регион памяти   | TEX  | С | В | S | Типа памяти и атрибут                          |
|-----------------|------|---|---|---|------------------------------------------------|
| Флеш-память     | b000 | 1 | 0 | 0 | Обычная память, не общий доступ, сквозная      |
|                 |      |   |   |   | запись                                         |
| Внутренняя SRAM | b000 | 1 | 0 | 1 | Обычная память, общий доступ, сквозная запись  |
| Внешняя SRAM    | b000 | 1 | 1 | 1 | Обычная память, общий доступ, обратная запись, |
|                 |      |   |   |   | выделенная запись                              |
| Периферия       | b000 | 0 | 1 | 1 | Память устройства, общий доступ                |

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

#### 12 Сигналы тактовой частоты

Микроконтроллер имеет 2 встроенных генератора, 2 внешних осциллятора и специализированный блок формирования тактовой синхронизации микроконтроллера.



Рисунок 12-1 - Структурная блок-схема формирования тактовой частоты

### Встроенный RC-генератор HSI

Генератор HSI вырабатывает тактовую частоту  $f_{O_HSI}$ . Генератор автоматически запускается при появлении питания Ucc и при выходе в нормальный режим работы вырабатывает сигнал HSIRDY в регистре батарейного домена BKP\_REG\_0F. Первоначально процессорное ядро запускается на тактовой частоте HSI. При дальнейшей работе генератор HSI может быть отключен при помощи сигнала HSION в регистре BKP\_REG\_0F. Также генератор может быть подстроен при помощи сигнала HSITRIM в регистре BKP\_REG\_0F.

#### Встроенный RC-генератор LSI

Генератор LSI вырабатывает тактовую частоту  $f_{O_LSI}$ . Генератор автоматически запускается при появлении питания Ucc и при выходе в нормальный режим работы вырабатывает сигнал LSIRDY в регистре BKP\_REG\_0F. Первоначально тактовая частота генератор LSI используется для формирования дополнительной задержки tpor. При дальнейшей работе генератор LSI может быть отключен при помощи сигнала LSION в регистре BKP\_REG\_0F.

### Внешний осциллятор HSE

Осциллятор HSE предназначен для выработки тактовой частоты 2...16 МГц с помощью внешнего резонатора. Осциллятор запускается при появлении питания Ucc и сигнала разрешения HSEON в регистре HS\_CONTROL. При выходе в нормальный режим работы вырабатывает сигнал HSERDY в регистре CLOCK\_STATUS. Также осциллятор может работать в режиме HSEBYP, когда входная тактовая частота с входа OSC\_IN проходит напрямую на выход HSE. Выход OSC\_OUT находится в этом режиме в третьем состоянии.

### Внешний осциллятор LSE

Осциллятор LSE предназначен для выработки тактовой частоты 32 КГц с помощью внешнего резонатора. Осциллятор запускается при появлении питания  $U_{CCBD}$  и сигнала разрешения LSEON в регистре BKP\_REG\_0F . При выходе в нормальный режим работы вырабатывает сигнал LSERDY в регистре BKP\_REG\_0F. Также осциллятор может работать в режиме LSEBYP, когда входная тактовая частота с входа OSC\_IN32 проходит напрямую на выход LSE. Выход OSC\_OUT32 находится в этом режиме третьем состоянии. Так как генератор LSE питается от напряжения питания  $U_{CCBD}$  и его регистр управления BKP\_REG\_0F расположен в батарейном домене, то генератор может продолжать работать при пропадании основного питания  $U_{CC}$ . Генератор LSE используется для работы часов реального времени.

### Встроенный блок умножения системной тактовой частоты

Блок умножения позволяет провести умножение входной тактовой частоты на коэффициент от 2 до 16, задаваемых на входе PLLCPUMUL[3:0] в регистре PLL\_CONTROL. При выходе блока умножителя тактовой частоты в расчетный режим вырабатывается сигнал PLLCPURDY в регистре CLOCK\_STATUS. Блок включается с помощью сигнала PLLCPUON в регистре PLL\_CONTROL. Выходная частота используется как основная частота процессора и периферии.

### Встроенный блок умножения системной тактовой частоты DSP

Блок умножения позволяет провести умножение входной тактовой частоты на коэффициент от 2 до 16, задаваемых на входе PLLDSPMUL[3:0] в регистре PLL\_CONTROL. При выходе блока умножителя тактовой частоты в расчетный режим вырабатывается сигнал PLLDSPRDY в регистре CLOCK\_STATUS. Блок включается с помощью сигнала PLLDSPON в регистре PLL\_CONTROL. Выходная частота используется как основная частота подсистемы DSP.

#### Встроенный блок умножения тактовой частоты USB

Блок умножения позволяет провести умножение входной тактовой частоты на коэффициент от 2 до 16, задаваемых на входе PLLUSBMUL[3:0] в регистре PLL\_CONTROL. Выходная частота блока умножителя должна составлять 48 МГц. При выходе блока умножителя тактовой частоты в расчетный режим вырабатывается сигнал PLLUSBRDY в регистре CLOCK\_STATUS. Блок включается с помощью сигнала PLLUSBON в регистре PLL\_CONTROL. Выходная частота используется как основная частота протокольной части USB интерфейса.

#### 12.1 Описание регистров блока контроллера тактовой частоты

Управление тактовыми частотами ведется через периферийный блок RST\_CLK. При включении питания микроконтроллер запускается на частоте HSI генератора. Выдача тактовых сигналов синхронизации для всех периферийных блоков кроме RST\_CLK отключена. Для начала работы с нужным периферийным

блоком необходимо включить его тактовую частоту в регистре PER\_CLOCK. Некоторые контроллеры интерфейсов (UART, USB, Таймеры) могут работать на частотах отличных от частоты процессорного ядра, по этому в соответствующих регистрах (UART\_CLOCK, USB\_CLOCK, TIM\_CLOCK) могут быть заданы их скорости работы. Для изменения тактовой частоты ядра можно перейти на другой генератор и/или воспользоваться блоком умножения тактовой частоты. Для корректной смены тактовой частоты сначала должны быть сформированы необходимые тактовые частоты и за тем осуществлено переключение на них на соответствующих мультиплексорах управляемых регистрами CPU\_CLOCK и USB\_CLOCK.

Таблица 12–1 – Описание регистров блока контроллера тактовой частоты

| Базовый<br>Адрес | Название           | Описание                                                                                            |
|------------------|--------------------|-----------------------------------------------------------------------------------------------------|
| 0x4002_0000      | MDR_RST_CLK        | Контроллер тактовой частоты                                                                         |
| Смещение         |                    |                                                                                                     |
| 0x00             | CLOCK_STATUS       | MDR_RST_CLK->CLOCK_STATUS Регистр состояния блока управления тактовой частотой                      |
| 0x04             | PLL_CONTROL        | MDR_RST_CLK->PLL_CONTROL<br>Регистр управления блоками умножения частоты                            |
| 0x08             | HS_CONTROL         | MDR_RST_CLK->HS_CONTROL Регистр управления высокочастотным генератором и осциллятором               |
| 0x0C             | CPU_CLOCK          | MDR_RST_CLK->CPU_CLOCK Регистр управления тактовой частотой процессорного ядра                      |
| 0x10             | USB_CLOCK          | MDR_RST_CLK->USB_CLOCK Регистр управления тактовой частотой контроллера USB                         |
| 0x14             | ADC_MCO_CLOCK      | MDR_RST_CLK->ADC_MCO_CLOCK Регистр управления тактовой частотой АЦП                                 |
| 0x18             | RTC_CLOCK          | MDR_RST_CLK->RTC_CLOCK Регистр управления формированием высокочастотных тактовых сигналов блока RTC |
| 0x1C             | PER_CLOCK          | MDR_RST_CLK->PER_CLOCK Регистр управления тактовой частотой периферийных блоков                     |
| 0x20             | -                  | Зарезервировано                                                                                     |
| 0x24             | TIM_CLOCK          | MDR_RST_CLK->TIM_CLOCK Регистр управления тактовой частотой TIMER                                   |
| 0x28             | UART_CLOCK         | MDR_RST_CLK->UART_CLOCK Регистр управления тактовой частотой UART                                   |
| 0x2C             | SSP_CLOCK          | MDR_RST_CLK->SSP_CLOCK Регистр управления тактовой частотой SSP                                     |
| 0x30             | DSP_CLOCK          | Регистр управления тактовой частотой контроллера DSP                                                |
| 0x34             | SSP_CLOCK2         | Регистр управления тактовой частотой SSP                                                            |
| 0x38             | DSP_CONTROL_STATUS | Регистр управления DSP<br>См. Контроллер блока DSP                                                  |

### 12.1.1 MDR\_RST\_CLK->CLOCK\_STATUS

## Таблица 12-2 - Регистр CLOCK\_STATUS

| Номер  | 314 | 3                 | 2          | 1                 | 0                 |
|--------|-----|-------------------|------------|-------------------|-------------------|
| Доступ | U   | RO                | RO         | RO                | RO                |
| Сброс  | 0   | 0                 | 0          | 0                 | 0                 |
|        | -   | PLL<br>DSP<br>RDY | HSE<br>RDY | PLL<br>CPU<br>RDY | PLL<br>USB<br>RDY |

### Таблица 12-3 - Описание бит регистра CLOCK\_STATUS

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 314       | -                          | Зарезервировано                                                                            |
| 3         | PLL                        | Флаг выхода в рабочий режим DSP PLL                                                        |
|           | DSP                        | 0 – PLL не запущена или не стабильна                                                       |
|           | RDY                        | 1 – PLL запущена и стабильна                                                               |
| 2         | HSE                        | Флаг выхода в рабочий режим осциллятора HSE:                                               |
|           | RDY                        | 0 – осциллятор не запущен или не стабилен;                                                 |
|           |                            | 1 – осциллятор запущен и стабилен                                                          |
| 1         | PLL                        | Флаг выхода в рабочий режим CPU PLL:                                                       |
|           | CPU                        | 0 – PLL не запущена или не стабильна;                                                      |
|           | RDY                        | 1 – PLL запущена и стабильна                                                               |
| 0         | PLL                        | Флаг выхода в рабочий режим USB PLL:                                                       |
|           | USB                        | 0 – PLL не запущена или не стабильна;                                                      |
|           | RDY                        | 1 – PLL запущена и стабильна                                                               |

### 12.1.2 MDR\_RST\_CLK->PLL\_CONTROL

### Таблица 12-4 - Регистр PLL\_CONTROL

| Номер  | 3124 | 2320       | 19,18 | 17         | 16         | 1512 |
|--------|------|------------|-------|------------|------------|------|
| Доступ | U    | R/W        | U     | R/W        | R/W        | U    |
| Сброс  | 0    |            | 0     | 0          |            |      |
|        | -    | PLL<br>DSP | -     | PLL<br>DSP | PLL<br>DSP | _    |
|        |      | MUL[3:0]   |       | RLD        | ON         |      |

| Номер  | 118      | 74       | 3   | 2   | 1   | 0   |
|--------|----------|----------|-----|-----|-----|-----|
| Доступ | R/W      | R/W      | R/W | R/W | R/W | R/W |
| Сброс  | 0        | 0        | 0   | 0   | 0   | 0   |
|        | PLL      | PLL      | PLL | PLL | PLL | PLL |
|        | CPU      | USB      | CPU | CPU | USB | USB |
| 1      | MUL[3:0] | MUL[3:0] | RLD | ON  | RLD | ON  |

## Таблица 12-5 - Описание бит регистра PLL\_CONTROL

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3124 | -              | Зарезервировано                                 |
| 2320 | PLL            | Коэффициент умножения для DSP PLL:              |
|      | DSP            | PLLDSPo = PLLDSPi x (PLLDSPMUL+1)               |
|      | MUL[3:0]       | , , , , , , , , , , , , , , , , , , ,           |

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое        |
|------|----------------|--------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений             |
| 1918 | -              | Зарезервировано                                        |
| 17   | PLL            | Бит перезапуска DSP PLL                                |
|      | DSP            | При смене коэффициента умножения в рабочем режиме      |
|      | RLD            | необходимо задать равным 1, а после этого сбросить в 0 |
| 16   | PLL            | Бит включения DSP PLL                                  |
|      | DSP            | 0 – PLL выключена                                      |
|      | ON             | 1 – PLL включена                                       |
| 1512 | -              | Зарезервировано                                        |
| 118  | PLL            | Коэффициент умножения для CPU PLL:                     |
|      | CPU            | PLLCPUo = PLLCPUi x (PLLCPUMUL+1)                      |
|      | MUL[3:0]       |                                                        |
| 74   | PLL            | Коэффициент умножения для USB PLL:                     |
|      | USB            | PLLUSBo = PLLUSBi x (PLLUSBMUL+1)                      |
|      | MUL[3:0]       |                                                        |
| 3    | PLL            | Бит перезапуска CPU PLL.                               |
|      | CPU            | При смене коэффициента умножения в рабочем режиме      |
|      | RLD            | необходимо задать равным 1, а после этого сбросить в 0 |
| 2    | PLL            | Бит включения CPU PLL:                                 |
|      | CPU            | 0 – PLL выключена;                                     |
|      | ON             | 1 – PLL включена                                       |
| 1    | PLL            | Бит перезапуска USB PLL.                               |
|      | USB            | При смене коэффициента умножения в рабочем режиме      |
|      | RLD            | необходимо задать равным 1, а после этого сбросить в 0 |
| 0    | PLL            | Бит включения USB PLL:                                 |
|      | USB            | 0 – PLL выключена;                                     |
|      | ON             | 1 – PLL включена                                       |

## 12.1.3 MDR\_RST\_CLK->HS\_CONTROL

### Таблица 12-6 - Регистра HS\_CONTROL

| Номер  | 312 | 1   | 0   |
|--------|-----|-----|-----|
| Доступ | U   | R/W | R/W |
| Сброс  | 0   | 0   | 0   |
|        |     | HSE | HSE |
|        | -   | BYP | ON  |

# Таблица 12-7 - Описание бит регистра HS\_CONTROL

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений   |
|-----------|-------------------------|----------------------------------------------------------------------------------------------|
| 312       | •                       | Зарезервировано                                                                              |
| 1         | HSE<br>BYP              | Бит управления HSE осциллятором :<br>0 – режим осциллятора;<br>1 – режим внешнего генератора |
| 0         | HSE<br>ON               | Бит управления HSE осциллятором:<br>0 – выключен;<br>1 – включен                             |

# 12.1.4 MDR\_RST\_CLK->CPU\_CLOCK

## Таблица 12-8 - Регистр CPU\_CLOCK

| Номер  | 3110 | 98               | 74                    | 3 | 2                | 10                    |
|--------|------|------------------|-----------------------|---|------------------|-----------------------|
| Доступ | U    | R/W              | R/W                   | U | R/W              | R/W                   |
| Сброс  | 0    | 0                | 0                     | 0 | 0                | 0                     |
|        | -    | HCLK<br>SEL[1:0] | CPU<br>C3<br>SEL[3:0] | - | CPU<br>C2<br>SEL | CPU<br>C1<br>SEL[1:0] |

# Таблица 12–9 – Описание бит регистра CPU\_CLOCK

| Nº   | Функциональное        | Расшифровка функционального имени бита, краткое                                                                                                                             |
|------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита              | описание назначения и принимаемых значений                                                                                                                                  |
| 3110 | -                     | Зарезервировано                                                                                                                                                             |
| 98   | HCLK<br>SEL[1:0]      | Биты выбора источника для HCLK:  00 – HSI  01 – CPU_C3  10 – LSE  11 – LSI                                                                                                  |
| 74   | CPU<br>C3<br>SEL[3:0] | Биты выбора делителя для CPU_C3:  0xxx - CPU_C3 = CPU_C2  1000 - CPU_C3 = CPU_C2 / 2  1001 - CPU_C3 = CPU_C2 / 4  1010 - CPU_C3 = CPU_C2 / 8   1111 - CPU_C3 = CPU_C2 / 256 |
| 3    | -                     | Зарезервировано                                                                                                                                                             |
| 2    | CPU<br>C2<br>SEL      | Биты выбора источника для CPU_C2: 0 – CPU_C1 1 – PLLCPUo                                                                                                                    |
| 10   | CPU<br>C1<br>SEL[1:0] | Биты выбора источника для CPU_C1: 00 – HIS 01 – HSI/2 10 – HSE 11 – HSE/2                                                                                                   |

## 12.1.5 MDR\_RST\_CLK->USB\_CLOCK

# Таблица 12-10 - Регистр USB\_CLOCK

| Номер  | 319 | 8   | 75 | 4   | 3 | 2   | 10       |
|--------|-----|-----|----|-----|---|-----|----------|
| Доступ | U   | R/W | U  | R/W | U | R/W | R/W      |
| Сброс  | 0   | 0   | 0  | 0   | 0 | 0   | 0        |
|        |     | USB |    | USB |   | USB | USB      |
|        | -   | CLK | -  | C3  | - | C2  | C1       |
|        |     | EN  |    | SEL |   | SEL | SEL[1:0] |

## Таблица 12-11 - Описание бит регистра USB\_CLOCK

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 319  | •              | Зарезервировано                                 |
| 8    | USB            | Бит разрешения тактирования USB:                |
|      | CLK            | 0 – нет тактовой частоты;                       |
|      | EN             | 1 – есть тактовая частота                       |
| 75   | -              | Зарезервировано                                 |
| 4    | USB            | Биты выбора делителя для USB_C3:                |
|      | C3             | 0 – USB_C3 = USB _C2                            |
|      | SEL            | 1 – USB _C3 = USB _C2 / 2                       |
| 3    | -              | Зарезервировано                                 |
| 2    | USB            | Биты выбора источника для USB_C2:               |
|      | C2             | 0 – USB_C1                                      |
|      | SEL            | 1 – PLLUSBo                                     |
| 10   |                | Биты выбора источника для USB_C1:               |
|      | USB            | 00 – HSI                                        |
|      | C1             | 01 – HSI/2                                      |
|      | SEL[1:0]       | 10 – HSE                                        |
|      |                | 11 – HSE/2                                      |

## 12.1.6 MDR\_RST\_CLK->ADC\_MCO\_CLOCK

# Таблица 12-12 - Регистр ADC\_MCO\_CLOCK

| Номер  | 3114 | 13  | 12 | 118      | 76 | 54       | 32 | 10       |
|--------|------|-----|----|----------|----|----------|----|----------|
| Доступ | U    | R/W | U  | R/W      | U  | R/W      | U  | R/W      |
| Сброс  | 0    | 0   | 0  | 0        | 0  | 0        | 0  | 0        |
|        |      | ADC |    | ADC      |    | ADC      |    | ADC      |
|        | -    | CLK | -  | C3       | -  | C2       | -  | C1       |
|        |      | EN  |    | SEL[3:0] |    | SEL[1:0] |    | SEL[1:0] |

# Таблица 12–13 – Описание бит регистра ADC\_MCO\_CLOCK

| Nº    |            | Расшифровка функционального имени бита, краткое   |
|-------|------------|---------------------------------------------------|
| бита  | имя бита   | описание назначения и принимаемых значений        |
| 31    | AUC_CLK_EN | Бит разрешения выдачи тактовой частоты AUC CLK:   |
|       |            | 0 – запрещен;                                     |
|       |            | 1 – разрешен                                      |
| 3028  | -          | Зарезервировано                                   |
| 2724  | AUC_SEL3   | Биты выбора делителя для AUC_C3:                  |
|       |            | $0xxx - AUC\_C3 = AUC\_C2$                        |
|       |            | 1000 - AUC_C3 = AUC_C2 / 2                        |
|       |            | 1001 - AUC_C3 = AUC_C2 / 4                        |
|       |            | 1010 - AUC_C3 = AUC_C2 / 8                        |
|       |            |                                                   |
| 00.00 |            | 1111 - AUC_C3 = AUC_C2 / 256                      |
| 2322  | -          | Зарезервировано                                   |
| 2120  | AUC_SEL2   | Биты выбора источника для AUC_C2:                 |
|       |            | 00 – AUC_C1                                       |
|       |            | 01 – CPU_C2                                       |
|       |            | 10 – USB_C2                                       |
| 1918  |            | 11 – DSP_C2                                       |
| 1716  | AUC SEL1   | Зарезервировано Биты выбора источника для AUC_C1: |
| 1716  | AUC_SELI   | оо – HSI                                          |
|       |            | 01 – HSI/2                                        |
|       |            | 10 – HSE                                          |
|       |            | 11 – HSE/2                                        |
| 1514  | _          | Зарезервировано                                   |
| 13    | ADC        | Бит разрешения выдачи тактовой частоты ADC CLK:   |
| .0    | CLK        | 0 – запрещен;                                     |
|       | EN         | 1 – разрешен                                      |
| 12    | -          | Зарезервировано                                   |
| 118   |            | Биты выбора делителя для ADC_C3:                  |
|       |            | $0xxx - ADC_C3 = ADC_C2$                          |
|       | ADC        | 1000 - ADC_C3 = ADC _C2 / 2                       |
|       | C3         | 1001 - ADC_C3 = ADC _C2 / 4                       |
|       | SEL[3:0]   | 1010 - ADC_C3 = ADC _C2 / 8                       |
|       |            | <br>1111 - ADC_C3 = ADC _C2 / 256                 |
| 76    | -          | Зарезервировано                                   |

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 54        |                         | Биты выбора источника для ADC_C1:                                                          |
|           | ADC                     | 00 – LSE                                                                                   |
|           | C2                      | 01 – LSI                                                                                   |
|           | SEL[1:0]                | 10 – ADC_C1                                                                                |
|           |                         | 11 – HSI_C1                                                                                |
| 32        | -                       | Зарезервировано                                                                            |
| 10        |                         | Биты выбора источника для ADC_C1:                                                          |
|           | ADC                     | 00 - CPU_C1                                                                                |
|           | C1                      | 01 – USB_C1                                                                                |
|           | SEL[1:0]                | 10 - CPU_C2                                                                                |
|           |                         | 11 – USB_C2                                                                                |

#### 12.1.7 MDR\_RST\_CLK->RTC\_CLOCK

## Таблица 12-14 - Регистр RTC\_CLOCK

| Номер  | 3110 | 9                | 8                | 74              | 30              |
|--------|------|------------------|------------------|-----------------|-----------------|
| Доступ | U    | R/W              | R/W              | R/W             | R/W             |
| Сброс  | 0    | 0                | 0                | 0               | 0               |
|        | -    | HSI<br>RTC<br>EN | HSE<br>RTC<br>EN | HSI<br>SEL[1:0] | HSE<br>SEL[1:0] |

# Таблица 12-15 - Описание бит регистра RTC\_CLOCK

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3110 | -              | Зарезервировано                                 |
| 9    | HSI            | Бит разрешения HSI RTC:                         |
|      | RTC            | 0 – запрещён;                                   |
|      | EN             | 1 – разрешён                                    |
| 8    | HSE            | Бит разрешения HSE RTC:                         |
|      | RTC            | 0 – запрещён;                                   |
|      | EN             | 1 – разрешён                                    |
| 74   | HSI            | Биты выбора делителя для HSI_C1:                |
|      | SEL[3:0]       | 0xxx – RTCHSI = HSI _C2                         |
|      |                | 1000 - RTCHSI = HSI _C2 / 2                     |
|      |                | 1001 - RTCHSI = HSI _C2 / 4                     |
|      |                | 1010 - RTCHSI = HSI _C2 / 8                     |
|      |                |                                                 |
|      |                | 1111 - RTCHSI = HSI _C2 / 256                   |
| 30   |                | Биты выбора делителя для HSE_C1:                |
|      |                | 0xxx – RTCHSE = HSE _C2                         |
|      | HSE            | 1000 - RTCHSE = HSE _C2 / 2                     |
|      | SEL[3:0]       | 1001 - RTCHSE = HSE _C2 / 4                     |
|      | 3LL[3.0]       | 1010 - RTCHSE = HSE _C2 / 8                     |
|      |                |                                                 |
|      |                | 1111 - RTCHSE = HSE _C2 / 256                   |

## 12.1.8 MDR\_RST\_CLK->PER\_CLOCK

# Таблица 12-16 - Регистр PER\_CLOCK

| Номер  | 310           |
|--------|---------------|
| Доступ | R/W           |
| Сброс  | 0             |
|        | PCLK_EN[31:0] |

# Таблица 12-17 - Описание бит регистра PER\_CLOCK

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 310       | PCLK                       | Биты разрешения тактирования периферийных блоков:                                          |
| 010       | EN[31:0]                   | 0 – запрещено;                                                                             |
|           | 211[01:0]                  | 1 – разрешено.                                                                             |
|           |                            | г расрошене.                                                                               |
|           |                            | PCLK[0] - SSP3                                                                             |
|           |                            | PCLK[1] - SSP4                                                                             |
|           |                            | PCLK[2] – USB                                                                              |
|           |                            | PCLK[3] – EEPROM_CNTRL                                                                     |
|           |                            | PCLK[4] – RST_CLK                                                                          |
|           |                            | PCLK[5] – DMA                                                                              |
|           |                            | PCLK[6] – UART1                                                                            |
|           |                            | PCLK[7] – UART2                                                                            |
|           |                            | PCLK[8] – SPI1                                                                             |
|           |                            | PCLK[9] – SDI0                                                                             |
|           |                            | PCLK[10] – I2C1                                                                            |
|           |                            | PCLK[11] – POWER                                                                           |
|           |                            | PCLK[12] – WWDT                                                                            |
|           |                            | PCLK[13] – IWDT                                                                            |
|           |                            | PCLK[14] – TIMER1                                                                          |
|           |                            | PCLK[15] – TIMER2                                                                          |
|           |                            | PCLK[16] – TIMER3                                                                          |
|           |                            | PCLK[17] – ADC                                                                             |
|           |                            | PCLK[18] – DAC                                                                             |
|           |                            | PCLK[19] – COMP                                                                            |
|           |                            | PCLK[20] – SPI2                                                                            |
|           |                            | PCLK[21] – PORTA                                                                           |
|           |                            | PCLK[22] – PORTB                                                                           |
|           |                            | PCLK[23] – PORTC                                                                           |
|           |                            | PCLK[24] – PORTD                                                                           |
|           |                            | PCLK[25] – PORTE                                                                           |
|           |                            | PCLK[26] – UART3                                                                           |
|           |                            | PCLK[27] – BKP                                                                             |
|           |                            | PCLK[28] – AUDIO CODEC                                                                     |
|           |                            | PCLK[29] – PORTF                                                                           |
|           |                            | PCLK[30] – EXT_BUS_CNTRL                                                                   |
|           |                            | PCLK[31] – CRYPTO                                                                          |

## 12.1.9 MDR\_RST\_CLK->TIM\_CLOCK

# Таблица 12-18 - Регистр TIM\_CLOCK

| Номер  | 3127 | 26   | 25   | 24   | 2316  | 158   | 70    |
|--------|------|------|------|------|-------|-------|-------|
| Доступ | U    | R/W  | R/W  | R/W  | R/W   | R/W   | R/W   |
| Сброс  | 0    | 0    | 0    | 0    | 0     | 0     | 0     |
|        |      | TIM3 | TIM2 | TIM1 | TIM3  | TIM2  | TIM1  |
|        | -    | CLK  | CLK  | CLK  | BRG   | BRG   | BRG   |
|        |      | EN   | EN   | EN   | [7:0] | [7:0] | [7:0] |

# Таблица 12–19 – Описание бит регистра TIM\_CLOCK

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3127 | -              | Зарезервировано                                 |
| 26   | TIM3           | Разрешение тактовой частоты на TIM3:            |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 25   | TIM2           | Разрешение тактовой частоты на TIM2:            |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 24   | TIM1           | Разрешение тактовой частоты на TIM1:            |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 2316 | TIM3           | Делитель тактовой частоты TIM3:                 |
|      | BRG            | xxxxx000 - TIM3_CLK == HCLK                     |
|      | [7:0]          | xxxxx001 – TIM3_CLK == HCLK/2                   |
|      |                | xxxxx010 – TIM3_CLK == HCLK/4                   |
|      |                | •••                                             |
|      |                | xxxxx111 – TIM3_CLK == HCLK/128                 |
| 158  | TIM2           | Делитель тактовой частоты TIM2:                 |
|      | BRG            | xxxxx000 - TIM2_CLK == HCLK                     |
|      | [7:0]          | xxxxx001 – TIM2_CLK == HCLK/2                   |
|      |                | xxxxx010 – TIM2_CLK == HCLK/4                   |
|      |                | •••                                             |
|      |                | xxxxx111 – TIM2_CLK == HCLK/128                 |
| 70   | TIM1           | Делитель тактовой частоты TIM1:                 |
|      | BRG            | xxxxx000 - TIM1_CLK == HCLK                     |
|      | [7:0]          | xxxxx001 – TIM1_CLK == HCLK/2                   |
|      |                | xxxxx010 – TIM1_CLK == HCLK/4                   |
|      |                |                                                 |
|      |                | xxxxx111 – TIM1_CLK == HCLK/128                 |

# 12.1.10 MDR\_RST\_CLK->UART\_CLOCK

# Таблица 12-20 - Регистр UART\_CLOCK

| Номер  | 3127 | 26           | 25           | 24           | 2316         | 158           | 70            |
|--------|------|--------------|--------------|--------------|--------------|---------------|---------------|
| Доступ | U    | R/W          | R/W          | R/W          | U            | R/W           | R/W           |
| Сброс  | 0    | 0            | 0            | 0            | 0            | 0             | 0             |
|        |      |              |              |              |              |               |               |
|        |      | UART3        | UART2        | UART1        | UART3        | UART 2        | UART 1        |
|        | -    | UART3<br>CLK | UART2<br>CLK | UART1<br>CLK | UART3<br>BRG | UART 2<br>BRG | UART 1<br>BRG |

# Таблица 12–21 – Описание бит регистра UART\_CLOCK

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3127 | -              | Зарезервировано                                 |
| 26   | UART3          | Разрешение тактовой частоты на UART3:           |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 25   | UART2          | Разрешение тактовой частоты на UART2:           |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 24   | UART1          | Разрешение тактовой частоты на UART 1:          |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 2316 | UART3          | Делитель тактовой частоты UART 3:               |
|      | BRG            | xxxxx000 – UART 3_CLK == HCLK                   |
|      | [7:0]          | xxxxx001 – UART 3_CLK == HCLK/2                 |
|      |                | xxxxx010 – UART 3_CLK == HCLK/4                 |
|      |                |                                                 |
|      |                | xxxxx111 – UART 3_CLK == HCLK/128               |
| 158  | UART2          | Делитель тактовой частоты UART 2:               |
|      | BRG            | xxxxx000 – UART 2_CLK == HCLK                   |
|      | [7:0]          | xxxxx001 – UART 2_CLK == HCLK/2                 |
|      |                | xxxxx010 – UART 2_CLK == HCLK/4                 |
|      |                |                                                 |
|      |                | xxxxx111 – UART 2_CLK == HCLK/128               |
| 70   | UART1          | Делитель тактовой частоты UART1:                |
|      | BRG            | xxxxx000 – UART 1_CLK == HCLK                   |
|      | [7:0]          | xxxxx001 – UART 1_CLK == HCLK/2                 |
|      |                | xxxxx010 – UART 1_CLK == HCLK/4                 |
|      |                |                                                 |
|      |                | xxxxx111 – UART 1_CLK == HCLK/128               |

# 12.1.11 MDR\_RST\_CLK->SSP\_CLOCK

# Таблица 12-22 - Регистр SSP\_CLOCK

| Номер  | 3127 | 26   | 25   | 24    | 2316  | 158   | 70    |
|--------|------|------|------|-------|-------|-------|-------|
| Доступ | U    | R/W  | R/W  | R/W   | R/W   | R/W   | R/W   |
| Сброс  | 0    | 0    | 0    | 0     | 0     | 0     | 0     |
|        |      | SSP3 | SSP2 | SSP 1 | SSP 3 | SSP 2 | SSP 1 |
|        | -    | CLK  | CLK  | CLK   | BRG   | BRG   | BRG   |
|        |      | EN   | EN   | EN    | [7:0] | [7:0] | [7:0] |

# Таблица 12-23 - Описание бит регистра SSP\_CLOCK

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3127 | -              | Зарезервировано                                 |
| 26   | SSP3           | Разрешение тактовой частоты на SSP 3            |
|      | CLK            | 0 – нет частоты                                 |
|      | EN             | 1 – есть частота                                |
| 25   | SSP2           | Разрешение тактовой частоты на SSP 2:           |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 24   | SSP1           | Разрешение тактовой частоты на SSP 1:           |
|      | CLK            | 0 – нет частоты;                                |
|      | EN             | 1 – есть частота                                |
| 2316 |                | Делитель тактовой частоты SSP 3                 |
|      |                |                                                 |
|      | SSP3           | xxxxx000 – SSP 3_CLK == HCLK                    |
|      | BRG            | xxxxx001 – SSP 3_CLK == HCLK/2                  |
|      | [7:0]          | xxxxx010 – SSP 3_CLK == HCLK/4                  |
|      |                |                                                 |
| 45.0 |                | xxxxx111 – SSP 3_CLK == HCLK/128                |
| 158  |                | Делитель тактовой частоты SSP 2:                |
|      | CCDO           | www.000 CCD 2 CLK LICLK                         |
|      | SSP2           | xxxxx000 - SSP 2_CLK == HCLK                    |
|      | BRG            | xxxxx001 - SSP 2_CLK == HCLK/2                  |
|      | [7:0]          | xxxxx010 - SSP 2_CLK == HCLK/4                  |
|      |                | <br>xxxxx111 - SSP 2_CLK == HCLK/128            |
| 70   |                | Делитель тактовой частоты SSP 1:                |
| /0   |                | HEIMIEND TAKTOBOM MACTOTEL SOF T.               |
|      | SSP1           | xxxxx000 - SSP 1 CLK == HCLK                    |
|      | BRG            | xxxxx000 - SSP 1 CLK == HCLK/2                  |
|      | [7:0]          | xxxxx010 - SSP 1_CLK == HCLK/4                  |
|      | [, .0]         |                                                 |
|      |                | xxxxx111 - SSP 1_CLK == HCLK/128                |
|      |                | 7.000 C3. 1_01.V .1.0                           |

### 12.1.12 MDR\_RST\_CLK->DSP\_CLOCK

## Таблица 12-24 - Регистр DSP\_CLOCK

| Номер  | 319 | 8   | 75 | 4   | 3 | 2   | 10  |
|--------|-----|-----|----|-----|---|-----|-----|
| Доступ | U   | R/W | U  | R/W | U | R/W | R/W |
| Сброс  | 0   |     | 0  | 0   | 0 | 0   | 0   |
|        |     | DSP |    | DSP |   | DSP | DSP |
|        | -   | CLK | -  | C3  | - | C2  | C1  |
|        |     | EN  |    | SEL |   | SEL | SEL |

## Таблица 12-25 - Описание бит регистра DSP\_CLOCK

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3126 | -              | Зарезервировано                                 |
| 8    | DSP            | Бит разрешения тактирования DSP                 |
|      | CLK            | 0 – нет тактовой частоты                        |
|      | EN             | 1 – есть тактовая частота                       |
| 75   | -              | Зарезервировано                                 |
| 4    | DSP            | Биты выбора делителя для DSP_C3                 |
|      | C3             | $DSP_C3 = DSP_C2/(DSP_C3_SEL+1)$                |
|      | SEL            |                                                 |
| 3    | -              | Зарезервировано                                 |
| 2    | DSP            | Биты выбора источника для DSP_C2                |
|      | C2             | 0 – DSP_C1                                      |
|      | SEL            | 1 – PLLDSPo                                     |
| 10   |                | Биты выбора источника для DSP_C1                |
|      | DSP            | 00 – HSI                                        |
|      | C1             | 01 – HSI/2                                      |
|      | SEL            | 10 – HSE                                        |
|      |                | 11 – HSE/2                                      |

### 12.1.13 MDR\_RST\_CLK->SSP\_CLOCK2

## Таблица 12-26 - Регистр SSP\_CLOCK2

| Номер  | 3125 | 24   | 258 | 70    |
|--------|------|------|-----|-------|
| Доступ | U    | R/W  | U   | R/W   |
| Сброс  | 0    | 0    | 0   | 0     |
|        |      | SSP4 |     | SSP 4 |
|        | -    | CLK  | -   | BRG   |
|        |      | EN   |     | [7:0] |

# Таблица 12–27 – Описание бит регистра SSP\_CLOCK2

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                     |
|------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3125             | -                       | Зарезервировано                                                                                                                                                |
| 24               | SSP4                    | Разрешение тактовой частоты на SSP 4                                                                                                                           |
|                  | CLK                     | 0 – нет частоты                                                                                                                                                |
|                  | EN                      | 1 – есть частота                                                                                                                                               |
| 238              | -                       | Зарезервировано                                                                                                                                                |
| 70               | SSP4<br>BRG<br>[7:0]    | Делитель тактовой частоты SSP 4 xxxxxx000 – SSP 4_CLK == HCLK xxxxxx001 – SSP 4_CLK == HCLK/2 xxxxx010 – SSP 4_CLK == HCLK/4 xxxxxx111 – SSP 4_CLK == HCLK/128 |

### 13 Батарейный домен и часы реального времени MDR\_BKP

Блок батарейного домена предназначен для обеспечения функций часов реального времени и сохранения некоторого набора пользовательских данных при отключении основного источника питания. При снижении питания Ucc в блоке SW происходит автоматическое переключение питания Uccb с Ucc на Uccb. Если на Uccb имеется отдельный источник питания (батарейка), то батарейный домен остается включенным и может выполнять свои функции.



Рисунок 13–1 – Структурная блок-схема батарейного домена и часов реального времени

#### 13.1 Часы реального времени

Часы реального времени позволяют организовать механизм отсчета времени в кристалле, в том числе при отключении основного источника питания. Включение часов реального времени осуществляется битом RTCEN. В качестве источника тактовой частоты часов реального времени может выступать генератор LSI, или осциллятор LSE, или HSE, или HSI с дополнительным делителем до 256 (HSE и HSI формируются в блоке управления тактовыми частотами и могут быть выбраны только при наличии питания  $U_{\rm CCD}$ , LSI может быть выбран при наличии питания  $U_{\rm CC}$ , LSE может быть выбран при наличии  $U_{\rm CC}$  или  $U_{\rm CCB}$ ). Выбор между источниками осуществляется битами RTCSEL. При возможном отключении основного источника питания  $U_{\rm CC}$  в качестве источника тактовой частоты должен использоваться осциллятор LSE, так как он также имеет питание  $U_{\rm CCBD}$ . Биты управления осциллятором LSE расположены в батарейном домене и таким образом при отключении основного питания они не сбрасываются.

Для калибровки тактовой частоты используются биты CAL[6:0]. Значение CAL определяет, какое число тактов из  $2^{20}$  будет замаскировано. Таким образом, с помощью бит CAL[6:0] производится замедление хода часов. Изменение значения бит CAL может быть осуществлено в ходе работы часов реального времени.

Регистр RTC\_DIV выступает в роли 20-ти битного предварительного делителя входной тактовой частоты, таким образом, чтобы на его выходе была тактовая частота в 1 Гц. Для задания коэффициента деления регистра RTC\_DIV используется регистр RTC PRL.

Регистр RTC\_CNT предназначен для отсчета времени в секундах и работает на выходной частоте делителя RTC\_DIV. Регистр RTC\_ALR предназначен для задания времени, при совпадении с которым вырабатывается флаг прерывания и пробуждения процессора. Таким образом, бит STANDBY, отключающий внутренний регулятор напряжения, автоматически сбрасывается при совпадении RTC\_CNT и RTC\_ALR.

Бит STANDBY также может быть сброшен с помощью вывода WAKEUP.

#### 13.2 Регистры аварийного сохранения

Батарейный домен имеет 16 встроенных 32-х разрядных регистров аварийного сохранения. 16-й и 15-й регистры служат для хранения бит управления батарейным доменом, оставшиеся 14 регистров могут быть использованы разработчиком программы.

#### 13.3 Описание регистров блока батарейного домена

Таблица 13-1 - Описание регистров блока батарейного домена

| Базовый Адрес | Название   | Описание                                                |
|---------------|------------|---------------------------------------------------------|
| 0x400D_8000   | MDR_BKP    | Контроллер батарейного домена и часов реального времени |
| Смещение      |            |                                                         |
| 0x00          | REG_[000D] | Регистр MDR_BKP-> REG_[000D] аварийного сохранения      |
|               |            | 0                                                       |
|               |            |                                                         |
| 0x38          | REG_0E     | Регистр MDR_BKP->REG_0E аварийного сохранения 14        |
| 0x3C          | REG_0F     | Регистр MDR_BKP->REG_0F аварийного сохранения 15 и      |
|               |            | управления блоками RTC, LSE, LSI и HSI                  |
| 0x40          | RTC_CNT    | Регистр MDR_BKP->RTC_CNT основного счетчика часов       |
|               |            | реального времени                                       |
| 0x44          | RTC_DIV    | Perистр MDR_BKP->RTC_DIV предварительного делителя      |
|               |            | основного счетчика                                      |
| 0x48          | RTC_PRL    | Регистр MDR_BKP->RTC_PRL основания счета                |
|               |            | предварительного делителя                               |
| 0x4C          | RTC_ALRM   | Регистр MDR_BKP->RTC_ALRM значения для сравнения        |
|               |            | основного счетчика и выработки сигнала ALRF             |
| 0x50          | RTC_CS     | Регистр MDR_BKP->RTC_CS управления и состояния          |
|               |            | флагов часов реального времени                          |

### 13.3.1 *MDR\_BKP-> REG\_[00...0D]*

Здесь приведено описание следующих регистров:

- MDR\_BKP->REG\_00;
- MDR\_BKP->REG\_01;
- MDR BKP->REG 02:
- MDR\_BKP->REG\_03;
- MDR BKP->REG 04;
- MDR\_BKP->REG\_05;
- MDR\_BKP->REG\_06;
- MDR BKP->REG 07;

- MDR\_BKP->REG\_08;
- MDR\_BKP->REG\_09;
- MDR\_BKP->REG\_0A;
- MDR\_BKP->REG\_0B;
- MDR\_BKP->REG\_0C;
- MDR\_BKP->REG\_0D.

### Таблица 13-2 - Регистры REG\_[0D...00]

| Номер  | 310           |
|--------|---------------|
| Доступ | R/W           |
| Сброс  | U             |
|        | BKP REG[31:0] |

### Таблица 13-3 - Описание бит регистров REG\_[0D...00]

| <b>№</b><br>бита |               | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------------------|---------------|--------------------------------------------------------------------------------------------|
| 310              | BKP REG[31:0] | Регистр аварийного сохранения                                                              |

#### 13.3.2 *MDR\_BKP->REG\_0E*

### Таблица 13-4 - Регистр REG\_0E

| Номер<br>Доступ | 3115<br>U | 1412<br>R/W        | 11<br>R/W | 108<br>R/W         | R/W    | R/W    | 53<br>R/W              | 20<br>R/W         |
|-----------------|-----------|--------------------|-----------|--------------------|--------|--------|------------------------|-------------------|
| Сброс           | -         | ∪<br>MODE<br>[2:0] | FPOR      | 0<br>Trim<br>[2:0] | JTAG_B | JTAG_A | 0<br>SelectRI<br>[2:0] | 0<br>LOW<br>[2:0] |

#### Таблица 13-5 - Описание бит регистра REG\_0E

| № бита | Функциональное | Расшифровка функционального имени бита, краткое                                                              |
|--------|----------------|--------------------------------------------------------------------------------------------------------------|
|        | имя бита       | описание назначения и принимаемых значений                                                                   |
| 3115   | ı              | Зарезервировано                                                                                              |
| 1412   | MODE[20]       | Режим работы микроконтроллера, определенный при включении питания по выводам MODE[2:0] (PF[6:4]):            |
|        |                | 000 – микроконтроллер, с отладкой через JTAG_B                                                               |
|        |                | 001 – микроконтроллер, с отладкой через JTAG_A                                                               |
|        |                | 010 – микропроцессор, с отладкой через JTAG_B                                                                |
|        |                | 011 – микропроцессор, с отладкой через JTAG_B                                                                |
|        |                | 100 – зарезервировано                                                                                        |
|        |                | 101 – зарезервировано                                                                                        |
|        |                | 110 – UART загрузчик без отладки                                                                             |
|        |                | 111 – зарезервировано (режим тестирования кристалла)                                                         |
|        |                | Подробнее см. в разделе «Загрузочное ПЗУ и режимы работы                                                     |
|        |                | микроконтроллера».                                                                                           |
|        |                | При смене режима работы в данном регистре, изменение вступит в силу после сброса процессора через RESET, при |
|        |                | сбросе по просадке питания режим будет определяться                                                          |
|        |                | выводами MODE[2:0]                                                                                           |
| 11     | FPOR           | Флаг срабатывания POR.                                                                                       |
|        |                | Устанавливается в 1 загрузочным ПЗУ при первоначальном                                                       |
|        |                | включении по появлению питания U <sub>CC</sub> , при сбросе по питанию                                       |
|        |                | устанавливается в 0. Служит для анализа загрузочным ПЗУ, что                                                 |
|        |                | сейчас идет выполнение программы после системного или                                                        |
|        |                | программного сброса, либо после сброса по питанию                                                            |

| № бита | Функциональное |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | имя бита       | описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 108    | Trim[2:0]      | Коэффициент настройки опорного напряжения встроенного регулятора напряжения U <sub>CCD</sub> . С помощью Trim осуществляется подстройка напряжения U <sub>CCD</sub> :  000 – U <sub>CCD</sub> + 0,10 B – значение по умолчанию.  001 – U <sub>CCD</sub> + 0,06 B                                                                                                                                                                                                                                                                                                 |
|        |                | 010 - U <sub>CCD</sub> + 0,04 B<br>011 - U <sub>CCD</sub> + 0,01 B<br>100 - U <sub>CCD</sub> - 0,01 B<br>101 - U <sub>CCD</sub> - 0,04 B<br>110 - U <sub>CCD</sub> - 0,06 B<br>111 - U <sub>CCD</sub> - 0,10 B                                                                                                                                                                                                                                                                                                                                                   |
| 7      | JTAG B         | Разрешение работы порта JTAG B:  0 – запрещён;  1 – разрешён. При одновременной установке JTAG B и JTAG A выбирается режим отбраковочного тестирования микросхемы, при этом она                                                                                                                                                                                                                                                                                                                                                                                  |
|        |                | не функционирует как микроконтроллер                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6      | JTAG A         | Разрешение работы порта JTAG A:  0 – запрещён;  1 – разрешён                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 53     | SelectRI[2:0]  | Выбор дополнительной стабилизирующей нагрузки для встроенного регулятора напряжения U <sub>CCD</sub> :  000 — ~ 6 кОм (дополнительный ток потребления 300 мкА)  001 — ~ 270 кОм (дополнительный ток потребления 6,6 мкА)  010 — ~ 90 кОм (дополнительный ток потребления 20 мкА)  011 — ~ 24 кОм (дополнительный ток потребления 80 мкА)  100 — ~ 900 кОм (собственное потребление 2 мкА)  101 — ~ 2 кОм (дополнительный ток потребления 900 мкА)  110 — ~ 400 Ом (дополнительный ток потребления 4,4 мА)  111 — ~ 100 Ом (дополнительный ток потребления 19 мА) |
| 20     | LOW[2:0]       | Выбор режима работы встроенного регулятора напряжения Ucct Значение LOW должно совпадать со значением SelectRI и выставляться в зависимости от тактовой частоты микроконтроллера:  000 — частота до 10 МГц 001 — частота до 200 КГц 010 — частота до 500 КГц 011 — частота до 1 МГц 100 — при выключении всех генераторов 101 — частота до 40 МГц 110 — частота до 80 МГц 111 — частота более 80 МГц                                                                                                                                                             |

# 13.3.3 *MDR\_BKP->REG\_0F*

# Таблица 13-6 - Регистр REG\_0F

| Номер  | 15  | 14 | 13  | 125   | 4   | 3, 2     | 1   | 0   |
|--------|-----|----|-----|-------|-----|----------|-----|-----|
| Доступ | R/W | U  | RO  | R/W   | R/W | R/W      | R/W | R/W |
| Сброс  | 1   | 0  | 0   | 0     | 0   | 0        | 0   | 0   |
|        | LSI |    | LSE | CAL   | RTC | RTC      | LSE | LSE |
|        | ON  | -  | RDY | [7:0] | EN  | SEL[1:0] | BYP | ON  |

| Номер  | 31           | 30      | 2924              | 23         | 22        | 21         | 2016              |
|--------|--------------|---------|-------------------|------------|-----------|------------|-------------------|
| Доступ | R/W          | R/W     | R/W               | RO         | R/W       | RO         | R/W               |
| Сброс  | 0            | 0       | 100000            | 1          | 1         | 1          | 10000             |
|        | RTC<br>RESET | STANDBY | HSI<br>TRIM [5:0] | HSI<br>RDY | HSI<br>ON | LSI<br>RDY | LSI<br>TRIM [4:0] |

# Таблица 13-7 - Описание бит регистра REG\_0F

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                              |  |  |
|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31               | RTC RESET               | Сброс часов реального времени:                                                                                                                                          |  |  |
|                  |                         | 0 – часы не сбрасываются;                                                                                                                                               |  |  |
|                  |                         | 1 – часы сбрасываются                                                                                                                                                   |  |  |
| 30               | STANDBY                 | Режим отключения регулятора Uccd:                                                                                                                                       |  |  |
|                  |                         | 0 – регулятор включен и выдает напряжение;                                                                                                                              |  |  |
|                  |                         | 1 – регулятор выключен                                                                                                                                                  |  |  |
|                  |                         | Триггер сбрасывается флагом ALRF или по низкому уровню на выводе WAKEUP                                                                                                 |  |  |
| 2924             | HSI                     | Коэффициент подстройки частоты генератора HSI.                                                                                                                          |  |  |
|                  | TRIM[5:0]               | Смотрите диаграмму зависимости (Рисунок 13–3)                                                                                                                           |  |  |
| 23               | HSI                     | Флаг выхода генератора HSI в рабочий режим:                                                                                                                             |  |  |
|                  | RDY                     | 0 – генератор не запущен или не вышел в режим;                                                                                                                          |  |  |
|                  |                         | 1 – генератор работает в рабочем режиме                                                                                                                                 |  |  |
| 22               | HSI                     | Бит управления генератором HSI:                                                                                                                                         |  |  |
|                  | ON                      | 0 – генератор выключен;                                                                                                                                                 |  |  |
| 04               | 1.01                    | 1 – генератор включен                                                                                                                                                   |  |  |
| 21               | LSI<br>RDY              | Флаг выхода генератора LSI в рабочий режим:                                                                                                                             |  |  |
|                  | וטא                     | <ul><li>0 – генератор не запущен или не вышел в режим;</li><li>1 – генератор находится в рабочем режиме</li></ul>                                                       |  |  |
| 2016             | LSI                     | Г – генератор находится в расочем режиме Коэффициент подстрой ки частоты генератора LSI.                                                                                |  |  |
| 2010             | TRIM[4:0]               | Смотрите диаграмму зависимости (Рисунок 13–2)                                                                                                                           |  |  |
| 15               | LSI                     | Бит управления генератором LSI:                                                                                                                                         |  |  |
| 13               | ON                      | 0 – генератор выключен;                                                                                                                                                 |  |  |
|                  | OIV                     | 1 – генератор включен                                                                                                                                                   |  |  |
| 14               | -                       | Зарезервировано                                                                                                                                                         |  |  |
| 13               | LSE                     | Флаг выхода генератора LSE в рабочий режим:                                                                                                                             |  |  |
|                  | RDY                     | 0 – генератор не запущен или не вышел в режим;                                                                                                                          |  |  |
|                  |                         | 1 – генератор работает в рабочем режиме                                                                                                                                 |  |  |
| 125              | CAL[7:0]                | Коэффициент подстройки тактовой частоты часов реального времени, из каждых 2 <sup>20</sup> тактов будет замаскировано CAL тактов: 00000000 – 0 тактов 00000001 – 1 такт |  |  |
|                  |                         | <br>11111111 – 256 тактов                                                                                                                                               |  |  |
|                  |                         | Таким образом, при частоте 32768.00000 Гц                                                                                                                               |  |  |
|                  |                         | при CAL = 0 тактов частота = 32768.00000 Гц                                                                                                                             |  |  |
|                  |                         | при CAL = 1 такт частота = 32767,96875 Гц;<br>                                                                                                                          |  |  |
|                  |                         | при CAL = 256 тактов частота = 32760,00000 Гц                                                                                                                           |  |  |
| 4                | RTC                     | Бит разрешения работы часов реального времени:                                                                                                                          |  |  |
|                  | EN                      | 0 – работа запрещена;                                                                                                                                                   |  |  |
| 0.0              | D=0                     | 1 – работа разрешена                                                                                                                                                    |  |  |
| 3, 2             | RTC                     | Биты выбора источника тактовой синхронизации часов                                                                                                                      |  |  |
|                  | SEL[1:0]                | реального времени:                                                                                                                                                      |  |  |
|                  |                         | 00 – LSI                                                                                                                                                                |  |  |
|                  |                         | 01 – LSE<br>10 – HSIRTC (формируется в блоке CLKRST)                                                                                                                    |  |  |
|                  |                         | 10 – HSIRTC (формируется в блоке CLKRST)<br>11 – HSERTC (формируется в блоке CLKRST)                                                                                    |  |  |
|                  |                         | 11 HOLITTO (MODIMINIPLE OF B OFFICE OFFICE)                                                                                                                             |  |  |

| Nº   | Функциональное |                                                                  |  |
|------|----------------|------------------------------------------------------------------|--|
| бита | имя бита       | описание назначения и принимаемых значений                       |  |
| 1    | LSE            | Бит управления генератором LSE:                                  |  |
|      | BYP            | 0 – режим осциллятора;                                           |  |
|      |                | <ul><li>1 – режим работы на проход (внешний генератор)</li></ul> |  |
| 0    | LSE            | Флаг выхода генератора LSI в рабочий режим:                      |  |
|      | ON             | 0 – генератор не запущен или не вышел в режим;                   |  |
|      |                | 1 – генератор работает в рабочем режиме                          |  |



Рисунок 13-2 – Зависимость частоты LSI от значения LSITRIM



Рисунок 13-3 - Зависимость частоты HSI от значения HSITRIM

### 13.3.4 MDR\_BKP->RTC\_CNT

Таблица 13-8 - Регистр RTC\_CNT

| Номер  | 310 |
|--------|-----|
| Доступ | R/W |
| Сброс  | 0   |
|        | RTC |

| CNT[31:0] |
|-----------|

### Таблица 13-9 - Описание бит регистра RTC\_CNT

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 310       | RTC                     | Значение основного счетчика часов реального времени                                        |
|           | CNT[31:0]               |                                                                                            |

### 13.3.5 *MDR\_BKP->RTC\_DIV*

### Таблица 13-10 - Регистр RTC\_DIV

| Номер           | 3120 | 190       |
|-----------------|------|-----------|
| Доступ<br>Сброс | U    | R/W       |
| Сброс           | 0    | 0         |
|                 |      | RTC       |
|                 | -    | DIV[19:0] |

### Таблица 13-11 - Описание бит регистра RTC\_DIV

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------------------|-------------------------|--------------------------------------------------------------------------------------------|
| 3120             | -                       | Зарезервировано                                                                            |
| 190              | RTC<br>DIV[19:0]        | Значение счетчика предварительного делителя часов реального времени                        |

### 13.3.6 MDR\_BKP->RTC\_PRL

#### Таблица 13-12 - Регистр RTC\_PRL

| Номер           | 3120 | 190               |
|-----------------|------|-------------------|
| Доступ<br>Сброс | U    | R/W               |
| Сброс           | 0    | 0                 |
|                 | -    | RTC<br>PRI [19:0] |
|                 | -    | PRL[19:0]         |

### Таблица 13-13 - Описание бит регистра RTC\_PRL

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое        |
|------|----------------|--------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений             |
| 3120 | -              | Зарезервировано                                        |
| 190  | RTC            | Значение основания для счета счетчика предварительного |
|      | PRL[19:0]      | делителя часов реального времени                       |

### 13.3.7 MDR\_BKP->RTC\_ALRM

### Таблица 13-14 - Регистр RTC\_ALRM

| Номер  | 310        |  |
|--------|------------|--|
| Доступ | R/W        |  |
| Сброс  | 0          |  |
|        | RTC        |  |
|        | ALRM[31:0] |  |

## Таблица 13-15 - Описание бит регистра RTC\_ALRM

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 310       | RTC<br>ALRM[31:0]       | Значения для сравнения основного счетчика и выработки<br>сигнала ALRF                      |

### 13.3.8 *MDR\_BKP->RTC\_CS*

# Таблица 13-16 - Регистр RTC\_CS

| Номер  | 317 | 6   | 5       | 4       | 3      | 2    | 1    | 0   |
|--------|-----|-----|---------|---------|--------|------|------|-----|
| Доступ | U   | R/W | R/W     | R/W     | R/W    | R/W  | R/W  | R/W |
| Сброс  | 0   | 0   | 0       | 0       | 0      | 0    | 0    | 0   |
|        | -   | WEC | ALRF_IE | SECF_IE | OWF_IE | ALRF | SECF | OWF |

# Таблица 13-17 - Описание бит регистра RTC\_PRL

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое             |
|------|----------------|-------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                  |
| 307  | -              | Зарезервировано                                             |
| 6    | WEC            | Запись завершена:                                           |
|      |                | 0 – можно записывать в регистры RTC;                        |
|      |                | 1 – запись в регистры запрещена, идет запись в регистры RTC |
| 5    | ALRF_IE        | Флаг разрешения прерывания по совпадению основного счетчики |
|      |                | и регистра RTC_ALRM:                                        |
|      |                | 0 – нет совпадения;                                         |
|      |                | 1 – есть совпадение                                         |
| 4    | SECF_IE        | Флаг разрешения прерывания по разрешению счета основного    |
|      |                | счетчика от счетчика предварительного деления:              |
|      |                | 0 – нет разрешения счета;                                   |
|      |                | 1 – разрешение счета                                        |
| 3    | OWF_IE         | Флаг разрешения прерывания по переполнению основного        |
|      |                | счетчика RTC_CNT:                                           |
|      |                | 0 – нет переполнения                                        |
|      |                | 1 – было переполнение                                       |
| 2    | ALRF           | Флаг совпадения основного счетчики и регистра RTC_ALRM:     |
|      |                | 0 – нет совпадения;                                         |
|      |                | 1 – есть совпадение                                         |
| 1    | SECF           | Флаг разрешения счета основного счетчика от счетчика        |
|      |                | предварительного деления:                                   |
|      |                | 0 – нет разрешения счета;                                   |
|      |                | 1 – разрешение счета                                        |
| 0    | OWF            | Флаг переполнения основного счетчика RTC_CNT:               |
|      |                | 0 – нет переполнения;                                       |
|      |                | 1 – было переполнение                                       |

### 14 Порты ввода-вывода

Микроконтроллер имеет 6 портов ввода/вывода. Порты 16-ти разрядные и их выводы мультиплексируются между различными функциональными блоками, управление для каждого вывода отдельное. Для того, что бы выводы порта перешли под управление того или иного периферийного блока необходимо задать для нужных выводов выполняемую функцию и настройки.

При работе в режиме отладки не допускается изменение функций выводов, совмещенных с выводами JTAG, путем записи 1 в соответствующие биты регистров RXTX, SET и OE. Это может привести к блокировке интерфейса отладки.

Таблица 14-1 - Порты ввода-вывода

|       | Augraranas            | Цифровая функция |              |   |               |     |              |      |
|-------|-----------------------|------------------|--------------|---|---------------|-----|--------------|------|
| Вывод | Аналоговая<br>функция | Порт IO          | Основная     |   | Альтернативна | я   | Переопределе | нная |
|       | ANALOG EN-O           | MODE[1:0]=00     | MODE[1:0]=01 |   | MODE[1:0]=10  |     | MODE[1:0]=11 |      |
|       | ANALOG_EN=0           | ANALOG_EN=1      | ANALOG_EN=   | 1 | ANALOG_EN=1   |     | ANALOG_EN=1  |      |
|       |                       | <u>.</u>         | Порт А       |   |               |     |              |      |
| PA0   | -                     | PA0              | DATA0        | 1 | SDIO_CLK      | 2   | TMR1_CH1     | 3    |
| PA1   | -                     | PA1              | DATA1        | 1 | SDIO_CMD      |     | TMR1_CH1n    |      |
| PA2   | -                     | PA2              | DATA2        |   | SDIO_DATA0    |     | TMR1_CH2     |      |
| PA3   | -                     | PA3              | DATA3        |   | SDIO_DATA1    |     | TMR1_CH2n    |      |
| PA4   | -                     | PA4              | DATA4        | 1 | SDIO_DATA2    |     | TMR1_CH3     |      |
| PA5   | -                     | PA5              | DATA5        | 1 | SDIO DATA3    |     | TMR1_CH3n    |      |
| PA6   | -                     | PA6              | DATA6        | 1 | UART1_RXD     | 10  | TMR1_CH4     |      |
| PA7   | -                     | PA7              | DATA7        | 1 | UART1_TXD     | 7.  | TMR1_CH4n    |      |
| PA8   | -                     | PA8              | DATA8        | 1 | SSP2_CLK      | 13  | BSP1 RTCLK   | 18   |
| PA9   | -                     | PA9              | DATA9        | 1 | SSP2_FSS      | 1   | BSP1_RTFR    | -    |
| PA10  | -                     | PA10             | DATA10       | 1 | SSP2_TXD      | 1   | BSP1 TX      |      |
| PA11  | -                     | PA11             | DATA11       | 1 | SSP2_RXD      | 1   | BSP1 RX      |      |
| PA12  | -                     | PA12             | DATA12       |   | SSP1_RXD      | 16  | TMR1_ETR     | 3    |
| PA13  | -                     | PA13             | DATA13       |   | SSP1_TXD      | 1   | TMR1_BLK     |      |
| PA14  | -                     | PA14             | DATA14       |   | SSP1_CLK      |     | TMR2_CH1     | 15   |
| PA15  | -                     | PA15             | DATA15       |   | SSP1_FSS      |     | EXT_INT1/XF  | 9    |
|       |                       |                  | Порт В       |   | _             |     |              |      |
| PB0   | -                     | PB0 JA TDO       | DATA16       | 1 | UART2_TXD     | 141 | TMR2_CH1n    | 15   |
| PB1   | -                     | PB1 JA_TMS       | DATA17       |   | TMR1_ETR      | 3   | TMR2_CH2     |      |
| PB2   | -                     | PB2 JA_TCK       | DATA18       | 1 | TMR1_BLK      | 1   | TMR2_CH2n    |      |
| PB3   | -                     | PB3 JA TDI       | DATA19       |   | UART2 RXD     | 14  | TMR2_CH3     |      |
| PB4   | -                     | PB4 JA_TRST      | DATA20       |   | TMR1_CH1      | 3   | TMR2_CH3n    |      |
| PB5   | -                     | PB5              | DATA21       | 1 | SSP3 TXD      | 4   | BSP1 TX      | 18   |
| PB6   | -                     | PB6              | DATA22       | 1 | SSP3 FSS      |     | BSP1_TFR     |      |
| PB7   | -                     | PB7              | DATA23       |   | SSP3_RXD      |     | BSP1_RX      |      |
| PB8   | -                     | PB8              | DATA24       |   | SSP3_CLK      |     | BSP1_TCLK    |      |
| PB9   | -                     | PB9              | DATA25       |   | TMR1_CH1n     | 3   | TMR2_ETR     | 15   |
| PB10  | -                     | PB10             | DATA26       |   | TMR1_CH2      |     | TMR2_BLK     |      |
| PB11  | -                     | PB11             | DATA27       |   | TMR1_CH2n     |     | EXT_INT2     | 9    |
| PB12  | -                     | PB12             | DATA28       |   | SSP2_CLK      | 13  | BSP1_RCLK    | 18   |
| PB13  | -                     | PB13             | DATA29       |   | SSP2_FSS      |     | BSP1_RFR     |      |
| PB14  | -                     | PB14             | DATA30       |   | SSP2_TXD      |     | BSP1_TX      |      |
| PB15  | -                     | PB15             | DATA31       |   | SSP2_RXD      |     | BSP1_RX      |      |
|       |                       |                  | Порт С       |   |               |     |              |      |
| PC0   | -                     | PC0              | COMP_OUT     | 7 | SSP4_FSS      | 17  | SDIO_CLK     | 2    |
| PC1   | -                     | PC1              | OE           | 1 | UART1_TXD     | 10  | SDIO_CMD     |      |
| PC2   | -                     | PC2              | WE           |   | UART1_RXD     | L   | SDIO_DATA0   |      |
| PC3   | -                     | PC3              | BE0          |   | SSP4_RXD      | 17  | SDIO_DATA1   |      |
| PC4   | -                     | PC4              | BE1          |   | SSP4_TXD      | _   | SDIO_DATA2   |      |
| PC5   | -                     | PC5              | BE2          |   | SSP4_CLK      |     | SDIO_DATA3   |      |
| PC6   | -                     | PC6              | BE3          |   | TMR1_CH3      | 3   | UART2_TXD    | 14   |
| PC7   | -                     | PC7              | CLOCK        |   | TMR1_CH3n     |     | UART2_RXD    |      |
| PC8   | -                     | PC8              | SDIO_CLK     | 2 | SSP3_TXD      | 4   | BSP2_TX      | 19   |
| PC9   | -                     | PC9              | SDIO_CMD     |   | SSP3_FSS      |     | BSP2_RTFR    |      |
| PC10  | -                     | PC10             | SDIO_DATA0   | 1 | SSP3_RXD      |     | BSP2_RX      |      |

|       |            |   |           |         | Цифровая функция |    |                |     |                  |            |  |
|-------|------------|---|-----------|---------|------------------|----|----------------|-----|------------------|------------|--|
|       | Аналоговая |   | Порт IO   |         | Основная         |    | Альтернативная |     | Переопределенная |            |  |
| Вывод | функция    |   |           |         | Conobinar        |    | , o.b.op.ia    |     | Пороспродоле     | 111021     |  |
| Бывод |            | _ | MODE[1    | :01=00  | MODE[1:0]=01     |    | MODE[1:0]=10   |     | MODE[1:0]=11     |            |  |
|       | ANALOG_EN= | 0 |           | G_EN=1  | ANALOG_EN=       | 1  | ANALOG EN=1    |     | ANALOG_EN=1      |            |  |
| PC11  | -          | 1 | PC11      |         | SDIO DATA1       |    | SSP3 CLK       |     | BSP2_RTCLK       |            |  |
| PC12  | -          | 1 | PC12      |         | SDIO DATA2       |    | SSP4_FSS       | 17  | BSP3_RTFR        | 20         |  |
| PC13  | -          | 1 | PC13      |         | SDIO DATA3       |    | SSP4 CLK       |     | BSP3_RTCLK       |            |  |
| PC14  | -          | 1 | PC14      |         | I2C1_SCK         | 11 | SSP4_TXD       |     | BSP3_TX          |            |  |
| PC15  | -          | 1 | PC15      |         | I2C_SDA          |    | SSP4_RXD       |     | BSP3_RX          |            |  |
|       | 1          | • |           |         | Порт D           |    | _              |     |                  |            |  |
| PD0   | ADC0_REF+  | 5 | PD0       | JB TMS  | TMR1 BLK         | 3  | I2C1_SCK       | 11  | BSP3_RX          | 20         |  |
| PD1   | ADC1_REF-  | 1 | PD1       | JB_TCK  | TMR1 ETR         | 1  | I2C1 SDA       |     | BSP3_TX          |            |  |
| PD2   | ADC2       |   | PD2       | JB_TRST | BUSY1            | 1  | SSP1_TXD       | 16  | BSP2_TX          | 19         |  |
| PD3   | ADC3       |   | PD3       | JB_TDI  | TMR1 CH1         | 3  | SSP1_FSS       |     | BSP2_TFR         |            |  |
| PD4   | ADC4       |   | PD4       | JB_TDO  | TMR1_CH1n        |    | SSP1_RXD       |     | BSP2_RX          |            |  |
| PD5   | ADC5       | 1 | PD5       |         | CLE              | 1  | SSP1_CLK       |     | BSP2_TCKL        |            |  |
| PD6   | ADC6       | 1 | PD6       |         | ALE              | 1  | TMR1_CH4       | 3   | BSP3_TCLK        | 20         |  |
| PD7   | ADC7       |   | PD7       |         | TMR1 CH2         | 3  | UART1_SIROUT   |     | BSP3_TFR         |            |  |
| PD8   | ADC8       | 1 | PD8       |         | TMR1 CH2n        | 1  | UART1_SIRIN    | 1   | BSP3_TX          |            |  |
| PD9   | ADC9       | 1 | PD9       |         | TMR1 CH3         | 1  | TMR1 CH4n      | 3   | BSP3_RFR         | 1          |  |
| PD10  | ADC10      | 1 | PD10      |         | TMR1 CH3n        | 1  | TMR2_BLK       | 15  | BSP3_RX          | 1          |  |
| PD11  | ADC11      | 1 | PD11      |         | TMR1 CH4         |    | TMR2_ETR       |     | BSP3_RCLK        |            |  |
| PD12  | ADC12      | 1 | PD12      |         | TMR1 CH4n        |    | SSP2_FSS       | 13  | BSP2_RFR         | 19         |  |
| PD13  | ADC13      | 1 | PD13      |         | UART3_TXD        | 18 | SSP2_RXD       |     | BSP2 RX          | - I        |  |
| PD14  | ADC14      | 1 | PD14      |         | UART3 RXD        | '  | SSP2 CLK       |     | BSP2_RCKL        |            |  |
| PD15  | ADC15      | 1 | PD15      |         | EXT_INT1         | 9  | SSP2 TXD       |     | BSP2_TX          |            |  |
|       | , o . o    | 1 | <u>  </u> |         | Порт Е           |    | 00             | l   | 20.2//           | L.         |  |
| PE0   | DAC2_OUT   | 6 | PE0       |         | ADDR16           | 1  | SSP4_FSS       | 17  | BSP1 RTFR        | 18         |  |
| PE1   | DAC2 REF   | ਁ | PE1       |         | ADDR17           | 1  | SSP4 CLK       | ' ' | BSP1_RTCLK       | <b>∃</b> . |  |
| PE2   | COMP_IN1   | 7 | PE2       |         | ADDR18           | 1  | SSP4 TXD       |     | BSP1 TX          |            |  |
| PE3   | COMP_IN2   | 1 | PE3       |         | ADDR19           |    | SSP4 RXD       |     | BSP1 RX          |            |  |
| PE4   | COMP_REF+  |   | PE4       |         | ADDR20           |    | SSP2_TXD       | 13  | UART1_TXD        | 10         |  |
| PE5   | COMP_REF-  | 1 | PE5       |         | ADDR21           |    | SSP2 FSS       | . • | UART1_RXD        | <b>∃</b> . |  |
| PE6   | OSC_IN32   | 8 | PE6       |         | ADDR22           |    | SSP2_RXD       |     | EXT_INT3         | 9          |  |
| PE7   | OSC_OUT32  | 1 | PE7       |         | ADDR23           |    | SSP2 CLK       |     | TMR2 CH4         | 15         |  |
| PE8   | COMP_IN3   | 7 | PE8       |         | ADDR24           |    | TMR2_CH4       | 15  | TMR2 CH4n        |            |  |
| PE9   | DAC1_OUT   | 6 | PE9       |         | ADDR25           |    | TMR2_CH4n      |     | TMR3 CH1         | 12         |  |
| PE10  | DAC1_REF   | 1 | PE10      |         | ADDR26           |    | UART2_TXD      | 14  | TMR3_ETR         |            |  |
| PE11  | -          |   | PE11      |         | ADDR27           |    | UART2_RXD      |     | TMR3_BLK         |            |  |
| PE12  | -          |   | PE12      |         | ADDR28           |    | SSP1_RXD       | 16  | BSP2_RTFR        | 19         |  |
| PE13  | -          |   | PE13      |         | ADDR29           |    | SSP1 TXD       |     | BSP2_RTCLK       |            |  |
| PE14  | -          |   | PE14      |         | ADDR30           |    | SSP1_CLK       |     | BSP2_TX          |            |  |
| PE15  | -          |   | PE15      |         | ADDR31           |    | SSP1_FSS       |     | BSP2_RX          |            |  |
|       | I          |   |           |         | Порт F           |    | _              |     | _                | I          |  |
| PF0   | -          |   | PF0       |         | ADDR0            | 1  | UART3_RXD      | 18  | TMR3_CH1n        | 12         |  |
| PF1   | -          | 1 | PF1       |         | ADDR1            |    | UART3_TXD      |     | TMR3_CH2         |            |  |
| PF2   | -          |   | PF2       |         | ADDR2            |    | SSP4_RXD       | 17  | BSP3 RX          | 20         |  |
| PF3   | -          |   | PF3       |         | ADDR3            |    | SSP4_TXD       |     | BSP3_TX          |            |  |
| PF4   | -          | 1 | PF4       | MODE[0] | ADDR4            |    | SSP4_CLK       |     | BSP3 TCKL        |            |  |
| PF5   | -          | 1 | PF5       | MODE[1] | ADDR5            | 1  | SSP4_FSS       |     | BSP3_TFR         |            |  |
| PF6   | -          | 1 | PF6       | MODE[2] | ADDR6            | 1  | TMR2_CH3n      | 15  | TMR3_CH2n        | 12         |  |
| PF7   | -          | 1 | PF7       |         | ADDR7            | 1  | TMR2_CH3       | 1   | TMR3_CH3         |            |  |
| PF8   | -          | 1 | PF8       |         | ADDR8            | 1  | TMR2_CH2n      |     | TMR3_CH3n        |            |  |
| PF9   | -          | 1 | PF9       |         | ADDR9            | 1  | TMR2_CH2       |     | TMR3_CH4         |            |  |
| PF10  | -          | 1 | PF10      |         | ADDR10           | 1  | TMR2_CH1n      | 1   | TMR3_CH4n        |            |  |
| PF11  | -          | 1 | PF11      |         | ADDR11           | 1  | TMR2_CH1       |     | EXT_INT4         | 9          |  |
| PF12  | -          | 1 | PF12      |         | ADDR12           | 1  | SSP3_TXD       | 4   | BSP3_TX          | 20         |  |
| PF13  | -          | 1 | PF13      |         | ADDR13           | 1  | SSP3_FSS       |     | BSP3_RFR         | 7          |  |
| PF14  | -          | 1 | PF14      |         | ADDR14           | 1  | SSP3_RXD       |     | BSP3_RX          |            |  |
| PF15  | -          | 1 | PF15      |         | ADDR15           | 1  | SSP3_CLK       |     | BSP3_RCKL        |            |  |
|       |            |   |           |         | •                |    | _              |     |                  |            |  |

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

- 1) Выводы управляются системной шиной EXT\_BUS.
- 2) Выводы управляются контроллером интерфейса SDIO.

- 3) Выводы управляются Таймером 1.
- 4) Выводы управляются контроллером интерфейса SSP3.
- 5) Выводы используются АЦП.
- 6) Выводы используются ЦАП.
- 7) Выводы используются Компаратором.
- 8) Выводы используются генератором LSE.
- 9) Выводы используются контроллером прерываний.
- 10) Выводы управляются контроллером интерфейса UART1.
- 11) Выводы управляются контроллером интерфейса I2C.
- 12) Выводы управляются Таймером 3.
- 13) Выводы управляются контроллером интерфейса SSP2.
- 14) Выводы управляются контроллером интерфейса UART2.
- 15) Выводы управляются Таймером 2.
- 16) Выводы управляются контроллером интерфейса SSP1.
- 17) Выводы управляются контроллером интерфейса SSP4.
- 18) Выводы управляются контроллером интерфейса McBSP1.
- 19) Выводы управляются контроллером интерфейса McBSP2.
- 20) Выводы управляются контроллером интерфейса McBSP3.



Рисунок 14-1 - Структурная схема порта ввода/вывода

### 14.1 Описание регистров портов ввода-вывода

Таблица 14-2 - Описание регистров портов ввода-вывода

| Базовый<br>Адрес | Название            |                                | Описание                                                                                                                                                                                                                     |
|------------------|---------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x400A_8000      | MDR_PORTA           | Порт А                         |                                                                                                                                                                                                                              |
| 0x400B_0000      | MDR_PORTB           | Порт В                         |                                                                                                                                                                                                                              |
| 0x400B_8000      | MDR_PORTC           | Порт С                         |                                                                                                                                                                                                                              |
| 0x400C_0000      | MDR_PORTD           | Порт D                         |                                                                                                                                                                                                                              |
| 0x400C_8000      | MDR_PORTE           | Порт Е                         |                                                                                                                                                                                                                              |
| 0x400E_8000      | MDR_PORTF           | Порт F                         |                                                                                                                                                                                                                              |
| Смещение         |                     |                                |                                                                                                                                                                                                                              |
| 0x00             | RXTX[15:0]          | MDR_PORTx->RXTX                | Данные порта                                                                                                                                                                                                                 |
| 0x04             | OE[15:0]            | MDR_PORTx->OE                  | Направление порта                                                                                                                                                                                                            |
| 0x08             | FUNC[31:0]          | MDR_PORTx->FUNC                | Режим работы порта                                                                                                                                                                                                           |
| 0x0C             | ANALOG[15:0]        | MDR_PORTx->ANALOG              | Аналоговый режим работы порта                                                                                                                                                                                                |
| 0x10             | PULL[31:0]          | MDR_PORTx->PULL                | Подтяжка порта                                                                                                                                                                                                               |
| 0x14             | PD[31:0]            | MDR_PORTx->PD                  | Режим работы выходного                                                                                                                                                                                                       |
|                  |                     |                                | драйвера                                                                                                                                                                                                                     |
| 0x18             | PWR[31:0]           | MDR_PORTx->PWR                 | Режим мощности передатчика                                                                                                                                                                                                   |
| 0x1C             | GFEN[15:0]          | MDR_PORTx->GFEN                | Режим работы входного фильтра                                                                                                                                                                                                |
| 0x20<br>0x24     | SET[15:0] CLR[15:0] | MDR_PORTx->SET  MDR_PORTx->CLR | Установка данных выходного порта. Записываемые данные объединяются по «ИЛИ» с регистром выходных данных порта Установка данных выходного порта. Инверсия записываемых данных объединяется по «И» с регистром выходных данных |
| 0x28             | RD[15:0]            | MDR_PORTx->RD                  | порта<br>Чтение регистра выходных<br>данных порта                                                                                                                                                                            |

### 14.1.1 MDR\_PORTx->RXTX

### Таблица 14-3 - Регистр RXTX

| Номер           | 3116 | 150                |
|-----------------|------|--------------------|
| Доступ<br>Сброс | U    | R/W                |
| Сброс           | 0    | 0                  |
|                 | -    | PORT<br>RXTX[15:0] |

### Таблица 14-4 - Описание бит регистра RXTX

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 3116      | -                          | Зарезервировано                                                                            |
| 150       | PORT                       | Режим работы контроллера.                                                                  |
|           | RXTX[15:0]                 | Данные для выдачи на выводы порта и для чтения                                             |

# 14.1.2 *MDR\_PORTx->OE*

# Таблица 14-5 - Регистр ОЕ

| Номер  | 3116 | 150      |
|--------|------|----------|
| Доступ | U    | R/W      |
| Сброс  | 0    | 0        |
|        |      | PORT     |
|        | -    | OE[15:0] |

# Таблица 14-6 - Описание бит регистра ОЕ

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3116 | -              | Зарезервировано                                 |
| 150  | PORT           | Режим работы контроллера.                       |
|      | OE[15:0]       | Направление передачи данных на выводах порта:   |
|      |                | 1 – выход;                                      |
|      |                | 0 – вход                                        |

## 14.1.3 MDR\_PORTx->FUNC

# Таблица 14-7 - Регистр FUNC

| Номер  | 31          | 30  | <br>3    | 2      | 1    | 0      |
|--------|-------------|-----|----------|--------|------|--------|
| Доступ | R/W         | R/W | <br>R/W  | R/W    | R/W  | R/W    |
| Сброс  | 0           | 0   | <br>0    | 0      | 0    | 0      |
|        | MODE15[1:0] |     | <br>MODE | 1[1:0] | MODE | 0[1:0] |

# Таблица 14-8 - Описание бит регистра FUNC

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 312  | MODEx          | Аналогично MODE0 для остальных бит порта        |
| 10   | MODE0[1:0]     | Режим работы вывода порта:                      |
|      |                | 00 – порт;                                      |
|      |                | 01 – основная функция;                          |
|      |                | 10 – альтернативная функция                     |
|      |                | 11 – переопределенная функция                   |

# 14.1.4 MDR\_PORTx->ANALOG

# Таблица 14-9 - Регистр ANALOG

| Номер  | 3116 | 150      |
|--------|------|----------|
| Доступ | U    | R/W      |
| Сброс  | 0    | 0        |
|        |      | ANALOG   |
|        | -    | EN[15:0] |

# Таблица 14-10 - Описание бит регистра ANALOG

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 3116      | -                          | Зарезервировано                                                                            |
| 150       | ANALOG                     | Режим работы контроллера:                                                                  |
|           | EN[15:0]                   | 0 – аналоговый;                                                                            |
|           |                            | 1 – цифровой                                                                               |

# 14.1.5 MDR\_PORTx->PULL

# Таблица 14-11 - Регистр PULL

| Номер  | 3116     | 150        |
|--------|----------|------------|
| Доступ | R/W      | R/W        |
| Сброс  | 0        | 0          |
|        | PULL     | PULL       |
|        | UP[15:0] | DOWN[15:0] |

# Таблица 14-12 - Описание бит регистра PULL

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                           |  |
|------|----------------|---------------------------------------------------------------------------|--|
| бита | имя бита       | описание назначения и принимаемых значений                                |  |
| 3116 | PULL           | Режим работы контроллера.                                                 |  |
|      | UP15:0]        | Разрешение подтяжки вверх:                                                |  |
|      |                | 0 – подтяжка в питание выключена;                                         |  |
|      |                | <ul><li>1 – подтяжка в питание включена (есть подтяжка ~50 кОм)</li></ul> |  |
| 150  | PULL           | Режим работы контроллера.                                                 |  |
|      | DOWN[15:0]     | Разрешение подтяжки вниз:                                                 |  |
|      |                | 0 – подтяжка в ноль выключена;                                            |  |
|      |                | <ul><li>1 – подтяжка в ноль включена (есть подтяжка ~ 50 кОм)</li></ul>   |  |

# 14.1.6 *MDR\_PORTx->PD*

# Таблица 14-13 - Регистр PD

| Номер  | 3116      | 150      |
|--------|-----------|----------|
| Доступ | R/W       | R/W      |
| Сброс  | 0         | 0        |
|        | PORT      | PORT     |
|        | SHM[15:0] | PD[15:0] |

# Таблица 14-14 - Описание бит регистра PD

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3116 | PORT           | Режим работы контроллера.                       |
|      | SHM[15:0]      | Режим работы входа:                             |
|      |                | 0 – триггер Шмитта выключен гистерезис 200 мВ;  |
|      |                | 1 – триггер Шмитта включен гистерезис 400 мB    |
| 150  | PORT           | Режим работы контроллера.                       |
|      | PD[15:0]       | Режим работы выхода:                            |
|      |                | 0 – управляемый драйвер;                        |
|      |                | 1 – открытый сток                               |

# 14.1.7 MDR\_PORTx->PWR

# Таблица 14-15 - Регистр PWR

| Номер  | 31         | 30  | <br>3   | 2      | 1   | 0      |
|--------|------------|-----|---------|--------|-----|--------|
| Доступ | R/W        | R/W | <br>R/W | R/W    | R/W | R/W    |
| Сброс  | 0          | 0   | <br>0   | 0      | 0   | 0      |
|        | PWR15[1:0] |     | <br>PWR | 1[1:0] | PWR | 0[1:0] |

# Таблица 14-16 - Описание бит регистра PORTx\_PWR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 312  | PWRx           | Аналогично PWR0 для остальных бит порта         |
| 10   | PWR0[1:0]      | Режим работы вывода порта:                      |
|      |                | 00 – зарезервировано (передатчик отключен)      |
|      |                | 01 – медленный фронт                            |
|      |                | 10 – быстрый фронт                              |
|      |                | 11 – максимально быстрый фронт                  |

#### 14.1.8 MDR\_PORTx->GFEN

# Таблица 14-17 - Регистр GFEN

| Номер  | 3116 | 150        |
|--------|------|------------|
| Доступ | R/W  | R/W        |
| Сброс  | 0    | 0          |
|        | -    | GFEN[15:0] |

# Таблица 14-18 - Описание бит регистра GFEN

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|--|
| 3116      | •                       | Зарезервировано                                                                            |  |
| 150       | GFEN[15:0]              | Режим работы входного фильтра:                                                             |  |
|           |                         | 0 – фильтр выключен;                                                                       |  |
|           |                         | 1 – фильтр включен                                                                         |  |

# 14.1.9 *MDR\_PORTx->SET*

# Таблица 14-19 - Регистр SET

| Номер  | 3116        | 150 |
|--------|-------------|-----|
| Доступ | U           | W   |
| Сброс  | 0           | 0   |
|        | - SET[15:0] |     |

# Таблица 14-20 - Описание бит регистра SET

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое    |  |  |  |
|------|----------------|----------------------------------------------------|--|--|--|
| бита | имя бита       | описание назначения и принимаемых значений         |  |  |  |
| 3116 | -              | Зарезервировано                                    |  |  |  |
| 150  | SET[15:0]      | Установка данных выходного порта.                  |  |  |  |
|      |                | Записываемые данные объединяются по «ИЛИ» с        |  |  |  |
|      |                | регистром выходных данных порта.                   |  |  |  |
|      |                | При чтении читается регистр выходных данных порта. |  |  |  |

# 14.1.10 *MDR\_PORTx->CLR*

# Таблица 14-21 - Регистр CLR

| Номер           | 3116        | 150 |
|-----------------|-------------|-----|
| Доступ<br>Сброс | U           | W   |
| Сброс           | 0           | 0   |
|                 | - CLR[15:0] |     |

# Таблица 14-22 - Описание бит регистра CLR

| Nº   | Функциональное | ное Расшифровка функционального имени бита, краткое |  |
|------|----------------|-----------------------------------------------------|--|
| бита | имя бита       | описание назначения и принимаемых значений          |  |
| 3116 | -              | Зарезервировано                                     |  |
| 150  | CLR[15:0]      | /становка данных выходного порта.                   |  |
|      |                | Инверсия записываемых данных объединяется по «И» с  |  |
|      |                | регистром выходных данных порта.                    |  |

# 14.1.11 *MDR\_PORTx->RD*

# Таблица 14-23 - Регистр RD

| Номер           | 3116 | 150      |
|-----------------|------|----------|
| Доступ<br>Сброс | U    | R        |
| Сброс           | 0    | 0        |
|                 | -    | RD[15:0] |

# Таблица 14-24 - Описание бит регистра RD

| № Функциональное Расшифровка функционального имени бита, кратко бита имя бита описание назначения и принимаемых значений |          | • • • • • • • • • • • • • • • • • • • • |  |
|--------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------|--|
| 3116                                                                                                                     |          | Зарезервировано                         |  |
| 150                                                                                                                      | RD[15:0] | Чтение регистра выходных данных порта   |  |

# 15 Детектор напряжения питания MDR\_POWER

Блок детектора напряжения питания PVD предназначен для контроля питания Ucc и Uccв при работе микроконтроллера. Блок PVD позволяет сравнивать внешние уровни напряжения с внутренними опорными уровнями и в случае превышения или снижения ниже опорного уровня выработать сигнал или прерывание для программной обработки.

Уровень опорного напряжения для сравнения с  $U_{CC}$  задается битами PLS[2:0] в регистре PVDCS, для сравнения с  $U_{CCB}$  задается битами PLBS[1:0] в регистре PVDCS. В соответствии с уровнями напряжения формируются флаги PVD и PBVD. Данные флаги выставляются при возникновении события и сбрасываются программно.

В микроконтроллерах первой ревизии (по адресу 0x000003FC загрузочного ПЗУ хранится значение 0x03400FDF) при Uccв < Ucc блок определения уровня Uccв не функционирует.

Таблица 15-1 - Типовые уровни напряжений детектора питания

| Параметр                                                           | Не менее | Типовое | Не более |
|--------------------------------------------------------------------|----------|---------|----------|
| Входное напряжение, U <sub>CC</sub> , В                            | 2,0      | -       | 3,6      |
| Входное напряжение, Uccв, В                                        | 1,8      | -       | 3,6      |
| Уровень срабатывания PVD от U <sub>CC</sub> , при PLS = "000", В   |          | 2,0     |          |
| Уровень срабатывания PVD от U <sub>CC</sub> , при PLS = "001", В   |          | 2,2     |          |
| Уровень срабатывания PVD от U <sub>CC</sub> , при PLS = "010", В   |          | 2,4     |          |
| Уровень срабатывания PVD от U <sub>cc</sub> , при PLS = "011", В   |          | 2,6     |          |
| Уровень срабатывания PVD от U <sub>CC</sub> , при PLS = "100", В   |          | 2,8     |          |
| Уровень срабатывания PVD от U <sub>cc</sub> , при PLS = "101", В   |          | 3,0     |          |
| Уровень срабатывания PVD от U <sub>CC</sub> , при PLS = "110", В   |          | 3,2     |          |
| Уровень срабатывания PVD от U <sub>cc</sub> , при PLS = "111", В   |          | 3,4     |          |
| Уровень срабатывания PBVD от U <sub>CCB</sub> , при PBLS = "00", В |          | 1,8     |          |
| Уровень срабатывания PBVD от Uccв, при PBLS = "01", В              |          | 2,2     |          |
| Уровень срабатывания PBVD от Uccв, при PBLS = "10", В              |          | 2,6     |          |
| Уровень срабатывания PBVD от Uccв, при PBLS = "11", В              |          | 3,0     |          |

Таблица 15-2 - Описание регистров блока PVD

| Базовый<br>Адрес  | Название  | Описание                              |  |  |
|-------------------|-----------|---------------------------------------|--|--|
| 0x4005_8000       | MDR_POWER | Датчик подсистемы питания             |  |  |
| Смещение          |           |                                       |  |  |
| 0x00 PVDCS [12:0] |           | Peгистр MDR_POWER->PVDCS управления и |  |  |
|                   |           | состояния датчика питания             |  |  |

# 15.1 MDR\_POWER->PVDCS

# Таблица 15-3 - Регистр PVDCS

| Номер  | 9     | 8      | 7   | 6    | 53           | 21            | 0         |
|--------|-------|--------|-----|------|--------------|---------------|-----------|
| Доступ | R/W   | R/W    | R/W | R/W  | R/W          | R/W           | R/W       |
| Сброс  | 0     | 0      | 0   | 0    | 000          | 00            | 0         |
|        | IEPVD | IEPVBD | PVD | PVBD | PLS<br>[2:0] | PBLS<br>[1:0] | PVD<br>EN |

| Номер  | 3112 | 11  | 10   |
|--------|------|-----|------|
| Доступ | U    | R/W | R/W  |
| Сброс  | 0    | 0   | 0    |
|        | -    | INV | INVB |

# Таблица 15-4 - Описание бит регистра PVDCS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                              |
|-----------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3112      | -                       | Зарезервировано                                                                                                                                                                                                                                                                                                                                         |
| 11        | INV                     | Флаг инверсии выхода от датчика PVD:  0 – нет инверсии;                                                                                                                                                                                                                                                                                                 |
|           |                         | 1 – инверсия. Если флаг не инвертируется, то флаг выставляется при превышении заданного уровня, если инвертируется, то при снижении ниже заданного уровня                                                                                                                                                                                               |
| 10        | INVB                    | Флаг инверсии выхода от датчика PVBD:  0 – нет инверсии;  1 – инверсия.  Если флаг не инвертируется, то флаг выставляется при превышении заданного уровня, если инвертируется, то при снижении ниже заданного уровня                                                                                                                                    |
| 9         | IEPVD                   | Флаг разрешения прерывания от датчика PVD:  0 – прерывание запрещено;  1 – прерывание разрешено. Очищается записью 0, если при очистке, датчик продолжает выдавать сигнал, то флаг не будет очищен                                                                                                                                                      |
| 8         | IEPVBD                  | Флаг разрешения прерывания от датчика PVBD:  0 – прерывание запрещено;  1 – прерывание разрешено. Очищается записью 0, если при очистке, датчик продолжает выдавать сигнал, то флаг не будет очищен                                                                                                                                                     |
| 7         | PVD                     | Результат сравнения напряжения основного питания Устанавливается событием, очищается записью 0. Если событие продолжается запись игнорируется:  0 – напряжение питания меньше чем уровень задаваемый PLS;  1 – напряжение питания больше чем уровень задаваемый PLS Примечание - Сброс флага необходимо проводить с подтверждением - сбрасывать дважды. |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                  |
|-----------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6         | PVBD                    | Результат сравнения напряжения батарейного питания Устанавливается событием, очищается записью 0. Если событие продолжается запись игнорируется:  0 – напряжение питания меньше чем уровень задаваемый PBLS;  1 – напряжение питания больше чем уровень задаваемый PBLS Примечание - Сброс флага необходимо проводить с подтверждением - сбрасывать дважды. |
| 53        | PLS[2:0]                | Уровень напряжения для сравнения с напряжением основного питания:  000 - 2,0 В  001 - 2,2 В  010 - 2,4 В  011 - 2,6 В  100 - 2,8 В  101 - 3,0 В  110 - 3,2 В  111 - 3,4 В                                                                                                                                                                                   |
| 21        | PBLS[1:0]               | Уровень напряжения для сравнения с напряжением батарейного питания:  00 – 1,8 В  01 – 2,2 В  10 – 2,6 В  11 – 3,0 В                                                                                                                                                                                                                                         |
| 0         | PVDEN                   | Бит разрешения работы блока датчика напряжения питания:  0 – датчик отключен;  1 – датчик включен                                                                                                                                                                                                                                                           |

через S Bus. К этой области имеет доступ DMA контроллер

# 16 Внешняя системная шина MDR\_EBC

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

| Адресный                     | Размер      | Описание                                                                                                                                                                           |
|------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| диапазон                     |             |                                                                                                                                                                                    |
| 0x1000_0000 -<br>0x1FFF_FFFF | 256 Мбайт   | Область памяти секции CODE отображаемая на внешнюю системную шину с доступом через I Code и D code шины. В режиме микропроцессора из этой области начинается выполняться программа |
| 0x5000_0000 -                | 2,256 Гбайт | Область памяти секции PERIPHERAL и EXTERNAL BUS                                                                                                                                    |
| 0xDFFF_FFFF                  |             | отображаемая на внешнюю системную шину с доступом                                                                                                                                  |

Таблица 16-1 - Адресные диапазоны внешней системной шины

Контроллер внешней системной шины во всех режимах не формирует сигналов выборки чипа СЕ. При работе с внешними статическими ОЗУ, ПЗУ и периферийными устройствами в качестве сигнала выборки чипа можно использовать старшие линии шины адреса, не используемые для непосредственной адресации, либо использовать программно управляемые выводы портов для формирования сигналов СЕ.

# 16.1 Работа с внешними статическими ОЗУ, ПЗУ и периферийными устройствами

Для работы контроллера внешней системной ШИНЫ С внешними микросхемами статического ОЗУ, ПЗУ или внешними периферийными устройствами необходимо задать режим работы через регистр EXT BUS CONROL. Бит RAM разрешает работу с внешними ОЗУ, бит ROM разрешает только чтение внешних ОЗУ или ПЗУ. В зависимости от скорости работы ядра микроконтроллера и внешних устройств необходимо задать времена транзакции на внешней системной шине через биты WAIT STATE[3:0]. После этого все обращения в область памяти, отображаемой на внешнюю системную шину, будут транслироваться на выводы внешней системной шины ADDR, DATA и сигналы управления OE, WE, BE[3:0] и сигнал синхронизации CLOCK.



Рисунок 16-1 - Обмен по внешней системной шине



Рисунок 16-2 - Диаграмма записи

Время цикла записи tcycle задается битами WAIT\_STATE[3:0]. Активный уровень сигналов WE, OE, BE[3:0] низкий. Если сигнал CLOCK не требуется, он может не использоваться.



Рисунок 16-3 - Диаграмма чтения

При чтении по внешней системной шине необходимо выбрать такую длительность времени tcycle, чтобы выполнялось время скорости доступа к памяти. Время tdh для микроконтроллера равно нулю.

| WAIT_STATE | Предустановка<br>адреса и данных<br>перед сигналом WE<br>или OE | Длительность<br>WE или OE | Удержание адреса и<br>данных после<br>сигнала WE или OE |
|------------|-----------------------------------------------------------------|---------------------------|---------------------------------------------------------|
| 0          | 1                                                               | 1                         | 0                                                       |
| 1          | 1                                                               | 1                         | 1                                                       |
| 2          | 1                                                               | 1                         | 1                                                       |
| 3          | 1                                                               | 2                         | 1                                                       |
| 4          | 2                                                               | 2                         | 1                                                       |
| 5          | 2                                                               | 3                         | 1                                                       |
| 6          | 2                                                               | 3                         | 2                                                       |
| 7          | 2                                                               | 4                         | 2                                                       |
| 8          | 3                                                               | 4                         | 2                                                       |
| 9          | 3                                                               | 5                         | 2                                                       |
| 10         | 3                                                               | 5                         | 3                                                       |
| 11         | 3                                                               | 6                         | 3                                                       |
| 12         | 4                                                               | 6                         | 3                                                       |

Таблица 16-2 - Длительность фаз обращения в тактах процессора

### 16.2 Работа с внешней NAND Flash-памятью

Для работы контроллера внешней системной шины с внешними NAND Flash микросхемами памяти необходимо задать режим работы через регистр EXT\_BUS\_CONROL. Бит NAND разрешает работу с внешними NAND Flash микросхемами. В зависимости от скорости работы ядра микроконтроллера и внешних устройств необходимо задать времена выполнения различных этапов работы NAND Flash-памяти через регистр NAND\_CYCLES. После этого обращения в область памяти, отображаемой на внешнюю системную шину, будут перекодироваться в командные, адресные и обмена данными циклы обращения с NAND Flash через выводы внешней системной шины DATA[7:0], ALE, CLE, BUSY1 и BUSY2.



Рисунок 16-4 - Подключение внешней NAND Flash

Контроллер имеет два сигнала BUSY1 и BUSY2 для возможности подключения двух независимых микросхем NAND Flash. Оба сигнала объединяются по логическому И внутри контроллера и формируют общий сигнал BUSY. Если использование второго сигнала BUSY не требуется, то достаточно не задавать соответствующую функцию вывода порта D (BUSY1 – PD2 (основная функция) и BUSY1 – PD15 (альтернативная функция)).

При работе с NAND Flash-памятью тип выполняемой операции кодируется адресом обращения, а данные и адрес передаются данными при записи и чтении памяти. Формат кодирования адреса обращения представлен ниже (Таблица 16–3).

Таблица 16-3 - Формат кодирования адреса обращения

| Адрес обращения | Фаза команды                       | Фаза данных                  |  |  |  |  |
|-----------------|------------------------------------|------------------------------|--|--|--|--|
| ADDR[31:24]     | Не имеет значения, но должно г     | опадать в адресные диапазоны |  |  |  |  |
|                 | внешней системной шины:            |                              |  |  |  |  |
|                 | 0x100x1F                           |                              |  |  |  |  |
|                 | 0x30                               |                              |  |  |  |  |
|                 |                                    | .0xCF                        |  |  |  |  |
| ADDR[23:21]     | ADR_CYCLES[2:0]                    | Не имеет значения            |  |  |  |  |
|                 | 000 – 0 циклов                     |                              |  |  |  |  |
|                 | 001 — 1 цикл                       |                              |  |  |  |  |
|                 |                                    |                              |  |  |  |  |
| 10001001        | 111 – 7 циклов                     |                              |  |  |  |  |
| ADDR[20]        | Выполнение завершающей ком         | анды:                        |  |  |  |  |
|                 | 0 – не выполнять;                  |                              |  |  |  |  |
| 4 D D D [4 0]   | 1 – выполнять                      |                              |  |  |  |  |
| ADDR[19]        | Всегда 0                           | Всегда 1                     |  |  |  |  |
| ADDR[18:11]     | Код завершающей команды            |                              |  |  |  |  |
|                 | ECMD[7:0]                          |                              |  |  |  |  |
|                 | 0x10/0x11 - Page Program           |                              |  |  |  |  |
| A D D D [40 0]  | 0xD0 - Block Erase                 |                              |  |  |  |  |
| ADDR[10:3]      | Код начальной команды<br>SCMD[7:0] | Не имеет значения            |  |  |  |  |
|                 | 0x00/0x01 - Read1                  |                              |  |  |  |  |
|                 | 0x50 - Read2                       |                              |  |  |  |  |
|                 | 0x90 - Read ID                     |                              |  |  |  |  |
|                 | 0xFF – Reset                       |                              |  |  |  |  |
|                 | 0x80 – Page Program                |                              |  |  |  |  |
|                 | 0x60 – Block Erase                 |                              |  |  |  |  |
|                 | 0x70 – Read Status                 |                              |  |  |  |  |
| ADDR[2:0]       | Не имеет значения                  |                              |  |  |  |  |

Более подробная информация о командах NAND Flash-памяти представлена в документации на этот тип микросхем.

#### Пример работы с NAND Flash-памятью

```
// Инициализация контроллера внешней системной шины для работы с NAND Flash
NAND CYCLES = 0x02A63466;
// время t_r = 2 цикла HCLK или 20 нс при частоте HCLK 100 МГц
// время t_alea = 10 циклов
// время t_whr = 6 циклов
// время t wp = 3 цикла
// время t_rea = 4 цикла
// время t_wc = 6 циклов
// время \bar{t} rc = 6 циклов
EXT BUS CONTROL = 0x000000004;
//NAND = 1;
// Чтение ID микросхемы
unsigned char IDH;
unsigned char IDL;
// Фаза команды
*((volatile unsigned char *) (0x77200480)) = 0x00;
// ADR_CYCLE = 1
// SCMD = 0x90 (READ)
// Address 1 cycle = 0x00
// Фаза данных
IDL = *((volatile unsigned char *)(0x77080000));
IDH = *((volatile unsigned char *)(0x77080000));
// Стирание блока памяти
// Фаза команды
*((volatile unsigned char *)(0x70768300))=0x11;
*((volatile unsigned char *)(0x70768301))=0x22;
*((volatile unsigned char *)(0x70768302))=0x33;
// ADR_CYCLE = 3
// выполнять завершающую команду
// ECMD = 0xD0
//SCMD = 0x60
// Address 1 cycle = 0x11
// Address 2 cycle = 0x22
// Address 1 cycle = 0x33
while (EXT_BUS_CONTROL!=0x080 ) {};
//Ждем R/nВ
*((volatile unsigned char *)(0x70000380+addon))=0x00;

// ADR_CYCl F = 0
//ADR_CYCLE = 0
//SCMD = 0x70
// Фаза данных
IDL = *((volatile unsigned char *)(0x77080000));
If (IDL & 0x01)=0x01) Error ();
// Если бит IO0==1, то стирание не выполнено
// Запись страницы
// Фаза команды
*((volatile unsigned char *)(0x70800400))=0x11;
*((volatile unsigned char *)(0x70800400))=0x22;
*((volatile unsigned char *)(0x70800400))=0x33;
*((volatile unsigned char *)(0x70800400))=0x44;
// ADR_CYCLE = 4
//SCMD = 0x80
```

```
// Фаза данных
*((volatile unsigned char *)(0x70088000+addon))=0xBB;
*((volatile unsigned char *)(0x70088000+addon))=0xCC;
*((volatile unsigned char *)(0x70088000+addon))=0xDD;
// не выполнять завершающую команду
/\!/ ECMD = 0x10
*((volatile unsigned char *)(0x70188000+addon))=0xEE;
// не выполнять завершающую команду
/\!\!/ ECMD = 0x10
// Данные 0 – 0xBB, 1 – 0xCC,... N – 0xEE
// N om 1 ∂o 528
while (EXT_BUS_CONTROL!=0x080 ) {};
//Ждем R/nB
// Фаза команды
*((volatile unsigned char *)(0x70000380+addon))=0x00;
// ADR_CYCLE = 0
//SCMD = 0x70
// Фаза данных
IDL = *((volatile unsigned char *)(0x77080000));
If (IDL & 0x01=0x01) Error ();
// Если бит IO0==1, то запись не выполнена
// Чтение страницы
// Фаза команды
*((volatile unsigned char *)(0x70800000))=0x11;

*((volatile unsigned char *)(0x70800000))=0x22;

*((volatile unsigned char *)(0x70800000))=0x33;

*((volatile unsigned char *)(0x70800000))=0x44;

// ADR_CYCLE = 4
//SCMD = 0x00
while (EXT_BUS_CONTROL!=0x080 ) {};
//Ждем R/nB
// Фаза данных
IDL=*((volatile unsigned char *)(0x70080000));
IDH=*((volatile unsigned char *)(0x70080000));
If (IDL != 0xBB || IDH != 0xCC) Error ();
// Если считали не то, что записали, то ошибка
```

# 16.3 Описание регистров блока контроллера внешней системной шины Таблица 16–4 – Описание регистров блока контроллера внешней системной шины

| Базовый Адрес | Название    | Описание                                                     |
|---------------|-------------|--------------------------------------------------------------|
| 0x400F_0000   | MDR_EBC     | Контроллер внешней системной шины                            |
| Смещение      |             |                                                              |
| 0x50          | NAND_CYCLES | Pегистр MDR_EBC->NAND_CYCLES управления работой с NAND_Flash |
| 0x54          | CONTROL     | Perистр MDR_EBC->CONTROL управления внешней системной шиной  |

# 16.3.1 MDR\_EBC->NAND\_CYCLES

# Таблица 16-5 - Регистр NAND\_CYCLES

| Номер  | 31-28 | 27-24 | 23-20  | 19-16 | 15-12 | 11-8  | 7-4  | 3-0  |
|--------|-------|-------|--------|-------|-------|-------|------|------|
| Доступ | U     | R/W   | R/W    | R/W   | R/W   | R/W   | R/W  | R/W  |
| Срос   |       | 0     | 0      | 0     | 0     | 0     | 0    | 0    |
|        | -     | t_rr  | t_alea | t_whr | t_wp  | t_rea | t_wc | t_rc |

# Таблица 16-6 - Описание бит регистра NAND\_CYCLES

| № бита | Функциональное | Расшифровка функционального имени бита, краткое          |
|--------|----------------|----------------------------------------------------------|
|        | имя бита       | описание назначения и принимаемых значений               |
| 3128   |                | Зарезервировано                                          |
| 2724   | t_rr[3:0]      | Время от снятия busy до операции чтения:                 |
|        |                | 0000 – 0 HCLK циклов                                     |
|        |                | 0001 – 1 HCLK цикл                                       |
|        |                |                                                          |
|        |                | 1111 – 15 HCLK циклов                                    |
|        |                | Типовое значение для памяти NAND Flash составляет 20 нс  |
| 2320   | t_alea[3:0]    | Время доступа к регистрам ID.                            |
|        |                | Аналогично t_rr.                                         |
|        |                | Типовое значение для памяти NAND Flash составляет 100 нс |
| 1916   | t_whr[3:0]     | Время доступа к регистру статуса.                        |
|        |                | Аналогично t_rr.                                         |
|        |                | Типовое значение для памяти NAND Flash составляет 60 нс  |
| 1512   | t_wp[3:0]      | Время доступа по записи.                                 |
|        |                | Аналогично t_rr.                                         |
|        |                | Типовое значение для памяти NAND Flash составляет 25 нс  |
| 118    | t_rea[3:0]     | Время доступа по чтению.                                 |
|        |                | Аналогично t_rr.                                         |
|        |                | Типовое значение для памяти NAND Flash составляет 35 нс  |
| 74     | t_wc[3:0]      | Время цикла записи.                                      |
|        |                | Аналогично t_rr.                                         |
|        |                | Типовое значение для памяти NAND Flash составляет 60 нс  |
| 30     | t_rc[3:0]      | Время цикла чтения.                                      |
|        |                | Аналогично t_rr.                                         |
|        |                | Типовое значение для памяти NAND Flash составляет 60 нс  |

# 16.3.2 MDR\_EBC->CONTROL

# Таблица 16-7 - Регистр CONTROL

| Номер  | 3116 | 15              | 14  | 13  | 12  | 118  | 7  | 64   | 3    | 2   | 1   | 0   |
|--------|------|-----------------|-----|-----|-----|------|----|------|------|-----|-----|-----|
| Доступ | U    | R/W             | R/W | R/W | R/W | U    | RO | U    | R/W  | R/W | R/W | R/W |
| Срос   | 0    | 0               | 0   | 0   | 0   | 0    | 1  | 0    | 0    | 0   | 0   | 0   |
|        | -    | WAIT_STATE[3:0] |     |     | -   | BUSY | -  | CPOL | NAND | RAM | ROM |     |

# Таблица 16-8 - Описание бит регистра CONTROL

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое        |
|------|----------------|--------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений             |
| 3116 | -              | Зарезервировано                                        |
| 1512 | WAIT           | Количество тактов шины АНВ, необходимых для            |
|      | STATE[3:0]     | стандартного цикла записи/чтения. Сигналы OE/WE        |
|      |                | устанавливаются в момент времени ¼ WAIT_STATE,         |
|      |                | снимаются в момент времени ¾ WAIT_STATE:               |
|      |                | 0000 – 3 такта HCLK                                    |
|      |                | 0001 – 4 такта HCLK                                    |
|      |                |                                                        |
|      |                | 1111 – 17 тактов HCLK                                  |
| 118  | <u>-</u>       | Зарезервировано                                        |
| 7    | BUSY           | Сигнал занятости NAND Flash-памяти:                    |
|      |                | 1 – операция завершена;                                |
|      |                | 0 – операция не завершена                              |
| 64   | <u>-</u>       | Зарезервировано                                        |
| 3    | CPOL           | Бит задания полярности сигнала CLOCK:                  |
|      |                | 0 – положительная полярность;                          |
|      |                | 1 – отрицательная полярность                           |
| 2    | NAND           | Бит глобального разрешения памяти NAND:                |
|      |                | 1 – выбрана NAND;                                      |
|      |                | 0 – NAND не выбрана.                                   |
|      |                | Одновременная установка нескольких бит 30 недопустима, |
|      |                | в этом случае запрещается работа со всей памятью       |
| 1    | RAM            | Бит глобального разрешения памяти RAM:                 |
|      |                | 1 – выбрана RAM;                                       |
|      |                | 0 – RAM не выбрана                                     |
| 0    | ROM            | Бит глобального разрешения памяти ROM:                 |
|      |                | 1 – выбрана ROM;                                       |
|      |                | 0 – ROM не выбрана                                     |

# 17 Контроллер прямого доступа в память MDR\_DMA

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

Данный контроллер имеет доступ к ОЗУ RISC части, всем периферийным модулям RISC и DSP, памяти программ и памяти данных DSP, контроллеру выхода на внешнюю шину. Контроллер не имеет доступа к ROM и Flash памяти RISC, ядра DSP (Таблица 17–1). Контроллер DMA регистрам содержит Аппаратные 32 аппаратных/программных запроса. запросы реализованы от большинства периферийных устройств RISC и DSP-подсистем (таблица 21-3). Каждый канал может быть сконфигурирован для обработки аппаратных или программных запросов.

Несмотря на то, что DSP-ядро не имеет доступа к регистрам DMA RISC, в системе реализован специальный регистр, предоставляющий возможность задавать запросы при помощи DSP-ядра. Подробнее об этом см. раздел «Организация управления DSP-подсистемой».

Таблица 17-1 - Таблица доступа к секторам памяти со стороны DMA RISC

| Адрес DMA<br>RISC | Сектор                             | Тип со стороны<br>DMA (RISC) |
|-------------------|------------------------------------|------------------------------|
| 0x0000_0000       | BOOT ROM                           | NA                           |
| 0x0800_0000       | EEPROM                             | NA                           |
| 0x1000_0000       | EXTERNAL BUS                       | WR                           |
| 0x2000_0000       | SYSTEM RAM                         | WR                           |
| 0x2200_0000       | SYSTEM RAM Bit Band Region         | NA                           |
| 0x3000_0000       | Регистры ядра DSP                  | NA                           |
| 0x3000_0040       | Регистры периферийных модулей DSP  | WR                           |
| 0x3000_0100       | Память данных DSP                  | WR                           |
| 0x3002_0000       | Память программ DSP                | WR                           |
| 0x3000_0040       | Регистры периферийных модулей RISC | WR                           |
| 0x5000_0000       | EXTERNAL BUS                       | WR                           |

#### Обозначения:

NA – нет доступа;

RO – только чтение;

WR – полный доступ (чтение/запись).

### 17.1 Основные свойства контроллера DMA

Основные свойства и отличительные особенности:

- 32 канала DMA;
- каждый канал DMA имеет свои сигналы управления передачей данных;
- каждый канал DMA имеет программируемый уровень приоритета;
- каждый уровень приоритета обрабатывается, исходя из уровня приоритета, определяемого номером канала DMA;
- поддержка различного типа передачи данных:
  - память память;

- память периферия;
- периферия память;
- поддержка различных типов DMA циклов;
- поддержка передачи данных различной разрядности;
- каждому каналу DMA доступна первичная и альтернативная структура управляющих данных канала;
- все управляющие данные канала хранятся в системной памяти;
- разрядность данных приемника равна разрядности данных передатчика;
- количество передач в одном цикле DMA может программироваться от 1 до 1024;
- инкремент адреса передачи может быть больше чем разрядность данных.

# 17.2 Термины и определения

При описании контроллера используются следующие термины:

# Таблица 17-2 - Термины и определения

| Альтернативная               | Альтернативная структура управляющих данных канала. Вы можете установить соответствующий регистр для изменения типа структуры данных (см. раздел «Структура управляющих данных канала»).                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| С                            | Идентификатор номера канала прямого доступа. Например:<br>C=1 - канал DMA 1<br>C=23 - канал DMA 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Канал                        | Возможны конфигурации контроллера с числом каналов до 32. Каждый канал содержит независимые сигналы управления передачей данных, которые могут инициировать передачу данных по каналу DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Управляющие данные<br>канала | Структура данных находится в системной памяти. Вы можете программировать эту структуру данных так, что контроллер может выполнять передачу данных по каналу DMA в желаемом режиме. Контроллер должен иметь доступ к области системной памяти, где находится эта информация.  Примечание - Любое упоминание в документе структуры данных означает управляющие данные канала.                                                                                                                                                                                                                                                                                     |
| Цикл DMA                     | Все передачи DMA, которые контроллер должен выполнить для передачи N пакетов данных.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Передача DMA                 | Акция пересылки одного байта, полуслова или слова. Общее количество передач DMA, которые контроллер выполняет для канала.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Пинг-понг                    | Режим работы для выбранного канала, при котором контроллер получает начальный запрос и затем выполняет цикл DMA, используя первичную или альтернативную структуру данных. После завершения этого цикла DMA контроллер начинает выполнять новый цикл DMA, используя другую структуру данных. Контроллер сигнализирует об окончании каждого цикла DMA, позволяя главному процессору перенастраивать неактивную структуру данных. Контроллер продолжает переключаться от первичной к альтернативной структуре данных и обратно, до тех пор, пока он не прочитает «неправильную» структуру данных или пока он не завершит цикл без переключения к другой структуре. |

| Первичная                                  | Первичная структура управляющих данных канала. Контроллер использует эту структуру данных, если соответствующий разряд в регистре chnl_pri_alt_set установлен в 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R                                          | Степень числа 2, устанавливающее число передач DMA, которые могут произойти перед сменой арбитража. Количество передач DMA программируется в диапазоне от 1 до 1024 двоичными шагами от 2 в степени 0 до 2 в степени 10.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Исполнение с<br>изменением<br>конфигурации | Режим работы для выбранного канала, при котором контроллер получает запрос от периферии и выполняет 4 DMA передачи, используя первичную структуру управляющих данных, которые настраивают альтернативную структуру управляющих данных. После чего контроллер начинает цикл DMA, используя альтернативную структуру данных. После того, как цикл закончится, если периферия устанавливает новый запрос на обслуживание, контроллер выполняет снова 4 DMA передачи, используя первичную структуру управляющих данных, которые опять перенастраивают альтернативную структуру управляющих данных. После чего контроллер начинает цикл DMA, используя альтернативную структуру данных. Контроллер будет продолжать работать вышеописанным способом до тех пор, пока не прочитает неправильную структуру данных или процессор не установит альтернативную структуру данных для обычного цикла. Контроллер устанавливает флаг dma_done, если окончание подобного режима работы происходит после выполнения обычного цикла. |  |  |

#### 17.3 Функциональное описание

Ниже (Рисунок 17–1) показана упрощенная структурная схема контроллера.



Рисунок 17-1 - Структурная схема контроллера

Контроллер состоит из следующих основных функциональных блоков:

- блок, подключенный к шине APB;
- блок, подключенный к шине АНВ;
- управляющий блок DMA.

#### 17.3.1 Распределение каналов DMA

Таблица 17-3 - Распределение каналов DMA

| Номер<br>канала | Источник reg | Источник sreg | Описание                             |
|-----------------|--------------|---------------|--------------------------------------|
| 0               | UART1 TX     | UART1 TX      | Запрос от UART1 по передаче          |
| 1               | UART1 RX     | UART1 RX      | Запрос от UART1 по приему            |
| 2               | UART2 TX     | UART2 TX      | Запрос от UART2 по передаче          |
| 3               | UART2 RX     | UART2 RX      | Запрос от UART2 по приему            |
| 4               | SSP1 TX      | SSP1 TX       | Запрос от SSP1 по передаче           |
| 5               | SSP1 RX      | SSP1 RX       | Запрос от SSP1 по приему             |
| 6               | SSP2 TX      | SSP2 TX       | Запрос от SSP2 по передаче           |
| 7               | SSP2 RX      | SSP2 RX       | Запрос от SSP2 по приему             |
| 8               | -            | ADC1          | Запрос от АЦП1                       |
| 9               | DSP0         | ADC2          | Запросы от ядра DSP/Запрос от АЦП2   |
| 10              | DSP1         | TIMER1        | Запросы от ядра DSP/Запрос от Timer1 |
| 11              | -            | TIMER2        | Запрос от Timer2                     |
| 12              | -            | TIMER3        | Запрос от Timer3                     |
| 13              | -            | SDIO          | Запрос от SDIO                       |
| 14              | DSP2         | DSP0          | Запросы от ядра DSP                  |
| 15              | DSP3         | DSP1          | Запросы от ядра DSP                  |
| 16              | SSP3 TX      | SSP3 TX       | Запрос от SSP3 по передаче           |
| 17              | SSP3 RX      | SSP3 RX       | Запрос от SSP3 по приему             |
| 18              | SSP4 TX      | SSP4 TX       | Запрос от SSP4 по передаче           |
| 19              | SSP4 RX      | SSP4 RX       | Запрос от SSP4 по приему             |
| 20              | UART3 TX     | UART3 TX      | Запрос от UART3 по передаче          |
| 21              | UART3 RX     | UART3 RX      | Запрос от UART3 по приему            |
| 22              | A_ADC(DSP)   | -             | Запрос от АЦП Аудиокодека(DSP)       |
| 23              | A_DAC(DSP)   | -             | Запрос от ЦАП Аудиокодека(DSP)       |
| 24              | Crypto(DSP)  | -             | Запрос от Криптомодуля(DSP)          |
| 25              | TIMER (DSP)  | TIMER (DSP)   | Запрос от таймера DSP части          |
| 26              | McBSP1 X     | McBSP1 X      | Запрос от McBSP1(DSP) по передаче    |
| 27              | McBSP1 R     | McBSP1 R      | Запрос от McBSP1(DSP) по приему      |
| 28              | McBSP2 X     | McBSP2 X      | Запрос от McBSP2(DSP) по передаче    |
| 29              | McBSP2 R     | McBSP2 R      | Запрос от McBSP2(DSP) по приему      |
| 30              | McBSP3 X     | McBSP3 X      | Запрос от McBSP3(DSP) по передаче    |
| 31              | McBSP3 R     | McBSP3 R      | Запрос от McBSP3(DSP) по приему      |

#### 17.3.2 Блок, подключенный к шине АРВ

Блок содержит набор регистров, позволяющих настраивать контроллер, используя ведомый APB интерфейс. Регистры занимают адресное пространство емкостью 4 кбайт.

#### 17.3.3 Блок, подключенный к шине АНВ

Контроллер содержит один блок типа «ведущий» шины DMA Bus, который позволяет, используя 32-х разрядную шину, передавать данные от источника к приемнику. Источник и приемник являются ведомыми шины AHB.

#### 17.3.4 Управляющий блок DMA

Этот блок содержит схему управления, позволяющую реализовать следующие функции:

- осуществление арбитража поступающих запросов;
- индикацию активного канала;
- индикацию завершения обмена по каналу;
- индикацию состояния ошибки обмена по шине DMA Bus;
- разрешение медленным устройствам приостанавливать исполнение цикла DMA;
- ожидание запроса на очистку до завершения цикла DMA;
- осуществление одиночных или множественных передач DMA для каждого запроса;
- осуществление следующих типов DMA передач:
  - память память;
  - память периферия;
  - периферия память.

# 17.3.5 Типы передач

Контроллер интерфейса не поддерживает пакетные передачи. Контроллер выполняет одиночные передачи. Отсутствие возможности осуществлять пакетные передачи оказывает минимальное влияние на производительность системы, так как пакетные передачи более эффективны в одноуровневых системах с шиной АНВ, где блоки должны «захватывать» шину или обращаться к внешней памяти. В тоже время контроллер DMA предназначен для использования в многоуровневых системах с шиной АНВ, включающих встроенную память.

#### 17.3.6 Разрядность передач данных

Контроллер интерфейса предоставляет возможность осуществлять передачу 8-, 16- и 32-разрядных данных. Таблица перечисляет значения комбинаций шины HSIZE.

Таблица 17-4 - Комбинации шины HSIZE

| HSIZE[2]*) | HSIZE[1] | HSIZE[0] | Разрядность<br>данных (бит) |
|------------|----------|----------|-----------------------------|
| 0          | 0        | 0        | 8                           |
| 0          | 0        | 1        | 16                          |
|            | 1        | 0        | 32                          |
|            | 1        | 1        | **)                         |

<sup>\*) -</sup> сигнал постоянно удерживается в состоянии логический ноль.

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

#### 17.3.7 Управление защитой данных

Контроллер позволяет устанавливать режимы защиты данных протокола AHB-Lite, определяемые шиной HPROT[3:1]. Возможен выбор следующих режимов защиты:

- кэширование;
- буферизация;
- привилегированный.

<sup>\*\*) -</sup> запрещенная комбинация

Таблица 17-5 перечисляет значения комбинаций шины HPROT.

Таблица 17-5 - Режимы защиты данных

| HPROT[3]<br>Кэширование | HPROT[2]<br>буферизация | HPROT[1]<br>Привилегиро-<br>ванный | HPROT[0]<br>Данные/<br>команда | Описание                 |
|-------------------------|-------------------------|------------------------------------|--------------------------------|--------------------------|
| -                       | -                       | -                                  | 1*)                            | Доступ к данным          |
| -                       | -                       | 0                                  | -                              | Пользовательский доступ  |
| -                       | -                       | 1                                  | -                              | Привилегированный доступ |
| -                       | 0                       | -                                  | -                              | Без буферизации          |
| -                       | 1                       | -                                  | -                              | Буферизированный         |
| 0                       | -                       | -                                  | -                              | Без кэширования          |
| 1                       | -                       | -                                  | -                              | Кэшированный             |

<sup>\*) –</sup> Контроллер удерживает HPROT[0] в состоянии логической единицы, чтобы обозначить доступ к данным.

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

Для каждого канала DMA также возможен выбор режима защиты данных. Более подробно это описано в разделе Управление DMA.

#### 17.3.8 Инкремент адреса

Контроллер позволяет управлять инкрементом адреса при чтении данных из источника и при записи данных в приемник. Инкремент адреса зависит от разрядности передаваемых данных. В следующей таблице перечислены возможные комбинации.

Таблица 17-6 - Инкремент адреса

| Разрядность данных | Величина инкремента    |
|--------------------|------------------------|
| 8                  | Байт, полуслово, слово |
| 16                 | Полуслово, слово       |
| 32                 | слово                  |

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

Примечание — Если необходимо оставлять адрес неизменным при чтении или записи данных, для примера, при работе с FIFO, можно соответствующим образом настроить контроллер на работу с фиксированным адресом (см. раздел 17.5 «Структура управляющих данных канала»).

# 17.4 Управление DMA

#### 17.4.1 Правила обмена данными

Контроллер использует правила обмена данными, перечисленные далее в Таблица 17–7, при соблюдении следующих условий:

- канал DMA включен, что выполняется установкой в состояние логической единицы разрядов управления chnl enable set[C] и master enable;
- флаги запроса dma\_req[C] и dma\_sreq[C] не замаскированы, что выполняется установкой в состояние логического нуля разряда управления chnl req mask set [C];
- контроллер находится не в тестовом режиме, что выполняется установкой в состояние логического нуля разряда управления int\_test\_en\_bit[C].

Таблица 17–7 – Правила, при которых передача данных по каналам разрешена, и запросы не маскируются

| Правило | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1       | Если dma_active[C] установлен в 0, то установка в 1 dma_req[C] или dma_sreq[C] на один или более тактов сигнала hclk, следующих или не следующих друг за другом, инициирует передачу по каналу номер C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2       | Контроллер осуществляет установку в 1 только одного разряда dma_active[C]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3       | Контроллер устанавливает в 1 dma_active[C] в момент начала передачи по каналу C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4       | Для типов циклов DMA, отличных от периферийного «Исполнение с изменением конфигурации», dma_active[C] остается в состоянии 1 до тех пор, пока контроллер не окончит передачи с номерами меньше, чем значение $2^R$ или чем число передач, указанное в регистре n_minus_1. В периферийном режиме «Исполнение с изменением конфигурации», dma_active[C] остается в состоянии 1 в течение каждой пары DMA передач, с использованием первичной и альтернативной структур управляющих данных. Таким образом, контроллер выполняет $2^R$ передач, используя первичную структуру управляющих данных, затем без осуществления арбитража выполняет передачи с номерами меньше, чем значение $2^R$ (или чем число передач, указанное в регистре n_minus_1), используя альтернативную структуру управляющих данных. По окончании последней передачи dma_active[C] сбрасывается в 0 |
| 5       | Контроллер устанавливает dma_active[C] в 0 на как минимум один такт сигнала hclk перед тем, как снова установит dma_active[C] или dma_active[] в 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6       | Для каналов, по которым разрешена передача, контроллер осуществляет установку в 1 только одного dma done[]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7       | Если dma_req[C] устанавливается в состояние 1 в момент, когда dma_active[C] или dma_stall также в состоянии 1, то это означает, что контроллер обнаружил запрос                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8       | Если разряды cycle_ctrl для канала установлены в состояние 3'b100, 3'b101, 3'b110, 3'b111, то dma_done[C] никогда не будет установлен в 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9       | Если все передачи по каналу завершены, и разряды cycle_ctrl позволяют удержание dma_done[C], то по срезу сигнала dma_active[] произойдут события: - если dma_stall в состоянии 0, контроллер устанавливает dma_done[] в состояние 1 продолжительностью один такт hclk - если dma_stall в состоянии 1, работа контроллера приостановлена. После того, как dma_stall будет установлен в 0, контроллер устанавливает dma_done[] в состояние 1 продолжительностью один такт hclk                                                                                                                                                                                                                                                                                                                                                                                            |

| Правило | Описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10      | Cocтoяние dma_waitonreq[C] можно изменять только при выключенном канале                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11      | Если dma_waitonreq[C] в состоянии 1, то сигнал dma_active[C] не перейдет в состояние 0 до тех пор, пока:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         | контроллер завершит 2 <sup>R</sup> передач (или число передач, указанное в регистре n_minus_1);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | dma_req[C] будет установлен в 0;<br>dma_sreq[C] будет установлен в 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12      | Если за один такт сигнала hclk перед установкой dma_active[C] в 0 dma_stall устанавливается в 1, то контроллер установит dma_active[C] в 0 на следующем такте сигнала hclk; передача по каналу С не завершится, пока не будет сброшен в 0 dma_stall                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13      | Контроллер игнорирует dma_sreq[C], если dma_waitonreq[C] в состоянии 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14      | Контроллер игнорирует dma_sreq[O], если dma_wattoffreq[O] в состоянии о                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15      | Для циклов DMA, отличных по типу от периферийного режима «Исполнение с                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15      | изменением конфигурации», по окончании 2 <sup>R</sup> передач контроллер устанавливает значение chnl_useburst_set[C] в состояние 0, если количество оставшихся передач меньше, чем 2 <sup>R</sup> . В периферийном режиме «Исполнение с изменением конфигурации» контроллер устанавливает значение chnl_useburst_set[C] в состояние 0 только, если количество оставшихся передач с использованием                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | альтернативной структуры управляющих данных меньше, чем 2 <sup>R</sup> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 16      | Для типов циклов DMA, отличных от периферийного режима «Исполнение с изменением конфигурации», если за один такт hclk до установки dma_active[C] в 1 dma_sreq[C] и dma_waitonreq[C] установлены в 1 и dma_req[C] установлен в 0, то контроллер выполняет одну DMA передачу. В периферийном режиме «Исполнение с изменением конфигурации», если за один такт hclk до установки dma_active[C] в 1 dma_sreq[C] и dma_waitonreq[C] установлены в 1 и dma_req[C] установлен в 0, контроллер выполняет $2^R$ передач с использованием первичной структуры управляющих данных. Затем без осуществления арбитража выполняет одну передачу, используя альтернативную структуру управляющих данных                                                                                                                                                                |
| 17      | Для типов циклов DMA, отличных от периферийного режима «Исполнение с изменением конфигурации», если за один такт hclk до установки dma_active[C] в 1, а dma_sreq[C] и dma_req[C] установлены в 1, то приоритет предоставляется dma_req[c], и контроллер выполняет $2^R$ (или число передач, указанное в регистре n_minus_1) DMA передач. В периферийном режиме «Исполнение с изменением конфигурации», если за один такт hclk до установки dma_active[C] в 1 dma_sreq[C] и dma_req[C] установлены в 1, то приоритет предоставляется dma_req[c], и контроллер выполняет $2^R$ передач с использованием первичной структуры управляющих данных, затем без осуществления арбитража выполняет передачи с номерами меньше, чем значение $2^R$ (или чем число передач, указанное в регистре n_minus_1), используя альтернативную структуру управляющих данных |
| 18      | Когда chnl_req_mask_set[C] установлен в 1, контроллер игнорирует запросы по dma_sreq[C] и dma_req[C]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

 $<sup>^*</sup>$ ) — Необходимо с осторожностью устанавливать эти разряды. Если значение, указанное в perистре n\_minus\_1 меньше, чем значение  $2^R$ , то контроллер не очистит paspяды chnl\_useburst\_set и поэтому запросы по dma\_sreq[C] будут маскированы. Если периферия не устанавливает dma\_req[C] в состояние 1, то контроллер никогда не выполнит необходимых передач.

При отключении канала контролер осуществляет DMA передачи согласно правилам, представленным в Таблица 17–8.

Таблица 17–8 – Правила осуществления DMA передач при «запрещенных» каналах

| Правило | Описание                                                                     |
|---------|------------------------------------------------------------------------------|
| 19      | Если dma_req[C] установлен в 1, то контроллер устанавливает dma_done[C] в    |
|         | 1. Это позволяет контроллеру показать центральному процессору запрос         |
|         | готовности, даже если канал выключен (запрещен)                              |
| 20      | Если dma_sreq[C] установлен в 1, то контроллер устанавливает dma_done[C] в   |
|         | 1 при условии dma_waitonreq[C] в 1 и chnl_useburst_set[C] в состоянии 0. Это |
|         | позволяет контроллеру показать центральному процессору запрос готовности,    |
|         | даже если канал выключен (запрещен)                                          |
| 21      | dma_active[C] всегда удерживается в состоянии 0                              |

#### 17.4.2 Диаграммы работы контроллера DMA

Данный раздел описывает примеры функционирования контроллера с использованием правил обмена данными, представленных ранее (Таблица 17–7):

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

*Примечание* – Все диаграммы, показанные далее в этом подразделе на рисунках ниже (Рисунок 17–2 - Рисунок 17–6), подразумевают следующее:

- hready находится в состоянии 1;
- АНВ «ведомый» всегда дает ответ «ОКАУ».

#### 17.4.2.1 Импульсный запрос на обработку

Рисунок 17–2 показывает временную диаграмму работы контроллера DMA при получении импульсного запроса от периферии.



Рисунок 17-2 - Диаграмма работы при получении импульсного запроса

Пояснения к диаграмме (Рисунок 17–2) приведены ниже.

# Таблица 17–9 – Пояснения к диаграмме работы при получении импульсного запроса

| T1      | Контроллер обнаружил запрос на обработку по каналу С (см. правило 1) при условии, что chnl_req_mask_set[С] находится в состоянии 0 (см. правило 18)                                                                                                                                                                                |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T4      | Контроллер устанавливает dma_active[C] (см. правила 2 и 3) и начинает DMA передачи по каналу C                                                                                                                                                                                                                                     |
| T4-T7   | Контроллер считывает управляющую данные канала, где: rc – чтение настроек канала, channel_cfg; rsp – чтение указателя адреса окончания данных источника, src data end ptr;                                                                                                                                                         |
| Т7      | rdp - чтение указателя адреса окончания данных приемника, dst_data_end_ptr При установленном dma_active[C] в 1 и при условии, что chnl_req_mask_set[C] находится в состоянии 0, контроллер обнаруживает импульс запроса на обработки по каналу С (см. правило 7). Контроллер обработает этот запрос в течение следующего арбитража |
| Т7-Т9   | Контроллер выполняет передачу DMA по каналу С, где:<br>RD – чтение данных;<br>WD – запись данных                                                                                                                                                                                                                                   |
| T9-T10  | Контроллер осуществляет запись настроек канала, channel_cfg, где wc – запись настроек канала, channel_cfg                                                                                                                                                                                                                          |
| T10     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 4)                                                                                                                                                                                                                                |
| T10-T11 | Контроллер удерживает dma_active[C] на,как минимум, один такт hclk (см. правило 5)                                                                                                                                                                                                                                                 |
| T11     | Если канал C имеет более высокий приоритет, то контроллер устанавливает dma_active[C], так как ранее на такте T7 был получен запрос на обработку (см. правила 2 и 3)                                                                                                                                                               |
| T12     | При установленном dma_active[C] в 1 и при условии, что chnl_req_mask_set[C] находится в состоянии 0, контроллер обнаруживает импульс запроса на обработки по каналу C (см. правило 7). Контроллер обработает этот запрос в течение следующего арбитража                                                                            |
| T14     | Контроллер игнорирует запрос по каналу С из-за отложенного запроса полученного на такте T12                                                                                                                                                                                                                                        |
| T17     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 4)                                                                                                                                                                                                                                |
| T17-T18 | Контроллер удерживает dma_active[C],как минимум, на один такт hclk (см. правило 5)                                                                                                                                                                                                                                                 |
| T18     | Если канал С имеет более высокий приоритет, то контроллер устанавливает dma_active[C], так как ранее на такте T12 был получен запрос на обработку (см. правила 2 и 3)                                                                                                                                                              |

# 17.4.2.2 Запрос на обработку по уровню

Рисунок 17–3 показывает временную диаграмму работы контроллера DMA при получении от периферии запроса на обработку по уровню.



Рисунок 17–3 – Диаграмма работы при получении запроса на обработку по уровню

Пояснения к диаграмме (Рисунок 17–3) представлены ниже (Таблица 17–10).

# Таблица 17–10 – Пояснения к диаграмме работы при получении запроса на обработку по уровню

| T1      | Контроллер обнаружил запрос на обработку по каналу С (Таблица 17–7, правило 1) при условии, что chnl_req_mask_set[C] находится в состоянии 0 (см. правило 18)                                                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T4      | Контроллер устанавливает dma_active[C] (см. правила 2 и 3) и начинает DMA передачи по каналу C                                                                                                                                                            |
| T4-T7   | Контроллер считывает управляющие данные канала, где: rc – чтение настроек канала, channel_cfg; rsp – чтение указателя адреса окончания данных источника, src_data_end_ptr; rdp - чтение указателя адреса окончания данных приемника, dst_data_end_ptr     |
| T7-T9   | Контроллер выполняет передачу DMA по каналу С, где:<br>RD – чтение данных<br>WD – запись данных                                                                                                                                                           |
| T9-T10  | Контроллер осуществляет запись настроек канала, channel_cfg, где wc – запись настроек канала, channel_cfg                                                                                                                                                 |
| T10     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 4). Контроллер обнаружил запрос на обработку по каналу С (см. правило 1) при условии, что chnl_req_mask_set[C] находится в состоянии 0 (см. правило 18). |
| T10-T11 | Контроллер удерживает dma_active[C] на как минимум один такт hclk (см. правило 5)                                                                                                                                                                         |
| T11     | Если канал C имеет более высокий приоритет, то контроллер устанавливает dma_active[C] и начинает вторую DMA передачу по каналу C                                                                                                                          |
| T11-T14 | Контроллер считывает управляющие данные канала                                                                                                                                                                                                            |
| T14-T16 | Контроллер выполняет передачу DMA по каналу С                                                                                                                                                                                                             |
| T15-T16 | Периферийный блок обнаруживает, что передача DMA началась и сбрасывает dma_req[C]                                                                                                                                                                         |
| T16-T17 | Контроллер осуществляет запись настроек канала channel_cfg                                                                                                                                                                                                |
| T17     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 4)                                                                                                                                                       |

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

запроса, в этом случае он должен установить сигнал dma\_stall. Установка сигнала dma stall предотвращает повторение выполненной передачи.

#### 17.4.2.3 Флаги завершения

Рисунок 17–4 демонстрирует функционирование сигнала (флага) dma\_done[] при следующих условиях:

- dma\_stall и dma\_waitonreq[] находятся в состоянии 0;
- dma stall установлен в 1;
- dma waitonreq[] установлен в 1.



Рисунок 17-4 - Диаграммы функционирования dma\_done

Пояснения к диаграмме (Рисунок 17–4), такты от Т0 до Т2, приведены в таблице ниже.

Таблица 17–11 – Пояснения функционирования dma\_done, такты от T0 до T2

| T1    | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание                                                                                                                                                               |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | передачи DMA (см. Таблица 17–7, правило 4)                                                                                                                                                                                           |
| T1-T2 | Контроллер завершает цикл DMA и если cycle_ctrl[2] установлен в 0, то устанавливает в 1 dma_done[C] на один такт hclk (см. правила 8 и 9). Для других разрешенных каналов сигнал dma_done[C] останется в состоянии 0 (см. правило 6) |

Пояснения к диаграмме (Рисунок 17–4), такты от Т10 до Т15, приведены в таблице ниже.

Таблица 17–12 – Пояснения функционирования dma\_done, такты от T10 до T15

| T11     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 4)                                                                                                                                  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T12-T13 | Периферийный блок сбрасывает сигнал dma_stall                                                                                                                                                                                        |
| T14-T15 | Контроллер завершает цикл DMA и если cycle_ctrl[2] установлен в 0, то устанавливает в 1 dma_done[C] на один такт hclk (см. правила 8 и 9). Для других разрешенных каналов сигнал dma_done[C] останется в состоянии 0 (см. правило 6) |

*Примечание к Т11* – Контроллер не устанавливает сигнал dma\_done[C], так как сигнал dma\_stall установлен в 1 в предшествующем такте hclk (см. правила 9, 12).

Пояснения к диаграмме (Рисунок 17–4), такты от Т20 до Т25, приведены в таблице ниже.

Таблица 17–13 – Пояснения функционирования dma\_done, такты от T20 до T25

| T20     | Контроллер выполнил передачу DMA, но из-за установленного в 1 dma_waitonreq[C] он должен ожидать сброса в 0 сигнала dma_req[C], перед тем как сбросить dma_active[C] (см. правило 11) и установить dma_done[C] (см. правило 9)        |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T21-T25 | Периферийный блок сбрасывает dma_req[C]                                                                                                                                                                                               |
| T24     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 4)                                                                                                                                   |
| T24-T25 | Контроллер завершает цикл DMA и, если cycle_ctrl[2] установлен в 0, то устанавливает в 1 dma_done[C] на один такт hclk (см. правила 8 и 9). Для других разрешенных каналов сигнал dma_done[C] останется в состоянии 0 (см. правило 6) |

#### 17.4.2.4 Флаги ожидания запроса на обработку

Ниже приведены рисунки, которые демонстрируют примеры использования флагов ожидания запроса на обработку при выполнении  $2^{\rm R}$  передач и одиночных передач:

- диаграмма работы контроллера DMA при использовании периферией dma\_waitonreq;
- диаграмма работы контроллера DMA при использовании периферией dma waitonreq совместно с dma sreq.



Рисунок 17–5 – Диаграмма работы контроллера DMA при использовании dma\_waitonreq

Пояснения к диаграмме (Рисунок 17–5) приведены в таблице ниже.

Таблица 17–14 – Пояснения работы контроллера DMA при использовании dma\_waitonreq

| T0-T16 | Периферийный блок должен оставлять состояние dma_waitonreq[C] постоянно (см. правило 10)                                                                        |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T0-T1  | Контроллер обнаружил запрос на обработку по каналу С (см. правило 1) при условии, что chnl_req_mask_set[C] находится в состоянии 0 (см. правило 18)             |
| T3-T4  | Периферийный блок удерживает dma_req[C] и dma_sreq[C] в 1.<br>Контроллер игнорирует dma_sreq[C] запрос и отвечает на dma_req[C] запрос<br>(см. правила 16 и 17) |
| T4     | Контроллер устанавливает dma_active[C] (см. правила 2 и 3) и начинает DMA передачи по каналу C                                                                  |
| T4-T7  | Контроллер считывает управляющие данные канала, где:<br>rc – чтение настроек канала, channel_cfg;                                                               |

| T7-T9   | rsp – чтение указателя адреса окончания данных источника, src_data_end_ptr; rdp - чтение указателя адреса окончания данных приемника, dst_data_end_ptr Контроллер выполняет передачу DMA по каналу C, где: RD – чтение данных; WD – запись данных             |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T9-T11  | Контроллер считывает 2 указателя адреса окончания данных rsp и rdp                                                                                                                                                                                            |
| T11-T13 | Периферийный блок сбрасывает сигналы dma_req[C] и dma_sreq[C]                                                                                                                                                                                                 |
| T15-T16 | Контроллер осуществляет запись настроек канала, channel_cfg, где wc – запись настроек канала, channel_cfg                                                                                                                                                     |
| T16     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 11). Контроллер устанавливает значение по чтению регистра chnl_useburst_set[C] в 0, если количество оставшихся передач менее 2 <sup>R</sup> (см. правило 15) |

Рисунок 17–6 показывает работу контроллера DMA при установке dma waitonreq в 1 и выполнении одиночной DMA передачи.



Рисунок 17–6 – Работа DMA при использовании dma\_waitonreq совместно с dma\_sreq

Пояснения к диаграмме (Рисунок 17-6) приведены в таблице ниже.

Таблица 17–15 – Пояснения работы DMA при использовании dma\_waitonreq совместно c dma\_sreq

| T0-T13 | Периферийный блок должен оставлять состояние dma_waitonreq[C] постоянно (см. правило 10)                                                                                                                                                              |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| T0-T1  | Контроллер обнаружил запрос на обработку по каналу С (см. правило 1) при условии, что chnl_useburst_set[C] находится в состоянии 0 (см. правила 13 и 14)                                                                                              |
| T3-T4  | Контроллер отвечает на dma_sreq[C] запрос (см. правила 16)                                                                                                                                                                                            |
| T4     | Контроллер устанавливает dma_active[C] (см. правила 2 и 3) и начинает DMA передачи по каналу C                                                                                                                                                        |
| T4-T7  | Контроллер считывает управляющие данные канала, где: rc – чтение настроек канала, channel_cfg; rsp – чтение указателя адреса окончания данных источника, src_data_end_ptr; rdp - чтение указателя адреса окончания данных приемника, dst_data_end_ptr |
| T7-T9  | Контроллер выполняет передачу DMA по каналу С, где:<br>RD – чтение данных;                                                                                                                                                                            |

|         | WD – запись данных.<br>Это запрос в ответ на dma_sreq[], таким образом, R=0 и, следовательно, контроллер исполнит 1 DMA передачу |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------|--|
| T10-T11 | Периферийный блок сбрасывает сигнал dma_sreq[C]                                                                                  |  |
| T12_T13 | Контроллер осуществляет запись настроек канала, channel_cfg, где wc – запись настроек канала, channel_cfg                        |  |
| T13     | Контроллер сбрасывает сигнал dma_active[C], что указывает на окончание передачи DMA (см. правило 11)                             |  |

# 17.4.3 Правила арбитража DMA

Контроллер имеет возможность настройки момента арбитража при передачах DMA. Эта возможность позволяет уменьшить время отклика при обслуживании каналов с высоким приоритетом.

Контроллер имеет 4 разряда, которые определяют количество транзакций по шине АНВ до повторения арбитража. Эти разряды задают степень R числа 2; изменение R напрямую устанавливает периодичность арбитража как 2 в степени R. Для примера, если R равно 4, то арбитраж будет проводиться через каждые 16 передач DMA.

Таблица 17–16 показывает возможную периодичность арбитража.

Таблица 17-16 - Периодичность арбитража в единицах передач по шине АНВ

| Значение <b>R</b> | Периодичность арбитража каждые x передач DMA |
|-------------------|----------------------------------------------|
| b0000             | 1                                            |
| b0001             | 2                                            |
| b0010             | 4                                            |
| b0011             | 8                                            |
| b0100             | 16                                           |
| b0101             | 32                                           |
| b0110             | 64                                           |
| b0111             | 128                                          |
| b1000             | 256                                          |
| b1001             | 512                                          |
| b1010-b1111       | 1024                                         |

Примечание – Необходимо с осторожностью устанавливать большие значения R для низкоприоритетных каналов, так как это может привести к невозможности обслуживать запросы по высокоприоритетным каналам.

При N >  $2^R$  (N — номер передачи) и если результат деления  $2^R$  на N не целое число, контроллер всегда выполняет последовательность из  $2^R$  передач до тех пор, пока не станет верным N< $2^R$ . Контроллер выполняет оставшиеся N передач в конце цикла DMA.

Разряды степени R числа 2 находятся в структуре управляющих данных канала. Местонахождение этих разрядов описано в разделе «Управляющие данные канала».

#### **17.4.4** Приоритет

При проведении арбитража определяется канал для обслуживания в следующем цикле DMA. На выбор следующего канала влияют:

• номер канала

• уровень приоритета, присвоенного каналу.

Каждому каналу может быть присвоен уровень приоритета по умолчанию (низкий) или высокий уровень приоритета. Присвоение уровня приоритета осуществляется установкой или сбросом разряда chnl\_priority\_set.

Канал номер 0 имеет высший уровень приоритета и уровень приоритета снижается с увеличением номера канала. Таблица 17–17 показывает уровень приоритета каналов DMA в порядке его уменьшения.

Таблица 17-17 - Уровень приоритета каналов DMA

| Уровень приоритета<br>в порядке его уменьшения | Номер канала | Уровень приоритета,<br>установленный битом<br>chnl_priority_set |
|------------------------------------------------|--------------|-----------------------------------------------------------------|
| Наивысший уровень приоритета                   | 0            | Высокий                                                         |
| -                                              | 1            | Высокий                                                         |
| -                                              | 2            | Высокий                                                         |
|                                                |              |                                                                 |
| -                                              | 30           | Высокий                                                         |
| -                                              | 31           | Высокий                                                         |
| -                                              | 0            | По умолчанию (низкий)                                           |
| -                                              | 1            | По умолчанию (низкий)                                           |
| -                                              | 2            | По умолчанию (низкий)                                           |
|                                                |              |                                                                 |
| -                                              | 30           | По умолчанию (низкий)                                           |
| Низший уровень приоритета                      | 31           | По умолчанию (низкий)                                           |

После окончания цикла DMA контроллер выбирает следующий для обслуживания канал из всех включенных каналов DMA. Рисунок 17–7 иллюстрирует процесс выбора следующего канала для обслуживания.



Рисунок 17–7 – Алгоритм выбора следующего канала для обслуживания

# 17.4.5 Типы циклов DMA

Разряды cycle\_ctrl определяют, как контроллер будет выполнять циклы DMA. Описание значений этих разрядов приведено ниже.

Таблица 17-18 - Типы циклов DMA

| cycle_ctrl | Описание                                                    |
|------------|-------------------------------------------------------------|
| b000       | Структура управляющих данных канала в запрещенном состоянии |
| b001       | Обычный цикл DMA                                            |
| b010       | Авто-запрос                                                 |
| b011       | Режим «пинг-понг»                                           |
| b100       | Работа с памятью в режиме «Исполнение с изменением          |
|            | конфигурации»                                               |
|            | с использованием первичных управляющих данных канала        |
| b101       | Работа с памятью в режиме «Исполнение с изменением          |
|            | конфигурации»                                               |
|            | с использованием альтернативных управляющих данных канала   |
| b110       | Работа с периферией в режиме «Исполнение с изменением       |
|            | конфигурации» с использованием первичных управляющих данных |
|            | канала                                                      |
| b111       | Работа с периферией в режиме «Исполнение с изменением       |
|            | конфигурации» с использованием альтернативных управляющих   |
|            | данных канала                                               |

Примечание — Разряды cycle\_ctrl находятся в области памяти, отведенной под channel cfg – см. раздел «Настройка управляющих данных канала».

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

Данный раздел описывает следующие типы циклов DMA:

- недействительный;
- основной;
- авто-запрос;
- «ПИНГ-ПОНГ»;
- работа с памятью в режиме «исполнение с изменением конфигурации»;
- работа с периферией в режиме «исполнение с изменением конфигурации».

#### 17.4.5.1 Недействительный

После окончания цикла DMA контроллер устанавливает тип цикла в значение «недействительный» для предотвращения повтора выполненного цикла DMA.

#### 17.4.5.2 Основной

- В этом режиме контроллер работает только с основными или альтернативными управляющими данными канала. После того, как разрешена работа канала, и контроллер получил запрос на обработку, цикл DMA выглядит следующим образом:
- 1. Контроллер выполняет 2R передач. Если число оставшихся передач 0, контроллер переходит к шагу 3.
  - 2. Осуществление арбитража:
    - если высокоприоритетный канал выдает запрос на обработку, то контроллер начинает обслуживание этого канала;
    - если периферийный блок или программное обеспечение выдает запрос на обработку (повторный запрос на обработку по каналу), то контроллер переходит к шагу 1.
- 3. Контроллер устанавливает dma\_done[C] в состояние 1 на один такт сигнала hclk. Это указывает центральному процессору на завершение цикла DMA.

# 17.4.5.3 Авто-запрос

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

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

работа канала, и контроллер получил запрос на обработку, цикл DMA выглядит следующим образом:

- 1. Контроллер выполняет 2R передач для канала C. Если число оставшихся передач 0, контроллер переходит к шагу 3.
  - 2. Осуществление арбитража:
    - если высокоприоритетный канал выдает запрос на обработку, то контроллер начинает обслуживание этого канала;
    - если периферийный блок или программное обеспечение выдает запрос на обработку (повторный запрос на обработку по каналу), то контроллер переходит к шагу 1.
- 3. Контроллер устанавливает dma\_done[C] в состояние 1 на один такт сигнала hclk. Это указывает центральному процессору на завершение цикла DMA.

#### 17.4.5.4 Пинг-понг

В данном режиме контроллер выполняет цикл DMA, используя одну из структур управляющих данных, а затем выполняет еще один цикл DMA, используя другую структуру управляющих данных. Контроллер выполняет циклы DMA с переключением структур до тех пор, пока не считает «неправильную» структуру данных или пока процессор не запретит работу канала.

Рисунок 17–8 демонстрирует пример функционирования контроллера в режиме «пинг-понг».



Рисунок 17-8 - Пример функционирования контроллера в режиме «пинг-понг»

Пояснения к схеме (Рисунок 17-8):

**Шаг А** Процессор устанавливает первичную структуру управляющих данных для шага A.

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

Контроллер получает запрос и выполняет 4 передачи DMA.

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

Контроллер выполняет оставшиеся 2 передачи DMA.

Контроллер устанавливает dma\_done[C] в состояние 1 на один такт сигнала синхронизации hclk и входит в процедуру арбитража

После выполнения шага А процессор может установить первичные управляющие данные канала для шага С. Это позволит контроллеру переключиться к шагу С незамедлительно после выполнения шага В, при условии, что контроллер не получит запрос на обработку от высокоприоритетного канала.

После получения нового запроса на обработку от канала при условии его наивысшего приоритета исполняется шаг В:

#### **Шаг В** Контроллер выполняет 4 передачи DMA.

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

Контроллер выполняет 4 передачи DMA.

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

Контроллер выполняет оставшиеся 4 передачи DMA.

Контроллер устанавливает dma\_done[C] в состояние 1 на один такт сигнала синхронизации hclk и входит в процедуру арбитража

После выполнения шага В процессор может установить альтернативные управляющие данные канала для шага D.

После получения нового запроса на обработку от канала при условии его наивысшего приоритета исполняется шаг С:

#### **Шаг С** Контроллер выполняет 2 передачи DMA.

Контроллер устанавливает dma\_done[C] в состояние 1 на один такт сигнала синхронизации hclk и входит в процедуру арбитража

После выполнения шага С процессор может установить первичные управляющие данные канала для шага Е.

После получения нового запроса на обработку от канала при условии его наивысшего приоритета исполняется шаг D:

#### **Шаг D** Контроллер выполняет 4 передачи DMA.

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

Контроллер выполняет оставшуюся передачу DMA.

Контроллер устанавливает dma\_done[C] в состояние 1 на один такт сигнала синхронизации hclk и входит в процедуру арбитража

После получения нового запроса на обработку от канала при условии его наивысшего приоритета исполняется шаг Е:

#### **Шаг Е** Контроллер выполняет 4 передачи DMA.

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

Контроллер выполняет оставшиеся 3 передачи DMA.

Контроллер устанавливает dma\_done[C] в состояние 1 на один такт сигнала синхронизации hclk и входит в процедуру арбитража

Если контроллер получит новый запрос на обработку от данного канала и этот запрос будет самым приоритетным, контроллер предпримет попытку выполнения следующего шага. Однако из-за того, что процессор не установил альтернативные управляющие данные, и по окончанию шага D контроллер установил cycle\_ctrl в состояние b000, передачи DMA прекращаются.

Примечание — Для прерывания цикла DMA, исполняемого в режиме «пингпонг», также возможен перевод режима работы контроллера на шаге Е в режим «Основной цикл DM» путем установки cycle ctrl в 3'b001.

### 17.4.5.5 Режим работы с памятью «исполнение с изменением конфигурации»

В данном режиме контроллер, получая начальный запрос на обработку, выполняет 4 передачи DMA, используя первичные управляющие данные. По окончании этих передач контроллер начинает цикл DMA используя альтернативные управляющие данные. Затем контроллер выполняет еще 4 передачи DMA, используя первичные управляющие данные. Контроллер продолжает выполнять циклы ПДА, меняя структуры управляющих данных, пока не произойдет одно из следующих условий:

- процессор переведет контроллер в режим «Основной» во время цикла с альтернативной структурой
- контроллер считает «неправильную» структуру управляющих данных.

Примечание — После исполнения контроллером N передач с использованием первичных управляющих данных он делает эти управляющие данные «неправильными» путем установки cycle ctrl в 3'b000.

Контроллер устанавливает флаг dma\_done[C] в этом режиме работы только тогда, когда передача DMA заканчивается с использованием основного цикла.

В данном режиме контроллер использует первичные управляющие данные для программирования альтернативных управляющих данных. Таблица 17–19 перечисляет области памяти channel\_cfg, как те, которые должны быть определены константами, так и те, значения которых определяются пользователем.

Таблица 17–19 – Channel\_cfg для первичной структуры управляющих данных в режиме работы с памятью «исполнение с изменением конфигурации»

| № бита | № бита Обозначение Значение |           | Описание                                           |  |  |
|--------|-----------------------------|-----------|----------------------------------------------------|--|--|
|        |                             | Области   | с константными значениями                          |  |  |
| 3130   | dst_inc                     | b'10      | Контроллер производит инкремент адреса пословно    |  |  |
| 2928   | dst_size                    | b'10      | Контроллер осуществляет передачу пословно          |  |  |
| 2726   | src_inc                     | b'10      | Контроллер производит инкремент адреса пословно    |  |  |
| 2524   | src_size                    | b'10      | Контроллер осуществляет передачу пословно          |  |  |
| 1714   | R_power                     | b'0010    | Контроллер выполняет 4 передачи DMA                |  |  |
| 3      | next_useburst               | b'0       | Для данного режима этот разряд должен быть равен 0 |  |  |
| 20     | cycle_ctrl                  | b'100     | Контролер работает в режиме работы с периферией    |  |  |
|        |                             |           | «исполнение с изменением конфигурации»             |  |  |
|        | Области                     | го значен | иями, определяемыми пользователем                  |  |  |
| 2321   | dst_prot_ctrl               | -         | Определяет состояние HPROT при записи данных в     |  |  |
|        |                             |           | приемник                                           |  |  |
| 2018   | src_prot_ctrl               | -         | Определяет состояние HPROT при чтении данных из    |  |  |
|        |                             |           | источника                                          |  |  |
| 134    | n_minus_1                   | N*)       | Настраивает контроллер на выполнение N передач     |  |  |
|        |                             |           | DMA, где N кратно 4                                |  |  |

\*) – Так как R\_power задает значение 4, то необходимо задавать значение N, кратное 4. Число, равное N/4, это количество раз, которое нужно настраивать альтернативные управляющие данные.

Рисунок 17–9 демонстрирует пример функционирования в режиме работы с памятью «Исполнение с изменением конфигурации».

## Инициализация:

- 1. Настройка первичных управляющих данных для разрешения копирования A, B, C и D: cycle  $\,$  ctrl=b100,  $\,$  2 $^{R}$ =4, N=16.
- 2. Запись первичных данных в память с использованием структуры, показанной в таблице ниже.

| -               | -                |                  | _                                            |            |
|-----------------|------------------|------------------|----------------------------------------------|------------|
|                 | src_data_end_ptr | dst_data_end_ptr | channel_cfg                                  | Unused     |
| Data for Task A | 0x0A000000       | 0x0AE00000       | cycle_ctrl = b101, 2 <sup>R</sup> = 4, N = 3 | 0xXXXXXXXX |
| Data for Task B | 0x0B000000       | 0x0BE00000       | cycle_ctrl = b101, 2 <sup>R</sup> = 2, N = 8 | 0xXXXXXXXX |
| Data for Task C | 0x0C000000       | 0x0CE00000       | cycle_ctrl = b101, 2 <sup>R</sup> = 8, N = 5 | 0xXXXXXXXX |
| Data for Task D | 0x0D000000       | 0x0DE00000       | cycle_ctrl = b001, 2 <sup>R</sup> = 4, N = 4 | 0xXXXXXXXX |



Рисунок 17–9 – Пример работы DMA в режиме «Исполнение с изменением конфигурации»

Пояснения к схеме (Рисунок 17-9):

#### Инициализация:

- 1. Процессор настраивает первичную структуру управляющих данных для работы в режиме работы с памятью «исполнение с изменением конфигурации» путем установки cycle\_ctrl в b100. Так как управляющие данные канала состоят из 4 слов, необходимо установить  $2^R$  в 4. В этом примере количество задач равно 4 и поэтому N установлен в 16.
- 2. Процессор записывает управляющие данные для шагов A, B, C, D в область памяти с адресом, указанным в src\_data\_end\_ptr.
  - 3. Процессор разрешает работу канала DMA.

Передачи в данном режиме начинают исполняться при получении контроллером запроса на обслуживание по dma\_req[] или запроса от процессора. Порядок выполнения следующий:

## Первичная, копирование А

По получению запроса на обслуживание контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага A.

Контроллер генерирует автозапрос для канала, после чего проводит процедуру арбитража.

#### Шаг А

Контроллер выполняет шаг А. По окончании контроллер генерирует автозапрос для канала и проводит процедуру арбитража.

#### Первичная, копирование В

Контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага В.

Контроллер генерирует автозапрос для канала, после чего проводит процедуру арбитража.

#### Шаг В

Контроллер выполняет шаг В. По окончании контроллер генерирует автозапрос для канала и проводит процедуру арбитража.

## Первичная, копирование С

Контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага С.

Контроллер генерирует автозапрос для канала, после чего проводит процедуру арбитража.

## Шаг С

Контроллер выполняет шаг С. По окончании контроллер генерирует автозапрос для канала и проводит процедуру арбитража.

## Первичная, копирование D

Контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага D.

Контроллер устанавливает cycle\_ctrl первичных управляющих данных в b000 для индикации о том, что эта структура управляющих данных является «неправильной».

Контроллер генерирует автозапрос для канала, после чего проводит процедуру арбитража.

#### Шаг D

Контроллер выполняет шаг D, используя основной цикл DMA.

Контроллер устанавливает флаг dma\_done[C] в состояние 1 на один такт сигнала hclk и входит в процедуру арбитража.

# 17.4.5.6 Режим работы с периферией «исполнение с изменением конфигурации»

В данном режиме контроллер, получая начальный запрос на обработку, выполняет 4 передачи DMA, используя первичные управляющие данные. По окончании этих передач контроллер начинает цикл DMA, используя альтернативные управляющие данные без осуществления арбитража и не устанавливая сигнал dma\_active[C] в 0.

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

После того, как этот цикл завершился, контроллер выполняет арбитраж и по получении запроса на обслуживание от периферии, имеющего наивысший приоритет, он выполняет еще 4 передачи DMA, используя первичные управляющие данные. По окончании этих передач контроллер начинает цикл DMA, используя альтернативные управляющие данные без осуществления арбитража и не устанавливая сигнал dma\_active[C] в 0.

Контроллер продолжает выполнять циклы ПДА, меняя структуры управляющих данных, пока не произойдет одно из следующих условий:

процессор переведет контроллер в режим «Основной» во время цикла с альтернативной структурой;

контроллер считает «неправильную» структуру управляющих данных.

Примечание – После исполнения контроллером N передач с использованием первичных управляющих данных, он делает эти управляющие данные «неправильными» путем установки cycle ctrl в 3'b000.

Контроллер устанавливает флаг dma\_done[C] в этом режиме работы только тогда, когда передача DMA заканчивается с использованием основного цикла.

В данном режиме контроллер использует первичные управляющие данные для программирования альтернативных управляющих данных. Таблица 17–20 перечисляет области памяти channel\_cfg, как те, которые должны быть определены константами, так и те, значения которых определяются пользователем.

Таблица 17–20 – Channel\_cfg для первичной структуры управляющих данных в режиме работы с периферией «Исполнение с изменением конфигурации»

| № бита | Обозначение                       | Значение    | Описание                                             |  |  |  |  |  |  |
|--------|-----------------------------------|-------------|------------------------------------------------------|--|--|--|--|--|--|
|        | Области с константными значениями |             |                                                      |  |  |  |  |  |  |
| 3130   | dst_inc                           | b'10        | Контроллер производит инкремент адреса пословно      |  |  |  |  |  |  |
| 2928   | dst_size                          | b'10        | Контроллер осуществляет передачу пословно            |  |  |  |  |  |  |
| 2726   | src_inc                           | b'10        | Контроллер производит инкремент адреса пословно      |  |  |  |  |  |  |
| 2524   | src_size                          | b'10        | Контроллер осуществляет передачу пословно            |  |  |  |  |  |  |
| 1714   | R_power                           | b'0010      | Контроллер выполняет 4 передачи DMA                  |  |  |  |  |  |  |
| 20     | cycle_ctrl                        | b'110       | Контролер работает в режиме работы с периферией      |  |  |  |  |  |  |
|        | •                                 |             | «исполнение с изменением конфигурации»               |  |  |  |  |  |  |
|        | Области                           | и со значен | иями, определяемыми пользователем                    |  |  |  |  |  |  |
| 2321   | dst_prot_ctrl                     | -           | Определяет состояние HPROT при записи данных в       |  |  |  |  |  |  |
|        |                                   |             | приемник                                             |  |  |  |  |  |  |
| 2018   | src_prot_ctrl                     | -           | Определяет состояние HPROT при чтении данных из      |  |  |  |  |  |  |
|        |                                   |             | источника                                            |  |  |  |  |  |  |
| 134    | n_minus_1                         | N*)         | Настраивает контроллер на выполнение N передач       |  |  |  |  |  |  |
|        |                                   |             | DMA, где N кратно 4                                  |  |  |  |  |  |  |
| 3      | next_useburst                     | -           | При установке в 1 контроллер установит               |  |  |  |  |  |  |
|        |                                   |             | chnl_useburst_set[C] в 1 после выполнения передачи с |  |  |  |  |  |  |
|        |                                   |             | альтернативной структурой                            |  |  |  |  |  |  |

\*) – Так как R\_power задает значение 4, то необходимо задавать значение N, кратное 4. Число, равное N/4, это количество раз, которое нужно настраивать альтернативные управляющие данные.

Следующий рисунок демонстрирует пример функционирования в режиме работы с периферией «исполнение с изменением конфигурации».

#### Инициализация:

- 1. Настройка первичных управляющих данных для разрешения копирования A, B, C и D: cycle  $\,$  ctrl=b110,  $\,$  2<sup>R</sup>=4, N=16.
- 2. Запись первичных данных в память с использованием структуры, показанной в таблице ниже.

|                 | src_data_end_ptr | dst_data_end_ptr | channel_cfg                                  | Unused     |
|-----------------|------------------|------------------|----------------------------------------------|------------|
| Data for Task A | 0x0A000000       | 0x0AE00000       | cycle_ctrl = b111, 2 <sup>R</sup> = 4, N = 3 | 0xXXXXXXXX |
| Data for Task B | 0x0B000000       | 0x0BE00000       | cycle_ctrl = b111, 2 <sup>R</sup> = 2, N = 8 | 0xXXXXXXXX |
| Data for Task C | 0x0C000000       | 0x0CE00000       | cycle_ctrl = b111, 2 <sup>R</sup> = 8, N = 5 | 0xXXXXXXXX |
| Data for Task D | 0x0D000000       | 0x0DE00000       | cycle_ctrl = b001, 2 <sup>R</sup> = 4, N = 4 | 0xXXXXXXXX |



Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4 Рисунок 17–10 – Пример работы DMA в режиме с «Исполнением с изменением конфигурации»

Пояснения к схеме (Рисунок 6–10)

Инициализация:

- 1. Процессор настраивает первичную структуру управляющих данных для работы в режиме работы с периферией «исполнение с изменением конфигурации» путем установки cycle\_ctrl в b110. Так как управляющие данные канала состоят из 4 слов, необходимо установить 2<sup>R</sup> в 4. В этом примере количество задач равно 4 и поэтому N установлен в 16.
- 2. Процессор записывает управляющие данные для шагов A, B, C, D в область памяти с адресом, указанным в src data end ptr.
  - 3. Процессор разрешает работу канала DMA.

Передачи в данном режиме начинают исполняться при получении контроллером запроса на обслуживание по dma\_req[]. Передачи выполняются следующим образом:

## Первичная, копирование из области А памяти

По получению запроса на обслуживание, контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага A.

#### Шаг А

Контроллер выполняет шаг А.

По окончании контроллер проводит процедуру арбитража.

## Первичная, копирование из области В памяти

Контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага В.

#### Шаг В

Контроллер выполняет шаг В. Для завершения задачи периферия должна установить последовательно 3 запроса.

По окончании контроллер проводит процедуру арбитража.

#### Первичная, копирование из области С памяти

Контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага С.

## Шаг С

Контроллер выполняет шаг С.

По окончании контроллер проводит процедуру арбитража.

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

## Первичная, копирование из области D памяти

Контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага D.

Контроллер устанавливает cycle\_ctrl первичных управляющих данных в b000 для индикации о том, что эта структура управляющих данных является «неправильной».

#### Шаг D

Контроллер выполняет шаг D, используя основной цикл DMA.

Контроллер устанавливает флаг dma\_done[C] в состояние 1 на один такт сигнала hclk и входит в процедуру арбитража.

#### 17.4.6 Индикация ошибок

При получении контроллером по шине АНВ ответа об ошибке, он выполняет следующие действия:

- 1. отключает канал, связанный с ошибкой;
- 2. устанавливает флаг dma err в состояние 1.

После обнаружения процессором флага dma\_err процессор определяет номер канала, который был активен в момент появления ошибки. Для этого он осуществляет следующее:

- чтение perистра chnl\_enable\_set с целью создания списка отключенных каналов:
- если канал установил флаг dma\_done[], то контроллер отключает канал. Программа, выполняемая процессором, должна всегда хранить данные о каналах, которые недавно установили флаги dma\_done[];
- процессор должен сравнить список выключенных каналов, полученный в шаге 1, с данными о каналах, которые недавно устанавливали флаги dma\_done[]. Канал, по которому отсутствуют данные об установке флага dma\_done[], это и есть канал, с которым связана ошибка.

## 17.5 Структура управляющих данных канала

В системной памяти должна быть отведена область для хранения управляющих данных каналов. Системная память должна:

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

Рисунок 17–11 показывает область памяти, необходимую контроллеру для структур управляющих данных канала, при использовании всех 32 каналов и опциональной альтернативной структуры управляющих данных.

| Alternate data str                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ucture                                                                                                                                                                                                                                 | Primary data st                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ructure                                                                                                                                                                                                                       |   |          |                                            |                                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------|--------------------------------------------|----------------------------------|
| Alternate data str  Alternate_Ch_31 Alternate_Ch_29 Alternate_Ch_28 Alternate_Ch_27 Alternate_Ch_26 Alternate_Ch_25 Alternate_Ch_25 Alternate_Ch_23 Alternate_Ch_23 Alternate_Ch_21 Alternate_Ch_21 Alternate_Ch_19 Alternate_Ch_19 Alternate_Ch_15 Alternate_Ch_15 Alternate_Ch_15 Alternate_Ch_14 Alternate_Ch_13 Alternate_Ch_11 Alternate_Ch_10 Alternate_Ch_5 Alternate_Ch_5 | 0x3F0<br>0x3E0<br>0x3D0<br>0x3C0<br>0x3B0<br>0x3A0<br>0x3A0<br>0x380<br>0x370<br>0x360<br>0x350<br>0x340<br>0x330<br>0x320<br>0x310<br>0x2F0<br>0x2E0<br>0x2E0<br>0x2D0<br>0x2E0<br>0x2B0<br>0x2A0<br>0x290<br>0x280<br>0x270<br>0x260 | Primary data st  Primary_Ch_31  Primary_Ch_29  Primary_Ch_28  Primary_Ch_26  Primary_Ch_25  Primary_Ch_25  Primary_Ch_23  Primary_Ch_23  Primary_Ch_22  Primary_Ch_21  Primary_Ch_21  Primary_Ch_19  Primary_Ch_18  Primary_Ch_17  Primary_Ch_15  Primary_Ch_15  Primary_Ch_14  Primary_Ch_13  Primary_Ch_11  Primary_Ch_11  Primary_Ch_11  Primary_Ch_11  Primary_Ch_12  Primary_Ch_15  Primary_Ch_15  Primary_Ch_16  Primary_Ch_17  Primary_Ch_17  Primary_Ch_18  Primary_Ch_19  Primary_Ch_10  Primary_Ch_5 | 0x1F0<br>0x1E0<br>0x1D0<br>0x1C0<br>0x1B0<br>0x1A0<br>0x190<br>0x180<br>0x170<br>0x160<br>0x150<br>0x140<br>0x130<br>0x120<br>0x110<br>0x0F0<br>0x0E0<br>0x0D0<br>0x0C0<br>0x0B0<br>0x0A0<br>0x0A0<br>0x080<br>0x070<br>0x060 |   |          |                                            |                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                               |   |          |                                            |                                  |
| Alternate_Ch_4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x250<br>0x240                                                                                                                                                                                                                         | Primary_Ch_4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x050<br>0x040                                                                                                                                                                                                                | _ |          |                                            |                                  |
| Alternate_Ch_3 Alternate_Ch_2 Alternate_Ch_1 Alternate_Ch_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x240<br>0x230<br>0x220<br>0x210<br>0x200                                                                                                                                                                                              | Primary_Ch_3 Primary_Ch_2 Primary_Ch_1 Primary_Ch_0                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x040<br>0x030<br>0x020<br>0x010<br>0x000                                                                                                                                                                                     |   | Destinat | Unused Control Ion End Pointer End Pointer | 0x00C<br>0x008<br>0x004<br>0x000 |

Рисунок 17–11 – Карта памяти для 32-х каналов, включая альтернативную структуру

Пример, приведенный выше (см. Рисунок 17–11), использует 1 Кбайт системной памяти. В этом примере контроллер использует младшие 0x10 разрядов адреса для доступа ко всем элементам структуры управляющих данных, и поэтому базовый адрес структуры должен быть 0xxxxxx000, далее 0xxxxxx400, далее 0xxxxxx000.

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

Необходимый размер области системной памяти зависит:

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

Таблица 17–21 перечисляет разряды адреса, обеспечивающие контроллеру доступ к различным элементам структуры управляющих данных, в зависимости от количества каналов, используемых в контроллере.

Таблица 17–21 – Разряды адреса, соответствующие элементам структуры управляющих данных

|                                                      |     |      | Разр | ояды адр | еса  |      |       |
|------------------------------------------------------|-----|------|------|----------|------|------|-------|
| Количество каналов,<br>используемых в<br>контроллере | [9] | [8]  | [7]  | [6]      | [5]  | [4]  | [3:0] |
| 1                                                    |     |      |      |          |      | Α    |       |
| 2                                                    |     |      |      |          | Α    | C[0] | 0x0   |
| 3-4                                                  |     |      |      | Α        | C[1] | C[0] | 0x4   |
| 5-8                                                  |     |      | Α    | C[2]     | C[1] | C[0] | 0x8   |
| 9-16                                                 |     | Α    | C[3] | C[2]     | C[1] | C[0] |       |
| 17-32                                                | Α   | C[4] | C[3] | C[2]     | C[1] | C[0] |       |

Где А выбирает одну из структур управляющих данных канала:

А = 0 выбирает первичную структуру управляющих данных;

А = 1 выбирает альтернативную структуру управляющих данных.

C[x:0] Выбирает канал DMA.

Address[3:0] Выбирает один из управляющих элементов:

0х0 выбирает указатель конца данных источника;

0х4 выбирает указатель конца данных приемника;

0х8 выбирает конфигурацию управляющих данных;

0xC контроллер не имеет доступа к этому адресу. Если это необходимо, то возможно разрешить процессору использовать эти адреса в качестве системной памяти.

Примечание – Совсем не обязательно вычислять базовый адрес альтернативной структуры управляющих данных, так как регистр alt\_ctrl\_base\_ptr содержит эту информацию.

Рисунок 17–12 демонстрирует пример реализации контроллера с использованием 3 каналов DMA и с альтернативной структурой управляющих данных.



Рисунок 17–12 – Карта памяти для трех каналов DMA, включая альтернативную структуру

Этот пример структуры управляющих данных использует 128 байт системной памяти. В нем контроллер использует младшие 0x06 разрядов адреса для доступа ко всем элементам структуры управляющих данных. Поэтому базовый адрес структуры должен быть 0xXXXXXX00, далее 0xXXXXXX80.

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

## Таблица 17–22 – Разрешенные базовые адреса

| Количество<br>каналов DMA | Разрешенные значения базового адреса для первичной структуры<br>управляющих данных |
|---------------------------|------------------------------------------------------------------------------------|
| 17-32                     | 0xXXXXX000, 0xXXXXX400, 0xXXXXX800, 0xXXXXXC00                                     |

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

- указатель конца данных источника;
- указатель конца данных приемника;
- разряды управления;
- вычисление адреса.

### Указатель конца данных источника

Область памяти под названием src\_data\_end\_ptr содержит указатель на последний адрес месторасположения данных источника.

## Таблица 17-23 - Значения разрядов src\_data\_end\_ptr

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 310       | src_data_end_ptr           | Указатель последнего адреса данных источника                                               |

Перед тем, как контроллер выполнит передачу DMA, необходимо определить эту область памяти. Контроллер считывает значение этой области перед началом 2R передачи DMA.

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

- 1. Контроллер не имеет доступа по записи в эту область памяти.
- 2. Значение записываемое в этот регистр должно быть кратно разрядности транзакций. (Для 32-разрядных передач младшие два байта нули, для 16-разрядных передач младший байт ноль, в случае байтовых передач возможен любой адрес.)

#### Указатель конца данных приемника

Область памяти под названием dst\_data\_end\_ptr содержит указатель на последний адрес месторасположения данных приемника.

Таблица 17-24 - Значения разрядов dst data end ptr

| Nº   | Функциональное Расшифровка функционального имени бита, кра |                                               |  |  |  |  |
|------|------------------------------------------------------------|-----------------------------------------------|--|--|--|--|
| бита | имя бита                                                   | описание назначения и принимаемых значений    |  |  |  |  |
| 310  | dst_data_end_ptr                                           | Указатель на последний адрес данных приемника |  |  |  |  |

Перед тем, как контроллер выполнит передачу DMA, необходимо определить эту область памяти. Контроллер считывает значение этой области перед началом 2R передачи DMA.

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

- 1. Контроллер не имеет доступа по записи в эту область памяти.
- 2. Значение записываемое в этот регистр должно быть кратно разрядности транзакций. (Для 32-разрядных передач младшие два байта нули, для 16-разрядных передач младший байт ноль, в случае байтовых передач возможен любой адрес.)

## Разряды управления

Область памяти под названием channel\_cfg обеспечивает управление каждой передачей DMA.

Таблица 17-25 - Название разрядов области памяти channel\_cfg

| Номер  | 31 | 30      | 29 | 28       | 27 | 26      | 25 | 24       | 2321          | 2018          | 1714    | 134       | 3             | 20         |
|--------|----|---------|----|----------|----|---------|----|----------|---------------|---------------|---------|-----------|---------------|------------|
| Доступ |    |         |    |          |    |         |    |          |               |               |         |           |               |            |
| Сброс  |    |         |    |          |    |         |    |          |               |               |         |           |               |            |
|        |    | ast_inc |    | dst_size |    | รเร_เทธ |    | Si CSize | dst_prot_crtl | Src_prot_ctrl | R_power | n_minus_1 | next_useburst | cycle_ctrl |

Таблица 17–26 объясняет назначение разрядов этой области памяти.

Таблица 17-26 - Назначение разрядов channel\_cfg

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                    |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                         |
| 3130 | dst_src        | Шаг инкремента адреса приемника. Шаг инкремента адреса зависит от разрядности данных источника. Разрядность данных источника = байт: b00 = байт;                   |
|      |                | b00 – байт,<br>b01 = полуслово (16 разрядов);<br>b10 = слово (32 разряда);<br>b11 = нет инкремента. Адрес остается равным значению                                 |
|      |                | области памяти dst_data_end_ptr. Разрядность данных источника = полуслово: b00 = зарезервировано;                                                                  |
|      |                | b01 = полуслово;<br>b10 = слово;<br>b11 = нет инкремента. Адрес остается равным значению                                                                           |
|      |                | области памяти dst_data_end_ptr. Разрядность данных источника = слово: b00 = зарезервировано;                                                                      |
|      |                | b01 = зарезервировано;                                                                                                                                             |
|      |                | b10 = слово (32 разряда);<br>b11 = нет инкремента. Адрес остается равным значению<br>области памяти dst_data_end_ptr                                               |
| 2928 | dst_size       | Размерность данных приемника  Примечание — Значение этого поля должно быть равно значению поля src size                                                            |
| 2726 | src_inc        | Шаг инкремента адреса источника.<br>Шаг инкремента адреса зависит от разрядности данных источника.                                                                 |
|      |                | Разрядность данных источника = байт:<br>b00 = байт;<br>b01 = полуслово;                                                                                            |
|      |                | b10 = слово (32 разряда);<br>b11 = нет инкремента. Адрес остается равным значению<br>области памяти src_data_end_ptr.<br>Разрядность данных источника = полуслово: |
|      |                | b00 = зарезервировано                                                                                                                                              |

|      |               | Tio                                                      |
|------|---------------|----------------------------------------------------------|
|      |               | b01 = полуслово                                          |
|      |               | b10 = слово                                              |
|      |               | b11 = нет инкремента. Адрес остается равным значению     |
|      |               | области памяти src_data_end_ptr.                         |
|      |               | Разрядность данных источника = слово:                    |
|      |               | b00 = зарезервировано;                                   |
|      |               | b01 = зарезервировано;                                   |
|      |               | b10 = слово;                                             |
|      |               | b11 = нет инкремента. Адрес остается равным значению     |
|      |               | области памяти src_data_end_ptr                          |
| 2524 | src_size      | Задает размерность данных источника:                     |
|      |               | b00 = байт;                                              |
|      |               | b01 = полуслово (в русском обычно слово);                |
|      |               | b10 = слово (в русском обычно двойное слово);            |
|      |               | b11 = зарезервировано                                    |
| 2321 | dst_prot_ctrl | Задает состояние HPROT[3:1], когда контроллер записывает |
|      | <b>_,</b> _   | данные в приемник.                                       |
|      |               | Разряд 23     управляет разрядом HPROT[3]:               |
|      |               | 0 = HPROT[3] в состоянии 0 и доступ не кэшируется;       |
|      |               | 1 = HPROT[3] в состоянии 1 и доступ кэшируется.          |
|      |               | Разряд 22 управляет разрядом HPROT[2]:                   |
|      |               | 0 = HPROT[2] в состоянии 0 и доступ не буферизуется;     |
|      |               | 1 = HPROT[2] в состоянии 1 и доступ буферизуется.        |
|      |               | Разряд 21 управляет разрядом HPROT[1]:                   |
|      |               | 0 = HPROT[1] в состоянии 0 и доступ непривилегированный; |
|      |               | 1 = HPROT[1] в состоянии 1 и доступ привилегированный    |
| 2018 | src_prot_ctrl | Задает состояние HPROT[3:1], когда контроллер считывает  |
|      | _, _          | данные из источника.                                     |
|      |               | Разряд 20 управляет разрядом HPROT[3]:                   |
|      |               | 0 = HPROT[3] в состоянии 0 и доступ не кэшируется;       |
|      |               | 1 = HPROT[3] в состоянии 1 и доступ кэшируется.          |
|      |               | Разряд 19 управляет разрядом HPROT[2]:                   |
|      |               | 0 = HPROT[2] в состоянии 0 и доступ не буферизуется;     |
|      |               | 1 = HPROT[2] в состоянии 1 и доступ буферизуется.        |
|      |               | Разряд 18 управляет разрядом HPROT[1]:                   |
|      |               | 0 = HPROT[1] в состоянии 0 и доступ непривилегированный; |
|      |               | 1 = HPROT[1] в состоянии 1 и доступ привилегированный    |
| 1714 | R_power       | Задает количество передач DMA до выполнения              |
|      | <u></u> F-001 | контроллером процедуры арбитража.                        |
|      |               | Возможные значения:                                      |
|      |               | b0000 – арбитраж производится после каждой передачи      |
|      |               | DMA;                                                     |
|      |               | b0001 – арбитраж производится после 2 передач DMA;       |
|      |               | b0010 – арбитраж производится после 4 передач DMA;       |
|      |               | b0011 – арбитраж производится после 8 передач DMA;       |
|      |               | b0100 – арбитраж производится после 16 передач DMA;      |
|      |               | b0101 – арбитраж производится после 32 передач DMA;      |
|      |               | b0110 – арбитраж производится после 64 передач DMA;      |
|      |               | b0111 – арбитраж производится после 128 передач DMA;     |
|      |               | b1000 – арбитраж производится после 256 передач DMA;     |
|      |               | b1001 – арбитраж производится после 512 передач DMA;     |
|      |               | b1010 – b1111 – арбитраж производится после 1024 передач |
|      |               | DMA. Это означает, что арбитраж не производится, так как |
|      |               | максимальное количество передач DMA равно 1024           |
| 134  | n_minus_1     | Перед выполнением цикла DMA эти разряды указывают        |
|      |               | общее количество передач DMA, из которых состоит цикл    |

|    |               | DMA. Необходимо установить эти разряды в значение, соответствующее размеру желаемого цикла DMA. 10-разрядное число плюс 1 задает количество передач DMA. Возможные значения: b00000000000 = 1 передача DMA; b0000000001 = 2 передачи DMA; b0000000010 = 3 передачи DMA; b000000011 = 4 передачи DMA; b000000010 = 5 передач DMA; b0000000101 = 6 передач DMA; b0111111111 = 1024 передачи DMA. Контроллер обновит это поле перед тем, как произвести процесс арбитража. Это позволяет контроллеру хранить                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |               | количество оставшихся передач DMA до завершения цикла DMA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3  | next_useburst | Контролирует, не установлен ли chnl_useburst_set[C] в состояние 1, если контроллер работает в режиме работы с периферией «Исполнение с изменением конфигурации» и если контроллер завершает цикл DMA, используя альтернативные управляющие данные.  Примечание — Перед завершением цикла DMA, использующего альтернативные управляющие данные, контроллер устанавливает chnl_useburst_set[C] в значение 0, если количество оставшихся передач DMA меньше, чем 2 <sup>R</sup> . Установка next_useburst разряда определяет, будет ли контроллер дополнительно переопределять разряд chnl_useburst_set[C].  Если контроллер выполняет цикл DMA в режиме работы с периферией «Исполнение с изменением конфигурации», то после окончания цикла, использующего альтернативные управляющие данные, происходит следующее в зависимости от состояния next_useburst:  О — контроллер не изменяет значение chnl_useburst_set[C]. Если chnl_useburst_set[C] установлен в 0, то для всех оставшихся циклов DMA в режиме работы с периферией «Исполнение с изменением конфигурации», контроллер отвечает на запросы по dma_req[] и dma_sreq[], при выполнении циклов DMA он использует альтернативные управляющие данные.  1 — контроллер изменяет значение chnl_useburst_set[C] в состояние 1. Поэтому для оставшихся циклов DMA в режиме работы с периферией «Исполнение с изменением конфигурации», контроллер реагирует только на запросы по dma_req[], при выполнении циклов DMA он использует альтернативные управляющие данные. |
| 20 | cycle_ctrl    | Режим работы при выполнении цикла DMA: b000 <b>Стоп</b> . Означает, что структура управляющих данных                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|    |               | является «неправильной»; b001 Основной. Контроллер должен получить новый запрос для окончания цикла DMA, перед этим он должен выполнить процедуру арбитража; b010 Авто-запрос. Контроллер автоматически осуществляет запрос на обработку по соответствующему каналу в течение процедуры арбитража. Это означает, что начального запроса на                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| ботку достаточно для выполнения цикла DMA;                               |
|--------------------------------------------------------------------------|
| <b>-понг</b> . Контроллер выполняет цикл DMA                             |
| льзую одну из структур управляющих данных.                               |
| кончании выполнения цикла DMA, контроллер                                |
| олняет следующий цикл DMA, используя                                     |
| ую структуру. Контроллер сигнализирует об                                |
| чании каждого цикла DMA, позволяя                                        |
| ессору перенастраивать неактивную структуру                              |
| ых. Контроллер продолжает выполнять циклы                                |
| х, до тех пор, пока он не прочитает                                      |
| равильную» структуру данных или пока                                     |
| рессор не изменит cycle ctrl поле в состояние                            |
| или b 010;                                                               |
| Режим работы с памятью «Исполнение с                                     |
|                                                                          |
| ригурации». Смотрите соответствующий                                     |
|                                                                          |
| работе контроллера в данном режиме значение                              |
| о поля в первичной структуре управляющих                                 |
| ных должно быть b100;                                                    |
| Режим работы с памятью «Исполнение с                                     |
| TOMMIN PAGGIBLE O HAMPITBLE WHOTESTHOTHE O                               |
| оигурации». Смотрите соответствующий                                     |
| ли урации. Омотрите соответствующий                                      |
| работе контроллера в данном режиме значение                              |
|                                                                          |
| о поля в альтернативной структуре<br>вляющих данных должно быть b101;    |
| вляющих данных должно оыть отот,<br>им работы с периферией «исполнение с |
| ·                                                                        |
| енением конфигурации».                                                   |
| трите соответствующий раздел.                                            |
| работе контроллера в данном режиме значение                              |
| о поля в первичной структуре управляющих                                 |
| ных должно быть b110;                                                    |
| им работы с периферией «исполнение с                                     |
| енением конфигурации».                                                   |
| трите соответствующий раздел.                                            |
| работе контроллера в данном режиме значение                              |
| о поля в альтернативной структуре                                        |
| вляющих данных должно быть b111                                          |
|                                                                          |

В начале цикла DMA или 2<sup>R</sup> передачи DMA контроллер считывает значение channel\_cfg из системной памяти. После выполнения 2R или N передач он сохраняет обновленное значение channel\_cfg в системную память.

Контроллер не поддерживает значений dst\_size, отличных от значений src\_size. Если контроллер обнаруживает неравные значения этих полей, он использует значение src\_size в качестве размера данных и приемника, и источника и при ближайшем обновлении поля n\_minus\_1, он также устанавливает значение поля dst\_size, равное src\_size.

После выполнения контроллером N передач, контроллер устанавливает значение поля cycle\_ctrl в b000, делая тем самым channel\_cfg данные «неправильными». Это позволяет избежать повторения выполненной передачи DMA.

#### Вычисление адреса

Для вычисления адреса источника передачи DMA, контроллер выполняет сдвиг влево значения n minus 1 на количество разрядов, соответствующее полю

src\_inc, и затем вычитает получившееся значение от значения указателя адреса конца данных источника. Подобным образом вычисляется адрес передатчика передачи DMA, контроллер выполняет сдвиг влево значения n\_minus\_1 на количество разрядов, соответствующее полю dst\_inc, и затем вычитает получившееся значение от значения указателя адреса конца данных приемника.

В зависимости от значения полей src\_inc и dst\_inc вычисления адресов приемника и источника выполняются по следующим уравнениям:

```
src_inc=b00 and dst_inc=b00 адрес источника = src_data_end_ptr - n_minus_1 адрес приемника = dst_data_end_ptr - n_minus_1.

src_inc=b01 and dst_inc=b01 адрес источника = src_data_end_ptr - (n_minus_1<<1) адрес приемника = dst_data_end_ptr - (n_minus_1<<1).

src_inc=b01 and dst_inc=b10 адрес источника = src_data_end_ptr - (n_minus_1<<2) адрес приемника = dst_data_end_ptr - (n_minus_1<<2).

src_inc=b11 and dst_inc=b11 - адрес источника = src_data_end_ptr - (n_minus_1<<2).
```

Таблица 17–27 перечисляет адреса приемника цикла DMA для 6 слов.

Таблица 17–27 – Цикла DMA для 6 слов с пословным инкрементом

| Начальные значения channel_cfg перед циклом DMA |                                               |                   |                      |       |  |  |  |
|-------------------------------------------------|-----------------------------------------------|-------------------|----------------------|-------|--|--|--|
|                                                 | src_size=b10, dst_i                           | nc=b10, n_minus_  | 1=b101, cycle_ctrl=1 |       |  |  |  |
|                                                 | Указатель Счетчик Отличие <sup>*)</sup> Адрес |                   |                      |       |  |  |  |
| DMA                                             | конца данных                                  |                   |                      |       |  |  |  |
| передачи                                        | 0x2AC                                         | 5                 | 0x14                 | 0x298 |  |  |  |
|                                                 | 0x2AC                                         | 4                 | 0x10                 | 0x29C |  |  |  |
|                                                 | 0x2AC                                         | 3                 | 0xC                  | 0x2A0 |  |  |  |
|                                                 | 0x2AC                                         | 2                 | 0x8                  | 0x2A4 |  |  |  |
|                                                 | 0x2AC                                         | 1                 | 0x4                  | 0x2A8 |  |  |  |
|                                                 | 0x2AC 0 0x0 0x2AC                             |                   |                      |       |  |  |  |
| Конечные значения channel_cfg после цикла DMA   |                                               |                   |                      |       |  |  |  |
|                                                 | src_size=b10, dst                             | _inc=b10, n_minus | s_1=0, cycle_ctrl=0  |       |  |  |  |

<sup>\*</sup> это значение, полученное после сдвига влево значения счетчика на количество разрядов, соответствующее dst\_inc.

Таблица 17–28 перечисляет адреса приемника для передач DMA 12 байт с использованием «полусловного» инкремента.

Таблица 17–28 – Цикла DMA для 12 байт с «полусловным» инкрементом

| Начальные значения channel_cfg перед циклом DMA                       |              |           |       |       |  |  |  |
|-----------------------------------------------------------------------|--------------|-----------|-------|-------|--|--|--|
| src_size=b00, dst_inc=b01, n_minus_1=b1011, cycle_ctrl=1, R_power=b11 |              |           |       |       |  |  |  |
|                                                                       | Указатель    | Отличие*) | Адрес |       |  |  |  |
| DMA                                                                   | конца данных |           |       |       |  |  |  |
| передачи                                                              | 0x5E7        | 11        | 0x16  | 0x5D1 |  |  |  |
|                                                                       | 0x5E7        | 10        | 0x14  | 0x5D3 |  |  |  |

|                                                                      | 0x5E7                                     | 9                 | 0x12                 | 0x5D5    |  |  |
|----------------------------------------------------------------------|-------------------------------------------|-------------------|----------------------|----------|--|--|
|                                                                      |                                           |                   |                      |          |  |  |
|                                                                      | 0x5E7                                     | 8                 | 0x10                 | 0x5D7    |  |  |
|                                                                      | 0x5E7                                     | 7                 | 0xE                  | 0x5D9    |  |  |
|                                                                      | 0x5E7                                     | 6                 | 0xC                  | 0x5DB    |  |  |
|                                                                      | 0x5E7                                     | 5                 | 0xA                  | 0x5DD    |  |  |
|                                                                      | 0x5E7                                     | 4                 | 0x8                  | 0x5DF    |  |  |
|                                                                      | Значения channel_cfg после 2R передач DMA |                   |                      |          |  |  |
| src_siz                                                              | ze=b00, dst_inc=b0                        | 1, n_minus_1=b011 | , cycle_ctrl=1, R_pc | ower=b11 |  |  |
|                                                                      | 0x5E7                                     | 3                 | 0x6                  | 0x5E1    |  |  |
| DMA                                                                  | 0x5E7                                     | 2                 | 0x4                  | 0x5E3    |  |  |
| передачи                                                             | 0x5E7                                     | 1                 | 0x2                  | 0x5E5    |  |  |
|                                                                      | 0x5E7                                     | 0                 | 0x0                  | 0x5E7    |  |  |
| Конечные значения channel_cfg после цикла DMA                        |                                           |                   |                      |          |  |  |
| src_size=b00, dst_inc=b01, n_minus_1=0, cycle_ctrl=0**), R_power=b11 |                                           |                   |                      |          |  |  |

<sup>\* –</sup> это значение, полученное после сдвига влево значения счетчика на количество разрядов, соответствующее dst\_inc.

## 17.6 Описание регистров контроллера DMA

Данный раздел описывает регистры контроллера и управление контроллером через них.

Раздел содержит следующие сведения:

- о регистровой модели контроллера;
- описание регистров.

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

- нужно избегать адресации при доступе к зарезервированным или неиспользованным адресам, так как это может привести к непредсказуемым результатам;
- необходимо заполнять неиспользуемые или зарезервированные разряды регистров нулями при записи и игнорировать значения таких разрядов при считывании, кроме случаев, специально описанных в разделе;
- системный сброс или сброс по установке питания сбрасывает все регистры в состояние 0, кроме случаев, специально описанных в разделе;
- все регистры поддерживают доступ по чтению и записи, кроме случаев, специально описанных в разделе. Доступ по записи обновляет содержание регистра, а доступ по чтению возвращает содержимое регистра.

Таблица 17-29 - Перечень регистров контроллера

| Смещение отн.   | Наименование  | Тип | Значение по             | Описание                   |
|-----------------|---------------|-----|-------------------------|----------------------------|
| базового адреса |               |     | сбросу                  |                            |
| 0x40028000      | MDR_DMA       |     |                         | Контроллер DMA             |
| 0x000           | STATUS        | RO  | 11 1V_( 1mm( 1) 11 11 1 | MDR_DMA->STATUS            |
| 0.000           |               |     |                         | Статусный регистр DMA      |
| 0x004           | CFG           | wo  | _                       | MDR_DMA->CFG               |
| 0.004           | Ci G          | VVO | _                       | Регистр конфигурации DMA   |
|                 |               |     |                         | MDR_DMA->CTRL_BASE_PTR     |
| 0x008           | CTRL_BASE_PTR | R/W | 0x00000000              | Регистр базового адреса    |
|                 |               |     |                         | управляющих данных каналов |

<sup>\*\* –</sup> после окончания цикла DMA контроллер делает channel\_cfg «неправильным», сбрасывая в 0 поле cycle ctrl.

| Смещение отн.<br>базового адреса | Наименование      | Тип | Значение по<br>сбросу | Описание                                                                                                  |
|----------------------------------|-------------------|-----|-----------------------|-----------------------------------------------------------------------------------------------------------|
| 0x00C                            | ALT_CTRL_BASE_PTR | RO  | 0x000000nn**)         | MDR_DMA->ALT_CTRL_BASE_PTR<br>Регистр базового адреса<br>альтернативных управляющих<br>данных каналов     |
| 0x010                            | WAITONREQ_STATUS  | RO  | 0x00000000            | MDR_DMA->WAITONREQ_STATUS Регистр статуса ожидания запроса на обработку каналов                           |
| 0x014                            | CHNL_SW_REQUEST   | WO  | -                     | MDR_DMA->CHNL_SW_REQUEST<br>Регистр программного запроса на<br>обработку каналов                          |
| 0x018                            | CHNL_USEBURST_SET | R/W | 0x00000000            | MDR_DMA->CHNL_USEBURST_SET Регистр установки пакетного обмена каналов                                     |
| 0x01C                            | CHNL_USEBURST_CLR | WO  | -                     | MDR_DMA->CHNL_USEBURST_CLR<br>Регистр сброса пакетного обмена<br>каналов                                  |
| 0x020                            | CHNL_REQ_MASK_SET | R/W | 0x00000000            | MDR_DMA->CHNL_REQ_MASK_SET<br>Регистр маскирования запросов на<br>обслуживание каналов                    |
| 0x024                            | CHNL_REQ_MASK_CLR | WO  | -                     | MDR_DMA->CHNL_REQ_MASK_CLR Регистр очистки маскирования запросов на обслуживание каналов                  |
| 0x028                            | CHNL_ENABLE_SET   | R/W | 0x00000000            | MDR_DMA->CHNL_ENABLE_SET Регистр установки разрешения каналов                                             |
| 0x02C                            | CHNL_ENABLE_CLR   | WO  | -                     | MDR_DMA->CHNL_ENABLE_CLR<br>Регистр сброса разрешения каналов                                             |
| 0x030                            | CHNL_PRI_ALT_SET  | R/W | 0x00000000            | MDR_DMA->CHNL_PRI_ALT_SET Регистр установки первичной/альтернативной структуры управляющих данных каналов |
| 0x034                            | CHNL_PRI_ALT_CLR  | WO  | -                     | MDR_DMA->CHNL_PRI_ALT_CLR Регистр сброса первичной/альтернативной структуры управляющих данных каналов    |
| 0x038                            | CHNL_PRIORITY_SET | R/W | 0x00000000            | DFMDR_DMA-<br>>CHNL_PRIORITY_SET<br>Регистр установки приоритета<br>каналов                               |
| 0x03C                            | CHNL_PRIORITY_CLR | WO  | -                     | MDR_DMA->CHNL_PRIORITY_CLR<br>Регистр сброса приоритета каналов                                           |
| 0x040-0x048                      | -                 |     | -                     | Зарезервировано                                                                                           |
| 0x04C                            | ERR_CLR           | R/W | 0x00000000            | MDR_DMA->ERR_CLR<br>Регистр сброса флага ошибки                                                           |
| 0x050-0xDFC                      | -                 | -   |                       | Зарезервировано                                                                                           |

<sup>\* –</sup> значение по сбросу зависит от количества каналов DMA, использованных в контроллере, а также от того, интегрирована ли схема тестирования.

<sup>\*\* –</sup> значение по сбросу зависит от количества каналов DMA, использованных в контроллере.

## 17.6.1 *MDR\_DMA->STATUS*

Статусный регистр DMA

Данный регистр имеет доступ только на чтение. При чтении регистр возвращает состояние контроллера. Если контроллер находится в состоянии сброса, то чтение регистра запрещено. Таблица 17–31 перечисляет назначение разрядов регистра.

Таблица 17-30 - Статусный регистр DMA

| Номер  | 3128        | 2721 | 2016         | 158 | 74    | 31 | 0             |
|--------|-------------|------|--------------|-----|-------|----|---------------|
| Доступ | RO          | U    | RO           | U   | RO    | U  | RO            |
| Сброс  | 0           | 0    | 0            | 0   | 0     | 0  | 0             |
|        | test_status | -    | chnls_minus1 | -   | state | -  | master_enable |

Таблица 17-31 - Назначение разрядов регистра dma\_status

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3128      | test_status             | Значение при чтении:                                                                       |
| 3120      | เษรเ_รเสเนร             | 0x0 = контроллер не имеет интегрированной схемы тестирования;                              |
|           |                         | 0х1 = контроллер имеет интегрированной ехемы тестирования;                                 |
|           |                         | 0x2 - 0xF = не определено                                                                  |
| 2721      | -                       | Не определено                                                                              |
| 2016      | chnls minus1            | Количество доступных каналов DMA минус 1.                                                  |
|           | _                       | Например:                                                                                  |
|           |                         | b00000 = контроллер имеет 1 канал DMA;                                                     |
|           |                         | b00001 = контроллер имеет 2 канала DMA;                                                    |
|           |                         | b00010 = контроллер имеет 3 канала DMA;                                                    |
|           |                         |                                                                                            |
|           |                         | b11111 = контроллер имеет 32 канала DMA                                                    |
| 158       | -                       | Не определено                                                                              |
| 74        | state                   | Текущее состояние автомата управления контроллера.                                         |
|           |                         | Состояние может быть одним из следующих:                                                   |
|           |                         | b0000 = в покое;                                                                           |
|           |                         | b0001 = чтение управляющих данных канала;                                                  |
|           |                         | b0010 = чтение указателя конца данных источника;                                           |
|           |                         | b0011 = чтение указателя конца данных приемника;                                           |
|           |                         | b0100 = чтение данных источника;                                                           |
|           |                         | b0101 = запись данных в приемник;                                                          |
|           |                         | b0110 = ожидание запроса на выполнение DMA;                                                |
|           |                         | b0111 = запись управляющих данных канала;                                                  |
|           |                         | b1000 = приостановлен;                                                                     |
|           |                         | b1001 = выполнен;                                                                          |
|           |                         | b1010 = режим работы с периферией «Исполнение с                                            |
|           |                         | изменением конфигурации»;                                                                  |
| 0.4       |                         | b1011-b1111 = не определено                                                                |
| 31        | -                       | Не определено                                                                              |
| 0         | master_enable           | Состояние контроллера:                                                                     |
|           |                         | 0 = работа контроллера запрещена;                                                          |
|           |                         | 1 = работа контроллера разрешена                                                           |

## 17.6.2 MDR DMA->CFG

Регистр конфигурации DMA

Данный регистр имеет доступ только на запись. Регистр определяет состояние контроллера.

Таблица 17-33 перечисляет назначение разрядов регистра.

Таблица 17-32 - Регистр конфигурации DMA

| Номер  | 318 | 75             | 41 | 0             |
|--------|-----|----------------|----|---------------|
| Доступ | U   | WO             | U  | WO            |
| Сброс  | 0   | 0              | 0  | 0             |
|        | -   | chnl_prot_ctrl | -  | master_enable |

Таблица 17-33 - Назначение разрядов регистра dma\_cfg

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений      |  |  |
|-----------|----------------------------|-------------------------------------------------------------------------------------------------|--|--|
| 318       | -                          | Не определено, следует записывать 0.                                                            |  |  |
| 75        | chnl_prot_ctrl             | Определяет уровни индикации сигналов HPROT[3:1] защиты шины AHB-Lite:                           |  |  |
|           |                            | Разряд 7 управляет сигналом HPROT[3], с целью индикации о появлении доступа с кэшированием;     |  |  |
|           |                            | Разряд 6 управляет сигналом HPROT[2], с целью индикации о появлении доступа с буферизацией;     |  |  |
|           |                            | Разряд 5 управляет сигналом HPROT[1], с целью индикации о появлении привилегированного доступа. |  |  |
|           |                            | Примечания:                                                                                     |  |  |
|           |                            | Если разряд[n] = 1, то соответствующий сигнал HPROT в состоянии 1;                              |  |  |
|           |                            | Если разряд[n] = 0, то соответствующий сигнал HPROT в состоянии 0                               |  |  |
| 41        | -                          | Не определено. Следует записывать 0.                                                            |  |  |
| 0         | master_enable              | Определяет состояние контроллера:                                                               |  |  |
|           |                            | 0 – запрещает работу контроллера;                                                               |  |  |
|           |                            | 1 – разрешает работу контроллера                                                                |  |  |

## 17.6.3 MDR\_DMA->CTRL\_BASE\_PTR

Регистр базового адреса управляющих данных каналов

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

*Примечание* – Контроллер не содержит внутреннюю память для хранения управляющих данных каналов.

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

разрядов регистра, необходимых для задания базового адреса, варьируется и зависит от варианта построения системы.

Если контроллер находится в состоянии сброса, то чтение регистра запрещено. Таблица 17–35 перечисляет назначение разрядов регистра ctrl\_base\_ptr.

Таблица 17-34 - Регистр базового адреса управляющих данных каналов

| Номер  | 3110          | 90 |
|--------|---------------|----|
| Доступ | R/W           | U  |
| Сброс  | 0             | 0  |
|        | ctrl_base_ptr | -  |

Таблица 17-35 - Назначение разрядов регистра ctrl\_base\_ptr

|      | Функциональное имя | Расшифровка функционального имени бита, краткое |                                     |         |       |           |           |  |
|------|--------------------|-------------------------------------------------|-------------------------------------|---------|-------|-----------|-----------|--|
| бита | бита               | описание назначения и принимаемых значений      |                                     |         |       |           |           |  |
| 3110 | ctrl_base_ptr      | Указатель                                       | на                                  | базовый | адрес | первичной | структуры |  |
|      |                    | управляющих данных. См. соответствующий раздел  |                                     |         |       |           |           |  |
| 90   | -                  | Не определ                                      | Не определено. Следует записывать 0 |         |       |           |           |  |

## 17.6.4 MDR\_DMA->ALT\_CTRL\_BASE\_PTR

Регистр базового адреса альтернативных управляющих данных каналов

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

Таблица 17–37 перечисляет назначение разрядов регистра.

Таблица 17–36 – Регистр базового адреса альтернативных управляющих данных каналов

| Номер  | 31 0              |
|--------|-------------------|
| Доступ | RO                |
| Сброс  | 0                 |
|        | Alt_ctrl_base_ptr |

Таблица 17-37 - Назначение разрядов регистра alt ctrl base ptr

| <b>№</b><br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |  |  |  |
|------------------|----------------------------|--------------------------------------------------------------------------------------------|--|--|--|--|
| 310              | alt_ctrl_base_ptr          | Указатель базового адреса альтернативной структуры<br>управляющих данных                   |  |  |  |  |

## 17.6.5 MDR\_DMA->WAITONREQ\_STATUS

Регистр статуса ожидания запроса на обработку каналов

Данный регистр имеет доступ только на чтение. Регистр возвращает при чтении состояние сигналов dma\_waitonreq[]. Если контроллер находится в состоянии сброса, то чтение регистра запрещено.

Таблица 17-39 перечисляет назначение разрядов регистра.

Таблица 17-38 - Регистр статуса ожидания запроса на обработку каналов

| Номер  | 31                                            | <br>2                                            | 1                                            | 0                                            |
|--------|-----------------------------------------------|--------------------------------------------------|----------------------------------------------|----------------------------------------------|
| Номер  | RO                                            | <br>RO                                           | RO                                           | RO                                           |
| Доступ | 0                                             | <br>0                                            | 0                                            | 0                                            |
|        | dma_waitonreg_status<br>for dma_waitnreg [31] | <br>dma_waitonreg_status<br>for dma_waitnreg [2] | dma_waitonreg_status<br>for dma_waitnreg [1] | dma_waitonreg_status<br>for dma_waitnreg [0] |

Таблица 17-39 - Назначение разрядов регистра dma waitonreg status

|      | Функциональное имя   | · · · · · · · · · · · · · · · · · · ·                      |
|------|----------------------|------------------------------------------------------------|
| бита | бита                 | описание назначения и принимаемых значений                 |
| 310  | dma_waitonreq_status | Состояние сигналов ожидания запроса на обработку каналов   |
|      |                      | DMA.                                                       |
|      |                      | При чтении:                                                |
|      |                      | Разряд [C] =0 означает, что dma_waitonreq[C] в состоянии 0 |
|      |                      | Разряд [C] =1 означает, что dma_waitonreq[C] в состоянии 1 |

## 17.6.6 MDR\_DMA->CHNL\_SW\_REQUEST

Регистр программного запроса на обработку каналов

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

Таблица 17-41 перечисляет назначение разрядов регистра.

Таблица 17-40 - Регистр программного запроса на обработку каналов

| Номер           | 31                                  | <br>2                                  | 1                                  | 0                                  |
|-----------------|-------------------------------------|----------------------------------------|------------------------------------|------------------------------------|
| Доступ<br>Сброс | WO                                  | <br>WO                                 | WO                                 | WO                                 |
| Сброс           | 0                                   | <br>0                                  | 0                                  | 0                                  |
|                 | chnl_sw_request<br>for channel [31] | <br>chnl_sw_request<br>for channel [2] | chnl_sw_request<br>for channel [1] | chnl_sw_request<br>for channel [0] |

Таблица 17-41 - Назначение разрядов регистра chnl\_sw\_request

| Nº   | Функциональное  | Расшифровка функционального имени бита, краткое                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита        | описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 310  | chnl_sw_request | Устанавливает соответствующий разряд для генерации программного запроса на выполнение цикла DMA по соответствующему каналу DMA.  При записи:  Разряд [C] = 0 означает, что запрос на выполнение цикла DMA по каналу С не будет установлен;  Разряд [C] =1 означает, что запрос на выполнение цикла DMA по каналу С будет установлен.  Запись разряда соответствующего нереализованному каналу, означает, что запрос на выполнение цикла DMA не будет установлен |

## 17.6.7 MDR\_DMA->CHNL\_USEBURST\_SET

Регистр установки пакетного обмена каналов

Данный регистр имеет доступ на чтение и запись. Регистр отключает выполнение одиночных запросов по установке dma\_sreq[] и поэтому будут обрабатываться и исполняться только запросы по dma\_req[]. Регистр возвращает при чтении состояние установок пакетного обмена.

Таблица 17-43 перечисляет назначение разрядов регистра.

Таблица 17-42 - Регистр установки пакетного обмена каналов

| Номер  | 31                                    | <br>2                                    | 1                                    | 0                                    |
|--------|---------------------------------------|------------------------------------------|--------------------------------------|--------------------------------------|
| Доступ | R/W                                   | <br>R/W                                  | R/W                                  | R/W                                  |
| Сброс  | 0                                     | <br>0                                    | 0                                    | 0                                    |
|        | chnl_useburst_set<br>for channel [31] | <br>chnl_useburst_set<br>for channel [2] | chnl_useburst_set<br>for channel [1] | chnl_useburst_set<br>for channel [0] |

Таблица 17-43 - Назначение разрядов регистра chnl\_useburst\_set

| Nº   | Функциональное    | Расшифровка функционального имени бита, краткое             |  |  |  |  |
|------|-------------------|-------------------------------------------------------------|--|--|--|--|
| бита | имя бита          | описание назначения и принимаемых значений                  |  |  |  |  |
| 310  | chnl_useburst_set | Отключает обработку запросов на выполнение циклов DMA от    |  |  |  |  |
|      |                   | dma_sreq[] и возвращает при чтении состоянии этих настроек. |  |  |  |  |
|      |                   | При чтении:                                                 |  |  |  |  |
|      |                   | Разряд [C] =0 означает, что канал DMA C выполняет циклы DMA |  |  |  |  |
|      |                   | в ответ на запросы, полученные от dma_sreq[]                |  |  |  |  |
|      |                   | иdma_req[].                                                 |  |  |  |  |
|      |                   | Контроллер выполняет одиночные передачи или                 |  |  |  |  |
|      |                   | 2 <sup>R</sup> передач.                                     |  |  |  |  |
|      |                   | Разряд [C] =1 означает, что канал DMA C выполняет циклы DMA |  |  |  |  |
|      |                   | в ответ на запросы, полученные только от                    |  |  |  |  |
|      |                   | dma_req[].                                                  |  |  |  |  |
|      |                   | Контроллер выполняет 2 <sup>R</sup> передач.                |  |  |  |  |
|      |                   | При записи:                                                 |  |  |  |  |
|      |                   | Разряд [C] =0 не дает эффекта. Необходимо использовать      |  |  |  |  |
|      |                   | chnl_useburst_clr регистр и установить                      |  |  |  |  |
|      |                   | соответствующий разряд С в 0;                               |  |  |  |  |
|      |                   | Разряд [С] =1 отключает возможность обрабатывать запросы на |  |  |  |  |
|      |                   | выполнение циклов DMA, полученные от                        |  |  |  |  |
|      |                   | dma_sreq[].                                                 |  |  |  |  |
|      |                   | Контроллер выполняет 2 <sup>R</sup> передач.                |  |  |  |  |
|      |                   | Запись разряда соответствующего нереализованному каналу     |  |  |  |  |
|      |                   | не дает никакого эффекта                                    |  |  |  |  |

После выполнения предпоследней передачи из  $2^R$  передач, в том случае, если число оставшихся передач (N) меньше чем  $2^R$ , контроллер сбрасывает разряд chnl\_useburst\_set в 0. Это позволяет выполнять оставшиеся передачи, используя dma\_sreq[] и dma\_req[].

Примечание — При программировании channel\_cfg значением N меньшим, чем 2<sup>R</sup>, запрещена установка соответствующего разряда chnl\_useburst\_set в случае, если периферийный блок не поддерживает сигнал dma\_req[].

В режиме работы с периферией «исполнение с изменением конфигурации», если разряд next\_useburst установлен в channel\_cfg, то контроллер устанавливает chnl\_useburst\_set [C] в 1 после окончания цикла DMA, использующего альтернативные управляющие данные.

## 17.6.8 MDR\_DMA->CHNL\_USEBURST\_CLR

Регистр сброса пакетного обмена каналов

Данный регистр имеет доступ только на запись. Регистр разрешает выполнение одиночных запросов по установке dma\_sreq[]. Таблица 17–45 перечисляет назначение разрядов регистра chnl\_useburst\_clr.

Таблица 17-44 - Регистр сброса пакетного обмена каналов

| Номер           | 31                                    |       | 2                                    | 1                                    | 0                                    |
|-----------------|---------------------------------------|-------|--------------------------------------|--------------------------------------|--------------------------------------|
| Доступ<br>Сброс | WO                                    |       | WO                                   | WO                                   | WO                                   |
| Сброс           | 0                                     |       | 0                                    | 0                                    | 0                                    |
|                 | chnl_useburst_clr<br>for channel [31] | ••••• | chnl_useburst_clr<br>for channel [2] | chnl_useburst_clr<br>for channel [1] | chnl_useburst_clr<br>for channel [0] |

Таблица 17-45 - Назначение разрядов регистра chnl useburst clr

| Nº   | Функциональное    | Расшифровка функционального имени бита, краткое                                                                                                                                                                       |
|------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита          | описание назначения и принимаемых значений                                                                                                                                                                            |
| 310  | chnl_useburst_clr | Установка соответствующего разряда разрешает обработку запросов на выполнение циклов DMA от dma_sreq[].  При записи: Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_useburst_set регистр для отключения |
|      |                   | обработки запросов от dma_sreq[];                                                                                                                                                                                     |
|      |                   | Разряд [С] = 1 разрешает обрабатывать запросы на                                                                                                                                                                      |
|      |                   | выполнение циклов DMA, полученные от                                                                                                                                                                                  |
|      |                   | dma_sreq[].                                                                                                                                                                                                           |
|      |                   | Запись разряда соответствующего нереализованному каналу                                                                                                                                                               |
|      |                   | не дает никакого эффекта                                                                                                                                                                                              |

## 17.6.9 MDR\_DMA->CHNL\_REQ\_MASK\_SET

Регистр маскирования запросов на обслуживание каналов

Данный регистр имеет доступ на чтение и запись. Регистр отключает установку запросов на выполнение циклов DMA на dma\_sreq[] и dma\_req[]. Регистр возвращает при чтении состояние установок маскирования запросов от dma\_sreq[] и dma\_req[] на обслуживание каналов. Таблица 17–47 перечисляет назначение разрядов регистра chnl\_req\_mask\_set.

Таблица 17-46 - Регистр маскирования запросов на обслуживание каналов

| Номер  | 31                                                         | <br>2                                                        | 1                                                        | 0                                                        |
|--------|------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|
| Доступ | R/W                                                        | <br>R/W                                                      | R/W                                                      | R/W                                                      |
| Сброс  | 0                                                          | <br>0                                                        | 0                                                        | 0                                                        |
|        | chnl_reg_mask_set<br>for dma_reg [31]<br>and dma_sreg [31] | <br>chnl_reg_mask_set<br>for dma_reg [2] and<br>dma_sreg [2] | chnl_reg_mask_set<br>for dma_reg [1] and<br>dma_sreg [1] | chnl_reg_mask_set<br>for dma_reg [0] and<br>dma_sreg [0] |

Таблица 17-47 - Haзнaчeние разрядов регистра chnl\_req\_mask\_set

| Nº   | Функциональное    | Расшифровка функционального имени бита, краткое             |
|------|-------------------|-------------------------------------------------------------|
| бита | имя бита          | описание назначения и принимаемых значений                  |
| 310  | chnl_req_mask_set | Отключает обработку запросов по dma_sreq[] и dma_req[] на   |
|      |                   | выполнение циклов DMA от каналов и возвращает при чтении    |
|      |                   | состоянии этих настроек.                                    |
|      |                   | При чтении:                                                 |
|      |                   | Разряд [C] = 0 означает, что канал DMA C выполняет циклы    |
|      |                   | DMA в ответ на поступающие запросы;                         |
|      |                   | Разряд [C] = 1 означает, что канал DMA C не выполняет циклы |
|      |                   | DMA в ответ на поступающие запросы.                         |
|      |                   | При записи:                                                 |
|      |                   | Разряд [С] = 0 не дает эффекта. Необходимо использовать     |
|      |                   | chnl_req_mask_clr регистр для разрешения                    |
|      |                   | установки запросов;                                         |
|      |                   | Разряд [С] = 1 отключает установку запросов на выполнение   |
|      |                   | циклов DMA, по dma_sreq[] и dma_req[].                      |
|      |                   | Запись разряда соответствующего нереализованному каналу     |
|      |                   | не дает никакого эффекта                                    |

## 17.6.10 MDR\_DMA->CHNL\_REQ\_MASK\_CLR

Регистр очистки маскирования запросов на обслуживание каналов.

Данный регистр имеет доступ только на запись. Регистр разрешает установку запросов на выполнение циклов DMA на dma\_sreq[] и dma\_req[].

Таблица 17–49 перечисляет назначение разрядов регистра chnl\_req\_mask\_clr.

Таблица 17–48 – Регистр очистки маскирова ния запросов на обслуживание каналов

| Номер  | 31                                                         | <br>2                                                        | 1                                                        | 0                                                        |
|--------|------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------|
| Доступ | WO                                                         | <br>WO                                                       | WO                                                       | WO                                                       |
| Сброс  | 0                                                          | <br>0                                                        | 0                                                        | 0                                                        |
|        | chnl_reg_mask_clr<br>for dma_reg [31]<br>and dma_sreg [31] | <br>chnl_reg_mask_clr<br>for dma_reg [2]<br>and dma_sreg [2] | chnl_reg_mask_clr<br>for dma_reg [1]<br>and dma_sreg [1] | chnl_reg_mask_clr<br>for dma_reg [0]<br>and dma_sreg [0] |

Таблица 17-49 - Назначение разрядов регистра chnl\_req\_mask\_clr

| Nº   | Функциональное    | Расшифровка функционального имени бита, краткое                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита          | описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                          |
| 310  | chnl_req_mask_clr | Установка соответствующего разряда разрешает установку запросов по dma_sreq[] и dma_req[] на выполнение циклов DMA от каналов.  При записи:  Разряд [C] =0 не дает эффекта. Необходимо использовать chnl_req_mask_set регистр для отключения установки запросов;  Разряд [C] =1 разрешает установку запросов на выполнение циклов DMA, по dma_sreq[] и dma_req[].  Запись разряда соответствующего нереализованному каналу не дает никакого эффекта |

## 17.6.11 MDR\_DMA->CHNL\_ENABLE\_SET

Регистр установки разрешения каналов

Данный регистр имеет доступ на чтение и запись. Регистр разрешает работу каналов DMA. Регистр возвращает при чтении состояние разрешений работы каналов DMA.

Таблица 17-51 перечисляет назначение разрядов регистра chnl enable set.

Таблица 17-50 - Регистр установки разрешения каналов

| Номер  | 31                                  | <br>2                                  | 1                                  | 0                                  |
|--------|-------------------------------------|----------------------------------------|------------------------------------|------------------------------------|
| Доступ | R/W                                 | <br>R/W                                | R/W                                | R/W                                |
| Сброс  | 0                                   | <br>0                                  | 0                                  | 0                                  |
|        | chnl_enable_set<br>for channel [31] | <br>chnl_enable_set<br>for channel [2] | chnl_enable_set<br>for channel [1] | chnl_enable_set<br>for channel [0] |

Таблица 17-51 - Назначение разрядов регистра chnl\_enable\_set

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
|           |                         |                                                                                            |
| 310       | chnl_enable_set         | Разрешает работу каналов DMA и возвращает при чтении                                       |
|           |                         | состоянии этих настроек.                                                                   |
|           |                         | При чтении:                                                                                |
|           |                         | Разряд [С] = 0 означает, что канал DMA С отключен;                                         |
|           |                         | Разряд [C] = 1 означает, что работа канала DMA C разрешена.                                |
|           |                         | При записи:                                                                                |
|           |                         | Разряд [С] = 0 не дает эффекта. Необходимо использовать                                    |
|           |                         | chnl_enable_clr регистр для отключения канала;                                             |
|           |                         | Разряд [C] = 1 разрешает работу канала DMA C.                                              |
|           |                         | Запись разряда соответствующего нереализованному каналу                                    |
|           |                         | не дает никакого эффекта                                                                   |

## 17.6.12 MDR\_DMA->CHNL\_ENABLE\_CLR

Регистр сброса разрешения каналов

Данный регистр имеет доступ только на запись. Регистр запрещает работу каналов DMA.

Таблица 17-53 перечисляет назначение разрядов регистра chnl\_enable\_clr.

Таблица 17-52 - Регистр сброса разрешения каналов

| Номер  | 31                                | <br>2                                | 1                                | 0                                |
|--------|-----------------------------------|--------------------------------------|----------------------------------|----------------------------------|
| Доступ | WO                                | <br>WO                               | WO                               | WO                               |
| Сброс  | 0                                 | <br>0                                | 0                                | 0                                |
|        | chnl_enable_clr<br>for channel 31 | <br>chnl_enable_clr<br>for channel 2 | chnl_enable_clr<br>for channel 1 | chnl_enable_clr<br>for channel 0 |

Таблица 17-53 - Назначение разрядов регистра chnl\_enable\_clr

| Nº   | Функциональное  | Расшифровка функционального имени бита, краткое описание                                                                                                                                                                                                                                                                                |  |  |  |  |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| бита | имя бита        | назначения и принимаемых значений                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| 310  | chnl_enable_clr | Установка соответствующего разряда запрещает работу соответствующего канала DMA.  При записи:  Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_enable_set регистр для разрешения работы канала;  Разряд [C] = 1 запрещает работу канала DMA C.                                                                             |  |  |  |  |
|      |                 | Запись разряда соответствующего нереализованному каналу не дает никакого эффекта.  Примечание — Контроллер может отключить канал DMA, установив соответствующий разряд в следующих случаях:  - при завершении цикла DMA;  - при чтении из channel_cfg с полем cycle_ctrl установленным в b000;  - при появлении ошибки на шине AHB-Lite |  |  |  |  |

## 17.6.13 MDR\_DMA->CHNL\_PRI\_ALT\_SET

Регистр установки первичной/альтернативной структуры управляющих данных каналов

Данный регистр имеет доступ на запись и чтение. Регистр разрешает работу канала DMA с использованием альтернативной структуры управляющих данных. Чтение регистра возвращает состояние каналов DMA (какую структуру управляющих данных использует каждый канал DMA).

Таблица 17-55 перечисляет назначение разрядов регистра chnl pri alt set.

Таблица 17–54 – Регистр установки первичной/альтернативной структуры управляющих данных каналов

| Номер  | 31                                   | <br>2                                   | 1                                   | 0                                   |
|--------|--------------------------------------|-----------------------------------------|-------------------------------------|-------------------------------------|
| Доступ | R/W                                  | <br>R/W                                 | R/W                                 | R/W                                 |
| Сброс  | 0                                    | <br>0                                   | 0                                   | 0                                   |
|        | chnl_pri_alt_set<br>for channel [31] | <br>chnl_pri_alt_set<br>for channel [2] | chnl_pri_alt_set<br>for channel [1] | chnl_pri_alt_set<br>for channel [0] |

Таблица 17-55 - Назначение разрядов регистра chnl\_pri\_alt\_set

| краткое описание                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ений</b>                                                                                                                                                                                                                                                                                                                                          |
| ет использование соответствующего настроек.  ользует первичную  С использует пяющих данных.  мо использовать а разряда [С] в 0; альтернативной заначение разряда ных в первичной нии цикла DMA в й «исполнение с в альтернативной нии цикла DMA в |
| пессия при                                                                                                                                                                                                                                                                                                       |

| — «пинг-понг»; — работа с памятью «Исполнение с изменением конфигурации — работа с периферией «Исполнение с изменением конфигурации; |  |
|--------------------------------------------------------------------------------------------------------------------------------------|--|
|--------------------------------------------------------------------------------------------------------------------------------------|--|

## 17.6.14 MDR\_DMA->CHNL\_PRI\_ALT\_CLR

Регистр сброса первичной/альтернативной структуры управляющих данных каналов

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

Таблица 17-57 перечисляет назначение разрядов регистра chnl\_pri\_alt\_clr.

Таблица 17–56 – Регистр сброса первичной/альтернативной структуры управляющих данных каналов

| Номер  | 31                                   |       | 2                                   | 1                                   | 0                                   |
|--------|--------------------------------------|-------|-------------------------------------|-------------------------------------|-------------------------------------|
| Доступ | WO                                   |       | WO                                  | WO                                  | WO                                  |
| Сброс  | 0                                    |       | 0                                   | 0                                   | 0                                   |
|        | chnl_pri_alt_clr<br>for channel [31] | ••••• | chnl_pri_alt_clr<br>for channel [2] | chnl_pri_alt_clr<br>for channel [1] | chnl_pri_alt_clr<br>for channel [0] |

Таблица 17-57 - Назначение разрядов регистра chnl\_pri\_alt\_clr

| №<br>бита               | Функциональное имя бита                  | Расшифровка функционального имени бита, краткое                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>№</b><br>бита<br>310 | Функциональное имя бита chnl_pri_alt_clr | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений  Установка соответствующего разряда подключает использование первичных управляющих данных для соответствующего канала DMA.  При записи:  Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_pri_alt_set регистр для выбора альтернативных управляющих данных;  Разряд [C] = 1 подключает использование первичной структуры управляющих данных каналом DMA C.  Запись разряда соответствующего нереализованному каналу не дает никакого эффекта.  Примечание — Контроллер может переключить значение разряда chnl_pri_alt_clr[C] в следующих случаях:  — при завершении 4-х передач DMA указанных в первичной структуре управляющих данных при выполнении цикла DMA в режимах работы с памятью или периферией «исполнение с изменением конфигурации»; |
|                         |                                          | изменением конфигурации»,  – при завершении всех передач DMA указанных в первичной структуре управляющих данных при выполнении цикла DMA в режиме «пинг-понг»;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                         |                                          | – при завершении всех передач DMA указанных в альтернативной структуре управляющих данных при выполнении цикла DMA в режимах:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| <ul> <li>– «пинг-понг»</li> <li>– работа с памятью «Исполнение с изменением конфигурации»</li> <li>– работа с периферией «Исполнение с изменением</li> </ul> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| конфигурации»                                                                                                                                                |

## 17.6.15 DFMDR\_DMA->CHNL\_PRIORITY\_SET

Регистр установки приоритета каналов

Данный регистр имеет доступ на запись и чтение. Регистр позволяет присвоить высокий приоритет каналу DMA. Чтение регистра возвращает состояние приоритета каналов DMA.

Таблица 17–59 перечисляет назначение разрядов регистра chnl\_priority\_set.

Таблица 17-58 - Регистр установки приоритета каналов

| Номер  | 31                                   |       | 2                                    | 1                                    | 0                                    |
|--------|--------------------------------------|-------|--------------------------------------|--------------------------------------|--------------------------------------|
| Доступ | R/W                                  |       | R/W                                  | R/W                                  | R/W                                  |
| Сброс  | 0                                    |       | 0                                    | 0                                    | 0                                    |
|        | chnl_priorit_set<br>for channel [31] | ••••• | chnl_priority_set<br>for channel [2] | chnl_priority_set<br>for channel [1] | chnl_priority_set<br>for channel [0] |

Таблица 17-59 - Назначение разрядов регистра chnl\_priority\_set

| Nº   | Функциональное    | Расшифровка функционального имени бита, краткое                                                          |  |  |
|------|-------------------|----------------------------------------------------------------------------------------------------------|--|--|
| бита | имя бита          | описание назначения и принимаемых значений                                                               |  |  |
| 310  | chnl_priority_set | Установка высокого приоритета каналу DMA, чтение                                                         |  |  |
|      |                   | возвращает состояние приоритета каналов DMA.                                                             |  |  |
|      |                   | При чтении:                                                                                              |  |  |
|      |                   | Разряд [C] = 0 означает, что каналу DMA C присвоен уровень приоритета по умолчанию;                      |  |  |
|      |                   | Разряд [C] = 1 означает, что каналу DMA C присвоен высокий уровень приоритета.                           |  |  |
|      |                   | При записи:                                                                                              |  |  |
|      |                   | Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_priority_clr регистр для установки каналу C |  |  |
|      |                   | уровня приоритета по умолчанию;                                                                          |  |  |
|      |                   | Разряд [C] = 1 устанавливает каналу DMA C высокий                                                        |  |  |
|      |                   | уровеньприоритета.                                                                                       |  |  |
|      |                   | Запись разряда соответствующего нереализованному каналу не дает никакого эффекта                         |  |  |

## 17.6.16 MDR\_DMA->CHNL\_PRIORITY\_CLR

Регистр сброса приоритета каналов

Данный регистр имеет доступ только на запись. Регистр позволяет присвоить каналу DMA уровень приоритета по умолчанию.

Таблица 17-61 перечисляет назначение разрядов регистра chnl\_priority\_clr.

## Таблица 17-60 - Регистр сброса приоритета каналов

| Номер  | 31                                   | <br>2                                    | 1                                    | 0                                    |
|--------|--------------------------------------|------------------------------------------|--------------------------------------|--------------------------------------|
| Доступ | WO                                   | <br>WO                                   | WO                                   | WO                                   |
| Сброс  | 0                                    | <br>0                                    | 0                                    | 0                                    |
|        | chnl_priorit_clr<br>for channel [31] | <br>chnl_priority_clr<br>for channel [2] | chnl_priority_clr<br>for channel [1] | chnl_priority_clr<br>for channel [0] |

## Таблица 17-61 - Назначение разрядов регистра chnl\_priority\_clr

| Nº     | Функциональное    |                                                         |  |  |
|--------|-------------------|---------------------------------------------------------|--|--|
| бита   | имя бита          | описание назначения и принимаемых значений              |  |  |
| [31:0] | chnl_priority_clr | Установка разряда присваивает соответствующему каналу   |  |  |
|        |                   | DMA уровень приоритета по умолчанию.                    |  |  |
|        |                   | При записи:                                             |  |  |
|        |                   | Разряд [C] = 0 не дает эффекта. Необходимо использовать |  |  |
|        |                   | chnl_priority_set регистр для установки каналу С        |  |  |
|        |                   | высокого уровня приоритета.                             |  |  |
|        |                   | Разряд [C] = 1 устанавливает каналу DMA C уровень       |  |  |
|        |                   | приоритета по умолчанию.                                |  |  |
|        |                   | Запись разряда соответствующего нереализованному каналу |  |  |
|        |                   | не дает никакого эффекта                                |  |  |

## 17.6.17 *MDR\_DMA->ERR\_CLR*

Регистр сброса флага ошибки

Данный регистр имеет доступ на запись и чтение. Регистр позволяет сбрасывать сигнал dma\_err в 0. Чтение регистра возвращает состояние сигнала dma\_err.

Таблица 17-63 перечисляет назначение разрядов регистра err clr.

## Таблица 17-62 - Регистр сброса флага ошибки

| Номер  | 311 | 0       |
|--------|-----|---------|
| Доступ | U   | R/W     |
| Сброс  | 0   | 0       |
|        |     | err_clr |

## Таблица 17-63 - Назначение разрядов регистра err\_clr

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                                                            |  |  |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                                                                 |  |  |
| 311  | -              | Не определено. Следует записывать 0                                                                                                                                                                        |  |  |
| 0    | err_clr        | Установка сигнала в состояние 0, чтение возвращает состояние сигнала (флага) dma_err. При чтении:                                                                                                          |  |  |
|      |                | Разряд [C] = 0 означает, что dma_err находится в состоянии 0; Разряд [C] = 1 означает, что dma_err находится в состоянии 1. При записи:                                                                    |  |  |
|      |                | Разряд [C] =0 не дает эффекта. Состояние dma_err останется неизменным;                                                                                                                                     |  |  |
|      |                | Разряд [C] =1 сбрасывает сигнал (флаг) dma_err в состояние 0.                                                                                                                                              |  |  |
|      |                | Примечание – При сбросе сигнала dma_err одновременно с появлением ошибки на шине AHB-Lite, то приоритет отдается ошибке и следовательно, значение регистра (и dma_err) останется неизменным (несброшенным) |  |  |

#### Data DSP BUS Prog **ETDR** RAM CPU RAMAPB DSP RISC2 AHB2 RISC AHB BUS McBSP DSP APB x3 AHB DSP AHB BUS Bridge Codec DMA CLKR System Reset OR DSP RST REG MEM RST STAT DSP RST AIR Timer MEM RST RISC/ OR MEM CPU RST CPU RST DSP CTRL PER RST Synch OR CPU DSP Crypto OR Periferal DIR RISC i DSP JTAG RST Domain Domain TAP

## 18 Организация управления DSP-подсистемой

Рисунок 18-1 - Структурная схема подсистемы DSP

## 18.1 Средства управления подсистемой DSP

При включении питания DSP-подсистема не активна (находится в сбросе, тактовая частота на подсистему не подается). Активировать DSP подсистему можно только при помощи RISC. Для этого RISC-ядро обладает следущими средствами:

- Управление тактовой частотой DSP. Для управления тактовой частотой DSP в системе реализован регистр управления тактовой частой DSP DSP\_CLOCK в RISC-подсистеме и CLKMD в DSP-подсистеме. Возможны различные варианты источника синхросигнала DSP (в т. ч. в системе реализована отдельная PLL для DSP). Возможно отключение тактовых сигналов от отдельных модулей DSP-подсистемы.
- Управление сбросами подсистемы DSP. Возможен общий сброс системы, сброс отдельно ядра DSP, всей памяти подсистемы, всех периферийных модулей.
- Ядро RISC и DMA RISC имеет доступ ко всему адресному пространству памяти программ и памяти данных DSP, кроме регистров ядра. Таким образом RISC имеет возможность задавать и изменять программы для ядра DSP, управлять всеми периферийными устройствами DSP, управлять DMA DSP.



Рисунок 18-2 - Организация управления подсистемой DSP

#### 18.2 Синхросигналы DSP-подсистемы

Первичными синхросигналами для подсистемы DSP являются:

- синхросигнал CLK\_DSP, который формируется в блоке контроллера тактовой частоты RISC, регистр DSP\_CLOCK;
- синхросигнал ТСК, который формируется аппратным эмулятором при отладке и подается на выводы ТСК.

Вторичным синхросигналом подсистемы DSP является сигнал CLK\_MUX, который формируется путем мультиплексирования исходных синхросигналов CLK\_DSP в рабочем режиме и сигнала TCK интерфейса JTAG в режиме отладки. Т.е. в случае начала работы с TAP контроллером DSP-средствами отладочного интерфейса JTAG через среду Code Composer вся система переходит на синхросигнал TCK. Если отладка DSP-ядра не производится (в т.ч. в случае отладки только RISC-ядра), подсистема DSP работает на основной частоте CLK\_DSP. Сигнал CLK\_MUX подается на все шины подсистемы, регистры прерываний AIRQ и DIRQ, модуль управления синхросигналами и регистр CLKMD. В случае отсутствия сигнала CLK\_MUX ни одна часть подсистемы не активна.



Рисунок 18-3 - Структурная схема дерева синхросигналов подсистемы DSP

Все остальные синхросигналы сопроцессора формируются путем логического умножения CLK\_MUX и соответствующего сигнала разрешения синхронизации заданного устройства регистра CLKMD. Регистр CLKMD отображен в адресное пространство RISC и DSP.

## 18.2.1 Режимы отключения синхросигналов DSP-подсистемы (IDLE1, IDLE2, IDLE3)

Регистр СLKMD программно доступен как по записи, так и по чтению со стороны обоих ядер и DMA контроллеров системы. Однако при записи данных в регистр CLKMD со стороны DSP-ядра, биты 15-13 не могут быть обнулены (т.е. DSP не может программно отключить синхросигнал для самого себя и своей памяти данных или программ). Для выполнения этих операций в подсистеме реализованы команды пониженого потребления IDLE1, IDLE2, IDLE3. При выполнении инструкции IDLE 1 отключается только синхросигнал ядра сопроцессора (обнуляется бит 15). При выполнении инструкции IDLE 2 отключаются синхросигнал ядра сопроцессора и синхросигналы периферийных устройств (обнуляются биты 15, 12-3). При выполнении инструкции IDLE 3 отключаются синхросигнал ядра DSP, синхросигналы периферийных устройств, а также синхросигналы памяти программ и памяти данных DSP (обнуляются биты 15-3). Переход процессора в состояние IDLE генерирует соответствующее прерывание RISC процессору. Код состояния DSP может быть

считан в регистре DSP\_CONTROL\_STATUS. В случае выполнения любой из команд, DSP-ядро заканчивает выполнение выбранных команд и очищает конвейер. Вывод процессора DSP из режимов отключения синхросигналов может быть осуществлен при помощи прерывания от RISC или от периферийных модулей DSP. В этом случае биты регистра CLKMD автоматически установятся, подача синхросигналов будет возобновлена, ядро DSP перейдет по адресу вектора активного прерывания. Не рекомендуется отключать синхросигналы ядра и памяти DSP путем записи в регистр, в тот момент, когда ядро DSP находится в активном состоянии.

#### 18.3 Сбросы DSP подсистемы

Управление сбросами устройств подсистемы DSP может быть осуществлено только со стороны RISC. Для этого в регистр DSP\_CONTROL\_STATUS включены биты управления сбросами: RST\_DSP, RST\_DSP\_CPU, RST\_DSP\_MEM, RST\_DSP\_PER.

#### Общий сброс DSP подсистемы

Бит RST\_DSP в регистре DSP\_CONTROL\_STATUS служит для общего сброса подсистемы DSP. В началиный момент времени он равен нулю (неактивен), но, т.к. он пересинхронизируется на частоту DSP, вывести подсистему из состояния сброса он может только после подачи синхросигнала CLK\_DSP. Данный бит автоматически выводит из сброса все шины подсистемы, регистры прерываний AIRQ и DIRQ, модуль управления синхросигналами и регистр CLKMD. Остальные устройства подсистемы DSP будут выведены из сброса при условии неактивных частных битов управления сбросами. В том случае, если бит равен единице (активен) сброшены все устройства подсистемы DSP, запрещен любой обмен данными, все адреса подсистемы читаются как 0.

#### Сброс ядра DSP

Бит RST\_DSP\_CPU управляет сбросом ядра DSP. После подачи питания находится в активном состоянии (ядро сброшено).

#### Сброс памяти DSP

Бит RST\_DSP\_MEM управляет сбросом памяти программ и данных DSP. После подачи питания находится в активном состоянии (память сброшена). Влияет только на возможность считывать и записывать данные в память. Не влияет на содержимое ячеек памяти.

#### Сброс периферийных модулей DSP

Бит RST\_DSP\_PER управляет сбросом всех периферийных модулей подсистемы DSP. После подачи питания находится в активном состоянии (периферия сброшена).

#### 18.4 Прерывания и запросы DMA между подсистмемами

Для утановки запросов прерываний и DMA запросов в системе реализованы регистры AIRQ и DIRQ. Оба регистра доступны RISC и DSP. Регистр AIRQ используется для установки прерываний от RISC к DSP и для организации запросов к DMA RISC состороны ядра DSP. Регистр DIRQ используется для передачи запросов прерываний от ядра и периферии DSP к RISC.

Для предотвращения потери прерываний при перезаписи регистров в каждом регистре имеется бит SNR.

Для перезаписи битов прерываний (регистры AIRQ, DIRQ) необходимо сформировать следущее слово (Таблица 18–1 и Таблица 18–2):

- 1. В бит SNR вносится значение, которое тербуется записать в один или несколько бит регистра.
- 2. Если записываемый регистр AIRQ, устанавливаем SID в 1.
- 3. Один или несколько бит соответствующих прерываниям, которые требуется перезаписать, устанавливается в единицу.

Т.е. в случае записи прерываний значащим битом является SNR, биты соответствующие прерываниям являются выбором записываемых бит. Бит SID регистра AIRQ является выбором перезаписи прерываний или запросов DMA.

Для установки запросов RISC DMA (регистр AIRQ) необходимо сформировать следущее слово (таблица 94):

- 1. Бит SID = 0. В этом случае запись в регистр не оказывает влияния на биты запросов прерываний.
- 2. Запись бит соответствующие запросам DMA RISC производится обычным образом (значение регистра SNR не влияет).

|     | Запи | сываемое сл | 10В0       | Изменени      | ие регистра   |
|-----|------|-------------|------------|---------------|---------------|
| SID | SNR  | ANMI(i),    | DMARQ(i)   | ANMI, AIRQ(i) | DMARQ(i)      |
|     |      | AIRQ(i)     | DMADONE(i) |               | DMADONE(i)    |
| 1   | 0    | 0           | Χ          | Не изменяется | Не изменяется |
| 1   | 1    | 0           | Χ          | Не изменяется | Не изменяется |
| 1   | 0    | 1           | Χ          | 0             | Не изменяется |
| 1   | 1    | 1           | Χ          | 1             | Не изменяется |
| 0   | 0    | 0           | NEW DATA   | Не изменяется | NEW DATA      |
| 0   | 1    | 0           | NEW DATA   | Не изменяется | NEW DATA      |
| 0   | 0    | 1           | NEW DATA   | Не изменяется | NEW DATA      |
| 0   | 1    | 1           | NEW DATA   | Не изменяется | NEW DATA      |

Таблица 18-2 - Биты регистра запросов прерываний от DSP к RISC DIRQ.

| Data_in(i) | Data_in(15) | DIRQ(i)       | Соответствующее прерывание      |
|------------|-------------|---------------|---------------------------------|
| 0          | 0           | Не изменяется | Не изменяется                   |
| 0          | 1           | Не изменяется | Не изменяется                   |
| 1          | 0           | 0             | Сбрасывается (выход равен 1)    |
| 1          | 1           | 1             | Устанавливается (выход равен 0) |

### 18.5 Специальные возможности управления

#### Сигналы HOLD, HOLDA

В микроконтроллере реализована возможность остановки конвейера DSP со стороны RISC. Для этого в регистр DSP\_CONTROL\_STATUS включены биты HOLD и HOLDA. Активный уровень обоих сигналов — единица. Для остановки конвейера необходимо установить бит HOLD. При этом конвейер процессора остановится и бит HOLDA установится в 1.

#### Флаги BIO, XF

Также в системе реализованы флаги BIO и XF. Состояние данных флагов может быть обработано специальными командами процессора DSP.

В 3 ревизии микросхемы добавлена возможность вывода сигнала XF на порт PA[15] в режиме работы «Переопределенной и DSP функции». При этом для обеспечения совместимости микросхемы с предыдущими ревизиями данная функция совмещена с ранее реализованной на данном порту функцией внешнего прерывания. В регистр

«Управления и статуса DSP» включен ранее зарезервированный бит XF\_EN, переводящий вывод PA[15] в режим вывода флага XF.

Таким образом для прямого вывода флага XF необходимо:

- Перевести порт PA[15] микроконтроллера в режим «Переопределенной и DSP функции». Порт, при этом, будет работать в режиме внешнего прерывания.
- Установить бит XF\_EN регистра «Управления и статуса DSP». Порт переключится на выход и будет транслировать состояние флага XF.

Данная функция реалищована для упрощения отладки программ DSP-ядра.

#### 18.6 Работа моста пересинхронизации RISC - DSP

Так как подсистемы RISC и DSP работают на разных синхросигналах, для корректной передачи данных между ними организован модуль пересинхронизации. Для осуществления операций записи по шине RISC-DSP организовано асинхронное FIFO глубиной четыре запроса, позволяющее передавать данные на частоте наименьшей из частот двух подсистем, без потерь на пересинхронизацию. Операции чтения организованы по принципу двухфазного запроса-ответа. Минимальная задержка вносимая пересинхронизацией составляет три такта частоты RISC. В случае, если DSP-частота меньше частоты RISC, данная задержка может быть существенно увеличена. При этом, чтение всегда имеет приоритет над записью.

Особенностью передачи данных с использованием асинхронного FIFO является некоторая задержка между получением сигнала READY по запросу и реальной записью данных. Таким образом, если последовательно записать несколько адресов DSP, и сразу после этого осуществить чтение данных по только что записанным адресам, существует опасность считать прежнее значение. Особенно опасна данная ситуация может быть при работе с периферийными модулями (например при записи регистра SPSA модуля McBSP, и следом регистра данных см. Контроллер McBSP(DSP)). Для того, чтобы убедится что все транзакции закончены и ячейки памяти содержат корректные данные, в регистре DSP\_CONTROL\_STATUS реализован бит BRTRD. В том случае, если он равен единице, все операции моста завершены.



Рисунок 18-4- Структура буфера пересинхронизации RISC- DSP

Для ускорения обработки запросов чтения в модуле пересинхронизации реализован механизм предчтения. Данный механизм активизируется сигналом RD\_Buff\_EN регистра DSP\_CONTROL\_STATUS и заключается в том, что после чтения по адресу N, в случае если нет других активных задач доступа к данным, контроллер чтения автоматически вычитывает адрес N+m. Значение m зависит от размера запрошенных данных:

- m=1, если был запрошен байт;
- m=2, если было запрошено полуслово (16 бит);
- m=4, если было запрошено слово (32 бит).

Полученные данные сохраняются в специальном буфере. Если следующее чтение осуществляется по адресу N+m, данные выдаются из буфера без задержек. Данный режим рекомендуется использовать в случае чтения больших массивов последовательных данных. Нерекомендуется данный режим при обращении к регистрам (т.к. автоматическое чтение некоторых регистров может изменить их значение). После подачи питания механизм предчтения данных неактивен.

#### 18.7 Способы управления подсистемой DSP

#### 18.7.1 Нормальная работа DSP.

Для начала работы с ядром DSP необходимо:

- 1. Подать синхросигнал DSP\_CLK (регистр DSP\_CLOCK модуля управления синхросигналами RISC).
- 2. Включить память DSP (регистр DSP\_CONTROL\_STATUS). При этом удостоверится что общий сброс подсистемы DSP неактивен.
- 3. Записать в память программи данных DSP образ программного обеспечения (программу, необходимые константы, таблицу векторов прерыаний).
- 4. Снять сброс с ядра DSP и, при необходимости, с периферии (регистр DSP\_CONTROL\_STATUS).

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

#### 18.7.2 Динамическое изменение программного обеспечения DSP-ядра

Изменения программы DSP без остановки ядра может быть осуществлено как при помощи RISC так и самим DSP.

Для динамического измененипрограммы при помощи RISC необходимо:

- 1. При создании образа памяти DSP, выделить участок памяти, куда гарантированно не будет обращений со стороны DSP в ходе выполнения программы. В подсистеме DSP использована расслоена память, позволяющая одновременное безконфликтное обращение двух устройств.
- 2. Занести в свободный участок памяти новую функцию, требуемую к исполнению.
- 3. Уведомить DSP-ядро о готовность функции. Для этого можно использовать прерывания регистра DIRQ, аппаратные флаги XF и BIO, программные флаги.

Для динамического изменения программы при помощи DSP можно использовать DMA контроллеры DMA DSP, если программа находится внутри DSP-подсистемы, либо DMA-RISC, если программа находится вне DSP-подсистемы. DSP-ядро не имеет доступа к памяти программ на запись

Для изменения программ с использованием DMA RISC со стороны DSP необходимо:

- 1. Со стороны RISC настроить контроллер DMA RISC таким образом, чтобы его управляющие структуры находились в DSP-подсистеме. Включить каналы соответствующие запросам DSP.
- 2. Со стороны DSP указать в упраляющейструктуре адрес источника и назначения для данных.
- 3. Подать DMA запрос на контроллер DMA RISC (регистр AIRQ).
- 4. Периодически проверять готовность данных (регистр AIRQ).

### 18.7.3 Работа с периферийными модулями и памятью DSP без участия ядра DSP

В случае необходимости, RISC может использоватьвсе периферийные модули и память безучастия ядра DSP. Для этого необходимо:

- 1. Подать синхросигнал DSP\_CLK (регистр DSP\_CLOCK модуля управления синхросигналами RISC).
- 2. Включить память и(или) периферию DSP (регистр DSP\_CONTROL\_STATUS). При этом удостоверится что общий сброс подсистемы DSP неактивен.
- 3. После чего ядро RISC может без участия ядра DSP может работать с памятью и периферией подсистемы DSP.

## 18.8 Регистры управления подсистемой DSP

Для управления DSP частью в системе реализован набор регистров (Таблица 18–3).

Таблица 18-3 - Регистры управления подсистемой DSP

| Адрес<br>RISC | Адрес<br>DSP | Регистр       | Описание                                   |
|---------------|--------------|---------------|--------------------------------------------|
| 0x4002_0038   | -            | DSP_CTRL_STAT | Регистр управления и статуса DSP           |
| 0x3000_00BC   | 005Eh        | CLKMD         | Управление синхросигналами DSP             |
| 0x3000_0078   | 003Ch        | DIR           | Регистры запросов прерывания от DSP к RISC |
| 0x3000_007A   | 003Dh        | AIR           | Регистры запросов прерывания от RISC к DSP |

#### Таблица 18-4 - Регистр управления и статуса DSP

| 15         | 14    | 1312 | 11 | 10 | 9     | 76 | 5   | 4    | 3            | 2           | 1           | 0       |
|------------|-------|------|----|----|-------|----|-----|------|--------------|-------------|-------------|---------|
|            |       |      |    |    |       |    |     |      |              |             |             |         |
| RD_Buff_EN | BRTRD |      |    |    | НОГДА | ı  | BIO | НОГР | RST_DSP_ PER | RST_DSP_MEM | RST_DSP_CPU | RST_DSP |

#### Таблица 18-5 - Биты регистра управления подсистемой DSP

| 1     |              |                                                           |
|-------|--------------|-----------------------------------------------------------|
| Биты  | Наименование | Назначение                                                |
| 15    | RD_Buff_EN   | Разрешение предвыборки чтения адресного пространства      |
|       |              | DSP.                                                      |
|       |              | 0 – Запрещено.                                            |
|       |              | 1 – Разрешено.                                            |
| 14    | BRTRD        | Статус моста DSP.                                         |
|       |              | 0 – Идет передача данных.                                 |
|       |              | 1 – Все операции завершены.                               |
| 13    | -            | Зарезервировано.                                          |
| 12    | -            | Зарезервировано.                                          |
| 11-10 | IDLE num1    | Код состояния DSP.                                        |
|       |              | 00 – DSP-подсистема в нормальном режиме работы.           |
|       |              | 01 – Отключен синхросигнал только от ядра DSP.            |
|       |              | 10 – Отключен синхросигнал от ядра и памяти DSP.          |
|       |              | 11 – Отключен синхросигнал от ядра, памяти и периферии    |
|       |              | DSP. Активен только глобальный синхросигнал DSP.          |
| 9     | HOLDA        | Уведомление об остановки конвейера DSP.                   |
|       |              | 0 – Конвйер DSP остановлен.                               |
|       |              | 1 – Конвейер DSP работает (Не было запроса, либо конвейер |
|       |              | еще не остановлен).                                       |
| 8     | XF           | Флаг общего назначения DSP к RISC. Обрабатывается         |
|       |              | специальными командами DSP.                               |
| 7     | -            | Зарезервировано                                           |

| 1            |                                                       |
|--------------|-------------------------------------------------------|
| XF_EN        | Разрешение вывода сигнала ХГ напрямую на порт РА [15] |
|              | микроконтроллера                                      |
| BIO          | Флаг общего назначения от RISC к DSP. Обрабатывается  |
|              | специальными командами DSP.                           |
| HOLD         | Запрос остановки конвейера DSP                        |
|              | 0 – Запрос на остановку конвейера DSP.                |
|              | 1 – DSP работает в штатном режиме.                    |
| RST_DSP_ PER | Выключение периферийных блоков DSP                    |
|              | 0 – Периферийные блоки работают.                      |
|              | 1 – Периферийные находятся в сбросе.                  |
| RST_DSP_MEM  | Выключение блоков памяти DSP                          |
|              | 0 – Блоки памяти работают.                            |
|              | 1 – Блоки памяти находятся в сбросе.                  |
| RST_DSP_CPU  | Выключение ядра DSP                                   |
|              | 0 – Ядро выполняет программу.                         |
|              | 1 – Ядро находятся в сбросе.                          |
| RST_DSP      | Общий сброс DSP части устройства.                     |
|              | 0 – DSP-подсистема работает.                          |
|              | 1 – DSP-подсистема находистя в сбросе.                |
|              | HOLD  RST_DSP_PER  RST_DSP_MEM  RST_DSP_CPU           |

## 18.8.1 Регистр управления синхронизацией CLKMD

## Таблица 18-6 - Регистр управления синхронизацией CLKMD

| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2-0 |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| CPU | CPM | CDM | PC1 | MC1 | PC2 | MC2 | PC3 | MC3 | DMA | TMR | CDC | CRP | -   |

## Таблица 18-7 - Биты регистра управления синхронизацией CLKMD

| Название | Назначение бита регистра                                |
|----------|---------------------------------------------------------|
| CPU      | 0 – синхросигнал ядра сопроцессора запрещен,            |
|          | 1 – синхросигнал ядра сопроцессора разрешен             |
| CPM      | 0 – синхросигнал памяти программ сопроцессора запрещен, |
|          | 1 – синхросигнал памяти программ сопроцессора разрешен  |
| CDM      | 0 – синхросигнал памяти данных сопроцессора запрещен,   |
|          | 1 – синхросигнал памяти данных сопроцессора разрешен    |
| PC1      | 0 – синхросигнал PCLK устройства MCBSP1 запрещен,       |
|          | 1 – синхросигнал PCLK устройства MCBSP1 разрешен        |
| MC1      | 0 – синхросигнал MCLK устройства MCBSP1 запрещен,       |
|          | 1 – синхросигнал MCLK устройства MCBSP1 разрешен        |
| PC2      | 0 – синхросигнал PCLK устройства MCBSP2 запрещен,       |
|          | 1 – синхросигнал PCLK устройства MCBSP2 разрешен        |
| MC2      | 0 – синхросигнал MCLK устройства MCBSP2 запрещен,       |
|          | 1 – синхросигнал MCLK устройства MCBSP2 разрешен        |
| PC3      | 0 – синхросигнал PCLK устройства MCBSP3 запрещен,       |
|          | 1 – синхросигнал PCLK устройства MCBSP3 разрешен        |
| MC3      | 0 – синхросигнал MCLK устройства MCBSP3 запрещен,       |
|          | 1 – синхросигнал MCLK устройства MCBSP3 разрешен        |
| DMA      | 0 – синхросигнал контроллера DMA запрещен,              |
|          | 1 – синхросигнал контроллера DMA разрешен               |
| TMR      | 0 – синхросигнал таймера запрещен,                      |
|          | 1 – синхросигнал таймера разрешен                       |
| CDC      | 0 – синхросигнал кодека запрещен,                       |
|          | 1 – синхросигнал кодека разрешен                        |
| CRP      | 0 – синхросигнал устройства шифрации запрещен,          |
|          | 1 – синхросигнал устройства шифрации разрешен           |
|          | CPU CPM CDM PC1 MC1 PC2 MC2 PC3 MC3 DMA TMR CDC         |

| 2 – 0 | Резервные биты (при записи данных в регистр должны быть |
|-------|---------------------------------------------------------|
|       | установлены в 0, при чтении регистра равны 0)           |

## Таблица 18–8 – Регистр прерываний от RISC к DSP и запросовперываний для RISC AIRQ

| Номер          | 15  | 14  | 13            | 12            | 11            | 10            | 9           | 8           |
|----------------|-----|-----|---------------|---------------|---------------|---------------|-------------|-------------|
| Доступ<br>RISC | R/W | R/W | R/W           | R/W           | R/W           | R/W           | R/W         | R/W         |
| Доступ<br>DSP  | R/W | R/W | R/W           | R/W           | R/W           | R/W           | R/W         | R/W         |
| Срос           | 0   | 0   | 0             | 0             | 0             | 0             | 0           | 0           |
|                | SNR | SID | ADMA<br>DONE3 | ADMA<br>DONE2 | ADMA<br>DONE1 | ADMA<br>DONE0 | ADMA<br>RQ3 | ADMA<br>RQ2 |

| Номер          | 7           | 6           | 5 | 4    | 3     | 2     | 1     | 0     |
|----------------|-------------|-------------|---|------|-------|-------|-------|-------|
| Доступ<br>RISC | R/W         | R/W         | U | R/W  | R/W   | R/W   | R/W   | R/W   |
| Доступ<br>DSP  | R/W         | R/W         | U | R/W  | R/W   | R/W   | R/W   | R/W   |
| Срос           | 0           | 0           | 0 | 0    | 0     | 0     | 0     | 0     |
|                | ADMA<br>RQ1 | ADMA<br>RQ0 | - | ANMI | AIRQ3 | AIRQ2 | AIRQ1 | AIRQ0 |

# Таблица 18–9 – Описание бит регистра прерываний от RISC к DSP и запросовперываний для RISC AIRQ

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое    |  |  |  |  |  |  |  |
|------|----------------|----------------------------------------------------|--|--|--|--|--|--|--|
| бита | имя бита       | описание назначения и принимаемых значений         |  |  |  |  |  |  |  |
| 15   | SNR            | Управление установкой или сбросом битов управления |  |  |  |  |  |  |  |
|      |                | прерываниями (1 – установка, 0 – сброс).           |  |  |  |  |  |  |  |
| 14   | SID            | Управление мультиплексором записи                  |  |  |  |  |  |  |  |
|      |                | 0 – Запись бит управления DMA.                     |  |  |  |  |  |  |  |
|      |                | 1 – Запись бит прерываний (активизируется вместе с |  |  |  |  |  |  |  |
|      |                | выбором требуемых бит и значением бита SNR).       |  |  |  |  |  |  |  |
| 13   | ADMADONE3      | Бит состояния готовности данных DMA RISC           |  |  |  |  |  |  |  |
| 12   | ADMADONE2      | Бит состояния готовности данных DMA RISC           |  |  |  |  |  |  |  |
| 11   | ADMADONE1      | Бит состояния готовности данных DMA RISC           |  |  |  |  |  |  |  |
| 10   | ADMADONE0      | Бит состояния готовности данных DMA RISC           |  |  |  |  |  |  |  |
| 9    | ADMARQ3        | Бит запроса передачиданных DMA RISC                |  |  |  |  |  |  |  |
| 8    | ADMARQ2        | Бит запроса передачиданных DMA RISC                |  |  |  |  |  |  |  |
| 7    | ADMARQ1        | Бит запроса передачиданных DMA RISC                |  |  |  |  |  |  |  |
| 6    | ADMARQ0        | Бит запроса передачиданных DMA RISC                |  |  |  |  |  |  |  |
| 5    | -              | _                                                  |  |  |  |  |  |  |  |
| 4    | ANMI           | Немаскируемоепрерыавание от RISC к DSP             |  |  |  |  |  |  |  |
| 3    | AIRQ3          | Прерывание 3 от RISC к DSP                         |  |  |  |  |  |  |  |
| 2    | AIRQ2          | Прерывание 2 от RISC к DSP                         |  |  |  |  |  |  |  |
| 1    | AIRQ1          | Прерывание 1 от RISC к DSP                         |  |  |  |  |  |  |  |
| 0    | AIRQ0          | Прерывание 0 от RISC к DSP                         |  |  |  |  |  |  |  |

## 18.8.2 Регистр прерываний от DSP к RISC

## Таблица 18-10 - Регистр запросов прерываний от DSP к RISC

| Номер          | 15  | 14 | 13 | 12    | 11    | 10    | 9     | 8     |
|----------------|-----|----|----|-------|-------|-------|-------|-------|
| Доступ<br>RISC | R/W | U  | U  | R/W   | R/W   | R/W   | R/W   | R/W   |
| Доступ<br>DSP  | R/W | U  | U  | R/W   | R/W   | R/W   | R/W   | R/W   |
| Срос           | 0   | 0  | 0  | 0     | 0     | 0     | 0     | 0     |
|                | SNR | -  | •  | CRIRQ | CDIRQ | XIRQ3 | RIRQ3 | XIRQ2 |

| Номер          | 7     | 6     | 5     | 4    | 3     | 2     | 1     | 0     |
|----------------|-------|-------|-------|------|-------|-------|-------|-------|
| Доступ<br>RISC | R/W   | R/W   | R/W   | R/W  | R/W   | R/W   | R/W   | R/W   |
| Доступ<br>DSP  | R/W   | R/W   | R/W   | R/W  | R/W   | R/W   | R/W   | R/W   |
| Срос           | 0     | 0     | 0     | 0    | 0     | 0     | 0     | 0     |
|                | RIRQ2 | XIRQ1 | RIRQ1 | TIRQ | DIRQ3 | DIRQ2 | DIRQ1 | DIRQ0 |

## Таблица 18-11 - Описание бит регистра запросов прерываний от DSP к RISC

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 15        | SNR                     | Управление установкой или сбросом битов прерываний                                         |
|           |                         | (1 – установка, 0 – сброс)                                                                 |
| 14        | -                       | Зарезервировано                                                                            |
| 13        | DMAIRQ                  | Бит состояния готовности данных DMA RISC                                                   |
| 12        | CRIRQ                   | прерывание от криптографического модуля                                                    |
| 11        | CDIRQ                   | прерывание от кодека                                                                       |
| 10        | XIRQ3                   | прерывание от передатчика третьего устройства MCBSP                                        |
| 9         | RIRQ3                   | прерывание от приемника третьего устройства MCBSP                                          |
| 8         | XIRQ2                   | прерывание от передатчика второго устройства MCBSP                                         |
| 7         | RIRQ2                   | прерывание от приемника второго устройства MCBSP                                           |
| 6         | XIRQ1                   | прерывание от передатчика первого устройства MCBSP                                         |
| 5         | RIRQ1                   | прерывание от приемника первого устройства MCBSP                                           |
| 4         | TIRQ                    | прерывание от таймера DSP                                                                  |
| 3         | DIRQ3                   | Прерывание 3 от DSP к RISC                                                                 |
| 2         | DIRQ2                   | Прерывание 2 от DSP к RISC                                                                 |
| 1         | DIRQ1                   | Прерывание 1 от DSP к RISC                                                                 |
| 0         | DIRQ0                   | Прерывание 0 от DSP RISC                                                                   |

### 19 Процессорное ядро DSP

#### 19.1 Основные особенности ядра DSP

- 40-битовый арифметико-логический модуль (арифметико-логическое устройство), Включающее 40-битовое циклическое сдвиговое и два независимых 40-битовых аккумулятора.
- 17\*17-разрядный параллельный умножитель, совмещённый с 40-битовым специализированным сумматором, выполняющий в одном цикле (без конвейеризации) операцию умножения с накоплением (MAC).
- Модуль сравнения, выбора и хранения (CSSU) для операции сложения/сравнения и выбора в операторе Viterbi.
- Кодер экспоненты, для вычисления значения экспоненты 40-битового аккумулятора в одном такте.
- Два генератора адреса с восьмью вспомогательными регистрами и двумя вспомогательными арифметическими регистрами (ARAUs).
- Инструкции повторения одной команды и повторения блока программного кода.
- Команды с 32-разрядными длинными словами.
- Команды с чтением двух и трёх операндов (бинарные и тернарные).
- Арифметические команды с параллельным сохранением и параллельной загрузкой.
- Условные команды.
- Быстрый возврат из прерывания.
- 187 инструкций (16-разрядные инструкции, содержащие от одного до трёх слов).
- 6-стадийный конвейер обработки.
- Аппаратное разрешение кофликтов конвейерной обработки.

#### 19.2 Архитектура ядра DSP

Микропроцессорное ЦОС (DSP) ядро использует расширенную, модифицированную гарвардскую архитектуру, которая увеличивает скорость обработки, поддерживая три отдельных шинных структуры для памяти данных и одну для памяти программы. Раздельные пространства программ и данных позволяют реализовать одновременный доступ к командам и данным, обеспечивая высокую степень параллелизма. Например, два чтения и одна запись могут быть выполнены в одном цикле. Команды с параллельным хранением в специфических приложениях могут полностью использовать эту архитектуру. Такой параллелизм поддерживается мощным набором арифметики, логики и операций побитовой обработки, которые могут быть выполнены в одном машинном цикле. Кроме того, имеются механизмы управления прерываниями, повтором операций, и вызовом функций. Функциональная блок-схема включает основные блоки и шинную структуру в описываемом устройстве.

Ядро DSP включает в себя следующие модули:

- Устройства управления;
- 40-битовое арифметико-логическое устройство (ALU);
- Два 40-битовых регистра аккумулятора;
- Циклический сдвигатель, поддерживающий диапазон сдвигов от -16 до 31;
- Блок умножения с накоплением;

- 16-битовый временный регистр (Т);
- 16-битовый регистр перехода (TRN);
- Устройство сравнения, выбора и хранения (CSSU);
- Шифратор показателя.



Рисунок 19-1 - Блок-схема микропроцессорного ядра

#### 19.2.1 Шинная структура DSP

Процессороное ядро DSP использует четыре 16-разрядные шины:

- Шина чтения программ ({PAB,PB}), которая доставляет код инструкции и операнды из памяти программы;
- Две шины чтения данных ({CAB,CB}, {DAB,DB}) и одна шина записи данных ({EAB,EB}). В процессе работы может быть осуществлена одновременное чтение двух операндов и записьрезультата.

Микропроцессорное ядро имеет возможность генерировать до двух адресов памяти данных в цикле, которые сохраняются в двух вспомогательных регистрах модуля арифметики (ARAU0 и ARAU1).

В ЦОС части микроконтроллера все шины ядра преобразуются в шины стандарта AMBA. Обращение к периферийным модулям ЦОС части устройства происходит по шине APB, к памяти по шине AHB.

#### 19.2.2 Устройство управления выполнением программ

Устройство управления выполненят следущие функции:

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

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



Рисунок 19-2 - Структура арифметико-логического устройства процессора DSP

Арифметико-логическое устройство может функционировать как два 16-разрядных арифметико-логических устройства и выполнять две 16-разрядных операции одновременно, когда бит С16 в регистре состояния 1 (ST1) установлен.

40-разрядное АЛУ, реализует много различных арифметических и логических операций, большинство из которого выполняется за один такт. После того, как действие будет выполнено в ALU, результат обычно передается на аккумулятор

назначения (аккумулятор A или B). Инструкции, которые выполняют действия типа память-память (ADDM, ANDM, ORM, и XORM) являются исключением.

Источник входа Х АЛУ любая из двух величин:

- Выход сдвигового устройства (32- битный или 16-битный операнд памяти данных или сдвинутое значение аккумулятора).
- Операнд памяти данных из шины данных DB.

Источник входа Y на ALU - любая из трех величин:

- Значение одного из аккумуляторов (А или В).
- Операнд памяти данных из шины данных СВ.
- Значение в регистре Т.

Когда 16-битный операнд памяти данных подан через шину данных СВ или DB, 40-разрядное значение образуется одним из двух способов:

- Если биты с 15 по 0 содержат операнд памяти данных, биты с 39 по 16 заполняются нулем (SXM = 0) или расширением знака (SXM = 1).
- Если биты 31 по 16 содержат операнд памяти данных, биты 15 по 0 заполняются нулем, и биты с 39 по 32 заполняются или нулем (SXM = 0) или расширением знака (SXM = 1).

#### 19.2.3.1 Переполнение АЛУ

Механизм насыщения АЛУ предохраняет результат от переполнения. Эта особенность полезна, например, для реализации фильтра.

Механизм переполнения включается, когда бит режима переполнения (OVM) регистра статуса ST1 установлен в единицу.

В том случае, если произошло переполнение, в зависимоти от бита OVM выполняются следующие действия:

- Если OVM = 0, аккумуляторы загружены результатом АЛУ без модификации.
- Если OVM = 1, аккумуляторы загружаются либо максимальной положительной 32-разрядной величиной (00 7FFF FFFFh), либо максимальной отрицательная 32-разрядной величиной (0FF 8000 0000h) (в зависимости от знака переполнения).
- Флаг переполнения (OVA/OVB) в регистре статуса ST0 устанавливается для аккумулятора назначения и остается установленным пока не произойдет одно из условий:
  - Выполнен сброс (подсистемы DSP либо ядра DSP).
  - Условная инструкция (например: переход, возврат, вызов или исполнение) выполнена по условию переполнения.
  - Флаг переполнения (OVA/OVB) сброшен.

Аккумулятор может быть программно насыщен, с использованием инструкции SAT, независимо от значения OVM.

#### 19.2.3.2 Бит переноса

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

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

Два операнда условий, С и NC, разрешают переходы, вызовы, возвраты и условное выполнение согласно состоянию (установленное или сброшенное) бита переноса.

Также, могут быть использованы инструкции SSBX и RSBX, чтобы установить или сбросить бит переноса соответственно. Бит переноса автоматически устанавливается при сбросе.

Для арифметических действий, АЛУ может действовать в 16-разрядном режиме, когда выполняются два 16-разрядных действия (например, два сложения или два вычитания) в одном цикле. Вы можете выбрать этот режим, установив бит С16 в регистре ST1.

#### 19.2.3.3 Парный 16-разрядный режим

Для арифметических действий, АЛУ может действовать в специальном парном 16-разрядном арифметическом режиме, когда выполняются два 16-разрядных действия (например, два сложения или два вычитания) в одном цикле. Данный режим может быть установлен выбором бита C16 в регистре ST1.

#### 19.2.4 Аккумуляторы А и В

Аккумуляторы ACCA и ACCB, хранят результаты вычислений или используются в качестве второго операнда модулей АЛУ и множителя/сумматора. Кроме того, они могут быть использованы для выполнения инструкций MIN и MAX или инструкции LD||MAC.

Каждый аккумулятор разделен на три части:



Аккумулятор В

#### Рисунок 19-3 - Структура регистров аккумуляторов

Биты охраны (защитные) использованы как резерв для вычислений. Резервные биты позволяют предохраняться от переполнения в итеративных вычислениях (например автокорреляции).

АG, BG, AX, BH, AL, и BL являются регистрами отображенными в память, которые могут быть как записаны так и прочитаны из стека для сохранения контекста и его восстановления, используя инструкции PSHM и POPM. Эти регистры могут быть также использованы другими инструкциями, которые используют отображенные регистры памяти (MMR) для адресации страницы 0. Единственное различие между аккумуляторами A и B то, что биты 32-16 регистра A могут быть использованы как вход умножителя в устройстве умножения/сложения.

#### 19.2.4.1 Сохранение значения аккумуляторов

Содержание аккумуляторов может быть загружено в память данных, используя инструкции STH, STL, STLM и SACCD, или используя инструкции параллельного сохранения. Для сохранения 16 младших разрядов аккумулятора в память со сдвигом, используйте инструкции STH, SACCD и параллельного сохранения. Для операций сдвига вправо, биты из AG и BG сдвигаются к AH и BH. Для операций левого сдвига, биты из AL и BL заменяют AH и BH, соответственно.

Для сохранения младших 16 разрядов аккумулятора в памяти со сдвигом, используйте инструкцию STL. Для операций сдвига вправо, биты из AH и BH заменяют AL и BL, соответственно, а младшие теряются. Для действий левого сдвига, биты в AL и BL заполняются нулями. Поскольку действия сдвига выполняются в сдвиговом устройстве, содержание аккумулятора остается неизменным.

Следующие инструкции сдвигают или циклически сдвигают содержание аккумулятора через бит переноса:

- SFTA (сдвиг арифметический).
- SFTL (сдвиг логический).
- SFTC (сдвиг условный).
- ROL (циклический сдвиг аккумулятора влево).
- ROR (циклический сдвиг аккумулятора вправо).
- ROLTC (циклический сдвиг аккумулятора влево с TC).

При выполнении команд SFTA и SFTL, количество сдвигов определено как 16≤ SHIFT ≤ 15. Выполнение команды SFTA зависит от бита SXM. Когда SXM = 1 и сдвиг является отрицательной величиной, SFTA выполняет арифметический сдвиг вправо и поддерживает знак аккумулятора. Когда SXM = 0, старший разряд аккумулятора нулевой. Инструкция SFTL не зависит от бита SXM; поэтому выполняется действие сдвига для битов 31 – 0, сдвигая нулевой разряд в сторону старших или младших разрядов, в зависимости от направления перемещения.

Инструкция SFTC выполняет 1-битовый сдвиг влево, когда биты 31 и 30 или оба в 1 или оба в 0. Это нормализует 32-битовый аккумулятор, устраняя наиболее значимый повторяющийся бит.

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

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

Инструкция ROLTC (циклически сдвинуть аккумулятор влево с битом TC), вращает аккумулятор налево и сдвигает бит управления тестирования (TC) в младшие разряды аккумулятора.

#### 19.2.4.2 Насыщение при сохранении значений аккумуляторов

Бит SST в PMST определяет необходимость насыщения данных в аккумуляторе перед сохранением его значения в памяти. Насыщение выполняется после операции сдвига. Насыщение при сохранении доступно с десятью инструкциями:

- STH
- ST || ADD
- ST || MPY

- STL
- ST || LD
- ST || SUB
- STLM
- ST || MAC[R]
- DST
- ST || MAS[R]

Следующие шаги выполняются при насыщении в случае сохранения аккумулятора:

- 1. 40-разрядное значение данных сдвигается (вправо или влево) в зависимости от инструкции. Сдвиг такой же, как и описанный в инструкции SFTA и зависит от величины бита SXM.
- 2. 40-битовая величина насыщается в 32-битовую величину. Насыщение зависит от значения бита SXM (число всегда предполагается положительным):
- SXM = 0. 7FFF FFFFh генерируется, если 40-битовая величина больше или равна 7FFF FFFFh.
- SXM = 1. 7FFF FFFFh генерируется, если 40-битовая величина больше, чем 7FFF FFFFh.
- 8000 0000h генерируется, если 40-битовая величина меньше чем 8000 0000h.
- 3. Данные загружаются в память в зависимости от инструкции (16-бит младшая часть, 16-бит старшая часть, или 32-битовые данные). Аккумулятор остается неизменным в течение этого процесса.

#### 19.2.4.3 Специальные инструкции

Каждый аккумулятор предназначен для использования в специализированных инструкциях с параллельными операциями. Это включает операции симметричного фильтра с конечной импульсной характеристикой, использующие инструкцию FIRS, операции адаптивного фильтра, использующие инструкцию LMS, вычисления расстояния по Евклиду, использующие инструкцию SQDST, и другие параллельные действия:

- FIRS выполняет действия для симметричных фильтров с конечной импульсной характеристикой использующей умножение с накоплением (MACs) одновременно со сложением.
- LMS выполняет умножение с накоплением и параллельное сложение с округлением, чтобы эффективно обновлять коэффициенты в фильтре с конечной импульсной характеристикой.
- SQDST выполняет умножение с накоплением и параллельное вычитание. Инструкция FIRS умножает значение аккумулятора (32-16) со значением программной памяти и добавляет результат к величине аккумулятора В. В то же самое время, она складывает операнды памяти Xmem и Ymem, сдвигает результат влево на 16 бит и загружает эту величину на аккумулятор А.

В инструкции LMS, аккумулятор В хранит временные результаты свертки входной последовательности и коэффициентов фильтра; аккумулятор А обновляет коэффициенты фильтра. Аккумулятор А может быть также использован как вход для МАС, который содействует единственному циклу выполнения инструкций с параллельными действиями.

Инструкция SQDST вычисляет квадрат расстояния между двумя векторами. Значение аккумулятора A (32-16) возводится в квадрат производится сложение с аккумулятором В. Результат сохраняется на аккумуляторе В. В то же самое время, Ymem вычитается из Xmem и разница сохраняется на аккумуляторе А. Значение, которое возводится в квадрат, есть значение аккумулятора перед вычитанием.

#### 19.2.5 Циклическое сдвиговое устройство

Циклическое сдвиговое устройство имеет 40-разрядный ввод от аккумулятора или памяти данных (CB, DB) и 40-битовый вывод результата в АЛУ или память данных (ЕВ). Циклическое сдвиговое устройство производит сдвиг влево от 0 до 31 бит или сдвиг вправо от 0 до 16 бит. Требования сдвига определены в поле количества (ASM) регистра ST1 или определены во временном регистре (TREG), который определяется как регистр количества сдвигов. Это сдвигающее устройство и определитель экспоненты нормализуют значения в аккумуляторе в одном цикле. Наименьшие значащие биты (младшие биты) выхода заполнены нулями, а наиболее значащие биты (MSBs) могут быть заполнены или нулями или расширены знаковым разрядом в ОТ состояния признака бита режима (SXM) регистра Дополнительные возможности сдвига дают возможность процессору выполнить числовое масштабирование, извлечение отдельных битов, расширенную арифметику и операции предотвращения переполнения.

Циклическое сдвиговое устройство используется для масштабирования данных:

- Предварительное масштабирование входных операндов из памяти данных или значение аккумулятора перед операцией АЛУ;
- Выполнение логического или арифметического сдвига значения аккумулятора;
- Нормализация аккумулятора;
- Масштабирование аккумулятора перед сохранением значения аккумулятора в памяти данных.



#### Рисунок 19-4 - Структурная схема сдвигового устройства

40-разрядное сдвиговое устройство соединено следующим образом:

- Вход модуля соединен с
  - шиной DB для входного операнда 16-битовых данных;
  - шинами DB и CB для входного операнда 32-битовых данных.
  - с одним из двух 40-разрядных аккумуляторов.
- Выход модуля соединен с:
  - одним из входов АЛУ;
  - шиной EB через устройство выбора записи MSW/LSW.

Бит SXM управляет знаковым или беззнаковым расширением операндов данных (когда бит установлен, расширение знака выполняется). Некоторые инструкции, как например, LDU, ADDS, и SUBS оперируют с беззнаковыми операндами памяти и не выполняют расширение знака, независимо от величины SXM.

Положительные значения сдвига соответствуют сдвигам влево, тогда как отрицательные значения соответствуют сдвигам вправо. Количество сдвигов определено в дополнительном коде, зависящим от типа инструкции. Непосредственный операнд, поле ASM регистра ST1 в режиме сдвига аккумулятора, или значение регистра Т может быть использовано, чтобы определять количество сдвигов:

• 4- или 5-битовое непосредственное значение определенное в операнде инструкции представляет значение сдвига в дипазоне от -16 до 15. Например:

ADD A, -4, В ; сложение аккумулятора (сдвинутого вправо на 4 бита)

с аккумулятором В

; (одно слово, один цикл).

SFTL A, +8 ; сдвиг (логический) аккумулятора на восемь бит влево

; (одно слово, один цикл)

• величина ASM представляет величину сдвига в диапазоне от -16 до 15 и может быть загружено инструкцией LD (с непосредственным операндом или с операндом памяти данных). Например:

ADD A, ASM, B; сложение аккумулятору A с аккумулятором B ; со сдвигом определенным полем ASM

• Шесть младших бит регистра Т представляют величину сдвига в диапазоне от -16 до 31. Например:

NORM A ; нормализация аккумулятора A (Т содержит величину показателя)

#### 19.2.6 Устройство умножения/сложения

Умножитель/сумматор выполняет 17\*17-битовое умножение чисел в дополнительном коде с 40-битовым накоплением в одном цикле команды. Умножитель/сумматор состоит из нескольких элементов: умножитель, сумматор, знаковый/беззнаковый входной контроль, контроль на ноль, округление в дополнительном коде, включает логику переполнения и насыщения, и временный регистр TREG. Умножитель имеет два входа: одним входом является либо TREG,

операнд памяти данных или аккумулятор; другой выбирается из памяти программы, памяти данных, аккумулятора или является непосредственно заданным операндом. Быстрый аппаратный умножитель позволяет микропроцессору эффективно выполнять операции типа свёртки, нахождения корреляционной функции и фильтрации. Кроме того, умножитель и арифметико-логическое устройство вместе выполняют операцию умножения с накоплением (МАС) и арифметико-логическую операцию параллельно в одном конвейерном цикле. Эта функция используется в определении расстояния по Евклиду, и для реализации симметричных фильтров и фильтров по методу наименьшего среднего квадрата (LMS), которые требуются для сложных алгоритмов DSP.

Умножитель может выполнить знаковое, беззнаковое, и знаковое/беззнаковое умножение со следующими ограничениями:

- Для знакового умножения, каждый 16-разрядный операнд памяти переводится в 17-разрядное слово с расширением знака.
- Для беззнакового умножения нуль добавляется к старшему биту (биту 16) в каждом входном операнде.
- Для знакового/беззнакового умножения, один из операндов с расширением знака, а другой расширен нулем.

Выход умножителя может быть сдвинут влево на один бит, чтобы скомпенсировать дополнительный бит знака сгенерированный умножением двух 16-битовых дробных чисел в дополнительном коде. (Дробный режим выбирается когда бит FRCT = 1 в ST1.)

Сумматор в умножителе/сумматоре содержит детектор нуля, схему округления (в дополнительном коде) и логику переполнения/насыщения. Округление состоит из сложения 215 к результату и затем очищению младших 16 бит аккумулятора назначения.



Рисунок 19-5 - 17 \* 17-разрядный аппаратный умножитель

Округление выполняется в некоторых операциях умножения, операциях МАС и умножении/вычитании (MAS), когда суффикс R включен инструкцией. Инструкция LMS также округляет, чтобы минимизировать ошибки квантования в обновленных коэффициентах.

#### 19.2.6.1 Источники данных для модуля умножителя

Вход ХМ в умножителе – любое из следующих значений:

- временный регистр (Т);
- операнд памяти данных из шины данных DB;
- биты 32-16 аккумулятора А.

Входной источник ҮМ в умножителе – любое из следующего значений:

- операнда памяти данных из шины данных DB;
- операнда памяти данных из шины данных СВ;
- операнд из памяти программ из программной шины РВ;
- биты аккумулятора 32-16.

Таблица 19-1 показывает, как ввод данных в умножитель производится для некоторых инструкций. В общей сложности имеется девять используемых комбинаций ввода.

Таблица 19-1

|      |          |                  | ΧN           | X Multiplexer |           |           | Y Multiplexer |           |           |  |  |
|------|----------|------------------|--------------|---------------|-----------|-----------|---------------|-----------|-----------|--|--|
| Case | Instruct | Т                | DB           | Α             | РВ        | СВ        | DB            | Α         |           |  |  |
| 1    | MPY      | #1234h, A        | V            |               |           |           |               | √         |           |  |  |
| 2    | MPY[R]   | *AR2, A          | $\sqrt{}$    |               |           |           |               | $\sqrt{}$ |           |  |  |
| 3    | MPYA     | В                | $\checkmark$ |               |           |           |               |           | $\sqrt{}$ |  |  |
| 4    | MACP     | *AR2, pmad, A    |              | $\sqrt{}$     |           | $\sqrt{}$ |               |           |           |  |  |
| 5    | MPY      | *AR2, *AR3, B    |              | $\sqrt{}$     |           |           | $\sqrt{}$     |           |           |  |  |
| 6    | SQUR     | *AR2, B          |              | $\sqrt{}$     |           |           |               | $\sqrt{}$ |           |  |  |
| 7    | MPYA     | *AR2             |              | $\sqrt{}$     |           |           |               |           | $\sqrt{}$ |  |  |
| 8    | FIRS     | *AR2, *AR3, pmad |              |               | $\sqrt{}$ | $\sqrt{}$ |               |           |           |  |  |
| 9    | SQUR     | A, B             |              |               | $\sqrt{}$ |           |               |           |           |  |  |

Для инструкций, использовавших Т как один ввод, второй ввод может быть получен или как непосредственная величина или из памяти данных через шину данных (DB), или с аккумулятора А.

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

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

Последние два случая используются инструкцией FIRS и SQUR и инструкцией SQDST. Инструкция FIRS получает вводные данные с PB и аккумулятора A. SQUR и SQDST получают оба операнда из аккумулятора A.

Регистр Т предоставляет один операнд для инструкции умножения и умножения с накоплением; другим операндом является операнд памяти данных одиночного доступа. Регистр Т также предоставляет операнд для инструкции умножения с параллельной загрузкой или параллельной записью, как например, LD||MAC, LD||MAS, ST||MAC, ST||MAS, и ST||MPY.

Так как биты аккумулятора A (32-16), могут быть поданы на вход в умножитель, то некоторые последовательности, которые требуют сохранения результата одного вычисления в памяти и питают этим результатом множитель могут выполняться быстрее. Для некоторых специализированных инструкций (FIRS, SQDST, ABDST, и POLY), содержимое аккумулятора А может быть вычислено в АЛУ и затем использовано как вход умножителя без накладных расходов. Иначе говоря, блок АЛУ и умножителя в некоторых инструкциях работают параллельно.

#### 19.2.6.2 Инструкции умножения с накоплением

В инструкциях MAC, MAS, и MACSU с адресацией двойного операнда памяти данных, данные могут быть переданы в умножитель в течение каждого цикла с помощью шин CB и DB, умножены и сложены за один такт. Адреса данных для этих операндов генерируют ARAU0 и ARAU1 — вспомогательные регистры арифметического устройства.

В инструкциях MACD и MACP, данные могут быть переданы в умножитель в течение каждого цикла через DB и PB. DB извлекает данные из памяти данных, а PB извлекает коэффициенты из программной памяти. Когда MACD и MACP используются с инструкциями повторения (RPT и RPTZ), они выполняются в единственном цикле

операции MAC с последовательным доступом к данным и коэффициентам. Адреса данных генерируются ARAU0 и программным адресным регистром (PAR). Адрес памяти данных обновляется ARAU0 согласно единственному операнду памяти данных в режиме косвенной адресации; адрес программной памяти инкрементируется в PAGEN.

Регулярная инструкция MACD поддерживает конструкцию фильтрации (нахождение средневзвешенного). Пока вычисляется сумма произведений, экземпляры данных сдвигаются в памяти, чтобы освободить место для следующего экземпляра и выбросить самый старый член последовательности. Инструкции MAC и MACP с циклической адресацией могут также поддержать реализацию фильтра. Инструкция FIRS осуществляет эффективную симметричную структуру для КИХ фильтра, когда используется циклическая адресация.

Инструкции MPYU и MACSU облегчают арифметические действия повышенной точности. Инструкция MPYU выполняет беззнаковое умножение. Беззнаковое содержание регистра Т умножается на беззнаковое содержание адресуемой памяти данных и результат размещается в аккумуляторе. Инструкция MACSU выполняет знаковое/беззнаковое умножение и сложение. Беззнаковое содержание одной из ячейки памяти данных умножается на знаковое содержание другой ячейки памяти данных, и результат складывается с аккумулятором. Эта операция допускает операнды более чем в 16 бит, которые нужно разбить в 16-битовые слова и затем обрабатывать отдельно, чтобы сгенерировать произведение более чем в 32 бита.

Инструкция возведения в квадрат и сложения (SQURA) и возведения в квадрат и вычитания (SQURS) передает это значение данных на оба ввода множителя для возведения в квадрат. Результат сложения (SQURA) или вычитания (SQURS) с аккумулятором реализуется на уровне сумматора. Инструкция SQUR возводит в квадрат значение памяти данных или содержание аккумулятора A.

#### 19.2.6.3 Насыщение в модуле умножения с накоплением

Когда установлено насыщение в умножении (SMUL = 1), инструкция MAC является эквивалентом MPY + ADD, когда OVM = 1. Эффект - в том, что умножение, 8000h x 8000h, насыщено к 7FFF FFFFh в режиме дробных чисел перед выполнением последующего сложения (MAC) или вычитания (MAS).

Когда не установлено насыщение в умножении (SMUL = 0), только конечные результаты MAC и MAS насыщаются.

Когда OVM = 1 и FRCT = 1, бит SMUL в PMST определяет, насыщен ли результат умножения прежде, чем накопление будет выполнено в инструкциях MAC и MAS. Эта характеристика позволяет операциям MAC и MAS соответствовать основным операциям MAC и MAS, определенным в спецификации ETSI GSM (спецификация GSM 6.06, 6.10, и 6.53)

#### 19.2.7 Устройство сравнения, выбора и хранения (CSSU)

Устройство сравнения, выбора и хранения является специализированным аппаратным устройством, предназначенным для операций сложения/сравнения/выбора по Витерби.



Рисунок 19-6 - Устройство сравнения, выбора и хранения (CSSU)

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

Функция сложения оператора Viterbi, выполняется в АЛУ. Эта функция состоит из двойной функции сложения (Met1  $^{\pm}$  D1 и Met2  $^{\pm}$  D2). Двойное сложение завершается в одном такте, если АЛУ сконфигурировано в двойном 16-разрядном режиме, установкой бита C16 в ST1. С АЛУ, сконфигурированном в двойном 16-разрядном режиме, все длинные слова (32-бит) становится двойными 16-битовыми арифметическими операндами.

Регистр Т подключен к вводу АЛУ (как двойной 16-битовый операнд) и использован как локальная память для того, чтобы минимизировать обращения к памяти. Таблица 19-2 показывает инструкции, которые выполняют двойные 16-разрядные операции.

Таблица 19-2

| Инструкции             | Функции (двойной 16-разрядный режим)                   |
|------------------------|--------------------------------------------------------|
| DADD Lmem, src [, dst] | $src(31-16) + Lmem(31-16) \rightarrow \Box dst(39-16)$ |
|                        | src(15–0) + Lmem(15–0)→□dst(15–0)                      |
| DADST Lmem, dst        | Lmem(31–16) + T → □dst(39–16)                          |
|                        | Lmem(15–0) – T → □dst(15–0)                            |
| DRSUB Lmem, src        | Lmem(31–16) – $src(31–16) \rightarrow \Box src(39–16)$ |
|                        | Lmem(15–0) – $src(15–0)$ → $\Box src(15–0)$            |
| DSADT Lmem, dst        | Lmem(31–16) – T→dst(39–16)                             |
|                        | Lmem(15–0) + T → □ dst(15–0)                           |
| DSUB Lmem, src         | $src(31-16) - Lmem(31-16) \rightarrow \Box src(39-16)$ |
|                        | src(15–0) – Lmem(15–0) → □src(15–0)                    |
| DSUBT Lmem, dst        | Lmem(31–16) – T → □dst(39–16)                          |
|                        | Lmem(15–0) + T → □dst(15–0)                            |

#### Обозначения:

→ сохраняется в Lmem длинное (32 бит) значение памяти данных;

src аккумулятор- источник;

dst аккумулятор назначения;

х(n-m) чтение битов х от m до n.

Устройство сравнения, выбора и хранения осуществляет сравнение и выбирает действие через инструкцию CMPS, компаратор, и 16-битовый регистр

перехода (TRN). Эта операция сравнивает две 16-битовых части определенного аккумулятора и сдвигает решение к биту 0 TRN. Это решение также сохраняется в бите TC регистра ST0.

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

```
CMPS B,*AR3 ; if (B(31-16)>B(15-0)) then
; B(31-16)->(*AR3); TRN<<1; 0->TRN(0);
; 0->TC}
; else B(15-0)->(*AR3); TRN<<1;
; 1->TRN(0); 1->TC;
```

Рисунок 19-7 - Сравнение и выбор операции CMPS

Регистр TRN содержит информацию о решении пути перехода в новые состояния. Эта информация может быть использована для обратной трассировки программы, которая находит оптимальный путь для результатов при декодировании кода.

#### 19.2.8 Шифратор показателя

Шифратор показателя является специализированным аппаратным устройством предназначенным поддерживать инструкции EXP за один цикл. С инструкцией EXP, величина показателя на аккумуляторе может быть сохранена в Т как значение в дополнительном коде в пределах диапазона от -8 до 31. Показатель определен как количество старших лишних битов -8, которые соответствуют количеству сдвигов требующихся в аккумуляторе, чтобы устранять незначащие биты знака. Это действие заканчивается отрицательной величиной, когда величина аккумулятора превышает 32 бита.



Рисунок 19-8 - Шифратор экспоненты

Инструкции EXP и NORM используют шифратор показателя, чтобы эффективно нормализовать содержание аккумуляторов. Инструкция NORM поддерживает сдвиг величины аккумулятора на число бит, определенных в Т за один цикл. Отрицательная величина в Т производит перемещение вправо содержания аккумуляторов, которое нормализует любую величину, выходящую за 32-битовым

диапазон представлений аккумулятора. Рисунок 19–9 демонстрирует нормализацию аккумулятора А.

;Normalize accumulator A

EXP A ; (the number of leading bits -8)-> T. ST T, EXPONENT ; Store the exponent (T) into data

; memory

NORM A ; Normalize accumulator A, (A) << (T)

Рисунок 19-9 - Нормализация аккумулятора А

#### 19.3 Организация конвейера

Реализованный в ядре DSP конвейер имеет следующие особенности:

- Конвейер эластичный, что означает то, что каждый его ярус передает результаты своей работы на следующий ярус при условии готовности к приёму следующего яруса. При этом состояние предыдущих ярусов неважно. Перемещение команды по уровням конвейера в процессе исполнения в свою очередь зависит только от состояния этих последующих ярусов. Иначе говоря, операция управления префиксная. Префиксной называется такая операция над векторами, в которой результирующее значение каждого элемента зависит только от тех элементов исходных операндов, которые расположены только справа или только слева от данного элемента, а также элементов данной позиции. Примером префиксной операции обработки является сложение чисел, где значение каждого бита результата зависит только от значений битов слагаемых с меньшим либо тем же весом. В данном случае речь идёт об операции управления, в которой вектор составлен из элементов управляющей структуры ярусов конвейера. В таком конвейере "пузыри" (bubble) могут возникать на любом ярусе, по причине того, что тормозится предыдущий ярус, однако это не мешает перемещению данного яруса. Причиной возникновения "пузырей" может быть то, что последующая команда двух или трёхсловная или фаза чтения операнда затянулась на два или более такта и т.д. Если таких причин нет, то конвейер остается предельно "плотным" и в идеальном случае в каждом такте синхросигнала все команды в конвейере перемещаются на новый уровень обработки.
- Помехи типа "чтение после записи" (RAW-read after write), возникающие в конвейере разрешаются не программно, а аппаратно. При этом используется как торможение яруса чтения, так и "короткие замыкания" (bypass).

#### 19.3.1 Стадии конвейера

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

• Упреждающая выборка программы. Шина программного адреса (PAB), загружается адресом следующей инструкции, которую нужно выбрать.

- **Выборка программного кода**. Слово инструкции выбирается из шины команд (РВ) и загружается в регистр инструкции (IR). Это завершает последовательность выборки инструкции, которая состоит из этого и предыдущего циклов.
- Декодирование. Содержание регистра инструкции (IR) декодируется, чтобы определять тип операций при доступе в память и управляющую последовательность в устройстве генерации адреса данных (DAGEN).
- Доступ. DAGEN загружает адреса операндов на шину адреса данных, DAB. Если требуется второй операнд, другая шина адреса данных, CAB, также загружается соответствующим адресом. Вспомогательный регистр в режиме косвенной адресации и указатель стека (SP) также обновляются. Это считается первым этапом 2-х стадийной последовательности чтения операндов.
- **Чтение.** Операнд или операнды данных для чтения, если они необходимы, читаются из шины данных, DB и CB. Это завершает двухступенчатую последовательность чтения операндов. В то же самое время начинается двухступенчатая последовательность записи операнда. Адрес данных записываемого операнда, если это требуется, загружается на шину адреса записи данных (EAB). Для регистров, отображенных в памяти, операнд данных читается из выбранных регистров.
- **Выполнение.** Последовательность записи операнда завершается записью данных с использованием шины записи данных (EB). Инструкция выполняется в этой фазе.

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



Рисунок 19-10 - Этапы работы конвейера

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

Следующие две стадии конвейера, доступа и чтения – последовательность чтения операнда. Если требуется инструкцией, адрес данных одного или двух операндов загружается в фазе доступа и операнд или операнды читаются в следующей фазе чтения.

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

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

Рисунок 19–11 показывает, как различные фазы доступа к памяти выполняются в конвейере. На рисунке допущено, что любой доступ к памяти выполняется в одном цикле, единственным словом инструкции с расположенной на кристалле расслоенной оперативной памятью. Внутренняя память поддерживает двойной доступ за один такт конвейера, если они адресуются в разные банки (слои).

|             | а) выборка слова инст | рукции (один цикл)     |                              |                          |                               |                   |
|-------------|-----------------------|------------------------|------------------------------|--------------------------|-------------------------------|-------------------|
|             | Предвыборка           | Выборка                | Декодирование                | Доступ                   | Чтение                        | Выполнение/запись |
|             | Загрузка РАВ          | Чтение из РВ           |                              |                          |                               |                   |
|             |                       |                        |                              |                          |                               |                   |
|             | б) выполнение инстру  | кцией чтения одного о  | перанда (например, Ц         | D *AR1,A; один цикл)     |                               |                   |
|             | Предвыборка           | Выборка                | Декодирование                | Доступ                   | Чтение                        | Выполнение/запись |
|             |                       |                        |                              | Загрузка DAB             | Чтение из DB                  |                   |
|             |                       |                        |                              |                          |                               |                   |
|             | с) инструкция выполн  | яет чтение двух опера  | ндов (например, МАС          | *AR2+,*AR+,A or DLD */   | AR2,A; один цикл)             |                   |
|             | Предвыборка           | Выборка                | Декодирование                | Доступ                   | Чтение                        | Выполнение/запись |
|             |                       |                        |                              | Загрузка DAB и CAB       | Чтение из DB и CB             |                   |
|             |                       |                        |                              |                          |                               |                   |
|             | д) инструкция выполн  | няет запись одного опе | ранда (например, STH         | A, *AR1; один цикл)      |                               |                   |
|             | Предвыборка           | Выборка                | Декодирование                | Доступ                   | Чтение                        | Выполнение/запись |
|             |                       |                        |                              |                          | Загрузка ЕАВ                  | Запись на ЕВ      |
|             |                       |                        |                              |                          |                               |                   |
|             | е) инструкция выполн  | няет запись двух опера | ндов (например, DST <i>I</i> | *AR1; два цикла)         |                               |                   |
| Предвыборка | Выборка               | Декодирование          | Доступ                       | Чтение                   | Выполнение/запись             | 1                 |
|             |                       |                        |                              | Загрузка ЕАВ             | Запись в ЕВ                   |                   |
|             |                       |                        |                              |                          |                               | •                 |
|             |                       | D. C                   |                              |                          | University                    | D                 |
|             | Предвыборка           | Выборка                | Декодирование                | Доступ                   | Чтение                        | Выполнение/запись |
|             |                       |                        |                              |                          | Загрузка ЕАВ                  | Запись в ЕВ       |
|             |                       |                        |                              |                          |                               |                   |
| и           | ) инструкция выполняе | г чтение операнда и за | пись операнда (наприм        | иер, ST A, *AR2    LD *A | R3,B; один цикл)              |                   |
|             | Предвыборка           | Выборка                | Декодирование                | Доступ                   | Чтение                        | Выполнение/запись |
|             |                       |                        |                              | Загрузка DAB             | Чтение из DB;<br>Загрузка EAB | Запись в ЕВ       |
|             |                       |                        |                              |                          |                               |                   |

Рисунок 19-11 - Выполнение в ковейере различных фаз доступа к памяти

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

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

| <b>Адрес</b> a1,a2 a3 a4 b1 | Инструкция В b1 это 4-х цикловая 2-х словная инструкция перехода i3 это любая одноцикловая однословная инструкция i4 это любая одноцикловая однословная инструкция j1 |               |               |               |                       |                       |                       |                       |                       |  |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------|---------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|--|
| 1                           | 2                                                                                                                                                                     | 3             | 4             | 5             | 6                     | 7                     | 8                     | 9                     | 10                    |  |
| Предвыборка                 | Выборка                                                                                                                                                               | Декодирование | Доступ        | Чтение        | Выполнение/<br>запись |                       |                       |                       |                       |  |
| PAB=a1                      | PB=B                                                                                                                                                                  | IR=B          |               |               | В                     |                       |                       |                       |                       |  |
|                             | Предвыборка                                                                                                                                                           | Выборка       | Декодирование | Доступ        | Чтение                | Выполнение/<br>запись |                       |                       |                       |  |
| b1                          | PAB=a2                                                                                                                                                                | PB=b1         | IR=b1         |               |                       | b1                    |                       |                       |                       |  |
|                             |                                                                                                                                                                       | Предвыборка   | Выборка       | Декодирование | Доступ                | Чтение                | Выполнение/<br>запись |                       |                       |  |
| Очистка конве               | йера                                                                                                                                                                  | PAB=a3        | PB=i3         |               |                       |                       |                       |                       |                       |  |
|                             |                                                                                                                                                                       |               | Предвыборка   | Выборка       | Декодирование         | Доступ                | Чтение                | Выполнение/<br>запись |                       |  |
| Очистка конве               | Очистка конвейера                                                                                                                                                     |               | PAB=a4        | PB=i4         |                       |                       |                       |                       |                       |  |
|                             |                                                                                                                                                                       |               |               | Предвыборка   | Выборка               | Декодирование         | Доступ                | Чтение                | Выполнение/<br>запись |  |
| j1                          |                                                                                                                                                                       |               |               | PAB=b1        | PB=j1                 | IR=j1                 |                       |                       | j1                    |  |

Рисунок 19-12 - Работа конвейера

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

Каждый блок в примере содержит наиболее важные действия, которые происходят на этом конвейерном этапе. Имя каждого конвейерного этапа показано выше блока, в котором это действие происходит.

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

#### 19.3.2 Инструкции перехода в конвейер

Следующие примеры показывают поведение конвейера в течение выполнения инструкции перехода (B) и задержанной инструкции перехода (BD), соответственно.

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



Рисунок 19-13 - Инструкция перехода в конвейере

- Цикл 1: РАВ загружается адресом инструкции перехода.
- Циклы 2 и 3: Выборка двух слов инструкции перехода.
- **Циклы 4 и 5**: Выбираются две дополнительные инструкции і3 и і4. Хотя две инструкции после инструкции перехода, і3 и і4, выбираются ядром, но им не позволено перемещаться в дальнейшем на этап декодирования и, в конечном счете, они будут отвергнуты. После того как второе слово инструкции перехода (представленное как b1 в левой колонке), декодировано, РАВ загружается этой новой величиной (в цикле 5).
- **Циклы 6 и 7**: двухсловная инструкция перехода входит в стадию выполнения в конвейере в циклах 6 и 7. Также, выбирается ј1 по адресу b1 в цикле 6.
- **Циклы 8 и 9:** эти циклы также заняты той же инструкцией перехода, так как следующим двум инструкциям, i3 и i4, не было позволено завершить выполнение. В этом, и заключается причина, по которой инструкция перехода занимает 4 цикла вместо двух.
- Цикл 10: j1 завершает выполнение.



Рисунок 19-14 - Задержанная инструкция перехода в конвейере

В этом случае, конвейер ведется себя также, как при обычной инструкции перехода. Тем не менее, двум инструкциям, следующим за переходом, і3 и і4, позволено завершать выполнение. Следовательно, только циклы 6 и 7 используются задержанной инструкцией перехода, делая задержанную инструкцию перехода 2-х цикловой.

#### 19.3.3 Инструкции вызова функций в конвейере

Стандартная инструкция вызова требует четыре цикла при выполнении. Хотя стандартный вызов является двухсловной инструкцией и кажется, что нужно только два цикла, он в действительности очищает конвейер в двух циклах.



Рисунок 19–15 – Инструкция вызова в конвейере

- Цикл 1: РАВ загружается адресом инструкции вызова функции.
- Циклы 2 и 3: Два слова инструкции вызова выбраны.
- **Цикл 4:** SP декрементируется (представлено как SP -- ), поскольку адрес возврата записан в стек. Инструкция i3 выбрана; тем не менее, ей не позволено перемещаться далее к фазе декодирования.
- **Цикл 5**: шина адреса записи (EAB) загружается содержимым SP и расположенный на кристалле регистр возврата (RTN) загружается адресом возврата а3. После того как второе слово инструкции вызова (b1) будет декодировано, PAB загружается новой величиной в цикле 5 (показано в колонке j1).
- **Циклы 6 и 7:** содержание RTN записано в стек, используя EB в цикле 6. Инструкция j1 по адресу b1 выбрана в цикле 6. Двухсловная инструкция вызова входит в стадию выполнения в конвейерных циклов 6 и 7.
- Циклы 8 и 9: Эти циклы поглощены инструкцией вызова, поскольку выполнение следующих двух инструкций не разрешено.
- Цикл 10: ј1 завершает выполнение.



Рисунок 19-16 - Задержанная инструкция вызова в конвейере

В этом случае, конвейер ведется себя также, как и обычная инструкция вызова. Тем не менее, в этом случае следующим двум инструкциям, і3 и і4, позволено завершить выполнение. Следовательно, только циклы 6 и 7 используются задержанной инструкцией перехода, делая задержанную инструкцию перехода 2-х цикловой.

Инструкция INTR ведется себя подобно инструкции вызова. Т.к. INTR однословная инструкция, она может вычислить векторный табличный адрес и предвыборку на один цикл раньше. Как показано на рисунке INTR использует для выполнения только три цикла.



Рисунок 19-17 - Инструкция прерывания INTR в конвейере

#### 19.3.4 Инструкции возврата в конвейере

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



Рисунок 19-18 - Инструкция возврата в конвейере

- Цикл 1: РАВ загружается адресом инструкции возврата.
- Цикл 2: код инструкции возврата выбран.
- **Цикл 3 и 4:** две дополнительные инструкции i2 и i3, выбраны. Хотя эти две инструкции и выбраны устройством, им не позволено переместиться далее на стадию декодирования и они отвергаются. В цикле 4 SP инкрементируется (представлено как SP ++) и DAB загружается содержимым SP для того, чтобы читать адрес возврата из стека.

- **Цикл 5:** верхушка стека прочитана с использованием DB.
- **Цикл 6:** инструкция возврата входит в этап конвейерного выполнения. Адрес, выбранный из стека, загружается на РАВ. Это позволяет выбрать следующую инструкцию j1, по адресу возврата.
- **Цикл 7 и 8:** Эти циклы поглощены инструкцией возврата, поскольку следующие две инструкции, іЗ и і4, не завершили своё выполнение.
- **Цикл 9 и 10:** Поскольку никакие инструкции не были выбраны в циклах 4 и 5, циклы 9 и 10 холостые.
- Цикл 11: ј1 завершает выполнение.



Рисунок 19-19 - Инструкция задержанного возврата в конвейере

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



Рисунок 19-20 - Инструкция возврата с разрешением прерываний в конвейере



Рисунок 19–21 – Задержанная инструкция возврата с разрешением прерываний в конвейере

Следующие примеры показывают поведение конвейера для инструкции быстрого возврата (RETF) и для задержанной инструкции быстрого возврата (RETFD), соответственно. Инструкция RETF, в отличие от инструкции RETE, не делает чтение адреса возврата из стека. Вместо этого она читает его из регистра RTN. Это позволяет инструкции загружать PAB адресом возврата на два цикла быстрее, чем может инструкция RETE. Как показано в примерах, инструкция RETF использует для

выполнения только три цикла; задержанная версия инструкции, RETFD, выполняется в одном цикле.



Рисунок 19-22 - Команда быстрого возврата в конвейере



Рисунок 19-23 - Задержанная команда быстрого возврата в конвейере

#### 19.3.5 Условная инструкция в конвейере

Поскольку XC – однословная инструкция, она использует минимально один цикл для выполнения. Пример показывает конвейерное поведение в течение выполнения XC.



Рисунок 19-24 - Инструкция ХС в конвейере

- Цикл 4: РАВ загружается адресом инструкции ХС.
- Цикл 5: инструкция ХС выбрана.
- Цикл 6: инструкция декодирована.
- **Цикл 7**: когда инструкция ХС перемещается на этап доступа к операндам в цикле 7 конвейера, любые условия определенные в инструкции ХС вычислены. Если тестируемые условия истинны, следующие две инструкции і5 и і6, декодированы и допускают выполнение. Тем не менее, если тестируемые условия ложны, і5 и і6 не декодируются.

Чтобы выполнять XC в одном цикле, ядро оценивает условия тестирования на этапе доступа. Это означает, что две однословные инструкции (или одна 2-х словная) до инструкции XC не будут полностью выполнены перед их тестированием. Поскольку коды условия изменяются инструкциями только на стадии выполнения, эти две инструкции не окажут эффекта на действия команды XC.

## 19.3.6 Команды условного вызова и условного перехода в конвейере

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

Условный вызов инструкции аналогичен в своем конвейерном поведении инструкции безусловного вызова. Единственное исключение в том, что тестируемые условия для инструкции условного вызова устанавливаются на этапе вычислений конвейера. Когда тестируемые условия определяются в цикле 7, предшествующая инструкция, i1, полностью выполнилась. Кроме того, следующие две инструкции после СС, i4 и i5, также выбраны. Если тестируемые условия оценены как ложные, эти две инструкции продолжают движение через конвейер.

В противном случае, они отвергаются. Упреждающая выборка инструкции в цикле 7 также зависит от оцениваемых условий. Если условия истинны, РАВ загружается адресом вызова (b1); в противном случае, загружается следующим инкрементированным адресом (a6).

Если оцененные условия истинны, i4 и i5 не выполнятся в циклах 10 и 11. В этом случае, инструкция СС становится инструкцией 5-ти цикловой. Тем не менее, если оцененные условия ложные, команды i4 и i5 выполнятся, делая инструкцию СС 3-х цикловой.



Рисунок 19-25 - Команда условного вызова (СС) в конвейере

Конвейер ведется себя также для инструкции ССD. Тем не менее, следующим двум инструкциям, i3 и i4, позволено завершить выполнение независимо от того, истинны или нет протестированные условия. Только циклы 7, 8, и 9 использованы инструкцией ССD, делая эту инструкцию 3-х цикловой.



Рисунок 19–26 – Инструкция задержанного условного вызова функции (CCD) в конвейере

Следующие примеры показывают поведение конвейера в течение выполнения инструкции условного перехода (BC) и инструкции задержанного условного перехода (BCD).

Поведение инструкций условного перехода (BC) и задержанного условного перехода (BCD) в конвейере подобно инструкциям СС и ССD, соответственно. Различие в том, что в этом случае адрес возврата не записывается в стек. Инструкция ВС использует три или пять циклов при выполнении, в зависимости от того, есть переход или нет. Инструкция ВСD выполняется в три цикла.



Рисунок 19-27 - Команда условного перехода (ВС) в конвейере



Рисунок 19-28 - Команда задержанного условного перехода (ВСD) в конвейере

#### 19.3.7 Прерывания и конвейер

Если прерывание обслужено в конце цикла 3, инструкция INTR автоматически устанавливается в стадии декодирования конвейера в течение следующего цикла (4). Инструкция i2 не декодируется, поскольку инструкция INTR установлена в конвейере на этом этапе. В течение следующих трех циклов, инструкции, которые уже были до этого декодированы, выполняются. Циклы 7, 8, и 9 используются инструкцией INTR. Первая инструкция в ISR, RETFD, выполняется в цикле 10. Циклы 11 и 12 используются двумя однословными инструкциями, которые заполняют щель задержки инструкции RETFD. В следующем цикле, выполняется инструкция i2, завершая возврат из ISR.

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



Рисунок 19–29 – Ответ конвейера на прерывание

#### 19.4 Адресация данных

Микропроцессор ЦОС предлагает семь основных способов адресации:

- непосредственная адресация использует фиксированное значение в команде;
- абсолютная адресация использует фиксированный адрес в команде;
- аккумуляторная адресация использует аккумулятор, чтобы обратиться к памяти программ как к данным;
- прямая адресация использует семь бит команды как смещение относительно DP или SP. Смещение плюс значение DP или SP определяет исполнительный адрес в памяти данных;
- косвенная адресация использует вспомогательные регистры, чтобы обратиться к памяти;
- адресация регистра отображенного в память изменяет регистры, отображенные в памяти, не затрагивая текущее значение DP(data pointer) или текущее значение SP(stack pointer);
- стековая адресация управляет добавлением и удалением элементов системного стека.

# 19.4.1 Непосредственная адресация

В непосредственной адресации, синтаксис команды содержит конкретное значение операнда. Два типа значений могут быть закодированы в команде:

- короткие непосредственные значения могут быть 3, 5, 8, или 9 битовыми по длине;
- 16-разрядные непосредственные значения всегда 16 битовые.

Непосредственные значения могут быть закодированы в 1-ом или 2-ом слове инструкции. 3-, 5-, 8- или 9-битовые значения закодированы в 1 слове команды; 16-разрядные значения закодированы 2-ом во слове команды. Длина непосредственного операнда, закодированного в команде, зависит от типа используемой команды. Таблица 19-3 даёт список команд, которые могут закодировать непосредственные операнды в своём слове команды. Таблица также дает число разрядов, которое может быть закодировано в команде.

| 3- и 5-разрядные константы | 8-разрядная<br>константа | 9-разрядная<br>константа | 16-разрядна | я константа |
|----------------------------|--------------------------|--------------------------|-------------|-------------|
| LD FRAME                   |                          | LD                       | ADD         | ORM         |
|                            | LD                       |                          | ADDM        | RPT         |
|                            | RPT                      |                          | AND         | RPTZ        |
|                            |                          |                          | ANDM        | ST          |
|                            |                          |                          | BITF        | STM         |
|                            |                          |                          | СМРМ        | SUB         |
|                            |                          |                          | LD          | XOR         |
|                            |                          |                          | MAC         | XORM        |
|                            |                          |                          | OR          |             |

Таблица 19-3 – Команды, разрешающие непосредственную адресацию

Синтаксис непосредственной адресации использует знак (#), предшествующий значению или символу, чтобы указать, что это – непосредственное значение. Например, чтобы загрузить сумматор значением 80 в шестнадцатеричной системе счисления, Вы написали бы:

LD #80h. A

Рисунок 19–30 и Рисунок 19–31 используют команду RPT, чтобы показать, как непосредственное значение закодировано в командах, которые используют непосредственную адресацию. Код операции в команде закодирован в старшей половине команды: биты 8-15 1-ого слова инструкции, биты 0-15 старшего слова кодирования с 2 словами. Значение константы находится в остальной части кодового пространства.



Рисунок 19-30 - Команда RPT с короткой непосредственной адресацией

|                   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 2 командных слова | 1                 | 1  | 1  | 1  | 0  | 0  | 0 | D | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |
|                   |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|                   | 16 БИТ ПОСТОЯННЫЙ |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Рисунок 19-31 - Команда RPT с 16-разрядной непосредственной адресацией

### 19.4.2 Абсолютная адресация

Это 4 типа абсолютной адресации:

- dmad адресация (data-memory address):
  - MVDK Smem, dmad
  - MVDM dmad, MMR
  - MVKD dmad, Smem
  - MVMD MMR, dmad
- pmad адресация (program-memory address):
  - FIRS Xmem, Ymem, pmad
  - MACD Smem, pmad, src
  - MACP Smem, pmad, src
  - MVDP Smem, pmad
  - MVPD pmad, Smem
- PA адресация (port address):
  - PORTR PA, Smem
  - PORTW Smem, PA
- \*(lk) адресация.

#### dmad адресация

dmad (data-memory address) – Адресация к памяти данных (dmad) использует определенное значение, указывающее адрес в пространстве данных. В синтаксисе для обращения dmad используется символ или число, определяющее адрес в пространстве данных. Например, чтобы скопировать значение, содержавшееся в адресе, обозначенном как SAMPLE в пространстве данных в ячейку памяти в пространстве данных, на которое указывает AR5, Вы должны написать:

MVKD SAMPLE, \*AR5

В этом примере адрес, на который ссылается SAMPLE-значение типа dmad.

#### pmad адресация

Адресация к памяти программ (pmad-program-memory address) использует значение, определяющее адрес в пространстве программы. В синтаксисе обращения pmad использовуется символ или число, определяющее адрес в пространстве программы. Например, скопировать значение из программной памяти с меткой TABLE в ячейку памяти в пространстве данных, помеченную как AR7, Вы будете писать:

MVPD TABLE, \*AR7-

В этом примере, адрес, на который ссылается TABLE – значение типа pmad.

## РА адресация

Адресация к порту (PA – port address) использует значение, определяющее внешний адрес порта ввода – вывода. Синтаксис для PA адресации, использует символ или число, определяющее адрес порта. Например, чтобы скопировать значение с порта ввода – вывода FIFO в память данных, на которое указывает AR5, Вы написали бы:

PORTR FIFO,\*AR5

В этом примере, FIFO – это обращение к адресу порта.

#### \*(lk) адресация

\* (lk) адресация используется для определения адреса в пространстве данных.

Синтаксически \* (lk) адресация определяется использованием символа или числа определяющего адрес в пространстве данных. Например, чтобы загрузить аккумулятор значением, содержавшимся в адресе BUFFER в пространстве данных, Вы бы написали:

LD \*(BUFFER), A

Синтаксис для \* (lk) адресация таков, что позволяет всем командам, которые используют Smem, осуществить доступ к любому месту в пространстве данных, не изменяя значение регистра DP или инициализации регистра AR. Когда используется эта форма абсолютной адресации, длина команды расширена одним словом. К примеру, однословная инструкция стала бы двухсловной, а двухсловная станет трёхсловной. Добавление одного слова к команде затрагивает ее практичность и задержку в тактах.

Примечание — Команды использующие \* (lk) форму абсолютной адресации не могут быть использованы с повторением единственной команды (RPT,RPTZ).

### 19.4.3 Аккумуляторная адресация

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

- READA Smem
- WRITA Smem

READA перемещает слово памяти программ, определенного аккумулятором А к месту памяти данных, определенному единственным операндом команды (Smemsingle data-memory).

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

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

В режиме прямой адресации, команда содержит младшие семь бит адреса памяти данных (dma). 7-битовый dma — смещение адреса, которое объединено с базовым адресом, с указателем страницы данных (DP), или с указателем вершины стека (SP), чтобы сформировать 16-разрядный адрес памяти данных. Используя эту форму адресации, Вы можете обратиться к любой из 128 ячеек памяти в произвольном порядке, не изменяя значение регистров DP или SP.

Примечание — Прямая адресация не единственный метод адресации по смещению. Однако, преимущество этого режима в том, что это кодирует каждую команду с адресом в единственном слове. DP или SP могут быть объединены со смещением dma, чтобы генерировать исполнительный адрес. Бит режима компилятора (CPL-compiler mode bit), расположенный в регистре состояния ST1, выбирает, какой метод используется для генерации адреса:

- когда CPL = 0, dma поле сочленяется с 9-битовым полем DP, чтобы сформировать 16-разрядный адрес памяти данных.
- когда CPL = 1, dma поле складывается (положительное смещение) с SP, чтобы сформировать 16-разрядный адрес памяти данных.

Синтаксис для прямой адресации использует символ или число, чтобы определить значение смещения. Например, чтобы добавить содержание ячейки памяти SAMPLE к аккумулятору В, при условии, что правильный базовый адрес находится в DP (CPL = 0) или SP (CPL = 1), Вы написали бы:

ADD SAMPLE, B

Младшие семь бит адреса SAMPLE сохранены в слове команды.

Рисунок 19–32 показывает формат кода операции для команд, использующих прямую адресацию.

Таблица 19-4 описывает биты команды прямой адресации.

Рисунок 19–33 иллюстрирует, как сформирован 16-разрядный адрес данных.

| 15-8         | 7     | 6 - 0 |
|--------------|-------|-------|
| Код операции | I = 0 | dma   |

Рисунок 19-32 - Формат команд прямой адресации

Таблица 19-4 – Краткое описание битов команды прямой адресации

| Бит    | Название     | Функция                                                                        |
|--------|--------------|--------------------------------------------------------------------------------|
| 15 – 8 | Код операции | Это 8-разрядное поле содержит код операции команды                             |
| 7      | I            | I=0, режим адресации, используемый командой, является режимом прямой адресации |
| 6 – 0  | dma          | Это 7-разрядное поле содержит адрес смецения памяти данных для команды         |



Рисунок 19-33 - Блок-схема прямой адресации

#### Прямая адресация со ссылкой на DP

В прямой адресации, ссылаемой на DP, 7-битовое поле dma в команде сочленяется (конкатенация) с 9-битовым значением в DP, чтобы сформировать адрес. Рисунок 19–34 показывает, как два значения составляют исполнительный адрес.



Рисунок 19-34 - Прямая адресация, связанная с DP

Прямая адресация со ссылкой на DP делит память на 512 страниц, потому что диапазон DP от 0 до 511 ( $2^9-1$ ). Каждая страница имеет 128 адресов, потому диапазон dma от 0 до 127 ( $2^7-1$ ).

Другими словами, DP указывает на одну из 512 возможных страниц памяти данных с 128 словами; dma указывает на определенное место в пределах этой страницы. Единственное различие между доступом к месту 0 на странице 1 и к месту 0 на странице 2 проявляется в значении DP.

Регистр DP загружается командой LD.

#### Прямая адресация со ссылкой на SP

В прямой адресации, связанной с SP, 7-битовый dma в регистре команды складывается как положительное смещение со значением SP, чтобы сформировать эффективный 16-разрядный адрес памяти данных. Рисунок 19–35 показывает, как два значения объединяются, чтобы сформировать результирующий адрес.



Рисунок 19-35 - Прямая адресация, связанная с SP

SP указывает на любой адрес в памяти. dma указывает на определенное место на странице, разрешая Вам обратиться к непрерывному в 128 слов (27 – 1) блоку в памяти от любого базового адреса. Через регистр SP можно также добавить или удалить элементы из стека. См. раздел адресации через стек.

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

В косвенной адресации, к любому месту в пространстве данных в 64К-слов можно обратиться через 16-разрядный адрес, содержавшийся во вспомогательном регистре. Микропроцессор имеет восемь 16-разрядных вспомогательных регистров (AR0-AR7). Косвенная адресация используется главным образом тогда, когда есть потребность доступа к последовательным местам в памяти с фиксированным шагом.

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

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

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

Рисунок 19–36 показывает формат команды с косвенным обращением для единственного (Smem) операнда. Таблица 19-5 описывает биты команды.

| 15-8         | 7     | 6 - 3 | 2 - 0 |
|--------------|-------|-------|-------|
| Код операции | I = 0 | MOD   | ARF   |

Рисунок 19–36 – Формат команд косвенной адресации для операнда памяти данных одиночного доступа

Таблица 19-5 – Косвенная адресация одного операнда

| Биты | Название | Функции                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Opcode   | Это 8-ми битовое поле содержит код операции                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7    | I        | При единичном значении используется косвенная адресация                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6-3  | MOD      | Это 4-х битовое поле определяет тип косвенной адресации (см.далее)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2-0  | ARF      | Это поле определяет вспомогательный регистр, используемый при адресации. ARF зависит от бита совместимости в статусном регистре 1 (ST1).  СМРТ = 0 – Стандартная мода. В стандартной моде ARF всегда определяет вспомогательный регистр, независимо от значения в ARP (auxiliary register pointer – поле в статусном регистре 0). ARP не изменяется. ARP должен всегда быть устанавлен в нуль, когда DSP – в этой моде.  СМРТ = 1 – Мода совместимости. В моде совместимости, ARP выбирает вспомогательный регистр, если ARF = 0. В противном случае, ARF выбирает вспомогательный регистр и величина ARF загружается в ARP, когда доступ завершен. *ARO в командах ассемблера указывает вспомогательный регистр, выбранный с помощью ARP в моде совместимости |

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

### ARAU и операция генерации адресов

Два модуля арифметики над вспомогательными регистрами (ARAU0 и ARAU1) оперируют содержимым вспомогательных регистров. ARAUs выполняют 16-разрядные беззнаковые арифметические операции над вспомогательными регистрами. Некоторые адреса могут быть получены, предварительной модификацией вспомогательных регистров.

Вспомогательные регистры могут быть:

- загружены непосредственным значением, используя команду STM;
- загружены через шину данных, записью во вспомогательный регистр, отображенный в памяти;
- изменены косвенной адресацией любой команды, которая поддерживает косвенную адресацию;
- изменены инструкцией модификации вспомогательного регистра (MAR);
- использованы как счетчики цикла в команде BANZ[D].

Примечание — Как правило, чтобы загрузить вспомогательные регистры, используются команды STM или MVDK. Обе эти команды позволяют следующей команде использовать новое значение в регистре. Другие команды, которые

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

Рисунок 19–37 показывает ARAUs, используемый для генерации адреса в косвенном способе адресации с единственным операндом памяти данных. Как показано на рисунке, основные компоненты, используемые для генерации адресов в косвенной адресации – арифметические модули вспомогательных регистров (ARAU0 и ARAU1) и сами вспомогательные регистры (AR0-AR7).



Рисунок 19–37 – Блок-схема косвенной адресации для операнда памяти данных одиночного доступа

#### Модификация адреса единственного операнда

Вы можете изменить адреса, которые Вы используете в командах прежде или после того, как к ним обратились, или Вы можете оставить их неизменными. Вы можете изменить их, инкрементируя или декрементируя адрес на единицу, добавляя 16-разрядное смещение или индексируя со значением в AR0. Эти три типа действий, предпринятые до или после доступа, плюс способы оставляющие адрес неизменным дают в общей сложности 16 типов адресации, которые определяются значением поля МОD, 4-битовым полем в коде команды, использующем косвенную адресацию.

Таблица 19-6 дает список типов адресации одного операнда памяти данных, в соответствии со значением поля MD, синтаксис ассемблера и выполняемые действия для каждого типа.

|         | 400    | _      | •                  |
|---------|--------|--------|--------------------|
| Таблица | 19-6 - | Типы к | освенной адресации |

| Поле<br>MOD | Синтаксис<br>операнда | Функция                    | Описание                                     |  |  |  |  |  |
|-------------|-----------------------|----------------------------|----------------------------------------------|--|--|--|--|--|
| 0000 (0)    | *ARx                  | addr = ARx                 | ARx содержит адрес памяти данных             |  |  |  |  |  |
| 0001 (1)    | *ARx-                 | addr = ARx<br>ARx = ARx -1 | После доступа адрес в ARx декрементируется ‡ |  |  |  |  |  |

| Поле<br>MOD | Синтаксис<br>операнда | Функция                                       | Описание                                                                                                                                                                            |
|-------------|-----------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0010 (2)    | *ARx+                 | addr = ARx<br>ARx = ARx +1                    | После доступа адрес в ARx инкрементируется ‡                                                                                                                                        |
| 0011 (3)    | *+ARx                 | addr = ARx + 1<br>ARx = ARx + 1               | Адрес в ARх инкрементируется перед его использованием ‡§#                                                                                                                           |
| 0100 (4)    | *ARx-0B               | addr = ARx<br>ARx = B(ARx –AR0)               | После доступа AR0 вычитается из ARx с реверсным распространением переноса                                                                                                           |
| 0101 (5)    | *ARx-0                | addr = ARx<br>ARx = ARx – AR0                 | После доступа AR0 вычитается из ARx                                                                                                                                                 |
| 0110 (6)    | *ARx+0                | addr = ARx<br>ARx = ARx + AR0                 | После доступа AR0 прибавляется к<br>ARx                                                                                                                                             |
| 0111 (7)    | *ARx+0B               | addr = ARx<br>ARx = B(ARx + AR0)              | После доступа AR0 прибавляется к ARx с реверсным распространением переноса                                                                                                          |
| 1000 (8)    | *ARx-%                | addr = ARx<br>ARx = circ(ARx - 1)             | После доступа адрес в ARx декрементируется с циклической адресацией ‡                                                                                                               |
| 1001 (9)    | *ARx-0%               | addr = ARx<br>ARx = circ(ARx - AR0)           | После доступа AR0 вычитается из ARx с циклической адресацией                                                                                                                        |
| 1010 (10)   | *ARx+%                | addr = ARx<br>ARx = circ(ARx + 1)             | После доступа адрес в ARx инкрементируется с циклической адресацией ‡                                                                                                               |
| 1011 (11)   | *ARx+0%               | addr = ARx<br>ARx = circ(ARx + AR0)           | После доступа, AR0 складывается с ARx (циклическая адресация)                                                                                                                       |
| 1100 (12)   | *ARx(lk)              | addr = ARx + Ik<br>ARx = ARx                  | Сумма ARx и 16-битового длинного смещения используется для доступа к памяти данных. ARx не изменяется.                                                                              |
| 1101 (13)   | *+ARx(lk)             | addr = ARx + lk<br>ARx = ARx + lk             | Адрес в ARх инкрементируется перед его использованием и складывается с 16-битовым знаковым длинным смещением. Результат затем используется для доступа к памяти данных.§            |
| 1110 (14)   | *+ARx(lk)%            | addr = circ(ARx + lk)<br>ARx = circ(ARx + lk) | Адрес в ARх инкрементируется перед его использованием и складывается с 16-битовым знаковым длинным смещением циклически. Результат затем используется для доступа к памяти данных.§ |
| 1111 (15)   | *(lk)                 | addr = lk                                     | Беззнаковое 16 битное длинное смещение используется как абсолютный адрес памяти данных.§¶                                                                                           |

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

- † ARх используется как адрес памяти данных, если не указано особо;
- ‡ Значение инкрементируемого и декрементируемого значения равно 1 для 16 битовых адресуемых слов и 2 для 32 битовых;
  - § Эта мода невозможна для регистров, отображаемых в памяти;
  - ¶ Эта мода подробнее обсуждается далее;
  - # Эта мода позволяет осуществить доступ только для записи.

Инкрементная и декрементная адресация (MOD = 0, 1, 2, или 3)

Во время использования AR вы можете изменить его значение, инкрементируя или декрементируя его.

Синтаксис использования AR без модификации, последующего декремента или инкремента, предварительного инкремента показан в таблице для MOD = 0, 1, 2, и 3, соответственно.

Предварительный инкремент (\* +ARx) поддержан только в командах, которые обращаются к операндам в операции записи

### Адресация по смещению (MD = 12 или 13)

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

Этот тип адресации полезен при доступе к определенному элементу массива или структуры, особенно когда вспомогательный регистр не обновляется. Когда вспомогательный регистр обновляется, этот тип адресации особенно полезен для того, чтобы делать доступ в массиве с фиксированным шагом. Синтаксис для адресации по смещению AR без и с обновлением AR использует смещение так, как показано в таблице при MOD = 12 и 13, соответственно.

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

- 1) Команда использующая адресацию по смещению не может быть повторена, используя повторение единственной команды.
- 2) Предварительная модификация 16-разрядным словом смещения (\* +ARx (lk)) использует дополнительный цикл, потому что код команды имеет два или три слова. Последнее слово смещение.

### Индексная адресация (MD = 5 или 6)

Индексная адресация – тип косвенной адресации, в которой содержание AR0 складывается или вычитается из любого другого вспомогательного регистра ARx. Индексная адресация отличается от адресации по смещению тем, что индекс или размер шага могут быть определены во время выполнения программы. Поскольку индекс определяется во время выполнения программы, Вы можете легко внести изменения в размер шага. Индексная адресация также имеет преимущество перед адресацией по смещению – это не требует дополнительного слова команды. Синтаксис для этой адресации смотри в таблице для MD = 5 и 6, соответственно.

### <u>Циклическая адресация (MD = 8, 9, 10, 11, или 14)</u>

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

Регистр размера циклического буфера (ВК) определяет размер кругового буфера. Круговой буфер размера R должен начаться на N-битовой границе (то есть,

младшие разряды базового адреса N кругового буфера должны быть нулевыми), где N — наименьшее целое число, которое удовлетворяет условию  $2^N$ > R. Значение R должно быть загружено в BK. Например, круговой буфер с 31 словами должен начаться в адресе, пять младших битов которого — 0 (то есть, XXXX XXXX XXXX 00002), и значение 31 должно быть загружено в BK. Как второй пример, круговой буфер с 32 словами должен начаться в адресе, шесть младших битов которого — 0 (то есть, XXXX XXXX XX00 00002), и значение 32 должно быть загружено в BK. В некоторых приложениях, однако, может быть возможно использование битреверсивной адресации, размещением  $2^N$  буфера на  $2^N$  границе и реализацией круговой адресации.

Эффективный базовый адрес (EFB-effective base address) кругового буфера определяется обнулением младших N бит выбраного пользователем вспомогательного регистра (ARx). Конец адреса кругового буфера (EOB-end of buffer address) определяется заменой младших N бит ARx младшими N битами BK. Индекс кругового буфера – просто младшие биты N ARx, и шаг – количество, добавляемое или вычтаемое из вспомогательного регистра. Следуйте следующим трем правилам, когда Вы используете круговую адресацию:

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

Круговая адресация может использоваться как для единственного операнда памяти данных так и двух операндов памяти данных. Когда в ВК нулевое значение, циклической модификации адреса не происходит. Это особенно полезно, когда двойной операнд должен выполнить модификацию адреса, эквивалентную ARx+0.

0 иллюстрирует отношения между BK, вспомогательным регистром (ARx), началом кругового буфера, его вершиной и индекса в циклическом буфере.

0 показывает, как круговой буфер реализуется и каковы отношения между сгенерированными значениями и элементами в циклическом буфере.



Рисунок 19-38 - Блок-схема циклической адресации



Рисунок 19-39 - Осуществление работы циклического буфера

Циклическая адресация типично использует декремент или инкремент на единицу (MD = 8 и 10) или декремент или приращение на величину индекса (MD = 9 и 11). Предварительная модификация 16-разрядным словом смещения (\* +ARx (lk) %) требует дополнительного кодового слова так, что код команды имеет два или три слова. Последнее слово — смещение. Команда, используя косвенную адресацию по смещению не может быть повторена, с использованием единственной повторяемой операции.

Синтаксис для каждого из пяти типов круговой адресации показан в таблице для MD = 8, 9, 10, 11 и 14.

## <u>Бит-реверсивная адресация (MD = 4 или 7)</u>

Бит-реверсная адресация увеличивает скорость выполнения и память программы для алгоритмов быстрого преобразования Фурье (FFT), которые используют разные основания системы счисления. В этом способе адресации, AR0 определяет одну половину длины последовательности FFT. содержавшееся в AR0 должно быть равным 2<sup>N-1</sup>, где N – целое число, и размер FFT – 2<sup>N</sup>. Вспомогательный регистр указывает на физическое местоположение значения данных. Когда Вы складываете AR0 с вспомогательным регистром, используя битреверсную адресацию, адрес генерируется бит-реверсным способом, с битом переноса, распространяющимся слева-направо, вместо нормального способа справаналево. Синтаксис для каждого из двух режимов бит-реверсной адресации показан в таблице для MD 4 и 7, соответственно. Предположим, что вспомогательные регистры длиной в восемь бит, что AR2 представляет базовый адрес данных в памяти и что AR0 содержит значение 00001000<sub>2</sub>. Ниже  $(01100000_2)$ , приведена последовательность модификаций AR2 и получающихся значений AR2.

Последовательность изменений вспомогательных регистров в адресации с инвертированием разрядов

| *AR2+0B | ;AR2 = | 0110 0000 | (0th           | значение) |
|---------|--------|-----------|----------------|-----------|
| *AR2+0B | ;AR2 = | 0110 1000 | (1st           | значение) |
| *AR2+0B | ;AR2 = | 0110 0100 | (2nd           | значение) |
| *AR2+0B | ;AR2 = | 0110 1100 | (3rd           | значение) |
| *AR2+0B | ;AR2 = | 0110 0010 | (4th           | значение) |
| *AR2+0B | ;AR2 = | 0110 1010 | (5th           | значение) |
| *AR2+0B | ;AR2 = | 0110 0110 | (6th           | значение) |
| *AR2+0B | ;AR2 = | 0110 1110 | (7th значение) | •         |

Таблица 19-7 показывает соотношение битовой комбинации четырех младших бита AR2 в шаговой индексации и при использовании бит-реверсной адресации.

Таблица 19-7 - Адресация с инвертированием разрядов

| Шаг | Конфигурация бит | Конфигурация<br>инвертированных<br>бит | Шаг<br>инвертированных<br>бит |  |  |  |
|-----|------------------|----------------------------------------|-------------------------------|--|--|--|
| 0   | 0000             | 0000                                   | 0                             |  |  |  |
| 1   | 0001             | 1000                                   | 8                             |  |  |  |
| 2   | 0010             | 0100                                   | 4                             |  |  |  |
| 3   | 0011             | 1100                                   | 12                            |  |  |  |
| 4   | 0100             | 0010                                   | 2                             |  |  |  |
| 5   | 0101             | 1010                                   | 10                            |  |  |  |
| 6   | 0110             | 0110                                   | 6                             |  |  |  |
| 7   | 0111             | 1110                                   | 14                            |  |  |  |
| 8   | 1000             | 0001                                   | 1                             |  |  |  |
| 9   | 1001             | 1001                                   | 9                             |  |  |  |
| 10  | 1010             | 0101                                   | 5                             |  |  |  |
| 11  | 1011             | 1101                                   | 13                            |  |  |  |
| 12  | 1100             | 0011                                   | 3                             |  |  |  |
| 13  | 1101             | 1011                                   | 11                            |  |  |  |
| 14  | 1110             | 0111                                   | 7                             |  |  |  |
| 15  | 1111             | 1111                                   | 15                            |  |  |  |

### Адресация двойного операнда

Двойная адресация операнда памяти данных используется для команд, которые выполняют два чтения или единственное чтение и параллельно запись (обозначенный двумя вертикальными чертами, ||) в то же самое время. Эти команды – все длиной в одно слово и работают только в косвенном способе адресации. Два операнда памяти данных представлены Xmem и Ymem:

- Хтет операнд чтения с доступом через шину D. Команды записи, например STH и STL с операцией сдвига, изменяют Хтет на операнд записи.
- Ymem используется как операнд чтения в командах с двойным чтением (доступ через шину С) или как операнд записи в командах с параллельным сохранением (доступ через шину Е).

Если операнд источника и операнд приемника указывают на то же самое место, в командах с параллельной записью(например, ST|| LD), источник читается перед записью. Если команда двойного операнда (например, ADD), указывает на тот же самый вспомогательный регистр с различными способами адресации, определенными для обоих операндов, для адресации используется режим, определенный Xmod.

Рисунок 19–40 показывает формат косвенной адресации команды с двойным операндом памяти данных.

Таблица 19-8 описывает биты команды.

Поскольку только два бита доступны для выбора каждого вспомогательного регистра в этом режиме, только четыре из вспомогательных регистров могут использоваться, AR2 – AR5. Таблица 19-9 показывает, какие Xar и Yar выбираются в качестве вспомогательных регистров.

| 15-8         | 7 | 6  | 5  | 4  | 3  | 2   | 1 | 0  |
|--------------|---|----|----|----|----|-----|---|----|
| Код операции |   | od | Xa | ar | Ym | nod | Y | ar |

Рисунок 19–40 – Формат команды косвенной адресации для операндов памяти данных двойного доступа

Таблица 19-8 – Краткое описание битов команды адресации двойного операнда

| Биты | Имя    | Функция                                                                               |
|------|--------|---------------------------------------------------------------------------------------|
| 15-8 | Opcode | Это 8 разрядное поле содержит код операции команды                                    |
| 7-6  | Xmod   | Это 2-х разрядное поле определяет тип косвенной адресации для доступа к Xmem операнду |
| 5-4  | Xar    | Двухразрядное поле определяет вспомогательный регистр, который содержит адрес Xmem    |
| 3-2  | Ymod   | Это 2-х разрядное поле определяет тип косвенной адресации для доступа к Ymem операнду |
| 1-0  | Yar    | Двухразрядное поле определяет вспомогательный регистр, который содержит адрес Ymem    |

Таблица 19-9 – Выбор вспомогательных регистров

| Xar или Yar | Вспомогательный регистр |
|-------------|-------------------------|
| 00          | AR2                     |
| 01          | AR3                     |

| 10 | AR4 |
|----|-----|
| 11 | AR5 |

Рисунок 19–41 показывает, как при генерации адреса используется двойная адресация памяти данных.

Адресация двойного операнда памяти данных использует четыре вспомогательных регистра (AR2-AR5). ARAUs совместно с этими регистрами, обеспечивают возможность обратиться к двум операндам в единственном цикле.



Рисунок 19–41 – Блок схема косвенной адресации для операндов памяти данных двойного доступа

Таблица 19-10 перечисляет типы двойной адресации операнда памяти данных, наряду со значением поля модификации (Xmod или Ymod), синтаксисом ассемблера и функцией для каждого типа.

Таблица 19-10 – Косвенная адресация с двойным операндом памяти данных

| Xmod или<br>Ymod | Синтаксис<br>операнда | Функция               | Описание†                      |
|------------------|-----------------------|-----------------------|--------------------------------|
| 00               | *ARx                  | addr = ARx            | ARх является адресом памяти    |
|                  |                       |                       | данных                         |
| 01               | *ARx-                 | addr = ARx            | После доступа адрес ARx        |
|                  |                       | ARx = ARx - 1         | декрементируется               |
| 10               | *ARx+                 | addr = ARx            | После доступа адрес ARx        |
|                  |                       | ARx = ARx + 1         | инкрементируется               |
| 11               | *ARx+0%               | addr = ARx            | После доступа AR0 складывается |
|                  |                       | ARx = circ(ARx + AR0) | с ARx циклически‡              |

†ARх используется как адрес памяти данных, если не указан другой способ действия

‡Размер циклического буфера определён в регистре размера ВК

В каждом случае, содержание вспомогательного регистра используется как операнд памяти данных. После использования адреса во вспомогательном регистре, ARAUs выполняют указанную математическую операцию. Отключая круговые модификации адреса, можно выполнить индексную адресацию или эквивалентно \*ARx+0. Очистка ВК отключает циклическую адресацию.

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

#### Инкремент и декремент адреса для двойного операнда (Xmod или Ymod = 0, 1 или 2)

Вы можете изменить AR, увеличиваясь или уменьшая его значение. Когда Xmod или Ymod = 0, ARх используется как адрес памяти данных без инкрементирования или декрементирования. Когда Xmod или Ymod = 1, ARх - декрементируется после того, как доступ осуществлён. Когда Xmod или Ymod = 2, ARх увеличивается после доступа.

## Индексная адресация для двойного операнда (Xmod или Ymod = 3 и BK = 0)

Когда Xmod или Ymod = 3 и BK = 0, AR0 склаывается с ARx после каждого доступа. Иначе говоря, индексная адресация двойного операнда точно такая же, как описана в ранее.

### <u>Циклическая адресация для двойного операнда (Xmod или Ymod = 3 и BK =/ 0)</u>

Когда Xmod или Ymod = 3 и BK=/ 0, AR0 складывается с ARх используя циклическую адресацию после каждого доступа. Иначе говоря, циклическая адресация двойного операнда точно такая же, как описана ранее.

#### Команды с одним операндом, которые используют формат двойного операнда

Некоторые команды с одним операндом памяти данных используют адресацию двойных операндов памяти данных так, чтобы они размещались в одном слове для выполнения в одном цикле. В этих командах, доступен только Xmem, и поля Xmod и Xar определяют способ адресации для операнда. Четыре команды с одним операндом могут выполниться в одном цикле:

- BIT Xmem, BITC
- SACCD src, Xmem, cond
- SRCCD Xmem, cond
- STRCD Xmem, cond

Пять инструкций с дополнительным сдвигом также поддерживают этот тип адресации для одного операнда и выполняются в одном цикле.

- ADD Xmem, SHFT, src
- LD Xmem, SHFT, dst
- STH src, SHFT, Xmem
- STL src, SHFT, Xmem
- SUB Xmem, SHFT, src

#### Режим совместимости (аналоги - TMS320C2x/C20x/C24x/C5x) (ARP)

ARP может использоваться в косвенной адресации. Это позволяет определить AR с помощью ARP для простой трансляции кода 'C2x/C20x/C24x/C5x

устройств. С СМРТ = 1 и ARF = 0, ARP используется, чтобы определить, какое AR используется для обращения к памяти. Рисунок 19–42 показывает, как APR индексирует вспомогательные регистры. При использовании ARP, микропроцессор отличается от 'C5-х в том, что когда микропроцессор использует AR, на которое указывает ARP, микропроцессор не обновляет ARP в той же самой командой. Таблица 19-11 показывает синтаксис ассемблера для 'C2x/C20x/C24x/C5x сравнивая его с данным микропроцессором.



Рисунок 19–42 – Формирование индексов вспомогательных регистров протоколом разрешения адреса (ARP протоколом)

Таблица 19-11 – Сравнение синтаксисов ассемблерадля устройств TMS320C2x/C20x/C24x/C5x и '54x

| Синтаксис для<br>'C2x/C20x/C24x/C5x | Синтаксис для '54х | Синтаксис для<br>'C2x/C20x/C24x/C5x | Синтаксис для '54х |
|-------------------------------------|--------------------|-------------------------------------|--------------------|
| *                                   | *AR0               | *0-                                 | *AR0-0             |
| *_                                  | *AR0-              | *0+                                 | *AR0+0             |
| *+                                  | *AR0+              | *BR0-                               | *AR0-0B            |
|                                     |                    | *BR+                                | *AR0+0B            |

Рисунок 19–43 показывает формат команды с косвенным обращением для ARP режима.

| 15-8         | 7     | 6 - 3 | 2 - 0   |
|--------------|-------|-------|---------|
| Код операции | I = 1 | MOD   | ARF=000 |

Рисунок 19–43 – Формат команды косвенной адресации в режиме сравнения Таблица 19-12 описывает биты команды в ARP режиме.

Таблица 19-12 – Инструкции с косвенной адресацией - совместимая мода

| Биты | Имя    | Функция                                                 |  |
|------|--------|---------------------------------------------------------|--|
| 15-8 | Opcode | Это 8-ми битовое поле содержит код операции             |  |
| 7    | I      | При единичном значении используется косвенная адресация |  |
| 6-3  | MOD    | Это 4-х битовое поле определяет тип косвенной адресации |  |

| Биты | Имя | Функция                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     | (см. ранее определение 16-ти путей организации адресации)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2-0  | ARF | Это поле определяет вспомогательный регистр, используемый при адресации. ARF зависит от бита совместимости в статусном регистре 1.  СМРТ=0 — Стандартная мода. В стандартной моде ARF всегда определяет вспомогательный регистр, независимо от значения в ARP (auxiliary register pointer — поле в статусном регистре 0). ARP не изменяется. ARP должен всегда быть устанавлен в нуль, когда DSP в этой моде.  СМРТ=1 — Мода совместимости. В моде совместимости, ARP выбирает вспомогательный регистр, если ARF = 0. В противном случае, ARF выбирает вспомогательный регистр и величина ARF загружается в ARP когда доступ завершен. *ARO в командах ассемблера указывает вспомогательный регистр выбранный с |
|      |     | определяет вспомогательный регистр, независимо от значения в ARP (auxiliary register pointer — поле в статусном регистре 0) ARP не изменяется. ARP должен всегда быть устанавлен в нулькогда DSP в этой моде.  СМРТ=1 — Мода совместимости. В моде совместимости, ARF выбирает вспомогательный регистр, если ARF = 0. В противном случае, ARF выбирает вспомогательный регистр и величина ARF загружается в ARP когда доступ завершен. *AR0 в команда:                                                                                                                                                                                                                                                          |

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

ARP должен всегда быть установлен в 0, когда DSP — в стандартной моде (CMPT = 0).

При сбросе как ARP так и CMPT устанавливаются в 0 принудительно.

### 19.4.6 Адресация регистра отображенного в памяти

Адресация регистра отображенного в памяти используется, чтобы изменить регистры отображенные в памяти, не затрагивая или текущее значение указателя страницы данных (DP) или текущее значение указателя вершины стека (SP). Поскольку DP и SP не должны быть изменены в этом режиме, дополнительные расходы для записи в регистр минимальны. Регистр отображенный в памяти используется как в прямой так и косвенной адресации.

Рисунок 19–44 показывает, как сгенерированы адреса отображенные в памяти. Адреса генерируется посредством:

- Установкой в нуль девяти наиболее значительных битов (MSBs) адреса памяти данных к 0, независимо от текущего значения DP или SP, когда используется прямая адресация.
- Используя семь младших битов текущего значения вспомогательного регистра, когда используется косвенная адресация.

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

Например, если AR1 используется для указания на регистр отображенный в памяти в способе адресации регистров отображенных в памяти, и он содержит значение FF25h, тогда AR1 указывает на регистр периода таймера (PRD), так как семь младших битов AR1 хранят 25 в шестнадцатеричной системе счисления, и адрес PRD как раз и равен 0025h. После выполнения, значение, остающееся в AR1 является 0025h.



Рисунок 19-44 - Блок-схема адресации отображаемого в памяти регистра

Примечание – В дополнение к регистрам, любая сверхоперативная память, расположенная на странице 0 данных может быть изменена при использовании адресации регистра отображенного в памяти.

Только восемь команд могут использовать адресацию регистра с отображенной памятью:

- LDM MMR, dst
- MVDM dmad, MMR
- MVMD MMR, dmad
- MVMM MMRx, MMRy
- POPM MMR
- PSHM MMR
- STLM src, MMR
- STM # lk, MMR

Примечание — Следующие моды косвенной адресации недоступны для адресации регистров отображенных в памяти:

- \*ARx(lk)
- \*+ARx(lk)
- \*+ARx(lk)%
- \*(lk)

В этих случаях ассемблер выдаёт предупреждение.

### 19.4.7 Стековая адресация

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

Четыре команды обращаются к стеку, используя способ стековую адресацию:

- PSHD помещает значение памяти данных в стек;
- PSHM помещает регистр, отображенный в памяти в стек;
- POPD выталкивает значение памяти данных из стека;
- РОРМ выталкивает регистр, отображенный в памяти из стека.

Запись предекрементирует и выталкивание постинкрементирует адрес в SP. Рисунок 19–45 показывает пример состояния стека и SP до и после помещения X2 в стек (PSHD X2).



Рисунок 19-45 - Стек и указатель стека до и после операции записи в стек

Другие действия также влияют на стек и указатель стека. Стек используется в течение прерываний и вызова подпрограмм, чтобы сохранять и восстанавливать содержание РС. Когда произошел вызов подпрограмма или возникло прерывание, адрес возврата автоматически сохраняется в стеке, используя вталкивание в вершину. Инструкции использующие вызов подпрограмм и прерывания — CALA[D], CALL[D], CC[D], INTR, и TRAP.

Когда происходит возврат из подпрограммы, адрес возврата извлекается из стека, используя действие выталкивания и загружается в РС. Инструкции использующие возврат из подпрограмм - RET[D], RETE[D], RETEF[D], и RC[D].

Инструкция FRAME также влияет на стек. Эта инструкция добавляет короткий непосредственный операнд сдвига к указателю стека. Стек также используется в прямой адресации со ссылкой на SP (смотри ранее).

#### 19.4.8 Типы Данных

Есть два основных типа данных для доступа к памяти в микропроцессоре: 16-бит и 32-бит. Большинство инструкций могут иметь доступ к 16-битовым данным. Доступ к 32-битовые данным, тем не менее, требует использование специальных инструкций, которые указаны в Таблица 19-13.

| Таблица 19-13 – | Инструкции, оперирующи | <b>ве с 32-битовыми словами</b> |
|-----------------|------------------------|---------------------------------|
|-----------------|------------------------|---------------------------------|

| Команда | Описание                                                             |
|---------|----------------------------------------------------------------------|
| DADD    | Сложение двойной точности/двойное 16-битное сложение с аккумулятором |
| DADST   | Загрузка двойной точности и сложение или вычитание с Т               |
| DLD     | Загрузка длинного числа в аккумулятор                                |
| DRSUB   | Вычитание двойной точности из длинного числа                         |
| DSADT   | Загрузка длинного числа и сложение или вычитание с Т                 |
| DST     | Запись аккумулятора как длинного слова                               |
| DSUB    | Вычитание числа двойной точности из аккумулятора                     |
| DSUBT   | Вычитание числа двойной точности из Т                                |

Для доступа к 16-битовому операнду, 16-битовое слово читается из памяти данных через шину D и записывается в память данных через шину E. Для доступа к 32-битовому операнду, шина C (для старшей части слова) и шина D (для младшей части слова) используются для чтения совместно. Тем не менее, поскольку только шина E используется для записи, операция записи (инструкция DST) выполняется в два цикла.

При доступе к 32-битовым словам, первое доступное слово рассматривается как наиболее значимое (старшая часть – MSW), тогда как второе доступное слово как младшая часть (LSW). Если исходный адрес доступа четный, то затем следует доступ ко второму слову – по нечётному адресу( большему на 1). Если сначала доступ по нечетному адресу, то затем доступ ко второму слову будет по меньшему чётному адресу. Рисунок 19–46 показывает этот эффект.



Рисунок 19-46 - Порядок слов в памяти

### 19.5 Адресация программ

В этой главе обсуждается, как генерируются адреса программной памяти, и какие адреса загружаются в счетчик команд (PC). Эта глава также описывает действия по управлению выполнением программ, которые влияют на загрузки в PC:

- Переходы;
- Вызовы подпрограмм;
- Возвраты из подпрограмм;
- Условные операции.
- Повторение инструкций или группы инструкций;
- Сброс аппаратуры;
- Прерывания.

Эти действия могут возникнуть в произвольной последовательности и произвести загрузку РС.

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

Мода выключения питания останавливает выполнение программ.

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

При сбросе устройства, вектора сброса, прерывания и ловушек отображаются к адресам FF80h в пространстве программы. Однако, эти векторы могут быть повторно отображены к началу любой страницы с 128 словами в пространстве программы после сброса устройства. Это делается загрузкой указателя вектора прерывания (IPTR) в регистр PMST с соответствующим адресом границы страницы в 128 слов. После загрузки IPTR любой вектор пользовательского прерывания или ловушки отображается к новой странице в 128 слов. Например:

STM #05800h, PMST; Повторно отображение векторов, начиная с 5800 адреса.

Этот пример перемещения векторов прерывания в пространство программ с 05800-ого адреса. Любое последующее прерывание (за исключением сброса устройства) выбирает его вектор прерывания от этого нового местоположения. Например, если, после загрузки IPTR, возникает INT2, вектор программы обработки прерывания выбирается, начиная с адреса 5848 в пространстве программы в FFC8h. Эта противоположность местоположению особенность перемещение необходимых векторов из аппаратного загрузчика и затем удаления ПЗУ из карты памяти. Как только системный код загружен в систему от резидентного загрузчика в ПЗУ, приложение перезагружает IPTR значения, указывая на новые вектора. В предыдущем примере, команда STM используется, чтобы изменить PMST. Отметим, что команда STM изменяет не только IPTR, но и другие биты состояния в регистре PMST.

В случае сброса ядра DSP-средствами бит RST\_DSP или RST\_DSP\_CPU регистр IPTR загружается значением 0xFFFF. Вектор сброса всегда выбирается с адреса FF80h в пространстве памяти программ. Кроме того, для микропроцессора, 128 слов зарезервированы в ПЗУ на кристалле в целях тестирования. Прикладной

код, написанный для реализации на ПЗУ в кристалле должен резервировать эти 128 слов в адресах FF00h-FF7Fh в пространстве программы.

### 19.5.1 Генерация адреса программной памяти

Программная память содержит коды приложений, таблицы коэффициентов и непосредственные операнды. Микропроцессор может адресовать до 64K слов программной памяти, используя шину адресов программы (PAB).

Логика генерации программного адреса (PAGEN) генерирует адрес, используемый для доступа к инструкциям, таблицам коэффициентов, 16-битовые непосредственным операндам или любой другой информации загружаемой в программную память и устанавливает этот адрес на шине PAB.

PAGEN состоит из пяти регистров (см. Рисунок 19–47):

- счетчик программы (PC-programm counter);
- счетчик повторения (RC-repeat counter);
- счетчик повторения блоков (BRC-block-repeat counter);
- регистр стартового адреса повторения блока (RSA-block-repeat start address register);
- регистр конечного адреса повторения блока (REA-block-repeat end address register).



Рисунок 19–47 – Регистры логической схемы генерации адреса программ

Микропроцессор выбирает инструкции, устанавливая величину РС на РАВ и читая соответствующее место в памяти. Когда команда прочитана из памяти, РС инкрементируется для следующей выборки. Если происходит прерывание, программы (например, переход, вызов подпрограммы, возврат из подпрограммы, прерывание или блочное повторение), соответствующий адрес загружается в РС. Инструкция, адресованная через РАВ – затем загружается в регистр инструкции (IR).

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

Некоторые инструкции, как например, FIRS, MACD, и MACP, используют программную шину, чтобы выбирать второй сомножитель.

### 19.5.2 Программный Счетчик (РС)

PC — 16-битный регистр, который содержит адрес внутренний или внешний программной памяти используемый, когда выбирается инструкция или когда 16-битовый непосредственный операнд или коэффициент таблицы доступен в программной памяти. Для адресации программной памяти адрес из PC помещается на PAB.

PC может быть установлен несколькими способами. Таблица 19-14 показывает, что загрузка в PC зависит от того, какое действие выполняется.

| Таблица 1 | 9-14 – | Загрузка | адреса | В | P | C |
|-----------|--------|----------|--------|---|---|---|
|-----------|--------|----------|--------|---|---|---|

| Операция                                                        | Адрес, загружаемый в РС                                                                                                                                                                                              |  |  |
|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Сброс                                                           | PC загружается кодом FF80h                                                                                                                                                                                           |  |  |
| Последовательное<br>выполнение                                  | РС загружается значением РС + 1                                                                                                                                                                                      |  |  |
| Переход                                                         | PC загружается 16-битным непосредственным значением следующим за инструкцией                                                                                                                                         |  |  |
| Переход из аккумулятора                                         | РС загружается младшими 16-ти битами аккумулятора<br>А или В                                                                                                                                                         |  |  |
| Цикл повторения блока                                           | PC загружается начальным адресом повторения(RSA), когда PC+1 эквивалентно конечному адресу повторения (REA), при условии того, что BRAF = 1                                                                          |  |  |
| Вызов подпрограммы                                              | РС+2 заталкивается в стек, РС загружается 16 битным операндом, непосредственно следующим после инструкции. Инструкция возврата выталкивает вершину стека обратно на РС для возврата к прерванной последовательности. |  |  |
| Вызов подпрограммы из<br>аккумулятора                           | РС+1 вталкивается в стек, РС загружается младшими 16 битами аккумулятора А или В. Инструкция возврата выталкивает вершину стека обратно на РС для возврата к прерванной последовательности.                          |  |  |
| Аппаратное прерывание,<br>программное прерывание<br>или ловушка | PC+1 вталкивается в стек, PC загружается адресом соответствующим вектору ловушки. Инструкция возврата выталкивает вершину стека обратно на PC для возврата к прерванной последовательности.                          |  |  |

### 19.5.3 Ветвления

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

#### Безусловные переходы

Безусловный переход всегда выполняется, когда он возник. Во время выполнения, РС загружается определённым адресом программной памяти, и выполнение новой секции кода начинается с этого адреса. Адресом, загружаемым в

PC, является второе слово инструкции перехода или младшие 16 бит аккумулятора (аккумулятор A или аккумулятор B).

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

- Не задержанный: Два слова инструкции удаляются из конвейера, чтобы они не были выполнены, и затем выполнение передается по адресу перехода.
- Задержанный: Одна 2-х словная инструкция или две однословные инструкции, следующих за инструкцией перехода выполняются. Это позволяет Вам избегать опустошения конвейера, который требует дополнительных циклов.

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

Таблица 19-15 показывает безусловные инструкции перехода в микропроцессоре и количестве циклов необходимых для выполнения этих инструкций (как не задержанных, так и задержанных). Задержанные инструкции используют на два цикла меньше, чем соответствующие не задержанные инструкции, поскольку они не сбрасывают конвейер.

| Таблица 19-15 – Безусловный переход | 1 |
|-------------------------------------|---|
|-------------------------------------|---|

| Команда | Описание                                                                 | Число циклов<br>Не задерж./задерж. |
|---------|--------------------------------------------------------------------------|------------------------------------|
| B[D]    | Загрузка РС адресом,<br>определенным инструкцией                         | 4/2                                |
| BACC[D] | Загрузка РС адресом, определяемым 16-тью младшими разрядами аккумулятора | 6/4                                |

### Условные переходы

Условные переходы выполняются подобно безусловным переходам, но они выполняются только тогда, когда одно или более определенных программистом условий выполнены. Возможные условия даны в Таблица 19-16. Если все условия выполнены, РС загружается вторым словом инструкции перехода, которая содержит адрес перехода и выполнение продолжается с этого адреса.

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

- Не задержанный: Если все условия выполнены, эти два слова инструкции удаляются из конвейера и выполнение передаётся на адрес перехода. Если условия не выполнены, два слова инструкции выполняются вместо перехода.
- Задержанный: Одна 2-словная инструкция или две 1-словные инструкции, следующих за инструкцией перехода выполняются. Это позволяет Вам избежать сброса конвейера, что требует дополнительных циклов. Тестируемые условия не оказывают влияния на инструкции, следующие за задержанным переходом.

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

Таблица 19-16 показывает условные инструкции перехода и количество циклов необходимых для выполнения этих инструкций. Поскольку условные переходы используют условия, определяемые выполнением предшествующих инструкций, условная инструкция перехода, BC[D], требует на один цикл больше, чем безусловный переход.

Таблица 19-16 – Команды условного перехода

| Инструкция | Описание                                                                                                                                          | Количество циклов<br>Условие выполнено/не<br>выполнено |             |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-------------|
|            |                                                                                                                                                   | Не Задержанная                                         | Задержанная |
| BC[D]      | Загрузка РС адресом, определенным инструкцией, если условие, определённое в команде, выполнено                                                    | 5/3                                                    | 3/3         |
| BANZ[D]    | Загрузка PC адресом, определенным командой, если текущее значение вспомогательного регистра не эквивалентно нулю (полезно для организации циклов) | 4/2                                                    | 2/2         |

Таблица 19-17 – Команды длинных переходов

| Команды  | Описание                                                                            | Количество циклов<br>Не задержанная /<br>Задержанная |
|----------|-------------------------------------------------------------------------------------|------------------------------------------------------|
| FB[D]    | Загрузка РС и ХРС адресом, определённым в инструкции                                | 4/2                                                  |
| FBACC[D] | Загрузка РС и ХРС адресом, определённым в 23 разрядах соответствующего аккумулятора | 6/4                                                  |

# 19.5.4 Вызов процедур

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

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

#### Безусловные вызовы процедур

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

Когда безусловная инструкция вызова достигает фазы выполнения в конвейере, следующие два слова инструкции уже выбраны. То, как эти два слова инструкции будут использованы, зависит частично от того, задержанный или нет вызов процедуры:

- Не задержанный: Два слова инструкции удаляются из конвейера, чтобы они не были выполнены, адрес возврата сохраняется в стеке и затем выполнение продолжается с начала вызванной функции.
- Задержанный: Одна 2-словная или две 1-словные инструкции, следующих за инструкцией вызова выполняются. Это позволяет избежать сброса конвейера, что требует дополнительных циклов.

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

Таблица 19-18 показывает безусловные инструкции вызова процедур в микропроцессоре (как не задержанных так и задержанных) и количество циклов необходимых для выполнения этих инструкций.

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

| Таблица 19-18 – К | Команды безуслов | ного перехода |
|-------------------|------------------|---------------|
|-------------------|------------------|---------------|

| Команда | Описание                                                                                                                | Количество<br>циклов<br>выполнения.<br>Не задерж./задерж. |
|---------|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| CALL[D] | В стеке размещается адрес возврата и затем в РС загружается адрес, определённый в инструкции                            | 4/2                                                       |
| CALA[D] | В стеке размещается адрес возврата и затем в РС загружается адрес, определённый значением соответствующего аккумулятора | 6/4                                                       |

#### Условные вызовы

Условные вызовы действуют подобно безусловным вызовам, но они выполняют только когда один или многочисленные условия выполнены. Возможные условия даны в Таблица 19-19. Если все условия выполнены, РС загружается вторым словом инструкции вызова, который содержит стартовый адрес вызываемой функции. Перед переходом в указанную функцию, процессор сохраняет адрес инструкции, следующей за инструкцией вызова в стеке.

Функция должна закончиться вызовом инструкции, адрес которой берется из стека и загружается в РС, позволяя процессору продолжать выполнение прерванной программы.

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

- Не задержанный: Если все условия выполнены, эти два слова инструкции удаляются из конвейера чтобы не быть выполненными, и затем управление передаётся в начало вызванной функции. Если условия не выполнены, эти две инструкции выполняются вместо вызова.
- Задержанный: одна 2-словная или две 1-словные инструкции, следующие за инструкцией вызова всегда выполняются. Это позволяет избежать сброса конвейера, что требует дополнительных циклов. Условия тестирования не оказывают влияния на инструкциями, следующие за задержанным вызовом. Если условия не выполнены, процессор выполняет эти два слова инструкции вместо вызова.

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

Таблица 19-19 показывает команду условного вызова и количество циклов необходимых на его выполнение. Поскольку есть цикл ожидания для установления условий, условная инструкция вызова, CC[D], требует на один цикл больше, чем безусловный вызов.

|         |                                    | Количеств   | о циклов           |
|---------|------------------------------------|-------------|--------------------|
| Команда | Описание                           | He          | Задержанная        |
|         |                                    | задержанная | <b>Задержаппая</b> |
|         | Размещает адрес возврата в стеке и |             |                    |
|         | затем загружает в РС адрес         |             |                    |
| CC[D]   | определённый в инструкции, если    | 5/3         | 3/3                |
|         | условия обозначенные в команде     |             |                    |

Таблица 19-19 – Условные вызовы

# 19.5.5 Возвраты

выполнены.

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

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

#### Безусловный возврат

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

Когда безусловная инструкция возврата достигает фазу выполнения в конвейере, следующие два слова инструкции уже выбраны. То, как эти два слова инструкции используются, будет зависеть частично от того, не задержанная или задержанная инструкция возврата:

- Не задержанная: Два слова инструкции удаляются из конвейера, чтобы они не были выполнены, адрес возврата взят из стека, и затем выполнение продолжается с этого адреса.
- Задержанная: одна 2-словная или две 1-словные инструкции, следующие за инструкцией возврата выполняются. Это позволяет избежать сброса конвейера, что требует дополнительных циклов. Адрес возврата берётся из стека.

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

Таблица 19-20 показывает безусловные инструкции возврата в микропроцессоре (не задержанные и задержанные) и количество нужных циклов для выполнения этих инструкций. Задержанным инструкциям нужно на два цикла меньше, чем соответствующим не задержанным инструкциям.

| Таблица 19-20 – Ин | іструкции бе: | зусповного | возврата |
|--------------------|---------------|------------|----------|
|--------------------|---------------|------------|----------|

| Инструкция | Описание                                                                          | Количество<br>циклов<br>Не<br>задерж./Задерж. |
|------------|-----------------------------------------------------------------------------------|-----------------------------------------------|
| RET[D]     | Загрузка РС адресом возврата с верхушки стека                                     | 5/3                                           |
| RETE[D]    | Загрузка РС адресом возврата с верхушки стека и разрешение маскируемых прерываний | 5/3                                           |
| RETF[D]    | Загрузка РС адресом возврата из RTN регистра и разрешение маскируемых прерываний  | 3/1                                           |

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

#### Условные возвраты

Используя инструкцию условного возврата (RC-conditional return), Вы можете дать функции или программе обработки прерывания (ISR- interrupt service routine) более чем один из возможных путей возврата. Путь выбора зависит от обрабатываемых данных. Кроме того, Вы можете использовать условный возврат, чтобы избежать условного перехода на инструкцию возврата в конце функции или программы обработки прерывания.

Условные возвраты действуют подобно безусловным возвратам, но они выполняют только тогда, когда одно или более условий выполнены. Возможные

условия даны в Таблица 19-21. Если все условия выполнены, процессор загружает адрес возврата из стека в РС и продолжает выполнение прерванной программы.

Условный возврат является однословной инструкцией; тем не менее, из-за возможности прерывания последовательности значений PC, он выполняется с тем же эффективным временем, что и условный переход или вызов программы.

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

- Не задержанный: Если все условия выполнены, эти два слова инструкции удаляются из конвейера, чтобы они не выполнялись, и тогда остаётся только выполнение вызова прерванной программы. Если условия не выполнены, две инструкции выполняются вместо возврата.
- Задержанный: Процессор выполняет две инструкции, которые следуют за инструкцией возврата. Это позволяет избежать сброса конвейера, что требует дополнительных циклов. Значения тестируемых условий не влияют на инструкции, следующие за задержанным возвратом.

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

Таблица 19-21 показывает условную инструкцию возврата и количество циклов необходимых для выполнения этой инструкции.

| Таблица 19-21 - | - Команды у | <b>УСЛОВНОГО</b> | возврата |
|-----------------|-------------|------------------|----------|
|-----------------|-------------|------------------|----------|

| Инструкция | Описание                                                                                        | Количество<br>Условия вып<br>не выпол | олнились /  |
|------------|-------------------------------------------------------------------------------------------------|---------------------------------------|-------------|
|            |                                                                                                 | Не задержанный                        | Задержанный |
| RC[D]      | РС загружается адресом возврата из вершины стека, если условия определённые в команде выполнены | 5/3                                   | 3/3         |

### 19.5.6 Условные операции

Микропроцессор включает инструкции, которые выполняются только тогда, когда одно или более условий выполнены. Таблица 19-22 перечисляет условия, которые Вы можете использовать с этими инструкциями и соответствующие символы операнда.

Таблица 19-22 – Условия для условных операций

| Условие | Описание                    | Операнд |
|---------|-----------------------------|---------|
| A = 0   | Аккумулятор А равен нулю    | AEQ     |
| B = 0   | Аккумулятор В равен нулю    | BEQ     |
| A ≠ 0   | Аккумулятор А не равен нулю | ANEQ    |
| B ≠ 0   | Аккумулятор В не равен нулю | BNEQ    |
| A < 0   | Аккумулятор А меньше нуля   | ALT     |

| _                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Аккумулятор В меньше нуля           | BLT                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Аккумулятор А меньше или равен нулю | ALEQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Аккумулятор В меньше или равен нулю | BLEQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Аккумулятор А больше нуля           | AGT                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Аккумулятор В больше нуля           | BGT                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Аккумулятор А больше или равен нулю | AGEQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Аккумулятор В больше или равен нулю | BGEQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Аккумулятор А переполнен            | AOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Аккумулятор В переполнен            | BOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Аккумулятор А не переполнен         | ANOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Аккумулятор В не переполнен         | BNOV                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Бит переноса С равен единице        | С                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Бит переноса С равен нулю           | NC                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Флаг тест/управление равен единице  | TC                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Флаг тест/управление равен нулю     | NTC                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| BIO\ сигнал в низком состоянии      | BIO                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| BIO\ сигнал в высоком состоянии     | NBIO                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Безусловная операция                | UNC                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                     | Аккумулятор А меньше или равен нулю Аккумулятор В меньше или равен нулю Аккумулятор А больше нуля Аккумулятор В больше нуля Аккумулятор А больше или равен нулю Аккумулятор В больше или равен нулю Аккумулятор В переполнен Аккумулятор В переполнен Аккумулятор В переполнен Аккумулятор В не переполнен Бит переноса С равен единице Бит переноса С равен нулю Флаг тест/управление равен единице Флаг тест/управление равен нулю ВІО\ сигнал в низком состоянии |

# Использование множественных условий

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

Если указаны множественные условия, то все они должны быть выполнены для того чтобы инструкция выполнялась. Только определенные комбинации условий приемлемы (Таблица 19-23). Для каждой комбинации, условия должны быть выбраны из группы 1 или группа 2 следующим образом:

- Группа 1: Вы можете выбрать одно условие из категории А и одно условие из категории В. Два условия не могут быть из одной и той же категории. Например, Вы можете протестировать EQ и OV одновременно, но Вы не можете одновременно протестировать GT и NEQ. Аккумулятор должен быть тем же для обоих условий; Вы не можете протестировать условия для обоих аккумуляторов в одной и той же инструкции. Например, Вы можете протестировать AGT и AOV одновременно, но Вы не можете одновременно протестировать AGT и BOV.
- Группа 2: Вы можете выбрать одно условие из каждой из трех категорий (A, B, и C). Никакие два условия могут быть из одной и той же категории. Например, Вы можете одновременно протестировать TC, C, и BIO, но Вы не можете протестировать NTC, C, и NC в одно и то же время.

Таблица 19-23 – Группирование множественных условий инструкций

| Группа 1    |             |             | Группа 2    |             |
|-------------|-------------|-------------|-------------|-------------|
| Категория А | Категория В | Категория А | Категория В | Категория С |
| EQ          | OV          | TC          | С           | BIO         |
| NEQ         | NOV         | NTC         | NC          | NBIO        |
| LT          |             |             |             |             |
| LEQ         |             |             |             |             |
| GT          |             |             |             |             |
| GEQ         |             |             |             |             |

#### Условно выполняемая инструкция (ХС)

Там, где есть условные фрагменты кода из одного или двух слов программы, Вы можете заменить переход 1-цикловой условно выполняемой инструкцией (ХС). Есть две формы для инструкции ХС. Одна форма — условное выполнение 1-словной инструкции (ХС 1, условие). Вторая форма —условное выполнение одной 2-х словной инструкции или двух 1-словных инструкций (ХС 2, условие). Условия для ХС такие же, как и условия для условных переходов, вызовов и возвратов.

Примечание — Условие должно быть стабильным к моменту решения о том, следует ли исполнять одну или две команды следующие за ХС. В оригинальном микропроцессоре это гарантировалось таким программированием, что если некоторое условие может измениться предыдущими командами, то эти команды должыо быть на таком удалении от команды ХС, чтобы к моменту решения об исполнении анализируемые условия не менялись. О возможных ошибках программирования сообщал ассемблер.

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

# Инструкции условного хранения

Некоторые регистры CPU могут условно быть загружены в память данных, используя условные инструкции загрузки, перечисленные в Таблица 19-24. Условия, использованные условными инструкциями загрузки, указаны в Таблица 19-25.

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

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

Условное сохранение счётчика повторения блока (BRC) позволяет Вам сохранить индекс в цикле повторения блока.

Таблица 19-24 – Инструкции условного сохранения (условной записи)

| Инструкция | Регистр процессора       |
|------------|--------------------------|
| SACCD      | Аккумулятор А или В      |
| STRCD      | Временный регистр        |
| SRCCD      | Счётчик повторения блока |

Таблица 19-25 – Условия для команд условного хранения

| Операнд | Условие | Описание                    |
|---------|---------|-----------------------------|
| AEQ     | A = 0   | Аккумулятор А равен нулю    |
| BEQ     | B = 0   | Аккумулятор В равен нулю    |
| ANEQ    | A ≠ 0   | Аккумулятор А не равен нулю |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Операнд | Условие | Описание                            |
|---------|---------|-------------------------------------|
| BNEQ    | B ≠ 0   | Аккумулятор В не равен нулю         |
| ALT     | A < 0   | Аккумулятор А меньше нуля           |
| BLT     | B < 0   | Аккумулятор В меньше нуля           |
| ALEQ    | A ≤ 0   | Аккумулятор А меньше или равен нулю |
| BLEQ    | B ≤ 0   | Аккумулятор В меньше или равен нулю |
| AGT     | A > 0   | Аккумулятор А больше нуля           |
| BGT     | B > 0   | Аккумулятор В больше нуля           |
| AGEQ    | A ≥ 0   | Аккумулятор А больше или равен нулю |
| BGEQ    | B ≥ 0   | Аккумулятор В больше или равен нулю |

#### 19.5.6.1 Повторение одной инструкции

Микропроцессор включает две инструкции, RPT и RPTZ, которые вызывают повторение следующей инструкции. Количество повторений инструкции получается из операнда инструкции и равняется этому операнду + 1.

Эта величина сохраняется в 16-битовом счетчике повторения (RC). Вы не можете запрограммировать величину в регистре RC, он загружается только инструкциями повторения (RPT или RPTZ). Максимальное количество выполнений определяемых инструкциями — 65 536. Абсолютный адрес программы или данных автоматически увеличивается, когда использовано свойство повторения единственной команды.

Как только инструкция повторения будет декодирована, все прерывания, включая NMI\, но не RS\, запрещены до завершения цикла повторения. Тем не менее, микропроцессор реагирует на сигнал HOLD\ когда выполняется цикл RPT/RPTZ, ответ зависит от величины бита HM регистра ST1.

Функция повторения может быть использована некоторыми инструкциями, как например, умножение с накоплением и перемещение блока, увеличивая скорость выполнения этих инструкций. Эти многоцикловые инструкции (см. Таблица 19-26) эффективно становятся одноцикловыми инструкциями после первой итерации инструкции повторения.

Таблица 19-26 – Многоцикловые инструкции, которые становятся одноцикловыми при повторении

| Команда | Описание                                                 | # Циклы † |  |  |
|---------|----------------------------------------------------------|-----------|--|--|
| FIRS    | Симметричный фильтр с конечной импульсной                | 3         |  |  |
|         | характеристикой (FIR)                                    |           |  |  |
| MACD    | Умножение и посылка результата в аккумулятор с задержкой | 3         |  |  |
| MACP    | Умножение и посылка результата в аккумулятор             | 3         |  |  |
| MVDK    | Пересылка из области данных в область данных             | 2         |  |  |
| MVDM    | Пересылка данных в MMR                                   | 2         |  |  |
| MVDP    | Пересылка данных в программную область                   |           |  |  |
| MVKD    | Пересылка из области данных в область данных             | 2         |  |  |
| MVMD    | Пересылка из MMR в область данных                        | 2         |  |  |
| MVPD    | Пересылка из области программ в область данных           | 3         |  |  |
| READA   | Пересылка из области программ в область данных           | 5         |  |  |
| WRITE   | Пересылка данных в программную область                   | 5         |  |  |

<sup>†</sup> Количество циклов, когда инструкция не повторяется

Единственный операнд памяти данных в инструкции не может быть повторен, если использованы мода длинного смещения или абсолютный адрес (например, \*ARn(lk), \*+ARn(lk), \*+ARn(lk)% и \*(lk)). Инструкции указанные в Таблица 19-27 не могут быть повторены использованием RPT.

Таблица 19-27 – Неповторяемые инструкции

| Команда | Описание                                               |
|---------|--------------------------------------------------------|
| ADDM    | Сложение длинной константы с ячейкой памяти данных     |
| ANDM    | Операция AND ячейки памяти данных с длинной константой |
| B[D]    | Безусловный переход                                    |
| BACC[D] | Переход по адресу в аккумуляторе                       |
| BANZ[D] | Переход, если вспомогательный регистр не равен нулю    |
| BC[D]   | Условный переход                                       |
| CALA[D] | Вызов функции по адресу в аккумуляторе                 |

| CALL[D]  | Безусловный вызов функции                                     |
|----------|---------------------------------------------------------------|
| CC[D]    | Условный вызов функции                                        |
| CMPR     | Сравнение со вспомогательным регистром                        |
| DST      | Сохранение длинного (32 бита) слова                           |
| FRETE[D] | Разрешение прерываний и возврат из подпрограммы               |
| IDLE     | Инструкция перевода процессора в нерабочий режим              |
| INTR     | Ловушка прерывания                                            |
| LD ARP   | Загрузка значения в указатель вспомогательного регистра (ARP) |
| LD DP    | Загрузка указателя страницы памяти (DP)                       |
| MVMM     | Перемещение одного регистра в другой                          |
|          | (MMR - отображенный в памяти)                                 |
| ORM      | Операция OR ячейки памяти данных с длинной константой         |
| RC[D]    | Условный возврат                                              |
| RESET    | Программный сброс                                             |
| RET[D]   | Безусловный возврат                                           |
| RETE[D]  | Возврат из обработки прерываний                               |
| RETF[D]  | Быстрый возврат из прерываний                                 |
| RND      | Округление аккумулятора                                       |
| RPT      | Повторение следующей инструкции                               |
| RPTB[D]  | Повторение блока инструкций                                   |
| RPTZ     | Повторение следующей инструкции и очистка аккумулятора        |
| RSBX     | Сброс бита статусного регистра                                |
| SSBX     | Установка бита статусного регистра                            |
| TRAP     | Программная ловушка                                           |
| XC       | Условное выполнение                                           |
| XORM     | Операция XOR ячейки памяти данных с длинной константой        |
|          |                                                               |

#### 19.5.6.2 Повторение блока инструкций

Повторение блока инструкций используется для того, чтобы повторять блок кода N + 1 раз, где N – некоторая величина, загруженная в регистр-счётчик повторения блоков (BRC). Этот блок кода может содержать одну или более инструкций. В отличие от повторения единственного действия, которое выводит из строя все маскируемые прерывания, действие повторения блока может быть прервано.

Инструкции, использованные для этих действий — RPTB и RPTBD (задержанная инструкция). Инструкция RPTB выполняется в четыре цикла. RPTBD позволяет выполнение одной 2-словной инструкции или двух 1-словных инструкций, следующих за инструкцией RPTBD вместо очистки конвейера; таким образом, RPTBD эффективно выполняется в 2 цикла.

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

- BRC содержит величину N, которая на единицу меньше, чем количество повторений блока.
- Регистр стартового адреса повторения блока (RSA), содержит адрес первой инструкции блока кода, который нужно повторять.
- Регистр конечного адреса повторения блока (REA), содержит адрес последнего слова инструкции блока кода, который нужно повторять.

BRAF устанавливается в 1, чтобы активизировать блочное повторение. Свойство повторения блока может активизироваться, только если количество итераций больше, чем 0. Цикл начинается со следующих шагов:

• **Шаг 1:** Загружается BRC числом циклов в диапазоне от 0 до 65 535.

- **Шаг 2:** Инструкция загружает адрес первой инструкции, которая должна повторяться. Эта инструкция одна немедленно следующая за RPTB или вторая инструкция, следующая за RPTBD. Инструкция повторения блока (RPTB) или инструкция повторения блока с задержкой (RPTBD) автоматически загружают RSA адресом инструкции, следующей за инструкцией RPTB, или адресом второй инструкции, следующей за инструкцией RPTBD.
- Шаг 3: Инструкция загружает REA адресом, следующим за последним словом последней инструкции, которая должна повторяться в блоке, являющаяся также длинным непосредственным операндом, определенным в инструкции. Это действие также устанавливает BRAF. REA загружается 16-битовым непосредственным операндом инструкции RPTB или RPTBD, и бит BRAF устанавливается. Значение для 16-битового непосредственного операнда RPTB или RPTBD равно L-1, где L адрес инструкции, следующей за последним словом последней инструкции в цикле.

Каждый раз РС обновляется в течение выполнения цикла, REA сравнивается с величиной РС. Если величины равные, BRC - декрементируется. Если BRC больше или равно 0, RSA загружается в РС, чтобы перезапустить цикл. Если нет, BRAF сбрасывается в 0 и процессор продолжает выполнение инструкции следующей за концом цикла.

BRC декрементируется в течение фазы декодирования последней инструкции в блоке повторения. По этой причине, будьте осторожными при использовании инструкции SRCCD в пределах цикла. Для того, чтобы сохранять текущее значение счётчика цикла ( предекрементированное BRC), инструкция SRCCD должна быть размещена минимум за три инструкции до конца цикла.

Есть только одна установка регистров повторения блока, так что многочисленный блоки повторения не могут быть вложены, сохраняя при этом контекст вне циклов. Самый простой путь создания вложенных циклов в том, чтобы использовать RPTB[D] инструкцию только для внутреннего цикла и использовать BANZ[D] для всех внешних циклов.

# 19.6 Функционирование DSP-ядра после сброса

Сброс – немаскируемое внешнее прерывание, которое может быть использовано в любое время, чтобы устанавливать микропроцессор в известное состояние. В данной реализации производится путем записи соответствующих бит регистра DSP\_CONTROL\_STATUS со стороны RISC. Для правильной системной операции после подачи синхпросигнала, в течении нескольких тактов бит RST\_DSP\_MEM должен находится в исходном состоянии. Пять тактов синхросигнала снятия сброса процессорное ядро DSP выбирает инструкцию по адресу FF80h и начинает выполнять код.

Следующие действия происходят в течение операции сброса:

- IPTR устанавливается в 1FFh;
- PC устанавливается в FF80h;
- Адрес FF80h выдается на шину адреса;
- Шина данных переходит в высокоимпедансное состояние;
- Управляющие сигналы становятся не активными;
- Генерируется сигнал ІАСК\;
- INTM устанавливается в 1, чтобы запретить все маскируемые прерывания;
- IFR сбрасывается, чтобы сбросить флаги прерывания;
- Счетчик повторения одной команды (RC) сброшен;
- Следующие биты статуса установлены в их начальное состояние:

| -ARP = 0   | -CLKOFF = 0 | - HM = 0   | - SXM = 1 |
|------------|-------------|------------|-----------|
| -ASM = 0   | -CMPT = 0   | - INTM = 1 | - TC = 1  |
| - AVIS = 0 | - CPL = 0   | - OVA = 0  | - XF = 1  |
| -BRAF = 0  | -DP = 0     | -OVB = 0   |           |
| - C = 1    | -DROM = 0   | - OVLY = 0 |           |
| -C16 = 0   | - FRCT = 0  | - OVM = 0  |           |

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

- 1) Остальные биты статуса не инициализируются Ваш код должен их инициализировать.
- 2) Сброс не инициализирует указатель стека (SP). Ваш код должен инициализировать его.
  - 3) Если MP/MC = 0, устройство начинает выполнять код из встроенного ROM. В противном случае, начинает выполняться код из внешней памяти.

#### 19.7 Прерывания DSP

Прерывания являются аппаратно и программно задаваемыми сигналами, которые, возникнув в микропроцессоре, приостанавливают основную программу и выполняют другую функцию, называемую программой обработки прерывания (ISR – interrupt service routine). Обычно, прерывания генерируются аппаратурой, которой нужно давать данные или брать из неё данные (например, АЦП, ЦАП, и другие процессоры). Прерывания могут также быть использованы, чтобы сигнализировать, что произошло конкретное событие (например, таймер закончил счет).

Микропроцессор поддерживает как программные, так и аппаратные прерывания:

- Программное прерывание, вызываемое инструкцией (INTR, TRAP, или сброс RESET).
- Аппаратное прерывание, вызываемое сигналом с физического устройства (регистра DIRQ).
- Когда многочисленные аппаратные прерывания инициируются в одно и то же время, микропроцессор обслуживает их согласно приоритету, в котором прерывание ранга 1 имеет самый высший приоритет.

Каждое прерывание в микропроцессоре может быть маскируемым или немаскируемым:

- Маскируемые прерывания. Эти аппаратные или программные прерывания, которые могут быть заблокированы (замаскированы) или разрешены (размаскированы) по программе. Микропроцессор поддерживает до 16 маскируемых пользователем прерываний (SINT15 SINT0). Обычно использует подмножество этих 16 прерываний. Некоторые из них имеют два имени, поскольку они могут быть введены программным обеспечением или аппаратными средствами;
- Немаскируемые прерывания. Эти прерывания не могут быть заблокированы. Микропроцессор всегда признает этот тип прерывания и переходит от основной программы к ISR. Немаскируемые прерывания включают все программные прерывания и два прерывания от RISC: RS (регистр DSP\_CONTROL\_STATUS) и NMI (регистр AIRQ).

Микропроцессор обрабатывает прерывания в три фазы:

- 1. Получение требования на прерывание. Требование на останов основной программы требуется через программное обеспечение (программный код) или аппаратные средства. Если источник прерывания просит маскируемое прерывание, соответствующий бит в регистре флага прерывания (IFR) установливается при возникновении прерывания.
- 2. Подтверждение прерывания. Микропроцессор должен подтвердить приём прерывания. Если прерывание является маскируемым, преопределенные условиями должно быть выполнены для этого подтверждения. Для немаскируемых аппаратных прерываний и для программных прерываний, подтверждение безусловное.
- 3. Выполнение программы обработки прерывания (ISR interrupt service routine). Как только прерывание подтверждено, микропроцессор выполняет команду перехода на предопределённый адрес (позицию вектора прерывания) и выполняют ISR.

# 19.7.1 Регистры управления прерываниями ядра

# Таблица 19-28 – Регистр флага прерывания (IFR-interrupt flag register)

| 7      | 6      | 5       | 4      | 3     | 2     | 1       | 0     |
|--------|--------|---------|--------|-------|-------|---------|-------|
|        |        |         |        |       |       |         |       |
| VINITO | DINITO | VINIT 4 | DIVITA | TINIT | INITO | IN IT 4 | INITO |
| XINT2  | RINT2  | XINT1   | RINT1  | TINT  | INT2  | INT1    | INT0  |
| 15     | 1.1    | 12      | 10     | 11    | 10    | 0       | 0     |
| 15     | 14     | 13      | 12     | 11    | 10    | 9       | 0     |
|        |        |         |        |       |       |         |       |
| -      | -      | DMA_INT | CRINT  | CDINT | XINT3 | RINT3   | INT3  |

# Таблица 19-29 – Назначение битов регистра

| Биты | Наименование | Назначение                                                                        |
|------|--------------|-----------------------------------------------------------------------------------|
| 15   |              |                                                                                   |
| 14   |              |                                                                                   |
| 13   | DMA_INT      | Прерывание DMA (завершение обработкиодного иззапросов) 0 – Не активно 1 – Активно |
| 12   | CRINT        | Прерывание Криптомодуля<br>0 – Не активно<br>1 – Активно                          |
| 11   | CDINT        | Прерывание Аудиокодека<br>0 – Не активно<br>1 – Активно                           |
| 10   | XINT3        | Прерывание передатчика McBSP3<br>0 – Не активно<br>1 – Активно                    |
| 9    | RINT3        | Прерывание приемника McBSP3<br>0 – Не активно<br>1 – Активно                      |
| 8    | INT3         | Прерывание RISC3<br>0 – Не активно<br>1 – Активно                                 |
| 7    | XINT2        | Прерывание передатчика McBSP2<br>0 – Не активно<br>1 – Активно                    |
| 6    | RINT2        | Прерывание приемника McBSP2<br>0 – Не активно<br>1 – Активно                      |
| 5    | XINT1        | Прерывание передатчика McBSP1<br>0 – Не активно<br>1 – Активно                    |
| 4    | RINT1        | Прерывание приемника McBSP1<br>0 – Не активно<br>1 – Активно                      |
| 3    | TINT         | Прерывание Таймера<br>0 – Не активно<br>1 – Активно                               |

| 2 | INT2 | Прерывание RISC2<br>0 – Не активно<br>1 – Активно |
|---|------|---------------------------------------------------|
| 1 | INT1 | Прерывание RISC1<br>0 – Не активно<br>1 – Активно |
| 0 | INT0 | Прерывание RISC0<br>0 – Не активно<br>1 – Активно |

IFR – регистр, отображенный в памяти процессора, который идентифицирует и определяет активные прерывания. Прерывание устанавливает соответствующий флаг прерывания в IFR, пока оно не будет признано ядром DSP. Любое из следующих четырех событий сбрасывает флаг прерывания в регистре IFR (но не в регистре AIRQ):

- Сброс ядра DSP.
- Ловушка прерывания захвачена.
- Записана единица в соответствующий бит IFR.
- Инструкция INTR выполнена, используя соответствующий номер прерывания.

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

# 19.7.2 Регистр Маски Прерывания (IMR-interrupt mask register)

Таблица 19-30 показывает, как микропроцессор использует отображенный в памяти регистр IMR для маскирования внешних и внутренних прерываний. Если INTM = 0 в ST1, единица на любом бите IMR допускает соответствующее прерывание. Немаскируемое прерывание от RISC не включены в IMR.

Таблица 19-30 - Регистр маски прерывания

| 7      |       | 6      | 5      | 4        | 4 |        | 2      | 1      | 0     |
|--------|-------|--------|--------|----------|---|--------|--------|--------|-------|
|        |       |        |        |          |   |        |        |        |       |
|        |       |        |        |          |   |        |        |        |       |
| XINT2N | / RIN | RINT2M |        | I RINT1N | / | TINTM  | INT2M  | INT1M  | INTOM |
|        |       |        |        |          |   |        |        |        |       |
| 15     | 14    |        | 13     | 12       |   | 11     | 10     | 9      | 8     |
|        |       |        |        |          |   |        |        |        |       |
|        |       |        |        |          |   |        |        |        |       |
| -      | -     | DM     | A_INTM | CRINTM   | ( | CDINTM | XINT3M | RINT3M | INT3M |

Таблица 19-31 – Назначение битов регистра

| Биты | Наименование | Назначение      |  |  |  |  |
|------|--------------|-----------------|--|--|--|--|
| 15   | -            | зарезервировано |  |  |  |  |
| 14   | -            | зарезервировано |  |  |  |  |

| 40 | DAAA INITAA | N                                                |
|----|-------------|--------------------------------------------------|
| 13 | DMA_INTM    | Маска прерывания DMA (завершение обработкиодного |
|    |             | иззапросов)                                      |
|    |             | 0 – запрещено                                    |
| 10 | 0501714     | 1 – разрешено                                    |
| 12 | CRINTM      | Маска прерывания Криптомодуля                    |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 11 | CDINTM      | Маска прерывания Аудиокодека                     |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 10 | XINT3M      | Маска прерывания передатчика McBSP3              |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 9  | RINT3M      | Маска прерывания приемника McBSP3                |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 8  | INT3M       | Маска прерывания RISC3                           |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 7  | XINT2M      | Маска прерывания передатчика McBSP2              |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 6  | RINT2M      | Маска прерывания приемника McBSP2                |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 5  | XINT1M      | Маска прерывания передатчика McBSP1              |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 4  | RINT1M      | Маска прерывания приемника McBSP1                |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 3  | TINTM       | Маска прерывания Таймера                         |
|    |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 2  | INT2M       | Маска прерывания RISC2                           |
| _  |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 1  | INT1M       | Маска прерывания RISC1                           |
| '  |             | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
| 0  | INTOM       | Маска прерывания RISC0                           |
|    | 11410101    | 0 – запрещено                                    |
|    |             | 1 – разрешено                                    |
|    |             | i — разрешено                                    |

# 19.7.3 Обработка прерываний

#### 19.7.3.1 Фаза 1: Приём требования на прерывание



Требование прерывание возникает от аппаратных устройств (в т.ч. и от RISC-ядра) или от команды программы.

Когда возникает требование прерывания, соответствующий флаг (если он имеется), активируется в IFR.

Этот флаг активируется, если даже прерывание позже не подтверждено процессором. Флаг автоматически очищается, когда соответствующее прерывание захвачено.

<u>Требования аппаратных прерываний.</u> Внешние аппаратные прерывания вызываются сигналами с внешних портов прерывания и внутренними аппаратными прерывания с встроенных периферийных устройств. Например, на данном микропроцессоре аппаратные прерывания могут потребоваться от следующих источников:

- Прерывания от RISC-ядра (регистр AIRQ) INT0...INT3, NMI;
- Сброс ядра DSP (регистр DSP\_CONTROL\_STATUS подсистемы RISC);
- Прерывания от последовательных портов (RINT0 и XINT0, RINT1 и XINT1, RINT2 и XINT2, RINT3 и XINT3);
- Прерывание от таймера (TINT);
- Прерывание от криптомодуля (CRINT);
- Прерывание от аудиокодека (CDINT).

<u>Требования программного прерывания.</u> Программное прерывание вызывается одной из следующих инструкций программы:

- INTR. Эта инструкция позволяет Вам выполнить любую программу обработки прерывания.
- Операнд инструкции (К) указывает значение вектора прерывания СРU.
   Когда прерывание INTR подтверждено, бит моды прерывания (INTM) в ST1 устанавливается в 1, чтобы запретить маскируемые прерывания.
- TRAP. Эта инструкция выполняется подобно инструкции INTR, но без установки бита INTM.
- RESET. Эта инструкция выполняет немаскируемый программный сброс, что может быть использовано всякий раз для установки микропроцессора в известное состояние. Инструкция RESET влияет на ST0 и ST1, но не влияет на PMST. Для общего описания воздействия на биты и регистры, смотри описание инструкции RESET.

Когда инструкция RESET подтверждена, INTM устанавливается в 1, чтобы запретить маскируемые прерывания. Инициализация IPTR и периферийных регистров отличается от инициализации сделанной аппаратным сбросом.

#### 19.7.3.2 Фаза 2: Подтверждение прерывания



После возникновения требования прерывания от аппаратных или программных средств, CPU должно предложить ответ. Выполнение программ прерывается для немаскируемых аппаратных прерываний немедленно. Маскируемые аппаратные прерывания признаются только после того, как определенные условия будут выполнены:

- Приоритет самый высокий. Когда более, чем одно аппаратное прерывание требуется в одно и то же время, микропроцессор обслуживает их согласно приоритету, причём приоритет в наборе ранга 1 указывает самый высокий приоритет.
- *INTM бит в 0.* Бит способа прерывания (INTM), который в ST1, разрешает или запрещает все маскируемые прерывания:
  - Когда INTM = 0, все незамаскированные прерывания разрешены.
  - Когда INTM = 1, все незамаскированные прерывания запрещены.
     INTM устанавливается в 1 автоматически, когда прерывание захвачено.
     Если программа обработки прерывания (ISR) заканчивается, используя инструкцию RETE (возврат из прерывания с автоматическим разрешением), INTM восстанавливается (очистка бита).
     INTM также может быть установлен сбросом ядра DSP или выполнением инструкции SSBX INTM (запрет прерывания). INTM сбрасывается при выполнении инструкции RSBX INTM (разрешить прерывание). INTM не модифицирует IMR или IFR.
- *Бит маски IMR в 1.* Каждое маскируемое прерывание имеет собственный бит маски в IMR. Для того, чтобы разрешить прерывание, установите соответствующий бит маски в 1.

CPU отвечает на маскируемое аппаратное прерывание и выдает на шину инструкций инструкцию INTR. Эта инструкция переводит PC в соответствующий адрес и выбирает программный вектор.

# 19.7.3.3 Фаза 3: Выполнение программы обработки прерывания (ISR-interrupt service routine)



После того, как прерывание подтверждено, центральный процессор выполняет следующие действия:

- 1. Загружает значение программного счетчика (РС) (адрес возврата) на вершину стека памяти данных.
- 2. Загружается РС адресом вектора прерывания.
- 3. Выбирает инструкцию, расположенную по адресу вектора. (Если переход задержанный, и Вы также загрузили одну 2-словную инструкцию или две 1-словные инструкции, CPU также выбирает эти слова.)

- 4. Выполняется переход, который лидирует по адресу вашего ISR. (Если переход задержанный, дополнительная инструкция (инструкции) выполняются перед переходом.)
- 5. Выполняется ISR, пока инструкция возврата не подведёт итог ISR
- 6. В соответствии с указателем верхушки стека (SP) выталкивает адресу возврата в PC
- 7. Продолжает выполнять основную программу

Для того, чтобы определять, что какой векторный адрес назначен каждому из прерываний, смотрите на таблицу векторов. Адресы прерываний расположены отдельно, разделённые шагом в четыре адреса, так что в этих позициях может быть размещена задержанная инструкция перехода и две 1-словные инструкции или одна 2-словная инструкция.

#### 19.7.3.4 Сохранение контекста при прерываниях

Когда выполняется программа обработки прерывания, определенные регистры должно быть сохранены в стеке. Когда программа возвращается из ISR (RC[D], RETE[D], или RETF[D]), ваш программный код должен восстановить содержание этих регистров. Вы можете управлять хранением в стеке до тех пор, пока стек не превысит пространство памяти. Этот стек также используется для подпрограммных вызовов; Микропроцессор поддерживает подпрограммные вызовы в пределах ISR. Поскольку регистры DSP и периферийные регистры отображены в памяти, команды PSHM и POPM могут передать эти регистры из стека и в стек. Кроме того, инструкции PSHD и POPD могут передать значения из памяти данных в стек и наоборот.

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

- 1. Восстановление данных из стэка должно происходить в точном обратном порядке его сохранению.
- 2. BRC должен быть восстановлен до восстановления бита BRAF в ST1. Если не придерживаться этого правила, бит BRAF будет очищен, если BRC = 0 прежде, чем BRC будет восстановлен.

#### 19.7.3.5 Время перехода к обработке прерывания

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

Инструкция повторения одной инструкций (RPT и RPTZ) требует, чтобы выполнение следующей инструкции было полностью завершено перед разрешением прерывания, чтобы не нарушить контекст повторяющейся инструкции. Эта защита необходима, поскольку эти инструкции запускают параллельные действия в конвейер, и контекст этих действий не может быть сохранен в ISR.

Прерывания не могут быть обработаны между инструкцией RSBX INTM (RSBX – сброс бита статусного регистра, INTM (Interrupt mode – общее разрешение прерываний) и следующей инструкцией в программной последовательности. Если прерывание происходит в течение фазы декодирования RSBX INTM, CPU всегда

завершает RSBX INTM, а также следующую инструкцию прежде, чем незаконченное прерывание будет обработано. При ожидании завершения этих инструкций проверяется, что возврат (RET) может быть выполнен в ISR прежде, чем следующее прерывание будет обработано, чтобы защититься от переполнения стека.

Если команда ISR заканчивается инструкцией RETE (возврат из ISR с разрешением прерываний), инструкция RSBX INTM необязательная. Подобно сказанному инструкции RSBX INTM, инструкция SSBX INTM и инструкция, следующая за ней, не могут быть прерваны.

Примечание – Сброс, не задерживается в случае многоцикловых инструкций.

#### 19.7.3.6 Таблица веторов прерываний

Векторы прерывания могут быть перераспределены в начало любой 128-словной страницы в программной памяти за исключением резервных областей. Адрес вектора прерывания генерируется конкатенацией поля указателя прерываний (IPTR) регистра PMST (Processor Mode Status Register) с номером вектора (0 – 31) сдвинутым влево на 2 позиции. Смотрите в качестве примера Рисунок 19–48: если возник INT0 и IPTR = 0001h, вектором прерывания выбирается 00C0h. Вектор прерывания для INT0 – 16 или 10h.



Рисунок 19-48 - Генерация адреса вестора прерываний

При сбросе, биты IPTR устанавливаются в 1 (IPTR = 1FFh); эта величина отображает векторы на страницу 511 в пространстве памяти программ. Следовательно, вектор аппаратного сброса всегда расположен на позиции 0FF80h., векторы прерывания могут быть отображены в другое место загрузкой IPTR другой, нежели 1FFh, величиной. Например, векторы прерывания могут начинаться с адреса 0080h загрузкой IPTR величиной 0001h.

Примечание — Вектор аппаратного сброса (RS) не может быть перемещён, поскольку аппаратный сброс загружает IPTR единицами. Следовательно, вектор аппаратного сброса всегда расположен по адресу FF80h в программном пространстве.



Рисунок 19-49 - Структурная схема процесса прерывания

Таблица 19-32 показывает номер прерывания, приоритет и размещение для микропроцессора.

Таблица 19-32 – Расположение и приоритеты прерываний '546

| TRAP/INTR<br>номер (К) | Приоритет | Название     | Расположение<br>(hex) | Фунция                                          |
|------------------------|-----------|--------------|-----------------------|-------------------------------------------------|
| 0                      | 1         | RS, SINTR    | 0                     | сброс (аппаратный и программный сброс)          |
| 1                      | 2         | NMI, SINT16  | 4                     | немаскируемое прерывание от RISC (регистр AIRQ) |
| 2                      | -         | SINT17       | 8                     | программное прерывание #17                      |
| 3                      | -         | SINT18       | С                     | программное прерывание #18                      |
| 4                      | -         | SINT19       | 10                    | программное прерывание #19                      |
| 5                      | -         | SINT20       | 14                    | программное прерывание #20                      |
| 6                      | -         | SINT21       | 18                    | программное прерывание #21                      |
| 7                      | -         | SINT22       | 1C                    | программное прерывание #22                      |
| 8                      | -         | SINT23       | 20                    | программное прерывание #23                      |
| 9                      | -         | SINT24       | 24                    | программное прерывание #24                      |
| 10                     | -         | SINT25       | 28                    | программное прерывание #25                      |
| 11                     | -         | SINT26       | 2C                    | программное прерывание #26                      |
| 12                     | -         | SINT27       | 30                    | программное прерывание #27                      |
| 13                     | -         | SINT28       | 34                    | программное прерывание #28                      |
| 14                     | -         | SINT29       | 38                    | программное прерывание #29                      |
| 15                     | -         | SINT30       | 3C                    | программное прерывание #30                      |
| 16                     | 3         | INTO, SINTO  | 40                    | прерывание от RISC 0 (регистр<br>AIRQ)          |
| 17                     | 4         | INT1, SINT1  | 44                    | прерывание от RISC 1 (регистр<br>AIRQ)          |
| 18                     | 5         | INT2, SINT2  | 48                    | прерывание от RISC 2 (регистр<br>AIRQ)          |
| 19                     | 6         | TINT, SINT3  | 4C                    | прерывание таймера                              |
| 20                     | 7         | RINT1, SINT4 | 50                    | прерывание приема BSP 1                         |
| 21                     | 8         | XINT1, SINT5 | 54                    | прерывание передачи BSP1                        |
| 22                     | 9         | RINT2, SINT6 | 58                    | прерывание приема BSP2                          |
| 23                     | 10        | XINT2, SINT7 | 5C                    | прерывание передачи BSP2                        |
| 24                     | 11        | ĪNT3, SINT8  | 60                    | прерывание от RISC 3 (регистр<br>AIRQ)          |
| 25                     | 12        | RINT3,       | 64                    | прерывание приема BSP 3                         |
| 26                     | 13        | XINT3,       | 68                    | прерывание передачи BSP 3                       |
| 27                     | 14        | CDINT        | 6C                    | Прерывание аудиокодека                          |
| 28                     | 15        | CRINT        | 70                    | Прерывание криптомодуля                         |
| 29                     | 16        | DMAINT       | 74                    | Прерывание DMA (DSP)                            |
| 30-31                  | -         |              | 78-7C                 | зарезервировано                                 |

## 19.8 Регистры управления и состояния ядра

Микропроцессор имеет три регистра статуса и управления:

- Регистр состояния 0 (ST0);
- Регистр состояния 1 (ST1);
- Регистр состояния моды процессора (PMST).

ST0 и ST1 содержит состояние различных условий и мод; PMST содержит состояние установок памяти и управляющую информацию. Поскольку эти регистры отображены в память, они могут быть загружены и выгружены из памяти данных;

статус процессора может быть сохранен и восстановлен подпрограммами и программами обработки прерываний (ISRs).

## 19.8.1 Регистры Статуса (ST0 и ST1)

Индивидуальные биты регистров ST0 и ST1 могут быть установлены или сброшены инструкциями SSBX и RSBX. Например, мода расширения знака устанавливается инструкциями SSBX 1, SXM, а сбрасывается RSBX 1, SXM. Битовые поля ARP, DP и ASM могут быть загружены с использованием инструкции LD с коротким непосредственно заданным операндом. Поля ASM и DP могут также быть загружены как значения в памяти, используя инструкцию LD.

Рисунок 19–50 и Таблица 19-33 описывают биты ST0. Рисунок 19–51 и Таблица 19-34 описыают биты ST1.



Рисунок 19-50 - Регистр состояния 0 (ST0)

Таблица 19-33 – Назначение битов регистра состояния 0 (ST0)

|       |             | 2                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Биты  | Обозначение | Значение<br>по сбросу | Функция                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15-13 | ARP         | 0                     | Указатель вспомогательного регистра. Это 3-х битовое поле выбирает вспомогательный регистр, используемый в совместимой моде косвенной адресации одного операнда. ARP должен быть всегда установлен в нуль, когда DSP в стандартной моде (CMPT=0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 12    | TC          | 1                     | Флаг тестирования/управления. ТС хранит результаты тестирования арифметико-логическим устройством (ALU).  ТС формируется командами ВІТ, ВІТГ, ВІТТ, СМРМ, СМРЯ, СМРЯ, и SFTC. Состояние (установленное или сброшенное) ТС определяется тогда, когда выполняется команда условного перехода, вызов процедуры, выполнения и возврата из подпрограммы. ТС = 1, если следующие условия являются истиной:  Бит, протестированный командой ВІТ или ВІТТ равен 1.  Условие сравнения, протестированное командами СМРМ, СМРР, или СМРЅ верно (СМРМ-равенство между значением в памяти данных и непосредственным операндом, СМРР-сравнение ARO и другого вспомогательного регистра, СМРЅ сравнение старшего и младшего слова аккумулятора).  Бит 31 и бит 30 аккумулятора, протестированных командой SFTC, имеют значения разнящиеся друг от друга. |

| Биты | Обозначение | Значение<br>по сбросу | Функция                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11   | С           | 1                     | Перенос установлен в 1, если результат сложения генерирует перенос; сброшен в 0, если результат вычитания генерирует заем. В противном случае, сбрасывается после сложения и устанавливается после вычитания, за исключением ADD или SUB с 16-битовым сдвигом. Только в этих случаях, командой ADD может быть установлен и в командой SUB сброшен бит переноса, но на него ничто не может повлиять иное. Перенос и заем определены в 32-й битовой позиции и формируются только на уровне ALU. Инструкции сдвига и циклического сдвига (ROR, ROL, SFTA, и SFTL), и MIN, MAX, ABS, и NEG инструкции также влияют на этот бит. |
| 10   | OVA         | 0                     | Флаг переполнения для аккумулятора А. OVA устанавливается в 1, когда происходит переполнение в ALU или сумматоре умножителя и расположение для результата - аккумулятор А. Как только переполнение произойдет, OVA остается установленным до сброса, и инструкций BC[D], CC[D], RC[D], или XC, выполненных с использованием условия AOV и условия ANOV. Инструкция RSBX может также очистить этот бит.                                                                                                                                                                                                                      |
| 9    | OVB         | 0                     | Флаг переполнения для аккумулятора В. OVB устанавливается в 1, когда происходит переполнение в ALU или сумматоре умножителя и расположение для результата — аккумулятор В. Как только переполнение произойдет, OVB остается установленным до сброса, и инструкций BC[D], CC[D], RC[D], или XC выполненных с использованием условия BOV и условия BNOV. Инструкция RSBX может также очистить этот бит.                                                                                                                                                                                                                       |
| 8-0  | DP          | 0                     | Указатель страницы памяти данных. Эта 9-битовая область конкатенируется с семью младшими словами инструкции, чтобы сформировать прямой адрес памяти в 16 бит для адресации единственного операнда памяти. Эта операция выполняется, если бит моды компиляции в ST1 (CPL) = 0. Поле DP может быть загружено инструкцией LD с коротким непосредственно заданным операндом или из памяти данных.                                                                                                                                                                                                                               |

| 15   | 14  | 13 | 12 | 11   | 10 | 9   | 8   | 7   | 6    | 5    | 4-0 |
|------|-----|----|----|------|----|-----|-----|-----|------|------|-----|
| BRAF | CPL | XF | НМ | INTM | 0  | OVM | SXM | C16 | FRCT | CMPT | ASM |

Рисунок 19-51 - Регистр состояния 1 (ST1)

Таблица 19-34 – Назначение битов регистра состояния 1 (ST1)

| показывает активность в настоящее повторения блока.  ВRAF = 0 блочное повторение дезактивири ВRAF сбрасывается, когда счетчик повто блока (ВRC) декрементирован ниже 0.  ВRAF = 1 повторение блока активно. автоматически устанавливается, когда выпо инструкция RPTB.  14 CPL 0 Режим компилятора. CPL показывает, указатель использован в относительной п адресации:  CPL = 0 мода относительной п адресации;  CPL = 1 мода относительной п адресации, использовавший выбор страни указателя данных (DP).  CPL = 1 мода относительной п адресации, использовавший выбор указателя (SP).  13 XF 1 Состояние XF. XF показывает статус шт внешнего флага (XF), который является выхоштырьком общего назначения. Инструкция может установить XF и инструкция RSBX сбросить XF.  12 НМ 0 Способ захвата. НМ показывает, какой из источников программы продолжает выполне внутри процессором, огращивая активность си HOLD:  HM = 0 процессор продолжает выполне внутренней программной памяти, при устанавливая свой внешний интерфей высокоимпедансное состояние.  HM = 1 процессор останавливает внутр выполнение.  INTM = 1 все маскирует или разр глобально все прерывания.  INTM = 0 все незамаскированные прерь разрешены.  INTM = 1 все маскируемые прерь запрещены.  INTM = 1 все маскируемые прерь запрещены.  INTM = 1 все маскируемые прерь запрещены.  INTM я все маскируемая ло прерывания (INTR или внешние прерывания).  INTM корасывает INTM. INTM устанавливает сбросом или когда принята маскируемая ло прерывания (INTR или внешние прерывания).  INTM сбрасывается в 0, когда выполниструкция RETE или RETF (возвра | Биты | Обозначение | Значение<br>по сбросу | Функция                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14 СРЬ 0 Режим компилятора. СРЬ показывает, указатель использован в относительной п адресации:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 15   | BRAF        | 0                     | показывает активность в настоящее время повторения блока.  BRAF = 0 блочное повторение дезактивировано. BRAF сбрасывается, когда счетчик повторения блока (BRC) декрементирован ниже 0.  BRAF = 1 повторение блока активно. BRAF автоматически устанавливается, когда выполнена                                                                                                                                                                                                                             |
| 13 XF 1 Состояние XF. XF показывает статус шт внешнего флага (XF), который является выхо штырьком общего назначения. Инструкция может установить XF и инструкция RSBX сбросить XF.  12 HM 0 Способ захвата. НМ показывает, какой из источников программы продолжает выполне внутри процессором, опрашивая активность си НОLD\table :  14 HM = 0 процессор продолжает выполне внутренней программной памяти, при устанавливая свой внешний интерфей высокоимпедансное состояние.  15 HM = 1 процессор останавливает внутр выполнение.  16 Mода прерывания. INTM маскирует или разр глобально все прерывания.  17 INTM 1 Мода прерывания. INTM маскирует или разр глобально все прерывания.  18 INTM = 0 все незамаскированные прерь разрешены.  19 INTM = 1 все маскируемые прерь запрещены.  19 Инструкция SSBX устанавливает INTM и инструкция SSBX устанавливает сбросом или когда принята маскируемая ло прерывания (INTR или внешние прерывания).  19 INTM сбрасывает INTM или внешние прерывания).  10 INTM сбрасывается в 0, когда выполнинструкция RETE или RETF (возвраг                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 14   | CPL         | 0                     | указатель использован в относительной прямой адресации:  CPL = 0 мода относительной прямой адресации, использовавший выбор страничного указателя данных (DP).  CPL = 1 мода относительной прямой адресации, использовавший выбор указателя стека                                                                                                                                                                                                                                                            |
| источников программы продолжает выполивнутри процессором, опрашивая активность си HOLD\:  HM = 0 процессор продолжает выполнен внутренней программной памяти, при устанавливая свой внешний интерфей высокоимпедансное состояние.  HM = 1 процессор останавливает внутренней.  INTM 1 Мода прерывания. INTM маскирует или разрилобально все прерывания.  INTM = 0 все незамаскированные преры разрешены.  INTM = 1 все маскируемые преры запрещены.  Инструкция SSBX устанавливает INTM и инструкция SSBX устанавливает сбросом или когда принята маскируемая лопрерывания (INTR или внешние прерывания).  INTM сбрасывается в 0, когда выполнинструкция RETE или RETF (возвратинструкция RETE или RETF (возвратинструкция RETE или RETF)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 13   | XF          | 1                     | Состояние XF. XF показывает статус штырька внешнего флага (XF), который является выходным штырьком общего назначения. Инструкция SSBX может установить XF и инструкция RSBX может                                                                                                                                                                                                                                                                                                                           |
| глобально все прерывания.  INTM = 0 все незамаскированные прерь разрешены.  INTM = 1 все маскируемые прерь запрещены.  Инструкция SSBX устанавливает INTM и инстр RSBX сбрасывает INTM. INTM устанавливает сбросом или когда принята маскируемая ло прерывания (INTR или внешние прерывания).  INTM сбрасывается в 0, когда выполн инструкция RETE или RETF (возвраг                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 12   | НМ          | 0                     | HM = 0 процессор продолжает выполнение из внутренней программной памяти, при этом устанавливая свой внешний интерфейс в высокоимпедансное состояние.  HM = 1 процессор останавливает внутреннее                                                                                                                                                                                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |             | ·                     | INTM = 0 все незамаскированные прерывания разрешены.  INTM = 1 все маскируемые прерывания запрещены.  Инструкция SSBX устанавливает INTM и инструкция RSBX сбрасывает INTM. INTM устанавливается в 1 сбросом или когда принята маскируемая ловушка прерывания (INTR или внешние прерывания).  INTM сбрасывается в 0, когда выполняется инструкция RETE или RETF (возврат из прерывания). INTM не влияет на немаскируемые прерывания (RS\ и NMI\). INTM не может быть установлен действиями записи в память. |

| Биты | Обозначение | Значение<br>по сбросу | Функция                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9    | OVM         | 0                     | Мода переполнения. OVM определяет, что загружается на аккумулятор назначения, когда происходит переполнение:  OVM = 0 переполнение результата из ALU или сумматора умножителя обычно переполняется и на аккумуляторе назначения.  OVM = 1 аккумуляторе назначения установлен на или наиболее положительную величину (00 7FFF                                                                                        |
|      |             |                       | FFFFh) или наиболее отрицательную величину (FF 8000 0000h) при столкновении с переполнением. Инструкции SSBX и RSBX устанавливают и сбрасывают ОVM, соответственно.                                                                                                                                                                                                                                                 |
| 8    | SXM         | 1                     | Мода расширения знака. SXM определяет, как выполняется расширение знака: SXM = 0 расширение знака подавлено. SXM = 1 данные расширяются знаком прежде, чем будут использованы в ALU. SXM не влияет на определения некоторых инструкций: инструкции ADDS, LDU и SUB подавляют расширение знака независимо от величины SXM. Инструкции SSBX и RSBX устанавливают и сбрасывают SXM, соответственно.                    |
| 7    | C16         | 0                     | Мода двойной 16- битовой или спаренной точности арифметических операций. С16 определяет моду арифметических действий в ALU: С16 = 0 ALU работает в моде двойной точности арифметических действий. С16 = 1 ALU работает в моде спаренных арифметических действий.                                                                                                                                                    |
| 6    | FRCT        | 0                     | Мода дробности. Когда FRCT в 1, выход множителя сдвигается влево на один бит, чтобы компенсировать дополнительный бит знака.                                                                                                                                                                                                                                                                                        |
| 5    | CMPT        | 0                     | Мода совместимости. СМРТ определяет способ совместимости для ARP:  СМРТ = 0 ARP не обновляется в моде косвенной адресации с единственным операндом в памяти данных. ARP должен быть всегда установлен в 0, когда DSP - в этом способе.  СМРТ = 1 ARP обновляется в моде косвенной адресации с единственным операндом в памяти данных, кроме тех случаев, когда инструкция выбирает вспомогательный регистр 0 (AR0). |
| 4-0  | ASM         | 0                     | Мода сдвига аккумулятора. 5- битовая поле ASM определяет величину перемещения в пределах от - 16 до 15 и закодирована как величина в дополнительном коде. Инструкции с параллельным хранением, а также STH, STL, ADD, SUB и LD, используют эту возможность сдвига. ASM может быть загружен из памяти данных или же инструкцией LD, использовавшей короткий непосредственный операнд.                                |

## Регистр состояния моды процессора (PMST)

Регистр PMST загружается инструкциями работающими с регистрами, отображенными в памяти, как например, STM. Рисунок 19–52 и Таблица 19-35 описывают биты PMST.

| 15-7 | 6          |      | 4    | 3    |        | 1         | 0        |
|------|------------|------|------|------|--------|-----------|----------|
| IPTR | MP/<br>MC\ | OVLY | AVIS | DROM | CLKOFF | SMUL<br>† | SST<br>† |

† В данной модели микропроцессора эти биты не поддержаны.

# Рисунок 19-52 - Регистр состояния моды процессора (PMST)

Таблица 19-35 – Назначение битов регистра PMST

| Биты | Обозначение | Значние<br>по сбросу | Функция                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-7 | IPTR        | 1FFh                 | Указатель вектора прерывания. 9-битовое поле IPTR указывает на 128-словную программную страницу, где находятся векторы прерывания. Вы можете перенаправить векторы прерывания при загрузке. При сбросе, эти биты все устанавливаются в 1; при сбросе вектора всегда расположены по адресу FF80h в пространстве программной памяти. Инструкция RESET не влияет на эту поле.                                                                                                                                    |
| 6    | MP/MC\      | МР/МС\<br>контакт    | Мода микропроцессор/микрокомпьютер. МР/МС\ разрешает/запрещает встроенное ПЗУ, при адресации в пространстве программной памяти. МР/МС = 0 встроенное ПЗУ разрешен и адресуем. МР/МС = 1 встроенное ПЗУ не доступно. МР/МС устанавливается в значение, соответствующее логическому уровню на контакте МР/МС когда он семплируется при сбросе. Этот штырек - не семплируется снова до следующего сброса. Инструкция RESET не влияет на этот бит. Этот бит может быть также установлен или сброшен по программе. |
| 5    | OVLY        | 0                    | Оверлей ОЗУ. OVLY разрешает отобразить встроенное ОЗУ в программное пространство. Величины для OVLY бита:  OVLY = 0 встроенное ОЗУ адресуется в пространстве данных, но не в программном пространстве.  OVLY = 1 встроенное ОЗУ отображено в программном пространстве и пространстве данных.  Страница данных 0 (адреса от 0h до 7Fh), тем не менее, не отображаются в программное пространство.                                                                                                              |
| 4    | AVIS        | 0                    | Мода видимости адреса. AVIS разрешает/запрещает видимость внутреннего программного адреса на контактах адреса.  AVIS = 0 внешние линии адреса не изменяются с внутренним программным адресом. Управляющие сигналы и сигналы данных не воздействуют на шины адреса, передавая последний адрес в шину.  AVIS = 1 эта мода позволяет внутреннему программному адресу появляться на контактах                                                                                                                     |

| Биты | Обозначение | Значние по сбросу | Функция                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|-------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             |                   | микропроцессора, так чтобы внутренний программный адрес мог быть прослежен. Также, это позволяет вектору прерывания быть декодированным вместе с IACK когда векторы прерывания находятся во встроенной памяти.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3    | DROM        | 0                 | ПЗУ данных. DROM разрешает отображать встроенное ПЗУ в пространство данных. Значения для бита DROM: DROM = 0 встроенное ПЗУ не отображено в пространство данных. DROM = 1 часть встроенного ПЗУ отображена в пространство данных. Смотри главу 3, Память, относительно деталей.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2    | CLKOFF      | 0                 | CLOCKOUT OFF. Когда бит CLKOFF в 1, выход CLKOUT запрещен и остается в высокоуровневом состоянии.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1    | SMUL†       | N/A               | Насыщение в умножении. Когда SMUL = 1, насыщение результата умножения происходит перед выполнением накопления в МАС или МАЅ инструкции. Бит SMUL применяется только тогда, когда OVM = 1 и FRCT = 1.  БИТ SMUL позволяет операциям МАС и МАЅ соответствовать базовым операциям МАС и МАЅ определенным в спецификации ETSI GSM (спецификация GSM 6.06,6.10, 6.53). Эффект - в том, что результат 8000h * 8000h насыщается к 7FF FFFFh в случае дробных чисел прежде, чем последующее сложение/вычитание потребуется в МАС или МАЅ инструкциях. В этой моде, инструкция МАС является эквивалентом МРҮ + ADD, когда OVM=1. Если способ не установлен и OVM = 1, результат умножения не насыщен перед выполнением дополнения/ вычитания, только результаты МАС и инструкции МАЅ насыщены. См. пример 4-1 насыщения в действиях умножения.                                         |
| 0    | SST†        | N/A               | Насыщение при хранении. Когда SST в 1, насыщение данных с аккумулятора разрешено перед хранением в памяти. Насыщение выполняется после операции сдвига. Насыщение в загрузке происходит со следующими инструкциями: STH, STL, STLM, DST, ST  ADD, ST  LD, ST  MACR[R], ST  MAS[R], ST  MPY, и ST  SUB. Следующие шаги выполняются, когда используется насыщение при сохранении:  1) 40-Битовая величина данных сдвигается (право или влево) в зависимости от инструкции. Сдвиг такой же, как и описанный в инструкции SFTA и зависит от бита SXM.  2) 40-Битовая величина данных насыщается к 32-битовому значению; насыщение зависит от бита SXM (предполагается, что число всегда положительное). Если SXM = 0, генерируется следующая 32-битовая величина:  • 7FFF FFFFh, если величина больше, чем 7FFF FFFFh.  Если SXM = 1, генерируется следующая 32-битовая величина: |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Биты | Обозначение | Значние<br>по сбросу | Функция                                                                                                                                                                                 |
|------|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             |                      | <ul> <li>7FFF FFFFh, если величина больше, чем 7FFF FFFFh</li> <li>8000 0000h, если величина – меньше чем 8000 0000h</li> </ul>                                                         |
|      |             |                      | 3) Данные загружены в память в зависимости от инструкции. 4) Содержание аккумулятора остается неизменным в течение операции. См. пример 4-2 насыщения на операциях загрузки (хранения). |

# 20 Система команд DSP

#### 20.1 Обзор набора команд

Команды ядра DSP можно распределить по четырем типам операций:

- 1. Арифметические операции;
- 2. Логические операции;
- 3. Операции управления командой;
- 4. Операции загрузки с запоминанием.

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

# 20.1.1 Арифметические операции

Этот раздел включает команды арифметических операций. С таблицах ниже приведены команды следующих функциональных групп:

- 1. Команды сложения (Таблица 20-1);
- 2. Команды вычитания (Таблица 20-2);
- 3. Команды умножения (Таблица 20-3);
- 4. Команды умножения со сложением (Таблица 20-4);
- 5. Команды умножения с вычитанием (Таблица 20-4);
- 6. Команды с двойным операндом (32 бита) (Таблица 20-5);
- 7. Проблемно-ориентированные команды (Таблица 20-6).

Таблица 20-1 – Команды сложения

| Синтаксис                  | Выражение (операция)          | W † | C† | Класс  |
|----------------------------|-------------------------------|-----|----|--------|
| ADD Smem, src              | src = src + Smem              | 1   | 1  | 3A, 3B |
| ADD Smem, TS, src          | src = src + Smem << TS        | 1   | 1  | 3A, 3B |
| ADD Smem, 16,              | dst = src + Smem << 16        | 1   | 1  | 3A, 3B |
| src[, dst]                 |                               |     |    |        |
| ADD Smem [, SHIFT ],       | dst = src + Smem << SHIFT     | 2   | 2  | 4A, 4B |
| src[, dst]                 |                               |     |    |        |
| ADD Xmem, SHFT, src        | src = src + Xmem << SHFT      | 1   | 1  | 3A     |
| ADD Xmem, Ymem, dst        | dst = Xmem << 16 + Ymem << 16 | 1   | 1  | 7      |
| ADD #lk [, SHFT ],         | dst = src + #lk << SHFT       | 2   | 2  | 2      |
| src[, dst]                 |                               |     |    |        |
| ADD #lk, 16, src [ , dst ] | dst = src + #lk << 16         | 2   | 2  | 2      |
| ADD src [, SHIFT][, dst]   | dst = dst + src << SHIFT      | 1   | 1  | 1      |
| ADD src, ASM [ , dst ]     | dst = dst + src << ASM        | 1   | 1  | 1      |
| ADDC Smem, src             | src = src + Smem + C          | 1   | 1  | 3A, 3B |
| ADDM #lk, Smem             | Smem = Smem + #lk             | 2   | 2  | 18A,   |
|                            |                               |     |    | 18B    |
| ADDS Smem, src             | src = src + uns(Smem)         | 1   | 1  | 3A, 3B |

† количество слов (W) и циклов (Ц) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-2 – Команды вычитания

| Синтаксис                            | Выражение (операция)                                                                     | W † | C † | Класс  |
|--------------------------------------|------------------------------------------------------------------------------------------|-----|-----|--------|
| SUB Smem, src                        | src = src - Smem                                                                         | 1   | 1   | 3A, 3B |
| SUB Smem, TS, src                    | src = src - Smem << TS                                                                   | 1   | 1   | 3A, 3B |
| SUB Smem, 16, src [ , dst ]          | dst = src - Smem << 16                                                                   | 1   | 1   | 3A, 3B |
| SUB Smem [ , SHIFT ], src [ , dst ]  | dst = src - Smem << SHIFT                                                                | 2   | 2   | 4A, 4B |
| SUB Xmem, SHFT, src                  | src = src - Xmem << SHFT                                                                 | 1   | 1   | 3A     |
| SUB Xmem, Ymem, dst                  | dst = Xmem << 16 – Ymem << 16                                                            | 1   | 1   | 7      |
| SUB #lk [ , SHFT ],<br>src [ , dst ] | dst = src - #lk << SHFT                                                                  | 2   | 2   | 2      |
| SUB #lk, 16, src [ , dst ]           | dst = src - #lk <<16                                                                     | 2   | 2   | 2      |
| SUB src[ , SHIFT ] [ , dst ]         | dst = dst - src << SHIFT                                                                 | 1   | 1   | 1      |
| SUB src, ASM [ , dst ]               | dst = dst - src << ASM                                                                   | 1   | 1   | 1      |
| SUBB Smem, src                       | src = src - Smem - C                                                                     | 1   | 1   | 3A, 3B |
| SUBC Smem, src                       | If (src – Smem << 15) _ 0<br>src = (src – Smem << 15) << 1 + 1<br>Else<br>src = src << 1 | 1   | 1   | 3A, 3B |
| SUBS Smem, src                       | src = src - uns(Smem)                                                                    | 1   | 1   | 3A, 3B |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-3 – Команды умножения

| Синтаксис           | Выражение (операция)          | W † | C † | Класс  |
|---------------------|-------------------------------|-----|-----|--------|
| MPY Smem, dst       | dst = T * Smem                | 1   | 1   | 3A, 3B |
| MPYR Smem, dst      | dst = rnd(T * Smem)           | 1   | 1   | 3A, 3B |
| MPY Xmem, Ymem, dst | dst = Xmem * Ymem, T = Xmem   | 1   | 1   | 7      |
| MPY Smem, #lk, dst  | dst = Smem * #lk , T = Smem   | 2   | 2   | 6A, 6B |
| MPY #lk, dst        | dst = T * #lk                 | 2   | 2   | 2      |
| MPYA dst            | dst = T * A(32–16)            | 1   | 1   | 1      |
| MPYA Smem           | B = Smem * A(32–16), T = Smem | 1   | 1   | 3A, 3B |
| MPYU Smem, dst      | dst = uns(T) * uns(Smem)      | 1   | 1   | 3A, 3B |
| SQUR Smem, dst      | dst = Smem * Smem, T = Smem   | 1   | 1   | 3A, 3B |
| SQUR A, dst         | dst = A(32–16) * A(32–16)     | 1   | 1   | 1      |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-4 – Команды умножения со сложением и умножения с вычитанием

| Синтаксис                      | Выражение (операция)                                    | W † | C† | Класс       |
|--------------------------------|---------------------------------------------------------|-----|----|-------------|
| MAC Smem, src                  | src = src + T * Smem                                    | 1   | 1  | 3A, 3B      |
| MAC Xmem, Ymem, src [ , dst ]  | dst = src + Xmem * Ymem,<br>T = Xmem                    | 1   | 1  | 7           |
| MAC #lk, src [ , dst ]         | dst = src + T * #lk                                     | 2   | 2  | 2           |
| MAC Smem, #lk, src [ , dst ]   | dst = src + Smem * #lk,<br>T = Smem                     | 2   | 2  | 6A, 6B      |
| MACR Smem, src                 | src = rnd(src + T * Smem)                               | 1   | 1  | 3A, 3B      |
| MACR Xmem, Ymem, src [ , dst ] | dst = rnd(src + Xmem * Ymem),<br>T = Xmem               | 1   | 1  | 7           |
| MACA Smem [, B]                | B = B + Smem * A(32-16),<br>T = Smem                    | 1   | 1  | 3A, 3B      |
| MACA T, src [ , dst ]          | dst = src + T * A(32–16)                                | 1   | 1  | 1           |
| MACAR Smem [, B]               | B = rnd(B + Smem * A(32–16)),<br>T = Smem               | 1   | 1  | 3A, 3B      |
| MACAR T, src [ , dst ]         | dst = rnd(src + T * A(32-16))                           | 1   | 1  | 1           |
| MACD Smem, pmad, src           | src = src + Smem * pmad,<br>T = Smem, (Smem + 1) = Smem | 2   | 3  | 23A,<br>23B |
| MACP Smem, pmad, src           | src = src + Smem * pmad,<br>T = Smem                    | 2   | 3  | 22A,<br>22B |
| MACSU Xmem, Ymem, src          | src = src + uns(Xmem) * Ymem,<br>T = Xmem               | 1   | 1  | 7           |
| MAS Smem, src                  | src = src - T * Smem                                    | 1   | 1  | 3A, 3B      |
| MASR Smem, src                 | src = rnd(src - T * Smem)                               | 1   | 1  | 3A, 3B      |
| MAS Xmem, Ymem, src [ , dst ]  | dst = src - Xmem * Ymem,<br>T = Xmem                    | 1   | 1  | 7           |
| MASR Xmem, Ymem, src [ , dst ] | dst = rnd(src – Xmem * Ymem),<br>T = Xmem               | 1   | 1  | 7           |
| MASA Smem [ , B ]              | B = B - Smem * A(32–16),<br>T = Smem                    | 1   | 1  | 3A, 3B      |
| MASA T, src [ , dst ]          | dst = src - T * A(32-16)                                | 1   | 1  | 1           |
| MASAR T, src [ , dst ]         | dst = rnd(src - T * A(32-16))                           | 1   | 1  | 1           |
| SQURA Smem, src                | src = src + Smem * Smem,<br>T = Smem                    | 1   | 1  | 3A, 3B      |
| SQURS Smem, src                | src = src - Smem * Smem,<br>T = Smem                    | 1   | 1  | 3A, 3B      |

<sup>†</sup> количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-5 – Двухоперандные команды (32 бита)

| Синтаксис                | Выражение (операция)                                                                                                          | W † | C† | Класс  |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----|----|--------|
| DADD Lmem, src [ , dst ] | If C16 = 0<br>dst = Lmem + src<br>If C16 = 1<br>dst(39–16) = Lmem(31–16) + src(31–16)<br>dst(15–0) = Lmem(15–0) + src(15–0)   | 1   | 1  | 9A, 9B |
| DADST Lmem, dst          | If C16 = 0<br>dst = Lmem + (T << 16 + T)<br>If C16 = 1<br>dst(39–16) = Lmem(31–16) + T<br>dst(15–0) = Lmem(15–0) – T          | 1   | 1  | 9A, 9B |
| DRSUB Lmem, src          | If C16 = 0<br>src = Lmem - src<br>If C16 = 1<br>src(39-16) = Lmem(31-16) - src(31-16)<br>src(15-0) = Lmem(15-0) - src(15-0)   | 1   | 1  | 9A, 9B |
| DSADT Lmem, dst          | If C16 = 0<br>dst = Lmem - (T << 16 + T)<br>If C16 = 1<br>dst(39-16) = Lmem(31-16) - T<br>dst(15-0) = Lmem(15-0) + T          | 1   | 1  | 9A, 9B |
| DSUB Lmem, src           | If C16 = 0<br>src = src - Lmem<br>If C16 = 1<br>src (39-16) = src(31-16) - Lmem(31-16)<br>src (15-0) = src(15-0) - Lmem(15-0) | 1   | 1  | 9A, 9B |
| DSUBT Lmem, dst          | If C16 = 0<br>dst = Lmem - (T << 16 + T)<br>If C16 = 1<br>dst(39-16) = Lmem(31-16) - T<br>dst(15-0) = Lmem(15-0) - T          | 1   | 1  | 9A, 9B |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 циклt при использовании длинного смещения в косвенной адресации или абсолютной адресации Lmem.

Таблица 20-6 – Проблемно-ориентированные команды

| Синтаксис             | Выражение (операция)                                   | W † | C† | Класс       |
|-----------------------|--------------------------------------------------------|-----|----|-------------|
| ABDST Xmem, Ymem      | B = B +  A(32-16) <br>A = (Xmem - Ymem) << 16          | 1   | 1  | 7           |
| ABS src [ , dst ]     | dst =  src                                             | 1   | 1  | 1           |
| CMPL src [ , dst ]    | dst = ~src                                             | 1   | 1  | 1           |
| DELAY Smem            | (Smem + 1) = Smem                                      | 1   | 1  | 24A,<br>24B |
| EXP src               | T = number of sign bits (src) – 8                      | 1   | 1  | 1           |
| FIRS Xmem, Ymem, pmad | B = B + A * pmad<br>A = (Xmem + Ymem) << 16            | 2   | 3  | 8           |
| LMS Xmem, Ymem        | B = B + Xmem * Ymem<br>A = A + Xmem << 16 + 215        | 1   | 1  | 7           |
| MAX dst               | dst = max(A, B)                                        | 1   | 1  | 1           |
| MIN dst               | dst = min(A, B)                                        | 1   | 1  | 1           |
| NEG src [ , dst ]     | dst = -src                                             | 1   | 1  | 1           |
| NORM src [ , dst ]    | dst = src << TS<br>dst = norm(src, TS)                 | 1   | 1  | 1           |
| POLY Smem             | B = Smem << 16<br>A = rnd(A(32–16) * T + B)            | 1   | 1  | 3A, 3B      |
| RND src [ , dst ]     | dst = src + 215                                        | 1   | 1  | 1           |
| SAT src               | saturate(src)                                          | 1   | 1  | 1           |
| SQDST Xmem, Ymem      | B = B + A(32–16) * A(32–16)<br>A = (Xmem – Ymem) << 16 | 1   | 1  | 7           |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Lmem.

## 20.1.2 Логические операции

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

- 1. Команды И (AND) (Таблица 20-7);
- 2. Команды ИЛИ (OR) (Таблица 20-8);
- 3. Команды, исключающие ИЛИ (XOR) (Таблица 20-9);
- 4. Команды сдвига (Таблица 20-10);
- 5. Команды тестирования (Таблица 20-11).

Таблица 20-7 – Команды AND

| Синтаксис                            | Выражение (операция)     | W † | C† | Класс       |
|--------------------------------------|--------------------------|-----|----|-------------|
| AND Smem, src                        | src = src & Smem         | 1   | 1  | 3A, 3B      |
| AND #lk [ , SHFT ],<br>src [ , dst ] | dst = src & #lk << SHFT  | 2   | 2  | 2           |
| AND #lk, 16, src [ , dst ]           | dst = src & #lk << 16    | 2   | 2  | 2           |
| AND src [, SHIFT][, dst]             | dst = dst & src << SHIFT | 1   | 1  | 1           |
| ANDM #lk, Smem                       | Smem = Smem & #lk        | 2   | 2  | 18A,<br>18B |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-8 – Команды OR

| Синтаксис                           | Выражение (операция)     | W † | C† | Класс       |
|-------------------------------------|--------------------------|-----|----|-------------|
| OR Smem, src                        | src = src   Smem         | 1   | 1  | 3A, 3B      |
| OR #lk [ , SHFT ],<br>src [ , dst ] | dst = src   #lk << SHFT  | 2   | 2  | 2           |
| OR #lk, 16, src [ , dst ]           | dst = src   #lk << 16    | 2   | 2  | 2           |
| OR src[, SHIFT][, dst]              | dst = dst   src << SHIFT | 1   | 1  | 1           |
| ORM #lk, Smem                       | Smem = Smem   #lk        | 2   | 2  | 18A,<br>18B |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-9 – Команды XOR

| Синтаксис                         | Выражение (операция)     | W † | C† | Класс  |
|-----------------------------------|--------------------------|-----|----|--------|
| XOR Smem, src                     | src = src ^ Smem         | 1   | 1  | 3A, 3B |
| XOR #lk [, SHFT, ], src [ , dst ] | dst = src ^ #lk << SHFT  | 2   | 2  | 2      |
| XOR #lk, 16, src [ , dst ]        | dst = src ^ #lk << 16    | 2   | 2  | 2      |
| XOR src [, SHIFT] [ , dst ]       | dst = dst ^ src << SHIFT | 1   | 1  | 1      |
| XORM #lk, Smem                    | Smem = Smem ^ #lk        | 2   | 2  | 18A,   |
|                                   |                          |     | 2  | 18B    |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-10 – Команды сдвига

| Синтаксис                 | Выражение (операция)                        | W † | C† | Класс |
|---------------------------|---------------------------------------------|-----|----|-------|
| ROL src                   | циклический сдвиг влево через перенос       | 1   | 1  | 1     |
| ROLTC src                 | циклический сдвиг влево через ТС            | 1   | 1  | 1     |
| ROR src                   | циклический сдвиг вправо через<br>перенос   | 1   | 1  | 1     |
| SFTA src, SHIFT [ , dst ] | dst = src << SHIFT {арифметический сдвиг}   | 1   | 1  | 1     |
| SFTC src                  | если src(31) = src(30)<br>то src = src << 1 | 1   | 1  | 1     |
| SFTL src, SHIFT [ , dst ] | dst = src << SHIFT {логический}             | 1   | 1  | 1     |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.

| Синтаксис      | Выражение (операция)   | W † | C† | Класс  |
|----------------|------------------------|-----|----|--------|
| BIT Xmem, BITC | TC = Xmem(15 - BITC)   | 1   | 1  | 3A     |
| BITF Smem, #lk | TC = (Smem && #lk)     | 2   | 2  | 6A, 6B |
| BITT Smem      | TC = Smem(15 - T(3-0)) | 1   | 1  | 3A, 3B |
| CMPM Smem, #lk | TC = (Smem == #lk)     | 2   | 2  | 6A, 6B |
| CMPR CC, ARx   | сравнивает ARx с AR0   | 1   | 1  | 1      |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

# 20.1.3 Команды управления программой

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

- 1. Команды перехода (Таблица 20-12);
- 2. Команды вызова (Таблица 20-13);
- 3. Команды прерывания (Таблица 20-14);
- 4. Команды возврата (Таблица 20-15);
- 5. Команды повторения (Таблица 20-16);
- 6. Команды управления стеком (Таблица 20-17);
- 7. Разные команды управления программой (Таблица 20-18).

Таблица 20-12 – Команды перехода

| Синтаксис                                      | Выражение (операция)                   | W † | C†         | Класс |
|------------------------------------------------|----------------------------------------|-----|------------|-------|
| B[D] pmad                                      | PC = pmad(15-0)                        | 2   | 4/[2¶]     | 29A   |
| BACC[D] src                                    | PC = src(15-0)                         | 1   | 6/[4¶]     | 30A   |
| BANZ[D] pmad, Sind                             | if (Sind _ 0) then PC = pmad(15-<br>0) | 2   | 4‡/2§/[2¶] | 29A   |
| BC[D] pmad, cond<br>[, cond [, cond]]          | if (cond(s)) then PC = pmad(15–0)      | 2   | 5‡/3§/[3¶] | 31A   |
| FB[D] extpmad (в данной модели не реализовано) | PC = pmad(15–0),<br>XPC = pmad(22–16)  | 2   | 4/[2¶]     | 29A   |
| FBACC[D] src (в данной модели не реализовано)  | PC = src(15-0), XPC = src(22-16)       | 1   | 6/[4¶]     | 30A   |

<sup>†</sup> количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.

<sup>‡</sup> условие истинно.

<sup>§</sup> условие ложно.

<sup>¶</sup> задержанная команда.

Таблица 20-13 – Команды вызова

| Синтаксис                   | Выражение (операция)             | W † | C†         | Класс |
|-----------------------------|----------------------------------|-----|------------|-------|
| CALA[D] src                 | $SP, PC + 1[3\P] = TOS,$         | 1   | 6/[4¶]     | 30B   |
|                             | PC = src(15-0)                   | ı   | 0/[4]]     | מטכ   |
| CALL[D] pmad                | $SP, PC + 2[4\P] = TOS,$         | 2   | 4/[2§]     | 29B   |
|                             | PC = pmad(15-0)                  | ۷   | 4/[28]     | 290   |
| CC[D] pmad, cond [, cond [, | if (cond(s)) then – –SP,         |     |            |       |
| cond ]]                     | $PC + 2[4\P] = TOS,$             | 2   | 5‡/3§/[3¶] | 31B   |
|                             | PC = pmad(15-0)                  |     |            |       |
| FCALA[D] src (в данной      | $SP, PC + 1 [3\P] = TOS,$        | 1   | 6/[4¶]     | 30B   |
| модели не реализовано)      | PC = src(15-0), XPC = src(22-16) | ı   | 0/[4]]]    | 300   |
| FCALL[D] extpmad            | $SP, PC + 2[4\P] = TOS,$         |     |            |       |
| (в данной модели не         | PC = pmad(15-0),                 | 2   | 4/[2¶]     | 29B   |
| реализовано)                | XPC = pmad(22-16)                |     |            |       |

- † количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.
  - ‡ условие истинно.
  - § условие ложно.
  - ¶ задержанная команда.

Таблица 20-14 – Команды прерывания

| Синтаксис | Выражение (операция)                                      | W † | C† | Класс |
|-----------|-----------------------------------------------------------|-----|----|-------|
| INTR K    | SP, ++ PC = TOS,<br>PC = IPTR(15-7) + K << 2,<br>INTM = 1 | 1   | 3  | 35    |
| TRAP K    | SP, + + PC = TOS,<br>PC = IPTR(15-7) + K << 2             | 1   | 3  | 35    |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.

Таблица 20-15 – Команды возврата

| Синтаксис              | Выражение (операция)             | W † | C†         | Класс          |
|------------------------|----------------------------------|-----|------------|----------------|
|                        | XPC = TOS, ++ SP, PC = TOS,      | 1   | 6/[4¶]     | 34             |
| не реализовано)        | ++SP                             | ı   | 0/[+  ]    | <del>5 1</del> |
| FRETE[D] (в данной     | XPC = TOS, ++ SP, PC = TOS,      | 4   | 6/[4¶]     | 34             |
| модели не реализовано) | ++SP, $INTM = 0$                 | I   | 0/[4]]]    | 34             |
| RC[D] cond             | if (cond(s)) then PC = TOS, ++SP | 4   | E+/36/E3@I | 22             |
| [, cond [, cond]]      |                                  | I   | 5‡/3§/[3¶] | 32             |
| RET[D]                 | PC = TOS, ++SP                   | 1   | 5/[3¶]     | 32             |
| RETE[D]                | PC = TOS, ++SP, INTM = 0         | 1   | 5/[3¶]     | 32             |
| RETF[D]                | PC = RTN, ++SP, INTM = 0         | 1   | 3/[1¶]     | 33             |

- † количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.
  - ‡ условие истинно.
  - § условие ложно.
  - ¶ задержанная команда.

Таблица 20-16 – Команды повторения

| Синтаксис     | Выражение (операция)                                    | W † | C †    | Класс  |
|---------------|---------------------------------------------------------|-----|--------|--------|
| RPT Smem      | Repeat single, RC = Smem                                | 1   | 3      | 5A, 5B |
| RPT #K        | Repeat single, RC = #K                                  | 1   | 1      | 1      |
| RPT #lk       | Repeat single, RC = #lk                                 | 2   | 2      | 2      |
| RPTB[D] pmad  | Repeat block, RSA = PC + 2[4¶],<br>REA = pmad, BRAF = 1 | 2   | 4/[2¶] | 29A    |
| RPTZ dst, #lk | Repeat single, RC = #lk, dst = 0                        | 2   | 2      | 2      |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

¶ задержанная команда

Таблица 20-17 – Команды управления стеком

| Синтаксис | Выражение (операция) | W † | C†  | Класс |
|-----------|----------------------|-----|-----|-------|
| FRAME K   | SP = SP + K          | 1   | 1   | 1     |
| POPD Smem | Smem = TOS, ++SP     | 1   | 4   | 17A,  |
|           |                      | 1   | l I | 17B   |
| POPM MMR  | MMR = TOS, ++SP      | 1   | 1   | 17A   |
| PSHD Smem | SP, Smem = TOS       | 1   | 1   | 16A,  |
|           |                      | 1   | l I | 16B   |
| PSHM MMR  | −−SP, MMR = TOS      | 1   | 1   | 16A   |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-18 – Разные команды управления программой

| Синтаксис                       | Выражение (операция)                                                                                                            | W † | C † | Класс |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------|
| IDLE K                          | idle(K)                                                                                                                         | 1   | 4   | 36    |
| MAR Smem                        | If CMPT = 0, then modify ARx If CMPT = 1 and ARx _ AR0, then modify ARx, ARP = x If CMPT = 1 and ARx = AR0, then modify AR(ARP) | 1   | 1   | 1,2   |
| NOP                             | no operation                                                                                                                    | 1   | 1   | 1     |
| RESET                           | software reset                                                                                                                  | 1   | 3   | 35    |
| RSBX N, SBIT                    | STN (SBIT) = 0                                                                                                                  | 1   | 1   | 1     |
| SSBX N, SBIT                    | STN (SBIT) = 1                                                                                                                  | 1   | 1   | 1     |
| XC n , cond [ , cond [ , cond ] | If (cond(s)) then execute the next n instructions; n = 1 or 2                                                                   | 1   | 1   | 1     |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 циклt при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

#### 20.1.4 Команды загрузки и сохранения

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

- 1. Команды загрузки (Таблица 20-19);
- 2. Команды сохранения (Таблица 20-20);
- 3. Команды условного сохранения (Таблица 20-21);
- 4. Команды параллельной загрузки и сохранения (Таблица 20-22);
- 5. Команды параллельной загрузки и умножения (Таблица 20-23);
- 6. Команды параллельного сохранения и сложения/вычитания (Таблица 20-24);
- 7. Команды параллельного сохранения и умножения (Таблица 20-25);
- 8. Разные команды типа загрузки и сохранения (Таблица 20-26).

Таблица 20-19 – Команды загрузки

| Синтаксис                | Выражение (операция)        | W † | C† | Класс       |
|--------------------------|-----------------------------|-----|----|-------------|
| DLD Lmem, dst            | dst = Lmem                  | 1   | 1  | 9A, 9B      |
| LD Smem, dst             | dst = Smem                  | 1   | 1  | 3A, 3B      |
| LD Smem, TS, dst         | dst = Smem << TS            | 1   | 1  | 3A, 3B      |
| LD Smem, 16, dst         | dst = Smem << 16            | 1   | 1  | 3A, 3B      |
| LD Smem [ , SHIFT ], dst | dst = Smem << SHIFT         | 2   | 2  | 4A, 4B      |
| LD Xmem, SHFT, dst       | dst = Xmem << SHFT          | 1   | 1  | 3A          |
| LD #K, dst               | dst = #K                    | 1   | 1  | 1           |
| LD #lk [ , SHFT ], dst   | dst = #lk << SHFT           | 2   | 2  | 2           |
| LD #lk, 16, dst          | dst = #lk << 16             | 2   | 2  | 2           |
| LD src, ASM [ , dst ]    | dst = src << ASM            | 1   | 1  | 1           |
| LD src [ , SHIFT ], dst  | dst = src << SHIFT          | 1   | 1  | 1           |
| LD Smem, T               | T = Smem                    | 1   | 1  | 3A, 3B      |
| LD Smem, DP              | DP = Smem(8-0)              | 1   | 3  | 5A, 5B      |
| LD Smem, DP              | DP = #k9                    | 1   | 1  | 1           |
| LD #k5, ASM              | ASM = #k5                   | 1   | 1  | 1           |
| LD #k3, ARP              | ARP = #k3                   | 1   | 1  | 1           |
| LD Smem, ASM             | ASM = Smem(4-0)             | 1   | 1  | 3A, 3B      |
| LDM MMR, dst             | dst = MMR                   | 1   | 1  | 3A          |
| LDR Smem, dst            | dst = rnd(Smem)             | 1   | 1  | 3A, 3B      |
| LDU Smem, dst            | dst = uns(Smem)             | 1   | 1  | 3A, 3B      |
| LTD Smem                 | T = Smem, (Smem + 1) = Smem | 1   | 1  | 24A,<br>24B |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem или Lmem.

Таблица 20-20 – Команды сохранения

| Синтаксис                 | Выражение (операция)       | W † | C† | Класс       |
|---------------------------|----------------------------|-----|----|-------------|
| DST src, Lmem             | Lmem = src                 | 1   | 2  | 13A,<br>13B |
| ST T, Smem                | Smem = T                   | 1   | 1  | 10A,<br>10B |
| ST TRN, Smem              | Smem = TRN                 | 1   | 1  | 10A,<br>10B |
| ST #lk, Smem              | Smem = #lk                 | 2   | 2  | 12A,<br>12B |
| STH src, Smem             | Smem = src << -16          | 1   | 1  | 10A,<br>10B |
| STH src, ASM, Smem        | Smem = src << (ASM - 16)   | 1   | 1  | 10A,<br>10B |
| STH src, SHFT, Xmem       | Xmem = src << (SHFT - 16)  | 1   | 1  | 10A         |
| STH src [ , SHIFT ], Smem | Smem = src << (SHIFT – 16) | 2   | 2  | 11A,<br>11B |
| STL src, Smem             | Smem = src                 | 1   | 1  | 10A,<br>10B |
| STL src, ASM, Smem        | Smem = src << ASM          | 1   | 1  | 10A,<br>10B |
| STL src, SHFT, Xmem       | Xmem = src << SHFT         | 1   | 1  | 10A,<br>10B |
| STL src [ , SHIFT ], Smem | Smem = src << SHIFT        | 2   | 2  | 11A,<br>11B |
| STLM src, MMR             | MMR = src                  | 1   | 1  | 10A         |
| STM #lk, MMR              | MMR = #lk                  | 2   | 2  | 12A         |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem или Lmem.

Таблица 20-21 – Команды условного сохранения

| Синтаксис             | Выражение (операция)                                                                                      | W † | C† | Класс       |
|-----------------------|-----------------------------------------------------------------------------------------------------------|-----|----|-------------|
| CMPS src, Smem        | If src(31–16) > src(15–0) then<br>Smem = src(31–16)<br>If src(31–16) _ src(15–0) then<br>Smem = src(15–0) | 1   | 1  | 10A,<br>10B |
| SACCD src, Xmem, cond | If (cond) Xmem = src << (ASM - 16)                                                                        | 1   | 1  | 15          |
| SRCCD Xmem, cond      | If (cond) Xmem = BRC                                                                                      | 1   | 1  | 15          |
| STRCD Xmem, cond      | If (cond) Xmem = T                                                                                        | 1   | 1  | 15          |

† количество слов (W) и циклов (Ц) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

Таблица 20-22 – Команды параллельной загрузки и сохранения

| Синтаксис    | Выражение (операция)     | W † | C† | Класс |
|--------------|--------------------------|-----|----|-------|
| ST src, Ymem | Ymem = src << (ASM _ 16) | 1   | 1  | 14    |
| LD Xmem, dst | dst = Xmem << 16         | 1   | 1  | 14    |
| ST src, Ymem | Ymem = src << (ASM - 16) | 1   | 4  | 14    |
| LD Xmem, T   | T = Xmem                 | 1   | ı  | 14    |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.

Таблица 20-23 – Команды параллельной загрузки и умножения

| Синтаксис       | Выражение (операция)        | W † | C† | Класс |
|-----------------|-----------------------------|-----|----|-------|
| LD Xmem, dst    | dst = Xmem << 16            | 1   | 1  | 7     |
| MAC Ymem, dst_  | dst_ = dst_ + T * Ymem      | ı   |    | ,     |
| LD Xmem, dst    | dst = Xmem << 16            | 1   | 1  | 7     |
| MACR Ymem, dst_ | dst_ = rnd(dst_ + T * Ymem) | '   |    |       |
| LD Xmem, dst    | dst = Xmem << 16            | 1   | 1  | 7     |
| MAS Ymem, dst_  | dst_ = dst T * Ymem         | '   |    |       |
| LD Xmem, dst    | dst = Xmem << 16            | 1   |    | 7     |
| MASR Ymem, dst_ | dst_ = rnd(dst T * Ymem)    | ı   |    | /     |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.

Таблица 20-24 – Команды параллельного сохранения и сложения/вычитания

| Синтаксис     | Выражение (операция)      | W † | C† | Класс |
|---------------|---------------------------|-----|----|-------|
| ST src, Ymem  | Ymem = src << (ASM _ 16)  | 1   | 1  | 14    |
| ADD Xmem, dst | dst = dst_ + Xmem << 16   | '   |    |       |
| ST src, Ymem  | Ymem = src << (ASM - 16)  | 1   | 1  | 14    |
| SUB Xmem, dst | dst = (Xmem << 16) - dst_ | '   |    |       |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.

Таблица 20-25 – Команды параллельного сохранения и умножения

| Синтаксис      | Выражение (операция)      | W † | C†       | Класс |
|----------------|---------------------------|-----|----------|-------|
| ST src, Ymem   | Ymem = src << (ASM - 16)  | 1   | 1        | 14    |
| MAC Xmem, dst  | dst = dst + T * Xmem      |     |          |       |
| ST src, Ymem   | Ymem = src << (ASM - 16)  | 1   | 1        | 14    |
| MACR Xmem, dst | dst = rnd(dst + T * Xmem) | I   |          |       |
| ST src, Ymem   | Ymem = src << (ASM - 16)  | 1   | 1        | 14    |
| MAS Xmem, dst  | dst = dst - T * Xmem      |     |          |       |
| ST src, Ymem   | Ymem = src << (ASM - 16)  | 1   | 1        | 14    |
| MASR Xmem, dst | dst = rnd(dst - T * Xmem) |     |          |       |
| ST src, Ymem   | Ymem = src << (ASM - 16)  | 1   | 1        | 14    |
| MPY Xmem, dst  | dst = T * Xmem            | l   | <b> </b> | 14    |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных.

Таблица 20-26 – Разные программы типа загрузки и сохранения

| Синтаксис       | Выражение (операция) | W † | C†       | Класс |
|-----------------|----------------------|-----|----------|-------|
| MVDD Xmem, Ymem | Ymem = Xmem          | 1   | 1        | 14    |
| MVDK Smem, dmad | dmad = Smem          | 2   | 2        | 19A,  |
|                 |                      |     |          | 19B   |
| MVDM dmad, MMR  | MMR = dmad           | 2   | 2        | 19A   |
| MVDP Smem, pmad | pmad = Smem          | 2   | 4        | 20A,  |
|                 |                      |     | 4        | 20B   |
| MVKD dmad, Smem | Smem = dmad          | 2   | 2        | 19A,  |
|                 |                      |     | 2        | 19B   |
| MVMD MMR, dmad  | dmad = MMR           | 2   | 2        | 19A   |
| MVMM MMRx, MMRy | MMRy = MMRx          | 1   | 1        | 1     |
| MVPD pmad, Smem | Smem = pmad          | 2   | 3        | 21A,  |
|                 |                      |     | <b>5</b> | 21B   |
| PORTR PA, Smem  | Smem = PA            | 2   | 2        | 27A,  |
|                 |                      |     | ۷        | 27B   |
| PORTW Smem, PA  | PA = Smem            | 2   | 2        | 28A,  |
|                 |                      | 2   | 2        | 28B   |
| READA Smem      | Smem = A             | 1   | 5        | 25A,  |
|                 |                      | l l | 5        | 25B   |
| WRITA Smem      | A = Smem             | 1   | 5        | 26A,  |
|                 |                      | ı   | ວ        | 26B   |

† количество слов (W) и циклов (C) соответствуют использованию расслоенной RAM для данных, когда обмен адресуется к разным блокам данных. Добавляется 1 слово и 1 цикл при использовании длинного смещения в косвенной адресации или абсолютной адресации Smem.

## 20.1.5 Повторения одной команды

Процессор имеет команды повторения, которые заставляют следующую команду повториться нужное число раз. Количество повторений команды равно значению операнда команды повторения + 1. Это значение сохраняется в 16-разрядном регистре счетчика повторении (RC). Невозможно запрограммировать значение в регистре RC, оно загружается исключительно командами повторения. Максимальное число повторений команды — 65 536. Абсолютный адрес памяти программ или данных автоматически увеличивается при каждом повторении команды.

Как только команда повторения декодирована, все прерывания, включая NMI, но не RS, заблокированы до завершения цикла повторения. Однако процессор реагирует на сигнал HOLD при выполнении цикла повторения в соответствии со значением бита HM в регистре состояния 1 (ST1).

Функция повторения может использоваться с некоторыми командами типа умножение/накопление и блочные пересылки, для увеличения скорости выполнения этих команд. Эти многоцикловые команды (Таблица 20-27) становятся одноцикловыми после первой итерации команды повторения.

Таблица 20-27 – Многоцикловые команды, выполняемые за один цикл при повторении

| Команда | Описание                | # Циклы † |
|---------|-------------------------|-----------|
| FIRS    | симметричный FIR-фильтр | 3         |

| Команда | Описание                                  | # Циклы † |
|---------|-------------------------------------------|-----------|
| MACD    | умножаются с аккумулированием и задержкой | 3         |
| MACP    | умножаются с аккумулированием             | 3         |
| MVDK    | пересылка данные-данные                   | 2         |
| MVDM    | пересылка данные-регистры MMR             | 2         |
| MVDP    | пересылка данные-программа                | 4         |
| MVKD    | персылка данные-данные                    | 2         |
| MVMD    | пресылка регистры MMR - данные            | 2         |
| MVPD    | пересылка программа-данные                | 3         |
| READA   | чтение из памяти программ в память данных | 5         |
| WRITA   | запись из памяти данных в память программ | 5         |

<sup>†</sup> число циклов, когда команда не повторяется

Отдельные команды одного операнда в памяти данных не могут быть повторены при использовании длинного смещения или абсолютного адреса (например, \*ARn(lk), \*+ARn(lk), \*+ARn(lk)% и \*(lk)). Таблица 20-28 содержит команды, которые не могут быть повторены командами RPT или RPTZ.

Таблица 20-28 – Неповторяемые команды

| Команда  | Описание                                                                |
|----------|-------------------------------------------------------------------------|
| ADDM     | прибавить длинную константу к памяти данных                             |
| ANDM     | AND память данных с длинной константой                                  |
| B[D]     | безусловный переход                                                     |
| BACC[D]  | переход по адресу из аккумулятора                                       |
| BANZ[D]  | переход по вспомогательному регистру не равному 0                       |
| BC[D]    | условный переход                                                        |
| CALA[D]  | вызов подпрограммы по адресу из аккумулятора                            |
| CALL[D]  | безусловный вызов                                                       |
| CC[D]    | условный вызов                                                          |
| CMPR     | сравнение вспомогательных регистров                                     |
| DST      | сохранение длинного слова (32-бита)                                     |
| FB[D]    | дальний безусловный переход (в данной модели не реализовано)            |
| FBACC[D] | дальний переход по адресу из аккумулятора(в данной модели не            |
|          | реализовано)                                                            |
| FCALA[D] | дальний вызов подпрограммы по адресу из аккумулятора                    |
|          | (в данной модели не реализовано)                                        |
| FCALL[D] | дальний безусловный вызов (в данной модели не реализовано)              |
| FRET[D]  | дальний возврат(в данной модели не реализовано)                         |
| FRETE[D] | разрешение прерывания и дальний возврат(в данной модели не реализовано) |
| IDLE     | команда ожидания                                                        |
| INTR     | прерывание                                                              |
| LD ARP   | загрузка указателя вспомогательного регистра (ARP)                      |
| LD DP    | загрузка указателя страницы данных (DP)                                 |
| MVMM     | пересылка регистров, отображаемых на память (MMR)                       |
| ORM      | OR память данных с длинной константой                                   |
| RC[D]    | условный возврат                                                        |
| RESET    | программный сброс                                                       |
| RET[D]   | безусловный возврат                                                     |
| RETE[D]  | возврат из прерывания                                                   |
| RETF[D]  | быстрый возврат из прерывания                                           |
| RND      | округление аккумулятора                                                 |

| Команда | Описание                                            |
|---------|-----------------------------------------------------|
| RPT     | повторение следующей команды                        |
| RPTB[D] | повторение блока                                    |
| RPTZ    | повторение следующей команды и очистка аккумулятора |
| RSBX    | сброс бита статусного регистра                      |
| SSBX    | установка бита статусного регистра                  |
| TRAP    | программное прерывание                              |
| XC      | условное выполнение команды                         |
| XORM    | XOR память данных с длинной константой              |

## 20.2 Классы и циклы команд

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

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

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

**ROM** команды выполняется из внутреннего ПЗУ программ (ROM);

**RAM** команда выполняется из внутреннего ОЗУ данных (RAM);

External команда выполняется из внешней памяти программ.

Если класс команды требует наличие операнда(ов) памяти, то расположение операнда(ов) указывается в строках таблицы. Эти расположения определяются следующим образом:

**RAM** операнд(ы) имеет доступ к одной (двум) внутренним ячейкам в ОЗУ;

**DROM** операнд во внутренней памяти данных ПЗУ;

**PROM** операнд во внутренней памяти программ;

External операнд во внешней памяти:

**MMR** операнд является регистром, отображаемым в памяти.

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

- **d** состояния ожидания памяти данных количество дополнительных циклов, которое устройство ожидает для получения разрешения доступа к внешней ячейке памяти данных;
- **io** состояние ожидания ввода/вывода количество дополнительных циклов, которое устройство ожидает для получения разрешения доступа к внешнему вводу-выводу;
  - **n** повторения количество выполнений повторяющейся команды;
  - **nd** состояние ожидания памяти данных, повторяющееся n раз;
  - **пр** состояние ожидания памяти программ, повторяющееся n раз;
  - **npd** состояние ожидания памяти программ и данных, повторяющееся n раз;
- **р** состояния ожидания памяти программ количество дополнительных циклов, которое устройство ожидает для получения разрешения доступа к внешней ячейке памяти программ;
- **pd** состояния ожидания памяти программ количество дополнительных циклов, которое устройство ожидает для получения разрешения доступа к операнду памяти программ.

Эти переменные могут также использовать нижние индексы src, dst и code, чтобы обозначить источник, пункт назначения и код, соответственно.

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

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

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

Это возможно, потому что конвейер выполнения команд занимает только один цикл запроса доступа записи во внешнюю память, а блок интерфейса шины завершает ответ на доступ к записи немедленно. Запрос на запись фиксируется и в дальнейшем завершается.

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

Количество циклов выполнения команд получается при следующих допущениях:

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

He рассматриваются любые конфликты по данным, вызванные конвейерным выполнением команды (например, типа RAW-read after write).

## Класс 1

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

## Мнемоника:

| ABS             | MACA[R] | NORM  | SFTA |
|-----------------|---------|-------|------|
| ADD             | MAR     | OR    | SFTC |
| AND             | MASA[R] | RND   | SFTL |
| CMPL            | MAX     | ROL   | SQUR |
| CMPR            | MIN     | ROLTC | SSBX |
| EXP             | MPYA    | ROR   | SUB  |
| FRAME           | MVMM    | RPT   | XC   |
| LD              | NEG     | RSBX  | XOR  |
| LD T/DP/ASM/ARP | NOP     | SAT   |      |

## Циклы

## Циклы единичного выполнения

|     | Програм | ма       |  |
|-----|---------|----------|--|
| ROM | RAM     | External |  |
| 1   | 1       | 1+p      |  |

## Циклы повторяющихся выполнений

|     | Програм | <b>і</b> ма |
|-----|---------|-------------|
| ROM | RAM     | External    |
| n   | n       | n+p         |

## Класс 2

2 слова, 2 цикла. Длинный непосредственный операнд и отсутствие операндов памяти.

#### Мнемоника:

| ADD | MAC | OR   | SUB |
|-----|-----|------|-----|
| AND | MAR | RPT  | XOR |
| I D | MPY | RPT7 |     |

## Циклы

## Циклы единичного выполнения

| Программа |     |          |  |
|-----------|-----|----------|--|
| ROM       | RAM | External |  |
| 2         | 2   | 2+2p     |  |

| Программа |     |          |  |
|-----------|-----|----------|--|
| ROM       | RAM | External |  |
| n+1       | n+1 | n+1+2p   |  |

## Класс ЗА

1 слово, 1 цикл. Операнд чтения в памяти данных (Smem или Xmem) или операнд чтения MMR.

## Мнемоника:

| ADD             | LDM     | MPYA  | SUBB |
|-----------------|---------|-------|------|
| ADDC            | LDR     | MPYU  | SUBC |
| ADDS            | LDU     | OR    | SUBS |
| AND             | MAC[R]  | POLY  | XOR  |
| BIT             | MACA[R] | SQUR  |      |
| BITT            | MAS[R]  | SQURA |      |
| LD              | MASA    | SQURS |      |
| LD T/DP/ASM/ARP | MPY[R]  | SUB   |      |

## Циклы

## Циклы единичного выполнения

| Операнд  | Программа |      |          |
|----------|-----------|------|----------|
| Smem     | ROM       | RAM  | External |
| RAM      | 1         | 1,2† | 1+p      |
| DROM     | 2         | 1    | 1+p      |
| External | 1+d       | 1+d  | 2+d+p    |
| MMR      | 1         | 1    | 1+p .    |

<sup>†</sup> операнд и код в одном блоке памяти.

## Циклы повторяющихся выполнений

| Операнд  | Программа |         |          |
|----------|-----------|---------|----------|
| Smem     | ROM       | RAM     | External |
| RAM      | n         | n, n+1† | n+p      |
| DROM     | n+1       | n       | n+p      |
| External | n+nd      | n+nd    | n+1+nd+p |
| MMR      | n         | n       | n+p      |

<sup>†</sup> операнд и код в одном блоке памяти.

# Класс 3В

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem), использущий косвенную адресацию с длинным смещением.

#### Мнемоника:

| ADD             | LDU     | OR       | SUBS |
|-----------------|---------|----------|------|
| ADDC            | MAC[R]  | POLY XOR |      |
| ADDS            | MACA[R] | SQUR     |      |
| AND             | MAS[R]  | SQURA    |      |
| BITT            | MASA    | SQURS    |      |
| LD              | MPY[R]  | SUB      |      |
| LD T/DP/ASM/ARP | MPYA    | SUBB     |      |
| LDR             | MPYU    | SUBC     |      |

## Циклы

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  | Операнд Программа |       | ма       |
|----------|-------------------|-------|----------|
| Smem     | ROM               | RAM   | External |
| RAM      | 2                 | 2, 3† | 2+2p     |
| DROM     | 3                 | 2     | 2+2p     |
| External | 2+d               | 2+d   | 3+d+2p   |
| MMR      | 2                 | 2     | 2+2p     |

<sup>†</sup> операнд и код в одном блоке памяти.

## Класс 4А

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem).

## Мнемоника:

ADD

LD

**SUB** 

## Циклы

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

|          |     | · · · · · · · · · · · · · · · · · · · |          |
|----------|-----|---------------------------------------|----------|
| Операнд  |     | Програмі                              | ма       |
| Smem     | ROM | RAM                                   | External |
| RAM      | 2   | 2, 3†                                 | 2+2p     |
| DROM     | 3   | 2                                     | 2+2p     |
| External | 2+d | 2+d                                   | 3+d+2p   |
| MMR      | 2   | 2                                     | 2+2p     |

<sup>†</sup> операнд и код в одном блоке памяти.

## Циклы повторяющихся выполнений

| Операнд  | Программа |           |           |
|----------|-----------|-----------|-----------|
| Smem     | ROM       | RAM       | External  |
| RAM      | n+1       | n+1, n+2† | n+1+2p    |
| DROM     | n+2       | n+1       | n+1+2p    |
| External | n+1+nd    | n+1+nd    | n+2+nd+2p |
| MMR      | n+1       | n+1       | n+1+2p    |

<sup>†</sup> операнд и код в одном блоке памяти.

## Класс 4В

3 слова, 3 цикла. Операнд чтения в памяти данных (Smem) с использованием косвенной адресации с длинным смещением.

#### Мнемоника:

ADD

LD

SUB

# Циклы

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  | Программа |       |          |
|----------|-----------|-------|----------|
| Smem     | ROM       | RAM   | External |
| RAM      | 3         | 3, 4† | 3+3p     |
| DROM     | 4         | 3     | 3+3p     |
| External | 3+d       | 3+d   | 4+d+3p   |
| MMR      | 3         | 3     | 3+3p     |

† операнд и код в одном блоке памяти.

## Класс 5А

1 слово, 1 цикл. Операнд чтения в памяти данных (Smem) (с назначением в качестве приёмника регистра указателя страницы памяти данных – DP).

#### Мнемоника:

LD

## Циклы

## Циклы единичного выполнения

| Операнд  | ранд Программа |     | ма       |
|----------|----------------|-----|----------|
| Smem     | ROM            | RAM | External |
| RAM      | 1              | 1   | 1+p      |
| DROM     | 2              | 1   | 1+p      |
| External | 1+d            | 1+d | 2+d+p    |
| MMR      | 1              | 1   | 1+p      |

## Класс 5В

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem) с использованием косвенной адресации с длинным смещением (с назначением в качестве приёмника регистра указателя страницы памяти данных – DP).

## Мнемоника:

LD

# Циклы

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  | Программа |      |          |
|----------|-----------|------|----------|
| Smem     | ROM       | RAM  | External |
| RAM      | 2         | 2,3† | 2+2p     |
| DROM     | 3         | 2    | 2+2p     |
| External | 2+d       | 2+d  | 3+d+2p   |
| MMR      | 2         | 2    | 2+2p     |

† операнд и код в одном блоке памяти.

## Класс 6А

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem) и операнд с длинным непосредственным значением.

## Мнемоника:

BITF

CMPM

MAC

MPY

## Циклы

## Циклы единичного выполнения

| Операнд  |     | Программа |          |
|----------|-----|-----------|----------|
| Smem     | ROM | RAM       | External |
| RAM      | 2   | 2, 3†     | 2+2p     |
| DROM     | 3   | 2         | 2+2p     |
| External | 2+d | 2+d       | 3+d+2p   |
| MMR      | 2   | 2         | 2+2p     |

<sup>†</sup> операнд и код в одном блоке памяти.

## Циклы повторяющихся выполнений

| Операнд  |        | Программа |           |  |
|----------|--------|-----------|-----------|--|
| Smem     | ROM    | RAM       | External  |  |
| RAM      | n+1    | n+1, n+2† | n+1+2p    |  |
| DROM     | n+2    | n+1       | n+1+2p    |  |
| External | n+1+nd | n+1+nd    | n+2+nd+2p |  |
| MMR      | n+1    | n+1       | n+1+2p    |  |

<sup>†</sup> операнд и код в одном блоке памяти.

#### Класс 6В

3 слова, 3 цикла. Операнд чтения в памяти данных (Smem), использущий косвенную адресацию с длинным смещением и операнд с длинным непосредственным значением.

## Мнемоника:

**BITF** 

CMPM

MAC

MPY

#### Циклы

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд<br>Smem |     | Програм | ма       |
|-----------------|-----|---------|----------|
|                 | ROM | RAM     | External |
| RAM             | 3   | 3, 4†   | 3+3p     |
| DROM            | 4   | 3       | 3+3p     |
| External        | 3+d | 3+d     | 4+d+3p   |
| MMR             | 3   | 3       | 3+3p     |

## Класс 7

1 слово, 1 цикл. Операнды двойного чтения в памяти данных (Хтет и Утет).

### Мнемоника:

ABDST LD||MAS[R] MACSU SQDST
ADD LMS MAS[R] SUB
LD||MAC[R] MPY

## Циклы

### Циклы единичного выполнения

| Оп       | еранд    | Программа            |                     |          |
|----------|----------|----------------------|---------------------|----------|
| Xmem     | Ymem     | ROM                  | RAM                 | External |
| RAM      | RAM      | 1, 2¤                | 1, 2†,3‡            | 1+p, 2*  |
|          | DROM     | 2                    | 1,2†                | 1+p      |
|          | External | 1+d                  | 1+d, 2 <sup>∥</sup> | 2+d+p    |
| DROM     | RAM      | 2                    | 1, 2†               | 1+p      |
|          | DROM     | 3                    | 2                   | 1+p, 2*  |
|          | External | 1+d, 2 <sup>  </sup> | 1+d                 | 2+d+p    |
| External | RAM      | 1+d                  | 1+d,2†              | 2+d+p    |
|          | DROM     | 1+d, 2 <sup>  </sup> | 1+d                 | 2+d+p    |
|          | External | 2+2d                 | 2+2d                | 3+2d+p   |
| MMR      | RAM      | 1                    | 1,2†                | 1+p      |
|          | DROM     | 2                    | 1                   | 1+p      |
|          | External | 1+d                  | 1+d                 | 2+d+p    |

<sup>¤</sup> Операнды в одном блоке памяти

| Оп       | еранд       |                                | Программа            |                                 |
|----------|-------------|--------------------------------|----------------------|---------------------------------|
| Xmem     | Ymem        | ROM                            | RAM                  | External                        |
| RAM      | RAM         | n, 2n#                         | n, 2n#,2n+1‡         | n+p, 2n (p=0)#,<br>2n-1+p(p≥1)# |
|          | DROM        | n+1                            | n,n+1†               | n+p                             |
|          | External    | n+nd                           | n+nd,n+nd+1†         | n+nd+1+p                        |
| DROM     | RAM         | n+1†                           | n+1†                 | n+p                             |
|          | DROM        | 2n+1                           | 2n                   | 2n (p=0),<br>2n-1+p(p≥1)        |
|          | External    | n+nd+1                         | n+nd                 | n+nd+1+p                        |
| External | RAM<br>DROM | n+nd<br>n+nd(d≠0),<br>n+1(d=0) | n+nd,n+nd+1†<br>n+nd | n+nd+1+p<br>n+nd+1+p            |
|          | External    | 2n+2nd <sup>′</sup>            | 2n+2nd               | 2n+2nd+1+p                      |
| MMR      | RAM         | n                              | n,n+1†               | n+p                             |
|          | DROM        | n+1                            | n                    | n+p                             |
|          | External    | n+nd                           | n+nd                 | n+nd+1+p                        |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>∥</sup> операнд и код в одном блоке памяти при d=0.

<sup>\*</sup>два операнда в одном блоке памяти при p=0.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 8

2 слова, 3 цикла. Операнды двойного чтения в памяти данных (Xmem и Ymem) и операнд в памяти программ единичного доступа (pmad).

## Мнемоника:

**FIRS** 

# Циклы

Циклы единичного выполнения

|          | Операнд  |          |                       | Программа             |                       |
|----------|----------|----------|-----------------------|-----------------------|-----------------------|
| pmad     | Xmem     | Ymem     | ROM                   | RAM                   | External              |
| RAM      | RAM      | RAM      | 2†,3§                 | 3, 4†                 | 2+p, 3+p†             |
|          |          | DROM     | 2                     | 2, 3†                 | 2+p, 3+p†             |
|          |          | External | 1+d, 2+d†             | 2+d,3+d†              | 2+d+p                 |
|          | DROM     | RAM      | 2                     | 2, 3†                 | 2+p,3+p†              |
|          |          | DROM     | 3                     | 2                     | 2+p                   |
|          |          | External | 2+d                   | 2+d                   | 2+d+p                 |
|          | External | RAM      | 1+d,2+d†              | 2+d,3+d†              | 2+d+p,3+d+p†          |
|          |          | DROM     | 2+d                   | 2+d                   | 2+d+p                 |
|          |          | External | 2+2d                  | 2+2d                  | 3+2d+p                |
| DROM     | RAM      | RAM      | 2                     | 2,3†                  | 1+p,2+p(p=0,‡)        |
|          |          | DROM     | 3                     | 2                     | $2(p=0),1+p(p\neq 0)$ |
|          |          | External | $2(d=0),1+d(d\neq 0)$ | 2(d=0&†),1+d          | 2+d+p                 |
|          | DROM     | RAM      | 3                     | 2                     | $2(p=0),1+p(p\neq 0)$ |
|          |          | DROM     | 4                     | 3                     | 3+2p                  |
|          |          | External | $3(d=0),2+d(d\neq 0)$ | $2(d=0),1+d(d\neq 0)$ | 2+d+p                 |
|          | External | RAM      | $2(d=0),1+d(d\neq 0)$ | 2(d=0&†),1+d          | 2+d+p                 |
|          |          | DROM     | $3(d=0),2+d(d\neq 0)$ | $2(d=0),1+d(d\neq 0)$ | 2+d+p                 |
|          |          | External | 2+2d                  | 2+2d                  | 3+2d+p                |
| External | RAM      | RAM      | 1+d, 2+d‡             | 2+d,3+d†‡             | 2+d+p                 |
|          |          | DROM     | $2(d=0),1+d(d\neq 0)$ | 2(d=0&†),1+d          | 2+d+p                 |
|          |          | External | 2+2d                  | 2+2d                  | 3+2d+p                |
|          | DROM     | RAM      | $2(d=0),1+d(d\neq 0)$ | 2(d=0&†),1+d          | 2+d+p                 |
|          |          | DROM     | $3(d=0),2+d(d\neq 0)$ | $2(d=0),1+d(d\neq 0)$ | 2+d+p                 |
|          |          | External | 2+2d                  | 2+2d                  | 3+2d+p                |
|          | External | RAM      | 2+2d                  | 2+2d                  | 3+2d+p                |
|          |          | DROM     | 2+2d                  | 2+2d                  | 3+2d+p                |
|          |          | External | 3+3d                  | 3+3d                  | 4+3d+p                |

- † Xmem(Ymem) и pmad в одном блоке памяти.
- ‡ Xmem и Ymem в одном блоке памяти.
- § Xmem, Ymem и pmad в одном блоке памяти.

|      | Операнд | <u> </u>             |                             | Программа                     |                                        |
|------|---------|----------------------|-----------------------------|-------------------------------|----------------------------------------|
| pmad | Xmem    | Ymem                 | ROM                         | RAM                           | External                               |
| RAM  | RAM     | RAM                  | n,2n†,3n§                   | n,2n+1†‡, 3n+1¶               | n+p,2n+p†‡<br>, 3n+p†                  |
|      |         | DROM<br>Externa<br>I | n+1,2n+1†<br>n+nd, 2n(d=0)† | n,2n†, 3n§†<br>n+nd, 2n(d=0)† | n+p, 2n+p†<br>1+n+nd+p,<br>2n+p(d=0) † |

| Externa   RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         | DROM    | RAM<br>DROM<br>Externa | 1+n,1+2n†<br>2n+1<br>n+1(d=0),n+nd(d≠0  | 1+n,1+2n†<br>2n<br>n+nd | n+p,2n+p†<br>2n+p<br>n+nd+p |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|------------------------|-----------------------------------------|-------------------------|-----------------------------|
| DROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         | Externa | RAM                    | n+nd, 2n(d=0)†                          | n+nd, 2n(d=0)†          | •                           |
| DROM   RAM   RAM   1+n,1+2n†   1+n,1+2n†   n+p,2n+p†                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         | 1       | DROM                   | n+1(d=0),n+nd(d≠0                       | n+nd                    | , .                         |
| DROM 2n+1 2n 2n+p n+nd+p n+nd |         |         | Externa<br>I           | )<br>2n+2nd                             | 2n+2nd                  | 2n+2nd+p                    |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | DROM    | RAM     | DROM                   | 2n+1                                    | 2n                      | 2n+p                        |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         | DROM    | DROM                   | 3n+1                                    | 3n                      | 3n+p                        |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         | Externa | RAM                    | n+1(d=0),n+nd(d≠0                       | n+nd                    | n+nd+p                      |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         | ı       | DROM                   | )<br>2n(d=0),n+nd(d≠0)                  | 2n(d=0),n+nd(d≠0        | n+nd+p                      |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |         | Externa<br>I           | 2n+2nd                                  | )<br>2n+2nd             | 2n+2nd+p                    |
| DROM $n+1(d=0),n+nd(d\neq 0 \ n+nd \ n+nd+p \ )$ Externa $2n+2nd$ $2n+2nd$ $2n+2nd+p$ DROM RAM $n+1(d=0),n+nd(d\neq 0 \ n+nd \ n+nd+p \ )$ DROM $2n(d=0),n+nd(d\neq 0)$ $2n(d=0),n+nd(d\neq 0 \ n+nd+p \ )$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Externa | RAM     | RAM                    | n+nd, 2n(d=0)†                          | n+nd, 2n(d=0)†          | •                           |
| DROM RAM $n+1(d=0),n+nd(d\neq0$ $n+nd$ $n+nd+p$ ) $DROM 2n(d=0),n+nd(d\neq0) 2n(d=0),n+nd(d\neq0) n+nd+p$ )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ı       |         | DROM                   | n+1(d=0),n+nd(d≠0                       | n+nd                    | , .                         |
| )<br>DROM 2n(d=0),n+nd(d≠0) 2n(d=0),n+nd(d≠0 n+nd+p<br>)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |         | Externa                | )<br>2n+2nd                             | 2n+2nd                  | 2n+2nd+p                    |
| DROM $2n(d=0),n+nd(d\neq0)$ $2n(d=0),n+nd(d\neq0)$ $n+nd+p$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         | DROM    | RAM                    | , , , , , , , , , , , , , , , , , , , , | n+nd                    | n+nd+p                      |
| Externa 2n+2nd 2n+2nd 2n+2nd+p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |         | DROM                   | )<br>2n(d=0),n+nd(d≠0)                  | 2n(d=0),n+nd(d≠0        | n+nd+p                      |
| •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |         | Externa<br>I           | 2n+2nd                                  | )<br>2n+2nd             | 2n+2nd+p                    |
| Externa RAM 2n+2nd 2n+2nd 2n+2nd+p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         | Externa | RAM                    | 2n+2nd                                  | 2n+2nd                  | 2n+2nd+p                    |
| DROM 2n+2nd 2n+2nd 2n+2nd+p Externa 3n+3nd 3n+3nd 3n+3nd+p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         | ı       |                        |                                         |                         | •                           |

<sup>†</sup> Xmem и pmad в одном блоке памяти.

## Класс 9А

1 слово, 1 цикл. Операнд чтения в памяти данных, использующий адресацию длинного слова (Lmem).

<sup>‡</sup> Xmem и Ymem в одном блоке памяти.

<sup>§</sup> Ymem и pmad в одном блоке памяти.

<sup>¶</sup> Xmem, Ymem и pmad в одном блоке памяти.

#### Мнемоника:

DADD DLD DSADT DSUBT

DADST DRSUB DSUB

## Циклы:

## Циклы единичного выполнения

| Операнд  | Программа |               |          |
|----------|-----------|---------------|----------|
| Lmem     | ROM       | RAM           | External |
| RAM      | 1         | 1, 2†         | 1+p      |
| DROM     | 2         | 1             | 1+p      |
| External | 1+d       | 1+d           | 2+d+p    |
|          |           | <b>c</b> 00)/ | •        |

<sup>†</sup> операнд и команда в одном блоке ОЗУ.

## Циклы повторяющихся выполнений

| Операнд  | Программа |        |          |
|----------|-----------|--------|----------|
| Lmem     | ROM       | RAM    | External |
| RAM      | n         | n,n+1† | n+p      |
| DROM     | n+1       | n      | n+p      |
| External | n+nd      | n+nd   | n+nd+p   |

<sup>†</sup> операнд и код в одном блоке ОЗУ.

#### Класс 9В

2 слова, 2 цикла. Операнд чтения в памяти данных, использующий косвенную адресацию длинного слова (Lmem) с длинным смещением.

#### Мнемоника:

DADD DLD DSADT DSUBT DADST DRSUB DSUB

## Циклы:

## Циклы выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |      | Программа |          |  |
|----------|------|-----------|----------|--|
| Lmem     | ROM  | RAM       | External |  |
| RAM      | 2    | 1,2†,3†   | 2+2p     |  |
| DROM     | 4    | 2         | 2+2p     |  |
| External | 2+2d | 2+2d      | 4+2d+2p  |  |

<sup>†</sup> операнд и код в одном блоке памяти

## Класс 10А

1 слово, 1 цикл. Операнд записи в памяти данных (Smem или Xmem) или операнд записи в MMR.

#### Мнемоника:

CMPS STH STLM

ST STL

## Циклы:

## Циклы единичного выполнения

| Операнд  |     | Программа |          |  |
|----------|-----|-----------|----------|--|
| Smem     | ROM | RAM       | External |  |
| RAM      | 1   | 1,2†      | 1+p      |  |
| MMR      | 1   | 1         | 1+p      |  |
| External | 1+d | 1+d       | 2+d+p    |  |

† операнд и код в одном блоке памяти.

## Циклы повторяющихся выполнений

| Операнд  |      | Программа |          |  |
|----------|------|-----------|----------|--|
| Smem     | ROM  | RAM       | External |  |
| RAM      | n    | n,n+1†    | n+p      |  |
| MMR      | n    | n         | n+p      |  |
| External | n+nd | n         | n+nd+p   |  |

† операнд и код в одном блоке памяти.

## Класс 10В

2 слова, 2 цикла. Операнд записи в память данных (Smem или Xmem) использующий косвенную адресацию с длинным смещением.

#### Мнемоника:

CMPS

ST

STH

STL

#### Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смешением

| Операнд  |     | Программа |          |  |
|----------|-----|-----------|----------|--|
| Smem     | ROM | RAM       | External |  |
| RAM      | 2   | 2         | 2+2p     |  |
| MMR      | 2   | 2         | 2+2p     |  |
| External | 2+d | 2+d       | 3+d+2p   |  |

† операнд и код в одном блоке памяти.

## Класс 11А

2 слова, 2 цикла. Операнд записи в память данных (Smem).

## Мнемоника:

STH

STL

## Циклы:

| Операнд  |     | Программа |          |  |
|----------|-----|-----------|----------|--|
| Smem     | ROM | RAM       | External |  |
| RAM      | 2   | 2,3†      | 2+2p     |  |
| MMR      | 2   | 2         | 2+2p     |  |
| External | 1+d | 1+d       | 3+d+2p   |  |

† операнд и код в одном блоке памяти.

## Циклы повторяющихся выполнений

|               | Программа     |                               |
|---------------|---------------|-------------------------------|
| ROM           | RAM           | External                      |
| n+1           | n+1,n+2†      | n+1+2p                        |
| n+1           | n+1           | n+1+2p                        |
| n+nd,n+1(d=0) | n+nd,n+1(d=0) | n+nd+2+2p                     |
|               | n+1<br>n+1    | ROM RAM  n+1 n+1,n+2† n+1 n+1 |

<sup>†</sup> операнд и код в одном блоке памяти.

#### Класс 11В

3 слова, 3 цикла Операнд записи в память данных (Smem) использующий косвенную адресацию с длинным смещением.

#### Мнемоника:

STH STL

## Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |            | Программа  |          |
|----------|------------|------------|----------|
| Smem     | ROM        | RAM        | External |
| RAM      | 3          | 3,4†       | 3+3p     |
| MMR      | 3          | 3          | 3+3p     |
| External | 3,1+d(d≥2) | 3,1+d(d≥2) | 4+d+3p   |

<sup>†</sup> операнд и код в одном блоке памяти.

## Класс 12А

2 слова, 2 цикла. Операнд записи в память данных (Smem) или операнд записи в MMR.

#### Мнемоника:

ST STM

## Циклы:

#### Циклы единичного выполнения

| Операнд  |            | Программа  |          |
|----------|------------|------------|----------|
| Smem     | ROM        | RAM        | External |
| RAM      | 2          | 2, 3†      | 2+2p     |
| MMR      | 2          | 2          | 2+2p     |
| External | 2,1+d(d≥2) | 2,1+d(d≥2) | 3+d+2p   |

<sup>†</sup> операнд и код в одном блоке памяти.

| Операнд |     | Програми | ма       |
|---------|-----|----------|----------|
| Smem    | ROM | RAM      | External |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| RAM      | 2n        | 2n,2n+1†  | 2n+2p     |  |
|----------|-----------|-----------|-----------|--|
| MMR      | 2n        | 2n        | 2n+2p     |  |
| External | 2n+(n-1)d | 2n+(n-1)d | 3+n+nd+2p |  |

<sup>†</sup> операнд и код в одном блоке памяти.

#### Класс 12В

3 слова, 3 цикла. Операнд записи в память данных (Smem), использующий косвенную адресацию с длинным смещением.

Мнемоника: ST

## Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |            | Программа  |          |
|----------|------------|------------|----------|
| Smem     | ROM        | RAM        | External |
| RAM      | 3          | 3, 4†      | 3+3p     |
| MMR      | 3          | 3          | 3+3p     |
| External | 3,1+d(d≥2) | 3,1+d(d≥2) | 4+d+3p   |

<sup>†</sup> операнд и код в одном блоке памяти.

#### Класс 13А

1 слово, 2 цикла. Операнд записи в памяти данных, использующий адресацию длинного слова (Lmem).

### Мнемоника:

DST

## Циклы:

Циклы единичного выполнения

| Операнд  |      | Програми | ма              |
|----------|------|----------|-----------------|
| Smem     | ROM  | RAM      | External        |
| RAM      | 1    | 1,2†     | 2(p=0),1+p(p>0) |
| MMR      | 1    | 1        | 2(p=0),1+p(p>0) |
| External | 2+2d | 2+2d     | 3+2d+p          |

<sup>†</sup> операнд и код в одном блоке памяти.

| Операнд  |        | Программ | a          |
|----------|--------|----------|------------|
| Smem     | ROM    | RAM      | External   |
| RAM      | n      | n,n+1†   | n+p+1      |
| MMR      | n      | 2n       | n+p+1      |
| External | 2n+2nd | 2n+2nd   | 2n+2nd+1+p |

<sup>†</sup> операнд и код в одном блоке памяти.

## Класс 13В

2 слова, 3 цикла. Операнд записи в памяти данных, использующий косвенную адресацию длинного слова (Lmem) с длинным смещением.

### Мнемоника:

DST

## Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |      | Програмі | ма       |
|----------|------|----------|----------|
| Lmem     | ROM  | RAM      | External |
| RAM      | 2    | 2,3†     | 2+2p     |
| External | 2+2d | 2+2d     | 4+2d+2p  |
| MMR      | 2    | 2        | 2+2p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 14

1 слово, 1 цикл. Операнды чтения и записи в расслоенной памяти данных (Xmem и Ymem).

## Мнемоника:

MVDD ST||LD ST||MAS[R] ST||SUB ST||ADD ST||MAC[R] ST||MPY

## Циклы:

## Циклы единичного выполнения

| Опе      | еранд    |               | Программа    |               |
|----------|----------|---------------|--------------|---------------|
| Xmem     | Ymem     | ROM           | RAM          | External      |
| RAM      | RAM      | 1, 2†         | 1,2†,3†‡     | 1+p,2(p=0, ‡) |
|          | External | 1+d           | 1+d          | 2+d+p         |
| DROM     | RAM      | 2             | 1,2†         | 1+p           |
|          | External | 1+d, 2(d=0,†) | 1            | 2+d+p         |
| External | RAM      | 1+d           | 1+d,2(d=0,†) | 2+d+p         |
|          | External | 2+2d          | 2+2d         | 3+2d+p        |
| MMR      | RAM      | 1             | 1, 2†        | 1+p           |
|          | External | 1+d           | 1+d          | 2+d+p         |

<sup>†</sup> Операнд и код в одном блоке памяти.

| Ог   | еранд           |               | Программа                          |                       |
|------|-----------------|---------------|------------------------------------|-----------------------|
| Xmem | Ymem            | ROM           | RAM                                | External              |
| RAM  | RAM<br>External | n,2n#<br>n+nd | n,n+1†,2n#, 2n+1†#<br>n+nd,n+nd+1† | n+p,2n+p#<br>n+nd+1+p |

<sup>‡</sup> два операнда в одном блоке памяти.

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| DROM     | RAM      | n,n+1† | n, n+1†      | n+p      |
|----------|----------|--------|--------------|----------|
|          | External | n+nd+1 | n+nd         | n+nd+1+p |
| External | RAM      | n+nd   | n+nd,n+nd+1† | n+nd+1+p |
|          | External | 2n+2nd | 2n+2nd       | 2n+2nd+p |
| MMR      | RAM      | n      | n, n+1†      | n+p      |
|          | External | n+nd   | n+nd         | n+nd+1+p |

<sup>†</sup> Операнд и код в одном блоке памяти.

#### Класс 15

1 слово, 1 цикл. Операнд записи в память данных (Хтет).

#### Мнемоника:

SACCD

SRCCD

**STRCD** 

## Циклы:

# Циклы единичного выполнения

| Операнд  |     | Програмі | ма       |
|----------|-----|----------|----------|
| Xmem     | ROM | RAM      | External |
| RAM      | 1   | 1,2†     | 1+p      |
| External | 1+d | 1+d      | 2+d+p    |
| MMR      | 1   | 1        | 1+p      |

<sup>†</sup> операнд и код в одном блоке памяти.

#### Циклы повторяющихся выполнений

| Операнд  |      | Программ | 1a        |
|----------|------|----------|-----------|
| Xmem     | ROM  | RAM      | External  |
| RAM      | n    | n,n+1†   | n+p       |
| External | n+nd | n+nd     | 2n+nd+1+p |
| MMR      | n    | n        | n+p       |

<sup>†</sup> операнд и код в одном блоке памяти.

## Класс 16А

1 слово, 1 цикл. Операнд чтения в памяти данных (Smem) или операнд чтения в MMR, и операнд записи в память стека

# Мнемоника:

**PSHD** 

**PSHM** 

## Циклы:

| Оп   | еранд |     | Программа | l            |
|------|-------|-----|-----------|--------------|
| Xmem | Stack | ROM | RAM       | External     |
| RAM  | RAM   | 1   | 1, 2†,3‡  | 1+p,2(p=0) # |

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

|          | External | 1               | 1, 2†    | 2+d+p  |
|----------|----------|-----------------|----------|--------|
| DROM     | RAM      | 2               | 1,2†     | 1+p    |
|          | External | 2(d=0),1+d(d≠0) | 1        | 2+d+p  |
| External | RAM      | 1+d             | 1+d,2+d† | 2+d+p  |
|          | External | 2+2d            | 2+2d     | 3+2d+p |
| MMR      | RAM      | 1               | 1, 2†    | 1+p    |
|          | External | 1               | 1        | 2+d+p  |

<sup>†</sup> Операнд и код в одном блоке памяти.

Циклы повторяющихся выполнений

| Опе      | еранд    |              | Программа    |            |
|----------|----------|--------------|--------------|------------|
| Xmem     | Stack    | ROM          | RAM          | External   |
| RAM      | RAM      | n, 2n#       | n,n+1†‡,n+2‡ | n+p,n+p+1# |
|          | External | n+nd         | n+nd,n+nd+1† | n+nd+1+p   |
| DROM     | RAM      | n+1          | n, n+1†      | n+p        |
|          | External | n+nd,n+nd+1† | n+nd         | n+nd+1+p   |
| External | RAM      | n+nd         | n+nd,n+nd+1† | n+nd+1+p   |
|          | External | 2n+2nd       | 2n+2nd       | 2n+2nd+1+p |
| MMR      | RAM      | n            | n, 2n†       | n+p        |
|          | External | n+nd         | n+nd         | n+nd+1+p   |

<sup>†</sup> Операнд и код в одном блоке памяти.

# Класс 16В

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem) использующий косвенную адресацию с длинным смещением и операнд записи в память стека.

#### Мнемоника:

**PSHD** 

## Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |          |            | Программа  |          |
|----------|----------|------------|------------|----------|
| Smem     | Stack    | ROM        | RAM        | External |
| RAM      | RAM      | 2          | 2,3†       | 2+2p     |
|          | External | 2+d        | 2+d        | 3+d+2p   |
| DROM     | RAM      | 3          | 2,3†       | 2+2p     |
|          | External | 3,1+d(d≥2) | 2,1+d(d≥1) | 3+d+2p   |
| External | RAM      | 2+d        | 2+d        | 3+d+2p   |
|          | External | 2+2d       | 2+2d       | 4+2d+2p  |
| MMR      | RAM      | 2          | 2,3†       | 2+2p     |
|          | External | 2+d        | 2+d        | 3+d+2p   |
|          | ·        | ·          | ·          | ·        |

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

† Операнд и код в одном блоке памяти.

## Класс 17А

1 слово, 1 цикл. Операнд записи в памяти данных (Smem) или операнд записи в MMR и операнд чтения в памяти стека.

#### Мнемоника:

**POPD** 

**POPM** 

# Циклы:

Циклы единичного выполнения

| Операнд    |          |                 | Программа |              |
|------------|----------|-----------------|-----------|--------------|
| Smem Stack |          | ROM             | RAM       | External     |
| RAM        | RAM      | 1, 2†           | 1, 2†,3‡  | 1+p,2(p=0) # |
|            | DROM     | 2               | 1,2†      | 1+p          |
|            | External | 1+d             | 1+d, 2+d† | 2+d+p        |
|            | MMR      | 1               | 1,2†      | 1+p          |
| External   | RAM      | 1+d             | 1+d       | 2+d+p        |
|            | DROM     | 1+d(d≠0),2(d=0) | 1+d       | 2+d+p        |
|            | External | 2+2d            | 2+2d      | 3+2d+p       |
|            | MMR      | 1+d             | 1+d       | 2+d+p        |

<sup>†</sup> Операнд и код в одном блоке памяти.

| Операнд  |          |        | Программа    |            |  |
|----------|----------|--------|--------------|------------|--|
| Smem     | Stack    | ROM    | RAM          | External   |  |
| RAM      | RAM      | n, 2n# | n, n+1†,2n#  | n+p,2n+p#  |  |
|          | DROM     | n+1    | n n+1†       | n+p        |  |
|          | External | n+nd   | n+nd,n+dn+1† | n+nd+1+p   |  |
|          | MMR      | n      | n, n+1†      | n+p        |  |
| External | RAM      | n+nd   | n+nd,n+nd+1† | n+nd+1+p   |  |
|          | DROM     | n+nd+1 | n+nd         | n+nd+1+p   |  |
|          | External | 2n+2nd | 2n+2nd       | 2n+2nd+1+p |  |
|          | MMR      | n+nd   | n+nd         | n+nd+1+p   |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 17В

2 слова, 2 цикла. Операнд записи в память данных (Smem) с использованием косвенной адресации с длинным смещением и операнд чтения в памяти стека.

### Мнемоника:

**POPD** 

## Циклы:

Циклы единичного выполнения

| Опе      | еранд    |       | Программ | a        |
|----------|----------|-------|----------|----------|
| Smem     | Stack    | ROM   | RAM      | External |
| RAM      | RAM      | 2, 3† | 2, 3‡    | 2+2p     |
|          | DROM     | 3     | 2, 3†    | 2+2p     |
|          | External | 1+d   | 1+d,2+d  | 3+d+2p   |
|          | MMR      | 2     | 2, 3†    | 2+2p     |
| External | RAM      | 2     | 2, 3†    | 3+d+2p   |
|          | DROM     | 3     | 2        | 3+d+2p   |
|          | External | 2+2d  | 2+2d     | 4+2d+2p  |
|          | MMR      | 2     | 2        | 3+d+2p   |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 18А

2 слова, 2 цикла. Операнд чтения и записи в памяти данных (Smem).

## Мнемоника:

ADDM ANDM ORM XORM

## Циклы:

| Операнд  |      | Програмі | ма       |
|----------|------|----------|----------|
| Smem     | ROM  | RAM      | External |
| RAM      | 2    | 2, 3†    | 2+2p     |
| External | 2+2d | 2+2d     | 4+2d+2p  |
| MMR      | 2    | 2        | 1+p      |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 18В

3 слова, 3 цикла. Операнд чтения и записи в памяти данных (Smem) с использованием косвенной адресации с длинным смещением

### Мнемоника:

ADDM

ANDM

ORM

**XORM** 

## Циклы:

Циклы единичного выполнения

| Операнд  |     | Програмі | ма       |
|----------|-----|----------|----------|
| Smem     | ROM | RAM      | External |
| RAM      | 3   | 3,4†     | 3+3p     |
| External | 3+d | 3+d      | 5+2d+3p  |
| MMR      | 3   | 3        | 3+3p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 19А

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem) или операнд чтения в MMR, операнд записи в памяти данных (dmad); или операнд чтения в памяти данных (dmad), и операнд записи в памяти данных (Smem) или операнд записи в MMR.

#### Мнемоника:

**MVDK** 

MVDM

MVKD

**MVMD** 

## Циклы:

| Опе      | еранд    |       | Программа | а        |
|----------|----------|-------|-----------|----------|
| Smem     | dmad     | ROM   | RAM       | External |
| RAM      | RAM      | 2, 3# | 2, 3#, 4‡ | 2+2p     |
|          | External | 2+d   | 2+d       | 3+d+2p   |
|          | MMR      | 2     | 2,3†      | 2+2p     |
| DROM     | RAM      | 3     | 2,3†      | 2+2p     |
|          | External | 3+d   | 2+d       | 3+d+2p   |
|          | MMR      | 3     | 2         | 2+2p     |
| External | RAM      | 2+d   | 2+d       | 3+d+2p   |
|          | External | 2+2d  | 2+d       | 4+2d+2p  |
|          | MMR      | 2+d   | 2+d       | 3+d+2p   |
| MMR      | RAM      | 2     | 2, 3†     | 2+2p     |
|          | External | 2+d   | 2+d       | 3+d+2p   |
|          | MMR      | 2     | 2         | 2+2p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

Циклы повторяющихся выполнений

| Опе      | еранд    |        | Программа        |                 |  |  |
|----------|----------|--------|------------------|-----------------|--|--|
| Smem     | dmad     | ROM    | RAM              | External        |  |  |
| RAM      | RAM      | n, 2n# | n,n+1†,2n#,2n+1‡ | n+1+2p,2n+1+2p# |  |  |
|          | External | n+nd   | n+nd,n+nd+1†     | n+nd+2+2p       |  |  |
|          | MMR      | n      | n,n+1†           | n+1+2p          |  |  |
| DROM     | RAM      | n+2    | n+1              | n+1+2p          |  |  |
|          | External | n+nd+1 | n+nd             | n+nd+2+2p       |  |  |
|          | MMR      | n+2    | n+1              | n+1+2p          |  |  |
| External | RAM      | n+nd   | n+nd,n+nd+1†     | n+nd+2+2p       |  |  |
|          | External | 2n+2nd | 2n+2nd           | 2n+2nd+2+2p     |  |  |
|          | MMR      | n+nd   | n+nd             | n+nd+2+2p       |  |  |
| MMR      | RAM      | n      | n,n+1†           | n+1+2p          |  |  |
|          | External | 2n+2nd | 2n+2nd           | 2n+2nd+2+2p     |  |  |
|          | MMR      | n      | n                | n+1+2p          |  |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 19В

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem) с использованием косвенной адресации с длинным смещением и операнд записи в память данных (dmad) или операнд чтения в память данных (dmad) и операнд записи в память данных (Smem) с использованием косвенной адресации с длинным смещением.

#### Мнемоника:

MVDK

**MVKD** 

## Циклы:

| Операнд  |          |       | Программа | a        |
|----------|----------|-------|-----------|----------|
| Smem     | dmad     | ROM   | RAM       | External |
| RAM      | RAM      | 2, 3† | 2, 3#, 4‡ | 2+2p     |
|          | External | 2+d   | 2+d       | 3+d+2p   |
|          | MMR      | 2     | 2,3†      | 2+2p     |
| DROM     | RAM      | 3     | 3         | 2+2p     |
|          | External | 3+d   | 2+d       | 3+d+2p   |
|          | MMR      | 3     | 2         | 2+2p     |
| External | RAM      | 2+d   | 2+d       | 3+d+2p   |
|          | External | 2+2d  | 2+d       | 4+2d+2p  |
|          | MMR      | 2+d   | 2+d       | 3+d+2p   |
| MMR      | RAM      | 2     | 2, 3†     | 2+2p     |
|          | External | 2+d   | 2+d       | 3+d+2p   |
|          | MMR      | 2     | 2         | 2+2p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 20А

2 слова, 4 цикла. Операнд чтения в памяти данных (Smem) и операнд записи в памяти программ (pmad).

## Мнемоника:

**MVDP** 

## Циклы:

## Циклы единичного выполнения

| Операнд  |          | Программа |          |            |  |
|----------|----------|-----------|----------|------------|--|
| Smem     | pmad     | ROM       | RAM      | External   |  |
| RAM      | RAM      | 2, 3#     | 2,3#,4‡  | 2+2p,3+2p# |  |
|          | External | 2+d       | 2+d,3+d# | 3+d+2p     |  |
| DROM     | RAM      | 3         | 2,3†     | 2+2p       |  |
|          | External | 3+d       | 2+d      | 3+d+2p     |  |
| External | RAM      | 2+d       | 2+d,3+d† | 3+d+2p     |  |
|          | External | 2+2d      | 2+2d     | 3+d+2p     |  |
| MMR      | RAM      | 2         | 2        | 2+2p       |  |
|          | External | 2+d       | 2+d      | 3+d+2p     |  |

- † Операнд и код в одном блоке памяти.
- ‡ два операнда и код в одном блоке памяти.
- # два операнда в одном блоке памяти.

| Опе      | еранд    | Программа   |                |                 |
|----------|----------|-------------|----------------|-----------------|
| Smem     | pmad     | ROM         | RAM            | External        |
| RAM      | RAM      | 2+n,3+n#    | 2+n,3+n#,4+n‡  | n+1+2p,2n+1+2p# |
|          | External | n+nd+1      | n+nd+1,n+nd+2† | n+nd+2+2p       |
| DROM     | RAM      | n+3         | n+3            | n+3+2p          |
|          | External | n+nd+1      | n+nd           | n+nd+2+2p       |
| External | RAM      | n+nd+1      | n+nd           | n+nd+2+2p       |
|          | External | 2n+2nd+1+2p | 2n+2nd+1+2p    | 2n+2nd+2+2p     |
| MMR      | RAM      | 2+n         | 2+n            | n+3+2p          |
|          | External | n+nd+1      | n+nd+1         | n+nd+2+2p       |

- † Операнд и код в одном блоке памяти.
- ‡ два операнда и код в одном блоке памяти.
- # два операнда в одном блоке памяти.

## Класс 20В

3 слова, 5 циклов. Операнд чтения в памяти данных (Smem) использующий косвенную адресацию с длинным смещением и операнд записи в памяти программ (pmad).

## Мнемоника:

**MVDP** 

# Циклы:

Циклы одиночного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |          |       | Программа |            |  |  |
|----------|----------|-------|-----------|------------|--|--|
| Smem     | pmad     | ROM   | RAM       | External   |  |  |
| RAM      | RAM      | 3, 4# | 3,4#,5‡   | 3+3p,4+3p# |  |  |
|          | External | 3+d   | 3+d,4+d#  | 4+d+3p     |  |  |
| DROM     | RAM      | 4     | 3,4†      | 3+3p       |  |  |
|          | External | 4+d   | 3+d       | 4+d+3p     |  |  |
| External | RAM      | 3+d   | 3+d,4+d†  | 4+d+3p     |  |  |
|          | External | 3+2d  | 3+2d      | 5+2d+3p    |  |  |
| MMR      | RAM      | 3     | 3,4‡      | 3+3p       |  |  |
|          | External | 3+d   | 3+d       | 3+d+3p     |  |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

#### Класс 21А

2 слова, 3 цикла. Операнд чтения в памяти программ (pmad) и операнд записи в памяти данных (Smem).

#### Мнемоника:

**MVPD** 

## Циклы:

| Операнд  |          |      | Программа |            |  |
|----------|----------|------|-----------|------------|--|
| pmad     | Smem     | ROM  | RAM       | External   |  |
| RAM      | RAM      | 2,3# | 2,3#,4‡   | 2+2p,3+2p# |  |
|          | External | 2+d  | 2+d,3+d‡  | 3+d+2p     |  |
|          | MMR      | 2    | 2,3†      | 2+2p       |  |
| PROM     | RAM      | 3    | 2,3†      | 2+2p       |  |
|          | External | 3+d  | 2+d       | 3+d+2p     |  |
|          | MMR      | 3    | 2         | 2+2p       |  |
| External | RAM      | 2+d  | 2+d,3+d†  | 3+d+2p     |  |
|          | External | 2+2d | 2+2d      | 4+2d+2p    |  |
|          | MMR      | 2+d  | 2+d       | 3+d+2p     |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

|           |          |          | •            |
|-----------|----------|----------|--------------|
|           |          | $\alpha$ | я выполнений |
| IIIVIKIII | 11018101 |          | я выпопнении |
|           | 110010   |          |              |
|           |          |          |              |

| Опе      | еранд    |          | Программа |               |
|----------|----------|----------|-----------|---------------|
| pmad     | Smem     | ROM      | RAM       | External      |
| RAM      | RAM      | n+2      | n+2,2n#   | n+2+2p,2n+2p# |
|          | External | n+nd     | n+nd      | n+nd+2+2p     |
|          | MMR      | n+2      | n+2       | n+2+2p        |
| PROM     | RAM      | n+2      | n+2       | 3+2p          |
|          | External | n+nd+2   | n+nd+1    | n+nd+2+2p     |
|          | MMR      | n+2      | n+1       | n+2+2p        |
| External | RAM      | n+nd     | n+nd      | n+nd+2+2p     |
|          | External | 2n+2nd+1 | 2n+2nd+1  | 2n+2nd+2+2p   |
|          | MMR      | n+nd     | n+nd      | n+nd+2+2p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 21В

3 слова, 4 цикла. Операнд чтения в памяти программ (pmad) и операнд записи в памяти данных (Smem), использующий максимально удаленную косвенную адресацию.

#### Мнемоника:

**MVPD** 

## Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |          |      | Программа | l          |
|----------|----------|------|-----------|------------|
| pmad     | Smem     | ROM  | RAM       | External   |
| RAM      | RAM      | 3,4# | 3,4#,5‡   | 3+3p,4+3p# |
|          | External | 3+d  | 3+d,4+d‡  | 4+d+3p     |
|          | MMR      | 3    | 3,4†      | 3+3p       |
| PROM     | RAM      | 4    | 3,4†      | 3+3p       |
|          | External | 4+d  | 3+d       | 4+d+3p     |
|          | MMR      | 4    | 3         | 3+3p       |
| External | RAM      | 3+d  | 3+d,4+d†  | 4+d+3p     |
|          | External | 3+3d | 3+3d      | 5+2d+3p    |
|          | MMR      | 3+d  | 3+d       | 3+d+3p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 22А

2 слова, 3 цикла. Операнд чтения в памяти данных (Smem) и операнд чтения в памяти программ (pmad).

### Мнемоника:

**MACP** 

# Циклы:

#### Циклы единичного выполнения

| Операнд  |          |      | Программа |            |  |  |
|----------|----------|------|-----------|------------|--|--|
| pmad     | Smem     | ROM  | RAM       | External   |  |  |
| RAM      | RAM      | 2,3† | 2,3†,4‡   | 2+2p,3+2p# |  |  |
|          | External | 2+d  | 2+d,3+d†  | 3+d+2p     |  |  |
|          | MMR      | 2    | 2,3†      | 2+2p       |  |  |
| PROM     | RAM      | 3    | 3, 4†     | 2+2p       |  |  |
|          | External | 3+d  | 3+d       | 3+d+2p     |  |  |
|          | MMR      | 3    | 3         | 2+2p       |  |  |
| External | RAM      | 2+d  | 2+d, 3+d† | 3+d+2p     |  |  |
|          | External | 3+2d | 3+2d      | 4+2d+2p    |  |  |
|          | MMR      | 2+d  | 2+d       | 3+d+2p     |  |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

| Операнд  |          | Программа |                 |                 |  |
|----------|----------|-----------|-----------------|-----------------|--|
| pmad     | Smem     | ROM       | RAM             | External        |  |
| RAM      | RAM      | n+2,2n+2# | n+2, n+3†,2n+2# | n+2+2p,2n+2+2p# |  |
|          | External | n+nd+2    | n+nd+2          | n+nd+2+2p       |  |
|          | MMR      | n+2       | n+2,n+3†        | n+2+2p          |  |
| PROM     | RAM      | n+3       | n+3, n+4†,      | n+2+2p          |  |
|          | External | n+nd+3    | n+nd+3          | n+nd+2+2p       |  |
|          | MMR      | n+3       | n+3             | n+2+2p          |  |
| External | RAM      | n+nd+2    | n+nd+2,n+nd+3†  | n+nd+2+2p       |  |
|          | External | 2n+2nd+2  | 2n+2nd+2        | 2n+2nd+2+2p     |  |
|          | MMR      | n+nd+2    | n+nd+2          | n+nd+2+2p       |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 22В

3 слова, 4 цикла. Операнд чтения в памяти данных (Smem), использующий максимально удаленную косвенную адресацию и операнд чтения в памяти программ (pmad).

## Мнемоника:

**MACP** 

# Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |          |      | Программа |            |  |
|----------|----------|------|-----------|------------|--|
| pmad     | Smem     | ROM  | RAM       | External   |  |
| RAM      | RAM      | 3,4† | 3,4†,5‡   | 3+3p,4+3p# |  |
|          | External | 3+d  | 3+d,4+d†  | 4+d+3p     |  |
|          | MMR      | 3    | 3,4†      | 3+3p       |  |
| PROM     | RAM      | 4    | 4, 5†     | 4+3p       |  |
|          | External | 4+d  | 4+d       | 5+d+3p     |  |
|          | MMR      | 4    | 4         | 4+3p       |  |
| External | RAM      | 3+d  | 3+d, 4+d† | 4+d+3p     |  |
|          | External | 4+2d | 4+2d      | 5+2d+3p    |  |
|          | MMR      | 3+d  | 3+d       | 4+d+3p     |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 23А

2 слова, 3 цикла. Операнд чтения в памяти данных (Smem), операнд записи в памяти данных (Smem), и операнд чтения в памяти программ (pmad).

#### Мнемоника:

**MACD** 

## Циклы:

| Операнд  |          |      | Программа | 1          |
|----------|----------|------|-----------|------------|
| pmad     | Smem     | ROM  | RAM       | External   |
| RAM      | RAM      | 2,3# | 2,3#,4‡   | 2+2p,3+2p# |
|          | External | 2+d  | 2+d,3+d‡  | 3+d+2p     |
|          | MMR      | 2    | 2,3†      | 2+2p       |
| PROM     | RAM      | 3    | 2,3†      | 2+2p       |
|          | External | 3+d  | 2+d       | 3+d+2p     |
|          | MMR      | 3    | 2         | 2+2p       |
| External | RAM      | 2+d  | 2+d,3+d†  | 3+d+2p     |
|          | External | 2+2d | 2+2d      | 4+2d+2p    |
|          | MMR      | 2+d  | 2+d       | 3+d+2p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

# два операнда в одном блоке памяти.

Циклы повторяющихся выполнений

| Опе      | еранд    |          | Программа |               |
|----------|----------|----------|-----------|---------------|
| pmad     | Smem     | ROM      | RAM       | External      |
| RAM      | RAM      | n+2      | n+2,2n#   | n+2+2p,2n+2p# |
|          | External | n+nd     | n+nd      | n+nd+2+2p     |
|          | MMR      | n+2      | n+2       | n+2+2p        |
| PROM     | RAM      | n+2      | n+2       | 3+2p          |
|          | External | n+nd+2   | n+nd+1    | n+nd+2+2p     |
|          | MMR      | n+2      | n+1       | n+2+2p        |
| External | RAM      | n+nd     | n+nd      | n+nd+2+2p     |
|          | External | 2n+2nd+1 | 2n+2nd+1  | 2n+2nd+2+2p   |
|          | MMR      | n+nd     | n+nd      | n+nd+2+2p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 23В

3 слова, 4 цикла. Операнд чтения в памяти данных (Smem), использующий косвенную адресацию с длинным смещением, операнд записи в памяти данных (Smem), использующий косвенную адресацию с длинным смещением, и операнд чтения из памяти программ (pmad).

## Мнемоника:

**MACD** 

## Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Опе      | еранд    |      | Программа | 1          |
|----------|----------|------|-----------|------------|
| pmad     | Smem     | ROM  | RAM       | External   |
| RAM      | RAM      | 3,4# | 3,4#,5‡   | 3+3p,4+3p# |
|          | External | 3+d  | 3+d,4+d‡  | 4+d+3p     |
|          | MMR      | 3    | 3,4†      | 3+3p       |
| PROM     | RAM      | 4    | 3,4†      | 3+3p       |
|          | External | 4+d  | 3+d       | 4+d+3p     |
|          | MMR      | 4    | 3         | 3+3p       |
| External | RAM      | 3+d  | 3+d,4+d†  | 4+d+3p     |
|          | External | 3+3d | 3+3d      | 5+2d+3p    |
|          | MMR      | 3+d  | 3+d       | 3+d+3p     |

<sup>†</sup> Операнд и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 24А

1 слово, 1 цикл. Операнд чтения в памяти данных (Smem) и операнд записи в памяти данных (Smem).

Мнемоника:

**DELAY** 

LTD

# Циклы:

Циклы единичного выполнения

| Операнд  |      | Программа |          |  |
|----------|------|-----------|----------|--|
| Smem     | ROM  | RAM       | External |  |
| RAM      | 1    | 1,2†      | 1+p      |  |
| External | 2+2d | 2+2d      | 3+p+2d   |  |

† операнд и код в одном блоке памяти.

## Циклы повторяющихся выполнений

| Операнд  |        | Программ | a          |
|----------|--------|----------|------------|
| Smem     | ROM    | RAM      | External   |
| RAM      | n      | n,n+1†   | n+p        |
| External | 2n+2nd | 2n+2nd   | 2n+2nd+2+p |

<sup>†</sup> операнд и код в одном блоке памяти.

## Класс 24В

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem), использующий косвенную адресацию с длинным смещением и операнд записи в памяти данных (Smem), использующий косвенную адресацию с длинным смещением.

## Мнемоника:

**DELAY** 

LTD

## Циклы:

Циклы единичного выполнения, использущие косвенную адресацию с длинным смещением

| Операнд  |      | Програми | иа       |
|----------|------|----------|----------|
| Smem     | ROM  | RAM      | External |
| RAM      | 2    | 2,3†     | 2+2p     |
| External | 3+2d | 3+2d     | 4+2p+2d  |

† операнд и код в одном блоке памяти.

#### Класс 25А

1 слово, 5 циклов. Адрес чтения в памяти программ (pmad адресуемый аккумулятором A) и операнд записи в памяти данных (Smem).

## Мнемоника:

**READA** 

## Циклы:

Циклы единичного выполнения

| Операнд  |          |      | Программа | 1         |
|----------|----------|------|-----------|-----------|
| pmad     | Smem     | ROM  | RAM       | External  |
| RAM      | RAM      | 1    | 1,2†      | 1+p, 2+p# |
|          | External | 1+d  | 1+d       | 2+d+p     |
|          | MMR      | 1    | 1         | 1+p       |
| PROM     | RAM      | 2    | 1, 2†     | 1+p       |
|          | External | 2    | 1+d       | 2+d+p     |
|          | MMR      | 2    | 1         | 1+p       |
| External | RAM      | 1+d  | 1+d,2+d†  | 2+d+p     |
|          | External | 2+2d | 2+2d      | 3+2d+p    |
|          | MMR      | 1+d  | 1+d       | 2+d+p     |

<sup>†</sup> операнд и код в одном блоке памяти.

| Операнд  |                               |                        | Программа                           |                                          |
|----------|-------------------------------|------------------------|-------------------------------------|------------------------------------------|
| pmad     | Smem                          | ROM                    | RAM                                 | External                                 |
| RAM      | RAM<br>External               | n<br>n+nd              | n,n+1†<br>n+nd                      | n+p, 2n+p#<br>n+nd+1+p                   |
| PROM     | MMR<br>RAM<br>External<br>MMR | n+1<br>n+nd+2<br>n+1   | n<br>n+1, n+2†<br>n+nd              | n+1+p<br>n+p<br>n+nd+p                   |
| External | RAM<br>External<br>MMR        | n+nd<br>2n+2nd<br>n+nd | n<br>n+nd,n+nd+1†<br>2n+2nd<br>n+nd | n+p<br>2n+nd+p<br>2n+2nd+1+p<br>n+nd+1+p |

<sup>†</sup> операнд и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

## Класс 25В

2 слова, 6 циклов. Адрес чтения в памяти программ (pmad) операнд записи в памяти данных (Smem) с использованием косвенной адресации с длинным смещением.

## Мнемоника

#### READA

# Циклы

Циклы единичного выполнения с косвенной адресацией и длинным смещением

|          |          |      |           | <u>'</u>    |
|----------|----------|------|-----------|-------------|
| Опе      | еранд    |      | Программа | 1           |
| pmad     | Smem     | ROM  | RAM       | External    |
| RAM      | RAM      | 2    | 2,3†      | 2+2p, 3+2p# |
|          | External | 2+d  | 2+d       | 3+d+2p      |
|          | MMR      | 2    | 2         | 2+2p        |
| PROM     | RAM      | 3    | 2, 3†     | 2+2p        |
|          | External | 3    | 2+d       | 3+d+2p      |
|          | MMR      | 3    | 2         | 2+2p        |
| External | RAM      | 2+d  | 2+d,3+d†  | 3+d+2p      |
|          | External | 3+2d | 3+2d      | 4+2d+2p     |
|          | MMR      | 2+d  | 2+d       | 3+d+2p      |

#### Класс 26А

1 слово, 5 циклов. Операнд чтения в памяти данных (Smem) адрес записи в памяти программ (pmad).

### Мнемоника

## **WRITA**

## Циклы

| Операнд  |          |      | Программа | a         |
|----------|----------|------|-----------|-----------|
| Smem     | pmad     | ROM  | RAM       | External  |
| RAM      | RAM      | 1    | 1,2†,3‡   | 1+p, 2+p# |
|          | External | 1+d  | 1+d       | 2+d+p     |
| DROM     | RAM      | 2    | 1, 2†     | 1+p       |
|          | External | 2+d  | 1+d       | 2+d+p     |
| External | RAM      | 1+d  | 1+d,2+d†  | 2+d+p     |
|          | External | 2+2d | 2+2d      | 3+2d+p    |
| MMR      | RAM      | 1    | 1,2†      | 1+p, 2+p# |
|          | External | 1+d  | 1+d       | 2+d+p     |

<sup>†</sup> операнд и код в одном блоке памяти.

<sup>‡</sup> два операнда и код в одном блоке памяти.

<sup>#</sup> два операнда в одном блоке памяти.

Циклы повторяющихся выполнений

| Операнд  |          |        | Программа   |             |  |
|----------|----------|--------|-------------|-------------|--|
| Smem     | pmad     | ROM    | RAM         | External    |  |
| RAM      | RAM      | n      | n,2n†,2n+1‡ | n+p, 2n+p#  |  |
|          | External | n+nd   | n+nd        | n+nd+1+p    |  |
| DROM     | RAM      | n+1    | n, n+1†     | n+p         |  |
|          | External | n+1    | n+nd        | n+nd+1+p    |  |
| External | RAM      | n+nd   | n+nd,n+1+d† | n+nd+1+p    |  |
|          | External | 2n+2nd | 2n+2nd      | 2n+2nd+1+p  |  |
| MMR      | RAM      | n      | n,n+1†      | n+p, n+1+p# |  |
|          | External | n+nd   | n+nd        | n+nd+1+p    |  |

- † операнд и код в одном блоке памяти.
- ‡ два операнда и код в одном блоке памяти.
- # два операнда в одном блоке памяти.

## Класс 26В

2 слова, 6 циклов. Операнд чтения в памяти данных (Smem) использующий косвенную адресацию с длинным смещением и адрес записи в памяти программ (pmad).

## Мнемоника

## **WRITA**

## Циклы

Циклы единичного выполнения с максимально удаленным модификатором

|          |          |      | 711       |             |
|----------|----------|------|-----------|-------------|
| Опе      | еранд    |      | Программа | 1           |
| Smem     | pmad     | ROM  | RAM       | External    |
| RAM      | RAM      | 2    | 2,3†,4‡   | 2+2p, 3+2p# |
|          | External | 2+d  | 2+d       | 3+d+2p      |
| DROM     | RAM      | 3    | 2, 3†     | 2+2p        |
|          | External | 3+d  | 2+d       | 3+d+2p      |
| External | RAM      | 2+d  | 2+d,3+d†  | 3+d+2p      |
|          | External | 3+2d | 3+2d      | 4+2d+2p     |
| MMR      | RAM      | 2    | 2,3†      | 2+2p, 3+2p# |
|          | External | 2+d  | 2+d       | 3+d+2p      |

## Класс 27А

2 слова, 2 цикла. Операнд чтения порта ввода-вывода и операнд записи в память данных (Smem).

#### Мнемоника

**PORTR** 

## Циклы

Циклы единичного выполнения

| Опе      | еранд    |        | Программа   |           |
|----------|----------|--------|-------------|-----------|
| Port     | Smem     | ROM    | RAM         | External  |
| External | RAM      | 2+io   | 3+io, 4+io† | 3+2p+io   |
| -        | External | 2+d+io | 3+d+io      | 4+2p+d+io |

<sup>†</sup> Операнд и код в одном блоке памяти.

Циклы повторяющихся выполнений

| Операнд  |                 | Программа              |                                  |                              |
|----------|-----------------|------------------------|----------------------------------|------------------------------|
| Port     | Smem            | ROM                    | RAM                              | External                     |
| External | RAM<br>External | n+nio+1<br>2n+nd+nio+1 | n+nio+1, n+nio+2†<br>2n+nd+nio+1 | n+nio+2+2p<br>2n+nio+nd+2+2p |

<sup>†</sup> Операнд и код в одном блоке памяти

#### Класс 27В

3 слова, 3 цикла. Операнд чтения порта ввода-вывода и операнд записи в память данных (Smem) с использованием косвенной адресации с длинным смещением.

#### Мнемоника

**PORTR** 

## Циклы

Циклы единичного выполнения с максимально удаленным модификатором

| Опе      | еранд    |        | Программа   |           |
|----------|----------|--------|-------------|-----------|
| Port     | Smem     | ROM    | RAM         | External  |
| External | RAM      | 3+io   | 4+io, 5+io† | 4+3p+io   |
|          | External | 3+d+io | 4+d+io      | 5+3p+d+io |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 28А

2 слова, 2 цикла. Операнд чтения в памяти данных (Smem) и операнд записи в порт ввода-вывода.

#### Мнемоника

**PORTW** 

## Циклы

Циклы единичного выполнения

| Опе      | еранд    |        | Программа  |           |
|----------|----------|--------|------------|-----------|
| Port     | Smem     | ROM    | RAM        | External  |
| External | RAM      | 2+io   | 3+io,4+io† | 3+io+2p   |
|          | DROM     | 3+io   | 2+io       | 3+io+2p   |
|          | External | 2+d+io | 3+d+io     | 4+io+2p+d |

<sup>†</sup> Операнд и код в одном блоке памяти.

Циклы повторяющихся выполнений

| Опе      | еранд    |             | Программа        |                |
|----------|----------|-------------|------------------|----------------|
| Port     | Smem     | ROM         | RAM              | External       |
| External | RAM      | n+nio+1     | n+nio+1,n+nio+2† | n+nio+2+2p     |
|          | DROM     | n+nio+2     | n+nio+1          | n+nio+2+2p     |
|          | External | 2n+nd+nio+1 | 2n+nd+nio+1      | 2n+nio+nd+2+2p |

<sup>†</sup> Операнд и код в одном блоке памяти.

#### Класс 28В

3 слова, 3 цикла. Операнд чтения в памяти данных (Smem) с использованием косвенной адресации с длинным смещением и операнд записи в порт ввода-вывода.

#### **Мнемоника**

**PORTW** 

## Циклы

Циклы единичного выполнения с максимально удаленным модификатором

| Опе      | еранд    |        | Программа  |           |
|----------|----------|--------|------------|-----------|
| Port     | Smem     | ROM    | RAM        | External  |
| External | RAM      | 3+io   | 4+io,5+io† | 4+3p+io   |
|          | DROM     | 4+io   | 4+io       | 4+3p+io   |
|          | External | 3+d+io | 4+d+io     | 5+3p+d+io |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 29А

2 слова, 4 цикла, 2 цикла (с задержкой), 2 цикла (ложное условие). Операнд в памяти программ (pmad)

## Мнемоника

B[D] BANZ[D] FB[D] (в данной модели не реализовано) RPTB[D]

## Циклы

|  | Ш | иклы | единичного | выполнения |
|--|---|------|------------|------------|
|--|---|------|------------|------------|

|     | Програм | Іма      |  |
|-----|---------|----------|--|
| ROM | RAM     | External |  |
| 4   | 4       | 4+4p     |  |

## Циклы единичного выполнения с задержкой

|     | Програми | иа       |
|-----|----------|----------|
| ROM | RAM      | External |
| 2   | 2        | 2+2p     |

## Класс 29В

2 слова, 4 цикла, 2 цикла (с задержкой). Операнд в памяти программ (pmad).

#### Мнемоника

CALL[D] FCALL[D] (в данной модели не реализовано)

## Циклы

## Циклы единичного выполнения

| Операнд  | <u> </u> | Программа |          |  |
|----------|----------|-----------|----------|--|
| Stack    | ROM      | RAM       | External |  |
| RAM      | 4        | 4,5†      | 4+4p     |  |
| External | 4+d      | 4+d       | 5+4p+d   |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

# Циклы единичного выполнения с задержкой

| Операнд  | Программа |      |          |  |
|----------|-----------|------|----------|--|
| Stack    | ROM       | RAM  | External |  |
| RAM      | 4         | 4,5† | 4+4p     |  |
| External | 4+d       | 4+d  | 5+4p+d   |  |

<sup>†</sup> Операнд и код в одном блоке памяти.

# Класс 30А

1 слово, 6 циклов, 4 цикла (с задержкой). Операнд регистра.

#### **Мнемоника**

BACC[D]

FBACC[D] (в данной модели не реализована)

# Циклы

|     | Програм |          |  |
|-----|---------|----------|--|
| ROM | RAM     | External |  |
| 4   | 4       | 4+3p     |  |

#### Циклы единичного выполнения с задержкой

|     | Програм | ма       |
|-----|---------|----------|
| ROM | RAM     | External |
| 4   | 4       | 4+3p     |

#### Класс 30В

1 слово, 6 циклов, 4 циклов (с задержкой). Операнд регистра.

#### Мнемоника

CALA[D]

FCALA[D] (в данной модели не реализовано)

# Циклы

# Циклы единичного выполнения

| Операнд  | Программа |     |          |
|----------|-----------|-----|----------|
| Stack    | ROM       | RAM | External |
| RAM      | 6         | 6   | 6+3p     |
| External | 6         | 6   | 7+3p+d   |

# Циклы единичного выполнения с задержкой

| Операнд  | Программа |     |          |
|----------|-----------|-----|----------|
| Stack    | ROM       | RAM | External |
| RAM      | 4         | 4   | 4+p      |
| External | 4         | 4   | 5+p+d    |

#### Класс 31А

2 слова, 5 цикла, 3 цикла (с задержкой). Операнд в памяти программ (pmad) и операнды короткого непосредственного значения

#### Мнесоника

BC[D]

#### Циклы

#### Циклы единичного выполнения

|         | Программа |     |          |
|---------|-----------|-----|----------|
| Условие | ROM       | RAM | External |
| Истина  | 5         | 5   | 5+4p     |
| Ложь    | 3         | 3   | 3+2p     |

# Циклы единичного выполнения с задержкой

|         | Программа |     |          |
|---------|-----------|-----|----------|
| Условие | ROM       | RAM | External |
| Истина  | 3         | 3   | 3+2p     |
| Ложь    | 3         | 3   | 3+2p     |

#### Класс 31В

2 слова, 5 циклов, 3 цикла (с задержкой), 3 цикла (ложное условие). Операнд в памяти программ (pmad) и операнды с коротким непосредственным значением.

#### **Мнемоника**

CC[D]

#### Циклы

#### Циклы единичного выполнения (условие истинное)

| Операнд  | Программа |      |          |
|----------|-----------|------|----------|
| Stack    | ROM       | RAM  | External |
| RAM      | 5         | 5,6† | 5+4p     |
| External | 5         | 5    | 8+4p+d   |

<sup>†</sup> Операнд и код в одном блоке памяти.

#### Циклы единичного выполнения (условие ложное)

| Операнд  | Программа |      |          |
|----------|-----------|------|----------|
| Stack    | ROM       | RAM  | External |
| RAM      | 3         | 3,4† | 3+2p     |
| External | 3         | 3    | 6+2p+d   |

<sup>†</sup> Операнд и код в одном блоке памяти.

# Циклы единичного выполнения (условие ложное)

| Операнд  | анд Программа |      | ма       |
|----------|---------------|------|----------|
| Stack    | ROM           | RAM  | External |
| RAM      | 3             | 3,4† | 3+2p     |
| External | 3             | 3    | 6+2p+d   |

<sup>†</sup> Операнд и код в одном блоке памяти.

#### Класс 32

1 слово, 5 циклов, 3 цикла (с задержкой), 3 цикла (ложное условие). Операнд отсутствует, или операнд с коротким непосредственным значением.

#### Мнемоника

RC[D]

RET[D]

RETE[D]

# Циклы

## Циклы единичного выполнения

| Операнд  | Программа |      |          |
|----------|-----------|------|----------|
| Stack    | ROM       | RAM  | External |
| RAM      | 5         | 5,6† | 5+3p     |
| External | 5+d       | 5+d  | 6+d+3p   |

<sup>†</sup> Операнд и код в одном блоке памяти.

Циклы единичного выполнения с задержкой

| Операнд  | Программа |      |          |
|----------|-----------|------|----------|
| Stack    | ROM       | RAM  | External |
| RAM      | 3         | 3,4† | 3+p      |
| External | 3+d       | 3+d  | 4+d+p    |

<sup>†</sup> Операнд и код в одном блоке памяти.

## Класс 33

1 слово, 3 цикла, 1 цикл (с задержкой). Операнд отсутствует.

#### **Мнемоника**

RETF[D]

# Циклы

### Циклы единичного выполнения

| Программа |     |          |  |  |  |  |  |  |
|-----------|-----|----------|--|--|--|--|--|--|
| ROM       | RAM | External |  |  |  |  |  |  |
| 3         | 3   | 3+p      |  |  |  |  |  |  |

#### Циклы единичного выполнения с задержкой

| Программа |                |     |  |  |  |  |  |  |
|-----------|----------------|-----|--|--|--|--|--|--|
| ROM       | M RAM External |     |  |  |  |  |  |  |
| 1         | 1              | 1+p |  |  |  |  |  |  |

#### Класс 34

1 слово, 6 циклов, 4 цикла (с задержкой). Операнд отсутствует.

#### Мнемоника

FRET[D] FRETE[D]

# Циклы

В данной модели операции не реализованы.

### Класс 35

1 слово, 3 цикла. Операнд отсутствует или операнд с коротким непосредственным значением.

#### Мнемоника

INTR RESET TRAP

# Циклы

Циклы единичного выполнения

| Программа |     |          |  |  |  |  |  |  |
|-----------|-----|----------|--|--|--|--|--|--|
| ROM       | RAM | External |  |  |  |  |  |  |
| 3         | 3   | 3+p      |  |  |  |  |  |  |

#### Класс 36

1 слово, 4 цикла (минимум). Операнд с коротким непосредственным значением.

#### Мнемоника

**IDLE** 

# Циклы

Количество циклов, необходимое для выполнения этой команды, зависит от периода бездействия

# 20.3 Команды на языке ассемблера

Этот раздел содержит подробную информацию о наборе команд для DSPядра микроконтроллера. Набор команд включает команды обработки сигналов, требующие большого объема вычислений и команды общего назначения, такие как мультиобработка и высокоскоростное управление.

# 20.3.1 Обозначения и сокращения

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

Таблица 20-29 – Обозначения и сокращения в наборе команд

| Обозначени<br>е | Содержание                                                                                                      |  |  |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Α               | Аккумулятор А                                                                                                   |  |  |  |  |  |  |  |
| ALU             | Арифметико-логическое устройство (АЛУ)                                                                          |  |  |  |  |  |  |  |
| AR              | Вспомогательный регистр общего пользования                                                                      |  |  |  |  |  |  |  |
| ARx             | Определяет указанный вспомогательный регистра (0 ≤ x ≤ 7)                                                       |  |  |  |  |  |  |  |
| ARP             | Указатель вспомогательного регистра (3-битное поле в ST0), указывает текущий AR.                                |  |  |  |  |  |  |  |
| ASM             | 5-разрядное поле режима сдвига аккумулятора в ST1<br>(–16 ≤ ASM ≤ 15)                                           |  |  |  |  |  |  |  |
| В               | Аккумулятор В                                                                                                   |  |  |  |  |  |  |  |
| BRAF            | Флаг активности повторения блока команд в ST1                                                                   |  |  |  |  |  |  |  |
| BRC             | Счетчик повторения блока программного кода                                                                      |  |  |  |  |  |  |  |
| BITC            | 4-разрядное значение, определяющее бит ячейки памяти данных, тестируемый командой контроля битов (0 ≤ BITC≤ 15) |  |  |  |  |  |  |  |
| C16             | 16-разрядный бит режима двухсловной/двойной точности арифметики в ST1                                           |  |  |  |  |  |  |  |
| С               | Бит переноса в ST0                                                                                              |  |  |  |  |  |  |  |
| CC              | 2-разрядный код условия (0 ≤ СС ≤ 3)                                                                            |  |  |  |  |  |  |  |
| CMPT            | Бит режима совместимости в ST1                                                                                  |  |  |  |  |  |  |  |
| CPL             | Бит режима трансляции в ST1                                                                                     |  |  |  |  |  |  |  |
| cond            | Операнд, представляющий условие, используемое условными командами                                               |  |  |  |  |  |  |  |
| [D]             | режим задержки                                                                                                  |  |  |  |  |  |  |  |
| DAB             | Адресная шина D                                                                                                 |  |  |  |  |  |  |  |
| DAR             | Адресный регистр DAB                                                                                            |  |  |  |  |  |  |  |
| dmad            | Непосредственный 16-разрядный адрес памяти данных (0 ≤ dmad ≤ 65 535)                                           |  |  |  |  |  |  |  |
| Dmem            | Операнд в памяти данных                                                                                         |  |  |  |  |  |  |  |
| DP              | 9-разрядное поле указателя страницы памяти данных в ST0 (0 ≤ DP ≤ 511)                                          |  |  |  |  |  |  |  |
| dst             | Аккумулятор приемник (А или В)                                                                                  |  |  |  |  |  |  |  |

| Обозначени<br>е | Содержание                                                                                                                      |  |  |  |  |  |  |  |  |  |  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| dst_            | Противоположный аккумулятор:<br>если dst = A, то dst_ = B<br>если dst = B, то dst_ = A                                          |  |  |  |  |  |  |  |  |  |  |
| EAB             | Е адресная шина                                                                                                                 |  |  |  |  |  |  |  |  |  |  |
| EAR             | ЕАВ адресный регистр                                                                                                            |  |  |  |  |  |  |  |  |  |  |
| extpmad         | Непосредственный 23- разрядный адрес памяти программ                                                                            |  |  |  |  |  |  |  |  |  |  |
| FRCT            | Бит режима дробных чиселв ST1                                                                                                   |  |  |  |  |  |  |  |  |  |  |
| hi(A)           | Старшая часть аккумулятора А (биты 31–16)                                                                                       |  |  |  |  |  |  |  |  |  |  |
| HM              | Бит режима захвата (HOLD режима) в ST1                                                                                          |  |  |  |  |  |  |  |  |  |  |
| IFR             | Регистр флага прерывания                                                                                                        |  |  |  |  |  |  |  |  |  |  |
| INTM            | Бит режима прерывания в ST1                                                                                                     |  |  |  |  |  |  |  |  |  |  |
| K               | Короткое непосредственное значение меньше чем 9 бит                                                                             |  |  |  |  |  |  |  |  |  |  |
| k3              | 3-разрядное непосредственное значение (0 ≤ k3 ≤ 7)                                                                              |  |  |  |  |  |  |  |  |  |  |
| k5              | 5-разрядное непосредственное значение (–16 ≤ k5 ≤ 15)                                                                           |  |  |  |  |  |  |  |  |  |  |
| k9              | 9-разрядное непосредственное значение (0 ≤ k9 ≤ 511)                                                                            |  |  |  |  |  |  |  |  |  |  |
| lk              | 16-битное длинное непосредственное значение                                                                                     |  |  |  |  |  |  |  |  |  |  |
| Lmem            | 32-разрядный операнд памяти данных, использующий адресацию длинного слова                                                       |  |  |  |  |  |  |  |  |  |  |
| mmr, MMR        | Регистр, отображаемый на память                                                                                                 |  |  |  |  |  |  |  |  |  |  |
| MMRx,<br>MMRy   | Регистр, отображаемый на память, AR0–AR7 или SP                                                                                 |  |  |  |  |  |  |  |  |  |  |
| n               | Число слов, полученных а результате выполнения команды XC;<br>n = 1 или 2                                                       |  |  |  |  |  |  |  |  |  |  |
| N               | Определяет регистр состояния, изменяемый в командах RSBX, SSBX, и XC: N = 0 статусный регистр ST0 N = 1 статусный регистр ST1   |  |  |  |  |  |  |  |  |  |  |
| OVA             | Флаг переполнения аккумулятора А в ST0                                                                                          |  |  |  |  |  |  |  |  |  |  |
| OVB             | Флаг переполнения аккумулятора В в ST0                                                                                          |  |  |  |  |  |  |  |  |  |  |
| OVdst           | Флаг переполнения аккумулятора приемника (А или В)                                                                              |  |  |  |  |  |  |  |  |  |  |
| OVdst_          | Флаг переполнения аккумулятора, противоположного приемнику (А или В)                                                            |  |  |  |  |  |  |  |  |  |  |
| OVsrc           | Флаг переполнения аккумулятора источника (А или В)                                                                              |  |  |  |  |  |  |  |  |  |  |
| OVM             | Бит режима переполнения в ST1                                                                                                   |  |  |  |  |  |  |  |  |  |  |
| PA              | непосредственный 16-разрядный адрес порт (0 ≤ РА ≤ 65 535)                                                                      |  |  |  |  |  |  |  |  |  |  |
| PAR             | Регистр адреса программы                                                                                                        |  |  |  |  |  |  |  |  |  |  |
| PC              | Счетчик программ                                                                                                                |  |  |  |  |  |  |  |  |  |  |
| pmad            | Непосредственный 16-разрядный адрес памяти программ (0 ≤ pmad ≤ 65 535)                                                         |  |  |  |  |  |  |  |  |  |  |
| Pmem            | Операнд в памяти программ                                                                                                       |  |  |  |  |  |  |  |  |  |  |
| PMST            | Регистр состояния режима процессора                                                                                             |  |  |  |  |  |  |  |  |  |  |
| prog            | Операнд в памяти программ                                                                                                       |  |  |  |  |  |  |  |  |  |  |
| [R]             | Режим округления                                                                                                                |  |  |  |  |  |  |  |  |  |  |
| RC              | Счетчик повторения                                                                                                              |  |  |  |  |  |  |  |  |  |  |
| REA             | Регистр конечного адреса повторяемого блока                                                                                     |  |  |  |  |  |  |  |  |  |  |
| rnd             | округление                                                                                                                      |  |  |  |  |  |  |  |  |  |  |
| RSA             | Регистр начального адреса повторяемого блока                                                                                    |  |  |  |  |  |  |  |  |  |  |
| RTN             | Регистр быстрого возврата, используемый в команде RETF[D]                                                                       |  |  |  |  |  |  |  |  |  |  |
| SBIT            | 4-битное значение, которое определяет номер разряда регистра состояния, изменяемого в командах RSBX, SSBX, и XC (0 ≤ SBIT ≤ 15) |  |  |  |  |  |  |  |  |  |  |

| Обозначени<br>е | Содержание                                                          |
|-----------------|---------------------------------------------------------------------|
| SHFT            | 4-разрядное значение сдвига (0 ≤ SHFT ≤ 15)                         |
| SHIFT           | 5-разрядное значение сдвига (0 ≤ SHFT ≤ 15)                         |
| Sind            | Операнд в памяти данных, использующий косвенную адресацию           |
| Smem            | 16-разрядный операнд в памяти данных                                |
| SP              | Указатель стека                                                     |
| src             | Аккумулятор источник (A or B)                                       |
| ST0, ST1        | Статусный регистр 0, статусный регистр 1                            |
| SXM             | Бит режима расширения знака в ST1                                   |
| Т               | Временный регистр                                                   |
| TC              | Флаг проверки/управления в ST0                                      |
| TOS             | Вершина стека                                                       |
| TRN             | Регистр перехода                                                    |
| TS              | Значение сдвига, указанное битами 5-0 регистра Т<br>(–16 ≤ TS ≤ 31) |
| uns             | Беззнаковое значение                                                |
| XF              | Бит внешнего флага в ST1                                            |
| XPC             | Регистр расширения программного счетчика                            |
|                 | 16-битный операнд в расслоенной памяти,                             |
| Xmem            | используемый в двухоперандных командах и                            |
|                 | некоторых однооперандных командах                                   |
| Ymem            | 16-битный операнд в расслоенной памяти,                             |
|                 | используемый в двухоперандных командах                              |
| SP              | Значение указателя стека уменьшается на 1                           |
| + + SP          | Значение указателя стека увеличивается на 1                         |
| + + PC          | Значение программного счетчика увеличивается на 1                   |

# Таблица 20-30 – Обозначения и сокращения в коде операции

| Символ     | Значение                                                         |  |  |  |  |  |  |  |  |  |
|------------|------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Α          | Бит адреса памяти данных                                         |  |  |  |  |  |  |  |  |  |
| ARX        | 3-разрядное значение, которое определяет вспомогательный регистр |  |  |  |  |  |  |  |  |  |
| BITC       | 4-разрядный код номера разряда                                   |  |  |  |  |  |  |  |  |  |
| CC         | 2-разрядный код состояния                                        |  |  |  |  |  |  |  |  |  |
| CCCC CCCC  | 8-разрядный код состояния                                        |  |  |  |  |  |  |  |  |  |
| COND       | 4-разрядный код состояния                                        |  |  |  |  |  |  |  |  |  |
| D          | Бит аккумулятора приемника (dst)                                 |  |  |  |  |  |  |  |  |  |
|            | D = 0 аккумулятор A                                              |  |  |  |  |  |  |  |  |  |
|            | D = 1 аккумулятор В                                              |  |  |  |  |  |  |  |  |  |
| 1          | Бит режима адресации                                             |  |  |  |  |  |  |  |  |  |
|            | I = 0 режим прямой адресации                                     |  |  |  |  |  |  |  |  |  |
|            | I = 1 режим косвенной адресации                                  |  |  |  |  |  |  |  |  |  |
| K          | Короткое непосредственное значение меньше чем 9 бит              |  |  |  |  |  |  |  |  |  |
| MMRX       | 4-битное значение, определяющее один из девяти отображаемых на   |  |  |  |  |  |  |  |  |  |
| IVIIVIIXX  | память регистров (0 ≤ MMRX ≤ 8)                                  |  |  |  |  |  |  |  |  |  |
| MMRY       | 4-битное значение, определяющее один из девяти отображаемых на   |  |  |  |  |  |  |  |  |  |
| IVIIVIIX I | память регистров (0 ≤ MMRY ≤ 8)                                  |  |  |  |  |  |  |  |  |  |
| N          | Одиночный бит                                                    |  |  |  |  |  |  |  |  |  |
| NN         | 2-битное значение, определяющее тип прерывания                   |  |  |  |  |  |  |  |  |  |

| Символ | Значение                                                      |
|--------|---------------------------------------------------------------|
| R      | Бит выбора округления (rnd)                                   |
|        | R = 0 команда выполняется без округления                      |
|        | R = 1 округление результата                                   |
| S      | Бит аккумулятора источника (src)                              |
|        | S = 0 аккумулятор А                                           |
|        | S = 1 аккумулятор В                                           |
| SBIT   | 4-разрядный номер разряда статусного регистра                 |
| SHFT   | 4-разрядное значение сдвига (0 ≤ SHFT ≤ 15)                   |
| SHIFT  | 5-разрядное значение сдвига (–16 ≤ SHIFT ≤ 15)                |
| Χ      | Бит памяти данных                                             |
| Υ      | Бит памяти данных                                             |
| Z      | Бит задержки команды: Z = 0 команда выполняется без задержки, |
|        | Z = 1 команда выполняется с задержкой                         |

# Таблица 20-31 – Система обозначений набора команд

| Символ            | Значение                                                                                                                           |  |  |  |  |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Выделение         | Выделенные жирным шрифтом буквы в синтаксисе команды должны                                                                        |  |  |  |  |  |  |
| жирным            | быть записаны точно в таком же виде, например: в синтаксисе ADD                                                                    |  |  |  |  |  |  |
| шрифтом           | <u>Xmem, Ymem, dst,</u> можно использовать любые значения <u>Xmem</u> и <u>Ymem,</u>                                               |  |  |  |  |  |  |
|                   | но слово ADD должно быть напечатано так, как показано.                                                                             |  |  |  |  |  |  |
| курсив            | Символы, выделенные в синтаксисе курсивом, являются переменными.                                                                   |  |  |  |  |  |  |
|                   | Например: в синтаксисе <b>ADD</b> <u>Хтем, Ymem, dst,</u> можно использовать                                                       |  |  |  |  |  |  |
|                   | любые значения для <u>Хтет</u> и <u>Утет</u> .                                                                                     |  |  |  |  |  |  |
| [x]               | Операнд, взятый в квадратные скобки является необязательным.                                                                       |  |  |  |  |  |  |
|                   | Например: в синтаксисе <b>ADD</b> <u>Smem</u> [, <u>SHIFT</u> ], <u>src</u> [, <u>dst</u> ], необходимо                            |  |  |  |  |  |  |
|                   | использовать значения для <u>Smem</u> и <u>src;</u> в то время как <u>SHIFT</u> и <u>dst</u>                                       |  |  |  |  |  |  |
| #                 | являются необязательными.                                                                                                          |  |  |  |  |  |  |
| #                 | Префикс константы, используемый в непосредственной адресации. Для коротких или длинных непосредственных операндов # используется в |  |  |  |  |  |  |
|                   | коротких или длинных непосредственных операндов # используется в командах где присутствует неоднозначность по отношению к другим   |  |  |  |  |  |  |
|                   | режимам адресации, использующим непосредственный операнд.                                                                          |  |  |  |  |  |  |
|                   | например: RPT #15 короткую непосредственную адресацию, что                                                                         |  |  |  |  |  |  |
|                   | вызывает 16-тикратное повторение следующей команды. RPT 15                                                                         |  |  |  |  |  |  |
|                   | использует прямую адресацию. Количество повторов следующей                                                                         |  |  |  |  |  |  |
|                   | команды определяется значением, хранимым в памяти. Для команд                                                                      |  |  |  |  |  |  |
|                   | использующих непосредственные операнды, для которых нет                                                                            |  |  |  |  |  |  |
|                   | неоднозначности, # принимается ассемблером. Например, RPTZ A, #15                                                                  |  |  |  |  |  |  |
|                   | и RPTZ A, 15 эквивалентны.                                                                                                         |  |  |  |  |  |  |
| (abc)             | Содержание регистра или расположение abc. Например : (src)                                                                         |  |  |  |  |  |  |
|                   | обозначает содержание аккумулятора источника.                                                                                      |  |  |  |  |  |  |
| $x \rightarrow y$ | Значение х присваивается регистру или ячейке у. Например: (Smem) →                                                                 |  |  |  |  |  |  |
|                   | dst обозначает, что содержанием ячейки памяти данных загружается                                                                   |  |  |  |  |  |  |
|                   | аккумулятор приемник.                                                                                                              |  |  |  |  |  |  |
| r(n–m)            | Биты с n по m в регистре или ячейке r . Например: src(15-0) означает                                                               |  |  |  |  |  |  |
|                   | биты аккумулятора источника с 15 по 0.                                                                                             |  |  |  |  |  |  |
| << nn             | Сдвиг влево битов nn (отрицательный или положительный)                                                                             |  |  |  |  |  |  |
|                   | Параллельная команда                                                                                                               |  |  |  |  |  |  |
| //                | Циклически сдвинуть влево                                                                                                          |  |  |  |  |  |  |
| //                | Циклически сдвинуть вправо                                                                                                         |  |  |  |  |  |  |
| _<br>X            | Логическая инверсия х (в двоичной системе)                                                                                         |  |  |  |  |  |  |

| Символ | Значение                                                |  |  |  |  |  |  |  |  |
|--------|---------------------------------------------------------|--|--|--|--|--|--|--|--|
| x      | Абсолютное значение х                                   |  |  |  |  |  |  |  |  |
| AAh    | Показывает, что АА представляет шестнадцатеричное число |  |  |  |  |  |  |  |  |

# Таблица 20-32 - Операторы, используемые в наборе команд

| Символ | Операторы                           | Вычисление    |
|--------|-------------------------------------|---------------|
| + - ~  | унарный плюс, минус, обратный код   | справа налево |
| * / %  | умножение, деление, число по модулю | слева направо |
| + -    | сложение, вычитание                 | слева направо |
| << >>  | сдвиг влево, сдвиг вправо           | слева направо |
| < < <  | логический сдвиг влево              | слева направо |
| < ≤    | меньше чем, меньше чем или равно    | слева направо |
| >≥     | больше чем, больше чем или равно    | слева направо |
| ≠ !=   | не равно                            | слева направо |
| &      | побитовое «И» (AND)                 | слева направо |
| ^      | побитовое исключение ИЛИ (XOR)      | слева направо |
|        | побитовое "ИЛИ» (OR)                | слева направо |

# 20.3.1.1 Структура описания команд

Данный типичный пример описания команды приводится для того, чтобы ознакомить с форматом описания команды и объяснить, что описывается каждым заголовком. Каждое описание команды представляет следующую информацию:

- 1. Синтаксис ассемблера;
- 2. Операнды;
- 3. Код операции;
- 4. Выполнение;
- 5. Статусные биты (признаки);
- 6. Описание:
- 7. Слова:
- 8. Циклы;
- 9. Классы;
- 10. Примеры.

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

- 1. Метка;
- 2. Команда и операнды;
- 3. Комментарий.

#### **Синтаксис** 1: **EXAMPLE** Smem, src

- 2: **EXAMPLE** Smem, **TS**, src
- 3: **EXAMPLE** Smem, **16**, src [, dst ]
- 4: **EXAMPLE** Smem [, SHIFT], src [, dst ]

Каждое описание команды начинается с выражения на языке ассемблера. См. раздел о значении символов синтаксиса.

**Операнды** Smem: Единичный операнд памяти данных

Xmem, Ymem: Двойные операнды памяти данных

src, dst: A (аккумулятор A) В (аккумулятор В)

-16 ≤ SHIFT ≤ 15

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

# Код операции

Код операции разделяет различные поля битов для формирования каждой из команд. См. раздел об определении символы кода операции.

#### Выполнение

- 1: (Smem) + (src) → src
- 2: (Smem) << (TS) + (src) → src
- 3:  $(Smem) << 16 + (src) \rightarrow dst$ 
  - (Smem) [ << SHIFT ] + (src) → dst

Раздел выполнения описывает процессы, которые происходят во время выполнения команды. Примеры выполнений пронумерованы в соответствии с нумерацией синтаксиса. См. раздел определения символов выполнения.

# Статусные биты

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

#### Описание

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

#### Слова

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

#### Циклы

Это поле уточняет количество циклов, требуемых для выполнения данной команды в процессоре один раз с доступом данных в DARAM доступом программ из ROM. Дополнительное уточнение количества циклов необходимое для других конфигураций памяти и режимов повторения, приводится в главе 3, Классы и циклы команд.

#### Классы

Это поле уточняет класс команды для каждого синтаксиса команды. См. главу о классах и циклах команд, для определения каждого класса.

Пример

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

# 20.3.2 ABDST Xmem, Ymem

Операнды

Xmem, Ymem: операнды в памяти данных двойного доступа.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 1 | х | X | Χ | Χ | Υ | Υ | Υ | Υ |

Выполнение

(B) +  $|(A(32-16))| \rightarrow B$ 

 $((Xmem) - (Ymem)) << 16 \rightarrow A$ 

Статусные

((∧птетт) - (тттетт)) < то → д Изменяется под влиянием

Влияет на C, OVA, и OVB.

биты Описание

Эта команда рассчитывает абсолютное значение расстояния между векторами Xmem и Ymem. Абсолютное значение аккумулятора A(32–16) добавляется к значению аккумулятора В. Содержимое Ymem вычитается из Xmem, результат сдвигается влево на 16 бит и сохраняется в аккумуляторе А. Если установлен режим дробных чисел (FRCT = 1), то абсолютное значение умножается на 2.

OVM,

FRCT.

SXM.

Слова1 слово.Циклы1 цикл.КлассыКласс 7.

Пример ABDST \*AR3+, \*AR4+

|      | Перед исполнением |      |      |  |  |  |
|------|-------------------|------|------|--|--|--|
| Α    | FF                | ABCD | 0000 |  |  |  |
| В    | 00                | 0000 | 0000 |  |  |  |
| AR3  |                   |      | 0100 |  |  |  |
| AR4  |                   |      | 0200 |  |  |  |
| FRCT |                   |      | 0    |  |  |  |
|      |                   |      |      |  |  |  |

|      | Посл | После исполнения |      |  |  |  |
|------|------|------------------|------|--|--|--|
| Α    | FF   | FFAB             | 0000 |  |  |  |
| В    | 00   | 0000             | 5433 |  |  |  |
| AR3  |      |                  | 0101 |  |  |  |
| AR4  |      |                  | 0201 |  |  |  |
| FRCT |      |                  | 0    |  |  |  |
|      |      |                  |      |  |  |  |

Память данных

| 0100h | 0055 |
|-------|------|
| 0200h | 00AA |

| 0100h | 0055 |
|-------|------|
| 0200h | 00AA |

# 20.3.3 ABS src [, dst ]

В (аккумулятор В)

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | S | D | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |

Выполнение

 $|(src)| \rightarrow dst$  (или src, если dst не задан).

Статусные биты OVM влияет на выполнение команды следующим образом:

если OVM = 1, то абсолютное значение 80 0000 0000h равно 00

7FFF FFFFh.

если OVM = 0, то абсолютное значение 80 0000 0000h равно 80

0000 0000h.

Осказывает влияние на С и OVdst (или OVsrc, если dst = src).

**Описание** Данная команда вычисляет абсолютное значение src и загружает

это значение в dst. Если dst не задан, то абсолютное значение

загружается в src.

Если результат команды равен 0, то устанавливается бит С.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.Пример 1ABS A, B

|   | Перед | исполнен | ием  |       |
|---|-------|----------|------|-------|
| Α | FF    | FFFF     | FFCB | -53   |
| В | FF    | FFFF     | FC18 | -1000 |

|   | После | исполне | ния  |     |
|---|-------|---------|------|-----|
| Α | FF    | FFFF    | FFCB | -53 |
| В | 00    | 0000    | 0035 | +53 |

Пример 2

ABS A Перед исполнением

| Α   | 03 | 1234 | 5678 |
|-----|----|------|------|
| OVM |    |      | 1    |

|     | После исполнения |      |      |  |  |  |
|-----|------------------|------|------|--|--|--|
| Α   | 00               | 7FFF | FFFF |  |  |  |
| OVM |                  |      | 1    |  |  |  |

Пример 3

ABS A

|     | перед | исполнен | ием  |
|-----|-------|----------|------|
| Α   | 03    | 1234     | 5678 |
| OVM |       |          | 0    |

|     | После | исполне | ния  |
|-----|-------|---------|------|
| Α   | 00    | 7FFF    | FFFF |
| OVM |       |         | 0    |

#### 20.3.4 ADD

1: ADD Smem, src

2: ADD Smem, TS, src

3: **ADD** Smem, 16, src [, dst ]

4: ADD Smem [, SHIFT], src [, dst ]

5: ADD Xmem, SHFT, src

6: ADD Xmem, Ymem, dst

7: **ADD** #lk [, SHFT], src [, dst ]

8: **ADD** #lk, 16, src [, dst ]

9: **ADD** src [, SHIFT], [, dst ]

10: **ADD** src, ASM [, dst ]

# Операнды

Smem: операнд памяти данных одиночного доступа.

Xmem, Ymem: операнды памяти данных двойного доступа.

src, dstA: A (аккумулятор A). B (аккумулятор B).

 $-32768 \le lk \le 32767$ 

-16 ≤ SHIFT ≤ 15

0 ≤ SHFT ≤ 15

## Код операции 1:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | s | ı | Α | Α | Α | Α | Α | Α | Α |

2:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 1  | 0 | S | 1 | Α | Α | Α | Α | Α | Α | Α |

3:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 1  | 1  | 1  | 1  | S | D | I | Α | Α | Α | Α | Α | Α | Α |

4:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 1  | 0  | 1  | 1  | 1 | 1 | ı | Α | Α | Α | Α | Α | A | Α |
| 0  | 0  | 0  | 0  | 1  | 1  | S | D | 0 | 0 | 0 | S | Н | ı | F | Т |

5:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 1  | 0  | 0  | 0 | S | Х | Х | Х | Х | S | Н | F | Т |

6:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 1  | 0  | 0  | 0  | 0 | D | Х | X | X | X | Υ | Υ | Υ | Υ |

7:

|     | 15      | 14   | 13    | 12      | 11    | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|-----|---------|------|-------|---------|-------|----|-----|-----|-----|------|----|---|---|---|---|---|
|     | 1       | 1    | 1     | 1       | 0     | 0  | S   | D   | 0   | 0    | 0  | 0 | S | Н | F | Т |
|     |         |      |       |         |       | 16 | бит | ная | кон | стан | та |   |   |   |   |   |
| 8:  |         |      |       |         |       |    |     |     |     |      |    |   |   |   |   |   |
|     | 15      | 14   | 13    | 12      | 11    | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|     | 1       | 1    | 1     | 1       | 0     | 0  | S   | D   | 0   | 0    | 1  | 1 | 0 | 0 | 0 | 0 |
|     |         |      |       |         |       | 16 | бит | ная | кон | стан | та |   |   |   |   |   |
| 9:  |         |      |       |         |       |    |     |     |     |      |    |   |   |   |   |   |
|     | 15      | 14   | 13    | 12      | 11    | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|     | 1       | 1    | 1     | 1       | 0     | 1  | S   | D   | 0   | 0    | 0  | S | Н | I | F | T |
| 10: |         |      |       |         |       |    |     |     |     |      |    |   |   |   |   |   |
|     | 15      | 14   | 13    | 12      | 11    | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|     | 1       | 1    | 1     | 1       | 0     | 1  | S   | D   | 1   | 0    | 0  | 0 | 0 | 0 | 0 | 0 |
| 4./ | C 100 0 | ·m \ | . /0: | · ~ / ~ | 0 " 0 |    |     |     |     |      |    |   |   |   |   |   |

#### Выполнение

- 1: (Smem) + (src) → src
- 2: (Smem) << (TS) + (src) → src
- 3: (Smem) << 16 + (src) → dst
- 4: (Smem) [<< SHIFT] + (src) → dst
- 5: (Xmem) << SHFT + (src) → src
- 6: ((Xmem) + (Ymem)) << 16 → dst
- 7: lk << SHFT + (src)→ dst
- 8: lk << 16 + (src) → dst
- 9: (src or [dst]) + (src) << SHIFT → dst
- 10: (src or [dst]) + (src) << ASM → dst

# Статусные биты

Изменяется под влиянием SXM и OVM.

Влияет на С и OVdst (или OVsrc, если dst = src).

Для синтаксиса команды 3, если результат сложения вызывает перенос, то бит переноса С, принимает значение 1; в противном случае, С остается неизменным.

# Описание

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

- 1. Содержимое операнда в памяти данных одиночного доступа (Smem).
- 2. Содержимое операнда в памяти данных двойного доступа (Ymem).
- 3. Операнд с непосредственным 16-битным значением (#lk).
- 4. Значение со сдвигом src.

Если dst указан, то данная команда сохраняет результат в dst. если dst не определен, то команда сохраняет результат в src.

Большинство вторых операндов может быть со сдвигом. Для сдвига влево:

- 1. Младшие разряды принимают значение 0.
- 2. Старшие разряды:
  - Знак расширяется, если SXM = 1
  - Принимает значение 0, если SXM = 0

В случае сдвига вправо старшие разряды:

- Знак расширяется, если SXM = 1
- Принимает значение 0, SXM = 0

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

- 1. Синтаксис 4: если dst = src и SHIFT = 0, тогда код операции команды транслируется как синтаксис 1.
- 2. Синтаксис 4: если dst = src, SHIFT ≤ 15 и режим косвенной адресации Smem включен в Xmem, тогда код операции команды транслируется как синтаксис 5.
- 3. Синтаксис 5: если SHIFT = 0, тогда код операции команды транслируется как синтаксис 1.

#### Слова

Синтаксисы 1, 2, 3, 5, 6, 9, и 10: 1 слово.

Синтаксисы 4, 7, и 8: 2 слова.

Добавляется 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Циклы

Синтаксисы 1, 2, 3, 5, 6, 9, и 10: 1 цикл.

Синтаксис 4, 7, и 8: 2 цикла.

Добавляется 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Классы

Синтаксисы 1, 2, 3, и 5: класс 3А.

Синтаксисы 1, 2, и 3: класс 3.

Синтаксис 4: класс 4А. Синтаксис 4: класс 4В.

Синтаксис 6: класс 7.

Синтаксисы 7 и 8: класс 2.

Синтаксисы 9 и 10: класс 1.

#### Пример 1

ADD \*AR3+, 14, A

|            | Перед | исполнен | ием  |       | После | исполне | <b>Р</b> |
|------------|-------|----------|------|-------|-------|---------|----------|
| Α          | 00    | 0000     | 1200 | Α     | 00    | 0540    | 1200     |
| С          |       |          | 1    | С     |       |         | 01       |
| AR3        |       |          | 0100 | AR3   |       |         | 0101     |
| SXM        |       |          | 1    | SXM   |       |         | 1        |
| Память дан | ных   |          |      |       |       |         |          |
| 0100h      |       |          | 1500 | 0100h |       |         | 1500     |

#### Пример 2

ADD A, -8, B

|          |        | Перед      | исполнен | ием  |                 | После     | исполне | ния  |
|----------|--------|------------|----------|------|-----------------|-----------|---------|------|
|          | Α      | 00         | 0000     | 1200 | Α               | 00        | 0000    | 1200 |
|          | В      | 00         | 0000     | 1800 | В               | 00        | 0000    | 1812 |
|          | С      |            |          | 1    | С               |           |         | 0    |
| Пример 3 | ADD #4 | 4568, 8, A | , В      |      |                 |           |         |      |
|          |        | Перед      | исполнен | ием  |                 | После     | исполне | ния  |
|          | Α      | 00         | 0000     | 1200 | Α               | 00        | 0000    | 1200 |
|          | В      | 00         | 0000     | 1800 | В               | 00        | 0045    | 7A00 |
|          | С      |            |          | 1    | С               |           |         | 0    |
| Пример 4 | ADD *A | \R2+, *AF  | R2–, A   | ;пос | пе доступа к оп | еранду, А | R2      |      |

;увеличивается на 1.

Пример 4 показывает один и тот же вспомогательный регистр (AR2) с различными режимами адресации, установленный для обоих операндов. Режим, установленный полем Xmod (\*AR2+), используется для адресации.

#### 20.3.5 ADDC Smem, src

| оступа. |
|---------|
| 0       |

А (аккумулятор А). src: В (аккумулятор В).

Код 14 13 12 11 10 операции 0 0 1 S Α Α Α

Выполнение  $(Smem) + (src) + (C) \rightarrow src$ Статусные Результат зависит от OVM, C.

биты Влияет на С и OVsrc.

Описание Эта команда складывает 16-битный операнд в памяти данных одиночного доступа Smem и значение бита переноса (C) с src. Команда сохраняет результат в src. Знаковый разряд не расширяется

независимо от значения бита SXM.

Слова 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Класс 3А. Классы Класс 3В.

ADDC \*+AR2(5), A Пример 1

|            | Перед    | исполнен | ием  |       | После | исполне | ния  |
|------------|----------|----------|------|-------|-------|---------|------|
| Α          | 00       | 0000     | 0013 | Α     | 00    | 0000    | 0018 |
| С          |          |          | 1    | С     |       |         | 0    |
| AR2        |          |          | 0100 | AR2   |       |         | 0105 |
| Память дан | ных      |          |      |       |       |         |      |
| 0105h      |          |          | 0004 | 0105h |       |         | 0004 |
| ADDM #I    | lk, Smem |          |      |       |       |         |      |

#### 20.3.6

Операнды Smem: операнд памяти данных одиночного доступа.

 $-32768 \le lk \le 32767$ 

Код операции

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|-----|-----|-----|------|----|---|---|---|---|---|
|   | 0  | 1  | 1  | 0  | 1  | 0  | 1   | 1   | ı   | Α    | Α  | Α | Α | Α | Α | Α |
|   |    |    |    |    |    | 16 | бит | ная | кон | стан | та |   |   |   |   |   |

Выполнение

#lk + (Smem) → Smem

Статусные

Результат зависит от OVM и SXM.

биты

Влияет на С и OVA.

Описание

Эта команда добавляет 16-битный операнд в памяти данных одиночного доступа Smem к 16-битному непосредственному значению памяти lk и сохраняет результат в Smem.

Примечание – Эта команда не повторяемая.

Слова

2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Smem.

Циклы

2 цикла.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Smem.

Классы

Класс 18А. Класс 18В.

Пример 1

ADDM 0123Bh, \*AR4+

|               | Перед командой |       | После команды |  |  |  |  |  |  |
|---------------|----------------|-------|---------------|--|--|--|--|--|--|
| AR4           | 0100           | AR4   | 0101          |  |  |  |  |  |  |
| Память данных |                |       |               |  |  |  |  |  |  |
| 0100h         | 0004           | 0100h | 132F          |  |  |  |  |  |  |

Пример 2 ADDM 0FFF8h, \*AR4+



## 20.3.7 ADDS Smem, src

**Операнды** Smem: операнд в памяти данных одиночного доступа.

src: A (аккумулятор A).

В (аккумулятор В).

операции

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

0 0 0 0 0 0 1 S I A A A A A A A

Выполнение uns(Smem) + (src)  $\rightarrow$  src Статусные Ha результат влияет OVM.

**биты** Сама инструкция влияет на С и OVsrc.

Описание Эта команда складывает 16-битный операнд в памяти данных

одиночного доступа Smem к src и сохраняет результат в src.

Расширение знака подавляется независимо от значения бита SXM.

**Слова** 1 слово.

Код

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Класс 3А.

Класс 3В.

Пример ADDS \*AR2-, В

|            | Перед | исполнен | ием  |       | После | исполне | ния  |
|------------|-------|----------|------|-------|-------|---------|------|
| В          | 00    | 0000     | 0003 | В     | 00    | 0000    | F009 |
| С          |       |          | х    | С     |       |         | 0    |
| AR2        |       |          | 0100 | AR2   |       |         | 00FF |
| Память дан | ных   |          |      |       |       |         |      |
| 0104h      |       |          | F006 | 0104h |       |         | F006 |

#### 20.3.8 AND

1: AND Smem, src

2: **AND** #lk [, SHFT], src [, dst]

3: **AND** #lk, 16, src [, dst ]

4: **AND** src [, SHIFT ], [, dst ]

#### Операнды

Smem:

операнд в памяти данных одиночного доступа

src:

1:

А (аккумулятор А) В (аккумулятор В)

 $-16 \le SHIFT \le 15$ 0 ≤ SHFT ≤ 15 0 ≤ lk ≤ 65 535

# Код операции



| ാ |  |
|---|--|
| _ |  |

| _1 | 5                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| •  | 1                   | 1  | 1  | 1  | 0  | 0  | S | D | 0 | 0 | 1 | 1 | S | Н | F | Т |
|    | 16 битная константа |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

3:

| _ | 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|   | 1                   | 1  | 1  | 1  | 0  | 0  | S | D | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 |
|   | 16 битная константа |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

4:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | S | D | 1 | 0 | 0 | S | Н | ı | F | Т |

#### Выполнение

- 1: (Smem) AND (src) → src
- 2: lk << SHFT AND (src)→ dst
- 3: lk << 16 AND (src)→ dst
- 4: (dst) AND (src) << SHIFT → dst

# Статусные биты Описание

Не используются

Данная команда реализует логическое умножение(AND) с src одного из следующих операндов:

- 1. 16-битного операнда Smem.
- 2. 16-битного непосредственного операнда lk.
- 3. Аккумулятора источник или аккумулятора приемник (src или dst).

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

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

обнуляются, а старший разряд знака не расширяется. При сдвиге

вправо к старшие разряды знака не расширяются.

Слова Синтаксис 1 и 41 слово.

Синтаксис 2 и 32 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Smem.

Циклы Синтаксис 1 и 4: 1 цикл.

Синтаксис 2 и 3: 2 цикла.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Smem.

Классы Синтаксис 1: класс 3А.

Синтаксис 1: класс 3В. Синтаксис 2 и 3: класс 2.

Синтаксис 4: класс 1.

**Пример 1** AND \*AR3+, A

|     | перед | исполнен | ием  |
|-----|-------|----------|------|
| Α [ | 00    | 00FF     | 1200 |
| ∖R3 |       |          | 0100 |

|   | TIOCHE | исполне | КИГ  |
|---|--------|---------|------|
| Α | 00     | 0000    | 1000 |
| С |        |         | 0101 |

Память данных

0100h 1500

0100h 1500

**Пример 2** AND A, 3, B

|   | Перед | исполнен | ием  |
|---|-------|----------|------|
| Α | 00    | 0000     | 1200 |
| В | 00    | 0000     | 1800 |

|   | После | исполне | ния  |
|---|-------|---------|------|
| Α | 00    | 0000    | 1200 |
| В | 00    | 0000    | 1000 |

### 20.3.9 ANDM #lk, Smem

**Операнды** Smem: операнд в памяти данных одиночного доступа.

 $0 \le lk \le 65535$ 

Код

операции

| 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0                   | 1  | 1  | 0  | 1  | 0  | 0 | 0 | 1 | Α | Α | Α | Α | Α | Α | Α |
| 16 битная константа |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Выполнение

Ik AND (Smem) → Smem

Статусные биты Не используются.

Описание

Данная команда производит логическое умножение (AND) 16-битного операнда памяти данных одиночного доступа Smem и 16-разрядной длинной константы Ik. Результат сохраняется в ячейке памяти данных,

определяемой Smem.

Примечание – Данная команда не повторяемая.

Слова 2 слова

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Класс 18А.

Класс 18В.

Пример 1 ANDM #00FFh, \*AR4+

|     | Перед исполнением |     | После исполнения |
|-----|-------------------|-----|------------------|
| AR4 | 0100              | AR4 | 0101             |
|     |                   |     |                  |

Память данных

0100h 0444 0100h 0044

Пример 2 ANDM #0101h, 4; DP = 0

Перед исполнением После исполнения

Память данных

0004h 00 0000 0100 0004h 00 0000 0100

# 20.3.10 *B[D] pmad*

Операнды Код операции  $0 \le pmad \le 65535$ 

| 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1                   | 1  | 1  | 1  | 0  | 0  | Z | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |
| 16 битная константа |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Выполнение Статусные биты Описание  $pmad \rightarrow PC$ 

Не используются.

Данная команда передает управление по адресу памяти программ (pmad), который может быть задан как символически так и числом. Если переход задержанный (определяется по наличию суффикса D), то две однословные команды или одна двухсловная команда, следующие за командой перехода, вызываются из памяти программ и выполняются.

Примечание – Командна не повторяемая.

**Слова** 2 слова. **Циклы** 4 цикла.

2 цикла (задержанный).

**Классы** Класс 29A. **Пример 1** В 2000h

|   | Перед командой |    | После команды |
|---|----------------|----|---------------|
| C | 1F45           | PC | 2000          |

# Пример 2

BD 1000h

Ρ

ANDM 4444h, \*AR1+

|    | Перед командой |    | После команды |
|----|----------------|----|---------------|
| PC | 1F45           | PC | 1000          |

После того, как команда AND была выполнена над операндом со значением 4444h, программа продолжает выполнение в ячейке 1000h.

# 20.3.11 BACC[D] src

Операнды А (аккумулятор А) src:

В (аккумулятор В)

Код операции

| <br>15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1      | 1  | 1  | 1  | 0  | 1  | Z | S | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |

Выполнение

 $(src(15-0)) \rightarrow PC$ 

Статусные биты

Не используются.

Описание

Данная команда передает управление по 16-разрядному адресу в младшей части src (биты 15-0). Если переход задержанный (определяется по наличию суффикса D), то две команды с одним словом или одна команда с двумя словами, следующие за вызываются из командой перехода, памяти программ выполняются.

Примечание – Данная команда не повторяющаяся.

1 слово. Слова 6 циклов. Циклы

4 цикла (задержанный).

Класс 30А. Классы **BACC A** Пример 1

| Пере | д командо | рй   |    | Посл | іе команды |
|------|-----------|------|----|------|------------|
| 00   | 00 0000   |      | Α  | 00   | 0000       |
|      |           | 1F45 | PC |      |            |

#### Пример 2

BACCD B

PC

ANDM 4444h, \*AR1+

|    | Пере | д командо | рй   |    | После команды |      |      |  |  |
|----|------|-----------|------|----|---------------|------|------|--|--|
| В  | 00   | 0000      | 2000 | В  | 00            | 0000 | 2000 |  |  |
| PC |      |           | 1F45 | PC |               |      | 2000 |  |  |

После того, как команда AND была выполнена над операндом со значением 4444h, программа продолжает выполнение в ячейке 2000h.

3000

3000

# 20.3.12 BANZ[D] pmad, Sind

| 20.3.12           | BANZ[D] pmad, Smd                                                                                                      |  |  |  |  |  |  |  |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Операнды          | Sind: операнд косвенной адресации одиночного доступа.<br>0 ≤ pmad ≤ 65 535                                             |  |  |  |  |  |  |  |  |
| Код операции      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                  |  |  |  |  |  |  |  |  |
|                   | 0 1 1 0 1 1 Z 0 I A A A A A A                                                                                          |  |  |  |  |  |  |  |  |
|                   | 16 битная константа                                                                                                    |  |  |  |  |  |  |  |  |
| Выполнение        | If $((ARx) \neq 0)$                                                                                                    |  |  |  |  |  |  |  |  |
|                   | then pmad → PC                                                                                                         |  |  |  |  |  |  |  |  |
|                   | Else                                                                                                                   |  |  |  |  |  |  |  |  |
| 0                 | $(PC) + 2 \rightarrow PC$                                                                                              |  |  |  |  |  |  |  |  |
| Статусные<br>биты | Не используются.                                                                                                       |  |  |  |  |  |  |  |  |
| Описание          | Если значение текущего вспомогательного регистра ARx не равно                                                          |  |  |  |  |  |  |  |  |
|                   | 0, команда осуществляет переход по указанному адресу памяти                                                            |  |  |  |  |  |  |  |  |
|                   | программ (pmad). В противном случае, PC увеличивается на 2. Если переход задержанный (определяется по наличию суффикса |  |  |  |  |  |  |  |  |
|                   | <ul><li>D), то две команды с одним словом или одна команда с двумя</li></ul>                                           |  |  |  |  |  |  |  |  |
|                   | словами, следующие за командой перехода, вызываются из                                                                 |  |  |  |  |  |  |  |  |
|                   | памяти программ и выполняются.                                                                                         |  |  |  |  |  |  |  |  |
| _                 | Примечание – Данная команда не повторяемая.                                                                            |  |  |  |  |  |  |  |  |
| Слова             | 2 слова.                                                                                                               |  |  |  |  |  |  |  |  |
| Циклы             | 4 цикла (истинное условие).<br>2 цикла (ложное условие).                                                               |  |  |  |  |  |  |  |  |
|                   | 2 цикла (ложное условие).<br>2 цикла (задержанная).                                                                    |  |  |  |  |  |  |  |  |
| Классы            | Класс 29А.                                                                                                             |  |  |  |  |  |  |  |  |
|                   |                                                                                                                        |  |  |  |  |  |  |  |  |
|                   |                                                                                                                        |  |  |  |  |  |  |  |  |
| - 4               | DANIZ 00001 #AD0                                                                                                       |  |  |  |  |  |  |  |  |
| Пример 1          | BANZ 2000h, *AR3–                                                                                                      |  |  |  |  |  |  |  |  |
|                   | Перед командой После команды PC 1000 PC 2000                                                                           |  |  |  |  |  |  |  |  |
|                   | AR3 0005 AR3 0004                                                                                                      |  |  |  |  |  |  |  |  |
| Пример 2          | BANZ 2000h, *AR3–                                                                                                      |  |  |  |  |  |  |  |  |
| пример 2          | Перед командой После команды                                                                                           |  |  |  |  |  |  |  |  |
|                   | PC 1000 PC 1002                                                                                                        |  |  |  |  |  |  |  |  |
|                   | AR3 0000 AR3 FFFF                                                                                                      |  |  |  |  |  |  |  |  |
| Пример 3          | BANZ 2000h, *AR3(–1)                                                                                                   |  |  |  |  |  |  |  |  |
| · ·               | Перед командой После команды                                                                                           |  |  |  |  |  |  |  |  |

BANZD 2000h, \*AR3-

PC

AR3

1000

0001

PC

AR3

1003

0001

|     | Перед командой |
|-----|----------------|
| PC  | 1000           |
| AR3 | 0004           |

|     | После команды |
|-----|---------------|
| PC  | 2000          |
| AR3 | 0003          |

После того, как ячейку памяти логически умножается (AND) на значение 4444h, программа продолжает выполнение с ячейки 2000h.

# 20.3.13 BC[D] pmad, cond [, cond [, cond ]]

# Операнды

 $0 \le pmad \le 65535$ 

В таблице ниже приводятся условия для данной команды (операнд условия).

| Операнд<br>условия | Описание     | Код<br>условия | Операнд<br>условия | Описание     | Код<br>условия |
|--------------------|--------------|----------------|--------------------|--------------|----------------|
| BIO                | BIO low      | 0000 0011      | NBIO               | BIO high     | 0000 0010      |
| С                  | C=1          | 0000 1100      | NC                 | C=0          | 0000 1000      |
| TC                 | TC=1         | 0011 0000      | NTC                | TC=0         | 0010 0000      |
| AEQ                | (A) = 0      | 0100 0101      | BEQ                | (B) = 0      | 0100 1101      |
| ANEQ               | $(A) \neq 0$ | 0100 0100      | BNEQ               | (B) ≠ 0      | 0100 1100      |
| AGT                | (A) > 0      | 0100 0110      | BGT                | (B) > 0      | 0100 1110      |
| AGEQ               | $(A) \geq 0$ | 0100 0010      | BGEQ               | (B) ≥ 0      | 0100 1010      |
| ALT                | (A) < 0      | 0100 0011      | BLT                | (B) < 0      | 0100 1011      |
| ALEQ               | $(A) \leq 0$ | 0100 0111      | BLEQ               | (B) ≤ 0      | 0100 1111      |
| AOV                | Α            | 0111 0000      | BOV                | В            | 0111 1000      |
|                    | переполнение |                |                    | переполнение |                |
| ANOV               | А отсутствие | 0110 0000      | BNOV               | В отсутствие | 0110 1000      |
|                    | переполнения |                |                    | переполнения |                |
| UNC                | безусловный  | 0000 0000      |                    |              |                |

# Код операции

| 15 | 14                  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---------------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1                   | 1  | 1  | 1  | 0  | Z | 0 | С | С | С | С | С | С | С | С |
|    | 16 битная константа |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Выполнение

If (cond(s))

Then

 $pmad \rightarrow PC$ 

Else

 $(PC) + 2 \rightarrow PC$ 

Статусные биты Описание Зависит от OVA или OVB, если выбран OV или NOV.

Данная команда осуществляет переход по адресу памяти программ (pmad) в случае выполнения определенного(ых) условия(й). Две команды однословные или одна команда двухсловная, следующие за командой перехода извлекаются из памяти программ. Если условие(я) выполняется(ются), то два слова, следующие за командой, удаляются из конвейера и начинается выполнение с адреса pmad. Если условие(я) не выполняется(ются), то значение

РС увеличивается на 2 и выполняются два слова, следующие за командой.

Если переход задержаный (определяется по наличию суффикса D), то две команды по одному слову или одна команда с двумя словами извлекаются из памяти программ и выполняются. Два слова инструкции(й), следующие за задержанной командой, не влияют на анализируемое условие. Если условие выполняется, то выполнение будет продолжено по адресу pmad. Если условие не выполняется, то значение PC увеличивается на 2 и выполняются два слова инструкций, следующие за задержанной командой.

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

Группа 1: Вы можете выбрать не более двух условий. Каждое из этих условий должно быть из различных категорий (категория А или В); у вас не должно быть двух условий из одной категории. Например, вы можете осуществлять проверку EQ и OV одновременно, но не можете одновременно тестировать GT и NEQ. Для обоих условий аккумулятор должен быть один и тот же; одной командой нельзя осуществлять проверку сразу двух аккумуляторов. Например, вы можете одновременно осуществлять проверку AGT и AOV и не можете проверять одновременно AGT и BOV.

Группа 2: Вы можете выбрать не более трех условий. Каждое из этих условий должно быть из различных категорий (категория A, B, или C); у вас не должно быть двух условий из одной категории. Например, вы можете осуществлять проверку TC, C, и BIO одновременно, но не можете одновременно тестировать NTC, C, и NC.

Условия для данной команды

| Груп        | па 1        |             | Группа 2    |             |  |
|-------------|-------------|-------------|-------------|-------------|--|
| Категория А | Категория В | Категория А | Категория В | Категория С |  |
| EQ          | OV          | TC          | С           | BIO         |  |
| NEQ         | NOV         | NTC         | NC          | NBIO        |  |
| LT          |             |             |             |             |  |
| LEQ         |             |             |             |             |  |
| GT          |             |             |             |             |  |
| GEO         |             |             |             |             |  |

Примечание – Данная инструкция не повторяемая.

Слова

2 слова.

Циклы

5 циклов (истинное условие).

3 цикла (ложное условие).

3 цикла (задержанная).

Классы

Класс 31А.

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|          | -                           | <u> </u>               |                                  |        | • •                                               | <u>'</u> |         |            |
|----------|-----------------------------|------------------------|----------------------------------|--------|---------------------------------------------------|----------|---------|------------|
| Пример 1 | BC 200                      | 0h, AGT                |                                  |        |                                                   |          |         |            |
|          |                             | Перед                  | выполнен                         | нем    |                                                   | После    | выполне | <b>РИН</b> |
|          | Α                           | 00                     | 0000                             | 0053   | Α                                                 | 00       | 0000    | 0053       |
|          | PC                          |                        |                                  | 1000   | PC                                                |          |         | 2000       |
| Пример 2 | BC 200                      | 0h, AGT                |                                  |        |                                                   |          |         |            |
|          |                             | Перед                  | выполнен                         | нем    |                                                   | После    | выполне | <b>РИН</b> |
|          | Α                           | FF                     | FFFF                             | FFFF   | Α                                                 | FF       | FFFF    | FFFF       |
|          | PC                          |                        |                                  | 1000   | PC                                                |          |         | 1002       |
| Пример 3 |                             | 000h, BO\<br>4444h, *A |                                  |        |                                                   |          |         |            |
|          |                             | Перед                  | выполнен                         | нем    |                                                   | После    | выполне | <b>РИН</b> |
|          | PC                          |                        |                                  | 3000   | PC                                                |          |         | 1000       |
|          | OVB                         |                        |                                  | 1      | OVB                                               |          |         | 1          |
| Пример 4 | перехо<br>против<br>за данн | д осуще<br>ном случа   | ествляе <sup>:</sup><br>ае, выпс | тся пр | ги добавляется<br>ои выполнении<br>е продолжается | і услови | я (OV   | 'B). B     |
| 1-       |                             |                        | выполнен                         | нем    |                                                   | После    | выполне | <b>РИН</b> |
|          | PC                          |                        |                                  | 3000   | PC                                                |          |         | 3002       |

# 20.3.14 BIT Xmem, BITC

Операнды Хтет: операнд в памяти данных двойного доступа

0 ≤ BITC ≤ 15

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 1  | 0  | 1  | 1 | 0 | Х | Χ | X | X | В | I | T | C |

Выполнение Статусные биты  $(Xmem(15 - BITC)) \rightarrow TC$ 

Результат влияет на ТС.

Описание Данная команда копирует указанный бит операнда в памяти данных двойного доступа Xmem в бит TC статусного регистра ST0. В таблице ниже приведены коды битов, соответсвующие каждому биту в памяти

данных.

Код бита соответствует BITC , а адрес бита соответсвует (15 – BITC).

Коды битов для данной команды

| Адрес бита | Код бита | Адрес бита | Код бита |
|------------|----------|------------|----------|
| (LSB) 0    | 1111     | 8          | 0111     |
| 1          | 1110     | 9          | 0110     |
| 2          | 1101     | 10         | 0101     |
| 3          | 1100     | 11         | 0100     |
| 4          | 1011     | 12         | 0011     |
| 5          | 1010     | 13         | 0010     |
| 6          | 1001     | 14         | 0001     |
| 7          | 1000     | (MSB) 15   | 0000     |

Слова Циклы Классы 1 слово. 1 цикл.

Класс 3А.

Пример BIT \*AR5+, 15-12; test bit 12

|     | Перед исполнением |
|-----|-------------------|
| AR5 | 0100              |
| тс  | 0                 |

|     | После исполнения |
|-----|------------------|
| AR5 | 0101             |
| тс  | 1                |

Память данных

0100h 7688 0100h

7688

# 20.3.15 BITF Smem, #lk

| Операнды         | Smem: 0<br>0 ≤ lk ≤ 6                                                  |                                                                                                                                                                                                                                                                                                    |        | в па             | амят   | ги да    | аннь | IX O   | дин   | очно  | го д  | ост  | упа. |       |       |       |       |
|------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------|--------|----------|------|--------|-------|-------|-------|------|------|-------|-------|-------|-------|
| Код              | 15                                                                     | 14                                                                                                                                                                                                                                                                                                 | 13     | 12               | 11     | 10       | 9    | 8      | 7     | 6     | 5     | 4    | 3    | 2     | 1     | 0     |       |
| операции         | 0                                                                      | 1                                                                                                                                                                                                                                                                                                  | 1      | 0                | 0      | 0        | 0    | 1      | 1     | Α     | Α     | Α    | Α    | Α     | Α     | Α     |       |
|                  | 16 битная константа                                                    |                                                                                                                                                                                                                                                                                                    |        |                  |        |          |      |        |       |       |       |      |      |       |       |       |       |
| Выполнение       | If ((Smem) AND lk) = 0 Then $0 \rightarrow TC$ Else $1 \rightarrow TC$ |                                                                                                                                                                                                                                                                                                    |        |                  |        |          |      |        |       |       |       |      |      |       |       |       |       |
| Статусные        | Влияет н                                                               | на ТС                                                                                                                                                                                                                                                                                              | С.     |                  |        |          |      |        |       |       |       |      |      |       |       |       |       |
| биты<br>Описание | ячейки п<br>Если ука<br>регистра                                       | Данная команда осуществляет проверку определенного бита или битов чейки памяти данных Smem. Если указанный бит (биты) принимает значение 0, то бит ТС статусного регистра ST0 сбрасывается; в противном случае, ТС принимает вначение 1. константа lk является маской тестируемого бита или битов. |        |                  |        |          |      |        |       |       |       |      |      |       |       |       |       |
| Слова            | 2 слова.                                                               |                                                                                                                                                                                                                                                                                                    | ہے ۔ ۔ |                  | 4      |          |      |        |       |       |       |      |      |       |       |       |       |
|                  | Необход<br>с длинны                                                    |                                                                                                                                                                                                                                                                                                    |        |                  |        |          |      |        |       |       |       |      |      |       |       | дре   | сации |
| Циклы            | 2 цикла.<br>Необход<br>с длинны                                        | цимо                                                                                                                                                                                                                                                                                               | доб    | ави <sup>.</sup> | ть 1   | цик      | л пр | ои и   | СПОЈ  | пьзо  | вані  | ии к | осве | энне  | ой а, | дре   | сации |
| Классы           | Класс 6 <i>E</i><br>Класс 6                                            | ٨.                                                                                                                                                                                                                                                                                                 | VIСШ   | CHIVI            | CIVI V | , IJ IVI | 4000 | יטוונע | 11101 | і адр | JCCa  | ции  | 00   | IIICI |       |       |       |
| Пример 1         | BITF 5, 0                                                              | )OFF                                                                                                                                                                                                                                                                                               | h      |                  |        |          |      |        |       |       |       |      |      |       |       |       |       |
|                  |                                                                        |                                                                                                                                                                                                                                                                                                    | Пере   | ед ис            | полі   | нение    | М    | _      |       |       |       |      | Пос  | сле и | испол | інені | ия    |
|                  | TC                                                                     |                                                                                                                                                                                                                                                                                                    |        |                  |        |          | х    |        |       |       | TC    |      |      |       |       |       | 0     |
|                  | DP                                                                     |                                                                                                                                                                                                                                                                                                    |        |                  |        |          | 004  |        |       |       | DP    |      |      |       |       |       | 004   |
|                  | Память д                                                               | анных                                                                                                                                                                                                                                                                                              | K      |                  |        |          |      | _      |       |       |       |      |      |       |       |       |       |
|                  | 0205l                                                                  | ا ا                                                                                                                                                                                                                                                                                                |        |                  |        |          | 5400 |        |       | (     | )205h |      |      |       |       |       | 5400  |
| Пример 2         | BITF 5, 0                                                              | )800l                                                                                                                                                                                                                                                                                              | า      |                  |        |          |      |        |       |       |       |      |      |       |       |       |       |
|                  |                                                                        |                                                                                                                                                                                                                                                                                                    | Пере   | ед ис            | полі   | нение    | М    | _      |       |       |       |      | Пос  | сле и | испол | інені | ия    |
|                  | тс                                                                     |                                                                                                                                                                                                                                                                                                    |        |                  |        |          | х    |        |       |       | TC    |      |      |       |       |       | 0     |
|                  | DP                                                                     |                                                                                                                                                                                                                                                                                                    |        |                  |        |          | 004  |        |       |       | DP    |      |      |       |       |       | 004   |
|                  | Память да                                                              | анных                                                                                                                                                                                                                                                                                              | K      |                  |        |          |      | -      |       |       |       |      |      |       |       |       |       |
|                  | 02051                                                                  | n                                                                                                                                                                                                                                                                                                  |        |                  |        |          | 0F7F |        |       | (     | )205h |      |      |       |       |       | 0F7F  |

#### 20.3.16 BITT Smem

Операнды

Smem: операнд памяти данных одиночного доступа.

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 1  | 1  | 0  | 1  | 0 | 0 | - | Α | Α | Α | Α | Α | Α | Α |

Выполнение Статусные биты Описание  $(Smem (15 - T(3-0))) \rightarrow TC$ 

Операция устанавливает бит ТС.

Данная команда копирует указанный бит значения памяти данных Smem в бит TC статусного регистра ST0. Четыре младших разряда T содержат код бита, который указывает на то, какой именно бит копируется.

Адрес бита соответсвует (15 – T(3-0)). Код бита соответсвует содержимому T(3-0).

Коды битов для данной команды

|            |          | H          | ·—·      |
|------------|----------|------------|----------|
| Адрес бита | Код бита | Адрес бита | Код бита |
| (LSB) 0    | 1111     | 8          | 0111     |
| 1          | 1110     | 9          | 0110     |
| 2          | 1101     | 10         | 0101     |
| 3          | 1100     | 11         | 0100     |
| 4          | 1011     | 12         | 0011     |
| 5          | 1010     | 13         | 0010     |
| 6          | 1001     | 14         | 0001     |
| 7          | 1000     | (MSB) 15   | 0000     |

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 3А.

Класс 3В.

Пример

BITT \*AR7+0

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| Т          | С              | Т     | С             |
| TC         | 0              | TC    | 1             |
| AR0        | 0008           | AR0   | 0008          |
| AR7        | 0100           | AR7   | 0108          |
| Память дан | ных            |       |               |
| 0100h      | 0008           | 0100h | 0008          |

# 20.3.17 CALA[D] src

Операнды src: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | Z | S | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 |

# Выполнение Без задержки

$$(SP) - 1 \rightarrow SP$$
  
 $(PC) + 1 \rightarrow TOS$   
 $(src(15-0)) \rightarrow PC$ 

С задержкой

$$\begin{array}{l} (SP)-1 \rightarrow SP \\ (PC)+3 \rightarrow TOS \\ (src(15-0)) \rightarrow PC \end{array}$$

Статусные биты

Описание

Не используются.

Данная команда передает управление по 16-разрядному адресу в младшей части src (биты 15–0). Если переход задержанный (определяется по наличию суффикса D), то две однословные команды

одна двухслолвная команда, следующие за командой перехода,

вызываются из памяти программ и выполняются.

Примечание – Эта команда не может повторяться.

**Слова** 1 слово. **Циклы** 6 циклов.

4 циклов (задержанная).

Классы Класс 30В.

#### CALA A

# Пример 1

|    | перед командои |
|----|----------------|
| PC | 0025           |
| SP | 1111           |

Перед командой

|    | после команды |
|----|---------------|
| PC | 3333          |
| SP | 1110          |

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

| 1110h | 4567 |
|-------|------|

| 1110h | 0027 |
|-------|------|
| 1110h | 0027 |

# Пример 2 CALAD В

ANDM 4444h, \*AR1+

|    | Пере | д командо | рй   |
|----|------|-----------|------|
| В  | 00   | 0000      | 2000 |
| PC |      |           | 0025 |
| SP |      |           | 1111 |
|    |      |           |      |

|    | Посл | іе команді | Ы    |
|----|------|------------|------|
| В  | 00   | 0000       | 2000 |
| PC |      |            | 2000 |
| SP |      |            | 1110 |

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

| 1110h   4567   1110h | 1110h | 4567 | 1110h |  |
|----------------------|-------|------|-------|--|
|----------------------|-------|------|-------|--|

0028

После того, как содержимое ячейки памяти логически умножается (AND) со значением 4444h, программа продолжает выполнение с адреса 2000h.

# 20.3.18 CALL[D] pmad

Операнды

 $0 \le pmad \le 65535$ 

Код

операции

| _ | 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|   | 1                   | 1  | 1  | 1  | 0  | 0  | Z | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 0 |
|   | 16 битная константа |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Выполнение

Без задержики.

$$(SP) - 1 \rightarrow SP$$
  
 $(PC) + 2 \rightarrow TOS$   
pmad  $\rightarrow PC$ 

С задержкой.

$$(SP) - 1 \rightarrow SP$$
  
 $(PC) + 4 \rightarrow TOS$   
pmad  $\rightarrow PC$ 

# Статусные биты Описание

Не используются.

Данная команда передает управление по указанному адресу памяти программ (pmad). Адрес возврата помещается в TOS стека до того, как загрузится pmad в PC. Если вызов задерживается (определяется по наличию суффикса D), то две команды однословные или одна команда двухсловная, следующие за командой перехода, вызываются из памяти программ и выполняются.

Примечание – Эта команда не может повторяться.

Слова 2 слова. 4 цикла. Циклы

2 цикла (с задержкой).

Классы Класс 29В.

#### Пример 1 CALL 3333h

|               | Перед командой |       | После команды |  |  |  |  |  |  |
|---------------|----------------|-------|---------------|--|--|--|--|--|--|
| PC            | 0025           | PC    | 3333          |  |  |  |  |  |  |
| SP            | 1111           | SP    | 1110          |  |  |  |  |  |  |
| Память данных |                |       |               |  |  |  |  |  |  |
| 1110h         | 4567           | 1110h | 0027          |  |  |  |  |  |  |

## Пример 2

CALLD 1000h

ANDM #4444h, \*AR1+

|               | Перед командой |       | После команды |  |  |  |  |  |
|---------------|----------------|-------|---------------|--|--|--|--|--|
| PC            | 0025           | PC    | 1000          |  |  |  |  |  |
| SP            | 1111           | SP    | 1110          |  |  |  |  |  |
| Память данных |                |       |               |  |  |  |  |  |
| 1110h         | 4567           | 1110h | 0029          |  |  |  |  |  |

После того, как в ячейка памяти логически умножается (AND) со значением 4444h, программа продолжает выполнение с адреса 1000h.

# 20.3.19 CC[D] pmad, cond [, cond [, cond ]]

# Операнды

 $0 \le pmad \le 65535$ 

В таблице ниже перечислены условия (операнды условий) для данной команды.

| Условие | Описание     | Код<br>условия | Условие | Описание     | Код<br>условия |
|---------|--------------|----------------|---------|--------------|----------------|
| BIO     | BIO low      | 0000 0011      | NBIO    | BIO high     | 0000 0010      |
| С       | C=1          | 0000 1100      | NC      | C=0          | 0000 1000      |
| TC      | TC=1         | 0011 0000      | NTC     | TC=0         | 0010 0000      |
| AEQ     | (A) = 0      | 0100 0101      | BEQ     | (B) = 0      | 0100 1101      |
| ANEQ    | $(A) \neq 0$ | 0100 0100      | BNEQ    | (B) ≠ 0      | 0100 1100      |
| AGT     | (A) > 0      | 0100 0110      | BGT     | (B) > 0      | 0100 1110      |
| AGEQ    | $(A) \ge 0$  | 0100 0010      | BGEQ    | (B) ≥ 0      | 0100 1010      |
| ALT     | (A) < 0      | 0100 0011      | BLT     | (B) < 0      | 0100 1011      |
| ALEQ    | $(A) \leq 0$ | 0100 0111      | BLEQ    | (B) ≤ 0      | 0100 1111      |
| AOV     | Α            | 0111 0000      | BOV     | В            | 0111 1000      |
|         | переполнение |                |         | переполнение |                |
| ANOV    | А отсутствие | 0110 0000      | BNOV    | В отсутствие | 0110 1000      |
|         | переполнения |                |         | переполнения |                |
| UNC     | безусловный  | 0000 0000      |         | -            |                |

# Код операции



#### Выполнение

Без задержки:

If (cond(s))

Then  $(SP) - 1 \rightarrow SP \\ (PC) + 2 \rightarrow TOS \\ pmad \rightarrow PC$  Else

$$(PC) + 2 \rightarrow PC$$

С задержкой:

If (cond(s))
Then

$$(SP)$$
 - 1 →  $SP$   
 $(PC)$  + 4 →  $TOS$   
pmad →  $PC$ 

Else  $(PC) + 2 \rightarrow PC$ 

# Статусные биты Описание

Выполнение зависит от OVA или OVB (если выбраны OV или NOV).

Данная команда передает управления в адресе памяти программ (pmad) если выполняется (ются) определенное (ые) условие (я). Две команды с одним словом или одна команда с двумя словами, следующие за командой перехода, вызываются из памяти программ.

Если условие(я) выполняется(ются), то два слова, следующие за командой, удаляются из конвейера и начинается выполнение с адреса pmad. Если условие(я) не выполняется(ются), то значение PC увеличивается на 2 и выполняются два слова, следующие за командой. Если вызов задержанный (определяется по наличию суффикса D), то две однословные команды или одна двухсловная команда извлекаются из памяти программ и выполняются. Два слова, следующие за задержанной командой, не влияют на тестируемое условие. Если условие выполняется, то выполнение будет продолжено с адреса pmad. Если условие не выполняется, то значение PC увеличивается на 2 и выполняются инструкции определенные двумя словами, следующие за задержанной командой.

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

Группа 1: Вы можете выбрать не более двух условий. Каждое из этих условий должно быть из различных категорий (категория А или В); у вас не должно быть двух условий из одной категории. Например, вы можете осуществлять проверку EQ и OV одновременно, но не можете одновременно тестировать GT и NEQ. Для обоих условий аккумулятор должен быть один и тот же; одной командой нельзя осуществлять проверку сразу двух аккумуляторов. Например, вы можете одновременно осуществлять проверку AGT и AOV и не можете проверять одновременно AGT и BOV.

**Группа 2:** Вы можете выбрать не более трех условий. Каждое из этих условий должно быть из различных категорий (категория A, B, или C); у вас не должно быть двух условий из одной категории. Например, вы можете осуществлять проверку TC, C, и BIO одновременно, но не можете одновременно тестировать NTC, C, и NC.

Условия для данной команды

| Груг        | па 1        |             |             |             |
|-------------|-------------|-------------|-------------|-------------|
| Категория А | Категория В | Категория А | Категория В | Категория С |
| EQ          | OV          | TC          | С           | BIO         |
| NEQ         | NOV         | NTC         | NC          | NBIO        |
| LT          |             |             |             |             |
| LEQ         |             |             |             |             |
| GT          |             |             |             |             |
| GEO         |             |             |             |             |

Примечание – Данная команда не повторяемая.

Слова Циклы 2 слова.

5 циклов (истинное условие).

3 цикла (ложное условие).

3 цикла (с задержкой).

Классы

Класс 31В.

| Пример 1      | CC 2222h, /                         | 4GT   |           |      |       |      |           |      |
|---------------|-------------------------------------|-------|-----------|------|-------|------|-----------|------|
|               |                                     | Пере  | д командо | рй   |       | Посл | е команды | əl   |
|               | Α                                   | 00    | 0000      | 3000 | Α [   | 00   | 0000      | 3000 |
|               | PC                                  |       |           | 0025 | PC [  |      |           | 2222 |
|               | SP                                  |       |           | 1111 | SP [  |      |           | 1110 |
| Память данных |                                     |       |           |      |       |      |           |      |
|               | 1110h                               |       |           | 4567 | 1110h |      |           | 0027 |
| Пример 2      | CCD 1000h, BOV<br>ANDM 4444h, *AR1+ |       |           |      |       |      |           |      |
|               |                                     | Перед | , командо | й    |       | Пос  | пе команд | ды   |
|               | PC                                  |       |           | 0025 | PC    |      |           | 1000 |
|               | OVB                                 |       |           | 1    | OVB   |      |           | 1    |
|               | SP                                  |       |           | 1111 | SP    |      |           | 1110 |
|               | Память данн                         | ых    |           |      |       |      |           |      |
|               | 1110h                               |       |           | 4567 | 1110h |      |           | 0029 |

После того, как ячейка памяти логически умножается (AND) на значение 4444h, программа продолжает выполнение с ячейки 1000h.

#### 20.3.20 CMPL src [, dst ]

А (аккумулятор А). Операнды src, dst:

В (аккумулятор В).

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | S | D | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |

Выполнение

 $(\overline{\operatorname{src}}) \to \operatorname{dst}$ 

Статусные

Не используются.

биты

Описание

Данная команда вычисляет обратный код содержимого (логическая инверсия). Результат сохраняется в dst, если он указан,

или, в противном случае, в src.

1 слово. Слова 1 цикл. Циклы Классы Класс 1. Пример CMPL A, B

После исполнения

| Α | FC | DFFA | AEAA |
|---|----|------|------|
| В | 00 | 0000 | 7899 |

| Α | FC | DFFA | AEAA |
|---|----|------|------|
| В | 03 | 2005 | 5155 |

#### 20.3.21 CMPM Smem, #lk

Операнды Smem: операнд памяти данных одиночного доступа.

 $-32768 \le lk \le 32767$ 

Код операции

| 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0                   | 1  | 1  | 0  | 0  | 0  | 0 | 0 | ı | Α | Α | Α | Α | Α | Α | Α |
| 16 битная константа |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Выполнение

If (Smem) = Ik

Then

 $1 \rightarrow TC$ 

Else

 $0 \rightarrow TC$ 

Статусные

биты

Команда влияет на значение ТС.

Описание

Эта команда сравнивает 16-разрядный операнд памяти данных одиночного доступа Smem с 16-разрядной константой constant lk . если они равны, ТС принимает значение 1. В противном случае, значение ТС

сбрасывается.

2 слова. Слова

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

2 цикла Циклы

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Класс 6А. Классы

Класс 6В.

#### Пример CMPM \*AR4+, 0404h Перед исполнением После исполнения TC TC 1000 AR4 0100 AR4 1110 Память данных 0100h 4444 0100h 4444 20.3.22 CMPR CC, ARX Операнды $0 \le CC \le 3$ ARxAR0-AR7 Код 15 14 11 операции С С 0 R Χ Выполнение If (cond) Then $1 \rightarrow TC$ Else $0 \rightarrow TC$ Статусные Команда влияет на значение ТС. биты Описание Данная команда сравнивает содержание определенного регистра (ARx) с содержимым AR0 и устанавливает бит TC в соответствии с результатом сравнения. Сравнение определяется значением кода условия СС (см. таблицу ниже). Если условие истинно, то ТС принимает значение 1. если условие ложно, то значение ТС сбрасывается. Все условия рассматриваются так, как если бы операнды были беззнаковыми. Условие Код условия Описание EQ 00 Test if (ARx) = (AR0)LT 01 Test if (ARx) < (AR0)GT 10 Test if (ARx) > (AR0)**NEQ** 11 Test if $(ARx) \neq (AR0)$ Слова 1 слово. Циклы 1 цикл. Классы Класс 1. CMPR 2, AR4 Пример Перед командой После команды TC TC 0 AR0 **FFFF** AR0 **FFFF** AR4 AR4 7FFF 7FFF

#### 20.3.23 CMPS src, Smem

Операнды src: A

с: А (аккумулятор А).

В (аккумулятор В).

Smem: операнд памяти данных одиночного доступа.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 0  | 1  | 1  | 1 | S | - | Α | Α | Α | Α | Α | Α | Α |

Выполнение

If ((src(31-16)) > (src(15-0)))

Then

 $(src(31-16)) \rightarrow Smem$   $(TRN) << 1 \rightarrow TRN$   $0 \rightarrow TRN(0)$  $0 \rightarrow TC$ 

Else

 $(src(15-0)) \rightarrow Smem$   $(TRN) << 1 \rightarrow TRN$   $1 \rightarrow TRN(0)$  $1 \rightarrow TC$ 

Статусные биты Описание Инструкция влияет на значение ТС.

Эта команда сравнивает два 16-разрядных значения в дополнительном двоичном коде, расположенных в старшей и младшей части src и сохраняет максимальное значение в ячейке памяти данных Smem. Если старшая часть src (биты 31–16) больше, то 0 вдвигается в младший разряд (LSB) регистра перехода (TRN) и значение бита TC сбрасывается. Если младшая часть src (биты 15–0) больше, то 1 вдвигается в LSB регистра TRN и бит TC принимает значение 1.

Слова 1 сло

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы 1 цикл

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Классы** Класс 10A.

Класс 10В.

Пример CMPS A, \*AR4+

|               | Перед | исполнен | ием  |       | После | исполне | нения |  |  |  |  |
|---------------|-------|----------|------|-------|-------|---------|-------|--|--|--|--|
| Α             | 00    | 2345     | 7899 | Α     | 00    | 7899    |       |  |  |  |  |
| TC            |       |          | 0    | тс    |       |         | 1     |  |  |  |  |
| AR4           |       |          | 0100 | AR4   |       |         | 0101  |  |  |  |  |
| TRN           |       |          | 4444 | TRN   |       |         | 8889  |  |  |  |  |
| Память данных |       |          |      |       |       |         |       |  |  |  |  |
| 0100h         |       |          | 0000 | 0100h |       |         | 7899  |  |  |  |  |

#### 20.3.24 DADD Lmem, src [, dst ]

#### Операнды

Lmem: операнд памяти данных, использующий адресацию длинного

слова.

src, dst: A (аккумулятор A). B (аккумулятор B).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 1  | 0  | 0  | S | D | I | Α | Α | Α | Α | Α | Α | Α |

#### Выполнение

If C16 = 0

Then

(Lmem) + (src) → dst

Else

 $(Lmem(31-16)) + (src(31-16)) \rightarrow dst(39-16)$  $(Lmem(15-0)) + (src(15-0)) \rightarrow dst(15-0)$ 

#### Статусные биты

Исполнение зависит от SXM и OVM (только если C16 = 0).

Команда влияет на значение С и OVdst (или OVsrc, если dst не определен).

#### Описание

Данная команда добавляет содержимое src к 32-разрядному операнду памяти данных, использующему адресацию длинного слова, Lmem. Если dst определен, то команда сохраняет результат в dst. Если dst не определен, то команда сохраняет результат в src. Значение C16 определяет режим команды:

- 1. если C16 = 0, команда выполняется в режиме двойной точности. 40разрядное значение src добавляется к Lmem. Биты насыщения и переполнения устанавливаются в зависимости от результата операции.
- 2. если С16 = 1, команда выполняется в двойном 16-разрядном режиме. Старшая часть src (биты 31–16) добавляются к 16 самым старшим битам (MSB) операнда Lmem, а младшая часть src (биты 15–0) добавляются к 16 самым младшим битам (LSB) операнда Lmem. Биты насыщения и переполнения не изменяются в этом режиме. В этом режиме результаты являются ненасыщенными, независимо от состояния бита OVM.

#### Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Классы

Класс 9А.

Класс 9В.

#### Пример 1 DADD \*AR3+, A, B

|           | перед | исполнен | ием           |      | После | исполне | ния  |
|-----------|-------|----------|---------------|------|-------|---------|------|
| Α         | 00    | 5678     | 8933          | Α    | 00    | 5678    | 8933 |
| В         | 00    | 0000     | 0000          | В    | 00    | 6BAC    | BD89 |
| C16       |       |          | 0             | C16  |       |         | 0    |
| AR3       |       |          | 0100          | AR3† |       |         | 0201 |
| амять дан | ІНЫХ  |          |               |      |       |         |      |
|           |       |          | $\overline{}$ |      |       |         |      |

Па

| 0100h | 1534 | 0100h | 1534 |
|-------|------|-------|------|
| 0101h | 3456 | 0101h | 3456 |

† данная команда является командой с длинным операндом и как следствие после его выполнения AR3 увеличивается на 2.

#### Пример 2 DADD \*AR3-, A, B

|            | Перед | исполнен | ием  |       | После | исполне | ния  |
|------------|-------|----------|------|-------|-------|---------|------|
| Α          | 00    | 5678     | 3933 | Α     | 00    | 5678    | 3933 |
| В          | 00    | 0000     | 0000 | В     | 00    | 6BAC    | 6D89 |
| C16        |       |          | 1    | C16   |       |         | 1    |
| AR3        |       |          | 0100 | AR3†  |       |         | 00FE |
| Память дан | ных   |          |      |       |       |         |      |
| 0100h      |       |          | 1534 | 0100h |       |         | 1534 |
| 0101h      |       |          | 3456 | 0101h |       |         | 3456 |

† данная команда является командой с длинным операндом, и потому после выполнения AR3 уменьшается на 2.

#### Пример 3 DADD \*AR3-, A, B

|            | Пере | д командо | рй   |       | Посл | ы    |      |
|------------|------|-----------|------|-------|------|------|------|
| Α          | 00   | 5678      | 3933 | Α     | 00   | 5678 | 3933 |
| В          | 00   | 0000      | 0000 | В     | 00   | 8ACE | 4E67 |
| C16        |      |           | 0    | C16   |      |      | 0    |
| AR3        |      |           | 0101 | AR3†  |      |      | 00FF |
| Память дан | ных  |           |      |       |      |      |      |
| 0100h      |      |           | 1534 | 0100h |      |      | 1534 |
| 0101h      |      |           | 3456 | 0101h |      |      | 3456 |

† данная команда является командой с длинным операндом, и потому после выполнения AR3 уменьшается на 2.

#### 20.3.25 DADST Lmem, dst

#### Операнды

Lmem: операнд памяти данных, использующий адресацию

длинного слова.

dst: A (аккумулятор A). B (аккумулятор B).

#### Код операции

#### Выполнение

If 
$$C16 = 1$$

Then

$$(Lmem(31-16)) + (T) \rightarrow dst(39-16)$$
  
 $(Lmem(15-0)) - (T) \rightarrow dst(15-0)$ 

Else

$$(Lmem) + ((T) + (T) << 16) \rightarrow dst$$

#### Статусные биты Описание

На результат инструкции влияет SXM и OVM (только если C16 = 0) Операция влияет на C и OVdst.

Данная команда добавляет содержимое Т к 32-разрядному операнду памяти данных, использующему адресацию длинного слова Lmem. Значение С16 определяет режим исполнения команды:

- 1. Если С16 = 0, команда выполняется в режиме двойной точности. Lmem добавляется к 32-разрядному значению, состоящему из содержимого Т сочленённому с содержимым 16 битов того же регистра Т сдвинутого влево на 16 разрядов (Т <<16 + Т). Результат сохраняется в dst.
- 2. Если С16 = 1, команда выполняется в двойном 16-разрядном режиме. 16 самых старших битов операнда Lmem добавляются к содержимому Т и сохраняются в старших 24 битах dst. В то же время содержимое Т вычитается из 16 самых младших битов операнда Lmem. В этом режиме результаты являются ненасыщенными, независимо от состояния бита OVM.

Примечание — Эта команда имеет смысловую интерпретацию только когда С16 принимает значение 1 (двойной 16-битный режим).

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

Классы

Класс 9А.

Класс 9В.

Пример 1

DADST \*AR3-, A

|            | Пере         | ед командо | рй   |       | Посл | е команд | ы    |
|------------|--------------|------------|------|-------|------|----------|------|
| Α          | 00 0000 0000 |            |      | Α     | 00   | 579B     |      |
| Т          |              |            | 2345 | т     |      |          | 2345 |
| C16        |              |            | 0    | C16   |      |          | 0    |
| AR3        |              |            | 0100 | AR3†  |      |          | 0102 |
| Память дан | ных          |            |      |       |      |          |      |
| 0100h      |              |            | 1534 | 0100h |      |          | 1534 |
| 0101h      |              |            | 3456 | 0101h |      |          | 3456 |

<sup>†</sup> данная команда использует длинный операнд и после выполнения AR3 уменьшается на 2.

## Пример 2

DADST \*AR3+, A

|            | Перед | д командо | Й    |       | Посл | е команд | Ы    |
|------------|-------|-----------|------|-------|------|----------|------|
| Α          | 00    | 0000      | 0000 | Α     | 00   | 3879     | 579B |
| Т          |       |           | 2345 | т     |      |          | 2345 |
| C16        |       |           | 0    | C16   |      |          | 0    |
| AR3        |       |           | 0100 | AR3†  |      |          | 0102 |
| Память дан | ных   |           |      |       |      |          |      |
| 0100h      |       |           | 1534 | 0100h |      |          | 1534 |
| 0101h      |       |           | 3456 | 0101h |      |          | 3456 |

<sup>†</sup> данная команда использует длинный операнд и после выполнения AR3 увеличивается на 2.

#### 20.3.26 **DELAY Smem**

Операнды

Smem: операнд памяти данных одиночного доступа.

Код

операции

| _1: | 5 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|---|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0   | ) | 1  | 0  | 0  | 1  | 1  | 0 | 1 | I | Α | A | Α | Α | Α | A | Α |

Выполнение Статусные  $(Smem) \rightarrow Smem + 1$  Не используются.

биты

Описание

Данная команда копирует содержимое ячейки памяти данных Smem в ячейку памяти по следующему большему адресу. Когда данные скопированы, содержимое адресуемой ячейки остается таким же. Эта функция может быть полезной при осуществлении задержки Z при применении в цифровой обработке сигналов. Операция задержки также присутствует в командах загрузки T (инструкция LTD) и инструкции умножения ячейки памяти программ с ячейкой памяти данных с накоплением (MACD).

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

1 цикл

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 24А.

Класс 24В.

Пример

**DELAY \*AR3** 

|            | Перед исполнением |       | После исполнения |
|------------|-------------------|-------|------------------|
| AR3        | 0100              | AR3   | 0100             |
| Память дан | ных               |       |                  |
| 0100h      | 6CAC              | 0100h | 6CAC             |
| 0101h      | 0000              | 0101h | 6CAC             |

#### 20.3.27 DLD Lmem, dst

#### Операнды

Lmem: операнд памяти данных, использующий адресацию

длинного слова.

dst: A (аккумулятор A). В (аккумулятор В).

#### Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 1  | 0  | 1  | 1 | D | I | Α | Α | Α | Α | Α | Α | Α |

#### Выполнение

If C16 = 0

Then

 $(Lmem) \rightarrow dst$ 

Else

 $(Lmem(31-16)) \rightarrow dst(39-16)$  $(Lmem(15-0)) \rightarrow dst(15-0)$ 

# Статусные биты Описание

Изменяется под влиянием SXM.

Данная команда загружает 32-разрядный операнд Lmem в dst. Значение C16 определяет режим исполнения команды:

- 1. Если C16 = 0, команда выполняется в режиме двойной точности. Lmem загружается в dst.
- 2. Если C16 = 1, команды выполняется в двойном 16-разрядном режиме. 16 самых старших битов Lmem загружаются в старшие 24 бита dst. В то же время, 16 самых младших битов Lmem загружаются в 16 младших битов dst.

#### Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Классы

Класс 9А. Класс 9В.

#### Пример

DLD \*AR3+, B

|     | Пере | ед командо | йС   |
|-----|------|------------|------|
| В   | 00   | 0000       | 0100 |
| AR3 |      |            | 0100 |

|      | После команды |      |      |  |  |  |  |
|------|---------------|------|------|--|--|--|--|
| В    | 00            | 6CAC | 0201 |  |  |  |  |
| AR3† |               |      | 0102 |  |  |  |  |

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

| 0100h | 6CAC | 0100h | 6CAC |
|-------|------|-------|------|
| 0101h | BD90 | 0101h | BD90 |

† данная команда является командой с чтением длинного операнда, потому после выполнения AR3 увеличивается на 2.

#### 20.3.28 DRSUB Lmem, src

#### Операнды

Lmem: операнд памяти данных, использующий адресацию

длинного слова.

src: A (аккумулятор A). В (аккумулятор В).

#### Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 1  | 1  | 0  | 0 | S | I | Α | Α | Α | Α | Α | Α | Α |

#### Выполнение

If 
$$C16 = 0$$

Then

(Lmem) - (src)  $\rightarrow$  src

Else

 $(Lmem(31-16)) - (src(31-16)) \rightarrow src(39-16)$  $(Lmem(15-0)) - (src(15-0)) \rightarrow src(15-0)$ 

# Статусные биты Описание

Результат зависит от SXM и OVM (только если C16 = 0).

Операция влияет на С и OVsrc.

Данная команда вычитает содержимое src из 32-битного операнда Lmem и сохраняет результат в src. Значение C16 определяет режим команды:

- 1. Если C16 = 0, команда выполняется в режиме двойной точности. Содержимое src (32 бита) вычитается из Lmem. Результат сохраняется в src.
- 2. Если С16 = 1, команда выполняется в двойном 16-битном режиме. Старшая часть src (биты 31–16) вычитается из 16 самых старших битов операнда Lmem и результат сохраняется в старшей части src (биты 39–16). В то же время, младшая часть src (биты 15–0) вычитаются из 16 самых младших битов операнда Lmem. Результат сохраняется в младшей части src (биты 15–0). В этом режиме результаты являются ненасыщенными, независимо от состояния бита OVM.

#### Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Lmem.

#### Классы

Класс 9А.

Класс 9В.

## Пример 1 DRSUB \*AR3+, A

|            | Пере | д командо | рй   |       | Пос | пе команд | Ы    |
|------------|------|-----------|------|-------|-----|-----------|------|
| Α          | 00   | 5678      | 8933 | Α     | FF  | BEBB      | AB23 |
| Т          |      |           | x    | т     |     |           | 0    |
| C16        |      |           | 0    | C16   |     |           | 0    |
| AR3        |      |           | 0100 | AR3†  |     |           | 0102 |
| Память дан | ных  |           |      |       |     |           |      |
| 0100h      |      |           | 1534 | 0100h |     |           | 1534 |
| 0101h      |      |           | 3456 | 0101h |     |           | 3456 |

† данная команда является командой обработки длинного операнда и после выполнения AR3 увеличивается на 2.

## Пример 2 DRSUB \*AR3-, A

|            | Перед | д командо | рй   |       | Посл | пе команд | Ы    |
|------------|-------|-----------|------|-------|------|-----------|------|
| Α          | 00    | 5678      | 3933 | Α     | FF   | BEBC      | FB23 |
| т          |       |           | 1    | т     |      |           | 0    |
| C16        |       |           | 1    | C16   |      |           | 1    |
| AR3        |       |           | 0100 | AR3†  |      |           | 00FE |
| Память дан | ных   |           |      |       |      |           |      |
| 0100h      |       |           | 1534 | 0100h |      |           | 1534 |
| 0101h      |       |           | 3456 | 0101h |      |           | 3456 |

† данная команда является командой обработки длинного операнда и после выполнения AR3 уменьшается на 2.

#### 20.3.29 DSADT Lmem, dst

#### Операнды

Lmem: операнд памяти данных, использующий адресацию длинного слова.

dst: A (аккумулятор A). В (аккумулятор В).

#### Код операции

#### Выполнение

If 
$$C16 = 1$$

Then

$$(Lmem(31-16)) - (T) \rightarrow dst(39-16)$$
  
 $(Lmem(15-0)) + (T) \rightarrow dst(15-0)$ 

Else

$$(Lmem) - ((T) + (T << 16)) \rightarrow dst$$

# Статусные биты Описание

Результат зависит от SXM и OVM (только если C16 = 0)

Команда влияет на С и OVdst.

Данная команда вычитает/складывает содержимое Т из 32-битного операнда Lmem и сохраняет результат в dst. Значение С16 определяет режим исполнения команды:

- 1. Если С16 = 0, команда выполняется в режиме двойной точности. 32-разрядное значение, состоящее из содержимого Т, сочленённому с содержимым того же регистра Т сдвинутого влево на 16 разрядов (Т <<16 + T) вычитается из Lmem. Результат сохраняется в dst.
- 2. Если С16 = 1, команда выполняется в двойном 16-разрядном режиме. Содержимое Т вычитается из 16 самых старших битов операнда Lmem и результат сохраняется в dst (биты 39–16). В то же самое время содержимое Т добавляется к 16 самым младшим битам операнда Lmem и результат сохраняется в младшей части dst (биты 15–0). В этом режиме результаты являются ненасыщенными, независимо от состояния бита OVM.

Примечание — Данная команда имеет смысл только, если установлен бит С16 (двойной 16-битный режим).

#### Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Классы

Класс 9А.

Класс 9В.

### Пример 1 DSADT \*AR3+, A

|            | Перед і | исполнен | ием  |       | После | исполне | ния  |
|------------|---------|----------|------|-------|-------|---------|------|
| Α          | 00      | 0000     | 0000 | Α     | FF    | F1EF    | 1111 |
| Т          |         |          | 2345 | т     |       |         | 2345 |
| С          |         |          | 0    | С     |       |         | 0    |
| C16        |         |          | 0    | C16   |       |         | 0    |
| AR3        |         |          | 0100 | AR3†  |       |         | 0102 |
| Память дан | ных     |          |      |       |       |         |      |
| 0100h      |         |          | 1534 | 0100h |       |         | 1534 |
| 0101h      |         |          | 3456 | 0101h |       |         | 3456 |

† команда является командой обработки длинного операнда и после выполнения AR3 увеличивается на 2.

## Пример 2 DSADT \*AR3-, A

|            | Перед | д командо | рй   |       | Посл | іе команді | Ы    |
|------------|-------|-----------|------|-------|------|------------|------|
| Α          | 00    | 0000      | 0000 | Α     | FF   | F1EF       | 1111 |
| Т          |       |           | 2345 | т     |      |            | 2345 |
| С          |       |           | 0    | С     |      |            | 1    |
| C16        |       |           | 1    | C16   |      |            | 1    |
| AR3        |       |           | 0100 | AR3†  |      |            | 00FE |
| Память дан | ных   |           |      |       |      |            |      |
| 0100h      |       |           | 1534 | 0100h |      |            | 1534 |
| 0101h      |       |           | 3456 | 0101h |      |            | 3456 |

† команда является командой обработки длинного операнда и после выполнения AR3 уменьшается на 2.

#### 20.3.30 DST src, Lmem

**Операнды** src: A (аккумулятор A).

В (аккумулятор В).

Lmemоперанд памяти данных, использующий адресацию длинного

слова.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | S | ı | Α | Α | Α | Α | Α | Α | Α |

Выполнение

 $(\operatorname{src}(31-0)) \to \operatorname{Lmem}$ 

Статусные

Не используются.

биты Описание

Данная команда сохраняет содержимое src в 32-разрядной ячейке

памяти данных Lmem.

Слова 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Lmem.

Циклы 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Lmem.

**Классы** Класс 13A.

Класс 13В.

**Пример 1** DST B, \*AR3+

|     | Пере | ед команд | ой   |      | Пос | пе команд | Ы    |
|-----|------|-----------|------|------|-----|-----------|------|
| В   | 00   | 6CAC      | BD90 | В    | 00  | 6CAC      | BD90 |
| AR3 |      |           | 0100 | AR3† |     |           | 0102 |

Память данных

| 0100h | 0000 | 0100h | 6CAC |
|-------|------|-------|------|
| 0101h | 0000 | 0101h | BD90 |

<sup>†</sup> данная команда является командой обработки длинного операнда и после выполнения AR3 увеличивается на 2.

#### **Пример 2** DST B, \*AR3-

|            | Пере | ед команд | ой   |       | Пос | пе команд | Ы    |
|------------|------|-----------|------|-------|-----|-----------|------|
| В          | 00   | 6CAC      | BD90 | В     | 00  | 6CAC      | BD90 |
| AR3        |      |           | 0101 | AR3†  |     |           | 00FF |
| Память дан | ных  |           |      |       |     |           |      |
| 0100h      |      |           | 0000 | 0100h |     |           | BD90 |
| 0101h      |      |           | 0000 | 0101h |     |           | 6CAC |

<sup>†</sup> данная команда является командой обработки длинного операнда и после выполнения AR3 увеличивается на 2.

#### 20.3.31 DSUB Lmem, src

#### Операнды

Lmem: операнд памяти данных, использующий адресацию длинного

слова.

src:

А (аккумулятор А). В (аккумулятор В).

#### Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 1  | 0  | 1  | 0 | S | I | Α | Α | A | Α | Α | Α | Α |

#### Выполнение

If C16 = 0

Then

 $(src) - (Lmem) \rightarrow src$ 

Else

 $(src(31-16)) - (Lmem(31-16)) \rightarrow src(39-16)$  $(src(15-0)) - (Lmem(15-0)) \rightarrow src(15-0)$ 

## Статусные биты Описание

Результат зависит от SXM и OVM (только если C16 = 0).

Команда влияет на С и OVsrc.

Данная команда вычитает 32-разрядный операнд Lmem из содержимого src и сохраняет результат в src. Значение C16 определяет режим команды:

- 1. если C16 = 0, команда выполняется в режиме двойной точности. Lmem вычитается из содержимого src.
- 2. если С16 = 1, команда выполняется в двойном 16-битном режиме. 16 самых старших битов операнда Lmem вычитаются из старшей части src (биты 31–16) и результат сохраняется в старшей части src (биты 39–16). В то же самое время, 16 самых младших разрядов операнда Lmem вычитаются из младшей части src (биты 15–0) и результат сохраняется в младшей части src (биты 15–0).

#### Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Lmem.

#### Классы

Класс 9А.

Класс 9В.

#### Пример 1

DSUB \*AR3+, A

|            | Пере | д командо | рй   |       | Посл | іе команд | Ы    |
|------------|------|-----------|------|-------|------|-----------|------|
| Α          | 00   | 5678      | 8933 | A     | 00   | 4144      | 54DD |
| C16        |      |           | 0    | Т     |      |           | 0    |
| AR3        |      |           | 0100 | AR3†  |      |           | 0102 |
| Память дан | ных  |           |      |       |      |           |      |
| 0100h      |      |           | 1534 | 0100h |      |           | 1534 |
| 0101h      |      |           | 3456 | 0101h |      |           | 3456 |
| '          |      |           |      | ,     |      |           |      |

† поскольку данная команда является командой с длинным операндом, после выполнения AR3 увеличивается на 2.

#### Пример 2

DSUB \*AR3-, A

|            | Перед | д командо | рй   |       | Посл | е команд | ы    |
|------------|-------|-----------|------|-------|------|----------|------|
| Α          | 00    | 5678      | 3933 | Α     | 00   | 4144     | 04DD |
| С          |       |           | 1    | С     |      |          | 1    |
| C16        |       |           | 1    | C16   |      |          | 1    |
| AR3        |       |           | 0100 | AR3†  |      |          | 00FE |
| Память дан | ных   |           |      |       |      |          |      |
| 0100h      |       |           | 1534 | 0100h |      |          | 1534 |
| 0101h      |       |           | 3456 | 0101h |      |          | 3456 |

† поскольку данная команда является командой с длинным операндом, после выполнения AR3 увеличивается на 2.

#### 20.3.32 DSUBT Lmem, dst

длинного слова.

dst: A (аккумулятор A). B (аккумулятор B).

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 1  | 1  | 1  | 0 | D | I | Α | Α | Α | Α | Α | Α | Α |

Выполнение

If 
$$C16 = 1$$

Then

$$(Lmem(31-16)) - (T) \rightarrow dst(39-16)$$
  
 $(Lmem(15-0)) - (T) \rightarrow dst(15-0)$ 

Else

$$(Lmem) - ((T) + (T << 16)) \rightarrow dst$$

**Статусные** Результат зависит от SXM и OVM (только если C16 = 0).

**биты** Инструкция влияет на С и OVdst.

Описание Данная команда вычитает содержимое Т из 32-разрядного

операнда Lmem и

Слова 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Lmem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Lmem.

Классы Класс 9А.

Класс 9В.

#### Пример 1

DSUBT \*AR3+, A

| Α   | 00 | 0000 | 0000 |
|-----|----|------|------|
| Т   |    |      | 2345 |
| C16 |    |      | 0    |
| AR3 |    |      | 0100 |

| Α    | FF | F1EF | 1111 |
|------|----|------|------|
| Т    |    |      | 2345 |
| C16  |    |      | 0    |
| AR3† |    |      | 0102 |

Память данных

| 0100h | 1534 |
|-------|------|
| 0101h | 3456 |

| 0100h | 1534 |
|-------|------|
| 0101h | 3456 |

† поскольку данная команда является командой с длинным операндом, после выполнения AR3 увеличивается на 2.

#### Пример 2

DSUBT \*AR3-, A

|     | Перед | исполнен | ием  |
|-----|-------|----------|------|
| Α   | 00    | 0000     | 0000 |
| T   |       |          | 2345 |
| C16 |       |          | 1    |
| AR3 |       |          | 0100 |
|     |       |          |      |

|     | После | исполне | ния  |
|-----|-------|---------|------|
| Α   | FF    | F1EF    | 1111 |
| Т   |       |         | 2345 |
| C16 |       |         | 1    |
| R3† |       |         | 00FE |

Память данных

| 0100h | 1534 |
|-------|------|
| 0101h | 3456 |

| 0100h | 1534 |
|-------|------|
| 0101h | 3456 |

† поскольку данная команда является командой с длинным операндом, после выполнения AR3 уменьшается на 2.

#### 20.3.33 EXP src

Операнды

src: A (аккумулятор A).

В (аккумулятор В).

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | S | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |

Выполнение

If (src) = 0

Then

0 → T

Else

(количество ведущих битов в src) - 8 → T

# Статусные биты Описание

Не используются.

Команда рассчитывает значение экспоненты, которое является значением со знаком в двоичном дополнительном коде в диапазоне от -8 до 31, и сохраняет результат в Т. Экспонента вычисляется путем подсчета количества ведущих бит в src и вычитанием 8 из этого значения. Количество ведущих бит эквивалентно количеству сдвигов влево, необходимых для того, чтобы исключить незначимые биты из 40-разрядного src за исключением знакового бита. src не изменяется после выполнения команды.

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

Слова 1 слово. Циклы 1 цикл. Классы Класс 1 EXP A Пример 1

|   | перед | исполнен | нем  |     |     | После | исполне | ния  |     |
|---|-------|----------|------|-----|-----|-------|---------|------|-----|
| Α | FF    | FFFF     | FFCB | -53 | Α [ | FF    | FFFF    | FFCB | -53 |
| T |       |          | FC18 |     | т [ |       |         | 0019 | 25  |

#### Пример 2 EXP B

|   | Перед | исполнен | ием  |   | После | исполне | ния  |    |
|---|-------|----------|------|---|-------|---------|------|----|
| В | 07    | 8543     | 2105 | В | 07    | 8543    | 2105 |    |
| T |       |          | FFFC | Т |       |         | FFFC | -4 |

† значение аккумулятора В среди «сторожевых» битов имеет значимые разряды, что приводит к отрицательному показателю.

## 20.3.34 FB[D] extpmad

Операнды Код операции 0 ≤ extpmad ≤ 7F FFFF

| 15 | 14 | 13 | 12 | 11   | 10    | 9     | 8    | 7    | 6     | 5    | 4    | 3   | 2      | 1     | 0      |
|----|----|----|----|------|-------|-------|------|------|-------|------|------|-----|--------|-------|--------|
| 1  | 1  | 1  | 1  | 1    | 0     | Z     | 0    | 1    | 7 БИ  | т по | стоя | нны | й = рı | nad(2 | 22-16) |
|    |    |    | 16 | битн | ая ко | онста | анта | = pn | nad(1 | 5-0) |      |     |        |       |        |

Выполнение

 $(pmad(15-0)) \rightarrow PC$ 

 $(pmad(22-16)) \rightarrow XPC$ 

Статусные биты

Не используются.

Описание Данная команда передает управление по адресу памяти программ pmad (биты 15-0) на страницу, определенную по pmad (биты 22-16). Адрес pmad может быть задан и как число и символически. Если переход с задержкой (определяется по

наличию индекса D), то две команды по одному слову или одна команда из двух слов, следующие за командой перехода,

вызываются из памяти программ и выполняются.

Примечания – Данная команда не повторяемая.

В данной модели процессора операция не реализована!

Слова 2 слова. Циклы 4 цикла.

2 цикла (с задержкой).

Классы Класс 29А. FB 012000h Пример 1

|     | Перед командой |
|-----|----------------|
| PC  | 1000           |
| KPC | 00             |

|     | после команды |
|-----|---------------|
| PC  | 2000          |
| XPC | 7F            |

2000h загружается в PC, 01h загружаются в XPC и программа продолжает выполнение с этой ячейки.

#### Пример 2

FBD 7F1000h

ANDM #4444h, \*AR1+

|     | Перед командой |
|-----|----------------|
| PC  | 2000           |
| XPC | 00             |

|     | После команды |
|-----|---------------|
| PC  | 1000          |
| XPC | 7F            |

После того, как в операнд логически умножается (AND) на значение 4444h, программа продолжает выполнение с ячейки 1000h на странице 7Fh

### 20.3.35 FBACC[D] src

Операнды

src: A (аккумулятор A)

В (аккумулятор В)

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | Z | S | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |

Выполнение

 $(src(15-0)) \rightarrow PC$ 

 $(src(22-16)) \rightarrow XPC$  Не используются.

Статусные

биты

Описание

Данная команда загружает в XPC значение src (биты 22–16) и передает управление в 16-разрадный адрес младшей части src (биты 15–0). Если переход задержанный (определяется по наличию индекса D), то две команды по одному слову или одна команда из двух слов, следующие за командой перехода, вызываются из памяти программ и выполняются.

Примечания – Данная команда не повторяемая.

В данной модели процессора операция не реализована!

**Слова** 1 слово. **Циклы** 6 цикла.

4 цикла (с задержкой).

**Классы** Класс 30А. **Пример 1** FBACC A

|     | пере | д командо | УИ   |
|-----|------|-----------|------|
| Α   | 00   | 0001      | 3000 |
| PC  |      |           | 1000 |
| XPC |      |           | 00   |
|     |      |           |      |

|     | После | команді | ol . |
|-----|-------|---------|------|
| Α   | 00    | 0001    | 3000 |
| PC  |       |         | 3000 |
| XPC |       |         | 01   |

1h загружается в XPC, 3000h загружается в PC, и программа продолжает выполнение с этой ячейки на странице 1h.

#### Пример 2

FBACCD B ANDM 4444h \*AR1+

|     | Перед | д командо | рй   |
|-----|-------|-----------|------|
| В   | 00    | 007F      | 2000 |
| XPC |       |           | 01   |

|     | Посл | те команд | Ы    |
|-----|------|-----------|------|
| В   | 00   | 007F      | 2000 |
| XPC |      |           | 7F   |

После того, как в операнд логически умножается (AND) на значение 4444h, 7Fh загружается в XPC, и программа продолжает выполнение с ячейки 2000h на странице 7Fh.

### 20.3.36 FCALA[D] src

Операнды

src: A (аккумулятор A)

В (аккумулятор В)

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | Z | S | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 |

#### Выполнение

Без задержки

 $(SP) - 1 \rightarrow SP$  $(PC) + 1 \rightarrow TOS$ 

 $(SP) - 1 \rightarrow SP$ 

 $(XPC) \rightarrow TOS$ 

 $(\operatorname{src}(15-0)) \to \operatorname{PC}$ 

 $(src(22-16)) \rightarrow XPC$ 

С задержкой

 $(SP) - 1 \rightarrow SP$ 

 $(PC) + 3 \rightarrow TOS$ 

 $(SP) - 1 \rightarrow SP$ 

 $(XPC) \rightarrow TOS$ 

 $(src(15-0)) \rightarrow PC$ 

 $(src(22-16)) \rightarrow XPC$ 

# Статусные биты Описание

Не используются.

Данная команда загружает в XPC значение src (биты 22–16) и передает управление в 16-разрадный адрес младшей части src (биты 15–0). Если вызов задержанный (определяется по наличию индекса D), то две команды с одним словом или одна команда с двумя словами, следующие за командой вызова, вызываются из памяти программ и выполняются.

Примечание – Данная команда не повторяемая.

В данной модели процессора операция не реализована!

Слова Циклы 1 слово.

6 цикла.

4 цикла (с задержкой).

| Классы<br>Пример 1 | Класс 30В.<br>FCALA A |          |            |      |       |       |           |      |
|--------------------|-----------------------|----------|------------|------|-------|-------|-----------|------|
|                    |                       | Перед    | выполнен   | ием  |       | После | выполн    | ения |
|                    | Α [                   | 00       | 007F       | 3000 | Α     | 00    | 007F      | 3000 |
|                    | PC [                  |          |            | 0025 | PC    |       |           | 3000 |
|                    | XPC                   |          |            | 00   | XPC   |       |           | 7F   |
|                    | SP                    |          |            | 1111 | SP    |       |           | 110F |
|                    | Память данн           | IЫX      |            |      |       |       |           |      |
|                    | 1110h                 |          |            | 4567 | 1110h |       |           | 0026 |
|                    | 110Fh                 |          |            | 4567 | 110Fh |       |           | 0000 |
| Пример 2           | FCALAD B<br>ANDM #44  | 44h, *AR | 1+         |      |       |       |           |      |
|                    |                       | Пере     | ед командо | рй   |       | Посл  | е команді | ы    |
|                    | Α                     | 00       | 0020       | 2000 | Α [   | 00    | 0020      | 2000 |
|                    | PC                    |          |            | 0025 | PC [  |       |           | 2000 |
|                    | XPC                   |          |            | 7F   | XPC [ |       |           | 20   |
|                    | SP                    |          |            | 1111 | SP [  |       |           | 110F |
|                    | Память дан            | іных     |            |      |       |       |           |      |

После того, как ячейка памяти логически умножается (AND) на значение 4444h, программа продолжает выполнение с ячейки 2000h на странице 20h.

1110h

4567

1110h

0028

### 20.3.37 FCALL[D] extpmad

Операнды

Код операции 0 ≤ extpmad ≤ 7F FFFF

| 15 | 5                                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5    | 4    | 3   | 2      | 1     | 0      |
|----|----------------------------------|----|----|----|----|----|---|---|---|------|------|------|-----|--------|-------|--------|
| 1  |                                  | 1  | 1  | 1  | 1  | 0  | Z | 1 | 1 | 7 БИ | т по | стоя | ННЫ | Й = рі | mad(2 | 22-16) |
|    | 16 битная константа = pmad(15-0) |    |    |    |    |    |   |   |   |      |      |      |     |        |       |        |

#### Выполнение

Без задержки

$$(SP) - 1 \rightarrow SP$$
  
 $(PC) + 2 \rightarrow TOS$   
 $(SP) - 1 \rightarrow SP$   
 $(XPC) \rightarrow TOS$   
 $(pmad(15-0)) \rightarrow PC$   
 $(pmad(22-16)) \rightarrow XPC$ 

С задержкой

(SP) – 1 
$$\rightarrow$$
 SP  
(PC) + 4  $\rightarrow$  TOS  
(SP) – 1  $\rightarrow$  SP  
(XPC)  $\rightarrow$  TOS  
(pmad(15–0))  $\rightarrow$  PC  
(pmad(22–16))  $\rightarrow$  XPC

#### Статусные биты Описание

Не используются.

Данная команда передает управления по указанному адресу памяти программ pmad (биты 15–0) на странице, определяемой pmad (биты 22–16). Адрес возврата записывается в стек до загрузки pmad в РС. Если вызов задержанный (определяется по наличию индекса D), то две команды по одному слову или одна команда из двух слов, следующие за командой вызова, извлекаются из памяти программ и выполняются.

Примечание – Данная команда не повторяемая.

В данной модели процессора операция не реализована!

Слова Циклы 2 слова.4 цикла.

2 цикла (с задержкой).

Классы Пример 1 Класс 29В.

FCALL 013333h

|             | Перед командой |       | После команды |
|-------------|----------------|-------|---------------|
| PC          | 0025           | PC    | 3333          |
| XPC         | 00             | XPC   | 01            |
| SP          | 1111           | SP    | 110F          |
| Память данн | ых             |       |               |
| 1110h       | 4567           | 1110h | 0027          |
| 110Fh       | 4657           | 110Fh | 0000          |
|             | 40001-         |       |               |

Пример 2

FCALLD 301000h ANDM #4444h, \*AR1+

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| PC         | 3001           | PC    | 1000          |
| XPC        | 7F             | XPC   | 30            |
| SP         | 1111           | SP    | 110F          |
| Память дан | ных            |       |               |
| 1110h      | 4567           | 1110h | 3005          |
| 110Fh      | 4657           | 110Fh | 007F          |

После того, как ячейка памяти логически умножается (AND) на значение 4444h, программа продолжает выполнение с ячейки 1000h.

#### 20.3.38 FIRS Xmem, Ymem, pmad

Операнды

Xmem, Ymem: операнды памяти данных двойного доступа.  $0 \le pmad \le 65535$ 

Код операции

|                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|                     | 1  | 1  | 1  | 0  | 0  | 0  | 0 | 0 | Х | X | X | X | Υ | Y | Υ | Υ |
| 16 битная константа |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Выполнение

 $pmad \rightarrow PAR$ 

While  $(RC) \neq 0$ 

(B) + (A(32–16)) x (Ртет адресован PAR)  $\rightarrow$  B

 $((Xmem) + (Ymem)) \ll 16 \rightarrow A$ 

 $(PAR) + 1 \rightarrow PAR$ 

(RC) - 1 → RC

Статусные

Изменяются под влиянием SXM, FRCT, и OVM.

биты Влияет на C, OVA, и OVB.

Описание

Данная команда выполняет функцию симметричного фильтра с конечной импульсной характеристикой (КИХ-фильтра).

Команда умножает аккумулятор А (биты 32–16) на значение Ртем, адресованное pmad (через регистр программного адреса PAR) и складывает результат CO значением аккумуляторе В Одновременно складывает значение операндов Хтет и Утет. сдвигает результат влево на 16 бит, и загружает это значение в аккумулятор A. Во время следующей итерации, pmad увелисивается на 1. Как только конвейер повторений начинает работу, команда становится одноцикловой.

Слова 2 слова. Циклы 3 цикла. Классы Класс 8.

Пример FIRS \*AR3+, \*AR4+, COEFFS

|            | Перед | выполнен | нем  |        | После | выполне | ния  |
|------------|-------|----------|------|--------|-------|---------|------|
| Α          | 00    | 0077     | 0000 | Α      | 00    | 00FF    | 0000 |
| В          | 00    | 0000     | 0000 | В      | 00    | 8000    | 762C |
| FRCT       |       |          | 0    | FRCT   |       |         | 0    |
| AR3        |       |          | 0100 | AR3    |       |         | 0101 |
| AR4        |       |          | 0200 | AR4    |       |         | 0201 |
| Память дан | ных   |          |      |        |       |         |      |
| 0100h      |       |          | 0055 | 0100h  |       |         | 0055 |
| 0200h      |       |          | 00AA | 0200h  |       |         | 00AA |
| Память про | грамм |          |      |        |       |         |      |
| COEFFS     |       |          | 1234 | COEFFS |       |         | 1534 |

#### 20.3.39 FRAME K

Операнды

 $-128 \le K \le 127$ 

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | 1  | 1  | 1 | 0 | K | K | K | K | K | K | K | K |

Выполнение Статусные

 $(SP) + K \rightarrow SP$ 

Не используются.

биты Описание

Данная команда складывает короткое непосредственное смещение К к SP. Задержка генерации адреса отсутствует в режиме компилятора (CPL = 1), когда используется указатель стека или в стековой обработке, осуществляемой командой, следующей за данной.

Слова 1 слово. Циклы 1 цикл. Классы Класс 1. Пример 1 FRAME 10h

> Перед командой После команды SP 1000 SP 1010

#### 20.3.40 FRET[D]

Операнды Код операции Отсутствуют.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | Z | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |

**Выполнение**  $(TOS) \rightarrow XPC$ 

 $(SP) + 1 \rightarrow SP$   $(TOS) \rightarrow PC$  $(SP) + 1 \rightarrow SP$ 

Статусные

Не используются.

биты Описание

Данная команда заменяет значение XPC 7-разрядным значением из TOS, затем заменяет PC следующим 16-разрядным значением в стеке. SP увеличивается на 1 во время каждой из двух замен. Если возврат задержанный (определяется по наличию индекса D), то две

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

Примечание – Данная команда не повторяемая.

В данной модели процессора операция не реализована!

**Слова** 1 слово. **Циклы** 6 цикла.

4 цикла (с задержкой).

**Классы** Класс 34. **Пример** FRET

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| PC         | 2112           | PC    | 1000          |
| XPC        | 01             | XPC   | 05            |
| SP         | 0300           | SP    | 0302          |
| Память дан | ных            |       |               |
| 0300h      | 0005           | 0300h | 0005          |
| 0301h      | 1000           | 0301h | 1000          |

#### 20.3.41 FRETE[D]

Операнды

Отсутствуют.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | Z | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 |

Выполнение

 $(TOS) \rightarrow XPC$  $(SP) + 1 \rightarrow SP$  $(TOS) \rightarrow PC$ (SP) + 1 → SP  $0 \rightarrow INTM$ 

Статусные

Влияет на INTM

биты Описание

Данная команда заменяет значение ХРС 7-разрядным значением из TOS, затем заменяет PC следующим 16-разрядным значением из стека, продолжая выполнение по новому значению РС. Эта команда автоматически устанавливает в 0 бит маски прерывания (INTM) в ST1. (сбрасывание этого бита делает возможным прерывание.) Если возврат задерживается (определяется по наличию индекса D), то две команды с одним словом или одна команда с двумя словами, следующие за этой командой, вызываются из памяти программ и выполняются.

Примечание – Данная команда не повторяемая.

В данной модели процессора операция не реализована!

Слова Циклы

1 слово.

6 цикла. 4 цикла (с задержкой).

Класс 34. Классы FRETE Пример

|     | Перед командой |
|-----|----------------|
| PC  | 2112           |
| XPC | 05             |
| ST1 | хСхх           |
| SP  | 0300           |

|     | После команды |      |
|-----|---------------|------|
| PC  |               | 0110 |
| XPC |               | 6E   |
| ST1 |               | x4xx |
| SP  |               | 0302 |
|     |               |      |

Память данных

| 0300h | 006E |
|-------|------|
| 0301h | 0110 |

| 0300h | 006E |
|-------|------|
| 0301h | 0110 |

#### 20.3.42 IDLE K

Операнды Код операции  $1 \le K \le 3$ 

| 15 | 14 | 13 | 12 | 11 | 10     | 9 | 8 | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|--------|---|---|---|---|----|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1      | N | N | 1 | 1 | 1  | 0 | 0 | 0 | 0 | 1 |
|    |    |    |    |    | Іри К: |   |   |   |   | NN |   |   |   |   |   |
|    |    |    |    |    | 1      |   |   |   |   | 00 |   |   |   |   |   |
|    |    |    |    |    | 2      |   |   |   |   | 10 |   |   |   |   |   |
|    |    |    |    |    | 3      |   |   |   |   | 01 |   |   |   |   |   |

Выполнение Статусные биты Описание  $(PC) +1 \rightarrow P\overline{C}$ 

Выполнение зависит от INTM.

Данная команда задерживает выполнение программы до появления немаскированного прерывания или сброса. Значение PC увеличивается на 1. устройство остается в состоянии незанятости (режим пониженного потребления энергии) до прерывания.

Выход из состояния неактивности происходит после незамаскированного прерывания, даже если INTM = 1. Если INTM = 1, программа продолжает выполнение с команды, следующей за нерабочим состоянием. Если INTM = 0, программа переходит к соответствующей программе обработки прерывания. Прерывание включается регистром маски прерывания (IMR), независимо от значения INTM. Следующие опции, установленные значением K, определяют тип прерываний, которые могут вывести устройство из состояния неактивности:

- 1. **K** = **1** периферийные устройства, такие как таймер и последовательный порт, активны. Прерывания от периферийного устройства, а также сброс и внешние прерывания выводят процессор из состояния неактивности.
- 2. **K = 2** периферийные устройства, такие как таймер и последовательный порт, не активны. Сброс и внешние прерывания выводят процессор из состояния неактивности. Поскольку в режиме неактивности прерывания не фиксируются в регистре-защелке, как во время нормальной работы устройства, они должны быть меньше на количество подтверждаемых циклов.
- 3. **K** периферийные устройства, 3 такие как таймер последовательный порт, не активны и останавливается работа PLL. Сброс и внешние прерывания выводят процессор из состояния неактивности. Поскольку в режиме неактивности прерывания не фиксируются в регистре-защелке, как во время нормальной работы устройства, ОНИ быть количество должны меньше подтверждаемых циклов.

Примечание – Данная команда не повторяемая.

Слова Циклы 1 слово.

Число циклов, необходимое для выполнения данной команды зависит от периода бездействия. Поскольку все устройство прекращает работу при K = 3, то число циклов не может быть установлено. Минимальное число циклов равно 4.

Классы

Класс 36.

**Пример 1** IDLE 1

Процессор бездействует до возникновения немаскированного

прерывания или сброса.

**Пример 2** IDLE 2

Процессор бездействует до возникновения немаскированного внешнего

прерывания или сброса.

**Пример 3** IDLE 3

Процессор бездействует до возникновения немаскированного внешнего

прерывания или сброса.

#### 20.3.43 INTR K

Операнды

 $0 \le K \le 31$ 

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 1 | 1 | 1 | 1 | 0 | K | K | K | K | K |

Выполнение

(SP) -  $1 \rightarrow SP$ 

 $(PC) + 1 \rightarrow TOS$ 

Вектор прерывания определяемый К — РС

 $1 \rightarrow INTM$ 

Статусные

На команду влияет INTM и IFR.

биты Описание

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

Во время выполнения команды PC увеличивается на 1 и записывается в TOS. Таким образом, вектор прерывания, определенный значением K, загружается в PC и для него выполняется программа обработки прерывания. Соответствующий бит в регистре флага прерывания (IFR) сбрасывается, а все прерывания отключаются (INTM = 1). Регистр маски прерываний (IMR) не оказывает влияние на команду INTR. INTR выполняется независимо от значения INTM.

Примечание – Данная команда не повторяемая.

Слова1 слово.Циклы3 цикла.КлассыКласс 35.ПримерINTR 3

|            | Перед выполнением |       | После выполнения |
|------------|-------------------|-------|------------------|
| PC         | 0025              | PC    | FF8C             |
| INTM       | 0                 | INTM  | 1                |
| IPTR       | 01FF              | IPTR  | 01FF             |
| SP         | 1000              | SP    | 0FFF             |
| Память дан | ных               |       |                  |
| 0FFFh      | 9653              | 0FFFh | 0026             |

#### 20.3.44 LD

- 1: **LD** Smem, dst
- 2: LD Smem, TS, dst
- 3: **LD** Smem, 16, dst
- 4: LD Smem [, SHIFT], dst
- 5: LD Xmem, SHFT, dst
- 6: **LD** #K, dst
- 7: **LD** #lk [, SHFT], dst
- 8: **LD** #lk, 16, dst
- 9: **LD** src, ASM [, dst ]
- 10: LD src [, SHIFT], dst

Дополнительные команды загрузки см. в разделе «Load T/DP/ASM/ARP».

#### Операнды

Smem: операнд памяти данных двойного доступа Xmem:

операнд памяти данных одиночного доступа

А (аккумулятор А) src, dst:

В (аккумулятор В)

 $0 \le K \le 255$ 

 $-32768 \le lk \le 32767$ 

-16 ≤ SHIFT ≤ 15

0 ≤ SHFT≤ 15

### Код операции

1:

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 0 |   | 0 | <u> </u> | 4 | <u> </u> |   |   |   |
|---|----|----|----|----|----|----|---|---|---|---|----------|---|----------|---|---|---|
|   | 0  | 0  | 0  | 1  | 0  | 0  | 0 | D | _ | Α | Α        | Α | Α        | Α | Α | Α |
| 2 | :  |    |    |    |    |    |   |   |   |   |          |   |          |   |   |   |
| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5        | 4 | 3        | 2 | 1 | 0 |
|   | 0  | 0  | 0  | 1  | 0  | 1  | 0 | D | ı | Α | Α        | Α | Α        | A | Α | Α |

3:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 0  | 1  | 0 | D | ı | Α | Α | Α | Α | Α | Α | Α |

| 4:                                                                           |                                                                 |                                                              |                                                                  |                                                |                     |     |     |     |      |    |   |   |   |   |   |
|------------------------------------------------------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------|---------------------|-----|-----|-----|------|----|---|---|---|---|---|
| 15                                                                           | 14                                                              | 13                                                           | 12                                                               | 11                                             | 10                  | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 0                                                                            | 0                                                               | 1                                                            | 1                                                                | 0                                              | 1                   | 1   | 1   | ı   | A    | Α  | Α | Α | Α | Α | Α |
| 0                                                                            | 0                                                               | 0                                                            | 0                                                                | 1                                              | 1                   | 0   | D   | 0   | 1    | 0  | S | Н | ı | F | Т |
| 5:                                                                           |                                                                 |                                                              |                                                                  |                                                |                     |     |     |     |      |    |   |   |   |   |   |
| 15                                                                           | 14                                                              | 13                                                           | 12                                                               | 11                                             | 10                  | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1                                                                            | 0                                                               | 0                                                            | 1                                                                | 0                                              | 1                   | 0   | D   | Х   | X    | X  | X | S | Н | F | Т |
| 6:                                                                           |                                                                 |                                                              |                                                                  |                                                |                     |     |     |     |      |    |   |   |   |   |   |
| 15                                                                           | 14                                                              | 13                                                           | 12                                                               | 11                                             | 10                  | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1                                                                            | 1                                                               | 1                                                            | 0                                                                | 1                                              | 0                   | 0   | D   | K   | K    | K  | K | K | K | K | K |
| 7:                                                                           |                                                                 |                                                              |                                                                  |                                                |                     |     |     |     |      |    |   |   |   |   |   |
| 15                                                                           | 14                                                              | 13                                                           | 12                                                               | 11                                             | 10                  | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1                                                                            | 1                                                               | 1                                                            | 1                                                                | 0                                              | 0                   | 0   | D   | 0   | 0    | 1  | 0 | S | Н | F | T |
|                                                                              |                                                                 |                                                              |                                                                  |                                                | 16                  | бит | ная | кон | стан | та |   |   |   |   |   |
| 8:                                                                           |                                                                 |                                                              |                                                                  |                                                |                     |     |     |     |      |    |   |   |   |   |   |
| 15                                                                           | 14                                                              | 13                                                           | 12                                                               | 11                                             | 10                  | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1                                                                            | 1                                                               | 1                                                            | 1                                                                | 0                                              | 0                   | 0   | D   | 0   | 1    | 1  | 0 | 0 | 0 | 1 | 0 |
|                                                                              |                                                                 |                                                              |                                                                  |                                                | 16                  | бит | ная | кон | стан | та |   |   |   |   |   |
| 9:                                                                           |                                                                 |                                                              |                                                                  |                                                |                     |     |     |     |      |    |   |   |   |   |   |
| 15                                                                           | 14                                                              | 13                                                           | 12                                                               | 11                                             | 10                  | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1                                                                            | 1                                                               | 1                                                            | 1                                                                | 0                                              | 1                   | S   | D   | 1   | 0    | 0  | 0 | 0 | 0 | 1 | 0 |
| 10:                                                                          |                                                                 |                                                              |                                                                  |                                                |                     |     |     |     |      |    |   |   |   |   |   |
| 15                                                                           | 14                                                              | 13                                                           | 12                                                               | 11                                             | 10                  | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1                                                                            | 1                                                               | 1                                                            | 1                                                                | 0                                              | 1                   | S   | D   | 0   | 1    | 0  | S | Н | I | F | T |
| 2: (S<br>3: (S<br>4: (S<br>5: (X<br>6: K<br>7: lk<br>8: lk<br>9: (S<br>10: ( | Smen<br>Smen<br>(men<br>→ d:<br><< 5<br><< 1<br>src) <<br>(src) | า) <<<br>า) <<<br>า) <<<br>st<br>SHFT<br>6 →<br>< AS<br><< S | TS -<br>16 -<br>SHI<br>SHF<br>→ d<br>dst<br>M →<br>HIFT<br>Babus | → ds°<br>FT —<br>FT →<br>Ist<br>· dst<br>· → c | t<br>→ dst<br>· dst |     |     |     |      |    |   |   |   |   |   |

Выполнение

Статусные

биты

Результат влияет на OVdst (или OVsrc, если dst = src) при загрузке со сдвигом SHIFT или ASM.

#### Описание

Данная команда загружает в аккумулятор (dst, или src, если dst не указан) значение памяти данных или непосредственное значение, поддерживая при этом различные величины сдвига.

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

Примечание – Следующие синтаксисы ассемблируются как различный синтаксис в определенных условиях.

- 1. Синтаксис 4: если SHIFT = 0, код операции команды ассемблируется по синтаксису 1.
- 2. Синтаксис 4: если 0 < SHIFT ≤ 15 и режим косвенной адерсации Smem входит в Xmem, код операции команды ассемблируется как синтаксис 5.
- 3. Синтаксис 5: если SHFT = 0, код операции команды ассемблируется как синтаксис 1.
- 4. Синтаксис 7если SHFT = 0 и 0 ≤ lk ≤ 255, код операции команды ассемблируется как синтаксис 6.

#### Слова

Синтаксисы 1, 2, 3, 5, 6, 9, и 10: 1 слово.

Синтаксисы 4, 7, и 8: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Циклы

Синтаксисы 1, 2, 3, 5, 6, 9, и 10: 1 цикл.

Синтаксисы 4, 7, и 8: 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Классы

Синтаксисы 1, 2, 3 и 5: Класс 3А.

Синтаксисы 1, 2 и 3: Класс 3В.

Синтаксис 4: Класс 4А. Синтаксис 4: Класс 4В.

Синтаксисы 6, 9, и 10: Класс 1.

Синтаксисы 7 и 8: Класс 2.

#### **Пример 1** LD \*AR1, A

|            | Пере | д командо | ой   |       | Посл | сле команды |      |  |
|------------|------|-----------|------|-------|------|-------------|------|--|
| Α          | 00   | 0000      | 0000 | Α     | 00   | 0000        | FEDC |  |
| SXM        |      |           | 0    | SXM   |      |             | 0    |  |
| AR1        |      |           | 0200 | AR1   |      |             | 0200 |  |
| Память дан | ных  |           |      |       |      |             |      |  |
| 0200h      |      |           | FEDC | 0200h |      |             | FEDC |  |

#### Пример 2 LD \*AR1, A Перед командой После команды Α 0000 0000 Α **FFFF FEDC** SXM SXM AR1 0200 AR1 0200 Память данных 0200h **FEDC** 0200h **FEDC** LD \*AR1, TS, B Пример 3 Перед командой После команды В 00 0000 0000 В DC00 FF **FFFE** SXM SXM AR1 0200 AR1 0200 8 Т Т 8 Память данных 0200h 0200h **FEDC FEDC** Пример 4 LD \*AR3+, 16, A Перед командой После команды В 00 0000 0000 В **FEDC** 0000 SXM SXM AR3 0300 AR3 0301 Память данных 0300h **FEDC** 0300h **FEDC** Пример 5 LD #248, B Перед командой После команды 0000 0000 00 0000 00F8 В 00 В SXM 1 SXM 1 Пример 6 LD A, 8, B

|            | Пере    | д команд | ой   |       | Пос | пе команд | <b>,</b> Ы |
|------------|---------|----------|------|-------|-----|-----------|------------|
| Α          | 00      | 7FFD     | 0040 | Α     | 00  | 7FF0      | 0040       |
| В          | 00      | 0000     | FFFF | В     | 7F  | FD00      | 4000       |
| OVB        |         |          | 0    | OVB   |     |           | 1          |
| SXM        |         |          | 1    | SXM   |     |           | 1          |
| Память дан | ных     |          |      |       |     |           |            |
| 0200h      |         |          | FEDC | 0200h |     |           | FEDC       |
| S LDM MM   | IR, dst |          |      |       |     |           |            |

#### 20.3.45

Операнды MMR: отображаемый в памяти регистр.

> А (аккумулятор). dst: В (аккумулятор).

Код операции

| 15 | 14 | 1 | 3 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|---|---|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | C | ) | 0  | 1  | 0  | 0 | D | I | Α | Α | Α | Α | Α | Α | Α |

Выполнение  $(MMR) \rightarrow dst(15-0)$ 

 $00\ 0000h \rightarrow dst(39-16)$ 

Статусные

биты

Не используются.

Описание Данная команд загружает в dst значение отображаемого в памяти

регистра MMR.

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

от значения SXM.

Слова 1 слова. Циклы 1 цикл. Классы Класс 3А. Пример 1 LDM AR4, A

|     | Перед | д командо | рй   |     | Посл | е команд | Ы    |
|-----|-------|-----------|------|-----|------|----------|------|
| Α   | 00    | 0000      | 1111 | Α   | 00   | 0000     | FFFF |
| AR4 |       |           | FFFF | AR4 |      |          | FFFF |

Пример 2 LDM 060h, B

|   | Перед командой |      |      |   |    | После команды |      |  |  |  |  |
|---|----------------|------|------|---|----|---------------|------|--|--|--|--|
| В | 00             | 0000 | 0000 | В | 00 | 0000          | 1234 |  |  |  |  |
|   |                |      |      |   |    |               |      |  |  |  |  |

Память данных

0060h 1234 0060h 1234

20.3.46

#### LD Xmem, dst || MAC[R] Ymem [, dst\_]

**Операнды** dst: A (аккумулятор A).

В (аккумулятор В).

 $dst_{-}$ : If dst = A, then  $dst_{-} = B$ ; if dst = B, then  $dst_{-} = A$ 

Xmem, Ymem: операнды памяти данных двойного доступа

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 1  | 0  | 1  | 0  | R | D | Х | Х | Х | Х | Υ | Υ | Υ | Υ |

Выполнение (Xmem)  $<< 16 \rightarrow dst (31-16)$ 

If (округление)

Round (((Ymem) x (T)) + (dst ))  $\rightarrow$  dst

Else

 $((Ymem) x (T)) + (dst_) \rightarrow dst_$ 

Статусные биты

Циклы

Выполнение изменяется под влиянием SXM, FRCT и OVM

Команда влияет на OVdst\_ и OVdst

Описание Данная команда загружает операнд памяти данных двойного

доступа Xmem, сдвигая его влево на 16 бит в сторону старшей части dst (биты 31–16). Параллельно с эти, данная команда умножает операнд Ymem на содержимое T, складывает результат

умножения с dst\_ и сохраняет результат в dst\_.

При использовании индекса R, эта команда округляет результат умножения и выполняет операцию сложения путем добавления  $2^{15}$  к результату и сбрасыванием значений младших битов (15–0) в 0,

и сохраняет результат в dst\_.

**Слова** 1 слово.

Классы Класс 7.

**Пример 1** LD \*AR4+, A

IIMAC \*AR5+, B

1 цикл.

| Α          | 00  | 0000 | 1000 |
|------------|-----|------|------|
| В          | 00  | 0000 | 1111 |
| Т          |     |      | 0400 |
| FRCT       |     |      | 0    |
| AR4        |     |      | 0100 |
| AR5        |     |      | 0200 |
| Память дан | ных |      |      |
| 0100h      |     |      | 1234 |
| 0200h      |     |      | 4321 |
|            |     |      |      |

Перед командой

|      | Пос | сле команд | ļЫ   |
|------|-----|------------|------|
| Α    | 00  | 1234       | 0000 |
| В    | 00  | 010C       | 9511 |
| Т    |     |            | 0400 |
| FRCT |     |            | 0    |
| AR4  |     |            | 0101 |
| AR5  |     |            | 0201 |

| 0100h | 1234 |
|-------|------|
| 0200h | 4321 |

Пример 2 LD \*AR4+, A ||MACR \*AR5+, B

| 11         | ,    |           |      |       |      |           |      |
|------------|------|-----------|------|-------|------|-----------|------|
|            | Пере | д командо | рй   |       | Посл | те команд | ы    |
| Α          | 00   | 0000      | 1000 | Α     | 00   | 1234      | 0000 |
| В          | 00   | 0000      | 1111 | В     | 00   | 010D      | 0000 |
| Т          |      |           | 0400 | Т     |      |           | 0400 |
| FRCT       |      |           | 0    | FRCT  |      |           | 0    |
| AR4        |      |           | 0100 | AR4   |      |           | 0101 |
| AR5        |      |           | 0200 | AR5   |      |           | 0201 |
| Память дан | ных  |           |      |       |      |           |      |
| 0100h      |      |           | 1234 | 0100h |      |           | 1234 |
| 0200h      |      |           | 4321 | 0200h |      |           | 4321 |

### 20.3.47 LD Xmem, dst || MAS[R] Ymem [, dst\_]

Операнды Хтем, Үтем: операнды памяти данных двойного доступа.

dst: A (аккумулятор A).

В (аккумулятор В).

dst\_: If dst = A, then dst\_ = B; if dst = B, then dst\_ = A

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 1  | 0  | 1  | 1  | R | D | Х | Χ | Χ | X | Υ | Υ | Υ | Υ |

**Выполнение** (Xmem)  $<< 16 \rightarrow dst (31-16)$ 

If (Rounding)

Round ((dst )  $\times$  ((T) (Ymem)))  $\rightarrow$  dst

Else

 $(dst_{-}) - ((T) \times (Ymem)) \rightarrow dst_{-}$ 

Статусные биты Описание Выполнение зависит от SXM, FRCT и OVM

Команда влияет на OVdst и OVdst

Данная команда загружает операнд памяти данных двойного доступа Xmem, сдвигая его влево на 16 бит в сторону старшей части dst (биты 31–16). Параллельно с эти, данная команда умножает операнд Ymem на содержимое Т, вычитает результат умножения из dst и сохраняет

результат в dst .

При использовании индекса R, эта команда округляет результат умножения с вычитанем путем сложения  $2^{15}$  с результатом и сбрасыванием значений младших бит (15–0) в 0, и сохраняет результат

в dst\_.

Слова1 слово.Циклы1 цикл.КлассыКласс 7.

# **Пример 1** LD \*AR4+, A ||MAS \*AR5+, B

|      | Перед | д командо | Й    |
|------|-------|-----------|------|
| Α    | 00    | 0000      | 1000 |
| В    | 00    | 0000      | 1111 |
| Т    |       |           | 0400 |
| FRCT |       |           | 0    |
| AR4  |       |           | 0100 |
| AR5  |       |           | 0200 |

|      | Пост | те команды | ol   |
|------|------|------------|------|
| Α    | 00   | 1234       | 0000 |
| В    | FF   | FEF3       | 8D11 |
| Т    |      |            | 0400 |
| FRCT |      |            | 0    |
| AR4  |      |            | 0101 |
| AR5  |      |            | 0201 |

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

| 0100h | 1234 |
|-------|------|
| 0200h | 4321 |

| 0100h | 1234 |
|-------|------|
| 0200h | 4321 |

# Пример 2 LD \*AR4+, A ||MASR \*AR5+, B

|      | Пе | ред коман | дой  |
|------|----|-----------|------|
| Α    | 00 | 0000      | 1000 |
| В    | 00 | 0000      | 1111 |
| T    |    |           | 0400 |
| FRCT |    |           | 0    |
| AR4  |    |           | 0100 |
| AR5  |    |           | 0200 |
| AR5  |    |           | 0200 |

|      | П | осле і | команды |      |
|------|---|--------|---------|------|
| Α    | 0 | 0      | 1234    | 0000 |
| В    | F | F      | FEF4    | 0000 |
| T    |   |        |         | 0400 |
| FRCT |   |        |         | 0    |
| AR4  |   |        |         | 0101 |
| AR5  |   |        |         | 0201 |
|      |   |        |         |      |

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

| 0100h | 1234 |
|-------|------|
| 0200h | 4321 |

| 0100h | 1234 |
|-------|------|
| 0200h | 4321 |

## 20.3.48 LDR Smem, dst

**Операнды** Smem: операнд памяти данных одиночного доступа.

 $\mathsf{dst}$ : A (аккумулятор A).

В (аккумулятор В).

Код операции

12 11 10 14 15 7 5 0 0 0 1 0 1 1 D ī Α Α Α Α Α Α

Выполнение (Smem)  $<< 16 + 1 << 15 \rightarrow dst(31-16)$ 

**Статусные** Выполнение зависит от SXM. **биты** Команда влияет на OVdst

Описание Данная команда загружает значение операнда памяти, сдвинутого

влево на 16 битов в старшую часть dst (биты 31-16). Smem округляется путем сложения с числом  $2^{15}$  с этим значением и сбрасыванием 15 самых младших битов (14-0) аккумулятора. Бит 15 аккумулятора

принимает значение 1.

**Слова** 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Класс 3А.

Класс 3В.

Пример LDR \*AR1, A

| Пере | д командо | й    | После команды |    |      |      |  |  |
|------|-----------|------|---------------|----|------|------|--|--|
| 00   | 0000      | 0000 | Α             | 00 | FEDC | 8000 |  |  |
|      |           | 0    | SXM           |    |      | 0    |  |  |
|      |           | 0200 | AR1           |    |      | 0200 |  |  |

Память данных

SXM

AR1

0200h FEDC 0200h FEDC

7

ī

Α

5

Α

Α

Α

Α

Α

## 20.3.49 LDU Smem, dst

**Операнды** Smem: операнд памяти данных одиночного доступа.

12 11

1

 $\mathsf{dst}$ : A (аккумулятор A).

13

0

В (аккумулятор В).

0

Выполнение (Smem)  $\rightarrow$  dst(15–0)

 $00\ 0000h \rightarrow dst(39-16)$ 

14

0

Статусные

операции

Не используются.

15

0

биты

Код

Описание Данная команда загружает значение Smem в младшую часть dst (биты

10

0

1

D

15–0). Сторожевые биты и старшая часть dst (биты 39–16) сбрасываются в 0. Данные обрабатываются как 16-разрядное число без

знака. Знак не расширяется независимо от статуса бита SXM.

Слова 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Класс 3А.

Класс 3В.

Пример LDU \*AR1, A

|     | Пере | д командо | рй   |     | После команды |      |      |  |
|-----|------|-----------|------|-----|---------------|------|------|--|
| Α   | 00   | 0000      | 0000 | Α   | 00            | 0000 | FEDC |  |
| AR1 |      |           | 0200 | AR1 |               |      | 0200 |  |

Память данных

0200h FEDC 0200h FEDC

## 20.3.50 LMS Xmem, Ymem

Операнды

Xmem, Ymem: операнды памяти данных двойного доступа.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | 0  | 0  | 0 | 1 | Х | X | Χ | X | Υ | Υ | Υ | Α |

Выполнение

(A) + (Xmem)  $<< 16 + 2^{15} \rightarrow A$ 

(B) + (Xmem) × (Ymem)  $\rightarrow$  B

Статусные

Выполнение команды зависит от SXM, FRCT и OVM.

биты Описание Инструкция влияет на C, OVA и OVB.

Данная команда выполняет алгоритм метода наименьших квадратов (LMS). Операнд Хтет сдвигается влево на 16 битов и добавляется к аккумулятору А. Результат округляется путем добавления  $2^{15}$  к старшей части аккумулятора (биты 31-16). Результат сохраняется в аккумуляторе А. Параллельно, Хтет и Утет перемножаются и результат добавляется к аккумулятору В. Хтет не записывает поверх Т; в связи с этим, Т всегда содержит значение ошибки, используемое

для обновлениря коэффициента.

Слова Циклы Классы 1 слово.

1 цикл. Класс 7.

Пример

LMS \*AR3+, \*AR4+

|            | Пере | д командо | ой   |       | После команды |      |      |  |  |
|------------|------|-----------|------|-------|---------------|------|------|--|--|
| Α          | 00   | 7777      | 8888 | Α     | 00            | 77CD | 0888 |  |  |
| В          | 00   | 0000      | 0100 | В     | 00            | 0000 | 3972 |  |  |
| FRCT       |      |           | 0    | FRCT  |               |      | 0    |  |  |
| AR3        |      |           | 0100 | AR3   |               |      | 0101 |  |  |
| AR4        |      |           | 0200 | AR4   |               |      | 0201 |  |  |
| Память дан | ных  |           |      |       |               |      |      |  |  |
| 0100h      |      |           | 0055 | 0100h |               |      | 0055 |  |  |
| 0200h      |      |           | 00AA | 0200h |               |      | 00AA |  |  |

#### 20.3.51 LTD Smem

Операнды

Smem: операнд памяти данных одиночного значения.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 0 | 0 | I | Α | Α | Α | Α | Α | Α | Α |

Выполнение

 $(Smem) \rightarrow T$ 

(Smem) → Smem + 1

Статусные

биты Описание Не используются.

Данная команда копирует содержимое ячейки памяти данных Smem в Т и по адресу ячейки памяти данных, следующей за данной. Когда данные скопированы, содержимое по адресу ячейки остается прежним. Эта функция полезна при осуществлении задержки Z в применении цифровой обработки сигнала. Эту функцию также содержит команда

DELAY.

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 24А.

Класс 24В. Пример LTD \*AR3

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| Т          | 0000           | Т     | 6CAC          |
| AR3        | 0100           | AR3   | 0100          |
| Память дан | ных            |       |               |
| 0100h      | 6CAC           | 0100h | 6CAC          |
| 0101h      | xxxx           | 0101h | 6CAC          |

## 20.3.52 MAC[R]

1: MAC[R] Smem, src

2: MAC[R] Xmem, Ymem, src [, dst ]

3: **MAC** #lk, src [, dst ]

4: MAC Smem, #lk, src [, dst ]

#### Операнды

Smem: операнд памяти данных одиночного доступа

Xmem, Ymem: операнды памяти данных двойного доступа

src, dst: A (аккумулятор A)

В (аккумулятор В) –32 768 ≤ lk ≤ 32 767

## Код операции

1:

0

1

| 15  | 14                  | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
|-----|---------------------|----|----|----|----|---|---|-----|---|----|---|---|---|---|---|
| 0   | 0                   | 1  | 0  | 1  | 0  | R | S | ı   | Α | Α  | Α | Α | Α | Α | Α |
| 2:  |                     |    |    |    |    |   |   |     |   |    |   |   |   |   |   |
| 15  | 14                  | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
| 1   | 0                   | 1  | 1  | 0  | R  | S | D | Х   | X | X  | X | Y | Υ | Υ | Υ |
| 3:  |                     |    |    |    |    |   |   |     |   |    |   |   |   |   |   |
| 15  | 14                  | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
| 1   | 1                   | 1  | 1  | 0  | 0  | S | D | 0   | 1 | 1  | 0 | 0 | 1 | 1 | Y |
|     | 16 битная константа |    |    |    |    |   |   |     |   |    |   |   |   |   |   |
| 4:  |                     |    |    |    |    |   |   |     |   |    |   |   |   |   |   |
| 15_ | 14                  | 13 | 12 | 11 | 10 | 9 | 8 | . 7 | 6 | 5_ | 4 | 3 | 2 | 1 | 0 |

#### Выполнение

1:  $(Smem) \times (T) + (src) \rightarrow src$ 

0

2:  $(Xmem) \times (Ymem) + (src) \rightarrow dst$ 

0

1

S

16

D

ı

битная константа

Α

Α

Α

 $(Xmem) \rightarrow T$ 

1

- 3:  $(T) \times lk + (src) \rightarrow dst$
- 4:  $(Smem) \times lk + (src) \rightarrow dst$

 $(Smem) \rightarrow T$ 

## Статусные биты

Результат зависит от FRCT и OVM.

# Описание

Команда влияет на OVdst (или OVsrc, если не определен dst).

Данная команда умножает с накоплением, с округлением или без него. Результат сохраняется в dst или src, в зависимости от того, что определено. Для синтаксисов 2 и 4, значение памяти данных после выполнения команды сохраняется в Т. Т обновляется в фазе чтения.

При использовании индекса R, эта команда округляет результат умножения и выполняет операцию сложения путем добавления  $2^{15}$  к результату и сбрасыванием значений младших битов (15–0) в 0.

#### Слова

Синтаксисы 1 и 2: 1 слово.

Синтаксисы 3 и 4: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

Циклы

Синтаксисы 1 и 2: 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с

длинным смещением или абсолютной адресации с Smem.

Классы Синтаксис 1: Класс 3А.

Синтаксис 1: Класс 3В. Синтаксис 2: Класс 7. Синтаксис 3: Класс 2. Синтаксис 4: Класс 6А. Синтаксис 4: Класс 6В.

Синтаксисы 3 и 4: 2 цикла.

**Пример 1** MAC \*AR5+, A

|      | перед командои |      |      |  |  |  |  |  |  |
|------|----------------|------|------|--|--|--|--|--|--|
| Α    | 00             | 0000 | 1000 |  |  |  |  |  |  |
| T    |                |      | 0400 |  |  |  |  |  |  |
| FRCT |                |      | 0    |  |  |  |  |  |  |
| AR5  |                |      | 0100 |  |  |  |  |  |  |

Пород командой

|      | После команды |      |      |  |  |  |  |  |  |
|------|---------------|------|------|--|--|--|--|--|--|
| Α    | 00            | 0048 | E000 |  |  |  |  |  |  |
| Т    |               |      | 0400 |  |  |  |  |  |  |
| FRCT |               |      | 0    |  |  |  |  |  |  |
| AR5  |               |      | 0101 |  |  |  |  |  |  |

Память данных

| 0100h | 1234 |
|-------|------|
|-------|------|

0100h 1234

**Пример 2** MAC #345h, A, B

|      | Перед командой |      |      |  |  |  |  |  |  |  |
|------|----------------|------|------|--|--|--|--|--|--|--|
| Α    | 00             | 0000 | 1000 |  |  |  |  |  |  |  |
| В    | 00             | 0000 | 0000 |  |  |  |  |  |  |  |
| T    |                |      | 0400 |  |  |  |  |  |  |  |
| FRCT |                |      | 1    |  |  |  |  |  |  |  |

|     | После команды |      |      |  |  |  |  |  |  |  |  |
|-----|---------------|------|------|--|--|--|--|--|--|--|--|
| A   | 00            | 0000 | 1000 |  |  |  |  |  |  |  |  |
| В   | 00            | 001A | 3800 |  |  |  |  |  |  |  |  |
| T   |               |      | 4000 |  |  |  |  |  |  |  |  |
| RCT |               |      | 1    |  |  |  |  |  |  |  |  |

**Пример 3** MAC \*AR5+, #1234h, A

|      | i iepe, | д командо | М    |
|------|---------|-----------|------|
| Α _  | 00      | 0000      | 1000 |
| т [  |         |           | 0000 |
| FRCT |         |           | 0    |
| AR5  |         |           | 0100 |
|      |         |           |      |

Пород комошлой

|      | Посл | е команді | əl   |
|------|------|-----------|------|
| Α    | 00   | 0626      | 1060 |
| T    |      |           | 5678 |
| FRCT |      |           | 0    |
| AR5  |      |           | 0101 |
|      |      |           |      |

Память данных

| 0100h | 5678 |
|-------|------|
|-------|------|

0100h 5678

**Пример 4** MAC \*AR5+, \*AR6+,A, В

|          |             | Перед    | д командо | Й    |       | Посл | е команды | ol   |
|----------|-------------|----------|-----------|------|-------|------|-----------|------|
|          | Α [         | 00       | 0000      | 1000 | Α [   | 00   | 0000      | 1000 |
|          | В           | 00       | 0000      | 0004 | В     | 00   | 0C4C      | 10C0 |
|          | т [         |          |           | 8000 | т [   |      |           | 5678 |
|          | FRCT        |          |           | 1    | FRCT  |      |           | 1    |
|          | AR5         |          |           | 0100 | AR5   |      |           | 0101 |
|          | AR6         |          |           | 0200 | AR6   |      |           | 0201 |
|          | Память данн | ных      |           |      |       |      |           |      |
|          | 0100h       |          |           | 5678 | 0100h |      |           | 5678 |
|          | 0200h       |          |           | 1234 | 0200h |      |           | 1234 |
| Пример 5 | MACR *AR    | 5+, A    |           |      |       |      |           |      |
|          |             | Пер      | ед команд | цой  |       | Пос  | ле коман, | ды   |
|          | A           | 00       | 0000      | 1000 | Α     | 00   | 0049      | 0000 |
|          | T           |          |           | 0400 | Т     |      |           | 0400 |
|          | FRCT        |          |           | 0    | FRCT  |      |           | 0    |
|          | AR5         |          |           | 0100 | AR5   |      |           | 0101 |
|          | Память да   | нных     |           |      |       |      |           |      |
|          | 0100h       |          |           | 1234 | 0100h |      |           | 1234 |
| Пример 6 | MACR *AR    | 5+, *AR6 | 5+,A, B   |      |       |      |           |      |
|          | _           | Перед    | д командо | рй   | _     | Посл | е командь | ol   |
|          | Α           | 00       | 0000      | 1000 | Α     | 00   | 0000      | 1000 |
|          | В           | 00       | 0000      | 0004 | В     | 00   | 0C4C      | 0000 |
|          | т [         |          |           | 8000 | т [   |      |           | 5678 |
|          | FRCT        |          |           | 1    | FRCT  |      |           | 1    |
|          | AR5         |          |           | 0100 | AR5   |      |           | 0101 |
|          | AR6         |          |           | 0200 | AR6   |      |           | 0201 |
|          | Память данн | ных      |           |      |       |      |           |      |
|          | 0100h       |          |           | 5678 | 0100h |      |           | 5678 |
|          | 0200h       |          |           | 1234 | 0200h |      |           | 1234 |

## 20.3.53 MACA[R]

MACA[R] Smem [, B ]
 MACA[R] T, src [, dst ]

**Операнды** Smem: операнд памяти данных одиночного доступа.

src, dst: A (аккумулятор A).

В (аккумулятор В).

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 1  | 1  | 0  | 1  | R | 1 | I | Α | Α | Α | Α | Α | Α | Α |

2:

1:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | S | D | 1 | 0 | 0 | 0 | 1 | 0 | 0 | R |

Выполнение

1:  $(Smem) \times (A(32-16)) + (B) \rightarrow B$ 

 $(Smem) \rightarrow T$ 

2:  $(T) \times (A(32-16)) + (src) \rightarrow dst$ 

Статусные

Результат под влиянием FRCT и OVM.

биты

Команда влияет на OVdst (или OVsrc, если dst не указан) и OVB в

синтаксисе 1.

Описание

Данная команда умножает старшую часть аккумулятора A (биты 32–16) на значение операнда Smem или на содержимое T, добавляет результат к аккумулятору B (синтаксис 1) или к src. Результат сохраняется в аккумулятор B (синтаксис 1) или в dst или src если не указан dst. A(32–16) используется в множителе в качестве 17-разрядного операнда.

При использовании индекса R, эта команда округляет результат умножения аккумулятора A путем добавления  $2^{15}$  к результату и сбрасыванием значений 16 младших битов dst (15–0) в 0.

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Синтаксисы 1 и 2: Класс 3A. Синтаксисы 1 и 2: Класс 3B. Синтаксисы 3 и 4: Класс 1.

| Пример 1 | MACA *A   | \R5+        |            |      |       |      |           |      |
|----------|-----------|-------------|------------|------|-------|------|-----------|------|
|          |           | Пеј         | ред команд | дой  |       | Пос  | ле команд | ίΡΙ  |
|          | Α         | 00          | 1234       | 0000 | Α     | 00   | 1234      | 0000 |
|          | В         | 00          | 0000       | 0000 | В     | 00   | 0626      | 0060 |
|          | т         |             |            | 0400 | т     |      |           | 5678 |
|          | FRCT      | г           |            | 0    | FRCT  |      |           | 0    |
|          | AR5       |             |            | 0100 | AR5   |      |           | 0101 |
|          | Память да | анных       |            |      |       |      |           |      |
|          | 0100h     | n           |            | 5678 | 0100h |      |           | 5678 |
| Пример 2 | MACA T,   | , B, B      |            |      | •     |      |           |      |
|          | _         | Перед       | командо    | й    |       | Посл | те команд | Ы    |
|          | Α         | 00          | 1234       | 0000 | Α     | 00   | 1234      | 0000 |
|          | В         | 00          | 0002       | 0000 | В     | 00   | 009D      | 4BA0 |
|          | Т         |             |            | 0444 | Т     |      |           | 0444 |
|          | FRCT      |             |            | 1    | FRCT  |      |           | 1    |
| Пример 3 | MACAR     | *AR5+, B    |            |      |       |      |           |      |
|          |           | Пеј         | оед команд | дой  |       | Пос  | ле команд | цы   |
|          | Α         | 00          | 1234       | 0000 | A     | 00   | 1234      | 0000 |
|          | В         | 00          | 0000       | 0000 | В     | 00   | 0626      | 0000 |
|          | т         |             |            | 0400 | т     |      |           | 5678 |
|          | FRCT      | г           |            | 0    | FRCT  |      |           | 0    |
|          | AR5       |             |            | 0100 | AR5   |      |           | 0101 |
|          | Память да | анных       |            |      |       |      |           |      |
|          | 0100h     | n           |            | 5678 | 0100h |      |           | 5678 |
| Пример 4 | MACAR     | <br>Т, В, В |            |      | •     |      |           |      |
|          |           | Перед       | , командо  | й    |       | Посл | те команд | Ы    |
|          | Α [       | 00          | 1234       | 0000 | Α [   | 00   | 1234      | 0000 |
|          | В         | 00          | 0002       | 0000 | В     | 00   | 009D      | 0000 |
|          | т [       |             |            | 0444 | т [   |      |           | 0444 |
|          | FRCT      |             |            | 1    | FRCT  |      |           | 1    |

#### 20.3.54 MACD Smem, pmad, src

**Операнды** Smem: операнд памяти данных одиночного доступа

src: A (аккумулятор A)

В (аккумулятор В)

0 ≤ pmad ≤ 65 535

| Код      |
|----------|
| операции |

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|-----|------|-----|------|----|---|---|---|---|---|
|   | 0  | 1  | 1  | 1  | 1  | 0  | 1   | S    | ı   | Α    | Α  | Α | Α | Α | Α | Α |
| Ī |    |    |    |    |    | 16 | бит | гная | кон | стан | та |   |   |   |   |   |

#### Выполнение

 $\mathsf{pmad} \to \mathsf{PAR}$ 

If  $(RC) \neq 0$ 

Then

(Smem) x (Pmem адресованный через PAR) + (src) → src

 $(Smem) \rightarrow T$ 

(Smem) → Smem + 1

 $(PAR) + 1 \rightarrow PAR$ 

Else

(Smem) x (Pmem адресованный через PAR) + (src)  $\rightarrow$  src

 $(Smem) \rightarrow T$ 

 $(Smem) \rightarrow Smem + 1$ 

## Статусные биты Описание

Выполнение зависит от FRCT и OVM.

Команда влияет на OVsrc.

Данная команда умножает значение Smem на значение pmad, добавляет произведение к src, и сохраняет результат в src. Значение Smem копируется в Т и в ячейку по адресу, следующему за адресом Smem. При повторении этой команды, адрес памяти программ (в регистре адреса программ PAR) увеличивается на 1. Как только конвейер повторений начинает работу, команда становится одноцикловой. Данная функция включает в себя команду DELAY.

**Слова** 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы 3 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Класс 23А.

Класс 23В.

#### Пример MACD \*AR3-, COEFFS, A Перед командой После команды Α 0077 0000 Α 007D 0B44 Т 8000 Т 0055 **FRCT FRCT** 0 AR5 0100 AR5 00FF Память программ COEFFS 1234 **COEFFS** 1234 Память данных 0100h 0055 0100h 0055 0200h 0066 0200h 0055

## 20.3.55 MACP Smem, pmad, src

| Операнды | Smem: | операнд памяти данных одиночного доступа |
|----------|-------|------------------------------------------|
|----------|-------|------------------------------------------|

src: A (аккумулятор A).

В (аккумулятор В).

0 ≤ pmad ≤ 65 535

| Код      |
|----------|
| операции |

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|-----|-----|-----|------|----|---|---|---|---|---|
|   | 0  | 1  | 1  | 1  | 1  | 0  | 0   | S   | ı   | Α    | Α  | Α | Α | Α | Α | Α |
|   |    |    |    |    |    | 16 | бит | ная | кон | стан | та |   |   |   |   |   |

#### Выполнение

pmad $\rightarrow$ PAR If (RC)  $\neq$  0

Then

(Smem) x (Pmem адресованный через PAR) + (src)  $\rightarrow$  src

 $(Smem) \rightarrow T$ 

(Smem) → Smem + 1

 $(PAR) + 1 \rightarrow PAR$ 

Else

(Smem) × (Pmem адресованный через PAR) + (src)  $\rightarrow$  src

 $(Smem) \rightarrow T$ 

 $(Smem) \rightarrow Smem + 1$ 

Статусные биты Описание Результат зависит от FRCT и OVM.

Команда влияет на OVsrc.

Данная команда умножает значение Smem на значение pmad, добавляет произведение к src, и сохраняет результат в src. Значение Smem копируется в T и в адрес, следующий за адресом Smem. При повторении этой команды, адрес памяти программ (в регистре адреса программ PAR) увеличивается на 1. Как только конвейер повторений начинает работу, команда становится одноцикловой.

Слова 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы 3 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Класс 23А.

Класс 23В.

Пример MACD \*AR3-, COEFFS, A

|            | Перед | д командо | рй   |        | Посл | іе команд | Ы    |
|------------|-------|-----------|------|--------|------|-----------|------|
| Α          | 00    | 0077      | 0000 | Α      | 00   | 007D      | 0B44 |
| т          |       |           | 8000 | т      |      |           | 0055 |
| FRCT       |       |           | 1    | FRCT   |      |           | 0    |
| AR3        |       |           | 0100 | AR3    |      |           | 00FF |
| Память про | грамм |           |      |        |      |           |      |
| COEFFS     |       |           | 1234 | COEFFS |      |           | 1234 |
| Память дан | ных   |           |      |        |      |           |      |
| 0100h      |       |           | 0055 | 0100h  |      |           | 0055 |
| 0101h      |       |           | 0066 | 0101h  |      |           | 0055 |

## 20.3.56 MACSU Xmem, Ymem, src

13

Операнды Xmem, Ymem: операнды памяти данных двойного доступа.

10

А (аккумулятор А). src:

В (аккумулятор В). 11

1 0 1 0 1 1 D X X X Χ 0

12

Выполнение unsigned(Xmem)  $\times$  signed(Ymem) + (src)  $\rightarrow$  src

 $(Xmem) \rightarrow T$ 

14

15

Статусные Результат изменяется под влиянием FRCT и OVM.

биты Команда влияет на OVsrc.

Описание Данная команда умножает значение без знака памяти данных Хтет на значение памяти данных Ymem со знаком, складывает произведение с src, и сохраняет результат в src. 16-разрядное значение Xmem без знака сохраняется в Т. Т обновляется значением Хтет без знака в фазе

чтения.

Данные, адресованные Xmem, передаются по шине D. Данные,

8

6

5

2

Υ

Υ

адресованные Ymem, передаются по шине С.

Слова 1 слово. Циклы 1 цикл. Классы Класс 7.

Код

операции

Пример MACSU \*AR4+, \*AR5+, A

|            | Перед | д командо | рй   |       | Посл | іе команд | ы    |
|------------|-------|-----------|------|-------|------|-----------|------|
| Α          | 00    | 0000      | 1000 | Α     | 00   | 09A0      | AA84 |
| т          |       |           | 8000 | т     |      |           | 8765 |
| FRCT       |       |           | 0    | FRCT  |      |           | 0    |
| AR4        |       |           | 0100 | AR4   |      |           | 0101 |
| AR5        |       |           | 0200 | AR5   |      |           | 0201 |
| Память дан | ных   |           |      |       |      |           |      |
| 0100h      |       |           | 8765 | 0100h |      |           | 5678 |
| 0200h      |       |           | 1234 | 0200h |      |           | 00AA |

#### 20.3.57 MAR Smem

Операнды

Код операции

| Smem: | операнд | памяти | данных | одиночного | достуг | ıa. |
|-------|---------|--------|--------|------------|--------|-----|
| imem: | операнд | памяти | данных | одиночного | досту  | Γ   |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 1  | 0  | 1  | 1  | 0 | 1 | ı | Α | Α | Α | Α | Α | Α | Α |

#### Выполнение

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

If compatibility is on (CMPT = 1), then:

If (ARx = AR0)

AR(ARP) is modified ARP is unchanged

Else

ARx is modified

 $x \rightarrow ARP$ 

Else compatibility is off (CMPT = 0)

ARx is modified ARP is unchanged

Статусные

Выполнение зависит от СМРТ.

биты

Команда влияет на ARP (если CMPT = 1).

Описание

Данная команда изменяет содержимое выбранного вспомогательного регистра (ARx) определенного по Smem. В режиме совместимости (CMPT = 1), данная команда изменяет содержание ARx и значение указателя вспомогательного регистра (ARP).

Если CMPT = 0, то вспомогательный регистр изменяется, а ARP - нет.

Слова 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 1.

Класс 2.

| Пример 1 | MAR *AR3 | 3+             |      |               |
|----------|----------|----------------|------|---------------|
|          |          | Перед командой |      | После команды |
|          | CMRT     | 0              | CMRT | 1             |
|          | ARP      | 0              | ARP  | 3             |
|          | AR3      | 0100           | AR3  | 0101          |
| Пример 2 | MAR *ARC | )_             |      |               |
|          |          | Перед командой |      | После команды |
|          | CMRT     | 1              | CMRT | 1             |
|          | ARP      | 4              | ARP  | 4             |
|          | AR4      | 0100           | AR4  | 00FF          |
| Пример 3 | MAR *AR3 | 3              |      |               |
|          |          | Перед командой |      | После команды |
|          | СМРТ     | 1              | CMPT | 1             |
|          | ARP      | 0              | ARP  | 3             |
|          | AR0      | 0008           | AR0  | 0008          |
|          | AR3      | 0100           | AR3  | 0100          |
| Пример 4 | MAR *+AF | 3              |      |               |
|          |          | Перед командой |      | После команды |
|          | CMRT     | 1              | CMRT | 1             |
|          | ARP      | 0              | ARP  | 3             |
|          | AR3      | 0100           | AR3  | 0101          |
| Пример 5 | MAR *AR3 | }_<br>-        |      |               |
|          |          | Перед командой |      | После команды |
|          | CMRT     | 1              | CMRT | 1             |
|          | ARP      | 0              | ARP  | 3             |
|          | AR3      | 0100           | AR3  | 00FF          |

#### 20.3.58 MAS[R]

1: MAS[R] Smem, src

2: MAS[R] Xmem, Ymem, src [, dst ]

Операнды Smem: операнд памяти данных одиночного доступа.

> Xmem, Ymem: операнды памяти данных двойного доступа.

А (аккумулятор А). src, dst:

В (аккумулятор В).

Код операции 1:

| 0 0 1 0 1 1 R S I A A A |   |   |   |   |   |   |   |   |   |   |   | <u> </u> |   |   |   | 1 |   |
|-------------------------|---|---|---|---|---|---|---|---|---|---|---|----------|---|---|---|---|---|
|                         | 0 | 0 | ) | 1 | 0 | 1 | 1 | R | S | I | Α | Α        | Α | Α | Α | Α | Α |

2:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 1  | 1  | 1  | R  | S | D | Х | Х | Χ | Х | Υ | Υ | Υ | Υ |

Выполнение

1: (src) - (Smem)  $\times$  (T)  $\rightarrow$  src

2: (src) - (Xmem)  $\times$  (Ymem)  $\rightarrow$  dst

 $(Xmem) \rightarrow T$ 

Статусные

Результат зависит от FRCT и OVM.

биты Описание Команда влияет на OVdst (или OVsrc, если dst = src).

Данная команда умножает операнд на содержание Т или перемножает два операнда, вычитает результат из src, если не установлен dst, и сохраняет результат в src или dst. Xmem загружается в T в фазе чтения. При использовании индекса R, эта команда округляет результат умножения и вычитания путем добавления 2<sup>15</sup> к результату и сбрасыванием значений битов 15-0 в 0.

Данные, адресованные Xmem, передаются по шине DB и данные,

адресованные Үтем. передаются по СВ.

Слова

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Синтаксис 1: Класс 3А. Классы

Синтаксис 1: Класс 3В. Синтаксис 2: Класс 7.

| Пример 1 | MAS *AR5   | +, A     |           |           |       |     |           |      |
|----------|------------|----------|-----------|-----------|-------|-----|-----------|------|
|          |            | Перед    | д командо | рй        |       | Пос | пе команд | ы    |
|          | Α          | 00       | 0000      | 1000      | Α     | FF  | FFB7      | 4000 |
|          | Т          |          |           | 0400      | Т     |     |           | 0400 |
|          | FRCT       |          |           | 0         | FRCT  |     |           | 0    |
|          | AR5        |          |           | 0100      | AR5   |     |           | 0101 |
|          | Память дан | ных      |           |           |       |     |           |      |
|          | 0100h      |          |           | 1234      | 0100h |     |           | 1234 |
| Пример 2 | MAS *AR5   | +, *AR6+ | , A, B    |           |       |     |           |      |
|          |            | Перед    | д командо | рй        |       | Пос | пе команд | ы    |
|          | Α          | 00       | 0000      | 1000      | Α     | 00  | 0000      | 1000 |
|          | В          | 00       | 0000      | 0004      | В     | FF  | F9DA      | 0FA0 |
|          | Т          |          |           | 8000      | Т     |     |           | 5678 |
|          | FRCT       |          |           | 1         | FRCT  |     |           | 1    |
|          | AR5        |          |           | 0100      | AR5   |     |           | 0101 |
|          | AR6        |          |           | 0200      | AR6   |     |           | 0201 |
|          | Память дан | ных      |           |           |       |     |           |      |
|          | 0100h      |          |           | 5678      | 0100h |     |           | 5678 |
|          | 0200h      |          |           | 1234      | 0200h |     |           | 1234 |
| Пример 3 | MASR *AR   | R5+, A   |           |           |       |     |           |      |
|          | ı          | Перед    | д командо | <b>ОЙ</b> |       | Пос | пе команд | ы    |
|          | Α          | 00       | 0000      | 1000      | Α     | FF  | FFB7      | 0000 |
|          | Т          |          |           | 0400      | Т     |     |           | 0400 |
|          | FRCT       |          |           | 0         | FRCT  |     |           | 0    |
|          | AR5        |          |           | 0100      | AR5   |     |           | 0101 |
|          | Память дан | ных      |           |           |       |     |           |      |
|          | 0100h      |          |           | 1234      | 0100h |     |           | 1234 |

Пример **4** MASR \*AR5+, \*AR6+, A, B

|            | Пере | д командо | рй   |       | Посл | те команд | Ы    |
|------------|------|-----------|------|-------|------|-----------|------|
| Α          | 00   | 0000      | 1000 | Α     | 00   | 0000      | 1000 |
| В          | 00   | 0000      | 0004 | В     | FF   | F9DA      | 0000 |
| т          |      |           | 8000 | Т     |      |           | 5678 |
| FRCT       |      |           | 1    | FRCT  |      |           | 1    |
| AR5        |      |           | 0100 | AR5   |      |           | 0101 |
| AR6        |      |           | 0200 | AR6   |      |           | 0201 |
| Память дан | ных  |           |      |       |      |           |      |
| 0100h      |      |           | 5678 | 0100h |      |           | 5678 |
| 0200h      |      |           | 1234 | 0200h |      |           | 1234 |

#### 20.3.59 MASA

1:

1: **MASA** Smem [, B ] 2: **MASA[R]** T, src [, dst ]

**Операнды** Smem: операнд памяти данных одиночного доступа.

A (аккумулятор A).

В (аккумулятор В).

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 1  | 1  | 0  | 0  | 1 | 1 | I | Α | Α | Α | Α | Α | Α | Α |

2: 15 14 13 12 10 11 1 1 1 1 0 1 S D 0 0 0 1 0 1 R

#### Выполнение

1: (B) - (Smem) × (A(32–16))  $\rightarrow$  B

 $(Smem) \rightarrow T$ 

2:  $(src) - (T) \times (A(32-16)) \rightarrow dst$ 

# Статусные **биты**

На результат влияет FRCT и OVM.

Команда влияет на OVdst (или OVsrc, если dst не указан) и OVB в синтаксисе 1.

#### Описание

Данная команда умножает старшую часть аккумулятора A (биты 32–16) на операнд Smem или на содержимое T, вычитает результат из аккумулятора B (синтаксис 1) или из src. Результат сохраняется в аккумуляторе B (синтаксис 1) или в dst или src, если не указан dst. T принимает значение Smem в фазе чтения.

При использовании индекса R в синтаксисе 2, данная команда округляет результат умножения на аккумулятор A и вычитания путем добавления  $2^{15}$  к результату и сбрасыванием значений битов 15–0.

Слова 1 слово. Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem. Циклы 1 цикл. Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem. Классы Синтаксис 1 Класс 3А. Синтаксис 1 Класс 3В. Синтаксис 2 Класс 1. MASA \*AR5+ Пример 1 Перед командой После команды Α 00 1234 0000 Α 00 1234 0000 В 00 0002 0000 В FF F9DB FFA0 Т 0400 Т 5678 **FRCT** 0 **FRCT** 1 0100 0101 AR5 AR5 Память данных 0100h 0100h 5678 5678 Пример 2 MASA T, B Перед командой После команды 0000 1234 0000 Α 00 1234 Α 00 В 0002 0000 В FF **FF66 B460** T 0444 T 0444 **FRCT** 1 **FRCT** Пример 3 MASA T, B

|      | Пере | ед командо | Й    |
|------|------|------------|------|
| Α    | 00   | 1234       | 0000 |
| В    | 00   | 0002       | 0000 |
| Т    |      |            | 0444 |
| FRCT |      |            | 1    |

|     | Пос | сле коман | ды   |
|-----|-----|-----------|------|
| Α   | 00  | 1234      | 0000 |
| В   | FF  | FF67      | 0000 |
| T   |     |           | 0444 |
| RCT |     |           | 1    |

## 20.3.60 MAX dst

**Операнды** dst: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | D | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |

**Выполнение** If (A > B)

Then

$$(A) \to dst$$

$$0 \to C$$

Else

Статусные

биты

Команда устанавливает С.

Описание Данная команда сравнивает содержание аккумуляторов и сохраняет максимальное значение в dst. Если максимальное значение

принадлежит аккумулятору А, то бит переноса, С, принимает значение

0; в противном случае принимает значение 1.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.Пример 1MAX A





## Пример 2 МАХ А

|     | Перед | д командо | рй   |
|-----|-------|-----------|------|
| Α _ | 00    | 0000      | 0055 |
| в   | 00    | 0000      | 1234 |
| с Г |       |           | 0    |

|   | Пос | пе командь | ıl   |
|---|-----|------------|------|
| Α | 00  | 0000       | 1234 |
| В | 00  | 0000       | 1234 |
| С |     |            | 1    |

#### 20.3.61 MIN dst

**Операнды** dst: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | D | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |

**Выполнение** If (A < B)

Then

$$\begin{array}{c} (A) \rightarrow dst \\ 0 \rightarrow C \end{array}$$

Else

$$(B) \rightarrow dst$$
  
1  $\rightarrow C$ 

Статусные

биты Описание Команда устанавливает С.

Данная команда сравнивает содержимое аккумуляторов и сохраняет минимальное значение в dst. Если минимальное значение принадлежит

аккумулятору А, то бит переноса, С, принимает значение 0; иначе-1.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.Пример 1MIN A

|   | Перед командой |     |
|---|----------------|-----|
| Α | FFCB           | -53 |
| В | FFF6           | -10 |
| С | 1              |     |



## Пример 2 MIN A

|   | Пере | ед команд | ЮЙ   |
|---|------|-----------|------|
| Α | 00   | 0000      | 1234 |
| В | 00   | 0000      | 1234 |
| С |      |           | 0    |

|   | Пос | ле команд | ļЫ   |
|---|-----|-----------|------|
| Α | 00  | 0000      | 1234 |
| В | 00  | 0000      | 1234 |
| С |     |           | 1    |

#### 20.3.62 MPY[R]

1: MPY[R] Smem, dst

2: MPY Xmem, Ymem, dst

3: MPY Smem, #lk, dst

4: **MPY** #lk, dst

Операнды

Smem: операнд памяти данных одиночного доступа.

Xmem, Ymem: операнды памяти данных двойного доступа.

 $\mathsf{dst}$ :  $\mathsf{A}$  (аккумулятор  $\mathsf{A}$ ).

В (аккумулятор В).

 $-32768 \le lk \le 32767$ 

## Код операции

1:

| 15 | 14  | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----|-----|----|----|----|----|-----|------|-----|------|----|---|---|---|---|---|
| 0  | 0   | 1  | 0  | 0  | 0  | R   | D    | ı   | Α    | Α  | Α | Α | Α | Α | Α |
| 2: |     |    |    |    |    |     |      |     |      |    |   |   |   |   |   |
| 15 | 14  | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1  | 0   | 1  | 0  | 0  | 1  | 0   | D    | х   | X    | X  | X | Υ | Υ | Y | Y |
| 3: |     |    |    |    |    |     |      |     |      |    |   |   |   |   |   |
| 15 | 14  | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 0  | 1   | 1  | 0  | 0  | 0  | 1   | D    | 1   | Α    | Α  | Α | A | A | A | Α |
|    |     |    |    |    | 16 | бит | гная | кон | стан | та |   |   |   |   |   |
| 4: |     |    |    |    |    |     |      |     |      |    |   |   |   |   |   |
| 45 | 4.4 | 40 | 40 | 44 | 40 | _   | •    | -   | _    | _  | 4 | _ | _ | 4 | • |

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|-----|------|-----|------|----|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0   | D    | 0   | 1    | 1  | 0 | 0 | 1 | 1 | 0 |
|    |    |    |    |    | 16 | бит | гная | кон | стан | та |   |   |   |   |   |

#### Выполнение

- 1:  $(T) \times (Smem) \rightarrow dst$
- 2:  $(Xmem) \times (Ymem) \rightarrow dst$

 $(Xmem) \rightarrow T$ 

3:  $(Smem) \times lk \rightarrow dst$ 

 $(Smem) \rightarrow T$ 

4:  $(T) \times lk \rightarrow dst$ 

# Статусные

Выполнение команды зависит от FRCT и OVM.

## биты Описание

Команда влияет на OVdst.

Данная команда умножает содержимое Т или значение памяти данных на значение памяти данных или на непосредственное значение, и сохраняет результат в dst. Т загружается значением Smem или Xmem в фазе чтения.

При использовании индекса R, данная команда округляет результат операции умножения путем добавления 2<sup>15</sup> к результату с последующим сбрасыванием битов 15–0.

#### Слова Синтаксисы 1 и 2: 1 слово. Синтаксисы 3 и 4: 2 слова. Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem. Синтаксисы 1 и 2: 1 цикл. Циклы Синтаксисы 3 и 4: 2 цикла. Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem. Классы Синтаксис 1: Класс 3А. Синтаксис 1: Класс 3В. Синтаксис 2: Класс 7. Синтаксис 3: Класс 6А. Синтаксис 3: Класс 6В. Синтаксис 4: Класс 2. Пример 1 MPY 13, A Перед командой После команды 00 0000 0036 0000 0054 Α Α Т 0036 T 0006 **FRCT FRCT** DP 800 DΡ 800 Память данных 040Dh 0007 040Dh 0007 Пример 2 MPY \*AR2-, \*AR4+0%, B; Перед командой После команды В 0020 FF **FFFF** FFE0 В 00 0000 **FRCT** 0 **FRCT** 0 0001 AR0 0001 AR0 AR2 01FF AR2 01FE AR4 0300 AR4 0301 Память данных 01FFh 01FFh 0010 0010 0300h 0002 0300h 0002 Пример 3 MPY #0FFFEh, A Перед командой После команды 00 1234 C000 Α 0000 Α **FFFF** Т 2000 Т 2000 **FRCT** 0 **FRCT** 0

**Пример 4** MPYR 0, В

|      | Пере | д командо | Й    |
|------|------|-----------|------|
| В    | FF   | FE00      | 0001 |
| Т    |      |           | 1234 |
| FRCT |      |           | 0    |
| DP   |      |           | 004  |
|      |      |           |      |

|      | П | осле к | оманды |      |
|------|---|--------|--------|------|
| В    | 0 | 0      | 0626   | 0000 |
| T    |   |        |        | 1234 |
| FRCT |   |        |        | 0    |
| DP   |   |        |        | 004  |

Память программ

| 0200h 5678 | 0200h |
|------------|-------|
|------------|-------|

| )200h | 5678 |
|-------|------|
|-------|------|

#### 20.3.63 MPYA

1: **MPYA** Smem 2: **MPYA** dst

Операнды Smem:

операнд памяти данных одиночного действия.

dst: A (аккумулятор A).

В (аккумулятор В).

Код операции 1:

2:

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|   | 0  | 0  | 1  | 1  | 0  | 0  | 0 | 1 | ı | Α | Α | Α | Α | Α | Α | Α |
| 2 | 2: |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | D | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 |

Выполнение

1:  $(Smem) \times (A(32-16)) \rightarrow B$ 

 $(\text{Smem}) \to T$ 

 $(T) \times (A(32-16)) \rightarrow dst$ 

Статусные биты Изменяется под влиянием FRCT и OVM. Влияет на OVdst (OVB в синтаксисе 1).

Описание

Данная команда умножает старшую часть аккумулятора A (биты 32–16)

на значение операнда Smem или на содерджимое T, и сохраняет результат в dst или аккумуляторе B. T обновляется в фазе чтения.

**Слова** 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Синтаксис 1: Класс 3А.

Синтаксис 1: Класс 3В. Синтаксис 2: Класс 1.

| Пример 1 | MPYA *   | AR2    |        |         |      |       |     |            |      |
|----------|----------|--------|--------|---------|------|-------|-----|------------|------|
|          |          |        | Пере   | д коман | дой  |       | Пос | сле команд | цы   |
|          | Α        |        | FF     | 8765    | 111  | 1 A   | FF  | 8765       | 1111 |
|          | В        |        | 00     | 0000    | 032  | В     | FF  | D743       | 6558 |
|          | т        |        |        |         | 123  | т     |     |            | 5678 |
|          | FRC      | т 🗀    |        |         | (    | FRCT  |     |            | 0    |
|          | AR       | 2      |        |         | 020  | AR2   |     |            | 0200 |
|          | Память , | данных |        |         |      |       |     |            |      |
|          | 0200     | 0h     |        |         | 567  | 0200h |     |            | 5678 |
| Пример 2 | MPYA E   | 3      |        |         |      | _     |     |            |      |
|          |          | П      | еред к | омандо  | Й    |       | Пос | ле команд  | Ы    |
|          | Α        | F      | F      | 8765    | 1111 | Α     | FF  | 8765       | 1111 |
|          | В        | 0      | 0      | 0000    | 0320 | В     | FF  | DF4D       | B2A3 |
|          | Т        |        |        |         | 4567 | Т     |     |            | 4567 |
|          | FRCT     |        |        |         | 0    | FRCT  |     |            | 0    |

## 20.3.64 MPYU Smem, dst

**Операнды** Smem: операнд памяти данных одиночного доступа.

dst: A (аккумулятор A).

В (аккумулятор В).

Код

операции 15 14 13 12 11 10 9 8 7 6 5 4

| операции   | 0     | 0     | 1     | 0    | 0    | 1   | 0    | D    | I | Α | Α | Α | Α | Α | A | Α |
|------------|-------|-------|-------|------|------|-----|------|------|---|---|---|---|---|---|---|---|
| Выполнение | uneid | npadi | (T) v | unci | anad | (Sm | 2m)_ | > 4e | t |   |   |   |   |   |   |   |

Выполнение Статусные unsigned(T) x unsigned(Smem)  $\rightarrow$  dst Результат зависит от FRCT и OVM.

биты Описание Команда влияет на OVdst.

Данная команда умножает содержимое Т как числа без знака на содержимое операнда Smem без знака, и сохраняет результат в dst. В данной команде умножитель действует как умножитель 17х17-бит со сброшенными самыми старшими битами обоих операндов. Эта команда особенно применяется для расчета произведений многократной точности, таких, как умножение 32-разрядных чисел и получением 64-

разрядного произведения.

Слова 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Класс 3А.

Класс 3В.

Пример MPYU \*AR0-, A

|            | Перед | выполнен | ием  |       | После | выполне | ния  |
|------------|-------|----------|------|-------|-------|---------|------|
| Α          | FF    | 8000     | 0000 | Α     | 00    | 3F80    | 0000 |
| Т          |       |          | 4000 | т     |       |         | 0400 |
| FRCT       |       |          | 0    | FRCT  |       |         | 0    |
| AR0        |       |          | 1000 | AR0   |       |         | 0FFF |
| Память дан | ных   |          |      |       |       |         |      |
| 1000h      |       |          | FE00 | 0100h |       |         | FE00 |

## 20.3.65 MVDD Xmem, Ymem

| Операнды | Xme | m, Yı | mem | : o | пера | нды | памя | яти д | анны | их де | войно | ого д | осту | па. |   |   |
|----------|-----|-------|-----|-----|------|-----|------|-------|------|-------|-------|-------|------|-----|---|---|
| Код      | 15  | 14    | 13  | 12  | 11   | 10  | 9    | 8     | 7    | 6     | 5     | 4     | 3    | 2   | 1 | 0 |
| операции | 1   | 1     | 1   | 0   | 0    | 1   | 0    | 1     | х    | X     | X     | X     | Υ    | Υ   | Υ | Υ |
|          |     |       |     |     |      |     |      |       |      |       |       |       |      |     |   |   |

**Выполнение** (Xmem) → Ymem **Статусные** Не используются.

биты

Описание Данная команда копирует содержание ячейки памяти данных,

адресованной операндом Xmem, в ячейку памяти данных,

адресованную операндом Ymem.

Слова1 слово.Циклы1 цикл.КлассыКласс 14.

Пример MVDD \*AR3+, \*AR5+

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| AR3        | 8000           | AR3   | 8001          |
| AR5        | 0200           | AR5   | 0201          |
| Память дан | ных            |       |               |
| 0200h      | ABCD           | 0200h | 1234          |
| 8000h      | 1234           | 8000h | 1234          |

## 20.3.66 MVDK Smem, dmad

**Операнды** Smem: операнд памяти данных одиночного доступа.

 $0 \le dmad \le 65535$ 

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|-----|------|-----|------|----|---|---|---|---|---|
| 0  | 1  | 1  | 1  | 0  | 0  | 0   | 1    | ı   | Α    | Α  | Α | Α | Α | Α | Α |
|    |    |    |    |    | 16 | бит | гная | кон | стан | та |   |   |   |   |   |

**Выполнение**  $(dmad) \rightarrow EAR$ 

If  $(RC) \neq 0$ 

Then

 $(\text{Smem}) \to \text{Dmem addressed by EAR}$ 

 $(EAR) + 1 \rightarrow EAR$ 

Else

(Smem) → Dmem addressed by EAR

**Статусные** Не используются.

биты

#### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

#### Описание

Данная команда копирует содержимое операнда Smem в ячейку памяти данных, адресованную 16-разрядным непосредственным значением dmad (адрес находится в EAB адресного регистра EAR). Данная команда может быть использована с командами одиночного повторения для перемещения последовательных слов в память данных (с применением косвенной адресации). Количество перемещаемых слов больше на единицу количества в счетчике повторений на начало выполнения команды. Как только конвейер повторений начинает работу, команда становится одноцикловой.

**Слова** 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы 2 цикла

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Классы** Класс 19A.

Класс 19В.

**Пример 1** MVDK 10, 8000h

|          |            | Перед командой |       | После команды |
|----------|------------|----------------|-------|---------------|
|          | DP         | 004            | DP    | 004           |
|          | Память дан | ных            |       |               |
|          | 020Ah      | 1234           | 020Ah | 1234          |
|          | 8000h      | ABCD           | 8000h | 1234          |
| Пример 2 | MVDK *AF   | R3-, 1000h     |       |               |
|          |            | Перед командой |       | После команды |
|          | AR3        | 01FF           | AR3   | 01FE          |
|          | Память дан | ных            |       |               |
|          | 1000h      | ABCD           | 1000h | 1234          |
|          | 01FFh      | 1234           | 01FFh | 1234          |

## 20.3.67 MVDM dmad, MMR

**Операнды** MMR: отображаемый в памяти регистр.

 $0 \le dmad \le 65535$ 

Код

операции

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|-----|------|-----|------|----|---|---|---|---|---|
|   | 0  | 1  | 1  | 1  | 0  | 0  | 1   | 0    | I   | Α    | Α  | Α | Α | Α | Α | Α |
|   |    |    |    |    |    | 16 | бит | гная | кон | стан | та |   |   |   |   |   |

Выполнение dma

 $dmad \rightarrow DAR$ If (RC)  $\neq 0$ 

Не используются.

Then

(Dmem addressed by DAR)  $\rightarrow$  MMR

 $(DAR) + 1 \rightarrow DAR$ 

Else

(Dmem addressed by DAR) → MMR

Статусные

биты

Описание

Данная команда копирует данные из ячеек памяти данных dmad (адрес

находится в адресном регистре DAR) в отображаемые в памяти регистры MMR. Значение ячейки памяти данных адресуется 16-разрядным непосредственным значением. Как только конвейер

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

Слова2 слова.Циклы2 цикла.КлассыКласс 19А.ПримерMVDM 300h, BK

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| ВК         | ABCD           | ВК    | 1234          |
| Память дан | ных            |       |               |
| 0300h      | 1234           | 0300h | 1234          |

## 20.3.68 MVDP Smem, pmad

|                   | •            |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|-------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------|--------------------------|-------|--------------|----------|-------|--------|------|---------|---------|--------|------|--------------|
| Операнды          | Sme<br>0 ≤ p |                                                                                                                                                                                                                                      | -      |             |                          | ги да | ННЫХ         | соди     | 1НОЧІ | ного , | дост | упа.    |         |        |      |              |
| Код<br>операции   | 15           | 14                                                                                                                                                                                                                                   | 13     | 12          | 11                       | 10    | 9            | 8        | 7     | 6      | 5    | 4       | 3       | 2      | 1    | 0_           |
| операции          | 0            | 1                                                                                                                                                                                                                                    | 1      | 1           | 1                        | 1     | 0            | 1        | ı     | Α      | Α    | Α       | Α       | Α      | Α    | Α            |
|                   |              |                                                                                                                                                                                                                                      |        |             |                          | 16    | бит          | ная      | кон   | стан   | та   |         |         |        |      |              |
| Выполнение        | pmad         |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   | If (R0       |                                                                                                                                                                                                                                      | )      |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   | men          | (Smem) → Pmem addressed by PAR (PAR) + 1 → PAR  Else (Smem) → Pmem addressed by PAR  Не используются.  Данная команда копирует 16-битное значение операнда Smem в ячейку памяти программ, адресованную 16-разрядным непосредственным |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   | Eloo         |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   | EISE         |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
| Статусные<br>биты | Не и         |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
| Описание          | Данн         |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   |              |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   |              | начением pmad. Данная команда может быть использована как овторяющаяся для перемещения последовательных слов памяти                                                                                                                  |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   | данн         | данных (с применением косвенной адресации) в непрерывное                                                                                                                                                                             |        |             |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   | прос<br>непо | •                                                                                                                                                                                                                                    |        |             | амя <sup>.</sup><br>м зі |       | прог<br>нием | •        |       | -      | -    | мое     |         | •      | •    | цным<br>а не |
|                   | обяз         | ател                                                                                                                                                                                                                                 | ьно    | дол         | ІЖНЫ                     | бы    | ть в         | встр     | эенн  | ыми    | ИЛ   | и ра    | аспол   | пагат  | гься | вне          |
|                   | •            |                                                                                                                                                                                                                                      |        | •           |                          |       |              |          |       |        |      | •       |         |        | •    | ания<br>анда |
|                   | стан         | овит                                                                                                                                                                                                                                 |        |             |                          |       | 201.0        | <b>P</b> | 2.00  |        |      | ,,,,,,, | , pu    |        | ,    | апда         |
| Слова             | 2 сло        |                                                                                                                                                                                                                                      | 4840.7 | <b>3050</b> | DIATI                    | 1 00  | 000 5        | inia ia  | юпог  | JI 200 |      | 4 1/00  | ·DOLIII | പ്പ    | прос | e a l llala  |
|                   | с длі        |                                                                                                                                                                                                                                      |        |             |                          |       |              |          |       |        |      |         |         |        | дрес | ации         |
| Циклы             | 4 цин        |                                                                                                                                                                                                                                      |        | 6-          |                          | 4     |              |          |       |        |      |         |         | _×_    |      |              |
|                   | с длі        |                                                                                                                                                                                                                                      | -      | -           |                          | -     |              | •        |       |        |      |         |         |        | дрес | ации         |
| Классы            | Клас         | c 20                                                                                                                                                                                                                                 | Α.     | •           |                          |       |              |          |       | . "    | •    |         |         |        |      |              |
| Пример            | Клас<br>MVD  | _                                                                                                                                                                                                                                    |        | ∩0h         |                          |       |              |          |       |        |      |         |         |        |      |              |
| Пришор            | WVD          | . 0,                                                                                                                                                                                                                                 | 0      |             | ед ко                    | мандо | й            |          |       |        |      |         | Посл    | е кома | анды |              |
|                   |              | DP                                                                                                                                                                                                                                   |        |             |                          |       | 00           | 4        |       |        | )P [ |         |         |        |      | 004          |
|                   | Памя         | ть пр                                                                                                                                                                                                                                | ограм  | IM          |                          |       |              |          |       |        |      |         |         |        |      |              |
|                   | 0            | 200h                                                                                                                                                                                                                                 |        |             |                          |       | 012          | 3        |       | 020    | 00h  |         |         |        |      | 0123         |
|                   | Памя         | іть да                                                                                                                                                                                                                               | нных   |             |                          |       |              |          |       |        | -    |         |         |        |      |              |

FE00h

FFFF

FE00h

0123

## 20.3.69 MVKD dmad, Smem

**Операнды** Smem: операнд памяти данных одиночного доступа.

 $0 \le dmad \le 65535$ 

Код операции

| 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0                   | 1  | 1  | 1  | 0  | 0  | 0 | 0 | ı | Α | Α | Α | Α | Α | Α | Α |
| 16 битная константа |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Выполнение

 $\text{dmad} \to \text{DAR}$ 

If  $(RC) \neq 0$ 

Then

(Dmem addressed by DAR)  $\rightarrow$  Smem (DAR) + 1  $\rightarrow$  DAR

 $(DAIX) + 1 \rightarrow$ 

Else

(Dmem addressed by DAR) → Smem

## Статусные биты Описание

Не используются.

Данная команда перемещает данные из одной ячейки памяти данных в другую ячейку памяти данных. Ячейка памяти данных источника адресована 16-разрядным непосредственным операндом dmad а перемещается в Smem. Данная команда может быть использована с командами повторения одиночной инструкции для перемещения последовательных слов в памяти данных (с применением косвенной адресации). Количество перемещаемых слов больше на единицу количества в счетчике повторений на начало выполнения команды. Как только конвейер повторений начинает работу, команда становится одноцикловой.

Слова

2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 19А.

Класс 19В.

Пример 1

MVKD 300h, 0

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| DP         | 004            | DP    | 004           |
| Память дан | ных            |       |               |
| 0200h      | ABCD           | 0200h | 1234          |
| 0300h      | 1234           | 0300h | 1234          |

#### Пример 2 MVKD 1000h, \*+AR5 Перед командой После команды AR5 01FF AR5 0200 Память данных 1000h 1234 1000h 1234 0200h **ABCD** 0200h 1234 20.3.70 MVMD MMR, dmad Операнды MMR: отображаемый в памяти регистр. $0 \le dmad \le 65535$ Код 14 13 12 10 9 7 6 5 11 8 4 3 2 1 0 операции 1 1 1 1 1 0 0 0 Ī Α Α Α Α Α Α Α 16 битная константа $dmad \rightarrow EAR$ Выполнение If $(RC) \neq 0$ Then (MMR) → Dmem addressed by EAR $(EAR) + 1 \rightarrow EAR$ Else (MMR) → Dmem addressed by EAR Статусные Не используются. биты Описание Данная команда перемещает данные из отображаемого в памяти регистра MMR в ячейку памяти данных. Адрес в памяти данных назначается 16-разрядным непосредственным значением dmad. Как только конвейер повторений начинает работу, команда становится одноцикловой. Слова 2 слова. Циклы 2 цикла. Классы Класс 19А. Пример MVMD AR7, 8000h Перед командой После команды 1234 1234 AR7 AR7

Память данных

8000h

**ABCD** 

8000h

1234

## 20.3.71 MVMM MMRx, MMRy

**Операнды** MMRx: AR0-AR7, SP

MMRy: AR0-AR7, SP

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | 0  | 1  | 1 | 1 | M | M | R | Χ | M | M | R | Υ |

| Регистр | MMRX/MMRY | Регистр | MMRX/MMRY |
|---------|-----------|---------|-----------|
| AR0     | 0000      | AR5     | 0101      |
| AR1     | 0001      | AR6     | 0110      |
| AR2     | 0010      | AR7     | 0111      |
| AR3     | 0011      | SP      | 1000      |
| AR4     | 0100      |         |           |

Выполнение Статусные  $(MMRx) \rightarrow MMRy$  Не используются.

биты Описание

Данная команда перемещает содержимое отображаемого в памяти регистра MMRx в регистр MMRy. Разрешены только девять операндов: AR0–AR7 и SP. Операция чтения из MMRx выполняется в фазе чтения (в отличии от прототипа, где указана фаза декодирования). Операция записи в MMRy выполняется в фазе записи (в отличии от прототипа, где указана фаза доступа).

Примечание – Данная команда не повторяемая.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.

Пример MVMM SP, AR1

|     | Перед командой |     | После команды |
|-----|----------------|-----|---------------|
| AR1 | 3EFF           | AR1 | 0200          |
| SP  | 0200           | SP  | 0200          |

## 20.3.72 MVPD pmad, Smem

| Операнды          |                                                              | nem: операнд памяти данных одиночного доступа.<br>≤ pmad ≤ 65 535 |                                                     |                                                   |                                                                |                                                   |                                                             |                                                  |                                                     |                                                                 |                                                       |                                                      |                                                    |                                                     |                                               |               |
|-------------------|--------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------|-----------------------------------------------|---------------|
| Код               | 15                                                           | 14                                                                | 13                                                  | 12                                                | 11                                                             | 10                                                | 9                                                           | 8                                                | 7                                                   | 6                                                               | 5                                                     | 4                                                    | 3                                                  | 2                                                   | 1                                             | 0             |
| операции          | 0                                                            | 1                                                                 | 1                                                   | 1                                                 | 1                                                              | 1                                                 | 0                                                           | 0                                                | ı                                                   | Α                                                               | Α                                                     | Α                                                    | Α                                                  | Α                                                   | Α                                             | Α             |
|                   |                                                              | 16 битная константа                                               |                                                     |                                                   |                                                                |                                                   |                                                             |                                                  |                                                     |                                                                 |                                                       |                                                      |                                                    |                                                     |                                               |               |
| Выполнение        | pmae<br>If (Re<br>Ther                                       | C) ≠ (<br>า                                                       | 0                                                   | addr                                              | ·esse                                                          | ed by                                             | ΡΔΕ                                                         | 2) →                                             | Sme                                                 | m                                                               |                                                       |                                                      |                                                    |                                                     |                                               |               |
|                   | Else                                                         | (Pmem addressed by PAR) → Smem<br>(PAR) + 1 → PAR<br>Else         |                                                     |                                                   |                                                                |                                                   |                                                             |                                                  |                                                     |                                                                 |                                                       |                                                      |                                                    |                                                     |                                               |               |
| Статусные<br>биты | Не и                                                         | •                                                                 |                                                     |                                                   |                                                                | ed by                                             | PAF                                                         | <) →                                             | Sme                                                 | m                                                               |                                                       |                                                      |                                                    |                                                     |                                               |               |
| Описание          | адре<br>Данн<br>кома<br>разр<br>непр<br>исто<br>расп<br>повт | есова<br>ная<br>яднь<br>эднь<br>еры<br>чник<br>олаг               | аннун<br>инст<br>для<br>ым<br>вное<br>а и п<br>атьс | о 16<br>рукц<br>пер<br>неп<br>прос<br>рием<br>я в | 6-раз<br>ия ме<br>емец<br>осре<br>стран<br>иник<br>вне<br>ерыв | врядниоже<br>цени<br>дств<br>нство<br>а не<br>кри | ным<br>т бі<br>я по<br>еннь<br>опам<br>обяз<br>стал<br>запр | неп<br>ыть<br>оследым<br>ияти ,<br>вател<br>пла. | юсре<br>испо<br>цоват<br>адре<br>данн<br>пьно<br>Пр | едств<br>ользо<br>гель<br>есом<br>ых, а<br>долх<br>и ।<br>Как т | венни<br>ована<br>ных<br>и п<br>адре<br>кны (<br>выпо | ым<br>слов<br>амят<br>сова<br>быть<br>элнен<br>о кон | знач<br>к по<br>ги<br>нное<br>встр<br>нии<br>нвейе | ение<br>рвтор<br>ресу<br>прог<br>Sme<br>соен<br>ком | ем р<br>ояюц<br>емы<br>рамг<br>рам. Е<br>нымг | локи<br>и или |
| Слова             | 2 сл                                                         | ова.                                                              |                                                     |                                                   |                                                                |                                                   |                                                             |                                                  |                                                     |                                                                 |                                                       |                                                      |                                                    | പ്രവ് ച                                             | прес                                          | าลเมผม        |

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem

Циклы 3 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Классы** Класс 21A.

Класс 21В.

**Пример 1** MVPD 0FE00h, 5

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| DP         | 006            | DP    | 006           |
| Память про | грамм          |       |               |
| FE00h      | 8A55           | FE00h | 8A55          |
| Память дан | ных            |       |               |
| 0305h      | FFFF           | 0305h | 8A55          |

## **Пример 2** MVPD 2000h, \*AR7–0

|                 | Перед командой |       | После команды |  |  |  |  |  |  |  |
|-----------------|----------------|-------|---------------|--|--|--|--|--|--|--|
| AR0             | 0002           | AR0   | 0002          |  |  |  |  |  |  |  |
| AR7             | 0FFE           | AR7   | 0FFC          |  |  |  |  |  |  |  |
| Память программ |                |       |               |  |  |  |  |  |  |  |
| 2000h           | 1234           | 2000h | 1234          |  |  |  |  |  |  |  |
| Память дан      | ных            |       |               |  |  |  |  |  |  |  |
| 0FFEh           | ABCD           | 0FFEh | 1234          |  |  |  |  |  |  |  |

## 20.3.73 NEG src [, dst ]

**Операнды** src, dst: A (аккумулятор A). B (аккумулятор B).

Код операции

15 14 13 12 11 10 7 5 2 0 6 1 1 1 1 0 1 S 1 0 0 0 0 1 0 0 D

Выполнение

(src) \*  $-1 \rightarrow dst$ 

**Статусные** Команда под влиянием OVM.

биты Описание Результат влияет на С и OVdst (или OVsrc, если dst = src).

Данная команда расчитывает дополнительный код (дополнение до двух) содержимого src (также A или B) и сохраняет результат в dst или src, если dst не указан. Данная команда сбрасывает значение бита переноса, C, для любых ненулевых значений аккумулятора. Если аккумулятор равен 0, значение бита переноса - 1. Если аккумулятор равен FF 8000 0000h, операция отрицания вызывает переполнение, поскольку дополнение до двух FF 8000 0000h превышает значения младших 32 битов аккумулятора. Если OVM = 1, значением dst назначается 00 7FFF FFFFh. Если OVM = 0, значением dst назначается 00 8000 0000h. Бит OV для dst устанавливается, чтобы информировать о переполнении в каждом случае.

Слова Циклы Классы Пример 1 1 слово. 1 цикл.

Класс 1. NEG A, B

| Α   | FF | FFFF | F228 |
|-----|----|------|------|
| В   | 00 | 0000 | 1234 |
| OVA |    |      |      |

| Α [   | FF | FFFF | F228 |
|-------|----|------|------|
| В     | 00 | 0000 | 0DD8 |
| ova 「 |    |      |      |

|          |          | <u> </u> |           |      | , , |      | •                |      |
|----------|----------|----------|-----------|------|-----|------|------------------|------|
| Пример 2 | NEG B, A | 4        |           |      |     |      |                  |      |
|          |          | Перед    | д команде | ой   |     | Посл | <b>пе команд</b> | ы    |
|          | Α [      | 00       | 0000      | 1234 | Α   | FF   | 8000             | 0000 |
|          | В        | 00       | 8000      | 0000 | В   | 00   | 8000             | 0000 |
|          | OVA      |          |           | 0    | OVA |      |                  | 0    |
| Пример 3 | NEG A    |          |           |      |     |      |                  |      |
|          |          | Пере     | д команд  | ой   |     | Посл | <b>пе команд</b> | ы    |
|          | Α [      | 80       | 0000      | 0000 | Α   | 80   | 8000             | 0000 |
|          | OVA      |          |           | 1    | OVA |      |                  | 1    |
|          | OVM      |          |           | 0    | OVM |      |                  | 0    |
| Пример 4 | NEG A    |          |           |      |     |      |                  |      |
|          |          | Пере     | д команд  | ой   |     | Посл | <b>пе команд</b> | ы    |
|          | Α [      | 80       | 0000      | 0000 | Α   | 00   | 7FFF             | FFFF |
|          | OVA      |          |           | 0    | OVA |      |                  | 1    |
|          | OVM      |          |           | 1    | OVM |      |                  | 1    |
|          |          |          |           |      |     |      |                  |      |
|          |          |          |           |      |     |      |                  |      |
| 20.3     | .74 NOP  |          |           |      |     |      |                  |      |
|          |          |          |           |      |     |      |                  |      |

| Операнды | Отсутствуют. |
|----------|--------------|
|----------|--------------|

Код операции

| 1 1 1

|   | 17 | 13 | 14 |   | 10 | <u> </u> | - |   | <u> </u> | <u> </u> |   | <u> </u> |   |   |   |
|---|----|----|----|---|----|----------|---|---|----------|----------|---|----------|---|---|---|
|   |    | 4  |    | ^ |    | ^        | ^ | 4 | ^        | ^        |   | ^        | 4 | ^ | _ |
| 1 | 1  | 1  | 1  | U | 1  | U        | U | 1 | U        | U        | 1 | U        | 1 | U | 1 |

**Выполнение** Отсутствует. **Статусные** Не используются.

биты

Описание

Пустая операция (нет действий). Увеличивается только РС. Это может

быть полезным при создании в конвейере задержек выполнения.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.ПримерNOP

Действия отсутствуют.

## 20.3.75 NORM src [, dst ]

Операнды

src, dst:

А (аккумулятор А).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | S | D | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |

Выполнение

 $(src) \ll TS \rightarrow dst$ 

Статусные

Выполнение изменяется под влиянием SXM и OVM.

биты Описание Команда влияет на OVdst (или OVsrc, когда dst = src).

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

Данная команда за один цикл нормализует значение аккумулятора одновременно с командой ЕХР, которая рассчитывает экспоненту этого числа. Значение сдвига определяется Т(5-0) и кодируется как знаковое число в дополнительном коде. Действующие значения сдвига – от 16 до 31. Для осуществления нормализации сдвигатель использует значение сдвига (в Т) в фазе выполнения; нормализация происходит в фазе выполнения.

Слова Циклы Классы Пример 1 1 слово. 1 цикл. Класс 1. **NORM A** 

NORM B, A

| перед командои |  |      |  |  |  |  |  |  |
|----------------|--|------|--|--|--|--|--|--|
| FF FFFF FC     |  |      |  |  |  |  |  |  |
|                |  |      |  |  |  |  |  |  |
|                |  | 0013 |  |  |  |  |  |  |

| После команды |    |      |      |  |  |  |  |  |
|---------------|----|------|------|--|--|--|--|--|
| Α             | FF | 8008 | 0000 |  |  |  |  |  |
| Т             |    |      | 0013 |  |  |  |  |  |

#### Пример 2

Перед командой

|   | пород командол |      |      |  |  |  |  |  |  |
|---|----------------|------|------|--|--|--|--|--|--|
| Α | FF             | FFFF | F001 |  |  |  |  |  |  |
| В | 21             | 0A0A | 0A0A |  |  |  |  |  |  |
| Т |                |      | 0FF9 |  |  |  |  |  |  |
|   |                |      |      |  |  |  |  |  |  |

|   | Пос | ле коман | ды   |
|---|-----|----------|------|
| Α | 00  | 4214     | 1414 |
| В | 21  | 0A0A     | 0A0A |
| Т |     |          | 0FF9 |

#### 20.3.76 OR

1: OR Smem, src

2: **OR** #lk [, SHFT], src [, dst]

3: **OR** #lk, 16, src [, dst ]

4: **OR** src [, SHIFT ], [, dst ]

#### Операнды

src, dst: A (аккумулятор A).

В (аккумулятор В).

Smem: Операнд памяти данных одиночного доступа.

 $0 \le SHFT \le 15$ -16 \le SHIFT \le 15  $0 \le lk \le 65535$ 

### Код операции

1:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 0  | 1  | 1  | 0  | 1 | S | I | Α | Α | Α | Α | Α | Α | Α |
|    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

2:

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|-----|------|-----|------|----|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | S   | D    | 0   | 1    | 0  | 0 | S | Н | F | Т |
|    |    |    |    |    | 16 | бит | гная | кон | стан | та |   |   |   |   |   |

3:

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|-----|-----|-----|------|----|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | S   | D   | 0   | 1    | 1  | 0 | 0 | 1 | 0 | 0 |
|    |    |    |    |    | 16 | бит | ная | кон | стан | та |   |   |   |   |   |

4:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | S | D | 1 | 0 | 1 | S | Н | ı | F | Т |

#### Выполнение

1: (Smem) OR (src(15-0))  $\rightarrow$  src

src(39-16) без изменений

2:  $lk \ll SHFT OR (src) \rightarrow dst$ 

3:  $k \ll 16 \text{ OR (src)} \rightarrow \text{dst}$ 

4: (src or [dst]) OR (src)  $\leq$  SHIFT  $\rightarrow$  dst

# Статусные биты Описание

Не используются.

Эта команда логического сложения ИЛИ (OR) между src и операндом памяти данных одиночного доступа Smem, непосредственным значением lk со сдвигом влево на 16 бит, dst или самим собой. Результат созраняется в dst или src, если dst не указан. По предписанию команды значения могут быть сдвинуты. При положительных сдвигах (влево) значения младших разрядов обнуляются, а значения старших разрядов не дополняются знаком. Для отрицательных сдвигах (вправо) значения старших разрядов не дополняются знаком.

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

Слова Синтаксисы 1 и 4: 1 слово.

Синтаксисы 2 и 3: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** Синтаксисы 1 и 4: 1 цикл.

Синтаксисы 2 и 3: 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы Синтаксис 1: Класс 3А.

Синтаксис 1: Класс 3В. Синтаксисы 2 и 3: Класс 2.

Синтаксис 4: Класс 1.

**Пример 1** OR \*AR3+, A

|     | Пере | ед команд | ой   |     | Посл | <b>те команд</b> | Ы  |
|-----|------|-----------|------|-----|------|------------------|----|
| Α   | 00   | 00FF      | 1200 | A   | 00   | 00FF             | 17 |
| AR3 |      |           | 0100 | AR3 |      |                  | 01 |

Память данных

| 0100h 1500 | 0100h | 1500 |
|------------|-------|------|
|------------|-------|------|

**Пример 2** OR A, +3, B

|   | Пере | д команд | рй   |   | Посл | те команд | ιы   |
|---|------|----------|------|---|------|-----------|------|
| Α | 00   | 0000     | 1200 | Α | 00   | 0000      | 1200 |
| В | 00   | 0000     | 1800 | В | 00   | 0000      | 9800 |

#### 20.3.77 ORM #lk, Smem

**Операнды** Smem: Операнд памяти данных одиночного доступа.

 $0 \le lk \le 65535$ 

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|-----|-----|-----|------|----|---|---|---|---|---|
| 0  | 1  | 1  | 0  | 1  | 0  | 0   | 1   | I   | Α    | Α  | Α | Α | Α | Α | Α |
|    |    |    |    |    | 16 | бит | ная | кон | стан | та |   |   |   |   |   |

Выполнение

Ik OR (Smem) → Smem

Статусные **биты** 

Не используются.

Описание

ие Эта команда логического поразрядного сложения ИЛИ (OR) между

операндом памяти данных одиночного доступа Smem и 16-разрядной константой lk, результат сохраняется в Smem. Данная команда

выполняет операцию типа память-память.

Примечание – Данная команда не повторяемая.

**Слова** 2 слова

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 2 цикла.

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 18А. Класс 18В.

Пример

ORM 0404h, \*AR4+

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| AR4        | 0100           | AR4   | 0101          |
| Память дан | ных            |       |               |
| 0100h      | 4444           | 0100h | 4444          |

### 20.3.78 POLY Smem

Операнды

Smem: операнд памяти данных одиночного доступа.

Код

операции

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|   | 0  | 0  | 1  | 1  | 0  | 1  | 1 | 0 | I | Α | Α | Α | Α | Α | Α | Α |

Выполнение

Round (A(32–16) x (T) + (B))  $\rightarrow$  A

 $(Smem) \ll 16 \rightarrow B$ 

Статусные

Выполнение изменяется под влиянием FRCT, OVM и SXM.

биты Описание Команда влияет на OVA.

Данная команда сдвигает содержимое операнда памяти данных одиночного доступа Smem на 16 бит влево и сохраняет результат в аккумуляторе В. Одновременно, эта команда умножает старшую часть аккумулятора А (биты 32-16) на содержание Т, складывает произведение с аккумулятором В, округляет результат операции, и сохраняет конечный результат в аккумуляторе А. Эта команда может быть полезна для вычисления полинома при осуществлении расчетов, затрачивая 1 цикл при расчете слагаемого полинома.

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 3А. Кпасс 3В

|        | TOTAGO OD.  |
|--------|-------------|
| Пример | POLY *AR3+% |

|            | Пере | д команд | ой   |       | Посл | іе команд | ы    |
|------------|------|----------|------|-------|------|-----------|------|
| Α          | 00   | 1234     | 0000 | Α     | 00   | 0627      | 0000 |
| В          | 00   | 0001     | 0000 | В     | 00   | 2000      | 0000 |
| Т          |      |          | 5678 | т     |      |           | 5678 |
| AR3        |      |          | 0200 | AR3   |      |           | 0201 |
| Память дан | ных  |          |      |       |      |           |      |
| 0200h      |      |          | 2000 | 0200h |      |           | 2000 |

#### 20.3.79 POPD Smem

**Операнды** Smem: операнд памяти данных одиночного доступа.

Код

15 14 13 12 11 10 7 2 операции 1 0 0 0 1 0 1 1 ī Α Α Α Α Α Α Α

**Выполнение**  $(TOS) \rightarrow Smem$ 

 $(SP) + 1 \rightarrow SP$ 

Статусные

Не используются.

биты

Описание Данная команда перемещает содержимое ячейки памяти данных,

адресуемое SP в ячейку памяти, определяемую Smem. SP

увеличивается на 1.

**Слова** 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Классы** Класс 17A.

Класс 17В.

**Пример** POPD 10

|    | Перед командой |    | После команды |
|----|----------------|----|---------------|
| DP | 008            | DP | 008           |
| SP | 0300           | SP | 0301          |

Память данных

| 0300h | 0092 | 0300h | 0092 |
|-------|------|-------|------|
| 040Ah | 0055 | 040Ah | 0092 |

#### 20.3.80 POPM MMR

Операнды

MMR: отображаемый в памяти регистр.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 0  | 1  | 0  | 1 | 0 | ı | Α | Α | Α | Α | Α | Α | Α |

Выполнение

 $(TOS) \rightarrow MMR$  $(SP) + 1 \rightarrow SP$ 

Статусные

Не используются.

биты

Описание

Данная команда перемещает содержимое ячейки памяти данных, адресуемое SP в определенный регистр MMR. SP инкрементируется.

Слова1 слово.Циклы1 цикл.КлассыКласс 17А.ПримерPOPM AR5

| Перед командой |     | После командь |
|----------------|-----|---------------|
| 0055           | AR5 |               |
| 03F0           | SP  |               |
|                |     |               |

Память данных

AR5

SP

03F0h 0060 03F0h 0060

### 20.3.81 PORTR PA, Smem

**Операнды** Smem: операнд памяти данных одиночного доступа.

 $0 \le PA \le 65535$ 

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7    | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|------|----|---|---|---|---|---|---|
| 0  | 1  | 1  | 1  | 0  | 1  | 0 | 0    | ı    | Α  | Α | Α | Α | Α | Α | Α |
|    |    |    |    |    |    | Α | дрес | порт | га |   |   |   |   |   |   |

Выполнение Статусные  $(PA) \rightarrow Smem$  Не используются.

биты

Описание

Данная команда считывает 16-разрядное значение с внешнего порта ввода-вывода РА (16-разрядный непосредственный адрес) в ячейку памяти данных определяемую Smem. Сигнал IS устанавливается в состояние низкого потенциала для индикации доступа по вводу-выводу, временные соотношения IOSTRB и READY такие же, как при чтении внешней памяти данных.

Слова

2 спова.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

2 цикла (зависит от внешней операции ввода-вывода)

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

0060

03F1

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Классы                          | Класс                                 |                       |                             |                           |                      |                        |                       |                     |                     |                                     |                            |                       |                      |                      |                       |                          |
|---------------------------------|---------------------------------------|-----------------------|-----------------------------|---------------------------|----------------------|------------------------|-----------------------|---------------------|---------------------|-------------------------------------|----------------------------|-----------------------|----------------------|----------------------|-----------------------|--------------------------|
| Примор                          | Класс<br>PORT                         |                       |                             | דעחו                      | r · INI              | DAT                    | OGLI                  | 60h                 |                     |                                     |                            |                       |                      |                      |                       |                          |
| Пример                          | PORT                                  | N U                   | , ווי                       |                           |                      |                        | •                     | OUII                |                     |                                     |                            |                       | П                    |                      |                       |                          |
|                                 |                                       | <b>D</b> D            |                             | riep                      | ред ко               | мандо                  |                       | 7                   |                     | -                                   | ,                          |                       | ПОСЛ                 | е ком                | анды                  |                          |
|                                 |                                       | DP                    |                             |                           |                      |                        | 000                   | <u>'</u>            |                     | L                                   | )P                         |                       |                      |                      |                       | 000                      |
|                                 | Памят                                 | Память ввода-вывода   |                             |                           |                      |                        |                       |                     |                     |                                     |                            |                       |                      |                      |                       |                          |
|                                 | 00                                    | 005h                  |                             |                           |                      |                        | 7FF                   |                     |                     | 00                                  | 05h                        |                       |                      |                      |                       | 7FFA                     |
|                                 | Памят                                 | ь дан                 | ІНЫХ                        |                           |                      |                        |                       |                     |                     |                                     |                            |                       |                      |                      |                       |                          |
|                                 | 00                                    | )60h                  |                             |                           |                      |                        | 000                   | )                   |                     | 00                                  | 60h                        |                       |                      |                      |                       | 7FFA                     |
|                                 | 2 POR                                 |                       |                             | ·                         |                      | TI4 FIG                | N. III II IN          | , O.D.              | 411011              | 11050                               | поот                       | ZVEO.                 |                      |                      |                       |                          |
| Операнды                        | Smem<br>0 ≤ PA                        |                       | •                           |                           | іамя                 | ти да                  | инных                 | СОДИ                | 1НОЧ                | ного                                | дост                       | yna.                  |                      |                      |                       |                          |
| Код                             |                                       | 14                    | 13                          | 12                        | 11                   | 10                     | 9                     | 8                   | 7                   | 6                                   | 5                          | 4                     | 3                    | 2                    | 1                     | 0                        |
| операции                        |                                       |                       |                             |                           |                      |                        |                       |                     |                     |                                     |                            | -                     |                      |                      |                       |                          |
|                                 | 0                                     | 1                     | 1                           | 1                         | 0                    | 1                      | 0                     | 1                   | l                   | Α                                   | Α                          | Α                     | Α                    | Α                    | Α                     | Α                        |
|                                 |                                       |                       |                             |                           |                      |                        | A,                    | дрес                | пор                 | та                                  |                            |                       |                      |                      |                       |                          |
| Выполнение<br>Статусные<br>биты | (Smen<br>He исі                       | ,                     |                             |                           |                      |                        |                       |                     |                     |                                     |                            |                       |                      |                      |                       |                          |
| Описание                        | Данна даннь по ад потеню соотно памят | оше<br>циал           | іред<br>;у Г<br>па д<br>ния | целе<br>PA.<br>для<br>IOS | ннук<br>Сигі<br>отоб | о знач<br>нал<br>браже | чение<br>IS у<br>ения | ем S<br>стан<br>дос | mem<br>навл<br>тупа | п во в<br>ивае <sup>-</sup><br>а по | неш<br>тся<br>вво <i>р</i> | ний г<br>в с<br>цу-вь | порт<br>осто<br>ывод | ввод<br>яниє<br>у, в | ца-вь<br>е ни<br>реме | ывода<br>ізкого<br>енныє |
| Слова                           | 2 слов<br>Необх                       | оди                   | -                           | -                         |                      |                        |                       | •                   |                     |                                     |                            |                       |                      |                      | ідрес                 | сации                    |
| Циклы                           | с длин<br>2 цикл<br>Необх<br>с длин   | та (з<br>коди<br>нныг | ави<br>мо ,<br>и см         | сит (<br>доба             | от вн<br>авить       | нешне<br>ь 1 ці        | ей оп<br>икл п        | ераі<br>ри и        | спол<br>Дии і       | ввода<br>1ьзов                      | а-вы<br>аниі               | вода<br>и кос         | ).<br>венн           | юй а                 | ідрес                 | сации                    |
| Классы                          | Класс<br>Класс                        |                       |                             |                           |                      |                        |                       |                     |                     |                                     |                            |                       |                      |                      |                       |                          |
| Пример                          | PORT                                  |                       |                             | DAT                       | , 5h ;               | ; OUT                  | ΓDΑΤ                  | .equ                | ı 07h               | า                                   |                            |                       |                      |                      |                       |                          |
|                                 |                                       |                       |                             | Пер                       | ед ко                | мандо                  | рй                    |                     |                     |                                     |                            |                       | Посл                 | е ком                | анды                  |                          |
|                                 | I                                     | DP                    |                             |                           |                      |                        | 00                    | ī                   |                     | 0                                   | )P                         |                       |                      |                      |                       | 001                      |
|                                 | Памят                                 | ь вво                 | да-в                        | ывод                      | ıa                   |                        |                       | _                   |                     |                                     |                            |                       |                      |                      |                       |                          |
|                                 | 00                                    | )05h                  |                             |                           |                      |                        | 000                   | <u> </u>            |                     | 00                                  | 05h                        |                       |                      |                      |                       | 7FFA                     |
|                                 | Памят                                 |                       | ∟<br>Іных                   |                           |                      |                        |                       |                     |                     |                                     | ا "۔۔۔                     |                       |                      |                      |                       |                          |
|                                 |                                       | )87h                  |                             |                           |                      |                        | 7FF                   |                     |                     | nn                                  | 87h                        |                       |                      |                      |                       | 7FFA                     |
|                                 | 00                                    | ,0111                 | L                           |                           |                      |                        | 7117                  |                     |                     | 00                                  | ٠, ,,                      |                       |                      |                      |                       |                          |

#### 20.3.83 PSHD Smem

**Операнды** Smem: операнд памяти данных одиночного доступа.

Код

15 13 12 11 10 2 операции 0 1 0 0 1 0 1 1 ī Α Α Α Α Α Α Α

**Выполнение** (SP) -  $1 \rightarrow SP$ 

 $(Smem) \rightarrow TOS$ 

Статусные

Не используются.

биты Описание

После уменьшения SP на 1, данная команда сохраняет содержание ячейки памяти Smem в ячейку памяти данных, адресованную SP. Чтение SP осуществляется во время фазы чтения (в прототипе – декодирования); сохранение происходит во время фазы записи (в

прототипе – доступа).

**Слова** 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Классы** Класс 16A.

Класс 16В.

Пример PSHD \*AR3+

|            | Перед командой |       | После команды |  |  |  |  |  |  |  |  |
|------------|----------------|-------|---------------|--|--|--|--|--|--|--|--|
| AR3        | 0200           | AR3   | 0201          |  |  |  |  |  |  |  |  |
| SP         | 8000           | SP    | 7FFF          |  |  |  |  |  |  |  |  |
| Память дан | Память данных  |       |               |  |  |  |  |  |  |  |  |
| 0200h      | 07FF           | 0200h | 07FF          |  |  |  |  |  |  |  |  |
| 7FFFh      | 0092           | 7FFFh | 07FF          |  |  |  |  |  |  |  |  |

#### 20.3.84 PSHM MMR

Операнды

MMR: отображаемый в памяти регистр.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 0  | 1 | 0 | ı | Α | Α | Α | Α | Α | Α | Α |

Выполнение

 $(SP) - 1 \rightarrow SP$  $(MMR) \rightarrow TOS$ 

Статусные

Не используются.

биты

Описание

После уменьшения SP на 1, данная команда сохраняет содержимое

регистра MMR в ячейке памяти данных, адресованной SP.

Слова1 слово.Циклы1 цикл.КлассыКласс 16A.ПримерPSHM BRC

|     | Перед командой |
|-----|----------------|
| BRC | 1234           |
| SP  | 2000           |

После команды
BRC 1234
SP 1FFF

Память данных

1FFFh 07FF

1FFFh 1234

### 20.3.85 RC[D] cond [, cond [, cond ] ]

Операнды

В таблице перечислены условия (операнд условий) для данной команды.

| Операнд<br>условий | Описание     | Код<br>условия | Операнд<br>условий | Описание     | Код<br>условия |
|--------------------|--------------|----------------|--------------------|--------------|----------------|
| BIO                | DIO.         | 0000 0011      | NBIO               | DIO          | 0000 0010      |
|                    | BIO Low      |                |                    | BIO high     |                |
| С                  | C=1          | 0000 1100      | С                  | C=0          | 0000 1000      |
| TC                 | TC=1         | 0011 0000      | TC                 | TC=0         | 0010 0000      |
| AEQ                | (A) = 0      | 0100 0101      | BEQ                | (B) = 0      | 0100 1101      |
| ANEQ               | $(A) \neq 0$ | 0100 0100      | BNEQ               | (B) ≠ 0      | 0100 1100      |
| AGT                | (A) > 0      | 0100 0110      | BGT                | (B) > 0      | 0100 1110      |
| AGEQ               | $(A) \geq 0$ | 0100 0010      | BGEQ               | (B) ≥ 0      | 0100 1010      |
| ALT                | (A) < 0      | 0100 0011      | BLT                | (B) < 0      | 0100 1011      |
| ALEQ               | (A) ≤ 0      | 0100 0111      | BLEQ               | (B) ≤ 0      | 0100 1111      |
| AOV                | Α            | 0111 0000      | BOV                | В            | 0111 1000      |
|                    | переполнение |                |                    | переполнение |                |
| ANOV               | А отсутствие | 0110 0000      | BNOV               | В отсутствие | 0110 1000      |
|                    | переполнения |                |                    | переполнения |                |
| UNC                | Безусловный  | 0000 0000      |                    | ,            |                |
|                    |              | •              | •                  | ·            |                |

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 1  | 1  | Z | 0 | С | С | С | С | С | С | С | С |

Выполнение

If (cond(s))

Then

$$(TOS) \rightarrow PC$$
  
 $(SP) + 1 \rightarrow SP$ 

Else

$$(PC) + 1 \rightarrow PC$$

#### Статусные биты

Не используются.

#### Описание

При выполнении условия, заданного операндом условия, эта команда заменяет значение PC значением памяти данных из TOS и увеличивает SP на 1. Если условие не выполняется, то команда просто увеличивает PC на 1.

При задержанной команде возврата (определяется по наличию индекса D), две однословные команды или одна двухсловная команда, следующие за командой перехода, извлекаются из памяти программ и выполняются.

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

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

- 1. Группа 1. Можно выбрать не более двух условий. Каждое условие должно принадлежать разной категории (категория А или В); нельзя выбрать два условия из одной категории. Например, можно осуществлять проверку EQ и OV одновременно, но нельзя осуществлять проверку GT и NEQ в одно и то же время. Аккумулятор должен быть одним для обоих условий; нельзя одной командой осуществлять проверку условий для двух аккумуляторов. Например, можно осуществлять проверку AGT и AOV одновременно, но нельзя осуществлять проверку AGT и BOV в одно и то же время.
- 2. **Группа 2.** Можно выбрать не более трех условий. Каждое из этих условий должно быть из разных категорий (категория A, B или C); нельзя выбирать два условия из одной категории. Например, можно осуществлять проверку TC, C и BIO одновременно, но нельзя осуществлять проверку NTC, C и NC в одно и то же время.

Условия для данной команды

| Груп        | па 1        |             | Группа 2    |             |  |  |  |  |  |  |
|-------------|-------------|-------------|-------------|-------------|--|--|--|--|--|--|
| Категория А | Категория В | Категория А | Категория В | Категория С |  |  |  |  |  |  |
| EQ          | OV          | TC          | С           | BIO         |  |  |  |  |  |  |
| NEQ         | NOV         | NTC         | NC          | NBIO        |  |  |  |  |  |  |
| LT          |             |             |             |             |  |  |  |  |  |  |
| LEQ         |             |             |             |             |  |  |  |  |  |  |
| GT          |             |             |             |             |  |  |  |  |  |  |
| GEO         |             |             |             |             |  |  |  |  |  |  |

Примечание – Данная команда не повторяемая.

Слова Циклы 1 слово.

5 циклов (истинное условие).

3 цикла (ложное условие). 3 цикла (с задержкой).

### Классы Пример

Класс 32.

RC AGEQ, ANOV ; возврат осуществляется если содержание

; аккумулятора А положительно и значение бита OVA

; равно нулю



#### 20.3.86 READA Smem

Операнды

Код операции Smem: операнд памяти данных одиночного доступа.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 1  | 1  | 1  | 1  | 1 | 0 | ı | Α | Α | Α | Α | Α | Α | Α |

#### Выполнение

$$\mathsf{A} \to \mathsf{PAR}$$

If  $((RC) \neq 0)$ 

(Pmem (addressed by PAR))  $\rightarrow$  Smem

 $(PAR) + 1 \rightarrow PAR$ 

 $(RC) - 1 \rightarrow RC$ 

Else

(Pmem (addressed by PAR)) → Smem

# Статусные биты Описание

Не используются.

Команда перемещает слово из ячейки памяти программ, адресуемой аккумулятором А в ячейку памяти данных, определенную Smem. Как только конвейер повторений начинает работу, команда становится одноцикловой. Для адресации ячейки памяти программ используется аккумулятор A(15-0).

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

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

5 циклов.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 25А.

Класс 25В.

### Пример

**READA 6** 

|            | Перед | д командо | Й    |       | Ы  |      |      |
|------------|-------|-----------|------|-------|----|------|------|
| Α          | 00    | 0000      | 0023 | Α     | 00 | 0000 | 0023 |
| DP         |       |           | 004  | DP    |    |      | 004  |
| Память про | грамм |           |      |       |    |      |      |
| 0023h      |       |           | 0306 | 0023h |    |      | 0306 |
| Память дан | ных   |           |      |       |    |      |      |
| 0206h      |       |           | 0075 | 0206h |    |      | 0306 |

#### 20.3.87 RESET

Операнды

Отсутствуют.

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 |

#### Выполнение

В эти поля PMST, ST0 и ST1 загружаются указанные значения:

| (IPTR) << 7 _ PC           | $0 \rightarrow OVA$  | $0 \rightarrow OVB$  |
|----------------------------|----------------------|----------------------|
| $1 \rightarrow C$          | 1→ TC                | $0 \rightarrow ARP$  |
| $0 \rightarrow DP$         | $1 \rightarrow SXM$  | $0 \rightarrow ASM$  |
| $0 \rightarrow BRAF$       | $0 \rightarrow HM$   | $1 \rightarrow XF$   |
| $0 \rightarrow C16$        | $0 \rightarrow FRCT$ | $0 \rightarrow CMPT$ |
| $0 \rightarrow CPL$        | $1 \rightarrow INTM$ | $0 \rightarrow IFR$  |
| $0 \rightarrow \text{OVM}$ |                      |                      |

# Статусные биты Описание

Изменение статусных бит представлено в разделе выполнения.

Данная команда представляет собой немаскируемый программный сброс, который может быть испрльзован в любое время для помещения микросхемы в известное состояние. Когда команда сброса выполнена, возникают операции, указанные в разделе Выполнение. Вывод МР/МС не фиксируется во время программного сброса. Инициализация IPTR и периферийных регистров отличается от инициализации с использованием контактной площадки RS. Данная команда не зависит от INTM; напротив, она устанавливает в INTM значение 1 с целью запрета прерываний.

Примечание – Данная команда не повторяемая.

Слова1 слово.Циклы3 цикла.КлассыКласс 35.ПримерRESET

|        | Перед командой |      | После команды |
|--------|----------------|------|---------------|
| PC     | 0025           | PC   | 0080          |
| INTM [ | 0              | INTM | 1             |
| IPTR [ | 1              | IPTR | 1             |

20.3.88 RET[D]

Операнды Отсутствуют.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 1  | 1  | Z | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Выполнение**  $(TOS) \rightarrow PC$ 

 $(SP) + 1 \rightarrow SP$ 

Статусные

Не используются.

биты

Описание

Данная команда заменяет значение PC 16-разрядным значением из TOS. SP увеличивается на 1. Если возврат задержанный (определяется по наличию индекса D), то две однословные команды или одна двухсловная, следующие за командой перехода, извлекаются из памяти программ и выполняются.

Примечание – Данная команда не повторяемая.

**Слова** 1 слово. **Циклы** 5 циклов.

3 цикла (задержанная).

**Классы** Класс 32. **Пример** RET

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| PC         | 2112           | PC    | 1000          |
| SP         | 0300           | SP    | 0301          |
| Память дан | ных            |       |               |
| 0300h      | 1000           | 0300h | 1000          |

### 20.3.89 RETE[D]

Операнды

Отсутствуют.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | Z | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |

Выполнение

 $(TOS) \rightarrow PC$  $(SP) + 1 \rightarrow SP$  $0 \rightarrow INTM$ 

Статусные биты

Влияет на INTM.

Описание

Данная команда заменяет значение РС 16-разрядным значением из TOS. Выполнение продолжается с этого адреса. SP увеличивается на 1. Данная команда автоматически сбрасывает маску прерывания (INTM) в ST1. (сбрасывание этого бита разрешает прерывания.) Если возврат (определяется по наличию задержанный индекса D), то две однословные команды или одна двухсловная, следующие за командой перехода, извлекаются из памяти программ и выполняются.

Примечание – Данная команда не повторяемая.

Слова Циклы 1 слово. 5 циклов.

3 цикла (задержанная).

Классы Пример Класс 32.

**RETE** 

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| PC         | 01C3           | PC    | 0110          |
| SP         | 2001           | SP    | 2002          |
| ST1        | хСхх           | ST1   | x4xx          |
| Память дан | ных            |       |               |
| 2001h      | 0110           | 2001h | 0110          |

### 20.3.90 RETF[D]

Операнды

Отсутствуют.

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | Z | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 1 |

Выполнение

 $(RTN) \rightarrow PC$   $(SP) + 1 \rightarrow SP$  $0 \rightarrow INTM$ 

Статусные

Влияет на INTM.

биты Описание

В прототипе данная команда заменяет значение PC 16-разрядным значением в RTN. RTN содержит информацию об адресе, в котором должна осуществить возврат программа управления прерываниями. RTN загружается в PC во время возврата вместо чтения PC из стека. В процессоре реализация данной команды не отличается от реализации команды RETE.

Примечание – Данная команда не повторяемая.

Слова Циклы 1 слово. 3 цикла.

1 цикл (задержанная).

Классы

Класс 33.

Пример RETF

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| PC         | 01C3           | PC    | 0110          |
| SP         | 2001           | SP    | 2002          |
| ST1        | хСхх           | ST1   | x4xx          |
| Память дан | ных            |       |               |
| 2001h      | 0110           | 2001h | 0110          |

### 20.3.91 RND src [, dst ]

Операнды

src , dst: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | S | D | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 |

Выполнение

 $(src) + 8000h \rightarrow dst$ 

Статусные

Исполнение зависит от OVM.

биты

Описание

Данная команда округляет содержимое src (A или B) добавлением 2<sup>15</sup>. Округленное значение сохраняется в dst или src, если dst не указан.

Примечание – Данная команда не повторяемая, она не реализована в прототипе и потому её нет и в процессоре. Наличие её кода в потоке команд воспринимается как холостая инструкция NOP.

#### 20.3.92 ROL src

Операнды

src: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|   | 1  | 1  | 1  | 1  | 0  | 1  | 0 | S | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |

Выполнение

 $(C) \rightarrow src(0)$ 

 $(\operatorname{src}(30-0)) \to \operatorname{src}(31-1)$ 

 $(\operatorname{src}(31)) \to C$ 

 $0 \rightarrow src(39-32)$ 

Статусные

Результат выполнения зависит от С.

биты

Инструкция влияет на С.

Описание

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

1 слово. 1 цикл.

Классы Пример

Слова Циклы

> Класс 1. ROLA

| NOL A |      |             |
|-------|------|-------------|
|       | Пере | ед командой |
| Α     | 5F   | B000        |

|   | Посл | пе команд | Ы    |
|---|------|-----------|------|
| Α | 00   | 6000      | 2468 |
| С |      |           | 1    |

1234

#### 20.3.93 ROLTC src

**Операнды** src: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | S | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |

**Выполнение**  $(TC) \rightarrow src(0)$ 

 $(src(30-0)) \rightarrow src(31-1)$ 

 $(src(31)) \rightarrow C$  $0 \rightarrow src(39-32)$ 

**Статусные** Команда изменяет бит С. **биты** Результат зависит от ТС.

**Описание** Данная команда циклически сдвигает каждый бит src влево на 1 бит.

Значение бита TC бывшее до выполнения этой команды сдвигается в самый младший разряд src. Затем самый старший разряды src

сдвигается в С. Значения защитных бит src сбрасываются.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.ПримерROLTC A

|    | Пере | д командо | рй   |
|----|------|-----------|------|
| Α  | 81   | C000      | 5555 |
| С  |      |           | х    |
| TC |      |           | 1    |

|    | Посл | пе команд | ды   |
|----|------|-----------|------|
| Α  | 00   | 8000      | AAAB |
| С  |      |           | 1    |
| тс |      |           | 1    |

### 20.3.94 ROR src

Операнды src: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | S | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |

**Выполнение**  $(C) \rightarrow src(31)$ 

 $(src(31-1)) \rightarrow src(30-0)$ 

 $(src(0)) \rightarrow C$  $0 \rightarrow src(39-32)$ 

Статусные Команда влияет на значение С.

биты Результат зависит от прежнего значения С.

Описание Данная команда циклически сдвигает каждый бит src вправо на 1 бит. Значение бита переноса С, бывшее до выполнения этой команды

значение бита переноса С, бывшее до выполнения этои команды сдвигается в самый старший разряд src. Затем самый младший разряд

src сдвигается в С. Значения защитных бит src сбрасываются.

Слова1 слово.Циклы1 цикл.

Α

C

Классы Пример Класс 1. ROR A

Перед командой

| 7F | B000 | 1235 |
|----|------|------|
|    |      | 0    |

После команды

| 00 | 5800     | 091A |
|----|----------|------|
|    | <u> </u> | 1    |

#### 20.3.95 RPT

1: **RPT** Smem 2: **RPT** #K 3: **RPT** #lk

Операнды

Smem: операнд памяти данных одиночного доступа.

 $0 \le K \le 255$ 

 $0 \le lk \le 65535$ 

Код операции 1:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 0  | 1  | 1 | 1 | ı | Α | Α | Α | Α | A | Α | Α |
| 2: |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 1  | 1  | 0 | 0 | κ | K | K | K | K | K | K | κ |
| 3: |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

16 битная константа

| _   |     |    |     |
|-----|-----|----|-----|
| Выг | 10Л | не | ние |

e 1: (Smem)  $\rightarrow$  RC

2:  $K \rightarrow RC$ 

3:  $lk \rightarrow RC$ 

Статусные биты Описание Не используются.

В счетчик повторений (RC) загружается число интераций выполнения команды. Число итераций (n) задается в 16-разрядном операнде памяти данных Smem или 8 или 16-ти разрядной константой, К или lk, соответственно. Команда, следующая за повторяющейся командой, выполняется n + 1 раз. Доступ к RC отсутствует во время его декрементирования.

Примечание - Сама данная команда не повторяемая.

Слова

Синтаксисы 1 и 2: 1 слово.

Синтаксис 3: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Циклы    | Синтаксис<br>Синтаксис<br>Необходим<br>с длинным | 3: 2 цикла.<br>ио добавить 1 ц<br>смещением илі | •          |            |       | и косвенной адрес<br>ции с Smem. | сации |
|----------|--------------------------------------------------|-------------------------------------------------|------------|------------|-------|----------------------------------|-------|
| Классы   |                                                  | 1: Класс 5A.                                    |            |            |       |                                  |       |
|          |                                                  | 1: Класс 5B.<br>2: Класс 1.                     |            |            |       |                                  |       |
|          |                                                  | 3: Класс 2.                                     |            |            |       |                                  |       |
| Пример 1 | _                                                | 27 ; DAT127 .EQ                                 | U 0FFF     |            |       |                                  |       |
|          |                                                  | Перед командо                                   | ой         |            |       | После команды                    |       |
|          | RC                                               |                                                 | 0          | R          | C     |                                  | 000C  |
|          | DP                                               |                                                 | 031        | D          | P     |                                  | 031   |
|          | Память дан                                       | ных                                             | _          |            |       |                                  |       |
|          | 0FFFh                                            |                                                 | 000C       | 0FI        | FFh   |                                  | 000C  |
| Пример 2 | RPT #2 ; Γ                                       | Товторение след                                 | <br>цующей | инструкции | 1 3 p | раза                             |       |
|          |                                                  | Перед командой                                  |            |            |       | После команды                    |       |
|          | RC                                               |                                                 | 0          | RC         | ; [   |                                  | 0002  |
| Пример 3 | RPT #1111                                        | h ; Повторение                                  | следую     | щей инстру | кци   | и 4370 раз                       |       |
|          | Пере                                             | д командой                                      |            |            |       | После команды                    |       |
|          |                                                  | 0                                               |            | RC         |       |                                  | 1111  |

### 20.3.96 RPTB[D] pmad

Операнды

Код операции  $0 \le pmad \le 65535$ 

|                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|                     | 1  | 1  | 1  | 1  | 0  | 0  | Z | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 |
| 16 битная константа |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Выполнение

 $1 \rightarrow BRAF$ 

If (delayed) then

$$(PC) + 4 \rightarrow RSA$$

Else

$$(PC) + 2 \rightarrow RSA$$
 pmad  $\rightarrow REA$ 

### Статусные биты Описание

Команда влияет на значение BRAF.

Данная команда повторяет блок команд то количество раз, какое установлено счетчиком повторений блока (BRC), являющимся регистром, отображаемым в памяти. BRC должен быть загружен до выполнения этой команды. Когда команда выполнена, в регистр начального адреса повторений блока (RSA) загружается PC + 2 (или PC + 4 при использовании задержанной команды), а в регистр конечного адреса повторений блока (REA) загружается конечный адрес памяти программ (pmad).

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

- 1. соответсвующие BRC, RSA и REA были сохранены(при необходимости) и затем восстановлены.
- 2. текущий флаг повторений блока (BRAF) установлен должным образом.

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

Примечание – Повторение блока может быть прекращено сбрасыванием значения бита BRAF.

Данная команда не повторяемая.

Слова Циклы 2 слова.4 цикла.

2 цикла (задержанная).

Классы Пример 1 Класс 29A. ST #99, BRC

RPTB end block - 1

; end block = Bottom of Block

|     | Перед командой |     | После команды |
|-----|----------------|-----|---------------|
| PC  | 1000           | PC  | 1002          |
| BRC | 1234           | BRC | 0063          |
| RSA | 5678           | RSA | 1002          |
| REA | 9ABC           | REA | end block - 1 |

**Пример 2** ST #99, BRC ; выполнение блока 100 раз

RPTBD end\_block – 1 MVDM POINTER, AR1 ; initialize pointer

; end\_block ; Bottom of Block

|     | Перед командой |     | После команды |
|-----|----------------|-----|---------------|
| PC  | 1000           | PC  | 1004          |
| BRC | 1234           | BRC | 0063          |
| RSA | 5678           | RSA | 1004          |
| REA | 9ABC           | REA | end block - 1 |

### 20.3.97 RPTZ dst, #lk

**Операнды** dst: A (аккумулятор A).

В (аккумулятор В).

 $0 \le lk \le 65535$ 

Код операции

|                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|                     | 1  | 1  | 1  | 1  | 0  | 0  | 0 | D | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |
| 16 битная константа |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Выполнение**  $0 \rightarrow dst$ 

 $\text{lk} \to \text{RC}$ 

Статусные

Не используются.

биты

**Описание** Данная команда сбрасывает значение dst и повторяет следующую

команду n + 1 раз, где n – значение счетчика повторений (RC). Значение

RC становится равным 16-разрядной константе lk.

Слова2 слова.Циклы2 цикла.КлассыКласс 2.

Пример RPTZ A, 1023; Repeat the next instruction 1024 times

STL A, \*AR2+

|    | Пере | д командо | ОЙ   |    | Пос | пе команд | ļЫ   |
|----|------|-----------|------|----|-----|-----------|------|
| Α  | 0F   | FE00      | 8000 | Α  | 00  | 0000      | 0000 |
| RC |      |           | 0000 | RC |     |           | 03FF |

### 20.3.98 RSBX N, SBIT

**Операнды**  $0 \le SBIT \le 15$ 

N = 0 or 1

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | N | 0 | 1 | 0 | 1 | 1 | S | В | I | Т |

Выполнение Статусные  $0 \rightarrow STN(SBIT)$  Не используются.

биты

Описание

Данная команда сбрасывает значение заданного бита в статусном

регистре 0 или 1. N назначает номер статусного регистра для внесения

изменений, а SBIT задает номер изменяемого бита.

Название поля статусного регистра может быть использовано в

качестве операнда вместо операндов N и SBIT (см. Пример1).

Примечание – Данная команда не повторяемая.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.

Пример 1 RSBX SXM; SXM подразумевает: n=1 и SBIT=8

Перед командой

После команды

ST1 35CD

ST1

34CD

**Пример 2** RSBX 1,8

Перед командой

После команды

ST1 35CD

ST1

34CD

### 20.3.99 SACCD src, Xmem, cond

Операнды

А (аккумулятор А). src:

В (аккумулятор В).

Xmem: операнд памяти данных двойного доступа

В таблице перечислены условия (в соответствии с кодом операнда

условий cond) для данной команды.

| Опера<br>услов  | :: Описани           | іе Код<br>условия | Операнд<br>условий | Описание | Код<br>условия |
|-----------------|----------------------|-------------------|--------------------|----------|----------------|
| AEC             | $Q \qquad (A) = 0$   | 0101              | BEQ                | (B) = 0  | 1101           |
| ANE             | Q $(A) \neq 0$       | 0100              | BNEQ               | (B) ≠ 0  | 1100           |
| AG <sup>-</sup> | T $(A) > 0$          | 0110              | BGT                | (B) > 0  | 1110           |
| AGE             | Q (A) ≥ 0            | 0010              | BGEQ               | (B) ≥ 0  | 1010           |
| AL              | $\Gamma$ (A) < 0     | 0011              | BLT                | (B) < 0  | 1011           |
| ALE             | $Q \qquad (A) \le 0$ | 0111              | BLEQ               | (B) ≤ 0  | 1111           |

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 1  | 1  | 1  | 1 | S | х | X | X | X | С | 0 | N | D |

#### Выполнение

If (cond)

Then

$$(src) \ll (ASM - 16) \rightarrow Xmem$$

Else

 $(Xmem) \rightarrow (Xmem)$ 

Статусные биты Описание

Изменяется под влиянием ASM и SXM.

Если условие истинно, эта команда сохраняет src со сдвигом влево на (ASM – 16). Значение сдвига находится в ячейке памяти, определяемой Хтет. Если условие ложное, то команда считывает Хтет и записывает значение обратно в Хтет по тому же адресу; таким образом, Хтет остается прежним. Независимо от условия Хтет всегда считывается и

обновляется.

Слова Циклы Классы 1 слово. 1 цикл. Класс 15.

Пример 1

SACCD A. \*AR3+0%. ALT

| SACCD A,    | AINSTU | /0, ∧∟ i  |      |       |      |           |      |
|-------------|--------|-----------|------|-------|------|-----------|------|
|             | Пере   | д командо | рй   |       | Посл | те команд | ы    |
| Α [         | FF     | FE00      | 4321 | A     | FF   | FE00      | 4321 |
| ASM         |        |           | 01   | ASM   |      |           | 01   |
| AR0         |        |           | 0002 | AR0   |      |           | 0002 |
| AR3         |        |           | 0202 | AR3   |      |           | 0204 |
| Память дані | ных    |           |      |       |      |           |      |
| 0202h       |        |           | 0101 | 0202h |      |           | FC00 |

### 20.3.100 SAT src

**Операнды** src: A (аккумулятор A).

В (аккумулятор В).

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 1  | 1  | 1  | 1 | S | х | X | X | X | С | 0 | N | D |

В

OVB

Выполнение Статусные Насыщенный (src) → src Команда влияет на OVsrc.

биты

Описание Независимо от значения OVM, данная команда обеспечивает

насыщение содержания src на 32 бита.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.Пример 1SAT B

| Перед | командой |
|-------|----------|
|-------|----------|

| В   | 71 | 2345 | 6789 |
|-----|----|------|------|
| OVB |    |      | х    |

#### После команды

| 00 | 7FFF | FFFF |
|----|------|------|
|    |      | 1    |

**Пример 2** SAT A

Перед командой

| Α   | F8 | 1234 | 5678 |
|-----|----|------|------|
| OVA |    |      | х    |

После команды

| Α     | FF | 8000 | 0000 |
|-------|----|------|------|
| ova [ |    |      | 1    |

**Пример 3** SAT В

Перед командой

| В   | 00 | 0012 | 3456 |
|-----|----|------|------|
| OVB |    |      | х    |

После команды

| В   | 00 | 0012 | 3456 |
|-----|----|------|------|
| OVB |    |      | 0    |

## 20.3.101 SFTA src, SHIFT [, dst ]

| Операнды                      | src, o        | dst                           | Е                                       | З (акі                                      | уму.                    | пято<br>пято<br>FT ≤ | р B)                               |                       |              |                 |                     |                |               |      |         |                |
|-------------------------------|---------------|-------------------------------|-----------------------------------------|---------------------------------------------|-------------------------|----------------------|------------------------------------|-----------------------|--------------|-----------------|---------------------|----------------|---------------|------|---------|----------------|
| Код                           | 15            | 14                            | 13                                      | 12                                          | 11                      | 10                   | 9                                  | 8                     | 7            | 6               | 5                   | 4              | 3             | 2    | 1       | 0              |
| операции                      | 1             | 1                             | 1                                       | 1                                           | 0                       | 1                    | S                                  | D                     | 0            | 1               | 1                   | S              | Н             | ı    | F       | Т              |
| Выполнение                    | If SH<br>Ther |                               | < 0                                     |                                             |                         |                      |                                    |                       |              |                 |                     |                |               |      |         |                |
|                               | (src(         | (sre<br>If S<br>The<br>39)) - | SXM :<br>en<br>→ ds<br>if<br>e<br>→ dst | -0)) <<br>= 1<br>t(39-<br>dst               | -(39<br>is no           | H (SI<br>t spe       | → ds                               | + 1))<br>d]<br>+ 1))) |              | •               | •                   |                |               |      |         |                |
|                               | Else          | (sr                           | c(39 ·<br>c) <<<br>→ dst                | SHIF                                        | -T →                    | dst                  |                                    | r src(                | (SHI         | FT –            | 1)—0                | )), if (       | dst is        | not  | spec    | ified]         |
| Статусные<br>биты<br>Описание | Данн          | льта<br>анда<br>иая к<br>или  | т зав<br>влия<br>оман<br>src,           | виси <sup>-</sup><br>вет н<br>нда а<br>еслі | г от 9<br>а С і<br>ариф | SXM<br>и OV<br>меті  | и O\<br>dst (i<br>ичесі            | /М.<br>или (<br>ки сд | DVsr<br>вига | с, ес.<br>ет si | пи ds               | st = s<br>coxp | src).<br>аняе | т ре | зуль    | тат в<br>1т от |
|                               | 1. e          | сли з                         | вначе                                   | ение                                        | SHII                    | =Т м                 | еньц                               | ıe 0,                 | то:          |                 |                     |                |               |      |         |                |
|                               | 2)<br>впра    | если<br>во и                  | SXI<br>стар                             | М ра<br>шие                                 | авен<br>биті            | 1,<br>ы src          | уется<br>кома<br>сдві<br>апис      | нда<br>игаю           | ВЫП<br>ТСЯ В | олня<br>s dst(  | ет <i>а</i><br>39–( | ариф<br>39 +   | (SHI          | FT + | - 1))). |                |
|                               | 2. e          | сли з                         | вначе                                   | ение                                        | SHII                    | <del>-</del> Т бо    | ольш                               | е, че                 | ем Ο,        | TO:             |                     |                |               |      |         |                |
| Слова                         | 1 сл          | 2) i<br>3) i                  | кома                                    | нда                                         | осуц                    | це́ств               | пиру<br>зляе <sup>-</sup><br>dst(( | г ари                 | фме          | тиче            | ский                |                |               | ево. |         |                |
| Циклы                         | 1 ци          |                               |                                         |                                             |                         |                      |                                    |                       |              |                 |                     |                |               |      |         |                |

Классы

Класс 1.

### **Пример 1** SFTA A, -5, В

| Перед командой |    |      |      |  |  |  |  |  |  |  |
|----------------|----|------|------|--|--|--|--|--|--|--|
| Α              | FF | 8765 | 0055 |  |  |  |  |  |  |  |
| В              | 00 | 4321 | 1234 |  |  |  |  |  |  |  |
| С              |    |      | Х    |  |  |  |  |  |  |  |
| SXM            |    |      | 1    |  |  |  |  |  |  |  |

|     | Пос | пе команды |      |
|-----|-----|------------|------|
| Α   | FF  | 8765       | 0055 |
| В   | FF  | FC3B       | 2802 |
| С   |     |            | 1    |
| SXM |     |            | 1    |

### **Пример 2** SFTA B, +5

|     | riep | ред команд | цои  |
|-----|------|------------|------|
| В   | 80   | AA00       | 1234 |
| С   |      |            | 0    |
| OVM |      |            | 0    |
| SXM |      |            | 0    |

|     | После команды |   |      |      |  |  |  |  |  |  |
|-----|---------------|---|------|------|--|--|--|--|--|--|
| В   | 1             | 5 | 4002 | 4680 |  |  |  |  |  |  |
| С   |               |   |      | 1    |  |  |  |  |  |  |
| OVM |               |   |      | 0    |  |  |  |  |  |  |
| SXM |               |   |      | 0    |  |  |  |  |  |  |
|     |               |   |      |      |  |  |  |  |  |  |

### 20.3.102 SFTC src

**Операнды** src: A (аккумулятор A). B (аккумулятор B).

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | S | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 |

## **Выполнение** If (src) = 0

Then

 $1 \rightarrow TC$ 

Else

If (src(31)) XOR (src(30)) = 0Then (two significant sign bits)  $0 \rightarrow TC$  $(src) \ll 1 \rightarrow src$ Else (only one sign bit)

 $1 \rightarrow TC$ 

## Статусные

Команда определяет значение бита ТС.

биты

Описание

Если src имеет два совпадающих старших знаковых бита, то команда сдвигает 32-разрядный src влево на 1бит. Если есть два совпадающих знаковых бита, то значение бита тестирования (TC) сбрасывается; в противном случае устанавливается в 1.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.Пример 1SFTC A

|    | Пере | д командо | рй   |
|----|------|-----------|------|
| Α  | FF   | FFFF      | F001 |
| тс |      |           | х    |

|    | Пос | ле команд | Ы    |
|----|-----|-----------|------|
| Α  | FF  | FFFF      | E002 |
| тс |     |           | 0    |

### 20.3.103 SFTL src, SHIFT [, dst ]

Операнды А (аккумулятор А). src, dst: В (аккумулятор В).

-16 ≤ SHIFT ≤ 15

### Код операции

| _1 | 5 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  |   | 1  | 1  | 1  | 0  | 0  | S | D | 1 | 1 | 1 | S | Н | I | F | Т |

#### Выполнение

If SHIFT < 0

Then

$$src((-SHIFT) - 1) \rightarrow C$$
  
 $src(31-0) \ll SHIFT \rightarrow dst$   
 $0 \rightarrow dst(39-(31 + (SHIFT + 1)))$ 

If SHIFT = 0

Then

 $0 \rightarrow C$ 

Else

$$src(31 - (SHIFT - 1)) \rightarrow C$$
  
 $src((31 - SHIFT) - 0) \ll SHIFT \rightarrow dst$ 

 $0 \rightarrow dst((SHIFT - 1) - 0)$  [or src((SHIFT - 1) - 0), if dst is not specified]

 $0 \rightarrow dst(39-32)$  [or src(39-32), if dst is not specified]

### Статусные биты Описание

Операция влияет на значение С.

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

- 3. если значение SHIFT меньше 0, то:
  - 1) src((-SHIFT) 1) копируется в бит переноса, С.
  - 2) Команда выполняет логический сдвиг вправо.
  - 3) 0 записывается в dst(39-(31 + (SHIFT + 1))).
- 4. если значение SHIFT больше 0, то:
  - 1) src(31 (SHIFT 1)) копируется в бит переноса, С.
  - 2) Команда выполняет логический сдвиг влево.
  - 3) 0 записывается в dst((SHIFT 1)–0).

Слова Циклы Классы 1 слово.

1 цикл.

Класс 1. Пример 1 SFTL A, -5, B

|   | Пер | ед команд | цой  |
|---|-----|-----------|------|
| Α | FF  | 8765      | 0055 |
| В | FF  | 8000      | 0000 |
| С |     |           | 0    |

|   | После команды |      |      |  |  |  |  |  |  |
|---|---------------|------|------|--|--|--|--|--|--|
| Α | FF            | 8765 | 0055 |  |  |  |  |  |  |
| В | 00            | 043B | 2802 |  |  |  |  |  |  |
| С |               |      | 1    |  |  |  |  |  |  |

#### Пример 2

SFTL B, +5

|   | Пере | д командо | Й    |
|---|------|-----------|------|
| В | 80   | AA00      | 1234 |
| С |      |           | 0    |

|    | е команді | ы    |
|----|-----------|------|
| 00 | 4002      | 4680 |
|    |           | 1    |
|    |           |      |

#### 20.3.104 SQDST Xmem, Ymem

Операнды

Xmem, Ymem: операнды памяти данных двойного доступа.

Код операции

15 14 13 12 11 10 7 5 8 0 1 1 1 0 0 0 1 0 Χ Χ Χ Χ Υ Υ Υ

Выполнение

 $(A(32-16)) \times (A(32-16)) + (B) \rightarrow B$ 

 $((Xmem) - (Ymem)) << 16 \rightarrow A$ 

Статусные

Результат выполнения зависит от OVM, FRCT и SXM.

биты Описание Команда влияет на значение С, OVA и OVB.

Используемая в режиме одиночного повторения, данная команда вычисляет квадрат расстояния между двумя векторами. Старшая часть аккумулятора А (биты 32–16) возводится в квадрат, произведение складывается с аккумулятором В, и результат записывается в аккумулятор В. Утем вычитается из Хтем, разница сдвигается на 16 бит влево, и результат записывается в аккумулятор А. Значение, которое возводится в квадрат (A(32–16)) — это значение аккумулятора до выполнения вычитания в данной команде.

Слова1 слово.Циклы1 цикл.КлассыКласс 7.

Пример 1 SQDST \*AR3+, AR4+

| команд |
|--------|

|      | riep | ед команд | цои  |
|------|------|-----------|------|
| Α    | FF   | ABCD      | 0000 |
| В    | 00   | 0000      | 0000 |
| FRCT |      |           | 0    |
| AR3  |      |           | 0100 |
| AR4  |      |           | 0200 |

|      | Пос | ле команд | цы   |
|------|-----|-----------|------|
| Α    | FF  | FFAB      | 0000 |
| В    | 00  | 1BB1      | 8229 |
| FRCT |     |           | 0    |
| AR3  |     |           | 0101 |
| AR4  |     |           | 0201 |

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

| 0100h | 0055 |
|-------|------|
| 0200h | 00AA |

| 0100h | 0055 |
|-------|------|
| 0200h | 00AA |

1: **SQUR** Smem, dst

Smem:

2: SQUR A, dst

Операнды

Операнд памяти данных одиночного доступа

dst: A (аккумулятор A).

В (аккумулятор В).

### Код операции

1:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 1  | 0  | 0  | 1  | 1 | D | ı | Α | Α | Α | Α | Α | Α | Α |
|    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

2:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | D | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |

#### Выполнение

1:  $(Smem) \rightarrow T$ 

(Smem) x (Smem)  $\rightarrow$  dst

2:  $(A(32-16)) \times (A(32-16)) \rightarrow dst$ 

## Статусные

Результат зависит от OVM и FRCT.

## биты

Команда влияет на OVsrc.

Описание Данная команда вычисляет квадрат операнда памяти данных одиночного доступа Smem или старшей части аккумулятора A (биты 32–

16) и записывает результат в dst. Т не изменяется во время использования аккумулятора A; в противном случае, Smem сохраняется

в Т.

#### Слова 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

### **Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

#### Классы Синтаксис 1: Класс 3А.

Синтаксис 1: Класс 3В.

Синтаксис 2: Класс 1.

### Пример 1

\_

|      |   | lepe | ц команд | ОЙ   |
|------|---|------|----------|------|
| В    | ( | 00   | 0000     | 01F4 |
| Т    |   |      |          | 0003 |
| FRCT |   |      |          | 0    |
| DP   |   |      |          | 006  |
|      |   |      |          |      |

|      | Пос | сле команд | Ы    |
|------|-----|------------|------|
| В    | 00  | 0000       | 00E1 |
| T    |     |            | 000F |
| FRCT |     |            | 0    |
| DP   |     |            | 006  |

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

SQUR 30, B

031Eh 000F

| 031Eh | 000F |
|-------|------|
|-------|------|

#### Пример 2 SQUR A, B

| Перед | командой |
|-------|----------|
|       |          |

| Α    | 00 | 000F | 0000 |
|------|----|------|------|
| В    | 00 | 0101 | 0101 |
| FRCT |    |      | 1    |

|      | Пос | ле коман | ды   |
|------|-----|----------|------|
| Α    | FF  | 8765     | 0055 |
| В    | 00  | 0000     | 01C2 |
| FRCT |     |          | 1    |

## 20.3.105 SQURA Smem, src

| Операнды   | Smer<br>src: | m:             | Δ     | <b>.</b> (акі | куму. | памя<br>пятор<br>пятор | ,      | ННЫ      | іх од | иноч            | ного     | дос <sup>-</sup> | тупа.       |        |          |              |
|------------|--------------|----------------|-------|---------------|-------|------------------------|--------|----------|-------|-----------------|----------|------------------|-------------|--------|----------|--------------|
| Код        | 15           | 14             | 13    | 12            | 11    | 10                     | 9      | 8        | 7     | 6               | 5        | 4                | 3           | 2      | 1        | 0            |
| операции   | 0            | 0              | 1     | 1             | 1     | 0                      | 0      | S        | I     | Α               | Α        | Α                | Α           | Α      | Α        | Α            |
| Выполнение | `            | em) –<br>em) x |       | em)           | + (sr | .c) →                  | src    |          |       |                 |          |                  |             |        |          |              |
| Статусные  | •            | •              | •     |               | •     |                        | трук⊔  | ии з     | зави  | сит о           | тΟν      | /Ми              | FRC         | Т.     |          |              |
| биты       | •            |                |       |               |       | OVsi                   |        | •        |       |                 |          |                  |             |        |          |              |
| Описание   |              |                |       |               |       |                        |        | чени     | ие Si | mem             | в Т.     | . зат            | ем о        | на в   | ычис     | сляет        |
|            | <br>квад     |                | Sm    |               | •     |                        | цывае  |          |       | извед           |          |                  |             |        |          | тьтат        |
|            | запи         |                |       |               |       |                        | 1      | -        |       |                 | ,        | _                |             |        | ,-       |              |
| Слова      | 1 сло        |                |       |               | ٠.    |                        |        |          |       |                 |          |                  |             |        |          |              |
| 0,1020     |              |                | имо л | оба           | вить  | 1 спо                  | ово п  | ри и     | СПОГ  | 1 <b>53</b> 0F  | заниі    | и кос            | венн        | ой а   | лрес     | ации         |
|            | с дли        |                | -     | -             |       |                        |        |          |       |                 |          |                  |             | -      | <b>-</b> | .с. Ц. г. г. |
| Циклы      | 1 цин        |                |       |               |       |                        | 4000   |          |       | о <b>.</b> Пр , | , ос. д. |                  | · · · · · · |        |          |              |
| 7,         |              |                | MO J  | าดดีล         | вить  | . 1 ни                 | ıкп пr | ои и     | СПОП  | L3OB            | ании     | 1 KOC            | венн        | ой а   | лрес     | ации         |
|            | с дли        |                | -     | -             |       | -                      |        |          |       |                 |          |                  |             |        | црос     | ации         |
| Классы     | Клас         |                |       | ощо           |       |                        | aooc   | ,,,,,    |       | чДР,            | очц.     |                  | 011101      | •••    |          |              |
| iti idoobi | Клас         |                |       |               |       |                        |        |          |       |                 |          |                  |             |        |          |              |
| Пример 1   | SQU          | _              |       |               |       |                        |        |          |       |                 |          |                  |             |        |          |              |
| iipimop i  | OQU          |                | , D   |               |       |                        |        |          |       |                 |          |                  |             |        |          |              |
|            |              | _              |       |               |       | мандо                  |        | ٦ .      |       |                 | _ [      |                  | После       |        |          |              |
|            |              | В              |       | 00            | 03    | 320                    | 0000   |          |       |                 | В        |                  | 00          | 0320   | )        | 00E1         |
|            |              | Т              |       |               |       |                        | 0003   |          |       |                 | т [      |                  |             |        |          | 000F         |
|            |              | FRCT           |       |               |       |                        | 0      | <u>'</u> |       | FF              | кст [    |                  |             |        |          | 0            |
|            |              | DP             |       |               |       |                        | 006    |          |       | ſ               | OP [     |                  |             |        |          | 006          |
|            | Памя         | ть да          | нных  |               |       |                        |        |          |       |                 |          |                  |             |        |          |              |
|            | (            | )31Eh          |       |               |       |                        | 000F   |          |       | 03              | 1Eh [    |                  |             |        |          | 000F         |
| Пример 2   | SQU          | RA *           | AR3-  | +, A          |       |                        |        |          |       |                 |          |                  |             |        |          |              |
|            |              |                |       | Пер           | ед ко | мандо                  | Й      |          |       |                 |          |                  | После       | е кома | анды     |              |
|            |              | В              |       | 00            | 00    | 000                    | 01F4   |          |       |                 | в [      |                  | 00          | 0000   | )        | 02D5         |
|            |              | Т              |       |               |       |                        | 0003   |          |       |                 | т [      |                  |             |        |          | 000F         |
|            |              | FRCT           |       |               |       |                        | 0      |          |       | FF              | кст [    |                  |             |        |          | 0            |
|            |              | DP             |       |               |       |                        | 031E   |          |       | [               | OP [     |                  |             |        |          | 031F         |
|            | Памя         | ть да          | нных  |               |       |                        |        |          |       |                 |          |                  |             |        |          |              |
|            | (            | )31Eh          |       |               |       |                        | 000F   |          |       | 03              | 1Eh [    |                  |             |        |          | 000F         |
|            |              |                | _     |               |       |                        |        | _        |       |                 | _        |                  |             |        |          |              |

### 20.3.106 SQURS Smem, src

| 20.3.1             | 06 SQ                        | URS                  | Sm      | em,    | src                     |                                       |       |          |        |                |            |       |       |        |      |                |
|--------------------|------------------------------|----------------------|---------|--------|-------------------------|---------------------------------------|-------|----------|--------|----------------|------------|-------|-------|--------|------|----------------|
| Операнды           | Smer<br>src:                 | m:                   | A       | \ (акн | анд г<br>кумул<br>кумул | іятор                                 | o A). | анны     | іх од  | иноч           | ІНОГО      | дос   | тупа  |        |      |                |
| Код                | 15                           | 14                   | 13      | 12     | 11                      | 10                                    | 9     | 8        | 7      | 6              | 5          | 4     | 3     | 2      | 1    | 0              |
| операции           | 0                            | 0                    | 1       | 1      | 1                       | 0                                     | 1     | S        | I      | Α              | Α          | Α     | Α     | Α      | Α    | Α              |
| Выполнение         | (Sme                         |                      |         | ) x (S | Smerr                   | າ) →                                  | src   |          |        |                |            |       |       |        |      |                |
| Статусные          | На р                         | •                    |         |        |                         |                                       |       |          |        |                |            |       |       |        |      |                |
| биты               | Кома                         |                      |         |        |                         |                                       |       |          |        |                | _ <b>_</b> |       |       |        |      |                |
| Описание           |                              |                      |         |        |                         |                                       |       |          |        |                |            |       |       |        |      | сляет<br>ается |
| Слова              | в src.<br>1 слс              | ово.<br>бході        | имо д   | доба   | вить                    | 1 сл                                  | ово г | іри и    | ІСПОЛ  | 1 <b>53</b> 01 | зани       | и кос | венн  | ной а, |      | ации           |
| Циклы              | 1 цик                        |                      | IVI OIV | ющо    | TIVICIVI                | , , , , , , , , , , , , , , , , , , , | uoo   | 0,1101   | 111071 | чдр.           | эоац.      | ,,,,  | 01110 |        |      |                |
| Классы<br>Пример 1 | с дли<br>Клас<br>Клас<br>SQU | инны<br>с 3А<br>с 3В | M CN    | еще    | нием                    | или                                   | абс   | •        |        |                |            |       |       |        | црес | ации           |
|                    |                              |                      |         | Пер    | ед ком                  | андо                                  | Й     | _        |        |                |            |       | Посл  | е кома | нды  |                |
|                    |                              | Α                    |         | 00     | 014                     | IB                                    | 5DB(  | <u>_</u> |        |                | Α [        |       | 00    | 0000   | )    | 0320           |
|                    |                              | Т                    |         |        |                         |                                       | 8765  | <u> </u> |        |                | т          |       |       |        |      | 1234           |
|                    | Ī                            | FRCT                 |         |        |                         |                                       |       | 0        |        | FI             | RCT        |       |       |        |      | 0              |
|                    |                              | DP                   |         |        |                         |                                       | 00    | 6        |        | I              | OP [       |       |       |        |      | 006            |
|                    | Памя                         | ть да                | нных    |        |                         |                                       |       |          |        |                |            |       |       |        |      |                |
|                    | (                            | 0309h                |         |        |                         |                                       | 123   | 4        |        | 03             | 09h        |       |       |        |      | 1234           |
| Пример 2           | SQU                          | RS *                 | AR3     | , B    |                         |                                       |       |          |        |                |            |       |       |        |      |                |
|                    |                              |                      |         | Пер    | ед ком                  | андо                                  |       | _        |        |                |            |       | Посл  | е кома |      |                |
|                    |                              | В                    |         | 00     | 014                     | IB                                    | 5DB(  |          |        |                | В          |       | 00    | 0000   | )    | 02D5           |
|                    |                              | T                    |         |        |                         |                                       | 8765  | <u> </u> |        |                | т [        | 1234  |       |        |      | 1234           |
|                    | I                            | FRCT                 |         |        |                         |                                       |       | 0        |        | FI             | кст [      |       |       |        |      | 0              |
|                    |                              | AR3                  |         |        |                         |                                       | 030   | 9        |        | A              | .R3 [      |       |       |        |      | 0309           |
|                    | Памя                         | ть да                | нных    |        |                         |                                       |       |          |        |                |            |       |       |        |      |                |

0309h

1234

0309h

1234

### 20.3.107 SRCCD Xmem, cond

#### Операнды

Xmem: Операнд памяти данных двойного доступа.

В таблице перечислены условия (операнд cond) для данной команды.

| Операнд<br>условий | Описание     | Код<br>условия | Операнд<br>условий | Описание | Код<br>условия |
|--------------------|--------------|----------------|--------------------|----------|----------------|
| AEQ                | (A) = 0      | 0101           | BEQ                | (B) = 0  | 1101           |
| ANEQ               | $(A) \neq 0$ | 0100           | BNEQ               | (B) ≠ 0  | 1100           |
| AGT                | (A) > 0      | 0110           | BGT                | (B) > 0  | 1110           |
| AGEQ               | $(A) \geq 0$ | 0010           | BGEQ               | (B) ≥ 0  | 1010           |
| ALT                | (A) < 0      | 0011           | BLT                | (B) < 0  | 1011           |
| ALEQ               | $(A) \leq 0$ | 0111           | BLEQ               | (B) ≤ 0  | 1111           |

### Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 1  | 1  | 1  | 0 | 1 | х | Х | Х | X | С | 0 | N | D |

### Выполнение

If (cond)

Then

(BRC) → Xmem

Else

(Xmem) → Xmem

Статусные **биты** 

Не используются.

Описание

Если условие истинно, то данная команда сохраняет содержимое счетика повторений блока (BRC) в Xmem. Если условие ложное, то команда считывает Xmem и записывает значение в Xmem обратно по тому же адресу; Таким образом, Xmem остается прежним. Независимо от условия, Xmem всегда считывается и обновляется.

Слова1 слово.Циклы1 цикл.КлассыКласс 15.

#### Пример

SRCCD \*AR5-, AGT

|            | пере | ед команд | ои   |       | HOCJ | пе команд | <b>ды</b> |
|------------|------|-----------|------|-------|------|-----------|-----------|
| Α          | 00   | 70FF      | FFFF | Α     | 00   | 70FF      | FFFF      |
| AR5        |      |           | 0202 | AR5   |      |           | 0201      |
| BRC        |      |           | 4321 | BRC   |      |           | 4321      |
| Память дан | ных  |           |      |       |      |           |           |
| 0202h      |      |           | 1234 | 0202h |      |           | 4321      |

### 20.3.108 SSBX N, SBIT

**Операнды**  $0 \le SBIT \le 15$ 

N = 0 or 1

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | N | 1 | 1 | 0 | 1 | 1 | S | В | ı | Т |

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

Выполнение Статусные  $1 \rightarrow STN(SBIT)$  Не используются.

биты

оиты Описание Данная команда присваивает значение логической единицы указанному

биту в статусном регистре 0 или 1. N назначает номер статусного регистра для внесения изменений, а SBIT задает бит для изменения. Название поля статусного регистра может быть использовано в

качестве операнда вместо операндов N и SBIT (см. Пример 1).

Примечание – Данная команда не повторяемая.

Слова1 слово.Циклы1 цикл.КлассыКласс 1.

Пример 1 SSBX SXM; SXM means: N=1, SBIT=8

Перед командой После команды

 ST1
 34CD
 ST1
 35CD

**Пример 2** SSBX 1,8

Перед командой После команды

 ST1
 34CD
 ST1
 35CD

#### 20.3.109 ST

1: **ST** T, Smem 2: ST TRN, Smem 3: ST #lk, Smem

Smem: операнд памяти данных одиночного доступа. Операнды

 $-32768 \le lk \le 32767$ 

Код операции 1:

0

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 0  | 1  | 1  | 0 | 0 | I | Α | Α | Α | Α | Α | Α | Α |
| 2: |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 1  | 1  | 0 | 1 | ı | Α | Α | Α | Α | Α | Α | Α |
| 3: |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

| _  |    |    |    |   |   |
|----|----|----|----|---|---|
| Вы | пΩ | пн | ен | и | ρ |

1:  $(T) \rightarrow Smem$ 

2: (TRN) → Smem

3:  $lk \rightarrow Smem$ 

Статусные

Описание

биты

Не используются.

Данная команда сохраняет содержимое T, регистр перехода (TRN), или

16 битная константа

16-разрядную константу lk в ячейке памяти данных Smem.

Слова

Синтаксисы 1 и 2: 1 слово.

Синтаксис 3: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Циклы

Синтаксисы 1 и 2: 1 цикл.

Синтаксис 3: 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

Классы

Синтаксисы 1 and 2: Класс 10A.

Синтаксисы 1 and 2: Класс 10B.

Синтаксис 3: Класс 12А.

Синтаксис 3: Класс 12В.

ST FFFFh, 0 Пример 1

|               | Перед командой |       | После команды |  |  |  |  |
|---------------|----------------|-------|---------------|--|--|--|--|
| DP [          | 004            | DP    | 004           |  |  |  |  |
| Память данных |                |       |               |  |  |  |  |
| 0200h         | 0101           | 0200h | FFFF          |  |  |  |  |

#### Пример 2 ST TRN, 5 Перед командой После команды DP 004 DP 004 TRN 1234 TRN 1234 Память данных 0205h 0205h 0030 1234 Пример 3 ST T, \*AR7-Перед командой После команды Т 4210 T 4210 AR7 0321 AR7 0320 Память данных 0321h 1200 0321h 4210 20.3.110 STH 1: STH src, Smem 2: STH src, ASM, Smem 3: STH src, SHFT, Xmem 4: STH src [, SHIFT ], Smem Операнды src: А (аккумулятор А). В (аккумулятор В). Smem: Операнд памяти данных одиночного доступа. Xmem: Операнд памяти данных двойного доступа. 0 ≤ SHFT ≤ 15 -16 ≤ SHIFT ≤ 15 Код 1: операции 15 14 13 12 11 10 9 7 6 5 3 2 0 8 4 1 1 0 0 0 0 0 1 S I Α Α Α Α Α Α Α 2: 15 14 13 12 11 10 9 7 5 4 2 0 8 6 1 0 0 0 0 1 1 S ī Α Α Α Α Α Α Α 3: 15 14 13 12 11 10 9 5 2 0 7 3 0 1 1 1 S Χ Χ Χ Χ S F Т 1 0 0 Н 4:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 1  | 0  | 1  | 1  | 1 | 1 | ı | Α | Α | Α | Α | Α | Α | Α |
| 0  | 0  | 0  | 0  | 1  | 1  | 0 | s | 0 | 1 | 1 | s | н | ı | F | Т |

#### Выполнение

1:  $(src(31-16)) \rightarrow Smem$ 

2: (src) << (ASM − 16) → Smem

3: (src) << (SHFT - 16)  $\rightarrow$  Xmem

4:  $(src) \ll (SHIFT - 16) \rightarrow Smem$ 

# Статусные биты Описание

Результат зависит от SXM.

Эта команда сохраняет старшую часть src (биты 31–16) в ячейке памяти данных Smem. src сдвигается влево (в соответсвии с требованиями ASM, SHFT или SHIFT) и биты 31–16 сдвинутого значения записываются в память данных (Smem или Xmem). Если SXM = 0, бит 39 src копируется в самые старшие биты ячейки памяти данных. Если SXM = 1, значение src расширенное знаком (39 бит) сохраняется в ячейке памяти данных после сдвига вправо с использованием защитных бит. Аккумулятор src остается неизмененным.

Примечания – Следующие синтаксисы ассемблируются как различный синтаксис в определенных условиях.

- 5. Синтаксис 3: если SHFT = 0, код операции команды ассемблируется как Синтаксис 1.
- 6. Синтаксис 4: если SHIFT = 0, код операции команды ассемблируется как Синтаксис 1.

Синтаксис 4: если 0 < SHIFT ≤15 косвенный адрес приравнивается к режиму Xmem, код операции команды ассемблируется как Синтаксис 3. Синтаксисы 1, 2 и 3: 1 слово.

### Слова

Синтаксис 4: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Циклы

Синтаксисы 1, 2 и 3: 1 цикл.

Синтаксис 4: 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Классы

Синтаксисы 1. 2. и 3: Класс 10А.

Синтаксисы 1 и 2: Класс 10В.

Синтаксис 4: Класс 11A. Синтаксис 4: Класс 11B.

| Пример | 1 | STH A | , 10 |
|--------|---|-------|------|
|        |   |       |      |

|    | пере | ед команд | ои   |
|----|------|-----------|------|
| Α  | FF   | 8765      | 4321 |
| DP |      |           | 004  |



Память данных

| 020Ah | 1234 |
|-------|------|
|-------|------|



**Пример 2** STH B, –8, \*AR7–

|     | Пере | д команд | ОЙ   |
|-----|------|----------|------|
| В   | FF   | 8421     | 1234 |
| AR7 |      |          | 0321 |
|     |      |          |      |



Память данных

| 0321h | ABCD |
|-------|------|
|       |      |

| 0321h | FF84 |
|-------|------|

**Пример 3** STH A, -4, 10

|     | перед командои |      |      |  |  |  |  |  |  |
|-----|----------------|------|------|--|--|--|--|--|--|
| Α   | FF             | 8421 | 1234 |  |  |  |  |  |  |
| SXM |                |      | 1    |  |  |  |  |  |  |
| DP  |                |      | 004  |  |  |  |  |  |  |
|     |                |      |      |  |  |  |  |  |  |

|     | После команды |      |      |
|-----|---------------|------|------|
| Α   | FF            | 8421 | 1234 |
| SXM |               |      | 1    |
| DP  |               |      | 004  |
|     |               |      |      |

Память данных

| 020Ah 7F | FF |
|----------|----|
|----------|----|

| 020Ah | F842 |
|-------|------|

#### 20.3.111 STL

1: STL src, Smem

2: STL src, ASM, Smem

3: STL src, SHFT, Xmem

4: STL src [, SHIFT], Smem

**Операнды** src: A (аккумулятор A).

В (аккумулятор В).

Smem: операнд памяти данных одиночного доступа. Xmem: операнд памяти данных двойного доступа.

0 ≤ SHFT ≤ 15 -16 ≤ SHIFT ≤ 15

## Код операции

1:

| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1   | 0  | 0  | 0  | 0  | 0  | 0 | S | I | Α | Α | Α | Α | Α | Α | Α |
| 2:  | 2: |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1   | 0  | 0  | 0  | 0  | 1  | 0 | S | I | Α | Α | Α | Α | Α | Α | Α |
| 3:  | 3: |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1   | 0  | 0  | 1  | 1  | 0  | 0 | S | Х | X | X | X | S | Н | F | т |
| 4:  | 4: |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| _15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0   | 1  | 1  | 0  | 1  | 1  | 1 | 1 | - | Α | Α | Α | Α | Α | Α | Α |
| 0   | 0  | 0  | 0  | 1  | 1  | 0 | S | 1 | 0 | 0 | S | Н | ı | F | Т |

#### Выполнение

1:  $(src(15-0)) \rightarrow Smem$ 

2: (src)  $\ll$  ASM  $\rightarrow$  Smem

3: (src) << SHFT → Xmem

4: (src) << SHIFT → Smem

## Статусные биты Описание

Результат зависит от SXM.

Данная команда сохраняет младшую часть src (биты 15–0) в ячейку памяти данных Smem. Сдвигается влево (в соответсвии с требованиями ASM, SHFT или SHIFT) и биты 15–0 сдвинутого значения помещаются в память данных (Smem или Xmem). Когда значение сдвига положительно, то в самые младшие биты вдвигаются нули.

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

Следующие синтаксисы ассемблируются как различный синтаксис в неизменных условиях.

- 1. Синтаксис 3: если SHFT = 0, код операции команды ассемблируется как Синтаксис 1.
- 2. Синтаксис 4: если SHIFT = 0, код операции команды ассемблируется как Синтаксис 1.

SHIFT ≤15 косвенный Синтаксис 4: если 0 ≤ модификатор приравнивается К режиму Xmem, код операции команды ассемблируется как Синтаксис 3.

#### Слова

Синтаксисы 1, 2 и 3: 1 слово.

Синтаксис 4: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

## Циклы

Синтаксисы 1, 2 и 3: 1 цикл.

Синтаксис 4: 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Классы

Синтаксисы 1, 2 и 3: Класс 10А.

Синтаксисы 1, 2 и 3: Класс 10В.

Синтаксис 4: Класс 11А. Синтаксис 4: Класс 11В.

#### Пример 1

STL A, 11

|    | Пер | ед команд | цой  |    | После команды |      |      |  |
|----|-----|-----------|------|----|---------------|------|------|--|
| Α  | FF  | 8765      | 4321 | Α  | FF            | 8765 | 4321 |  |
| DP |     |           | 004  | DP |               |      | 004  |  |
|    |     |           |      |    |               |      |      |  |

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

| 020Bh | 1234 | 020Bh | 4321 |
|-------|------|-------|------|

### Пример 2

STL B, -8, \*AR7-

|          | Пере | ед команд | ой   |     | пе команд | Ы    |      |
|----------|------|-----------|------|-----|-----------|------|------|
| В        | FF   | 8421      | 1234 | В   | FF        | 8421 | 1234 |
| SXM      |      |           | 1    | SXM |           |      | 1    |
| AR7      |      |           | 004  | AR7 |           |      | 004  |
| іять дан | ных  |           |      |     |           |      |      |

#### Памят

| 0321h | 0099 | 0321h | 2112 |
|-------|------|-------|------|

#### Пример 3 STL A, 7, 11

|               | Пере | д команд | ОЙ   |       | После команды |      |      |  |  |
|---------------|------|----------|------|-------|---------------|------|------|--|--|
| Α             | FF   | 8421     | 1234 | Α     | FF            | 8421 | 1234 |  |  |
| DP            |      |          | 004  | DP    |               |      | 004  |  |  |
| Память данных |      |          |      |       |               |      |      |  |  |
| 020Bh         |      |          | 0101 | 020Bh |               |      | 1A00 |  |  |

## 20.3.112 STLM src, MMR

Операнды src: А (аккумулятор А).

В (аккумулятор В).

MMR: отображаемый в памяти регистр.

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 0  | 1  | 0  | 0 | S | ı | Α | Α | Α | Α | Α | Α | Α |

Выполнение Статусные биты

Описание

 $(src(15-0)) \rightarrow MMR$ 

Не используются.

Эта команда сохраняет младшую часть src (биты 15-0) в адресуемый регистр отображенный в памяти MMR. Значения девяти самых старших бит действительного адреса сбрасываются независимо от текущего значения DP или от старших девяти бит ARx. Эта команда позволяет сохранять src в любой ячейке памяти на нулевой странице данных без

внесения изменений в поле DP статусного регистра ST0.

Спова 1 слово.

| -,.oba   | 1 011000.   |
|----------|-------------|
| Циклы    | 1 цикл.     |
| Классы   | Класс 10А.  |
| Пример 1 | STLM A, BRC |
|          |             |

|          |            | Перед | командо  | й    |
|----------|------------|-------|----------|------|
|          | Α [        | FF    | 8765     | 4321 |
|          | BRC(1Ah)   |       |          | 1234 |
| Пример 2 | STLM B, *A | \R1-  |          |      |
|          |            | Пере  | д команд | ой   |

| Α   | FF | 8765 | 4321 |
|-----|----|------|------|
| BRC |    |      | 4321 |

После команды

|          | Перед командои |      |      |  |  |  |  |  |
|----------|----------------|------|------|--|--|--|--|--|
| В        | FF             | 8421 | 1234 |  |  |  |  |  |
| AR1      |                |      | 3F17 |  |  |  |  |  |
| AR7(17h) |                |      | 0099 |  |  |  |  |  |

|     | <br>После команды |      |      |  |  |  |  |  |
|-----|-------------------|------|------|--|--|--|--|--|
| В   | FF                | 8421 | 1234 |  |  |  |  |  |
| AR1 |                   |      | 0016 |  |  |  |  |  |
| AR7 |                   |      | 1234 |  |  |  |  |  |
|     |                   |      |      |  |  |  |  |  |

## 20.3.113 STM #lk, MMR

AR7

| Операнды                        | MMF<br>-32            |                        |                       |                                  |                     | в паг        | ияти               | реги                  | істр.                  |                     |                      |                |              |               |       |                                  |
|---------------------------------|-----------------------|------------------------|-----------------------|----------------------------------|---------------------|--------------|--------------------|-----------------------|------------------------|---------------------|----------------------|----------------|--------------|---------------|-------|----------------------------------|
| Код                             | 15                    | 14                     | 13                    | 12                               | 11                  | 10           | 9                  | 8                     | 7                      | 6                   | 5                    | 4              | 3            | 2             | 1     | 0                                |
| операции                        | 0                     | 1                      | 1                     | 1                                | 0                   | 1            | 1                  | 1                     | ı                      | Α                   | Α                    | Α              | Α            | Α             | Α     | Α                                |
|                                 |                       |                        |                       |                                  |                     | 16           | бит                | гная                  | кон                    | стан                | та                   |                |              |               |       |                                  |
| Выполнение<br>Статусные<br>биты | lk →<br>Отсу          |                        | -                     |                                  |                     |              |                    |                       |                        |                     |                      |                |              |               |       |                                  |
| Описание                        | ячей<br>стату<br>дейс | ку па<br>усноі<br>твит | амяті<br>го р<br>ельн | и на<br>егис <sup>.</sup><br>юго | 0 стр<br>тра<br>адр | аниL<br>ST0. | це да<br>Зн<br>сбр | анны:<br>ачен<br>расы | х без<br>іия ,<br>вают | в вне<br>девя<br>ся | сени<br>ти (<br>неза | ія изі<br>самы | иене<br>х ст | ний і<br>гарш | в пол | R или<br>ie DP<br>битов<br>ищего |
| Слова                           | 2 сло                 |                        |                       |                                  |                     | •            |                    |                       |                        |                     |                      |                |              |               |       |                                  |
| Циклы                           | 2 ци                  |                        | _                     |                                  |                     |              |                    |                       |                        |                     |                      |                |              |               |       |                                  |
| Классы                          | Клас                  |                        |                       | 11.40                            |                     |              |                    |                       |                        |                     |                      |                |              |               |       |                                  |
| Пример 1                        | STM                   | OFF                    | FFN,                  | IIVIR                            |                     |              |                    |                       |                        |                     |                      |                |              |               |       |                                  |
|                                 |                       |                        | Пе                    | ред к                            | оманд               | дой          |                    |                       |                        |                     |                      | П              | осле і       | коман         | ІДЫ   |                                  |
|                                 | IMI                   | ₹ [                    |                       |                                  |                     | F            | F01                |                       |                        | IM                  | R [                  |                |              |               |       | FFFF                             |
| Пример 2                        | STM                   | 876                    | 5h, */                | 4R7+                             | ŀ                   |              |                    |                       |                        |                     |                      |                |              |               |       |                                  |
|                                 |                       |                        | Пе                    | ред к                            | оманд               | дой          |                    |                       |                        |                     |                      | П              | осле і       | коман         | іды   |                                  |
|                                 | AR                    | o [                    |                       |                                  |                     | (            | 0000               |                       |                        | AF                  | ro [                 |                |              |               |       | 8765                             |

8010

AR7

0011

## 20.3.114 ST src, Ymem | ADD Xmem, dst

**Операнды** src, dst: A (аккумулятор A).

В (аккумулятор В).

Xmem, Ymem: операнды памяти данных двойного доступа.

 $dst_{-}$ : если dst = A, то  $dst_{-} = B$ ; если dst = B, то  $dst_{-} = A$ 

Код операции

12 11 10 9 7 5 13 4 2 0 1 1 0 0 0 0 S D Χ Χ Χ Χ Υ Υ Υ Υ

**Выполнение** (src)  $\ll$  (ASM - 16)  $\rightarrow$  Ymem

 $(dst_) + (Xmem) \ll 16 \rightarrow dst$ 

**Статусные** Выполнение инструкции зависит от OVM, SXM и ASM.

биты Операция влияет на С и OVdst.

Описание Эта команда сохраняет src, сдвинутый на (ASM – 16) в ячейку памяти

данных Ymem. Параллельно, эта команда складывает содержимое dst\_ со сдвинутым влево на 16 разрядов операндом памяти данных Xmem, и сохраняет результат в dst. Если src равно dst, значение сохраняемое в

Ymem является значением src до выполнения команды.

Слова1 слово.Циклы1 цикл.КлассыКласс 14.

Пример ST A, \*AR3

||ADD \*AR5+0%, B

|            | Пере | д команд | ой   |       | Посл | пе команд | Ы    |
|------------|------|----------|------|-------|------|-----------|------|
| Α          | FF   | 8421     | 1000 | Α     | FF   | 8021      | 1000 |
| В          | 00   | 0000     | 1111 | В     | FF   | 0422      | 1000 |
| OVM        |      |          | 0    | OVM   |      |           | 0    |
| SXM        |      |          | 1    | SXM   |      |           | 1    |
| ASM        |      |          | 1    | ASM   |      |           | 1    |
| AR0        |      |          | 0002 | AR0   |      |           | 0002 |
| AR3        |      |          | 0200 | AR3   |      |           | 0200 |
| AR5        |      |          | 0300 | AR5   |      |           | 0302 |
| Память дан | ных  |          |      |       |      |           |      |
| 0200h      |      |          | 0101 | 0309h |      |           | 0842 |
| 0300h      |      |          | 8001 | 0309h |      |           | 8001 |

## 20.3.115 ST//LD

1: ST src, Ymem

| LD Xmem, dst

2: ST src, Ymem || LD Xmem, T

src, dst: Операнды А (аккумулятор А). В (аккумулятор В).

> операнды памяти данных двойного доступа. Xmem, Ymem:

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 0  | 0  | 1  | 0  | S | D | Х | Χ | X | Χ | Υ | Y | Υ | Υ |

2:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 1  | 0  | 0  | 1  | S | 0 | Х | X | X | X | Υ | Υ | Υ | Υ |

### Выполнение

1. (src) << (ASM - 16) → Ymem

 $(Xmem) \ll 16 \rightarrow dst$ 

2. (src) << (ASM - 16) → Ymem  $(Xmem) \rightarrow T$ 

Статусные

Выполнение зависит от значений OVM и ASM.

биты

Команды влияет на значение С.

Описание

Эта команда сохраняет src, сдвинутое на (ASM – 16) разрядов в ячейку памяти данных Ymem. Параллельно, эта команда загружает 16 битный операнд памяти данных Xmem в dst или Т. Если src равно dst, значение, сохраняемое в Ymem, является значением src до выполнения команды. 1 слово.

Слова Циклы Классы Пример 1

1 цикл.

Класс 14. STB, \*AR2-

||LD \*AR4+, A

|              | Пере | ед команд | ой   |       | Посл | те команд | ļЫ   |
|--------------|------|-----------|------|-------|------|-----------|------|
| Α _          | 00   | 0000      | 001C | Α [   | FF   | 8001      | 0000 |
| В            | FF   | 8421      | 1234 | В     | FF   | 8421      | 1234 |
| SXM          |      |           | 1    | SXM   |      |           | 0    |
| ASM          |      |           | 1C   | ASM   |      |           | 1    |
| AR2          |      |           | 01FF | AR2   |      |           | 01FE |
| AR4          |      |           | 0200 | AR4   |      |           | 0201 |
| Память даннь | ıx   |           |      |       |      |           |      |
| 01FFh        |      |           | xxxx | 01FFh |      |           | F842 |
| 0200h        |      |           | 8001 | 0200h |      | <u> </u>  | 8001 |

**Пример 2** ST A, \*AR3 ||LD \*AR4, T

|            | Перед | ц команд | ой   |       | Посл | те команд | ΙЫ   |
|------------|-------|----------|------|-------|------|-----------|------|
| Α          | FF    | 8421     | 1234 | Α     | FF   | 8421      | 1234 |
| Т          |       |          | 3456 | т     |      |           | 80FF |
| ASM        |       |          | 1    | ASM   |      |           | 1    |
| AR3        |       |          | 0200 | AR3   |      |           | 0200 |
| AR4        |       |          | 0100 | AR4   |      |           | 0100 |
| Память дан | ных   |          |      |       |      |           |      |
| 0200h      |       |          | 0001 | 0200h |      |           | 0842 |
| 0100h      |       |          | 80FF | 0100h |      |           | 80FF |

Пример 3 ST A, \*AR2+ ||LD \*AR2-, A

В примере 3, LD считывает операнд-источник из ячейки памяти, указанной AR2 прежде, чем ST делает запись в ту же ячейку. ST считывает операнд-источник аккумулятора A прежде, чем LD загрузит новое значение в аккумулятор A.

## 20.3.116 ST src, Ymem

| MAC[R] Xmem, dst

**Операнды** src, dst: A (аккумулятор A).

В (аккумулятор В).

Xmem, Ymem: Операнды памяти данных двойного доступа.

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 0  | 1  | 0  | R  | S | D | х | Х | X | X | Υ | Y | Υ | Υ |

**Выполнение**  $(src \ll (ASM - 16)) \rightarrow Ymem$ 

If (Rounding)

Then

Round ((Xmem)  $\times$  (T) + (dst))  $\rightarrow$  dst

Else

 $(Xmem) \rightarrow (T) + (dst) \rightarrow dst$ 

Статусные биты Описание Выполнение зависит от OVM, SXM, ASM и FRCT.

Результат влияет на значение С и OVdst.

Эта команда сохраняет src, сдвинутое на (ASM – 16) разрядов в ячейке памяти данных Ymem. Параллельно, эта команда умножает содержимое T на операнд памяти данных Xmem, складывает со значением dst (с округлением или без него) и сохраняет результат в dst. Если src равно dst, значение, сохраняемое в Ymem, является значением src до выполнения команды

При использовании индекса R команда округляет результат операции умножения путем добавления  $2^{15}$  к результату и сбрасыванием значений самых младших битов (биты 15–0).

Слова Циклы Классы Пример 1 1 слово.

**иклы** 1 цикл. **лассы** Класс 14.

**ример 1** ST A, \*AR4– ||MAC \*AR5, B

Пам

|          | •    |            |      |      |      |           |      |
|----------|------|------------|------|------|------|-----------|------|
|          | Пере | ед командо | рй   |      | Посл | те команд | ы    |
| Α        | 00   | 0011       | 1111 | Α    | 00   | 0011      | 1111 |
| В        | 00   | 0000       | 1111 | В    | 00   | 010C      | 9511 |
| Т        |      |            | 0400 | Т    |      |           | 0400 |
| ASM      |      |            | 5    | ASM  |      |           | 5    |
| FRCT     |      |            | 0    | FRCT |      |           | 0    |
| AR4      |      |            | 0100 | AR4  |      |           | 00FF |
| AR5      |      |            | 0200 | AR5  |      |           | 0200 |
| іять дан | ІНЫХ |            |      |      |      |           |      |
| 100h     |      |            | 1234 | 100h |      |           | 0222 |
| 200h     |      |            | 4321 | 200h |      |           | 4321 |
|          |      |            |      |      |      |           |      |

Пример 2 ST A, \*AR4+ ||MACR \*AR5+, В

|            | •    |           |      |      |      |           |      |
|------------|------|-----------|------|------|------|-----------|------|
|            | Пере | д команде | рй   |      | Посл | іе команд | ы    |
| Α          | 00   | 0011      | 1111 | Α    | 00   | 0011      | 1111 |
| В          | 00   | 0000      | 1111 | В    | 00   | 010D      | 0000 |
| Т          |      |           | 0400 | Т    |      |           | 0400 |
| ASM        |      |           | 1C   | ASM  |      |           | 1C   |
| FRCT       |      |           | 0    | FRCT |      |           | 0    |
| AR4        |      |           | 0100 | AR4  |      |           | 0101 |
| AR5        |      |           | 0200 | AR5  |      |           | 0201 |
| Память дан | ІНЫХ |           |      |      |      |           |      |
| 100h       |      |           | 1234 | 100h |      |           | 0001 |
| 200h       |      |           | 4321 | 200h |      |           | 4321 |

## 20.3.117 ST src, Ymem || MAS[R] Xmem, dst

**Операнды** src, dst: A (аккумулятор A).

В (аккумулятор В).

Xmem, Ymem: Операнды памяти данных двойного доступа.

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 0  | 1  | 1  | R  | S | D | Х | X | X | X | Υ | Υ | Υ | Υ |

Выполнение

 $(src \ll (ASM - 16)) \rightarrow Ymem$ 

If (Rounding)

Then

Round ((dst) – (Xmem) × (T))  $\rightarrow$  dst

Else

 $(dst) - (Xmem) \times (T) \rightarrow dst$ 

Статусные биты Описание Выполнение зависит от значения OVM, SXM, ASM и FRCT.

Команда влияет на значение С и OVdst.

Эта команда сохраняет src, сдвинутое на (ASM – 16) разрядов в ячейке памяти данных Ymem. Параллельно, эта команда умножает содержимое T на операнд памяти данных Xmem, вычитает результат из dst (с округлением или без него) и сохраняет результат в dst. Если src равно dst, значение, сохраняемое в Ymem, является значением src до выполнения команды

При использовании индекса R команда округляет результат операции умножения путем добавления 2<sup>15</sup> к результату и сбрасыванием значений самых младших битов (биты 15–0).

Слова1 слово.Циклы1 цикл.КлассыКласс 14.

| Пример 1 | ST A, *AR4+ |
|----------|-------------|
|          | MAS *AR5, B |
|          |             |

| TIPIMOP I | MAS *AR                 |       |           |      |       |      |           |      |
|-----------|-------------------------|-------|-----------|------|-------|------|-----------|------|
|           |                         | Перед | д командо | рй   |       | Посл | іе команд | Ы    |
|           | Α [                     | 00    | 0011      | 1111 | Α     | 00   | 0011      | 1111 |
|           | В                       | 00    | 0000      | 1111 | В     | FF   | FEF3      | 8D11 |
|           | т [                     |       |           | 0400 | Т     |      |           | 0400 |
|           | ASM [                   |       |           | 5    | ASM   |      |           | 5    |
|           | FRCT                    |       |           | 0    | FRCT  |      |           | 0    |
|           | AR4                     |       |           | 0100 | AR4   |      |           | 0101 |
|           | AR5                     |       |           | 0200 | AR5   |      |           | 0200 |
|           | Память дані             | ных   |           |      |       |      |           |      |
|           | 0100h                   |       |           | 1234 | 0100h |      |           | 0222 |
|           | 0200h [                 |       |           | 4321 | 0200h |      |           | 4321 |
| Пример 2  | ST A, *AR4<br>  MASR *A |       |           |      |       |      |           |      |
|           | _                       | Перед | д командо | ой   |       | Посл | іе команд | ы    |
|           | Α [                     | 00    | 0011      | 1111 | Α     | 00   | 0011      | 1111 |
|           | В                       | 00    | 0000      | 1111 | В     | FF   | FEF4      | 0000 |
|           | т [                     |       |           | 0400 | Т     |      |           | 0400 |
|           | ASM                     |       |           | 0001 | ASM   |      |           | 0001 |
|           | FRCT                    |       |           | 0    | FRCT  |      |           | 0    |
|           | AR4                     |       |           | 0100 | AR4   |      |           | 0101 |
|           | AR5                     |       |           | 0200 | AR5   |      |           | 0201 |
|           | Память дані             | ных   |           |      |       |      |           |      |
|           | 0100h                   |       |           | 1234 | 0100h |      |           | 0022 |
|           | L                       |       |           |      |       |      |           |      |

### 20.3.118 ST src, Ymem | MPY Xmem, dst

**Операнды** src, dst: A (аккумулятор A).

В (аккумулятор В).

Xmem, Ymem: Операнды памяти данных двойного доступа.

Код

14 13 12 11 10 8 7 6 операции 1 1 0 0 1 1 S D Χ Χ Χ Χ Υ Υ Υ

**Выполнение**  $(src \ll (ASM - 16)) \rightarrow Ymem$ 

 $(T) \times (Xmem) \rightarrow dst$ 

**Статусные** Выполнение находится под влиянием OVM, SXM, ASM и FRCT.

биты Команда влияет на С и OVdst.

**Описание** Эта команда сохраняет src, сдвинутое на (ASM – 16) разрядов в ячейке

памяти данных Ymem. Параллельно, эта команда умножает содержимое T на операнд памяти данных двойного доступа Xmem и сохраняет результат в dst. Если src равно dst, значение, сохраняемое в

Ymem, является значением src до выполнения команды.

Слова1 слово.Циклы1 цикл.КлассыКласс 14.Пример 1ST A, \*AR3+<br/>||MPY \*AR5+, B

|      | Пе | ред кома | ндой   |
|------|----|----------|--------|
| Α    | FF | 842      | 1 1234 |
| В    | xx | xxx      | x xxxx |
| Т    |    |          | 4000   |
| ASM  |    |          | 00     |
| FRCT |    |          | 1      |
| AR3  |    |          | 0200   |
| AR5  |    |          | 0300   |

| 0200h | 1111 |
|-------|------|
| 0300h | 4000 |

Память данных

|      | После | команды |      |
|------|-------|---------|------|
| Α    | FF    | 8421    | 1234 |
| В    | 00    | 2000    | 0000 |
| Т    |       |         | 4000 |
| ASM  |       |         | 00   |
| FRCT |       |         | 1    |
| AR3  |       |         | 0201 |
| AR5  |       |         | 0301 |
|      |       |         |      |

Υ

| 0200h | 8421 |
|-------|------|
| 0300h | 4000 |

## 20.3.119 ST src, Ymem || SUB Xmem, dst

**Операнды** src, dst: A (аккумулятор A).

В (аккумулятор В).

Xmem, Ymem: Операнды памяти данных двойного доступа

 $dst_{=}$  если dst = A, то  $dst_{=} = B$ ; если dst = B, то  $dst_{=} = A$ .

Код операции

11 10 13 12 7 5 0 1 1 0 0 0 1 S D Χ Χ Χ Χ Υ Υ Υ Υ

**Выполнение**  $(src \ll (ASM - 16)) \rightarrow Ymem$ 

 $(Xmem) \ll 16 - (dst_) \rightarrow dst$ 

**Статусные** Результат операции зависит от OVM, SXM и ASM.

биты Операция влияет на С и OVdst.

Описание Эта команда сохраняет src, сдвинутое на (ASM – 16) разрядов в ячейке памяти данных Ymem. Параллельно, эта команда вычитает содержимое dst\_ из 16-разрядного операнда памяти данных двойного доступа Xmem, сдвинутого влево на 16 бит и сохраняет результат в dst. Если src

хтет, сдвинутого влево на то оит и сохраняет результат в dst. Если src равно dst, значение, сохраняемое в Ymem, является значением src до

выполнения команды.

Слова1 слово.Циклы1 цикл.КлассыКласс 14.Пример 1ST A, \*AR3-

||SUB \*AR5+0%, B

|            | Пере | д командо | рй   |       | Посл | <b>те команд</b> | ы    |
|------------|------|-----------|------|-------|------|------------------|------|
| Α          | FF   | 8421      | 0000 | Α     | FF   | 8421             | 0000 |
| В          | 00   | 1000      | 0001 | В     | FF   | FBE0             | 0000 |
| ASM        |      |           | 01   | ASM   |      |                  | 01   |
| SXM        |      |           | 1    | SXM   |      |                  | 1    |
| AR0        |      |           | 0002 | AR0   |      |                  | 0002 |
| AR3        |      |           | 01FF | AR3   |      |                  | 01FE |
| AR5        |      |           | 0300 | AR5   |      |                  | 0302 |
| Память дан | ных  |           |      |       |      |                  |      |
| 01FFh      |      |           | 1111 | 01FFh |      |                  | 0842 |
| 0300h      |      |           | 8001 | 0300h |      |                  | 8001 |

### 20.3.120 STRCD Xmem, cond

## Операнды

Xmem: Операнд памяти данных двойного доступа.

В таблице перечислены условия (операнд cond) для данной команды.

| Операнд<br>условий | Описание     | Код<br>условия | Операнд<br>условий | Описание | Код<br>условия |
|--------------------|--------------|----------------|--------------------|----------|----------------|
| AEQ                | (A) = 0      | 0101           | BEQ                | (B) = 0  | 1101           |
| ANEQ               | $(A) \neq 0$ | 0100           | BNEQ               | (B) ≠ 0  | 1100           |
| AGT                | (A) > 0      | 0110           | BGT                | (B) > 0  | 1110           |
| AGEQ               | $(A) \ge 0$  | 0010           | BGEQ               | (B) ≥ 0  | 1010           |
| ALT                | (A) < 0      | 0011           | BLT                | (B) < 0  | 1011           |
| ALEQ               | $(A) \leq 0$ | 0111           | BLEQ               | (B) ≤ 0  | 1111           |

Код

операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 0  | 0  | 1  | 1  | 1  | 0 | 0 | х | X | X | X | С | 0 | N | D |

Выполнение

If (cond)

 $(T) \rightarrow Xmem$ 

Else

 $(Xmem) \rightarrow Xmem$ 

Статусные

Не используются.

биты

Описание

Если условие истинно, то команда сохраняет содержимое Т в ячейке памяти данных Xmem. Если условие ложное, то команда считывает Xmem и записывает значение Xmem обратно по тому же адресу; таким образом, Xmem остается прежним. Независимо от условия Xmem всегда считывается и обновляется.

Слова1 слово.Циклы1 цикл.КлассыКласс 15.

Пример 1 STRCD \*AR5—, AGT

|            | Hepe | д командо | ОИ   |       | После команд |      |      |
|------------|------|-----------|------|-------|--------------|------|------|
| Α          | 00   | 70FF      | FFFF | A     | 00           | 70FF | FFFF |
| Т          |      |           | 4321 | т     |              |      | 4321 |
| AR5        |      |           | 0202 | AR5   |              |      | 0201 |
| Память дан | ных  |           |      |       |              |      |      |
| 0202h      |      |           | 1234 | 0202h |              |      | 4321 |

#### 20.3.121 SUB

```
1: SUB Smem, src
 2: SUB Smem, TS, src
 3: SUB Smem, 16, src [, dst ]
 4: SUB Smem [, SHIFT], src [, dst]
 5: SUB Xmem, SHFT, src
 6: SUB Xmem, Ymem, dst
 7: SUB #lk [, SHFT ], src [, dst ]
 8: SUB #lk, 16, src [, dst ]
 9: SUB src [, SHIFT ], [, dst ]
 10: SUB src, ASM [, dst ]
Операнды
                 src, dst:
                                       А (аккумулятор А).
                                       В (аккумулятор В).
                                       Операнд памяти данных одиночного доступа.
                 Smem:
                                       Операнды памяти данных двойного доступа.
                 Xmem, Ymem:
                 -32768 \le lk \le 32767
                 0 ≤ SHFT ≤ 15
                 -16 ≤ SHIFT ≤ 15
                  1:
Код
операции
                     15
                               13
                                   12
                                        11
                                             10
                                                                     5
                      0
                           0
                               0
                                    0
                                         1
                                             0
                                                  0
                                                           ı
                                                                     Α
                                                                              Α
                                                                                   Α
                                                                                       Α
                                                                                            Α
                 2:
                     15
                         14
                              13
                                   12
                                        11
                                            10
                                                  9
                                                      8
                                                           7
                                                                6
                                                                     5
                                                                          4
                                                                              3
                                                                                        1
                                                                                             0
                                                                                   2
                                                           ı
                     0
                          0
                               0
                                   0
                                        1
                                             1
                                                  0
                                                      S
                                                                Α
                                                                     Α
                                                                         Α
                                                                              Α
                                                                                   Α
                                                                                        Α
                                                                                             Α
                 3:
                     15
                          14
                               13
                                   12
                                        11
                                             10
                                                  9
                                                                              3
                                                                                            0
                      0
                           1
                               0
                                    0
                                        0
                                             0
                                                  S
                                                      D
                                                           I
                                                                Α
                                                                     Α
                                                                              Α
                                                                                   Α
                                                                                       Α
                                                                                            Α
                 4:
                      15
                               13
                                    12
                                             10
                                                                    5
                                                                                           0
                           14
                                        11
                                                  9
                                                           7
                                                                6
                                                                              3
                                                                                  2
                                1
                                         1
                                              1
                                                  1
                                                           ı
                       0
                           1
                                    0
                                                       1
                                                                Α
                                                                    Α
                                                                         Α
                                                                             Α
                                                                                  Α
                                                                                       Α
                                                                                           Α
                                                                                           Т
                       0
                           0
                                0
                                    0
                                         1
                                              1
                                                  s
                                                      D
                                                           0
                                                                0
                                                                    1
                                                                         s
                                                                             Н
                                                                                       F
                 5:
                     15
                               13
                                   12
                                        11
                                             10
                                                                     5
                                                                              3
                      1
                           0
                               0
                                    1
                                         0
                                             0
                                                  1
                                                      D
                                                           X
                                                                X
                                                                    X
                                                                         X
                                                                              Υ
                                                                                   Υ
                                                                                       Υ
                                                                                            Υ
                 6:
                     15
                          14
                               13
                                   12
                                        11
                                             10
                                                  9
                                                      8
                                                                6
                                                                     5
                                                                              3
                                                                                       1
                                                                                            0
                      1
                           1
                               1
                                                  S
                                                      D
                                                           0
                                                                     0
                                                                              s
                                                                                       F
                                                                                            Т
                                    1
                                        0
                                             0
                                                                0
                                                                         1
                                                                                  н
                                              16 битная константа
                 7:
                     15
                          14
                               13
                                   12
                                        11
                                             10
                                                  9
                                                       8
                                                           7
                                                                     5
                                                                              3
                                                                                   2
                                                                                       1
                                                                                            0
                                                                6
                                                                         4
                      1
                           1
                               1
                                    1
                                        0
                                             0
                                                  S
                                                      D
                                                           0
                                                                0
                                                                     0
                                                                         1
                                                                              s
                                                                                  н
                                                                                       F
                                                                                            T
                                              16 битная константа
                 8:
```

|    | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7    | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|-----|-----|------|------|----|---|---|---|---|---|
|    | 1  | 1  | 1  | 1  | 0  | 0  | s   | D   | 0    | 1    | 1  | 0 | 0 | 0 | 0 | 1 |
|    |    |    |    |    |    | 16 | бит | ная | конс | стан | та |   |   |   |   |   |
| 9: |    |    |    |    |    |    |     |     |      |      |    |   |   |   |   |   |
|    | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7    | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|    | 1  | 1  | 1  | 1  | 0  | 1  | s   | D   | 0    | 0    | 1  | s | Н | I | F | Т |
| 10 | :  |    |    |    |    |    |     |     |      |      |    |   |   |   |   |   |
| _  | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7    | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|    | 1  | 1  | 1  | 1  | 0  | 1  | s   | D   | 1    | 0    | 0  | 0 | 0 | 0 | 0 | 1 |

#### Выполнение

- 1:  $(src) (Smem) \rightarrow src$
- 2: (src) (Smem)  $\lt\lt$  TS  $\rightarrow$  src
- 3: (src) (Smem)  $<< 16 \rightarrow dst$
- 4: (src) (Smem)  $\lt\lt$  SHIFT  $\rightarrow$  dst
- 5: (src) (Xmem)  $\lt \lt$  SHFT  $\rightarrow$  src
- 6: (Xmem)  $<< 16 (Ymem) << 16 \rightarrow dst$
- 7: (src) lk  $\lt\lt$  SHFT  $\rightarrow$  dst
- 8: (src) lk << 16  $\rightarrow$  dst
- 9:  $(dst) (src) \ll SHIFT \rightarrow dst$
- 10:  $(dst) (src) \ll ASM \rightarrow dst$

## Статусные биты

Результат зависит от SXM и OVM.

Команда влияет на С и OVdst (или OVsrc, если dst = src).

Для Синтаксиса 3: если в результате вычитания возникает заём, то значение бита переноса C обнуляется. Для других синтаксисов C не зависит от результата.

#### Описание

Данная команда вычитает 16-разрядное значение из содержимого выбранного аккумулятора или из 16-разрядного операнда Xmem в режиме двойной адресации памяти данных. Вычитаемым 16-разрядным значением может быть одно из следующих:

- 1. содержимое операнда памяти данных одиночного доступа (Smem)
- 2. содержимое операнда памяти данных двойного доступа (Ymem)
- 3. 16-разрядный непосредственный операнд (#lk)
- 4. значение сдвига в src

Если dst задан, то команда сохраняет результат в dst. Если dst не определен, то команда сохраняет результат в src. Большинство вторых операндов может быть сдвинуто. При сдвиге влево:

- 1. значения младших битов сбрасываются;
- 2. старшие биты:
  - дополняются знаком, если SXM = 1
  - сбрасываются, если SXM = 0

При сдвиге вправо, старшие биты:

- 1. дополняются знаком, если SXM = 1
- 2. сбрасываются, если SXM = 0

Примечания:

Следующие синтаксисы ассемблируются в разные синтаксисы в соответствующих условиях.

1. Синтаксис 4: если dst = src и SHIFT = 0, код операции команды ассемблируется как Синтаксис 1.

Синтаксис 4: если dst = src, SHIFT ≤ 15, и режим косвенной адресации Smem включен в Xmem, то код операции команды ассемблируется как Синтаксис 1.

#### Слова

Синтаксисы 1, 2, 3, 5, 6, 9 и 10: 1 слово.

Синтаксисы 4, 7 и 8: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Циклы

Синтаксисы 1, 2, 3, 5, 6, 9 и 10: 1 цикл.

Синтаксисы 4, 7 и 8: 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Классы

Синтаксисы 1, 2, 3 и 5: Класс 3А.

Синтаксисы 1, 2 и 3: Класс 3В.

Синтаксис 4: Класс 4А. Синтаксис 4: Класс 4В.

Синтаксис 6: Класс 7. Синтаксисы 7 и 8: Класс 2.

Синтаксисы 9 и 10: Класс 1.

#### Пример 1

SUB \*AR1+, 14, A

|     | Перед | д командо | рй   |
|-----|-------|-----------|------|
| Α   | 00    | 0000      | 1200 |
| С   |       |           | x    |
| SXM |       |           | 1    |
| AR1 |       |           | 0100 |

|     | Пост | <b>те команд</b> і | əl   |
|-----|------|--------------------|------|
| Α   | FF   | FAC0               | 1200 |
| С   |      |                    | 0    |
| SXM |      |                    | 1    |
| AR1 |      |                    | 0101 |

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

| 0100h | 1500 |
|-------|------|
|       |      |

| 0100h | 1500 |
|-------|------|
| 0100h | 1500 |

## **Пример 2** SUB A, –8, В

|     | Пер | ед команд | цой  |
|-----|-----|-----------|------|
| Α   | 00  | 0000      | 1200 |
| В   | 00  | 0000      | 1800 |
| С   |     |           | x    |
| SXM |     |           | 1    |

|     | Пос | сле коман | ды   |
|-----|-----|-----------|------|
| Α   | 00  | 0000      | 1200 |
| В   | 00  | 0000      | 17EE |
| С   |     |           | 1    |
| SXM |     |           | 1    |

#### **Пример 3** SUB #12345, 8, A, B

|          |                                    | Перед | командо    | й       |                 | Посл                 | е команд          | Ы      |
|----------|------------------------------------|-------|------------|---------|-----------------|----------------------|-------------------|--------|
|          | Α _                                | 00    | 0000       | 1200    | Α [             | 00                   | 0000              | 1200   |
|          | В                                  | 00    | 0000       | 1800    | В               | FF                   | FFCF              | D900   |
|          | с [                                |       |            | x       | c [             |                      |                   | 0      |
|          | SXM                                |       |            | 1       | sхм [           |                      |                   | 1      |
| Пример 4 | ST B, *AR<br>  LD *AR4             |       |            |         |                 |                      |                   |        |
|          | Α                                  | 00    | 0000       | 001C    | Α               | 00                   | 4214              | 1414   |
|          | В                                  | FF    | 8421       | 1234    | В               | FF                   | 8421              | 1234   |
|          | SXM                                |       |            | 1       | SXM             |                      |                   | 1      |
|          | ASM                                |       |            | 1C      | ASM             |                      |                   | 1C     |
|          | AR2                                |       |            | 01FF    | AR2             |                      |                   | 01FE   |
|          | AR4                                |       |            | 0200    | AR4             |                      |                   | 0201   |
|          | Память да                          | нных  |            |         |                 |                      |                   |        |
|          | 01FFh                              |       |            | xxxx    | 01FFh           |                      |                   | F842   |
|          | 0200h                              |       |            | 8001    | 0200h           |                      |                   | 8001   |
| Пример 5 | ST A, *AR<br>  LD *AR4             |       |            |         |                 |                      |                   |        |
|          |                                    | Пе    | ред коман, | дой     |                 | Посл                 | пе команд         | Ы      |
|          | Α                                  | FF    | 8421       | 1234    | Α               | FF                   | 8421              | 1234   |
|          | Т                                  |       |            | 3456    | т               |                      |                   | 80FF   |
|          | ASM                                |       |            | 1       | ASM             |                      |                   | 1      |
|          | AR3                                |       |            | 0200    | AR3             |                      |                   | 0200   |
|          | AR4                                |       |            | 0100    | AR4             |                      |                   | 0100   |
|          | Память да                          | нных  |            |         |                 |                      |                   |        |
|          | 0200h                              |       |            | 0001    | 0200h           |                      |                   | 0842   |
|          | 0100h                              |       |            | 80FF    | 0100h           |                      |                   | 80FF   |
| Пример 6 | ST A, *AF<br>  LD *AR2<br>B пример | ?–, A | читает (   | операнд | -источник из яч | ейки <sub>т</sub> ам | ияти ука<br>Столи | занной |

# 20.3.122 SUBB Smem, src

**Операнды** src: A (аккумулятор A).

загрузку аккумулятора А.

AR2 до того, как ST осуществит запись в ту же ячейку. ST считывает операнд-источник аккумулятора A прежде, чем LD осуществляет

|                                             | Smei                       | m:                                                                                                                                                                                                                                                                       |      | •   | •     | пятор<br>памят | р В).<br>ги да   | нных     | х оді | иночі | НОГО | дост | упа.  |        |      |      |
|---------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-------|----------------|------------------|----------|-------|-------|------|------|-------|--------|------|------|
| Код                                         | 15                         | 14                                                                                                                                                                                                                                                                       | 13   | 12  | 11    | 10             | 9                | 8        | 7     | 6     | 5    | 4    | 3     | 2      | 1    | 0    |
| операции                                    | 0                          | 0                                                                                                                                                                                                                                                                        | 0    | 0   | 1     | 1              | 1                | D        | ı     | A     | A    | A    | A     | A      | A    | Α    |
| Выполнение<br>Статусные<br>биты<br>Описание | Резу<br>Кома<br>Эта<br>Ѕте | (src) – (Smem) – (логическое отрицание C) → src<br>Результат зависит от OVM и C.<br>Команда влияет на C и OVsrc.<br>Эта команда вычитает из src содержимое 16-разрядного операнда<br>Smem и логическую инверсию бита переноса C (то есть заём), без<br>расширения знака. |      |     |       |                |                  |          |       |       |      |      |       |        |      |      |
| Слова                                       |                            | ходи                                                                                                                                                                                                                                                                     | -    | -   |       |                | ово п<br>ı абсо  | •        |       |       |      |      |       |        | дрес | ации |
| Циклы                                       | с дли                      | ходи<br>инны                                                                                                                                                                                                                                                             | м см |     |       |                | икл пр<br>и абсо |          |       |       |      |      |       |        | дрес | ации |
| Классы                                      | Клас                       |                                                                                                                                                                                                                                                                          |      |     |       |                |                  |          |       |       |      |      |       |        |      |      |
| Пример 1                                    | Клас<br>SUBI               | _                                                                                                                                                                                                                                                                        |      |     |       |                |                  |          |       |       |      |      |       |        |      |      |
|                                             |                            |                                                                                                                                                                                                                                                                          |      |     |       | мандо          |                  | _        |       |       | 1    |      | После |        |      |      |
|                                             |                            | Α                                                                                                                                                                                                                                                                        |      | 00  | 00    | 000            | 0006             | <u> </u> |       |       | A    |      | FF    | FFF    | F    | FFFF |
|                                             |                            | С                                                                                                                                                                                                                                                                        |      |     |       |                | C                |          |       |       | С    |      |       |        |      | 0    |
|                                             |                            | DP                                                                                                                                                                                                                                                                       |      |     |       |                | 008              | 3        |       | ſ     | OP   |      |       |        |      | 800  |
|                                             | Памя                       | ть да                                                                                                                                                                                                                                                                    | нных |     |       |                |                  |          |       |       |      |      |       |        |      |      |
|                                             | (                          | )405h                                                                                                                                                                                                                                                                    |      |     |       |                | 0006             | 5        |       | 04    | 05h  |      |       |        |      | 0006 |
| Пример 2                                    | SUBI                       | 3 *AF                                                                                                                                                                                                                                                                    | R1+, | В   |       |                |                  |          |       |       |      |      |       |        |      |      |
|                                             |                            |                                                                                                                                                                                                                                                                          |      | Пер | ед ко | мандо          | Й                |          |       |       |      |      | После | э кома | анды |      |
|                                             |                            | В                                                                                                                                                                                                                                                                        |      | FF  | 80    | 000            | 0006             | 5        |       |       | В    |      | FF    | 800    | 0    | 0000 |
|                                             |                            | С                                                                                                                                                                                                                                                                        |      |     |       |                | 1                |          |       |       | с    |      |       |        |      | 1    |
|                                             |                            | OVM                                                                                                                                                                                                                                                                      |      |     |       |                | 1                |          |       | 0     | VM   |      |       |        |      | 1    |
|                                             |                            | AR1                                                                                                                                                                                                                                                                      |      |     |       |                | 0405             | 5        |       | Α     | R1   |      |       |        |      | 0406 |
|                                             | Памя                       | ть да                                                                                                                                                                                                                                                                    | нных |     |       |                |                  |          |       |       |      |      |       |        |      |      |
|                                             | (                          | 0405h                                                                                                                                                                                                                                                                    |      |     |       |                | 0006             |          |       | 04    | 05h  |      |       |        |      | 0006 |
|                                             |                            |                                                                                                                                                                                                                                                                          |      |     |       |                |                  |          |       |       |      |      |       |        |      |      |

## 20.3.123 SUBC Smem, src

**Операнды** Smem: Операнд памяти данных одиночного доступа.

src: A (аккумулятор A).

В (аккумулятор В).

| Код      |
|----------|
| операции |

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|   | 0  | 0  | 0  | 1  | 1  | 1  | 1 | S | ı | Α | Α | Α | Α | Α | Α | Α |

#### Выполнение

 $(src) - ((Smem) << 15) \rightarrow ALU output$ 

If ALU output ≥ 0

Then

 $((ALU output) << 1) + 1 \rightarrow src$ 

Else (src)  $<< 1 \rightarrow src$ 

# Статусные биты Описание

Выполнение команды зависит от SXM.

Команда влияет на С и OVsrc.

Данная команда вычитает из содержимого src 16-разрядный операнд памяти данных одиночного доступа Smem, сдвинутый влево на 15 бит. Если результат больше 0, он сдвигается на 1 бит влево, к результату добавляется 1, и результат сохраняется в src. В противном случае, данная команда сдвигает содержимое src на 1 бит влево и сохраняет результат в src.

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

- 1. если SXM = 1, делитель должен иметь нулевое значение значение старшего бита.
- 2. если SXM = 0, любое 16-разрядное значение делителя дает ожидаемый результат.

Делимое, находящееся в src, изначально должно быть положительным (значение бита 31 равно 0) и должено оставаться положительным после сдвига аккумулятора, которое происходит на первом этапе выполнения команды. Эта команда влияет на OVA или OVB (в зависимости от src) но не зависит от OVM; поэтому, src не создает положительных или отрицательных насыщений во время выполнения команды.

#### Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Циклы

1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Классы

Класс 3А.

Класс 3В.

#### Пример 1

SUBC 2, A

|            | Пере | д командо | рй   |       | Посл | іе команді | Ы    |
|------------|------|-----------|------|-------|------|------------|------|
| Α          | 00   | 0000      | 0004 | Α     | 00   | 0000       | 8000 |
| С          |      |           | x    | С     |      |            | 0    |
| DP         |      |           | 006  | DP    |      |            | 006  |
| Память дан | ных  |           |      |       |      |            |      |
| 0302h      |      |           | 0001 | 0302h |      |            | 0001 |

**Пример 2** RPT #15

SUBC \*AR1, B

|            | Пере | д командо | рй   |       | Посл | е команд | Ы    |
|------------|------|-----------|------|-------|------|----------|------|
| В          | 00   | 0000      | 0041 | В     | 00   | 0002     | 0009 |
| С          |      |           | x    | С     |      |          | 1    |
| AR1        |      |           | 1000 | AR1   |      |          | 1000 |
| Память дан | ных  |           |      |       |      |          |      |
| 1000h      |      |           | 0007 | 1000h |      |          | 0007 |

## 20.3.124 SUBS Smem, src

**Операнды** Smem: Операнд памяти данных одиночного доступа.

src: A (аккумулятор A).

В (аккумулятор В).

15 14 13 12 11 10 9 8 7 6 5 3 2 операции 0 0 0 0 1 0 1 S ī Α Α Α Α

Выполнение Статусные (src) – без знака (Smem) → src Изменяется под влиянием OVM.

биты

Влияет на С и OVsrc.

ONIE DINNEL HA C N OVSI

**Описание** Команда вычитает содержимое 16-разрядного операнда Smem из

содержания src. Smem считается 16-разрядным числом без знака

независимо от значения SXM. Результат сохраняется в src.

**Слова** 1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem.

**Циклы** 1 цикл.

Необходимо добавить 1 цикл при использовании косвенной адресации

с длинным смещением или абсолютной адресации с Smem

**Классы** Класс 3A.

Класс 3В.

Пример SUBS \*AR2-, В

|            | Пере | д командо | рй   |       | Посл | те команд | Ы    |
|------------|------|-----------|------|-------|------|-----------|------|
| В          | 00   | 0000      | 0002 | В     | FF   | FFFF      | 0FFC |
| С          |      |           | х    | С     |      |           | 0    |
| AR2        |      |           | 0100 | AR2   |      |           | 00FF |
| Память дан | ных  |           |      |       |      |           |      |
| 0100h      |      |           | F006 | 0100h |      |           | F006 |

Α

#### 20.3.125 TRAP K

Операнды

 $0 \le K \le 31$ 

Код

операции

| _1 | 5 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|---|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | 1 | 1  | 1  | 1  | 0  | 1  | 0 | 0 | 1 | 1 | 0 | K | K | K | K | K |

Выполнение

(SP) -  $1 \rightarrow SP$ 

 $(PC) + 1 \rightarrow TOS$ 

Вектор прерывания, определяемый  $K \to PC$ 

Статусные биты Описание Не используются.

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

Данная команда записывает значение PC + 1 в ячейку памяти данных, адресованную SP. Это позволяет реализовать возврат процессора на прерванную программу после обработки прерывания путем загрузки счетчика команд значением из ячейки памяти данных, адресованную SP. Команда является немаскируемой и не зависит от INTM, а также не влияет на INTM.

Примечание – Данная команда не повторяемая.

Слова Циклы Классы Пример 1 1 слово. 3 цикла.

5 цикла. Класс 35. TRAP 10h

|            | Перед командой |       | После команды |
|------------|----------------|-------|---------------|
| PC         | 1233           | PC    | FFC0          |
| SP         | 03FF           | SP    | 03FE          |
| Память дан | ных            |       |               |
| 03FEh      | 9653           | 03FEh | 1234          |

#### 20.3.126 WRITA Smem

Операнды

Smem: операнд памяти данных одиночного доступа.

Код операции

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | ı | Α | Α | Α | Α | Α | Α | Α |

### Выполнение

 $A \rightarrow PAR$  If (RC)  $\neq 0$ 

Then

 $(Smem) \rightarrow (Pmem addressed by PAR)$  $(PAR) + 1 \rightarrow PAR$ 

 $(RC) - 1 \rightarrow RC$ 

Else

 $(Smem) \rightarrow (Pmem addressed by PAR)$ 

## Статусные биты Описание

Не используются.

Данная команда передает слово из ячейки памяти данных, указанной Smem, в ячейку памяти программ. Адрес памяти программ определяется аккумулятором A(15-0).

Данная команда может быть использована как повторяющаяся для перемещения последовательных слов (с использованием косвенной адрессации) в непрерывное пространство памяти программ, адресованное PAR, путем инкрементирования PAR. Исходное значение устанавливается 16-тью младшими битами аккумулятора А. Блоки источника и приемника не обязательно должны быть встроенными или располагаться вне кристалла.

Как только конвейер повторений начинает работу, команда становится одноцикловой. Содержимое аккумулятора A не зависит от данной команды.

Слова

1 слово.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

Циклы

5 циклов.

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

Классы

Класс 26А.

Класс 26В.

Пример

WRITA 5

|            | Пере  | д командо | рй   | После команды |    |      |      |  |
|------------|-------|-----------|------|---------------|----|------|------|--|
| Α          | 00    | 0000      | 0257 | Α             | 00 | 0000 | 0257 |  |
| DP         |       |           | 032  | DP            |    |      | 032  |  |
| Память про | грамм |           |      |               |    |      |      |  |
| 0257h      |       |           | 0306 | 0257h         |    |      | 4339 |  |
| Память дан | ных   |           |      |               |    |      |      |  |
| 1005h      |       |           | 4339 | 1005h         |    |      | 4339 |  |

## 20.3.127 XC n, cond [, cond [, cond ] ]

#### Операнды

n = 1 or 2

В таблице перечислены условия (операнд условий) для данной команды.

| Операнд<br>условий | Описание                           | Код<br>условия | Операнд<br>условий | Описание                            | Код<br>условия |
|--------------------|------------------------------------|----------------|--------------------|-------------------------------------|----------------|
| BIO                | $\overline{	ext{BIO}}_{	ext{Low}}$ | 0000 0011      | NBIO               | $\overline{	ext{BIO}}_{	ext{high}}$ | 0000 0010      |
| С                  | C=1                                | 0000 1100      | С                  | C=0                                 | 0000 1000      |
| TC                 | TC=1                               | 0011 0000      | TC                 | TC=0                                | 0010 0000      |
| AEQ                | (A) = 0                            | 0100 0101      | BEQ                | (B) = 0                             | 0100 1101      |
| ANEQ               | $(A) \neq 0$                       | 0100 0100      | BNEQ               | (B) ≠ 0                             | 0100 1100      |
| AGT                | (A) > 0                            | 0100 0110      | BGT                | (B) > 0                             | 0100 1110      |
| AGEQ               | $(A) \ge 0$                        | 0100 0010      | BGEQ               | (B) ≥ 0                             | 0100 1010      |
| ALT                | (A) < 0                            | 0100 0011      | BLT                | (B) < 0                             | 0100 1011      |
| ALEQ               | $(A) \leq 0$                       | 0100 0111      | BLEQ               | (B) ≤ 0                             | 0100 1111      |
| AOV                | Α                                  | 0111 0000      | BOV                | В                                   | 0111 1000      |
|                    | переполнение                       |                |                    | переполнение                        |                |
| ANOV               | А отсутствие                       | 0110 0000      | BNOV               | В отсутствие                        | 0110 1000      |
|                    | переполнения                       |                |                    | переполнения                        |                |
| UNC                | Безусловный                        | 0000 0000      |                    |                                     |                |

## Код операции

| _ | 15 | 14 | 13 | 12 | 11 | 10        | 9 | 8 | 7 | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|----|----|-----------|---|---|---|-----|---|---|---|---|---|---|
|   | 1  | 1  | 1  | 1  | 1  | 1         | N | 1 | С | С   | С | С | С | С | С | С |
|   |    |    |    |    |    | Синтаксис |   |   |   | Код | n |   |   |   |   |   |
|   |    |    |    |    |    |           | 1 |   |   | 0   |   |   |   |   |   |   |

1

#### Выполнение

If (cond)

Then

Next n instructions are executed

Else

Execute NOP for next n instructions

2

## Статусные биты Описание

Не используются.

Выполнение этой команды зависит от значения n и выбранных условий:

- 1. если n = 1 и условие(я) удовлетворяется, то выполняется однословная команда, следующая за данной командой.
- 2. если n = 2 и условие(я) удовлетворяется, то выполняется одна двухсловная или две однословные команды, следующие за данной командой.
- 3. если условие(я) не удовлетворяется, то 1 или 2 инструкции, в зависимости от значения n, следующие за данной инструкцией, не выполняются.

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

1. **Группа 1:** можно выбрать не более двух условий. Кажде из этих условий должно принадлежать различным категориям (категория А

или В); нельзя выбрать два условия из одной категории. Например, можно проверить EQ и OV одновременно, но нельзя проверить одновременно GT и NEQ. Аккумулятор должен быть одним для обоих условий; нельзя осуществлять проверку условий для двух аккумуляторов в рамках одной команды. Например, можно проверить AGT и AOV одновременно, но нельзя проверить одновременно AGT и BOV.

2. Группа 2: можно выбрать не более трех условий. Каждое из этих условий должно принадлежать разным категориям (категория А, В или С); нельзя выбрать два условия из одной категории. Например, можно осуществить проверку TC, C и BIO одновременно, но нельзя одновременно проверять NTC, C и NC.

Условия для данной команды

| Груг                                | ıпа 1       |             | Группа 2    |             |  |  |  |  |  |
|-------------------------------------|-------------|-------------|-------------|-------------|--|--|--|--|--|
| Категория А                         | Категория В | Категория А | Категория В | Категория С |  |  |  |  |  |
| EQ<br>NEQ<br>LT<br>LEQ<br>GT<br>GEO | OV<br>NOV   | TC<br>NTC   | C<br>NC     | BIO<br>NBIO |  |  |  |  |  |

Эта команда и два слова команды, следующие за ней, непрерываемые.

Примечание – Условия тестируются до того, как команда выполнится. Поэтому, если одна двухсловная или две однословные команды изменяют анализируемые условия, то это никак не повлияет на выполнение данной команды.

Данная команда не повторяемая.

Слова Циклы Классы Пример

1 слово. 1 цикл. Класс 1. XC 1, ALEQ

MAR \*AR1+

ADD A, DAT100

| Перед командой |    |      |      |     | После команды |      |      |  |
|----------------|----|------|------|-----|---------------|------|------|--|
| Α              | FF | FFFF | FFFF | Α   | FF            | FFFF | FFFF |  |
| AR1            |    |      | 0032 | AR1 |               |      | 0033 |  |

#### 20.3.128 XOR

1: XOR Smem, src

2: **XOR** #lk [, SHFT], src [, dst ]

3: **XOR** #lk, 16, src [, dst ]

4: **XOR** src [, SHIFT] [, dst ]

**Операнды** src, dst: A (аккумулятор A).

В (аккумулятор В).

Smem: Операнд памяти данных одиночного доступа.

0 ≤ SHFT ≤ 15 -16 ≤ SHIFT ≤ 15 0 ≤ lk ≤ 65 535

### Код операции 1:

| 15  | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|-----|-----|-----|------|----|---|---|---|---|---|
| 0   | 0  | 0  | 1  | 1  | 1  | 0   | S   | ı   | Α    | Α  | Α | Α | Α | Α | Α |
| 2:  |    |    |    |    |    |     |     |     |      |    |   |   |   |   |   |
| _15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1   | 1  | 1  | 1  | 0  | 0  | s   | D   | 0   | 1    | 0  | 1 | s | Н | F | т |
|     |    |    |    |    | 16 | бит | ная | кон | стан | та |   |   |   |   |   |
| 3:  |    |    |    |    |    |     |     |     |      |    |   |   |   |   |   |
| 15  | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |
| 1   | 1  | 1  | 1  | 0  | 0  | s   | D   | 0   | 1    | 1  | 0 | 0 | 1 | 0 | 1 |
|     |    |    |    |    | 16 | бит | ная | кон | стан | та |   |   |   |   |   |
| 4:  |    |    |    |    |    |     |     |     |      |    |   |   |   |   | • |
| 15  | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6    | 5  | 4 | 3 | 2 | 1 | 0 |

#### Выполнение

1: (Smem) XOR (src)  $\rightarrow$  src

2:  $lk \ll SHFT XOR (src) \rightarrow dst$ 

3:  $lk \ll 16 XOR (src) \rightarrow dst$ 

Не используются.

4: (src) << SHIFT XOR (dst)  $\rightarrow$  dst

0

0

## Статусные

биты

### Описание

Эта команда выполняет операцию исключающего ИЛИ над содержанием ячейки памяти данных Smem (со сдвигом, указанным в команде) и содержимым выбранного аккумулятора, и сохраняет результат в dst или src, как указано. При сдвиге влево значения младших битов сбрасываются, а старшие биты не расширяются

S

D

0

S

Н

F

Т

знаком. При сдвиге вправо знак не расширяется.

### Слова Синтаксисы 1 и 4: 1 слово.

1

Синтаксисы 2 и 3: 2 слова.

Необходимо добавить 1 слово при использовании косвенной адресации с длинным смещением или абсолютной адресации с

Smem.

#### Циклы Синтаксисы 1 и 4: 1 цикл.

Синтаксисы 2 и 3: 2 цикла.

## Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

Необходимо добавить 1 цикл при использовании косвенной адресации с длинным смещением или абсолютной адресации с Smem.

#### Классы

Синтаксис 1: Класс 3A. Синтаксис 1: Класс 3B. Синтаксисы 2 и 3: Класс 2. Синтаксис 4: Класс 1.

## Пример 1

XOR \*AR3+, A

|     | i iepe, | д командо | N    |
|-----|---------|-----------|------|
| Α   | 00      | 00FF      | 1200 |
| AR3 |         |           | 0100 |

| после команды |    |      |      |  |  |  |  |  |
|---------------|----|------|------|--|--|--|--|--|
| Α             | 00 | 00FF | 0700 |  |  |  |  |  |
| AR3           |    |      | 0101 |  |  |  |  |  |

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

| 0100h 15 | 500 |
|----------|-----|
|----------|-----|

| 0100h | 1500 |
|-------|------|

## Пример 2

XOR A, +3, B

| Перед командой |    |      |      |  |  |  |  |  |  |  |
|----------------|----|------|------|--|--|--|--|--|--|--|
| Α [            | 00 | 0000 | 1200 |  |  |  |  |  |  |  |
| в              | 00 | 0000 | 1800 |  |  |  |  |  |  |  |

|   | Посл | те команд | Ы    |
|---|------|-----------|------|
| Α | 00   | 0000      | 1200 |
| В | 00   | 0000      | 8800 |

### 20.3.129 XORM #lk, Smem

**Операнды** Smem: операнд памяти данных одиночного доступа.

 $0 \le lk \le 65535$ 

Код операции

 15
 14
 13
 12
 11
 10
 9
 8
 7
 6
 5
 4
 3
 2
 1
 0

 0
 1
 1
 0
 1
 0
 1
 A
 A
 A
 A
 A
 A
 A

Выполнение

Ik XOR (Smem)  $\rightarrow$  Smem

Статусные

Не используются.

биты

Описание Эта команда выполняет операцию исключающего ИЛИ над

содержанием ячейки памяти данных Smem и 16-разрядной

константой lk. Результат записывается в Smem.

Примечание – Данная команда не повторяется.

Слова 2 слова.

Необходимо добавить 1 слово при использовании косвенной

адресации с длинным смещением или абсолютной адресации с

Smem.

Циклы 2 цикла.

Необходимо добавить 1 цикл при использовании косвенной

адресации с длинным смещением или абсолютной адресации с

Smem.

**Классы** Класс 18A.

Класс 18В.

**Пример** XORM 0404h, \*AR4—

|               | Перед командой |       | После команды |  |  |  |  |
|---------------|----------------|-------|---------------|--|--|--|--|
| AR4           | 0100           | AR4   | 00FF          |  |  |  |  |
| Память данных |                |       |               |  |  |  |  |
| 0100h         | 4444           | 0100h | 4040          |  |  |  |  |

## 21 Контроллер McBSP (DSP)

#### McBSP обеспечивает:

- полнодуплексный режим работы;
- буферное FIFO на 8 слов по проему и передаче;
- независимую кадровую и битовую синхронизация по приему и передаче;
- возможность прямого подключения к стандартизованным промышленным кодекам, аналоговым интерфейсным приборам, последовательным ЦАП и АЦП приборам и прочим последовательным устройствам;
- возможность выбора между внешней и внутренними источниками кадровой и тактовой синхронизации.

#### Также в McBSP имеются следующие возможности:

- прямое подключение к:
  - T1/E1;
  - MVIP и ST-BUS совместимые устройства, включая:
  - формирователи MVIP;
  - о формирователи Н.100;
  - о формирователи SCSA.
  - IOM-2 совместимые устройства;
  - АС97 совместимые устройства (обеспечивается необходимая многофазная синхронизация);
  - IIS совместимые устройства;
  - SPI устройства.
- многоканальные прием и передача до 128 каналов;
- произвольная длина слова от 4х до 32х бит включительно;
- компадирование/декомпадирование по m- и A-законам;
- реверсивный порядок передачи бит в слове (MSB или LSB);
- программируемая полярность для кадровой и битовой синхронизации;
- программируемые битовая и кадровая синхронизации;
- частота битовой синхронизации до 50 МГц.

### 21.1 Общее описание McBSP

С точки зрения подключения McBSP состоит из блока данных и блока управления. Структурно McBSP разделен на следующие блоки:

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

Внешние устройства подключаются через последовательные 3-проводные интерфейсы независимые для приемника и передатчика.

BSPx\_TFR – сигнал кадровой синхронизации передатчика

BSPx TCLK – сигнал битовой синхронизации передатчика

BSPx\_TX – сигнал данных передатчика

BSPx\_RFR – сигнал кадровой синхронизации приемника

BSPx\_RCLK – сигнал битовой синхронизации приемника

BSPx\_RX – сигнал данных приемника

BSPx\_RTFR – сигнал кадровой синхронизации совмещенный для приемника и передатчика

BSPx\_RTCLK – сигнал битовой синхронизации совмещенный для приемника и передатчика

Для обмена данными с процессором в McBSP присутствует параллельный интерфейс.

ЦП или DMA-контроллер читают принятые данные через регистр принимаемых данных (DRRL и DDRH) и записывает данные на передачу через регистр передаваемых данных (DXRL и DXRH). Данные записанные в DXRL и DXRH проходя через FIFO передатчика XBR выдвигаются через вывод DX из сдвигового регистра передатчика XSR. Аналогично данные принимаемые через вывод DR задвигаются в сдвиговый регистр приемника RSR откуда попадают в FIFO приемника RBR, далее копируются в DRRL и DRRH и могут быть считаны ЦП или DMA-контроллером. Данный способ позволяет осуществлять одновременный прием и передачу данных и обмен с управляющим устройством.

Обмен данными между McBSP и ЦП или DMA-контроллером может осуществляться байтами (8 бит) словами (16 бит), двойными словами (32 бит) (выбирается управляющим устройством), при этом выбор записывается слово атомарно (единым словом) или набирается из слов меньшего размера управляется через регистры управления McBSP.

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

Кроме того, в McBSP присутствуют статусные выводы для информирования ЦП или DMA-контроллера о различных событиях и посредством программируемых выводов прерываний, независимых для приемника и передатчика.

## 21.2 Регистры McBSP

## 21.2.1 McBSP1

Таблица 21-1 – Регистр McBSP1

| Адрес RISC  | Адрес<br>DSP | Значение<br>SPSA | Название | Описание                    |
|-------------|--------------|------------------|----------|-----------------------------|
| 0x3000_0040 | 0x0020       | -                | DRRL     | Регистр приемника           |
|             |              |                  |          | (младшее слово)             |
| 0x3000_0042 | 0x0021       | -                | DRRH     | Регистр приемника           |
|             |              |                  |          | (старшее слово)             |
| 0x3000_0044 | 0x0022       | -                | DXRL     | Регистр передатчика         |
|             |              |                  |          | (младшее слово)             |
| 0x3000_0046 | 0x0023       | -                | DXRH     | Регистр передатчика         |
|             |              |                  |          | (старшее слово)             |
| 0x3000_0048 | 0x0024       | -                | SPSA*    | Регистр номера управляющего |
|             |              |                  |          | регистра                    |
| 0x3000_004C | 0x0026       | 0x00             | SPCRL    | Регистр общего управления   |
| 0x3000_004C | 0x0026       | 0x01             | SPCRH    | Регистр общего управления   |
| 0x3000_004C | 0x0026       | 0x02             | RCRL     | Регистр управления          |
|             |              |                  |          | приемником                  |
| 0x3000_004C | 0x0026       | 0x03             | RCRH     | Регистр управления          |
|             |              |                  |          | приемником                  |
| 0x3000_004C | 0x0026       | 0x04             | XCRL     | Регистр управления          |
|             |              |                  |          | передатчиком                |
| 0x3000_004C | 0x0026       | 0x05             | XCRH     | Регистр управления          |
|             |              |                  |          | передатчиком                |
| 0x3000_004C | 0x0026       | 0x06             | SRGRL    | Регистр управления          |
|             |              |                  |          | генераторами кадровой и     |
|             |              |                  |          | битовой синхронизации       |
| 0x3000_004C | 0x0026       | 0x07             | SRGRH    | Регистр управления          |
|             |              |                  |          | генераторами кадровой и     |
|             |              |                  |          | битовой синхронизации       |
| 0x3000_004C | 0x0026       | 0x08             | MCRL     | Регистр управления          |
|             |              |                  |          | многоканальными режимами    |
|             |              |                  |          | приемника                   |
| 0x3000_004C | 0x0026       | 0x09             | MCRH     | Регистр управления          |
|             |              |                  |          | многоканальными режимами    |
|             |              |                  |          | передатчика                 |
| 0x3000_004C | 0x0026       | 0x0A             | RCERL    | Регистр маски приемника     |
| 0x3000_004C | 0x0026       | 0x0B             | RCERH    | Регистр маски приемника     |
| 0x3000_004C | 0x0026       | 0x0C             | XCERL    | Регистр маски передатчика   |
| 0x3000_004C | 0x0026       | 0x0D             | XCERH    | Регистр маски передатчика   |
| 0x3000_004C | 0x0026       | 0x0E             | PCR      | Регистр управления выводами |
| 0x3000_004C | 0x0026       | 0x0F             | SPSR     | Регистр состояния           |

## 21.2.2 McBSP2

Таблица 21-2 – Регистр McBSP2

| Адрес RISC  | Адрес<br>DSP     | Значение<br>SPSA | Название | Описание                                            |  |
|-------------|------------------|------------------|----------|-----------------------------------------------------|--|
| 0x3000 0050 | 0x0028           | -                | DRRL     | Регистр приемника                                   |  |
| 00000_0000  | 0,0020           |                  | DIVICE   | (младшее слово)                                     |  |
| 0x3000 0052 | 0x0029           | _                | DRRH     | Регистр приемника                                   |  |
| 0X0000_0002 | 0,0020           |                  | Diam     | (старшее слово)                                     |  |
| 0x3000_0054 | 0x002A           | -                | DXRL     | Регистр передатчика                                 |  |
|             | 07100_71         |                  |          | (младшее слово)                                     |  |
| 0x3000_0056 | 0x002B           | -                | DXRH     | Регистр передатчика                                 |  |
|             |                  |                  |          | (старшее слово)                                     |  |
| 0x3000_0058 | 0x002C           | -                | SPSA*    | Регистр номера управляющего                         |  |
| _           |                  |                  |          | регистра                                            |  |
| 0x3000_005C | 0x002E           | 0x00             | SPCRL    | Регистр общего управления                           |  |
| 0x3000_005C | 0x002E           | 0x01             | SPCRH    | Регистр общего управления                           |  |
| 0x3000_005C | 0x002E           | 0x02             | RCRL     | Регистр управления                                  |  |
|             |                  |                  |          | приемником                                          |  |
| 0x3000_005C | 0x002E           | 0x03             | RCRH     | Регистр управления                                  |  |
|             |                  |                  |          | приемником                                          |  |
| 0x3000_005C | 0x002E           | 0x04             | XCRL     | Регистр управления                                  |  |
|             |                  |                  |          | передатчиком                                        |  |
| 0x3000_005C | 0x002E           | 0x05             | XCRH     | Регистр управления                                  |  |
|             |                  |                  |          | передатчиком                                        |  |
| 0x3000_005C | 0x002E           | 0x06             | SRGRL    | Регистр управления                                  |  |
|             |                  |                  |          | генераторами кадровой и                             |  |
|             |                  |                  |          | битовой синхронизации                               |  |
| 0x3000_005C | 0x002E           | 0x07             | SRGRH    | Регистр управления                                  |  |
|             |                  |                  |          | генераторами кадровой и                             |  |
| 0.0000.0050 | 2 2225           | 0.00             | 14001    | битовой синхронизации                               |  |
| 0x3000_005C | 0x002E           | 0x08             | MCRL     | Регистр управления                                  |  |
|             |                  |                  |          | многоканальными режимами                            |  |
| 0,2000 0050 | 0,000            | 0,,00            | MCDII    | приемника                                           |  |
| 0x3000_005C | 0x002E           | 0x09             | MCRH     | Регистр управления                                  |  |
|             |                  |                  |          | многоканальными режимами                            |  |
| 0x3000 005C | 0×002E           | ΟνΟΛ             | RCERL    | передатчика                                         |  |
| 0x3000_005C | 0x002E<br>0x002E | 0x0A<br>0x0B     | RCERH    | Регистр маски приемника                             |  |
| 0x3000_005C | 0x002E           | 0x0C             | XCERL    | Регистр маски приемника Регистр маски передатчика   |  |
| 0x3000_005C | 0x002E           | 0x0C             | XCERH    | Регистр маски передатчика Регистр маски передатчика |  |
| 0x3000_005C | 0x002E           | 0x0E             | PCR      | Регистр управления выводами                         |  |
| 0x3000_005C | 0x002E           | 0x0F             | SPSR     | Регистр управления выводами                         |  |
| 03000_0000  | リオリリム            | UXUF             | SFSK     | гелистр состояния                                   |  |

## 21.2.3 McBSP3

Таблица 21-3 – Регистр McBSP3

| Адрес RISC  | Адрес<br>DSP | Значение<br>SPSA | Название | Описание                    |
|-------------|--------------|------------------|----------|-----------------------------|
| 0x3000_0060 | 0x0030       | -                | DRRL     | Регистр приемника           |
|             |              |                  |          | (младшее слово)             |
| 0x3000_0062 | 0x0031       | -                | DRRH     | Регистр приемника           |
|             |              |                  |          | (старшее слово)             |
| 0x3000_0064 | 0x0032       | -                | DXRL     | Регистр передатчика         |
|             |              |                  |          | (младшее слово)             |
| 0x3000_0066 | 0x0033       | 1                | DXRH     | Регистр передатчика         |
|             |              |                  |          | (старшее слово)             |
| 0x3000_0068 | 0x0034       | -                | SPSA*    | Регистр номера управляющего |
|             |              |                  |          | регистра                    |
| 0x3000_006C | 0x0036       | 0x00             | SPCRL    | Регистр общего управления   |
| 0x3000_006C | 0x0036       | 0x01             | SPCRH    | Регистр общего управления   |
| 0x3000_006C | 0x0036       | 0x02             | RCRL     | Регистр управления          |
|             |              |                  |          | приемником                  |
| 0x3000_006C | 0x0036       | 0x03             | RCRH     | Регистр управления          |
|             |              |                  |          | приемником                  |
| 0x3000_006C | 0x0036       | 0x04             | XCRL     | Регистр управления          |
|             |              |                  |          | передатчиком                |
| 0x3000_006C | 0x0036       | 0x05             | XCRH     | Регистр управления          |
|             |              |                  |          | передатчиком                |
| 0x3000_006C | 0x0036       | 0x06             | SRGRL    | Регистр управления          |
|             |              |                  |          | генераторами кадровой и     |
|             |              |                  |          | битовой синхронизации       |
| 0x3000_006C | 0x0036       | 0x07             | SRGRH    | Регистр управления          |
|             |              |                  |          | генераторами кадровой и     |
|             |              |                  |          | битовой синхронизации       |
| 0x3000_006C | 0x0036       | 0x08             | MCRL     | Регистр управления          |
|             |              |                  |          | многоканальными режимами    |
|             |              |                  |          | приемника                   |
| 0x3000_006C | 0x0036       | 0x09             | MCRH     | Регистр управления          |
|             |              |                  |          | многоканальными режимами    |
|             |              |                  |          | передатчика                 |
| 0x3000_006C | 0x0036       | 0x0A             | RCERL    | Регистр маски приемника     |
| 0x3000_006C | 0x0036       | 0x0B             | RCERH    | Регистр маски приемника     |
| 0x3000_006C | 0x0036       | 0x0C             | XCERL    | Регистр маски передатчика   |
| 0x3000_006C | 0x0036       | 0x0D             | XCERH    | Регистр маски передатчика   |
| 0x3000_006C | 0x0036       | 0x0E             | PCR      | Регистр управления выводами |
| 0x3000_006C | 0x0036       | 0x0F             | SPSR     | Регистр состояния           |

## 21.3 Конфигурирование последовательного порта

Настройка последовательного порта осуществляется через регистры управления SPCR и PCR. В них содержатся биты управления, а также биты состояния McBSP.

Также регистр PCR предназначен для управления назначением выводов McBSP.

21.3.1 SPCRH

Таблица 21-4 - Регистр SPCRH

| 15     | 14         | 13 | 12 | 11    | 10            | 9      | 8      |
|--------|------------|----|----|-------|---------------|--------|--------|
| FREE   | XINTM[2:0] |    |    | XEVN. | T1[1:0]       | XEVNT  | [0:1]0 |
| R/W,+0 | R/W,+0     |    |    | R/W   | V, <b>+</b> 0 | R/W,+0 |        |
| 7      | 6          | 5  | 4  | 3     | 2             | 1      | 0      |
| SOFT   | RINTM[2:0] |    |    | REVN  | T1[1:0]       | REVNT  | 0[1:0] |
| R/W,+0 | R/W,+0     |    |    | R/V   | V,+0          | R/W,   | +0     |

Таблица 21-5 - Описание бит регистра SPCRH

| Nº       | Функциональное  | Расшифровка функционального имени бита, краткое    |
|----------|-----------------|----------------------------------------------------|
| бита     | имя бита        | описание назначения и принимаемых значений         |
| 15       | FREE            | Режим FreeRun (DEBUG Mode)                         |
|          |                 | 0 – Режим FreeRun отключен                         |
|          |                 | 1 – Режим FreeRun включен                          |
| 1412     | XINTM[2:0]      | Выбор источника прерывания передатчика             |
|          |                 | 000 – XRDY                                         |
|          |                 | 001 – Начало блока данных (XSOB)                   |
|          |                 | 010 – Окончание блока данных (ХЕОВ)                |
|          |                 | 011 – Ошибка синхронизации передатчика XSYNCERR    |
|          |                 | 100 – FIFO передатчика полупуст                    |
|          |                 | 101 – FIFO передатчика полуполон                   |
|          |                 | 110 – FIFO передатчика пуст                        |
| 44 40    | \/E\/\\IT4[4_0] | 111 – FIFO передатчика полон                       |
| 1110     | XEVNT1[1:0]     | Выбор источника события передатчика                |
|          |                 | 00 – XRDY                                          |
|          |                 | 01 – FIFO передатчика полуполон                    |
|          |                 | 10 – FIFO передатчика почти полон                  |
| 0 0      | VEV/NITO(4-01   | 11 – FIFO передатчика полон                        |
| 98       | XEVNT0[1:0]     | Выбор источника события передатчика                |
|          |                 | 00 – XRDY                                          |
|          |                 | 01 – FIFO передатчика полупуст                     |
|          |                 | 10 – FIFO передатчика не почти полон               |
| 7        | SOFT            | 11 – FIFO передатчика не полон                     |
| /        | SUFI            | Режим Halt (DEBUG Mode)<br>0 – Режим Halt отключен |
|          |                 | 0 – Режим нап отключен<br>1 – Режим Halt включен   |
| 64       | DINITM(0.01     |                                                    |
| 04       | RINTM[2:0]      | Выбор источника прерывания приемника<br>000 – RRDY |
|          |                 | 001 – Начало блока данных (RSOB)                   |
|          |                 | 010 – Окончание блока данных (REOB)                |
|          |                 | 011 – Ошибка синхронизации приемника RSYNCERR      |
|          |                 | 100 – FIFO приемника полупуст                      |
|          |                 | 101 – FIFO приемника полуполон                     |
| <u> </u> |                 |                                                    |

|    |             | 110 – FIFO приемника пуст           |
|----|-------------|-------------------------------------|
|    |             | 111 – FIFO приемника полон          |
| 32 | REVNT1[1:0] | Выбор источника события передатчика |
|    |             | 00 – RRDY                           |
|    |             | 01 – FIFO приемника полуполон       |
|    |             | 10 – FIFO приемника почти полон     |
|    |             | 11 – FIFO приемника полон           |
| 10 | REVNT0[1:0] | Выбор источника события приемника   |
|    |             | 00 – RRDY                           |
|    |             | 01 – FIFO приемника полупуст        |
|    |             | 10 – FIFO приемника не почти полон  |
|    |             | 11 – FIFO приемника не полон        |

## 21.3.2 SPCRL

## Таблица 21-6 - Регистр SPCRL

| 15     | 14     | 13          | 12     | 11     | 10      | 9      | 8      |
|--------|--------|-------------|--------|--------|---------|--------|--------|
| DXENA  | LW_ACC | JBOUND[1:0] |        | XJUS   | ST[1:0] | RJUS   | T[1:0] |
| R/W,+0 | R/W,+0 | R/W         | R/W,+1 |        | V,+0    | R/W,+0 |        |
| 7      | 6      | 5           | 4      | 3      | 2       | 1      | 0      |
| DLB    | ABIS   | CLKSTP[1:0] |        | nXRST  | nRRST   | nFGRST | nCGRST |
| R/W,+0 | R/W,+0 | R/W,+0      |        | R/W,+0 | R/W,+0  | R/W,+0 | R/W,+0 |

## Таблица 21-7 – Описание бит регистра SPCRL

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                         |
|------|----------------|-------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                              |
| 15   | DXENA          | Выключатель DX                                                          |
|      |                | 0 – Выключатель DX выключен                                             |
|      |                | 1 – Выключатель DX включен                                              |
| 14   | LW_ACC         | Способ записи/чтения данных                                             |
|      |                | 0 – Слово считается считанным/записанным после любого                   |
|      |                | чтения/записи                                                           |
|      |                | 1 – Слово считается считанным/записанным когда                          |
|      |                | считаны/записаны все байты                                              |
| 1312 | JBOUND[1:0]    | Граница выравнивания байтов/слов                                        |
|      |                | 00 – 1 байт                                                             |
|      |                | 01 – 2 байта                                                            |
|      |                | 1х – 4 байта                                                            |
| 1110 | XJUST[1:0]     | Выравнивание передаваемых данных                                        |
|      |                | 0х – Выравнивание по правой границе                                     |
|      |                | 1х – Выравнивание по левой границе (в соответствии с                    |
|      |                | JBOUND)                                                                 |
| 98   | RJUST          | 00 – Выравнивание по правой границе                                     |
|      |                | 01 – Выравнивание по правой границе с расширением знака                 |
|      |                | (MSB)                                                                   |
|      |                | 10 – Выравнивание по левой границе (в соответствии с                    |
|      |                | JBOUND) с заполнением нулями старших и младших                          |
|      |                | разрядов                                                                |
|      |                | 11 – Выравнивание по левой границе (в соответствии с                    |
|      |                | JBOUND) с расширением знака (MSB) и заполнением нулями младших разрядов |
|      |                | младшил разридов                                                        |

| 7  | DLB         | Режим КЗ                                                |
|----|-------------|---------------------------------------------------------|
|    |             | 0 – Режим КЗ выключен (штатный режим работы)            |
|    |             | 1 – Режим КЗ включен                                    |
| 6  | ABIS        | Режим A-bis                                             |
|    |             | 0 – Режим A-bis отключен                                |
|    |             | 1 – Режим A-bis включен                                 |
| 54 | CLKSTP[1:0] | Режим останова сигнала битовой синхронизации            |
|    |             | 0х – Режим останова сигнала битовой синхронизации       |
|    |             | отключен                                                |
|    |             | (штатный режим работы для не-SPI режима)                |
|    |             | 10 – Режим работы с остановом сигнала битовой           |
|    |             | синхронизации без задержки                              |
|    |             | 11 – Режим работы с остановом сигнала битовой           |
|    |             | синхронизации с задержкой сигнала синхронизации на      |
|    |             | полпериода                                              |
| 3  | nXRST       | Сброс передатчика                                       |
|    |             | 0 – Передатчик в состоянии сброса                       |
|    |             | 1 – Передатчик в штатном режиме работы                  |
| 2  | nRRST       | Сброс приемника                                         |
|    |             | 0 – Приемник в состоянии сброса                         |
|    |             | 1 – Приемник в штатном режиме работы                    |
| 1  | nFGRST      | Сброс генератора кадровой синхронизации                 |
|    |             | 0 – Генератор кадровой синхронизации в состоянии сброса |
|    |             | 1 – Генератор кадровой синхронизации в штатном режиме   |
|    |             | работы                                                  |
| 0  | nCGRST      | Сброс генератора битовой синхронизации                  |
|    |             | 0 – Генератор битовой синхронизации в состоянии сброса  |
|    |             | 1 – Генератор битовой синхронизации в штатном режиме    |
|    |             | работы                                                  |

## 21.3.3 SPSRH

# Таблица 21-8 – Регистр SPSRH

| 15 | 14      | 13      | 12      | 11    | 10    | 9      | 8    |
|----|---------|---------|---------|-------|-------|--------|------|
| -  | XFIFO_F | XFIFO_H | XFIFO_E | XLOST | XSERR | XEMPTY | XRDY |
|    | R,+0    | R,+0    | R,+1    | R,+0  | R,+0  | R,+1   | R,+1 |
|    |         |         |         |       |       |        |      |

| 7 | 6       | 5       | 4       | 3     | 2     | 1      | 0    |
|---|---------|---------|---------|-------|-------|--------|------|
| - | RFIFO_F | RFIFO_H | RFIFO_E | RLOST | RSERR | REMPTY | RRDY |
|   | R,+0    | R,+0    | R,+1    | R,+0  | R,+0  | R,+0   | R,+0 |

## Таблица 21-9 – Описание бит регистра SPSRH

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое         |
|------|----------------|---------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений              |
| 15   | -              | Зарезервировано                                         |
| 14   | XFIFO_F        | Признак заполненности FIFO передатчика (XBR)            |
|      |                | 0 – XBR не полон                                        |
|      |                | 1 – XBR полон                                           |
| 13   | XFIFO_H        | Признак половинной заполненности FIFO передатчика (XBR) |
|      |                | 0 – XBR полупуст (более чем наполовину пуст)            |
|      |                | 1 – XBR полуполон (заполнен более чем на половину)      |
| 12   | XFIFO_E        | Признак заполненности FIFO передатчика (XBR)            |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|    |         | 0 VDD up river                                             |
|----|---------|------------------------------------------------------------|
|    |         | 0 – XBR не пуст                                            |
| 44 | VLOOT   | 1 – XBR пуст                                               |
| 11 | XLOST   | Признак перезаписи данных в регистре DXR                   |
|    |         | 0 – Отсутствие потери данных                               |
|    |         | 1 – Произведена перезапись данных в DXR до их              |
|    |         | перемещения в FIFO                                         |
| 10 | XSERR   | Признак ошибки синхронизации передатчика                   |
|    |         | 0 – Ошибки синхронизации передатчика отсутствуют           |
|    |         | 1 – Имелась ошибка при синхронизации передатчика           |
| 9  | XEMPTY  | Опустошение передатчика                                    |
|    |         | 0 – XSR не пуст                                            |
|    |         | 1 – XSR пуст                                               |
| 8  | XRDY    | Готовность передатчика принять данные                      |
|    |         | 0 – Новые данные передатчиком приняты быть не могут        |
|    |         | 1 – Передатчик готов принять данные новые                  |
| 7  | -       | Зарезервировано                                            |
| 6  | RFIFO_F | Признак заполненности FIFO приемника (RBR)                 |
|    |         | 0 – RBR не полон                                           |
|    |         | 1 – RBR полон                                              |
| 5  | RFIFO_H | Признак половинной заполненности FIFO приемника (RBR)      |
|    | _       | 0 – RBR полупуст (более чем наполовину пуст)               |
|    |         | 1 – RBR полуполон (заполнен более чем на половину)         |
| 4  | RFIFO_E | Признак заполненности FIFO приемника (RBR)                 |
|    | _       | 0 – RBR не пуст                                            |
|    |         | 1 – RBR пуст                                               |
| 3  | RLOST   | Признак перезаписи данных в регистре RSR                   |
|    |         | 0 – Отсутствие потери данных                               |
|    |         | 1 – Произведена перезапись данных в RSR до их              |
|    |         | перемещения в FIFO                                         |
| 2  | RSERR   | Признак ошибки синхронизации приемника                     |
|    |         | 0 – Ошибки синхронизации приемника отсутствуют             |
|    |         | 1 – Имелась ошибка при синхронизации приемника             |
| 1  | RFULL   | Переполнение приемника                                     |
| '  | IN OLL  | 0 – Приемник не полон                                      |
|    |         | 1 – Приемник полон и не может принять новые данные из      |
|    |         | линии                                                      |
| 0  | RRDY    | Наличие принятых данных                                    |
|    | ININDI  | 0 – Новых данных нет                                       |
|    |         | 1 – Повых данных нет<br>1 – Приёмник содержит новые данные |
|    |         | т – присмин содержит повые данные                          |

# 21.3.4 PCRL

# Таблица 21-10 - Регистр PCRL

| 15 | 14 | 13     | 12     | 11     | 10     | 9      | 8      |
|----|----|--------|--------|--------|--------|--------|--------|
| -  | -  | XIOEN  | RIOEN  | FSXM   | FSRM   | CLKXM  | CLKRM  |
|    |    | R/W,+0 | R/W,+0 | R/W,+1 | R/W,+1 | R/W,+1 | R/W,+1 |

| 7 | 6       | 5     | 4     | 3      | 2      | 1      | 0      |
|---|---------|-------|-------|--------|--------|--------|--------|
|   | CLKS_ST | DX_ST | DR_ST | FSXP   | FSRP   | CLKXP  | CLKRP  |
|   | R,+0    | R,+0  | R,+0  | R/W,+0 | R/W,+0 | R/W,+0 | R/W,+0 |

# Таблица 21-11 - Описание бит регистра PCRL

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 1514      | -                       | Зарезервировано                                                                            |
| 13        | XIOEN                   | Назначение выводов передатчика                                                             |
|           |                         | 0 – Выводы передатчика используются как GPIO                                               |
|           |                         | 1 – Выводы передатчика подключены к контактным                                             |
|           |                         | площадкам                                                                                  |
| 12        | RIOEN                   | Назначение выводов приемника                                                               |
|           |                         | 0 – Выводы приемника используются как GPIO                                                 |
|           |                         | 1 – Выводы приемника подключены к контактным площадкам                                     |
| 11        | FSXM                    | Режим кадровой синхронизации передатчика                                                   |
|           |                         | 0 – Кадровая синхронизации от внешнего источника                                           |
|           |                         | 1 – Кадровая синхронизации от внутреннего генератора                                       |
| 10        | FSRM                    | Режим кадровой синхронизации приемника                                                     |
|           |                         | 0 – Кадровая синхронизации от внешнего источника                                           |
|           |                         | 1 – Кадровая синхронизации от внутреннего генератора                                       |
| 9         | CLKXM                   | Режим битовой синхронизации передатчика                                                    |
|           |                         | 0 – Битовая синхронизации от внешнего источника                                            |
|           |                         | 1 – Битовая синхронизации от внутреннего генератора                                        |
| 8         | CLKRM                   | Режим битовой синхронизации приемника                                                      |
|           |                         | 0 – Битовая синхронизации от внешнего источника                                            |
|           |                         | 1 – Битовая синхронизации от внутреннего генератора                                        |
| 7         | -                       | Зарезервировано                                                                            |
| 6         | CLKS_ST                 | Отражает текущее состояние вывода CLKS                                                     |
|           |                         | * фиксируется в регистре на частоте работы параллельного                                   |
|           |                         | интерфейса                                                                                 |
| 5         | DX_ST                   | Отражает текущее состояние вывода DX                                                       |
|           |                         | * фиксируется в регистре на частоте работы параллельного                                   |
|           |                         | интерфейса                                                                                 |
| 4         | DR_ST                   | Отражает текущее состояние вывода DR                                                       |
|           |                         | * фиксируется в регистре на частоте работы параллельного                                   |
|           | E0)/D                   | интерфейса                                                                                 |
| 3         | FSXP                    | Полярность сигнала кадровой синхронизации передатчика                                      |
|           |                         | 0 – Активный высокий уровень кадровой синхронизации                                        |
|           | LODD                    | 1 – Активный низкий уровень кадровой синхронизации                                         |
| 2         | FSRP                    | Полярность сигнала кадровой синхронизации приемника                                        |
|           |                         | 0 – Активный высокий уровень кадровой синхронизации                                        |
| 4         | CLIVVD                  | 1 – Активный низкий уровень кадровой синхронизации                                         |
| 1         | CLKXP                   | Активный фронт сигнала битовой синхронизации передатчика                                   |
|           |                         | 0 – Активный передний фронт битовой синхронизации                                          |
|           |                         | 1 – Активный задний фронт битовой синхронизации                                            |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| 0 | CLKRP | Активный фронт сигнала битовой синхронизации приемника |
|---|-------|--------------------------------------------------------|
|   |       | 0 – Активный передний фронт битовой синхронизации      |
|   |       | 1 – Активный задний фронт битовой синхронизации        |

# 21.4 Управление приемом и передачей

Управление приемом и передачей данных управляется посредством регистров управления приемником RCR и управления передатчиком XCR

# 21.4.1 RCRH, XCRH

# Таблица 21-12 – Регистры RCRH, XCRH

| 15         | 14      | 13           | 12           | 11 | 10 | 9 | 8 |
|------------|---------|--------------|--------------|----|----|---|---|
| MPHASE     |         | FLEN_P1[6:0] |              |    |    |   |   |
| R/W,+0     | R/W,+31 |              |              |    |    |   |   |
| 7          | 6       | 5            | 4            | 3  | 2  | 1 | 0 |
| CODEC[2:0] |         |              | WLEN_P1[4:0] |    |    |   |   |
| R/W,+0     |         |              | R/W,+15      |    |    |   |   |

# Таблица 21-13 - Описание бит регистров RCRH, XCRH

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое         |
|------|----------------|---------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений              |
| 15   | MPHASE         | Выбор одно- и многофазного (двухфазного) режимов работы |
|      |                | 0 – Однофазный режим                                    |
|      |                | 1 – Многофазный режим                                   |
| 148  | FLEN_P1[6:0]   | Размер кадра фазы №2                                    |
|      |                | Размер кадра в словах -1                                |
|      |                | (реальный диапазон 1–128 слов в кадре)                  |
| 75   | CODEC[2:0]     | Способ кодирования/декодирования                        |
|      |                | 000 – Кодирование/декодирование отключено               |
|      |                | 001 – Кодирование/декодирование отключено               |
|      |                | (зарезервировано)                                       |
|      |                | 010 – Включен режим компадирования/декомпадирования по  |
|      |                | u-Law                                                   |
|      |                | 011 – Включен режим компадирования/декомпадирования по  |
|      |                | A-Law                                                   |
|      |                | 100 – Кодирование/декодирование отключено               |
|      |                | (зарезервировано)                                       |
|      |                | 101 – Кодирование/декодирование отключено               |
|      |                | (зарезервировано)                                       |
|      |                | 110 – Кодирование/декодирование отключено               |
|      |                | (зарезервировано)                                       |
|      |                | 111 – Кодирование/декодирование отключено               |
|      |                | (зарезервировано)                                       |
| 40   | WLEN_P1[4:0]   | Размер слова данных фазы №2                             |
|      |                | Размер слова данных в битах -1                          |
|      |                | (реальный диапазон 4–32 бит в слове)                    |
|      |                | работа блока при размере слова менее 4-х бит не         |
|      |                | гарантируется                                           |

# 21.4.2 RCRL, XCRL

# Таблица 21-14 – Регистры RCRL, XCRL

| 15     | 14         | 13           | 12           | 11 | 10 | 9 | 8 |
|--------|------------|--------------|--------------|----|----|---|---|
| FIG    |            | FLEN_P0[6:0] |              |    |    |   |   |
| R/W,+0 | R/W,+31    |              |              |    |    |   |   |
| 7      | 6          | 5            | 4            | 3  | 2  | 1 | 0 |
| MSB1st | DELAY[1:0] |              | WLEN_P0[4:0] |    |    |   |   |
| R/W,+0 | R/V        | V,+1         | R/W,+15      |    |    |   |   |

# Таблица 21-15- Описание бит регистров RCRL, XCRL

| Nº   | Функциональ  | Расшифровка функционального имени бита, краткое              |
|------|--------------|--------------------------------------------------------------|
| бита | ное имя бита | описание назначения и принимаемых значений                   |
| 15   | FIG          | Режим игнорирования кадровой синхронизации                   |
|      |              | 0 – Каждый импульс кадровой синхронизации перезапускает      |
|      |              | обмен                                                        |
|      |              | 1 – Импульсы кадровой синхронизации кроме первого            |
|      |              | игнорируются                                                 |
| 148  | FLEN_P0[6:0] | Размер кадра фазы №1                                         |
|      |              | Размер кадра в словах -1                                     |
|      |              | (реальный диапазон 1–128 слов в кадре)                       |
| 7    | MSB1st       | Порядок передачи бит в слове                                 |
|      |              | 0 – Начиная с младшего бита (LSB)                            |
|      |              | 1 – Начиная со старшего бита (MSB)                           |
| 65   | DELAY[1:0]   | Задержка данных относительно кадровой синхронизации          |
|      |              | 0–3 битовых интервала                                        |
|      |              | * нулевая задержка соответствует началу передачи битов       |
|      |              | одновременно с импульсом кадровой синхронизации              |
| 40   | WLEN_P0[4:0] | Размер слова данных фазы №1                                  |
|      |              | Размер слова данных в битах -1 (реальный диапазон 4-32 бит в |
|      |              | слове)                                                       |
|      |              | * работа блока при размере слова менее 4х бит не             |
|      |              | гарантируется                                                |

## 21.5 Порядок приема и передачи данных

Как показано на структурной схеме, прием и передача осуществляется через FIFO.

Принимаемые данные поступают на вывод RX и вдвигаются в RSR. После получения заданного количества битов данные перемещаются в FIFO приемника RBR, если он не полон, и далее копируются в DRR, и остаются там до тех пор, пока не будут считаны через параллельный интерфейс

Передаваемые данные записываются через параллельный интерфейс в регистр DXR, откуда перемещаются в FIFO передатчика, если он не заполнен. После этого данные попадают в сдвиговый регистр передатчика XSR, откуда выдвигаются через вывод TX.

#### 21.6 Сброс последовательного порта

Последовательный порт может быть сброшен следующими способами:

- аппаратный сброс (вывод HRESETn);
- программный внешний сброс (вывод SRESETn);
- программный внутренний сброс (биты управления регистра SPCR).

# 21.7 Программный внутренний сброс (биты управления регистра SPCR)

В McBSP предусмотрен независимый сброс отдельных его блоков посредство регистра управления SPCR.

Программно могут быть сброшены:

- внутренний генератор битовой синхронизации (SPCR.nFGRST);
- внутренний генератор кадровой синхронизации (SPCR.nCGRST);
- приемник (SPCR nRRST);
- передатчик (SPCR nXRST).

Программный внутренний сброс переводит соответствующий блок McBSP в исходное состояние синхронно после подачи его активного уровня (выставления соответствующего бита в регистре управления SPCR). После снятия сигнала аппаратного сброса выход блока из состояния сброса осуществляется также синхронно.

Примечание — Перед сменой параметров приемника/передатчика рекомендуется перевести их в состояние программного внутреннего сброса, сменить параметры, вывести из состояния программного внутреннего сброса

#### 21.8 Обработка статусов

Признаки RRDY и XRDY определяют состояния готовности приемника и передатчика соответственно. Запись и чтение данных последовательного порта могут быть синхронизированы опросом этих битов, или используя их в качестве источников DMA-запросов или запросов прерывания ЦП.

# 21.9 Состояние приемника: RRDY, RRINT, RFULL, RSYNCERR

Признак RRDY = 1 сигнализирует о наличии несчитанных данных в регистре DRRL и DDRH, которые могут быть считаны ЦП или DMA-контроллером. Сразу после чтения, а также после сброса McBSP или приемника McBSP, данный признак

сбрасывается в 0. Кроме данного признака есть программируемый вывод состояния приемника, на который может быть выведен данный признак (SPCRH.RINTM=000b).

## 21.10 Состояние передатчика

Признак XRDY = 1 сигнализирует о готовности передатчика принять новое слово данных в регистры DXRL и DXRH. Данный признак снимается сразу после записи в него данных через параллельный интерфейс и выставляется после копирования полной порции данных из регистра DXRL и DXRH в FIFO передатчика XBR. Также имеется программируемый вывод состояния передатчика, на который может быть выведен данный признак (SPCRH.XINTM=000b).

## 21.11 События и прерывания

В McBSP имеются 6 программируемых вывода для информирования управляющее ЦП (XINT и RINT) или DMA-контроллер (XEVNT[x2] и REVENT[x2]) о возникновении события.

Прерывания приемника (RINT) и передатчика (XINT) информируют ЦП об изменении состояния последовательного порта. Данные выводы программируемы и для каждого доступны 8 настроек, определяемых полем конфигурации (RINTM и XINTM соответственно) источников событий:

- RINTM/XINTM = 000b. Прерывание по каждому слову перемещаемому между интерфейсными регистром (DRR/DXR) и FIFO буфером (RBR/XBR) приемника и передатчика определяемым битами SPCR.RRDY/SPCR.XRDY соответственно.
- 2. RINTM/XINTM = 001b. Прерывание по признаку конца текущей фазы приема/передачи.
- 3. RINTM/XINTM = 010b. Прерывание по признаку кадровой синхронизации.
- 4. RINTM/XINTM = 011b. Прерывание по признаку обнаружения ошибки кадровой синхронизации приемника (RSYNCERR) и передатчика (XSYNCERR) соответственно.
- 5. RINTM/XINTM = 100b. Заполнено менее половины FIFO приемника/передатчика.
- 6. RINTM/XINTM = 101b. Заполнено половина или более FIFO приемника/передатчика.
- 7. RINTM/XINTM = 110b. FIFO приемника/передатчика опустошено (не содержит данных).
- 8. RINTM/XINTM = 111b. FIFO приемника/передатчика полностью заполнено.

Для управления выводом событий через выводы XEVNT0/1 и REVENT0/1 применяются поля XEVNT0/1 и REVNT0/1 соответственно. В отличие от выводов прерываний данные выводы не имеют промежуточного регистра на выходе блока. Назначение сигналов аналогично выводам RINT/XINT.

#### 21.12 Настройка битовой и кадровой синхронизации

Рисунок 21–1 демонстрирует типовой режим работы битовой и кадровой синхронизации. Сигналы RCLK и TCLK определяют границы битов на прием и на передачу соответственно. Аналогично сигналы TFR/RFR определяют границу слова.

В McBSP предусмотрена независимая настройка параметров синхронизации данных для приемника и передатчика:

• Полярность синхросигналов RFR, TFR, RCLK и TCLK;

- Выбор между одно- и многофазным режимами;
- Количество слов в кадре для каждой фазы;
- Количество битов с слове для каждой фазы;
- Перезапуск обмена по каждому импульсу кадровой синхронизации или их игнорирование;
- Задержка данных относительно сигнала кадровой синхронизации от 0 до 3х битовых интервалов;
- Выравнивание данных по правой или левой границе, и расширение знака;
- Выравнивание передаваемых/принимаемых по границе байта (8 бит), слова (16 бит) или двойного слова(32 бит).



Рисунок 21–1 – Работа кадровой и битовой синхронизации

Битовая и кадровая синхронизации приемника и передатчика могут задаваться от внутреннего или от внешнего источника. Управление режимами осуществляется через биты режима в регистре PCR. Также на источник кадровой и битовой синхронизации влияет бит КЗ (DLB) при котором битовая и кадровая синхронизации приемника задаются от битовой и кадровой синхронизации передатчика.

Когда кадровая синхронизация приемника (RFR) и передатчика (TFR) задаются от внешнего источника (PCR.FSRM=PCR.FSRM=0), то McBSP определяет их наличие по отрицательному фронту сигналов битовой синхронизации приемника (RCLK) и передатчика (TCLK) соответственно.

Когда же кадровая синхронизация приемника (RFR) и передатчика (TFR) задаются от внутреннего источника (PCR.FSRM=PCR.FSRM=1), то McBSP выставляет их на линию по положительному фронту сигналов битовой синхронизации приемника (RCLK) и передатчика (TCLK) соответственно.

Входные данные захватываются по отрицательному фронту сигнала RCLK, а передаваемые данные выставляются по положительному фронту сигнала TCLK.

Биты FSXP, FSRP, CLKXP и CLKRP определяют полярность сигналов TFR, RFR, TCLK и RCLK. Все внутренние сигналы кадровой синхронизации имеют активный уровень «1», данные выставляются по положительному фронту битовой синхронизации, а принимаются по отрицательному. Для согласования уровней и активных фронтов с внешней линией производится инверсия сигналов кадровой и битовой синхронизации в соответствии с выставленными битами управления полярностью сигналов. Инверсия производится посредством вентилей типа XOR.

#### 21.12.1 Фазы кадровой синхронизации

Кадровая синхронизация обозначает начало обмена в McBSP. Поток данных, следующий за кадровой синхронизацией, может иметь одну или 2 фазы (фаза 1 и фаза 2). Количество фаз определяется битом управления в регистрах XCR и RCR (бит MPHASE). Размер кадра и размер слова для каждой фазы задается независимо посредством полей FLEN P0/ FLEN P1 и WLEN P0/WLEN P1 соответственно.

Размер кадра определяется число слов в фазе кадра (от 1 до 128 слов), а размер слова определяется длину слова в пределах фазы. Размер слова может быть задан произвольно в диапазоне от 4-х до 32-х бит\*.

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

\* – размер слова может быть задан и менее 4-х, но при этом работа блока не гарантируется.

## 21.12.2 Упаковка данных заданием размеров кадра и слова.

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

Пример такой упаковки приведен ниже.

К примеру, необходимо передавать данные по 4 байта (8 бит) в кадре с одной фазой. Данный режим может быть запрограммирован при помощи следующих установок:

- MPHASE = 0b , однофазный кадр;
- FLEN\_P0 = 0000011b (0x03), кадр из 4-х слов;
- WLEN P0 = 0000111b (0x07), слово из 8-ми бит.

В данном случае между ЦП или DMA-контроллером и McBSP будет совершено 8 обменов 8 битными словами – 4 чтения из DRR и 4 записи в DXR.



Рисунок 21–2 – Пример упаковки данных методом задания размера (несколько слов)

В тоже время можно тот же массив данных принять другим способом – как одно 32-х разрядное слово.

- MPHASE = 0b , однофазный кадр
- FLEN\_P0 = 0000000b (0x00), кадр из 1го слова
- WLEN P0 = 11111b (0x1F), слово из 32x бит

В данном случае будет произведено всего 2 обмена с ЦП или DMA-контроллером – по одному 32-разрядному слову на прием и на передачу.



Рисунок 21–3 – Пример упаковки данных методом задания размера (одно слово)

Как видно из примера управление разрядностью передаваемых слов и их количеством позволяет проводить упаковку и распаковку данных, тем самым снижая нагрузку на ЦП или DMA-контроллер.

## 21.13 Задержка данных

Начало импульса кадровой синхронизации определяет первый цикл, когда может начаться передача пакета. Реальный же пакет при необходимости может быть отправлен/принят с некоторой задержкой. Данная задержка определяется полями DELAY в регистрах управления XCR и RCR соответственно. Диапазон программно задаваемых задержек от 0 до 3-х битовых интервалов включительно. По сбросу установлена задержка в 1 битовый интервал.



Рисунок 21-4 – Задержка данных

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

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

Другой часто используемый режим - это задержка данных на 2 битовых интервала. Данный режим позволяет подключать последовательный порт к различным формирователям кадров типа Т1 с предварением пакета стартовым битом.

Во время приема подобного пакета (если установлена задержка в 2 битовых интервала) последовательный порт, по сути, отбрасывает стартовый бит. При передаче в этом случае передатчик оставляет стартовый бит в высокоимпедансном состоянии. Подразумевается, что формирователь кадров вставляет собственный стартовый бит или что данный бит формируется сторонним устройством. К тому же, можно установить подтяжку к «0» или к «1» вывода DX для поведением в этом состоянии.



Рисунок 21-5 - Задержка данных на два битовых интервала

# 21.14 Пример многофазного кадра (АС97)

Хорошим примером использования многофазного кадра является применение аудиокодека стандарта АС97, использующего двухфазные кадры, где первая фаза содержит одно слово из 16 бит, за которым следуют 12 слов длиной 20 бит.

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

- FSRP1 = 0b, активный высокий уровень;
- MPHASE = 1b, многофазный кадр;
- FLEN\_P0 = 0000000b (0x00), кадр из 1го слова;
- WLEN P0 = 01111b (0x0F), слово из 16x бит;
- FLEN\_P1 = 0001011b (0x0B), кадр из 12 слов;
- WLEN\_P1 = 10011b (0x13), слова из 20 бит;
- DELAY = 01b (0x1), задержка 1 битовый интервал.



Рисунок 21-6 - Многофазный кадр

Примечательно, что в кадрах данного формата импульс кадровой синхронизации перекрывает первое слово кадра. В McBSP кадровая синхронизация

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

# 21.15 Штатный режим работы McBSP

Во время последовательного обмена обычно существуют периоды неактивности между последовательными пакетами. Для каждого кадра формируется импульс кадровой синхронизации. Если MCBSP не находится в состоянии сброса или останова и настроен на желаемый режим работы обычный последовательный режим работы может быть запущен установкой битов MPHASE = 0, для однофазного кадра, и заданным числом слов в кадре FLEN\_P0. Кроме того, необходимо, чтобы была установлена длина слова WLEN\_P0. Для работы с двухфазными кадрами необходимо установить MPHASE = 1 и установить значения длины кадра и слова для фазы 2 в регистрах FLEN\_P1 и WLEN\_P1 соответственно.

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

- \* длины кадра и слова указываются с вычетом 1, т.е. значение «0x00» в соответствующем поле определяет 1 битовое слово или однословный кадр
  - \*\* при длине слова менее 4х бит работа устройства не гарантируется.

Ниже на рисунке приведен пример однофазного кадра содержащего одно 8-битное слово. Данная диаграмма (и последующие тоже, если не указано иначе) подразумевает следующие настройки приема/передачи:

- FSRP1 = 0b, активный высокий уровень;
- CLKRP1 = 0b, передача по положительному фронту, прием по отрицательному;
- MPHASE = 0b, однофазный кадр;
- FLEN\_P0 = 0000000b (0x00), кадр из 1-го слова;
- WLEN\_P0 = 00111b (0x0F), слово из 8 бит;
- DELAY = 01b (0x1), задержка 1 битовый интервал.



## Рисунок 21-7 - Работа приемника

Ниже показан пример приема данных по последовательному порту (Рисунок 21–8). Сразу по переходу сигнала кадровой синхронизации из неактивного состояния в активное по отрицательному фронту сигнала SCLR приемник обнаруживает начало кадра. Далее, данные задвигаются в сдвиговый регистр (RSR) после выжиданий установленной задержки (RCR.DELAY). После приема слова данные из регистра RSR переносятся в FIFO приемника (RBR), откуда перемещаются в регистр приемника DRR с выставлением признака готовности данных (RRDY), откуда в свою очередь могут быть считаны ЦП или DMA-контроллером. При чтении регистра DRR ЦП или DMA-контроллером признак готовности данных снимается.

Рисунок 21-8 - Выставление признака готовности приемника

После получения импульса кадровой синхронизации через задержку (XCR.DELAY) передатчик начинает выдвигать содержимое регистра XSR через вывод DX. В регистре XSR для этого должны уже находиться данные на отправку которые попадают в него посредством FIFO передатчик, куда в свою очередь помещаются из регистра передатчика DXR, доступного для записи из ЦП или DMA-контроллера. При записи в регистр DXR ЦП или DMA-контроллером регистр помечается как занятый с одновременным снятием признака готовности передатчика к приему новых данных (XRDY). Признак готовности выставляется после того как данные из регистра DXR перемещены в FIFO передатчика.

Ниже на диаграмме приведен пример работы передатчика.



Рисунок 21-9 - Работа передатчика

Частота следования кадров определяется периодом между сигналами кадровой синхронизации:

Ff = Fb/N,

N = D + Nb + Nz,

где

Ff – частота следования кадров;

Fb – частота следования битов;

N – число битовых интервалов между импульсами кадровой синхронизации.

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

Ff = Fb/Nb,

где

Ff – частота следования кадров;

Fb – частота следования битов

Nb — число битов в кадре

Ниже показан пример работы McBSP на предельной частоте следования кадров.

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



Рисунок 21–10 – Работа передатчика на предельной частоте следования кадров

В действительности допускаются непрерывные потоки данных и поэтому нет необходимости стробировать импульсом кадровой синхронизации все кадры. Теоретически достаточно только первого кадрового импульса для запуска многокадровой передачи. В McBSP предусмотрен подобный режим работы игнорированием импульса кадровой синхронизации кроме первого. Данный режим включается программно установкой бита FIG = 1.

# 21.16 Режим игнорирования кадровой синхронизации

McBSP может быть настроен для пропуска кадровой синхронизации приема и передачи. Бит [X/R]CR.FIG =0 задает режим слежения за импульсами кадровой синхронизации, в то время как [X/R]CR.FIG =1 задает режим их игнорирования, кроме первого. Пользователь может использовать второй режим для упаковки данных, либо для пропуска нежелательных импульсов кадровой синхронизации.

# 21.17 Упаковка данных при помощи режима пропуска кадровой синхронизации

Ранее был описан один из методов упаковки данных при помощи изменения размера принимаемого и количества слов в кадре. Этот пример показывает, как можно производить упаковку, если в кадре содержится несколько слов. Если же в кадре содержится одно слово, то данный метод не применим. Вместо него можно воспользоваться режимом пропуска импульсов синхронизации. Положим, что каждый кадр состоит из одного слова размером 8 бит. Таким образом, каждый кадр требует одного чтения и одной записи. Для снижения нагрузки на ЦП или DMA-контроллер можно осуществлять упаковку к примеру до 32-битных слов. Для этого наряду с изменением длины слова до 32х бит необходимо установить бит [X/R]CR.FIG = 1 и, таким образом, поток данных будет восприниматься как поток 32-разрядных слов, что существенно снизит частоту обменов между McBSP и ЦП или DMA-контроллером. Диаграмма работы модуля в данном режиме представлена ниже (Рисунок 21–11, Рисунок 21–12).



Рисунок 21–11 – Пример упаковки данных при помощи режима кадровой синхронизации (несколько слов)



Рисунок 21–12 – Пример упаковки данных при помощи режима кадровой синхронизации (одно слово)

# 21.18 Пропуск нежелательных кадров при помощи режима пропуска кадровой синхронизации

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

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

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

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

Ниже приведены диаграммы обоих режимов – с пропуском кадровых синхроимпульсов и без него.



Рисунок 21-13 - Работа модуля в обычном режиме



Рисунок 21–14 – Работа модуля в режиме пропуска кадровых синхроимпульсов

## 21.19 Особые ситуации работы последовательного порта

В контроллере McBSP существует 5 событий, которые могут привести к системной ошибке:

- 1. Переполнение приемника (RFULL = 1). Данное событие отражает состояние ошибки когда начинается прием нового слова при том что сдвиговый регистр приемника (RSR) не был вычитан (заполнены все регистры и буферы приемника). Если при этом на вход приемника (DR) поступит новое слово, то это приведет к ошибке и при этом с поступлением новых банных слово, находившееся в RSR, будет затираться, приводя к потере данных.
- 2. **Несвоевременная кадровая синхронизация приемника** (RSYNCERR = 1). Это событие происходит при режиме слежения за кадровыми синхроимпульсами (FIG = 0) и поступлении импульса кадровой синхронизации ранее чем закончится кадр согласно запрограммированному размеру кадра и слова. Наступление данного события приводит к прерыванию приема текущего слова и началу приема/передачи нового.
- 3. Перезапись передаваемых данных. Этот случай происходит когда ЦП или DMA-контроллер перезаписывает данные в регистре передатчика (DXR) до того как они будут перемещены в FIFO передатчика (XBR). Данная ситуация не обнаруживается встроенными средствами McBSP,
- 4. Опустошение передатчика (XEMPTY = 1). Данное событие возникает, когда сдвиговый регистр передатчика (XSR) пуст и начинается передача первого бита слова.

5. **Несвоевременная кадровая синхронизация передатчика (XSYNCERR = 1)**. Это событие происходит при режиме слежения за кадровыми синхроимпульсами (FIG = 0) и поступлении импульса кадровой синхронизации ранее, чем закончится кадр согласно запрограммированному размеру кадра и слова. Наступление данного события приводит к прерыванию передачи текущего слова и началу передачи нового.

#### 21.20 Переполнение приемника (RFULL)

Бит RFULL = 1 в регистре SPCR сигнализирует о том, что произошло (!) переполнение приемного регистра при приеме данных и данные были потеряны. Бит RFULL выставляется при условии, что RSR заполнен и нет текущего цикла переноса данных в FIFO и начался прием нового слова. RSR может быть заполнен по причине заполненности FIFO, которое в свою очередь может быть заполненным по причине отсутствия чтения DRR с момента последнего перемещения в него данных из FIFO, либо отсутствием частоты на системной шине, по которой производится чтение регистра DRR и соответственно перенос в него данных из FIFO.

Данный флаг снимается автоматически при опустошении регистра RSR или при переносе данных из него в FIFO приемника RBR. Данное событие может произойти, если вычитан регистр DRR и соответственно в FIFO освободилось место для приема нового слова. Также данный флаг может быть снят сбросом приемника или всего McBSP.

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

\* – возникновение данного события показывает, что сложились все условия для возникновения ошибки и велика вероятность, что данные будут потеряны.

#### Несвоевременная кадровая синхронизация приемника (RSYNCERR)

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



Рисунок 21–15 – Алгоритм обработки всех кадровых синхроимпульсов приемника

Диаграмма (см. Рисунок 21–16) подразумевает, что приемник находится в активном состоянии (RRST=0). Непредвиденные кадровые импульсы могут формироваться от внешнего или внутреннего источника кадровых синхроимпульсов. Непредвиденный кадровый синхроимпульс определен как синхроимпульс, пришедший на RCR.DELAY битовых интервалов ранее последнего передаваемого бита.

При этих условиях могут произойти следующие 4 случая:

- 1. Вариант 1: поступление непредвиденного внутреннего импульса FR при установленном FIG = 1. В данном случае кадровый синхроимпульс игнорируется и прием продолжается.
- 2. Вариант 2: Штатная работа приемника. Возможны следующие 3 случая:
  - 1). SFSR первый синхроимпульс после сброса приемника (RSR = 1);
  - 2). SFSR первый синхроимпульс после снятия флага ошибки переполнения приемника (RFULL = 1);
  - 3). Приемник находится в состоянии обработки межпакетного интервала (данные в канале отсутствуют).
- 3. Вариант 3: Поступление непредвиденного кадрового синхроимпульса при установленном RCR.FIG = 0 (режим пропуска синхроимпульсов). Данный режим рассмотрен ранее. При наступлении данного случая происходит формирование сигнала ошибки кадровой синхронизации приемника (RSYNCERR), который может быть снят только записи «1» в соответствующий бит слова состояния или сбросом приемника.



Рисунок 21-16 - Диаграмма обработки непредвиденных кадровых импульсов

#### 21.21 Перезапись передаваемых данных.

Рисунок 21–17 показывает, что происходит, если данные в DXR были перезаписаны до того, как были отправлены. В примере изначально программист записывает данные С для передачи. После чего записывает данные D, перезаписывая данные С до того, как они были скопированы в FIFO передатчика XBR. Таким образом, данные С не будут переданы. ЦП или может избежать этого опрашивая бит готовности передатчика к приему новых данных для отправки (XRDY). DMA-контроллер может избежать этого, работая синхронизируя передачи по XRDY в одиночном режиме или по состоянию XBR в блочном режиме (состояния полуполного или пустого FIFO).



Рисунок 21–17 – Диаграмма работы модуля, в случае перезаписи неотправленных данных

#### Опустошение передатчика (ХЕМРТУ)

Данное событие возникает когда сдвиговый регистр Признак XEMPTY отражает состояние ошибки, когда начата передача слова.

**Несвоевременная кадровая синхронизация передатчика (XSYNCERR)** Это событие аналогично событию отражаемому признаком RSYNCERR.

#### 21.22 Выравнивание данных и расширение знака

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

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

Режим расширения знака доступен только в приемнике (в передатчике в нем нет необходимости).

При выравнивания по левой границе выравнивание осуществляется до ближайшей границы кратной указываемому в SPCR.JBOUND.

JBOUND описание:

00 выравнивание по границе байта (8 бит)

01 выравнивание по границе слова (16 бит)

1х выравнивание по границе двойного слова (32 бит)

Так при длине приеме слова 5 бит и значении SPCR.JBOUND = 00b слово будет выровнено по границе 8 бит (старший бит слова будет на 8й позиции слова), а младшие 8-5=3 бит будут дополнены нулями. При значении SPCR.JBOUND = 01b слово будет выровнено по границе 16 бит (старший бит слова будет на 16й позиции слова), а младшие 16-5=11 бит будут дополнены нулями. При значении SPCR.JBOUND = 1xb слово будет выровнено по границе 32 бит (старший бит слова будет на 32-й позиции слова), а младшие 8-5=3 бит будут дополнены нулями. Если же принимаемое слово будет, например, 17 разрядов, то границы слова на выходе приемника будут соответственно 24, 32 и 32.

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

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

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

#### 21.23 Кодирование/декодирование данных

В McBSP предусмотрены встроенное кодирование и декодирование данных, при передаче и приеме соответственно, для снижения нагрузки на ЦП. Режим кодирования/декодирования определяется полем CODEC. Всего доступны 8 режимов кодирования/декодирования. Штатно доступны 4 режима:

- кодирования отключено (CODEC = 000b);
- кодирование/декодирование кодом Манчестер-2 (CODEC = 001b);
- компадирование/декомпадирование по u-закону (CODEC = 010b);
- компадирование/декомпадирование по A-закону (CODEC = 011b).

Остальные режимы кодирования/декодирования зависят от конкретной реализации. Если в какой-либо из режимов не реализован, то поведение McBSP в этом случае аналогично отсутствию кодирования/декодирования (CODEC = 000b).

Путь кодирования/декодирования данных представлен на рисунке ниже.

Рисунок 21–18 – Структурная схема модуля кодирования/декодирования данных

# 21.24 Компадирование/декомпадирование по u- и A-законам

При компадировании по u- и A-законам необходимо выравнивание данных согласно приведенному ниже (Рисунок 21–19 и Рисунок 21–20).

| 15 |       | 2 | 1 | 0 |
|----|-------|---|---|---|
|    | Value |   | ( | D |

Рисунок 21-19 - Выравнивание данных для компадирования по u-закону в DXR

| 15   | 3 | 2 | 0 |
|------|---|---|---|
| Valu |   | 0 |   |

# Рисунок 21–20 – Выравнивание данных для компадирования по A-закону в DXR

При декомпадировании данные декодируются как 16 битное слово. При этом декомпадированные данные в приемнике расположены также как и в регистре DXR при передаче (см выше). Далее эти данные могут быть выровнены по границе согласно установленному в SPCR.JBOUND и при необходимости расширен знак.

## 21.25 Кодирование/декодирование кодом Манчестер-2

При кодировании кодом Манчестер-2 размер передаваемого слова увеличивается вдвое и при настройках приемника/передатчика необходимо указывать удвоенную длину слова.

Так, если будет производиться передача/прием данных кодом манчестер-2 в кадрах с 1-ой фазой и размерами кадра 1 слово и слова 8 бит с задержкой передачи 1-битовый интервал, то необходимо установить следующие настройки:

- MPHASE = 0b, однофазный кадр;
- CODEC = 001b (0x1), кодирование/декодирование кодом Манчествер-2;
- FLEN\_P0 = 0000000b (0x00), кадр из 1го слова;
- WLEN P0 = 00111b (0x0F), слово из 8 бит;
- DELAY = 01b (0x1), задержка 1 битовый интервал.

## 21.26 Порядок передачи бит в словах

В контроллере McBSP предусмотрена реверсивная передача бит – передача, как с наименее, так и с наиболее значащих битов. Управление в передатчике и приемнике производится независимо битами MSB1st. Для передачи/приема данных

начиная со старшего бита (MSB) необходимо установить бит MSB1st = 1, а для передачи начиная с наименее значащего (LSB) MSB1st = 0.

Управление направлением передачи доступно во всех режимах работы и диапазонах длин передаваемого/принимаемого слова.

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

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

Схему подключений синхронизации демонстрирует Рисунок 21–21.



Рисунок 21-21 - Структурная схема модуля управления синхронизацией

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

#### 21.28 Внутренний генератора кадровой и битовой синхронизации

Внутренний генератор кадровой и битовой синхронизации структурно скомпонован из 3-х стадий деления опорной частоты для формирования заданных битового и кадрового синхроимпульсов. Рисунок 21–22 изображает схему генератора.

- Делитель опорного сигнала (задается CLKDIV). Формирует сигнал битовой синхронизации CLKG.
- Формирователь кадрового синхросигнала (задается FPER). Задает межкадровый интервал.
- Формирователь кадрового импульса (задается FWID). Формирует кадровый синхроимпульс заданной длины и периода в соответствии с межкадровым интервалом.

Сигналы CLKG и FSG могут быть использованы для синхронизации битов и кадров приемника/передатчика. В качестве опорной частоты для генератора может

быть использована внутренняя частота (частота работы параллельного интерфейса), либо частота опорная частота от внешнего источника.

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



Рисунок 21–22 – Структурная схема генератора кадровой и битовой синхронизации

#### 21.28.1 SRGRH

Таблица 21-16 - Регистр SRGRH

| 15              | 14        | 13     | 12     | 11         | 10 | 9 | 8 |
|-----------------|-----------|--------|--------|------------|----|---|---|
| GSYNC           | FSGM      | CLKSM  | CLKSP  | FPER[11:8] |    |   |   |
| R/W,+0          | R/W,+0    | R/W,+0 | R/W,+0 | R/W,+0     |    |   |   |
| 7 6 5 4 3 2 1 0 |           |        |        |            | 0  |   |   |
|                 | FPER[7:0] |        |        |            |    |   |   |
| R/W,+0          |           |        |        |            |    |   |   |

Таблица 21-17 - Описание бит регистра SRGRH

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                       |
|-----------|----------------------------|------------------------------------------------------------------------------------------------------------------|
| 15        | GSYNC                      | Выбор режима синхронизации генератора                                                                            |
|           |                            | 0 – Режим FreeRun. Без синхронизации                                                                             |
|           |                            | 1 – Синхронизации от внешнего источника. Внешним                                                                 |
|           |                            | источником является вход (!) кадровой синхронизации приемника (SFSR).                                            |
|           |                            | * период следования кадровых синхроимпульсов<br>определяется SFSR                                                |
|           |                            | ** для корректной работы необходимо чтобы вывод кадровой синхронизации был сконфигурирован как вход PCR.FSRM = 0 |
| 14        | FSGM                       | Выбор режима формирования кадрового сигнала                                                                      |
|           |                            | 0 – Кадровая синхронизация формируется генератором                                                               |
|           |                            | 1 – Кадровый синхроимпульс формируется при перемещении                                                           |
|           |                            | данных из FIFO передатчика XBR в сдвиговый регистр передатчика XSR                                               |

|     |       | * режим может быть активен только при следующих условиях: SRSGR.GSYNC = 0; MPHASE = 0; MCM = 0. |
|-----|-------|-------------------------------------------------------------------------------------------------|
| 13  | CLKSM | Выбор источника опорного тактового сигнала                                                      |
|     |       | 0 – Генератор тактируется от внешнего источника (MCLK)                                          |
|     |       | 1 – Генератор тактируется от системного тактового сигнала                                       |
| 12  | CLKSP | Полярность тактового сигнала                                                                    |
|     |       | 0 – Кадровый и битовый синхросигналы формируются по                                             |
|     |       | положительному фронту опорного тактового сигнала                                                |
|     |       | 1 – Кадровый и битовый синхросигналы формируются по                                             |
|     |       | отрицательному фронту опорного тактового сигнала                                                |
| 110 | FPER  | Период следования кадровых синхроимпульсов (-1)                                                 |
|     |       | Диапазон от 1 до 4096 битовых интервалов                                                        |

#### 21.28.2 SRGRL

#### Таблица 21-18 - Регистр SRGRL

| 15 | 14          | 13 | 12    | 11   | 10 | 9 | 8 |
|----|-------------|----|-------|------|----|---|---|
|    |             |    | FWID[ | 7:0] |    |   |   |
|    |             |    | R/W,  | +0   |    |   |   |
|    |             |    |       |      |    |   |   |
| 7  | 6           | 5  | 4     | 3    | 2  | 1 | 0 |
|    | CLKGDV[7:0] |    |       |      |    |   |   |
|    | R/W,+0      |    |       |      |    |   |   |

## Таблица 21-19 – Описание бит регистра SRGRL

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                  |
|-----------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 158       | FWID[7:0]                  | Длительность кадровых синхроимпульсов (-1)<br>Диапазон от 1 до 256 битовых интервалов                                       |
| 70        | CLKGDV[7:0]                | Коэффициент деления тактового сигнала для формирования битового синхроимпульса. Диапазон от 1 до 256 тактов опорной частоты |

# 21.29 Сброс генератора кадровой и битовой синхронизации

Сброс и настройка генератора кадровой и битовой синхронизации производится следующим образом:

- После аппаратного или программного сброса McBSP генератор находится в исходном состоянии. Программный сброс может быть осуществлен через внешний программный сброс или посредством бита регистра управления (GRST = 1). Сброс генератора кадровой синхронизации, кроме того, осуществляется посредством установки бита FRST = 1.
- 2. Если необходимо перевести приемник и передатчик в состояние сброса XRST и RRST = 1.

- 3. Далее необходимо установить в SRGR настройки требуемых параметров работы генератора, таких как коэффициент деления тактовой частоты, частота и длительность кадровых синхроимпульсов и пр.
- 4. Обождать несколько тактов опорной частоты работы генератора для установки соответствующих режимов.
- 5. Включить генератор битовой синхронизации, установив (GRST = 0)
- 6. Обождать несколько тактов опорной частоты работы генератора для его перехода в соответствующий режим.
- 7. Если необходимо вывести приемник и передатчик из состояния сбросом битов XRST = 0 и RRST=0.
- 8. Для выхода генератора битовой синхронизации в режим необходимо не более (1+CLKGDV) тактов опорной частоты генератора.
- 9. После произведения всех предустановок и помещения данных на передачу в FIFO передатчика включить генератор кадровых синхроимпульсов установив (FRST = 0). Если генератор кадровых синхроимпульсов был включен одновременно с включением генератора битовой синхронизации, то его выход в режим будет одно временно с выходом в режим генератора битовой синхронизации. Для исключения отправки «пустого кадра» необходимо поместить данные на передачу в FIFO до вывода генератора кадровой синхронизации из состояния сброса.
- 10. Кадровой синхронизации из состояния сброса.

# 21.30 Генератор битовой синхронизации

При установке битов FSXM =1 и FSRXM=1 приемник и передатчик работают от внутреннего генератора кадровой синхронизации. Для передатчика и для приемника выбор источника битовой синхронизации осуществляется независимо. Доступные настройки:

- Тактовый сигнал для генератора может быть от внешнего источника или от тактового сигнала параллельного интерфейса (системный).
- Тактовый сигнал может быть поделен на целое число от 1 до 256. При этом в поле CLKGDV задается коэффициент деления -1 (при CLKGDV = 0 коэффициент деления будет 1). Схема делителя всегда работает по положительному фронту опорного тактового сигнала. При делении опорной частоты скважность сигнала битовой синхронизации будет зависеть от четности и величины коэффициента деления:
  - для четных коэффициентов деления (нечетных CLKGDV): Q = 50%;
  - для нечетных коэффициентов деления (четных CLKGDV>0): Q = (1 + 1/(CLKGDV + 1))/2 \* 100%.

# 21.31 Полярность тактового сигнала генератора

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

#### 21.32 Битовая и кадровая синхронизация

При выборе режима работы генератора от внешнего опорного тактового сигнала (MCLK) бит GSYNC может применяться для управления синхронизацией фронта сигнала битовой синхронизации CLKG с фронтом опорного тактового сигнала.

При установленном бите GSYNC = 1 фазы сигнала битвой синхронизации и тактового сигнала синхронизирован, в противном случае по фазе они не согласованы. При установленном бите GSYNC = 1 синхронизация по фазе осуществляется по сигналу кадровой синхронизации приемника, поэтому данный вывод должен быть запрограммирован как вход. Синхронизация осуществляется по первому активному уровню опорного тактового сигнала независимо от длительности кадрового синхроимпульса. Следует обратить внимание, что в этом режиме поле SRGR.FPER игнорируется, поскольку период следования кадров определяется только входной кадровой синхронизацией.

На рисунках (Рисунок 21–23 и Рисунок 21–24) приведены примеры диаграмм для разных настроек битовой и кадровой синхронизации.



Также в данном режиме (GSYNC = 1) передатчик может работать синхронно с приемником. Для этого необходимы следующие настройки:

1. вывод SFSX должен быть настроен для работы от внутреннего генератора (FSXM = 1 и CLKXM = 1);

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

#### 21.33 Режим КЗ

Для тестирования и прочих нужд (к примеру, кодирования или декодирования данных) в McBSP предусмотрен режим K3. В данный режим McBSP вводится установкой бита SPCR.DLB = 1. В этом режиме все сигналы передатчика подключаются в выводам приемника. Данный режим штатно предназначен для тестирования McBSP программным путем ЦП без внешних инструментов. Также данный режим может быть использован для кодирования и декодирования массивов данных, а также для выравнивания по заданной границе и расширения знака без участия ЦП.

## 21.34 Генератор кадровой синхронизации

Подобно битовой синхронизации кадровая настраивается для приемника и для передатчика независимо. Сброс генератора кадровой синхронизации осуществляется битом FRST = 1.

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

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

\* — генератор кадровой синхронизации работает от генератора битовой синхронизации и, таким образом, для его работы необходима работа генератора битовой синхронизации (!).

# 21.35 Период и длина кадрового синхроимпульса

В генераторе кадровой синхронизации возможна настройка частоты следования и длительности формируемого кадрового синхроимпульса. Данная настройка осуществляется в битовых интервалах задаваемых генератором битовой синхронизации и задается полями SRGR.FPER и SRGR.FWID соответственно. Аппаратно они представлены декрементирующими счетчиками разрядности 12 и 8 бит соответственно и, таким образм, могут быть запрограммированы период следования кадрового синхроимпульса от 1 до 4096 битовых интервалов и его длина от 1 до 256 битовых интервалов. При этом в соответствующем поле указывается значение за вычетом 1. То есть, к примеру длине синхроимпульса 1 битовый интервал соответствует значение 0 в поле SRGR.FWID.

Рекомендуется задавать длительность кадрового синхроимпульса менее длины передаваемого/принимаемого слова. Также рекомендуется задавать частоту следования кадровых синхроимпульсов более их длины, в противном случае McBSP будет формировать кадровые синхроимпульсы с заданной частотой следования и длиной активного уровня равной половине частоты следования.

Ниже приведен пример формирования кадровой синхронизации (Рисунок 21–25).



Рисунок 21-25 - Пример формирования кадровой синхронизации

# 21.36 Примеры битовой и кадровой синхронизации в различных форматах

В данном разделе приведены примеры настроек для некоторых форматов синхронных последовательных интерфейсов.

# 21.36.1 ST-BUS

Для работы с ST-BUS необходимы следующие настройки McBSP:

- PCR.FS[X/R]P = 1, кадровые синхроимпульсы имеют активный низкий уровень;
- PCR.CLK[X/R]M = 1, битовая синхронизации формируются внутренним генератором битовой синхронизации;
- SRGR.GSYNC = 1, генератор кадровой и битовой синхронизации синхронизируется внешним синхроимпульсом;
- SRGR.CLKSM = 1, генератор кадровой и битовой синхронизации тактируется внешним источником тактовой частоты;
- SRGR.CLKSP = 1, генератор кадровой и битовой синхронизации синхронизируются по отрицательному фронту тактовой частоты;
- SRGR.CLKGDV = 0, прием ведется на половине частоты опорного тактового сигнала;
- MPHASE = 0, кадр содержит одну фазу;
- FLEN P0 = 11111b, в кадре 32 слова;
- WLEN\_P0 = 111b, каждое слово кадра 8 бит;
- DELAY = 0 задержка данных в канале отсутствует.



#### Рисунок 21-26 - Диаграмма работы в режиме ST-BUS

# 21.36.2 ST-BUS с удвоенной частотой

Для работы с Mitel ST-BUS необходимы следующие настройки McBSP:

- PCR.FS[X/R]P = 1, кадровые синхроимпульсы имеют активный низкий уровень;
- PCR.CLK[X/R]M = 1, битовая синхронизации формируются внутренним генератором битовой синхронизации;
- SRGR.GSYNC = 1, генератор кадровой и битовой синхронизации синхронизируется внешним синхроимпульсом;
- SRGR.CLKSM = 1, генератор кадровой и битовой синхронизации тактируется внешним источником тактовой частоты;
- SRGR.CLKSP = 1, генератор кадровой и битовой синхронизации синхронизируются по отрицательному фронту тактовой частоты;
- SRGR.CLKGDV = 1, прием ведется на половине частоты опорного тактового сигнала;
- [X/R]CR.MPHASE = 0, кадр содержит одну фазу;
- [X/R]CR.FLEN P0 = 11111b, в кадре 32 слова;
- [X/R]CR.WLEN\_P0 = 111b, каждое слово кадра 8 бит;
- [X/R]CR.DELAY = 0 задержка данных в канале отсутствует.



Рисунок 21-27 - Диаграмма работы в режиме ST-BUS с удвоенной частотой

#### 21.37 Работа в многоканальном режиме с выбором каналов

В McBSP предусмотрена независимая настройка выборки определенных каналов из множества для приема/передачи данных. Каждый канал представлен потоком данных с временным разделением (ВРК). В данном режиме все каналы имеют длину WLEN\_P0 и количество FLEN\_P0. Работа бита MPHASE блокируется.

При использовании ВРК ЦП зачастую имеет необходимость работы только в некоторых из них. Для этого имеется возможность маскирования активных и неактивных каналов для снижения нагрузки на системную шину. Одновременно могут быть активны некоторые или все из 128 каналов. Весь набор каналов разбит на 8 блоков по 16 каналов. Все блоки включаются независимо. Маска каналов для четных

блоков содержится в регистрах XCERL и RCERL, а для нечетных XCERH и RCERH. Для всех четных блоков маска одинакова. Аналогично и для нечетных блоков.

Если отключен канал на прием, то данные в сдвиговый регистр приемника RSR не поступают и данные в нем не изменяются.

В передатчике в отключенном канале вывод DX находится в высокоимпедансном состоянии. Сдвига данных также не происходит.

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

#### 21.37.1 MCRH, MCRL, XMCR, RMCR

Таблица 21-20 – Регистры MCRH, MCRL, XMCR, RMCR

| 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       |
|---------|---------|---------|---------|---------|---------|---------|---------|
| BLK7_EN | BLK6_EN | BLK5_EN | BLK4_EN | BLK3_EN | BLK2_EN | BLK1_EN | BLK0_EN |
| R/W,+0  |
| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|         | CUR_BLK |         |         |         |         | MC      | CM      |
|         | R,+0    |         |         | R/W,+0  | R/W,+0  | R/W     | /,+0    |

Таблица 21-21 – Описание бит регистров MCRH, MCRL, XMCR, RMCR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое              |
|------|----------------|--------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                   |
| 158  | BLK_EN[7:0]    | Разрешение активности каналов в Блоке:                       |
|      |                | Бит 0 – каналы 0 15                                          |
|      |                | Бит 1 – каналы 16 31                                         |
|      |                | Бит 2 – каналы 32 47                                         |
|      |                | Бит 3 – каналы 48 63                                         |
|      |                | Бит 4 – каналы 64 79                                         |
|      |                | Бит 5 – каналы 80 95                                         |
|      |                | Бит 6 – каналы 96 111                                        |
|      |                | Бит 7 – каналы 112 127                                       |
|      |                | 0 – Блок каналов неактивен                                   |
|      |                | 1 – Блок каналов активен                                     |
| 75   | CUR_BLK[2:0]   | Номер текущего блока в кадре                                 |
| 42   | -              |                                                              |
| 10   | MCM[1:0]       | Выбор многоканального режима                                 |
|      |                | 00 – Все каналы включены                                     |
|      |                | 01 – Все каналы выключены                                    |
|      |                | 10 – Включены каналы согласно маске в регистрах XCER и       |
|      |                | RCER                                                         |
|      |                | 11 – Выключены каналы согласно маске в регистрах XCER и RCER |

## 21.38 Включение многоканального режима

Многоканальный режим для приемника и для передатчика включается независимо битами RMCR.MCM[1] = 1 и XMCR.MCM[1] = 1 соответственно.

Включение и маскирование каналов

В многоканальном режиме в McBSP доступны до 128 каналов разделенных на 8 блоков по 16 каналов в каждом. Каждый блок может быть включен (BLK\_EN[номер блока] = 1) или отключен (BLK\_EN[номер блока] = 0) независимо от других. Включение блока разрешает или запрещает работу каналов посредством регистра разрешения работы активности каналов XCER и RCER. При этом для четных блоков применяется маска из младшей части регистра разрешения активности каналов (XCERL и RCERL), а для нечетных – старшей (XCERH и RCERH).

В зависимости от режима работы МСМ могут быть включены или отключены все 128 каналов, включены каналы соответствующие «1» в маске или наоборот – включены все каналы соответствующие «0» в маске.

На рисунке приведено распределение каналов и блоков в кадре.



# 21.39 Регистр управления активностью каналов

Регистр управления активностью позволяет управлять активностью того или иного канала в многоканальном режиме работы McBSP. Поскольку число разрешений активности каналов менее доступного количества каналов в кадре, то активность того или иного канала кроме также определяется активностью или неактивностью блока (см выше). Регистр управления активность каналов разбит на младшую и старшую части, которые активны в четных и нечетных блоках соответственно.

Примечание — Настройку активности каналов и блоков не рекомендуется производить во время приема/передачи данных.

#### 21.39.1 *XCERH, RCERH*

| Таблица | 21-22 - | Регистр | ы XCERH | , RCERH |
|---------|---------|---------|---------|---------|
|---------|---------|---------|---------|---------|

| <b>31</b> [15] | <b>30</b> [14] | <b>29</b> [13] | <b>28</b> [12] | <b>27</b> [11] | <b>26</b> [10] | <b>25</b> [9] | <b>24</b> [8] |
|----------------|----------------|----------------|----------------|----------------|----------------|---------------|---------------|
| CH31_E         | CH30_E         | CH29_E         | CH28_E         | CH27_E         | CH26_E         | CH25_E        | CH24_E        |
| N              | N              | N              | N              | N              | N              | N             | N             |
| R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0        | R/W,+0        |
| <b>23</b> [7]  | <b>22</b> [6]  | <b>21</b> [5]  | <b>20</b> [4]  | <b>19</b> [3]  | <b>18</b> [2]  | <b>17</b> [1] | <b>16</b> [0] |
| CH23_E         | CH22_E         | CH21_E         | CH20_E         | CH19_E         | CH18_E         | CH17_E        | CH16_E        |
| N              | N              | N              | N              | N              | N              | N             | N             |
| R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0        | R/W,+0        |

Таблица 21-23 - Описание бит регистров XCERH, RCERH

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| 150 | CH_EN[15:0] | Разрешение активности канала N = номер бита + 16 |
|-----|-------------|--------------------------------------------------|
|     |             | 0 – Канал неактивен                              |
|     |             | 1 – Канал активен                                |

# 21.39.2 XCERL, RCERL

# Таблица 21-24 – Регистры XCERL, RCERL

| <b>15</b> [15] | <b>14</b> [14] | <b>13</b> [13] | <b>12</b> [12] | <b>11</b> [11] | <b>10</b> [10] | <b>9</b> [9] | <b>8</b> [8] |
|----------------|----------------|----------------|----------------|----------------|----------------|--------------|--------------|
| CH15_EN        | CH14_EN        | CH13_EN        | CH12_EN        | CH11_EN        | CH10_EN        | CH9_EN       | CH8_EN       |
| R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0       | R/W,+0       |
| <b>7</b> [7]   | <b>6</b> [6]   | <b>5</b> [5]   | <b>4</b> [4]   | <b>3</b> [3]   | <b>2</b> [2]   | <b>1</b> [1] | <b>0</b> [0] |
| CH7_EN         | CH6_EN         | CH5_EN         | CH4_EN         | CH3_EN         | CH2_EN         | CH1_EN       | CH0_EN       |
| R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0         | R/W,+0       | R/W,+0       |

# Таблица 21-25 - Описание бит регистров XCERL, RCERL

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 150       | CH_EN[15:0]                | Разрешение активности канала N = номер бита<br>0 – Канал неактивен<br>1 – Канал активен    |

# 21.39.3 Интерфейс A-bis

В режиме A-bis McBSP может принимать и передавать до 1024 бит ИКМтракта. Приемник *может* извлечь все 1024 бита из ИКМ-кадра в соответствии с заданной маской и выдать на ЦП прерывание при упаковке в слова до 16 бит.

# 22 Системный Таймер (DSP)

Таймер DSP является программируемым таймером, который управляется тремя регистрами и может быть использован для генерации прерываний или запросов DMA (прерывания для DSP и RISC-ядер, запросы для DMA DSP и DMA RISC). Временное разрешение таймера определяется частотой синхросигналов DSP. Высокий динамический диапазон таймера достигнут 16-битовым счетчиком с 4-битовым предварительным делителем частоты.

# 22.1 Регистры таймера (DSP)

Таймер состоит из трех регистров отображенных в памяти (TIM, PRD и TCR). Эти три регистра и их соответствующие адреса указаны в таблице ниже.

Таблица 22-1 – Регистры таймера DSP-подсистемы

| Адрес<br>RISC | Адрес<br>DSP | Название | Описание                   |
|---------------|--------------|----------|----------------------------|
| 0x3000_0070   | 0038h        | TIM      | Регистр таймера            |
| 0x3000_0072   | 0039h        | PRD      | Регистр периода таймера    |
| 0x3000_0074   | 003Ah        | TCR      | Регистр управления таймера |

### 22.1.1 Регистры таймера (ТІМ)

## Регистр текущего значения таймера (TIM)

16-битный регистр таймера, адрес которого отображен в памяти, загружается значением регистром периода (PRD) и декрементируется.

Таблица 22-2 - Регистр ТІМ

| Номер  | 150                      |  |  |  |
|--------|--------------------------|--|--|--|
| Доступ | RW                       |  |  |  |
| Сброс  | 0                        |  |  |  |
|        | Текущее значение таймера |  |  |  |

Таблица 22-3 – Биты регистра управления таймером TIM

| № Бита | Имя бита | Краткое описание назначения бита |
|--------|----------|----------------------------------|
| 15-0   | TIM      | Текущее значение таймера         |

#### 22.1.2 Регистр периода таймера (PRD)

16-битный регистр периода таймера отображаемый в памяти (PRD), используется для того, чтобы перезагружать регистр таймера (TIM).

Таблица 22-4 - Регистр PRD

| Номер  | 150                        |  |  |
|--------|----------------------------|--|--|
| Доступ | RW                         |  |  |
| Сброс  | 0                          |  |  |
|        | Начальное значение таймера |  |  |

# Таблица 22-5 – Биты регистра управления таймером PRD

| № Бита | Имя бита | Краткое описание назначения бита |  |
|--------|----------|----------------------------------|--|
| 15-0   | PRD      | Начальное значение таймера       |  |

# 22.1.3 Управляющий регистр таймера (TCR)

16-битный регистр управления таймера, адрес которого отображен в памяти (TCR), содержит управляющие биты и биты состояния таймера. Ниже приведены битовые поля TCR (Таблица 22-6) и их описание (Таблица 22-7).

# Таблица 22-6 - Регистр TCR

| Номер  | 1512 | 11   | 10   | 96  | 5   | 4   | 30   |
|--------|------|------|------|-----|-----|-----|------|
| Доступ | NA   | R/W  | R/W  | R/W | R/W | R/W | R/W  |
| Сброс  | 0    | 0    | 0    | 0   | 0   | 0   | 0    |
|        | -    | Soft | Free | PCS | TRB | TSS | TDDR |

## Таблица 22-7 – Биты регистра управления таймером TCR

| №<br>Бита                | Имя бита | Краткое описание назначения бита                                       |  |  |
|--------------------------|----------|------------------------------------------------------------------------|--|--|
| 15-12                    | -        | Зарезервировано                                                        |  |  |
| 11                       | Soft     | Когда бит 10 сброшен, бит выбирает режим таймера.                      |  |  |
|                          |          | 0 – Остановки таймера немедленные.                                     |  |  |
|                          |          | 1 – Остановки тогда, когда значение таймера декрементировано до 0.     |  |  |
| 10                       | Free     | Используется вместе с битом 11. Когда бит сброшен, бит 11              |  |  |
|                          |          | выбирает режим таймера.                                                |  |  |
|                          |          | 0 – Бит 11 выбирает режим таймера.                                     |  |  |
|                          |          | 1 – Таймер работает независимо от бита 11.                             |  |  |
|                          |          | Счетчик предварительного делителя частоты. Когда PSC                   |  |  |
|                          |          | декрементируется до нуля, значение регистра TIM                        |  |  |
|                          |          | декрементируется на 1, PSC снова загружается содержимым регистра TDDR. |  |  |
| 5                        | TRB      | Перезагрузка таймера. Сбрасывает встроенный таймер. При                |  |  |
|                          |          | установке TRB в 1, в регистр TIM загружается значение регистра         |  |  |
|                          |          | PRD, а в регистр PSC загружается значение регистра TDDR. Всегда        |  |  |
|                          |          | читается как 0.                                                        |  |  |
| 4 TSS Остановка таймера. |          | Остановка таймера.                                                     |  |  |
|                          |          | TSS = 0 таймер работает.                                               |  |  |
|                          |          | TSS = 1 таймер остановлен.                                             |  |  |
| 3-0                      | TDDR     | Базовое значение предварительного счетчика.                            |  |  |

# 23 Работа таймера (DSP)



Рисунок 23-1 - Блок-схема таймера

Таймер управляется предварительным делителем частоты (PSC), который декрементируется на единицу каждый такт синхросигнала DSP. Всякий раз, когда счетчик PSC достигает нуля, он загружается значением поля TDDR, а регистр TIM декрементируется. Когда обнуляются оба счетчика (TIM и PSC) полный цикл счета считается выполненым, регистр TIM загружается значением регистра PRD, поле PSC значением поля TDDR, и цикл счета начинается снова. При завершении каждого цикла вырабатывается прерывание для DSP и RISC и запрос прерываний для DMA RISC и DMA DSP.

Периодичность прерывания от таймера (TINT) равняется частоте синхросигнала DSP поделенной на два независимых сомножителя:

TINT rate = 
$$\frac{1}{t_{c(C)} \times u \times v} = \frac{1}{t_{c(C)} \times (TDDR + 1) \times (PRD + 1)}$$

где

tc(C) – период синхрогенератора DSP;

u – содержание TDDR плюс 1;

v – содержание PRD плюс 1.

# 24 Контроллер DMA (DSP)

Контроллер прямого доступа в память DSP реализован для ускоренного переноса данных внутри подсистемы DSP. Данный контроллер имеет доступ только внутри подсистемы DSP (кроме реистров ядра DSP) (Таблица 24-1). При этом, в качестве адресов источника, назначения и управляющих структур используются система адресации RISC (т.е. общее адресное пространство и байтовые адреса).

# 24.1 Особенности контроллера DMA(DSP)

Контроллер DMA DSP аналогичен контроллеру DMA RISC, за исключением следующих особенностей:

- Количество активных каналов сокращено до 16. Аппаратные запросы реализованы только от периферийных модулей DSP части (Таблица 24-3). При этом, те каналы, для которых определены аппаратные запросы могут быть настроены либо на программные, либо на аппаратные запросы. Остальные каналы способны обрабатывать только программные запросы.
- Доступ к регистрам DMA контроллера возможен как со стороны DSP, так и со стороны RISC, соответственно, програмные запросы и управление модулем может быть осуществлен обоими ядрами.
- Для обеспечения возможности доступа со стороны 16-разрядного DSP регистры контроллера разбиты на младшую и старшую часть каждый (Таблица 24-2). При этом, со стороны RISC младшая и старшие части регистров могут быть записаны одновременно (по 32 бита) по адресу младшей части.

Для получения подробной информации по функционированию контроллера DMA RISC см. раздел «Контроллер прямого доступа в память DMA RISC».

# 24.2 Возможности доступа DMA(DSP)

Контроллер DMA DSP части имеет доступ только внутри подсистемы DSP. Ему доступно все адресное пространство памяти программ и памяти данных, за исключением. В качестве адресов источника и назначения необходимо указывать адреса также как в RISC-подсистеме (32-х битный байтовый адрес). DMA контроллер DSP может быть использован для модификации памяти программ внутри DSP-подсистемы.

| Таблица 24-1 – Таблица дос | гупа к секторам памяти со стор | оны DMA DSP |
|----------------------------|--------------------------------|-------------|
|----------------------------|--------------------------------|-------------|

| Адрес DMA<br>DSP | Сектор                             | Тип со стороны<br>DMA (ВЫЗ) |
|------------------|------------------------------------|-----------------------------|
| 0x0000_0000      | BOOT ROM                           | NA                          |
| 0x0800_0000      | EEPROM                             | NA                          |
| 0x1000_0000      | EXTERNAL BUS                       | NA                          |
| 0x2000_0000      | SYSTEM RAM                         | NA                          |
| 0x2200_0000      | SYSTEM RAM Bit Band Region         | NA                          |
| 0x3000_0000      | Регистры ядра DSP                  | NA                          |
| 0x3000_0040      | Регистры периферийных модулей DSP  | WR                          |
| 0x3000_0100      | Память данных DSP                  | WR                          |
| 0x3002_0000      | Память программ DSP                | WR                          |
| 0x3000_0040      | Регистры периферийных модулей RISC | NA                          |
| 0x5000_0000      | EXTERNAL BUS                       | NA                          |

Обозначения:

NA – нет доступа;

RO – только чтение;

WR – полный доступ (чтение/запись).

# 24.3 Регистры контроллера DMA(DSP)

Набор регистров и их функции контроллера DMA DSP такие же, как и контроллера DMA RISC. Все регистры могут быть доступны как со стороны RISC так и со стороны DSP (Таблица 24-2). Т.к. количество каналов контроллера сокращено, во всех регистрах доступны биты управления каналами с 1 по 16.

Таблица 24-2 - Описание регистров контроллера DMA DSP

| Адрес<br>RISC | Адрес<br>DSP | Регистр               | Описание                                                                   |
|---------------|--------------|-----------------------|----------------------------------------------------------------------------|
| 0x3000_00C0   | 0060h        | DMA_STATUSL           | Статусный регистр ПДП                                                      |
| 0x3000_00C2   | 0061h        | DMA_STATUSH           |                                                                            |
| 0x3000_00C4   | 0062h        | DMA_CONFIGL           | Регистр конфигурации<br>ПДП                                                |
| 0x3000_00C6   | 0063h        | DMA_CONFIGH           |                                                                            |
| 0x3000_00C8   | 0064h        | CTRL_BASE_PTRL        | Регистр базового адреса<br>управляющих данных<br>каналов                   |
| 0x3000_00CA   | 0065h        | CTRL_BASE_PTRH        |                                                                            |
| 0x3000_00CC   | 0066h        | ALT_CTRL_BASE_PTRL    | Регистр базового адреса<br>альтернативных<br>управляющих данных<br>каналов |
| 0x3000_00CE   | 0067h        | ALT_CTRL_BASE_PTRH    |                                                                            |
| 0x3000_00D0   | 0068h        | DMA_WAITONREG_STATUSL | Регистр статуса ожидания<br>запроса на обработку<br>каналов                |
| 0x3000_00D2   | 0069h        | DMA_WAITONREG_STATUSH |                                                                            |
| 0x3000_00D4   | 006Ah        | CHNL_SW_REQUESTL      | Регистр программного<br>запроса на обработку<br>каналов                    |
| 0x3000_00D6   | 006Bh        | CHNL_SW_REQUESTH      |                                                                            |
| 0x3000_00D8   | 006Ch        | CHNL_USEBURST_SETL    | Регистр установки<br>пакетного обмена каналов                              |
| 0x3000_00DA   | 006Dh        | CHNL_USEBURST_SETH    |                                                                            |
| 0x3000_00DC   | 006Eh        | CHNL_USEBURST_CLRL    | Регистр сброса пакетного обмена каналов                                    |
| 0x3000_00DE   | 006Fh        | CHNL_USEBURST_CLRH    |                                                                            |
| 0x3000_00E0   | 0070h        | CHNL_REQ_MASK_SETL    | Регистр маскирования<br>запросов на обслуживание<br>каналов                |
| 0x3000_00E2   | 0071h        | CHNL_REQ_MASK_SETH    |                                                                            |
| 0x3000_00E4   | 0072h        | CHNL_REQ_MASK_CLRL    | Регистр очистки маскирования запросов на обслуживание каналов              |
| 0x3000_00E6   | 0073h        | CHNL_REQ_MASK_CLRH    |                                                                            |
| 0x3000_00E8   | 0074h        | CHNL_ENABLE_SETL      | Регистр установки<br>разрешения каналов                                    |
| 0x3000_00EA   | 0075h        | CHNL_ENABLE_SETH      |                                                                            |

| 0x3000_00EC | 0076h | CHNL_ENABLE_CLRL   | Регистр сброса разрешения каналов                                               |
|-------------|-------|--------------------|---------------------------------------------------------------------------------|
| 0x3000_00EE | 0077h | CHNL_ENABLE_CLRH   |                                                                                 |
| 0x3000_00F0 | 0078h | CHNL_PRI_ALT_SETL  | Регистр установки первичной/альтернативной структуры управляющих данных каналов |
| 0x3000_00F2 | 0079h | CHNL_PRI_ALT_SETH  |                                                                                 |
| 0x3000_00F4 | 007Ah | CHNL_PRI_ALT_CLRL  | Регистр сброса первичной/альтернативной структуры управляющих данных каналов    |
| 0x3000_00F6 | 007Bh | CHNL_PRI_ALT_CLRH  |                                                                                 |
| 0x3000_00F8 | 007Ch | CHNL_PRIORITY_SETL | Регистр установки приоритета каналов                                            |
| 0x3000_00FA | 007Dh | CHNL_PRIORITY_SETH |                                                                                 |
| 0x3000_00FC | 007Eh | CHNL_PRIORITY_CLRL | Регистр сброса приоритета каналов                                               |
| 0x3000_00FE | 007Fh | CHNL_PRIORITY_CLRH |                                                                                 |
| 0x3000_010C | 0086h | ERR_CLRL           | Регистр сброса флага<br>ошибки                                                  |
| 0x3000_010E | 0087h | ERR_CLRH           | Регистр сброса флага<br>ошибки                                                  |

# 24.4 Распределение аппаратных запросов по каналам DMA(DSP)

Количество каналов контроллера сокращено до 16. Из них аппаратные прерывания заведены на 10 каналов. Запрос на эти каналы может быть осуществлен как программным, так и аппаратным способом. Транзакции по остальным каналам могут быть активированы программно.

Таблица 24-3 – Распределение аппаратных запросов DMA DSP по каналам

| Номер<br>канала | Источник reg | Источник sreg | Описание                       |
|-----------------|--------------|---------------|--------------------------------|
| 0               | mcBSP1 TX    | mcBSP1 TX     | Запрос DMA от mcBSP1 по        |
|                 |              |               | передаче                       |
| 1               | mcBSP1 RX    | mcBSP1 RX     | Запрос DMA от mcBSP1 по приему |
| 2               | mcBSP2 TX    | mcBSP2 TX     | Запрос DMA от mcBSP2 по        |
|                 |              |               | передаче                       |
| 3               | mcBSP2 RX    | mcBSP2 RX     | Запрос DMA от mcBSP2 по приему |
| 4               | mcBSP3 TX    | mcBSP3 TX     | Запрос DMA от mcBSP3 по        |
|                 |              |               | передаче                       |
| 5               | mcBSP3 RX    | mcBSP3 RX     | Запрос DMA от mcBSP3 по приему |
| 6               | AUC_in       | AUC_in        | Запрос DMA от Аудиокодека по   |
|                 |              |               | приему (АЦП)                   |
| 7               | AUC_out      | AUC_out       | Запрос DMA от Аудиокодека по   |
|                 |              |               | передаче (ЦАП)                 |
| 8               | Timer        | Timer         | Запрос DMA от Таймера          |
| 9               | Crypto       | Crypto        | Запрос DMA от Криптомодуля     |
| 10              | -            | -             | Только программные запросы     |
| 11              | -            | -             | Только программные запросы     |
| 12              | -            | -             | Только программные запросы     |
| 13              | -            | -             | Только программные запросы     |
| 14              | -            | -             | Только программные запросы     |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| 15 | - | - | Только программные запросы |
|----|---|---|----------------------------|

# 25 Контроллер AudioCodec (DSP)

Характеристики контроллера:

- Одноканальный ∑∆ АЦП с разрядность выходных отчетов 16 бит;
- Одноканальный ∑∆ ЦАП с разрядность входных отчетов 16 бит;
- Дифференциальный и недифференциальный аналоговый вход/выход;
- Возможность микширования данных тракта АЦП и ЦАП;
- Встроенный аналоговый antialiasing фильтр;
- Ручная регулировка усиления в тракте АЦП;
- Блок имеет независимые DMA каналы для тракта АЦП и ЦАП;
- Блок формирует сигнал прерывания по внутренним событиям;
- Имеет встроенный формирователь синхросигналов;
- ЦАП имеет защиту от короткого замыкание:
- Примечание Все измерения проводились для частоты отсчетов 8 кГц.

Таблица 25-1 - Параметры каналов ЦАП/АЦП

| Параметр                        | Значение  |
|---------------------------------|-----------|
| Уровень "0" для ЦАП             | 1,5 B     |
| Размах сигнала для ЦАП, р-р     | 2 B (max) |
| Уровень "0" для АЦП             | 1,5 B     |
| Размах входного сигнала для АЦП | 2 B (max) |

#### 25.1 Задание рабочей частоты аудиокодека

Рабочая частота аудиокодека задается при помощи регистра ADC\_MCO\_CLOCK (см. раздел "Сигналы тактовой частоты"). Запись данных в регистры осуществляется на частоте РСLК. Для пересинхронизации данных перед их обработкой цифровой частью аудиокодека реализован два раздельных FIFO интерфейса (для ЦАП и АЦП) по 16 16-ти битных отсчетов каждый.

#### 25.2 Архитектура модуля



Рисунок 25-1 - Структура IP звукового кодека

# Аналоговый фильтр нижних частот

Встроенный аналоговый фильтр нижних частот – фильтр с двумя полюсами, у которого есть ослабление на 20 дБ в 1 МГц.

# Сигма-Дельта АЦП

Аналого-цифровой преобразователь (АЦП) — модулятор дельты сигмы с фиксированной частотой дискретизации 256 отсчетов рабочей частоты аудиокодека.

Изменение частоты дискретизации достигается изменением рабочей частоты аудиокодека.

#### Фильтр децимации

Фильтры децимации – это фильтр БИХ или КИХ, в зависимости от состояния бита IIREN регистра общего управления кодеком. Фильтр КИХ обеспечивает выход линейной фазы 32/fs групповой задержки, тогда как фильтр БИХ генерирует нелинейную фазу с незначительной групповой задержкой. Фильтры децимации уменьшают цифровую скорость передачи данных до частоты сэмплирования. Это достигается коэффициентом передискретизации 128. Выход фильтра децимации 16-битные данные в дополнительном коде на частоте сэмплирования. ВW фильтра (0.45 FS) и изменяется линейно в зависимости от частоты сэмплирования.

# Интерполирующий фильтр

Фильтры интерполяции – это БИХ фильтр. Фильтр БИХ имеет нелинейный выход фазы с незначительной задержкой группы. Фильтр интерполяции передискретизирует цифровые данные в 64 раза поступающей частоты, в зависимости от заданной частоты дискретизации ЦАП. Выход фильтра используется в сигма-дельта ЦАП.

#### Цифровая обратная петля

Данные с выходов АЦП ослабляются и смешиваются со входами ЦАП. Уровень петли задается битами SIDETON регистра DACCTL.

#### Программируемый усилитель АЦП

В модуле имеется встроенный программируемый усилитель для управления уровнями сигнала на выходе АЦП. Программируемый усилитель может быть установлен с использованием поля ADGAIN регистра ADCCTL. Диапазон усилителя канала АЦП составляет от 20 до -42 дБ с шагом 1 дБ. Чтобы избежать внезапных скачков на уровнях сигнала с изменениями поля диапазона усиления, переход к новому значению ADGAIN происходит при пересечении нуля.

# Программируемый усилитель ЦАП

В модуле имеется встроенный программируемый усилитель для управления уровнями сигнала на выходе ЦАП. Программируемый усилитель ЦАП может быть установлен с использованием поля DAGAIN регистра DACCTL. Диапазон усилителя канала ЦАП составляет от 20 до -42 дБ с шагом 1 дБ. Чтобы избежать внезапных скачков на уровнях сигнала с изменениями поля диапазона усиления ЦАП, переход к новому значению DAGAIN происходит при пересечении нуля.

#### 25.3 Аналоговые площадки ввода-вывода

Для работы модуля реализованы три программируемых аналоговых входа и один программируемый аналоговый выход (Таблица 25-2). При помощи поля AINSEL регистра ADCCTL можно выбрать источник аналогового входа со входов MICIN, INP1/M1 или INP2/M2. Все аналоговые ввод/вывод могут быть как обычными, так и дифференциальными. Все аналоговые входы системы имеют внутренне смещение к 1,5 В. Управление аналоговым выходом осуществляется при помощи регистра DACCTL.



Рисунок 25–2 – Дифференциальное (а) и псевдо дифференциальное (б) подключение модуля

Таблица 25-2 – Выводы блока

| Название<br>вывода | Направление | Описание                    |
|--------------------|-------------|-----------------------------|
|                    | 1           | Dvo z wywoodouo             |
| MICIN              | ı           | Вход микрофона              |
| INP2               | I           | Положительный вход канала 2 |
| INM2               | I           | Отрицательный вход канала 2 |
| INP1               | I           | Положительный вход канала 1 |
| INM1               | I           | Отрицательный вход канала 1 |
| OUTP1              | 0           | Положительный выход         |
| OUTM1              | 0           | Отрицательный выход         |
| BIAS               | 0           | Выход смещения 1,5 В        |

#### 25.3.1 Вход микрофона

Модуль поддерживает один не диференциальный вход микрофона. Микрофонный вход выбирается установкой поля AINSEL в состояние 01 или 10.

В случае установки поля AINSEL в состояние 01 выбирается режим с внутренним формирование смещения в 1,5 В. Для уменьшения шума в этом режиме необходимо подключить микрофонный вход, как показано на рисунке (Рисунок 25–3 а).

Запись значение 10 в поле AINSEL переводит аудиокодек в псевдодиференциальный режим. В этом режиме недиференциальный вход объединяется с микрофонным входом и выходом напряжения смещения BIAS (Рисунок 25–3 б). Для уменьшения помех выводы MICIN и INM1 должны иметь разводку одинаковой длины.

Недиференциальный вход преобразуется внутри в диференциальный перед преобразованием для лучшей защиты от шумов. Для улучшения динамических характеристик модуль поддерживает настраиваемый предусилитель. Управление предусилителем осуществляется при помощи поля INBG регистра ADCCTL.



Рисунок 25-3 - Подключение MICIN

# 25.3.2 Входы INP и INM

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



Рисунок 25-4 - Внутрення схема смещения INP и INM

#### Недифференциальный вход

Каждый из дифференциальных входов (INP1/2 и INM1/2) может быть подключен как недиференциальный. Для этого вывод INP соответвующеговхода необходимо подключитьк источнику сигнала, а вывод INM к земле (Рисунок 25–5).



Рисунок 25-5 - Недифференциальный вход

#### 25.3.3 Аналоговые выходы

Выходы OUTP и OUTM диференциальные выходы канала ЦАП. Выходы OUTP и OUTM могут обеспечить прямую нагрузку 600 OM и могут быть использованы как не дифференциальны выходы (Рисунок 25–6).



Рисунок 25-6 - Подключение выходовОUTP1/OUTM1

#### 25.4 Работа с модулем

# 25.4.1 Воспроизведение звука (ЦАП)

Для воспроизведения потока данных необходимо:

- 1. Подать синхросигнал на DSP-подсистему (см. "Сигналы тактовой частоты").
- 2. Снять сброс с периферии DSP (см. "Организация управления DSP-подсистемой").
- 3. Подать синхросигнал на модуль Аудиокодек (см. "Сигналы тактовой частоты").
- 4. Записать в FIFO DAC 16 отсчетов (регистр DACREG). В случае если на момент начала работы модуля оставить FIFO пустым, возможны сбои при дальнейшей работе.
- 5. Настроить DAC припомощи регистра DACCTL. Обязательным является включение аналоговой части ЦАП (ODDAC), выходов OUTP1/OUTM1 (ODAMP), Всей схемы ЦАП (DACRES).
- 6. Включить DAC и выбрать фильтр (регистр POWCTL). При этом цифровая и аналоговая обратные связи должны быть обнулены.
- 7. По запросу прерывания или пофлагу регистра IRQFLAG записывать в FIFO DAC (регистр DACREG ) новые отсчеты. В том случае, если новые отсчеты не записаны в регистр, выход DAC стабилизируется в состоянии, соответствующем последнему записанному отсчету и бит DACVF регистра IRQFLAG будет взведен.

# 25.4.2 Оцифровка входного потока (АЦП)

Для оцифровки входного потока данных необходимо:

- 1. Подать синхросигнал на DSP-подсистему (см. "Сигналы тактовой частоты").
- 2. Снять сброс с периферии DSP (см. "Организация управления DSP-подсистемой").
- 3. Подать синхросигнал на модуль Аудиокодек (см. "Сигналы тактовой частоты").
- 4. Настроить ADC припомощи регистра ADCCTL. В регистре задаются: бит включения АЦП, выбор источника для АЦП (см. "Аналоговые площадки ввода-вывода"), уровень записи и уровень входного предусилителя.
- 5. Включить ADC и выбрать фильтр (регистр POWCTL). При этом цифровая и аналоговая обратные связи должны быть обнулены.
- 6. По запросу прерывания или по флагу регистра IRQFLAG считывать из FIFO ADC (регистр ADCREG) новые отсчеты. В том случае, если новые отсчеты не считаны, возможна потеря отсчетов и бит ADCVF регистра IRQFLAG будет взведен.

#### **25.4.3** Запросы DMA

Запросы DMA от модуля выведены на 22 канал (ЦАП) и на 23 канал (АЦП) DMA контроллера RISC, на 7 канал DMA (ЦАП) и на 6 канал DMA (АЦП) контроллера DSP (см. "Контроллер DMA (DSP)" и "Контроллер прямого доступа в память MDR DMA").

Запросы DMA ЦАП возникает в случае опустошения в FIFO ЦАП как минимум четырех отсчетов.

Запросы DMA АЦП возникают, если в FIFO АЦП имеется четыре или более отсчетов.

#### 25.4.4 Прерывания модуля

Прерывания от модуля аудиокодек могут быть обработаны как при помощи RISC-процессора, так и при помощи DSP-процессора (см. разделы "Прерывания и исключения RISC" и "Прерывания DSP"). Вектора прерываний ЦАП и АЦП различны для обоих ядер.

Прерывание ЦАП возводится по любому из нижеперечисленных событий:

- Короткое замыкания выхода ЦАП (В том случае, если прерывание незамаскировано в регистре MASKCTL и разрешена схема детектирования короткого замыкания в регистре DACCTL).
- Случилось опустошение FIFO DAC (В том случае, если прерывание незамаскировано в регистре MASKCTL).
- Есть хотябы один свободный отсчет FIFO DAC (В том случае, если прерывание незамаскировано в регистре MASKCTL).

Прерывание АЦП возводится по любому из нижеперечисленных событий:

- Случилось переполнение FIFO ADC (В том случае, если прерывание незамаскировано в регистре MASKCTL).
- Есть хотя бы одно оциврованной значение FIFO ADC (В том случае, если прерывание незамаскировано в регистре MASKCTL).

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

Таблица 25-3 – Регистры управления

| Адрес RISC  | Адрес  | Название | Начальное  | Описание                 |
|-------------|--------|----------|------------|--------------------------|
|             | DSP    |          | значение   |                          |
| 0x3000_00A0 | 0x0050 | POWCTL   | 0x000001C0 | Общее управление кодеком |
| 0x3000_00A4 | 0x0052 | ADCCTL   | 0x0000002A | Управление АЦП           |
| 0x3000_00A8 | 0x0054 | DACCTL   | 0x0000002A | Управление ЦАП           |
| 0x3000_00AC | 0x0056 | MASKCTL  | 0x0000000F | Маска вектора прерываний |
| 0x3000_00B0 | 0x0058 | IRQFLAG  | 0x00000000 | Флаги прерываний         |
| 0x3000_00B4 | 0x005A | ADCREG   | 0x00000000 | АЦП FIFO регистр         |
| 0x3000_00B8 | 0x005C | DACREG   | 0x00000000 | ЦАП FIFO регистр         |

# 25.5.1 Регистр общего управления кодеком

Таблица 25-4 – Описание бит регистра общего управления кодеком

| Бит | Поле  | Нач. значение | Описание              |
|-----|-------|---------------|-----------------------|
| 0   | ADCEN | 0             | Включение канала АЦП  |
|     |       |               | 0 – канал выключен    |
|     |       |               | 1 – канал включен     |
| 1   | DACEN | 0             | Включение канала ЦАП  |
|     |       |               | 0 – канал выключен    |
|     |       |               | 1 – канал включен     |
| 2   | IIREN | 0             | Включение БИХ фильтра |
|     |       |               | 0 – фильтр выключен   |
|     |       |               | 1 – фильтр включен    |

# 25.5.2 Регистр управления АЦП

Таблица 25-5 – Описание бит регистра управления АЦП

| Бит | Поле   | Нач. значение | Описание                                        |
|-----|--------|---------------|-------------------------------------------------|
| 5:0 | ADGAIN | 101010        | Уровень записи (шаг – 1dB)                      |
|     |        |               | 111111 : Mute                                   |
|     |        |               | 111110: +20dB                                   |
|     |        |               | 111101:+19dB                                    |
|     |        |               | <br>404040 - 0-ID                               |
|     |        |               | 101010 : 0dB                                    |
|     |        |               | 101001 : -1dB                                   |
|     |        |               |                                                 |
| 7.0 | INIDC  | 00            | 000000 : -42dB                                  |
| 7:6 | INBG   | 00            | Входной предусилитель                           |
|     |        |               | 00 : 0dB<br>01 : 6dB                            |
|     |        |               | 10 : 12dB                                       |
|     |        |               | 11 : 24 dB                                      |
| 9:8 | AINSEL | 00            | Выбор источника для аналогового входа           |
| 3.0 | AINOLL | 00            | оо – сигнал на INP1/INM1                        |
|     |        |               | 01 – сигнал на MICIN с внутренним формированием |
|     |        |               | смещения 1,5 В                                  |
|     |        |               | 10 – сигнал на MICIN с внешним формированием    |
|     |        |               | смещения                                        |
|     |        |               | 11 – сигнал на INP2/INM2                        |
| 11  |        | -             | Зарезервировано                                 |
| 10  | ICONT  | 0             | Управление аналоговым АЦП и фильтром            |
|     |        |               | 0 – выключен                                    |

| _ |  |               |
|---|--|---------------|
|   |  |               |
|   |  | I 1 — ВКПЮЧЕН |

# 25.5.3 Регистр управления ЦАП

# Таблица 25-6 – Описание бит регистра управления ЦАП

| Бит   | Поле     | Нач.<br>значение | Описание                                                                                                                        |
|-------|----------|------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 5:0   | DAGAIN   | 101010           | Уровень воспроизведения (шаг – 1dB)<br>111111 : Mute<br>111110 : +20dB<br>111101 : +19dB                                        |
|       |          |                  | 101010 : 0dB<br>101001 : -1dB<br>                                                                                               |
| 6     | MUTE1    | 0                | 000000 : -42dB  Mute на выходах OUTP1/OUTM1 0 – выходы OUTP1/OUTM1 работает в нормальном режиме 1 – выходы OUTP1/OUTM1 обнулены |
| 7     | ODAMP    | 0                | Управление аналоговым выходным усилителем OUTP1/OUTM1 0: OUTP1/OUTM1 – OFF. 1: OUTP1/OUTM1 – ON.                                |
| 8     | ODDAC    | 0                | Управление схемой смещения BIAS.<br>0 – Схема смещения BIAS выключена.<br>1 – Схема смещения BIAS включена.                     |
| 9     | ODDAC    | 0                | Управление аналоговым DAC и фильтрами<br>0 – аналоговая часть DAC выключена.<br>1 – аналоговая часть DAC включена.              |
| 10    | OVECBA   | 0                | Разрешение схемы детектирования короткого замыкания выходного буфера 1 – разрешено. 0 – запрещено.                              |
| 11    | OVECBS   | 0                | Разрешение схемы детектирования короткого замыкания схемы смещения. 1 – разрешено. 0 – запрещено.                               |
| 14:12 | SIDETONE | 111              | Цифровая обратная петля.  111 — Mute  110 — -21dB  110 — -18dB  110 — -15dB  110 — -12dB  110 — -9dB  110 — -6dB  000 — -3dB    |
| 15    | DACRES   | 1                | Сброс ЦАП (аналоговая часть).<br>0 – ЦАП находится в сбросе.<br>1 – ЦАП находится в рабочем режиме.                             |

# 25.5.3.1 Маска вектора прерываний

Таблица 25-7 – Описание бит маски вектора прерываний

| Бит | Поле     | Нач.     | Описание                                             |
|-----|----------|----------|------------------------------------------------------|
|     |          | значение |                                                      |
| 0   | DAOVFM   | 1        | Маска прерывания по событию чтения со стороны        |
|     |          |          | аудиокодека пустого значения из FIFO DAC (FIFO пусто |
|     |          |          | и произошло чтение)                                  |
|     |          |          | 0 – запретить прерывание                             |
|     |          |          | 1 – разрешить прерывание                             |
| 1   | ADCVFM   | 1        | Маска прерывания по событию записи в переполненный   |
|     |          |          | FIFO ADC со стороны ЦПУ                              |
|     |          |          | 0 – запретить прерывание                             |
|     |          |          | 1 – разрешить прерывание                             |
| 2   | ADCNSM   | 1        | Маска прерывания ADC FIFO                            |
|     |          |          | 0 – запретить прерывание                             |
|     |          |          | 1 – разрешить прерывание                             |
| 3   | DACNSM   | 1        | Маска прерывания DAC FIFO                            |
|     |          |          | 0 – запретить прерывание                             |
|     |          |          | 1 – разрешить прерывание                             |
| 4   | OVERCURM | 1        | Маска прерывания короткого замыкания выхода ЦАП      |
|     |          |          | 0 – запретить прерывание                             |
|     |          |          | 1 – разрешить прерывание                             |

# 25.5.4 Флаги прерываний

# Таблица 25-8 – Описание бит флагов прерываний

| Бит | Поле    | Нач.     | Описание                                                                                                                               |
|-----|---------|----------|----------------------------------------------------------------------------------------------------------------------------------------|
|     |         | значение |                                                                                                                                        |
| 0   | DAOVF   | 0        | Прерывания по событию чтения со стороны аудиокодека пустого значения из FIFO DAC (FIFO пусто и произошло чтение) 0 – DAC не переполнен |
|     |         |          | 1 – Произошло переполнение DAC                                                                                                         |
|     |         |          | Запись '1' сбрасывает прерывание                                                                                                       |
| 1   | ADCVF   | 0        | Прерывания по событию записи в переполненный FIFO ADC со стороны ЦПУ.  0 – ADC не переполнен                                           |
|     |         |          | 1 – Произошло переполнение ADC                                                                                                         |
|     |         |          | Запись '1' сбрасывает прерывание                                                                                                       |
| 2   | ADCNS   | 0        | Прерывание ADC FIFO                                                                                                                    |
|     |         |          | 0 – ADC FIFO пусто                                                                                                                     |
|     |         |          | 1 – в ADC FIFO имеется хотя бы один отсчет для чтения                                                                                  |
| 3   | DACNS   | 0        | Прерывание DAC FIFO 0 – DAC FIFO пусто 1 – в DAC FIFO имеется хотя бы одно свободное место                                             |
|     |         |          | для записи отсчета                                                                                                                     |
| 4   | OVERCUR | 0        | Прерывания короткого замыкания выхода ЦАП<br>0 – нет прерывания КЗ ЦАП<br>1 – есть прерывание КЗ ЦАП                                   |

#### 25.5.4.1 **АЦП FIFO** регистр

# Таблица 25-9 – Описание бит регистра АЦП FIFO

| Бит  | Поле   | Нач.     | Описание               |
|------|--------|----------|------------------------|
|      |        | значение |                        |
| 15:0 | ADCSMP | 00       | Новый отчет тракта АЦП |

# **25.5.4.2 ЦАП FIFO регистр**

# Таблица 25-10 - Описание бит регистра ЦАП FIFO

| Бит  | Поле   | Нач.     | Описание               |
|------|--------|----------|------------------------|
|      |        | значение |                        |
| 15:0 | DACSMP | 00       | Новый отчет тракта ЦАП |

# 26 Контроллер блока шифрования ГОСТ 28147-89 (DSP)

Блок шифрования предназначен для аппаратной поддержки программ криптографической защиты информации в соответствии с ГОСТ 28147-89.

Со стороны ядра микроконтроллера блок шифрования представляет собой набор программно доступных 16-разрядных регистров (Таблица 26-1).

# 26.1 Описание регистров

Таблица 26-1 - Описание регистров блока шифрования

| Адрес RISC  | Адрес DSP | Название регистра | Описание                 |
|-------------|-----------|-------------------|--------------------------|
| 0x3000_0080 | 0x0040    | CRPT_CWR          | регистра управления      |
| 0x3000_0084 | 0x0042    | CRPT_SR           | регистра состояния       |
| 0x3000_0088 | 0x0044    | CRPT_DATA         | регистра данных          |
| 0x3000_008C | 0x0046    | CRPT_KR           | регистра ключа           |
| 0x3000_0090 | 0x0048    | CRPT_CR           | регистра констант замены |
| 0x3000_0094 | 0x004A    | CRPT_SYNR         | регистра синхропосылки   |
| 0x3000_0098 | 0x004C    | CRPT_IMIT         | регистра имитовставки    |
| 0x3000_009C | 0x004E    | CRPT_ITER         | регистра числа итераций  |

Регистры данных, ключа, синхропосылки и констант замены являются 16-разрядными портами, через который осуществляется доступ к соответствующим массивам данных (8 байт), ключа (32 байта), синхропосылки (8 байт), констант замены (64 байт) и имитовставки (8 байт).

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

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

Флаг запроса прерывания CRPTIF (выход INT устройства) устанавливается после окончания преобразования данных при условии, что биты IE\_ CRPT (регистра CRPT\_CWR) и CRPTIE (регистра PIE1) установлены. Запрос прерывания снимается либо при сбросе устройства (программном или аппаратном), либо при старте (установке бита "START" регистра управления), либо по факту чтения данных.



Рисунок 26–1 – Блок-схема блока аппаратной поддержки алгоритма шифрования по ГОСТ 28147-89

Выработка имитовставки возможна в любом из описанных выше режимов работы. Для корректной работы в режимах с выработкой имитовставки необходимо перед загрузкой ключа, данных и т.д. сбросить устройство (установить бит "RST" в регистре управления) для синхронизации с началом пакета обрабатываемых данных. Таким образом, процесс программирования в режимах с выработкой имитовставки дополнятся еще одним, самым первым действием — сбросом устройства. В остальном отличий нет. После окончания преобразования данных имитовставка считывается из порта имитовставки, из нее программным путем вырезается отрезок нужной длины и посылается вслед пакету преобразованных данных.

В режимах дешифрации данных необходимо после обсчета последнего пакета данных дать еще одни старт преобразования для завершения расчета имитовставки. При этом требуется установить бит IM в регистре CRPT\_CWR, а новые данные посылать не требуется.

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

Таблица 26-2 - Описание бит регистра управления CRPT\_CWR

| R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0  BIST RST IE_CRPT DIR START IM MODE1_ MODE0_                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |       |                                                                |              |             |             |               |           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|----------------------------------------------------------------|--------------|-------------|-------------|---------------|-----------|
| бит 7 6 5 4 3 2 1 6ит 0  бит 7 ВІЗТ: Тестовый режим работы.  КЯТ: Сброс – предназначен для приведения устройства в исходное состояние.  Примечание - Бит «RST» сбрасывается автоматически в следующем цикле системной тактовой частоты  бит 5 ІЕ_СRPТ: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  бит 4 DIR: Направление шифрации: «0» – шифрация, «1» – дешифрация.  бит 3 START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных.  Примечание - Бит «START» сбрасывается автоматически после начала преобразования  бит 2 ІМ: Выработка имитовставки в режимах дешифрации данных. Бит «ІМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0 МОDE1_CRPT — МОDE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки.  Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                | R/W-0 | R/W-0 | R/W-0                                                          | R/W-0        | R/W-0       | R/W-0       | R/W-0         | R/W-0     |
| бит 7 6 5 4 3 2 1 бит 0 бит 7 ВІЯТ: Тестовый режим работы.  КЯТ: Сброс – предназначен для приведения устройства в исходное состояние. Примечание - Бит «RST» сбрасывается автоматически в следующем цикле системной тактовой частоты  Бит 5 ІЕ_СRPТ: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  Бит 4 БІЯ: Направление шифрации: «0» – шифрация, «1» – дешифрация.  Бит 3 ЗТАТ: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  Бит 2 ІМ: Выработка имитовставки в режимах дешифрации данных. Бит «ІМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0 МОDE1_СRPT – МОDE0_СRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                        | BIST  | RST   | IE_CRPT                                                        | DIR          | START       | IM          | MODE1_        | MODE0_    |
| бит 7  ВIST: Тестовый режим работы.  RST: Сброс – предназначен для приведения устройства в исходное состояние.  Примечание - Бит «RST» сбрасывается автоматически в следующем цикле системной тактовой частоты  ВЕСRPТ: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  Вит 4  DIR: Направление шифрации: «0» – шифрация, «1» – дешифрация.  ВТАRТ: Старт. Предназначен для запуска процесса шифрации/дешифрации данных.  Примечание - Бит «START» сбрасывается автоматически после начала преобразования  Вит 3  ИК: Выработка имитовставки в режимах дешифрации данных. Бит «Им» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  Вит 1, 0  МОDE1_CRPT — МОDE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить режим «11» и послать команду «старт». Далее необходимо установить нужный |       |       |                                                                |              |             |             | CRPT          | CRPT      |
| бит 6  RST: Сброс – предназначен для приведения устройства в исходное состояние.  Примечание - Бит «RST» сбрасывается автоматически в следующем цикле системной тактовой частоты  IE_CRPT: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  бит 4  DIR: Направление шифрации: «0» – шифрация, «1» – дешифрация.  бит 3  START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  бит 2  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IM» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT — МОDE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                             | бит 7 | 6     | 5                                                              | 4            | 3           | 2           | 1             | бит 0     |
| состояние. Примечание - Бит «RST» сбрасывается автоматически в следующем цикле системной тактовой частоты  Бит 5  IE_CRPT: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  Бит 4  DIR: Направление шифрации: «0» — шифрация, «1» — дешифрация.  Бит 3  START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  бит 2  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT — MODE0_CRPT: Режим работы блока: 00 — работа в режиме гаммирования; 10 — работа в режиме гаммирования с обратной связью; 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                  | би    | т 7   | BIST: Tect                                                     | овый режим   | і работы.   |             |               |           |
| Примечание - Бит «RST» сбрасывается автоматически в следующем цикле системной тактовой частоты  IE_CRPT: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  бит 4 DIR: Направление шифрации: «0» — шифрация, «1» — дешифрация.  бит 3 START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  бит 2 IM: Выработка имитовставки в режимах дешифрации данных. Бит «IM» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0 MODE1_CRPT — MODE0_CRPT: Режим работы блока:  00 — работа в режиме гаммирования;  10 — работа в режиме гаммирования с обратной связью;  11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                     | би    | т 6   | RST: Сброс – предназначен для приведения устройства в исходное |              |             |             |               |           |
| Следующем цикле системной тактовой частоты  Бит 5  IE_CRPT: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  Бит 4  DIR: Направление шифрации: «0» — шифрация, «1» — дешифрация.  Бит 3  START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  бит 2  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IM» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT — MODE0_CRPT: Режим работы блока: 00 — работа в режиме простой замены; 01 — работа в режиме гаммирования; 10 — работа в режиме гаммирования с обратной связью; 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                            |       |       |                                                                |              |             |             |               |           |
| бит 5  IE_CRPT: Разрешение прерывания. Используется для разрешения («1») или запрета («0») выдачи сигнала прерывания.  бит 4  DIR: Направление шифрации: «0» — шифрация, «1» — дешифрация.  бит 3  START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  бит 2  IM: Выработка имитовставки в режимах дешифрации данных. Бит «ІМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT — MODE0_CRPT: Режим работы блока: 00 — работа в режиме простой замены; 01 — работа в режиме гаммирования; 10 — работа в режиме гаммирования с обратной связью; 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                        |       |       | Примечани                                                      | 1е - Бит «RS | ST» сбрасыв | ается автом | иатически в   |           |
| («1») или запрета («0») выдачи сигнала прерывания.  Бит 4  DIR: Направление шифрации: «0» — шифрация, «1» — дешифрация.  Бит 3  START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  Бит 2  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT — MODE0_CRPT: Режим работы блока: 00 — работа в режиме простой замены; 01 — работа в режиме гаммирования; 10 — работа в режиме гаммирования с обратной связью; 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                           |       |       | следующе                                                       | и цикле сис  | темной такт | овой частот | Ы             |           |
| бит 3  DIR: Направление шифрации: «0» — шифрация, «1» — дешифрация.  START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT — MODE0_CRPT: Режим работы блока: 00 — работа в режиме простой замены; 01 — работа в режиме гаммирования; 10 — работа в режиме гаммирования с обратной связью; 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                             | би    | т 5   |                                                                |              |             |             |               | зрешения  |
| бит 3  START: Старт. Предназначен для запуска процесса шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IM» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |       | («1») или з                                                    | апрета («0»  | ) выдачи си | гнала прерь | ывания.       |           |
| шифрации/дешифрации данных. Примечание - Бит «START» сбрасывается автоматически после начала преобразования  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | би    | т 4   | DIR: Напра                                                     | вление шис   | фрации: «0» | – шифраци   | ıя, «1» – дец | иифрация. |
| Примечание - Бит «START» сбрасывается автоматически после начала преобразования  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IM» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | би    | т 3   |                                                                |              |             | запуска про | цесса         |           |
| начала преобразования  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IM» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |       |                                                                |              |             |             |               |           |
| бит 2  IM: Выработка имитовставки в режимах дешифрации данных. Бит «IM» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока: 00 – работа в режиме простой замены; 01 – работа в режиме гаммирования; 10 – работа в режиме гаммирования с обратной связью; 11 – инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |       |                                                                |              |             | ывается авт | гоматически   | і после   |
| «ІМ» устанавливается после окончания обработки данных для завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  МОDE1_CRPT — МОDE0_CRPT: Режим работы блока:  00 — работа в режиме простой замены;  01 — работа в режиме гаммирования;  10 — работа в режиме гаммирования с обратной связью;  11 — инициализация синхропосылки.  Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |       |                                                                |              |             |             |               |           |
| завершения выработки имитовставки. После установки необходимо выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  МОDE1_CRPT – MODE0_CRPT: Режим работы блока:  00 – работа в режиме простой замены;  01 – работа в режиме гаммирования;  10 – работа в режиме гаммирования с обратной связью;  11 – инициализация синхропосылки.  Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | би би | т 2   |                                                                |              |             |             |               |           |
| выполнить еще один цикл обработки (не посылая данных), после чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока:  00 – работа в режиме простой замены;  01 – работа в режиме гаммирования;  10 – работа в режиме гаммирования с обратной связью;  11 – инициализация синхропосылки.  Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |       |                                                                |              |             |             |               |           |
| чего имитовставка может быть прочитана из устройства  бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока:  00 – работа в режиме простой замены;  01 – работа в режиме гаммирования;  10 – работа в режиме гаммирования с обратной связью;  11 – инициализация синхропосылки.  Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |       |                                                                |              |             |             |               |           |
| бит 1, 0  MODE1_CRPT – MODE0_CRPT: Режим работы блока:  00 – работа в режиме простой замены;  01 – работа в режиме гаммирования;  10 – работа в режиме гаммирования с обратной связью;  11 – инициализация синхропосылки.  Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |       |                                                                |              |             |             |               | (), после |
| 00 — работа в режиме простой замены; 01 — работа в режиме гаммирования; 10 — работа в режиме гаммирования с обратной связью; 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | 1 0   |                                                                |              |             |             |               |           |
| 01 — работа в режиме гаммирования;<br>10 — работа в режиме гаммирования с обратной связью;<br>11 — инициализация синхропосылки.<br>Примечание - В режимах «01» и «10» перед началом обработки<br>данных следует записать синхропосылку, установить режим «11» и<br>послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | бит   | 1, 0  |                                                                |              |             |             | ы блока:      |           |
| 10 — работа в режиме гаммирования с обратной связью; 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |       |                                                                |              |             |             |               |           |
| 11 — инициализация синхропосылки. Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |       |                                                                |              |             |             | J             |           |
| Примечание - В режимах «01» и «10» перед началом обработки данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |       |                                                                |              |             |             | ои связью;    |           |
| данных следует записать синхропосылку, установить режим «11» и послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |       |                                                                |              |             |             |               | - F       |
| послать команду «старт». Далее необходимо установить нужный                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |       |                                                                |              |             |             |               |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |       |                                                                |              |             |             |               |           |
| режим и оораоотать данные                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |       |                                                                |              |             | еооходимо   | установить    | нужныи    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |       | режим и ос                                                     | рраоотать д  | анные       |             |               |           |

Обозначения здесь и далее по тексту:

R – бит для чтения;

W – бит с возможностью записи;

U – бит не реализован, читается как 0;

-n – значение бита после сброса по включению питания:

1 – установлен;

0 – сброшен;

х – значение не известно.

# 26.1.2 Регистр состояния CRPT\_SR

Таблица 26-3 – Описание бит регистра состояния CRPT\_SR

| R-0                                                   | R-0                                                              | R-0                                                    | R-0         | R-0         | R-0         | R-0            | R-0            |
|-------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------------|-------------|-------------|-------------|----------------|----------------|
| DNC_BIS<br>T                                          | KW(*)                                                            | SW(*)                                                  | DR(*)       | DW(*)       | KF(*)       | ERROR_<br>CRPT | READY_<br>CRPT |
| бит 7                                                 | 6                                                                | 5                                                      | 4           | 3           | 2           | 1              | бит 0          |
| би                                                    | бит 7 DNC BIST: Результат динамического контроля/самотестировани |                                                        |             |             |             | рования        |                |
| би                                                    | т 6                                                              | KW(*): Coc                                             | тояние указ | ателя чтени | я памяти им | итоданных      |                |
| би                                                    | т 5                                                              | SW(*): Состояние указателя записи памяти синхропосылки |             |             |             |                |                |
| бит 4 DR(*): Состояние указателя чтения памяти данных |                                                                  |                                                        |             |             |             |                |                |

| бит 3 | DW(*): Состояние указателя записи памяти данных                                                                                                                                                                                                        |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бит 2 | KF(*): Состояние указателя записи памяти ключа                                                                                                                                                                                                         |
| бит 1 | ERROR_CRPT: Ошибка. Бит определяет наличие или отсутствие ошибки в работе устройства. Состояние ошибки возникает в случае попытки запустить процесс преобразования данных при не                                                                       |
|       | полностью записанных данных или ключе                                                                                                                                                                                                                  |
| бит 0 | READY_CRPT: Работа/готовность. Бит определяет готовность данных после выполненного преобразования (шифрации или дешифрации). После начала преобразования данных бит автоматически сбрасывается и вновь устанавливается после завершения преобразования |

<sup>(\*)</sup> Биты 6...2 зарезервированы для системных целей. По их состоянию программист при необходимости может определить положение указателей записи и чтения (состояние битов и интерпретация будут определены в дальнейшем, так как для работы они не являются необходимыми)

# 26.1.3 Регистр данных шифрации CRPT DATA

# Таблица 26-4 – Описание бит регистра данных шифрации CRPT DATA

| R/W-0   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W-0                                                                                                                                                                                                                                                               |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA15  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DATA0                                                                                                                                                                                                                                                               |
| бит 15  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | бит 0                                                                                                                                                                                                                                                               |
| бит 150 | DATA15DATA0: 16-ти разрядный порт для ввода исходных или вывода преобра этом адрес для всех байтов данных в про и тот же. Запись всех байтов данных в мо последовательной записью 16-ти разряд регистра данных, начиная с младшего ба текста, если данные рассматривать как т осуществляется аналогично. Реальная а памяти модуля осуществляется внутреннавтоматически инкрементирующимися из зависимости от направления передачи дуказатели записи и чтения сбрасываются | данных, предназначенный азованных данных. При ограмме указывается один одуль осуществляется ных слов по адресу ойта (или первого байта екст). Чтение дресация во внутренней ними указателями, пи декрементирующимися в анных. Отметим, что а при программном сбросе |
|         | устройства, т.е. при установке бита «RST                                                                                                                                                                                                                                                                                                                                                                                                                                  | »                                                                                                                                                                                                                                                                   |

# 26.1.4 Регистр ключа шифрации CRPT\_KR

#### Таблица 26-5 – Описание бит регистра ключа шифрации CRPT\_KR

| R/W-0   |                                                                                                                                                                                                                                                                                       | R/W-0                |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| KEY15   |                                                                                                                                                                                                                                                                                       | KEY0                 |
| бит 15  |                                                                                                                                                                                                                                                                                       | бит 0                |
| бит 150 | КЕҮ15 КЕҮ0: 16-ти разрядный порт ключа, предназначе ввода исходного ключа. При этом адрес для всех байтов и программе указывается одни и тот же. Запись всех байтов модуль осуществляется последовательной записью 16-ти разрядных слов по адресу регистра ключа, начиная с мла байта | ключа в<br>з ключа в |

# 26.1.5 Регистр синхропосылки CRPT SYNR

# Таблица 26-6 – Описание бит регистра синхропосылки CRPT\_SYNR

| R/W-0   |                                                         | R/W-0      |
|---------|---------------------------------------------------------|------------|
| SYNCH15 |                                                         | SYNCH0     |
| бит 15  |                                                         | бит 0      |
| бит 150 | SYNCH15SYNCH0: 16-ти разрядный порт синхропосылк        | (И,        |
|         | предназначенный для ввода или вывода синхропосылки.     | При этом   |
|         | адрес для всех байтов синхропосылки в программе указы   | вается     |
|         | один и тот же. Запись всех байтов данных в модуль осуще | ествляется |
|         | последовательной записью 16-ти разрядных слов по адре   | ecy        |
|         | регистра синхропосылки, начиная с младшего байта. Чтен  | ние        |
|         | осуществляется аналогично                               |            |

# 26.1.6 Регистр констант замены CRPT\_CR

# Таблица 26-7 - Описание бит регистра констант замены CRPT\_CR

| R/W-0   |                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W-0                                             |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|
| CONST15 |                                                                                                                                                                                                                                                                                                                                                                                                                                                   | CONST0                                            |
| бит 15  |                                                                                                                                                                                                                                                                                                                                                                                                                                                   | бит 0                                             |
| бит 150 | СОNST15СОNST0: 16-ти разрядный порт констант заме предназначенный для ввода констант замены. При этом а всех байтов констант в программе указывается один и тот Запись всех байтов данных в модуль осуществляется последовательной записью байтов по адресу регистра да начиная с младшего байта. Ввод констант замены осущество 16 разрядов, те есть вводятся сразу 4 константы. Запо узлов замены осуществляется, начиная с 1 узла и заканчы 8. | дрес для<br>г же.<br>нных,<br>ствляется<br>лнение |

# 26.1.7 Регистр имитовставки CRPT IMIT

# Таблица 26-8 – Описание бит регистра имитовставки CRPT\_IMIT

| R/W-0   |                                                    | R/W-0     |
|---------|----------------------------------------------------|-----------|
| IMIT15  |                                                    | IMIT0     |
| бит 15  |                                                    | бит 0     |
| бит 150 | IMIT15 IMIT0: 16-ти разрядный порт имитовставки,   |           |
|         | предназначенный для вывода имитовставки после пр   |           |
|         | шифрации и дешифрации. При этом адрес для всех 6   |           |
|         | имитовставки в программе указывается один и тот же | е. Чтение |
|         | всех байтов данных из модуля осуществляется        |           |
|         | последовательно по адресу регистра имитовставки, н | начиная с |
|         | младшего байта. Выработка имитовставки осуществл   | пяется    |
|         | автоматически параллельно с шифрацией или дешис    | фрацией   |
|         | данных. После окончания шифрования имитовставка    | l         |
|         | считывается из регистра и далее обрабатывается пр  | ограммно  |
|         | в соответствие с ГОСТ 28147-89                     |           |

# 26.1.8 Регистр числа итераций CRPT\_ITER

Таблица 26-9 – Описание бит регистра числа итераций CRPT ITER

| R/W-0                                                                    | R/W-0       | R/W-1 R/W-0 R/W-0 R/W-0 R/W-0                                                                                             |                 |       |       |       |       |  |  |  |
|--------------------------------------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------|-----------------|-------|-------|-------|-------|--|--|--|
| -                                                                        | EN_CRP<br>T | ITER5                                                                                                                     | ITER4           | ITER3 | ITER2 | ITER1 | ITER0 |  |  |  |
| бит 7                                                                    | 6           | 5                                                                                                                         | 5 4 3 2 1 бит 0 |       |       |       |       |  |  |  |
| би                                                                       | т 7         | зарезервировано.                                                                                                          |                 |       |       |       |       |  |  |  |
| би                                                                       | т 6         | EN_CRPT: Бит разрешения работы блока. «0» – блок аппаратной поддержки алгоритма кодирования выключен; «1» – блок включен. |                 |       |       |       |       |  |  |  |
| бит 50 ITER5ITER0: Регистр счетчика итераций циклов шифрации/дешифрации. |             |                                                                                                                           |                 |       |       |       |       |  |  |  |

Примечание – Бит EN\_CRPT меняется только в том случае, если бит DNC\_BIST регистра CRPT CWR сброшен.

# 26.2 Работа блока по шифрованию и дешифрованию данных

# 26.2.1 Шифрование данных. Режим простой замены

Порядок выполняемых действий:

- 1. выполнить программный сброс блока для синхронизации имитовставки (установить бит «RST» в регистре управления);
- 2. установить режим «00» в регистре управления и бит направления шифрования;
- 3. ввести ключ;
- 4. ввести константы замены;
- 5. ввести очередной блок данных;
- 6. установить бит «START» в регистре управления;
- 7. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 8. прочитать преобразованные данные и, если не все пакеты обработаны перейти к п.5, или, в противном случае, перейти к п.9.;
- 9. прочитать имитовставку из порта имитовставки.

Примечание — Пункты 1 и 2 (программный сброс и установка режимов) можно выполнять одновременно (одной командой).

#### 26.2.2 Дешифрование данных. Режим простой замены

Порядок выполняемых действий:

- 1. выполнить программный сброс устройства для синхронизации имитовставки (установить бит «RST» в регистре управления);
- 2. ввести ключ;
- 3. ввести константы замены;
- 4. установить режим «00» в регистре управления и бит направления шифрования;
- 5. ввести очередной блок данных;
- 6. установить бит «START» в регистре управления;

- 7. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 8. прочитать преобразованные данные и, если не все пакеты обработаны перейти к п.5, или, в противном случае, перейти к п.9;
- 9. одновременно установить биты «IM» и «START» в регистре управления для завершения выработки имитовставки (их запись в регистр должна проводиться одной командой);
- 10. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 11. прочитать имитовставку из порта имитовставки.

# 26.2.3 Шифрование данных. Режим гаммирования

Порядок выполняемых действий:

- 1. выполнить программный сброс устройства для синхронизации имитовставки (установить бит «RST» в регистре управления);
- 2. ввести ключ:
- 3. ввести константы замены;
- 4. установить режим «11» в регистре управления для инициализации синхропосылки и бит направления шифрования;
- 5. ввести синхропосылку;
- 6. установить бит «START» в регистре управления;
- 7. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 8. установить режим гаммирования «01»;
- 9. ввести очередной блок данных;
- 10. установить бит «START» в регистре управления;
- 11. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 12. прочитать преобразованные данные и, если не все пакеты обработаны перейти к п.9, или, в противном случае перейти к п.13;
- 13. прочитать имитовставку из порта имитовставки.

#### 26.2.4 Дешифрование данных. Режим гаммирования

Порядок выполняемых действий:

- 1. выполнить программный сброс устройства для синхронизации имитовставки (установить бит «RST» в регистре управления);
- 2. ввести ключ;
- 3. ввести константы замены;
- 4. установить режим «11» в регистре управления для инициализации синхропосылки и бит направления шифрования;
- 5. ввести синхропосылку;
- 6. установить бит «START» в регистре управления;
- 7. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 8. установить режим гаммирования «01»;
- 9. ввести очередной блок данных;
- 10. установить бит «START» в регистре управления;
- 11. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);

- 12. прочитать преобразованные данные и, если не все пакеты обработаны перейти к п.9, или, в противном случае перейти к п.13;
- 13. одновременно установить биты «START» и «IM» в регистре управления для завершения выработки имитовставки;
- 14. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 15. прочитать имитовставку из порта имитовставки.

# 26.2.5 Шифрование данных. Режим гаммирования с обратной связью

Порядок выполняемых действий:

- 1. выполнить программный сброс устройства для синхронизации имитовставки (установить бит «RST» в регистре управления);
- 2. ввести ключ;
- 3. ввести константы замены;
- 4. установить режим гаммирования с обратной связью «10» в регистре управления и бит направления шифрования;
- 5. ввести синхропосылку;
- 6. ввести очередной блок данных;
- 7. установить бит «START» в регистре управления;
- 8. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 9. прочитать преобразованные данные и, если не все пакеты обработаны перейти к п.6, или, в противном случае перейти к п.10;
- 10. прочитать имитовставку из порта имитовставки.

# 26.2.6 Дешифрование данных. Режим гаммирования с обратной связью

Порядок выполняемых действий:

- 1. выполнить программный сброс устройства для синхронизации имитовставки (установить бит «RST» в регистре управления);
- 2. ввести ключ;
- 3. ввести константы замены;
- 4. установить режим гаммирования с обратной связью «10» в регистре управления и бит направления шифрования;
- 5. ввести синхропосылку;
- 6. ввести очередной блок данных;
- 7. установить бит «START» в регистре управления;
- 8. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 9. прочитать преобразованные данные и, если не все пакеты обработаны перейти к п.6, или, в противном случае перейти к п.10;
- 10. одновременно установить биты «START» и «IM» в регистре управления для завершения выработки имитовставки;
- 11. подождать, пока преобразование закончится (либо по прерыванию, либо по опросу бита готовности);
- 12. прочитать имитовставку из порта имитовставки.

#### 26.2.7 Режим самопроверки

Самопроверка устройства может осуществляться между преобразованиями пакетов данных. Для ее осуществления надо записать в регистр управления управляющее слово «11100000», если завершение самотестирования определяется по прерыванию, или «11000000», если завершение определяется по опросу бита готовности. Результат самотестирования определяется состоянием бита «DNC\_BIST» регистра контроля устройства. Если он установлен в «1», то устройство исправно, в противном случае аппаратура работает с ошибками.

Динамический контроль данных в процессе вычислений осуществляется автоматически. После окончания процесса шифрования бит «DNC\_BIST» содержит результат динамического контроля процесса шифрования. Если бит установлен в «1», то результат динамического контроля положительный, в противном случае во время работы схемы произошла ошибка.

# 26.2.8 Порядок занесения констант замены и ключа в соответствии с ГОСТ Р 34.11-94

В приложении А ГОСТ Р 34.11-94 приведена таблица констант замены. Последовательность занесения данных из этой таблицы в регистр CRPT\_CR содержит Таблица 26-11.

В приложении A ГОСТ Р 34.11-94 на странице 7 приведён ключ замены: K1= 733D2C20 65686573 74746769 79676120

626E7373 20657369 326C6568 33206D54 Порядок занесения этого ключа в регистр CRPT\_KR содержит Таблица 26-12.

| Таблица 26-1 | 0 – Констан | ты замены |
|--------------|-------------|-----------|
|--------------|-------------|-----------|

|    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
|----|---|---|---|---|---|---|---|---|
| 0  | 1 | D | 4 | 6 | 7 | 5 | Е | 4 |
| 1  | F | В | В | С | D | 6 | В | Α |
| 2  | D | 4 | Α | 7 | Α | 1 | 4 | 9 |
| 3  | 0 | 1 | 0 | 1 | 1 | D | С | 2 |
| 4  | 5 | 3 | 7 | 5 | 0 | Α | 6 | D |
| 5  | 7 | F | 2 | F | 8 | 3 | D | 8 |
| 6  | Α | 5 | 1 | D | 9 | 4 | F | 0 |
| 7  | 4 | 9 | D | 8 | F | 2 | Α | Е |
| 8  | 9 | 0 | 3 | 4 | Ш | Ш | 2 | 6 |
| 9  | 2 | Α | 6 | Α | 4 | F | 3 | В |
| 10 | 3 | Е | 8 | 9 | 6 | C | 8 | 1 |
| 11 | Ш | 7 | 5 | Ш | C | 7 | 1 | С |
| 12 | 6 | 6 | 9 | 0 | В | 6 | 0 | 7 |
| 13 | В | 8 | С | 3 | 2 | 0 | 7 | F |
| 14 | 8 | 2 | F | В | 5 | 9 | 5 | 5 |
| 15 | С | С | Е | 2 | 3 | В | 9 | 3 |

Таблица 26-11 – Последовательность занесения данных в регистр CRPT\_CR

| Номер | Константа | Номер | Константа | Номер | Константа | Номер | Константа |
|-------|-----------|-------|-----------|-------|-----------|-------|-----------|
| 1     | 0xA4      | 17    | 0x85      | 33    | 0xC6      | 49    | 0xBD      |
| 2     | 0x29      | 18    | 0xD1      | 34    | 0x17      | 50    | 0x14      |
| 3     | 0x8D      | 19    | 0x3A      | 35    | 0xF5      | 51    | 0xF3      |

| Номер | Константа | Номер | Константа | Номер | Константа | Номер | Константа |
|-------|-----------|-------|-----------|-------|-----------|-------|-----------|
| 4     | 0xE0      | 20    | 0x24      | 36    | 0x8D      | 52    | 0x95      |
| 5     | 0xB6      | 21    | 0xFE      | 37    | 0xA4      | 53    | 0xA0      |
| 6     | 0xC1      | 22    | 0x7C      | 38    | 0xE9      | 54    | 0x7E      |
| 7     | 0xF7      | 23    | 0x06      | 39    | 0x30      | 55    | 0x86      |
| 8     | 0x35      | 24    | 0xB9      | 40    | 0x2B      | 56    | 0xC2      |
| 9     | 0xBE      | 25    | 0xD7      | 41    | 0xB4      | 57    | 0xF1      |
| 10    | 0xC4      | 26    | 0x1A      | 42    | 0x0A      | 58    | 0x0D      |
| 11    | 0xD6      | 27    | 0x80      | 43    | 0x27      | 59    | 0x75      |
| 12    | 0xAF      | 28    | 0xF9      | 44    | 0xD1      | 60    | 0x4A      |
| 13    | 0x32      | 29    | 0x4E      | 45    | 0x63      | 61    | 0x29      |
| 14    | 0x18      | 30    | 0xC6      | 46    | 0x58      | 62    | 0xE3      |
| 15    | 0x70      | 31    | 0x2B      | 47    | 0xC9      | 63    | 0xB6      |
| 16    | 0x95      | 32    | 0x35      | 48    | 0xEF      | 64    | 0xC8      |

# Таблица 26-12 – Порядок занесения ключа в регистр CRPT\_KR

| Номер | Константа | Номер | Константа | Номер | Константа | Номер | Константа |
|-------|-----------|-------|-----------|-------|-----------|-------|-----------|
| 1     | 0x54      | 9     | 0x69      | 17    | 0x20      | 25    | 0x73      |
| 2     | 0x6D      | 10    | 0x73      | 18    | 0x61      | 26    | 0x65      |
| 3     | 0x20      | 11    | 0x65      | 19    | 0x67      | 27    | 0x68      |
| 4     | 0x33      | 12    | 0x20      | 20    | 0x79      | 28    | 0x65      |
| 5     | 0x68      | 13    | 0x73      | 21    | 0x69      | 29    | 0x20      |
| 6     | 0x65      | 14    | 0x73      | 22    | 0x67      | 30    | 0x2C      |
| 7     | 0x6C      | 15    | 0x6E      | 23    | 0x74      | 31    | 0x3D      |
| 8     | 0x32      | 16    | 0x62      | 24    | 0x74      | 32    | 0x73      |

# 27 Контроллер интерфейса MDR\_USB

Контролер USB реализует функции контроллера функционального устройства (Device) и управляющего устройства (Host) в соответствии со спецификацией USB 1.0. Контроллер USB поддерживает следующие возможности:

- режимы работы Full Speed (12 Мбит/с) и Low Speed (1,5 Мбит/с);
- контроль ошибок с помощью циклического избыточного кода (CRC);
- NRZI код приема/передачи;
- управляющая (Control);
- сплошная (Bulk);
- изохронная (Isochronous) передачи и передача по прерываниям (Interrupt);
- конфигурирование USB Device от 1-й до 4-х оконечных точек. Каждая оконечная точка USB Device имеет собственную память FIFO размером 64 байта. USB Host поддерживает до 16 оконечных точек. Возможности USB Host: FIFO размером 64 байта; автоматическая отправка SOF пакетов; вычисление оставшегося во фрейме времени.

#### 27.1 Инициализация контроллера при включении

При включении питания в первую очередь должны быть заданы параметры тактового сигнала блока USB. Источником тактового сигнала для блока USB может быть внешний генератор HSE. Блок USB функционирует на частоте 48 МГц. Требуемая частота может быть получена умножением частоты генератора до требуемого значения. Умножение выполняется встроенным блоком PLL\_USB.

Блок умножения позволяет провести умножение входной тактовой частоты на коэффициент от 2 до 16, задаваемый в поле PLLUSBMUL регистра PLL\_CONTROL. Входная частота блока умножителя должна быть в диапазоне 6...16 МГц, выходная должна составлять 48 МГц. При выходе блока умножителя тактовой частоты в расчетный режим вырабатывается сигнал PLLRDY. Блок включается с помощью сигнала PLLUSBON. Выходная частота используется как основная частота протокольной части USB интерфейса.

Для задания тактовой частоты блока необходимо соблюдать следующий порядок работы. Установить бит разрешения тактирования блока (бит 3 регистра PER\_CLOCK). В регистре USB\_CLOCK установить бит USBCLKEN, задать источник тактового сигнала в полях USBC1SEL и USBC2SEL. Установить бит PLLUSBON и задать коэффициент умножения в поле PLLUSBMUL регистра PLL\_CONTROL, если используется USBPLL.

После подачи тактового сигнала на блок USB необходимо выполнить сброс контроллера. Сброс выполняется установкой бита RESET\_CORE в регистре USB\_HSCR. Сигнал сброса необходимо удерживать как минимум 10 циклов тактовой частоты. После этого могут быть заданы параметры шины USB (скорость, полярность, наличие подтяжек).

# 27.2 Задание параметров шины USB и события подключения/отключения

Контроллер USB может быть сконфигурирован как USB Host или как USB Device. Конфигурация задается битом CORE\_MODE в регистре HSCR (0 – режим Device, 1 – режим Host). Прием/передача через физический интерфейс USB разрешаются установкой бит EN RX и EN TX в этом же регистре. В режиме приема

имеется возможность отключить передатчик в целях экономии потребления (EN TX=0). Отключение всего блока в целом осуществляется при EN RX=0.

В режиме Device параметры шины задаются в регистре SC. Скорость задается битом SCFSR (0 – 1,5 Мбит/c, 1 – 12 Мбит/c), полярность битом SCFSP (0 – Low speed, 1 – Full speed) этого регистра.

- В режиме Host параметры шины задаются в регистре HTXLC. Скорость задается битом FSLR (0 1,5 Мбит/с, 1 12 Мбит/с), полярность битом FSPL (0 Low speed, 1 Full speed) этого регистра.
- В режиме Host контроллер автоматически определяет подключение или отключение устройства к шине. Бит CONEV регистра USB\_HIS устанавливается в 1 при возникновении одного из событий.

В режиме Host необходимо прямое подключение (без USB HUB) Low speed устройства.

#### 27.3 Задание адреса и инициализация оконечных точек

Функциональный адрес устройства USB задается в регистре SA.

Для инициализации конечной точки в первую очередь необходимо установить бит глобального разрешения всех оконечных точек (SCGEN = 1 в регистре SC). Биты EPEN в регистрах SEP[x].CTRL должны быть установлены, чтобы разрешить соответствующую оконечную точку. Если предполагается использовать изохронный тип передачи оконечной точки, то необходимо установить бит EPISOEN в соответствующем регистре SEP[x].CTRL.

# 27.4 Транзакция IN (USB Device)

Если на шине появляется IN пакет, и адрес совпадает с заданным в регистре SA, то бит SCTDONE регистра SIS устанавливается в 1.

Если оконечная точка не готова (бит EPRDY = 0 в регистре SEP[x].CTRL), то контроллер отправляет NAK пакет (Рисунок 27-1 а). Бит NAKSENT регистра SEP[x].STS устанавливается в 1.



# Рисунок 27–1 (а, б, в) – Транзакция IN (USB Device) а – оконечная точка не готова; б – установлен бит EPSTALL; в – оконечная точка готова

Если оконечная точка готова и установлен бит EPSSTALL в регистре SEP[x].CTRL, то контроллер отправляет STALL пакет (Рисунок 27–1 б). Бит SCSTALLSENT регистра SEP[x].STS устанавливается в 1.

Если оконечная точка готова (Рисунок 27–1 в), биты SCTTYPE[1:0] в регистре SEP[x].TS устанавливаются в значение 1 для конечной точки с номером,

содержащимся в поле пакета. Контроллер может передавать пакет данных. Пакет данных формируется записью в регистр EP[x]. TXFD побайтно в FIFO оконечной точки. Запись 1 в EP[x]. TXFDC сбрасывает указатель FIFO передачи в 0. Максимальный размер передаваемого пакета составляет 64 байт. Попытка записи более 64 байт подряд приведет к переполнению FIFO. Перед началом формирования очередного пакета необходимо выполнять сброс указателя FIFO.

Если в ответ на переданные данные хост отправляет АСК пакет, то бит SCACKRXED в регистре SEP[x].STS устанавливается в 1. Для отправки следующего пакета необходимо инвертировать бит EPDATASEQ в регистре SEP[x].CTRL, чтобы соблюдалась очередность отправки пакетов DATA0, DATA1.

После окончания транзакции бит SCTDONE регистра SIS должен быть очищен записью 1.

# 27.5 Транзакция SETUP/OUT (USB Device)

Если на шине появляется SETUP/OUT пакет, и адрес совпадает с заданным в регистре USB\_SA и оконечная точка готова (бит EP\_READY = 1 в регистре ENDPOINTx CONTROL), то бит SCTDONE регистра SIS устанавливается в 1.

Если оконечная точка не готова (бит EPRDY = 0 в регистре SEP[x].CTRL), то контроллер отправляет NAK пакет (Рисунок 27–2 а). Бит NAKSENT регистра SEP[x].ST устанавливается в 1.

Если оконечная точка готова и установлен бит EPSSTALL в регистре SEP[x].CTRL, то контроллер отправляет STALL пакет (Рисунок 27–2 б). Бит SCSTALLSENT регистра SEP[x].STS устанавливается в 1.

Если оконечная точка готова (Рисунок 27–2 в) и на шине был пакет SETUP, то биты SCTTYPE[1:0] в регистре SEP[x].TS устанавливаются в значение 00 для конечной точки с номером, содержащимся в поле пакета. Если пакет OUT, то значение SCTTYPE[1:0] = 2.



Рисунок 27–2 (а, б, в) – Транзакция SETUP/OUT (USB Device) а – оконечная точка не готова; б – установлен бит EPSTALL; в – оконечная точка готова

Когда на шине появляется DATA0/DATA1 пакет, данные начинают записываться побайтно в FIFO приема соответствующей оконечной точки. После записи каждого байта увеличивается на единицу счетчик принятых байтов. Принятые байты считываются через регистр EP[x].RXFD. Количество принятых байтов

содержится в регистре EP[x].RXFDC. После приема очередного пакета необходимо выполнять сброс указателя FIFO приема записью 1 в регистр EP[x].RXFC.

После окончания транзакции бит SCTDONE регистра SIS должен быть очищен записью 1.

# 27.6 Транзакция SETUP/OUT (USB Host)

Для начала транзакции должны быть заданы адрес устройства (регистр HTXA), оконечная точка (регистр HTXE) и тип token пакета (регистр HTXT). Данные записываются побайтно в регистр HTXFD. Максимальный размер передаваемого пакета составляет 64 байтов. Попытка записи более 64 байтов подряд приведет к переполнению FIFO. Запись 1 в HTXFDC сбрасывает указатель FIFO передачи в 0. Перед началом формирования очередного пакета необходимо выполнять сброс указателя FIFO. Транзакция запускается при установке бита TREQ регистра HTXC. Ноst отправляет пакет Setup/Out и пакет данных.

После окончания транзакции бит TDONE = 1 (регистр HIS). Этот бит перед началом каждой транзакции должен быть очищен записью 1. PID принятого пакета записывается в регистре HRXP.

Если в ответ получен пакет NAK (Рисунок 27-3 а), то бит NAKRXED = 1 (регистр HRXS).

Если в ответ получен пакет STALL (Рисунок 27–3 б), то бит STALLRXED = 1 (регистр HRXS).

Если в ответ получен пакет ACK (Рисунок 27-3 в), то бит ACKRXED = 1 (регистр HRXS).



Рисунок 27-3 (а, б, в) - Транзакция SETUP/OUT (USB Host)

# 27.7 Транзакция IN (USB Host)

Для начала транзакции должны быть заданы адрес устройства (регистр HTXA), оконечная точка (регистр HTXE) и тип token пакета (регистр HTXT). Транзакция запускается при установке бита TREQ регистра HTXC. Host отправляет IN пакет.

После окончания транзакции бит TDONE = 1 (регистр HIS). Этот бит перед началом каждой транзакцией должен быть очищен записью 1. PID принятого пакета записывается в регистре HRXP.

Если в ответ получен пакет NAK (Рисунок 27–4 а), то бит NAKRXED = 1 (регистр HRXS).

Если в ответ получен пакет STALL (Рисунок 27–4 б), то бит STALLRXED = 1 (регистр HRXS).

Если приходит DATA0/DATA1 пакет (Рисунок 27–4 в), то данные начинают записываться побайтно в FIFO приема. После записи каждого байта увеличивается на единицу счетчик принятых байтов. Принятые байты считываются через регистр HRXFD. Количество принятых байтов содержится в регистре HRXFDC. После приема очередного пакета необходимо выполнять сброс указателя FIFO приема записью 1 в регистр HRXFC. Бит DATASEQ регистра HRXS отображает тип принятого пакета данных (0 – DATA0, 1 – DATA1).



Рисунок 27-4 (а, б, в) – Транзакция IN (USB Host)

#### 27.8 Отправка SOF пакетов и отсчет времени (USB Host)

Для того, чтобы контроллер автоматически отправлял SOF пакеты на Full speed, необходимо установить SOFEN в регистре HTXSE. Если FSPL = 1 (регистр TXLC), то SOF будет автоматически отсылаться каждые 1 мс. Если FSPL = 0, то автоматически будет отправляться EOP каждые 1 мс.

После отправки SOF пакета бит SOFS = 1 (регистр HIS). Этот бит должен быть очищен записью 1.

Контроллер ведет счет времени во фрейме таймером. Таймер увеличивается на частоте 48 МГц и имеет 48000 тактов в 1 мс фрейме. Старший байт таймера содержится в регистре HSTM. Этот регистр может быть использован для вычисления оставшегося во фрейме времени.

# 27.9 Описание регистров управление контроллером USB интерфейса Таблица 27-1 – Описание регистров управление контроллером USB интерфейса

| Базовый адрес | Название                         | Описание                                                           |
|---------------|----------------------------------|--------------------------------------------------------------------|
| 0x4001_0000   | MDR_USB                          | Контроллер USB интерфейса                                          |
| Смещение      |                                  |                                                                    |
| 0x380         | MDR_USB->HSCR                    | Общее управление для контроллера USB интерфейса                    |
| 0x384         | MDR_USB->HSVR                    | Версия аппаратного контроллера USB<br>интерфейса                   |
|               | Контроллер HOST                  |                                                                    |
| 0x00          | MDR_USB->HTXC                    | Регистр управления передачей пакетов со<br>стороны хоста           |
| 0x04          | MDR_USB->HTXT                    | Регистр задания типа передаваемых пакетов со стороны хоста         |
| 0x08          | MDR_USB->HTXLC                   | Регистр управления линиями шины USB                                |
| 0x0C          | MDR_USB->HTXSE                   | Регистр управление автоматической отправки SOF                     |
| 0x10          | MDR_USB->HTXA                    | Регистр задания адреса устройства для<br>отправки пакета           |
| 0x14          | MDR_USB->HTXE                    | Регистр задания номера оконечной точки для<br>отправки пакета      |
| 0x18<br>0x1C  | MDR_USB->HFN_L<br>MDR_USB->HFN_H | Регистр задания номера фрейма для отправки<br>SOF                  |
| 0x20          | MDR_USB->HIS                     | Регистр флагов событий контроллера хост.                           |
| 0x24          | MDR_USB->HIM                     | Регистра флагов разрешения прерываний по событиям контролера хоста |
| 0x28          | MDR_USB->HRXS                    | Регистр состояния очереди приема данных хоста                      |
| 0x2C          | MDR_USB->HRXP                    | Регистр отображения PID принятого пакета                           |
| 0x30          | MDR_USB->HRXA                    | Регистр отображения адреса устройства от которого принят пакет.    |
| 0x34          | MDR_USB->HRXE                    | Регистр отображения номер оконечной точки от которой принят пакет. |
| 0x38          | MDR_USB->HRXCS                   | Регистр отображения состояния подсоединения<br>устройства          |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Базовый адрес | Название              | Описание                                    |
|---------------|-----------------------|---------------------------------------------|
| ,             |                       |                                             |
| 0x3C          | MDR_USB->HSTM         | Регистр расчета времени фрейма              |
|               |                       |                                             |
| 0x80          | MDR_USB->HRXFD        | Данные очереди приема                       |
| 0x88          | MDR_USB->HRXDC_L      | Число принятых данных в очереди             |
| 0x8C          | MDR_USB->HRXDC_H      |                                             |
| 0x90          | MDR_USB->HRXFC        | Управление очередью приема                  |
|               |                       |                                             |
| 0xC0          | MDR_USB->HTXFD        | Данные для передачи                         |
| 0xD0          | MDR_USB->HTXFC        | Управление очередью передачи                |
|               |                       |                                             |
|               |                       |                                             |
|               | Контроллер SLAVE      |                                             |
| 0x100         | MDR_USB->SEP[x].CTRL  | Управление очередью нулевой оконечной точки |
| 0x110         |                       |                                             |
| 0x120         |                       |                                             |
| 0x130         |                       |                                             |
| 0x104         | MDR_USB->SEP[x].STS   | Состояние оконечной точки                   |
| 0x114         |                       |                                             |
| 0x124         |                       |                                             |
| 0x134         |                       |                                             |
| 0x108         | MDR_USB->SEP[x].TS    | Состояние типа передачи оконечной точки     |
| 0x118         |                       |                                             |
| 0x128         |                       |                                             |
| 0x138         |                       |                                             |
| 0x10C         | MDR_USB->SEP[x].NTS   | Состояние передачи NAK оконечной точки      |
| 0x11C         |                       |                                             |
| 0x12C         |                       |                                             |
| 0x13C         |                       |                                             |
| 0.440         | MDD LIOD OO           | \/                                          |
| 0x140         | MDR_USB->SC           | Управление контроллеров SLAVE               |
| 0x144         | MDR_USB->SLS          | Отображение состояния линий USB шины        |
| 0x148         | MDR_USB->SIS          | Флаги событий контроллера SLAVE             |
| 0x14C         | MDR_USB->SIM          | Флаги разрешения прерываний от контроллера  |
| 0.450         | MDD LICE CA           | SLAVE                                       |
| 0x150         | MDR_USB->SA           | Функциональный адрес контроллера            |
| 0x154         | MDR_USB->SFN_L        | Номер фрейма                                |
| 0x158         | MDR_USB->SFN_H        |                                             |
| 0x180         | MDR USB->SEP[x].RXFD  | Принятые данные оконечной точки             |
| 0x200         | WIDN_USB->SEF[X].KAFD | припятые данные оконечной точки             |
| 0x200         |                       |                                             |
| 0x300         |                       |                                             |
| 0x188         | MDR USB-              | Число данных в оконечной точке              |
| 0x18C         | >SEP[x].RXFDC_L       | поло данных в окопечной точке               |
| 0x208         | MDR_USB-              |                                             |
| 0x20C         | >SEP[x].RXFDC_H       |                                             |
| 0x288         | _H                    |                                             |
| 0x28C         | -''                   |                                             |
| 0x308         |                       |                                             |
| 0x30C         |                       |                                             |
| J/1000        |                       |                                             |

| Базовый адрес | Название             | Описание                                   |
|---------------|----------------------|--------------------------------------------|
| 0x190         | MDR_USB->SEP[x].RXFC | Управление очередью приема оконечной точки |
| 0x210         |                      |                                            |
| 0x290         |                      |                                            |
| 0x310         |                      |                                            |
| 0x1C0         | MDR_USB->SEP[x].TXFD | Данные для передачи через оконечную точку  |
| 0x240         |                      |                                            |
| 0x2C0         |                      |                                            |
| 0x340         |                      |                                            |
| 0x1D0         | MDR_USB-             | Управление очередью передачи оконечной     |
| 0x250         | >SEP[x].TXFDC        | точки                                      |
| 0x2D0         |                      |                                            |
| 0x350         |                      |                                            |

# 27.9.1 *MDR\_USB->HSCR*

# Таблица 27-2 - Регистр HSCR

| Номер  | 318 | 7    | 6    | 5    | 4    | 3   | 2   | 1     | 0    |
|--------|-----|------|------|------|------|-----|-----|-------|------|
| Доступ | U   | R/W  | R/W  | R/W  | R/W  | R/W | R/W | R/W   | R/W  |
| Сброс  | 0   | 0    | 0    | 0    | 0    | 0   | 0   | 0     | 0    |
|        | -   | D-   | D-   | D+   | D+   | EN  | EN  | RESET | HOST |
|        |     | PULL | PULL | PULL | PULL | RX  | TX  | CORE  | MODE |
|        |     | DOWN | UP   | DOWN | UP   |     |     |       |      |

# Таблица 27-3 – Описание бит регистра HSCR

| № бита | Функциональное | Расшифровка функционального имени бита, краткое              |
|--------|----------------|--------------------------------------------------------------|
|        | имя бита       | описание назначения и принимаемых значений                   |
| 318    | -              | Зарезервировано                                              |
| 7      | D-             | Управление встроенной подтяжкой линии D-:                    |
|        | PULLDOWN       | 0 – нет подтяжки вниз;                                       |
|        |                | 1 – есть подтяжка вниз                                       |
| 6      | D-             | Управление встроенной подтяжкой линии D-:                    |
|        | PULLUP         | 0 – нет подтяжки вверх;                                      |
|        |                | 1 – есть подтяжка вверх                                      |
| 5      | D+             | Управление встроенной подтяжкой линии D+:                    |
|        | PULLDOWN       | 0 – нет подтяжки вниз;                                       |
|        |                | 1 – есть подтяжка вниз                                       |
| 4      | D+             | Управление встроенной подтяжкой линии D+:                    |
|        | PULLUP         | 0 – нет подтяжки вверх;                                      |
|        |                | 1 – есть подтяжка вверх                                      |
| 3      | EN_RX          | Разрешение работы приемника USB:                             |
|        |                | 0 – запрещен;                                                |
|        |                | 1 – разрешен.                                                |
|        |                | Может использоваться в энергосберегающих целях               |
| 2      | EN_TX          | Разрешение работы передатчика USB:                           |
|        |                | 0 – запрещен;                                                |
|        |                | 1 – разрешен.                                                |
|        |                | Может использоваться в энергосберегающих целях               |
| 1      | RESET_CORE     | Программный сброс контроллера:                               |
|        |                | 1 – сброс контроллера (удерживать минимум 10 циклов USBCLK); |
|        |                | 0 – рабочий режим                                            |
| 0      | HOST_MODE      | Режим работы контроллера:                                    |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| 1 – режим HOST;  |
|------------------|
| 0 – режим Device |

# 27.9.2 *MDR\_USB->HSVR*

# Таблица 27-4 – Регистр HSVR

| Номер  | 318 | 74       | 30      |
|--------|-----|----------|---------|
| Доступ | U   | RO       | RO      |
| Сброс  | 0   | 0        | 0       |
|        | -   | REVISION | VERSION |

# Таблица 27-5 - Описание бит регистра HSVR

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 318       | -                          | Зарезервировано                                                                            |
| 74        | REVISION                   | Номер Ревизии                                                                              |
| 30        | VERSION                    | Номер Версии                                                                               |

Регистры HOST режима

# 27.9.3 MDR\_USB->HTXC

# Таблица 27-6 – Регистр НТХС

| Номер  | 314 | 3     | 2     | 1    | 0    |
|--------|-----|-------|-------|------|------|
| Доступ | U   | R/W   | R/W   | R/W  | R/W  |
| Сброс  | 0   | 0     | 0     | 0    | 0    |
|        | -   | ISOEN | PREEN | SOFS | TREQ |

# Таблица 27-7 – Описание бит регистра НТХС

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений.                                                                                                                                                                                                      |
|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 314              | -                       | Зарезервировано                                                                                                                                                                                                                                                                                  |
| 3                | ISOEN                   | Флаг разрешения изохронного режима:  1 — разрешение изохронного режима, АСК не посылается и не принимается. Необходимо, что бы TRANS_TYPE_REG был установлен в IN_TRANS или OUTDATA0_TRANS. Изохронный режим не применим ни с какими другими типами передачи;  0 — запрещение изохронного режима |
| 2                | PREEN                   | Рекомендуется оставлять 0                                                                                                                                                                                                                                                                        |
| 1                | SOFS                    | Флаг задания синхронизации передачи с SOF:  1 – синхронизировать передачу с окончанием SOF. Передача будет запущена сразу за передачей SOF;  0 – передача не синхронизирована                                                                                                                    |
| 0                | TREQ                    | Флаг запроса передачи данных: 1 – запрос разрешения передачи данных, автоматически сбрасывается после передачи; 0 – запрещена передача                                                                                                                                                           |

#### 27.9.4 *MDR\_USB->HTXT*

#### Таблица 27-8 – Регистр НТХТ

| Номер  | 312 | 1   | 0   |
|--------|-----|-----|-----|
| Доступ | U   | R/W | R/W |
| Сброс  | 0   | 0   | 0   |
|        | •   | TTY | PE  |

# Таблица 27-9 – Описание бит регистра НТХТ

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 312       | -                       | Зарезервировано                                                                            |
| 10        | TTYPE                   | Тип передачи:  00 – setup_trans  01 – in_trans  10 – outdata0_trans  01 – outdata1 trans   |

# 27.9.5 *MDR\_USB->HTXLC*

# Таблица 27-10 – Регистр HTXLC

| Номер  | 315 | 4    | 3    | 2   | 1   | 0      |
|--------|-----|------|------|-----|-----|--------|
| Доступ | U   | R/W  | R/W  | R/W | R/W | R/W    |
| Сброс  | 0   | 0    | 0    | 0   | 0   | 0      |
|        | -   | FSLR | FSLP | DC  | TXL | S[1:0] |

# Таблица 27-11 - Описание бит регистра HTXLC

| №<br>бита | Функционально е имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                         |  |
|-----------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 315       | -                        | Зарезервировано                                                                                                                                                                                                                                    |  |
| 4         | FSLR                     | 1 – 12 Мбит в сек.                                                                                                                                                                                                                                 |  |
|           |                          | 0 – 1.5 Мбит в сек                                                                                                                                                                                                                                 |  |
| 3         | FSPL                     | 1 – FULL SPEED полярность шины USB.                                                                                                                                                                                                                |  |
|           |                          | 0 – LOW SPEED полярность шины USB.                                                                                                                                                                                                                 |  |
|           |                          | Если host работает с full speed устройством, full speed полярность должна быть установлена. Если работа ведется с low speed устройством на прямую, то должна быть установлена low speed полярность. Работа с low speed через hub не поддерживается |  |
| 2         | DC                       | Режим управления линиями шины USB:  1 – разрешение прямого управления состоянием линий USB шины;  0 – нормальный режим работы                                                                                                                      |  |
| 10        | TXLC[1:0]                | Если установлен бит DIRECT_CONTROL_BIT, то отображается состояние шины USB:  TXLC[0] = D-  TXLC[1] = D+                                                                                                                                            |  |

# 27.9.6 *MDR\_USB->HTXSE*

# Таблица 27-12 – Регистр HTXSE

| Номер  | 311 | 0    |
|--------|-----|------|
| Доступ | U   | R/W  |
| Сброс  | 0   | 0    |
|        | -   | SOFE |
|        |     | N    |

# Таблица 27-13 - Описание бит регистра HTXSE

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                    |
|-----------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 311       | •                       | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                                               |
| 0         | SOFEN                   | 1 – Если FSPL установлен, то SOF будет автоматически отсылаться каждые 1 мс. SOF отправляется на full speed независимо от состояния FSPL. Если FSPL не установлен, то автоматически будет отправляться ЕОР каждые 1 мс. Это необходимо при работе с low speed устройством напрямую (не через хаб).  0 – запрет автоматической отправки SOF/EOP и позволяет подсоединенным устройствам перейти в suspend режим |

#### 27.9.7 *MDR\_USB->HTXA*

# Таблица 27-14 – Регистр НТХА

| Номер  | 317 | 60           |
|--------|-----|--------------|
| Доступ | U   | R/W          |
| Сброс  | 0   | 0            |
|        | -   | DEVADDR[6:0] |

# Таблица 27-15 – Описание бит регистра НТХА

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|--|
| 317       | -                          | Зарезервировано                                                                            |  |
| 60        | DEVADDR[6:0]               | USB Device address. Адрес устройства для обращения                                         |  |

#### 27.9.8 *MDR\_USB->HTXE*

# Таблица 27-16 – Регистр НТХЕ

| Номер  | 314 | 30          |
|--------|-----|-------------|
| Доступ | U   | R/W         |
| Сброс  | 0   | 0           |
|        | -   | EPADDR[3:0] |

# Таблица 27-17 – Описание бит регистра НТХЕ

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|--|
| 314       | -                       | Зарезервировано                                                                            |  |
| 30        | EPADDR[3:0]             | Endpoint address. Номер оконечной точки устройства для обращения                           |  |

#### 27.9.9 *MDR\_USB->HFN*

# Таблица 27-18 – Регистр HFN

| Номер  | 3111 | 100        |
|--------|------|------------|
| Доступ | U    | R/W        |
| Сброс  | 0    | 0          |
|        | -    | FNUM[10:0] |

# Таблица 27-19 - Описание бит регистра HFN

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3111      | -                       | Зарезервировано                                                                            |
| 100       | FNUM[10:0]              | Номер фрейма                                                                               |

# 27.9.10 *MDR\_USB->HIS*

# Таблица 27-20 - Регистр HIS

| Номер  | 314 | 3    | 2     | 1      | 0     |
|--------|-----|------|-------|--------|-------|
| Доступ | U   | R/W  | R/W   | R/W    | R/W   |
| Сброс  | 0   | 0    | 0     | 0      | 0     |
|        | -   | SOFS | CONEV | RESUME | TDONE |

# Таблица 27-21 - Описание бит регистра HIS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                              |
|-----------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 314       | -                       | Зарезервировано                                                                                                                         |
| 3         | SOFS                    | <ul><li>1 – автоматически устанавливается, когда SOF был<br/>отправлен. Должен быть очищен записью 1.</li><li>0 – не было SOF</li></ul> |
| 2         | CONEV                   | 1 – автоматически устанавливается, когда подсоединение или отсоединение происходит. Должно быть очищено записью 1. 0 – события не было  |
| 1         | RESUME                  | 1 – автоматически устанавливается, когда возникает состояние повтора. Должен быть очищен записью 1. 0 – не было повтора.                |
|           | TDONE                   | 1 – автоматически устанавливается, когда передача закончена. Должен быть очищен записью 1. 0 – передача не закончена или ее нет         |

# 27.9.11 *MDR\_USB->HIM*

# Таблица 27-22 – Регистр НІМ

| Номер  | 314 | 3      | 2       | 1        | 0       |
|--------|-----|--------|---------|----------|---------|
| Доступ | U   | R/W    | R/W     | R/W      | R/W     |
| Сброс  | 0   | 0      | 0       | 0        | 0       |
|        | -   | SOFSIE | CONEVIE | RESUMEIE | TDONEIE |

# Таблица 27-23 – Описание бит регистра НІМ

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 314       | -                       | Зарезервировано                                                                            |
| 3         | SOFIE                   | 1 – разрешение выработки прерывания при передаче SOF.                                      |
|           |                         | 0 – запрещение выработки прерывания                                                        |
| 2         | CONEVIE                 | 1 – разрешение выработки прерывания при подсоединении                                      |
|           |                         | или отсоединении.                                                                          |
|           |                         | 0 – запрещение выработки прерывания                                                        |
| 1         | RESUMEIE                | 1 – разрешение выработки прерывания при повторе передачи.                                  |
|           |                         | 0 – запрещение выработки прерывания                                                        |
| 0         | TDONEIE                 | 1 – разрешение выработки прерывания при окончании                                          |
|           |                         | передачи.                                                                                  |
|           |                         | 0 – запрещение выработки прерывания                                                        |

# 27.9.12 *MDR\_USB->HRXS*

# Таблица 27-24 – Регистр HRXS

| Номер  | 318 | 7              | 6           | 5     | 4    | 3   | 2    | 1            | 0     |
|--------|-----|----------------|-------------|-------|------|-----|------|--------------|-------|
| Доступ | J   | R/W            | R/W         | R/W   | R/W  | R/W | R/W  | R/W          | R/W   |
| Сброс  | 0   | 0              | 0           | 0     | 0    | 0   | 0    | 0            | 0     |
|        | -   | <b>DATASEQ</b> | ACK         | STALL | NAK  | RX  | RXOF | <b>BSERR</b> | CRCER |
|        |     |                | <b>RXED</b> | RXED  | RXED | TO  |      |              |       |

# Таблица 27-25 - Описание бит регистра HRXS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 318       | ı                       | Зарезервировано                                                                            |
| 7         | DATASEQ                 | Если последняя транзакция была типа IN_TRANS, этот бит                                     |
|           |                         | указывает номер последнего принятого пакета. DATA0 = 0,<br>DATA1 = 1                       |
| 6         | ACK                     | 1 – получен АСК.                                                                           |
|           | RXED                    | 0 – не получен АСК                                                                         |
| 5         | STALL                   | 1 – получен STALL.                                                                         |
|           | RXED                    | 0 – не получен STALL                                                                       |
| 4         | NAK                     | 1 – получен NAK от устройства.                                                             |
|           | RXED                    | 0 – не получен NAK                                                                         |
| 3         | RXTO                    | 1 – переполнения времени ожидания ответа от устройства.                                    |
|           |                         | 0 – нет переполнения времени                                                               |
| 2         | RXOF                    | 1 – обнаружена ошибка переполнения FIFO при приеме                                         |
|           |                         | пакета.                                                                                    |
|           |                         | 0 – не было переполнения                                                                   |
| 1         | BSERR                   | 1 – обнаружена ошибка stuff при последней передаче.                                        |
|           |                         | 0 – ошибки stuff не было                                                                   |
| 0         | CRCERR                  | 1 – обнаружена ошибка CRC при последней передаче.                                          |
|           |                         | 0 – ошибки CRC не было                                                                     |

#### 27.9.13 *MDR\_USB->HRXP*

# Таблица 27-26 - Регистр HRXP

| Номер  | 314 | 30        |
|--------|-----|-----------|
| Доступ | U   | R/W       |
| Сброс  | 0   | 0         |
|        | •   | RPID[3:0] |

# Таблица 27-27 - Описание бит регистра HRXP

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 314       | -                          | Зарезервировано                                                                            |
| 30        | RPID[3:0]                  | Packet identifier от последнего принятого пакета                                           |

# 27.9.14 MDR\_USB->HRXA

# Таблица 27-28 – Регистр HRXA

| Номер  | 317 | 60         |
|--------|-----|------------|
| Доступ | U   | R/W        |
| Сброс  | 0   | 0          |
|        | •   | RADDR[6:0] |

# Таблица 27-29 - Описание бит регистра HRXA

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------------------|-------------------------|--------------------------------------------------------------------------------------------|
| 317              | -                       | Зарезервировано                                                                            |
| 60               | RADDR[6:0]              | Адрес последнего принятого пакета, который был послан                                      |

#### 27.9.15 *MDR\_USB->HRXE*

# Таблица 27-30 - Регистр HRXE

| Номер  | 314 | 30          |
|--------|-----|-------------|
| Доступ | U   | R/W         |
| Сброс  | 0   | 0           |
|        | •   | RXENDP[3:0] |

# Таблица 27-31 - Описание бит регистра HRXE

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений. |
|------------------|-------------------------|---------------------------------------------------------------------------------------------|
| 314              | -                       | Зарезервировано                                                                             |
| 30               | RXENDP[3:0]             | Номер оконечной точки в последнем принятом пакете, который был послан                       |

#### 27.9.16 *MDR\_USB->HRXCS*

# Таблица 27-32 – Регистр HRXCS

| Номер  | 312 | 1        | 0   |
|--------|-----|----------|-----|
| Доступ | U   | R/W      | R/W |
| Сброс  | 0   | 0        | 0   |
|        | •   | RXLS[1:0 | ]   |

# Таблица 27-33 - Описание бит регистра HRXCS

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 312  | -              | Зарезервировано                                 |
| 10   | RXLS[1:0]      | Состояние линий шины USB:                       |
|      |                | DISCONNECT = 0                                  |
|      |                | LOW_SPEED_CONNECT = 1                           |
|      |                | FULL_SPEED_CONNECT = 2                          |

#### 27.9.17 *MDR\_USB->HSTM*

# Таблица 27-34 – Регистр HSTM

| Номер  | 318 | 70        |
|--------|-----|-----------|
| Доступ | U   | R/W       |
| Сброс  | 0   | 0         |
|        | •   | HSTM[7:0] |

# Таблица 27-35 – Описание бит регистра HSTM

| N  | <b>√</b> 0 | Функциональное | Расшифровка функционального имени бита, краткое |
|----|------------|----------------|-------------------------------------------------|
| бν | ита        | имя бита       | описание назначения и принимаемых значений      |
| 31 | 8          | -              | Зарезервировано                                 |

| 70 | HSTM[7:0] | Старший байт SOF таймера, используемого для передачи |
|----|-----------|------------------------------------------------------|
|    |           | SOF. Таймер увеличивается на частоте 48 МГц, и имеет |
|    |           | 48000 тактов в 1 мс фрейме. Этот регистр может быть  |
|    |           | использован для вычисления оставшегося во фрейме     |
|    |           | времени                                              |

#### 27.9.18 *MDR\_USB->HRXFD*

# Таблица 27-36 – Регистр HRXFD

| Номер  | 318 | 70        |
|--------|-----|-----------|
| Доступ | U   | R/W       |
| Сброс  | 0   | 0         |
|        | -   | RX        |
|        |     | FIFO      |
|        |     | DATA[7:0] |

# Таблица 27-37 - Описание бит регистра HRXFD

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 318       | -                          | Зарезервировано                                                                            |
| 70        | RX                         | Если последняя транзакция была IN_TRANS, то порт                                           |
|           | FIFO                       | содержит принятые данные, и они могут быть считаны                                         |
|           | DATA[7:0]                  |                                                                                            |

# 27.9.19 MDR\_USB->HRXDC

# Таблица 27-38 - Регистр HRXDC

| Номер  | 3116 | 150         |
|--------|------|-------------|
| Доступ | U    | R/W         |
| Сброс  | 0    | 0           |
|        | -    | FIFO        |
|        |      | DATA        |
|        |      | COUNT[15:0] |

# Таблица 27-39 - Описание бит регистра HRXDC

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |
| 3116 | •              | Зарезервировано                                 |
| 150  | FIFO           | Счетчик принятых байт в очереди                 |
|      | DATA           | ·                                               |
|      | COUNT[15:0]    |                                                 |

#### 27.9.20 MDR USB->HRXFC

# Таблица 27-40 - Регистр HRXFC

| Номер  | 311 | 0                |
|--------|-----|------------------|
| Доступ | U   | R/W              |
| Сброс  | 0   | 0                |
|        | •   | FIFO FORCE EMPTY |

# Таблица 27-41 – Описание бит регистра HRXFC

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |

| 311 | -                | Зарезервировано                           |
|-----|------------------|-------------------------------------------|
| 0   | FIFO FORCE EMPTY | Запись 1 принудительно сбрасывает очередь |

#### 27.9.21 *MDR\_USB->HTXFD*

# Таблица 27-42 – Регистр HTXFD

| Номер  | 318 | 70        |
|--------|-----|-----------|
| Доступ | U   | R/W       |
| Сброс  | 0   | 0         |
|        | •   | TX        |
|        |     | FIFO      |
|        |     | DATA[7:0] |

# Таблица 27-43 – Описание бит регистра HTXFD

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 318       | -                       | Зарезервировано                                                                            |
| 70        | TX                      | При запросах передачи OUTDATA0_TRANS или                                                   |
|           | FIFO                    | OUTDATA1_TRANS, через данный порт должны быть                                              |
|           | DATA[7:0]               | загружены данные для отправки                                                              |

# 27.9.22 *MDR\_USB->HTXFC*

# Таблица 27-44 - Регистр НТХГС

| Номер  | 311 | 0                |
|--------|-----|------------------|
| Доступ | U   | R/W              |
| Сброс  | 0   | 0                |
|        | •   | FIFO FORCE EMPTY |

# Таблица 27-45 – Описание бит регистра HTXFC

| №<br>бита | Функциональное имя<br>бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 311       | -                          | Зарезервировано                                                                            |
| 0         | FIFO FORCE EMPTY           | Запись 1 принудительно сбрасывает очередь                                                  |

# **USB Slave (Device)**

# 27.9.23 MDR\_USB->SEP[x].CTRL

# Таблица 27-46 - Регистр SEP[x].CTRL

| Номер  | 315 | 4              | 3               | 2                | 1     | 0    |
|--------|-----|----------------|-----------------|------------------|-------|------|
| Доступ | U   | R/W            | R/W             | R/W              | R/W   | R/W  |
| Сброс  | 0   | 0              | 0               | 0                | 0     | 0    |
|        | -   | <b>EPISOEN</b> | <b>EPSSTALL</b> | <b>EPDATASEQ</b> | EPRDY | EPEN |

# Таблица 27-47 - Описание бит регистра USB\_SEPx.CTRL

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |
|------|----------------|-------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений      |

| 315 | -         | Зарезервировано                                             |  |  |  |
|-----|-----------|-------------------------------------------------------------|--|--|--|
| 4   | EPISOEN   | 0 – не изохронный режим передачи;                           |  |  |  |
|     |           | 1 – разрешить изохронные передачи.                          |  |  |  |
|     |           | В изохронном режиме не отсылаются какие-либо                |  |  |  |
|     |           | подтверждения передачи                                      |  |  |  |
| 3   | EPSSTALL  | 0 – не отвечать STALL на запрос;                            |  |  |  |
|     |           | 1 – если точка разрешена, готова, и не в изохронном режиме, |  |  |  |
|     |           | то на запрос хоста будет отвечать STALL                     |  |  |  |
| 2   | EPDATASEQ | 0 – отвечать на IN запрос от хоста с DATA0;                 |  |  |  |
|     |           | 1 – отвечать на IN запрос от хоста с DATA1.                 |  |  |  |
| 1   | EPRDY     | 0 – оконечная точка не готова или закончила передачу;       |  |  |  |
|     |           | 1 – оконечная точка готова.                                 |  |  |  |
|     |           | Если точка разрешена и готова, то она может ответить на     |  |  |  |
|     |           | инициализированную хостом передачу. Автоматически           |  |  |  |
|     |           | сбрасывается в 0 после успешного окончания передачи         |  |  |  |
| 0   | EPEN      | 0 – оконечная точка запрещена;                              |  |  |  |
|     |           | 1 – оконечная точка разрешена.                              |  |  |  |
|     |           | Если точка запрещена она не отвечает на транзакции, если    |  |  |  |
|     |           | точка разрешена, но не готова и не находится в изохронном   |  |  |  |
|     |           | режиме, то отвечает NAK                                     |  |  |  |

# 27.9.24 *MDR\_USB->SEP[x].STS*

# Таблица 27-48 - Регистр SEP[x].STS

| Номер  | 318 | 7    | 6    | 5     | 4    | 3    | 2    | 1   | 0   |
|--------|-----|------|------|-------|------|------|------|-----|-----|
| Доступ | U   | R/W  | R/W  | R/W   | R/W  | R/W  | R/W  | R/W | R/W |
| Сброс  | 0   | 0    | 0    | 0     | 0    | 0    | 0    | 0   | 0   |
|        | •   | SC   | SC   | SC    | NAK  | SC   | SC   | SC  | SC  |
|        |     | DATA | ACK  | STALL | SENT | RXTO | RXOF | BS  | CRC |
|        |     | SEQ  | RXED | SENT  |      |      |      | ERR | ERR |

# Таблица 27-49 - Описание бит регистра USB\_SEPx.STS

| Nº   | Функциональное      | Расшифровка функционального имени бита, краткое                                                             |
|------|---------------------|-------------------------------------------------------------------------------------------------------------|
| бита | имя бита            | описание назначения и принимаемых значений                                                                  |
| 318  | -                   | Зарезервировано                                                                                             |
| 7    | SC<br>DATA<br>SEQ   | Если предыдущий тип передачи был OUT_TRANS, то этот бит определяет тип принятого пакета DATA0 = 0, DATA1= 1 |
| 6    | SC<br>ACK<br>RXED   | 0 – нет подтверждения;<br>1 – получено подтверждение АСК от хоста на переданные<br>данные.                  |
| 5    | SC<br>STALL<br>SENT | 0 – не было STALL;<br>1 – признак отправки STALL                                                            |
| 4    | NAK<br>SENT         | 1 – признак отправки NAK ответа.<br>0 – не было NAK                                                         |
| 3    | SC<br>RXTO          | <ul><li>1 – признак возникновения ошибки времени ожидания ответа от хоста.</li><li>0 – нет ошибки</li></ul> |
| 2    | SC<br>RXOF          | 0 – нет переполнения;<br>1 – признак возникновения переполнения очереди при<br>последней передаче           |
| 1    | SC<br>BS<br>ERR     | 0 – нет ошибки;<br>1 – признак возникновения STUFF ошибки в последней<br>передаче                           |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|--|

# 27.9.25 *MDR\_USB->SEP[x].TS*

# Таблица 27-50 - Регистр SEP[x].TS

| Номер  | 312 | 1      | 0      |
|--------|-----|--------|--------|
| Доступ | U   | R/W    | R/W    |
| Сброс  | 0   | 0      | 0      |
|        | -   | SCTTYP | E[1:0] |

# Таблица 27-51 – Описание бит регистра SEP[x].TS

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                  |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                       |
| 312  | -              | Зарезервировано                                                                                                                                  |
| 10   | SCTTYPE[1:0]   | Отображает тип последней передачи перед тем как ENDPOINT_READY_BIT был изменен с 1 на 0. SC_SETUP_TRANS = 0 SC_IN_TRANS = 1 SC_OUTDATA_TRANS = 2 |

# 27.9.26 *MDR\_USB->SEP[x].NTS*

# Таблица 27-52 - Регистр SEP[x].NTS

| Номер  | 312 | 1      | 0      |
|--------|-----|--------|--------|
| Доступ | U   | R/W    | R/W    |
| Сброс  | 0   | 0      | 0      |
|        | •   | NTTYPI | E[1:0] |

#### Таблица 27-53 – Описание бит регистра USB\_SEPx.NTS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                   |
|-----------|-------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 312       | -                       | Зарезервировано                                                                                                              |
| 10        | NTTYPE[1:0]             | Тип последней передачи, в результате которой на хост был послан NAK. SC_SETUP_TRANS = 0 SC_IN_TRANS = 1 SC_OUTDATA_TRANS = 2 |

#### 27.9.27 MDR\_USB->SC

#### Таблица 27-54 - Регистр SC

| Номер  | 316 | 5     | 4     | 3    | 2     | 1       | 0     |
|--------|-----|-------|-------|------|-------|---------|-------|
| Доступ | U   | R/W   | R/W   | R/W  | R/W   | R/W     | R/W   |
| Сброс  | 0   | 0     | 0     | 0    | 0     | 0       | 0     |
|        | -   | SCFSR | SCFSP | SCDC | SCTXL | .S[1:0] | SCGEN |

# Таблица 27-55 – Описание бит регистра USB\_SC

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|--|
| 316       | -                       | Зарезервировано                                                                            |  |
| 5         | SCFSR                   | Флаг управления скоростью работы:                                                          |  |

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                           |
|-----------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |                         | 1 – 12 Мбит/с;<br>0 – 1.5 Мбит/с                                                                                                                                                     |
| 4         | SCFSP                   | Флаг выбора полярности линий USB шины:<br>1 – FULL SPEED;<br>0 –LOW SPEED                                                                                                            |
| 3         | SCDC                    | Флаг прямого управления линиями USB шины: 1 – разрешено прямое управление 0 – запрещено прямое управление                                                                            |
| 21        | SCTXL[1:0]              | Если установлен бит SC_DIRECT_CONTROL_BIT, то через SC_TX_LINE_STATE осуществляется прямое управление состоянием линий USB шины: SC_TX_LINE_STATE [2] = D+ SC_TX_LINE_STATE [1] = D- |
| 0         | SCGEN                   | 1 – разрешение для работы с разрешенных оконечных точек<br>0 – все оконечные точки запрещены                                                                                         |

# 27.9.28 MDR\_USB->SLS

# Таблица 27-56 - Регистр SLS

| Номер  | 312 | 1     | 0      |
|--------|-----|-------|--------|
| Доступ | U   | R/W   | R/W    |
| Сброс  | 0   | 0     | 0      |
|        | •   | SCRXL | S[1:0] |

# Таблица 27-57 – Описание бит регистра SLS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                |
|-----------|-------------------------|-----------------------------------------------------------------------------------------------------------|
| 312       | -                       | Зарезервировано                                                                                           |
| 10        | SCRXLS[1:0]             | Отображает состояние подсоединения на шине USB:  RESET = 0  LOW_SPEED_CONNECT = 1  FULL_SPEED_CONNECT = 2 |

# 27.9.29 *MDR\_USB->SIS*

# Таблица 27-58 - Регистр SIS

| Номер  | 316 | 5 | 4    | 3   | 2     | 1      | 0     |
|--------|-----|---|------|-----|-------|--------|-------|
| Доступ | U   | U | R/W  | R/W | R/W   | R/W    | R/W   |
| Сброс  | 0   | 1 | 0    | 0   | 0     | 0      | 0     |
|        | -   | - | SC   | SC  | SC    | SC     | SC    |
|        |     |   | NAK  | SOF | RESET | RESUME | TDONE |
|        |     |   | SENT | REC | EV    |        |       |

# Таблица 27-59 – Описание бит регистра USB\_SIS

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |  |
|------|----------------|-------------------------------------------------|--|
| бита | имя бита       | описание назначения и принимаемых значений      |  |
| 315  | -              | Зарезервировано                                 |  |
| 4    | SC             | При ответе NAK на запрос от хоста автоматически |  |
|      | NAK            | устанавливается в 1.                            |  |
|      | SENT           | Очищается записью 1                             |  |
| 3    | SC             | При принятии пакета SOF от хоста автоматически  |  |
|      | SOF            | устанавливается в 1.                            |  |

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
|           | REC                        | Очищается записью 1                                                                        |
| 2         | SC                         | Автоматически устанавливается в 1 при наличии состояния                                    |
|           | RESET                      | сброса на шине USB.                                                                        |
|           | EV                         | Очищается записью 1                                                                        |
| 1         | SC                         | Автоматически устанавливается в 1 при обнаружении                                          |
|           | RESUME                     | состояние повтора.                                                                         |
|           |                            | Очищается записью 1                                                                        |
| 0         | SC                         | Автоматически устанавливается в 1 после успешного                                          |
|           | TDONE                      | выполнения передачи.                                                                       |
|           |                            | Очищается записью 1                                                                        |

# 27.9.30 MDR\_USB->SIM

# Таблица 27-60 - Регистр SIM

| Номер  | 315 | 4                       | 3                  | 2                   | 1                  | 0                 |
|--------|-----|-------------------------|--------------------|---------------------|--------------------|-------------------|
| Доступ | U   | R/W                     | R/W                | R/W                 | R/W                | R/W               |
| Сброс  | 0   | 0                       | 0                  | 0                   | 0                  | 0                 |
|        | 1   | SC<br>NAK<br>SENT<br>IE | SC<br>SOF<br>RECIE | SC<br>RESET<br>EVIE | SC<br>RESUME<br>IE | SC<br>TDONE<br>IE |

# Таблица 27-61 – Описание бит регистра B\_SIM

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое          |
|------|----------------|----------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений               |
| 316  | -              | Зарезервировано                                          |
| 4    | SC             | Флаг управления разрешением прерывания при отправке NAK: |
|      | NAK            | 1 – разрешено прерывание;                                |
|      | SENT           | 0 – запрещено прерывание                                 |
|      | ΙE             |                                                          |
| 3    | SC             | Флаг управления разрешением прерывания при приеме SOF:   |
|      | SOF            | 1 – разрешено прерывание;                                |
|      | RECIE          | 0 – запрещено прерывание                                 |
| 2    | SC             | Флаг управления разрешением прерывания при состоянии     |
|      | RESET          | сброса на шине:                                          |
|      | EVIE           | 1 – разрешено прерывание;                                |
|      |                | 0 – запрещено прерывание                                 |
| 1    | SC             | Флаг управления разрешением прерывания при состоянии     |
|      | RESUME         | повтора:                                                 |
|      | ΙE             | 1 – разрешено прерывание;                                |
|      |                | 0 – запрещено прерывание                                 |
| 0    | SC             | Флаг управления разрешением прерывания при окончании     |
|      | TDONE          | передачи:                                                |
|      | ΙE             | 1 – разрешено прерывание;                                |
|      |                | 0 – запрещено прерывание                                 |

# 27.9.31 *MDR\_USB->SA*

# Таблица 27-62 – Регистр SA

| Номер  | 317 | 60  |
|--------|-----|-----|
| Доступ | U   | R/W |
| Сброс  | 0   | 0   |

| - | SDEVADDR[6:0] |
|---|---------------|

# Таблица 27-63 - Описание бит регистра SA

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 317       | -                          | Зарезервировано                                                                            |
| 60        | SDEVADDR[6:0]              | Функциональный адрес устройства USB                                                        |

# 27.9.32 *MDR\_USB->SFN*

# Таблица 27-64 - Регистр SFN

| Номер  | 3111 | 100        |
|--------|------|------------|
| Доступ | U    | R/W        |
| Сброс  | 0    | 0          |
|        | -    | FRAME      |
|        |      | NUM [10:0] |

# Таблица 27-65 - Описание бит регистра SFN

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое |  |
|------|----------------|-------------------------------------------------|--|
| бита | имя бита       | описание назначения и принимаемых значений      |  |
| 3111 | -              | Зарезервировано                                 |  |
| 100  | FRAME          | Номер фрейма, принятый в последнем SOF          |  |
|      | NUM [10:0]     |                                                 |  |

# 27.9.33 *MDR\_USB->SEP[x].RXFD*

#### Таблица 27-66 - Регистр SEP[x].RXFD

| Номер  | 318 | 70        |
|--------|-----|-----------|
| Доступ | U   | R/W       |
| Сброс  | 0   | 0         |
|        | -   | RX FIFO   |
|        |     | DATA[7:0] |

# Таблица 27-67 – Описание бит регистра SEP[x].RXFD

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|--|
| 318       | -                          | Зарезервировано                                                                            |  |
| 70        | RX FIFO                    | После приема OUTDATA_TRANS или SETUP_TRANS пакета,                                         |  |
|           | DATA[7:0]                  | принятые данные читаются из регистра RX_FIFO_DATA                                          |  |

# 27.9.34 MDR\_USB->SEP[x].RXFDC

# Таблица 27-68 - Регистр SEP[x].RXFDC

| Номер  | 3116 | 150          |
|--------|------|--------------|
| Доступ | U    | R/W          |
| Сброс  | 0    | 0            |
|        | -    | FIFO DATA    |
|        |      | COUNT [15:0] |

# Таблица 27-69 - Описание бит регистра SEP[x].RXFDC

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 3116      | -                          | Зарезервировано                                                                            |
| 150       | FIFO DATA<br>COUNT [15:0]  | Отображает число принятых байт в очереди                                                   |

### 27.9.35 MDR\_USB->SEP[x].RXFC

# Таблица 27-70 - Регистр SEP[x].RXFC

| Номер  | 311 | 0                   |
|--------|-----|---------------------|
| Доступ | U   | R/W                 |
| Сброс  | 0   | 0                   |
|        | -   | FIFO FORCE<br>EMPTY |

# Таблица 27-71 - Описание бит регистра USB\_SEPx.RXFC

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|------|----------------|--------------------------------------------------------------------------------------------|--|
| бита | имя бита       |                                                                                            |  |
| 311  | -              | Зарезервировано                                                                            |  |
| 0    | FIFO FORCE     | Запись 1 очищает всю очередь                                                               |  |
|      | EMPTY          | ·                                                                                          |  |

# 27.9.36 *MDR\_USB->SEP[x].TXFD*

# Таблица 27-72 - Регистр SEP[x].TXFD

| Номер  | 318 | 70        |
|--------|-----|-----------|
| Доступ | U   | R/W       |
| Сброс  | 0   | 0         |
|        | -   | TX FIFO   |
|        |     | DATA[7:0] |

#### Таблица 27-73 - Описание бит регистра SEP[x].TXFD

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 318       | -                       | Зарезервировано                                                                            |
| 70        | TX FIFO<br>DATA [7:0]   | Перед приемом IN_TRANS в очередь записываются данные для<br>отправки                       |

# 27.9.37 MDR\_USB->SEP[x].TXFDC

# Таблица 27-74 - Регистр SEP[x].TXFDC

| Номер  | 311 | 0          |
|--------|-----|------------|
| Доступ | U   | R/W        |
| Сброс  | 0   | 0          |
|        | -   | FIFO FORCE |
|        |     | EMPTY      |

# Таблица 27-75 - Описание бит регистра SEP[x].TXFDC

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 311       | -                       | Зарезервировано                                                                            |
| 0         | FIFO FORCE              | Запись 1 очищает всю очередь                                                               |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| EMPTY |       |  |
|-------|-------|--|
|       | FMPTY |  |

# 28 Таймеры общего назначения MDR\_TIMERx

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

Каждый из трех таймеров микроконтроллера содержит 16-битный счетчик, 16-битный предделитель частоты и 4-канальный блок захвата/сравнения. Их можно синхронизировать системной синхронизацией, внешними сигналами или другими таймерами.

Помимо составляющего основу таймера счетчика, в каждый блок таймера также входит четырехканальный блок захвата/сравнения. Данный блок выполняет как стандартные функции захвата и сравнения, так и ряд специальных функций. Таймеры с 4 каналами схем захвата и ШИМ с функциями формирования «мертвой зоны» и аппаратной блокировки. Каждый из таймеров может генерировать прерывания и запросы DMA.

#### Особенности:

- 16-битный счетчик; счёт прямой, обратный или двунаправленный.
- 16-разрядный программируемый предварительный делитель частоты.
- до четырех независимых 16-битных каналов захвата на один таймер.
   Каждый из каналов захвата может захватить (скопировать) текущее значение таймера при изменении некоторого входного сигнала. В случае захвата имеется дополнительная возможность генерировать прерывание и/или запрос DMA.
- четыре 16-битных регистра сравнения (совпадения), которые позволяют осуществлять непрерывное сравнение, с дополнительной возможностью генерировать прерывание и/или запрос DMA при совпадении;
- имеется до четыре внешних выводов, соответствующих регистрам совпадения со следующими возможностями:
  - сброс в НИЗКИЙ уровень при совпадении;
  - установка в ВЫСОКИЙ уровень при совпадении;
  - переключение (инвертирование) при совпадении;
  - при совпадении состояние выхода не изменяется;
  - переключение при некотором условии.

#### 28.1 Функционирование

Таймер предназначен для того, чтобы подсчитывать циклы периферийной тактовой частоты Fdts или какие-либо внешние события и произвольно генерировать прерывания, запросы DMA или выполнять другие действия. Значения таймера, при достижении которых будут выполнены те или иные действия, задаются восемью регистрами совпадения. Кроме того, в микроконтроллере имеются четыре входа захвата, чтобы захватить значение таймера при изменении некоторого входного сигнала, с возможностью генерировать прерывание или запрос DMA.

#### 28.1.1 Структурная схема

Рисунок 28–1 демонстрирует структурную схему блока Таймер.

Таймер содержит основной 16-ти битный счетчик CNT, блок регистров управления и четыре канала схем захвата/ШИМ.



Рисунок 28-1 - Структурная схема таймера

Таймер позволяет работать в режимах:

- таймер;
- расширенный таймер, с объединением нескольких таймеров;
- режим захвата;
- ШИМ.

#### 28.1.2 Инициализация таймера

Перед началом работы с таймерами в первую очередь должны быть включены тактовые сигналы.

Для задания тактовой частоты блока необходимо установить бит разрешения тактирования блока (бит 13 для таймера 1, бит 14 для таймера 2, бит 15 для таймера 3 регистра PER\_CLOCK). В регистре TIM\_CLOCK установить бит TIMxCLKEN, чтобы разрешить тактовую частоту для определенного таймера, задать коэффициент деления тактовой частоты HCLK для каждого таймера.

После подачи тактового сигнала на блок таймера можно приступать к работе с ним.

#### 28.1.3 Режим таймера

Таймеры построены на базе 16-битного счетчика, объединенного с 16-битным предварительным делителем. Скорость счета таймера зависит от значения, находящегося в регистре делителя.

Счетчик может считать вверх, вниз или вверх и вниз (счёт прямой, обратный, двунаправленный).

Базовый блок таймера включает в себя:

- основной счетчик таймера (TIMx CNT);
- делитель частоты при счете основного счетчика (TIMx PSC);
- основание счета основного счетчика (TIMx ARR).

Сигналом для изменения CNT может служить как внутренняя частота TIM\_CLK, так и события в других счетчиках, либо события на линиях TxCHi данного счетчика.

Чтобы запустить работу основного счетчика, необходимо задать:

- Начальное значение основного счетчика таймера TIMx\_CNT;
- Значение предварительного делителя счетчика TIMx\_PSG, при этом основной счетчик будет считать на частоте CLK = TIMx\_CLK/(PSG + 1);
- Значение основания счета для основного счетчика TIMx\_ARR;
- Режим работы счетчика TIMx CNTRL:
  - выбрать источник события переключения счетчика EVENT SEL;
  - режим счета основного счетчика CNT\_MODE (значения 00 и 01 при тактировании внутренней частотой, значения 10 и 11 при тактировании внешними сигналами);
  - направление счета основного счетчика DIR;
- разрешить работу счетчика CNT EN.

По событиям совпадения значения основного счетчика с значением нуля или значением основания счета генерируется прерывание и запрос DMA, которые могут быть замаскированы.

#### 28.2 Режимы счета

Счет вверх:  $CNT_MODE = 00$ , DIR = 0 (пример: счет вверх от 0 до 0х13, стартовое значение 0х04)

```
MDR_TIMERx->CNTRL = 0x000000000; //Режим инициализации таймера //Hacmpauваем работу основного счетчика
MDR_TIMERx->CNT = 0x00000004; //Haчальное значение счетчика
MDR_TIMERx->PSG = 0x000000000; //Предделитель частоты
MDR_TIMERx->ARR = 0x00000013; //Основание счета
//Paspewenue работы таймера.
MDR_TIMERx->CNTRL = 0x00000001; //Счет вверх по TIM_CLK.
```



# Рисунок 28-2 - Диаграммы работы таймера, счет вверх

Счет вниз: CNT\_MODE = 00, DIR = 1 (пример: счет вниз от 0x13 до 0, стартовое значение 0x04)

```
MDR_TIMERx->CNTRL = 0x000000000; //Режим инициализации таймера //Hacmpauваем работу основного счетчика
MDR_TIMERx->CNT = 0x00000004; //Haчальное значение счетчика
MDR_TIMERx->PSG = 0x00000000; //Предделитель частоты
MDR_TIMERx->ARR = 0x00000013; //Oснование счета
```

//Разрешение работы таймера.

MDR TIMERx->CNTRL =  $0x\dot{0}0000009$ ; //Cyem вниз по TIM CLK.



#### Рисунок 28-3 - Диаграммы работы таймера, счет вниз

Счет вверх/вниз: CNT MODE = 01, DIR = 0

```
MDR_TIMERx ->CNTRL = 0x000000000; //Режим инициализации таймера //Hacmpauваем работу основного счетчика
MDR_TIMERx ->CNT = 0x00000004; //Начальное значение счетчика
MDR_TIMERx ->PSG = 0x000000000; //Предделитель частоты
MDR_TIMERx ->ARR = 0x00000013; //Ocнование счета
//Paspewenue работы таймера.
MDR_TIMERx ->CNTRL = 0x00000041; //Счет вверх/вниз по ТІМ_СLК.
```



Рисунок 28-4 - Диаграммы работы таймера, счет вверх/вниз, сначала вверх

Счет вверх/вниз: CNT MODE = 01, DIR = 1

MDR\_TIMERx->CNTRL = 0x000000000; //Режим инициализации таймера //Hacmpausaeм работу основного счетчика
MDR\_TIMERx->CNT = 0x00000004; //Начальное значение счетчика
MDR\_TIMERx->PSG = 0x000000000; //Предделитель частоты

MDR\_TIMERx->ARR = 0x00000013; //Ochobahue cyema

//Разрешение работы таймера.

MDR TIMERx->CNTRL = 0x000000049; //Счет вверх/вниз по ТІМ СLК.



Рисунок 28-5 - Диаграммы работы таймера, счет вверх/вниз, сначала вниз

#### 28.3 Источник событий для счета

Источники событий для счета:

- внутренний тактовый сигнал (ТІМ\_СLК);
- события в других счетчиках (CNT==ARR в таймере X);
- внешний тактовый сигнал режим 1: События на линиях ТхСНО данного счетчика;
- внешний тактовый сигнал режим 2: События на входе ETR данного счетчика.



Рисунок 28-6 - Структурная схема формирования события для счета

### 28.3.1 Внутренний тактовый сигнал (TIM CLK)

Этот режим выбирается, когда CNT\_MODE = 0x, EVENT\_SEL = 0000. Для запуска этого режима необходимо задать начальное значение основного счетчика, значение предварительного делителя основного счетчика, основание счета для основного счетчика и задать режим работы в регистре CNTRL. Значения регистров CNT, PSG и ARR можно изменять даже во время работы счетчика, при этом их значения вступят в силу по CNT = ARR или CNT = 0, в зависимости от направления счета. Значение регистра основания счета (ARR) может вступить в силу мгновенно после записи его в регистр при условии установленного поля ARRB\_EN = 1 (регистр CNTRL). Если значение предварительного делителя основного счетчика не равно нулю, то счетный регистр делителя будет инкрементироваться по каждому импульсу сигнала TIM\_CLK до тех пор, пока не достигнет значения, находящегося в регистре делителя. Далее счетный регистр делителя сбрасывается в ноль, содержимое основного счетчика таймера изменится на 1 и снова начинается счет. Поле DIR определяет, в какую сторону будет меняться значение счетчика: DIR = 0 — счетчик считает вверх (см. Рисунок 28–7), DIR = 1 — счетчик считает вниз (см. Рисунок 28–8).





Рисунок 28-7 - Диаграммы работы счетчика: счет вверх





Рисунок 28-8 - Диаграммы работы счетчика: счет вниз

Если CNT\_MODE = 00, то направление счета определяется полем DIR, если CNT\_MODE = 01, счетчик считает вверх/вниз с автоматическим изменением DIR (см. Рисунок 28–9).





Рисунок 28-9 - Диаграммы работы счетчика: счет вниз/вверх

#### 28.3.2 События в других счетчиках (CNT==ARR в таймере X)

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

У каждого таймера имеются входы запуска от других трех таймеров, а также внешние входы, связанные с выводами блоков захвата/сравнения.

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



Рисунок 28-10 - Пример каскадного соединения таймеров

DIR\_1, DIR\_2, DIR\_3 = 0; EVENT\_SEL\_1 = 0000, EVENT\_SEL\_2 = 0001, EVENT\_SEL\_3 = 0010; CNT\_MODE\_1, CNT\_MODE\_2, CNT\_MODE\_3 = 00;



Рисунок 28-11 - Диаграммы работы трех таймеров в каскаде

# 28.3.3 Внешний тактовый сигнал «Режим 1». События на линиях ТхСНО данного счетчика

Этот режим выбирается, когда EVENT\_SEL = 01xx в регистре CNTRL. Счетчик может считать по положительному фронту, или по отрицательному фронту на выбранном входе, или по положительному фронту на других каналах (см. Рисунок 28—10). На входе сигнала стоит фильтр, с помощью которого можно контролировать длительность сигнала. Для фильтрования можно использовать как сигнал TIM\_CLK, при этом может быть идентифицированная длительность 1, 2, 4, 8 TIM\_CLK, так и производную от TIM\_CLK частоту FDTS. Частота семплирования данных задается в регистре CNTRL в поле FDTS.



Рисунок 28–12 – Диаграммы возможных частот семплирования данных (FDTS)



Рисунок 28-13 - Тактирование с входа первого канала



Рисунок 28–14 – Диаграмма внешнего тактирования с разными вариантами фильтра



Рисунок 28–15 – Диаграмма внешнего тактирования с разными вариантами фильтра

# 28.3.4 Внешний тактовый сигнал «Режим 2». События на входе ETR данного счетчика

Этот режим выбирается, когда EVENT\_SEL = 1000 в регистре CNTRL. В регистре BRKETR\_CNTRL можно настроить коэффициент деления 2, 4 или 8 (ETRPSC) данного входа тактовой частоты, а также использовать инверсию входа.



Рисунок 28-16 - Схема тактирования сигналом со входа ETR



Рисунок 28-17 - Диаграмма тактирования сигналом со входа ETR

#### 28.4 Режим захвата

Структурную схему блока захвата показыает Рисунок 28–18.



Рисунок 28-18 - Структурная схема блока захвата на примере канала 1

Для включения режима захвата для определенного канала необходимо в регистре управления каналом СНу\_CNTRL записать "1" в поле САРпРWМ. Для регистрации событий по линии СНхі используется схема регистрации событий. Входной сигнал фиксируется в Таймере с частотой Fdts, или TIM\_CLK. Также вход может быть настроен на прием импульсов заданной длины за счет конфигурирования блока FILTER. На выходе блока фильтр вырабатывает сигнал положительного перепада и отрицательного перепада. На блоке MUX производится выбор используемого для захвата сигнала между положительным фронтом канала, отрицательным фронтом канала и положительными и отрицательными фронтами сигналов от других каналов. После блока MUX предварительный делитель может быть использован для фиксации каждого события, каждого второго, каждого

четвертого и каждого восьмого события. Выход предварительного делителя является сигналом Capture для регистра CCR, и Capture1 для регистра CCR1, при этом в регистры CCR и CCR1 записывается текущее значение основного счетчика CNT.



Рисунок 28-19 - Диаграмма захвата события со входа первого канала

На рисунке показан пример захвата значения основного счетчика в регистр ССR по положительному фронту на входе канала, а в регистр ССR1 — по отрицательному фронту на входе канала. В регистре IE можно разрешить выработку прерываний по событию захвата на определенном канале, а в регистре DMA\_RE можно разрешить формирование запросов DMA.

#### 28.5 Режим ШИМ



Рисунок 28-20 - Структурная схема блока формирования ШИМ

Для включения режима сравнения для определенного канала необходимо в регистре управления каналом CHy CNTRL записать "0" в поле CAPnPWM. При работе в режиме ШИМ выходной сигнал может формироваться на основании сравнения значения в регистре CCR и основного счетчика CNT или регистров CCR, CCR1 и значения основного счетчика CNT. Полученный сигнал может без изменения выдаваться на выводы CHxO и nCHxO. Либо с применением схемы DEAD TIME Generator формируются управляющие сигналы с мертвой зоной. У каждого канала есть два выхода - прямой и инверсный. Для каждого выхода формируется как сигнал для выдачи, так и сигнал разрешения выдачи, т.е. если выход канала должен всегда выдавать тот или иной уровень, то на выводе разрешения выдачи СНхОЕ (для прямого) и на CHxNOE (для инверсного) должны формироваться "1". Если канал работает на вход (например, режим захвата), то там всегда должен быть "0" для прямого канала. Сигналы ОЕ формируются по тем же принципам, что и просто выходные уровни, но у них есть собственные сигналы разрешения вывода SELOE и nSELOE, в которых можно выбрать постоянный уровень, либо формируемый на основании REF.



Рисунок 28-21 - Диаграмма работы схемы в режиме ШИМ, CCR1\_EN=0



Рисунок 28-22 - Диаграмма работы схемы в режиме ШИМ, CCR1\_EN=0

Сигнал REF может быть очищен с использованием внешнего сигнала с входа ETR, или внешнего, синхронизированного по PCLK сигналу со входа BRK.



Рисунок 28-23 - Диаграмма работы схемы в режиме ШИМ, CCR1 EN = 0



Рисунок 28-24 - Диаграмма работы схемы DTG

Если CCR1\_EN = 1, тогда значение основного счетчика CNT сравнивается со значениями регистров CCR и CCR1, и в зависимости от запрограммированного формата выработки сигнала REF (регистры управления каналами таймера CHy\_CNTRL поле OCCM) будет формироваться сигнал соответствующей формы.



Рисунок 28-25 - Диаграмма работы схемы в режиме ШИМ, CCR1\_EN = 1

При записи новых значений CCR и CCR1, если установлен бит CRRRLD, то регистры CCR1 и CCR получат новые значения только при CNT = 0, иначе запись осуществляется немедленно. Факт окончания записи обозначается взведением флага WR\_CMPL.

# 28.6 Примеры

#### 28.6.1 Обычный счетчик

MDR\_RST\_CLK->PER\_CLOCK = 0xFFFFFFF;
MDR\_RST\_CLK->TIM\_CLOCK = 0x07000000;
MDR\_TIMERx->CNTRL = 0x00000000;
//Hастраиваем работу основного счетчика
MDR\_TIMERx->CNT = 0x00000000; //Начальное значение счетчика
MDR\_TIMERx->PSG = 0x000000000; //Предделитель частоты
MDR\_TIMERx->ARR = 0x00000000F; //Основание счета

MDR\_TIMERx->IE = 0x00000002; //Paspewerue генерировать прерывание при CNT=ARR

 $MDR\_TIMERx->CNTRL = 0x00000001;$  //Счет вверх по  $TIM\_CLK$ . Разрешение работы таймера.



Рисунок 28-26 - Режим обычного счетчика

#### 28.6.2 Режим захвата

```
MDR RST CLK->PER CLOCK = 0xFFFFFFFF; //Разрешение тактовой частоты
таймеров
MDR_RST_CLK->TIM_CLOCK = 0x07000000;
                                         //Включение тактовой частоты
таймеров
TIMx->TIMx CNTRL = 0x00000000;//Режим инициализации таймера
//Настраиваем работу основного счетчика
MDR TIMERx->CNT = 0x00000000; //Начальное значение счетчика
MDR_TIMERx->PSG = 0x00000000;//Предделитель частоты
MDR TIMERx->ARR = 0x000000FF://Ochosahue cyema
MDR_TIMERx->IE = 0x00001E00; //Paspewehue генерировать прерывание
              //по переднему фронту на выходе САР по всем каналам
//Режим работы каналов - захват
MDR TIMERx->CHy CNTRL[0] = 0x00008000;
MDR_TIMERx->CHy_CNTRL[1] = 0x00008002;
MDR TIMERx->CHy CNTRL[2] = 0x00008001;
MDR TIMERx->CHy CNTRL[3] = 0x00008003;
//Режим работы выхода канала – канал на выход не работает
MDR_TIMERx->CHy_CNTRL1[0]= 0x00000000;
MDR_TIMERx->CHy_CNTRL1[1]= 0x000000000;
MDR\_TIMERx->CHy\_CNTRL1[2]=0x000000000;
MDR TIMERx->CHy CNTRL1[3]= 0x000000000:
MDR TIMERx->CNTRL = 0x00000001;
                                   //Счет вверх по ТІМ СLК. Разрешение
```



Рисунок 28-27 - Диаграммы примера работы в режиме захвата

работы таймера

#### 28.6.3 Режим ШИМ

```
MDR RST CLK->PER CLOCK = 0xFFFFFFFF; //Разрешение тактовой частоты
таймеров
MDR_RST_CLK->TIM_CLOCK = 0x07000000;
                                         //Включение тактовой частоты
таймеров
MDR TIMERx->CNTRL = 0x000000000:
                                   //Режим инициализации таймера
//Настраиваем работу основного счетчика
MDR TIMERx->CNT = 0x00000000; //Начальное значение счетчика
MDR_TIMERx->PSG = 0x00000000;//Предделитель частоты
MDR TIMERx->ARR = 0x00000010://Ochosahue cyema
MDR_TIMERx->IE = 0x000001E0; //Разрешение генерировать прерывание
           //по переднему фронту на выходе REF по всем каналам
//Режим работы каналов - ШИМ
MDR TIMERx->CHy CNTRL[0] = 0x00000200;
MDR_TIMERx->CHy_CNTRL[1] = 0x00000200;
MDR TIMERx->CHy CNTRL[2] = 0x00000400:
MDR TIMERx->CHy CNTRL[3] = 0x00000600;
//Режим работы выхода канала – канал на выход не работает
MDR_TIMERx->CHy_CNTRL1[0]= 0x00000099;
MDR_TIMERx->CHy_CNTRL1[1]= 0x000000099;
MDR_TIMERx->CHy_CNTRL1[2]= 0x00000099;
MDR TIMERx->CHy CNTRL1[3]= 0x00000099:
//Разрешение работы таймера.
MDR TIMERx->CNTRL = 0x00000001:
                                   //Счет вверх по TIM CLK.
```



Рисунок 28-28 - Диаграммы примера работы в режиме ШИМ

# 28.7 Описание регистров блока таймера

Таблица 28-1 – Базовые адреса и смещения регистров управления таймера

| Адрес       | Название               | Описание                                        |
|-------------|------------------------|-------------------------------------------------|
| 0x4007 0000 | MDR TIMER1             | Контроллер Timer1                               |
| 0x4007_8000 | MDR_TIMER 2            | Контроллер Timer1<br>Контроллер Timer2          |
| 0x4008_0000 | MDR_TIMER 3            | Контроллер Timer2 Контроллер Timer3             |
| Смещение    | INIDIX_TIMEX 3         | Nonthornieh tilliero                            |
| ОхОО        | MDR_TIMERx->CNT[15:0]  | MDR_TIMERx->CNT                                 |
| UXUU        | MDR_TIMERX->CNT[15.0]  | _                                               |
| 0x04        | MDR TIMERx->PSG[15:0]  | Основной счетчик таймера                        |
| UXU4        | MDR_TIMERX->PSG[15:0]  | MDR_TIMERx->PSG                                 |
| 0.00        | MDD TIMED. ADDIAGO     | Делитель частоты при счете основного счетчика   |
| 0x08        | MDR_TIMERx->ARR[15:0]  | MDR_TIMERx->ARR                                 |
| 0.00        |                        | Основание счета основного счетчика              |
| 0x0C        | MDD TIMEDY CNTD 17:01  | MDD TIMEDY CONTDI                               |
|             | MDR_TIMERx->CNTRL[7:0] | MDR_TIMERx->CNTRL                               |
| 0.40        | 0004[45:0]             | Регистр управления основного счетчика           |
| 0x10        | CCR1[15:0]             | MDD TIMED. COD.                                 |
|             |                        | MDR_TIMERx->CCRy                                |
| 0.44        | 0000145.03             | Регистр сравнения, захвата для 1 канала таймера |
| 0x14        | CCR2[15:0]             | AADD TIMED OOD                                  |
|             |                        | MDR_TIMERx->CCRy                                |
|             |                        | Регистр сравнения, захвата для 2 канала таймера |
| 0x18        | CCR3[15:0]             |                                                 |
|             |                        | MDR_TIMERx->CCRy                                |
|             |                        | Регистр сравнения, захвата для 3 канала таймера |
| 0x1C        | CCR4[15:0]             |                                                 |
|             |                        | MDR_TIMERx->CCRy                                |
|             |                        | Регистр сравнения, захвата для 4 канала таймера |
| 0x20        | CH1_CNTRL[15:0]        | MDR_TIMERx->CHy_CNTRL                           |
|             |                        | Регистр управления для 1 канала таймера         |
| 0x24        | CH2_CNTRL[15:0]        | MDR_TIMERx->CHy_CNTRL                           |
|             |                        | Регистр управления для 2 канала таймера         |
| 0x28        | CH3_CNTRL[15:0]        | MDR_TIMERx->CHy_CNTRL                           |
|             |                        | Регистр управления для 3 канала таймера         |
| 0x2C        | CH4_CNTRL[15:0]        | MDR_TIMERx->CHy_CNTRL                           |
|             |                        | Регистр управления для 4 канала таймера         |
| 0x30        | CH1_CNTRL1[15:0]       |                                                 |
|             |                        | MDR_TIMERx->CHy_CNTRL1                          |
|             |                        | Регистр управления 1 для 1 канала таймера       |
| 0x34        | CH2_CNTRL1[15:0]       |                                                 |
|             |                        | MDR_TIMERx->CHy_CNTRL1                          |
|             |                        | Регистр управления 1для 2 канала таймера        |
| 0x38        | CH3_CNTRL1[15:0]       |                                                 |
|             |                        | MDR_TIMERx->CHy_CNTRL1                          |
|             |                        | Регистр управления 1 для 3 канала таймера       |
| 0x3C        | CH4_CNTRL1[15:0]       |                                                 |
|             |                        | MDR_TIMERx->CHy_CNTRL1                          |
|             |                        | Регистр управления 1 для 4 канала таймера       |
| 0x40        | CH1_DTG[15:0]          | MDR_TIMERx->CHy_DTG                             |
|             |                        | Регистр управления DTG для 1 канала таймера     |
| 0x44        | CH2_DTG[15:0]          | MDR_TIMERx->CHy_DTG                             |
|             |                        | Регистр управления DTG для 2 канала таймера     |
| 0x48        | CH3_DTG[15:0]          | MDR_TIMERx->CHy_DTG                             |
|             |                        | Регистр управления DTG для 3 канала таймера     |
|             | •                      |                                                 |

| 0x4C | CH4_DTG[15:0]       | MDR_TIMERx->CHy_DTG                           |
|------|---------------------|-----------------------------------------------|
|      |                     | Регистр управления DTG для 4 канала таймера   |
| 0x50 | BRKETR_CNTRL[15:0]  |                                               |
|      |                     | MDD TIMED DOWETT ONTO                         |
|      |                     | MDR_TIMERx->BRKETR_CNTRL                      |
| 0.54 | OTATI 10[45.0]      | Регистр управления входом BRK и ETR           |
| 0x54 | STATUS[15:0]        |                                               |
|      |                     | MDR_TIMERx->STATUS                            |
|      |                     | Регистр статуса таймера                       |
| 0x58 | IE[15:0]            | MDR_TIMERx->IE                                |
|      |                     | Регистр разрешения прерывания таймера         |
| 0x5C | DMA_RE[15:0]        |                                               |
|      |                     | MDR_TIMERx->DMA_RE                            |
|      |                     | Регистр разрешения запросов DMA от прерываний |
|      |                     | таймера                                       |
| 0x60 | CH1_CNTRL2[15:0]    |                                               |
|      |                     | MDR_TIMERx->CHy_CNTRL2                        |
| 2.24 | OUIS ONTEN STATE ST | Регистр управления 2 для 1 канала таймера     |
| 0x64 | CH2_CNTRL2[15:0]    | MDD TIMED. OUT ONTO                           |
|      |                     | MDR_TIMERx->CHy_CNTRL2                        |
| 0x68 | CH3_CNTRL2[15:0]    | Регистр управления 2 для 2 канала таймера     |
| UXOO | CH3_CNTRL2[15.0]    | MDR_TIMERx->CHy_CNTRL2                        |
|      |                     | Регистр управления 2 для 3 канала таймера     |
| 0x6C | CH4_CNTRL2[15:0]    | Т стиотр управления 2 для в канала таймера    |
| 0,00 | 0111_0111112[10:0]  | MDR_TIMERx->CHy_CNTRL2                        |
|      |                     | Регистр управления 2 для 4 канала таймера     |
| 0x70 | CCR11[15:0]         | MDR_TIMERx->CCRy1                             |
|      |                     | Регистр сравнения 1, захвата для 1 канала     |
|      |                     | таймера                                       |
| 0x74 | CCR21[15:0]         | MDR_TIMERx->CCRy1                             |
|      |                     | Регистр сравнения 1, захвата для 2 канала     |
|      |                     | таймера                                       |
| 0x78 | CCR31[15:0]         | MDR_TIMERx->CCRy1                             |
|      |                     | Регистр сравнения 1, захвата для 3 канала     |
|      |                     | таймера                                       |
| 0x7C | CCR41[15:0]         | MDR_TIMERx->CCRy1                             |
|      |                     | Регистр сравнения 1, захвата для 4 канала     |
|      |                     | таймера                                       |

# 28.7.1 MDR\_TIMERx->CNT

# Таблица 28-2 - Основной счетчик таймера CNT

| Номер  | 3116 | 15 0      |
|--------|------|-----------|
| Доступ | U    | R/W       |
| Сброс  | 0    | 0         |
|        | -    | CNT[15:0] |

# Таблица 28-3 – Описание бит регистра CNT

| N  | 0  | Функциональное | Расшифровка функционального имени бита, краткое |
|----|----|----------------|-------------------------------------------------|
| би | та | имя бита       | описание назначения и принимаемых значений      |
| 31 | 16 | •              | Зарезервировано                                 |

| 150 | CNT[7:0] | Значение основного счетчика таймера |
|-----|----------|-------------------------------------|

#### 28.7.2 MDR\_TIMERx->PSG

# Таблица 28-4 – Делитель частоты при счете основного счетчика PSG

| Номер  | 3116 | 15 0      |
|--------|------|-----------|
| Доступ | U    | R/W       |
| Сброс  | 0    | 0         |
| _      |      | PSG[15:0] |

# Таблица 28-5 – Описание бит регистра PSG

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                    |  |
|-----------|-------------------------|---------------------------------------------------------------------------------------------------------------|--|
| 3116      | -                       | Зарезервировано                                                                                               |  |
| 150       | PSG[7:0]                | Значение предварительного делителя счетчика.<br>Основной счетчик считает на частоте:<br>CLK = TIM_CLK/(PSG+1) |  |

#### 28.7.3 MDR\_TIMERx->ARR

#### Таблица 28-6 – Основание счета основного счетчика ARR

| Номер  | 3116 | 15 0      |
|--------|------|-----------|
| Доступ | U    | R/W       |
| Сброс  | 0    | 0         |
|        | •    | ARR[15:0] |

# Таблица 28-7 – Описание бит регистра ARR

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3116      | 1                       | Зарезервировано                                                                            |
| 150       | ARR[7:0]                | Основание счета для основного счетчика:<br>CNT = [0ARR]                                    |

#### 28.7.4 MDR TIMERx->CNTRL

# Таблица 28-8 - Регистр управления основного счетчика CNTRL

| Номер  | 3112 | 118      | 7, 6      | 5, 4  | 3   | 2    | 1    | 0   |
|--------|------|----------|-----------|-------|-----|------|------|-----|
| Доступ | U    | R/W      | R/W       | R/W   | R/W | R/W  | R/W  | R/W |
| Сброс  | 0    | 0        | 0         | 0     | 0   | 0    | 0    | 0   |
|        | -    | EVENT    | CNT       | FDTS  | DIR | WR   | ARRB | CNT |
|        |      | SEL[3:0] | MODE[1:0] | [1:0] |     | CMPL | EN   | EN  |

Таблица 28-9 – Описание бит регистра CNTRL

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|--|
| 3112      | -                       | Зарезервировано                                                                            |  |
| 118       | EVENT_SEL               | Биты выбора источника событий:                                                             |  |
|           | [3:0]                   | 0000 – всегда "0";                                                                         |  |
|           |                         | 0001 – CNT == ARR в таймере 1;                                                             |  |
|           |                         | 0010 – CNT == ARR в таймере 2;                                                             |  |
|           |                         | 0011 – CNT == ARR в таймере 3;                                                             |  |
|           |                         | 0100 – событие на первом канале «Режим 1»;                                                 |  |
|           |                         | 0101 – событие на втором канале «Режим 1»;                                                 |  |
|           |                         | 0110 – событие на третьем канале «Режим 1»;                                                |  |
|           |                         | 0111 – событие на четвертом канале «Режим 1»;                                              |  |
|           |                         | 1000 – событие на ETR «Режим 2»                                                            |  |
| 7, 6      | CNT_MODE                | Режим счета основного счетчика:                                                            |  |
|           | [1:0]                   | 00 – счетчик вверх при DIR=0 (при PSG = 0)                                                 |  |
|           |                         | счетчик вниз при DIR=1 (при PSG = 0);                                                      |  |
|           |                         | 01 – счетчик вверх/вниз с автоматическим изменением DIR при                                |  |
|           |                         | PSG = 0;                                                                                   |  |
|           |                         | 10 – счетчик вверх при DIR=0 (при EVENT = 1)                                               |  |
|           |                         | счетчик вниз при DIR=1 (при EVENT = 1);                                                    |  |
|           |                         | 11 – счетчик вверх/вниз с автоматическим изменением DIR (при                               |  |
| 5, 4      | FDTS[1:0]               | EVENT = 1) Частота семплирования данных FDTS:                                              |  |
| 5, 4      | [0.1]C1UT               | частота семплирования данных РВ13.<br>00 – каждый TIM_CLK;                                 |  |
|           |                         | 00 – каждый тім_Осік,<br>01 – каждый второй ТІМ_СЬК;                                       |  |
|           |                         | 10 – каждый второй тім_СЕК;<br>10 – каждый третий ТІМ_СЬК;                                 |  |
|           |                         | 10 – каждый третий тім_осік,<br>11 – каждый четвертый ТІМ_СLК                              |  |
| 3         | DIR                     | Направление счета основного счетчика:                                                      |  |
|           | Dirk                    | 0 – вверх, от 0 до ARR;                                                                    |  |
|           |                         | 1 – вниз, от ARR до 0                                                                      |  |
| 2         | WR_CMPL                 | Окончание записи, при задании нового значения регистров CNT,                               |  |
|           |                         | PSG и ARR:                                                                                 |  |
|           |                         | 0 – новые данные можно записывать;                                                         |  |
|           |                         | 1 – данные не записаны и идет запись                                                       |  |
| 1         | ARRB_EN                 | Разрешение мгновенного обновления ARR                                                      |  |
|           | _                       | 0 – ARR будет перезаписан в момент записи в ARR;                                           |  |
|           |                         | 1 – ARR будет перезаписан при завершении счета CNT                                         |  |
| 0         | CNT_EN                  | Разрешение работы таймера:                                                                 |  |
|           |                         | 0 – таймер отключен;                                                                       |  |
|           |                         | 1 – таймер включен                                                                         |  |

# 28.7.5 MDR\_TIMERx->CCRy

# Таблица 28-10 – Регистр сравнения/захвата для 'у' канала таймера ССКу

| Номер  | 3116 | 15 0      |
|--------|------|-----------|
| Доступ | U    | R/W       |
| Сброс  | 0    | 0         |
|        | -    | CCR[15:0] |

# Таблица 28-11 – Описание бит регистра CCRy

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                 |
|-----------|-------------------------|----------------------------------------------------------------------------------------------------------------------------|
| 3116      | -                       | Зарезервировано                                                                                                            |
| 150       | CCR[15:0]               | Значение ССR, с которым сравнивается СNT при работе в режиме ШИМ. Значение CNT при котором произошел факт захвата события, |
|           |                         | в режиме захвата.                                                                                                          |

# 28.7.6 MDR\_TIMERx->CCRy1

# Таблица 28-12 – Регистр сравнения/захвата для 'у' канала таймера ССКу1

| Номер  | 3116 | 150        |
|--------|------|------------|
| Доступ | U    | R/W        |
| Сброс  | 0    | 0          |
|        | -    | CCR1[15:0] |

# Таблица 28-13 - Описание бит регистра CCRy1

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                       |
|-----------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 3116      | •                       | Зарезервировано                                                                                                                                  |
| 150       | CCR1[15:0]              | Значение CCR1, с которым сравнивается CNT при работе в режиме ШИМ.<br>Значение CNT при котором произошел факт захвата события, в режиме захвата. |

# 28.7.7 MDR\_TIMERx->CHy\_CNTRL

# Таблица 28-14 – Регистр управления для 'у' канала таймера CHy\_CNTRL

| Номер  | 311 | 15   | 14   | 13   | 12  | 119   | 8    | 76    | 54    | 30    |
|--------|-----|------|------|------|-----|-------|------|-------|-------|-------|
|        | 6   |      |      |      |     |       |      |       |       |       |
| Доступ | U   | R/W  | RO   | R/W  | R/W | R/W   | R/W  | R/W   | R/W   | R/W   |
| Сброс  | 0   | 0    | 0    | 0    | 0   | 0     | 0    | 0     | 0     | 0     |
|        | -   | CAP  | WR   | ETRE | BRK | OCCM  | OCCE | CHPS  | CHSE  | CHFL  |
|        |     | nPWM | CMPL | N    | EN  | [2:0] |      | С     | L     | TR    |
|        |     |      |      |      |     |       |      | [1:0] | [1:0] | [3:0] |

# Таблица 28-15 – Описание бит регистра CHy\_CNTRL

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 3116      | -                          | Зарезервировано                                                                            |
| 15        | CAP                        | Режим работы канала Захват или ШИМ:                                                        |
|           | nPWM                       | 1 – канал работает в режиме Захват;                                                        |
|           |                            | 0 – канал работает в режиме ШИМ                                                            |
| 14        | WR                         | Флаг окончания записи, при задании нового значения                                         |
|           | CMPL                       | регистра CCR                                                                               |
|           |                            | 1 – данные не записаны и идет запись;                                                      |
|           |                            | 0 – новые данные можно записывать                                                          |
| 13        | ETREN                      | Разрешения сброса по выводу ETR:                                                           |
|           |                            | 0 – запрещен сброс;                                                                        |
|           |                            | 1 – разрешен                                                                               |

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 12        | BRKEN                   | Разрешение сброса по выводу BRK:                                                           |
|           |                         | 0 – запрещен сброс;                                                                        |
|           |                         | 1 – разрешен                                                                               |
| 119       | OCCM[2:0]               | Формат выработки сигнала REF в режиме ШИМ:                                                 |
|           |                         | Если CCR1_EN = 0:                                                                          |
|           |                         | 000 – всегда 0                                                                             |
|           |                         | 001 – 1, если CNT = CCR;                                                                   |
|           |                         | 010 – 0, если CNT = CCR;                                                                   |
|           |                         | 011 – переключение REF, если CNT =CCR;                                                     |
|           |                         | 100 – всегда 0;                                                                            |
|           |                         | 101 – всегда 1;                                                                            |
|           |                         | 110 – 1, если DIR= 0 (счет вверх), CNT <ccr, 0;<="" th="" иначе=""></ccr,>                 |
|           |                         | 0, если DIR= 1 (счет вниз), CNT> CCR, иначе 1;                                             |
|           |                         | 111 – 0, если DIR= 0 (счет вверх), CNT <ccr, 1;<="" th="" иначе=""></ccr,>                 |
|           |                         | 1, если DIR= 1 (счет вниз), CNT> CCR, иначе 0.                                             |
|           |                         | Если CCR1_EN = 1:<br>000 – всегда 0;                                                       |
|           |                         | 000 – всегда 0,<br>001 – 1, если CNT = CCR или CNT = CCR1                                  |
|           |                         | 010 – 0, если CNT = CCR или CNT = CCR1;                                                    |
|           |                         | 011 – переключение REF, если CNT =CCR или CNT =CCR1;                                       |
|           |                         | 100 – всегда 0;                                                                            |
|           |                         | 101 – всегда 1;                                                                            |
|           |                         | 110 – 1, если DIR = 0 (счет вверх), CCR <cnt 0;<="" <ccr1,="" th="" иначе=""></cnt>        |
|           |                         | 0, если DIR = 1 (счет вниз), CCR <cnt 1;<="" <ccr1,="" th="" иначе=""></cnt>               |
|           |                         | 111 – 0, если DIR = 0 (счет вверх), CCR <cnt 1;<="" <ccr1,="" th="" иначе=""></cnt>        |
|           |                         | 1, если DIR = 1 (счет вниз), CCR <cnt 0;<="" <ccr1,="" th="" иначе=""></cnt>               |
|           |                         | при условии что CCR < CCR1.                                                                |
| 8         | OCCE                    | Разрешение работы ETR:                                                                     |
|           |                         | 0 – запрет ETR;                                                                            |
|           |                         | 1 – разрешение ETR                                                                         |
| 76        | CHPSC[1:0]              | Предварительный делитель входного канала:                                                  |
|           |                         | 00 – нет деления;                                                                          |
|           |                         | 01 – /2;                                                                                   |
|           |                         | 10 – /4;                                                                                   |
| 54        | CHSEL[1:0]              | 11 – /8 Выбор события по входному каналу СНхі для фиксации                                 |
| 54        | CHSEL[1.0]              | значения основного счетчика (регистр MDR TIMERx->CNT) в                                    |
|           |                         | регистр ССR:                                                                               |
|           |                         | 00 – положительный фронт на входном канале CHxi;                                           |
|           |                         | 01 – отрицательный фронт на входном канале СНхі;                                           |
|           |                         | 10 – положительный фронт от других каналов;                                                |
|           |                         | Для первого канала от 2 канала;                                                            |
|           |                         | Для второго канала от 3 канала;                                                            |
|           |                         | Для третьего канала от 4 канала;                                                           |
|           |                         | Для четвертого канала от 1 канала;                                                         |
|           |                         | 11 – положительный фронт от других каналов;                                                |
|           |                         | Для первого канала от 3 канала;                                                            |
|           |                         | Для второго канала от 4 канала;                                                            |
|           |                         | Для третьего канала от 1 канала;                                                           |
|           | 011=1=======            | Для четвертого канала от 2 канала                                                          |
| 30        | CHFLTR[3:0]             | Сигнал зафиксирован:                                                                       |
|           |                         | 0000 – в 1 триггере на частоте ТІМ_СLК;                                                    |
|           |                         | 0001 – в 2 триггерах на частоте TIM_CLK;                                                   |
|           |                         | 0010 – в 4 триггерах на частоте TIM_CLK;                                                   |

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |  |  |  |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|--|--|--|--|
|           |                         | 0011 – в 8 триггерах на частоте TIM_CLK;                                                   |  |  |  |  |
|           |                         | 0100 – в 6 триггерах на частоте FDTS/2;                                                    |  |  |  |  |
|           |                         | 0101 – в 8 триггерах на частоте FDTS/2;                                                    |  |  |  |  |
|           |                         | 0110 – в 6 триггерах на частоте FDTS/4;                                                    |  |  |  |  |
|           |                         | 0111 – в 8 триггерах на частоте FDTS/4;                                                    |  |  |  |  |
|           |                         | 1000 – в 6 триггерах на частоте FDTS/8;                                                    |  |  |  |  |
|           |                         | 1001 – в 8 триггерах на частоте FDTS/8;                                                    |  |  |  |  |
|           |                         | 1010 – в 5 триггерах на частоте FDTS/16;                                                   |  |  |  |  |
|           |                         | 1011 – в 6 триггерах на частоте FDTS/16;                                                   |  |  |  |  |
|           |                         | 1100 – в 8 триггерах на частоте FDTS/16;                                                   |  |  |  |  |
|           |                         | 1101 – в 5 триггерах на частоте FDTS/32;                                                   |  |  |  |  |
|           |                         | 1110 – в 6 триггерах на частоте FDTS/32;                                                   |  |  |  |  |
|           |                         | 1111 – в 8 триггерах на частоте FDTS/32                                                    |  |  |  |  |

### 28.7.8 MDR\_TIMERx->CHy\_CNTRL1

### Таблица 28-16 – Регистр управления 1 для 'у' канала таймера CHy\_CNTRL1

| Номер  | 3113 | 12   | 1110  | 98    | 75 | 4   | 32         | 10    |
|--------|------|------|-------|-------|----|-----|------------|-------|
| Доступ | U    | R/W  | R/W   | R/W   | U  | R/W | R/W        | R/W   |
| Сброс  | 0    | 0    | 0     | 0     | 0  | 0   | 0          | 0     |
|        | -    | NINV | NSELO | NSELO | -  | INV | SELO       | SELOE |
|        |      |      | [1:0] | E     |    |     | [1:0]      | [1:0] |
|        |      |      |       | [1:0] |    |     | _ <b>-</b> |       |

### Таблица 28-17 - Описание бит регистра CHy\_CNTRL1

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое               |  |  |  |  |  |  |  |
|------|----------------|---------------------------------------------------------------|--|--|--|--|--|--|--|
| бита | имя бита       | описание назначения и принимаемых значений                    |  |  |  |  |  |  |  |
| 3113 | -              | Зарезервировано                                               |  |  |  |  |  |  |  |
| 12   | NINV           | Режим выходной инверсии инверсного канала nCHy:               |  |  |  |  |  |  |  |
|      |                | 0 – выход не инвертируется;                                   |  |  |  |  |  |  |  |
|      |                | 1 – выход инвертируется                                       |  |  |  |  |  |  |  |
| 1110 | NSELO[1:0]     | Режим работы выхода инверсного канала nCHy:                   |  |  |  |  |  |  |  |
|      |                | 00 – всегда на выход выдается 0, канал на выход не работает;  |  |  |  |  |  |  |  |
|      |                | 01 – всегда на выход выдается 1, канал всегда работает на     |  |  |  |  |  |  |  |
|      |                | выход;                                                        |  |  |  |  |  |  |  |
|      |                | 0 – на выход выдается сигнал REF;                             |  |  |  |  |  |  |  |
|      |                | 11 - на выход выдается сигнал с DTG                           |  |  |  |  |  |  |  |
| 98   | NSELOE[1:0]    | Режим работы инверсного канала nCHy на выход                  |  |  |  |  |  |  |  |
|      |                |                                                               |  |  |  |  |  |  |  |
|      |                | 00 – всегда на nCHyOE выдается 0, канал на выход не работает; |  |  |  |  |  |  |  |
|      |                | 01 – всегда на nCHyOE выдается 1, канал всегда работает на    |  |  |  |  |  |  |  |
|      |                | выход;                                                        |  |  |  |  |  |  |  |
|      |                | 10 – на nCHyOE выдается сигнал REF, при REF = 0 третье        |  |  |  |  |  |  |  |
|      |                | состояние, при REF = 1 выход;                                 |  |  |  |  |  |  |  |
|      |                | 11 - на nCHyOE выдается сигнал с DTG, при nCHyOE = 0          |  |  |  |  |  |  |  |
|      |                | третье состояние, при nCHyOE = 1 выход                        |  |  |  |  |  |  |  |
| 75   | -              | Зарезервировано                                               |  |  |  |  |  |  |  |
| 4    | INV            | Режим выходной инверсии прямого канала СНу:                   |  |  |  |  |  |  |  |
|      |                | 0 – выход не инвертируется;                                   |  |  |  |  |  |  |  |
|      |                | 1 – выход инвертируется                                       |  |  |  |  |  |  |  |
| 32   | SELO[1:0]      | Режим работы выхода прямого канала СНу:                       |  |  |  |  |  |  |  |
|      |                | 00 – всегда на выход выдается 0, канал на выход не работает;  |  |  |  |  |  |  |  |

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|    |            | 01 – всегда на выход выдается 1, канал всегда работает на    |  |  |  |  |  |
|----|------------|--------------------------------------------------------------|--|--|--|--|--|
|    |            | выход;                                                       |  |  |  |  |  |
|    |            | 10 – на выход выдается сигнал REF;                           |  |  |  |  |  |
|    |            | 11 – на выход выдается сигнал с DTG                          |  |  |  |  |  |
| 10 | SELOE[1:0] | Режим работы прямого канала СНу на выход:                    |  |  |  |  |  |
|    |            | 00 – всегда на СНуОЕ выдается 0, канал на выход не работает; |  |  |  |  |  |
|    |            | 01 – всегда на CHyOE выдается 1, канал всегда работает на    |  |  |  |  |  |
|    |            | выход;                                                       |  |  |  |  |  |
|    |            | 10 – на CHyOE выдается сигнал REF, при REF = 0 третье        |  |  |  |  |  |
|    |            | состояние, при REF = 1 выход;                                |  |  |  |  |  |
|    |            | 11 – на CHyOE выдается сигнал с DTG, при CHyOE = 0 третье    |  |  |  |  |  |
|    |            | состояние, при СНуОЕ = 1 выход                               |  |  |  |  |  |

### 28.7.9 MDR\_TIMERx->CHy\_CNTRL2

### Таблица 28-18 – Регистр управления 2 для 'у' канала таймера CHy\_CNTRL2

| Номер  | 31 4 | 3      | 2       | 10    |
|--------|------|--------|---------|-------|
| Доступ | U    | R/W    | R/W     | R/W   |
| Сброс  | 0    | 0      | 0       | 00    |
|        | -    | CRRRLD | CCR1_EN | CHSEL |
|        |      |        |         | [1:0] |

### Таблица 28-19 - Описание бит регистра CHy\_CNTRL2

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                    |
|------------------|-------------------------|---------------------------------------------------------------------------------------------------------------|
| 314              | -                       | Зарезервировано                                                                                               |
| 3                | CRRRLD                  | Разрешение обновления регистров ССR и ССR1:                                                                   |
|                  |                         | 0 – обновление возможно в любой момент времени;                                                               |
|                  |                         | 1 – обновление будет осуществлено только при CNT = 0                                                          |
| 2                | CCR1_EN                 | Разрешение работы регистра CCR1:                                                                              |
|                  |                         | 0 – CCR1 не используется;                                                                                     |
|                  |                         | 1 – CCR1 используется                                                                                         |
| 10               | CHSEL1[1:0]             | Выбор события по входному каналу СНхі для фиксации<br>значения основного счетчика (регистр MDR_TIMERx->CNT) в |
|                  |                         | регистр CCR1:                                                                                                 |
|                  |                         | 00 – положительный фронт на входном канале СНхі;                                                              |
|                  |                         | 01 – отрицательный фронт на входном канале СНхі;                                                              |
|                  |                         | 10 – отрицательный фронт от других каналов:                                                                   |
|                  |                         | - для первого канала от 2 канала;                                                                             |
|                  |                         | - для второго канала от 3 канала;                                                                             |
|                  |                         | - для третьего канала от 4 канала;                                                                            |
|                  |                         | - для четвертого канала от 1 канала.                                                                          |
|                  |                         | 11 – отрицательный фронт от других каналов:                                                                   |
|                  |                         | - для первого канала от 3 канала;                                                                             |
|                  |                         | - для второго канала от 4 канала;                                                                             |
|                  |                         | - для третьего канала от 1 канала;                                                                            |
|                  |                         | - для четвертого канала от 2 канала                                                                           |

#### 28.7.10 MDR\_TIMERx->CHy\_DTG

### Таблица 28-20 – Регистр CHy\_DTG управления DTG

| Номер  | 3116 | 158      | 75 | 4    | 30        |
|--------|------|----------|----|------|-----------|
| Доступ | U    | R/W      | U  | R/W  | R/W       |
| Сброс  | 0    | 0        | 0  | 0    | 0         |
|        | -    | DTG[7:0] | -  | EDTS | DTGx[3:0] |

### Таблица 28-21 - Описание бит регистра СНу\_DTG

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3116      | -                       | Зарезервировано                                                                            |
| 158       | DTG[7:0]                | Основной делитель частоты.<br>Задержка DTGdel = DTG*(DTGx+1)                               |
| 75        | -                       | Зарезервировано                                                                            |
| 4         | EDTS                    | Частота работы DTG:<br>0 – TIM_CLK;<br>1 – FDTS                                            |
| 30        | DTGx [3:0]              | Предварительный делитель частоты DTGx                                                      |

#### 28.7.11 MDR\_TIMERx->BRKETR\_CNTRL

#### Таблица 28-22 – Регистр BRKETR\_CNTRL управления входом BRK и ETR

| Номер  | 318 | 74     | 32    | 1   | 0   |
|--------|-----|--------|-------|-----|-----|
| Доступ | U   | R/W    | R/W   | R/W | R/W |
| Сброс  | 0   | 0      | 0     | 0   | 0   |
|        | -   | ETR    | ETR   | ETR | BRK |
|        |     | FILTER | PSC   | INV | INV |
|        |     | [3:0]  | [1:0] |     |     |

### Таблица 28-23 - Описание бит регистра BRKETR\_CNTRL

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | -                          | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 318       | ETR<br>FILTER[3:0]         | Зарезервировано  Цифровой фильтр на входе ETR.  Сигнал зафиксирован:  0000 – в 1 триггере на частоте TIM_CLK;  0001 – в 2 триггерах на частоте TIM_CLK;  0010 – в 4 триггерах на частоте TIM_CLK;  0011 – в 8 триггерах на частоте TIM_CLK;  0100 – в 6 триггерах на частоте FDTS/2;  0101 – в 8 триггерах на частоте FDTS/4;  0111 – в 6 триггерах на частоте FDTS/4;  1000 – в 6 триггерах на частоте FDTS/8;  1001 – в 8 триггерах на частоте FDTS/8;  1010 – в 5 триггерах на частоте FDTS/16;  1100 – в 8 триггерах на частоте FDTS/16; |
|           |                            | 1101 – в 5 триггерах на частоте FDTS/32;<br>  1110 – в 6 триггерах на частоте FDTS/32;                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|     |             | 1111 – в 8 триггерах на частоте FDTS/32     |
|-----|-------------|---------------------------------------------|
| 2 0 | ETDD00[4:0] |                                             |
| 32  | ETRPSC[1:0] | Асинхронный пред. делитель внешней частоты: |
|     |             | 00 – без деления;                           |
|     |             | 01 – /2;                                    |
|     |             | 10 – /4;                                    |
|     |             | 11 – /8                                     |
| 1   | ETR         | Инверсия входа ETR:                         |
|     | INV         | 0 – без инверсии;                           |
|     |             | 1 – инверсия                                |
| 0   | BRK         | Инверсия входа BRK:                         |
|     | INV         | 0 – без инверсии;                           |
|     |             | 1 – инверсия                                |

### 28.7.12 MDR\_TIMERx->STATUS

### Таблица 28-24 – Регистр статуса таймера STATUS

| Номер  | 311 | 1613  | 129   | 85    | 4     | 3            | 2            | 1            | 0            |
|--------|-----|-------|-------|-------|-------|--------------|--------------|--------------|--------------|
|        | 7   |       |       |       |       |              |              |              |              |
| Доступ | U   | R/W   | R/W   | R/W   | R/W   | R/W          | R/W          | R/W          | R/W          |
| Сброс  | 0   | 0     | 0     | 0     | 0     | 0            | 0            | 0            | 0            |
|        | -   | CCR   | CCR   | CCR   | BRK   | ETR          | ETR          | CNT          | CNT          |
|        |     | CAP1  | REF   | CAP   | EVENT | FE           | RE           | ARR          | ZERO         |
|        |     | EVENT | EVENT | EVENT |       | <b>EVENT</b> | <b>EVENT</b> | <b>EVENT</b> | <b>EVENT</b> |
|        |     | [3:0] | [3:0] | [3:0] |       |              |              |              |              |

# Таблица 28-25 – Описание бит регистра STATUS

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое           |
|------|----------------|-----------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                |
| 311  | -              | Зарезервировано                                           |
| 7    |                |                                                           |
| 161  | CCR            | Событие настроенного фронта на входе СНхі канала таймера: |
| 3    | CAP1           | 0 – нет события;                                          |
|      | EVENT[3:0]     | 1 – есть событие.                                         |
|      | • •            | Сбрасывается записью 0, если запись одновременно с новым  |
|      |                | событием. Приоритет у нового события.                     |
|      |                |                                                           |
|      |                | Бит 0 – первый канал.                                     |
|      |                | Бит 3 – четвертый канал                                   |
| 129  | CCR            | Событие переднего фронта на выходе REF каналов таймера:   |
|      | REF            | 0 – нет события;                                          |
|      | EVENT[3:0]     | 1 – есть событие.                                         |
|      |                | Сбрасывается записью 0, если запись одновременно с новым  |
|      |                | событием. Приоритет у нового события.                     |
|      |                |                                                           |
|      |                | Бит 0 – первый канал.                                     |
|      |                | Бит 3 – четвертый канал                                   |

| 85 | CCR        | Событие настроенного фронта на входе СНхі канала таймера:  |
|----|------------|------------------------------------------------------------|
|    | CAP        | 0 – нет события;                                           |
|    | EVENT[3:0] | 1 – есть событие.                                          |
|    |            | Сбрасывается записью 0, если запись одновременно с новым   |
|    |            | событием. Приоритет у нового события.                      |
|    |            |                                                            |
|    |            | Бит 0 – первый канал.                                      |
|    |            | Бит 3 – четвертый канал                                    |
| 4  | BRK        | Состояние входа BRK, синхронизированное по PCLK:           |
|    | EVENT      | 0 - BRK = 0;                                               |
|    |            | 1 – BRK = 1.                                               |
|    |            | Сбрасывается записью 0, при условии наличия 0 на входе BRK |
| 3  | ETR        | Событие заднего фронта на входе ETR:                       |
|    | FE         | 0 – нет события;                                           |
|    | EVENT      | 1 – есть событие.                                          |
|    |            | Сбрасывается записью 0, если запись одновременно с новым   |
|    |            | событием. Приоритет у нового события                       |
| 2  | ETR        | Событие переднего фронта на входе ETR:                     |
|    | RE_        | 0 – нет события;                                           |
|    | EVENT      | 1 – есть событие.                                          |
|    |            | Сбрасывается записью 0, если запись одновременно с новым   |
|    |            | событием. Приоритет у нового события                       |
| 1  | CNT        | Событие совпадения CNT с ARR:                              |
|    | ARR        | 0 – нет события;                                           |
|    | EVENT      | 1 – есть событие.                                          |
|    |            | Сбрасывается записью 0, если запись одновременно с новым   |
|    |            | событием совпадения. Приоритет у нового события.           |
|    |            | Если с момента совпадения до момента программного сброса   |
|    |            | CNT и ARR не изменили состояния, то флаг повторно не       |
|    | CNIT       | взводится                                                  |
| 0  | CNT        | Событие совпадения СNT с нулем:                            |
|    | ZERO       | 0 – нет события;                                           |
|    | EVENT      | 1 – есть событие.                                          |
|    |            | Сбрасывается записью 0, если запись одновременно с новым   |
|    |            | событием совпадения. Приоритет у нового события.           |
|    |            | Если с момента совпадения до момента программного сброса   |
|    |            | CNT не изменил состояния, то флаг повторно не взводится    |

### 28.7.13 *MDR\_TIMERx->IE*

### Таблица 28-26 – Регистр разрешения прерывания таймера ІЕ

| Номер  | 3117 | 1613  | 129          | 85           | 4            | 3            | 2            | 1            | 0            |
|--------|------|-------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Доступ | U    | R/W   | R/W          | R/W          | R/W          | R/W          | R/W          | R/W          | R/W          |
| Сброс  | 0    | 0     | 0            | 0            | 0            | 0            | 0            | 0            | 0            |
|        | -    | CCR   | CCR          | CCR          | BRK          | ETR          | ETR          | CNT          | CNT          |
|        |      | CAP1  | REF          | CAP          | <b>EVENT</b> | FE           | RE           | ARR          | ZERO         |
|        |      | EVENT | <b>EVENT</b> | <b>EVENT</b> | IE           | <b>EVENT</b> | <b>EVENT</b> | <b>EVENT</b> | <b>EVENT</b> |
|        |      | ΙE    | ΙE           | ΙE           |              | IE           | ΙE           | ΙE           | ΙE           |
|        |      | [3:0] | [3:0]        | [3:0]        |              |              |              |              |              |

# Таблица 28-27 – Описание бит регистра ІЕ

| № бита | Функциональное | Расшифровка функционального имени бита, краткое |
|--------|----------------|-------------------------------------------------|
|        | имя бита       | описание назначения и принимаемых значений      |
| 3117   | -              | Зарезервировано                                 |

| № бита | Функциональное | Расшифровка функционального имени бита, краткое            |
|--------|----------------|------------------------------------------------------------|
| 10 10  | имя бита       | описание назначения и принимаемых значений                 |
| 1613   | CCR<br>CAP1    | Флаг разрешения прерывания по событию настроенного фронта  |
|        | EVENT          | на входе СНхі канала таймера (фиксация значения основного  |
|        |                | счетчика таймера в регистре CCR1):                         |
|        | IE [3:0]       | 0 – нет прерывания;                                        |
|        |                | 1 – прерывание разрешено.                                  |
|        |                | Бит 0 – первый канал.                                      |
| 40 0   | COD            | Бит 3 – четвертый канал                                    |
| 129    | CCR            | Флаг разрешения прерывания по событию переднего фронта на  |
|        | REF            | выходе REF каналов таймера:                                |
|        | EVENT          | 0 – нет прерывания;                                        |
|        | IE[3:0]        | 1 – прерывание разрешено.                                  |
|        |                | Бит 0 – первый канал.                                      |
| 0 5    | 000            | Бит 3 – четвертый канал                                    |
| 85     | CCR            | Флаг разрешения прерывания по событию настроенного фронта  |
|        | CAP            | на входе СНхі канала таймера (фиксация значения основного  |
|        | EVENT          | счетчика таймера в регистре CCR):                          |
|        | IE [3:0]       | 0 – нет прерывания;                                        |
|        |                | 1 – прерывание разрешено.                                  |
|        |                | Бит 0 – первый канал.                                      |
|        |                | Бит 3 – четвертый канал                                    |
| 4      | BRK            | Флаг разрешения по состоянию входа BRK,                    |
|        | EVENT          | синхронизированному по PCLK:                               |
|        | IE             | 0 – нет прерывания;                                        |
|        |                | 1 – прерывание разрешено                                   |
| 3      | ETR            | Флаг разрешения прерывания по заднему фронту на входе ETR: |
|        | FE             | 0 – нет прерывания;                                        |
|        | EVENT          | 1 – прерывание разрешено                                   |
|        | IE             |                                                            |
| 2      | ETR            | Флаг разрешения прерывания по переднему фронту на входе    |
|        | RE             | ETR:                                                       |
|        | EVENT          | 0 – нет прерывания;                                        |
|        | IE             | 1 – прерывание разрешено                                   |
| 1      | CNT            | Флаг разрешения прерывания по событию совпадения CNT и     |
|        | ARR            | ARR:                                                       |
|        | EVENT          | 0 – нет прерывания;                                        |
|        | IE             | 1 – прерывание разрешено                                   |
| 0      | CNT            | Флаг разрешения прерывания по событию совпадения CNT и     |
|        | ZERO           | нуля:                                                      |
|        | EVENT          | 0 – нет прерывания;                                        |
|        | IE             | 1 – прерывание разрешено                                   |

### 28.7.14 MDR\_TIMERx->DMA\_RE

# Таблица 28-28 – Регистр DMA\_RE разрешения запросов DMA от прерываний таймера

| Номер  | 3117 | 1613  | 129          | 85    | 4            | 3            | 2            | 1            | 0            |
|--------|------|-------|--------------|-------|--------------|--------------|--------------|--------------|--------------|
| Доступ | U    | R/W   | R/W          | R/W   | R/W          | R/W          | R/W          | R/W          | R/W          |
| Сброс  | 0    | 0     | 0            | 0     | 0            | 0            | 0            | 0            | 0            |
|        | -    | CCR   | CCR          | CCR   |              | ETR          | ETR          | CNT          | CNT          |
|        |      | CAP1  | REF          | CAP   | BRK          | FE           | RE           | ARR          | ZERO         |
|        |      | EVENT | <b>EVENT</b> | EVENT | <b>EVENT</b> | <b>EVENT</b> | <b>EVENT</b> | <b>EVENT</b> | <b>EVENT</b> |
|        |      | RE    | RE           | RE    | RE           | RE           | RE           | RE           | RE           |
|        |      | [3:0] | [3:0]        | [3:0] |              |              |              |              |              |

### Таблица 28-29 - Описание бит регистра DMA\_RE

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                  |
|------|----------------|----------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                       |
| 3117 | -              | Зарезервировано                                                                  |
| 1613 | CCR            | Флаг разрешения запроса DMA по событию настроенного                              |
|      | CAP1           | фронта на входе СНхі канала таймера (фиксация значения                           |
|      | EVENT          | основного счетчика таймера в регистре CCR1):                                     |
|      | RE [3:0]       | 0 – нет запроса DMA;                                                             |
|      |                | 1 – запрос DMA разрешен.                                                         |
|      |                | Бит 0 – первый канал.                                                            |
| 129  | CCR            | Бит 3 – четвертый канал  Флаг разрешения запроса DMA по событию переднего фронта |
| 129  | REF            | на выходе REF каналов таймера:                                                   |
|      | EVENT          | на выходе КЕГ каналов таимера.<br>  0 – нет запроса DMA;                         |
|      | RE[3:0]        | 1 – запроса БМА,<br>1 – запрос DMA разрешен.                                     |
|      | IXL[3.0]       | Бит 0 – первый канал.                                                            |
|      |                | Бит 3 – четвертый канал                                                          |
| 85   | CCR            | Флаг разрешения запроса DMA по событию настроенного                              |
|      | CAP            | фронта на входе СНхі канала таймера (фиксация значения                           |
|      | EVENT          | основного счетчика таймера в регистре CCR):                                      |
|      | RE [3:0]       | 0 – нет запроса DMA;                                                             |
|      |                | 1 – запрос DMA разрешен.                                                         |
|      |                | Бит 0 – первый канал.                                                            |
|      |                | Бит 3 – четвертый канал                                                          |
| 4    | BRK            | Флаг разрешения по состоянию входа BRK,                                          |
|      | EVENT          | синхронизированному по PCLK:                                                     |
|      | RE             | 0 – нет запроса DMA;                                                             |
|      |                | 1 – запрос DMA разрешен                                                          |
| 3    | ETR            | Флаг разрешения запроса DMA по заднему фронту на входе                           |
|      | FE             | ETR:                                                                             |
|      | EVENT          | 0 – нет запроса DMA;                                                             |
| 2    | RE             | 1 – запрос DMA разрешен                                                          |
| 2    | ETR            | Флаг разрешения запроса DMA по переднему фронту на                               |
|      | RE<br>EVENT    | входе ETR:<br>0 – нет запроса DMA;                                               |
|      | RE             | 1 – запроса БМА,<br>  1 – запрос DMA разрешен                                    |
| 1    | CNT            | Флаг разрешения запроса DMA по событию совпадения CNT и                          |
| '    | ARR            | ARR:                                                                             |
|      | EVENT          | 0 – нет запроса DMA;                                                             |
|      | RE             | 1 – запрос DMA разрешен                                                          |
| 0    | CNT            | Флаг разрешения запроса DMA по событию совпадения CNT и                          |
|      | ZERO           | нуля:                                                                            |
|      | EVENT          | 0 – нет запроса DMA;                                                             |
|      | RE             | 1 – запрос DMA разрешен                                                          |

### 29 Контроллер MDR ADC

В микроконтроллере реализовано два 12-ти разрядных АЦП. С помощью АЦП можно оцифровать сигнал от 16-ти внешних аналоговых выводов порта D и от двух внутренних каналов, на которые выводятся датчик температуры и источник опорного напряжения. Скорость выборки составляет до 512 тысяч преобразований в секунду для каждого АЦП.

В качестве опорного напряжения преобразования могут выступать:

- питание АЦП с выводов U<sub>CCA</sub> и GND;
- внешние сигналы с выводов ADC0\_REF+ и ADC1\_REF-.

Контроллер АЦП позволяет:

- оцифровать один из 16-ти внешних каналов;
- оцифровать значение встроенного датчика температуры;
- оцифровать значение встроенного источника опорного напряжения;
- осуществить автоматический опрос заданных каналов;
- выработать прерывание при выходе оцифрованного значения за заданные пределы;
- запускать два АЦП синхронно для увеличения скорости выборки.

Для осуществления преобразования требуется не менее 28-ми тактов синхронизации C\_ADC. В качестве синхросигнала может выступать частота процессора PCLKd, либо частота ADC\_CLK. Выбор частоты осуществляется с помощью бита Cfg\_REG\_CLKS. Частота PCLKd формируется из частоты процессорного ядра делением на коэффициент Cfg\_REG\_DIVCLK[3:0]. Максимальная частота C\_ADC не может превышать 14 МГц.



Рисунок 29-1 - Структурная схема контроллера АЦП

Для включения АЦП необходимо установить бит Cfg\_REG\_ADON. Для снижения тока потребления вместо собственного источника опорного напряжения в АЦП может использоваться источник датчика температуры. Для этого необходимо включить блок датчика температуры и источник опорного напряжения, установив бит TS\_EN в 1. После включения можно использовать источник опорного напряжения для первого и второго АЦП вместо их собственных. Для этого необходимо установить биты ADCx\_OP в единицу. Для преобразования необходимо, чтобы выводы, используемые АЦП у порта D, были сконфигурированы как аналоговые и были отключены какие-либо внутренние подтяжки.

#### 29.1 Преобразование внешнего канала

В регистре ADCx\_CFG в битах Cfg\_REG\_CHS[4:0] необходимо задать соответствующий выводу номер канала. Преобразование может осуществляться при внутренней опоре бит Cfg\_M\_REF = 0 и внешней Cfg\_M\_REF = 1, в этом случае опора берется с выводов ADC0\_REF+ и ADC1\_REF-. Биты Cfg\_REG\_CHCH, Cfg\_REG\_RNGC, Cfg\_REG\_SAMPLE, TS\_BUF\_EN, SEL\_VREF, SEL\_TS и Cfg\_Sync\_Conver должны быть сброшены.

Для начала перобразования необходимо записать 1 в бит Cfg REG GO.

После завершения преобразования будет взведен бит Flg\_REG\_EOCIF в регистре ADCx\_STATUS, а в регистре ADCx\_RESULT будет результат преобразования.

После считывания результата бит Flg REG EOCIF сбросится.

Если после первого преобразования результат не был считан, и было выполнено второе преобразование, то в регистре результата ADCx\_RESULT будет значение от последнего преобразования, и помимо бита Flg\_REG\_EOCIF будет взведен бит Flg\_REG\_OVERWRITE. Флаг Flg\_REG\_OVERWRITE может быть сброшен только записью в регистр ADCx STATUS.

#### 29.2 Последовательное преобразование нескольких каналов

Для автоматического последовательного преобразования нескольких каналов или одного канала в регистре ADCx\_CHSEL необходимо установить единицы в битах, соответствующих выбранным для преобразования каналам. Выставление данных бит необходимо обеспечить до установки конфигурации АЦП, то есть до записи в регистр ADCx\_CFG. Преобразование может осуществляться при внутренней опоре бит Cfg\_M\_REF = 0 и внешней Cfg\_M\_REF = 1. В этом случая опора берется с выводов ADC0\_REF+ и ADC1\_REF-. Биты Cfg\_REG\_RNGC, TS\_BUF\_EN, SEL\_VREF, SEL\_TS и Cfg\_Sync\_Conver должны быть сброшены, а биты Cfg\_REG\_SAMPLE и Cfg\_REG\_CHCH должны быть установлены. С помощью бит Delay\_GO можно задать паузу между преобразованиями при переборе каналов. Эта определяется в тактах CPU\_CLK, независимо от того на какой частоте ADC\_CLK или CPU\_CLK идет само преобразование. Для начала преобразования необходимо записать 1 в бит Cfg\_REG\_GO.

После завершения преобразования будет взведен бит Flg\_REG\_EOCIF в регистре ADCx\_STATUS, а в регистре ADCx\_RESULT будет результат преобразования.

После считывания результата бит Flg REG EOCIF сбросится.

Если после первого преобразования результат не был считан, и было выполнено второе преобразование, то в регистре результата ADCx\_RESULT будет значение от последнего преобразования, и помимо бита Flg REG EOCIF будет

взведен бит Flg\_REG\_OVERWRITE. Флаг Flg\_REG\_OVERWRITE может быть сброшен только записью в регистр ADCx\_STATUS.

Для последовательного преобразования одного и того же канала можно в регистре ADCx\_CHSEL выбрать только один канал и установить бит Cfg\_REG\_CHCH в 1, либо установить номер канала в битах Cfg\_REG\_CHS[4:0] и сбросить бит Cfg\_REG\_CHCH в 0. В этом случае процесс последовательного преобразования будет выполняться только для данного канала. Последовательное преобразование значения датчика температуры и источника опорного напряжения могут выполняться только в режиме последовательного преобразования одного канала.

#### 29.3 Преобразование с контролем границ

При необходимости отслеживать нахождение оцифрованных значений в допустимых пределах можно задать нижнюю и верхнюю допустимые границы в регистрах ADCx\_L\_LEVEL и ADCx\_H\_LEVEL. При этом, если установлен бит Cfg\_REG\_RNGC, то в случае, если результат преобразования выходит за границы, выставляется флаг Flg\_REG\_AWOIFEN, а в регистре результата будет полученное значение.

#### 29.4 Внутренний источник опорного напряжения

С помощью первого АЦП можно осуществить преобразования внутреннего источника опорного напряжения (блок  $V_{\text{OP}}$ ). Для этого необходимо включить блок датчика температуры и источник опорного напряжения, установив бит TS\_EN в 1. После включения можно использовать источник опорного напряжения для первого и второго АЦП вместо их собственных, что позволяет снизить ток потребления. Для этого необходимо установить биты ADCx\_OP в единицу. Для выбора источника опорного напряжения в качестве источника для преобразования необходимо в битах Cfg\_REG\_CHS установить значение 30 канала, установить биты TS\_BUF\_EN и SEL\_VREF, после чего можно запустить процесс преобразования. Для запуска преобразования необходимо записать 1 в бит Cfg\_REG\_GO.

После завершения преобразования будет взведен бит Flg\_REG\_EOCIF в регистре ADC1\_STATUS, а в регистре ADC1\_RESULT будет результат преобразования.

После считывания результата бит Flg REG EOCIF сбросится.

Если после первого преобразования результат не был считан, и было выполнено второе преобразование, то в регистре результата ADC1\_RESULT будет значение от последнего преобразования, а помимо бита Flg\_REG\_EOCIF будет взведен бит Flg\_REG\_OVERWRITE. Флаг Flg\_REG\_OVERWRITE может быть сброшен только записью в регистр ADC1\_STATUS.

Для последовательного преобразования только источника опорного напряжения можно в регистре ADC1\_CHSEL выбрать только 30 канал и установить бит Cfg\_REG\_CHCH в 1, либо установить номер 30-го канала в битах Cfg\_REG\_CHS[4:0] и сбросить бит Cfg\_REG\_CHCH в 0. В этом случае процесс последовательного преобразования будет выполняться только для данного канала. При этом должны быть также установлены биты TS\_BUF\_EN и SEL\_VREF.

Источник опорного напряжения может быть выбран для более точного результата преобразования АЦП и не может быть использован для задания опорного напряжения преобразования.

#### 29.5 Датчик температуры

С помощью первого АЦП можно осуществить преобразования датчика опорного напряжения. Для этого необходимо включить блок датчика температуры и источник опорного напряжения, установив бит TS\_EN в 1. После включения можно использовать источник опорного напряжения для первого и второго АЦП вместо их собственных, что позволяет снизить ток потребления. Для этого необходимо установить биты ADCx\_OP в единицу. Для выбора датчика температуры в качестве источника для преобразования необходимо в битах Cfg\_REG\_CHS установить значение 31 канала, установить биты TS\_BUF\_EN и SEL\_TS, после чего можно запустить процесс преобразования. Для начала преобразования необходимо записать 1 в бит Cfg\_REG\_GO.

После завершения преобразования будет взведен бит Flg\_REG\_EOCIF в регистре ADC1\_STATUS, а в регистре ADC1\_RESULT будет результат преобразования.

После считывания результата бит Flg REG EOCIF сбросится.

Если после первого преобразования результат не был считан, и было выполнено второе преобразование, то в регистре результата ADC1\_RESULT будет значение от последнего преобразования, и помимо бита Flg\_REG\_EOCIF будет взведен бит Flg\_REG\_OVERWRITE. Флаг Flg\_REG\_OVERWRITE может быть сброшен только записью в регистр ADC1\_STATUS.

Для последовательного преобразования только датчика температуры можно в регистре ADC1\_CHSEL выбрать только 31 канал и установить бит Cfg\_REG\_CHCH в 1, либо установить номер 31-го канала в битах Cfg\_REG\_CHS[4:0] и сбросить бит Cfg\_REG\_CHCH в 0. В этом случае процесс последовательного преобразования будет выполняться только для данного канала. При этом должны быть также установлены биты TS\_BUF\_EN и SEL\_TS.

#### 29.6 Синхронный запуск двух АЦП

Для ускорения оцифровки одного канала можно использовать оба АЦП, запускаемые с задержкой одного относительно другого по времени. Время задержки запуска второго АЦП относительно первого задается битами Delay\_ADC. При этом задержка Delay\_ADC определяется в тактах PCLKd, независимо от того на какой частоте ADC\_CLK или PCLKd идет само преобразование. Для одновременного запуска процесса преобразования необходимо установить бит Cfg\_Sync\_Conver и запустить процесс преобразования установкой бита Cfg\_REG\_GO. Синхронный запуск двух АЦП может работать также и в режиме последовательного преобразования нескольких каналов.

#### 29.7 Время заряда внутренней емкости

Процесс преобразования состоит из двух этапов: сначала происходит заряд внутренней емкости до уровня внешнего сигнала, и затем происходит преобразование уровня заряда внутренней емкости в цифровой вид. Таким образом, для точного преобразования внешнего сигнала в цифровой вид, за время первого этапа внутренняя емкость должна зарядиться до уровня внешнего сигнала. Это время определяется соотношением номинальной внутренней емкости, входным сопротивлением тракта АЦП и выходным сопротивлением источника сигнала. выходное сопротивление источника Максимальное RAIN для обеспечения качественного преобразования определяется по формулам

$$R_{AIN} < \frac{T_{track}}{C_{ADC}*ln(2^{N})} - R_{ADC}, \qquad (1)$$

$$T_{\text{track}} = 4*T_{\text{C\_ADC}} + N_{\text{PCLKd}}*T_{\text{PCLKd}} = \frac{4}{f_{\text{C\_ADC}}} + \frac{(\text{DelayGo}+1)}{f_{\text{PCLKd}}}, \quad (2)$$

где  $C_{ADC}$  – внутренняя емкость АЦП (~15 – 20 пФ);

N – требуемая точность, в разрядах;

R<sub>ADC</sub> − входное сопротивление тракта АЦП (~500 Ом);

T<sub>track</sub> – время заряда внутренней емкости (определяется формулой (2)), с;

fc\_ADC - рабочая частота АЦП (определяется Cfg REG CLKS в регистре

ADC1\_CFG), c<sup>-1</sup>;

f<sub>PCLKd</sub> – определяется по формуле

$$f_{PCLKd} = \frac{f_{PCLK}}{2^{Cfg REG DIVCLK}}$$
 (3)

Если необходимо обеспечить преобразование с точностью 12 разрядов  $\pm$  1/4 LSB, то N = 14. Если необходимо обеспечить преобразование с точностью 10 разрядов  $\pm$  1 LSB, то N = 10. Время заряда  $T_{track}$  определяется битами DelayGo[2:0] и схемой самого АЦП и представлено в таблице ниже.

Таблица 29-1 – Время заряда внутренней емкости АЦП и время преобразования

| DelayGo[2:0] | Дополнительная<br>задержка перед<br>началом<br>преобразования | Общее время Т <sub>track</sub> заряда емкости АЦП перед началом преобразования | Общее время<br>преобразования АЦП |
|--------------|---------------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------|
| 000          | 1xPCLKd                                                       | 4xC_ADC+1xPCLKd                                                                | 28xC ADC+1xPCLKd                  |
| 001          | 2xPCLKd                                                       | 4xC_ADC+2xPCLKd                                                                | 28xC_ADC+2xPCLKd                  |
| 010          | 3xPCLKd                                                       | 4xC_ADC+3xPCLKd                                                                | 28xC_ADC+3xPCLKd                  |
| 011          | 4xPCLKd                                                       | 4xC_ADC+4xPCLKd                                                                | 28xC_ADC+4xPCLKd                  |
| 100          | 5xPCLKd                                                       | 4xC_ADC+5xPCLKd                                                                | 28xC_ADC+5xPCLKd                  |
| 101          | 6xPCLKd                                                       | 4xC_ADC+6xPCLKd                                                                | 28xC_ADC+6xPCLKd                  |
| 110          | 7xPCLKd                                                       | 4xC_ADC+7xPCLKd                                                                | 28xC_ADC+7xPCLKd                  |
| 111          | 8xPCLKd                                                       | 4xC_ADC+8xPCLKd                                                                | 28xC_ADC+8xPCLKd                  |

Помимо точности определяемой временем зарядки внутренней емкости АЦП, точность преобразования имеет ошибки, связанные с технологическими разбросами схемы и шумами, и определяемые параметрами E<sub>DLADC</sub>, E<sub>ILADC</sub> и E<sub>OFFADC</sub>.

Задание режимов работы АЦП в регистре ADCx\_CFG необходимо производить до задания бита Cfg\_REG\_GO, иначе новая конфигурация будет действовать со следующего преобразования.

### 29.8 Описание регистров блока контроллера АЦП

Таблица 29-2 – Описание регистров блока контроллера АЦП

| Базовый Адрес | Название          | Описание                                                       |  |
|---------------|-------------------|----------------------------------------------------------------|--|
| 0x4008_8000   | MDR_ADC           | Контроллер ADC                                                 |  |
| Смещение      |                   |                                                                |  |
| 0x00          | MDR_ADC->ADC1_CFG | Регистр управления ADC1                                        |  |
| 0x04          | MDR_ADC->ADC2_CFG | Регистр управления ADC2                                        |  |
| 0x08          |                   |                                                                |  |
| 0x0C          | ADC2_H_LEVEL      | Регистр<br>MDR_ADC->ADCx_H_LEVEL верхней границы<br>ADC2       |  |
| 0x10          | ADC1_L_LEVEL      | Perистр MDR_ADC->ADCx_L_LEVEL нижней границы ADC1              |  |
| 0x14          | ADC2_L_LEVEL      | Perистр MDR_ADC->ADCx_L_LEVEL нижней границы ADC2              |  |
| 0x18          | ADC1_RESULT       | Perистр MDR_ADC->ADCx_RESULT результата ADC1                   |  |
| 0x1C          | ADC2_RESULT       | Perистр MDR_ADC->ADCx_RESULT результата ADC2                   |  |
| 0x20          | ADC1_STATUS       | Perистр MDR_ADC->ADCx_STATUS статуса<br>ADC1                   |  |
| 0x24          | ADC2_STATUS       | Perистр MDR_ADC->ADCx_STATUS статуса<br>ADC2                   |  |
| 0x28          | ADC1_CHSEL        | Регистр<br>MDR_ADC->ADCx_CHSEL выбора каналов<br>перебора ADC1 |  |
| 0x2C          | ADC2_CHSEL        | Регистр<br>MDR_ADC->ADCx_CHSEL выбора каналов<br>перебора ADC2 |  |

### 29.8.1 MDR\_ADC->ADC1\_CFG

### Таблица 29-3 – Регистр ADC1\_CFG

| Номер  | 11           | 10                 | 9                  | 84                    | 3                        | 2                  | 1                | 0                  |
|--------|--------------|--------------------|--------------------|-----------------------|--------------------------|--------------------|------------------|--------------------|
| Доступ | R/W          | R/W                | R/W                | R/W                   | R/W                      | R/W                | R/W              | R/W                |
| Сброс  | 0            | 0                  | 0                  | 0                     | 0                        | 0                  | 0                | 0                  |
|        | Cfg<br>M_REF | Cfg<br>REG<br>RNGC | Cfg<br>REG<br>CHCH | Cfg<br>REG<br>CHS[4:0 | Cfg<br>REG<br>SAMPL<br>E | Cfg<br>REG<br>CLKS | Cfg<br>REG<br>GO | Cfg<br>REG<br>ADON |

| Номер  | 3128                  | 2725                 | 2421   | 20          | 19        | 18               | 17    | 16                        | 1512                              |
|--------|-----------------------|----------------------|--------|-------------|-----------|------------------|-------|---------------------------|-----------------------------------|
| Доступ | 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                         | 0                                 |
|        | Delay<br>ADC<br>[3:0] | Delay<br>Go<br>[2:0] | TR[3:0 | SEL<br>VREF | SEL<br>TS | TS_BU<br>F<br>EN | TS_EN | Cfg<br>Sync<br>Conve<br>r | Cfg<br>REG<br>DIVCL<br>K<br>[3:0] |

### Таблица 29-4 - Описание бит регистра ADC1\_CFG

| Nº   | Функциональное        | Расшифровка функционального имени бита, краткое                                                                                                                               |
|------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита              | описание назначения и принимаемых значений                                                                                                                                    |
| 3128 | Delay<br>ADC<br>[3:0] | Задержка между началом преобразования ADC1 и ADC2 при последовательном переборе, либо работе на один канал: 0000 – 1 такт PCLKd; 0001 – 2 такта PCLKd; 1111 – 16 тактов PCLKd |
| 2725 | Delay<br>Go<br>[2:0]  | Дополнительная задержка перед началом преобразования после выбора канала: 000 – 1 такт PCLKd; 001 – 2 такта PCLKd; 111 – 8 тактов PCLKd                                       |
| 2421 | TR[3:0]               | Подстройка опорного напряжения. Смотрите диаграмму зависимости источника опорного напряжения от подстройки (Рисунок 29–2)                                                     |
| 20   | SEL<br>VREF           | Выбор для оцифровки источника опорного напряжения на 1,23 В: 0 – не выбран; 1 – выбран. Должен использоваться совместно с выбором канала Cfg_REG_CHS = 30                     |
| 19   | SEL<br>TS             | Выбор для оцифровки датчика температуры: 0 – не выбран; 1 – выбран. Должен использоваться совместно с выбором канала Cfg_REG_CHS = 31                                         |
| 18   | TS<br>BUF<br>EN       | Включения выходного усилителя для датчика температуры и источника опорного напряжения:  0 – выключен;  1 – включен.  Используется при TS_EN = 1                               |

| 17   | TS           | Включения датчика температуры и источника опорного                                                                         |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------|
|      | EN           | напряжения:                                                                                                                |
|      |              | 0 – выключен;                                                                                                              |
|      |              | 1 — включен.                                                                                                               |
|      |              | При включении датчика температуры и источника опорного                                                                     |
|      |              | напряжения выходной сигнал стабилизируется в течении                                                                       |
| 40   | Ot -         | времени 1 мс                                                                                                               |
| 16   | Cfg<br>Sync  | Запускает работу двух АЦП одновременно, при этом биты конфигурации второго АЦП, такие как Cfg REG DIVCLK,                  |
|      | Conver       | Сfg_REG_ADON, Cfg_M_REF и Cfg_REG_CHS берутся из                                                                           |
|      | OONVCI       | регистра конфигурации первого:                                                                                             |
|      |              | 0 – независимые АЦП;                                                                                                       |
|      |              | 1 – синхронные АЦП                                                                                                         |
| 1512 | Cfg          | Выбор коэффициента деления частоты процессора:                                                                             |
|      | REĞ          | 0000 – PCLKd = PCLK;                                                                                                       |
|      | DIVCLK       | 0001 – PCLKd = PCLK /2;                                                                                                    |
|      | [3:0]        | 0010 – PCLKd = PCLK /4;                                                                                                    |
|      |              | 0011 – PCLKd = PCLK/8;                                                                                                     |
|      |              |                                                                                                                            |
|      |              | 1011 – PCLKd = PCLK/2048                                                                                                   |
| 4.4  | Ct a         | Остальные комбинации – PCLKd = PCLK                                                                                        |
| 11   | Cfg<br>M_REF | Выбор источника опорных напряжений:                                                                                        |
|      | IVI_KEF      | 0 – внутренне опорное напряжение (от U <sub>CCA</sub> и GND (вывод 60 корпуса 4229.132-3, выводы 65, 66 корпуса LQFP144)); |
|      |              | 1 – внешнее опорное напряжение (от ADC0_REF+ и                                                                             |
|      |              | ADC1_REF-)                                                                                                                 |
| 10   | Cfg          | Разрешение автоматического контроля уровней:                                                                               |
|      | REG          | 0 – не разрешена;                                                                                                          |
|      | RNGC         | 1 – разрешена выработка флага при выходе за диапазон в                                                                     |
|      |              | регистрах границы                                                                                                          |
| 9    | Cfg          | Выбор переключения каналов:                                                                                                |
|      | REG          | 0 – используется только выбранный канал;                                                                                   |
|      | CHCH         | 1 – переключение включено (перебираются каналы,                                                                            |
| 0 1  | 01           | выбранные в регистре выбора канала)                                                                                        |
| 84   | Cfg          | Выбор аналогового канала, по которому поступает сигнал для                                                                 |
|      | REG          | преобразования:                                                                                                            |
|      | CHS          | 00000 – 0 канал;<br>00001 – 1 канал;                                                                                       |
|      | [4:0]        | 00001 — 1 Kanaji,                                                                                                          |
|      |              | <br>  11111 – 31 канал                                                                                                     |
| 3    | Cfg          | Выбор способа запуска АЦП:                                                                                                 |
|      | REĞ          | 0 – одиночное;                                                                                                             |
|      | SAMPLE       | 1 – последовательное. Автоматический запуск после                                                                          |
|      |              | завершения предыдущего преобразования                                                                                      |
| 2    | Cfg          | Выбор источника синхросигнала C_ADC работы ADC:                                                                            |
|      | REG          | 0 – PCLKd (определяется по формуле (3));                                                                                   |
|      | CLKS         | 1 – ADC_CLK                                                                                                                |
| 1    | Cfg          | Начало преобразования.                                                                                                     |
|      | REG          | Запись "1" начинает процесс преобразования, сбрасывается                                                                   |
| 0    | GO           | автоматически                                                                                                              |
| 0    | Cfg<br>REG   | Включение АЦП:<br>0 – выключено;                                                                                           |
|      | ADON         | 0 – выключено,<br>1 – включено                                                                                             |
|      | ADOIN        |                                                                                                                            |



Рисунок 29-2 - Зависимость источника опорного напряжения от подстройки

29.8.2 MDR\_ADC->ADC2\_CFG

Таблица 29-5 – Регистр ADC2\_CFG

| Номер  | 11           | 10                 | 9                  | 84                    | 3                        | 2                  | 1                | 0                  |
|--------|--------------|--------------------|--------------------|-----------------------|--------------------------|--------------------|------------------|--------------------|
| Доступ | R/W          | R/W                | R/W                | R/W                   | R/W                      | R/W                | R/W              | R/W                |
| Сброс  | 0            | 0                  | 0                  | 0                     | 0                        | 0                  | 0                | 0                  |
|        | Cfg<br>M_REF | Cfg<br>REG<br>RNGC | Cfg<br>REG<br>CHCH | Cfg<br>REG<br>CHS[4:0 | Cfg<br>REG<br>SAMPL<br>E | Cfg<br>REG<br>CLKS | Cfg<br>REG<br>GO | Cfg<br>REG<br>ADON |

| Номер  | 3128 | 2725  | 2419 | 18   | 17   | 16 | 1512   |
|--------|------|-------|------|------|------|----|--------|
| Доступ | U    | R/W   | U    | R/W  | R/W  | U  | R/W    |
| Сброс  | 0    | 0     | 0    | 0    | 0    | 0  | 0      |
|        | -    | Delay | -    | ADC2 |      | -  | Cfg    |
|        |      | Go    |      | OP   | ADC1 |    | REG    |
|        |      | [2:0] |      |      | OP   |    | DIVCLK |
|        |      |       |      |      |      |    | [3:0]  |

Таблица 29-6 - Описание бит регистра ADC2\_CFG

| №<br>бита | Функционально<br>е имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-----------------------------|--------------------------------------------------------------------------------------------|
|           | е имя оита                  |                                                                                            |
| 3128      | -                           | Зарезервировано                                                                            |
| 2725      | Delay                       | Задержка перед началом следующего преобразования после                                     |
|           | Go                          | завершения предыдущего при последовательном переборе                                       |
|           | [2:0]                       | каналов:                                                                                   |
|           |                             | 000 – 1 такт PCLKd;                                                                        |
|           |                             | 001 – 2 такта PCLKd;                                                                       |
|           |                             |                                                                                            |
|           |                             | 111 – 8 тактов PCLKd                                                                       |
| 2419      | -                           | Зарезервировано                                                                            |
| 18        | ADC2                        | Выбор источника опорного напряжения 1.23 В:                                                |
|           | OP                          | 0 – внутренний (неточный);                                                                 |
|           |                             | 1 – от датчика температуры (точный)                                                        |

| 17   | ADC1       | Выбор источника опорного напряжения 1.23 В:                           |
|------|------------|-----------------------------------------------------------------------|
| ''   | OP         | 0 – внутренний (неточный);                                            |
|      | Oi         | 1 – от датчика температуры (точный)                                   |
| 16   | _          | Зарезервировано                                                       |
| 1512 | Cfg        | Выбор коэффициента деления частоты процессора:                        |
| 1012 | REG        | 0000 – PCLKd = PCLK;                                                  |
|      | DIVCLK     | 0001 – PCLKd = PCLK /2;                                               |
|      | [3:0]      | 0010 – PCLKd = PCLK /4;                                               |
|      | [0.0]      | 0011 – PCLKd = PCLK/8;                                                |
|      |            |                                                                       |
|      |            | 1011 - PCLKd = PCLK/2048;                                             |
|      |            | Остальные комбинации – PCLKd = PCLK                                   |
| 11   | Cfg        | Выбор источника опорных напряжений:                                   |
|      | M_REF      | 0 – внутренне опорное напряжение (от U <sub>CCA</sub> и GND (вывод 60 |
|      | _          | корпуса 4229.132-3, выводы 65, 66 корпуса LQFP144));                  |
|      |            | 1 – внешнее опорное напряжение (от ADC0_REF+ и ADC1_REF-)             |
| 10   | Cfg        | Разрешение автоматического контролирования уровней:                   |
|      | REG        | 1 – разрешено, выработка прерывания при выходе за диапазон в          |
|      | RNGC       | регистрах границы обработки;                                          |
|      |            | 0 – не разрешено                                                      |
| 9    | Cfg        | Выбор переключения каналов:                                           |
|      | REG        | 0 – используется только выбранный канал;                              |
|      | CHCH       | 1 – переключение включено (перебираются каналы, выбранные в           |
|      |            | регистре выбора канала)                                               |
| 84   | Cfg        | Выбор аналогового канала, по которому поступает сигнал для            |
|      | REG        | преобразования:                                                       |
|      | CHS        | 00000 – 0 канал;                                                      |
|      | [4:0]      | 00001 – 1 канал;                                                      |
|      |            | <br>44444 24 yeyes                                                    |
| 3    | Cta        | 11111 – 31 канал<br>Выбор способа запуска АЦП:                        |
| 3    | Cfg<br>REG | обысор спососа запуска Ацт.<br>0 – одиночное;                         |
|      | SAMPLE     | 1 – последовательное (автоматический запуск после завершения          |
|      | SAMELL     | предыдущего преобразования).                                          |
| 2    | Cfg        | Выбор источника синхросигнала C_ADC работы ADC:                       |
| _    | REG        | 0 – PCLKd (определяется по формуле (3));                              |
|      | CLKS       | 1 – ADC_CLK                                                           |
| 1    | Cfg        | Начало преобразования.                                                |
|      | REG        | Запись "1" начинает процесс преобразования. Сбрасывается              |
|      | GO         | автоматически                                                         |
| 0    | Cfg        | Включение АЦП:                                                        |
|      | REĞ        | 0 — выключено;                                                        |
|      | ADON       | 1 – включено                                                          |

### 29.8.3 MDR\_ADC->ADCx\_H\_LEVEL

# Таблица 29-7 – Регистр ADCx\_H\_LEVEL

| Номер  | 3112 | 110          |
|--------|------|--------------|
| Доступ | U    | R/W          |
| Сброс  | 0    | 0            |
|        | •    | REG H        |
|        |      | LEVEL [11:0] |

#### Таблица 29-8 - Описание бит регистра ADCx\_H\_LEVEL

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 311       | -                          | Зарезервировано                                                                            |
| 2         |                            |                                                                                            |
| 110       | REG H                      | Верхняя граница зоны допуска.                                                              |
|           | LEVEL [11:0]               |                                                                                            |

#### 29.8.4 MDR\_ADC->ADCx\_L\_LEVEL

#### Таблица 29-9 – Регистр ADCx\_L\_LEVEL

| Номер  | 3112 | 110          |
|--------|------|--------------|
| Доступ | U    | R/W          |
| Сброс  | 0    | 0            |
|        | -    | REG L        |
|        |      | LEVEL [11:0] |

#### Таблица 29-10 - Описание бит регистра ADCx\_L\_LEVEL

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3112      | -                       | Зарезервировано                                                                            |
| 110       | REG L                   | Нижняя граница зоны допуска                                                                |
|           | LEVEL [11:0]            |                                                                                            |

#### 29.8.5 MDR\_ADC->ADCx\_RESULT

#### Таблица 29-11 – Регистр ADCx\_RESULT

| Номер  | 3121 | 2016           | 1512 | 110    |
|--------|------|----------------|------|--------|
| Доступ | U    | RO             | U    | RO     |
| Сброс  | 0    | 0              | 0    | 0      |
|        | -    | CHANNEL [11:0] | -    | RESULT |
|        |      |                |      | [11:0] |

#### Таблица 29-12 - Описание бит регистра ADCx\_RESULT

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |  |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|--|--|
| 3121      | -                          | Зарезервировано                                                                            |  |  |
| 2016      | CHANNEL [11:0]             | Канал результата преобразования                                                            |  |  |
| 1512      | -                          | Зарезервировано                                                                            |  |  |
| 110       | RESULT [11:0]              | Значение результата преобразования                                                         |  |  |

#### 29.8.6 MDR\_ADC->ADCx\_STATUS

#### Таблица 29-13 – Регистр ADCx\_STATUS

| Номер  | 315 | 4     | 3       | 2     | 1       | 0   |
|--------|-----|-------|---------|-------|---------|-----|
| Доступ | U   | R/W   | R/W     | R/W   | R/W     | R/W |
| Сброс  | 0   | 0     | 0       | 0     | 0       | 0   |
|        | -   | ECOIF | AWOIFIE | Flg   | Flg     | Flg |
|        |     | IE    |         | REG   | REG     | REG |
|        |     |       |         | EOCIF | AWOIFEN |     |

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|  |  |  | OVERWRI |
|--|--|--|---------|
|  |  |  | TE      |

### Таблица 29-14 - Описание бит регистра ADCx\_STATUS

| № Функциональное |                         | Расшифровка функционального имени бита, краткое                                                                                                                                                                                                            |
|------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита             | имя бита                | описание назначения и принимаемых значений                                                                                                                                                                                                                 |
| 315              | -                       | Зарезервировано                                                                                                                                                                                                                                            |
| 4                | ECOIF_IE                | Флаг разрешения генерирования прерывания по событию Flg_REG_ECOIF: 0 – прерывания не генерируется;                                                                                                                                                         |
| 3                | AWOIF_IE                | <ul> <li>1 – прерывание генерируется</li> <li>Флаг разрешения генерирования прерывания по событию</li> <li>Flg_REG_AWOIFEN:</li> <li>0 – прерывания не генерируется;</li> <li>1 – прерывание генерируется</li> </ul>                                       |
| 2                | Flg<br>REG<br>EOCIF     | Флаг выставляется, когда закончено преобразования и данные еще не считаны. Очищается считыванием результата из регистра ADCx_RESULT:  1 – есть готовый результат преобразования;  0 – нет результата                                                       |
| 1                | Flg<br>REG<br>AWOIFEN   | Флаг выставляется, когда результат преобразования выше верней или ниже нижней границы автоматического контролирования уровней. Сбрасывается только при записи нуля в данный бит регистр флагов:  0 – результат в допустимой зоне;  1 – вне допустимой зоны |
| 0                | Flg<br>REG<br>OVERWRITE | Данные в регистре результата были перезаписаны, данный флаг сбрасывается только при записи нуля в данный бит регистр флагов:  0 – не было события перезаписи несчитанного результата;  1 – был результат преобразования, который не был считан             |

### 29.8.7 MDR\_ADC->ADCx\_CHSEL

### Таблица 29-15 – Регистр ADCx\_CHSEL

| Номер  | 31 0               |
|--------|--------------------|
| Доступ | R/W                |
| Сброс  | 0                  |
|        | SI_Ch_Ch_REF[31:0] |

### Таблица 29-16 - Описание бит регистра ADCx\_CHSEL

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                       |
|-----------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 310       | SI_Ch_Ch_REF[31:0]         | Выбор каналов автоматического перебора: 0 – в соответствующем бите канал не участвует в переборе; 1 – канал участвует в переборе |

### 30 Контроллер MDR\_DAC

В микроконтроллере реализовано два ЦАП. Для включения ЦАП необходимо установить бит Cfg\_ON\_DACx в 1, используемые выводы ЦАП порта Е были сконфигурированы, как аналоговые и были отключены какие-либо внутренние подтяжки. Оба ЦАП могут работать независимо или совместно. При независимой работе ЦАП (бит Cfg\_SYNC\_A=0) после записи данных в регистр данных DACx\_DATA на выходе DACx\_OUT формируется уровень напряжения, соответствующий записанному значению. При синхронной работе (бит Cfg\_SYNC\_A=1) данные обоих ЦАП могут быть обновлены одной записью в один из регистров DACx\_DATA. ЦАП может работать от внутренней опоры Cfg\_M\_REFx=0, тогда ЦАП формирует выходной сигнал в диапазоне от 0 до напряжения питания Ucca. В режиме работы с внешней опорой Cfg\_M\_REFx=1 ЦАП формирует выходное напряжение в диапазоне от 0 до значения DACx\_REF.



Рисунок 30-1 - Структурная схема контроллера ЦАП

### 30.1 Описание регистров блока контроллера ЦАП

Таблица 30-1 – Описание регистров блока контроллера ЦАП

| Базовый Адрес | Название           | Описание               |  |
|---------------|--------------------|------------------------|--|
| 0x4009_0000   | MDR_DAC            | Контроллер DAC         |  |
| Смещение      |                    |                        |  |
| 0x00          | MDR_DAC->CFG       | Регистр управления DAC |  |
| 0x04          |                    | Регистр данных DAC1    |  |
|               | MDR_DAC->DAC1_DATA | ·                      |  |
| 0x08          | MDR_DAC->DAC2_DATA | Регистр данных DAC2    |  |

#### 30.1.1 *MDR\_DAC->CFG*

### Таблица 30-2 - Регистр CFG

| Номер  | 315 | 4      | 3       | 2       | 1      | 0      |
|--------|-----|--------|---------|---------|--------|--------|
| Доступ | U   | R/W    | R/W     | R/W     | R/W    | R/W    |
| Сброс  | 0   | 0      | 0       | 0       | 0      | 0      |
|        | -   | Cfg    | Cfg     | Cfg     | Cfg    | Cfg    |
|        |     | SYNC_A | ON_DAC1 | ON_DAC0 | M_REF1 | M_REF0 |

### Таблица 30-3 - Описание бит регистра CFG

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 315       | -                          | Зарезервировано                                                                            |
| 4         | Cfg_SYNC_A                 | Синхронизация DAC1 и DAC2:                                                                 |
|           | -                          | 0 – асинхронные;                                                                           |
|           |                            | 1 – синхронные                                                                             |
| 3         | Cfg_ON_DAC1                | Включение DAC2:                                                                            |
|           |                            | 1 – включен;                                                                               |
|           |                            | 0 – выключен                                                                               |
| 2         | Cfg_ON_DAC0                | Включение DAC1:                                                                            |
|           |                            | 1 – включен;                                                                               |
|           |                            | 0 – выключен                                                                               |
| 1         | Cfg_M_REF1                 | Выбор источника опорного напряжения DAC2:                                                  |
|           |                            | 0 – в качестве опорного напряжения используется напряжение                                 |
|           |                            | питания с вывода U <sub>CCA</sub> ;                                                        |
|           |                            | 1 – в качестве опорного напряжения используется напряжение                                 |
|           |                            | на входе опорного напряжения DAC2_REF                                                      |
| 0         | Cfg_M_REF0                 | Выбор источника опорного напряжения DAC1:                                                  |
|           |                            | 0 – в качестве опорного напряжения используется напряжение                                 |
|           |                            | питания с вывода U <sub>CCA</sub> ;                                                        |
|           |                            | 1 – в качестве опорного напряжения используется напряжение                                 |
|           |                            | на входе опорного напряжения DAC1_REF                                                      |

### 30.1.2 MDR\_DAC->DAC1\_DATA

### Таблица 30-4 – Регистр DAC1\_DATA

| Номер  | 3128 | 2716            | 1512 | 110             |
|--------|------|-----------------|------|-----------------|
| Доступ | U    | WO              | U    | R/W             |
| Сброс  | 0    | 0               | 0    | 0               |
|        | -    | DAC1_DATA[11:0] | -    | DAC0_DATA[11:0] |

# Таблица 30-5 – Описание бит регистра DAC1\_DATA

| № Функциональное        |                    | Расшифровка функционального имени бита, краткое                                    |  |  |
|-------------------------|--------------------|------------------------------------------------------------------------------------|--|--|
| бита имя бита           |                    | описание назначения и принимаемых значений                                         |  |  |
| 3128                    | -                  | Зарезервировано                                                                    |  |  |
| 2716 DAC1<br>DATA[11:0] |                    | Данные DAC1 при Cfg_SYNC_A=1.<br>При чтении всегда равны нулю. Читать из DAC2_DATA |  |  |
| 1512                    | -                  | Зарезервировано                                                                    |  |  |
| 110                     | DAC0<br>DATA[11:0] | Данные DAC0                                                                        |  |  |

### 30.1.3 MDR\_DAC->DAC2\_DATA

### Таблица 30-6 - Регистр DAC2\_DATA

| Номер  | 3128 | 2716            | 1512 | 110             |
|--------|------|-----------------|------|-----------------|
| Доступ | U    | WO              | U    | R/W             |
| Сброс  | 0    | 0               | 0    | 0               |
|        | -    | DAC0_DATA[11:0] | •    | DAC1_DATA[11:0] |

### Таблица 30-7 – Описание бит регистра DAC21\_DATA

| № Функциональное бита имя бита |            | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |  |
|--------------------------------|------------|--------------------------------------------------------------------------------------------|--|--|
| 3128                           | -          | Зарезервировано                                                                            |  |  |
| 2716                           | DAC0       | Данные DAC0 при Cfg_SYNC_A=1.                                                              |  |  |
|                                | DATA[11:0] | При чтении всегда равны нулю. Читать из DAC1_DATA                                          |  |  |
| 1512                           | -          | Зарезервировано                                                                            |  |  |
| 110 DAC1                       |            | Данные DAC1                                                                                |  |  |
|                                | DATA[11:0] |                                                                                            |  |  |

Примечание – Если бит конфигурации Cfg\_SYNC\_A установлен, то данные для DAC1 и DAC2 задаются записью в один из регистров DACx\_DATA.

### 31 Контроллер схемы компаратора MDR\_COMP

В микроконтроллере реализована схема компаратора, обеспечивающая следующие режимы работы:

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

Для включения компаратора необходимо установить бит ON в 1, используемые выводы порта Е должны быть сконфигурированы как аналоговые и должны быть отключены какие-либо внутренние подтяжки. После появления флага Ready компаратор готов к работе.



Рисунок 31-1 - Структура блока компаратора



\*IVREF – выход внутреннего источника опорного напряжения 1,2 В.

Рисунок 31-2 - Структура мультиплексирования входов компаратора

#### 31.1 Сравнение внешних сигналов

Компаратор позволяет проводить сравнение двух сигналов, поступающих с трех выводов микросхемы. На вход «+» компаратора может быть подан сигнал IN1 (бит CREF=0), на вход «-» могут быть поданы сигналы IN1 (CCH=01), IN2 (CCH=00) и IN2 (CCH=10), при этом, если уровень на входе «+» будет больше уровня на входе «-», то выход Out установится в 1.

#### 31.2 Сравнение сигнала с внутренним источником опорного напряжения

Компаратор позволяет проводить сравнение сигнала, поступающего с вывода IN1 микросхемы, с внутренним источником опорного напряжения IVREF. Для этого на вход «+» компаратора должен быть подан сигнал IN1 (бит CREF=0), на вход «-» должен быть подан сигнал IVREF (CCH=11), при этом, если уровень на входе «+» будет больше уровня на входе «-», то выход Out установится в 1.

#### 31.3 Сравнение внешних сигналов с внутренней шкалой напряжений

Компаратор позволяет проводить сравнение внешних сигналов, поступающих с трех выводов микросхемы, со шкалой напряжений, формируемых внутри микросхемы. На вход «+» компаратора должен быть подан сигнал CVREF (бит CREF=1), на вход «-» могут быть поданы сигналы IN1 (CCH=01), IN2 (CCH=00) и IN2 (CCH=10), при этом, если уровень на входе «+» будет больше уровня на входе «-», то выход Out установится в 1.

#### 31.4 Формирование внутренней шкалы напряжений

Внутренняя шкала напряжений формируется на резистивном делителе (см Рисунок 31–3), который включается битом CVREN=1.



Рисунок 31-3 - Структура блока формирования CVREF

При этом в качестве опорного напряжения делителя может выступать питание микросхемы  $U_{CCA}$  (CVRSS = 0), либо напряжение на выводе COMP\_VREF+ (CVRSS = 1). Нижнее опорное напряжение компаратора задается на выводе COMP\_VREF-. Напряжение на выводе CVREF формируется на основании комбинации бит CVRR и

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

Таблица 31-1 – Формирование внутренней шкалы напряжений CVREF

| CVRR | CVR[3:0] | Отношение<br>резисторов | Напряжение CREF при U <sub>CC</sub> =,.3 B, | Входной импеданс VREF+, | Примечание |
|------|----------|-------------------------|---------------------------------------------|-------------------------|------------|
|      |          | резисторов              | При Осс-,.3 В,<br>В                         | Ом                      |            |
|      | 0000     | 8/32                    | 0.83                                        | 12K                     |            |
|      | 0001     | 9/32                    | 0.93                                        | 13K                     |            |
|      | 0010     | 10/32                   | 1.03                                        | 13.8K                   |            |
|      | 0011     | 11/32                   | 1.13                                        | 14.4K                   |            |
|      | 0100     | 12/32                   | 1.24                                        | 15K                     |            |
|      | 0101     | 13/32                   | 1.34                                        | 15.4K                   |            |
|      | 0110     | 14/32                   | 1.44                                        | 15.8K                   |            |
| 0    | 0111     | 15/32                   | 1.55                                        | 15.9K                   |            |
| U    | 1000     | 16/32                   | 1.65                                        | 16K                     |            |
|      | 1001     | 17/32                   | 1.75                                        | 15.9K                   |            |
|      | 1010     | 18/32                   | 1.86                                        | 15.8K                   |            |
|      | 1011     | 19/32                   | 1.96                                        | 15.4K                   |            |
|      | 1100     | 20/32                   | 2.06                                        | 15K                     |            |
|      | 1101     | 21/32                   | 2.17                                        | 14.4K                   |            |
|      | 1110     | 22/32                   | 2.27                                        | 13.8K                   |            |
|      | 1111     | 23/32                   | 2.37                                        | 12.9K                   |            |
|      | 0000     | 0/24                    | 0.00                                        | 0.5K                    |            |
|      | 0001     | 1/24                    | 0.14                                        | 1.9K                    |            |
|      | 0010     | 2/24                    | 0.28                                        | 3.7K                    |            |
|      | 0011     | 3/24                    | 0.41                                        | 5.3K                    |            |
|      | 0100     | 4/24                    | 0.55                                        | 6.7K                    |            |
|      | 0101     | 5/24                    | 0.69                                        | 7.9K                    |            |
|      | 0110     | 6/24                    | 0.83                                        | 9K                      |            |
| 1    | 0111     | 7/24                    | 0.96                                        | 9.9K                    |            |
| ı    | 1000     | 8/24                    | 1.10                                        | 10.7K                   |            |
|      | 1001     | 9/24                    | 1.24                                        | 11.3K                   |            |
|      | 1010     | 10/24                   | 1.38                                        | 11.7K                   |            |
|      | 1011     | 11/24                   | 1.51                                        | 11.9K                   |            |
|      | 1100     | 12/24                   | 1.65                                        | 12K                     |            |
|      | 1101     | 13/24                   | 1.79                                        | 11.9K                   |            |
|      | 1110     | 14/24                   | 1.93                                        | 11.7K                   |            |
|      | 1111     | 15/24                   | 2.06                                        | 11.3K                   |            |

Результат работы компаратора сигнал Out может быть проинвертирован с помощью бита INV и выдан на вывод микросхемы OUT\_COMP. Также результат сравнения доступен внутри микроконтроллера. Комбинационный сигнал с компаратора отображается в бите Rslt\_As (при чтении может быть считан как 1, но при этом не выработать прерывания). Зафиксированный в триггере по тактовой частоте HCLK сигнал сравнения отображается в бите Rslt\_Sy. Флаг Rst\_lch фиксирует событие появления положительного сигнала сравнения и устанавливается в 1 до тех пор, пока не будет считан регистр COMP RESULT LATCH.

### 31.5 Описание регистров блока контроллера компаратора

### Таблица 31-2 – Описание регистров блока контроллера компаратора

| Базовый Адрес | Название               | Описание                         |
|---------------|------------------------|----------------------------------|
| 0x4009_8000   | MDR_COMP               | Контроллер компаратора           |
| Смещение      |                        |                                  |
| 0x00          |                        | Регистр управления компаратора   |
|               | MDR_COMP->CFG          |                                  |
| 0x04          |                        | Регистр результата компаратора   |
|               |                        |                                  |
|               | MDR_COMP->RESULT       |                                  |
| 0x08          | MDR_COMP->RESULT_LATCH | Регистр результата компаратора - |
|               |                        | защелка                          |

#### 31.5.1 MDR\_COMP->CFG

#### Таблица 31-3 – Регистр CFG

| Номер  | 31 | 13  | 12   | 11  | 10    | 8   | 74    | 3   | 2   | 1   | 0   |
|--------|----|-----|------|-----|-------|-----|-------|-----|-----|-----|-----|
|        | 14 |     |      |     | 9     |     |       |     |     |     |     |
| Доступ | U  | R/W | RO   | R/W | R/W   | R/W | R/W   | R/W | R/W | R/W | R/W |
| Сброс  | 0  | 0   | 0    | 0   | 0     | 0   | 0     | 0   | 0   | 0   | 0   |
|        | -  | CMP | Read | INV | CCH   | CRE | CVR   | CVR | CVR | CVR | ON  |
|        |    | IE  | у    |     | [1:0] | F   | [3:0] | EN  | SS  | R   |     |

### Таблица 31-4 – Описание бит регистра CFG

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                                                                                                                                                             |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                                                                                                                                                                  |
| 3114 | -              | Зарезервировано                                                                                                                                                                                                                                                                                             |
| 13   | CMP<br>IE      | Флаг разрешения генерации прерывания по событию Rst_lch: 0 – запрещено прерывание;                                                                                                                                                                                                                          |
|      |                | 1 – разрешено прерывание                                                                                                                                                                                                                                                                                    |
| 12   | Ready          | Сигнал готовности аналогового компаратора при включении: 0 – компаратор не включен или не готов к работе; 1 – компаратор готов к работе                                                                                                                                                                     |
| 11   | INV            | Инверсия выхода компаратора:<br>0 – прямой;<br>1 – инверсный                                                                                                                                                                                                                                                |
| 109  | CCH<br>[1:0]   | Биты выбора сигнал управления мультиплексора канала: 00 – на «-» компаратора сигнал подается с IN2; 01 – на «-» компаратора сигнал подается с IN1; 10 – на «-» компаратора сигнал подается с IN3; 11 – на «-» компаратора сигнал подается с выхода внутреннего источника опорного напряжения 1.2 В (IVREF). |
| 8    | CREF           | Бит выбора сигнал управления мультиплексора канала: 0 – на «+» компаратора сигнал подается с IN1; 1 – на «+» компаратора сигнал подается с CREF                                                                                                                                                             |
| 74   | CVR<br>[3:0]   | Биты выбора сигнал управления мультиплексора выбора CVREF. Смотрите Таблица 31-1 — Формирование внутренней шкалы напряжений CVREF                                                                                                                                                                           |
| 3    | CVREN          | Бит разрешения работы источника CVREF:<br>0 – не разрешен;<br>1 – разрешен                                                                                                                                                                                                                                  |

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| 2 | CVRSS | Бит выбора опоры CVREF:                                      |
|---|-------|--------------------------------------------------------------|
|   |       | 0 – источник CVREF работает в границах U <sub>CCA</sub> GND; |
|   |       | 1 – источник CVREF работает в границах Vref+ Vref-           |
| 1 | CVRR  | Бит выбора диапазона CVREF:                                  |
|   |       | 0 – источник CVREF работает в верхнем диапазоне;             |
|   |       | 1 – источник CVREF работает в нижнем диапазоне               |
| 0 | ON    | Включение компаратора:                                       |
|   |       | 0 – выключен;                                                |
|   |       | 1 – включен                                                  |

#### 31.5.2 MDR\_COMP->RESULT

#### Таблица 31-5 – Регистр RESULT

| Номер  | 313 | 2       | 1       | 0       |
|--------|-----|---------|---------|---------|
| Доступ | U   | R/W     | R/W     | R/W     |
| Сброс  | 0   | 0       | 0       | 0       |
|        | -   | Rst_lch | Rslt_As | Rslt_Sy |

### Таблица 31-6 – Описание бит регистра RESULT

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                         |
|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 313              | -                       | Зарезервировано                                                                                                                                                    |
| 2                | Rst_lch                 | Значение компарирования хранится до момента считывания из регистра COMP_RESULT_LATCH, после чего сбрасывается. Взводится по переднему фронту сигнала с компаратора |
| 1                | Rslt_As                 | Значение компарирования непосредственно из компаратора                                                                                                             |
| 0                | Rslt_Sy                 | Значение результата компарирования, синхранизированное с частотой HCLK                                                                                             |

### 31.5.3 MDR\_COMP->RESULT\_LATCH

### Таблица 31-7 - Регистр RESULT\_LATCH

| Номер  | 311 | 0       |
|--------|-----|---------|
| Доступ | U   | R/W     |
| Сброс  | 0   | 0       |
|        | •   | Rst_lch |

### Таблица 31-8 - Описание бит регистра RESULT\_LATCH

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                    |  |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                         |  |
| 311  | -              | Зарезервировано                                                                                                                                                    |  |
| 0    | Rst_lch        | Значение компарирования хранится до момента считывания из регистра COMP_RESULT_LATCH, после чего сбрасывается. Взводится по переднему фронту сигнала с компаратора |  |

### 32 Контроллер интерфейса MDR\_I2C

I2C является двухпроводным, двунаправленным последовательным каналом связи с простым и эффективным методом обмена данными между устройствами. Интерфейс применяется, когда надо организовать обмен на коротком расстоянии между несколькими устройствами. Стандарт интерфейса I2C является многомастерным с обнаружением коллизий и арбитражем, исключающим потерю данных при обмене, когда два или более мастера пытаются осуществить передачу одновременно.

Интерфейс работает на 3 скоростях:

нормальная: 100 Kbps;быстрая: 400 Kbps;очень быстрая: 3.5 Mbps.

Приблизительная скорость обмена данными блока I2C рассчитывается по формуле:

$$F_{SCI} = \frac{HCLK}{5*(DIV + 1)}$$

Более точное значение скорости обмена можно установить опытным путем. Контроллер интерфейса I2C работает только в режиме Master.

#### 32.1 Конфигурация системы

I2C системы используют последовательную линию данных SDA и линию тактового сигнала SCL. Все устройства, подсоединенные к этим двум линиям, должны работать в режиме открытого стока, обеспечивая тем самым создание на линии «проводного И» за счет внешних резисторов подтяжки обоих линий к питанию.

Передача данных между мастером и ведомым осуществляется по линии SDA и синхронизируется по линии SCL. После завершения передачи информации осуществляется передача в обратную сторону одного бита подтверждения. Каждый принимаемый бит фиксируется принимающей стороной при высоком уровне SCL и может изменяться передатчиком при низком уровне. Изменение линии SDA при высоком уровне SCL является командным состоянием (см. «Сигнал START» и «Сигнал STOP»).

#### 32.2 Протокол І2С

Нормальная передача по интерфейсу I2С содержит 4 фазы:

- сигнал START;
- передача адреса;
- передача данных;
- сигнал STOP.



Рисунок 32-1 - Передача по I2C

#### 32.3 Сигнал START

Когда шина находится в свободном состоянии, т.е. не одно из устройств не осуществляет передачи (на линиях SCL и SDA высокий уровень), мастер может инициализировать процесс передачи через создание сигнала START на линии. Сигнал START или S бит задается, когда уровень на линии SDA переходит из высокого в низкий при высоком уровне на линии SCL. Появление сигнала START не означает начала передачи данных.

Повторный сигнал START является обычным сигналом START, но без предварительно сгенерированного до этого сигнала STOP. Мастер может использовать метод для начала соединения с другим ведомым или с тем же ведомым, но с изменением режима работы (например, чтение после записи, или, наоборот) без перевода шины в свободное состояние.

Контроллер интерфейса генерирует сигнал START при записи единицы в бит START регистра I2C\_CMD при установленных битах RD или WR. В зависимости от состояния линии SCL генерируется либо сигнал START, либо повторный сигнал START.

#### 32.4 Передача адреса

Первым байтом данных, передаваемым мастером сразу после сигнала START, является адрес ведомого. Это 7-ми битный адрес и следующий за ним бит RW. Бит RW определяет дальнейшее направление передачи данных. В системе не может быть несколько ведомых устройств с одним адресом. Ведомое устройство, у которого совпадает адрес с адресом в сообщении, подтверждает прием, выставляя АСК и опуская линию SDA в низкий уровень на 9-й SCL тактовый импульс. Контроллер также поддерживает 10-битный адрес путем генерации двух циклов передачи адреса.

Процесс выдачи адреса выполняется как цикл записи. Необходимо записать адрес ведомого в регистр I2C\_TXD и установить бит WR в регистре I2C\_CMD. Контроллер осуществит передачу адреса в линию.

#### 32.5 Передача данных

После успешного подтверждения приема адреса одним ведомым устройством может быть начата передача данных в направлении, задаваемым битом RW в посылке мастера. Каждый передаваемый бит подтверждается ACK на 9-й SCL тактовый импульс. Если ведомое устройство выдало NACK (нет подтверждения), то мастер может сгенерировать либо сигнал STOP для прекращения передачи, либо повторный сигнал START для начала нового цикла передачи.

Если мастер является принимающим устройством и выдает NACK, то ведомое устройство отпускает линию SDA и мастер может сгенерировать сигнал STOP или повторный сигнал START.

Для записи данных в ведомое устройство запишите данные в регистр I2C\_TXD и установите бит WR. Для чтения данных из устройства установите бит RD. На время выполнения передачи контроллер интерфейса выставляет флаг TR\_PROG в регистре I2C\_STA. Когда передача завершена, этот флаг снимается и устанавливается флаг INT. Если при этом установлен бит разрешения INT\_EN, то генерируется прерывание контроллеру прерываний. Регистр I2C\_RXD содержит корректные принятые данные после установки флага INT. Пользователь может начать новый цикл чтения или записи только тогда, когда флаг TR\_PROG сброшен.

#### 32.6 Сигнал STOP

Мастер может завершить соединение путем создания сигнала STOP. Сигнал STOP или P бит определяется переходом линии SDA из низкого состояния в высокое, когда SCL находится в высоком состоянии.

### 32.7 Описание регистров контроллера I2C

Таблица 32-1 - Описание регистров контроллера I2C

| Базовый Адрес | Название     | Описание                           |
|---------------|--------------|------------------------------------|
| 0x4005_0000   | MDR_I2C      | Контроллер I2С                     |
| Смещение      |              |                                    |
| 0x00          |              | Младшая часть предделителя частоты |
|               |              |                                    |
|               | MDR_I2C->PRL |                                    |
| 0x04          | MDR_I2C->PRH | Старшая часть предделителя частоты |
| 0x08          | MDR_I2C->CTR | Управление контроллером I2C        |
| 0x0C          |              | Принятые данные по I2С             |
|               | MDR_I2C->RXD |                                    |
| 0x10          | MDR_I2C->STA | Статус I2С                         |
| 0x14          | MDR_I2C->TXD | Передаваемые данные по I2C         |
| 0x18          | MDR_I2C->CMD | Управление I2C                     |

#### 32.7.1 *MDR\_I2C->PRL*

#### Таблица 32-2 - Регистр PRL

| Номер  | 318 | 7 0     |
|--------|-----|---------|
| Доступ | U   | R/W     |
| Сброс  | 0   | 0       |
|        | -   | PR[7:0] |

#### Таблица 32-3 - Описание бит регистра PRL

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 318       | -                       | Зарезервировано                                                                            |
| 70        | PR[7:0]                 | Младшая часть предделителя                                                                 |

#### 32.7.2 *MDR\_I2C->PRH*

#### Таблица 32-4 - Регистр PRH

| Номер  | 318 | 7 0      |
|--------|-----|----------|
| Доступ | U   | R/W      |
| Сброс  | 0   | 0        |
|        | •   | PR[15:8] |

### Таблица 32-5 - Описание бит регистра PRH

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, кратко описание назначения и принимаемых значений |  |
|------------------|-------------------------|-------------------------------------------------------------------------------------------|--|
| 318              | -                       | Зарезервировано                                                                           |  |
| 70               | PR[15:8]                | Старшая часть предделителя                                                                |  |

#### 32.7.3 *MDR\_I2C->CTR*

### Таблица 32-6 – Регистр CTR

| Номер  | 318 | 7      | 6      | 5     | 40 |
|--------|-----|--------|--------|-------|----|
| Доступ | U   | R/W    | R/W    | R/W   | U  |
| Сброс  | 0   | 0      | 0      | 0     | 0  |
|        | -   | EN_I2C | EN_INT | S_I2C | -  |

#### Таблица 32-7 – Описание бит регистра CTR

| <b>№</b><br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------------------|----------------------------|--------------------------------------------------------------------------------------------|
| 318              | -                          | Зарезервировано                                                                            |
| 7                | EN_I2C                     | Разрешение работы контроллера I2C:                                                         |
|                  |                            | 0 – выключен;                                                                              |
|                  |                            | 1 – включен                                                                                |
| 6                | EN_INT                     | Разрешение прерывания от I2C:                                                              |
|                  |                            | 0 – запрещено;                                                                             |
|                  |                            | 1 – разрешено                                                                              |
| 5                | S_I2C                      | Скорость работы I2C:                                                                       |
|                  |                            | 0 – до 400 кГц;                                                                            |
|                  |                            | 1 – до 1 МГц                                                                               |
| 40               | -                          | Зарезервировано                                                                            |

#### 32.7.4 *MDR\_I2C->RXD*

### Таблица 32-8 – Регистр RXD

| Номер  | 318 | 7 0      |
|--------|-----|----------|
| Доступ | U   | RO       |
| Сброс  | 0   | 0        |
|        | -   | RXD[7:0] |

### Таблица 32-9 - Описание бит регистра RXD

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|----------------------------|--------------------------------------------------------------------------------------------|
| 318       | -                          | Зарезервировано                                                                            |
| 70        | RXD[7:0]                   | Последний полученный по I2C байт                                                           |

#### 32.7.5 *MDR\_I2C->STA*

#### Таблица 32-10 - Регистр STA

| Номер  | 318 | 7   | 6    | 5    | 42 | 1    | 0   |
|--------|-----|-----|------|------|----|------|-----|
| Доступ | U   | RO  | RO   | RO   | J  | RO   | RO  |
| Сброс  | 0   | 0   | 0    | 0    | 0  | 0    | 0   |
|        | -   | Rx  | BUSY | LOST | -  | TR   | INT |
|        |     | ACK |      | ARB  |    | PROG |     |

Таблица 32-11 - Описание бит регистра STA

| Nº   | Функционально | Расшифровка функционального имени бита, краткое             |
|------|---------------|-------------------------------------------------------------|
| бита | е имя бита    | описание назначения и принимаемых значений                  |
| 318  | -             | Зарезервировано                                             |
| 7    | Rx            | Полученный от ведомого АСК:                                 |
|      | ACK           | 0 – АСК получен;                                            |
|      |               | 1 – получен NACK                                            |
| 6    | BUSY          | Состояние шины I2C:                                         |
|      |               | 0 – после получения Stop bit;                               |
|      |               | 1 – после получения состояния Start bit                     |
| 5    | LOST          | Потеря арбитража:                                           |
|      | ARB           | 0 – нет потери арбитража;                                   |
|      |               | 1 – потерян арбитраж.                                       |
|      |               | Этот быт выставляется если:                                 |
|      |               | – получен Stop bit, но он не был инициализирован этим       |
|      |               | контроллером;                                               |
|      |               | – Если контроллер пытается выставить SDA в высокий уровень, |
|      |               | но SDA остается в низком                                    |
| 42   | -             | Зарезервировано                                             |
| 1    | TR            | Процесс передачи:                                           |
|      | PROG          | 0 – передача завершена;                                     |
|      |               | 1 – передаются данные                                       |
| 0    | INT           | Флаг прерывания, выставляется всегда. Прерывание для        |
|      |               | процессора выдается, если есть флаг EN_INT:                 |
|      |               | 0 – нет прерывания;                                         |
|      |               | 1 – есть прерывание.                                        |
|      |               | Флаг выставляется если:                                     |
|      |               | – передача байта завершена;                                 |
|      |               | – был потерян арбитраж                                      |

### 32.7.6 *MDR\_I2C->TXD*

### Таблица 32-12 – Регистр TXD

| Номер  | 318 | 7 0      |
|--------|-----|----------|
| Доступ | U   | R/W      |
| Сброс  | 0   | 0        |
|        | -   | TXD[7:0] |

### Таблица 32-13 – Описание бит регистра TXD

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 318       | -                       | Зарезервировано                                                                            |
| 70        | TXD[7:0]                | Байт для отправки по I2C. При передаче адреса нулевой бит определяет режим                 |
|           |                         | передачи: 0 – запись в ведомое устройство; 1 – чтение из ведомого устройства               |

### 32.7.7 *MDR\_I2C->CMD*

### Таблица 32-14 – Регистр CMD

| Номер  | 318 | 7    | 6    | 5   | 4   | 3   | 21 | 0   |
|--------|-----|------|------|-----|-----|-----|----|-----|
| Доступ | U   | R/W  | R/W  | R/W | R/W | R/W | U  | R/W |
| Сброс  | 0   | 0    | 0    | 0   | 0   | 0   | 0  | 0   |
|        | -   | STAR | STOP | RD  | WR  | ACK | -  | CLR |
|        |     | T    |      |     |     |     |    | INT |

# Таблица 32-15 – Описание бит регистра CMD

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое            |
|------|----------------|------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                 |
| 318  | -              | Зарезервировано                                            |
| 7    | START          | Отправить START bit.                                       |
|      |                | Инициализируется записью 1.                                |
|      |                | После завершения отправки автоматически не сбрасывается,   |
|      |                | очищается записью нуля                                     |
| 6    | STOP           | Отправить STOP bit.                                        |
|      |                | Инициализируется записью 1.                                |
|      |                | После завершения отправки автоматически не сбрасывается, а |
|      |                | очищается записью нуля                                     |
| 5    | RD             | Чтение из ведомого:                                        |
|      |                | 0 – нет действия;                                          |
|      |                | 1 – начать чтение                                          |
| 4    | WR             | Запись в ведомого;                                         |
|      |                | 0 – нет действия;                                          |
|      |                | 1 – начать запись                                          |
| 3    | ACK            | Отправить АСК при чтении:                                  |
|      |                | 0 – отправить АСК;                                         |
|      |                | 1 – отправить NACK                                         |
| 21   | -              | Зарезервировано                                            |
| 0    | CLR            | Очистить прерывание INT.                                   |
|      | INT            | Запись 1 очищает прерывание                                |

### 33 Контроллер MDR\_SSP

Модуль порта синхронной последовательной связи (SSP – Synchronous Serial Port) выполняет функции интерфейса последовательной синхронной связи в режиме ведущего и ведомого устройства и обеспечивает обмен данными с подключенным ведомым или ведущим периферийным устройством в соответствии с одним из протоколов:

- интерфейс SPI фирмы Motorola;
- интерфейс SSI фирмы Texas Instruments;
- интерфейс Microwire фирмы National Semiconductor.

Как в ведущем, так и в ведомом режиме работы модуль SSP обеспечивает:

- преобразование данных, размещенных во внутреннем буфере FIFO передатчика (восемь 16-разрядных ячеек данных) из параллельного в последовательный формат;
- преобразование данных из последовательного в параллельный формат и их запись в аналогичный буфер FIFO приемника (восемь 16-разрядный ячеек данных).

Модуль формирует сигналы прерываний по следующим событиям:

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

Основные сведения о модуле представлены в следующих разделах:

- характеристики интерфейса SPI;
- характеристики интерфейса Microwire;
- характеристики интерфейса SSI.

#### 33.1 Основные характеристики модуля SSP

- функционирование как в ведущем, так и в ведомом режиме;
- программное управление скоростью обмена;
- состоит из независимых буферов приема и передачи (8 ячеек по 16 бит) с организацией доступа типа FIFO (First In First Out – первый вошел, первый вышел);
- программный выбор одного из интерфейсов обмена: SPI, Microwire, SSI;
- программируемая длительность информационного кадра от 4 до 16 бит;
- независимое маскирование прерываний от буфера FIFO передатчика, буфера FIFO приемника, а также по переполнению буфера приемника;
- доступна возможность тестирования по шлейфу, соединяющему вход с выходом;
- поддержка прямого доступа к памяти (DMA).

Структурная схема модуля представлена далее – см. Рисунок 33–1.

#### 33.2 Программируемые параметры

Следующие ключевые параметры могут быть заданы программно:

- режим функционирования периферийного устройства ведущее или ведомое;
- разрешение или запрещение функционирования;
- формат информационного кадра;
- скорость передачи данных;
- фаза и полярность тактового сигнала;
- размер блока данных от 4 до 16 бит;
- маскирование прерываний.



Рисунок 33-1 - Структурная схема модуля SSP

### 33.3 Характеристики интерфейса SPI

Последовательный синхронный интерфейс SPI фирмы Motorola обеспечивает:

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

#### 33.4 Характеристики интерфейса Microwire

Интерфейс Microwire фирмы National Semiconductor обеспечивает:

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

#### 33.5 Характеристики интерфейса SSI

Интерфейс SSI фирмы Texas Instruments обеспечивает:

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

#### 33.6 Общий обзор модуля SSP

Модуль SSP представляет собой интерфейс синхронного последовательного обмена данными, способный функционировать в качестве ведущего или ведомого устройства и поддерживающий протоколы передачи данных SPI фирмы Motorola, Microwire фирмы National Semiconductor, а также SSI фирмы Texas Instruments.

Модуль выполняет следующие функции:

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

Последовательные данные передаются по линии SSP\_TXD и принимаются с линии SSP\_RXD.

Модуль SSP содержит программируемые делители частоты, формирующие тактовый сигнал обмена данными SSP\_CLK из сигнала, поступающего на линию SSPCLK. Скорость передачи данных может достигать более 2 МГц, в зависимости от частоты SSPCLK и характеристик подключенного периферийного устройства.

Режим обмена данными, формат информационного кадра и количество бит данных задаются программно с помощью регистров управления CR0 и CR1.

Модуль формирует четыре независимо маскируемых прерывания:

SSPTXINTR – запрос на обслуживание буфера передатчика:

SSPRXINTR – запрос на обслуживание буфера приемника;

SSPRORINTR – переполнение приемного буфера FIFO;

SSPRTINTR — таймаут ожидания чтения данных из приемного FIFO.

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

Модуль также формирует сигналы запроса на прямой доступ к памяти (DMA) для совместной работы с контроллером DMA.

В зависимости от режима работы модуля сигнал SSPFSSOUT используется либо для кадровой синхронизации (интерфейс SSI, активное состояние – высокий уровень), либо для выбора ведомого режима (интерфейсы SPI и Microwire, активное состояние – низкий уровень).

## 33.6.1 Блок формирования тактового сигнала

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

Путем записи значения в регистр SSPCPSR можно задать коэффициент предварительного деления частоты в диапазоне от 2 до 254 с шагом 2. Так как младший значащий разряд коэффициента деления не используется, то исключается возможность деления частоты на нечетный коэффициент деления. Это, в свою очередь, гарантирует формирование тактового сигнала симметричной формы (с одинаковой длительностью полупериодов высокого и низкого уровней).

Сформированный описанным образом сигнал далее поступает на второй делитель частоты, с выхода которого и снимается тактовый сигнал обмена данными SSP\_CLK.

Коэффициент деления второго делителя задается программно в диапазоне от 1 до 256, путем записи соответствующего значения в регистр управления SSPCR0.

### 33.6.2 Буфер FIFO передатчика

Буфер передатчика имеет ширину 16 бит, глубину 8 слов, схему организации доступа типа FIFO — «первый вошел, первый вышел». Данные от центрального процессора сохраняются в буфере до тех пор, пока не будут считаны блоком передачи данных.

### 33.6.3 Буфер FIFO приемника

Буфер приемника имеет ширину 16 бит, глубину 8 слов, схему организации доступа типа FIFO — «первый вошел, первый вышел». Принятые от периферийного устройства данные сохраняются в этом буфере блоком приема данных в до тех пор, пока не будут считаны центральным процессором.

### 33.6.4 Блок приема и передачи данных

В режиме ведущего устройства модуль формирует тактовый сигнал обмена данными SSP\_CLK для подключенных ведомых устройств. Как было описано ранее, данный сигнал формируется путем деления частоты сигнала SSPCLK.

Блок передатчика последовательно считывает данные из буфера FIFO передатчика и производит их преобразование из параллельной формы в последовательную. Далее поток последовательных данных и элементов кадровой синхронизации, тактированный сигналом SSP\_CLK, передаётся по линии SSP\_TXD к подключенным ведомым устройствам.

Блок приемника выполняет преобразование данных, поступающих синхронно с линии SSP\_RXD, из последовательной в параллельную форму, после чего загружает их в буфер FIFO приемника, откуда они могут быть считаны процессором.

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

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

Аналогично, блок приемника выполняет преобразование данных, поступающих с линии SSP\_RXD синхронно с сигналом SSP\_CLK, из последовательной в параллельную форму, после чего загружает их в буфер FIFO приемника, откуда они могут быть считаны процессором.

### 33.6.5 Блок формирования прерываний

Модуль SSP генерирует независимые маскируемые прерывания с активным высоким уровнем. Кроме того, формируется комбинированное прерывание путем объединения указанных независимых прерываний по схеме ИЛИ.

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

### 33.6.6 Интерфейс прямого доступа к памяти

Модуль обеспечивает интерфейс с контроллером DMA согласно схеме взаимодействия приемопередатчика и контроллера DMA.

#### 33.6.7 Конфигурирование приемопередатчика

После сброса работа блоков приемопередатчика запрещается до выполнения процедуры задания конфигурации.

Для этого необходимо выбрать ведущий или ведомый режим работы устройства, а также используемый протокол передачи данных (SPI фирмы Motorola, SSI фирмы Texas Instruments, либо Microwave фирмы National Semiconductor), после чего записать необходимую информацию в регистры управления CR0 и CR1.

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

#### 33.6.8 Разрешение работы приемопередатчика

Разрешение осуществляется путем установки бита SSE регистра управления CR1. Буфер FIFO передатчика может быть либо проинициализирован путем записи в него до восьми 16-разрядных слов заблаговременно перед установкой этого бита, либо может заполняться передаваемыми данными в процедуре обслуживания прерывания.

После разрешения работы модуля приемопередатчик начинает обмен данными по линиям SSP\_TXD и SSP\_RXD.

#### 33.6.9 Соотношения между тактовыми сигналами

В модуле имеется ограничение на соотношение между частотами тактовых сигналов CPU\_CLK и SSPCLK. Частота SSPCLK должна меньше или равна частоте CPU\_CLK. Выполнение этого требования гарантирует синхронизацию сигналов управления, передаваемых из зоны действия тактового сигнала SSPCLK в зону действия сигнала CPU\_CLK в течение времени, меньшего продолжительности передачи одного информационного кадра:

#### FSSPCLK <= FPCLK

В режиме ведомого устройства сигнал SSP\_CLK от ведущего внешнего устройства поступает на схемы синхронизации, задержки и обнаружения фронта. Для того, чтобы обнаружить фронт сигнала SSP\_CLK, необходимо три такта сигнала SSP\_CLK. Сигнал SSP\_TXD имеет меньшее время установки по отношению к заднему фронту SSP\_CLK, по которому и происходит считывание данных из линии. Время установки и удержания сигнала SSP\_RXD по отношению к сигналу SSP\_CLK должно выбираться с запасом, гарантирующим правильное считывание данных. Для обеспечения корректной работы устройства необходимо, чтобы частота SSPCLK была как минимум в 12 раз больше, чем максимальная предполагаемая частота сигнала SSP\_CLK.

Выбор частоты тактового сигнала SSPCLK должен обеспечивать поддержку требуемого диапазона скоростей обмена данными. Отношение минимальной частоты сигнала SSPCLK к максимальной частоте сигнала SSP\_CLK в режиме ведомого устройства равно 12, в режиме ведущего – двум.

Так, в режиме ведущего устройства для обеспечения максимальной скорости обмена 1,8432 Мбит/с частота сигнала SSPCLK должна составлять не менее 3,6864 МГц. В этом случае в регистр CPSR должно быть записано значение 2, а поле SCR[7:0] регистра CR0 должно быть установлено в 0.

В режиме ведомого устройства для обеспечения той же информационной скорости необходимо использовать тактовый сигнал SSPCLK с частотой не менее 22,12 МГц. При этом в регистр CPSR должно быть записано значение 12, а поле SCR[7:0] регистра CR0 должно быть установлено в 0.

Соотношение между максимальной частотой сигнала SSPCLK и минимальной частотой SSPCLKOUT составляет 254 \* 256.

Минимальная допустимая частота сигнала SSPCLK определяется следующей системой соотношений, которые должны выполняться одновременно:

```
FSSPCLK(min) => 2 x FSSPCLKOUT(max) [for master mode] FSSPCLK(min) => 12 x FSSPCLKIN(max) [for slave mode].
```

Аналогично, максимальная допустимая частота сигнала SSPCLK определяется следующей системой соотношений, которые должны выполняться одновременно:

```
FSSPCLK(max) <= 254 x 256 x FSSPCLKOUT(min) [for master mode] FSSPCLK(max) <= 254 x 256 x FSSPCLKIN(min) [for slave mode].
```

#### 33.6.10 Программирование регистра управления CR0

Регистр CR0 предназначен для:

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

Скорость информационного обмена зависит от частоты внешнего тактового сигнала SSPCLK и коэффициента деления блока формирования тактового сигнала. Последний задается совместно значением поля SCR (Serial Clock Rate – скорость информационного обмена) регистра SSPCR0 и значением поля CPSDVSR (clock prescale divisor value – коэффициент деления тактового сигнала) регистра SSPCPSR.

Формат информационного кадра задается путем установки значения поля FRF, а размер слова данных – путем установки значения поля DSS регистра SSPCR0.

Для протокола SPI фирмы Motorola также задаются полярность и фаза сигнала (биты SPH и SPO).

## 33.6.11 Программирование регистра управления CR1

Регистр SSPCR1 предназначен для:

- выбора ведущего или ведомого режима функционирования приемопередатчика;
- включения режима проверки канала по шлейфу;
- разрешения или запрещения работы модуля.

Выбор ведущего режима осуществляется путем записи 0 в поле MS регистра SSPCR1 (это значение устанавливается после сброса автоматически).

Запись 1 в поле MS переводит приемопередатчик в режим ведомого устройства. В этом режиме разрешение или запрещение формирования сигнала передатчика SSP\_TXD осуществляется путем установки бита SOD (slave mode SSP\_TXD output disable – запрет линии SSP\_TXD для ведомого режима) регистра CR1. Указанная функция полезна при подключении к одной линии нескольких подчиненных устройств.

Для того, чтобы разрешить функционирование приемопередатчика, необходимо установить в 1 бит SSE (Synchronous Serial Port Enable – разрешение последовательного синхронного порта).

## 33.6.12 Формирование тактового сигнала обмена данными

Тактовый сигнал обмена данными формируется путем деления частоты тактового сигнала SSPCLK. На первом этапе формирования частота этого сигнал делится на четный коэффициент CPSDVSR, лежащий в диапазоне от 2 до 254, доступный для программирования через регистр CPSR. Сформированный сигнал далее поступает на делитель частоты с коэффициентом (1 + SCR) от 1 до 256, где значение SCR доступно для программирование через CR0.

Частота выходного тактового сигнала обмена данными SSP\_CLK определяется следующим соотношением:

FSSPCLKOUT = FSSPCLK / (CPSDVR \* (1+SCR) ).

Например, в случае, если частота сигнала SSPCLK составляет 3,6864 МГц, а значение CPSDVSR = 2, частота сигнала SSP\_CLK лежит в интервале от 7,2 кГц до 1,8432 МГц.

#### 33.6.13 Формат информационного кадра

Каждый информационный кадр содержит в зависимости от запрограммированного значения от 4 до 16 бит данных. Передача данных начинается со старшего значащего разряда. Возможно выбрать три базовых структуры построения кадра:

- SSI фирмы Texas Instruments;
- SPI фирмы Motorola;
- Microwire фирмы National Semiconductor.

Во всех трех режимах построения кадра тактовый сигнал SSP\_CLK формируется только тогда, когда приемопередатчик готов к обмену данными. Перевод сигнала SSP\_CLK в неактивное состояние используется как признак таймаута приемника, то есть наличия в буфере приемника необработанных данных по истечении заданного интервала времени.

В режимах SPI и Microwire выходной сигнал кадровой синхронизации передатчика SSP\_FSS имеет активный низкий уровень и поддерживается в низком уровне в течение всего периода передачи информационного кадра.

В режиме построения кадра SSI фирмы Texas Instruments перед началом каждого информационного кадра на выходе SSP\_FSS формируется импульс с длительностью, равной одному тактовому интервалу обмена данными. В этом режиме приемопередатчик SSP, равно как и ведомые периферийные устройства, передаёт данные в линию по переднему фронту сигнала SSP\_CLK, а считывает данные из линии по заднему фронту этого сигнала.

В отличие от полнодуплексных режимов передачи данных SSI и SPI, режим Microwire фирмы National Semiconductor использует специальный способ обмена данными между ведущим и ведомым устройством, функционирующий в режиме полудуплекса. В указанном режиме на внешнее ведомое устройство перед началом информационного посылается специальная восьмибитная передачи кадра управляющая последовательность. В течение всего времени передачи этой последовательности приемник не обрабатывает каких-либо входных данных. После того как сигнал передан и декодирован ведомым устройством, оно выдерживает паузу в один тактовый интервал после передачи последнего бита управляющей последовательности, после чего передает в адрес ведущего устройства запрошенные данные. Длительность блока данных от ведомого устройства может составлять от 4 до 16 бит, таким образом общая длительность информационного кадра составляет от 13 до 25 бит.





Рисунок 33-2 - Формат синхронного обмена протокола SSI (единичный обмен)

В данном режиме при неактивном приемопередатчике SSP сигналы SSP\_CLK и SSP\_FSS переводятся в низкий логический уровень, а линия передачи данных SSP TXD поддерживается в третьем состоянии.

После появления хотя бы одного элемента в буфере FIFO передатчика сигнал SSP\_FSS переводится в высокий логический уровень на время, соответствующее одному периоду сигнала SSP\_CLK. Значение из буфера FIFO при этом переносится в сдвиговый регистр блока передатчика. По следующему переднему фронту сигнала SSP\_CLK старший значащий разряд информационного кадра (4–16 бит данных) выдается на выход линии SSP\_TXD и т.д.

В режиме приема данных как модуль SSP, так и ведомое внешнее устройство последовательно загружают биты данных в сдвиговый регистр по заднему фронту сигнала SSP\_CLK. Принятые данные переносятся из сдвигового регистра в буфер FIFO после загрузки в него младшего значащего бита данных по очередному переднему фронту сигнала SSP CLK.

Временные диаграммы последовательного синхронного обмена по протоколу SSI фирмы Texas Instruments представлены на рисунках ниже(Рисунок 33–2, Рисунок 33–3).



Рисунок 33–3 – Формат синхронного обмена протокола SSI (непрерывный обмен)

#### 33.6.15 Формат синхронного обмена SPI фирмы Motorola

Интерфейс SPI фирмы Motorola осуществляется по четырем сигнальным линиям, при этом сигнал SSP\_FSS выполняет функцию выбора ведомого устройства. Главной особенностью протокола SPI является возможность выбора состояния и фазы сигнала SSP\_CLK в режиме ожидания (неактивном приемопередатчике) путем задания значений бит SPO и SPH регистра управления SSPSCR0.

Выбор полярности тактового сигнала – бит SPO

Если бит SPO равен 0, то в режиме ожидания линия SSP\_CLK переводится в низкий логический уровень. В противном случае при отсутствии обмена данными линия SSP CLK переводится в высокий логический уровень.

Выбор фазы тактового сигнала – бит SPH

Значение бита SPH определяет фронт тактового сигнала, по которому осуществляется выборка данных и изменение состояния на выходе линии.

В случае, если бит SPH установлен в 0, регистрация данных приемником осуществляется после первого обнаружения фронта тактового сигнала, в противном случае – после второго.

# 33.6.16 Формат синхронного обмена SPI фирмы Motorola, SPO=0, SPH=0

Временные диаграммы последовательного синхронного обмена в режиме SPI с SPO=0, SPH=0 показаны на рисунках (Рисунок 33–4, Рисунок 33–5).

Рисунок 33–4 – Формат синхронного обмена протокола SPI, SPO=0, SPH=0 (одиночный обмен)

Примечание – На рисунке буквой Q обозначен сигнал с неопределенным уровнем.



Рисунок 33–5 – Формат синхронного обмена протокола SPI, SPO=0, SPH=0 (непрерывный обмен)

В данном режиме во время ожидания приемопередатчика:

- сигнал SSP CLK имеет низкий логический уровень;
- сигнал SSP FSS имеет высокий логический уровень;
- сигнал SSP TXD переводится в высокоимпедансное состояние.

Если работа модуля разрешена и в буфере FIFO передатчика содержатся корректные данные, сигнал SSP\_FSS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SSP\_RXD ведущего. Контакт передатчика SSPTXD переходит из высокоимпедансного в активное состояние.

По истечении полутакта сигнала SSP\_CLK на линии SSP\_TXD формируется значение первого бита передаваемых данных. К этому моменту должны быть сформированы данные на линиях обмена, как ведущего, так и ведомого устройства. По истечении следующего полутакта сигнал SSP\_CLK переводится в высокий логический уровень.

Далее данные регистрируются по переднему фронту и выдаются в линию по заднему фронту сигнала SSP CLK.

В случае передачи одного слова данных после приема его последнего бита линия SSP\_FSS переводится в высокий логический уровень по истечении одного периода тактового сигнала SSP\_CLK.

В режиме непрерывной передачи данных на линии SSP\_FSS должны формироваться импульсы высокого логического уровня между передачами каждого из слов данных. Это связано с тем, что в режиме SPH=0 линия выбора ведомого устройства в низком уровне блокирует запись в сдвиговый регистр. Поэтому ведущее устройство должно переводить линию SSP\_FSS в высокий уровень по окончании передачи каждого кадра, разрешая таким образом запись новых данных. По

окончании приема последнего бита блока данных линия SSP\_FSS переводится в состояние, соответствующее режиму ожидания, по истечении одного такта сигнала SSP\_CLK.

## 33.6.17 Формат синхронного обмена SPI фирмы Motorola, SPO=0, SPH=1

Временные диаграммы последовательного синхронного обмена в режиме SPI с SPO=0, SPH=1 показывает Рисунок 33–6 – одиночный и непрерывный обмен.



Рисунок 33-6 - Формат синхронного обмена протокола SPI, SPO=0, SPH=1

Примечание – На рисунке буквой Q обозначен сигнал с неопределенным уровнем.

В данном режиме во время ожидания приемопередатчика:

- сигнал SSP CLK имеет низкий логический уровень;
- сигнал SSP FSS имеет высокий логический уровень;
- сигнал SSP TXD переводится в высокоимпедансное состояние.

Если работа модуля разрешена и в буфере FIFO передатчика содержатся корректные данные, сигнал SSP\_FSS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SSP\_RXD ведущего. Выходной контакт передатчика SSPTXD переходит из высокоимпедансного в активное состояние.

По истечении полутакта сигнала SSP\_CLK на линиях обмена, как ведущего, так и ведомого устройств будут сформированы значения первых бит передаваемых данных. В это же время включается линия SSP\_CLK и на ней формируется передний фронт сигнала.

Далее данные регистрируются по заднему фронту и выдаются в линию по переднему фронту сигнала SSP\_CLK.

В случае передачи одного слова данных после приема его последнего бита линия SSP\_FSS переводится в высокий логический уровень по истечении одного периода тактового сигнала SSP CLK.

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

## 33.6.18 Формат синхронного обмена SPI фирмы Motorola, SPO=1, SPH=0

Временные диаграммы последовательного синхронного обмена в режиме SPI с SPO=1, SPH=0 показаны на рисунках ниже: Рисунок 33–7 — одиночный обмен и Рисунок 33–8 — непрерывный обмен.



Рисунок 33–7 – Формат синхронного обмена протокола SPI, SPO=1, SPH=0 (одиночный обмен)

Примечание – На рисунке буквой Q обозначен сигнал с неопределенным уровнем.



Рисунок 33–8 – Формат синхронного обмена протокола SPI, SPO=1, SPH=0 (непрерывный обмен)

В данном режиме во время ожидания приемопередатчика:

- сигнал SSP CLK имеет высокий логический уровень;
- сигнал SSP FSS имеет высокий логический уровень;
- сигнал SSP TXD переводится в высокоимпедансное состояние.

Если работа модуля разрешена и в буфере FIFO передатчика содержатся корректные данные, сигнал SSP\_FSS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SSP\_RXD ведущего. Выходной контакт передатчика SSPTXD переходит из высокоимпедансного в активное состояние.

По истечении полутакта сигнала SSP\_CLK, на линии SSP\_TXD формируется значение первого бита передаваемых данных. К этому моменту должны быть сформированы данные на линиях обмена, как ведущего, так и ведомого устройства. По истечении следующего полутакта сигнал SSP\_CLK переводится в низкий логический уровень.

Далее данные регистрируются по заднему фронту и выдаются в линию по переднему фронту сигнала SSP CLK.

В случае передачи одного слова данных после приема его последнего бита линия SSP\_FSS переводится в высокий логический уровень по истечении одного периода тактового сигнала SSP CLK.

В режиме непрерывной передачи данных на линии SSP\_FSS должны формироваться импульсы высокого логического уровня между передачами каждого из слов данных. Это связано с тем, что в режиме SPH=0 линия выбора ведомого устройства в низком уровне блокирует запись в сдвиговый регистр. Поэтому ведущее устройство должно переводить линию SSP\_FSS в высокий уровень по окончании передачи каждого кадра, разрешая таким образом запись новых данных. По окончании приема последнего бита блока данных линия SSP\_FSS переводится в состояние, соответствующее режиму ожидания, по истечении одного такта сигнала SSP\_CLK.

## 33.6.19 Формат синхронного обмена SPI фирмы Motorola, SPO=1, SPH=1

Временные диаграммы последовательного синхронного обмена в режиме SPI с SPO=1, SPH=1 показывает Рисунок 33–9 – одиночный и непрерывный обмен.



Рисунок 33-9 - Формат синхронного обмена протокола SPI, SPO=1, SPH=1

Примечание – На рисунке буквой Q обозначен сигнал с неопределенным уровнем.

В данном режиме во время ожидания приемопередатчика:

- сигнал SSP CLK имеет высокий логический уровень;
- сигнал SSP FSS имеет высокий логический уровень;
- сигнал SSP\_TXD переводится в высокоимпедансное состояние.

Если работа модуля разрешена и в буфере FIFO передатчика содержатся корректные данные, сигнал SSP\_FSS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SSP\_RXD ведущего. Выходной контакт передатчика SSP TXD переходит из высокоимпедансного в активное состояние.

По истечении полутакта сигнала SSP\_CLK на линиях обмена как ведущего, так и ведомого устройств сформированы значения первых бит передаваемых данных. В это же время включается линия SSP\_CLK и на ней формируется передний фронт сигнала.

Далее данные регистрируются по переднему фронту и выдаются в линию по заднему фронту сигнала SSP CLK.

В случае передачи одного слова данных после приема его последнего бита линия SSP\_FSS переводится в высокий логический уровень по истечении одного периода тактового сигнала SSP\_CLK.

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

## 33.6.20 Формат синхронного обмена Microwire фирмы National Semiconductor

Временные диаграммы последовательного синхронного обмена в режиме Microwire показаны на рисунках ниже: Рисунок 33–10 – одиночный обмен и Рисунок 33–11 – непрерывный обмен.



Рисунок 33–10 – Формат синхронного обмена протокола Microwire (одиночный обмен)

Протокол передачи данных Microwire во многом схож с протоколом SPI, за исключением того, что обмен в нем осуществляется в полудуплексном режиме, с использованием служебных последовательностей. Каждая информационный обмен передачи устройством специальной начинается С ведущим управляющей последовательности. В течение всего времени ее передачи приемник не обрабатывает каких-либо входных данных. После того, как сигнал передан и декодирован ведомым устройством, оно выдерживает паузу в один тактовый интервал после передачи последнего бита управляющей последовательности, после чего передает в адрес ведущего устройства запрошенные данные. Длительность блока ведомого устройства данных ОТ может составлять от 4 до 16 бит, таким образом, общая длительность информационного кадра составляет от 13 до 25 бит.

В данном режиме во время ожидания приемопередатчика:

- сигнал SSP CLK имеет низкий логический уровень;
- сигнал SSP\_FSS имеет высокий логический уровень;
- сигнал SSP TXD переводится в высокоимпедансное состояние.

Переход в режим информационного обмена происходит после записи управляющего байта в буфер FIFO передатчика. По заднему фронту сигнала SSP\_FSS данные из буфера переносятся в регистр сдвига блока передатчика, откуда, начиная со старшего значащего разряда, последовательно выдаются в линию SSP\_TXD. Линия SSP\_FSS остается в низком логическом уровне в течение всей передачи кадра. Линия SSP\_RXD при этом находится в высокоимпедансном состоянии.

Внешнее ведомое устройство осуществляет прием бит данных по переднему фронту сигнала SSP\_CLK. По окончании приема последнего бита управляющей последовательности она декодируется в течение одного тактового интервала, после чего ведомое устройство передает запрошенные данные в адрес модуля SSP. Биты данных выдаются в линию SSP\_RXD по заднему фронту сигнала SSP\_CLK. Ведущее устройство, в свою очередь, регистрирует их по переднему фронту этого тактового сигнала. В случае одиночного информационного обмена по окончании приема последнего бита слова данных сигнал SSP\_FSS переводится в высокий уровень на время, соответствующее одному тактовому интервалу, что служит командой для переноса принятого слова данных из регистра сдвига в буфер FIFO приемника.

Примечание – Внешнее устройство может перевести линию приемника в третье состояние по заднему фронту сигнала SSP\_CLK после приема последнего бита слова данных, либо после перевода линии SSP\_FSS в высокий логический уровень.

Непрерывный обмен данными начинается и заканчивается также, как и одиночный обмен. Однако линия SSP\_FSS удерживается в низком логическом уровне в течение всего сеанса передачи данных. Управляющий байт следующего информационного кадра передается сразу же после приема младшего значащего разряда текущего кадра. Данные из сдвигового регистра передаются в буфер приемника после регистрации младшего разряда очередного слова по заднему фронту сигнала SSP CLK.



Рисунок 33–11 – Формат синхронного обмена протокола Microwire (непрерывный обмен)

## 33.6.20.1 Требования к временным параметрам сигнала SSP\_FSS относительно тактового сигнала SSP\_CLK в режиме Microwire

Модуль SSP, работающий в режиме Microwire как ведомое устройство, регистрирует данные по переднему фронту сигнала SSP\_CLK после установки сигнала SSP\_FSS в низкий логический уровень. Ведущие устройства, формирующие сигнал SSP\_CKL, должны гарантировать достаточное время установки и удержания сигнала SSP\_FSS по отношению к переднему фронту сигнала SSP\_CLK.

Данные требования иллюстрирует Рисунок 33–12. По отношению к переднему фронту сигнала SSP\_CLK, по которому осуществляется регистрация данных в приемнике ведомого модуля SSP, время установки сигнала SSP\_FSS должно быть как минимум в два раза больше периода SSP\_CLK, на котором работает модуль. По отношению к предыдущему переднему фронту сигнала SSP\_CLK должно обеспечиваться время удержания не менее одного периода этого тактового сигнала.



Рисунок 33–12 – Формат Microwire, требования к времени установки и удержания сигнала

## 33.6.21 Примеры конфигурации модуля в ведущем и ведомом режимах

На рисунках ниже показаны варианты подключения модуля SSP к периферийным устройствам, работающим в ведущем или ведомом режиме (Рисунок 33–13, Рисунок 33–14 и Рисунок 33–15).

Примечание – Модуль SSP не поддерживает динамическое изменение режима «ведущий – ведомый». Каждый приемопередатчик должен быть изначально сконфигурирован в одном из этих режимов.



Рисунок 33-13 - Ведущее устройство SSP подключено к двум ведомым

Рисунок 33–13 показывает совместную работу трех модулей SSP, один из которых сконфигурирован в качестве ведущего, а два – в качестве ведомых устройств. Ведущее устройство способно передавать данные циркулярно в адрес двух ведомых по линии SSP TXD.

Для ответной передачи данных один из ведомых модулей разрешает прохождение сигнала от своей линии SSP\_TXD на вход SSP\_RXD ведущего.



Рисунок 33–14 – Ведущее устройство SSP подключено к двум ведомым, поддерживающим SPI

Рисунок 33–14 показывает подключение модуля SSP, сконфигурированного как ведущее устройство, к двум ведомым устройствам, поддерживающим протокол SPI фирмы Motorola. Внешние устройства сконфигурированы как ведомые путем установки в низкий логический уровень сигнала выбора ведомого устройства Slave Select (SS). Как и в предыдущем примере, ведущее устройство способно передавать данные в адрес ведомых циркулярно по линии SSP\_TXD. Ответная передача данных на входную линю SSP\_RXD ведущего устройства одновременно осуществляется только одним из ведомых по соответствующей линии MISO.



Рисунок 33–15 – Ведущее устройство, протокол SPI, подключено к двум ведомым модулям SSP

Рисунок 33–15 показывает ведущее устройство, поддерживающее протокол SPI фирмы Motorola, соединенное с двумя модулями SSP, сконфигурированными для работы в ведомом режиме. Линия Slave Select (SS) ведущего устройства в этом случае установлена в высокий логический уровень. Ведущее устройство осуществляет передачу данных по линии MOSI циркулярно в адрес двух ведомых модулей.

Для ответной передачи данных один из ведомых модулей переводит линию SSP\_TXD в активное состояние, разрешая, таким образом, прохождение сигнала от своей линии SSP\_TXD на вход SSP\_RXD ведущего.

#### 33.6.22 Интерфейс прямого доступа к памяти

Модуль SSP предоставляет интерфейс подключения к контроллеру прямого доступа к памяти. Работа в данном режиме контролируется регистром управления DMA SSPDMACR.

Интерфейс DMA включает в себя следующие сигналы:

#### • Для приема:

- SSPRXDMASREQ запрос передачи отдельного символа, инициируется приемопередатчиком. Сигнал переводится в активное состояние в случае, если буфер FIFO приемника содержит по меньшей мере один символ;
- SSPRXDMABREQ запрос блочного обмена данными, инициируется модулем приемопередатчика. Сигнал переходит в активное состояние в случае, если буфер FIFO приемника содержит четыре или более символов;
- SSPRXDMACLR сброс запроса на DMA, инициируется контроллером DMA с целью сброса принятого запроса. В случае, если был запрошен блочный обмен данными, сигнал сброса формируется в ходе передачи последнего символа данных в блоке.

### • Для передачи:

- SSPTXDMASREQ запрос передачи отдельного символа, инициируется модулем приемопередатчика. Сигнал переводится в активное состояние в случае, если буфер FIFO передатчика содержит по меньшей мере одну свободную ячейку;
- SSPTXDMABREQ запрос блочного обмена данными, инициируется модулем приемопередатчика. Сигнал переводится в активное состояние в случае, если буфер FIFO передатчика содержит четыре или менее символов;
- SSPTXDMACLR сброс запроса на DMA, инициируется контроллером DMA с целью сброса принятого запроса. В случае, если был запрошен блочный обмен данными, сигнал сброса формируется в ходе передачи последнего символа данных в блоке.

Сигналы блочного и одноэлементного обмена данными не являются взаимоисключающими, они могут быть инициированы одновременно. Например, в случае, если заполнение данными буфера приемника превышает пороговое значение четыре, формируются как сигнал запроса одноэлементного обмена, так и сигнал запроса блочного обмена данными. В случае, если количество данных в буфере приема меньше порогового значения, формируется только запрос одноэлементного обмена. Это бывает полезно в ситуациях, при которых объем данных меньше размера блока. Пусть, например, нужно принять 19 символов. Тогда контроллер DMA осуществит четыре передачи блоков по четыре символа, а оставшиеся три символа передаст в ходе трех одноэлементных обменов.

Примечание – Для оставшихся трех символов контроллер SSP не инициирует процедуру блочного обмена.

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

После снятия сигнала сброса модуль приемопередатчика вновь получает возможность сформировать запрос на DMA в случае выполнения описанных выше

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

В Таблица 33-1 приведены значения порогов заполнения буферов приемника и передатчика, необходимых для срабатывания запросов блочного обмена DMABREQ.

Таблица 33-1 – Параметры срабатывания запросов блочного обмена данными в режиме DMA

|           | Длина блока обмена данными |                         |  |  |
|-----------|----------------------------|-------------------------|--|--|
| Пороговый | Буфер передатчика          | Буфер приемника         |  |  |
| уровень   | (количество незаполненных  | (количество заполненных |  |  |
|           | ячеек)                     | ячеек)                  |  |  |
| 1/2       | 4                          | 4                       |  |  |

Рисунок 33–16 показывает временные диаграммы одноэлементного и блочного запросов DMA, в том числе действие сигнала DMACLR. Все сигналы должны быть синхронизированы с PCLK.



Рисунок 33-16 - Временные диаграммы обмена в режиме DMA

#### 33.7 Программное управление модулем

#### 33.7.1 Общая информация

В микроконтроллере реализовано два модуля SSP, базовые адреса каждого модуля указаны далее в Таблица 33-2. Смещение каждого регистра относительно базового адреса постоянно. Следующие адреса являются резервными и не должны использоваться в нормальном режиме функционирования:

- адреса в со смещениями в диапазоне +0x028 ... +0x07С и +0xFD0 ... +0xFDC зарезервированы для перспективных расширений возможностей модуля;
- адреса в со смещениями в диапазоне +0x080 ... +0x088 зарезервированы для тестирования.

## 33.7.2 Описание регистров контроллера SSP

Данные о регистрах модуля SSP приведены ниже (Таблица 33-2).

Таблица 33-2 - Обобщенные данные о регистрах модуля SSP

| Баз | овый | Наимено- | Тип | Значение | Раз- | Описание |
|-----|------|----------|-----|----------|------|----------|
| ад  | цреc | вание    |     | после    | мер, |          |
|     |      |          |     | сброса   | бит  |          |

## Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| 0x4004_0000 | MDR_SSP1 |    |        |    | Контроллер SSP1                                                                   |
|-------------|----------|----|--------|----|-----------------------------------------------------------------------------------|
| 0x400A_0000 | MDR_SSP2 |    |        |    | Контроллер SSP2                                                                   |
| 0x4000_0000 | MDR_SSP3 |    |        |    | Контроллер SSP3                                                                   |
| 0x4000_8000 | MDR_SSP4 |    |        |    | Контроллер SSP4                                                                   |
| Смещение    |          |    |        |    |                                                                                   |
| 0x000       | CR0      | RW | 0x0000 | 16 | Регистр MDR_SSPx->CR0 управления 0                                                |
| 0x004       | CR1      | RW | 0x0    | 4  | Регистр MDR_SSPx->CR1 управления 1                                                |
| 0x008       | DR       | RW | 0x—    | 16 | Буфера FIFO приемника (чтение)<br>Буфер FIFO передатчика (запись)<br>MDR_SSPx->DR |
| 0x00C       | SR       | RO | 0x03   | 3  | Perистр MDR_SSPx->SR состояния                                                    |
| 0x010       | CPSR     | RW | 0x00   | 8  | Регистр<br>MDR_SSPx->CPSR делителя тактовой<br>частоты                            |
| 0x014       | IMSC     | RW | 0x0    | 4  | Регистр MDR_SSPx->IMSC маски прерывания                                           |
| 0x018       | RIS      | RO | 0x8    | 4  | Регистр MDR_SSPx->RIS состояния прерываний без учета маскирования                 |
| 0x01C       | MIS      | RO | 0x0    | 4  | Регистр MDR_SSPx->MIS состояния прерываний с                                      |
|             |          |    |        |    | учетом маскирования                                                               |
| 0x020       | ICR      | WO | 0x0    | 4  | Регистр  MDR_SSPx->ICR сброса прерывания                                          |
| 0x024       | DMACR    | RW | 0x0    | 2  | Peгистр MDR_SSPx->DMACR управления прямым доступом к памяти                       |

Примечание – В поле «тип» указан вид доступа к регистру: RW – чтение и запись, RO – только чтение, WO – только запись.

## 33.7.3 *MDR\_SSPx->CR0*

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

Регистр CR0 содержит пять битовых полей, предназначенных для управления блоками модуля SSP. Назначение разрядов регистра представлены ниже (Таблица 33-3).

Таблица 33-3 – Формат регистра CR0

| № бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                   |
|--------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3116   | -                       | Зарезервировано                                                                                                                                                                                                                                                                                              |
| 158    | SCR                     | Скорость последовательного обмена.  Значение поля SCR используется при формировании тактового сигнала обмена данными. Информационная скорость удовлетворяет соотношению: F_SSPCLK / (CPSDVR * (1 + SCR)), где CPSDVR – четное число в диапазоне от 2 до 254 (см. регистр SSPCPSR), а SCR – число от 0 до 255 |
| 7      | SPH                     | Фаза сигнала SSPCLKOUT (используется только в режиме обмена SPI фирмы Motorola). См. раздел «Формат SPI фирмы Motorola»                                                                                                                                                                                      |
| 6      | SPO                     | Полярность сигнала SSPCLKOUT (используется только в режиме обмена SPI фирмы Motorola). См. раздел «Формат синхронного обмена SPI фирмы Motorola»                                                                                                                                                             |
| 54     | FRF                     | Формат информационного кадра.<br>00 – протокол SPI фирмы Motorola;<br>01 – протокол SSI фирмы Texas Instruments;<br>10 – протокол Microwire фирмы National Semiconductor;<br>11 – резерв                                                                                                                     |
| 30     | DSS                     | Размер слова данных:  0000 — резерв  0001 — резерв  0010 — резерв  0011 — 4 бита  0100 — 5 бит  0101 — 6 бит  0110 — 7 бит  0111 — 8 бит  1000 — 9 бит  1001 — 10 бит  1011 — 12 бит  1100 — 13 бит  1101 — 14 бит  1111 — 16 бит                                                                            |

#### 33.7.4 MDR SSPx->CR1

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

Регистр CR1 содержит четыре битовых поля, предназначенных для управления блоками модуля SSP. Назначение разрядов регистра представлено в Таблица 33-4.

Таблица 33-4 - Регистр CR1

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое         |
|------|----------------|---------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений              |
| 154  |                | Резерв, при чтении результат не определен.              |
|      |                | При записи следует устанавливать в 0                    |
| 3    | SOD            | Запрет выходных линий в режиме ведомого устройства.     |
|      |                | Бит используется только в режиме ведомого устройства    |
|      |                | (MS=1). Это позволяет организовать двусторонний обмен   |
|      |                | данными в системах, содержащих одно ведущее и           |
|      |                | несколько ведомых устройств.                            |
|      |                | Бит SOD следует установить в случае, если данный        |
|      |                | ведомый модуль SSP не должен в настоящее время          |
|      |                | осуществлять передачу данных в линию SSP_TXD. При       |
|      |                | этом линии обмена данных ведомых устройств можно        |
|      |                | соединить параллельно.                                  |
|      |                | 0 – управление линией SSP_TXD в ведомом режиме          |
|      |                | разрешено.                                              |
|      |                | 1 – управление линией SSP_TXD в ведомом режиме          |
|      |                | запрещено                                               |
| 2    | MS             | Выбор ведущего или ведомого режима работы:              |
|      |                | 0 – ведущий модуль (устанавливается по умолчанию);      |
|      |                | 1 – ведомый модуль                                      |
| 1    | SSE            | Разрешение работы приемопередатчика:                    |
|      |                | 0 – работа запрещена;                                   |
|      |                | 1 – работа разрешена                                    |
| 0    | LBM            | Тестирование по шлейфу:                                 |
|      |                | 0 – нормальный режим работы приемопередатчика;          |
|      |                | 1 – выход регистра сдвига передатчика соединен с входом |
|      |                | регистра сдвига приемника                               |

#### 33.7.5 *MDR SSPx->DR*

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

Регистр SSPDR имеет разрядность 16 бит и предназначен для чтения принятых и записи передаваемых данных.

Операция чтения обеспечивает доступ к последней несчитанной ячейке буфера FIFO приемника. Запись данных в этот буфер FIFO осуществляет блок приемника.

Операция записи позволяет занести очередное слово в буфер FIFO передатчика. Извлечение данных из этого буфера осуществляет блок передатчика. При этом извлеченные данные помещаются в регистр сдвига передатчика, откуда последовательно выдаются на линию SSP\_TXD с заданной скоростью информационного обмена.

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

информационные слова автоматически выравниваются по правой границе в блоке приемника.

В режиме обмена данными Microwire фирмы National Semiconductor модуль SSP по умолчанию работает с восьмиразрядными информационными словами (старший значащий байт игнорируется). Размер принимаемых данных задается программно. Буфера FIFO приемника и передатчика автоматически не очищаются даже в случае, если бит SSE установлен в 0. Это позволяет заполнить буфер передатчика необходимой информацией заблаговременно, перед разрешением работы модуля.

Назначение разрядов регистра SSPDR описано в таблице, смледующей ниже (Таблица 33-5).

Таблица 33-5 – Формат регистра DR

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                          |
|-----------|-------------------------|---------------------------------------------------------------------------------------------------------------------|
| 150       | DATA                    | Принимаемые данные (чтение).                                                                                        |
|           |                         | Передаваемые данные (запись).<br>В случае, если выбран размер информационного слова менее                           |
|           |                         | 16 бит, перед записью в регистр SSPDR необходимо обеспечить выравнивание данных по правой границе. Блок передатчика |
|           |                         | игнорирует неиспользуемые биты. Принятые информационные                                                             |
|           |                         | слова автоматически выравниваются по правой границе в блоке                                                         |
|           |                         | приемника                                                                                                           |

#### 33.7.6 MDR SSPx->SR

Регистр состояния

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

Назначение бит регистра SSPCPSR представлено в таблице ниже (Таблица 33-6).

Таблица 33-6 - Регистр SR

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                               |
|-----------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 155       |                            | Резерв, при чтении результат не определен                                                                                                                |
| 4         | BSY                        | Флаг активности модуля: 0 – модуль SSP не активен; 1 – модуль SSP в настоящее время передает и/или принимает данные, либо буфер FIFO передатчика не пуст |
| 3         | RFF                        | Буфер FIFO приемника заполнен:<br>0 – не заполнен;<br>1 – заполнен                                                                                       |
| 2         | RNE                        | Буфер FIFO приемника не пуст:<br>0 – пуст;<br>1 – не пуст                                                                                                |
| 1         | TNF                        | Буфер FIFO передатчика не заполнен:<br>0 – заполнен;<br>1 – не заполнен                                                                                  |
| 0         | TFE                        | Буфер FIFO передатчика пуст:<br>0 – не пуст;                                                                                                             |

|  | 1 – пуст |  |
|--|----------|--|
|--|----------|--|

#### 33.7.7 MDR SSPx->CPSR

Регистр делителя тактовой частоты

Регистр SSPCPSR используется для установки параметров делителя тактовой частоты. Записываемое значение должно быть целым числом в диапазоне от 2 до 254. Младший значащий разряд регистра принудительно устанавливается в ноль. Если записать в регистр SSPCPSR нечетное число, его последующее чтение даст результатом это число, но с установленным в ноль младшим битом.

Таблица 33-7 отображает назначение бит регистра SSPSR.

Таблица 33-7 – Регистр CPSR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                              |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                   |
| 318  | -              | Резерв. При чтении результат не определен. При записи                                                                                                        |
|      |                | следует заполнить нулями                                                                                                                                     |
| 7 0  | CPSDVSR        | Коэффициент деления тактовой частоты. Записываемое значение должно быть целым числом в диапазоне от 2 до 254. Младший значащий разряд регистра принудительно |
|      |                | устанавливается в ноль                                                                                                                                       |

#### 33.7.8 MDR\_SSPx->IMSC

Регистр установки и сброса маски прерывания

При чтении выдается текущее значение маски. При записи производится установка или сброс маски на соответствующее прерывание. При этом запись 1 в разряд разрешает соответствующее прерывание, запись 0 – запрещает.

После сброса все биты регистра маски устанавливаются в нулевое состояние. Назначение бит регистра IMSC показано в таблице ниже.

Таблица 33-8 - Регистр IMSC

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                           |
|-----------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 314       |                            | Резерв. Не модифицируйте. При чтении выдаются нули                                                                                                                   |
| 3         | TXIM                       | Маска прерывания по заполнению на 50% и менее буфера FIFO передатчика.  1 – не маскирована.  0 – маскирована                                                         |
| 2         | RXIM                       | Маска прерывания по заполнению на 50% и менее буфера FIFO приемника.  1 – не маскирована.  0 – маскирована                                                           |
| 1         | RTIM                       | Маска прерывания по таймауту приемника (буфер FIFO приемника не пуст и не было попуток его чтения в течение времени таймаута).  1 – не маскирована.  0 – маскирована |
| 0         | RORIM                      | Маска прерывания по переполнению буфера приемника. 1 – не маскирована.                                                                                               |

#### 33.7.9 *MDR\_SSPx->RIS*

Регистр состояния прерываний

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

Таблица 33-9 отображает назначение бит в регистре RIS.

## Таблица 33-9 - Регистр RIS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 31 4      |                         | Резерв. Не модифицируйте. При чтении выдаются нули                                         |
| 3         | TXRIS                   | Состояние до маскирования прерывания SSPTXINTR                                             |
| 2         | RXRIS                   | Состояние до маскирования прерывания SSPRXINTR                                             |
| 1         | RTRIS                   | Состояние до маскирования прерывания SSPRTINTR                                             |
| 0         | RORRIS                  | Состояние до маскирования прерывания SSPRORINTR                                            |

## 33.7.10 *MDR\_SSPx->MIS*

Регистр маскированного состояния прерываний

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

Назначение бит в регистре SSPMIS представлено в таблице ниже (Таблица 33-10).

Таблица 33-10 - Регистр MIS

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое    |
|------|----------------|----------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений         |
| 314  |                | Резерв. Не модифицируйте. При чтении выдаются нули |
| 3    | TXMIS          | Состояние маскированного прерывания SSPTXINTR      |
| 2    | RXMIS          | Состояние маскированного прерывания SSPRXINTR      |
| 1    | RTMIS          | Состояние маскированного прерывания SSPRTINTR      |
| 0    | RORMIS         | Состояние маскированного прерывания SSPRORINTR     |

#### 33.7.11 *MDR\_SSPx->ICR*

Регистр сброса прерываний

Этот регистр доступен только для записи и предназначен для сброса признака прерывания по заданному событию путем записи 1 в соответствующий бит. Запись в любой из разрядов регистра 0 игнорируется.

Назначение бит в регистре SSPICR представлено в таблице ниже (Таблица 33-11).

## Таблица 33-11 – Регистр ICR

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |  |
|------------------|-------------------------|--------------------------------------------------------------------------------------------|--|
| 31 2             |                         | Резерв. Не модифицируйте. При чтении выдаются нули                                         |  |
| 1                | RTIC                    | Сброс прерывания SSPRTINTR                                                                 |  |
| 0                | RORIC                   | Сброс прерывания SSPRORINTR                                                                |  |

#### 33.7.12 MDR\_SSPx->DMACR

Регистр управления прямым доступом к памяти

Регистр доступен по чтению и записи. После сброса все биты регистра обнуляются.

Назначение бит регистра UARTDMACR представлено в таблице ниже (Таблица 33-12).

Таблица 33-12 - Регистр DMACR

| №<br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                            |
|-----------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 312       |                            | Резерв. Не модифицируйте. При чтении выдаются нули.                                                                                   |
| 1         | TXDMAE                     | Использование DMA при передаче. Если бит установлен в 1, разрешено формирование запросов DMA для обслуживания буфера FIFO передатчика |
| 0         | RXDMAE                     | Использование DMA при приеме. Если бит установлен в 1, разрешено формирование запросов DMA для обслуживания буфера FIFO приемника     |

#### 33.8 Прерывания

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

Сигналы запроса на прерывание:

- SSPRXINTR запрос на обслуживание буфера FIFO приемника;
- SSPTXINTR запрос на обслуживание буфера FIFO передатчика;
- SSPRORINTR переполнение буфера FIFO приемника;
- SSPRTINTR таймаут приемника;
- SSPINTR логическое ИЛИ сигналов SSPRXINTR, SSPTXINTR, SSPRTINTR и SSPRORINTR.

Каждый из независимых сигналов запроса на прерывание может быть маскирован путем установки соответствующего бита в регистре маски SSPIMSC. Установка бита в 1 разрешает соответствующее прерывание, а в 0 – запрещает.

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

Прерывания от приемника и передатчика SSPRXINTR и SSPTXINTR выведены отдельно от прерываний по изменению состояния устройства. Это позволяет использовать данные сигналы запроса для обеспечения чтения и записи

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

Признаки возникновения каждого из условий прерывания можно считать либо из регистра прерываний SSPRIS, либо из маскированного регистра прерываний SSPMIS.

#### **33.8.1 SSPRXINTR**

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

#### 33.8.2 SSPTXINTR

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

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

#### 33.8.3 SSPRORINTR

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

#### **33.8.4 SSPRTINTR**

Прерывание по таймауту приемника возникает в случае, если буфер FIFO приемника не пуст, и на вход приемника не поступало новых данных в течение периода времени, необходимого для передачи 32 бит. Данный механизм гарантирует, что пользователь будет знать о наличии в буфере приемника необработанных данных.

Прерывание по таймауту снимается либо после считывания данных из буфера приемника до его опустошения, либо после приема новых слов данных по входной линии SSP\_RXD. Кроме того, оно может быть снято путем записи 1 в бит RTIC регистра сброса прерывания SSPTICR.

#### 33.8.5 *SSPINTR*

Все описанные сигналы запроса на прерывание скомбинированы в общую линию путем объединения по схеме ИЛИ сигналов SSPRXINTR, SSPRTINTR, SSPRTINTR и SSPRORINTR с учетом маскирования. Общий выход может быть подключен к системному контроллеру прерывания, что позволит ввести дополнительное маскирование запросов на уровне периферийных устройств.

## 34 Контроллер MDR\_UART

Модуль универсального асинхронного приемопередатчика (UART – Universal Synchronous Asynchronous Receiver Transmitter) представляет собой периферийное устройство микроконтроллера.

В состав контроллера включен кодек (ENDEC – ENcoder/DEcoder) последовательного интерфейса инфракрасной (ИК) передачи данных в соответствии с протоколом SIR (SIR – Serial Infra Red) ассоциации Infrared Data Association (IrDA).

## 34.1 Основные сведения

Основные сведения о модуле представлены в следующих разделах:

- основные характеристики;
- программируемые параметры;
- отличия от приемопередатчика 16С650.

## 34.1.1 Основные характеристики модуля UART

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

Содержит независимые буферы приема (16х12) и передачи (16х8) типа FIFO (First In First Out – первый вошел, первый вышел), что позволяет снизить интенсивность прерываний центрального процессора.

Программное отключение FIFO позволяет ограничить размер буфера одним байтом.

Программное управление скоростью обмена. Обеспечивается возможность деления тактовой частоты опорного генератора в диапазоне (1x16 – 65535x16). Допускается использование нецелых коэффициентов деления частоты, что позволяет использовать любой опорный генератор с частотой более 3,6864 МГц.

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

Независимое маскирование прерываний от буфера FIFO передатчика, буфера FIFO приемника, по таймауту приемника, по изменению линий состояния модема, а также в случае обнаружения ошибки.

Поддержка прямого доступа к памяти.

Обнаружение ложных стартовых бит.

Формирование и обнаружения сигнала разрыва линии.

Поддержка функция управления модемом (линии CTS, DCD, DSR, RTS, DTR и RI).

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

Полностью программируемый асинхронный последовательный интерфейс с характеристиками:

- данные длиной 5, 6, 7 или 8 бит;
- формирование и контроль четности (проверочный бит выставляется по четности, нечетности, имеет фиксированное значение, либо не передается);
- формирование 1 или 2 стоповых бит;
- скорость передачи данных от 0 до UARTCLK/16 Бод.

Кодек ИУ обмена данными IrDA SIR обеспечивает:

- программный выбор обмена данными по линиям асинхронного приемопередатчика либо кодека ИК связи IrDA SIR;
- поддержку функционирования с информационной скоростью до 115200 бит/с в режиме полудуплекса;
- поддержку длительности бит для нормального режима (3/16) и для режима пониженного энергопотребления (1.41 – 2.23 мкс);
- программируемое деление опорной частоты UARTCLK для получения заданной длительности бит в режиме пониженного энергопотребления.

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

## 34.1.2 Программируемые параметры

Следующие ключевые параметры могут быть заданы программно:

- скорость передачи данных целая и дробная часть числа;
- количество бит данных;
- количество стоповых бит;
- режим контроля четности;
- разрешение или запрет использования буферов FIFO (глубина очереди данных 32 элемента или один элемент, соответственно);
- порог срабатывания прерывания по заполнению буферов FIFO (1/8, 1/4, 1/2, 3/4 и 7/8);
- частота внутреннего тактового генератора (номинальное значение 1,8432 МГц) может быть задана в диапазоне 1,42 2,12 МГц для обеспечения возможности формирования бит данных с укороченной длительностью в режиме пониженного энергопотребления;
- режим аппаратного управления потоком данных.

### 34.1.3 Отличия от контроллера UART 16C650

Контроллер отличается от промышленного стандарта асинхронного приемопередатчика 16С650 следующими характеристиками:

- пороги срабатывания прерывания по заполнению буфера FIFO приемника – 1/8, 1/4, 1/2, 3/4 и 7/8;
- пороги срабатывания прерывания по заполнению буфера FIFO передатчика 1/8, 1/4, 1/2, 3/4 и 7/8;
- отличается распределение адресов внутренних регистров и назначение бит в регистрах;
- недоступны изменения сигналов состоянии модема.

Следующие возможности контроллера 16С650 не поддерживаются:

- полуторная длительность стопового бита (поддерживается только 1 или 2 стоповых бита);
- независимое задание тактовой частоты приемника и передатчика.

#### 34.2 Функциональные возможности

Устройство выполняет следующие функции:

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

Процессор читает и записывает данные, а также управляющую информацию и информацию о состоянии модуля. Прием и передача данных буферизуются с помощью внутренней памяти FIFO, позволяющей сохранить до 16 байтов независимо для режимов приема и передачи.

## Модуль приемопередатчика:

- содержит программируемый генератор, формирующий тактовый сигнал одновременно для передачи и для приема данных на основе внутреннего тактового сигнала UARTCLK;
- обеспечивает возможности, сходные с возможностями индустриального стандарта контроллера UART 16C650;
- позволяет осуществлять обмен информацией с максимальной скоростью:
  - в режиме UART в зависимости от частоты (см раздел Тактовые сигналы);
  - в режиме IrDA до 460800 бит/с;
  - в режиме IrDA с пониженным энергопотреблением до 115200 бит/с.

Режим работа приемопередатчика и скорость обмена данными контролируются регистром управления линией UARTLCR\_H и регистрами делителя скорости передачи данных – целой части (UARTIBRD) и дробной части (UARTFBRD).

Устройство может формировать следующие сигналы:

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

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

Существует возможность программно ограничить размер буфера FIFO одним байтом, что позволяет реализовать общепринятый интерфейс асинхронной последовательной связи с двойной буферизацией.

Поддерживаются входные линии состояния модема:

- «готовность к приему» (Clear To Send, CTS);
- «обнаружен информационный сигнал» (Data Carrier Detected, DCD);
- «источник данных готов» (Data Set Ready, DSR);
- «индикатор вызова» (Ring Indicator, RI).

Также поддерживаются выходные линии:

- «запрос на передачу» (Request to Send, RTS);
- «приемник данных готов» (Data Terminal Ready, DTR).

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

<u>Блок последовательного интерфейса инфракрасной передачи данных</u> в соответствии с протоколом IrDA SIR реализует протокол обмена данными ENDEC. В случае его активизации обмен информацией осуществляется не с помощью сигналов UARTTXD и UARTRXD, а посредством сигналов nSIROUT и SIRIN.

В этом случае устройство переводит линию UARTTXD в пассивное состояние (высокий уровень), и перестает реагировать на изменение состояния модема, а также сигнала на линии UARTRXD. Протокол SIR ENDEC обеспечивает возможность обмена данными исключительно в режиме полудуплекса, то есть он не может передавать во время приема данных и принимать во время передачи данных.

В соответствии со спецификацией физического уровня протокола IrDA SIR, задержка между передачей и приемом должна составлять не менее 10 мс.

#### Чтение данных [11:0] txd [7:0] rxd [11:0] nUARTRST Запись 32x8 32x12 передача по прием по данных [7:0] принципу принципу **FIFO** FIFO **PCLK PRESETn PSEL** UARTTXD. Контроль и состояние Блок регистра Передатчик **PENABLE** nSIROUT и интерфейса Делитель скорости улучшенной **PWRITE** передачи периферийной шины АРВ PADDR [11:2] Контроллер Baud 16 скорости передачи PRDATA[15:0] **UARTRXD** PRDATA[15:0] Приемник SIRIN **UARTCLK** Метки Состояние Состояние Опорная частота FIFO передачи приема FIFO FIFO nUARTRI UARTRXDMACLR nUARTCTS UARTTXDMACLR **UARTTXINTR** Интерфейс nUARTDSR UARTRXINTR **UARTRXDMASREQ** канала Генерация nUARTDCD UARTMSINTR UARTRXDMABREQ прямого Состояния FIFO и nUARTDTR UARTRTINTR

## 34.3 Описание функционирования блока UART

Рисунок 34–1 – Блок-схема универсального асинхронного приёмопередатчика (UART)

nUARTDTR

nUARTRTS

**UARTTXDMASREQ** 

UARTTXDMABREQ

доступа

**nUARTRTS** 

nUARTOut1

nUARTOut2

прерывания

## 34.3.1 Генератор тактового сигнала приемопередатчика

Генератор содержит счетчики без цепи сброса, формирующие внутренние тактовые сигналы Baud16 и IrLPBaud16.

Сигнал Baud16 используется для синхронизации схем управления приемником и передатчиком последовательного обмена данными. Он представляет собой последовательность импульсов с шириной, равной одному периоду сигнала UARTCLK и частотой, в 16 раз выше скорости передачи данных.

Сигнал IrLPBaud16 предназначен для синхронизации схемы формирования импульсов с длительностью, требуемой для ИК обмена данными в режиме с пониженным энергопотреблением.

#### 34.3.2 Буфер FIFO передатчика

Буфер передатчика имеет ширину 8 бит, глубину 16 слов, схему организации доступа типа «первый вошел, первый вышел». Данные от центрального процессора, записанные через шину APB, сохраняются в буфере до тех пор, пока не будут считаны логической схемой передачи данных. Существует возможность запретить буфер FIFO передатчика, в этом случае он будет функционировать как однобайтовый буферный регистр.

#### 34.3.3 Буфер FIFO приемника

Буфер приемника имеет ширину 12 бит, глубину 16 слов, схему организации доступа типа «первый вошел, первый вышел». Принятые от периферийного устройства данные и соответствующие кодов ошибки сохраняются логикой приема данных в нем до тех пор, пока не будут считаны центральным процессором через шину APB. Буфер FIFO приемника может быть запрещен, в этом случае он будет действовать как однобайтовый буферный регистр.

#### 34.3.4 Блок передатчика

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

### 34.3.5 Блок приемника

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

## 34.3.6 Блок формирования прерываний

Контроллер генерирует независимые маскируемые прерывания с активным высоким уровнем. Кроме того, формируется комбинированное прерывание путем объединения указанных независимых прерываний по схеме ИЛИ.

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

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

Для более подробной информации см. раздел «Прерывания».

#### 34.3.7 Интерфейс прямого доступа к памяти

Модуль обеспечивает интерфейс с контроллером DMA согласно схеме взаимодействия приемопередатчика и контроллера DMA.

## 34.3.8 Блок и регистры синхронизации

Контроллер поддерживает как асинхронный, так и синхронный режимы работы тактовых генераторов CPU\_CLK и UARTCLK. Регистры синхронизации и логика квитирования постоянно находятся в активном состоянии. Это практически не отражается на характеристиках устройства и занимаемой площади. Синхронизация сигналов управления осуществляется в обоих направлениях потока данных, то есть как из области действия CPU CLK в область действия UARTCLK, так и наоборот.

#### 34.4 Описание функционирования ИК кодека IrDA SIR

Структурная схема кодека представлена ниже (Рисунок 34–2).



Рисунок 34-2 - Структурная схема кодека IrDA

### 34.4.1 Кодер ИК передатчика

Кодер преобразует поток данных с выхода асинхронного передатчика, сформированный по закону модуляции без возврата к нулю (NRZ). Спецификация физического уровня протокола IrDA SIR подразумевает использование модуляции с возвратом к нулю и инверсией (RZI), в соответствии с которой передача логического нуля соответствует излучению одного светового ИК импульса. Сформированный выходной поток импульсов подается на усилитель и, далее, на ИК светодиод.

Длительность импульса в режиме IrDA составляет, согласно спецификации, 3 периода внутреннего тактового генератора с частотой Baud16, то есть 3/16 периода времени, выделенного на передачу одного бита.

В режиме IrDA с пониженным энергопотреблением ширина импульса задана как 3/16 периода, выделенного на передачу бита, при скорости передачи данных 115200 бит/с. Данное требование реализуется за счет формирования трех периодов тактового сигнала IrLPBaud16 с номинальной частотой 1.8432 МГц, в свою очередь, формируемого путем деления частоты UARTCLK. Значение частоты IrLPBaud16 задается путем записи соответствующего коэффициента деления частоты в регистр UARTILPR.

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

Как в нормальном режиме, так и в режиме пониженного энергопотребления использование нецелых значений коэффициента деления скорости передачи данных увеличивает джиттер («дребезжание») фронтов импульсов данных. Наличие джиттера в случае использования дробных коэффициентов деления связано с тем, что интервалы между тактовыми импульсами Baud16 будут нерегулярными – период сигнала Baud16 в разное время будет содержать различное количество периодов сигнала UARTCLK. Можно показать, что в наихудшем случае величина джиттера в потоке ИК импульсов может достигать трех периодов UARTCLK. В соответствии со спецификацией стандарта IrDA SIR, джиттер не должен превышать величины 13 %. В случае, если частота сигнала UARTCLK составляет более 3 6834 МГц, а скорость передачи данных меньше или равна 115200 бит/с, величина джиттера не превышает 9%. Таким образом, требования стандарта выполняются.

#### 34.4.2 Декодер ИК приемника

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

Обнаружение стартового бита осуществляется при низком уровне сигнала на входе декодера.

Примечание — Для того, чтобы исключить ложные срабатывания UART от импульсных помех, на входе SIRIN игнорируются импульсы с длительностью менее, чем:

- 3/16 длительности Baud16 в режиме IrDA;
- 3/16 длительности IrLPBaud16 в режиме IrDA с пониженным энергопотреблением.

### 34.5 Описание работы UART

### 34.5.1 Сброс модуля

Приемопередатчик и кодек могут быть сброшены общим сигналом сброса процессора. Значения регистров после сброса описаны в разделе «

Программное управление модулем».

#### 34.5.2 Тактовые сигналы

Частота тактового сигнала UARTCLK должна обеспечивать поддержку требуемого диапазона скоростей передачи данных:

```
F_UARTCLK(min) >= 16 * baud_rate_max;
F_UARTCLK(max) <= 16 * 65535 * baud_rate_min.
```

Например, для поддержки скорости передачи данных в диапазоне от 110 до 460800 Бод частота UARTCLK должна находиться в интервале от 7 3728 МГц до 115,34 МГц.

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

#### 34.5.3 Работа универсального асинхронного приемопередатчика

Управляющая информация хранится в регистре управления линией UARTLCR. Этот регистр имеет внутреннюю ширину 30 бит, однако внешний доступ по шине APB к нему осуществляется через следующие регистры:

- UARTLCR H определяет:
  - параметры передачи данных;
  - длину слова;
  - режим буферизации;
  - количество передаваемых стоповых бит;
  - режим контроля четности;
  - формирование сигнала разрыва линии;
- UARTIBRD определяет целую часть коэффициента деления для скорости передачи данных;
- UARTFBRD определяет дробную часть коэффициента деления для скорости передачи данных.

#### 34.5.4 Коэффициент деления частоты

Коэффициент деления для формирования скорости передачи данных состоит из 22 бит, при этом 16 бит выделено для представления его целой части, а 6 бит – дробной части. Возможность задания нецелых коэффициентов деления позволяет осуществлять обмен данными со стандартными информационными скоростями, при этом используя в качестве UARTCLK тактовый сигнал с произвольной частотой более 3,6864 МГц.

Целая часть коэффициента деления записывается в 16-битный регистр UARTIBRD. Шестиразрядная дробная часть записывается в регистр UARTFBRD. Значение коэффициента деления связано с содержимым указанных регистров следующим образом:

Коэффициент деления = UARTCLK / (16 \* скорость передачи данных) = BRD\_I + BRD\_F,

где

BRD\_I – целая часть, а BRD\_F – дробная часть коэффициента деления.



Рисунок 34-3 - Коэффициент деления

Шестибитное значение, записываемое в регистр UARTFBRD, вычисляется путем выделения дробной части требуемого коэффициента деления, умножения ее на 64 (то есть на 2n, где n – ширина регистра UARTFBRD) и округления до ближайшего целого числа:

 $M = integer(BRD_F * 2n + 0.5),$  где integer - операция отсечения дробной части числа, n = 6.

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

#### 34.5.5 Передача и прием данных

Принятые или передаваемые данные заносятся в 16-элементные буферы FIFO, при этом каждый элемент приемного буфера FIFO кроме байта данных хранит также четыре бита информации о состоянии модема.

Для передачи данные заносятся в буфер FIFO передатчика. Если работа приемопередатчика разрешена, начинается передача информационного кадра с параметрами, указанными в регистре управления линией UARTLCR\_H. Передача данных продолжается до опустошения буфера FIFO передатчика. После записи элемента в буфер FIFO передатчика сигнал BUSY переходит в высокое состояние. Это состояние сохраняется в течение всего времени передачи данных. В низкое состояние сигнал BUSY переходит только после того, как буфер FIFO передатчика станет пуст, а последний бит данных (включая стоповые биты) будет передан. Сигнал BUSY может находиться в высоком состоянии даже в случае, если приемопередатчик будет переведен из разрешенного состояний в запрещенное.

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

В случае, если приемник находился в неактивном состоянии (на линии входного сигнала UART\_RXD постоянно присутствовала единица) и произошел переход входного сигнала из высокого в низкий логический уровень (обнаружен стартовый бит), включается счетчик, тактируемый сигналом Baud16, после чего отсчеты сигнала на входе приемника регистрируются каждые восемь тактов (в режиме асинхронного приемопередатчика) или каждые четыре такта (в режиме ИК обмена данными) сигнала Baud16. Более частая выборка данных в режиме ИК обмена

связана с необходимостью корректной обработки импульсов данных согласно протоколу SIR IrDA.

Стартовый бит считается достоверным в случае, если сигнал на линии UART\_RXD сохраняет низкий логический уровень в течение восьми отсчетов сигнала Baud16 с момента включения счетчика. В противном случае переход в ноль рассматривается как ложный старт и игнорируется.

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

Наконец, производится проверка присутствия корректного стопового бита (высокий логический уровень сигнала UART\_RXD). В случае, если последнее условие не выполняется, устанавливается признак ошибки формирования кадра. После того, как слово данных принято полностью, оно заносится в буфер FIFO приемника, наряду с четырьмя битами признаков ошибки, связанных с принятым словом (см. Таблица 34-1 – Назначение бит слова данных в FIFO-буфере приемника).

#### 34.5.6 Биты ошибки

Три бита признаков ошибки, ассоциированные с принятым символом данных, заносятся в разряды [10...8] слова данных в буфере FIFO приемника. Также предусмотрен признак ошибки переполнения буфера FIFO в разряде 11 слова данных.

Таблица 34-1 описывает назначение всех бит слова данных в FIFO-буфере приемника.

| Бит буфера FIFO | Назначение                  |
|-----------------|-----------------------------|
| 11              | Признак переполнения буфера |
| 10              | Ошибка – «разрыв линии»     |
| 9               | Ошибка проверки на четность |
| 8               | Ошибка формирования кадра   |
| 7 0             | Принятые данные             |

Таблица 34-1 – Назначение бит слова данных в FIFO-буфере приемника

### 34.5.7 Бит переполнения буфера

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

### 34.5.8 Запрет буфера FIFO

Предусмотрена возможность отключения FIFO буферов приемника и передатчика. В этом случае приемная и передающая сторона контроллера UART располагают лишь однобайтными буферными регистрами. Бит переполнения буфера устанавливается при этом тогда, когда очередной символ данных уже принят, однако предыдущий еще не был считан.

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

#### 34.5.8.1 Проверка по шлейфу

Проверка по шлейфу (замыкание выхода передатчика на вход приемника) выполняется путем установки в 1 бита LBE в регистре управления контроллером UARTCR.

#### 34.5.9 Работа кодека ИК обмена данными IrDA SIR

Кодек обеспечивает сопряжение асинхронного потока данных, сформированного приемопередатчиком, с полудуплексным последовательным интерфейсом IrDA SIR. Какая-либо аналоговая обработка сигнала при этом не выполняется. Назначение кодека — сформировать цифровой поток данных на вход приемника асинхронного сигнала и обработать цифровой поток данных с выхода передатчика.

Предусмотрено два режима работы:

**В режиме IrDA** уровень логического нуля передается на линию nSIROUT в виде импульса с высоким логическим уровнем и длительностью 3/16 от выбранного периода следования бит данных. Логическая единица при этом передается в виде постоянного низкого уровня сигнала. Сформированный выходной сигнал далее подается на передатчик ИК сигнала, обеспечивая излучение светового импульса всякий раз при передаче нулевого бита. На приемной стороне световые импульсы воздействуют на базу фототранзистора ИК приемника, который в результате формирует низкий логический уровень. Это, в свою очередь, обуславливает низкий уровень на входе SIRIN.

**В режиме IrDA с пониженным энергопотреблением** длительность передаваемых импульсов ИК излучения устанавливается в три раза выше длительности импульсов внутреннего опорного сигнала IrLPBaud16 (равной 1,63 мкс при номинальной частоте 1,8432 МГц). Данный режим активизируется путем установки бита SIRLP в регистре управления UARTCR.

Как в нормальном режиме, так и в режиме пониженного энергопотребления:

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

В соответствии со спецификацией физического уровня протокола IrDA SIR, обмен данными должен осуществляться в режиме полудуплекса, при этом задержка между передачей и приемом данных должна составлять не менее 10 мс. Эта задержка должна формироваться программно. Необходимость ее введения обусловлена тем,

что воздействие передающего ИК светодиода на находящийся рядом ИК приемник может привести к искажению принимаемого сигнала или даже ввести приемный тракт в состояние насыщения. Задержка между окончанием передачи и началом приема данных именуется латентность, или время установки (готовности) приемника.

Сигнал IrLPBaud16 формируется путем деления частоты сигнала UARTCLK в соответствии с коэффициентом деления, записанным в регистре UARTILPR.

Коэффициент деления вычисляется по формуле:

F UARTCLK / F IrLPBaud16,

где номинальное значение IrLPBaud16 составляет 1.8432 МГц. Коэффициент деления должен быть выбран так, чтобы выполнялось соотношение:

1,42 МГц < F IrLPBaud16 < 2,12 МГц.

#### 34.5.9.1 Проверка по шлейфу

Проверка по шлейфу выполняется после установки в 1 бита LBE регистра управления контроллером UARTCR с одновременной установкой в 1 бита SIRTEST регистра управления тестированием UARTTCR.

В этом режиме данные, передаваемые на выход nSIROUT, должны подаваться на вход SIRIN.

Примечание — Это единственный случай использования тестового регистра в нормальном режиме функционирования модуля.



Рисунок 34-4 - Кадр передачи данных

## 34.5.10 Модуляция данных IrDA



Рисунок 34-5 - Модуляция данных IrDA

#### 34.6 Линии управления модемом

Модуль универсального асинхронного приемопередатчика может использоваться как в режиме оконечного оборудования (DTE), так и в режиме оборудования передачи данных (DCE). Сигналы модема в режиме DTE показаны ранее (см. Рисунок 34–1).

Назначение сигналов в режимах DTE и DCE представлено в таблице ниже.

| имах DTE и DCE |
|----------------|
| ıмах DTE и DC  |

| Сигнал    | Назначение                         |                                       |  |  |
|-----------|------------------------------------|---------------------------------------|--|--|
|           | Режим оконечного оборудования      | Режим оборудования передачи<br>данных |  |  |
| nUARTCTS  | Готов к передаче данных            | Запрос передачи данных                |  |  |
| nUARTDSR  | Источник данных готов              | Приемник данных готов                 |  |  |
| nUARTDCD  | Обнаружен информационный<br>сигнал | -                                     |  |  |
| nUARTRI   | Индикатор вызова                   | -                                     |  |  |
| nUARTCTS  | Запрос передачи данных             | Готов к передаче данных               |  |  |
| nUARTDTR  | Приемник данных готов              | Источник данных готов                 |  |  |
| nUARTOUT1 | -                                  | Обнаружен информационный сигнал       |  |  |
| nUARTOUT2 | -                                  | Индикатор вызова                      |  |  |

## 34.6.1 Аппаратное управление потоком данных

Программно активизируемый режим аппаратного управления потоком данных позволяет контролировать (приостанавливать и возобновлять) информационный обмен с помощью сигналов nUARTRTS и nUARTCTS. Рисунок 34–6 иллюстрирует взаимодействие двух устройств последовательной связи с аппаратным управлением потоком данных.



Рисунок 34–6 – Взаимодействие двух устройств последовательной связи с аппаратным управлением потоком данных

Если разрешено управление потоком данных по сигналу RTS, линия nUARTRTS переводится в активное состоянии только после того, как в FIFO буфере приема появляется заданное количество свободных элементов.

Если разрешено управление потоком данных по сигналу CTS, передача данных осуществляется только после перевода линии nUARTCTS в активное состояние.

Режим аппаратного управления потоком данных задается путем установки значений бит RTSEn и CTSEn в регистре управления UARTCR. Таблица 34-3 показывает необходимые установки для различных режимов управления потоком данных.

| CTSEn | RTSEn | Описание                                              |
|-------|-------|-------------------------------------------------------|
| 1     | 1     | Разрешено управление потоком данных по CTS и RTS      |
| 1     | 0     | Управления потоком данных осуществляется по линии CTS |
| 0     | 1     | Управления потоком данных осуществляется по линии RTS |
| 0     | 0     | Управления потоком данных запрещено                   |

Таблица 34-3 – Режимы управления потоком данных

Примечание — В случае если выбран режим управления потоком данных по RTS, программное обеспечение не может использовать бит RTSEn регистра UARTCR для проверки состояния линии RTS.

## 34.6.2 Управление потоком данных по линии RTS

Логика управления потоком данных по RTS использует данные о превышении пороговых уровней заполнения буфера FIFO приемника. В случае выбора режимов с управлением по RTS, сигнал на линии nUARTRTS переводится в активное состояние только после того, как в FIFO буфере приема появляется заданное количество свободных элементов. После достижения порогового уровня заполнения буфера приемника сигнал nUARTRTS снимается (переводится в пассивное состояние), указывая, таким образом, на отсутствие свободного места для сохранения принятых данных. При этом дальнейшая передача данных должна быть прекращена по завершении передачи текущего символа.

Обратно в активное состояние сигнал nUARTRTS переводится после считывания данных из приемного буфера FIFO в количестве, достаточном для того, чтобы заполнение буфера оказалось ниже порогового уровня.

В случае, если управление потоком данных по RTS запрещено, однако работа приемопередатчика UART разрешена, прием будет осуществляться до полного заполнения буфера FIFO, либо до завершения передачи данных.

# 34.6.3 Управление потоком данных по линии CTS

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

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

Если управление потоком данных по CTS запрещено, и при этом работа приемопередатчика UART разрешена – данные будут выдаваться до опустошения буфера FIFO передатчика.

# 34.7 Интерфейс прямого доступа к памяти

Модуль универсального асинхронного приемопередатчика оснащен интерфейсом подключения к контроллеру прямого доступа к памяти. Работа в данном режиме контролируется регистром управления DMA UARTDMACR.

Интерфейс DMA включает в себя следующие сигналы:

## Для приема:

- UARTRXDMASREQ запрос передачи отдельного символа, инициируется контроллером UART. Размер символа в режиме приема данных до 12 бит. Сигнал переводится в активное состояние в случае, если буфер FIFO приемника содержит по меньшей мере один символ.
- UARTRXDMABREQ запрос блочного обмена данными, инициируется модулем приемопередатчика. Сигнал переходит в активное состояние в случае, если заполнение буфера FIFO приемника превысило заданный порог. Порог программируется индивидуально для каждого буфера FIFO путем записи значения в регистр UARTIFLS.
- UARTRXDMACLR сброс запроса на DMA, инициируется модулем приемопередатчика с целью сброса принятого запроса. В случае, если был запрошен блочный обмен данными, сигнал сброса формируется в ходе передачи последнего символа данных в блоке.

## Для передачи:

- UARTTXDMASREQ запрос передачи отдельного символа, инициируется модулем приемопередатчика. Размер символа в режиме передачи данных – до восьми бит. Сигнал переводится в активное состояние в случае, если буфер FIFO передатчика содержит, по меньшей мере, одну свободную ячейку.
- UARTTXDMABREQ запрос блочного обмена данными, инициируется модулем приемопередатчика. Сигнал переводится в активное состояние в случае, если заполнение буфера FIFO передатчика ниже заданного

- порога. Порог программируется индивидуально для каждого буфера FIFO путем записи значения в регистр UARTIFLS.
- UARTTXDMACLR сброс запроса на DMA, инициируется контроллером DMA с целью сброса принятого запроса. В случае, если был запрошен блочный обмен данными, сигнал сброса формируется в ходе передачи последнего символа данных в блоке.

Сигналы блочного и одноэлементного обмена данными не являются взаимно исключающими, они могут быть инициированы одновременно. Например, в случае, если заполнение данными буфера приемника превышает пороговое значение, формируется как сигнал запроса одноэлементного обмена, так и сигнал запроса блочного обмена данными. В случае, если количество данных в буфере приема меньше порогового значения, формируется только запрос одноэлементного обмена. Это бывает полезно в ситуациях, при которых объем данных меньше размера блока. Пусть, например, нужно принять 19 символов, а порог заполнения буфера FIFO установлен равным четырем. Тогда контроллер DMA осуществит четыре передачи блоков по четыре символа, а оставшиеся три символа передаст в ходе трех одноэлементных обменов.

Примечание – Для оставшихся трех символов контроллер UART не может инициировать процедуру блочного обмена.

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

После снятия сигнала сброса модуль приемопередатчика вновь получает возможность сформировать запрос на DMA в случае выполнения описанных выше условий. Все запросы DMA снимаются после запрета работы приемопередатчика, а также в случае установки в ноль бита управления DMA TXDMAE или RXDMAE в регистре управления DMA UARTDMACR.

В случае запрета буферов FIFO устройство способно передавать и принимать только одиночные символы; как следствие, контроллер может инициировать DMA только в одноэлементном режиме. При этом модуль в состоянии формировать только сигналы управления DMA UARTRXDMASREQ и UARTTXDMASREQ. Для информации о запрете буферов FIFO см. описание регистра управления линией UARTLCR H.

Когда буферы FIFO включены, обмен данными может производиться в ходе как одноэлементных, так и блочных передач данных, в зависимости от установленной величины порога заполнения буферов и их фактического заполнения. Таблица 34-4 показывает значения параметров срабатывания запросов блочного обмена UARTRXDMABREQ и UARTTXDMABREQ в зависимости от порога заполнения буфера.

Таблица 34-4 – Параметры срабатывания запросов блочного обмена данными в режиме DMA

| Попосовини           | Длина блока обмена данными                            |                                                   |  |  |
|----------------------|-------------------------------------------------------|---------------------------------------------------|--|--|
| Пороговый<br>уровень | Буфер передатчика (количество<br>незаполненных ячеек) | Буфер приемника<br>(количество заполненных ячеек) |  |  |
| 1/8                  | 28                                                    | 4                                                 |  |  |
| 1/4                  | 24                                                    | 8                                                 |  |  |
| 1/2                  | 16                                                    | 16                                                |  |  |
| 3/4                  | 8                                                     | 24                                                |  |  |
| 7/8                  | 4                                                     | 28                                                |  |  |

В регистре управления DMA UARTDMACR предусмотрен бит DMAONERR, который позволяет запретить DMA от приемника в случае активного состояния линии прерывания по обнаружению ошибки UARTEINTR. При этом соответствующие линии запроса DMA – UARTRXDMASREQ и UARTRXDMABREQ переводятся в неактивное состояние (маскируются) до сброса UARTEINTR. На линии запроса DMA, обслуживающие передатчик, состояние UARTEINTR не влияет.

Ниже показаны временные диаграммы одноэлементного и блочного запросов DMA, в том числе действие сигнала DMACLR (Рисунок 34–7). Все сигналы должны быть синхронизированы с CPU\_CLK. В интересах ясности изложения предполагается, что синхронизация сигналов запроса DMA в контроллере DMA не производится.



Рисунок 34–7 – Временные диаграммы одноэлементного и блочного запросов DMA

# 34.8 Прерывания

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

Сигналы запроса на прерывание:

- UARTRXINTR прерывание от приемника;
- UARTTXINTR прерывание от передатчика;
- UARTRTINTR прерывание по таймауту приемника;
- UARTMSINTR прерывание по состоянию модема:
  - UARTRIINTR, изменение состояния линии nUARTRI;
  - UARTCTSINTR, изменение состояния линии nUARTCTS;
  - UARTDCDINTR, изменение состояния линии nUARTDCD;
  - UARTDSRINTR, изменение состояния линии nUARTDSR.
- UARTEINTR ошибка:
  - UARTOEINTR, переполнение буфера;
  - UARTBEINTR, прерывание приема разрыв линии;
  - UARTPEINTR, ошибка контроля четности;
  - UARTFEINTR, ошибка в структуре кадра.
- UARTINTR логическое ИЛИ сигналов UARTRXINTR, UARTTXINTR, UARTRTINTR, UARTMSINTR и UARTEINTR.

Каждый из независимых сигналов запроса на прерывание может быть маскирован путем установки соответствующего бита в регистре маски UARTIMSC. Установка бита в 1 разрешает соответствующее прерывание, в 0 – запрещает.

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

глобальной процедуры обработки, так и с помощью драйвера устройства, построенного по модульному принципу.

Прерывания от приемника и передатчика UARTRXINTR и UARTTXINTR выведены отдельно от прерываний по изменению состояния устройства. Это позволяет использовать сигналы запроса UARTRXINTR и UARTTXINTR для обеспечения чтения и записи данных согласованно с достижением заданного порога заполнения буферов FIFO приемника и передатчика.

Прерывание по обнаружению ошибке UARTEINTR формируется в случае возникновения той или иной ошибки приема данных. Предусмотрен ряд условий формирования признака ошибки.

Прерывание по состоянию модема представляет собой комбинацию признаков изменения отдельных линий состояния модема.

Признаки возникновения каждого из условий прерывания можно считать либо из регистра прерываний UARTRIS, либо из маскированного регистра прерываний UARTMIS.

#### 34.8.1 *UARTMSINTR*

Прерывание по состоянию модема возникает в случае изменения любой из линий состояний модема (nUARTCTS, nUARTDCD, nUARTDSR, nUARTRI). Сброс прерывания осуществляется путем записи 1 в соответствующий (в зависимости от линии состояния модема, вызвавшей прерывание) разряд регистра сброса прерывания UARTICR.

#### 34.8.2 UARTRXINTR

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

- буфер FIFO разрешён и его заполнение достигло заданного порогового значения. В этом случае линия прерывания переходит в высокое состояние. Сигнал прерывания переходит в низкое состояние после чтения данных из буфера приемника до тех пор, пока его заполнение не станет меньше порога, либо после сброса прерывания;
- буфер FIFO запрещен (имеет размер один символ), принят один символ данных. При этом линия прерывания переходит в высокое состояние. Сигнал прерывания переходит в низкое состояние после чтения одного байта данных, либо после сброса прерывания.

#### 34.8.3 UARTTXINTR

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

- буфер FIFO разрешён и его заполнение меньше или равно заданному пороговому значению. В этом случае линия прерывания переходит в высокое состояние. Сигнал прерывания переходит в низкое состояние после записи данных в буфера передатчика до тех пор, пока его заполнение не станет больше порога, либо после сброса прерывания;
- буфер FIFO запрещен (имеет размер один символ), данные в буферном регистре передатчика отсутствуют. При этом линия прерывания переходит в высокое состояние. Сигнал прерывания переходит в низкое состояние после записи одного байта данных, либо после сброса прерывания.

Для <u>занесения данных в буфер FIFO передатичка</u> необходимо записать данные в буфер либо перед разрешением работы приемопередатичка и прерываний, либо после разрешения работы приемопередатичка и прерываний.

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

#### 34.8.4 UARTRTINTR

Прерывание по таймауту приемника возникает в случае, если буфер FIFO приемника не пуст, и на вход приемника не поступало новых данных в течение периода времени, необходимого для передачи 32 бит. Прерывание по таймауту снимается либо после считывания данных из буфера приемника до его опустошения (или считывания одного байта в случае, если буфер FIFO запрещен), либо путем записи 1 в соответствующий бит регистра сброса прерывания UARTICR.

#### **34.8.5** *UARTEINTR*

Прерывание по обнаружению ошибки возникает в случае ошибки при приеме данных. Оно может быть вызвано рядом факторов:

- ошибка в структуре кадра;
- ошибка контроля четности;
- разрыв линии;
- переполнение буфера.

Причину возникновения прерывания можно определить, прочитав содержимое регистра прерываний UARTRIS, либо содержимое маскированного регистра прерываний UARTMIS.

Сброс прерывания осуществляется путем записи соответствующих бит в регистр сброса прерывания UARTICR. За прерываниями по обнаружению ошибки закреплены биты с 7 по 10.

#### **34.8.6 UARTINTR**

Все описанные сигналы запроса на прерывание скомбинированы в общую линию путем объединения по схеме ИЛИ сигналов UARTRXINTR, UARTTXINTR, UARTRTINTR, UARTMSINTR и UARTEINTR с учетом маскирования. Общий выход может быть подключен к системному контроллеру прерывания, что позволит ввести дополнительное маскирование запросов на уровне периферийных устройств.

#### 34.9 Программное управление модулем

#### 34.9.1 Общая информация

Следующая информация применима ко всем регистрам контроллера:

• Базовый адрес контроллера не фиксирован и может быть различным в разных системах. Смещение каждого регистра относительно базового адреса постоянно.

- Не следует пытаться получить доступ к зарезервированным или неиспользуемым адресам. Это может привести к непредсказуемому поведению модуля.
- За исключением специально оговоренных в настоящем документе случаев:
  - не следует изменять значения не определенных в документе разрядов регистров;
  - не следует использовать значения не определенных в документе разрядов регистров;
  - все биты регистров (за исключением специально оговоренных случаев, прим. перев) устанавливаются в значение 0 после сброса по включению питания или системного сброса.
- Столбец «Тип» (Таблица 34-5) определяет режим доступа к регистру в соответствии с обозначениями:
  - RW чтение и запись:
  - RO только чтение;
  - WO только запись.

# 34.9.2 Обобщенные данные о регистрах устройства

Данные о регистрах модуля универсального асинхронного приемопередатчика приведены в таблице ниже (Таблица 34-5).

Таблица 34-5 - Обобщенные данные о регистрах устройства

| Смещение   | Наименование | Тип | Значение<br>после сброса | Размер,<br>бит | Описание                        |
|------------|--------------|-----|--------------------------|----------------|---------------------------------|
| 0x40030000 | MDR_UART1    |     |                          |                | Контроллер UART1                |
| 0x40038000 | MDR_UART2    |     |                          |                | Контроллер UART2                |
| 0x400D0000 | MDR_UART3    |     |                          |                | Контроллер UART3                |
| 0x000      | DR           | RW  | 0x                       | 12/8           | MDR_UARTx->DR                   |
|            |              |     |                          |                | Регистр данных                  |
| 0x004      | RSR_ECR      | RW  | 0x0                      | 4/0            | MDR_UARTx->RSR_ECR              |
|            |              |     |                          |                | Регистр состояния приемника /   |
|            |              |     |                          |                | Сброс ошибки приемника          |
| 0x008-     |              |     |                          |                | Зарезервироавано                |
| 0x014      |              |     |                          |                |                                 |
| 0x018      | FR           | RO  | 0b-10010                 | 9              | MDR_UARTx->FR                   |
|            |              |     |                          |                | Регистр флагов                  |
| 0x01C      |              |     |                          |                | Зарезервироавано                |
| 0x020      | ILPR         | RW  | 0x00                     | 8              | MDR_UARTx->ILPR                 |
|            |              |     |                          |                | Регистр управления ИК обменом в |
|            |              |     |                          |                | режиме пониженного              |
|            |              |     |                          |                | энергопотребления               |
| 0x024      | IBRD         | RW  | 0x0000                   | 16             | MDR_UARTx->IBRD                 |
|            |              |     |                          |                | Целая часть делителя скорости   |
|            |              |     |                          |                | обмена данными                  |
| 0x028      | FBRD         | RW  | 0x00                     | 6              | MDR_UARTx->FBRD                 |
|            |              |     |                          |                | Дробная часть делителя скорости |
|            |              |     |                          |                | обмена данными                  |
| 0x02C      | LCR_H        | RW  | 0x00                     | 8              | MDR_UARTx->LCR_H                |
|            |              |     |                          |                | Регистр управления линией       |

| Смещение | Наименование | Тип | Значение<br>после сброса | Размер,<br>бит | Описание                       |
|----------|--------------|-----|--------------------------|----------------|--------------------------------|
| 0x030    | CR           | RW  | 0x0300                   | 16             | MDR_UARTx->CR                  |
|          |              |     |                          |                | Регистр управления             |
| 0x034    | IFLS         | RW  | 0x12                     | 6              | MDR_UARTx->IFLS                |
|          |              |     |                          |                | Регистр порога прерывания по   |
|          |              |     |                          |                | заполнению буфера FIFO         |
| 0x038    | IMSC         | RW  | 0x000                    | 11             | MDR_UARTx->IMSC                |
|          |              |     |                          |                | Регистр маски прерывания       |
| 0x03C    | RIS          | RO  | 0x00-                    | 11             | MDR_UARTx->RIS                 |
|          |              |     |                          |                | Регистр состояния прерываний   |
| 0x040    | MIS          | RO  | 0x00-                    | 11             | MDR_UARTx->MIS                 |
|          |              |     |                          |                | Регистр состояния прерываний с |
|          |              |     |                          |                | маскированием                  |
| 0x044    | ICR          | WO  | -                        | 11             | MDR_UARTx->ICR                 |
|          |              |     |                          |                | Регистр сброса прерывания      |
| 0x048    | DMACR        | RW  | 0x00                     | 3              | MDR_UARTx->DMACR               |
|          |              |     |                          |                | Регистр управления DMA         |

#### 34.9.3 *MDR UARTx->DR*

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

#### В ходе передачиданных:

Если буфер FIFO передатчика разрешен, то слово данных, записанное в рассматриваемый регистр, направляется в буфер FIFO передатчика.

В противном случае, записанное слово фиксируется в буферный регистр передатчика (последний элемент буфера FIFO).

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

#### В ходе приема данных:

Если буфер FIFO приемника разрешен, байт данных и четыре бита состояния (разрыв, ошибка формирования кадра, четность, переполнение) сохраняются в 12-битном буфере.

В противном случае байт данных и биты состояния записываются в буферный регистр (последний элемент буфера FIFO).

Полученные из линии связи байты данных считывается путем чтения из регистра UARTDR принятых данных совместно с соответствующими битами состояния. Информация о состоянии также может быть получена путем чтения регистра UARTRSR/UARTECR (Таблица 34-6).

Таблица 34-6 – Формат регистра UARTDR

| № бита | Сигнал | Назначение                                                  |
|--------|--------|-------------------------------------------------------------|
| 1512   |        | Резерв                                                      |
| 11     | OE     | Переполнение буфера приемника. Бит устанавливается в 1 в    |
|        |        | случае, если на вход приемника поступают данные, в то       |
|        |        | время, как буфер заполнен. Сбрасывается в 0 после того, как |
|        |        | в буфере появится свободное место                           |

| № бита | Сигнал | Назначение                                                 |
|--------|--------|------------------------------------------------------------|
| 10     | BE     | Разрыв линии. Устанавливается в 1 при обнаружении          |
| 10     |        | признака разрыва линии, то есть в случае наличия низкого   |
|        |        | логического уровня на входе приемника в течение времени,   |
|        |        |                                                            |
|        |        | большего, чем длительность передачи полного слова данных   |
|        |        | (включая стартовый, стоповый биты и бит проверки на        |
|        |        | четность). При включенном FIFO данная ошибка               |
|        |        | ассоциируется с последним символом, поступившим в буфер.   |
|        |        | В случае обнаружения разрыва линии в буфер загружается     |
|        |        | только один нулевой символ, прием данных возобновляется    |
|        |        | только после перехода линии в логическую 1 и последующего  |
|        |        | обнаружения корректного стартового бита                    |
| 9      | PE     | Ошибка контроля четности. Устанавливается в 1 в случае,    |
|        |        | если четность принятого символа данных не соответствует    |
|        |        | установкам бит EPS и SPS в регистре управления линией      |
|        |        | UARTLCR_H. При включенном FIFO данная ошибка               |
|        |        | ассоциируется с последним символом, поступившим в буфер.   |
| 8      | FE     | Ошибка в структуре кадра. Устанавливается в 1 в случае,    |
|        |        | если в принятом символе не обнаружен корректный стоповый   |
|        |        | бит (корректный стоповый бит равен 1). При включенном FIFO |
|        |        | данная ошибка ассоциируется с последним символом,          |
|        |        | поступившим в буфер                                        |
| 70     | DATA   | Принимаемые данные (чтение).                               |
|        |        | Передаваемые данные (запись)                               |

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

#### 34.9.4 MDR UARTx->RSR ECR

Регистр состояния приемника / сброса ошибки

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

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

Таблица 34-7 показывает назначение бит регистра UARTRSR/UARTECR.

Таблица 34-7 – Регистр UARTRSR/UARTECR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                                                                              |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                                                                                   |
| 74   |                | Резерв, при чтении результат не определен                                                                                                                                                                                    |
| 3    | OE             | Переполнение буфера приемника. Бит устанавливается в 1 в случае, если на вход приемника поступают данные, в то время как буфер заполнен. Сбрасывается в 0 после записи в регистр UARTECR. Содержимое буфера остается верным, |

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                         | так как перезаписан был только регистр сдвига. Центральный процессор должен считать данные для того, чтобы освободить буфер FIFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2                | BE                      | Разрыв линии. Устанавливается в 1 при обнаружении признака разрыва линии, то есть в случае наличия низкого логического уровня на входе приемника в течение времени, большего, чем длительность передачи полного слова данных (включая стартовый, стоповый биты и бит проверки на четность). Бит сбрасывается в 0 после записи в регистр UARTECR. При включенном FIFO данная ошибка ассоциируется с символом, находящемся на вершине буфера. В случае обнаружения разрыва линии в буфер загружается только один нулевой символ, прием данных возобновляется только после перехода линии в логическую 1 и последующего обнаружения корректного стартового бита |
| 1                | PE                      | Ошибка контроля четности. Устанавливается в 1 в случае, если четность принятого символа данных не соответствует установкам бит EPS и SPS в регистре управления линией UARTLCR_H (стр. 3-12). Бит сбрасывается в 0 после записи в регистр UARTECR. При включенном FIFO данная ошибка ассоциируется с символом, находящимся на вершине буфера                                                                                                                                                                                                                                                                                                                  |
| 0                | FE                      | Ошибка в структуре кадра. Устанавливается в 1 в случае, если в принятом символе не обнаружен корректный стоповый бит (корректный стоповый бит равен 1). Бит сбрасывается в 0 после записи в регистр UARTECR. При включенном FIFO данная ошибка ассоциируется с символом, находящимся на вершине буфера                                                                                                                                                                                                                                                                                                                                                       |

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

1 Перед чтением регистра состояния UARTRSR необходимо считать данные, принятые из линии, путем обращения к регистру данных UARTDR. Противоположная последовательность действий не допускается, так как регистр UARTRSR обновляет свое состояние только после чтения регистра UARTDR. Вместе с тем, информация о состоянии приемника может быть получена непосредственно из регистра данных UARTDR.

2 Запись в регистр UARTRSR/UARTECR любого кода сбрасывает признаки ошибок формирования кадра, проверки на четность, разрыва линии и переполнения буфера

## 34.9.5 *MDR\_UARTx->FR*

#### Регистр флагов

После сброса биты регистра флагов TXFF, RXFF и BUSY устанавливаются в 0, а биты TXFE и RXFE – в 1. В таблице ниже представлена информация о назначении бит регистра UARTFR.

Таблица 34-8 – Регистр UARTFR

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                                                                                  |
|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                                                                                       |
| 159  |                | Резерв. Не модифицируйте. При чтении заполняются нулями                                                                                                                                                                          |
| 8    | RI             | Инверсия линии nUARTRI                                                                                                                                                                                                           |
| 7    | TXFE           | Буфер FIFO передатчика пуст. Значение бита зависит от состояния бита FEN регистра управления линией UARTLCR_H. Если буфер FIFO запрещен, бит устанавливается в 1, когда буферный регистр передатчика пуст. В противном случае он |

| Nº   | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое                |
|------|----------------------------|----------------------------------------------------------------|
| бита | имя бита                   | описание назначения и принимаемых значений                     |
|      |                            | равен 1, если пуст буфер FIFO передатчика. Данный бит не дает  |
|      |                            | никакой информации о наличии данных в регистре сдвига          |
|      | DVEE                       | передатчика                                                    |
| 6    | RXFF                       | Буфер FIFO приемника заполнен. Значение бита зависит от        |
|      |                            | состояния бита FEN регистра управления линией UARTLCR_H.       |
|      |                            | Если буфер FIFO запрещен, бит устанавливается в 1, когда       |
|      |                            | буферный регистр приемника занят. В противном случае он        |
|      |                            | равен 1, если заполнен буфер FIFO приемника                    |
| 5    | TXFF                       | Буфер FIFO передатчика заполнен. Значение бита зависит от      |
|      |                            | состояния бита FEN регистра управления линией UARTLCR_H.       |
|      |                            | Если буфер FIFO запрещен, бит равен 1, когда буферный          |
|      |                            | регистр передатчика занят. В противном случае он равен 1, если |
|      |                            | заполнен буфер FIFO передатчика                                |
| 4    | RXFE                       | Буфер FIFO приемника пуст. Значение бита зависит от            |
|      |                            | состояния бита FEN регистра управления линией UARTLCR_H.       |
|      |                            | Если буфер FIFO запрещен, бит устанавливается в 1, когда       |
|      |                            | буферный регистр приемника пуст. В противном случае он равен   |
|      |                            | 1, если пуст буфер FIFO приемника                              |
| 3    | BUSY                       | UART занят. Бит равен 1 в случае, если контроллер передает в   |
|      |                            | линию данные. Бит остается установленным до тех пор, пока      |
|      |                            | данные, включая стоповые биты, не будут полностью переданы.    |
|      |                            | Кроме того, бит занятости устанавливается в 1 при наличии      |
|      |                            | данных в буфере FIFO передатчика, вне зависимости от           |
|      |                            | состояния приемопередатчика (даже если он запрещен)            |
| 2    | DCD                        | Инверсия линии nUARTDCD                                        |
| 1    | DSR                        | Инверсия линии nUARTDSR                                        |
| 0    | CTS                        | Инверсия линии nUARTCT                                         |

#### 34.9.6 MDR\_UARTx->ILPR

Регистр управления ИК обменом в режиме пониженного энергопотребления Этот восьмиразрядный регистр, доступный для чтения и записи, содержит значение коэффициента деления частоты UARTCLK, для формирования тактового сигнала IrLPBaud16. Назначение разрядов регистра показано в Таблица 34-9.

Требуемое значение коэффициента деления для формирования сигнала IrLPBaud16 вычисляется по формуле

ILPDVSR = F UARTCLK / F IrLPBaud16,

где номинальное значение частоты F IrLPBaud16 составляет 1,8432 МГц.

Коэффициент деления должен быть установлен таким образом, чтобы выполнялось соотношение:

1,42 МГц < F IrLPBaud16 < 2,12 МГц,

что, в свою очередь, гарантирует формирование кодеком импульсов данных с длительностью 1,41 – 2,11 мкс (в три раза длиннее периода сигнала IrLPBaud16).

# Таблица 34-9 – Регистр UARTILPR

| <b>№</b><br>бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                 |
|------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 70               | ILPDVSR                    | Коэффициент деления частоты UARTCLK, для формирования тактового сигнала IrLPBaud16. После сброса устанавливается в 0. Примечание – Коэффициент 0 – запрещенное значение. В случае его установки импульсы IrLPBaud16 формироваться не будут |

Примечание – В интересах подавления помех при работе в режиме IrDA с пониженным энергопотреблением кодек игнорирует поступающие на вход SIRIN импульсы с длительностью, меньшей трех периодов сигнала IrLPBaud16.

#### 34.9.7 MDR UARTx->IBRD

Регистр целой части делителя скорости передачи данных

Назначение бит регистра UARTBIRD показано ниже.

# Таблица 34-10 – Регистр UARTBIRD

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 150       | BAUDDIV_INT             | Целая часть коэффициента деления частоты для                                               |
|           |                         | формирования тактового сигнала передачи данных. После сброса устанавливается в 0           |

## 34.9.8 MDR UARTx->FBRD

Регистр дробной части делителя скорости передачи данных, Таблица 34-11 показывает назначение бит регистра.

## Таблица 34-11 – Регистр UARTBFRD

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 50        | BAUDDIV_FRAC            | Дробная часть коэффициента деления частоты для                                             |
|           |                         | формирования тактового сигнала передачи данных. После                                      |
|           |                         | сброса устанавливается в 0                                                                 |

Коэффициент деления вычисляется по формуле

BAUDDIV = FUARTCLK/(16 \* Baud\_rate),

где FUARTCLK – тактовая частота контроллера UART, Baud\_rate – требуемая скорость передачи данных.

Коэффициент BAUDDIV состоит из целой и дробной частей – BAUDDIV\_INT и BAUDDIV FRAC, соответственно.

Примечания:

1. изменения содержимого регистров UARTIBRD и UARTFBRD вступают в силу только после завершения передачи и приема текущего символа данных;

- 2. минимальный допустимый коэффициент деления 1, максимальный 65535 (2<sup>16</sup> 1). Таким образом, значение UARTIBRD, равное 0, является недопустимым, при этом значение регистра UARTFBRD игнорируется;
- 3. аналогично, при UARTIBRD равном 65535 (0xFFFF), значение UARTFBRD не может быть больше нуля. Невыполнение этого условия приведет к прерыванию приема или передачи.

Далее приведен пример вычисления коэффициента деления.

#### Пример: Вычисление коэффициента деления

Пусть требуемая скорость передачи данных составляет 230400 бит/с, частота тактового сигнала UARTCLK равна 4 МГц. Тогда:

Коэффициент деления = (4\*106)/(16\*230400) = 1,085

Таким образом, BRDI = 1, BRDF = 0,085

Следовательно, значение, записываемое в регистр UARTBFRD, равно m = integer((0.085\*64)+0.5) = 5

Реальное значение коэффициента деления = 1+5/64 = 1,078

Реальная скорость передачи данных = (4\*106)/(16\*1,078) = 231911 бит/с

Ошибка установки скорости = (231911-230400)/230400 \* 100 % = 0,656 %

Максимальная ошибка установки скорости передачи данных с использованием шестиразрядного регистра UARTBFRD = 1/64\*100 % = 1,56 %. Такая ошибка возникает в случае m = 1, при этом разница накапливается в течение 64 тактовых интервалов.

В следующей таблице (Таблица 34-12) представлены значения коэффициента деления для типичных скоростей передачи данных при частоте UARTCLK = 7,3728 МГц. При таких параметрах дробная часть коэффициента деления не используется, следовательно, в регистр UARTFBRD должен быть записан ноль.

Таблица 34-12 – Коэффициенты деления при частоте UARTCLK = 7.3728 МГц

| Коэффициент деления | Скорость передачи данных |
|---------------------|--------------------------|
| 0x0001              | 460800                   |
| 0x0002              | 230400                   |
| 0x0004              | 115200                   |
| 0x0006              | 76800                    |
| 0x0008              | 57600                    |
| 0x000C              | 38400                    |
| 0x0018              | 19200                    |
| 0x0020              | 14400                    |
| 0x0030              | 9600                     |
| 0x00C0              | 2400                     |
| 0x0180              | 1200                     |
| 0x105D              | 110                      |

В таблице ниже приведены значения коэффициента деления для типичных скоростей передачи данных при частоте UARTCLK = 4 МГц.

Таблица 34-13 – Коэффициенты деления при частоте UARTCLK = 4 МГц

| Целая часть | Дробная часть | Требуемая<br>скорость | Реальная<br>скорость | Ошибка, % |
|-------------|---------------|-----------------------|----------------------|-----------|
| 0x001       | 0x05          | 230400                | 231911               | 0,656     |
| 0x002       | 0x0B          | 115200                | 115101               | 0,086     |

| Целая часть | Дробная часть | Требуемая<br>скорость | Реальная<br>скорость | Ошибка, % |
|-------------|---------------|-----------------------|----------------------|-----------|
| 0x003       | 0x10          | 76800                 | 76923                | 0,160     |
| 0x006       | 0x21          | 38400                 | 38369                | 0,081     |
| 0x011       | 0x17          | 14400                 | 14401                | 0,007     |
| 0x068       | 0x0B          | 2400                  | 2400                 | ~ 0       |
| 0x8E0       | 0x2F          | 110                   | 110                  | ~ 0       |

## 34.9.9 MDR\_UARTx->LCR\_H

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

Данный регистр обеспечивает доступ к разрядам с 29 по 22 регистра UARTLCR. При сбросе все биты регистра UARTLCR\_Н обнуляются.

Таблица 34-14 показывает назначение разрядов регистра UARTLCR\_H.

Таблица 34-14 - Регистр UARTLCR\_H

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                                                                                                |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                                                                                                                                                                                                     |
| 158  |                | Резерв. Не модифицируйте. При чтении выдаются нули.                                                                                                                                                                                            |
| 7    | SPS            | Передача бита четности с фиксированным значением.  0 – запрещена;  1 – на месте бита четности передается инверсное значение                                                                                                                    |
|      |                | бита EPS, оно же проверяется при приеме данных. (При EPS=0 на месте бита четности передается 1, при EPS=1 – передается 0).                                                                                                                     |
|      |                | Значение бита SPS не играет роли в случае, если битом PEN формирование и проверка бита четности запрещен                                                                                                                                       |
| 65   | WLEN           | Длина слова – количество передаваемых или принимаемых информационных бит в кадре: 0b11 – 8 бит 0b10 – 7 бит                                                                                                                                    |
|      |                | 0b01 – 6 бит<br>0b00 – 5 бит                                                                                                                                                                                                                   |
| 4    | FEN            | Разрешение работы буфера FIFO приемника и передатчика.<br>0 – запрещено;<br>1 – разрешено                                                                                                                                                      |
| 3    | STP2           | Режим передачи двух стоповых бит.  0 – один стоповый бит;  1 – два стоповых бита. Приемник не проверяет наличие дополнительного стопового бита в кадре                                                                                         |
| 2    | EPS            | Четность/нечетность.  0 – бит четности дополняет количество единиц в информационной части кадра до нечетного;  1 – до четного числа. Значение бита EPS не играет роли в случае, если битом PEN формирование и проверка бита четности запрещена |
| 1    | PEN            | Разрешение проверки четности.  0 – кадр не содержит бита четности;  1 – бит четности передается в кадре и проверяется при приеме данных                                                                                                        |

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------------------|-------------------------|--------------------------------------------------------------------------------------------|
| 0                | BRK                     | Разрыв линии. Если этот бит установлен в 1, то по                                          |
|                  |                         | завершении передачи текущего символа на выходе                                             |
|                  |                         | UARTTXD устанавливается низкий уровень сигнала. Для                                        |
|                  |                         | правильного выполнения этой операции программное                                           |
|                  |                         | обеспечение должно обеспечить передачу сигнала разрыва                                     |
|                  |                         | в течение, как минимум, времени передачи двух                                              |
|                  |                         | информационных кадров. В нормальном режиме                                                 |
|                  |                         | функционирования бит должен быть установлен в 0                                            |

Содержимое регистров UARTLCR\_H, UARTIBRD и UARTFBRD совместно образует общий 30-разрядный регистр UARTLCR, который обновляется по стробу, формируемому при записи в UARTLCR\_H. Таким образом, для того, чтобы изменение параметров коэффициента деления частоты обмена данными вступило в силу, после изменения значения регистров UARTIBRD и/или UARTFBRD необходимо осуществить запись данных в регистр UARTLCR H.

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

- 1. Изменение значений трех регистров можно осуществить корректно двумя способами:
  - запись UARTIBRD, запись UARTFBRD, запись UARTLCR\_H;
  - запись UARTFBRD, запись UARTIBRD, запись UARTLCR H.
- 2 Для того, чтобы изменить значение лишь одного из регистров (UARTIBRD или UARTFBRD) необходимо выполнить следующий шаг:
  - запись UARTIBRD (или UARTFBRD), запись UARTLCR H.

Таблица 34-15 показывает таблицу истинности для бит управления контролем четности PEN, EPS и SPS регистра управления линией UARTLCR H.

Таблица 34-15 – Управление режимом контроля четности

| PEN | EPS | SPS | Бит контроля четности            |
|-----|-----|-----|----------------------------------|
| 0   | Χ   | Х   | Не передается, не проверяется    |
| 1   | 1   | 0   | Проверка четности слова данных   |
| 1   | 0   | 0   | Проверка нечетности слова данных |
| 1   | 0   | 1   | Бит четности постоянно равен 1   |
| 1   | 1   | 1   | Бит четности постоянно равен 0   |

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

- 1 Регистры UARTLCR H, UARTIBRD и UARTFBRD не должны изменяться:
- при разрешенной работе приемопередатчика;
- во время завершения приема или передачи данных в процессе остановки (перевода в запрещенное состояние) приемопередатчика.
  - 2 Целостность данных в буферах FIFO не гарантируется в следующих случаях:
  - после установки бита разрыва линии BRK;
- если программное обеспечение произвело остановку приемопередатчика при наличии данных в буферах FIFO после его повторного перевода в разрешенное состояние.

#### 34.9.10 MDR UARTx->CR

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

После сброса все биты регистра управления, за исключением бит 9 и 8 устанавливаются в нулевое состояние. Биты 9 и 8 устанавливаются в единичное состояние.

Назначение разрядов регистра управления показано в следующей таблице.

Таблица 34-16 – Регистр управления UARTCR

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                           |
|-----------|-------------------------|----------------------------------------------------------------------------------------------------------------------|
| 15        | CTSEn                   | Разрешение управления потоком данных по CTS.                                                                         |
|           |                         | 1 – разрешено, данные передаются в линию только при                                                                  |
| 4.4       | DTOE:-                  | активном значении сигнала nUARTCTS.                                                                                  |
| 14        | RTSEn                   | Разрешение управления потоком данных по RTS.  1 – разрешено. Запрос данных от внешнего устройства осу-               |
|           |                         | т – разрешено. Запрос данных от внешнего устроиства осу-<br>ществляется только при наличии свободного места в буфере |
|           |                         | FIFO приемника                                                                                                       |
| 13        | Out2                    | Инверсия сигнала на линии состояния модема nUARTOut2. В                                                              |
|           |                         | режиме оконечного оборудования (DTE) эта линия может                                                                 |
|           |                         | использоваться в качестве линии «сигнал вызова» (RI)                                                                 |
| 12        | Out1                    | Инверсия сигнала на линии состояния модема nUARTOut1. В                                                              |
|           |                         | режиме оконечного оборудования (DTE) эта линия может                                                                 |
|           |                         | использоваться в качестве линии «обнаружен информационный сигнал» (DCD)                                              |
| 11        | RTS                     | Инверсия сигнала на линии состояния модема nUARTRTS                                                                  |
|           | DTR                     |                                                                                                                      |
| 10        |                         | Инверсия сигнала на линии состояния модема nUARTDTR                                                                  |
| 9         | RXE                     | Прием разрешен. Установка бита в 1 разрешает работу                                                                  |
|           |                         | приемника. Прием данных осуществляется либо по интерфейсу асинхронного последовательного обмена, либо                |
|           |                         | по интерфейсу ИК обмена SIR, в зависимости от значения                                                               |
|           |                         | бита SIREN.                                                                                                          |
|           |                         | В случае перевода приемопередатчика в запрещенное                                                                    |
|           |                         | состояние в ходе приема данных, он завершает прием                                                                   |
|           |                         | текущего символа перед остановкой                                                                                    |
| 8         | TXE                     | Передача разрешена. Установка бита в 1 разрешает работу                                                              |
|           |                         | передатчика. Передача осуществляется либо по интерфейсу асинхронного последовательного обмена, либо по               |
|           |                         | интерфейсу ИК обмена SIR, в зависимости от значения бита                                                             |
|           |                         | SIREN.                                                                                                               |
|           |                         | В случае перевода приемопередатчик в запрещенное                                                                     |
|           |                         | состояние в ходе передачи данных, он завершает передачу                                                              |
|           | 1.05                    | текущего символа: перед остановкой                                                                                   |
| 7         | LBE                     | 0 – запрещено;                                                                                                       |
|           |                         | 1 – шлейф разрешен.<br>В режиме разрешенного шлейфа:                                                                 |
|           |                         | Если установлены бит SIREN=1 и бит регистра управления                                                               |
|           |                         | тестированием UARTTCR SIRTEST=1, то сигнал с выхода                                                                  |
|           |                         | кодека nSIROUT инвертируется и подается на вход кодека                                                               |
|           |                         | SIRIN. Бит SIRTEST устанавливается в 1 для того, чтобы                                                               |
|           |                         | вывести устройство из полудуплексного режима, характерного                                                           |
|           |                         | для интерфейса SIR. После окончания тестирования по                                                                  |
|           |                         | шлейфу бит SIRTEST должен быть установлен в 0.<br>Если бит SIRTEST=0, то выходная линия передатчика                  |
|           |                         | Если оит SIRTEST=0, то выходная линия передатчика<br>  UARTTXD коммутируется на вход приемника UARTRXD.              |
|           |                         | Как в режиме SIR, так и в режиме UART, выходные линии                                                                |
|           |                         | состояния модема коммутируются на соответствующие                                                                    |
|           |                         | входные линии.                                                                                                       |
|           |                         | После сброса бит устанавливается в 0                                                                                 |
| 63        |                         | Резерв. Не модифицируйте. При чтении выдаются нули.                                                                  |

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                          |
|-----------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2         | SIRLP                   | Выбор режима ИК обмена с пониженным энергопотреблением:  0 – длительность импульсов данных равна 3/16 длительности передачи бита;  1 – длительность импульсов данных равна трем тактам сигнала IrLPBaud16 вне зависимости от выбранной скорости передачи данных. Выбор этого режима снижает энергопотребление, однако может привести к уменьшению дальности связи                                                   |
| 1         | SIREN                   | Разрешение работы кодека ИК передачи данных IrDA SIR:  0 – запрещено. Сигнал nSIROUT находится в низком состоянии, данные на входе SIRIN не обрабатываются.  1 – разрешено. Данные передаются на выход nSIROUT и принимаются с входа SIRIN. Линия UARTTXD находится в высоком состоянии. Данные на входе UARTRXD и линиях состояния модема не обрабатываются.  В случае, если UARTEN=0 значение бита не играет роли |
| 0         | UARTEN                  | Разрешение работы приемопередатчика:  0 – работа запрещена. Перед остановкой завершается прием и/или передача обрабатываемого в текущий момент символа.  1 – работа разрешена. Производится обмен данными либо по линиям асинхронного обмена, либо по линиям ИК обмена SIR, в зависимости от состояния бита SIREN                                                                                                   |

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

- 1 Для того, чтобы разрешить передачу данных, необходимо установить в логическую 1 биты ТХЕ и UARTEN. Аналогично, для разрешения приема данных необходимо установить в 1 биты RXE и UARTEN.
- 2 Рекомендуется следующая последовательность действий для программирования регистров управления:
  - остановите работу приемопередатчика;
  - дождитесь окончания приема и/или передачи текущего символа данных;
  - сбросьте буфер передатчика путем установки бита FEN регистра UARTLCR Н в 0;
  - измените настройки регистра UARTCR;
  - возобновите работу приемопередатчика.

#### 34.9.11 *MDR UARTx->IFLS*

Регистр порога прерывания по заполнению буфера FIFO

Данный регистр используется для установки порогового значения заполнения буферов передатчика и приемника, по достижению которых генерируется сигнал прерывания UARTTXINTR или UARTRXINTR, соответственно. Прерывание генерируется в момент перехода величины заполнения буфера через заданное значение.

После сброса в регистре устанавливается порог, соответствующий заполнению половины буфера. Формат регистра UARTIFLS и значения его бит представлены в таблице.

Таблица 34-17 - Регистр UARTIFLS

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое               |
|------|----------------|---------------------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений                    |
| 31   |                | Резерв. Не модифицируйте. При чтении выдаются нули.           |
| 6    |                |                                                               |
| 53   | RXIFLSEL       | Порог прерывания по заполнению буфера приемника:              |
|      |                | b000 = буфер заполнен на 1/8                                  |
|      |                | b001 = буфер заполнен на 1/4                                  |
|      |                | b010 = буфер заполнен на 1/2                                  |
|      |                | b011 = буфер заполнен на 3/4                                  |
|      |                | b100 = буфер заполнен на 7/8                                  |
|      |                | b101-b111 = резерв                                            |
| 20   | TXIFLSEL       | Порог прерывания по заполнению буфера передатчика:            |
|      |                | b000 = буфер заполнен на 1/8                                  |
|      |                | b001 = буфер заполнен на 1/4                                  |
|      |                | b010 = буфер заполнен на 1/2                                  |
|      |                | b011 = буфер заполнен на 3/4                                  |
|      |                | b100 = буфер заполнен на 7/8                                  |
|      |                | b101-b111 = резерв;                                           |
|      |                | Также стоит помнить, что в случае если сдвиговый регистр      |
|      |                | передатчика пуст, то слово, записанное в FIFO, будет сразу же |
|      |                | переписано в сдвиговый регистр. Следовательно, для            |
|      |                | генерирования события прерывания от передатчика блока         |
|      |                | UART необходимо произвести запись в FIFO такого количества    |
|      |                | слов, которое превысит установленный порог хотя бы на одно    |
|      |                | слово с учетом описанного случая.                             |

## 34.9.12 MDR\_UARTx->IMSC

Регистр установки сброса маски прерывания

При чтении выдается текущее значение маски. При записи производится установка или сброс маски на соответствующее прерывание.

После сброса все биты регистра маски устанавливаются в нулевое состояние. Назначение бит регистра UARTIMSC показано в Таблица 34-18.

Таблица 34-18 - Регистр UARTIMSC

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3111      |                         | Зарезервировано.                                                                           |
|           |                         | Не модифицируйте. При чтении выдаются нули                                                 |
| 10        | OEIM                    | Маска прерывания по переполнению буфера UARTOEINTR:                                        |
|           |                         | 1 – установлена;                                                                           |
|           |                         | 0 – сброшена                                                                               |
| 9         | BEIM                    | Маска прерывания по разрыву линии UARTBEINTR:                                              |
|           |                         | 1 – установлена;                                                                           |
|           |                         | 0 – сброшена                                                                               |
| 8         | PEIM                    | Маска прерывания по ошибке контроля четности                                               |
|           |                         | UARTPEINTR:                                                                                |
|           |                         | 1 – установлена;                                                                           |
|           |                         | 0 – сброшена                                                                               |
| 7         | FEIM                    | Маска прерывания по ошибке в структуре кадра                                               |
|           |                         | UARTFEINTR:                                                                                |
|           |                         | 1 – установлена;                                                                           |
|           |                         | 0 – сброшена                                                                               |

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое     |
|------|----------------|-----------------------------------------------------|
| бита | имя бита       | описание назначения и принимаемых значений          |
| 6    | RTIM           | Маска прерывания по таймауту приема данных          |
|      |                | UARTRTINTR:                                         |
|      |                | 1 – установлена;                                    |
|      |                | 0 – сброшена                                        |
| 5    | TXIM           | Маска прерывания от передатчика UARTTXINTR.         |
|      |                | 1 – установлена;                                    |
|      |                | 0 – сброшена                                        |
| 4    | RXIM           | Маска прерывания от приемника UARTRXINTR.           |
|      |                | 1 – установлена;                                    |
|      |                | 0 – сброшена                                        |
| 3    | DSRMIM         | Маска прерывания UARTDSRINTR по изменению состояния |
|      |                | линии nUARTDSR:                                     |
|      |                | 1 – установлена;                                    |
|      |                | 0 – сброшена                                        |
| 2    | DCDMIM         | Маска прерывания UARTDCDINTR по изменению состояния |
|      |                | линии nUARTDCD:                                     |
|      |                | 1 – установлена;                                    |
|      |                | 0 – сброшена                                        |
| 1    | CTSMIM         | Маска прерывания UARTCTSINTR по изменению состояния |
|      |                | линии nUARTCTS:                                     |
|      |                | 1 – установлена;                                    |
|      |                | 0 – сброшена                                        |
| 0    | RIMIM          | Маска прерывания UARTRIINTR по изменению состояния  |
|      |                | линии nUARTRI:                                      |
|      |                | 1 – установлена;                                    |
|      |                | 0 – сброшена                                        |

## 34.9.13 *MDR\_UARTx->RIS*

Регистр состояния прерываний

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

Предупреждение. После сброса все биты регистра, за исключением бит прерывания по состоянию модема (биты с 3 по 0), устанавливаются в 0. Значение бит прерывания по состоянию модема после сброса не определено.

Назначение бит регистра UARTRIS представлено в следующей таблице.

Таблица 34-19 – Регистр UARTRIS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3111      |                         | Зарезервировано.<br>Не модифицируйте. При чтении выдаются нули                             |
| 10        | OERIS                   | Состояние прерывания по переполнению буфера UARTOEINTR                                     |
| 9         | BERIS                   | Состояние прерывания по разрыву линии UARTBEINTR                                           |
| 8         | PERIS                   | Состояние прерывания по ошибке контроля четности UARTPEINTR                                |
| 7         | FERIS                   | Состояние прерывания по ошибке в структуре кадра UARTFEINTR                                |

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 6         | RTRIS                   | Cостояние прерывания по таймауту приема данных<br>UARTRTINTR                               |
|           |                         | Примечание - Бит RTRIS может быть установлен только при                                    |
|           |                         | установленной маске прерывания по таймауту приема                                          |
|           |                         | данных UARTRTINTR в регистре UARTIMSC. Это вызвано                                         |
|           |                         | тем, что сигнал маски прерывания по таймауту                                               |
|           |                         | используется в качестве разрешения перехода в режим                                        |
|           |                         | пониженного энергопотребления. Чтение состояния                                            |
|           |                         | прерывания по таймауту из регистров UARTMIS и UARTRIS                                      |
|           |                         | приводит к одинаковым результатам.                                                         |
| 5         | TXRIS                   | Состояние прерывания от передатчика UARTTXINTR                                             |
| 4         | RXRIS                   | Состояние прерывания от приемника UARTRXINTR                                               |
| 3         | DSRRMIS                 | Cостояние прерывания UARTDSRINTR по изменению линии nUARTDSR                               |
| 2         | DCDRMIS                 | Состояние прерывания UARTDCDINTR по изменению линии nUARTDCD                               |
| 1         | CTSRMIS                 | Cостояние прерывания UARTCTSINTR по изменению линии nUARTCTS                               |
| 0         | RIRMIS                  | Cостояние прерывания UARTRIINTR по изменению линии nUARTRI                                 |

#### 34.9.14 *MDR\_UARTx->MIS*

Регистр маскированного состояния прерываний

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

После сброса все биты регистра, за исключением бит прерывания по состоянию модема (биты с 3 по 0), устанавливаются в 0. Значение бит прерывания по состоянию модема после сброса не определено.

Назначение бит регистра UARTMIS представлено в таблице ниже.

Таблица 34-20 - Регистр UARTMIS

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3111      |                         | Зарезервировано.<br>Не модифицируйте. При чтении выдаются нули                             |
| 10        | OEMIS                   | Маскированное состояние прерывания по переполнению буфера UARTOEINTR                       |
| 9         | BEMIS                   | Маскированное состояние прерывания по разрыву линии UARTBEINTR                             |
| 8         | PEMIS                   | Маскированное состояние прерывания по ошибке контроля четности UARTPEINTR                  |
| 7         | FEMIS                   | Маскированное состояние прерывания по ошибке в<br>структуре кадра UARTFEINTR               |
| 6         | RTMIS                   | Маскированное состояние прерывания по таймауту приема данных UARTRTINTR                    |
| 5         | TXMIS                   | Маскированное состояние прерывания от передатчика UARTTXINTR                               |
| 4         | RXMIS                   | Маскированное состояние прерывания от приемника UARTRXINTR                                 |

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3         | DSRMMIS                 | Маскированное состояние прерывания UARTDSRINTR по изменению линии nUARTDSR                 |
| 2         | DCDMMIS                 | Маскированное состояние прерывания UARTDCDINTR по изменению линии nUARTDCD                 |
| 1         | CTSMMIS                 | Маскированное состояние прерывания UARTCTSINTR по изменению линии nUARTCTS                 |
| 0         | RIMMIS                  | Маскированное состояние прерывания UARTRIINTR по изменению линии nUARTRI                   |

## 34.9.15 *MDR\_UARTx->ICR*

Регистр сброса прерываний

Этот регистр доступен только для записи и предназначен для сброса признака прерывания по заданному событию путем записи 1 в соответствующий бит. Запись нуля в любой из разрядов регистра игнорируется.

Назначение бит регистра UARTICR представлено в таблице.

Таблица 34-21 - Регистр UARTICR

| №<br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----------|-------------------------|--------------------------------------------------------------------------------------------|
| 3111      |                         | Зарезервировано.                                                                           |
|           |                         | Не модифицируйте. При чтении выдаются нули                                                 |
| 10        | OEIC                    | Сброс прерывания по переполнению буфера UARTOEINTR                                         |
| 9         | BEIC                    | Сброс прерывания по разрыву линии UARTBEINTR                                               |
| 8         | PEIC                    | Сброс прерывания по ошибке контроля четности<br>UARTPEINTR                                 |
| 7         | FEIC                    | Сброс прерывания по ошибке в структуре кадра UARTFEINTR                                    |
| 6         | RTIC                    | Сброс прерывания по таймауту приема данных<br>UARTRTINTR                                   |
| 5         | TXIC                    | Сброс прерывания от передатчика UARTTXINTR                                                 |
| 4         | RXIC                    | Сброс прерывания от приемника UARTRXINTR                                                   |
| 3         | DSRMIC                  | Сброс прерывания UARTDSRINTR по изменению линии nUARTDSR                                   |
| 2         | DCDMIC                  | Сброс прерывания UARTDCDINTR по изменению линии nUARTDCD                                   |
| 1         | CTSMIC                  | Сброс прерывания UARTCTSINTR по изменению линии nUARTCTS                                   |
| 0         | RIMIC                   | Сброс прерывания UARTRIINTR по изменению линии nUARTRI                                     |

## 34.9.16 MDR\_UARTx->DMACR

Регистр управления прямым доступом к памяти

Регистр доступен по чтению и записи. После сброса все биты регистра обнуляются.

Назначение бит регистра UARTDMACR представлено в таблице.

# Таблица 34-22 – Регистр UARTDMACR

| <b>№</b><br>бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                             |
|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 313              |                         | Зарезервировано.<br>Не модифицируйте. При чтении выдаются нули                                                                                         |
| 2                | DMAONERR                | Если бит установлен в 1, то в случае возникновения прерывания по обнаружению ошибки блокируются запросы DMA от приемника UARTRXDMASREQ и UARTRXDMABREQ |
| 1                | TXDMAE                  | Использование DMA при передаче. Если бит установлен в 1, то разрешено формирование запросов DMA для обслуживания буфера FIFO передатчика               |
| 0                | RXDMAE                  | Использование DMA при приеме. Если бит установлен в 1, то разрешено формирование запросов DMA для обслуживания буфера FIFO приемника                   |

# 35 Контроллер SDIO

Контроллер SDIO – специализированный контроллер для работы с картами памяти SD и разрядностью шины данных от 1 до 4 бит. Поддерживается работа контроллера как в режиме ведущего (хоста), так и в режиме ведомого (карты памяти).

#### 35.1 Описание функционирования контроллера

# 35.1.1 Передача команды (по спецификации SDIO)

Для передачи команды по интерфейсу SDIO следует настроить режим работы контроллера (регистр SD\_CR), заполнить регистр команд (SD\_CMDDR), обнулить регистр контрольной суммы (SD\_CMDCRC), задать количество бит которые надо передать по линии команд(регистр SD\_CMDtransfer), а затем выставить бит WORK2 в «1». Формат передаваемой команды по спецификации SDIO представлен ниже (Рисунок 35–1).

При заполнении FIFO буфера команд следует учитывать, что команда передается старшим битом младшего байта вперед. Младший байт должен быть формата 0b01xxxxxx.



Рисунок 35–1 – Формат передаваемой команды по спецификации SDIO в режиме ведущего

Последовательность действий для передачи команды:

- включить контроллер SDIO (бит CR\_SDE);
- если бит WORK2 установлен в «1», то следует либо дождаться окончания передачи прошлой команды, либо вручную сбросить этот бит;
- настроить направление передачи команды (бит DIRCMD) и установить бит ожидания стартового бита в линии CMD (бит SBITCMD);
- заполнить регистр команд;
- инициализировать нулевым значением регистр контрольной суммы линии команд;
- задать длину передаваемой команды, с учетом стартового бита, CRC и стопового бита (т.е. по спецификации SDIO 48 бит);
- установить бит WORK2 в «1».

Пример инициализации передачи команды в соответствии со спецификацией SDIO:

```
SDIO->SD_CR = SDIO_SD_CR_SDE; /* SDIO ON, Master */
do { /* Wait while CmdActive bit is set */
SDIO->SD_CR &= ~SDIO_SD_CR_WORK2; /* Reset Work2 */
```

```
} while (SDIO->SD_CR & SDIO_SD_CR_WORK2);
SDIO->SD CR |= SDIO SD CR DIRCMD |
SDIO_SD_CR_SBITCMD;
                            /* Command TX & wait start bit */
SDIO->SD CMDDR =
                       ((idcmd | 0x40) & 0x0000007F) |
                       (arg>>16 & 0x0000FF00) |
                             & 0x00FF0000) |
                       (arg
                       (arg<<16 & 0xFF000000);/* Set the command + argument */
SDIO->SD\_CMDDR = arg \& 0x000000FF;
                                                    /* Set the argument */
SDIO->SD CMDCRC = 0x000000000:
                                              /* Clear CRC */
SDIO->SD CMDtransfer = 48;
                                              /* Command length */
                                              /* Initiate command transaction */
SDIO->SD_CR |= SDIO_SD_CR_WORK2;
```

# 35.1.2 Прием команды (по спецификации SDIO)

Для приема команды по интерфейсу SDIO следует настроить режим работы контроллера (регистр SD\_CR), обнулить регистр контрольной суммы (SD\_CMDCRC), задать количество бит которые надо принять по линии команд(регистр SD\_CMDtransfer), а затем выставить бит WORK2 в «1». Формат принимаемой команды по спецификации SDIO представлен ниже (Рисунок 35–2).



Рисунок 35–2 – Формат принимаемой команды по спецификации SDIO в режиме ведущего

Последовательность действий при приеме команды:

- включить контроллер SDIO (бит CR SDE);
- если бит WORK2 установлен в «1», то следует либо дождаться окончания передачи прошлой команды, либо вручную сбросить этот бит;
- настроить направление передачи команды (бит DIRCMD) и установить бит ожидания стартового бита в линии CMD (бит SBITCMD);
- инициализировать нулевым значением регистр контрольной суммы линии команд;
- задать длину ожидаемой команды, с учетом стартового бита, CRC и стопового бита (т.е. по спецификации SDIO 48 бит или 136 бит);
- установить бит WORK2 в «1».

Пример инициализации приема команды в соответствии со спецификацией SDIO:

SDIO->SD CR = SDIO SD CR CLKOE |

```
SDIO SD CR SDE:
                                  /* SDIO ON & Master */
                                              /* Wait while CmdActive bit is set */
do {
SDIO->SD_CR &= ~SDIO_SD_CR_WORK2; /* Reset Work2 */
} while (SDIO->SD CR & SDIO SD CR WORK2);
SDIO->SD_CR &= ~SDIO_SD_CR_DIRCMD;
                                              /* Command RX */
SDIO->SD_CR |= SDIO_SD_CR_SBITCMD;
                                              /* Set wait start bit */
SDIO->SD CMDCRC = 0x000000000;
                                              /* Clear CRC */
SDIO->SD_CMDtransfer = 136;
                                              /* Command response length */
SDIO->SD CR |= SDIO SD CR WORK2;
                                              /* Initiate command transaction */
```

#### 35.1.3 Передача данных (по спецификации SDIO)

Для передачи данных по интерфейсу SDIO следует настроить режим работы контроллера (регистр SD\_CR), заполнить буфер данных (SD\_DATDR), обнулить регистры контрольной суммы (SD\_DAT0CRC- SD\_DAT3CRC), задать количество бит которые надо передать по линиям данных (регистр SD\_DATtransfer), а затем выставить бит WORK1 в «1». Формат передаваемой команды по спецификации SDIO представлен ниже (Рисунок 35–3).



Data Packet Format for Standard Bus (only DAT0 used)



Data Packet Format for Wide Bus (all four lines used)

#### Рисунок 35-3 - Формат данных по спецификации SDIO в режиме ведущего

Последовательность действий для передачи данных:

- включить контроллер SDIO (бит CR\_SDE) и установить режим ведущего (бит CLKOE);
- если бит WORK1 установлен в «1», то следует либо дождаться окончания передачи прошлой команды, либо вручную сбросить этот бит;

- настроить направление передачи команды (бит DIRDAT), разрядность шины данных (бит WIDTHDAT) и установить бит формирования стартового бита в линиях DAT0-DAT3 (бит SBITDAT);
- заполнить буфер данных;
- инициализировать нулевым значением регистры контрольной суммы линий данных;
- задать длину передаваемых данных, с учетом CRC и стопового бита (без учета стартового бита);
- установить бит WORK1 в «1»;
- дождаться появления свободного места в FIFO передатчика (бит FIFODAT\_FULL), после чего записать в буфер данных одно фиктивное слово с нулевым значением.

Пример инициализации передачи данных в соответствии со спецификацией SDIO:

```
SDIO->SD_CR = SDIO_SD_CR_CLKOE |
SDIO SD CR SDE;
                                   /* SDIO ON & Master */
do {
                                               /* Wait while DATActive bit is set */
SDIO->SD CR &= ~SDIO SD CR WORK; /* Reset Work1 */
} while (SDIO->SD_CR & SDIO_SD_CR_WORK);
SDIO->SD CR |= SDIO SD CR DIRDAT:
                                               /* DATA TX */
SDIO->SD CR &= ~SDIO SD CR WIDTHDAT;
                                               /* 4 bit width */
SDIO->SD_DATA0CRC = 0x000000000;
                                               /* Clear CRC DATA0*/
SDIO->SD DATA1CRC = 0x000000000;
                                                     /* Clear CRC DATA1*/
SDIO->SD DATA2CRC = 0x000000000:
                                                     /* Clear CRC DATA2*/
SDIO->SD_DATA3CRC = 0x000000000;
                                                    /* Clear CRC DATA3*/
i = 0;
n_{byte} = 512;
while (i < n_byte)
SDIO->SD DATDR =
                                        /*Fill the FIFO buffer*/
                       buff[i] |
buff[i+1]<<8 |
buff[i+2]<<16 |
buff[i+3]<<24;
i = i + 4;
SDIO->SD DATtransfer = n byte *8 + (16 + 1);
                                                     /* Set length */
SDIO->SD_CR |= SDIO_SD_CR_SBITDAT;
                                               /* Set generate start bit */
SDIO->SD_CR |= SDIO_SD_CR_WORK;
                                                     /* Initiate data transaction */
while(SDIO->SD_SR & SDIO_SD_SR_FIFODAT_FULL){}
SDIO->SD DATDR = 0x000000000;
```

## 35.1.4 Прием данных (по спецификации SDIO)

Для приема данных по интерфейсу SDIO следует настроить режим работы контроллера (регистр SD\_CR), обнулить регистры контрольной суммы (SD\_DAT0CRC- SD\_DAT3CRC), задать количество бит которые надо принять по линиям данных (регистр SD\_DATtransfer), а затем выставить бит WORK1 в «1».

Последовательность действий для приёма данных:

- включить контроллер SDIO (бит CR\_SDE) и установить режим ведущего (бит CLKOE);
- если бит WORK1 установлен в «1», то следует либо дождаться окончания передачи прошлой команды, либо вручную сбросить этот бит;
- настроить направление передачи команды (бит DIRDAT), разрядность шины данных (бит WIDTHDAT) и установить бит ожидания стартового бита в линиях DAT0-DAT3 (бит SBITDAT);
- инициализировать нулевым значением регистры контрольной суммы линий данных;
- задать длину ожидаемых данных, с учетом CRC и стопового бита (без учета стартового бита)
- установить бит WORK1 в «1».

Примечание — Для корректного приёма команды/данных в режиме ведущего необходимо обеспечить подтяжку линии CMD и DAT[3:0] к питанию.

Пример инициализации приема данных в соответствии со спецификацией SDIO:

```
SDIO->SD_CR = SDIO_SD_CR_CLKOE |
SDIO SD CR SDE;
                                  /* SDIO ON & Master */
                                             /* Wait while DATActive bit is set */
do {
SDIO->SD_CR &= ~SDIO_SD_CR_WORK; /* Reset Work1 */
} while (SDIO->SD_CR & SDIO_SD_CR_WORK);
SDIO->SD_CR &= ~SDIO_SD_CR_DIRDAT;
                                              /* DATA RX */
SDIO->SD CR &= ~SDIO SD CR WIDTHDAT;
                                             /* 4 bit width */
SDIO->SD_DATA0CRC = 0x000000000;
                                             /* Clear CRC DATA0*/
SDIO->SD DATA1CRC = 0x000000000;
                                                   /* Clear CRC DATA1*/
SDIO->SD DATA2CRC = 0x000000000:
                                                   /* Clear CRC DATA2*/
SDIO->SD DATA3CRC = 0x000000000;
                                                   /* Clear CRC DATA3*/
n byte = 512;
SDIO->SD DATtransfer = n byte *8 + (16 + 1);
                                                   /* Set length */
SDIO->SD_CR |= SDIO_SD_CR_SBITDAT;
                                             /* Set wait start bit */
SDIO->SD_CR |= SDIO_SD_CR_WORK;
                                                   /* Initiate data transaction */
```

#### 35.2 Прерывания

В контроллере SDIO предусмотрено 6 маскируемых источников прерывания. В результате формируется один общий сигнал, представляющий собой комбинацию независимых сигналов, объединенных по схеме ИЛИ. Общий сигнал прерывания также является сигналом запроса DMA.

Прерывание может генерировать установка одного из шести флагов:

RX буфер команд полон;

- RX буфер команд не пуст;
- ТХ буфер команд пуст;
- RX буфер данных полон;
- RX буфер данных не пуст;
- ТХ буфер данных пуст.

Каждый из независимых сигналов запроса прерывания может быть маскирован битами разрешения прерывания в регистре SD CR.

## 35.3 Схемы включения контроллера

## 35.3.1 Подключение SD card к контроллеру



Рисунок 35-4 - Схема подключения хоста к SD-контроллеру

# 35.4 Регистры SD

Таблица 35-1 – Описание регистров контроллера интерфейса SDIO

| Базовый Адрес | Название       | Описание                                 |
|---------------|----------------|------------------------------------------|
| 0x4004_8000   | SDIO           | Контроллер интерфейса SDIO               |
| Смещение      |                |                                          |
| 0x00          | SD_CR          | Регистр управления                       |
| 0x04          | SD_SR          | Регистр состояния                        |
| 80x0          | SD_CMDDR       | Регистр команд                           |
| 0x0C          | SD_DATDR       | Регистр данных                           |
| 0x10          | SD_CMDCRC      | Регистр контрольной суммы линии команд   |
| 0x14          | SD_DAT0CRC     | Регистр контрольной суммы линии данных 0 |
| 0x18          | SD_DAT1CRC     | Регистр контрольной суммы линии данных 1 |
| 0x1C          | SD_DAT2CRC     | Регистр контрольной суммы линии данных 2 |
| 0x20          | SD_DAT3CRC     | Регистр контрольной суммы линии данных 3 |
| 0x24          | SD_CMDtransfer | Регистр-счётчик принимаемых/передаваемых |
|               |                | бит линии команд                         |

| 0x28 | SD_DATtransfer | Регистр-счётчик принимаемых/передаваемых |  |  |  |
|------|----------------|------------------------------------------|--|--|--|
|      |                | бит линий данных                         |  |  |  |

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

# Таблица 35-2 - Регистр SD\_CR

| Номер   | 7   | 6   | 5       | 4       | 3    | 2      | 1      | 0   |
|---------|-----|-----|---------|---------|------|--------|--------|-----|
| Доступ* | R/W | R/W | R/W     | R/W     | R/W  | R/W    | R/W    | R/W |
| Сброс   | 0   | 0   | 0       | 0       | 0    | 0      | 0      | 0   |
|         | BR1 | BR0 | SBITDAT | SBITCMD | WORK | DIRDAT | DIRCMD | SDE |

| Номер   | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8   |
|---------|--------|--------|--------|--------|--------|--------|--------|-----|
| Доступ* | R/W    | R/W |
| Сброс   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0   |
|         | RXNEIE | TXEIE_ | RXFIE_ | RXNEIE | TXEIE_ | CRCEN_ | CRCEN_ | BR2 |
|         | _CMD   | CMD    | DAT    | _DAT   | DAT    | CMD    | DAT    |     |

| Номер   | 3122 | 21    | 20    | 19      | 18      | 17     | 16      |
|---------|------|-------|-------|---------|---------|--------|---------|
| Доступ* | U    | R/W   | R/W   | R/W     | R/W     | R/W    | R/W     |
| Сброс   |      | 0     | 0     | 0       | 0       | 0      | 0       |
|         | -    | CLKOE | WORK2 | ENDBUSY | WRITECM | WIDTHD | RXFIE_C |
|         |      |       |       |         | D       | AT     | MD      |

Обозначения здесь и далее по тексту:

R/W – бит доступен на чтение и запись;

RO – бит доступен только на чтение;

U – бит физически не реализован или зарезервирован.

Таблица 35-3 - Описание бит регистра SD\_CR

| Nº   | Функциональ  | Расшифровка функционального имени бита, краткое              |
|------|--------------|--------------------------------------------------------------|
|      | ное имя бита | описание назначения и принимаемых значений                   |
| 3122 |              | Зарезервировано                                              |
| 21   | CLKOE        | Сигнал разрешения выдачи сигнала CLK                         |
|      |              | 1 – ведущий                                                  |
|      |              | 0 – ведомый                                                  |
| 20   | WORK2        | Бит начала транзакции команды                                |
|      |              | 1 – старт транзакции                                         |
|      |              | 0 – останов транзакции                                       |
|      |              | Бит автоматически сбрасывается в нуль, если SD_CMDtransfer   |
|      |              | равен нулю.                                                  |
|      |              | Перед установкой этого бита необходимо занести в регистр     |
|      |              | счётчика передаваемых битов команды ненулевое значение.      |
|      |              | Если бит установлен, но FIFO для передачи команды пусто или  |
|      |              | FIFO приёма команды полно, то транзакция не начнётся до тех  |
|      |              | пор, пока FIFO не будут подготовлено для приёма или передачи |
|      |              | команды                                                      |
| 19   | ENDBUSY      | Выставлять BUSY на линию DAT0                                |
|      |              | 1 – не выставлять BUSY                                       |
|      |              | 0 – выставлять BUSY                                          |
| 18   | WRITECMD     | Посылать ответ 101b на команду записи                        |
|      |              | 1 – посылать ответ                                           |
|      |              | 0 – не посылать ответ                                        |

| Nº | Функциональ<br>ное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|----|-----------------------------|--------------------------------------------------------------------------------------------|
| 17 | WIDTHDAT                    | Разрядность шины данных                                                                    |
|    |                             | 1 – шина одноразрядная                                                                     |
|    |                             | 0 –-шина четырёхразрядная                                                                  |
| 16 | RXFIE_CMD                   | Прерывание RX буфер команд полон разрешено                                                 |
|    |                             | 1 – прерывание не маскировано. Это разрешает генерировать                                  |
|    |                             | прерывание, если установлен флаг FIFOCMD_FULL.                                             |
|    |                             | 0 – прерывание маскировано                                                                 |
| 15 | RXNEIE_CMD                  | Прерывание RX буфер команд не пуст разрешено                                               |
|    |                             | 1 – прерывание не маскировано. Это разрешает генерировать                                  |
|    |                             | прерывание, если сброшен флаг FIFOCMD_EMPTY.                                               |
|    |                             | 0 – прерывание маскировано                                                                 |
| 14 | TXEIE_CMD                   | Прерывание ТХ буфер команд пуст разрешено                                                  |
|    |                             | 1 – прерывание не маскировано. Это разрешает генерировать                                  |
|    |                             | прерывание, если установлен флаг FIFOCMD_EMPTY.                                            |
|    |                             | 0 – прерывание маскировано                                                                 |
| 13 | RXFIE_DAT                   | Прерывание RX буфер данных полон разрешено                                                 |
|    |                             | 1 – прерывание не маскировано. Это разрешает генерировать                                  |
|    |                             | прерывание, если установлен флаг FIFODAT_FULL.                                             |
|    |                             | 0 – прерывание маскировано                                                                 |
| 12 | RXNEIE_DAT                  | Прерывание RX буфер данных не пуст разрешено                                               |
|    |                             | 1 – прерывание не маскировано. Это разрешает генерировать                                  |
|    |                             | прерывание, если сброшен флаг FIFODAT_EMPTY.                                               |
|    |                             | 0 – прерывание маскировано                                                                 |
| 11 | TXEIE_DAT                   | Прерывание ТХ буфер данных пуст разрешено                                                  |
|    |                             | 1 – прерывание не маскировано. Это разрешает генерировать                                  |
|    |                             | прерывание, если установлен флаг FIFODAT_EMPTY.                                            |
|    |                             | 0 – прерывание маскировано                                                                 |
| 10 | CRCEN_CMD                   | Аппаратное вычисление CRC по линии CMD                                                     |
|    |                             | 1- вычисление CRC разрешено                                                                |
|    |                             | 0- вычисление CRC запрещено                                                                |
|    |                             | Этот бит не должен изменяться во время транзакции.                                         |
| 9  | CRCEN_DAT                   | Аппаратное вычисление CRC по линиям DAT3-DAT0                                              |
|    |                             | 1 – вычисление CRC разрешено                                                               |
|    |                             | 0 – вычисление CRC запрещено                                                               |
|    |                             | Этот бит не должен изменяться во время транзакции                                          |
| 86 | BR2-BR0                     | Управление скоростью передачи                                                              |
|    |                             | 001 – PCLK/4                                                                               |
|    |                             | 010 - PCLK/8                                                                               |
|    |                             | 011 – PCLK/16                                                                              |
|    |                             | 100 – PCLK/32                                                                              |
|    |                             | 101 – PCLK/64                                                                              |
|    |                             | 110 – PCLK/128                                                                             |
|    |                             | 111 – PCLK/256                                                                             |
|    |                             | Эти биты не должны изменяться во время транзакции                                          |
| 5  | SBITDAT                     | Ожидание или формирование стартового бита в линиях                                         |
|    |                             | DAT3-DAT0                                                                                  |
|    |                             | 1 – ожидание или формирование в линиях DAT3-DAT0 стартового                                |
|    |                             | бита в зависимости от бита DIRDAT.                                                         |
|    |                             | 0 – ожидание или формирование стартового бита отключено.                                   |
|    |                             | После установления сигнала WORK в единицу происходит                                       |
|    |                             | ожидание (DIRDAT=0) или формирование (DIRDAT=1) стартового                                 |
|    |                             | бита в линиях DAT3-DAT0. После этого бит автоматически                                     |
|    |                             | сбрасывается в нуль                                                                        |

| Nº | Функциональ ное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|----|--------------------------|--------------------------------------------------------------------------------------------|
| 4  | SBITCMD                  | Ожидание стартового бита в линии СМD                                                       |
| 4  | SBITCIVID                | 1 – ожидание в линии СМD стартового бита.                                                  |
|    |                          | 0 – ожидание стартового бита отключено.                                                    |
|    |                          | После установления сигнала WORK в единицу происходит                                       |
|    |                          | ожидание стартового бита в линии СМD. После этого бит                                      |
|    |                          | автоматически сбрасывается в нуль. Передача стартового бита в                              |
|    |                          | линию СМD осуществляется записью команды определённого                                     |
|    |                          | формата (48 или 136 бит) в регистр SD_CMDDR                                                |
| 3  | WORK1                    | Бит начала транзакции данных                                                               |
|    | VVOICE                   | 1 – старт транзакции                                                                       |
|    |                          | 0 – останов транзакции                                                                     |
|    |                          | Бит автоматически сбрасывается в нуль, если SD_DATtransfer                                 |
|    |                          | равен нулю.                                                                                |
|    |                          | Перед установкой этого бита необходимо занести в регистр                                   |
|    |                          | счётчика передаваемых битов данных ненулевое значение.                                     |
|    |                          | Если бит установлен, но FIFO для передачи данных пусто или                                 |
|    |                          | FIFO приёма данных полно, то транзакция не начнётся до тех                                 |
|    |                          | пор, пока FIFO не будет подготовлено для приёма или передачи                               |
|    |                          | данных                                                                                     |
| 2  | DIRDAT                   | Бит выбора направления линий DAT3-DAT0                                                     |
|    |                          | 1 – линии работают на выход                                                                |
|    |                          | 0 – линии работают на вход                                                                 |
|    |                          | Этот бит не должен изменяться во время транзакции                                          |
| 1  | DIRCMD                   | Бит выбора направления линии CMD                                                           |
|    |                          | 1 – линия работает на выход                                                                |
|    |                          | 0 – линия работает на вход                                                                 |
|    |                          | Этот бит не должен изменяться во время транзакции                                          |
| 0  | SDE                      | Разрешение работы SD bus                                                                   |
|    |                          | 1 – периферия включена                                                                     |
|    |                          | 0 – периферия отключена                                                                    |

# 35.4.2 Регистр состояния

# Таблица 35-4 – Регистр SD\_SR

| Номер   | 314 | 3                | 2                | 1                 | 0                 |
|---------|-----|------------------|------------------|-------------------|-------------------|
| Доступ* | U   | R                | R                | R                 | R                 |
| Сброс   |     | 0                | 0                | 1                 | 1                 |
| -       |     | FIFODAT_<br>FULL | FIFOCMD_<br>FULL | FIFODAT_<br>EMPTY | FIFOCMD_EM<br>PTY |

# Таблица 35-5 – Описание бит регистра SD\_SR

| Nº  | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----|----------------------------|--------------------------------------------------------------------------------------------|
| 314 |                            | Зарезервировано                                                                            |
| 3   | FIFODAT_FULL               | Состояние FIFO приёма/передачи данных.                                                     |
|     |                            | 0 – FIFO не полно                                                                          |
|     |                            | 1 – FIFO полно                                                                             |
| 2   | FIFOCMD_FULL               | Состояние FIFO приёма/передачи команд.                                                     |
|     |                            | 0 – FIFO не полно                                                                          |
|     |                            | 1 – FIFO полно                                                                             |

| Nº | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|----|----------------------------|--------------------------------------------------------------------------------------------|
| 1  | FIFODAT EMPTY              | Состояние FIFO приёма/передачи данных.                                                     |
|    | _                          | 0 – FIFO не пусто                                                                          |
|    |                            | 1 – FIFO пусто                                                                             |
| 0  | FIFOCMD_EMPTY              | Состояние FIFO приёма/передачи команд                                                      |
|    |                            | 0 – FIFO не пусто                                                                          |
|    |                            | 1 – FIFO пусто                                                                             |

Примечание – выбор буфера FIFO приёма или передачи команд/данных, состояние которого отображается в регистре SD\_SR, определяется битом DIRCMD/DIRDAT регистра SD\_CR.

# 35.4.3 Регистр команд

# Таблица 35-6 – Perистр SD\_CMDDR

| Номер   | 31              |  |  |  |  | 0   |
|---------|-----------------|--|--|--|--|-----|
| Доступ* | R/W             |  |  |  |  | R/W |
| Сброс   | 0               |  |  |  |  | 0   |
|         | RX_FIFO/TX_FIFO |  |  |  |  |     |

## Таблица 35-7 - Описание бит регистра SD CMDDR

| Nº  | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----|----------------------------|--------------------------------------------------------------------------------------------|
| 310 | RX_FIFO/TX_FIFO            | 8x32 бита FIFO приёма и передачи                                                           |

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

## Таблица 35-8 – Регистр SD\_DATDR

| Номер   | 31              |  |  |  |  | 0   |
|---------|-----------------|--|--|--|--|-----|
| Доступ* | R/W             |  |  |  |  | R/W |
| Сброс   | 0               |  |  |  |  | 0   |
|         | RX_FIFO/TX_FIFO |  |  |  |  |     |

# Таблица 35-9 – Описание бит регистра SD\_DATDR

| Nº  | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|-----|-------------------------|--------------------------------------------------------------------------------------------|
| 310 | RX_FIFO/TX_FIFO         | 128x32 бита FIFO приёма и передачи                                                         |

# 35.4.5 Регистр контрольной суммы линии команд

# Таблица 35-10 - Регистр SD\_CMDCRC

| Номер   | 317 | 60        |
|---------|-----|-----------|
| Доступ* | U   | R/W       |
| Сброс   |     | 0         |
|         |     | SD_CMDCRC |

# Таблица 35-11 - Описание бит регистра SD\_CMDCRC

| Nº  | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                          |
|-----|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 317 |                         | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 60  | SD_CMDCRC               | CRC регистр линии команд                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |                         | Если разрешено вычисление контрольной суммы при приёме/передаче битом CRCEN_CMD, то регистр содержит подсчитанное значение CRC последовательно принятой/переданной команды. Перед началом подсчёта регистр необходимо инициализировать нулевым значением. CRC рассчитывается последовательно с использованием полинома CRC7 (х <sup>7</sup> +х <sup>3</sup> +1). Чтение регистра в момент незавершённой транзакции приведёт к ошибочному результату |

# 35.4.6 Регистры контрольных сумм линий данных

# Таблица 35-12 - Регистр SD\_DATCRC

| Номер   | 3116 | 150       |
|---------|------|-----------|
| Доступ* | U    | R/W       |
| Сброс   |      | 0         |
|         |      | SD_DATCRC |

# Таблица 35-13 - Описание бит регистра SD\_DATCRC

| Nº   | Функционально е имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------|--------------------------|--------------------------------------------------------------------------------------------|
| 3116 |                          | Зарезервировано                                                                            |
| 150  | SD_DAT0CRC               | CRC регистры линий данных                                                                  |
|      | SD_DAT1CRC               | Если разрешено вычисление контрольной суммы при                                            |
|      | SD DAT2CRC               | приёме/передаче битом CRC_DATEN, то регистр содержит                                       |
|      | SD DAT3CRC               | подсчитанное значение CRC последовательно                                                  |
|      |                          | принятых/переданных данных. Перед началом подсчёта                                         |
|      |                          | регистр необходимо инициализировать нулевым значением.                                     |
|      |                          | CRC рассчитывается последовательно с использованием                                        |
|      |                          | полинома CRC16 ( $x^{16}+x^{12}+x^5+1$ ). Чтение регистра в момент                         |
|      |                          | незавершённой транзакции приведёт к ошибочному                                             |
|      |                          | результату                                                                                 |

# 35.4.7 Регистр-счётчик принимаемых/ передаваемых бит линии команд

# Таблица 35-14 - Регистр SD\_CMDtransfer

| Номер   | 3116 | 150            |
|---------|------|----------------|
| Доступ* | U    | R/W            |
| Сброс   |      | 0              |
|         |      | SD_CMDtransfer |

# Таблица 35-15 – Описание бит регистра SD\_CMDtransfer

| Nº   | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                             |
|------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3116 |                         | Зарезервировано                                                                                                                                                                                                                                                                                                        |
| 150  | SD_CMDtransfer          | Содержит количество бит, которое необходимо передать/принять в линии команд. По мере приёма/передачи счётчик уменьшается на единицу при каждом принятом/переданном бите, пока не достигнет нулевого значения. Максимальное количество доступных бит для приёма/передачи 65536. Количество бит не обязательно кратно 32 |

# 35.4.8 Регистр-счётчик принимаемых/ передаваемых бит линий данных

# Таблица 35-16 – Регистр SD\_DATtransfer

| Номер   | 3116 | 150            |
|---------|------|----------------|
| Доступ* | U    | R/W            |
| Сброс   |      | 0              |
|         |      | SD_DATtransfer |

# Таблица 35-17 – Описание бит регистра SD\_DATtransfer

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое                                                                                                                                                                                                                                                                                                                                   |
|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | имя бита       | описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                        |
| 3116 |                | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                   |
| 150  | SD_DATtransfer | Содержит количество бит, которое необходимо передать/принять в линиях данных. По мере приёма/передачи счётчик уменьшается на четыре при каждом принятом/переданном полубайте, пока не достигнет нулевого значения. Поэтому значение счётчика должно быть кратно четырём. Максимальное количество доступных бит для приёма/передачи 65536. Количество бит не обязательно кратно 32 |

# 36 Прерывания и исключения RISC

Состояние исключений:

Inactive – исключение не находится в стадии Active или Pending

**Pending** – исключение находится в состоянии ожидания обработки процессором. Запрос прерывания от периферийных блоков или программы может изменить состояние соответствующего прерывания на состояние Pending

**Active** – исключение начало обрабатываться процессором, но еще не закончено. Обработчик исключения может быть прерван другим обработчиком исключения. В этом случае оба исключения находятся в состоянии Active

Active и Pending – исключение начало обрабатываться процессором, но появилось новое исключение в состоянии pending от того же источника.

#### 36.1 Типы исключений

Исключения бывают следующих типов:

- RESET;
- NON MASKABLE INTERRUPT (NMI);
- Hard Fault:
- Memory Management fault;
- Bus Fault;
- Usage Fault;
- Supervisor Call (SVCALL);
- PendSV;
- SysTick.

#### 36.1.1 *RESET*

RESET вызывается при включении питания и горячем сбросе. Модель исключений трактует RESET как специальную форму исключения. Когда выставляется RESET, работа процессора останавливается потенциально в любой точке инструкций. Когда RESET убирается, выполнение перезапускается с адреса, заданного в таблице векторов для сброса. Выполнение перезапускается с уровнем privileged в thread режиме.

### 36.1.2 NON MASKABLE INTERRUPT (NMI)

Немаскируемое прерывание (NMI) может быть вызвано периферией или установлено программой. Это самое высокоприоритетное исключение после сброса. Всегда разрешено и имеет фиксированный приоритет – 2.

Примечание – Данное прерывание не реализовано.

NMI не может быть:

- замаскировано или предотвращено от активации из другого исключения;
- прерывает любые исключения, кроме RESET.

### 36.1.3 Hard Fault

Исключение Hard Fault возникает при ошибке при обработке исключений или потому, что исключение не может быть обработано каким-либо другим механизмом. Hard fault имеет фиксированный приоритет – 1, означающий, что оно имеет больший приоритет, чем любое из исключений с конфигурируемым приоритетом.

# 36.1.4 Memory Management fault

Исключение Memory Management fault возникает при срабатывании по защите памяти. Блок MPU или фиксированные защитные настройки определяют это исключение, как для данных, так и для инструкций. Исключение используется для прерывания доступа за инструкцией в область EXECUTE NEVER (XN), если блок MPU не используется.

### 36.1.5 Bus Fault

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

### 36.1.6 Usage Fault

Исключение USAGE FAULT возникает при сбоях при выполнении инструкции. Например:

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

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

- невыровненный адрес при обращении за полусловами halfword и словами word:
- деление на ноль.

# 36.1.7 SVCall

Исключение Supervisor Call (SVCALL) возникает при выполнении инструкции SVC. В приложениях с использованием Операционных Сред инструкция SVC может использоваться для доступа к функциям ОС и драйверам устройств.

### 36.1.8 PendSV

Исключение PendSV является прерыванием запросом сервисов системного уровня. В приложениях с использованием ОС PendSV используется для переключения контекстов, когда нет других активных исключений.

### 36.1.9 SysTick

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

# 36.2 Прерывания (IRQ)

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

Таблица 36-1 – Различные типы исключений

| Номер<br>исключения | Номер<br>IRQ | Тип                           | Приоритет       | Адрес вектора<br>обработчика<br>(смещение) | Активация                  |
|---------------------|--------------|-------------------------------|-----------------|--------------------------------------------|----------------------------|
| 1                   | _            | RESET                         | -3,             | 0х0000 0004                                | Асинхронный                |
|                     |              |                               | наивысший       | 0.0000_0001                                | , torm, pormisir           |
| 2                   | -14          | NMI                           | -2              | 0x0000_0008                                | Асинхронный                |
| 3                   | -13          | Hard Fault                    | -1              | 0x0000_000C                                | -                          |
| 4                   | -12          | Memory<br>Management<br>Fault | Конфигурируемый | 0x0000_0010                                | Синхронный                 |
| 5                   | -11          | Bus Fault                     | Конфигурируемый | 0x0000_0014                                | Синхронный/<br>Асинхронный |
| 6                   | -10          | Usage Fault                   | Конфигурируемый | 0x0000_0018                                | Синхронный                 |
| 7-10                | -            | -                             | -               | Зарезервировано                            | -                          |
| 11                  | -5           | SVCall                        | Конфигурируемый | 0x0000_002C                                | Синхронный                 |
| 12-13               | ı            | -                             | •               | Зарезервировано                            | ı                          |
| 14                  | -2           | PendSV                        | Конфигурируемый | 0x0000_0038                                | Асинхронный                |
| 15                  | -1           | SysTick                       | Конфигурируемый | 0x0000_003C                                | Асинхронный                |
| 16                  | 0            | IRQ                           | Конфигурируемый | 0x0000_0040                                | Асинхронный                |
| и выше              | и выше       |                               |                 | и выше                                     |                            |

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

. Программа в Privileged режиме может запретить прерывания, имеющие конфигурируемый приоритет.

### 36.3 Обработчики исключений

Для обработки исключений используются:

- Процедуры обработки прерываний (Interrupt Service Routines ISRs) Прерывания с IRQ0 по IRQ31 обрабатываются процедурами ISR.
- Обработчики ошибок (Fault Handlers)
  Обрабатывают исключения Hard fault, memory management fault, usage fault и bus fault.
- Системные обработчики (System handlers) Обрабатывают исключения NMI, PendSV, SVCall и SysTick.

# 36.4 Таблица векторов

Таблица векторов содержит указатель стека, вектор входа по RESET и стартовые адреса обработчиков, также называемых векторами. Ниже представлена последовательность векторов в таблице (Рисунок 36–1). Младший бит всех векторов должен быть равен 1, указывая на то, что обработчик выполняется в Thumb режиме.

| Exception number                       | IRQ number              | Offset                                                             | Vector                                                           |
|----------------------------------------|-------------------------|--------------------------------------------------------------------|------------------------------------------------------------------|
| 45                                     | 29                      | 0x00B4                                                             | IRQ29                                                            |
| 18<br>17<br>16<br>15<br>14<br>13<br>12 | 2<br>1<br>0<br>-1<br>-2 | 0x0084<br>0x004C<br>0x0048<br>0x0044<br>0x0040<br>0x003C<br>0x0038 | IRQ2 IRQ1 IRQ0 Systick PendSV Reserved Reserved for Debug SVCall |
| 10<br>9<br>8<br>7                      |                         | 0x002C                                                             | Reserved                                                         |
| 6                                      | -10                     | 0x0018                                                             | Usage fault                                                      |
| 5                                      | -11                     | 0x0018                                                             | Bus fault                                                        |
| 4                                      | -12                     |                                                                    | Memory management fault                                          |
| 3                                      | -13                     | 0x0010                                                             | Hard fault                                                       |
| 2                                      | -14                     | 0x000C                                                             | Reserved                                                         |
| 1                                      |                         | 0x0008<br>0x0004                                                   | Reset<br>Initial SP value                                        |
|                                        |                         | 0x0000                                                             | illiudi Si Value                                                 |

Рисунок 36-1 - Таблица векторов исключений и прерываний

При системном сбросе таблица векторов располагается по фиксированному адресу 0x00000000. Программное обеспечение в privileged режиме может перенести таблицу в другое место памяти через регистр VTOR. Таблица может располагаться в адресах от 0x00000080 до 0x3fffff80. Подробнее в описании регистра VTOR.

## 36.5 Приоритеты исключений

- Более малое значение приоритета означает больший приоритет.
- Конфигурируемы все приоритеты, кроме RESET и Hard Fault.
- Если программное обеспечение не задает приоритетов, то все они имеют приоритет 0.
- Конфигурируемый приоритет может быть в диапазоне от 0 до 15. Это означает что RESET, Hard Fault и NMI, имеющие отрицательное значение приоритета, всегда имеют больший приоритет.

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

# 36.5.1 Группировка приоритетов прерываний

Для увеличения управляемости приоритетов в системах с прерываниями контроллер прерываний NVIC поддерживает группировку приоритетов. Это достигается за счет разбиения регистра приоритета прерывания на две части:

- верхняя часть определяет группу приоритетов;
- нижняя часть задает подприоритет в группе.

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

### 36.6 Вход в обработчик и выход из обработчика

### 36.6.1 Приоритетное прерывание

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

# 36.6.2 Возврат

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

- в системе отсутствуют необработанные исключения с достаточным приоритетом;
- завершенный обработчик не обрабатывал запоздавшее исключение (latearriving exception).

Процессор обращается к стеку и восстанавливает состояние, имевшее место до вызова обработчика. Более подробная информация дана в разделе «Возврат из обработчика исключения».

# 36.6.3 Передача управления без восстановления контекста (tailchaining)

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

# 36.6.4 Запоздавшее исключение (late-arriving exception)

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

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

# 36.6.5 Вход в процедуру обработки исключения

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

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

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

- регистры R0-R3, R12;
- адрес возврата;
- регистр PSR;
- регистр LR.

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

В случае, если бит STKALIGN в регистре управления конфигурацией (CCR) установлен в 1, во время сохранения контекста производится выравнивание адреса стека по границе двойного слова.

Стековый фрейм содержит адрес возврата, указывающий на ближайшую невыполненную инструкцию прерванной программы. По завершении процедуры

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

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

Одновременно в регистр LR записывается значение EXC\_RETURN, позволяющее определить, какой из двух указателей стека соответствует данному стековому фрейму, и в каком режиме находился процессор перед входом в обработчик.

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

В противном случае процессор передает управление обработчику высокоприоритетной исключительной ситуации без изменения состояния отложенного прерывания в соответствии с правилами, изложенными в разделе «Запоздавшее исключение (late-arriving exception)».

# 36.6.6 Возврат из обработчика исключения

Возврат из обработчика исключения осуществляется в случае, если процессор находится в режиме обработчика (handler mode) и выполняет одну из следующих инструкций, позволяющих загрузить значение EXC\_RETURN в регистр PC:

- инструкцию РОР с аргументом РС;
- инструкцию ВХ с любым регистром;
- инструкции LDR или LDM с регистром PC в качества приемника.

Значение EXC\_RETURN загружается в регистр LR по входу в обработчик исключения. Механизм обработки исключений использует это значение для того, чтобы определить, завершил ли процессор выполнение процедуры обработки исключительной ситуации. Младшие четыре бита EXC\_RETURN содержат информацию о состоянии стека и режиме работы процессора. Информация о назначении разрядов EXC\_RETURN[3:0] и особенности процесса возврата из обработчика исключения представлены в следующей таблице (Таблица 36-1).

Процессор устанавливает биты EXC\_RETURN [31:4] в 0xFFFFFFF. Загрузка данного значения в PC указывает на завершение процедуры обработки исключения и заставляет процессор выполнить необходимые действия для возврата из обработчика.

| EXC_RETURN[3:0] | Описание                                              |  |  |  |
|-----------------|-------------------------------------------------------|--|--|--|
| bXXX0           | Зарезервирован                                        |  |  |  |
| b0001           | Возврат в режим обработчика.                          |  |  |  |
|                 | Восстановление контекста осуществляется из стека MSP. |  |  |  |
|                 | Дальнейшая работа осуществляется со стеком MSP        |  |  |  |
| b0011           | Зарезервирован                                        |  |  |  |
| b01X1           | Зарезервирован                                        |  |  |  |
| b1001           | Возврат в режим приложения.                           |  |  |  |
|                 | Восстановление контекста осуществляется из стека MSP. |  |  |  |

|       | Дальнейшая работа осуществляется со стеком MSP        |
|-------|-------------------------------------------------------|
| b1101 | Возврат в режим приложения.                           |
|       | Восстановление контекста осуществляется из стека PSP. |
|       | Дальнейшая работа осуществляется со стеком PSP        |
| b1X11 | Зарезервирован                                        |

# 36.7 Обработка отказов

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

- ошибка шины в ходе:
- чтения инструкции или вектора обработчика;
- доступа к данным.
- ошибка, обнаруженная процессором, например, неопределенная инструкция или попытка изменить состояние процессора с помощью команды ВХ;
- попытка выполнить инструкцию, расположенную в области памяти, помеченной как неисполняемая (Non-Executable XN);
- отказ блока защиты памяти MPU вследствие нарушения прав доступа или вследствие попытки доступа к неподдерживаемой области адресного пространства.

### 36.7.1 Типы отказов

Таблица 36-3 демонстрирует типы отказов, обработчики, вызываемые при их возникновении, соответствующие данному типу отказа регистры состояния, и биты регистра, указывающие на конкретный отказ. Более подробная информация представлена в разделе "Конфигурируемый регистр отказов".

Таблица 36-3 – Отказы

| Отказ                                     | Обработ-              | Наименование  | Регистр отказа                         |
|-------------------------------------------|-----------------------|---------------|----------------------------------------|
|                                           | чик                   | бита регистра |                                        |
| Ошибка доступа к шине при чтении          | Тяжелый               | VECTTBL       | «Регистр состояния                     |
| вектора                                   | отказ                 |               | «гегистр состояния<br>тяжелых отказов» |
| Эскалация отказа                          | UTKAS                 | FORCED        | TAMEJIBIX OTRASOB//                    |
| Ошибка доступа к памяти:                  |                       | -             | «Регистр состояния                     |
| - при чтении команды                      |                       | IACCVIOL      | отказов доступа к                      |
| - при доступе к данным                    | Отказ                 | DACCVIOL      | памяти»,                               |
| - при сохранении контекста                | доступа к             | MSTKERR       | «Регистр адреса                        |
| - при восстановлении контекста            | памяти                | MUNSKERR      | отказа доступа к                       |
|                                           |                       |               | памяти»                                |
|                                           |                       |               |                                        |
| Ошибка шины:                              |                       | -             | «Регистр состояния                     |
| - при сохранении контекста                | Отказ                 | STKERR        | отказа доступа к                       |
| - при восстановлении контекста            | доступа к             | UNSTKERR      | шине»,                                 |
| - при загрузке инструкции                 | шине                  | IBUSERR       | «Регистр адреса                        |
| локализованная ошибка шины данных         | шине                  | PRECISERR     | отказа доступа к                       |
| нелокализованная ошибка шины данных       |                       | IMPRECISERR   | шине»                                  |
| Попытка доступа к сопроцессору            | Откоо                 | NOCP          | «Регистр состояния                     |
| Неизвестная инструкция                    | Отказ,                | UNDEFINSTR    | отказов, вызванных                     |
| Попытка выбора                            | вызванный<br>ошибками | INVSTATE      | ошибками                               |
| неверного набора инструкций <sup>*)</sup> | ошиоками              |               | программирования»                      |

| Отказ                        | Обработ-<br>чик | Наименование бита регистра | Регистр отказа |
|------------------------------|-----------------|----------------------------|----------------|
| Неверное значение EXC_RETURN | программи       | INVPC                      |                |
| Запись или чтение по неверно | рования         | UNALIGNED                  |                |
| выровненному адресу          |                 |                            |                |
| Деление на 0                 |                 | DIVBYZERO                  |                |

<sup>\* –</sup> Попытка выбора набора инструкций, не поддерживаемого процессором.

### 36.7.2 Эскалация отказов и тяжелые отказы

Всем типам исключительных ситуаций по отказу, за исключением тяжелых отказов (hard fault) можно задать приоритет обработки, см. «SCB->SHP[x]». Выполнение данных обработчиков можно программно запретить, см. «SCB->SHCSR».

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

В некоторых ситуациях отказ с конфигурируемым уровнем приоритета рассматривается системой как тяжелый. Такая ситуация именуется эскалацией отказа (escalation). Это возможно в следующих случаях:

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

Если отказ обращения к шине возник во время загрузки данных в стек при передаче управления на обработчик отказа доступа к шине — эскалации не происходит. Таким образом, в случае, если отказ возник вследствие разрушения стека, передача управления на обработчик отказа выполняется, несмотря на то, что сохранение контекста не было осуществлено.

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

# 36.7.3 Регистры состояния и адреса отказа

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

Таблица 36-4 – Регистры состояния и адреса отказа

| Обработчик | Регистр   | Регистр | Описание регистров |
|------------|-----------|---------|--------------------|
|            | состояния | адреса  |                    |

| Тяжелый отказ                                    | HFSR  | -     | "Регистр состояния тяжелых отказов"                                                   |
|--------------------------------------------------|-------|-------|---------------------------------------------------------------------------------------|
| Отказ доступа к памяти                           | MMFSR | MMFAR | "Регистр состояния отказов доступа к памяти" "Регистр адреса отказа доступа к памяти" |
| Отказ доступа к шине                             | BFSR  | BFAR  | "Регистр состояния отказов доступа к шине" "Регистр адреса отказа доступа к шине"     |
| Отказ, вызванный<br>ошибками<br>программирования | UFSR  | -     | "Регистр состояния отказов, вызванных ошибками программирования"                      |

# 36.7.4 Блокировка

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

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

## 36.8 Управление электропитанием

В процессоре RISC предусмотрены следующие режимы ожидания (пониженного энергопотребления):

- Deep Sleep;
- Sleep;
- Standby.

Выбор процессором конкретного режима ожидания определяется значением бита SLEEPDEEP регистра SCR (см. "Регистр управления системой").

Далее в разделе описаны механизмы перехода в режим пониженного энергопотребления и условия выхода из этого режима.

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

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

### 36.8.2 Ожидание прерывания

Инструкция ожидания прерывания WFI (wait for interrupt) после своего выполнения немедленно переводит процессор в режим пониженного энергопотребления.

### 36.8.3 Ожидание события

Инструкция ожидания сигнала события WFE (wait for event) переводит или не переводит процессор в режим пониженного энергопотребления в зависимости от результата проверки одноразрядного регистра события. При этом процессор проверяет значение регистра события, и в случае, если он равен 0, приостанавливает дальнейшее выполнение команд и переходит в состояние ожидания. В случае, если он равен 1, процессор записывает в регистр события 0 и продолжает нормальную работы без перехода в режим ожидания.

# 36.8.4 Переход в режим ожидания по выходу из обработчика исключения (режим Sleep)

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

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

### 36.8.5 Выход из состояния ожидания

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

### 36.8.5.1 Выход из ожидания по команде WFI и в режиме Sleep

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

В некоторых приложениях может возникнуть необходимость выполнения процедур восстановления системы после выхода процессора из режима пониженного энергопотребления, однако до того, как он начнет выполнять обслуживание прерываний. Для того, чтобы добиться этого, достаточно установить бит PRIMASK в 1, а бит FAULTMASK – в 0. В случае возникновения в системе разрешенного прерывания с приоритетом выше текущего приоритета, процессор будет выведен из ожидания, однако не сможет передать управление обработчику прерывания до тех пор, пока бит PRIMASK не будет установлен в 0.

### 36.8.5.2 Выход из ожидания по команде WFE

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

Кроме того, в случае установки бита SEVONPEND регистра SCR в 1, любое новое необслуженное прерывание формирует сигнал события и выводит процессор из ожидания, даже если это прерывание запрещено или имеет приоритет, недостаточно высокий для запуска обработчика.

Более подробная информация о регистре SCR представлена в разделе "Регистр управления системой".

# 36.8.6 Рекомендации по программированию режима энергопотребления

В стандарте ANSI языка С отсутствует возможность непосредственной генерации инструкций WFI и WFE. В CMSIS предусмотрены встроенные функции, предназначенные для включения в код этих инструкций:

void \_\_WFE(void) // Wait for Event void \_\_WFI(void) // Wait for Interrupt

Периферийные блоки формируют прерывания с IRQ0 до IRQ31

Таблица 36-5 – Формирование прерывания с IRQ0 до IRQ31

| Пропределения | Chaquia  | E               | Пришин формуратом                                                        |  |
|---------------|----------|-----------------|--------------------------------------------------------------------------|--|
| Прерывания    | Смещение | Блок            | Принцип формирования                                                     |  |
| IRQ0          | 0x0040   | SSP3            | Сигнал SSPINTR                                                           |  |
| IRQ1          | 0x0044   | SSP4            | Сигнал SSPINTR                                                           |  |
| IRQ2          | 0x0048   | USB             | Прерывания от USB Host при наличии                                       |  |
|               |          |                 | соответствующих флагов разрешения .<br>HostSOFSent или HostConnEvent или |  |
|               |          |                 | HostResume или HostTransDone.                                            |  |
|               |          |                 | Прерывания от USB Slave при наличии                                      |  |
|               |          |                 | соответствующих флагов разрешения                                        |  |
|               |          |                 | SlaveNAKSent или SlaveSOFRXed или                                        |  |
|               |          |                 | SlaveResetEvent или SlaveResume или                                      |  |
|               |          |                 | SlaveTransDone                                                           |  |
| IRQ3          | 0x004C   | McBSP1(DSP)     | Прерывания от McBSP (DSP)                                                |  |
| IRQ4          | 0x0050   | McBSP2(DSP)     | Прерывания от McBSP (DSP)                                                |  |
| IRQ5          | 0x0050   | DMA             | Прерывания от McDoi (Doi) Прерывания от DMA dma_err или                  |  |
| IIVQU         | 0,0004   | DIVIA           | dma done.                                                                |  |
|               |          |                 | обработка прерываний от DMA в                                            |  |
|               |          |                 | соответствии с разделом Error signaling                                  |  |
|               |          |                 | технического описания DMA                                                |  |
| IRQ6          | 0x0058   | UART1           | Сигнал UARTINTR                                                          |  |
| IRQ7          | 0x005C   | UART2           | Сигнал UARTINTR                                                          |  |
| IRQ8          | 0x0060   | SSP1            | Сигнал SSPINTR                                                           |  |
| IRQ9          | 0x0064   | McBSP3(DSP)     | Прерывания от McBSP (DSP)                                                |  |
| IRQ10         | 0x0068   | I2C             | Сигнал INT при EN_INT                                                    |  |
| IRQ11         | 0x006C   | POWER           | Сигнал прерывания от POWER Detecor                                       |  |
| IRQ12         | 0x0070   | WWDG            | Сигнал прерывания от WWDG                                                |  |
| IRQ13         | 0x0076   | DMA(DSP)        | Прерывания DMA (DSP). Возникает в                                        |  |
| II(Q15        | 0,0074   | DIVIA(DSI )     | случае завершения обработки полного                                      |  |
|               |          |                 | цикла одного из каналов.                                                 |  |
| IRQ14         | 0x0078   | Timer 1         | Сигнал прерывания от Таймера.                                            |  |
|               | 0,007.0  |                 | TIM STATUS II TIM IE                                                     |  |
| IRQ15         | 0x007C   | Timer 2         | Аналогично                                                               |  |
| IRQ16         | 0x0080   | Timer 3         | Аналогично                                                               |  |
| IRQ17         | 0x0084   | ADC             | Сигналы прерываний от АЦП.                                               |  |
| 111011        | 0,0001   | 7.20            | EOCIF 1 или AWOIF 1 или EOCIF 2 или                                      |  |
|               |          |                 | AWOIF_2                                                                  |  |
| IRQ18         | 0x0088   | SDIO            | Прерывание от контроллера SDIO                                           |  |
| IRQ19         | 0x008C   | COMPARATOR      | Сигнал Rslt Sy1                                                          |  |
| IRQ20         | 0x0090   | SSP2            | Сигнал SSPINTR                                                           |  |
| IRQ21         | 0x0094   | AudioCodec(DSP) | Прерывания от модуля Аудиокодека                                         |  |
|               |          |                 | (DSP)                                                                    |  |
| IRQ22         | 0x0098   | Crypto(DSP)     | Прерывания от Криптомодуля (DSP)                                         |  |
| IRQ23         | 0x009C   | Timer(DSP)      | Прерывания от Таймера (DSP)                                              |  |
| IRQ24         | 0x00A0   | DSP Core        | Программные прерывания от DSP                                            |  |
|               |          |                 | (регистр AIRQ)                                                           |  |
| IRQ25         | 0x00A4   | DSP State       | Прерывания, возникающие при переходе                                     |  |
|               | -        |                 | DSP в одно из состояний IDLE (Поле IDLE                                  |  |
|               |          |                 | регистра DSP Control не равно 0).                                        |  |
| IRQ26         | 0x00A8   | UART3           | Сигнал UARTINTR                                                          |  |
| IRQ27         | 0x00AC   | BACKUP          | Прерывание от ВКР и часов реального                                      |  |
|               | _        |                 | времени                                                                  |  |
| IRQ28         | 0x00B0   | Внешнее         | Сигнал EXT_INT1.                                                         |  |
|               |          | прерывание 1    | Вывод РА[15] в переопределенном                                          |  |
|               |          |                 | режиме и PD[15] в основном режиме                                        |  |
| -             |          | •               |                                                                          |  |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Прерывания | Смещение | Блок Принцип формирования                     |                                 |
|------------|----------|-----------------------------------------------|---------------------------------|
| IRQ29      | 0x00B4   | Внешнее Сигнал EXT INT2.                      |                                 |
|            |          | прерывание 2 Вывод РВ[11] в переопределенном  |                                 |
|            |          |                                               | режиме                          |
| IRQ30      | 0x00B8   | Внешнее Сигнал EXT INT3.                      |                                 |
|            |          | прерывание 3 Вывод РЕ[6] в переопределенном р |                                 |
| IRQ31      | 0x00BC   | Внешнее                                       | Сигнал EXT_INT4.                |
|            |          | прерывание 4                                  | Вывод PF[11] в переопределенном |
|            |          |                                               | режиме                          |

# 37 Контроллер прерываний NVIC (RISC)

В разделе описан векторный контроллер прерываний с возможностью вложения (NVIC – Nested Vectored Interrupt Controller) и используемые им регистры. Контроллер обеспечивает следующие возможности:

- программное задание уровня приоритета в диапазоне от 0 до 15 независимо каждому прерыванию. Более высокое значение уровня соответствует меньшему приоритету, таким образом, уровень 0 отвечает наивысшему приоритету прерывания;
- срабатывание сигнала прерывания по импульсу и по уровню;
- динамическое изменение приоритета прерываний;
- разделение исключений по группам с одинаковым приоритетом и по подгруппам внутри одной группы;
- передача управления из одного обработчика исключения в другой без восстановления контекста.

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

Назначение регистров контроллера прерываний представлено ниже.

Таблица 37-1 – Обобщенная информация о регистрах контроллера NVIC

| Адрес      | Название | Тип | Доступ            | Значение<br>после сброса | Описание                   |
|------------|----------|-----|-------------------|--------------------------|----------------------------|
| 0xE000E100 | NVIC     |     |                   |                          | Контроллер прерываний NVIC |
| 0x000      | ISER[0]  | RW  | Привилегированный | 0x00000000               | Регистр разрешения         |
|            |          |     |                   |                          | прерываний ISER            |
| 0x01C      | ISER[7]  |     |                   |                          |                            |
|            |          |     |                   |                          |                            |
| 0x080      | ICER[0]  | RW  | Привилегированный | 0x00000000               | Регистр запрета            |
|            |          |     |                   |                          | прерываний ICER            |
| 0x09C      | ICER[7]  |     |                   |                          |                            |
|            |          |     |                   |                          |                            |
| 0x100      | ISPR[0]  | RW  | Привилегированный | 0x00000000               | Регистр установки          |
|            |          |     |                   |                          | состояния ожидания для     |
| 0x11C      | ISPR[7]  |     |                   |                          | прерывания ISPR            |
|            |          |     |                   |                          |                            |
| 0x180      | ICPR[0]  | RW  | Привилегированный | 0x00000000               | Регистр сброса состояния   |
|            |          |     |                   |                          | ожидания для прерывания    |
| 0x19C      | ICPR[7]  |     |                   |                          | ICPR                       |
|            |          |     |                   |                          |                            |
| 0x200      | IABR[0]  | RO  | Привилегированный | 0x00000000               | Регистр активных           |
|            |          |     |                   |                          | прерываний IABR            |
| 0x21C      | IABR[7]  |     |                   |                          |                            |
|            |          |     |                   |                          |                            |

| Адрес | Название                                    | Тип | Доступ                                         | Значение<br>после сброса | Описание                                          |
|-------|---------------------------------------------|-----|------------------------------------------------|--------------------------|---------------------------------------------------|
| 0x300 | IP[3],IP[2],I<br>P[1],IP[0]                 | RW  | Привилегированный                              | 0x00000000               | Регистр приоритета<br>прерываний IP               |
|       |                                             |     |                                                |                          |                                                   |
| 0x3F0 | IP[239],<br>IP[238],<br>IP[237],<br>IP[236] |     |                                                |                          |                                                   |
|       |                                             |     |                                                |                          |                                                   |
| 0xE00 | STIR                                        | WO  | В зависимости от<br>конфигурации <sup>*)</sup> | 0x00000000               | Регистр программного формирования прерываний STIR |

<sup>\* –</sup> Более подробную информацию см. в описании регистра.

# 37.1 Логика работы прерываний контроллера NVIC.

В данном разделе описывается функционирование контроллера NVIC при поступлении на его вход запросов прерываний IRQ от различных модулей периферии микроконтроллера.

Первоначальным условием работы прерывания является его разрешение в модуле NVIC. За это отвечают регистры:

ISER – за разрешение прерываний,

ICER – за запрет прерываний.

В случае, когда соответствующий запрос разрешен (при данном условии рассмотрены все диаграммы в разделе), и приходит сигнал активации прерывания – запрос IRQ request, то возникает признак отложенного прерывания IRQ pending. Данный признак переводит прерывание в состояние ожидания его обработки ядром.



Рисунок 37-1 – Выставление отложенного запроса на прерывание и последующая его обработка

Pending биты выставляются в регистрах ISPR/ICPR, которые в свою очередь позволяют программно управлять признаком отложенного прерывания. ISPR — для установки pending бит, ICPR — для сброса соответственно. Если после прихода запроса на прерывание IRQ request, сбросить pending бит в регистре ICPR до того, как ядро приступит к его обработке, то прерывание будет проигнорировано (Рисунок 37-2).



Рисунок 37-2 – Сброс признака отложенного прерывания, до обработки ядром

Если произойдёт снятие запроса IRQ request от источника, «защелкивание» признака отложенного прерывания гарантирует отработку его ядром в соответствии с приоритетом (Рисунок 37-3). Сам IRQ pending признак снимается автоматически, когда прерывание становится активным, о чём сигнализирует признак IRQ active. Информация об активности соответствующего прерывания содержится в регистре IABR[x].



Рисунок 37-3 – Сброс признака отложенного прерывания, до обработки ядром

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

При удержании источником на входе NVIC запроса на обработку IRQ request, по окончании обработки прерывания и снятия признака активного прерывания IRQ active, происходит повторное выставление признака отложенного прерывания IRQ pending – «защелкивание» pending бита, сброс которого в дальнейшем инициирует повторную активность и обработку того же исключения (Рисунок 37-4).



Рисунок 37-4 – Повторная обработка прерываний при удержании запроса от источника

Необходимо учитывать, что если источник прерываний выдает многократную установку и снятие запроса IRQ request на входе контроллера NVIC, то в таком случае только первый запрос выставляет признак отложенного прерывания IRQ pending, а остальные запросы до начала процедуры обработки прерывания (в момент активного признака отложенного прерывания) будут проигнорированы ядром (Рисунок 37-5).



Рисунок 37-5 – Многократная установка снятие запроса IRQ request

Если запрос на прерывание пришел в момент активного прерывания, то в такой ситуации уже будут отработаны оба запроса на прерывание. В отличие от случая, изображенного на рисунке 5, запрос приходит тогда, когда признак отложенного прерывания IRQ pending уже сброшен, и новый запрос как раз его выставляет, что в дальнейшем позволяет провести повторную обработку прерывания (Рисунок 37-6).



Рисунок 37-6 – Повторная установка запроса на прерывание в момент выполнения обработчика исключения

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

# 37.2 Упрощенный доступ к регистрам контроллера прерываний

В целях повышения эффективности разработки программного обеспечения в CMSIS предусмотрен упрощенный доступ к регистрам контроллера прерываний NVIC из среды разработки программного обеспечения:

- регистры разрешения, запрета, установки и сброса состояния ожидания прерываний, а также регистр активных прерываний отображаются на массивы 32-разрядных целых чисел, а именно:
  - массив ISER[0] соответствует регистру ISER0;
  - массив ICER[0] соответствует регистру ICER0;
  - массив ISPR[0] соответствует регистру ISPR0;
  - массив ICPR[0] соответствует регистру ICPR0;
  - массив IABR[0] соответствует регистру IABR0;
- 4-битные поля регистра приоритета прерываний отображаются на массив 4-разрядных целых чисел, а именно:
  - массив IP[0]...IP[29] соответствует регистрам IPR0-IPR7, причем элемент массива IP[n] соответствует приоритету прерывания с номером n.

CMSIS генерирует код, гарантированно обеспечивающий в условиях многозадачности корректный непрерываемый (atomic) доступ к регистрам приоритета. Более подробная информация изложена в описании функции NVIC\_SetPriority в разделе «Рекомендации по программированию контроллера прерываний NVIC».

Таблица 37-2 показывает отображение прерываний (номеров запросов IRQ) на регистры прерываний и соответствующие переменные CMSIS, для которых предусмотрено по одному биту на прерывание.

Таблица 37-2 - Распределение прерываний в переменных прерывания

|                     | Элементы массивов CMSIS <sup>*)</sup> |         |                           |                             |                       |
|---------------------|---------------------------------------|---------|---------------------------|-----------------------------|-----------------------|
| Номер<br>прерывания | Разрешение                            | Запрет  | Установка режима ожидания | Сброс<br>режима<br>ожидания | Признак<br>активности |
| 0 – 29              | ISER[0]                               | ICER[0] | ISPR[0]                   | ICPR[0]                     | IABR[0]               |

<sup>\* —</sup> Каждый элемент массива соответствует одному регистру контроллера прерываний NVIC, например элемент ICER[1] соответствует регистру ICER1

# 37.2.1 *NVIC->ISER[x]*

Регистр ISER0 предназначен для разрешения прерываний (запись) и определения, какие из прерываний разрешены (чтение).

Таблица 37-3 – Регистр разрешения прерываний

| 310           | Номер  |
|---------------|--------|
| R/W           | Доступ |
| 0             | Сброс  |
| SETENA bits   |        |
| 0 SETENA bits | Сброс  |

Назначение бит **SETENA**:

запись: 0 – не влияет, 1 – разрешение прерывания;

**чтение**: 0 – прерывание запрещено, 1 – прерывание разрешено.

При разрешении прерывания, находящегося в состоянии ожидания обработки, контроллер NVIC активизирует его в зависимости от приоритета. Запрос запрещенного прерывания переводит его в состояние ожидания обработки, однако контроллер NVIC не активизирует его вне зависимости от приоритета.

# 37.2.2 *NVIC->ICER[x]*

Регистр запрета прерываний

Регистр ICER0 предназначен для запрета прерываний (запись) и определения, какие из прерываний разрешены (чтение) (Таблица 37-4).

Таблица 37-4 – Регистр запрета прерываний

| Номер  | 31 0   |
|--------|--------|
| Доступ | R/W    |
| Сброс  | 0      |
|        | CLRENA |

Назначение бит CLRENA:

запись: 0 – не влияет, 1 – запрет прерывания;

**чтение**: 0 – прерывание запрещено, 1 – прерывание разрешено.

# 37.2.3 *NVIC->ISPR[x]*

Регистр установки состояния ожидания для прерывания

Регистр ISPR0 предназначен для принудительного перевода прерываний в состояние ожидания обслуживания (запись) и определения, какие из прерываний находятся в этом состоянии (чтение) (Таблица 37-5).

Таблица 37-5 – Регистр установки состояния ожидания для прерывания

| Номер  | 310     |  |
|--------|---------|--|
| Доступ | R/W     |  |
| Сброс  | 0       |  |
|        | SETPEND |  |

Назначение бит **SETPEND**:

запись: 0 – не влияет, 1 – перевод прерывания в состояние ожидания;

**чтение**: 0 – прерывание не ожидает обслуживания, 1 – прерывание ожидает обслуживания.

Запись 1 в бит регистра ISPR, соответствующий:

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

# 37.2.4 *NVIC->ICPR[x]*

Регистр сброса состояния ожидания для прерывания

Регистр ICPR0 предназначен для принудительного сброса состояния ожидания обслуживания прерывания (запись) и определения, какие из прерываний находятся в состоянии ожидания (чтение).

Таблица 37-6 – Регистр сброса состояния ожидания для прерывания

| Номер  | 310     |
|--------|---------|
| Доступ | R/W     |
| Сброс  | 0       |
|        | CLRPEND |
|        |         |

Назначение бит **CLRPEND**:

запись: 0 – не влияет, 1 – сброс состояния ожидания;

**чтение**: 0 – прерывание не ожидает обслуживания, 1 – прерывание ожидает обслуживания.

Запись 1 в разряд регистра ICPR, соответствующий прерыванию в активном состоянии, не влияет на работу системы.

# 37.2.5 NVIC->IABR[x]

Регистр активных прерываний

Регистр ICPR0 показывает, какие из прерываний находятся в активном состоянии. Этот регистр доступен только для чтения (Таблица 37-7).

Таблица 37-7 - Регистр активных прерываний

| Номер  | 310    |
|--------|--------|
| Доступ | RO     |
| Сброс  | 0      |
|        | ACTIVE |

### Назначение бит **ACTIVE**:

**чтение**: 0 – прерывание не активно;

1 – прерывание активно и обслуживается, либо активно и ожидает обслуживания.

# 37.2.6 *NVIC->IP[x]*

Регистры приоритета прерываний

Регистры IPR0-IPR7 представляют собой набор 4-битных полей, каждое из которых соответствует одному прерыванию. Регистры доступны побайтно.

Каждый из регистров содержит четыре поля приоритета, которые отображаются на четыре элемента массива IP[0] .. IP[29] CMSIS, как показано ниже.

Таблица 37-8 – Регистры приоритета прерываний

ΙP

| Номер  | 3116 | 158    | 70     |
|--------|------|--------|--------|
| Доступ | U    | R/W    | R/W    |
| Сброс  | 0    | 0      | 0      |
|        | -    | IP[29] | IP[28] |

IΡ

| •      | IP[4m+3] | IP[4m+2] | IP[4m+1] | IP[4m] |
|--------|----------|----------|----------|--------|
| Сброс  | 0        | 0        | 0        | 0      |
| Доступ | R/W      | R/W      | R/W      | R/W    |
| Номер  | 3124     | 2316     | 158      | 70     |

IΡ

| Номер  | 3124  | 2316  | 158   | 70    |
|--------|-------|-------|-------|-------|
| Доступ | R/W   | R/W   | R/W   | R/W   |
| Сброс  | 0     | 0     | 0     | 0     |
|        | IP[3] | IP[2] | IP[1] | IP[0] |

Каждое поле содержит значение приоритета в диапазоне от 0 до 15, причем меньшие значения соответствуют более высокому приоритету соответствующего прерывания. Процессор обеспечивает доступ только к битам [7:5] приоритета, биты [4:0] при чтении всегда равны нулю, а при записи игнорируются.

Номер регистра IPR и смещение данных в регистре для заданного номера прерывания N определяются следующими соотношениями:

- номер M соответствующего регистра приоритета равен M = N DIV 4;
- смещение данных в регистре в зависимости от значения N MOD 4 равно:
  - 0 биты регистра [7:0];
  - 1 биты регистра [15:8];
  - 2 биты регистра [23:16];
  - 3 биты регистра [31:24].

### 37.2.7 **NVIC->STIR**

Регистр программного формирования прерывания

Запись в регистр STIR приводит к формированию в системе программного прерывания (SGI – Software Generated Interrupt).

В случае, если бит USERSETMPEND в регистре SCR установлен в 1, возможен доступ к регистру STIR из непривилегированных приложений (см. "Регистр управления системой"). Установка этого бита возможна только из привилегированного режима работы процессора.

Таблица 37-9 – Регистр программного формирования прерывания

| Номер  | 319 | 80    |
|--------|-----|-------|
| Доступ | U   | WO    |
| Сброс  | 0   | 0     |
|        | -   | INTID |

INTID – идентификатор формируемого прерывания в диапазоне 0 – 239. Например: значение b000000011 соответствует прерыванию IRQ3.

### 37.3 Прерывания, срабатывающие по уровню сигнала

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

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

После того, как процессор передал управление на обработчик, он автоматически снимает признак ожидания обслуживания прерывания (см. раздел "Аппаратное и программное управление прерываниями"). Если прерывание формируется по уровню сигнала, а сигнал запроса не снят до возврата из обработчика, процессор вновь переведет прерывание в состояние ожидания обслуживания, что, в свою очередь, приведет к повторному вызову его обработчика. Таким образом, периферийное устройство может поддерживать сигнал запроса прерывания в активном состоянии до тех пор, пока не перестанет нуждаться в обслуживании.

# 37.4 Аппаратное и программное управление прерываниями

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

- контроллер прерываний NVIC обнаруживает, что сигнал запроса имеет высокий логический уровень, а прерывание неактивно;
- контроллер прерываний NVIC обнаруживает передний фронт сигнала запроса прерывания;
- программное обеспечение осуществляет запись в соответствующий разряд регистра ISPR0 (см.
- •
- NVIC->ISPR[x]) или соответствующего значения в регистр STIR (см. NVIC->STIR).

Прерывание находится в состоянии ожидания до тех пор, пока не произойдет одно из следующих событий:

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

### 37.5 Рекомендации по работе с контроллером прерываний

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

Прерывание может быть переведено в состояние ожидания обслуживания даже в случае, если оно запрещено.

Перед установкой нового адреса таблицы векторов прерывания необходимо убедиться, что элементы новой таблицы корректно проинициализированы адресами обработчиков отказов и всех разрешенных исключений, в частности, прерываний. Более подробная информация представлена в разделе SCB->VTOR.

Программное разрешение или запрещение прерываний может осуществляться с помощью инструкций CPSIE I и CPSID I. В CMSIS предусмотрены следующие встроенные функции, генерирующие эти инструкции:

void \_\_disable\_irq(void) // Disable Interrupts
void \_\_enable\_irq(void) // Enable Interrupts

Кроме того, в CMSIS имеется ряд дополнительных функций, обеспечивающих управление контроллером прерываний NVIC:

Таблица 37-10 - Функции CMSIS для управления контроллером прерываний

| Функция                                                | Описание                         |
|--------------------------------------------------------|----------------------------------|
| void NVIC_SetPriorityGrouping                          | Установить группировку           |
| (uint32_t priority_grouping)                           | приоритетов                      |
| void NVIC_EnableIRQ(IRQn_t IRQn)                       | Разрешить IRQn                   |
| void NVIC_DisableIRQ(IRQn_t IRQn)                      | Запретить IRQn                   |
| uint32_t NVIC_GetPendingIRQ (IRQn_t IRQn)              | Вернуть TRUE, если прерывание    |
| -                                                      | IRQn ожидает обслуживания, FALSE |
|                                                        | – в противном случае             |
| void NVIC_SetPendingIRQ (IRQn_t IRQn)                  | Перевести IRQn в состояние       |
|                                                        | ожидания обслуживания            |
| void NVIC_ClearPendingIRQ (IRQn_t IRQn)                | Сбросить состояние ожидания      |
|                                                        | обслуживания для IRQn            |
| uint32_t NVIC_GetActive (IRQn_t IRQn)                  | Вернуть номер IRQ текущего       |
|                                                        | активного прерывания             |
| void NVIC_SetPriority (IRQn_t IRQn, uint32_t priority) | Установить приоритет для IRQn    |
| uint32_t NVIC_GetPriority (IRQn_t IRQn)                | Считать приоритет IRQn           |
| void NVIC_SystemReset (void)                           | Сбросить систему                 |

Более подробная информация отражена в документации по CMSIS.

# 38 Блок управления системой RISC

Блок управления системой SCB обеспечивает доступ к информации о конфигурации и управление работой системы. Регистры блока управления системой представлены в таблице (Таблица 38-1).

Таблица 38-1 – Обобщенная информация о регистрах блока управления системой

| Адрес      | РМЯ           | Тип  | Доступ                 | Значение        | Описание                              |
|------------|---------------|------|------------------------|-----------------|---------------------------------------|
|            |               |      |                        | после<br>сброса |                                       |
| 0xE000E000 | InterruptType |      |                        | зороси          |                                       |
| 0x008      | ACTLR         | RW   | Привилеги-             | 0x00000000      | Дополнительный                        |
|            | _             |      | ,<br>рованный          |                 | регистр управления                    |
| 0xE000ED00 | SCB           |      | •                      |                 | Блок управления                       |
|            |               |      |                        |                 | системой                              |
| 0x000      | CPUID         | RO   | Привилеги-             | 0x412FC230      | Регистр                               |
|            |               |      | рованный               |                 | идентификации                         |
|            |               |      |                        |                 | процессора                            |
| 0x004      | ICSR          | RW   | Привилеги-             | 0x00000000      | Регистр управления                    |
|            | \/705         | 5)4/ | рованный               |                 | прерываниями                          |
| 0x008      | VTOR          | RW   | Привилеги-             | 0x00000000      | Регистр смещения                      |
|            |               |      | рованный               |                 | таблицы векторов                      |
| 0x00C      | AIRCR         | DW   | Привидови              | 0.500000        | прерываний                            |
| UXUUC      | AIRCR         | RW   | Привилеги-<br>рованный | 0xFA050000      | Регистр управления                    |
|            |               |      | рованный               |                 | прерываниями и<br>программного сброса |
| 0x010      | SCR           | RW   | Привилеги-             | 0x00000000      | Регистр управления                    |
| 0,010      | JOIN          | 1200 | рованный               | 0.0000000       | системой                              |
| 0x014      | CCR           | RW   | Привилеги-             | 0x00000200      | Регистр конфигурации                  |
| 0,014      | OOK           | 1    | рованный               | 0,00000200      | и управления                          |
| 0x018      | SHPR1         | RW   | Привилеги-             | 0x00000000      | Регистр №1                            |
|            |               |      | рованный               |                 | приоритета системных                  |
|            |               |      | '                      |                 | обработчиков                          |
| 0x01C      | SHPR2         | RW   | Привилеги-             | 0x00000000      | Регистр №2 приори-                    |
|            |               |      | рованный               |                 | тета системных                        |
|            |               |      |                        |                 | обработчиков                          |
| 0x020      | SHPR3         | RW   | Привилеги-             | 0x00000000      | Регистр №3                            |
|            |               |      | рованный               |                 | приоритета системных                  |
|            |               |      |                        |                 | обработчиков                          |
| 0x024      | SHCRS         | RW   | Привилеги-             | 0x00000000      | Регистр управления и                  |
|            |               |      | рованный               |                 | состояния системных                   |
| 0.000      | CECD          | DW   | Привидови              | 0.0000000       | обработчиков                          |
| 0x028      | CFSR          | RW   | Привилеги-             | 0x00000000      | Регистр состояния<br>отказов с        |
|            |               |      | рованный               |                 | конфигурируемым                       |
|            |               |      |                        |                 | приоритетом                           |
| 0x028      | MMSR          | RW   | Привилеги-             | 0x00            | Регистр состояния                     |
| 0,1020     |               |      | рованный               | 0.00            | отказов доступа к                     |
|            |               |      |                        |                 | памяти                                |
| 0x029      | BFSR          | RW   | Привилеги-             | 0x00            | Регистр состояния                     |
|            |               |      | ,<br>рованный          |                 | отказов доступа к шине                |
| 0x02A      | UFSR          | RW   | Привилеги-             | 0x0000          | Регистр состояния                     |
|            |               |      | рованный               |                 | отказов, вызванных                    |

| Адрес | Имя  | Тип | Доступ     | Значение<br>после<br>сброса | Описание              |
|-------|------|-----|------------|-----------------------------|-----------------------|
|       |      |     |            |                             | ошибками              |
|       |      |     |            |                             | программирования      |
| 0x02C | HFSR | RW  | Привилеги- | 0x00000000                  | Регистр состояния     |
|       |      |     | рованный   |                             | тяжелого отказа       |
| 0x034 | MMAR | RW  | Привилеги- | He                          | Регистр адреса отказа |
|       |      |     | рованный   | определено                  | доступа к памяти      |
| 0x038 | BFAR | RW  | Привилеги- | He                          | Регистр адреса отказа |
|       |      |     | рованный   | определено                  | доступа к шине        |

# 38.1 Упрощенный доступ к регистрам блока управления системой

В целях повышения эффективности в CMSIS предусмотрен упрощенный доступ к регистрам SCB из среды разработки программного обеспечения, а именно, регистры SHPR1-SHPR3 в CMSIS отображаются на массив байтов SHP[0]...SHP[12].

# 38.1.1 InterrupType->ACTLR

Дополнительный регистр управления

Регистр ACTLR позволяет разрешить или запретить следующие возможности процессора:

- вложение условных инструкций (IT folding);
- использование буферизации записи в режиме отображения памяти по умолчанию (default memory map);
- прерывание многоэлементных инструкций чтения и записи регистров.

Обобщенные данные о регистре ACTLR представлены далее.

Таблица 38-2 – Дополнительный регистр управления

| Номер  | 313 | 2       | 1          | 0          |
|--------|-----|---------|------------|------------|
| Доступ | U   | R/W     | R/W        | R/W        |
| Сброс  | 0   | 0       | 0          | 0          |
|        | -   | DISFOLD | DISDEFWBUF | DISMCYCINT |

DISFOLD – установка разряда в 1 запрещает вложение условных инструкций (IT folding) (см. ниже "О вложении условных инструкций").

DISDEFWBUF — установка в 1 запрещает использование буфера записи при работе в режиме отображения памяти по умолчанию (default memory map). Это обеспечивает возможность локализовать любые отказы шины, однако приводит к снижению производительности системы, так как все операции записи данных в память должны быть завершены до того, как процессор перейдет к выполнению следующей инструкции. Данный бит влияет исключительно на функционирование буферов записи, реализованных в процессоре RISC.

DISMCYCINT – установка бита в 1 запрещает прерывание многоэлементных инструкций чтения и записи регистров (LDM и STM). Это приводит к увеличению задержки обработки прерываний, вследствие необходимости завершения выполнения инструкций LDM или STM перед началом сохранения контекста и передачи управления обработчику прерывания.

### О вложении условных инструкций

В некоторых случаях процессор может начать выполнение первой инструкции в IT-блоке, все еще выполняя инструкцию IT. Эта возможность, называемая далее вложением условных инструкций (IT folding), позволяет увеличить производительность системы, однако может привести к непостоянству времени выполнения тела цикла программы («джиттеру»). В случае, если в разрабатываемом приложении это нежелательно, следует установить бит DISFOLD в 1.

### 38.1.2 SCB->CPUID

Регистр идентификации процессора

Регистр CPUID содержит информацию о модели процессора, версии и варианте его реализации. Таблица 38-3 предоставляет более подробную информацию.

Таблица 38-3 – Регистр идентификации процессора

| Номер  | 3124        | 2320    | 1916     | 154    | 30       |
|--------|-------------|---------|----------|--------|----------|
| Доступ | RO          | RO      | RO       | RO     | RO       |
| Сброс  | 0x41        | 0x2     | 0xF      | 0xC23  | 0x0      |
|        | Implementer | Variant | Constant | PartNo | Revision |

Implementer – код разработчика 0x41 = MILANDR.

Variant – значение r в номере версии r прп изделия: 0x2 = r2p0;

Constant – постоянное значение 0xF;

PartNo - номер модели процессора: 0xC23 = RISCore;

Revision – значение р в номере версии rnpn изделия: 0x0 = r2p0.

### 38.1.3 *SCB->ICSR*

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

Perистр ICSR обеспечивает возможность установки и сброса состояния ожидания обслуживания для исключений PendSV и SysTick, а также доступ к следующей информации:

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

Таблица 38-4 – Регистр управления прерываниями

| Номер  | 3129 | 28        | 27        | 26        | 25        | 24 | 23                    | 22         | 2112        | 11        | 10 | 9 | 80         |
|--------|------|-----------|-----------|-----------|-----------|----|-----------------------|------------|-------------|-----------|----|---|------------|
| Доступ | U    | R/W       | WO        | R/W       | WO        | U  | R/W                   | R/W        | R/W         | R/W       | U  | U | R/W        |
| Сброс  | 0    | 0         | 0         | 0         | 0         | 0  | 0                     | 0          | 0           | 0         | 0  | 0 | 0          |
|        | -    | PENDSVSET | PENDSVCLR | PENDSTSET | PENDSTCLR | -  | Reserved for<br>Debug | ISRPENDING | VECTPENDING | RETTOBASE |    |   | VECTACTIVE |

PENDSVSET (RW) – бит установки состояния ожидания обслуживания для исключения PendSV.

**Запись 0** – не влияет на работу системы, 1 – переводит исключение PendSV в состояние ожидания обслуживания.

**Чтение 0** – исключение PendSV не ожидает обслуживания, 1 – ожидает.

Запись 1 — это единственно возможный способ перевода исключения PendSV в состояние ожидания обслуживания.

PENDSVCLR (WO) – бит сброса состояния ожидания обслуживания для исключения PendSV.

**Запись 0** – не влияет на работу системы.

**Запись 1** – сбрасывает состояние ожидания обслуживания для исключения PendSV.

PENDSTSET (RW) – бит установки состояния ожидания обслуживания для исключения SysTick.

**Запись 0** – не влияет на работу системы.

**Запись 1** – переводит исключение SysTick в состояние ожидания обслуживания.

**Чтение 0** – исключение SysTick не ожидает обслуживания. **1** – ожидает.

PENDSTCLR (WO) – бит сброса состояния ожидания обслуживания для исключения SysTick.

**Запись 0** – не влияет на работу системы.

**Запись 1** – сбрасывает состояние ожидания обслуживания для исключения SysTick.

Данный бит доступен только для записи, при чтении результат не определен.

Reserved for Debug use (RO) – этот бит зарезервирован для целей отладки, при чтении вне режима отладки возвращает значение 0.

ISRPENDING (RO) — флаг наличия в системе прерываний (за исключением отказов), ожидающих обслуживания. 0 — ожидающие обслуживания прерывания отсутствуют, 1 — присутствуют.

VECTPENDING (RO) — содержит номер ожидающего обслуживания исключения с наивысшим приоритетом, обработка которого в системе разрешена. 0 — необслуженных исключений нет, другое число — номер ожидающего обслуживания исключения.

Значение данного поля формируется с учетом полей BASEPRI и FAULTMASK, однако не учитывает влияние поля PRIMASK.

RETTOBASE (RO) – показывает наличие в системе активных исключений, обслуживание которых было прервано. 0 – присутствуют, 1 – отсутствуют.

VECTACTIVE (RO) – содержит номер активного исключения. 0 – режим приложения, другое число – номер текущего обслуживаемого исключения. Для получения номера запроса прерывания (IRQ) из значения VECTACTIVE необходимо вычесть 16.

Запись в регистр ICSR может привести к непредсказуемым результатам в случае:

- одновременной установки в 1 бит PENDSVSET и PENDSVCLR;
- одновременной установки в 1 бит PENDSTSET и PENDSTCLR.

### 38.1.4 *SCB->VTOR*

Регистр смещения таблицы векторов прерываний

Регистр VTOR содержит смещение базового адреса таблицы векторов прерываний относительно адреса 0x00000000.

Таблица 38-5 - Регистр смещения таблицы векторов прерываний

| Номер  | 31 | 30 | 29  | 7   | 60       |
|--------|----|----|-----|-----|----------|
| Доступ | U  | U  | R/W | R/W | R/W      |
| Сброс  | 0  | 0  | 0   | 0   | 0        |
|        | -  | •  | TBL | OFF | Reserved |

TBLOFF – смещение базового адреса таблицы векторов относительно нижней границы карты распределения памяти. Собственно смещение хранится в битах [28:7]. Бит [29] определяет, размещена ли таблица в области кода или в области памяти SRAM: 0 = область кода, 1 = SRAM. Бит [29] может также обозначаться как TBLBASE.

При установке значения TBLOFF требуется обеспечить выравнивание базового адреса таблицы векторов. Минимальный размер выравнивания – по границе блока из 32 слов, достаточен для хранения 16 векторов прерываний. Для поддержки большего количества прерываний необходимо увеличить размер выравнивания до ближайшей степени двойки, большей или равной размеру таблицы. Например, для хранения 21 вектора прерываний таблицу следует выровнять по границе блока из 64 слов, так как ее объем составляет 37 слов, а ближайшая степень двойки, большая или равная 37, равна 64.

Учитывая описанные выше требования по выравниванию, разряды [6...0] смещения всегда равны нулю.

### 38.1.5 *SCB->AIRCR*

Регистр управления прерываниями и программного сброса

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

Для записи данных в регистр необходимо установить его поле VECTKEY в значение 0x05FA, в противном случае попытка записи будет проигнорирована процессором.

Таблица 38-6 – Регистр управления прерываниями и программного сброса

| Номер  | 3116                                             | 15        | 1411 | 108      | 73 | 2           | 1             | 0         |
|--------|--------------------------------------------------|-----------|------|----------|----|-------------|---------------|-----------|
| Доступ | R/W                                              | RO        | U    | R/W      | U  | WO          | WO            | WO        |
| Сброс  | 0                                                | 0         | 0    | 0        | 0  | 0           | 0             | 0         |
|        | On Read:<br>VECTKEYSTAT,<br>On Write:<br>VECTKEY | ENDIANESS | •    | PRIGROUP | •  | SYSRESETREQ | VECTCLRACTIVE | VECTRESET |

VECTKEYSTAT – ключ доступа к регистру. При чтении возвращает 0xFA05.

VECTKEY – ключ доступа к регистру. При записи должен быть равен 0x05FA, в противном случае попытка записи в регистр будет проигнорирована процессором.

ENDIANESS (RO) – порядок следования значащих разрядов при доступе к данным. 0 – младший байт идет первым (little-endian), 1 – старший байт идет первым (big-endian). Значение поля устанавливается, исходя из уровня конфигурационного сигнала BIGEND в момент сброса системы.

PRIGROUP (RW) – группировка приоритетов исключений. Значение данного поля определяет положение двоичной точки, разделяющей поле приоритета на поля номера группы и подгруппы приоритетов.

PRIGROUP – определяет позицию двоичной точки, разделяющей поля PRI\_n регистров приоритета прерываний на два подполя – номер группы и номер подгруппы. Таблица 38-7 показывает зависимость этого разбиения от значения PRIGROUP.

Таблица 38-7 – Группировка приоритетов прерываний

|                               | Значение пр                    | иоритета в і             | поле PRI_N[7:0]          | Общее количество |          |  |  |
|-------------------------------|--------------------------------|--------------------------|--------------------------|------------------|----------|--|--|
| PRIGROUP                      | Положение<br>двоичной<br>точки | Биты<br>номера<br>группы | Биты номера<br>подгруппы | групп            | подгрупп |  |  |
| 0b000, 0b001,<br>0b010, 0b011 | bxxxx.0000                     | [7:4]                    | None                     | 16               | 1        |  |  |
| b100                          | bxxx.y0000                     | [7:5]                    | [4]                      | 8                | 2        |  |  |
| b101                          | bxx.yy0000                     | [7:6]                    | [5:4]                    | 4                | 4        |  |  |
| b110                          | bx.yyy0000                     | [7]                      | [6:4]                    | 2                | 8        |  |  |
| b111                          | b.yyyy0000                     | None                     | [7:4]                    | 1                | 16       |  |  |

SYSRESETREQ (WO) – запрос сброса системы. 0 – не влияет на работу, 1 – инициирует сигнал сброса процессора. При чтении возвращает 0.

VECTCLRACTIVE (WO) – зарезервировано для целей отладки. При чтении возвращает 0. При записи данных в регистр значение поля должно быть равно 0, в противном случае результат непредсказуем.

VECTRESET (WO) – зарезервировано для целей отладки. При чтении возвращает 0. При записи данных в регистр значение поля должно быть равно 0, в противном случае результат непредсказуем.

### 38.1.6 SCB->SCR

Регистр управления системой

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

Таблица 38-8 – Регистр управления системой

| Номер  | 315 | 4         | 3 | 2         | 1          | 0 |
|--------|-----|-----------|---|-----------|------------|---|
| Доступ | U   | R/W       | U | R/W       | R/W        | U |
| Сброс  | 0   | 0         | 0 | 0         | 0          | 0 |
|        | -   | SEVONPEND | - | SLEEPDEEP | SLEEONEXIT | - |

SEVONPEND – разрешает или запрещает формирование сигнала события при переводе исключения в состояние ожидания обработки. 0 — выход из режима пониженного энергопотребления по прерыванию могут инициировать только разрешенные прерывания или события; 1 — выход может инициироваться разрешенными событиями и любыми, в том числе запрещенными, прерываниями.

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

Кроме того, процессор может быть выведен из режима пониженного энергопотреблении при поступлении внешнего события, а также после выполнения инструкции SEV.

SLEEPDEEP – определяет режим пониженного энергопотребления процессора:

- 0 спящий режим (Sleep);
- 1 режим глубокого сна (Deep Sleep).

SLEEPONEXIT – разрешает или запрещает перевод процессора в режим пониженного энергопотребления при выходе из обработчика события в режим выполнения прикладной программы: 0 – не переводить, 1 – переводить.

### 38.1.7 *SCB->CCR*

Регистр конфигурации и управления

Регистр ССR управляет процессом перехода процессора в режим приложения, а также позволяет запретить или разрешить:

- игнорирование отказов доступа к шине в обработчиках тяжелых отказов и при эскалации отказа по FAULTMASK;
- генерацию исключений при делении на ноль и при доступе по невыровненному адресу;
- доступ к регистру STIR из непривилегированного приложения (см. NVIC->STIR).

| Номер  | 3110 | 9        | 8         | 75 | 4         | 3           | 2 | 1            | 0              |
|--------|------|----------|-----------|----|-----------|-------------|---|--------------|----------------|
| Доступ | U    | R/W      | R/W       | U  | R/W       | R/W         | J | R/W          | R/W            |
| Сброс  | 0    | 0        | 0         | 0  | 0         | 0           | 0 | 0            | 0              |
|        | -    | STKALIGN | BFHFNMIGN | -  | DIV_O_TRP | UNALIGN_TRP | - | USERSETMPEND | NONBASETHRDENA |

Таблица 38-9 – Регистр конфигурации и управления

STKALIGN определяет режим выравнивания адреса стека при обработке исключений: 0 – выравнивание по границе 4 байт; 1 – выравнивание по границе 8 байт. При передаче управления на обработчик исключения процессор анализирует бит [9] сохраненного в стеке слова состояния PSR и определяет по нему режим выравнивания стека. При возврате из обработчика процессор использует сохраненный в стеке бит этого слова для восстановления требуемого режима выравнивания.

ВFHFNMIGN разрешает обработчикам с уровнем приоритета -1 и -2 игнорировать отказы доступа к шине, вызванные инструкциями чтения и записи. Бит влияет на функционирование обработчиков тяжелых отказов и при эскалации отказов по FAULTMASK. 0 — отказы доступа к шине данных, вызванные инструкциями чтения или записи, приводят к блокировке процессора; 1 — обработчики с уровнем приоритета -1 и -2 игнорируют указанные отказы доступа к шине данных. Данный бит следует устанавливать лишь в том случае, если обработчик и используемые им данные размещены в абсолютно безопасной области памяти. Как правило, данный бит используется для локализации и исправления проблем доступа к системным устройствам и мостам ввода-вывода.

DIV\_0\_TRP разрешает процессору формировать отказ или останавливаться в случае деления на ноль при выполнении инструкций SDIV или UDIV. 0 — не обрабатывать деление на 0. 1 — обрабатывать. В случае, если бит установлен в 0, при делении на ноль процессор устанавливает частное в 0.

UNALIGN\_TRP разрешает процессору формировать отказ при невыровненном доступе к данным. 0 – не обрабатывать невыровненный доступ к словам или полусловам данных. 1 – обрабатывать. Если бит равен 1, то невыровненный доступ приводит к отказу, вызванному ошибкой программирования (usage fault).

В случае невыровненного доступа по инструкциям LDM, STM, LDRD или STRD отказ формируется всегда, вне зависимости от значения бита UNALIGN\_TRP.

USERSETMPEND разрешает доступ к регистру STIR (см. NVIC->STIR) из непривилегированного приложения. 0 – доступ запрещен, 1 – разрешен.

NONEBASETHRDENA определяет процедуру перехода процессора в режим приложения (Thread mode): 0 – процессор может перейти в режим приложения только в случае отсутствия активных исключений, 1 – процессор может перейти в режим приложения из обработчика любого уровня, в соответствии со значением слова EXC\_RETURN (см. «Возврат из обработчика исключения»).

### 38.1.8 *SCB->SHP[x]*

Регистры приоритета системных обработчиков

Регистры приоритета системных обработчиков SHPR1-SHPR3 позволяют установить уровень приоритета обработки исключений.

Доступ к регистрам осуществляется побайтно.

Поля PRI\_N регистров имеют ширину 8 бит, однако в процессоре реализована поддержка доступа только к старшему полубайту [7...4], при чтении данных из младшего полубайта [3...0] процессор возвращает нули, запись в этот полубайт игнорируется.

Таблица 38-10 - Поля приоритета обработчиков системных отказов

| Обработчик отказа                     | Поле       | Описание регистра                            |
|---------------------------------------|------------|----------------------------------------------|
| Отказ доступа к памяти                | SHP[4]     | Demonstration No.                            |
| Отказ доступа к шине                  | SHP[5]     | Регистр №1 приоритета системных обработчиков |
| Ошибка программирования (usage fault) | SHP[6]     | Тобработчиков                                |
| Вызов SVCall                          | CHD[44]    | Регистр №2 приоритета системных обработчиков |
| DBISOB OV Call                        | Of II [11] | обработчиков                                 |
| Вызов PendSV                          | SHP[14]    | Регистр №3 приоритета системных              |
| Вызов SysTick                         |            | обработчиков                                 |

### Регистр №1 приоритета системных обработчиков

Таблица 38-11 – Регистр №1 приоритета системных обработчиков

| Номер  | 3124          | 2316  | 158   | 70    |
|--------|---------------|-------|-------|-------|
| Доступ | R/W           | R/W   | R/W   | R/W   |
| Сброс  | 0             | 0     | 0     | 0     |
|        | PRI_7: Резерв | PRI_6 | PRI_5 | PRI_4 |

PRI 7 Резерв.

PRI 6 Приоритет системного обработчика 6, ошибка программирования.

PRI 5 Приоритет системного обработчика 5, отказ доступа к шине.

PRI 4 Приоритет системного обработчика 4, отказ доступа к памяти.

# Регистр №2 приоритета системных обработчиков

Таблица 38-12 - Регистр №2 приоритета системных обработчиков

| Номер  | 3124   | 230 |
|--------|--------|-----|
| Доступ | R/W    | U   |
| Сброс  | 0      | 0   |
|        | PRI_11 | -   |

PRI 11 Приоритет системного обработчика 11, вызов SVCall.

# Регистр №3 приоритета системных обработчиков

Таблица 38-13 - Регистр №3 приоритета системных обработчиков

| Номер  | 3124   | 2316   | 15 0 |
|--------|--------|--------|------|
| Доступ | R/W    | R/W    | U    |
| Сброс  | 0      | 0      | 0    |
|        | PRI_15 | PRI_14 | •    |

PRI\_15 Приоритет системного обработчика 15, вызов SysTick.

PRI\_14 Приоритет системного обработчика 14, вызов PendSV.

### 38.1.9 *SCB->SHCSR*

Регистр управления и состояния системных обработчиков.

Регистр SHCSR позволяет разрешить или запретить работу системных обработчиков, а также содержит сведения:

- о наличии ожидающих обработки отказов доступа к шине, управления памятью, а также вызов SVCall;
- об активных системных обработчиках.

Таблица 38-14 - Регистр управления и состояния системных обработчиков

| Номер  | 3119 | 18          | 17          | 16          | 15           | 14             | 13             | 12             | 11         | 10        | 9 | 8          | 7          | 64 | 3           | 2 | 1           | 0           |
|--------|------|-------------|-------------|-------------|--------------|----------------|----------------|----------------|------------|-----------|---|------------|------------|----|-------------|---|-------------|-------------|
| Доступ | U    | R/W         | R/W         | R/W         | R/W          | R/W            | R/W            | R/W            | R/W        | R/W       | J | R/W        | R/W        | J  | R/W         | U | R/W         | R/W         |
| Сброс  | 0    | 0           | 0           | 0           | 0            | 0              | 0              | 0              | 0          | 0         | 0 | 0          | 0          | 0  | 0           | 0 | 0           | 0           |
|        | -    | USGFAULTENA | BUSFAULTENA | MEMFAULTENA | SVCALLPENDED | BUSFAULTPENDED | MEMFAULTPENDED | USGFAULTPENDED | SYSTICKACT | PENDSVACT | 1 | MONITORACT | CVCALLAVCT | 1  | USGFAULTACT | • | BUSFAULTACT | MEMFAULTACT |

USGFAULTENA разрешение обработки отказов, вызванных ошибками программирования: 1 – разрешено, 0 – запрещено.

BUSFAULTENA разрешение обработки отказа доступа к шине: 1 – разрешено, 0 – запрещено.

MEMFAULTENA разрешение обработки отказа доступа к памяти: 1 – разрешено, 0 – запрещено.

SVCALLPENDED признак ожидания обработки вызова SVC: возвращает 1, если вызов ожидает обработки.

BUSFAULTPENDED признак ожидания обработки отказа доступа к шине: возвращает 1, если отказ ожидает обработки.

MEMFAULTPENDED признак ожидания обработки отказа доступа к памяти: возвращает 1, если отказ ожидает обработки.

USGFAULTPENDED признак ожидания обработки отказа, вызванного ошибками программирования: возвращает 1, если отказ ожидает обработки.

SYSTICKACT признак активности обработчика исключения SysTick: возвращает 1, если обработчик активен.

PENDSVACT признак активности обработчика исключения PendSV: возвращает 1, если обработчик активен.

MONITORACT признак активности монитора отладчика: возвращает 1, если монитор отладчика активен.

SVCALLACT признак активности обработчика вызова SVC: возвращает 1, если обработчик активен.

USGFAULTACT признак активности обработчика отказа, вызванного ошибкой программирования: возвращает 1, если обработчик активен.

BUSFAULTACT признак активности обработчика отказа доступа к шине, возвращает 1, если обработчик активен.

MEMFAULTACT признак активности обработчика отказа доступа к памяти: возвращает 1, если обработчик активен.

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

- 1. Установка бита разрешения в 1 разрешает обработку исключения, установка в 0 запрещает;
- 2. Чтение 1 из бита-признака активности свидетельствует об активности исключения, 0 о его неактивности. Существует возможность записи значения в данный бит для принудительного перевода исключения в активное состояние, однако при этом следует предпринять меры предосторожности, описанные далее в разделе;
- 3. Чтение 1 из бита-признака ожидания свидетельствует о том, что исключение находится в состоянии ожидания обработки. Существует

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

Если в системе возникло исключение (отказ), обработчик которого запрещен, процессор формирует запрос на обработку тяжелого отказа.

Существует возможность принудительного перевода того или иного системного исключения в состояние ожидания обработки или активное состояние путем записи в соответствующий разряд регистра SHCSR.

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

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

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

### 38.1.10 SCB->CFSR

Регистр состояния отказов с конфигурируемым уровнем приоритета.

Регистр CFSR содержит информацию о причине возникновения отказов управления памятью, отказов доступа к шине и ошибок программирования (usage fault).

Таблица 38-15 – Регистр состояния отказов с конфигурируемым уровнем приоритета

|        | Usage Fault Status Register:<br>UFSR | Bus Fault Status<br>Register: BFSR | Memory Management Fault Status Register: MMFSR |  |  |  |  |  |
|--------|--------------------------------------|------------------------------------|------------------------------------------------|--|--|--|--|--|
| Сброс  | 0                                    | 0                                  | 0                                              |  |  |  |  |  |
| Доступ | R/W                                  | R/W                                | R/W                                            |  |  |  |  |  |
| Номер  | 3116                                 | 158                                | 70                                             |  |  |  |  |  |

Perистр CFSR доступен побайтно. Возможны следующие варианты доступа к регистру CFSR и его отдельным элементам:

- слово по адресу 0xE000ED28 полный регистр CFSR;
- байт по адресу 0xE000ED28 регистр MMFSR;
- полуслово по адресу 0xE000ED28 регистры MMFSR и BFSR;
- байт по адресу 0хЕ000ED29 регистр BFSR;
- полуслово по адресу 0хЕ000ED2A регистр UFSR.

В последующих подразделах подробно описаны элементы, составляющие регистр CFSR:

- регистр состояния отказов доступа к памяти;
- регистр состояния отказов доступа к шине;
- регистр состояния отказов, вызванных ошибками программирования.

#### 38.1.11 Поле *MMFSR*

Регистр состояния отказов доступа к памяти

Perистр MMFSR содержит набор флагов, указывающих на различные причины отказа доступа к памяти.

Номер 6 2 0 Досту R/W R/W R/W U R/W R/W Сброс 0 0 0 0 0 0 0 0 **MMARVALI** MUNSTKER DACCVIO **IACCVIO MSTKER** D R R

Таблица 38-16 – Регистр состояния отказов доступа к памяти

ММARVALID признак корректности значения в регистре адреса отказа доступа к памяти (MMAR): 0 – значение в MMAR не содержит корректный адрес отказа, 1 – содержит.

В случае, если произошла эскалация отказа доступа к памяти, обработчик тяжелого отказа должен установить этот бит в 0. В противном случае, после возврата в обработчик отказа доступа к памяти, возможна его некорректная работа, так как значение регистра MMAR будет изменено.

MSTKERR признак отказа на этапе сохранения в стеке контекста при передаче управления на обработчик исключения: 0 — отсутствует, 1 — попытка сохранения в стеке контекста при вызове обработчика исключения вызвала одно или несколько нарушений доступа к памяти. В случае, если бит равен 1, значение указателя стека SP по прежнему корректно, однако содержимое стека может быть неверным. Адрес отказа в регистр MMAR не записывается.

MUNSTKERR признак отказа на этапе восстановления контекста из стека при выходе из обработчика исключения: 0 – отсутствует, 1 – попытка восстановления контекста из стека вызвала одно или несколько нарушений доступа к памяти.

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

Адрес отказа в регистр MMAR не записывается.

DACCVIOL признак нарушения доступа к памяти данных: 0 – отсутствует, 1 – процессор попытался прочесть или записать данные в области, для которой не разрешён такой тип доступа. Если бит равен 1, значение счетчика команд PC, сохраненное в стеке, указывает на инструкцию, вызвавшую отказ. В регистре MMAR содержится адрес, по которому была осуществлена попытка доступа к памяти.

IACCVIOL признак нарушения доступа к памяти команд: 0 — отсутствует, 1 — процессор попытался считать очередную команду из области памяти, для которой не разрешено выполнение. Этот отказ возникает всякий раз при доступе к области, помеченной как неразрешенная для выполнения (XN), даже в случае, если блок защиты памяти MPU не активен (disabled) или отсутствует. Если бит равен 1, значение

счетчика команд PC, сохраненное в стеке, указывает на инструкцию, вызвавшую отказ. Адрес отказа в регистр MMAR не записывается.

#### 38.1.12 Поле BFSR

Регистр состояния отказов доступа к шине

Регистр BFSR содержит набор флагов, указывающих на различные причины отказа доступа к шине:

Таблица 38-17 – Регистр состояния отказов доступа к шине

| Номер  | 7               | 6 | 5 | 4      | 3        | 2                  | 1                | 0              |
|--------|-----------------|---|---|--------|----------|--------------------|------------------|----------------|
| Доступ | R/W             | C | C | R/W    | R/W      | R/W                | R/W              | R/W            |
| Сброс  | 0               | 0 | 0 | 0      | 0        | 0                  | 0                | 0              |
|        | <b>BFRVALID</b> |   |   | STKERR | UNSTKERR | <b>IMPRECISERR</b> | <b>PRECISERR</b> | <b>IBUSERR</b> |

BFARVALID признак корректности значения в регистре адреса отказа доступа к шине (BFAR): 0 – значение в BFAR не содержит корректный адрес отказа, 1 – содержит.

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

В случае, если возникла эскалация отказа, обработчик тяжелого отказа должен установить этот бит в 0. В противном случае, после возврата в обработчик отказа доступа к шине возможна его некорректная работа, так как значение регистра MMAR будет изменено.

STKERR признак отказа на этапе сохранения в стеке контекста при передаче управления на обработчик исключения: 0 — отсутствует, 1 — попытка сохранения в стеке контекста при вызове обработчика исключения вызвала одно или несколько нарушений доступа к шине. В случае, если бит равен 1, значение указателя стека SP по прежнему корректно, однако содержимое стека может быть неверным. Адрес отказа в регистр BFAR не записывается.

UNSTKERR признак отказа на этапе восстановления контекста из стека при выходе из обработчика исключения: 0 – отсутствует, 1 – попытка восстановления контекста из стека вызвала одно или несколько нарушений доступа к шине.

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

Адрес отказа в регистр BFAR не записывается.

IMPRECISERR признак нелокализованной ошибки доступа к шине данных. 0 – отсутствует, 1 – произошла ошибка доступа к шине данных, однако адрес возврата в стековом фрейме не указывает на инструкцию, вызвавшую ошибку. В случае, если процессор установил этот бит в 1, адрес отказа в регистр BFAR не записывается. Данный отказ является асинхронным, таким образом, если он возник внутри процесса, приоритет которого выше, чем приоритет обработки отказа шины, процессор переводит его в состояние ожидания обслуживания до завершения более приоритетных процессов. В случае, если до передачи управления на обработчик

возникла также локализованная ошибка доступа к шине, процессор устанавливает оба соответствующих флага.

PRECISERR признак локализованной ошибки доступа к шине данных. 0 – отсутствует, 1 – произошла ошибка доступа к шине данных, при этом адрес возврата в стековом фрейме указывает на инструкцию, вызвавшую ошибку. В случае, если процессор установил этот бит в 1, он также записывает адрес отказа в регистр BFAR.

IBUSERR признак ошибки доступа к шине инструкций. 0 – отсутствует, 1 – произошла ошибка доступа к шине инструкций. Процессор обнаруживает факт ошибки доступа к шине инструкций на этапе выборки очередной команды, однако признак IBUSERR устанавливается только после попытки выполнения этой инструкции. В случае, если процессор установил этот бит в 1, адрес отказа в регистр BFAR не записывается.

#### 38.1.13 Поле UFSR

Регистр состояния отказов, вызванных ошибками программирования

Perистр UFSR содержит набор флагов, указывающих на различные причины отказа.

Таблица 38-18 – Регистр состояния отказов, вызванных ошибками программирования

| Номер | 151 | 9        | 8        | 7 | 3   | 2    | 1       | 0         |
|-------|-----|----------|----------|---|-----|------|---------|-----------|
|       | 0   |          |          | 4 |     |      |         |           |
| Досту | U   | R/W      | R/W      | U | R/W | R/W  | R/W     | R/W       |
| П     |     |          |          |   |     |      |         |           |
| Сброс | 0   | 0        | 0        | 0 | 0   | 0    | 0       | 0         |
|       | -   | DIVBYZER | UNALIGNE | - | NOC | INVP | INVSTAT | UNDEFINST |
|       |     | 0        | D        |   | Р   | С    | E       | R         |

DIVBYZERO признак деления на ноль: 0 – деления на ноль не было, либо обработка данного типа ошибки запрещена, 1 – процессор выполнил инструкцию SDIV или UDIV с делителем равным 0. Если бит равен 1, значение счетчика команд PC, сохраненное в стеке, указывает на инструкцию, вызвавшую отказ. Разрешить либо запретить обработку деления на ноль можно путем установки в 1 бита DIV\_0\_TRP регистра CCR (см. "SCB->CCR").

UNALIGNED признак доступа к памяти по невыровненному адресу: 0 – не было, либо обработка данного типа ошибки запрещена, 1 – процессор попытался обратиться к памяти по невыровненному адресу. Разрешить либо запретить обработку этой ошибки можно путем установки в 1 бита UNALIGN\_TRP регистра CCR (см. "SCB->CCR"). Инструкции LDM, STM, LDRD, и STRD, пытающиеся обратиться по невыровненному адресу, вызывают исключение всегда, вне зависимости от значения бита UNALIGN\_TRP.

NOCP попытка обращения к сопроцессору. Процессор не поддерживает инструкции, требующие наличия сопроцессора. 0 – не было, 1 – была.

INVPC загрузка неверного значения в счетчик команд PC. 0 – не было, 1 – процессор попытался загрузить в счетчик команд PC неверное значение

EXC\_RETURN, вследствие неправильного восстановления контекста, либо неверного значения EXC\_RETURN. Если бит равен 1, значение счетчика команд PC, сохраненное в стеке, указывает на инструкцию, пытавшуюся загрузить неверное значение в PC.

INVSTATE неверное состояние: 0 — не было, 1 — процессор попытался выполнить инструкцию, связанную с неверным использованием регистра EPSR. Если бит равен 1, значение счетчика команд PC, сохраненное в стеке, указывает на инструкцию, попытавшуюся некорректно использовать регистр EPSR.

UNDEFINSTR попытка выполнения неверной инструкции. 0 – не было, 1 – процессор попытался выполнить неверной инструкцию. Если бит равен 1, значение счетчика команд РС, сохраненное в стеке, указывает на инструкцию, вызвавшую отказ. Под неверной понимается инструкция, которую процессор не смог декодировать.

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

#### 38.1.14 SCB->HFSR

Регистр состояния тяжелого отказа

Регистр HFSR содержит сведения о причинах вызова обработчика тяжелого отказа. Особенностью данного регистра является то, что для сброса в 0 его разрядов необходимо записать в них значение 1.

Таблица 38-19 - Регистр состояния тяжелого отказа

| Номер  | 31       | 30     | 292 | 1       | 0        |
|--------|----------|--------|-----|---------|----------|
| Доступ | R/W      | R/W    | U   | R/W     | R/W      |
| Сброс  | 0        | 0      | 0   | 0       | 0        |
|        | DEBUGEVT | FORCED | -   | VECTTBL | Reserved |

DEBUGEVT бит зарезервирован для отладки. При записи в регистр данный бит должен быть равен 0, в противном случае поведение процессора непредсказуемо.

FORCED признак тяжелого отказа, возникшего вследствие эскалации отказа с конфигурируемым уровнем приоритета, который не может быть обработан (запрещен или имеет недостаточно высокий приоритет): 0 – нет, 1 – да.

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

VECTTBL признак возникновения отказа шины при попытке доступа к таблице векторов исключений: 0 — не было, 1 — было. Эта ошибка всегда вызывает передачу управления на обработчик тяжелого отказа. Если бит равен 1, значение счетчика команд PC, сохраненное в стеке, указывает на инструкцию, выполнение которой было прервано для обработки исключения.

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

#### 38.1.15 SCB->MMFAR

Регистр адреса отказа доступа к памяти

Регистр MMFAR содержит адрес, при обращении по которому возникла ошибка управления памятью.

Таблица 38-20 – Регистр адреса отказа доступа к памяти

| Номер  | 310     |
|--------|---------|
| Доступ | R/W     |
| Сброс  | 0       |
|        | ADDRESS |

ADDRESS если бит MMARVALID регистра MMFSR равен 1, это поле содержит адрес, при обращении по которому возникла ошибка управления памятью. В случае ошибки доступа по невыровненному адресу поле содержит фактическое значение адреса, вызвавшего отказ.

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

Флаги регистра MMFSR содержат информацию о причине отказа, а также сообщают, является ли значение MMFAR корректным. Подробнее см. "Регистры состояния и адреса отказа".

#### 38.1.16 SCB->BFAR

Регистр адреса отказа доступа к шине

Регистр BFAR содержит адрес, при обращении по которому возникла ошибка доступа к шине.

Таблица 38-21 – Регистр адреса отказа доступа к шине

| Номер  | 310     |
|--------|---------|
| Доступ | R/W     |
| Сброс  | 0       |
|        | ADDRESS |

ADDRESS если бит BFARVALID регистра BFSR равен 1, это поле содержит адрес, при обращении по которому возникла ошибка доступа к шине. В случае ошибки доступа по невыровненному адресу поле содержит значение адреса, запрошенного командой процессора, даже если оно не совпадает с адресом, вызвавшем отказ.

Флаги регистра BFSR содержат информацию о причине отказа, а также сообщают, является ли значение BFAR корректным. Подробнее см. "Регистры состояния и адреса отказа".

#### Рекомендации по программированию блока управления системой

Необходимо убедиться, что программа использует для обращения к регистрам блока управления системой доступ по корректно выровненным адресам. Обращение ко всем регистрам, за исключением CFSR и SHPR1-SHPR3, должно быть выровнено по границе слова. Регистры CFSR и SHPR1-SHPR3 допускают как побайтный доступ, так и доступ по адресам, выровненным по границе слова или полуслова.

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

- считать и сохранить значения регистров MMFAR или BFAR;
- проверить значение бита MMARVALID регистра MMFSR, либо бита BFARVALID регистра BFSR. Значения MMFAR или BFAR корректны только в случае, если соответствующие биты равны 1.

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

## 39 Сторожевые таймеры

## 39.1 Описание регистров блока сторожевых таймеров

# Таблица 39-1 – Обобщенная информация о регистрах блока сторожевых таймеров

| Базовый Адрес | Название       | Описание                |
|---------------|----------------|-------------------------|
| 0x4006_8000   | IWDG           | Сторожевой таймер IWDG  |
| Смещение      |                |                         |
| 0x00          | IWDG_KR[15:0]  | Регистр Ключа           |
| 0x04          | IWDG_PR[2:0]   | Делитель частоты        |
|               |                | сторожевого таймера     |
| 0x08          | IWDG_PRL[11:0] | Регистр основания счета |
|               |                | сторожевого таймера     |
| 0x0C          | IWDG_SR[1:0]   | Регистр статуса         |
|               |                | сторожевого таймера     |

| Базовый Адрес | Название      | Описание               |  |  |
|---------------|---------------|------------------------|--|--|
| 0x4006_0000   | WWDG          | Сторожевой таймер WWDG |  |  |
| Смещение      |               |                        |  |  |
| 0x00          | WWDG_CR[7:0]  | Регистр управления     |  |  |
| 0x04          | WWDG_CFR[9:0] | Регистр конфигурации   |  |  |
| 0x08          | WWDG_SR[0]    | Регистр статуса        |  |  |

#### 39.1.1 *IWDG\_KR*

## Таблица 39-2 – Регистр Ключа

| Номер   | 15        |  |  |  |  |  |  | 0 |
|---------|-----------|--|--|--|--|--|--|---|
| Доступ* | W         |  |  |  |  |  |  | W |
| Сброс   | 0         |  |  |  |  |  |  | 0 |
|         | KEY[15:0] |  |  |  |  |  |  |   |

## Таблица 39-3 – Описание бит регистра Ключа

| Nº   | Функционально<br>е имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3116 |                             | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 150  | KEY[15:0]                   | Значение ключа (только запись, читается 0000h) Эти биты должны перезаписываться программно через определённые интервалы ключевым значением AAAAh, в противном случае сторожевой таймер генерирует сброс, если таймер достиг значения нуля. Запись ключевого значения 5555h разрешает доступ по записи к регистрам IWDG_PR и IWDG_RLR. Запись ключевого значения ССССh разрешает работу сторожевого таймера (за исключением, если сторожевой таймер разрешается аппаратно битами конфигурации). Примечание - Сторожевой таймер IWDT не сбрасывается и не останавливается сбросом, а только выключением питания. |

## 39.1.2 *IWDG\_PR*

Таблица 39-4 – Регистр делителя частоты сторожевого таймера

| Номер   | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |
|---------|---|---|---|---|---|-----|-----|-----|
| Доступ* | U | U | U | U | U | R/W | R/W | R/W |
| Сброс   |   |   |   |   |   | 0   | 0   | 0   |
|         | • | - | - | - | - | PR2 | PR1 | PR0 |

## Таблица 39-5 – Описание бит регистра делителя частоты сторожевого таймера

| Nº   | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------|----------------------------|--------------------------------------------------------------------------------------------|
| 04.0 | имя онта                   |                                                                                            |
| 313  |                            | Зарезервировано                                                                            |
| 20   | PR[2:0]                    | Делитель частоты сторожевого таймера                                                       |
|      |                            | 000 – делитель на 4                                                                        |
|      |                            | 001 – делитель на 8                                                                        |
|      |                            | 010 – делитель на 16                                                                       |
|      |                            | 011 – делитель на 32                                                                       |
|      |                            | 100 – делитель на 64                                                                       |
|      |                            | 101 – делитель на 128                                                                      |
|      |                            | 110 – делитель на 256                                                                      |
|      |                            | 111 – делитель на 256                                                                      |
|      |                            | Чтение и запись этого регистра правомерна только, если бит                                 |
|      |                            | PVU=0 в регистре IWDG_SR                                                                   |

## 39.1.3 *IWDG\_RLR*

## Таблица 39-6 – Регистр основания счета сторожевого таймера

| Номер   | 11  |           |  |  |  |  |  | 0   |  |
|---------|-----|-----------|--|--|--|--|--|-----|--|
| Доступ* | R/W |           |  |  |  |  |  | R/W |  |
| Сброс   | 1   |           |  |  |  |  |  | 1   |  |
|         |     | RLR[11:0] |  |  |  |  |  |     |  |

## Таблица 39-7 – Описание бит регистра основания счета сторожевого таймера

| Nº   | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3112 |                         | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 110  | RLR[11:0]               | Значение перезагрузки сторожевого таймера Значение этих битов по доступу защищено с помощью регистра IWDG_KR. Эти биты записываются программно и определяют значение, загружаемое в сторожевой таймер в момент записи значение AAAAh в регистр IWDG_KR. Сторожевой таймер, декрементируется, начиная с этого значения. Период таймаута сторожевого таймера функция от этого значения и делителя частоты. Чтение и запись этого регистра правомерна только, если бит RVU=0 в регистре IWDG_SR. |

## 39.1.4 *IWDG\_SR*

Таблица 39-8 – Регистр статуса сторожевого таймера

| Номер   | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|---------|---|---|---|---|---|---|-----|-----|
| Доступ* | U | U | U | U | U | U | R   | R   |
| Сброс   |   |   |   |   |   |   | 0   | 0   |
|         | - | - | - | - | - | - | RVU | PVU |

## Таблица 39-9 – Описание бит регистра статуса сторожевого таймера

| Nº  | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                  |
|-----|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 312 |                         | Зарезервировано                                                                                                                                                                                                                                                                                                             |
| 1   | RVU                     | Флаг обновления значения сторожевого таймера Этот бит устанавливается аппаратно и служит признаком того, что обновляется значение сторожевого таймера из регистра перезагрузки. Этот бит сбрасывается, если обновление завершено. Значение регистра перезагрузки может быть обновлено только, если этот бит равен нулю.     |
| 0   | PVU                     | Флаг обновления делителя частоты сторожевого таймера Этот бит устанавливается аппаратно и служит признаком того, что обновляется значение делителя частоты сторожевого таймера. Этот бит сбрасывается, если обновление завершено. Значение регистра делителя частоты может быть обновлено только, если этот бит равен нулю. |

## 39.1.5 *WWDG\_CR*

### Таблица 39-10 - Регистр управления

| Номер   | 7    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|---------|------|-----|-----|-----|-----|-----|-----|-----|
| Доступ* | R/S  | R/W |
| Сброс   | 0    | 1   | 1   | 1   | 1   | 1   | 1   | 1   |
|         | WDGA | T6  | T5  | T4  | T3  | T2  | T1  | T0  |

## Таблица 39-11 – Описание бит регистра управления

| Nº   | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|------|-------------------------|--------------------------------------------------------------------------------------------|
| 3118 |                         | Зарезервировано                                                                            |
| 7    | WDGA                    | Бит активации                                                                              |
|      |                         | Этот бит устанавливается программно и очищается только                                     |
|      |                         | аппаратно при сбросе. Когда WDGA=1, сторожевой таймер                                      |
|      |                         | может генерировать сброс.                                                                  |
|      |                         | 0 – сторожевой таймер отключен                                                             |
|      |                         | 1 – сторожевой таймер включен                                                              |
| 60   | T[6:0]                  | Значение семиразрядного счётчика (от старших                                               |
|      |                         | разрядов к младшим)                                                                        |
|      |                         | Эти биты содержат значение сторожевого таймера, который                                    |
|      |                         | декрементируется каждые 4096х2 <sup>WDGTB</sup> циклов частоты                             |
|      |                         | PCLK периферийной шины APB                                                                 |

## 39.1.6 *WWDG\_CFR*

## Таблица 39-12 – Регистр конфигурации

| Номер   | 7      | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|---------|--------|-----|-----|-----|-----|-----|-----|-----|
| Доступ* | R/W    | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Сброс   | 0      | 1   | 1   | 1   | 1   | 1   | 1   | 1   |
|         | WDGTB0 | W6  | W5  | W4  | W3  | W2  | W1  | W0  |

| Номер   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8      |
|---------|----|----|----|----|----|----|-----|--------|
| Доступ* | U  | U  | U  | U  | U  | U  | R/S | R/W    |
| Сброс   |    |    |    |    |    |    | 0   | 0      |
|         | -  | -  | -  | -  | -  | -  | EWI | WDGTB1 |

## Таблица 39-13 – Описание бит регистра конфигурации

| Nº   | Функциональное | Расшифровка функционального имени бита, краткое          |
|------|----------------|----------------------------------------------------------|
|      | имя бита       | описание назначения и принимаемых значений               |
| 3110 |                | Зарезервировано                                          |
| 9    | EWI            | Раннее предупреждающее прерывание                        |
|      |                | Если бит установлен, то разрешается генерация            |
|      |                | прерывания при достижении сторожевым таймером            |
|      |                | значении 40h. Прерывание запрещается только аппаратным   |
|      |                | сбросом.                                                 |
| 87   | WGTB[1:0]      | Делитель частоты сторожевого таймера                     |
|      |                | 00 – частота таймера (PCLK / 4096) /1                    |
|      |                | 01 – частота таймера (PCLK / 4096) /2                    |
|      |                | 10 – частота таймера (PCLK / 4096) /4                    |
|      |                | 11 – частота таймера (PCLK / 4096) /8                    |
| 60   | W[6:0]         | Значение окна                                            |
|      |                | Эти биты содержат значение окна, в пределах которого     |
|      |                | возможна инициализация битов Т[6:0] значением в пределах |
|      |                | 40h-7Fh. Если происходит инициализация битов в момент    |
|      |                | T>W, то формируется сброс на выходе RESET. Если таймер   |
|      |                | достигнет значения T=3Fh, то также формируется сброс.    |

## 39.1.7 *WWDG\_SR*

## Таблица 39-14 – Регистр статуса

| Номер   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|---------|---|---|---|---|---|---|---|------|
| Доступ* | U | U | U | U | U | U | U | R/C  |
| Сброс   |   |   |   |   |   |   |   | 0    |
|         | - | - | - | - | - | - | - | EWIF |

## Таблица 39-15 – Описание бит регистра статуса

| Nº  | Функциональное | Расшифровка функционального имени бита, краткое         |
|-----|----------------|---------------------------------------------------------|
|     | имя бита       | описание назначения и принимаемых значений              |
| 311 |                | Зарезервировано                                         |
| 0   | EWIF           | Флаг раннего предупреждающего прерывания                |
|     |                | Этот бит устанавливается аппаратно, когда сторожевой    |
|     |                | таймер достигает значения 40h. Бит очищается программно |
|     |                | записью нуля. Запись единицы не влияет. Этот бит также  |
|     |                | устанавливается, если прерывание запрещено EWI=0.       |

## 40 Типовая схема включения



1901ВЦ1Т – включаемая микросхема;

C1 — конденсатор емкостью 22 мкФ ± 5 %, 16 B; C2-C13 — конденсаторы емкостью 0,1 мкФ ± 5 %, 16 B;

G1 – источник постоянного напряжения, (3,0 – 3,6) В G2 – источник постоянного напряжения, (1,8 – 3,6) В

Рисунок 40-1 - Типовая схема включения микросхемы

## 41 Типовые зависимости



Рисунок 41–1 — Зависимость статического тока потребления в режиме покоя (регулятор напряжения выключен) от напряжения источника питания, при T=25 °C



**Рисунок 41–3** – Зависимость динамического тока потребления модуля ПЦОС от температуры, при  $U_{CC}$  =3,6 B,  $f_{C DSP}$ =100 МГц,  $f_{C RISC}$ =0 МГц



**Рисунок 41–5** – Зависимость динамического тока потребления от температуры, при  $U_{CC}$  =3,6 B,  $f_{CDSP}$  =0 МГц,  $f_{CRISC}$  =70 МГц



Рисунок 41–2 – Зависимость динамического тока потребления модуля ПЦОС от частоты следования импульсов тактовых сигналов, при T=25 °C, U<sub>CC</sub> =3,6 B, f<sub>C RISC</sub> =70 МГц



Рисунок 41–4 — Зависимость динамического тока потребления RISC-процессора от частоты следования импульсов тактовых сигналов, при T=25 °C,  $U_{CC}=3,6$  B,  $f_{CDSP}=100$  МГц



**Рисунок 41–6** – Зависимость динамического тока потребления модуля ПЦОС от напряжения источника питания,

при T=25 °C,  $f_{CDSP}$  =100 МГц,  $f_{CRISC}$  =0 МГц



Рисунок 41–7 – Зависимость динамического тока потребления от напряжения источника питания, при T=25 °C, f<sub>C DSP</sub> =0 МГц,



**Рисунок 41–9** – Зависимость выходного напряжения низкого уровня от выходного тока нагрузки, при T=25 °C, U<sub>CC</sub> =3,0 В



**Рисунок 41–8** – Зависимость выходного напряжения высокого уровня от выходного тока нагрузки, при T=25 °C, U<sub>CC</sub> =3,0 В

# 42 Предельные и предельно-допустимые режимы работы

Таблица 42-1 – Предельные и предельно-допустимые режимы эксплуатации микросхемы

|                                                                                                                                 | <u> </u>                              | Норма параметра          |                        |               |             |  |
|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------------------------|------------------------|---------------|-------------|--|
| Наименование параметра,<br>единица измерения                                                                                    | Буквенное<br>обозначение<br>параметра | допус                    | ельно-<br>тимый<br>жим | Предел<br>реж |             |  |
|                                                                                                                                 | Бу<br>060<br>па                       | не<br>менее              | не<br>более            | не<br>менее   | не<br>более |  |
| Напряжение источника питания, В                                                                                                 | Ucc                                   | 3,0                      | 3,6                    | _             | 4,0         |  |
| Напряжение источника* питания АЦП и ЦАП, В                                                                                      | U <sub>CCA</sub>                      | 3,0                      | 3,6                    | _             | 4,0         |  |
| Напряжение источника* питания аудиокодека, В                                                                                    | U <sub>CCAU</sub>                     | 3,0                      | 3,6                    | _             | 4,0         |  |
| Напряжение источника питания батарейного домена, В                                                                              | U <sub>ССВ</sub>                      | 1,8                      | 3,6                    | -             | 4,0         |  |
| Входное напряжение низкого уровня, В, (при работе в цифровом режиме)                                                            |                                       | 0                        | 0,8                    | минус<br>0,3  | _           |  |
| на выводах: PA, PB, PC, PD, PE, PF, RESET, WAKEUP, DN, DP на выводе: OSC_IN при: BYPASS=1                                       | U <sub>IL</sub>                       | 0                        | 0,2 x Ucc              | минус<br>0,3  | _           |  |
| Входное напряжение высокого уровня, В,                                                                                          |                                       | 2,0                      | Ucc                    | _             | 4,0         |  |
| на выводах: PD, PE (0-10), DN, DP                                                                                               |                                       | 2,0                      | 5,25                   | _             | 5,3         |  |
| на выводах: PA, PB, PC, PE (11-15), PF, RESET, WAKEUP на выводе: OSC_IN при: BYPASS=1                                           | U <sub>IH</sub>                       | 0,8 x<br>U <sub>CC</sub> | U <sub>cc</sub>        | _             | 4,0         |  |
| Выходной ток низкого уровня, мА,<br>(при работе в цифровом режиме)<br>на выводах: РА, РВ, РС, РD, РЕ(1-5, 8-12), РF,<br>STANDBY | l <sub>OL</sub>                       | минус 6                  | _                      | минус 10      | _           |  |
| на выводах: РЕ 6, 7                                                                                                             |                                       | минус 3                  | _                      | минус 10      | _           |  |
| на выводах: DN, DP                                                                                                              |                                       | минус 6                  | _                      | минус 40      | _           |  |
| Выходной ток высокого уровня, мА,<br>на выводах: PA, PB, PC, PD, PE (1-5, 8-12), PF,<br>STANDBY                                 | I <sub>OH</sub>                       | _                        | 6                      | _             | 10          |  |
| на выводах: РЕ 6, 7                                                                                                             |                                       | _                        | 3                      | _             | 10          |  |
| на выводах: DN, DP                                                                                                              |                                       | _                        | 6                      | _             | 40          |  |
| Частота следования импульсов тактовых сигналов RISC-процессора, МГц                                                             | f <sub>C_RISC</sub>                   | _                        | 100                    | _             | _           |  |
| Частота следования импульсов тактовых сигналов модуля ПЦОС, МГц                                                                 | f <sub>C_DSP</sub>                    | _                        | 100                    | _             | _           |  |
| Частота следования импульсов тактовых сигналов HSE, МГц при: BYPASS=0                                                           | $f_{C\_HSE}$                          | 2                        | 16                     | -             | _           |  |
| при: BYPASS=1                                                                                                                   |                                       | 0                        | 100                    | _             | _           |  |
| Частота следования импульсов тактовых сигналов LSE, кГц при: BYPASS=0                                                           | $f_{C\_LSE}$                          | 32                       | 33                     | _             | -           |  |
| при: BYPASS=1                                                                                                                   |                                       | 0                        | 1 000                  | _             | _           |  |
| Частота следования импульсов тактовых сигналов PLL, МГц                                                                         | f <sub>C_PLL</sub>                    | 6                        | 16                     | -             | _           |  |

|                                                                                                                                                                           | аче                                   |                        | Норма пар              | раметра       |                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------------|------------------------|---------------|-------------------------|
| Наименование параметра,<br>единица измерения                                                                                                                              | Буквенное<br>обозначение<br>параметра | допус                  | ельно-<br>тимый<br>жим | Предел<br>реж |                         |
|                                                                                                                                                                           | Бу<br>060<br>па                       | не<br>менее            | не<br>более            | не<br>менее   | не<br>более             |
| Параметры ЦАП                                                                                                                                                             |                                       |                        |                        |               |                         |
| Напряжение верхней границы опоры ЦАП на выводе: DACx_REF при: Cfg_M_REFx=1                                                                                                | U <sub>REF(DACx)</sub>                | 2,4                    | U <sub>CCA</sub>       | Ι             | _                       |
| Резистивная нагрузка ЦАП, кОм при которой гарантируются параметры                                                                                                         | R <sub>LOAD</sub>                     | 10                     | 1                      | -             | _                       |
| Емкостная нагрузка ЦАП, пФ при которой гарантируются параметры                                                                                                            | C <sub>LOAD</sub>                     | _                      | 100                    | -             | _                       |
| Параметры АЦП                                                                                                                                                             |                                       |                        |                        |               |                         |
| Напряжение нижней границы внешнего опорного источника АЦП, В при: ADC1_Cfg_M_REF=1 или ADC2_Cfg_M_REF=1                                                                   | U <sub>ADC1_REF-</sub>                | 0                      | U <sub>CCA</sub> -3,0  | -             | 4,0                     |
| Напряжение верхней границы внешнего опорного источника АЦП, В при: ADC1_Cfg_M_REF=1 или ADC2_Cfg_M_REF=1                                                                  | U <sub>ADC0_REF+</sub>                | 3,0                    | Ucca                   | ı             | 4,0                     |
| Диапазон напряжения внешнего опорного источника АЦП, В при: U <sub>REF(ADC)</sub> = U <sub>ADC0_REF+</sub> — U <sub>ADC1_REF-</sub> ADC1_Cfg_M_REF=1 или ADC2_Cfg_M_REF=1 | UREF(ADC)                             | 3,0                    | Ucca                   | -             | _                       |
| Диапазон напряжения на входе АЦП, В**                                                                                                                                     | U <sub>AIN</sub>                      | U <sub>ADC1_REF-</sub> | U <sub>ADC0_REF+</sub> | минус<br>0,3  | 4,0                     |
| Частота следования импульсов тактовых сигналов АЦП, МГц                                                                                                                   | f <sub>C_ADC</sub>                    | -                      | 14                     | -             | -                       |
| Параметры аудиокодека                                                                                                                                                     |                                       |                        |                        |               |                         |
| Напряжения нуля входного сигнала АЦП, В, на<br>выводах: INP1, INM1, INP2, INM2                                                                                            | U <sub>IAUADC0</sub>                  | 1,3                    | 1,6                    | _             | _                       |
| Максимальная амплитуда входного<br>дифференциального сигнала АЦП, В,<br>на выводах: INP1, INM1, INP2,INM2                                                                 | Uiauadc                               | -                      | 1,05                   | -             | _                       |
| Напряжение на входе АЦП, В,<br>на выводах: INP1, INM1, INP2,INM2, MICIN                                                                                                   | U <sub>IADC</sub>                     | _                      | -                      | минус<br>0,3  | U <sub>CCAU</sub> + 0,3 |
| Частота дискретизации аудиокодека, кГц                                                                                                                                    | f <sub>C_AUC</sub>                    | _                      | 24                     | 1             | _                       |
| Резистивная нагрузка ЦАП, Ом                                                                                                                                              | R <sub>LDAC</sub>                     | 600                    | ı                      | _             | _                       |
| Резистивная нагрузка BIAS, Ом                                                                                                                                             | R <sub>LBIAS</sub>                    | 600                    | _                      | _             | _                       |
| Длительность фронта нарастания/спада входных сигналов, нс при: BYPASS=1                                                                                                   | T <sub>r</sub><br>Tf                  | _                      | 5                      |               |                         |
| Емкость нагрузки, пФ<br>на выводах: PA,PB,PC,PD,PE,PF, STANDBY                                                                                                            | CL                                    | _                      | 30                     | _             | _                       |
| Число циклов записи/стирания данных, при: T=85 °C                                                                                                                         | N <sub>PR</sub>                       | 10 000                 | _                      | _             | _                       |

## Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

|                                              | е<br>ие<br>а               | Норма параметра                   |             |                     |             |  |
|----------------------------------------------|----------------------------|-----------------------------------|-------------|---------------------|-------------|--|
| Наименование параметра,<br>единица измерения | квенно<br>значен<br>раметр | Предельно-<br>допустимый<br>режим |             | Предельный<br>режим |             |  |
|                                              | Бу<br>060<br>па            | не<br>менее                       | не<br>более | не<br>менее         | не<br>более |  |
| Время хранения информации, лет, при: T=25 °C | t <sub>GS</sub>            | 25                                | _           | _                   | _           |  |
| при: T=85 °C                                 | -30                        | 10                                | 1           | _                   | -           |  |

<sup>\*</sup> Допускается использование отдельного источника для питания АЦП, ЦАП и аудиокодека, но при этом его выходное напряжение не должно отличаться от  $U_{CC}$  более чем на  $\pm$  0,2 В.

<sup>\*\*</sup> При использовании внутреннего опорного напряжения  $U_{ADC1\_REF-} = GND$ ,  $U_{ADC0\_REF+} = U_{CCA}$ . Примечание — Не допускается одновременное воздействие двух и более предельных режимов

# 43 Электрические параметры микросхемы

Таблица 43-1 – Электрические параметры микросхемы

| Наименование параметра,                                                                                  | ное<br>эние<br>тра                    |          | ома<br>метра                                 | °C                       |
|----------------------------------------------------------------------------------------------------------|---------------------------------------|----------|----------------------------------------------|--------------------------|
| единица измерения,<br>режим измерения                                                                    | Буквенное<br>обозначение<br>параметра | не менее | не более                                     | Температура<br>среды, °С |
| Выходное напряжение низкого уровня, В, на выводах: РА, РВ, РС, РD, РЕ, РF, STANDBY, DN, DP               | U <sub>OL</sub>                       | _        | 0,4                                          |                          |
| Выходное напряжение высокого уровня, В, на выводах: PA, PB, PC, PD, PE, PF, STANDBY, DN, DP              | U <sub>OH</sub>                       | 2,4      | _                                            |                          |
| Уровень напряжения питания для срабатывания схемы формирования общего сброса, В                          | U <sub>BOR</sub>                      | 1,8      | 2,1                                          |                          |
| Входной ток утечки высокого уровня, мкА,<br>на выводах: PA, PB, PC, PD, PE, PF, DN, DP,<br>RESET, WAKEUP | I <sub>ILH1</sub>                     | минус 1  | 1                                            | 25,<br>85,<br>– 60       |
| Входной ток утечки высокого уровня, мкА,<br>на выводе: OSC_IN<br>при: BYPASS=1                           | I <sub>ILH2</sub>                     | минус 40 | 40                                           | - 00                     |
| Входной ток утечки низкого уровня, мкА,<br>на выводах: PA, PB, PC, PD, PE, PF, RESET,<br>WAKEUP, DN, DP  | I <sub>ILL1</sub>                     | минус 1  | 1                                            |                          |
| Входной ток утечки низкого уровня, мкА,<br>на выводе: OSC_IN<br>при: BYPASS=1                            | I <sub>ILL2</sub>                     | минус 1  | 1                                            |                          |
| Статический ток потребления в режиме покоя (регулятор напряжения выключен), мкА                          | I <sub>ccs</sub>                      | _        | 10                                           | 25,<br>- 60              |
|                                                                                                          |                                       | _        | 20                                           | 85                       |
| Динамический ток потребления, мА, при: fc_DSP= 0 МГц, fc_RISC= 100 МГц                                   | I <sub>OCC1</sub>                     | _        | 180                                          |                          |
| Динамический ток потребления, мА, при: $f_{C\_DSP}$ = 100 МГц, $f_{C\_RISC}$ = 100 МГц                   | I <sub>OCC2</sub>                     | -        | 300                                          |                          |
| Частота работы LSI RC-генератора, кГц                                                                    | f <sub>O_LSI</sub>                    | 10       | 60                                           | 25,                      |
| Частота работы HSI RC-генератора, МГц                                                                    | f <sub>O_HSI</sub>                    | 6        | 10                                           | 85,<br>- 60              |
| Выходная частота PLL, МГц<br>максимальная<br>минимальная                                                 | f <sub>O_PLL</sub>                    | 100<br>- | _<br>6                                       | - 00                     |
| Время выхода из режима sleep, мкс                                                                        | ton                                   | _        | 100                                          |                          |
| Параметры АЦП                                                                                            |                                       | 1        | <u>.                                    </u> |                          |
| Разрядность АЦП                                                                                          | E <sub>NADC</sub>                     | 12       | _                                            |                          |
| Дифференциальная нелинейность АЦП, единица младшего разряда                                              | E <sub>DLADC</sub>                    | минус 1  | 2                                            | 25,                      |
| Интегральная нелинейность АЦП, единица младшего разряда                                                  | E <sub>ILADC</sub>                    | минус 3  | 3                                            | 85,<br>- 60              |
| Ошибка смещения АЦП, единица младшего разряда                                                            | E <sub>OFFADC</sub>                   | минус 6  | 6                                            |                          |

| Наименование параметра,                                                                                                                                            | ное<br>ение<br>тра              |                                 | ома<br>метра | тура                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|---------------------------------|--------------|--------------------------|
| единица измерения,<br>режим измерения                                                                                                                              | Буквенное обозначение параметра | не менее                        | не более     | Температура<br>среды, °С |
| Параметры ЦАП                                                                                                                                                      |                                 |                                 | <u> </u>     |                          |
| Разрядность ЦАП                                                                                                                                                    | E <sub>NDAC</sub>               | 12                              | _            |                          |
| Дифференциальная нелинейность ЦАП, единица младшего разряда                                                                                                        | E <sub>DLDAC</sub>              | минус 1                         | 2            |                          |
| Интегральная нелинейность ЦАП, единица младшего разряда                                                                                                            | E <sub>ILDAC</sub>              | минус 6                         | 6            | 25,<br>85,               |
| Ошибка смещения ЦАП, мВ                                                                                                                                            | E <sub>OFFDAC</sub>             | минус 40                        | 40           | – 60                     |
| Минимальное выходное напряжение ЦАП, В при $R_L$ =10 кОм                                                                                                           | U <sub>O_DAC</sub>              | ı                               | 0,08         |                          |
| Максимальное выходное напряжение ЦАП, В при $R_L$ = 10 кОм                                                                                                         | U <sub>O_DAC</sub>              | U <sub>REF(DAC)</sub> -<br>0,08 | _            |                          |
| Параметры компаратора                                                                                                                                              |                                 |                                 |              |                          |
| Время включения компаратора, мкс                                                                                                                                   | t <sub>ON_C</sub>               | _                               | 100          | 25,                      |
| Время задержки переключения компаратора, нс                                                                                                                        | t <sub>d_C</sub>                | _                               | 400          | 85,<br>- 60              |
| Параметры аудиокодека                                                                                                                                              |                                 |                                 | l l          |                          |
| Коэффициент нелинейных искажений + шум ЦАП,<br>дБ,<br>при: Синус, частота 1 кГц, U <sub>I</sub> *= 0 дБ,<br>DAGAIN= минус 1 дБ                                     | T <sub>DAC</sub>                | 68                              | -            |                          |
| Коэффициент нелинейных искажений + шум АЦП, дБ (для диф. входов INP1/INM1 и INP2/INM2) при: Синус, частота 1 кГц, U <sub>I</sub> **= 0 дБ ADGAIN= 0 дБ, INBG= 0 дБ |                                 | 80                              | -            |                          |
| U <sub>I</sub> **= минус 6 дБ<br>ADGAIN= 0 дБ, INBG= 6 дБ                                                                                                          |                                 | 78                              | _            |                          |
| U <sub>I</sub> **= минус 12 дБ<br>ADGAIN= 0 дБ, INBG= 2 дБ                                                                                                         |                                 | 74                              | _            | 05                       |
| U <sub>I</sub> **= минус 24 дБ<br>ADGAIN= 0 дБ, INBG= 24 дБ                                                                                                        |                                 | 64                              | _            | 25,<br>85,<br>– 60       |
| Ошибка коэффициента входного предусилителя<br>АЦП, дБ                                                                                                              | GAIN<br>ERRADC                  | минус 0,5                       | 0,5          | - 00                     |
| Максимальная амплитуда выходного<br>дифференциального сигнала ЦАП на выходах<br>OUTP1 и OUTM1, B,<br>DAGAINT= минус 1 дБ<br>U <sub>I</sub> *= 0 дБ                 | U <sub>OAUDAC</sub>             | 1,8                             | 2,1          |                          |
| Напряжение нуля выходного сигнала ЦАП, на<br>выходах OUTP1 и OUTM1, B,<br>GAINT=0, MUTE1= 1, ODRCT1= 1                                                             | U <sub>OAUDAC</sub>             | 1,3                             | 1,6          |                          |
| Выходное напряжение BIAS<br>(на выходе BIAS), В                                                                                                                    | U <sub>OBIAS</sub>              | 1,3                             | 1,6          |                          |

<sup>\*</sup> Полная шкала сигнала для ЦАП  $U_I$ = 0 дБ соответствует сигналу с кодами отсчетов в диапазоне от минус 32 768 до 32 767.

### Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| Наимонование параметра                                           | ное<br>ение<br>тра             | •        | рма<br>метра | °C<br>°C                       |
|------------------------------------------------------------------|--------------------------------|----------|--------------|--------------------------------|
| Наименование параметра,<br>единица измерения,<br>режим измерения | Буквенн<br>обозначе<br>парамет | не менее | не более     | Темпера <sup>.</sup><br>среды, |

<sup>\*\*</sup> Полная шкала сигнала для АЦП  $U_{I=0}$  дБ соответствует сигналу с максимальной амплитудой  $U_{IAUADC}$  (на входах INP1/INM1 и INP2/INM2). При этом полной шкале сигнала для АЦП  $U_{I}=0$  дБ будет соответствовать появление отчетов с кодами от минус 22 000 до 22 000 для дифференциальных входов INP1/INM1 и INP2/INM2.

Полная шкала сигнала для АЦП  $U_i$ = минус 6 дБ соответствует сигналу с максимальной амплитудой  $U_{IAUADC}/2$  (на входах INP1/INM1 и INP2/INM2).

Полная шкала сигнала для АЦП  $U_I$ = минус 12 дБ соответствует сигналу с максимальной амплитудой  $U_{IAUADC}$ /4 (на входах INP1/INM1 и INP2/INM2).

Полная шкала сигнала для АЦП  $U_i$ = минус 24 дБ соответствует сигналу с максимальной амплитудой  $U_{IAUADC}/16$  (на входах INP1/INM1 и INP2/INM2)

Микросхемы устойчивы к воздействию статического электричества с потенциалом не менее 2 000 В.

# 44 Справочные данные

Таблица 43-2 – Справочные параметры

| Наименование параметра,                                                                                                                                                                                 | ное<br>ение<br>тра                    | Но <sub>і</sub><br>параі | °C<br>°C                    |                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------------------------|-----------------------------|--------------------------|
| единица измерения,<br>режим измерения                                                                                                                                                                   | Буквенное<br>обозначение<br>параметра | не<br>менее              | не<br>более                 | Температура<br>среды, °С |
| Динамический ток потребления модуля ПЦОС, мА, при: $f_{C\_DSP}$ = 100 МГц, $f_{C\_RISC}$ = 0 МГц                                                                                                        | I <sub>OCC1</sub>                     | ı                        | 95                          |                          |
| Выходное напряжение регулятора LDO, В при: $U_{CC}$ = 3,6 B, $I_{OL}$ = 200 мА                                                                                                                          | U <sub>O_LDO</sub>                    | 1,62                     | 1,98                        |                          |
| Ток потребления батарейного домена, мкА, при: Ucc = Ucca = 0 В                                                                                                                                          | I <sub>CC_B</sub>                     |                          | 5                           |                          |
| Гистерезис портов ввода/вывода, мВ,<br>на выводах: PA-PF<br>при: ModeRX = 0<br>ModeRX = 1                                                                                                               | $\Delta U_{TH(PA-PF)}$                | 100<br>200               | 400<br>500                  |                          |
| Длительность фронта переключения выходных сигналов, нс, на выводе: STANDBY, C <sub>I</sub> = 30 пФ                                                                                                      | tw(standby)                           | -                        | 10                          |                          |
| на выводах: PA – PF при: PowerTX=00, C <sub>I</sub> = 50 пФ PowerTX=01, C <sub>I</sub> = 50 пФ PowerTX=10, C <sub>I</sub> = 50 пФ PowerTX=11, C <sub>I</sub> = 50 пФ PowerTX=11, C <sub>I</sub> = 30 пФ | t <sub>W(PA-PF)</sub>                 | -<br>-<br>-<br>-         | 10<br>100<br>20<br>10<br>5  |                          |
| на выводах: DN, DP<br>при: Full Speed, C <sub>i</sub> = 50 пФ<br>Low Speed, C <sub>i</sub> = 600 пФ                                                                                                     |                                       | _<br>_                   | 15<br>300                   | 25,<br>85,               |
| Компаратор                                                                                                                                                                                              |                                       |                          |                             | – 60                     |
| Опорное напряжение компаратора при: CVRSS = 1 на выводах: PE4_COMP_REF+ и PE5_COMP_REF-                                                                                                                 | UREFCOMP                              | 2,4                      | Ucc                         |                          |
| Напряжение смещения компаратора, мВ, при: U <sub>CC</sub> = 3,6 В                                                                                                                                       | U <sub>IO_C</sub>                     | минус<br>0,5             | 0,5                         |                          |
| Гистерезис компаратора, мВ                                                                                                                                                                              | $\Delta U_{TH\_C}$                    | 8                        | 12                          |                          |
| Напряжение внутреннего опорного источника компаратора, В                                                                                                                                                | U <sub>REF_C</sub>                    | 1,17                     | 1,23                        |                          |
| Тактовые частоты и генераторы                                                                                                                                                                           |                                       |                          |                             |                          |
| Время установления сигнала HSIRDY относительно HSION, мкс                                                                                                                                               | t <sub>SU(HSI)</sub>                  | _                        | 1                           |                          |
| Время установления сигнала LSIRDY относительно LSION, мс                                                                                                                                                | t <sub>SU(LSI)</sub>                  | -                        | 80                          |                          |
| Время установления сигнала HSERDY относительно HSEON, мкс                                                                                                                                               | t <sub>SU(HSE)</sub>                  | _                        | 2048/f <sub>C_</sub>        |                          |
| Время установления сигнала LSERDY относительно LSEON, мкс                                                                                                                                               | t <sub>SU(LSE)</sub>                  | _                        | 4096/<br>f <sub>C_LSE</sub> |                          |
| Время установления сигнала PLLRDY относительно PLLON, мкс                                                                                                                                               | t <sub>SU(PLL)</sub>                  | _                        | 100                         |                          |

| Наименование параметра,                                                                                    | ное<br>ение<br>тра                    | Но<br>пара  | °C<br>°C              |                          |
|------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------|-----------------------|--------------------------|
| единица измерения,<br>режим измерения                                                                      | Буквенное<br>обозначение<br>параметра | не<br>менее | не<br>более           | Температура<br>среды, °С |
| Длительность сигнала сброса, мкс                                                                           | t <sub>W(RESET)</sub>                 | 20          | _                     |                          |
| Время запуска после сброса по POR, мс                                                                      | t <sub>POR</sub>                      | _           | 6                     |                          |
| АЦП                                                                                                        |                                       |             | •                     |                          |
| Время выборки заряда АЦП, нс                                                                               | t <sub>A_ADC</sub>                    | _           | 4∙f <sub>C_ADC</sub>  |                          |
| Время преобразования АЦП, нс                                                                               | t <sub>AO_ADC</sub>                   | -           | 28•f <sub>C_ADC</sub> |                          |
| Ток потребления по входу внешней верхней границы опоры АЦП, мкА при: ADC1_Cfg_M_REF=1 или ADC2_Cfg_M_REF=1 | I <sub>ADC0_VREF+</sub>               | Ι           | 50                    |                          |
| Ток потребления по входу внешней нижней опоры АЦП, мкА при: ADC1_Cfg_M_REF=1 или ADC2_Cfg_M_REF=1          | I <sub>ADC0_VREF</sub> -              | минус<br>50 | _                     |                          |
| Ток потребления по питанию АЦП, мА при: U <sub>CCA</sub> =3,6B, Fadc=14 МГц                                | I <sub>OCCADC</sub>                   | _           | 3                     |                          |
| Минимальная частота преобразования АЦП, кГц                                                                | F <sub>C_ADCMIN</sub>                 | 10          | _                     |                          |
| ЦАП                                                                                                        |                                       |             |                       | 25,                      |
| Время установления сигнала ЦАП, мкс, при: $C_I = 100$ пФ, $R_I = 10$ кОм                                   | t <sub>SU(DAC)</sub>                  | ı           | 5,2                   | 85,<br>- 60              |
| Время включения ЦАП, мкс                                                                                   | t <sub>ON_DAC</sub>                   | _           | 10                    |                          |
| Ток потребления по входу опоры, мкА при Cfg_M_REF0 = 1                                                     | I <sub>DAC1_VREF</sub>                | -           | 500                   |                          |
| Ток потребления по входу опоры, мкА при Cfg_M_REF1 = 1                                                     | I <sub>DAC2_VREF</sub>                | -           | 500                   |                          |
| Ток потребления ЦАП, мА при отсутствии нагрузки                                                            | IOCCDAC                               | _           | 2                     |                          |
| USB                                                                                                        |                                       |             |                       |                          |
| Сопротивление резистора между линиями DN, DP и питанием, кОм при: D-PULLUP=1                               | R <sub>DN-UCC</sub>                   | 1           | 2                     |                          |
| D+PULLUP=1                                                                                                 | R <sub>DP-UCC</sub>                   | 1           | 2                     |                          |
| Сопротивление резистора между линиями DN, DP и шиной «Общей», кОм при: D-PULLDOWN=1                        | R <sub>DN-GND</sub>                   | 10          | 20                    |                          |
| D+PULLDOWN=1                                                                                               | R <sub>DP-GND</sub>                   | 10          | 20                    |                          |
| Согласующее сопротивление на линиях DN, DP, Ом                                                             | R <sub>DN</sub><br>R <sub>DP</sub>    | 14          | 34                    |                          |

| Наименование параметра,                                                                                                    | ное<br>эние<br>тра                    | Но <sub>І</sub><br>параг | rypa<br>°C  |                          |
|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--------------------------|-------------|--------------------------|
| единица измерения,<br>режим измерения                                                                                      | Буквенное<br>обозначение<br>параметра | не<br>менее              | не<br>более | Температура<br>среды, °С |
| Аудиокодек                                                                                                                 |                                       |                          |             |                          |
| Коэффициент нелинейных искажений + шум АЦП, дБ (для микрофонного входа MICIN)<br>Сигнал: Синус, частотой 1 кГц, AINSEL= 10 |                                       |                          |             |                          |
| U <sub>I</sub> *= 0 дБ<br>ADGAIN= 0 дБ, INBG= 0 дБ                                                                         | _                                     | 63                       | _           |                          |
| U <sub>I</sub> *= минус 6 дБ<br>ADGAINT= 0 дБ, INBG= 6 дБ                                                                  | T <sub>ADC</sub><br>THD+N             | 58                       | _           |                          |
| U <sub>I</sub> *= минус 12 дБ<br>ADGAINT= 0 дБ, INBG= 12 дБ                                                                |                                       | 51                       | _           | 25,                      |
| U <sub>I</sub> *= минус 24 дБ<br>ADGAINT= 0 дБ, INBG= 24 дБ                                                                |                                       | 38                       | _           | 85,<br>- 60              |
| Коэффициент усиления ошибки, дБ                                                                                            | T <sub>ERR</sub>                      | минус<br>0,5             | 0,5         |                          |
| Коэффициент межканального усиления, дБ                                                                                     | T <sub>CH_ERR</sub>                   | _                        | 60          |                          |
| Коэффициент усиления шума питания, дБ                                                                                      | T <sub>PWR_ERR</sub>                  | _                        | 60          |                          |
| Ток короткого замыкания ЦАП, мА,<br>на выводах: OUTP1, OUTM1                                                               | I <sub>OSDAC</sub>                    | _                        | 20          |                          |
| Входной ток АЦП, мкА,<br>на выводах INP1, INP2, INM1, INM2, MICIN                                                          | I <sub>IADC</sub>                     | -                        | 100         |                          |

## 45 Габаритный чертеж микросхемы



Рисунок 45-1 - Микросхема в корпусе 4229.132-3



Остальное см. на рисунке 45-1.

Рисунок 45-2 - Микросхема в корпусе 4229.132-3 с формованными выводами



- 1 Толщина кристалла  $(0,406 \pm 0,040)$  мм.
- 2 Размер контактных площадок (КП) кристалла (85 х 105) мкм. Координаты КП см. таблицу ниже. Материал КП AlCu (0,5 % Cu).
- 3 Номера КП, кроме первой, присвоены условно. Расположение КП соответствует топологическому чертежу.
- 4 А маркировка MLDR52, показана условно.

Рисунок 45-3 - Кристалл (бескорпусное исполнение)

Таблица 45-1 – Координаты КП кристалла

| No ICE | Обозначение        | Коорди  | одинаты КП |     | Обозначение       | Коорди  | наты КП |
|--------|--------------------|---------|------------|-----|-------------------|---------|---------|
| № КП   | ΚП                 | Х       | Υ          | №КП | КΠ                | Х       | Υ       |
| 1      | U <sub>CCD</sub>   | -4903,6 | 3137,6     | 48  | BIAS              | -2463,8 | -3594,8 |
| 2      | Ucc                | -4903,6 | 2981,8     | 49  | U <sub>CCAU</sub> | -1902,9 | -3594,8 |
| 3      | Ucc                | -4903,6 | 2807,1     | 50  | GND <sub>AU</sub> | -1712,9 | -3594,8 |
| 4      | GND                | -4903,6 | 2662,1     | 51  | INP1              | -1492,9 | -3594,8 |
| 5      | PF0                | -4903,6 | 2454,2     | 52  | INM1              | -1202,1 | -3594,8 |
| 6      | PF1                | -4903,6 | 2264,2     | 53  | INP2              | -911,3  | -3594,8 |
| 7      | PF2                | -4903,6 | 2074,2     | 54  | INM2              | -620,5  | -3594,8 |
| 8      | PF3                | -4903,6 | 1884,2     | 55  | MICIN             | -329,6  | -3594,8 |
| 9      | PF4                | -4903,6 | 1694,2     | 56  | PE14              | 191,5   | -3594,8 |
| 10     | PF5                | -4903,6 | 1504,2     | 57  | PE8               | 391,5   | -3594,8 |
| 11     | PF6                | -4903,6 | 1314,2     | 58  | PE3               | 591,5   | -3594,8 |
| 12     | PF7                | -4903,6 | 1124,2     | 59  | PE2               | 791,5   | -3594,8 |
| 13     | PF8                | -4903,6 | 934,2      | 60  | PE5               | 991,5   | -3594,8 |
| 14     | PF9                | -4903,6 | 744,2      | 61  | PE4               | 1191,5  | -3594,8 |
| 15     | PF10               | -4903,6 | 554,2      | 62  | U <sub>CCA</sub>  | 1373,7  | -3594,8 |
| 16     | PF11               | -4903,6 | 364,2      | 63  | U <sub>CCA</sub>  | 1573,7  | -3594,8 |
| 17     | PF12               | -4903,6 | 174,2      | 64  | GND               | 1773,7  | -3594,8 |
| 18     | PF13               | -4903,6 | -15,8      | 65  | GND               | 1973,7  | -3594,8 |
| 19     | PF14               | -4903,6 | -205,8     | 66  | PE10              | 2191,6  | -3594,8 |
| 20     | PF15               | -4903,6 | -395,8     | 67  | PE9               | 2391,6  | -3594,8 |
| 21     | PE15               | -4903,6 | -565,4     | 68  | PE1               | 2591,6  | -3594,8 |
| 22     | PE13               | -4903,6 | -725,4     | 69  | PE0               | 2791,6  | -3594,8 |
| 23     | PE12               | -4903,6 | -885,4     | 70  | GND               | 2973,7  | -3594,8 |
| 24     | SHDN               | -4903,6 | -1045,4    | 71  | GND               | 3173,7  | -3594,8 |
| 25     | PE11               | -4903,6 | -1222,7    | 72  | $U_CCA$           | 3373,7  | -3594,8 |
| 26     | EXT_RESET          | -4903,6 | -1382,7    | 73  | $U_CCA$           | 3573,7  | -3594,8 |
| 27     | $U_CCB$            | -4903,6 | -1542,7    | 74  | PD15              | 3790,6  | -3594,8 |
| 28     | RESET              | -4903,6 | -1702,7    | 75  | PD14              | 3990,6  | -3594,8 |
| 29     | DN                 | -4903,6 | -1997,6    | 76  | PD13              | 4190,6  | -3594,8 |
| 30     | $U_{SBDR	ext{-}}$  | -4903,6 | -2127,5    | 77  | PD12              | 4390,6  | -3594,8 |
| 31     | U <sub>SBDR+</sub> | -4903,6 | -2248,8    | 78  | PD11              | 4590,6  | -3594,8 |
| 32     | DP                 | -4903,6 | -2373,8    | 79  | PD0               | 4903,6  | -3203,4 |
| 33     | GND                | -4903,6 | -2491,9    | 80  | PD10              | 4903,6  | -3063,4 |
| 34     | GND                | -4903,6 | -2602,2    | 81  | PD1               | 4903,6  | -2923,4 |
| 35     | U <sub>CCD</sub>   | -4903,6 | -2710,4    | 82  | PD7               | 4903,6  | -2783,4 |
| 36     | U <sub>CCD</sub>   | -4903,6 | -2825,9    | 83  | PD8               | 4903,6  | -2643,4 |
| 37     | OSC_IN             | -4903,6 | -2941,2    | 84  | PD2               | 4903,6  | -2503,4 |
| 38     | Ucc                | -4903,6 | -3077,7    | 85  | PD4               | 4903,6  | -2363,4 |
| 39     | Ucc                | -4903,6 | -3218,0    | 86  | PD3               | 4903,6  | -2223,4 |
| 40     | OSC_OUT            | -4514,3 | -3594,8    | 87  | PD5               | 4903,6  | -2083,4 |
| 41     | U <sub>CCBD</sub>  | -3815,3 | -3594,8    | 88  | PD6               | 4903,6  | -1943,4 |
| 42     | PE7                | -3625,3 | -3594,8    | 89  | PD9               | 4903,6  | -1803,4 |
| 43     | PE6                | -3435,3 | -3594,8    | 90  | Ucc               | 4903,6  | -1648,5 |
| 44     | WAKEUP             | -3245,3 | -3594,8    | 91  | Ucc               | 4903,6  | -1500,1 |
| 45     | STANDBY            | -3055,3 | -3594,8    | 92  | GND               | 4903,6  | -1360,6 |
| 46     | OUTP1              | -2845,4 | -3594,8    | 93  | U <sub>CCD</sub>  | 4903,6  | -1240,8 |
| 47     | OUTM1              | -2634,6 | -3594,8    | 94  | PC15              | 4903,6  | -649,0  |

# Спецификация 1901ВЦ1Т, К1901ВЦ1Т, К1901ВЦ1ТК, К1901ВЦ1Н4

| No ICE | Обозначение      | Коорди | інаты КП | No ICE | Обозначение | Координаты КП |        |  |
|--------|------------------|--------|----------|--------|-------------|---------------|--------|--|
| № КП   | ΚП               | Х      | Υ        | Nº KΠ  | КΠ          | Χ             | Υ      |  |
| 95     | PC14             | 4903,6 | -489,0   | 123    | PB7         | 2345,2        | 3594,8 |  |
| 96     | PC13             | 4903,6 | -329,0   | 124    | PB6         | 2125,2        | 3594,8 |  |
| 97     | PC12             | 4903,6 | -169,0   | 125    | PB5         | 1905,2        | 3594,8 |  |
| 98     | PC10             | 4903,6 | -9,0     | 126    | PB4         | 1685,2        | 3594,8 |  |
| 99     | PC11             | 4903,6 | 151,0    | 127    | PB3         | 1465,2        | 3594,8 |  |
| 100    | PC8              | 4903,6 | 311,0    | 128    | PB2         | 1245,2        | 3594,8 |  |
| 101    | PC9              | 4903,6 | 471,0    | 129    | PB1         | 1025,2        | 3594,8 |  |
| 102    | PC6              | 4903,6 | 631,0    | 130    | PB0         | 805,2         | 3594,8 |  |
| 103    | PC7              | 4903,6 | 791,0    | 131    | TM2         | 589,3         | 3594,8 |  |
| 104    | PC4              | 4903,6 | 951,0    | 132    | TM1         | 329,3         | 3594,8 |  |
| 105    | PC5              | 4903,6 | 1111,0   | 133    | TM0         | 69,3          | 3594,8 |  |
| 106    | PC2              | 4903,6 | 1271,0   | 134    | PA15        | -592,2        | 3594,8 |  |
| 107    | PC0              | 4903,6 | 1431,0   | 135    | PA14        | -812,2        | 3594,8 |  |
| 108    | PC3              | 4903,6 | 1591,0   | 136    | PA13        | -1032,2       | 3594,8 |  |
| 109    | PC1              | 4903,6 | 1751,0   | 137    | PA12        | -1252,2       | 3594,8 |  |
| 110    | PB14             | 4903,6 | 2317,4   | 138    | PA11        | -1472,2       | 3594,8 |  |
| 111    | PB15             | 4903,6 | 2477,4   | 139    | PA10        | -1692,0       | 3594,8 |  |
| 112    | PB13             | 4903,6 | 2637,4   | 140    | PA9         | -1912,0       | 3594,8 |  |
| 113    | PB12             | 4903,6 | 3245,5   | 141    | PA8         | -2132,0       | 3594,8 |  |
| 114    | PB11             | 4454,3 | 3594,8   | 142    | PA7         | -2352,0       | 3594,8 |  |
| 115    | Ucc              | 4280,7 | 3594,8   | 143    | PA6         | -2572,1       | 3594,8 |  |
| 116    | Ucc              | 4125,7 | 3594,8   | 144    | PA5         | -2792,1       | 3594,8 |  |
| 117    | JTAG_EN          | 3962,5 | 3594,8   | 145    | PA4         | -3012,1       | 3594,8 |  |
| 118    | GND              | 3799,6 | 3594,8   | 146    | VPP         | -3232,1       | 3594,8 |  |
| 119    | U <sub>CCD</sub> | 3624,8 | 3594,8   | 147    | PA3         | -3435,1       | 3594,8 |  |
| 120    | PB10             | 3005,2 | 3594,8   | 148    | PA2         | -3655,1       | 3594,8 |  |
| 121    | PB9              | 2785,2 | 3594,8   | 149    | PA1         | -3875,1       | 3594,8 |  |
| 122    | PB8              | 2565,2 | 3594,8   | 150    | PA0         | -4095,1       | 3594,8 |  |

## 46 Информация для заказа

| Обозначение | Маркировка              | Тип корпуса  | Температурный<br>диапазон, °С |
|-------------|-------------------------|--------------|-------------------------------|
| 1901ВЦ1Т    | 1901ВЦ1Т                | 4229.132-3   | от – 60 до 85                 |
| К1901ВЦ1Т   | К1901ВЦ1Т               | 4229.132-3   | от – 60 до 85                 |
| К1901ВЦ1ТК  | К1901ВЦ1Т∙              | 4229.132-3   | от 0 до 70                    |
| К1901ВЦ1Н4  | К1901ВЦ1Н4<br>(на таре) | бескорпусная | от 0 до 70                    |

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

<sup>1</sup> Микросхемы в бескорпусном исполнении поставляются в виде отдельных кристаллов, получаемых разделением пластины. Микросхемы поставляются в таре (кейсах) без потери ориентации.

<sup>2</sup> Необходимость поставки микросхем в корпусе с формованными выводами указывается в договоре на поставку.

# Лист регистрации изменений

| <b>№</b><br>п/п | Дата       | Версия | Краткое содержание изменения                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | №№<br>изменяемых<br>листов                                           |
|-----------------|------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| 1               | 23.05.2011 | 1.0    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                      |
| 2               | 05.07.2011 | 2.0    | Уточнения по результатам сдачи ОКР                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | По тексту                                                            |
| 3               | 07.02.2013 | 2.1.0  | Дополнено описание периферийных блоков                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | По тексту                                                            |
| 4               | 13.02.2013 | 2.1.1  | Исправления оформления                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | По тексту                                                            |
| 5               | 17.09.2013 | 2.2.0  | Исправлено описание UART - загрузчика.<br>Исправлено:<br>-Порты загрузки через UART.<br>-Номер блока UART, используемый для загрузки.<br>-Таблица режимов работы микроконтроллера.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | По тексту                                                            |
| 6               | 11.02.2014 | 2.3.0  | - Исправления оформления - Дополнение таблица 361: информация о смещении векторов прерываний относительно базового адреса таблицы векторов прерываний Исправление таблицы 34: смещения адресов регистров SSP_CLOCK2 и DSP_CONTROL_STATUS относительно базового адреса регистров блока управления синхросигналами микроконтроллера Исправление таблицы 50: исправлена и дополнена информация о соответствии бит регистра PER_CLOCK - Исправление таблицы 54: Дополнена информация об управление синхросигналами периферийного модуля UART3 Исправлена информация о смещение регистров CRPT_SYNR и CRPT_CR блока шифрования Таблица 1 дополнена описанием выводов Uccd Дополнены таблица 1, таблица 120, раздел организация управления DSP подсистемой описанием возможности вывода сигнала XF из DSP части напрямую на порт PA[15] микроконтроллера В описании регистра прерываний от DSP к RISC добавлен бит DMAIRQ. | По тексту                                                            |
| 7               | 14.04.2014 | 2.3.1  | Исправлена нумерация рисунков и таблиц                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | По тексту                                                            |
| 8               | 22.09.2014 | 2.3.2  | Приведение в соответствие с КД и ТУ. Выполнено форматирование. Исправлена структура заголовков, нумерация рисунков и таблиц.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | По тексту                                                            |
| 9               | 03.03.2015 | 2.4.0  | <ul> <li>Исправлено значение тактовой частоты;</li> <li>Исправлены таблица 4-8, таблица 4-19, таблица 9-13, таблица 14-3, таблица 21-2, таблица 22-4, таблица 22-7, таблица 33-5;</li> <li>Исправлен рисунок 9-1</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 20<br>50, 58, 155,<br>193, 194, 642,<br>643, 651, 653,<br>843<br>148 |
| 10              | 13.03.2015 | 2.5.0  | <ul> <li>Заменен рисунок 15-3;</li> <li>Обозначение счетчика PCR исправлено на PSC;</li> <li>Исправлено описание п. «Сигма-Дельта АЦП»;</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 252<br>640<br>645                                                    |

| <b>№</b><br>п/п | Дата       | Версия | Краткое содержание изменения                                                                                                                                                                                                                                                                               | №№<br>изменяемых<br>листов                                                                |
|-----------------|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
|                 |            |        | – Исправлено описание поля OVERCUR в таблице 22-8                                                                                                                                                                                                                                                          | 653                                                                                       |
| 11              | 20.03.2015 | 2.6.0  | <ul><li>Исправлено описание выводов SHDN и NC в таблице 2-1;</li><li>Исправления в таблице 16-32</li></ul>                                                                                                                                                                                                 | 26<br>340                                                                                 |
| 12              | 02.04.2015 | 2.6.1  | Удален вывод 24 в разделе Системное управление таблицы 2-1                                                                                                                                                                                                                                                 | 25                                                                                        |
| 13              | 12.11.2015 | 2.7.0  | Введение бескорпусной микросхемы К1901ВЦ1Н4 Внесены исправления в таблицы 22-6, 22-7, 22-8                                                                                                                                                                                                                 | По тексту<br>256, 257                                                                     |
| 14              | 18.10.2018 | 2.8.0  | Введение микросхемы K1901BЦ1QI в пластиковом корпусе LQFP144                                                                                                                                                                                                                                               | По тексту                                                                                 |
| 15              | 15.11.2018 | 2.9.0  | Внесение корректировок по отзывам пользователей; Исправление несоответствий в тактовых частотах, режимах первоначального запуска; Обновление таблиц 4-9, 18-1, 18-2, 18-3, 24-23, 24-58, 35-5; Исправления оформления; Скорректированы рисунки 41-1; 41-2; Внесены изменения в таблицу регистра SIS.       | 25, 46, 112,<br>113, 345, 379,<br>402, 488, 623,<br>671                                   |
| 16              | 15.02.2019 | 2.10.0 | Исправления оформления; Внесение корректировок по отзывам пользователей; Изменения в схеме сброса при включении и выключении основного питания                                                                                                                                                             | По тексту<br>249<br>34, 35                                                                |
| 17              | 18.05.2020 | 2.11.0 | Плановая корректировка по замечаниям.<br>Введение корпуса с формованными выводами                                                                                                                                                                                                                          | По тексту                                                                                 |
| 18              | 11.09.2020 | 2.12.0 | Плановая корректировка по замечаниям                                                                                                                                                                                                                                                                       | По тексту                                                                                 |
| 19              | 07.05.2021 | 2.12.1 | Корректировка перечня ИМС и уточнение температурного диапазона                                                                                                                                                                                                                                             | По тексту                                                                                 |
| 20              | 14.05.2021 | 2.13.0 | Для бескорпусного исполнения исправлен ГЧ и таблица с координатами КП                                                                                                                                                                                                                                      | 887 – 889                                                                                 |
| 21              | 29.07.2021 | 2.14.0 | Внесены изменения в таблицы: 3-2, 13-6, 13-7, 14-1, 28-7, 27-11, 28-9, 31-2, 32-10, 38-7 Внесены изменения в рисунок 6-1 и примечания к нему Внесены изменения в пункты: 6.1, 7.1, 15, 27.2, 32, 34.5.2, 37.3                                                                                              | 26, 172, 645,<br>646, 682, 710,<br>715, 822<br>34<br>33, 65, 185,<br>634, 712, 753<br>814 |
| 22              | 22.09.2021 | 2.15.0 | Изменено примечание в разделе 36.1.2 Скорректированы названия и описания битов 3 и 17 в таблицах 12-4, 12-5 Исправлено название параметра «Частота следования импульсов тактовых сигналов аудиокодека» на «Частота дискретизации аудиокодека» Добавлен раздел «Логика работы прерываний контроллера NVIC.» | 793<br>158<br>842<br>807                                                                  |