## СОДЕРЖАНИЕ 1.1 Архитектурные особенности микросхемы ....... 6 Инв. № дубл. 3.7.3 Регистры контроллера GPIO .......51 3.8 Контроллер интерфейса последовательного UHB. Взам. Подп. и дата Версия 2.04 от 01.09.2017 г. Изм. Лист № докум. Подп. Дата Разраб. Лист Лит Листов Микросхема интегральная нв. № подл. Пров. 259 5023BC016. Н. контр. Техническое описание Утв.

|               |                               | 3.8.5 Общие регистры настроек                                      | 61         |  |  |  |  |  |  |
|---------------|-------------------------------|--------------------------------------------------------------------|------------|--|--|--|--|--|--|
|               |                               | 3.8.6 Регистры монитора                                            | 63         |  |  |  |  |  |  |
|               |                               | 3.8.7 Peгистр INTERRUPT                                            | 64         |  |  |  |  |  |  |
|               |                               | 3.8.8 Описание функционирования контроллера последовательного инт  | ерфейса по |  |  |  |  |  |  |
|               |                               | ΓΟCT P 52070                                                       | 64         |  |  |  |  |  |  |
|               |                               | 3.9 Контроллер интерфейса SpaceWire                                | 72         |  |  |  |  |  |  |
|               |                               | 3.9.1 Описание функционирования контроллера интерфейса SpaceWire . | 72         |  |  |  |  |  |  |
|               |                               | 3.9.2 Контроллер BUS MASTER                                        | 75         |  |  |  |  |  |  |
|               |                               | 3.9.3 Регистры контроллера интерфейса SpaceWire                    | 76         |  |  |  |  |  |  |
|               |                               | 3.10 Контроллер прямого доступа к памяти                           | 80         |  |  |  |  |  |  |
|               |                               | 3.10.1 Общее описание                                              | 80         |  |  |  |  |  |  |
|               |                               | 3.10.2 Описание функционирования контроллера DMA                   | 81         |  |  |  |  |  |  |
|               |                               | 3.10.3 Программное управление модулем                              | 98         |  |  |  |  |  |  |
|               |                               | 3.11 Контроллер интерфейса SPI                                     | 127        |  |  |  |  |  |  |
|               |                               | 3.11.1 Общие положения                                             | 127        |  |  |  |  |  |  |
|               |                               | 3.11.2 Основные характеристики интерфейса SPI                      | 128        |  |  |  |  |  |  |
| Γ             |                               | 3.11.3 Программируемые параметры интерфейса SPI                    | 128        |  |  |  |  |  |  |
| <br>          |                               | 3.11.4 Характеристики интерфейса SPI фирмы Motorola                |            |  |  |  |  |  |  |
| и дата.       |                               | 3.11.5 Функциональное описание интерфейса SPI                      | 130        |  |  |  |  |  |  |
| Подп. ц       |                               | 3.11.6 Функционирование модуля SPI                                 | 132        |  |  |  |  |  |  |
|               |                               | 3.11.7 Интерфейс прямого доступа к памяти                          |            |  |  |  |  |  |  |
| дубл          |                               | 3.11.8 Программное управление модулем                              | 149        |  |  |  |  |  |  |
| Инв. Nº дубл. |                               | 3.11.9 Прерывания модуля                                           | 156        |  |  |  |  |  |  |
|               | ┢                             | 3.12 Контроллер интерфейса UART                                    | 158        |  |  |  |  |  |  |
| лнв. Л        |                               | 3.12.1 Общие положения                                             |            |  |  |  |  |  |  |
| Взам. инв. №  |                               | 3.12.2 Основные характеристики интерфейса UART                     | 158        |  |  |  |  |  |  |
| В             |                               | 3.12.3 Описание функционирования интерфейса UART                   | 162        |  |  |  |  |  |  |
|               |                               | 3.12.4 Описание функционирования модуля UART                       |            |  |  |  |  |  |  |
| ama           |                               |                                                                    |            |  |  |  |  |  |  |
| Подп. и дата  |                               |                                                                    |            |  |  |  |  |  |  |
| _             | 3.13 Таймер общего назначения |                                                                    |            |  |  |  |  |  |  |
| Инв. № подл.  |                               | Minima avana in mara ana ana ana ana ana ana ana ana ana           | In.        |  |  |  |  |  |  |
| '8. Nº        |                               | Микросхема интегральная 5023BC016<br>Техническое описание          | Лисп       |  |  |  |  |  |  |
| $\vec{z}$     |                               | 1зм Лист № докум. Подп. Дата Версия 2.04 om 01.09.2017 г.          | 3          |  |  |  |  |  |  |

| 3.13.1 Общее описание                                                | 192      |
|----------------------------------------------------------------------|----------|
| 3.14 Сторожевой таймер                                               |          |
| 3.14.1 Описание сторожевого таймера                                  |          |
| 3.14.2 Регистры сторожевого таймера (Watchdog)                       |          |
| 3.15 Передатчик телеметрической информации                           |          |
| 3.15.1 Описание структуры передатчика телеметрической информации     |          |
| 3.15.2 Описание работы интерфейса передатчика телеметри              |          |
| информации                                                           |          |
| 3.15.3 Программная модель управления передатчиком телеметри          |          |
| информации                                                           |          |
| 3.15.4 Регистры передатчика телеметрической информации               |          |
| 3.16 Приёмник телекомандной информации                               |          |
| 3.16.1 Общее описание приёмника телекомандной информации             |          |
| 3.16.2 Описание работы интерфейса приёмника телекомандной информации |          |
| 3.16.3 Программная модель управления приёмником телеком              |          |
| информации                                                           |          |
| 3.16.4 Описание регистров приёмника телекомандной информации         |          |
| 3.17 Специализированный вычислитель с плавающей точкой               |          |
| 3.17.1 Описание регистров                                            |          |
| 3.18 Контроллер интерфейса CAN                                       |          |
| 3.18.1 Общее описание                                                | 225      |
| 3.18.2 Базовый режим работы                                          | 226      |
| 3.18.3 Расширенный режим работы                                      | 231      |
| 3.18.4 Общие регистры для базового и расширенного режимов работы     | 243      |
| 3.19 Контроллер интерфейса I <sup>2</sup> C                          | 245      |
| 3.19.1 Описание работы блока I <sup>2</sup> C-мастер                 | 246      |
| 3.19.2 Описание регистров блока I <sup>2</sup> C-мастер              | 252      |
| Перечень сокращений и условных обозначений                           | 255      |
| Перечень ссылочных документов                                        | 257      |
| Перечень изменений                                                   | 258      |
|                                                                      |          |
|                                                                      | <u> </u> |
| Микросхема интегральная 5023BC016<br>Техническое описание            | Лисп     |
| Изм Лист № докум. Подп. Дата Версия 2.04 om 01.09.2017 г.            | 4        |

Инв. № подл. Подп. и дата

#### Введение

Настоящее техническое описание распространяется на интегральную микросхему 5023ВС016 (далее — микросхема СБИС СРU), предназначенную для применения в качестве специализированной схемы обработки информации в радиоэлектронной аппаратуре специального назначения.

Радиационно-стойкая специализированная микросхема 5023BC016 предназначена для построения аппаратуры контрольно-измерительных систем (КИС), телеметрии служебных систем космических аппаратов с учетом эксплуатации их в жестких условиях специальных видов воздействующих факторов.

Микросхема может использоваться для организации каналов связи по интерфейсам магистральной последовательной шины по ГОСТ Р 52070 с резервированием.

При этом микросхема может использоваться в качестве контроллера шины (КШ), оконечного устройства (ОУ), а также монитора.

Наличие двух контроллеров интерфейсов SpaceWire со скоростью передачи данных до 100 Мбит/с позволяет использовать микросхему в каналах передачи данных данного типа.

Микросхема имеет блоки передатчика телеметрической информации и приёмника телекомандной информации, позволяющие использовать различные виды кодирования (LDPC, Турбо, Рида-Соломона).

Применение микросхемы позволяет создавать системы управления космическими аппаратами совместимыми с международными стандартами CCSDS, уменьшить массогабаритные характеристики и потребляемую мощность аппаратуры КИС, телеметрии служебных систем космических аппаратов в 4 – 5 раз и обеспечить требования Федерального космического агентства по дозовой стойкости и воздействию тяжелых заряженных частиц.

Iнв. № подл. Подп. и дата Взам. инв. № Инв. № дубл. Подп. и дв

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

## 1 Назначение и основные технические характеристики

#### 1.1 Архитектурные особенности микросхемы

Интегральная микросхема 5023ВС016 представляет собой однокристальный 32 разрядный процессор, выполненный по КМОП технологии с нормами 0,18 мкм. Микросхема предназначена для построения аппаратуры КИС, телеметрии служебных систем космических аппаратов с учетом эксплуатации их в жестких условиях специальных видов воздействующих факторов.

Основные функциональные параметры микросхемы:

| разрядность шины адреса ядра процессора       | 32 бита    |
|-----------------------------------------------|------------|
| конвейер                                      | 3 стадии   |
| аппаратный умножитель                         | 32 x 32    |
| тип встроенной шины                           | AMBA       |
| размер встроенного оперативного запоминающего |            |
| устройства (ОЗУ)                              | 128 κΒ     |
| тактовая частота, МГц                         | 501)       |
| напряжение питания ядра, В                    | 1,8 ± 10 % |
| напряжение питания буферов ввода-вывода, В    | 3,3 ± 10 % |
| СБИС СРИ включает следующие основные блоки:   |            |

- а) ядро 32-битного Reduced Instruction Set Computer (RISC) процессора;
- б) четыре независимых контроллера последовательного интерфейса по ГОСТ Р 52070 с резервированием;
- в) два независимых контроллера интерфейса SpaceWire со скоростью передачи данных до 100 Мбит/с;
  - г) контроллер прямого доступа к памяти;

Инв. № дубл.

Взам. инв. №

Подп. и дата

д) внутрикристальную схему отладки с интерфейсом Joint Test Action Group (JTAG) (IEEE 1149.1);

 $<sup>^{1)}</sup>$  Возможна работа на тактовой частоте  $80\,\mathrm{MF}$ ц. При этом значения динамического тока потребления ядра для основных режимов работы микросхемы приведены в таблице 1.3.3.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 6    |

ж) контроллер внешней памяти со встроенным блоком обнаружения и исправления ошибок, с поддержкой до четырех микросхем внешней памяти и с поддержкой кэширования;

- 3) шесть независимых контроллеров асинхронного последовательного интерфейса Universal asynchronous receiver-transmitter (UART);
- и) два независимых контроллера последовательного интерфейса Serial Perepheral Interface (SPI);
- к) контроллер приёмника телекомандной информации (ПрТКИ) по стандарту Consultative Committee for Space Data Systems (CCSDS), включающий следующие блоки:
  - 1) декодер БЧХ (63,56) размер блока 63 бита, размер полезных данных 56 бит;
    - 2) декодер Витерби;
    - 3) дерандомизатор;

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

- л) контроллер передатчика телеметрической информации (ПдТМИ) по стандарту CCSDS, включающий следующие блоки:
  - 1) энкодер Рида-Соломона с параметрами (N = 255, K = 223), (N = 255, K = 239) размер блока 255 символов, размер полезных данных 223 или 239 символов, разрядность 8 бит, порождающий полином  $F(x) = x^8 + x^7 + x^2 + x + 1$ ;
  - 2) турбо энкодер со скоростью кодирования (отношению объёма полезных данных к объёму передаваемых) 1/2, 1/3, 1/4, 1/6;
  - 3) LDPC энкодер с параметрами (8160, 7136) (размер кодового блока 8160 символов, размер блока данных 7136 символов);
  - 4) сверточный энкодер со скоростью кодирования (отношению объема полезных данных к объему передаваемых) 1/2, 2/3, 3/4, 5/6 или 7/8, разрядность 7 бит, порождающие полиномы: G1 = 1111001, G2 = 1011011;
    - 5) рандомизатор;

| Микросхема интегральная 5023BC016<br>Техническое описание |      |
|-----------------------------------------------------------|------|
| Теунциеское описание                                      | Лист |
|                                                           | _    |
| Изм Лист № докум. Подп. Дата Версия 2.04 om 01.09.2017 г. | /    |

Копировал

Формат А4

- б) формирователь кадров;
- м) два независимых контроллера интерфейса Controller Area Network (CAN);
- н) контроллер интерфейса I<sup>2</sup>C в режиме мастера;
- о) специализированный вычислитель с плавающей точкой.
- 1.2 Конструктивные параметры микросхемы

Функциональное назначение выводов микросхемы приведено в таблице 1.2.1.

Микросхема выполнена в металлокерамическом корпусе 6112.145-1 и предназначена для ручной и автоматической сборки в соответствии с ГОСТ В 20.39.412.

Масса микросхемы не более 20 г.

Значение собственной резонансной частоты не менее 3,6 кГц.

Предельная повышенная температура среды плюс 125 °C.

Показатель герметичности микросхем со свободным внутренним объёмом по эквивалентному нормализованному потоку не более  $6,65\cdot10^{-3}$  Па·см<sup>3</sup>/с.

Более подробно конструктивные характеристики микросхемы приведены в технических условиях AEЯР.431290.994 ТУ.

Условное графическое обозначение микросхемы приведено на рисунке 1.2.1.

нв. № подл. и дата Взам. инв. № Инв. № дубл. Подп. и дат

13м Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г. Лист

8



Таблица 1.2.1 — Функциональное назначение выводов

Название вывода

GND

Номер вывода

**A**1

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

| 111 | GND          | Оощии        |            |
|-----|--------------|--------------|------------|
| A2  | MKPD3_RX_A   | Вход/выход   | GPIO_F(4)  |
| A3  | MKPD2_nRX_B  | Вход/выход   | GPIO_F(2)  |
| A4  | MKPD2_RX_B   | Вход/выход   | GPIO_F(1)  |
| A5  | MKPD2_nTX_A  | Вход/выход   | GPIO_E(15) |
| A6  | MKPD1_TXEN_B | Вход/выход   | GPIO_E(11) |
| A7  | UART1_TxD    | Вход/выход   | GPIO_D(15) |
| A8  | GND          | Общий        | Питание    |
| A9  | MKPD1_nRX_B  | Вход/выход   | GPIO_E(10) |
| A10 | MKPD1_RX_B   | Вход/выход   | GPIO_E(9)  |
| A11 | MKPD1_TX_A   | Вход/выход   | GPIO_E(6)  |
| A12 | SPI2_MOSI    | Вход/выход   | GPIO_D(14) |
| A13 | SPI2_SCK     | Вход/выход   | GPIO_D(12) |
| A14 | SPI1_MISO    | Вход/выход   | GPIO_D(9)  |
| A15 | GND          | Общий        | Питание    |
| B1  | MKPD3_TXEN_A | Вход/выход   | GPIO_F(8)  |
| B2  | MKPD3_nTX_A  | Вход/выход   | GPIO_F(7)  |
| В3  | MKPD2_TXEN_B | Вход/выход   | GPIO_F(3)  |
| B4  | UART1_RxD    | Вход/выход   | GPIO_E(0)  |
| B5  | MKPD2_TXEN_A | Вход/выход   | GPIO_F(0)  |
| B6  | MKPD2_nRX_A  | Вход/выход   | GPIO_E(13) |
| B7  | MKPD2_RX_A   | Вход/выход   | GPIO_E(12) |
| B8  | SW_CLK       | Вход/выход   | GPIO_H(4)  |
| B9  | MKPD1_nTX_A  | Вход/выход   | GPIO_E(7)  |
| B10 | MKPD1_nRX_A  | Вход/выход   | GPIO_E(5)  |
| B11 | SPI2_MISO    | Вход/выход   | GPIO_D(13) |
| B12 | SPI1_MOSI    | Вход/выход   | GPIO_D(10) |
| B13 | VCC1         | Питание UCC1 | Питание    |

Тип вывода

3

Общий

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

10

Номер соответствующего порта

ввода-вывода/функция

Питание

| 1   | 2               | 3                | 4                  |
|-----|-----------------|------------------|--------------------|
| B14 | SPI1_SCK        | Вход/выход       | GPIO_D(8)          |
| B15 | RAM_Lbn         | Вход/выход       | GPIO_D(5)          |
| C1  | UART2_RX        | Вход/выход       | GPIO_E(1)          |
| C2  | VCC1            | Питание UCC1     | Питание            |
| C3  | MKPD3_TX_A      | Вход/выход       | GPIO_F(6)          |
| C4  | MKPD3_nRX_A     | Вход/выход       | GPIO_F(5)          |
| C5  | UART2_TX        | Вход/выход       | GPIO_E(2)          |
| C6  | MKPD2_TX_A      | Вход/выход       | GPIO_E(14)         |
| C7  | VCC2            | Питание UCC2     | Питание            |
| C8  | VCC1            | Питание UCC1     | Питание            |
| C9  | MKPD1_TXEN_A    | Вход/выход       | GPIO_E(8)          |
| C10 | MKPD1_RX_A      | Вход/выход       | GPIO_E(4)          |
| C11 | SPI2_SS         | Вход/выход       | GPIO_D(11)         |
| C12 | VCC2            | Питание UCC2     | Питание            |
| C13 | SPI1_SS         | Вход/выход       | GPIO_D(7)          |
| C14 | RAM_Oen         | Вход/выход       | GPIO_D(4)          |
| C15 | RAM_DATA_CHK(8) | Вход/выход       | GPIO_D(0)          |
| D1  | MKPD3_TXEN_B    | Вход/выход       | GPIO_F(11)         |
| D2  | MKPD3_RX_B      | Вход/выход       | GPIO_F(9)          |
| D3  | VCC2            | Питание UCC2     | Питание            |
| D4  | VCC2            | Питание UCC2     | Питание            |
| D13 | RAM_Ubn         | Вход/выход       | GPIO_D(6)          |
| D14 | RAM_DATA_CHK(9) | Вход/выход       | GPIO_D(1)          |
| D15 | RAM_DATA_CHK(7) | Вход/выход       | GPIO_C(15)         |
| E1  | MKPD4_TX_A      | Вход/выход       | GPIO_F(14)         |
| E2  | RAM_Cen0        | Вход/выход       | GPIO_E(3)          |
| E3  | MKPD3_nRX_B     | Вход/выход       | GPIO_F(10)         |
| E13 | RAM_Wen         | Вход/выход       | GPIO_D(2)          |
| E14 | RAM_DATA_CHK(6) | Вход/выход       | GPIO_C(14)         |
|     |                 | Микросхема интеа | еральная 5023BC016 |

Инв. № дубл.

Взам. инв. №

Подп. и дата

| Продолжение      | таблииы   | 1.2.1 |
|------------------|-----------|-------|
| 11poodsidicerric | masiniqui | 1.2.1 |

RAM\_DATA\_CHK(5)

 $MKPD4_RX_B$ 

E15

F1

Инв. № дубл.

Взам. инв. №

Подп. и дата

Инв. Nº подл.

|     | 1,111 2111_2    | Влод выпод   | 3113_3(1)  |
|-----|-----------------|--------------|------------|
| F2  | MKPD4_nRX_A     | Вход/выход   | GPIO_F(13) |
| F3  | MKPD4_RX_A      | Вход/выход   | GPIO_F(12) |
| F13 | RAM_DATA_CHK(4) | Вход/выход   | GPIO_C(12) |
| F14 | RAM_DATA_CHK(3) | Вход/выход   | GPIO_C(11) |
| F15 | RAM_DATA_CHK(1) | Вход/выход   | GPIO_C(9)  |
| G1  | MKPD4_nRX_B     | Вход/выход   | GPIO_G(2)  |
| G2  | MKPD4_nTX_A     | Вход/выход   | GPIO_F(15) |
| G3  | MKPD4_TXEN_A    | Вход/выход   | GPIO_G(0)  |
| G13 | VCC2            | Питание UCC2 | Питание    |
| G14 | RAM_DATA_CHK(2) | Вход/выход   | GPIO_C(10) |
| G15 | RAM_DATA_CHK(0) | Вход/выход   | GPIO_C(8)  |
| H1  | GND             | Общий        | Питание    |
| H2  | TC_DIN(1)       | Вход/выход   | GPIO_H(2)  |
| Н3  | VCC1            | Питание UCC1 | Питание    |
| H13 | VCC1            | Питание UCC1 | Питание    |
| H14 | RAM_DATA(15)    | Вход/выход   | GPIO_C(7)  |
| H15 | GND             | Общий        | Питание    |
| J1  | TC_DIN(2)       | Вход/выход   | GPIO_H(3)  |
| J2  | SW_SIN(0)       | Вход/выход   | GPIO_G(4)  |
| J3  | VCC2            | Питание UCC2 | Питание    |
| J13 | RAM_DATA(12)    | Вход/выход   | GPIO_C(4)  |
| J14 | RAM_DATA(11)    | Вход/выход   | GPIO_C(3)  |
| J15 | RAM_DATA(14)    | Вход/выход   | GPIO_C(6)  |
| K1  | MKPD4_TXEN_B    | Вход/выход   | GPIO_G(3)  |
| K2  | SW_DIN(0)       | Вход/выход   | GPIO_G(5)  |
| K3  | SW_SOUT(0)      | Вход/выход   | GPIO_G(6)  |
| K13 | RAM_DATA(8)     | Вход/выход   | GPIO_C(0)  |

3

Вход/выход

Вход/выход

4

GPIO\_C(13)

 $GPIO\_G(1)$ 

| 1   | 2             | 3            | 4                                 |
|-----|---------------|--------------|-----------------------------------|
| K14 | RAM_DATA(9)   | Вход/выход   | GPIO_C(1)                         |
| K15 | RAM_DATA(13)  | Вход/выход   | GPIO_C(5)                         |
| L1  | SW_DOUT(0)    | Вход/выход   | GPIO_G(7)                         |
| L2  | SW_SIN(1)     | Вход/выход   | GPIO_G(8)                         |
| L3  | TM_CLKI       | Вход/выход   | GPIO_G(12)                        |
| L13 | RAM_DATA(4)   | Вход/выход   | GPIO_B(12)                        |
| L14 | RAM_DATA(6)   | Вход/выход   | GPIO_B(14)                        |
| L15 | RAM_DATA(10)  | Вход/выход   | GPIO_C(2)                         |
| M1  | SW_DIN(1)     | Вход/выход   | GPIO_G(9)                         |
| M2  | SW_DOUT(1)    | Вход/выход   | GPIO_G(11)                        |
| M3  | TC_CLKI       | Вход/выход   | GPIO_G(15)                        |
| M13 | VCC2          | Питание UCC2 | Питание                           |
| M14 | RAM_DATA(3)   | Вход/выход   | GPIO_B(11)                        |
| M15 | RAM_DATA(7)   | Вход/выход   | GPIO_B(15)                        |
| N1  | SW_SOUT(1)    | Вход/выход   | GPIO_G(10)                        |
| N2  | TM_DOUT_VALID | Вход/выход   | GPIO_G(13)                        |
| N3  | TC_ACT        | Вход/выход   | GPIO_H(0)                         |
| N4  | VCC2          | Питание UCC2 | Питание                           |
| N5  | JTAG_TRST     | Вход         | Сброс контроллера интерфейса JTAG |
| N6  | JTAG_TDO      | Выход        | Выход данных интерфейса<br>JTAG   |
| N7  | RAM_ADDR(1)   | Вход/выход   | GPIO_A(1)                         |
| N8  | VCC1          | Питание UCC1 | Питание                           |

Питание UCC2

Вход/выход

Вход/выход

Вход/выход

Питание UCC1

Вход

Подп. и дата Взам. инв. № Инв. № дубл. Подп. и

1нв. № подл.

N9

N10

N11

N12

N13

N14

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

VCC2

VCC1

RAM\_ADDR(9)

RAM\_ADDR(15)

JTAG\_Select

 $RAM_DATA(0)$ 

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Питание

 $GPIO_A(9)$ 

GPIO\_A(15)

GPIO\_B(8)

Питание

Выбор контроллера

интерфейса JTAG

| $\boldsymbol{\Pi}$ | _           | 1 2  | 1 |
|--------------------|-------------|------|---|
| Продолжение        | $man\pi mu$ | 1 /  | 1 |
| 11poodsisicenine   | тиолицы     | 1.4. | 1 |

RAM\_DATA(5)

TM\_DOUT

N15

P1

| P2               | TC_DIN(0)    | Вход/выход   | GPIO_H(1)                                         |  |
|------------------|--------------|--------------|---------------------------------------------------|--|
| P3               | VCC1         | Питание UCC1 | Питание                                           |  |
| P4               | RST          | Вход         | Сброс микросхемы. Активный уровень – «0»          |  |
| P5               | JTAG_TMS     | Вход         | Выбор режима интерфейса<br>JTAG                   |  |
| P6               | ExEDAC_En    | Вход         | Включение блока исправления ошибок внешней памяти |  |
| P7               | RAM_ADDR(0)  | Вход/выход   | GPIO_A(0)                                         |  |
| P8               | RAM_ADDR(4)  | Вход/выход   | GPIO_A(4)                                         |  |
| P9               | RAM_ADDR(7)  | Вход/выход   | GPIO_A(7)                                         |  |
| P10              | RAM_ADDR(8)  | Вход/выход   | GPIO_A(8)                                         |  |
| P11              | RAM_ADDR(11) | Вход/выход   | GPIO_A(11)                                        |  |
| P12              | RAM_ADDR(14) | Вход/выход   | GPIO_A(14)                                        |  |
| P13              | RAM_ADDR(16) | Вход/выход   | GPIO_B(0)                                         |  |
| P14              | RAM_DATA(1)  | Вход/выход   | GPIO_B(9)                                         |  |
| P15              | RAM_DATA(2)  | Вход/выход   | GPIO_B(10)                                        |  |
| Q1               | GND          | Общий        | Питание                                           |  |
| Q2               | CLK          | Вход         | Тактовый сигнал цифровой части микросхемы         |  |
| Q3               | JTAG_TCK     | Вход         | Тактовый сигнал интерфейса<br>JTAG                |  |
| Q4               | JTAG_TDI     | Вход         | Вход данных интерфейса<br>JTAG                    |  |
| Q5               | Ex8_16bit    | Вход         | Выбор режима работы интерфейса внешней памяти     |  |
| Q6               | RAM_ADDR(2)  | Вход/выход   | GPIO_A(2)                                         |  |
| Q7               | RAM_ADDR(3)  | Вход/выход   | GPIO_A(3)                                         |  |
| Q8               | GND          | Общий        | Питание                                           |  |
| Q9               | RAM_ADDR(5)  | Вход/выход   | GPIO_A(5)                                         |  |
| Q10              | RAM_ADDR(6)  | Вход/выход   | GPIO_A(6)                                         |  |
| Q11              | RAM_ADDR(10) | Вход/выход   | GPIO_A(10)                                        |  |
| Q12 RAM_ADDR(12) |              | Вход/выход   | GPIO_A(12)                                        |  |

3

GPIO\_B(13)

GPIO\_G(14)

Вход/выход

Вход/выход

№ докум.

Лист

Подп.

Дата

Инв. № дубл.

Взам. инв. №

Продолжение таблицы 1.2.1

| 1   | 2            | 3          | 4          |
|-----|--------------|------------|------------|
| Q13 | RAM_ADDR(13) | Вход/выход | GPIO_A(13) |
| Q14 | RAM_ADDR(17) | Вход/выход | GPIO_B(1)  |
| Q15 | GND          | Общий      | Питание    |

Выводы могут использоваться как в качестве интерфейсных сигналов, так и в режиме General Purpose input-output (GPIO). В режиме GPIO выводы разбиты на порты по 16 выводов в каждом. Управление каждым портом осуществляется с помощью контроллера портов ввода-вывода (п. 3.7).

Каждый вывод может поддерживать от одного до трех различных интерфейсных сигналов в режиме включенной альтернативной функции. Выбор используемой альтернативной функции осуществляется путем записи в регистры ALT\_FUNCTION\_CTRL в блоке регистров общего назначения. В таблице 1.2.2 приведено соответствие интерфейсных сигналов для различных альтернативных функций, и портов ввода-вывода, описанных в таблице 1.2.1.

Таблица 1.2.2 — Соответствие интерфейсных сигналов и портов ввода-вывода

| Номер порта<br>ввода-вывода | ALT_FUNC_1   | ALT_FUNC_2 | ALT_FUNC_3 | PAD |
|-----------------------------|--------------|------------|------------|-----|
| 1                           | 2            | 3          | 4          | 5   |
| A[0]                        | RAM_ADDR[0]  |            |            | P7  |
| A[1]                        | RAM_ADDR[1]  |            |            | N7  |
| A[2]                        | RAM_ADDR[2]  |            |            | Q6  |
| A[3]                        | RAM_ADDR[3]  |            |            | Q7  |
| A[4]                        | RAM_ADDR[4]  |            |            | P8  |
| A[5]                        | RAM_ADDR[5]  |            |            | Q9  |
| A[6]                        | RAM_ADDR[6]  |            |            | Q10 |
| A[7]                        | RAM_ADDR[7]  |            |            | P9  |
| A[8]                        | RAM_ADDR[8]  |            |            | P10 |
| A[9]                        | RAM_ADDR[9]  |            |            | N10 |
| A[10]                       | RAM_ADDR[10] |            |            | Q11 |
| A[11]                       | RAM_ADDR[11] |            |            | P11 |
| A[12]                       | RAM_ADDR[12] |            |            | Q12 |
| A[13]                       | RAM_ADDR[13] |            |            | Q13 |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. Nº подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

| 1     | 2                | 3                    | 4         | + |
|-------|------------------|----------------------|-----------|---|
| A[14] | RAM_ADDR[14]     |                      |           | I |
| A[15] | RAM_ADDR[15]     |                      |           | N |
| B[0]  | RAM_ADDR[16]     |                      |           | I |
| B[1]  | RAM_ADDR[17]     |                      |           | ( |
| B[8]  | RAM_DATA[0]      |                      |           | N |
| B[9]  | RAM_DATA[1]      |                      |           | I |
| B[10] | RAM_DATA[2]      |                      |           | I |
| B[11] | RAM_DATA[3]      |                      |           | N |
| B[12] | RAM_DATA[4]      |                      |           | I |
| B[13] | RAM_DATA[5]      |                      |           | N |
| B[14] | RAM_DATA[6]      |                      |           | I |
| B[15] | RAM_DATA[7]      |                      |           | N |
| C[0]  | RAM_DATA[8]      | MKPD3_RX_A           | SPI1_SS   | ŀ |
| C[1]  | RAM_DATA[9]      | MKPD3_nRX_A          | SPI1_SCK  | ŀ |
| C[2]  | RAM_DATA[10]     | MKPD3_TX_A           | SPI1_MISO |   |
| C[3]  | RAM_DATA[11]     | MKPD3_nTX_A          | SPI1_MOSI |   |
| C[4]  | RAM_DATA[12]     | MKPD3_TXEN_A         | SPI2_SS   |   |
| C[5]  | RAM_DATA[13]     | MKPD3_RX_B           | SPI2_SCK  | ŀ |
| C[6]  | RAM_DATA[14]     | MKPD3_nRX_B          | SPI2_MISO |   |
| C[7]  | RAM_DATA[15]     | MKPD3_TXEN_B         | SPI2_MOSI | F |
| C[8]  | RAM_DATA_CHK[0]  |                      |           | ( |
| C[9]  | RAM_DATA_ CHK[1] |                      |           | I |
| C[10] | RAM_DATA_ CHK[2] |                      |           | ( |
| C[11] | RAM_DATA_ CHK[3] |                      |           | I |
| C[12] | RAM_DATA_ CHK[4] |                      |           | I |
| C[13] | RAM_DATA_ CHK[5] |                      | UART1_TxD | I |
| C[14] | RAM_DATA_ CHK[6] |                      | UART1_RxD | I |
| C[15] | RAM_DATA_ CHK[7] |                      | UART2_TxD | I |
| D[0]  | RAM_DATA_ CHK[8] |                      | UART2_RxD | ( |
|       |                  | Микросхема интеграль | 500000010 |   |

Взам. инв. № Инв. № дубл.

Подп. и дата

| 1                 | 2                | 3                    | 4             | 5  |
|-------------------|------------------|----------------------|---------------|----|
| D[1]              | RAM_DATA_ CHK[9] |                      |               | D1 |
| D[2]              | RAM_Wen          |                      |               | E1 |
| D[4]              | RAM_Oen          |                      |               | C1 |
| D[5]              | RAM_LBn          |                      |               | B1 |
| D[6]              | RAM_Ubn          |                      |               | Di |
| D[7]              | SPI1_SS          | UART1_TxD            |               | C  |
| D[8]              | SPI1_SCK         | UART1_RxD            |               | B  |
| D[9]              | SPI1_MISO        | UART2_TxD            |               | A. |
| D[10]             | SPI1_MOSI        | UART2_RxD            |               | B  |
| D[11]             | SPI2_SS          | SW1_SIN              |               | C  |
| D[12]             | SPI2_SCK         | SW1_DIN              |               | A  |
| D[13]             | SPI2_MISO        | SW1_SOUT             |               | B  |
| D[14]             | SPI2_MOSI        | SW1_DOUT             |               | A  |
| D[15]             | UART1_TxD        | SW2_SIN              |               | A  |
| E[0]              | UART1_RxD        | SW2_DIN              |               | В  |
| E[1]              | UART2_TX         | SW2_SOUT             |               | С  |
| E[2]              | UART2_RX         | SW2_DOUT             |               | С  |
| E[3]              | RAM_Cen0         |                      |               | Е  |
| E[4]              | MKPD1_RX_A       | SPI1_SS              |               | C  |
| E[5]              | MKPD1_nRX_A      | SPI1_SCK             |               | В  |
| E[6]              | MKPD1_TX_A       | SPI1_MISO            |               | A  |
| E[7]              | MKPD1_nTX_A      | SPI1_MOSI            |               | В  |
| E[8]              | MKPD1_TXEN_A     | SPI2_SS              |               | С  |
| E[9]              | MKPD1_RX_B       | SPI2_SCK             |               | A  |
| E[10]             | MKPD1_nRX_B      | SPI2_MISO            |               | A  |
| E[11]             | MKPD1_TXEN_B     | SPI2_MOSI            |               | A  |
| E[12]             | MKPD2_RX_A       |                      | I2C_SCL       | В  |
| E[13] MKPD2_nRX_A |                  |                      | I2C_SDA       | В  |
| E[14]             | MKPD2_TX_A       | CAN1_TX              |               | C  |
| <u> </u>          |                  | Ликросхема интеграль | иза 5023RC016 | b  |

Взам. инв. № Инв. № дубл.

Подп. и дата

| 1     | 2            | 3                                      | 4             |   |
|-------|--------------|----------------------------------------|---------------|---|
| E[15] | MKPD2_nTX_A  | CAN1_RX                                |               | A |
| F[0]  | MKPD2_TXEN_A | CAN2_TX                                |               | I |
| F[1]  | MKPD2_RX_B   | CAN2_RX                                |               | A |
| F[2]  | MKPD2_nRX_B  | UART3_TxD                              |               | A |
| F[3]  | MKPD2_TXEN_B | UART3_RxD                              |               | I |
| F[4]  | MKPD3_RX_A   |                                        | UART5_TxD     | 1 |
| F[5]  | MKPD3_nRX_A  |                                        | UART5_RxD     | ( |
| F[6]  | MKPD3_TX_A   |                                        | UART6_TxD     | ( |
| F[7]  | MKPD3_nTX_A  |                                        | SW1_SIN       | I |
| F[8]  | MKPD3_TXEN_A |                                        | SW1_DIN       | I |
| F[9]  | MKPD3_RX_B   |                                        | SW1_SOUT      | I |
| F[10] | MKPD3_nRX_B  |                                        | SW1_DOUT      | I |
| F[11] | MKPD3_TXEN_B | RAM_ADDR[23]                           |               | I |
| F[12] | MKPD4_RX_A   | RAM_Cen1                               |               | ] |
| F[13] | MKPD4_nRX_A  | RAM_Cen2                               |               | ] |
| F[14] | MKPD4_TX_A   | RAM_Cen3                               |               | ] |
| F[15] | MKPD4_nTX_A  | RAM_ADDR[18]                           |               |   |
| G[0]  | MKPD4_TXEN_A | RAM_ADDR[19]                           |               | ( |
| G[1]  | MKPD4_RX_B   | RAM_ADDR[20]                           |               | ] |
| G[2]  | MKPD4_nRX_B  | RAM_ADDR[21]                           |               | ( |
| G[3]  | MKPD4_TXEN_B | RAM_ADDR[22]                           |               | I |
| G[4]  | SW1_SIN      | MKPD4_RX_A                             |               |   |
| G[5]  | SW1_DIN      | MKPD4_nRX_A                            |               | I |
| G[6]  | SW1_SOUT     | MKPD4_TX_A                             |               | I |
| G[7]  | SW1_DOUT     | MKPD4_nTX_A                            |               | I |
| G[8]  | SW2_SIN      | MKPD4_TXEN_A                           |               | 1 |
| G[9]  | SW2_DIN      | MKPD4_RX_B                             |               | N |
| G[10] | SW2_SOUT     | MKPD4_nRX_B                            |               | 1 |
| G[11] | SW2_DOUT     | MKPD4_TXEN_B                           |               | N |
|       |              | Микросхема интегральн                  | ная 5023BC016 |   |
|       |              | Техническое опи<br>Версия 2.04 om 01.0 |               |   |

Взам. инв. № Инв. № дубл.

Подп. и дата

инв. № дубл.

Взам. инв. №

Подп. и дата

| 1     | 2             | 3 | 4         | 5  |
|-------|---------------|---|-----------|----|
| G[12] | TM_CLKI       |   | CAN1_TX   | L3 |
| G[13] | TM_DOUT_VALID |   | CAN1_RX   | N2 |
| G[14] | TM_DOUT       |   | CAN2_TX   | P1 |
| G[15] | TC_CLKI       |   | CAN2_RX   | M3 |
| H[0]  | TC_ACT        |   | UART3_TxD | N3 |
| H[1]  | TC_DIN[0]     |   | UART3_RxD | P2 |
| H[2]  | TC_DIN[1]     |   | UART4_TxD | H2 |
| H[3]  | TC_DIN[2]     |   | UART4_RxD | J1 |
| H[4]  | SW_CLK        |   | UART6_RxD | В8 |

#### 1.3 Электрические параметры микросхемы

Электрические параметры СБИС СРU при приёмке и поставке должны соответствовать нормам, приведённым в таблице 1.3.1.

Электрические параметры микросхем в процессе и после воздействия специальных факторов (ВСФ) должны соответствовать нормам, приведённым в таблице 1.3.1 для крайних значений рабочей температуры среды.

Значения предельно-допустимых и предельных режимов эксплуатации в диапазоне рабочих температур среды должны соответствовать нормам, приведённым в таблице 1.3.2.

Таблица 1.3.1 — Электрические параметры СБИС СРU при приёмке и поставке

| Полимоморомую моромогра                                                                              | Буквенное       | Норма параметра |          |          |          |                          |  |
|------------------------------------------------------------------------------------------------------|-----------------|-----------------|----------|----------|----------|--------------------------|--|
| Наименование параметра, единица измерения, режим                                                     | обозначен<br>ие | До В            | СФ       | Во время |          | Температура<br>среды, °С |  |
| измерения                                                                                            | параметра       | не менее        | не более | не менее | не более |                          |  |
| 1                                                                                                    | 2               | 3               | 4        | 5        | 6        | 7                        |  |
| 1 Выходное напряжение низкого уровня буферов                                                         | II              |                 | 0,4      |          | 0,4      | 25 ± 10                  |  |
| ввода-вывода, B, при $U_{CC1}=3.0~\mathrm{B};$ $U_{CC2}=1,62~\mathrm{B},~I_{OL}\leq 2.0~\mathrm{mA}$ | $ m U_{OL}$     | _               | 0,5      | _        | 0,5      | от – 60 до + 85          |  |

|    |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|----|--------|----------|-------|------|-----------------------------------|------|
|    |        |          |       |      | Техническое описание              |      |
| Из | и Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 19   |

Копировал

Формат А4

| 1                                                                                                                                | 2                 | 3                             | 4                     | 5                             | 6                     | 7            |
|----------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------------|-----------------------|-------------------------------|-----------------------|--------------|
| 2 Выходное напряжение высокого уровня буферов ввода-вывода, В,                                                                   | U <sub>ОН</sub>   | 2,7                           | _                     | 2,0                           | _                     | 25 ± 10      |
| при $U_{CC1} = 3.0 \text{ B};$ $U_{CC2} = 1.62 \text{ B}, I_{OH} \le -0.3 \text{ мA}$                                            | - 011             | 2,3                           |                       | 1,8                           |                       | от – 60 до + |
| 3 Ток потребления в                                                                                                              | $I_{CC1}$         |                               | 150                   | _                             | 220                   | 25 ± 10      |
| статическом режиме, мА,                                                                                                          | ICCI              | _                             | 250                   | _                             | 300                   | от – 60 до + |
| при U <sub>CC1</sub> = 3,6 B;<br>U <sub>CC2</sub> = 1,98 B                                                                       | $I_{\rm CC2}$     |                               | 65                    | _                             | 220                   | $25 \pm 10$  |
| O(C2 – 1,76 B                                                                                                                    | 1002              |                               | 70                    |                               | 300                   | от – 60 до + |
| 4 Ток утечки низкого и высокого уровня на входе, мкА, Входы «pulldown» (К3, N1) Входы «pullup» (L1, M2)                          | ${ m I}_{ m ILL}$ | - 15<br>- 200<br>- 55<br>- 15 | 200<br>15<br>55<br>15 | - 15<br>- 200<br>- 55<br>- 15 | 200<br>15<br>55<br>15 | 25 ± 10      |
| Вход X2/CLKIN (Q2)<br>Все остальные входы<br>при $U_{CC1} = 3,6$ B;<br>$U_{CC2} = 1,98$ B, $U_{IL} = 0$ В<br>( $U_{IH} = 3,6$ В) | ${ m I_{ILH}}$    | -25<br>-300<br>-75<br>-25     | 300<br>25<br>75<br>25 | - 25<br>- 300<br>- 75<br>- 25 | 300<br>25<br>75<br>25 | от – 60 до + |
| 5 Выходной ток низкого и высокого уровня буфера с третьим состоянием в состоянии «Выключено»,                                    | I <sub>OZL</sub>  | - 15                          | 15                    | - 15                          | 15                    | 25 ± 10      |
| мкА, при $U_{CC1} = 3,6 B$ ; $U_{CC2} = 1,98 B$ $U_{OL} = 0 B (U_{OH} = 3,6 B)$                                                  | $I_{\rm OZH}$     | - 25                          | 25                    | - 25                          | 25                    | от – 60 до + |
| 6 Динамический ток потребления ядра, мА, при $U_{CC1} = 3,6 B$ ;                                                                 | I <sub>OCC</sub>  |                               | 300                   | _                             | 450                   | 25 ± 10      |
| При ССС1 3,0 В, $U_{CC2} = 1,98 B$ $fc = 40 M\Gamma$ ц и $C_L \le 20 \pi \Phi^{1)}$                                              | 1000              | _                             | 350                   | _                             | 550                   | от – 60 до + |
| 7 Функциональный контроль (ФК) при $U_{CC1} = 2,97 \ B;$ $U_{CC2} = 1,62 \ B,$                                                   | ФК                |                               |                       |                               |                       | 25 ± 10      |
| при $U_{CC1}$ = 3,63 B; $U_{CC2}$ = 1,98 B, $f_C$ = 50 МГц и $C_L$ = 20 п $\Phi^{1)}$                                            |                   |                               |                       |                               |                       | от – 60 до + |
| 8 Входная емкость, пФ                                                                                                            | Cı                |                               | 12                    |                               | 12                    | 25 ± 10      |
| 9 Выходная емкость, пФ                                                                                                           | Co                |                               | 12                    |                               | 12                    | ± 10         |
| 10 Емкость входа/выхода, пФ                                                                                                      | C <sub>I/O</sub>  |                               | 14                    |                               | 14                    | 25 ± 10      |
| • • • • • • • • • • • • • • • • • • • •                                                                                          |                   |                               |                       |                               |                       | <u> </u>     |

Инв. № дубл.

Взам. инв. №

Подп. и дата

Инв. № подл.

Лист

№ докум.

Подп.

Дата

Техническое описание

Версия 2.04 от 01.09.2017 г.

20

Примечание — В процессе и непосредственно после воздействия специального фактора 7.И с характеристикой 7.И6 требования к значениям электрических параметров не предъявляют на время потери работоспособности, указанной в пункте 2.6.1 АЕЯР.431290.994 ТУ.

Таблица 1.3.2 — Предельно-допустимые и предельные режимы эксплуатации микросхемы

| Наименование<br>параметра режима,                                             | Буквенное<br>обозначение          |          | -допустимый<br>жим                 | Предельный режим |                                    |
|-------------------------------------------------------------------------------|-----------------------------------|----------|------------------------------------|------------------|------------------------------------|
| единица измерения                                                             | параметра                         | не менее | не более                           | не менее         | не более                           |
| Напряжение питания<br>буферов ввода-вывода, В                                 | U <sub>CC1</sub>                  | 3,0      | 3,6                                | - 0,3            | 4,51)                              |
| Напряжение питания ядра, В                                                    | U <sub>CC2</sub>                  | 1,62     | 1,98                               | -0,2             | $2,5^{1)}$                         |
| Входное напряжение низкого уровня на входах, В                                | $ m U_{IL}$                       | 0        | 0,8                                | -0,3             | _                                  |
| Входное напряжение высокого уровня на входах, В                               | $ m U_{IH}$                       | 2,0      | U <sub>CC1</sub>                   | _                | U <sub>CC1</sub> + 0,3             |
| Выходное напряжение на выходе с третьим состоянием в состоянии «Выключено», В | Uoz                               | 0        | U <sub>CC1</sub>                   | - 0,3            | U <sub>CC1</sub> + 0,3             |
| Выходной ток низкого уровня, мА                                               | $I_{OL}$                          | _        | 1,5                                | _                | 2,0                                |
| Выходной ток высокого уровня, мА                                              | $I_{OH}$                          |          | -0,3                               |                  | -0,5                               |
| Частота следования импульсов тактовых сигналов, МГц                           | $f_{\mathrm{C}}$                  | 5        | 50 <sup>4)</sup>                   | _                | _                                  |
| Время нарастания и спада входных сигналов, нс                                 | t <sub>LH</sub> и t <sub>HL</sub> | _        | 0,05T <sub>CLK</sub> <sup>2)</sup> | _                | 0,05T <sub>CLK</sub> <sup>2)</sup> |
| Ёмкость нагрузки, пФ                                                          | $C_{L}$                           | _        | 203)                               | _                | 403)                               |

<sup>1)</sup> С учётом всех видов помех.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

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

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

 $<sup>^{2)}</sup>$  При переключении входных сигналов.

<sup>3)</sup> С учётом всех паразитных емкостей.

<sup>&</sup>lt;sup>4)</sup> С приёмкой «5».

Таблица 1.3.3 — Средний ток потребления ядра в основных режимах работы микросхемы (напряжение питания  $U_{cc2}=1{,}98~B,~T=25{,}0~^{\circ}C,~f_c=50~M\Gamma$ ц и  $f_c=80~M\Gamma$ ц)

| Downers no Soms                                     | Ток потребления, мА |             |  |  |
|-----------------------------------------------------|---------------------|-------------|--|--|
| Режимы работы                                       | fc = 50 МГц         | fc = 80 МГц |  |  |
| Работает ПдТМИ и UART1                              | 481                 | 665         |  |  |
| Работает ПрТКИ и UART1                              | 301                 | 403         |  |  |
| Работает вычислитель с плавающей запятой и UART1    | 236                 | 302         |  |  |
| Работают 4 контроллера по ГОСТ Р 52070 и UART1      | 315                 | 424         |  |  |
| Работают 2 контроллера интерфейса SpaceWire и UART1 | 321                 | 440         |  |  |
| Работают 2 контроллера SPI и UART1                  | 220                 | 284         |  |  |
| Работают 2 контроллера UART                         | 217                 | 285         |  |  |

СБИС CPU стойкая к воздействию специальных факторов, приведённых в таблице 1.3.4.

Таблица 1.3.4 — Стойкость к воздействию специальных факторов

| Характеристики специальных факторов | Значения характеристик специальных факторов |
|-------------------------------------|---------------------------------------------|
| 7.И1                                | 4Ус                                         |
| 7.И6                                | 4Ус                                         |
| 7.И7                                | 4Ус                                         |
| 7.И8                                | 0,02 · 1Ус                                  |
| 7.C1                                | 4Ус                                         |
| 7.C4                                | 4Ус                                         |
| 7.K1                                | $1K^{1)}(2K^{2)};$                          |
| 7.K4                                | 1К                                          |
| 7.K12                               | 60 <sup>3)</sup> МэВ · см²/мг               |

<sup>2)</sup> При независимом воздействии факторов 7.К1 и 7.К4.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

<sup>3)</sup> По катастрофическим отказам и тиристорному эффекту.

## 2 Общая характеристика СБИС СРИ

Системная шина микросхемы разделена на высокоскоростную шину Advanced Microcontroller Bus Architecture (AMBA) High-performance Bus (AHB) и низкоскоростную AMBA Advanced Peripheral Bus (APB).

Шина АМВА АНВ предназначена для связи высокоскоростных устройств:

- ядра процессора;
- оперативной памяти;
- контроллера прямого доступа к памяти (ПДП);
- интерфейсов SpaceWire;
- блоков мультиплексного канала передачи данных (МКПД);
- блоков ПдТМИ и ПрТКИ.

Шина AMBA APB предназначена для подключения низкоскоростных устройств:

- контроллеров последовательных портов;
- интерфейсов управления ПдТМИ и ПрТКИ и ПДП;
- таймеров;
- контроллеров интерфейсов CAN;
- $--I^2C$ .

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Функционирование шины обеспечивается блоками:

— AHB BusMUX — мультиплексор ведущих и ведомых устройств шины AMBA AHB. Данный блок выполняет арбитраж доступа ведущих устройств на шине к ведомым, а также передачу ответов в обратную сторону, обеспечивая доступ к шине всем устройствам с одинаковым приоритетом;

- АНВ-АРВ МОСТ выполняет передачу данных между шинами АНВ и АРВ;
- APB SLAVE MUX мультиплексор ведомых устройств шины AMBA APB. Данный блок выполняет передачу сигналов управления на ведомые устройства шины, а также передачу ответов в обратную сторону.

Блок ФТС выполняет формирования сетки тактовых частот, необходимых для работы схемы, а также пересинхронизацию сигнала сброса.

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г. Лист

23

# 3.1 Структурная организация микросхемы Структурная схема СБИС СРU приведена на рисунке 3.1.1. СБИС СРU состоит из следующих функциональных блоков: — 32-разрядного процессорного ядра (CPU CORE); — мультиплексора устройств шины AMBA AHB (матрица переключений шины АНВ); — моста между шинами AMBA AHB и AMBA APB (AHB-APB MOCT); — мультиплексора ведомых устройств шины AMBA APB (APBSLAVEMUX); — блока формирования тактовых сигналов и сигналов сброса (ФТС); контроллера прямого доступа к памяти (ПДП); — четырех резервированных контроллеров последовательного интерфейса по ГОСТ Р 52070 (МКПД1 – МКПД4); — двух контроллеров интерфейса SpaceWire со скоростью передачи данных до 100 Мбит/c (SW1 – SW2);— внутрикристальной схемы отладки с интерфейсом JTAG (IEEE 1149.1) (BCO); блока граничного сканирования (ГС); — встроенного оперативного запоминающего устройства, состоящего из двух блоков по 64 кБ (O3У1 – O3У2); — контроллера встроенного ОЗУ с блоком обнаружения и исправления ошибок; — контроллера внешней статической памяти со встроенным блоком обнаружения и исправления ошибок (КВП); — шести асинхронных последовательных портов UART (КАПП1 – КАПП6); двух последовательных портов SPI (КПП1 – КПП2); специализированного вычислителя с плавающей запятой (BC); — четырех таймеров общего назначения (T1 – T4); сторожевого таймера (СТ); Микросхема интегральная 5023ВС016 Лист

3 Описание микросхемы

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Лист

№ докум.

Подп.

*Д*ата

24

Техническое описание

Версия 2.04 от 01.09.2017 г.



#### JTAG\_SELECT:

- 0 выводы JTAG перенаправлены к программатору и отладчику ARM процессора;
  - 1 выводы JTAG перенаправлены к Boundary Scan контроллеру.

Ex8\_16bit: режим работы внешней памяти по Chip Select 1:

- 0 8-битный режим;
- 1 16-битный режим.

ExEDAC\_En: включение режима исправления единичных и обнаружения неисправимых ошибок во внешней памяти по Chip Select 1.

В 8-битном режиме используются выводы RAM\_DATA\_CHK [4:0], в 16-битном режиме — RAM\_DATA\_CHK [9:0].

#### 3.1.2 Инициализация работы микросхемы

Перед началом работы микросхемы должны быть настроены внешние выводы контроллера внешней памяти ExEDAC\_En и Ex8\_16bit. ExEDAC\_En управляет включением/выключением блока обнаружения и исправления ошибок (EDAC) контроллера внешней памяти по Chip Select 1.

Начальная загрузка происходит через Chip Select 1. В таблице 3.1.1 представлено соответствие Chip Select и выводов.

Таблица 3.1.1 — Соответствие Chip Select и выводов

Инв. № дубл.

Взам. инв. №

Подп. и дата

| CS            | Название<br>функции | Номер порта<br>ввыда-вывода | Номер<br>альтернативной<br>функции | Номер вывода |
|---------------|---------------------|-----------------------------|------------------------------------|--------------|
| Chip Select 1 | RAM_Cen0            | E[3]                        | ALT_FUNC_1                         | E2           |
| Chip Select 2 | RAM_Cen1            | F[12]                       | ALT_FUNC_2                         | F3           |
| Chip Select 3 | RAM_Cen2            | F[13]                       | ALT_FUNC_2                         | F2           |
| Chip Select 4 | RAM_Cen3            | F[14]                       | ALT_FUNC_2                         | E1           |

Если на вывод ExEDAC\_En подаётся уровень логической единицы, то EDAC включен. Если ExEDAC\_En подключен к земле, то EDAC выключен. Ex8\_16bit переключает режим 8/16 бит контроллера внешней памяти. При Ex8\_16bit равном

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 26   |

Копировал

Формат А4

После подачи питаний  $U_{CC1}$  и  $U_{CC2}$  микросхема должна быть сброшена внешним сигналом на выводе RST. Одновременно с сигналом сброса должен подаваться тактовый сигнал на вывод CLK. Минимальная длительность сигнала сброса должна быть не менее 2 периодов тактового сигнала. Активный уровень сигнала сброс — логический ноль.

Перед началом работы с периферийными модулями микросхемы необходимо включить тактовые сигналы этих модулей. Включение тактовых сигналов осуществляется в регистре общего назначения PWR\_CTRL\_CLK. Также должен быть снят сброс соответствующего модуля в регистре PWR CTRL RST.

#### 3.2 Распределение адресного пространства СБИС СРИ

Распределение адресного пространства микросхемы показано в таблице 3.2.1.

Таблица 3.2.1 — Структура адресного пространства

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

№ докум.

Подп.

Дата

| Адрес                     | Описание                                                                                                                                           |  |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1                         | 2                                                                                                                                                  |  |
| 0x0000_0000 - 0x00FF_FFFF | Алиасинг для областей: Внешняя память Chip Select 1-4, внутренняя память блок 1, внутренняя память блок 2. По сбросу: внешняя память Chip Select 1 |  |
| 0x0800_0000 - 0x08FF_FFFF | Внешняя память Chip Select 1                                                                                                                       |  |
| 0x0900_0000 - 0x09FF_FFFF | Внешняя память Chip Select 2                                                                                                                       |  |
| 0x0A00_0000 - 0x0AFF_FFFF | Внешняя память Chip Select 3                                                                                                                       |  |
| 0x0B00_0000 - 0x0BFF_FFFF | Внешняя память Chip Select 4                                                                                                                       |  |
| 0x2000_0000 - 0x2000_FFFF | Внутренняя память блок 1                                                                                                                           |  |
| 0x2001_0000 - 0x2001_FFFF | Внутренняя память блок 2                                                                                                                           |  |
| 0x8000_0000 - 0x8000_0FFF | GPIO_A                                                                                                                                             |  |
| 0x8001_0000 - 0x8001_0FFF | GPIO_B                                                                                                                                             |  |
| 0x8002_0000 - 0x8002_0FFF | GPIO_C                                                                                                                                             |  |
| 0x8003_0000 - 0x8003_0FFF | GPIO_D                                                                                                                                             |  |
| 0x8004_0000 - 0x8004_0FFF | GPIO_E                                                                                                                                             |  |
| 0x8005_0000 - 0x8005_0FFF | GPIO_F                                                                                                                                             |  |
| 0x8006_0000 - 0x8006_0FFF | GPIO_G                                                                                                                                             |  |
|                           | ·<br>·                                                                                                                                             |  |

Микросхема интегральная 5023BC016 Техническое описание

Версия 2.04 от 01.09.2017 г.

27

| l   | Продолжение таблицы 3.2    | 2.1                                                                         |     |  |  |  |
|-----|----------------------------|-----------------------------------------------------------------------------|-----|--|--|--|
|     | 1                          | 2                                                                           |     |  |  |  |
|     | 0x8007_0000 - 0x8007_0FFF  | GPIO_H                                                                      |     |  |  |  |
|     | 0x8008_0000 - 0x8008_0FFF  | GPIO_I                                                                      |     |  |  |  |
|     | 0xA000_0000 - 0xA000_FFFF  | Регистры общего назначения                                                  |     |  |  |  |
|     | 0xA001_0000 - 0xA001_0FFF  | DMA контроллер                                                              |     |  |  |  |
|     | 0xA002_0000 - 0xA002_0FFF  | SPI_1                                                                       |     |  |  |  |
|     | 0xA003_0000 - 0xA003_0FFF  | SPI_2                                                                       |     |  |  |  |
|     | 0xA004_0000 - 0xA004_0FFF  | UART_1                                                                      |     |  |  |  |
|     | 0xA005_0000 - 0xA005_0FFF  | UART_2                                                                      |     |  |  |  |
|     | 0xA006_0000 - 0xA006_0FFF  | UART_3                                                                      |     |  |  |  |
|     | 0xA007_0000 - 0xA007_0FFF  | UART_4                                                                      |     |  |  |  |
|     | 0xA008_0000 - 0xA008_0FFF  | WatchDog                                                                    |     |  |  |  |
|     | 0xA009_0000 - 0xA009_0FFF  | Timer 1                                                                     |     |  |  |  |
|     | 0xA00A_0000 - 0xA00A_FFFF  | SpaceWire_1                                                                 |     |  |  |  |
|     | 0xA00B_0000 - 0xA00B_FFFF  | SpaceWire_2                                                                 |     |  |  |  |
|     | 0xA00C_0000 - 0xA00C_FFFF  | МКПД_1                                                                      |     |  |  |  |
|     | 0xA00D_0000 - 0xA00D_FFFF  | МКПД _2                                                                     |     |  |  |  |
|     | 0xA00E_0000 - 0xA00E_FFFF  | МКПД_3                                                                      |     |  |  |  |
|     | 0xA00F_0000 - 0xA00F_FFFF  | МКПД _4                                                                     |     |  |  |  |
|     | 0xA010_0000 - 0xA010_FFFF  | Telemetry Encoder (TMTX)                                                    |     |  |  |  |
|     | 0xA011_0000 - 0xA011_FFFF  | TCRX                                                                        |     |  |  |  |
|     | 0xA012_0000 - 0xA012_FFFF  | Floating Point Unit (FPU)                                                   |     |  |  |  |
|     | 0xA013_0000 - 0xA013_FFFF  | Timer 2                                                                     |     |  |  |  |
|     | 0xA014_0000 - 0xA014_FFFF  | Timer 3                                                                     |     |  |  |  |
|     | 0xA015_0000 - 0xA015_FFFF  | Timer 4                                                                     |     |  |  |  |
|     | 0xA01B_0000 - 0xA01B_FFFF  | CAN 1                                                                       |     |  |  |  |
|     | 0xA01C_0000 - 0xA01C_FFFF  | CAN 2                                                                       |     |  |  |  |
|     | 0xA01D_0000 - 0xA01D_FFFF  | Мультиплексор прерываний                                                    |     |  |  |  |
|     | 0xA01E_0000 - 0xA01E_FFFF  | UART_5                                                                      |     |  |  |  |
|     | 0xA01F_0000 - 0xA01F_FFFF  | UART_6                                                                      |     |  |  |  |
|     | 0xA020_0000 - 0xA020_FFFF  | I <sup>2</sup> C                                                            |     |  |  |  |
|     | 0x6000_0000 - 0x6000_FFFF  | Тестовый доступ к памяти блок 1, данные                                     |     |  |  |  |
|     | 0x6010_0000 - 0x6010_FFFF  | Тестовый доступ к памяти блок 1, биты ECC (доступно 20 битмаска 0x1F1F1F1F) | г,  |  |  |  |
|     |                            |                                                                             |     |  |  |  |
|     |                            | Микросхема интегральная 5023BC016                                           | Лис |  |  |  |
| 131 | л Лист № докум. Подп. Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г.                        | 2   |  |  |  |

Инв. № дубл.

Взам. инв. №

Подп. и дата

Инв. Nº подл.

| 1                         | 2                                                              |
|---------------------------|----------------------------------------------------------------|
| 0x6100_0000 - 0x6100_3FFF | Тестовый доступ к памяти кэша way1 данные                      |
| 0x6110_0000 - 0x6110_3FFF | Тестовый доступ к памяти кэша way1 таг и crc (доступен 21 бит) |
| 0x6200_0000 - 0x6200_FFFF | Тестовый доступ к памяти блок 2, данные                        |
| 0x6210_0000 - 0x6210_FFFF | Тестовый доступ к памяти блок 2, биты ЕСС (доступно 20 бит)    |

#### 3.3 Вектора прерываний СБИС СРИ

Процессор имеет 32 вектора прерываний.

Управляющие регистры ссылаются на базовый адрес Мультиплексора прерываний — 0xA01D\_0000.

Каждому источнику прерывания соответствует свой управляющий регистр, с адресом, равным номеру источника прерываний, умноженному на 4.

Для ΤΟΓΟ чтобы подключить требуемый источник прерываний определенный вектор прерываний, нужно запрограммировать соответствующий (соответствует номеру источника прерывания) управляющий регистр мультиплексора прерываний. Также необходимо разрешить прерывания, вызвав NVIC En IRQ(vec), где vec — номер вектора прерываний.

Источники прерываний, которые подключены на один и тот же вектор прерываний, объединяются по «ИЛИ».

## 3.3.1 Регистры INTR MUX CTRL

Таблица 3.3.1 содержит описание регистра INTR MUX CTRL.

Таблица 3.3.1 — Описание регистра INTR\_MUX\_CTRL

| <b>№</b><br>бита | Наименование бита       | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений          |
|------------------|-------------------------|--------------------------------------------------------------------------------------------------|
| 31               | INTR_SRC_ENABLE<br>(RW) | 1 — включение источника прерывания                                                               |
| 30 - 5           | _                       |                                                                                                  |
| 4-0              |                         | номер вектора прерываний от 0 до 31, на который направляется соответствующий источник прерываний |

Микросхема интегральная 5023ВС016 Лист Техническое описание 29 Версия 2.04 от 01.09.2017 г. Подп. № докум. *Д*ата

Таблица 3.3.2 — Номера источников прерываний

| Номер      | Наименование | Номер      | Наименование     | Номер      | Наименование  |
|------------|--------------|------------|------------------|------------|---------------|
| источника  | источника    | источника  | источника        | источника  | источника     |
| прерываний | прерываний   | прерываний | прерываний       | прерываний | прерываний    |
| 1          | 2            | 1          | 2                | 1          | 2             |
| 00         | Watchdog     | 26         | UART 3           | 53         | CAN 2         |
| 01         | Timer 1      | 27         | UART 4           | 56         | EDAC          |
| 03         | Timer 2      | 28         | UART 5           | 98         | DMA SPI 2 TX  |
| 04         | Timer 3      | 29         | UART 6           | 99         | DMA SPI 2 RX  |
| 08         | Timer 4      | 32         | SPI 1            | 100        | DMA UART 1 TX |
| 09         | GPIO A       | 33         | SPI 2            | 101        | DMA UART 1 RX |
| 10         | GPIO B       | 36         | SpaceWire 1      | 102        | DMA UART 2 TX |
| 11         | GPIO C       | 37         | SpaceWire 2      | 103        | DMA UART 2 RX |
| 12         | GPIO D       | 40         | МКПД 1           | 104        | DMA UART 3 TX |
| 13         | GPIO E       | 41         | МКПД 2           | 105        | DMA UART 3 RX |
| 14         | GPIO F       | 42         | МКПД 3           | 106        | DMA UART 4 TX |
| 15         | GPIO G       | 43         | МКПД 4           | 107        | DMA UART 4 RX |
| 16         | GPIO H       | 48         | TMTX             | 108        | DMA UART 5 TX |
| 23         | GPIO I       | 49         | TCRX             | 109        | DMA UART 5 RX |
| 24         | UART 1       | 50         | I <sup>2</sup> C | 110        | DMA UART 6 TX |
| 25         | UART 2       | 52         | CAN 1            | 111        | DMA UART 6 RX |

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

## 3.4.1 Состав регистров общего назначения

Состав регистров общего назначения приведён в таблице 3.4.1.

Назначения разрядов регистров общего назначения приведены в таблицах 3.4.2 - 3.4.38.

Таблица 3.4.1 — Состав регистров общего назначения

| Сме-   | Название регистра | Тип | Значение по сбросу | Описание                                                          |
|--------|-------------------|-----|--------------------|-------------------------------------------------------------------|
| 1      | 2                 | 3   | 4                  | 5                                                                 |
| 0 x 00 | EXTMEM_CTRL       | RW  | 0x1FF              | Конфигурирование контроллера внешней памяти по Chip Select 1      |
| 0 x 04 | EDAC_CTRL         | RW  | 0x3                | Включение режима исправления и детекции ошибок внутренней памяти. |
| 0 x 08 | INTMEM_CERR_CNT   | RO  | 0                  | Счётчик исправленных ошибок внутренней памяти блока 1.            |
| 0 x 0C | INTMEM_FERR_CNT   | RO  | 0                  | Счётчик неисправимых ошибок внутренней памяти блока 1.            |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

| 1      | 2                    | 3  | 4     | 5                                                                |
|--------|----------------------|----|-------|------------------------------------------------------------------|
| 0 x 10 | EXTMEM_CERR_CNT      | RO | 0     | Счётчик исправленных ошибов внешней памяти.                      |
| 0 x 14 | EXTMEM_FERR_CNT      | RO | 0     | Счётчик неисправимых ошибо внешней памяти.                       |
| 0 x 1C | SPACEWIRE_CLK_CTRL   | RW | 0     | Выбор тактовой частоты блоко SpaceWire                           |
| 0 x 20 | INTMEM2_CERR_CNT     | RO | 0     | Счётчик исправленных ошибов внутренней памяти блока 2.           |
| 0 x 24 | INTMEM2_FERR_CNT     | RO | 0     | Счётчик неисправимых ошибо внутренней памяти блока 2.            |
| 0 x 28 | PWR_CTRL_CLK         | RW | 0     | Включение тактовых частот различных блоков                       |
| 0 x 2C | PWR_CTRL_RST         | RW | 0     | Асинхронный сброс различных блоков                               |
| 0 x 30 | EXTMEM2_CTRL         | RW | 0x1FF | Конфигурирование контроллер внешней памяти по Chip Select        |
| 0 x 34 | EXTMEM3_CTRL         | RW | 0x1FF | Конфигурирование контроллер внешней памяти по Chip Select        |
| 0 x 38 | EXTMEM4_CTRL         | RW | 0x1FF | Конфигурирование контроллер внешней памяти по Chip Select        |
| 0 x 3C | CACHE_HIGH_ADDR      | RW | 0     | Задает пространство работы кэ                                    |
| 0 x 40 | INTMEM_SCR_RNG_ADDR  | RW | 0x3   | Диапазон адресов скраббера дл<br>блока памяти 1.                 |
| 0 x 44 | INTMEM_SCR_PRD_SCAN  | RW | 0     | Период сканирования скраббер для блока памяти 1.                 |
| 0 x 48 | INTMEM_SCR_PRD_STOP  | RW | 0     | Период прерывания скрабберо контроллер памяти 1.                 |
| 0 x 4C | INTMEM2_SCR_RNG_ADDR | RW | 0x3   | Диапазон адресов скраббера дл<br>блока памяти 2.                 |
| 0 x 50 | INTMEM2_SCR_PRD_SCAN | RW | 0     | Период сканирования скраббер для блока памяти 2.                 |
| 0 x 54 | INTMEM2_SCR_PRD_STOP | RW | 0     | Период прерывания скрабберо контроллер памяти 2.                 |
| 0 x 58 | INTMEMS_SCR_MAIN     | RW | 0     | Общее управление скрабберам                                      |
| 0 x 5C | CACHE_CRC_ERROR      | RO | 0     | Счётчик сгс ошибок в кэше                                        |
| 0 x 60 | EDAC_INTMEM_SCR_CERR | RO | 0     | Счётчик исправимых ошибок, обнаруженных скраббером бло памяти 1. |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

Инв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

| Продолжение таблицы 3.4 |
|-------------------------|
|-------------------------|

EDAC\_INTMEM\_SCR\_FERR

EDAC\_INTMEM2\_SCR\_CERR

0 x 64

0 x 68

Инв. № дубл.

Взам. инв. №

Подп. и дата

Инв. № подл.

| 0 A 00              | LDNC_II\II\IILI\IZ_SER_EDIK |      | Ŭ | памяти 2.                                                            |
|---------------------|-----------------------------|------|---|----------------------------------------------------------------------|
| 0 x 6C              | EDAC_INTMEM2_SCR_FERR       | RO   | 0 | Счётчик неисправимых ошибок, обнаруженных скраббером блока памяти 2. |
| 0 x 70              | DMA_INTR_FLAGS              | RW1C | 0 | Флаги прерываний Direct Memory Access (DMA)                          |
| 0 x 74 –<br>0 x 94  | ALT_FUNCTION_CTRL           | RW   | 0 | Выбор альтернативной функции для каждого порта GPIO                  |
| 0 x A0              | CACHE_HIGH_ADDR_CS2         | RW   | 0 | Задает пространство работы кэша для памяти по Chip Select 2          |
| 0 x A4              | CACHE_HIGH_ADDR_CS3         | RW   | 0 | Задает пространство работы кэша для памяти по Chip Select 3          |
| 0 x A8              | CACHE_HIGH_ADDR_CS4         | RW   | 0 | Задает пространство работы кэша для памяти по Chip Select 4          |
| 0 x AC              | ALIAS_CTRL                  | RW   | 0 | Настройка алиасинга для области адресов 0x0000_0000-0x00F_FFFFF      |
| 0 x B0              | SCRUBBER_FERR_ADDR          | RO   | 0 | Адрес последнего FERR для скрабберов.                                |
| 0 x B4              | COMMON_FERR_ADDR            | RO   | 0 | Адрес последнего FERR для внешней и внутренней памяти без скраббера. |
| 0 x B8              | EDAC_REACTION_CTRL          | RW   | 0 | Управление реакцией на ошибки EDAC и CRC                             |
| 0 x BC              | GLOBAL_RESET                | RW   | 0 | Сброс всех блоков, включая отладчик (W1O)                            |
| 0 x C4              | CACHE_MAIN                  | RW   | 0 | Включение / сброс и статус кэша                                      |
| 0 x C8 –<br>0 xFFFF | _                           |      |   | Не используется, читается 0.                                         |

3

RO

RO

0

0

памяти 1.

Счётчик неисправимых ошибок, обнаруженных скраббером блока

Счётчик исправимых ошибок, обнаруженных скраббером блока

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

## 3.4.1.1 Регистр EXTMEM\_CTRL

## Таблица 3.4.2 — Описание регистра EXTMEM\_CTRL

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                            |
|---------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31      | EDAC_FORCE        | Если поле имеет значение «1», использование блока исправления ошибок по Chip Select 1 определяется полем EDAC, иначе определяется значением внешнего вывода EXTMEM_EDAC_EN.                                                        |
| 30      | SIZE_FORCE        | Если поле имеет значение «1», разрядность шины данных внешней памяти по Chip Select 1 определяется полем Size, иначе определяется значением внешнего вывода EXTMEM_CFGSIZE.                                                        |
| 29 - 25 | <del>_</del>      |                                                                                                                                                                                                                                    |
| 24      | EDAC              | Включение блока исправления ошибок внешней памяти по Chip Select 1. Значение 0 — блок исправления ошибок не используется, 1 — блок исправления ошибок включен. Имеет значение, только если бит EDAC_FORCE выставлен в «1».         |
| 23 - 17 | _                 |                                                                                                                                                                                                                                    |
| 16      | SIZE              | Выбор режима разрядности внешней памяти по Chip Select 1. Значение 0 — 8-битная шина данных, значение 1 — 16-битная шина данных. Имеет значение, только если бит SIZE_FORCE выставлен в «1».                                       |
| 15 – 9  | _                 |                                                                                                                                                                                                                                    |
| 8 – 6   | TURN_CYCLES       | Величина задержки Chip Select (сигнал CEN) в тактах системной частоты, которая приводит к паузе перед каждой операцией записи или чтения. Значение 0 — нет задержки, значение 1 — 1 такт задержки, значение 7 — 7 тактов задержки. |
| 5 – 3   | WRITE_CYCLES      | Количество тактов системной частоты, за время которых происходит операция записи во внешнюю память. Значение 0 — 1 такт, значение 1 — 2 такта, значение 7 — 8 тактов.                                                              |
| 2-0     | READ_CYCLES       | Количество тактов системной частоты, за время которых происходит операция чтения из внешней памяти. Значение 0 — 1 такт, значение 1 — 2 такта, значение 7 — 8 тактов.                                                              |

## 3.4.1.2 Регистр EDAC\_CTRL

Инв. № дубл.

Подп. и дата

## Таблица 3.4.3 — Описание регистра EDAC\_CTRL

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                |
|--------|-------------------|--------------------------------------------------------------------------------------------------------|
| 31 – 4 | _                 |                                                                                                        |
| 3      | EDAC_WR_DIS_2     | Отключение записи битов EDAC для блока памяти 2.                                                       |
| 2      | EDAC_WR_DIS_1     | Отключение записи битов EDAC для блока памяти 1.                                                       |
| 1      | EDAC_En_2         | Включение режима исправления единичных и обнаружения неисправимых ошибок во внутренней памяти блока 2. |
| 0      | HIJAL HN I        | Включение режима исправления единичных и обнаружения неисправимых ошибок во внутренней памяти блока 1. |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 33   |

#### 3.4.1.3 Peructp INTMEM\_CERR\_CNT

#### Таблица 3.4.4 — Описание регистра INTMEM\_CERR\_CNT

| № бита | Наименование бита  | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|--------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | INTIMENT CERR CIVI | Счётчик исправленных единичных ошибок внутренней памяти блока 1.                        |

## 3.4.1.4 Perистр INTMEM\_FERR\_CNT

#### Таблица 3.4.5 — Описание регистра INTMEM\_FERR\_CNT

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 - 0 | INTMEM_FERR_CNT   | Счётчик неисправимых ошибок внутренней памяти блока 1.                                  |

#### 3.4.1.5 Регистр EXTMEM CERR CNT

#### Таблица 3.4.6 — Описание регистра EXTMEM\_CERR\_CNT

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | EXTMEM_CERR_CNT   | Счётчик исправленных единичных ошибок внешней памяти.                                   |

#### 3.4.1.6 Регистр EXTMEM FERR CNT

## Таблица 3.4.7 — Описание регистра EXTMEM\_FERR\_CNT

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | EXTMEM_FERR_CNT   | Счётчик неисправимых ошибок внешней памяти.                                             |

## 3.4.1.7 Peгистр SPACEWIRE\_CLK\_CTRL

Инв. № дубл.

Взам. инв. №

Подп. и дата

## Таблица 3.4.8 — Описание регистра SPACEWIRE\_CLK\_CTRL

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                |
|---------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 17 | -                 |                                                                                                                                                                                        |
| 16      | SPACEWIRE_CLK     | Выбор тактовой частоты физического уровня блоков SpaceWire.  0 — тактирование осуществляется с внешнего вывода SW_CLK (PORTH[4]).  1 — тактирование осуществляется системной частотой. |
| 15 – 0  | _                 |                                                                                                                                                                                        |

| F |     |      |          |       |      | Микросхема интегральная 5023BC016                    | Лис |
|---|-----|------|----------|-------|------|------------------------------------------------------|-----|
| ı | 1зм | Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 3.  |
|   |     |      |          |       |      |                                                      |     |

Копировал

#### 3.4.1.8 Perистр INTMEM2\_CERR\_CNT

#### Таблица 3.4.9 — Описание регистра INTMEM2\_CERR\_CNT

| № бита | Наименование бита  | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|--------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | I NIMEMIZ CERR CNI | Счётчик исправленных единичных ошибок внутренней памяти блока 2.                        |

## 3.4.1.9 Регистр INTMEM2\_FERR\_CNT

## Таблица 3.4.10 — Описание регистра INTMEM2\_FERR\_CNT

| № бита                  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|-------------------------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 INTMEM2_FERR_CNT |                   | Счётчик неисправимых ошибок внутренней памяти блока 2.                                  |

#### 3.4.1.10 Регистр PWR\_CTRL\_CLK

#### Таблица 3.4.11 — Описание регистра PWR\_CTRL\_CLK

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | PWR_CTRL_CLK      | Включение тактовых частот для различных блоков. (1 — вкл).                              |

#### 3.4.1.11 Регистр PWR CTRL RST

Инв. № дубл.

Взам. инв. №

Подп. и дата

## Таблица 3.4.12 — Описание регистра PWR\_CTRL\_RST

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | I PWR CIRL RSI    | Включение путем вывода из асинхронного сброса для различных блоков. (1 — вкл).          |

Расшифровка групп битовых полей для регистров PWR\_CTRL\_CLK и PWR\_CTRL\_RST представлена в таблице 3.4.13. Каждый бит соответствует включению одного модуля.

# Таблица 3.4.13 — Расшифровка групп битовых полей для регистров PWR\_CTRL\_CLK и PWR\_CTRL\_RST.

| Номер источника прерываний | Наименование источника<br>прерываний | Номер<br>источника<br>прерываний | Наименование источника<br>прерываний |
|----------------------------|--------------------------------------|----------------------------------|--------------------------------------|
| 1                          | 2                                    | 1                                | 2                                    |
| 0                          | SPI_1                                | 11                               | МКПД_4                               |
| 1                          | SPI_2                                | 12                               | Telemetry Encoder (TMTX)             |
| 2                          | UART_1                               | 13                               | TCRX                                 |
| 3                          | UART_2                               | 14                               | FPU                                  |

|     |        |          |       |      | Микросхема интегральная 5023ВС016 |    |
|-----|--------|----------|-------|------|-----------------------------------|----|
|     |        |          |       |      | Техническое описание              |    |
| Изі | л Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 35 |

Копировал

Формат А4

## Продолжение таблицы 3.4.13

| 1  | 2           | 1       | 2               |
|----|-------------|---------|-----------------|
| 4  | UART_3      | 20      | CAN_1           |
| 5  | UART_4      | 21      | CAN_2           |
| 6  | SpaceWire_1 | 22      | UART_5          |
| 7  | SpaceWire_2 | 23      | UART_6          |
| 8  | МКПД_1      | 24      | $I^2C$          |
| 9  | МКПД_2      | 25 - 31 | не используются |
| 10 | МКПД_3      |         |                 |

## 3.4.1.12 Регистр EXTMEM2\_CTRL (Chip Select 2)

# Таблица 3.4.14 — Описание регистра EXTMEM2\_CTRL

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                            |
|---------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 25 | _                 |                                                                                                                                                                                                                                    |
| 24      | EDAC_2            | для внешней памяти: 0 — выключен; 1 — включен                                                                                                                                                                                      |
| 23 - 17 | I                 |                                                                                                                                                                                                                                    |
| 16      | SIZE_2            | 0 — 8-битный режим; 1 — 16-битный режим                                                                                                                                                                                            |
| 15 – 9  | _                 |                                                                                                                                                                                                                                    |
| 8-6     | TURN_CYCLES_2     | величина задержки Chip Select (сигнал CEN) в тактах системной частоты, которая приводит к паузе перед каждой операцией записи или чтения. Значение 0 — нет задержки, значение 1 — 1 такт задержки,, значение 7 — 7 тактов задержки |
| 5 – 3   | WRITE_CYCLES_2    | количество системных тактов, за время которых происходит операция записи во внешнюю память. Значение $0-1$ такт, значение $1-2$ такта,, значение $7-8$ тактов                                                                      |
| 2-0     | READ_CYCLES_2     | количество системных тактов, за время которых происходит операция чтения из внешней памяти. Значение $0 - 1$ такт, значение $1 - 2$ такта,, значение $7 - 8$ тактов                                                                |

## 3.4.1.13 Регистр EXTMEM3\_CTRL (Chip Select 3)

## Таблица 3.4.15 — Описание регистра EXTMEM3\_CTRL

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-------------------|-----------------------------------------------------------------------------------------|
| 1       | 2                 | 3                                                                                       |
| 31 – 25 | -                 |                                                                                         |
| 24      | EDAC_3            | для внешней памяти: 0 — выключен; 1 — включен                                           |
| 23 – 17 | -                 |                                                                                         |
| 16      | SIZE_3            | 0 — 8-битный режим; 1 — 16-битный режим                                                 |
| 15 – 9  | _                 |                                                                                         |

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|--------|----------|-------|------|-----------------------------------|------|
|     |        |          |       |      | Техническое описание              |      |
| Изі | и Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 36   |
|     |        |          |       |      | 14                                |      |

Копировал

# Продолжение таблицы 3.4.15

| 1     | 2              | 3                                                                                                                                                                                                                                  |
|-------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8 – 6 | TURN_CYCLES_3  | величина задержки Chip Select (сигнал CEN) в тактах системной частоты, которая приводит к паузе перед каждой операцией записи или чтения. Значение 0 — нет задержки, значение 1 — 1 такт задержки,, значение 7 — 7 тактов задержки |
| 5-3   | WRITE_CYCLES_3 | количество системных тактов, за время которых происходит операция записи во внешнюю память. Значение $0 - 1$ такт, значение $1 - 2$ такта,, значение $7 - 8$ тактов                                                                |
| 2-0   | READ_CYCLES_3  | количество системных тактов, за время которых происходит операция чтения из внешней памяти. Значение $0 - 1$ такт, значение $1 - 2$ такта,, значение $7 - 8$ тактов                                                                |

#### 3.4.1.14 Регистр EXTMEM4\_CTRL (Chip Select 4)

# Таблица 3.4.16 — Описание регистра EXTMEM4\_CTRL

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                            |
|---------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 25 | -                 |                                                                                                                                                                                                                                    |
| 24      | EDAC_4            | для внешней памяти: 0 — выключен; 1 — включен                                                                                                                                                                                      |
| 23 - 17 | _                 |                                                                                                                                                                                                                                    |
| 16      | SIZE_4            | 0 — 8-битный режим; 1 — 16-битный режим                                                                                                                                                                                            |
| 15 – 9  | _                 |                                                                                                                                                                                                                                    |
| 8-6     | TURN_CYCLES_4     | величина задержки Chip Select (сигнал CEN) в тактах системной частоты, которая приводит к паузе перед каждой операцией записи или чтения. Значение 0 — нет задержки, значение 1 — 1 такт задержки,, значение 7 — 7 тактов задержки |
| 5-3     | WRITE_CYCLES_4    | количество системных тактов, за время которых происходит операция записи во внешнюю память. Значение $0-1$ такт, значение $1-2$ такта,, значение $7-8$ тактов                                                                      |
| 2-0     | READ_CYCLES_4     | количество системных тактов, за время которых происходит операция чтения из внешней памяти. Значение 0 — 1 такт, значение 1 — 2 такта,, значение 7 — 8 тактов                                                                      |

# 3.4.1.15 Peгистр CACHE\_HIGH\_ADDR

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.4.17 — Описание регистра CACHE\_HIGH\_ADDR

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                             |
|---------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 24 | ı                 |                                                                                                                                                                                                                                                                                                                     |
| 23 – 2  | CACHE_HIGH_ADDR   | задает старший адрес в памяти, используемый блоком кэширования. Кэшироваться будут данные, расположенные по адресам между 0 и указанным значением не включительно. При увеличении значения этого поля, происходит переинициализация блока кэширования, при уменьшении значения поля переинициализация не происходит |
| 1 - 0   | -                 |                                                                                                                                                                                                                                                                                                                     |

|     |      |          |       |      | Микросхема интег |
|-----|------|----------|-------|------|------------------|
|     |      |          |       |      | Техническо       |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 о    |

гральная 5023BC016 сое описание от 01.09.2017 г.

# 3.4.1.16 Регистры CACHE\_HIGH\_ADDR\_CS2, CACHE\_HIGH\_ADDR\_CS3, CACHE\_HIGH\_ADDR\_CS4

Регистры задают старший адрес области кэширования для Chip Select 2, Chip Select 3 и Chip Select 4. Структура регистров описана в таблицах 3.4.18, 3.4.19, 3.4.20.

Таблица 3.4.18 — Описание регистра CACHE\_HIGH\_ADDR\_CS2

|         | Наименование     | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                               |
|---------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| № бита  | бита             | назначения и принимаемых значений                                                                                                                                                                                                                                                                                   |
| 31 – 24 |                  |                                                                                                                                                                                                                                                                                                                     |
| 23 – 2  | CACHE_HIGH_ADDR2 | задаёт старший адрес в памяти, используемый блоком кэширования. Кэшироваться будут данные, расположенные по адресам между 0 и указанным значением не включительно. При увеличении значения этого поля, происходит переинициализация блока кэширования, при уменьшении значения поля переинициализация не происходит |
| 1-0     | _                | эна тения пози перенинальная пе пропеледит                                                                                                                                                                                                                                                                          |

#### Таблица 3.4.19 — Описание регистра CACHE HIGH ADDR\_CS3

| № бита  | Наименование     | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                               |
|---------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻онта  | бита             | назначения и принимаемых значений                                                                                                                                                                                                                                                                                   |
| 31 - 24 | _                |                                                                                                                                                                                                                                                                                                                     |
| 23 – 2  | CACHE_HIGH_ADDR3 | задаёт старший адрес в памяти, используемый блоком кэширования. Кэшироваться будут данные, расположенные по адресам между 0 и указанным значением не включительно. При увеличении значения этого поля, происходит переинициализация блока кэширования, при уменьшении значения поля переинициализация не происходит |
| 1 - 0   |                  |                                                                                                                                                                                                                                                                                                                     |

# Таблица 3.4.20 — Описание регистра CACHE\_HIGH\_ADDR\_CS4

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита  | Наименование     | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                               |
|---------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻онта  | бита             | назначения и принимаемых значений                                                                                                                                                                                                                                                                                   |
| 31 – 24 | _                |                                                                                                                                                                                                                                                                                                                     |
| 23 – 2  | CACHE_HIGH_ADDR4 | задаёт старший адрес в памяти, используемый блоком кэширования. Кэшироваться будут данные, расположенные по адресам между 0 и указанным значением не включительно. При увеличении значения этого поля, происходит переинициализация блока кэширования, при уменьшении значения поля переинициализация не происходит |
| 1 – 0   | _                |                                                                                                                                                                                                                                                                                                                     |

|      |      |          |       |      | Микросхема интегральная 5023ВС016 |
|------|------|----------|-------|------|-----------------------------------|
|      |      |          |       |      | Техническое описание              |
| Изм. | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |
|      |      |          |       |      |                                   |

38

#### 3.4.1.17 Регистры INTMEM\_SCR\_RNG\_ADDR, INTMEM2\_SCR\_RNG\_ADDR

Таблица 3.4.21 — Описание регистров INTMEM\_SCR\_RNG\_ADDR, INTMEM2\_SCR\_RNG\_ADDR

| № бита  | Наименование бита     | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-----------------------|-----------------------------------------------------------------------------------------|
| 31 – 16 | _                     |                                                                                         |
| 15 – 3  | INTIMEM_SCK_KING_ADDK | задаёт верхнюю границу работы скраббера внутри блока памяти                             |
| 2 - 0   | _                     |                                                                                         |

#### 3.4.1.18 Регистры INTMEM\_SCR\_PRD\_SCAN, INTMEM2\_SCR\_PRD\_SCAN

Таблица 3.4.22 — Описание регистров INTMEM\_SCR\_PRD\_SCAN, INTMEM2\_SCR\_PRD\_SCAN

| № бита | Наименование бита    | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | I INTENESCE PRO SCAN | период сканирования заданной области скраббером в тактах. 0 — сканирует постоянно.      |

#### 3.4.1.19 Регистры INTMEM SCR PRD STOP, INTMEM2 SCR PRD STOP

Таблица 3.4.23 — Описание регистров INTMEM\_SCR\_PRD\_STOP, INTMEM2\_SCR\_PRD\_STOP

| № бита | Hayraayanayyya fiyara      | Функциональное назначение бита, краткое описание |
|--------|----------------------------|--------------------------------------------------|
| л⊻оита | Наименование бита          | бита назначения и принимаемых значений           |
|        | 31 – 0 INTMEM SCR PRD STOP | период прерывания скраббером контроллера памяти, |
| 31 – 0 |                            | если в контроллере нет пустых транзакций к       |
|        |                            | соответствующему чипу памяти.                    |
|        |                            | 0 — прерывает сразу.                             |

#### 3.4.1.20 Регистр INTMEMS SCR MAIN

# Таблица 3.4.24 — Описание регистра INTMEMS\_SCR\_MAIN

| № бита  | Наименование бита        | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|--------------------------|-----------------------------------------------------------------------------------------|
| 31 – 12 | _                        |                                                                                         |
| 11 – 8  | scrub_blk2_cs_ready (RO) | отдельные биты готовности скрабберов по каждому Chip                                    |
| 7 – 4   | scrub_blk1_cs_ready (RO) | Select (четные и нечетные)                                                              |
| 3       | scrub_blk2_ready (RO)    | 1 — сообщает о готовности всех скрабберов для                                           |
| 2       | scrub_blk1_ready (RO)    | соответствующего блока памяти                                                           |
| 1       | scrub_blk2_en (RW)       | 1 — включает скраббер для соответствующего блока                                        |
| 0       | scrub_blk1_en (RW)       | памяти                                                                                  |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

39

При включении скраббера, первый цикл скраббер не сообщает об исправленных ошибках, считается циклом инициализации не тронутых ячеек памяти, по завершении процедуры выставляется бит в «1». Также после изменения пользователем верхней границы INTMEM[1,2]\_SCR\_RNG\_ADDR в сторону увеличения, производится цикл инициализации, во время которого бит ready равен «0».

3.4.1.21 Регистры CACHE\_CRC\_ERROR, EDAC\_INTMEM[1,2]\_SCR\_CERR, EDAC\_INTMEM[1,2]\_SCR\_FERR

Таблица 3.4.25 — Описание регистров CACHE\_CRC\_ERROR, EDAC\_INTMEM[1,2]\_SCR\_CERR, EDAC\_INTMEM[1,2]\_SCR\_FERR

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | Counter (RO)      | Счётчики ошибок                                                                         |

#### 3.4.1.22 Регистр DMA INTR FLAGS

Таблица 3.4.26 — Описание регистра DMA\_INTR\_FLAGS

| № бита | Наименование бита | •                              | е назначение бита, кра<br>нения и принимаемых |                                                                                             |
|--------|-------------------|--------------------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------|
| 31 – 8 | _                 |                                |                                               |                                                                                             |
| 7-0    | DMA_INTR_FLAGS    | [0] — SPI1 TX<br>[1] — SPI1 RX |                                               | отся записью 1.<br>[12] — UART5 TX<br>[13] — UART5 RX<br>[14] — UART6 TX<br>[15] — UART6 RX |

#### 3.4.1.23 Регистры ALT\_FUNCTION\_CTRL

Инв. № дубл.

Взам. инв. №

Подп. и дата

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

Для каждого вывода микросхемы (например, D[0], D[1]...D[15]) используются 2 бита для выбора номера альтернативной функции. Например, для настройки вывода микросхемы D[7] в режиме ALT\_FUNC\_2, необходимо записать «1» в 14 бит и «0» в 15 бит. В таблицах 3.4.27-3.4.35 приведено описание регистров ALT\_FUNCTION\_CTRL.

|    |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|----|--------|----------|-------|------|-----------------------------------|------|
|    |        |          |       |      | Техническое описание              |      |
| Из | м Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 40   |

Копировал

Формат А4

# Таблица 3.4.27 — Описание регистра ALT\_FUNCTION\_CTRL\_A

| Мо бито                             | Наименование бита | Функциональное назначение бита, краткое описание бита        |
|-------------------------------------|-------------------|--------------------------------------------------------------|
| № Оита                              | паименование оита | назначения и принимаемых значений                            |
| OTT                                 | BIT_FUNC          | Для бита N (N=0 15, номер вывода микросхемы) значение поля   |
| от<br>N · 2 до                      |                   | определяет используемую альтернативную функцию:              |
| $N \cdot 2 \neq 0$<br>$N \cdot 2+1$ |                   | 0 — функция 1; 2 — функция 3;                                |
| IN · 2+1                            |                   | <ol> <li>функция 2;</li> <li>3 — не используется.</li> </ol> |

# Таблица 3.4.28 — Описание регистра ALT\_ FUNCTION\_CTRL \_B

| № бита         | Наименование бита | Функциональное назначение бита, краткое описание бита                                                                                        |
|----------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
|                |                   | назначения и принимаемых значений                                                                                                            |
| от<br>N · 2 до | RIT FUNC          | Для бита N (N=0 15, номер вывода микросхемы) значение поля определяет используемую альтернативную функцию: $0$ — функция 1; $2$ — функция 3; |
| N · 2+1        |                   | <ol> <li>функция 2;</li> <li>не используется.</li> </ol>                                                                                     |

# Таблица 3.4.29 — Описание регистра ALT\_ FUNCTION\_CTRL \_C

| <b>№</b> бита             | Наименование бита | Функциональное назначение бита, краткое описание бита                                                                                                                                |
|---------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻онта                    | паименование оита | назначения и принимаемых значений                                                                                                                                                    |
| от<br>N · 2 до<br>N · 2+1 |                   | Для бита N (N=0 15, номер вывода микросхемы) значение поля определяет используемую альтернативную функцию: $0$ — функция 1; $2$ — функция 3; $1$ — функция 2; $3$ — не используется. |

# Таблица 3.4.30 — Описание регистра ALT\_ FUNCTION\_CTRL \_D

| № бита                    | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                      |
|---------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| от<br>N · 2 до<br>N · 2+1 | RIT FUNC          | Для бита N (N=0 15, номер вывода микросхемы) значение поля определяет используемую альтернативную функцию: 0 — функция 1; 2 — функция 3; 1 — функция 2; 3 — не используется. |

# Таблица 3.4.31 — Описание регистра ALT\_ FUNCTION\_CTRL \_E

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

| № бита                    | Наименование бита       | Функциональное назначение бита, краткое описание бита                                                                                        |
|---------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 312 OHTU                  | Transicio Balline On Ta | назначения и принимаемых значений                                                                                                            |
| от<br>N · 2 до<br>N · 2+1 |                         | Для бита N (N=0 15, номер вывода микросхемы) значение поля определяет используемую альтернативную функцию: $0$ — функция 1; $2$ — функция 3; |
| 11 211                    |                         | <ol> <li>функция 2;</li> <li>не используется.</li> </ol>                                                                                     |

# Таблица 3.4.32 — Описание регистра ALT\_ FUNCTION\_CTRL \_F

| Мо бита               | Наименование бита | Функциональное назначение бита, краткое описание бита                                                                                                                        |
|-----------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻опта                | паимснование оита | назначения и принимаемых значений                                                                                                                                            |
| от<br>N·2 до<br>N·2+1 | RIT FUNC          | Для бита N (N=0 15, номер вывода микросхемы) значение поля определяет используемую альтернативную функцию: 0 — функция 1; 2 — функция 3; 1 — функция 2; 3 — не используется. |

| Изм Лист         № докум.         Подп.         Дата         Микросхема интегральная 5023ВС016         Лист           Нам Лист         № докум.         Подп.         Дата         Версия 2.04 от 01.09.2017 г.         41 |     |        |          |       |      |                                   |      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|----------|-------|------|-----------------------------------|------|
| 2 004 0400047                                                                                                                                                                                                              |     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
| Изм Лист № докум. Подп. Дата Версия 2.04 om 01.09.2017 г. 41                                                                                                                                                               |     |        |          |       |      | Техническое описание              |      |
|                                                                                                                                                                                                                            | Изл | 1 Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 41   |

Копировал

Формат А4

# Таблица 3.4.33 — Описание регистра ALT\_FUNCTION\_CTRL \_G

| Мо бито                   | Наименование бита | Функциональное назначение бита, краткое описание бита      |
|---------------------------|-------------------|------------------------------------------------------------|
| л⊻онта                    | паименование оита | назначения и принимаемых значений                          |
| OTT                       | RIT FUNC          | Для бита N (N=0 15, номер вывода микросхемы) значение поля |
| от<br>N · 2 до<br>N · 2+1 |                   | определяет используемую альтернативную функцию:            |
|                           |                   | 0 — функция 1;                                             |
|                           |                   | 1 — функция 2; 3 — не используется.                        |

#### Таблица 3.4.34 — Описание регистра ALT\_ FUNCTION\_CTRL \_H

| № бита                | Наименование бита | Функциональное назначение бита, краткое описание бита                                                                                                                                |
|-----------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | паимснование оита | назначения и принимаемых значений                                                                                                                                                    |
| от<br>N·2 до<br>N·2+1 |                   | Для бита N (N=0 15, номер вывода микросхемы) значение поля определяет используемую альтернативную функцию: $0$ — функция 1; $2$ — функция 3; $1$ — функция 2; $3$ — не используется. |

# Таблица 3.4.35 — Описание регистра ALT\_ FUNCTION\_CTRL \_I

| № бита                | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                      |  |  |
|-----------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| от<br>N·2 до<br>N·2+1 |                   | Для бита N (N=0 15, номер вывода микросхемы) значение поля определяет используемую альтернативную функцию: 0 — функция 1; 2 — функция 3; 1 — функция 2; 3 — не используется. |  |  |

#### 3.4.1.24 Регистр ALIAS\_CTRL

#### Таблица 3.4.36 — Описание регистра ALIAS\_CTRL

| № бита | Наименование бита    | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                            |
|--------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 4 | _                    |                                                                                                                                                                                                                                                                                                                                                                                    |
| 3 – 2  | EXTMEM_ALIAS<br>(RW) | алиасинг для внешней памяти имеет значение только если INTMEM_ALIAS=0:  0 — алиасинг внешней памяти по Chip Select 1 (0x0800_0000 — 0x08FF_FFFF);  1 — алиасинг внешней памяти по Chip Select 2 (0x0900_0000 — 0x09FF_FFFF);  2 — алиасинг внешней памяти по Chip Select 3 (0x0A00_0000 — 0x0AFF_FFFF);  3 — алиасинг внешней памяти по Chip Select 4 (0x0B00_0000 — 0x0BFF_FFFF). |
| 1-0    | INTMEM_ALIAS<br>(RW) | алиасинг для внутренней памяти:  0 — нет алиасинга;  1 — алиасинг только блока 1 (0x2000_0000 — 0x2000_FFFF);  2 — алиасинг только блока 2 (0x2001_0000 — 0x2001_FFFF);  3 — алиасинг обоих блоков (0x2000_0000 — 0x2001_FFFF).                                                                                                                                                    |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. Nº подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

#### 3.4.1.25 Peгистр EDAC\_REACTION\_CTRL

#### Таблица 3.4.37 — Описание регистра EDAC\_REACTION\_CTRL

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-------------------|-----------------------------------------------------------------------------------------|
| 31 - 21 | _                 |                                                                                         |
| 20 – 18 | CACHE_CRC_ERR     |                                                                                         |
| 17 – 15 | INTMEM_SCR_FERR   | Реакции на соответствующие события:                                                     |
| 14 – 12 | INTMEM_SCR_CERR   | 0 — нет реакции;<br>1 — прерывание;<br>2 — исключение;                                  |
| 11 – 9  | INTMEM_FERR       |                                                                                         |
| 8 – 6   | INTMEM_CERR       | 3 — сброс всего, исключая дебаг;<br>4 — сброс всего, включая дебаг;                     |
| 5 – 3   | EXTMEM_FERR       | 6 – 7 — нет реакции.                                                                    |
| 2-0     | EXTMEM_CERR       |                                                                                         |

#### 3.4.1.26 Регистр CACHE\_MAIN

#### Таблица 3.4.38 — Описание регистра CACHE\_MAIN

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |  |
|--------|-------------------|-----------------------------------------------------------------------------------------|--|
| 31 – 4 | -                 |                                                                                         |  |
| 1      | CACHE_READY       | 1 — готов, включен; $0$ — нет.                                                          |  |
| 0      | CACHE_ENABLE      | 1 — запрос на включение, инициализацию; 0 — выключен.                                   |  |

#### 3.4.1.27 Peгистр SCRUBBER\_FERR\_ADDR

# Таблица 3.4.39 — Описание регистра SCRUBBER\_FERR\_ADDR

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                            |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 0 | ADDR              | Адрес в адресном пространстве внутренней памяти, по которому блоками скрабберов было обнаружена последняя ошибка памяти типа FERR. |

# 3.4.1.28 Регистр COMMON\_FERR\_ADDR

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.4.40 — Описание регистра COMMON\_FERR\_ADDR

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 0 | ADDR              | Адрес в адресном пространстве внутренней либо внешней памяти, по которому блоком исправления ошибок была обнаружена последняя ошибка памяти типа FERR. |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 43   |

Копировал

Таблица 3.4.41 — Описание регистра GLOBAL\_RESET

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 1 | _                 |                                                                                         |
| 0      | RESET             | Запись «1» инициирует сброс всех блоков микросхемы, включая отладчик.                   |

#### 3.5 Контроллер внутренней памяти

Микросхема содержит внутреннюю память объёмом 128 кБ, реализованную в виде двух блоков размером по 64 кБ. Доступ к внутренней памяти осуществляется с помощью контроллера памяти, расположенного на шине АНВ. Контроллер включает в себя встроенный блок обнаружения и исправления ошибок Error Detection and Correction (EDAC), который исправляет одну битовую ошибку и детектирует наличие двух битовых ошибок на 8 бит данных. Работа контроллера может осуществляться в двух режимах:

- без использования блока исправления ошибок;
- с включенным блоком исправления ошибок.

Включение и выключение блока исправления ошибок осуществляется в регистре общего назначения EDAC\_CTRL. Можно отдельно включить или отключить исправление ошибок для каждого из двух блоков внутренней памяти.

В случае возникновения одной битовой ошибки в байте данных контроллер производит автоматическое исправление ошибки при чтении. При этом инкрементируется счётчик ошибок INTMEM\_CERR\_CNT. В случае возникновения неисправимой ошибки инкрементируется счётчик INTMEM\_FERR\_CNT в области регистров общего назначения.

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

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

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

в. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г. Лист 44

Формат А4

Копировал

путём чтения и записи в специальные области памяти адресного пространства (п. 3.2).

В области внутренней памяти используется аппаратная система исправления и обнаружения ошибок, реализованная с помощью скрабберов. Настройки скрабберов осуществляются с помощью регистров в области регистров общего назначения. Для каждого блока памяти используется свой скраббер. Программно настраивается верхняя граница диапазона адресов, находящихся в области сканирования скраббера (регистры INTMEM SCR RNG ADDR), периодичность сканирования (регистры INTMEM SCR PRD SCAN) и период прерывания скраббером обращений контроллера внутренней (регистры памяти INTMEM SCR PRD STOP). Каждый из двух скрабберов может быть отдельно включен или выключен (регистр INTMEM SCR MAIN). Каждый скраббер с указанным периодом производит чтение данных из заданного диапазона и производит исправление данных в случае, если была обнаружена единичная битовая ошибка, либо сигнализирует о наличии неисправимой ошибки в случае повреждения более Ошибки, бит обнаруженные скрабберами, чем двух данных. подсчитываются в отдельных регистрах (регистры EDAC INTMEM SCR CERR, EDAC INTMEM SCR FERR).

Реакция на обнаружение неисправимых ошибок и исправление единичных ошибок также настраивается программно в регистре EDAC\_REACTION\_CONTROL, в котором отдельно настраивается реакция для блока EDAC и для скрабберов. В зависимости от настроек, в случае возникновения ошибки того или иного типа, может возникать прерывание, высокоприоритетное исключение (немаскируемое прерывание NMI), либо происходить асинхронный сброс микросхемы (включающий, либо не включающий в себя сброс отладчика).

#### 3.6 Контроллер внешней памяти

Инв. № дубл.

Взам. инв. №

Подп. и дата

Контроллер внешней памяти позволяет работать с четырьмя устройствами по интерфейсу асинхронной памяти, т.е. имеет четыре Chip Select. Это могут быть микросхемы памяти SRAM или FLASH, либо другие устройства имеющие такой интерфейс.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 45   |

Копировал

Формат А4

для 8-битного режима и 26 бит для 16-битного режима. Режим исправления ошибок позволяет исправить одну ошибку в одном байте данных или обнаружить двойную ошибку в одном байте данных. Настройка блока исправления ошибок производится в регистрах общего назначения EXTMEM CTRL (Chip Select 1-4), количество обнаруженных ошибок подсчитывается в регистрах EXTMEM CERR CNT и EXTMEM FERR CNT (общие счётчики для всех Chip Select); — длительность операции чтения от 1 до 8 тактов; длительность операции записи от 1 до 8 тактов. Если выбран режим записи Инв. № дубл. 1 такт, то сигнал WEN устанавливается в 0 на полтакта, адрес, сигналы управления и данные выставляются за полтакта минус 1 нс до сигнала WEN, а снимаются через 1 нс после снятия сигнала WEN. Для режимов записи от 2 до 8 тактов, сигнал WEN Взам. инв. № устанавливается соответственно от 1 до 7 тактов, адрес, сигналы управления и данные выставляются за полтакта до сигнала WEN, и снимаются через полтакта после снятия WEN; — задержка Chip Select от 0 до 7 тактов. Позволяет выставить задержку Подп. и дата сигнала Chip Select (CEN) на определённое число тактов относительно сигналов адреса, данных и прочих сигналов управления, что увеличивает транзакцию на нв. № подл. Техническое описание № докум. Подп. Дата

— 0x08000000 – 0x08FFFFF Chip Select 1;

— 0x09000000 – 0x09FFFFFF Chip Select 2;

— 0x0A000000 – 0x0AFFFFFF Chip Select 3;

— 0x0B000000 – 0x0BFFFFFF Chip Select 4.

разрядность данных памяти 8 или 16 бит;

Контроллер позволяет выбрать для каждого Chip Select:

Контроллер имеет шину адреса 24 бита, что позволяет адресовать 16 МБ по

Доступ к контроллеру в общем адресном пространстве осуществляется по

— включить или выключить режим исправления ошибок. Режим исправления

ошибок требует дополнительно увеличить шину данных внешней памяти до 13 бит

каждому Chip Select.

адресам:

Микросхема интегральная 5023ВС016 Лист 46 Версия 2.04 от 01.09.2017 г. Формат А4

соответствующее количество тактов. Применяется для подключения нестандартных устройств, например на ПЛИС.

Временные диаграммы записи данных при различных настройках

Временные диаграммы записи данных при различных настройках длительности приведены на рисунках 3.6.1, 3.6.2, 3.6.3.



Рисунок 3.6.1 — Транзакция записи при длительности операции записи в 1 такт и задержки Chip Select 0 тактов. Примечание — WE переключается в ноль по заднему фронту, в единицу — по переднему фронту сигнала CLK



Рисунок 3.6.2 — Транзакция записи при длительности операции записи в 2 такта и задержки Chip Select 0 тактов. Примечание — WE переключается по заднему фронту сигнала CLK

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подп.



Рисунок 3.6.3 — Транзакция записи при длительности операции записи в 2 такта и задержки Chip Select 1 такт. Примечание — WE переключается по заднему фронту сигнала CLK

Для памяти, расположенной по Chip Select 1, предусмотрены дополнительные выводы микросхемы, задающие значение битности шины данных и управляющие включением блока исправления ошибок EDAC, которые будут использоваться по умолчанию при включении микросхемы (п. 3.1.2). По умолчанию при включении микросхемы внешняя память по Chip Select 1 доступна в адресном пространстве по младшим адресам.

В контроллере имеется однопроходной (1-way) кэш размером 16 кБ. Размер линии кэша составляет 32 бита. Каждая линия кэша защищена 8-битным СКС. Если проверочная сумма не совпадает, то данные вычитываются из внешней памяти, и линия перезаписывается. Кэш работает только для 32-битных АНВ транзакций чтения. Если АНВ транзакция чтения 8 или 16 бит, и происходит промах в кэше, то данные вычитываются из внешней памяти и в кэш не записываются. Если происходит запись в область кэша, то соответствующая линия из кэша стирается, без проверки совпадает таг или нет. Для каждого Chip Select можно настроить диапазон адресов, которые подлежат кэшированию. Кэш включается через регистр управления (САСНЕ\_МАІN), и требуется время для инициализации. Это занимает 4096 тактов системной частоты.

# 3.7 Контроллер портов ввода-вывода

Контроллер портов ввода вывода GPIO предназначен для управления портом из 16 выводов в режиме GPIO.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Контроллер имеет следующие особенности:

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

#### 3.7.1 Генерация прерываний

Блок контроллера GPIO поддерживает программную генерацию прерывания по событиям ввода-вывода. Для настройки прерываний используются три регистра с раздельным доступом по установке и снятию значения. Таблица 3.7.1 демонстрирует события, по которым возникают прерывания в зависимости от значений регистров.

Таблица 3.7.1 — Прерывания контроллера GPIO

| Interrupt enable[n] | Interrupt polarity[n] | Interrupt type[n] | Событие                                      |
|---------------------|-----------------------|-------------------|----------------------------------------------|
| 0                   | _                     | _                 | Запрет прерывания                            |
| 1                   | 0                     | 0                 | Срабатывание по уровню — низкий уровень      |
| 1                   | 0                     | 1                 | Срабатывание по фронту — отрицательный фронт |
| 1                   | 1                     | 0                 | Срабатывание по уровню — высокий уровень     |
| 1                   | 1                     | 1                 | Срабатывание по фронту — положительный фронт |

При возникновении соответствующего события на входе выставляется соответствующий бит регистра INTSTATUS, а также выставляется прерывание в контроллере прерываний Nested Vectory Interrupt Controller (NVIC). Пользователь может сбросить прерывание записью 1 в соответствующий бит регистра INTCLEAR.

# 3.7.2 Доступ по маске

Инв. № дубл.

Взам. инв. №

Подп. и дата

Доступ к портам ввода-вывода по маске позволяет записывать единичные биты порта за одну операцию записи. При использовании маскированного доступа операция записи в 16-битный порт разбивается на две части:

- запись младших восьми бит порта;
- запись старших бит.

| Изм | Лист | № докум. | Подп. | Дата |  |
|-----|------|----------|-------|------|--|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Пист 49

Формат А4

Копировал

Для доступа по маске к младшим битам используется массив из 256 регистров MASKLOWBYTE, для доступа к старшим — MASKHIGHBYTE.

Например, если требуется одновременно выставить единицы на выводы [1:0] и нули на выводы [7:6], необходимо выполнить доступ по маске к младшим битам. Маска для записи равна соответственно 0xC3 и в соответствующий регистр MASKLOWBYTE должно быть записано значение изменяемых бит: MASKLOWBYTE[0xC3] = 0x03, как показано на рисунке 3.7.1.

Также производится старших восьми бит порта запись ввода Для адресное пространство регистров вывода. записи используется MASKHIGHBYTE (см. рисунок 3.7.2).



Тодп. и дата.

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

|   |     |      |          |           |       |                                                                               | управления 0х0000 | )    |
|---|-----|------|----------|-----------|-------|-------------------------------------------------------------------------------|-------------------|------|
| _ | 1   |      | Рисунок  | : 3.7.1 – | – Опє | рация записи младших бит порта в                                              | звода-вывода      |      |
|   |     |      |          |           |       |                                                                               |                   |      |
| _ | I   |      |          |           |       |                                                                               |                   |      |
|   |     |      |          |           |       |                                                                               |                   |      |
|   |     |      |          |           |       |                                                                               |                   |      |
|   |     |      |          | 1         |       | Muunooyono uumoono suuos E                                                    | 02200016          | Лист |
|   | Изм | Лист | № докум. | Подп.     | Дата  | Микросхема интегральная 5<br>Техническое описани<br>Версия 2.04 от 01.09.2017 | <i>ie</i>         | 50   |
|   |     |      |          |           | •     | Копировал                                                                     | Формат А4         |      |



Рисунок 3.7.2 — Операция записи старших бит порта ввода-вывода

#### 3.7.3 Регистры контроллера GPIO

#### 3.7.3.1 Адресное пространство

Назначение регистров контроллера GPIO приведено в таблице 3.7.2.

Таблица 3.7.2 — Регистры контроллера GPIO

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

| Сме-              | Название<br>регистра | Тип | Значение по сбросу | Описание                                                                                                                                                                                                                 |
|-------------------|----------------------|-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                 | 2                    | 3   | 4                  | 5                                                                                                                                                                                                                        |
| 0x0000            | DATA                 | RW  | 0x                 | Регистр данных порта [15:0] По чтению: Данные на входе порта По записи: Значение выхода порта. Чтение записанного значения возможно после задержки в 2 такта системной частоты из-за пересинхронизации входного значения |
| 0x0004            | DATAOUT              | RW  | 0x0000             | Значение выходного регистра данных [15:0] По чтению: Текущее значение регистра данных По записи: Запись значения регистра данных                                                                                         |
| 0x0008<br>-0x000c | Резерв               | _   | _                  |                                                                                                                                                                                                                          |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

51

| 1      | 2          | 3        | 4                                                                                                                                      | 5                                                                                                                                                                                                                                                    |
|--------|------------|----------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0010 | OUTENSET   | RW       | 0x0000                                                                                                                                 | Разрешение выхода порта [15:0] По записи: 1 — Разрешение выхода порта 0 — Выход в третьем состоянии По чтению: 0 — Вывод порта в состоянии вход 1 — Вывод порта в состоянии выход                                                                    |
| 0x0014 | OUTENCLR   | RW       | 0x0000                                                                                                                                 | Сброс ранее установленного значения разрешения порта [15:0]. По записи: 1 — Перевод порта в третье состояние 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Вывод порта в состоянии вход 1 — Вывод порта в состоянии выход |
| 0x0018 | ALTFUNCSET | RW       | Hopt A: 0xFFFF Hopt B: 0xFFFF Hopt C: 0xFFFF Hopt D: 0x007F Hopt E: 0x0008 Hopt F: 0x0000 Hopt G: 0x0000 Hopt H: 0x00E0 Hopt I: 0x0000 | По записи: 1 — Перевод вывода в режим альтернативной функции 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Вывод в режиме GPIO 1 — Вывод в режиме альтернативной функции                                                  |
| 0x001c | ALTFUNCCLR | RW       | Hopt A: 0xFFFF Hopt B: 0xFFFF Hopt C: 0xFFFF Hopt D: 0x007F Hopt E: 0x0008 Hopt F: 0x0000 Hopt G: 0x0000 Hopt H: 0x00E0 Hopt I: 0x0000 | По записи: 1 — Перевод вывода в режим GPIO 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Вывод в режиме GPIO 1 — Вывод в режиме альтернативной функции                                                                    |
| 0x0020 | INTENSET   | RW       | 0x0000                                                                                                                                 | Регистр разрешения прерываний [15:0]: По записи: 1 — Разрешение прерываний 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Прерывания запрещены 1 — Прерывания разрешены                                                    |
| 0x0024 | INTENCLR   | RW       | 0x0000                                                                                                                                 | Сброс регистра разрешения прерываний [15:0]: По записи: 1 — Запрещение прерываний 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Прерывания запрещены 1 — Прерывания разрешены                                             |
|        |            | <b>—</b> | Микро                                                                                                                                  | осхема интегральная 5023BC016<br>Техническое описание                                                                                                                                                                                                |

Взам. инв. № Инв. № дубл.

Инв. № подл. Подп. и дата

|   | <b>!</b> _ | Прод            | олжение 1                | паблиць         | ı 3.7.2 |        |                                                                                                                                                                                                                                                                                                             |    |
|---|------------|-----------------|--------------------------|-----------------|---------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|   |            | 1               |                          | 2               | 3       | 4      | 5                                                                                                                                                                                                                                                                                                           |    |
|   |            | 0x002           | 8 INTT                   | YPESET          | RW      | 0x0000 | Регистр типа прерываний [15:0] По записи: 1 — Установка типа прерывани 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Прерывания по уровню 1 — Прерывания по фронту                                                                                                               | ιй |
|   |            | 0x002           | c INTTY                  | /PECLR          | RW      | 0x0000 | Сброс регистра типа прерываний [15:0] По записи: 1 — Сброс регистра типа прерываний, 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Прерывания по уровню 1 — Прерывания по фронту                                                                                                 |    |
|   |            | 0x003           | ) INTP                   | OLSET           | RW      | 0x0000 | Регистр полярности события прерывания [1 По записи: 1 — Установка полярности события прерываний 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — Прерывания по низкому уровню или отрицательному фронту 1 — Прерывания по высокому уровню или положительному фронту                 |    |
|   |            | 0x003           | 4 INTP                   | OLCLR           | RW      | 0x0000 | Сброс регистра полярности события прерывания [15:0] По записи: 1 — Сброс регистра полярности события прерываний 0 — Не изменяется ранее установленное значение в регистре По чтению: 0 — прерывания по низкому уровню или отрицательному фронту 1 — Прерывания по высокому уровню или положительному фронту |    |
|   |            | 0x003           | × I                      | ΓATUS,<br>CLEAR | RW      | 0x0000 | Регистр сброса прерывания [15:0] По записи: 1 — Сброс соответствующего прерывания 0 — Не изменяется ранее установленное значение в регистре По чтению: [15:0] — Статус прерывания                                                                                                                           |    |
|   |            | 0x400-<br>0x7F0 | $I \cap I \cap I \cap I$ | OWBYTI          | E RW    | 0x     | Доступ по маске для младших восьми бит порта. Биты [9:2] адреса регистра использу как битовая маска. [15:8] — не используето [7:0] — совместно с битами адреса [9:2] используются как маска для битов данных порта ввода-вывода                                                                             | СЯ |
|   |            | 0x800-<br>0xBF0 |                          | IGHBYT          | E RW    | 0x     | Доступ по маске для старших восьми бит порта. Биты [9:2] адреса регистра использу как битовая маска. [15:8] — совместно с битами адреса [9:2] используются как маск для битов данных порта ввода-вывода. [7:0] — не используется.                                                                           |    |
|   | L          |                 |                          |                 |         |        |                                                                                                                                                                                                                                                                                                             |    |
| Ì |            |                 |                          |                 |         | Mu     | кросхема интегральная 5023ВС016                                                                                                                                                                                                                                                                             | Л  |
| Ų |            |                 |                          |                 |         |        |                                                                                                                                                                                                                                                                                                             |    |
| L |            |                 |                          |                 |         |        | Техническое описание<br>Версия 2.04 om 01.09.2017 г.                                                                                                                                                                                                                                                        |    |

3.8 Контроллер последовательного интерфейса В соответствии **ΓΟCT 52070** 

#### 3.8.1 Общие положения

Инв. № дубл.

Взам. инв. №

Подп. и дата

Контроллер реализует магистральный последовательный интерфейс центральным управлением в соответствии с ГОСТ Р 52070 (аналог стандарта MIL STD-1553B).

Структурная схема контроллера последовательного интерфейса представлена на рисунке 3.8.1.



Рисунок 3.8.1 — Структурная схема контроллера последовательного интерфейса по ГОСТ Р 52070

Предусмотрены следующие основные режимы функционирования

| I   | COCT | T P 52070: |         |        |                                                        |           |    |
|-----|------|------------|---------|--------|--------------------------------------------------------|-----------|----|
|     |      | — контр    | оллер ш | ины (1 | КШ);                                                   |           |    |
|     |      |            |         |        | Микросхема интегральная 5023BC<br>Техническое описание | 016       | Ли |
| Изм | Лист | № докум.   | Подп.   | Дата   | Версия 2.04 от 01.09.2017 г.                           |           | 5  |
|     |      |            |         |        | Копировал                                              | Формат А4 |    |

- оконечное устройство;
- режим монитора (М).

Контроллер последовательного интерфейса по ГОСТ Р 52070 состоит из следующих основных блоков:

- блок AMBA AHB Master (реализует прямой доступ к памяти (DMA));
- блок контроллера шины (реализует функции контроллера в режиме контроллера шины);
- блок оконечного устройства (реализует функции контроллера в режиме оконечного устройства;
- блок монитора шины (реализует функции контроллера в режиме Монитора (M);
- передатчик каналов A и B (энкодер магистрального последовательного интерфейса с центральным управлением);
- приёмники A, B, C и D (декодер магистрального последовательного интерфейса с центральным управлением); используются 2 декодера на один канал: на канал A декодеры A и B, а на канал B C и D; декодер A принимает сигнал как A+ положительная составляющая дифференциального сигнала и A- как отрицательная составляющая дифференциального сигнала; а декодер B наоборот, A+ как отрицательная составляющая дифференциального сигнала и A как положительная составляющая дифференциального сигнала; данная реализация позволяет принимать сигналы с любой полярностью, и если сигналы физически были перепутаны, то это не повлияет на работу устройства;
  - регистры управления контроллером (Registers).

# 3.8.2 Регистры контроллера

Распределение регистров контроллера последовательного интерфейса по ГОСТ Р 52070 приведено в таблице 3.8.1.

Назначения разрядов регистров контроллера шин приведены в таблицах 3.8.2 - 3.8.11.

Микросхема интегральная 5023BC016
Техническое описание
вм Лист № докум. Подп. Дата
Микросхема интегральная 5023BC016
Техническое описание
Версия 2.04 от 01.09.2017 г.

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

Назначения разрядов регистров монитора приведены в таблицах 3.8.16 - 3.8.19.

Назначения разрядов регистров монитора приведены в таблицах 3.8.20 - 3.8.23.

Таблица 3.8.1 — Распределение регистров контроллера последовательного интерфейса по ГОСТ Р 52070

| Смещение | Название регистра | Тип | Значение по сбросу | Описание                      |
|----------|-------------------|-----|--------------------|-------------------------------|
| 0x00     | BCONE0            | W/R | 0x00000000         | Первый регистр группы 1 КШ    |
| 0x04     | BCONE1            | W/R | 0x00000000         | Второй регистр группы 1 КШ    |
| 0x08     | BCONE2            | W/R | 0x00000000         | Третий регистр группы 1 КШ    |
| 0x0C     | BCONE3            | RO  | 0x00000000         | Четвертый регистр группы 1 КШ |
| 0x10     | BCONE4            | RO  | 0x00000000         | Пятый регистр группы 1 КШ     |
| 0x14     | BCTWO0            | W/R | 0x00000000         | Первый регистр группы 2 КШ    |
| 0x18     | BCTWO1            | W/R | 0x00000000         | Второй регистр группы 2 КШ    |
| 0x1C     | BCTWO2            | W/R | 0x00000000         | Третий регистр группы 2 КШ    |
| 0x20     | BCTWO3            | RO  | 0x00000000         | Четвертый регистр группы 2 КШ |
| 0x24     | BCTWO4            | RO  | 0x00000000         | Пятый регистр группы 2 КШ     |
| 0x28     | EP0               | W/R | 0x00000000         | Регистр настроек ОУ 0         |
| 0x2C     | EP1               | W/R | 0x00000008         | Регистр настроек ОУ 1         |
| 0x30     | EP2               | RO  | 0x00000000         | Регистр настроек ОУ 2         |
| 0x34     | EP3               | RO  | 0x00000000         | Регистр настроек ОУ 3         |
| 0x38     | SETTING0          | W/R | 0x00000000         | Регистр общих настроек 0      |
| 0x3C     | SETTING1          | W/R | 0x00000000         | Регистр общих настроек 1      |
| 0x40     | SETTING2          | W/R | 0x00000000         | Регистр общих настроек 2      |
| 0x44     | SETTING3          | W/R | 0x00000000         | Регистр общих настроек 3      |
| 0x48     | MONITOR0          | W/R | 0x00000000         | Регистр настроек монитора 0   |
| 0x4C     | MONITOR1          | W/R | 0x00000000         | Регистр настроек монитора 1   |
| 0x50     | MONITOR2          | W/R | 0x00000000         | Регистр настроек монитора 2   |
| 0x54     | MONITOR3          | RO  | 0x00000000         | Регистр настроек монитора 3   |
| 0x58     | INTERRUPT         | W/R | 0x00000000         | Регистр прерываний            |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

#### 3.8.3 Регистры контроллера шины

# **3.8.3.1 Регистр BCONE0**

# Таблица 3.8.2 — Описание регистра BCONE0

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                               |
|---------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 26 | _                 |                                                                                                                                                       |
| 25 – 21 | EP_ADDR0          | адрес ОУ, которому предназначается командное слово (КС).<br>Если адрес ОУ равен 111112, то КС является групповым                                      |
| 20 – 16 | SUB_ADDR0         | подадрес ОУ, которому предназначается КС. Значения подадреса равные 111112 или 000002 являются признаком режима управления и не должны использоваться |
| 15      | _                 |                                                                                                                                                       |
| 14 – 10 | NUM               | количество передаваемых или принимаемых слов данных(СД). Также в режиме управления содержит код команды                                               |
| 9 – 5   | EP_ADDR1          | используется только для транзакций форматов 3 и 8 — адрес ОУ для второго КС                                                                           |
| 4-0     | SUB_ADDR1         | используется только для транзакций форматов 3 и 8 — подадрес ОУ для второго КС                                                                        |

# **3.8.3.2 Регистр BCONE1**

# Таблица 3.8.3 — Описание регистра BCONE1

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений        |
|--------|-------------------|------------------------------------------------------------------------------------------------|
| 31 – 0 | I DMA ADDR        | содержит адрес первого байта области памяти с СД. Младшие два бита регистра всегда равны нулю. |

# **3.8.3.3 Регистр BCONE2**

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.8.4 — Описание регистра BCONE2

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                         |
|---------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 16 | COM_DATA          | только для транзакций форматов 6 и 10 — содержит СД, которое необходимо передать для этих транзакций                                                            |
| 15 – 9  | ı                 |                                                                                                                                                                 |
| 8       | ENA               | запуск начала транзакции; при записи 1 блок начинает транзакцию; при чтении 1 после записи 1, блок не начал данной транзакции                                   |
| 7 – 5   | ı                 |                                                                                                                                                                 |
| 4       | MANAGE_CODE       | задает формат признака режима управления в командном слове. При значении MANAGE_CODE = 0, признак режима управления будет иметь значение 000002, иначе — 111112 |
| 3-0     | TYPE_TRANS        | код транзакции                                                                                                                                                  |

|    |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|----|--------|----------|-------|------|-----------------------------------|------|
|    |        |          |       |      | Техническое описание              |      |
| Из | и Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 57   |

# **3.8.3.4 Регистр ВСОNЕ3**

# Таблица 3.8.5 — Описание регистра BCONE3

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 16 | REPLY             | Ответное слово (ОС) на КС транзакции                                                    |
| 15 – 0  | I RHPLY WINKIN    | только для транзакции формата 5; содержит СД, которое передается с ОС                   |

# **3.8.3.5 Регистр BCONE4**

#### Таблица 3.8.6 — Описание регистра BCONE4

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                  |
|---------|-------------------|--------------------------------------------------------------------------------------------------------------------------|
| 31 – 17 | _                 |                                                                                                                          |
| 16      | TIMEOUT           | бит тайм-аута; чтение 1 означает, что в транзакции произошёл таймаут (не пришло ОС или СД от ОУ, необходимо смотреть ОС) |
| 15 – 9  | _                 |                                                                                                                          |
| 8       | ERROR             | бит ошибки; чтение 1 означает, что в транзакции произошла ошибка (несоответствие бита четности принимаемых данных)       |
| 7 – 1   | _                 |                                                                                                                          |
| 0       | STATUS            | бит статуса; чтение 1 означает, что транзакция в процессе выполнения                                                     |

# 3.8.3.6 Регистр ВСТWО0

# Таблица 3.8.7 — Описание регистра BCTWO0

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                |
|---------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 26 | _                 |                                                                                                                                                        |
| 25 – 21 | EP_ADDR0          | адрес ОУ, которому предназначается командное слово; если адрес ОУ равен 111112, то поле является групповым КС                                          |
| 20 – 16 | SUB_ADDR0         | подадрес ОУ, которому предназначается КС. Значения подадреса равные 111112 или 000002 являются признаком режима управления и не должны использоваться. |
| 15      | -                 |                                                                                                                                                        |
| 14 – 10 | NUM               | количество передаваемых или принимаемых слов данных; в режиме управления поле также содержит код команды                                               |
| 9 – 5   | EP_ADDR1          | адрес ОУ для второго КС — используется только для транзакций форматов 3 и 8                                                                            |
| 4-0     | SUB_ADDR1         | подадрес ОУ для второго КС используется только для транзакций форматов 3 и 8                                                                           |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубп.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

# 3.8.3.7 Регистр BCTWO1

# Таблица 3.8.8 — Описание регистра BCTWO1

| № бита | Наименование | Функциональное назначение бита, краткое описание бита         |
|--------|--------------|---------------------------------------------------------------|
| л онта | бита         | назначения и принимаемых значений                             |
| 31 – 0 | DMA ADDR     | содержит адрес первого байта области памяти с СД. Младшие два |
| 31 – 0 | DMA_ADDR     | бита регистра всегда равны нулю                               |

# 3.8.3.8 Регистр BCTWO2

# Таблица 3.8.9 — Описание регистра BCTWO2

| № бита  | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                           |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N= OHIU | бита         | назначения и принимаемых значений                                                                                                                               |
| 31 – 16 | COM_DATA     | СД, которое нужно передать для этих транзакций; используется только для транзакций форматов 6 и 10                                                              |
| 15 – 19 | _            | 7. 1                                                                                                                                                            |
| 8       | ENA          | запуск начала транзакции; при записи 1 блок начинает транзакцию; при чтении 1 после записи 1 блок не начал данной транзакции                                    |
| 7 – 5   | _            |                                                                                                                                                                 |
| 4       |              | задает формат признака режима управления в командном слове. При значении MANAGE_CODE = 0, признак режима управления будет иметь значение 000002, иначе — 111112 |
| 3-0     | TYPE_TRANS   | код транзакции                                                                                                                                                  |

#### 3.8.3.9 Регистр ВСТWО3

# Таблица 3.8.10 — Описание регистра ВСТWО3

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |  |
|---------|----------------------|-----------------------------------------------------------------------------------------|--|
| 31 – 16 | REPLY                | ОС на КС транзакции                                                                     |  |
| 15 – 0  | REPLY_WORD           | только для транзакции формата 5; Содержит СД, которое передается с ОС                   |  |

#### 3.8.3.10 Регистр ВСТWО4

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.8.11 — Описание регистра BCTWO4

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                      |
|---------|----------------------|------------------------------------------------------------------------------------------------------------------------------|
| 31 – 17 | _                    | •                                                                                                                            |
| 16      | TIMEOUT              | бит тайм-аута; чтение 1 означает, что в транзакции произошел таймаут (не пришло ОС или СД от ОУ, необходимо использовать ОС) |
| 15 – 9  | _                    |                                                                                                                              |
| 8       | ERROR                | бит ошибки; чтение 1 означает, что в транзакции произошла ошибка (несоответствие бита четности принимаемых данных)           |
| 7 – 1   | _                    |                                                                                                                              |
| 0       | STATUS               | бит статуса; чтение 1 означает, что транзакция в процессе выполнения.                                                        |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              | 50   |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 59   |

#### 3.8.4 Регистры оконечного устройства

# 3.8.4.1 Регистр ЕР0

Таблица 3.8.12 — Описание регистра ЕРО

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                     |
|--------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 0 | DMA_EP            | общая память для всех подадресов. Содержит адрес первого байта области памяти ОУ. Чтобы получить доступ к определенному подадресу, нужно сместить указатель памяти на 64 · k, где k — подадрес. Младшие два бита регистра всегда равны нулю |

# 3.8.4.2 Регистр ЕР1

# Таблица 3.8.13 — Описание регистра ЕР1

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                     |
|---------|-------------------|-------------------------------------------------------------------------------------------------------------|
| 31 – 16 | RDATA             | содержит СД, которое необходимо передать для этих транзакций (используется только для транзакции формата 5) |
| 15 – 10 | _                 |                                                                                                             |
| 9       | ERROR             | признак «Ошибка в сообщении»                                                                                |
| 8       | SREQ              | признак «Запрос на обслуживание» в ОС ОУ                                                                    |
| 7 – 5   | RESERV            | резерв в ОС ОУ                                                                                              |
| 4       | RXGROUP           | признак «Принята групповая команда»                                                                         |
| 3       | BUSY              | признак «Абонент занят» в ОС ОУ, при сбросе равен «1»                                                       |
| 2       | FEP0              | признак «Неисправность абонента» в ОС ОУ                                                                    |
| 1       | MAN               | признак «Принято управление интерфейсом» в ОС ОУ                                                            |
| 0       | FEP1              | признак «Неисправность ОУ» в ОС ОУ                                                                          |

# 3.8.4.3 Регистр ЕР2

Инв. № дубл.

Взам. инв. №

4нв. № подл. Подп. и дата

# Таблица 3.8.14 — Описание регистра ЕР2

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений               |
|--------|-------------------|-------------------------------------------------------------------------------------------------------|
| 31 – 2 | _                 |                                                                                                       |
| 1      | HP ( ( )          | бит тайм-аута; чтение «1» означает, что в транзакции произошел таймаут (в транзакции недостаточно СД) |
| 0      | EP_COM_ERR        | чтение «1» означает, что в транзакции была ошибка                                                     |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 60   |

#### 3.8.4.4 Регистр ЕР3

#### Таблица 3.8.15 — Описание регистра ЕРЗ

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 16 | EP_COM            | КС принятое ОУ; используется в режиме ОУ                                                |
| 15 – 0  | EP_COM_DATA       | только для транзакций формата 6 и 10; содержит принятое СД этих транзакций.             |

#### 3.8.5 Общие регистры настроек

# 3.8.5.1 Регистр SETTING0

#### Таблица 3.8.16 — Описание регистра SETTING0

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                |
|---------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 24 |                      | значение это байта вычисляется по формуле SYSTEM_CLOCK — «1», где SYSTEM_CLOCK — это системная частота в МГц; значение должно быть установлено для вычисления задержек |
| 23 – 17 | _                    |                                                                                                                                                                        |
| 16      | CHANNEL              | 0 — рабочий канал для КШ А<br>1 — рабочий канал для КШ В                                                                                                               |
| 15 – 10 | _                    |                                                                                                                                                                        |
| 9 – 8   | MODE                 | задает режим работы блока: 00 — блок отключён; 01 — блок функционирует в режиме КШ; 10 — блок функционирует в режиме ОУ; 11 — блок функционирует в режиме М.           |
| 7 – 5   | _                    |                                                                                                                                                                        |
| 4-0     | EP_ADDR              | задает адрес ОУ                                                                                                                                                        |

# 3.8.5.2 Регистр SETTING1

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

#### Таблица 3.8.17 — Описание регистра SETTING1

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                          |
|---------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1       | 2                    | 3                                                                                                                                                                                                                                                                                                                                                |
| 31 - 28 | _                    |                                                                                                                                                                                                                                                                                                                                                  |
| 27 – 24 | TIME                 | задает время паузы между наступлением «тишины» на линии и следующим сообщением в микросекундах; необходимо для работы в режиме КШ и ОУ: в режиме КШ — время перед отправкой следующей транзакции, в режиме ОУ — время перед отправкой ОС; общая пауза вычисляется как сумма ТІМЕ + NOACTTІМЕ (см. регистр SETTING2) и должна быть не менее 4 мкс |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

# Продолжение таблицы 3.7.2

| 1       | 2     | 3                                                                                                                                                              |
|---------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 16 | RWAIT | задает время ожидания следующего слова в режиме работы КШ и ОУ в микросекундах; должно быть не менее 21 мкс; необходимо для определения тайм-аута в сообщениях |
| 15 – 8  | EDGE  | задает время запрещенного состояния дифференциального сигнала в тактах системной частоты блока; должно быть не менее 0,2 мкс                                   |
| 7 – 0   | _     | зарезервировано                                                                                                                                                |

# 3.8.5.3 Регистр SETTING2

# Таблица 3.8.18 — Описание регистра SETTING2

| № бита  | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                                                      |
|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ju Oniu | бита         | назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                          |
| 31 – 24 | BCWAITREPLY  | задает время ожидания ОС в режиме работы КШ в микросекундах; должно быть не менее 20 мкс                                                                                                                                                                                                                                                                   |
| 23 – 16 | NOACTTIME    | задает время, в течение которого декодер определяет, что на линии нет активности; задается в тактах системной частоты; время выбирается в зависимости от помех на линии и должно быть не менее 1,3 мкс; необходимо для работы декодера                                                                                                                     |
| 15 – 14 | _            |                                                                                                                                                                                                                                                                                                                                                            |
| 13 – 10 | DECDIS       | биты отключения декодеров;<br>10 бит — отключает декодер А;<br>11 бит — отключает декодер В;<br>12 бит — отключает декодер С;<br>13 бит — отключает декодер D.                                                                                                                                                                                             |
| 9       | INCWITH      | бит выбора появления сигнала разрешения передачи по последовательному интерфейсу. Если бит равен 0, то сигнал разрешения передачи появляется вместе с дифференциальным сигналом. Если бит равен 1, то сигнал разрешения передачи появляется на 0,5 мкс раньше дифференциального сигнала, и заканчивается позже на 0,5 мкс после дифференциального сигнала. |
| 8       | INVTX        | бит инвертирования дифференциального сигнала при передаче, т.е. D+ в D-, а D- в D+                                                                                                                                                                                                                                                                         |
| 7-0     | 500NS        | количество тактов системной частоты равное 0,5 мкс; необходимо для работы энкодера магистрального последовательного интерфейса с центральным управлением                                                                                                                                                                                                   |

# 3.8.5.4 Регистр SETTING3

Инв. № дубл.

# Таблица 3.8.19 — Описание регистра SETTING3

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-------------------|-----------------------------------------------------------------------------------------|
| 1       | 2                 | 3                                                                                       |
| 31 – 24 | //3000            | количество тактов системной частоты равное 2,25 мкс; необходимо для работы декодера     |
| 23 – 16 | 1/5005            | количество тактов системной частоты равное 1,75 мкс; необходимо для работы декодера     |

| L ' |       | ı        |       | ľ    |                                                      | '    |
|-----|-------|----------|-------|------|------------------------------------------------------|------|
|     |       |          |       |      | Микросхема интегральная 5023ВС016                    | Лист |
|     | _     |          |       |      | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 62   |
| Изм | Jlucm | № докум. | Подп. | Дата | Берсия 2.04 om 01.09.2017 e.                         | UZ.  |

#### Продолжение таблицы 3.8.19

| 1      | 2       | 3                                                                                   |
|--------|---------|-------------------------------------------------------------------------------------|
| 15 – 8 | 1500188 | количество тактов системной частоты равное 1,5 мкс; необходимо для работы декодера  |
| 7 – 0  | 1/30188 | количество тактов системной частоты равное 1,25 мкс; необходимо для работы декодера |

#### 3.8.6 Регистры монитора

#### 3.8.6.1 Регистр MONITOR0

#### Таблица 3.8.20 — Описание регистра MONITOR0

| N: | ҈ бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                  |
|----|--------|-------------------|----------------------------------------------------------------------------------------------------------|
| 3  | 31 – 0 |                   | адрес первого байта области памяти, выделенной для монитора. Младшие два бита регистра всегда равны нулю |

#### 3.8.6.2 Регистр MONITOR1

#### Таблица 3.8.21 — Описание регистра MONITOR1

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | MEMORY_SIZE       | количество 32 битных слов, выделенных для монитора                                      |

#### 3.8.6.3 Регистр MONITOR2

# Таблица 3.8.22 — Описание регистра MONITOR2

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | IHKESHOLD         | количество записанных слов, при котором срабатывает прерывание монитора                 |

# 3.8.6.4 Регистр MONITOR3

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

#### Таблица 3.8.23 — Описание регистра MONITOR3

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 - 0 | MONCOUNT          | количество записанных слов                                                              |

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

#### 3.8.7 Регистр INTERRUPT

Описание регистра SETTING2 указаны в таблице 3.8.24.

Таблица 3.8.24 — Описание регистра SETTING2

| № бита     |         | Функциональное назначение бита, краткое описание бита назначения и                                                         |
|------------|---------|----------------------------------------------------------------------------------------------------------------------------|
| • (= 01110 | бита    | принимаемых значений                                                                                                       |
| 31 - 4     | _       |                                                                                                                            |
| 3          |         | прерывание монитора; прерывание срабатывает, когда указатель записи достигает адреса в памяти DMA_MONITOR_ADDR + THRESHOLD |
| 2          | EP_INT1 | прерывание ОУ - прерывание окончания транзакции в ОУ                                                                       |
| 1          | EP_INT0 | прерывание ОУ - прерывание по приёму КС                                                                                    |
| 0          | BC_INT  | прерывание КШ - прерывание окончания транзакции в КШ                                                                       |

3.8.8 Описание функционирования контроллера последовательного интерфейса по ГОСТ Р 52070

3.8.8.1 Общие настройки контроллера последовательного интерфейса по ГОСТ Р 52070

Для работы контроллера последовательного интерфейса по ГОСТ Р 52070 в любом режиме необходимо произвести настройку блока. За настройку отвечают регистры SETTING0, SETTING1, SETTING2 и SETTING3.

В поле SYS\_CLK регистра SETTING0 нужно записать значение системной тактовой частоты в МГц. Для работы блока системная тактовая частота должна быть целым числом, кратна 2 и больше или равно 8 МГц.

В поле CHANNEL нужно записать «0», если интерфейс будет работать по каналу A, или «1», если интерфейс будет работать по каналу B.

В поле RWAIT задать время не менее 21 мкс.

В поле EDGE регистра SETTING1 следует задать максимальное время запрещенного состояния. Запрещённое состояние — это состояние дифференциального сигнала, когда обе линии находятся в логическом нуле. На рисунке 3.8.2 время запрещённого состояния показано как tRG. Данное время задается в тактах приёмной частоты.

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.



Рисунок 3.8.2 — Временная диаграмма дифференциального сигнала на входе приёмника

В регистре SETTING2 следует задать поле 500NS, т.к. это необходимо для работы энкодера интерфейса. Также в полях NOACTTIME и BCWAITREPLY записать рекомендуемые значения.

Также в регистре SETTING3 необходимо задать времена 1,25; 1,5; 1,75 и 2,25 мкс, которые необходимы для работы декодера.

#### 3.8.8.2 Принцип работы декодера

Тодп. и дата.

Инв. № дубл.

Взам. инв.

Подп. и дата

№ подл.

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



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



Рисунок 3.8.4 — Результирующий сигнал с первым битом данных равным логическому нулю

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |  |
|-----|------|----------|-------|------|-----------------------------------|--|
|     |      |          |       |      | Техническое описание              |  |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |  |
|     | "    |          |       |      |                                   |  |

Лист

65

На рисунке представлены дифференциальный сигнал, состоящий из A(+) и B(-) сигналов, и его результирующий сигнал C. Результирующий сигнал C формируется по следующему правилу

$$C = \begin{cases} 1, \text{если A} = "1" \text{ и B} = "0" \\ 0, \text{если A} = "0" \text{ и B} = "1" \end{cases}$$
 (1)

Следует сразу указать, что при запрещённом состоянии (A=1 и B=1 или A=0 и B=0) С не изменяется и сохраняет предыдущее значение.

Декодирование начинается с поиска синхросигнала командного слова — поиск положительной полуволны длительностью 1,5 мкс, и отрицательной полуволны — 1,5 мкс. Но, допуская искажение сигнала при распространении, положительная и отрицательная полуволны синхросигнала должны быть более 1,25 мкс.

При первом бите данных равном 0, отрицательная полуволна синхросигнала сливается с первым битом данных, и образует отрицательную полуволну длительностью в 2 мкс, как показано на рисунке 3.8.4. Поэтому при детектировании синхросигнала захватывается и первый бит данных. Именно из-за этого было выбрано время 2,25 мкс.

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

Если на первом бите данных фронт был 1 раз, то это был логический ноль, если 2 раза — логическая единица. Если 0 раз или больше 2-х, то это ошибка детектирования, и процесс детектирования сбрасывается.

На последующих битах данных детектирование зависит от предыдущего бита. Если предыдущий бит равен логическому нулю и по истечении времени был обнаружен только 1 фронт, то текущий бит равен логической единице; если было 2 фронта, то текущий бит равен логическому нулю. Если предыдущий бит равен логической единице и по истечении времени был обнаружен только 1 фронт, то

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Лист 66

Копировал

текущий бит равен логическому нулю; если было 2 фронта, то текущий бит равен логической единице.

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



Рисунок 3.8.5 — Возможные искажения сигналов при приёме и их результирующая

На рисунке Рисунок 3.8.5 представлены 3 случая искажений:

- сигнал на линии A имеет более пологий фронт, и после приёмопередатчика это видно, как сужение сигнала, в следствие чего появляется запрещённое состояние;
  - сигнал на линии В имеет более пологий фронт;
  - сигналы А и В имеют пологие фронты.

Инв. № дубл.

Взам. инв. №

Подп. и дата

Как видно из рисунка 3.8.5, выбранное время 2,25 и 1,25 мкс позволяет принимать в широком диапазоне искажений.

Далее на рисунке 3.8.6 представлены диаграммы сигналов по завершении приёма командного слова. Какое следующее слово: командное или слово данных,

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|--------|----------|-------|------|-----------------------------------|------|
|     |        |          |       |      | Техническое описание              |      |
| Изл | 1 Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 67   |
|     |        |          |       |      | 14                                |      |

Копировал

Формат А4



Рисунок 3.8.6 — Диаграммы сигналов по завершении приёма командного слова

Декодирование следующих слов происходит также, как и первое.

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

3.8.8.3 Функционирование контроллера последовательного интерфейса по ГОСТ Р 52070 в режиме КШ

Для работы блока в режиме КШ, необходимо:

- задать время паузы между сообщениями (см. регистр SETTING1);
- задать время ожидания следующего слова (см. регистр SETTING1);
- задать время ожидания ОС от ОУ (см. регистр SETTING2);
- задать времена 1,25; 1,5; 1,75 и 2,25 мкс (см. регистр SETTING3);
- задать времена 0,5 мкс (см. регистр SETTING2);
- задать поле NOACTTIME (см. регистр SETTING2);
- установить режим работы блока как КШ (см. регистр SETTING0).

 Микросхема интегральная 5023BC016
 Лист

 Техническое описание
 Техническое описание

 Изм Лист
 № докум.
 Подп.

 Дата
 Версия 2.04 от 01.09.2017 г.

Формат А4

нв. № подл. Подп. и дата

Инв. № дубл.

Взам. инв.

Для выполнения транзакций в режиме КШ в блоке существует две идентичные группы регистров (группа 1: BCONE0, BCONE1, BCONE2, BCONE3 и группа 2: BCTWO0, BCTWO1, BCTWO2, BCTWO3).

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

- проверить наличие признака захвата транзакции в блоке (см. поле ENA в регистре BCONE2 или BCTWO2) и статус транзакции (см. поле STATUS в регистре BCONE3 или BCTWO3). Если поле ENA равно «1», то транзакция находится в очереди транзакций;
- если поле ENA равно «0», но поле STATUS равно «1», то транзакция в настоящий момент передается. Если поле ENA равно «0» и поле STATUS равно «0», то в данную группу регистров разрешается записывать данные для новой транзакции;
  - определить канал работы блока (A или B), (см. регистр SETTING0);
  - задать адрес первого байта области памяти с СД (см. регистр BCONE1);
  - задать адрес ОУ, количество слов СД, формат транзакции и т.д.

3.8.8.3.1 Формирование транзакций для каждого формата в отдельности

Формат транзакции задается в TYPE\_TRANS регистре BCONE2 или BCTWO2. Для запуска транзакции любого формата необходимо записать 1 в ENA в регистре BCONE2 или BCTWO2. Таблица 3.8.25 содержит описание форматов.

Таблица 3.8.25 — Описание форматов

| Номер<br>формата | Описание                                                                                                                                                                                                                                                                      |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                | 2                                                                                                                                                                                                                                                                             |
| 1                | Передача данных от КШ к ОУ, TYPE_TRANS = 0. Установить адрес ОУ (поле EP_ADDR0), подадрес ОУ (поле SUB_ADDR0), количество слов СД (поле NUM) в регистре BCONE0 или BCTWO0                                                                                                     |
| 2                | Передача данных от ОУ к КШ, TYPE_TRANS = 1. Установить адрес ОУ (поле EP_ADDR0), подадрес ОУ (поле SUB_ADDR0), количество слов СД (поле NUM) в регистре BCONE0 или BCTWO0                                                                                                     |
| 3                | Передача данных от ОУ к ОУ, TYPE_TRANS = 2. Установить адрес приёмного ОУ (поле EP_ADDR0), подадрес приёмного ОУ (поле SUB_ADDR0), количество слов СД (поле NUM), адрес передающего ОУ (поле EP_ADDR1), подадрес передающего ОУ (поле SUB_ADDR1) в регистре BCONE0 или BCTWO0 |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

| . Подп. и дата |
|----------------|
|                |

| Продол | лжение таблицы 3.8.25                                                                                                                                                                                                                               |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | 2                                                                                                                                                                                                                                                   |
| 4      | Передача КУ, TYPE_TRANS = 3. Установить адрес ОУ (поле EP_ADDR0), код команды (поле NUM) в регистре BCONE0 или BCTWO0                                                                                                                               |
| 5      | Передача КУ и приём СД от ОУ, TYPE_TRANS = 4. Установить адрес ОУ (поле EP_ADDR0), код команды (поле NUM) в регистре BCONE0 или BCTWO0                                                                                                              |
| 6      | Передача КУ с СД к ОУ, TYPE_TRANS = 5. Установить адрес ОУ (поле EP_ADDR0), код команды (поле NUM) в регистре BCONE0 или BCTWO0, и задать СД (поле COM_DATA) в регистре BCONE2 или BCTWO2                                                           |
| 7      | Групповая передача данных от КШ к ОУ, TYPE_TRANS = 6. Установить подадрес ОУ (поле SUB_ADDR0), количество слов СД (поле NUM) в регистре BCONE0 или BCTWO0                                                                                           |
| 8      | Групповая передача данных от ОУ к ОУ, TYPE_TRANS = 7. Установить подадрес приёмного ОУ (поле SUB_ADDR0), количество слов СД (поле NUM), адрес передающего ОУ (поле EP_ADDR1), подадрес передающего ОУ (поле SUB_ADDR1) в регистре BCONE0 или BCTWO0 |
| 9      | Групповая передача КУ, TYPE_TRANS = 8. Установить код команды (поле NUM) в регистре BCONE0 или BCTWO0                                                                                                                                               |
| 10     | Групповая передача КУ с СД к ОУ, TYPE_TRANS = 9. Установить код команды (поле NUM) в регистре BCONE0 или BCTWO0, и задать СД (поле COM_DATA) в регистре BCONE2 или BCTWO2                                                                           |

Для транзакций формата 1 – 6 КШ принимает ОС от ОУ. ОС хранится в REPLY в регистре BCONE3 или BCTWO3. Также для транзакций этих форматов есть 2 бита состояний: ERROR и TIMEOUT в регистре BCONE4 или BCTWO4. Признак ERROR означает, что в транзакции произошла ошибка чётности принятых данных в КШ. Признак TIMEOUT означает, что произошел таймаут, КШ не принял ОС или принял некорректное количество СД.

Для транзакций формата 5 КШ принимает ОС с СД. СД находится в поле REPLY\_WORD в регистре BCONE3 или BCTWO3.

Для транзакций формата 3 КШ принимает ОС от передающего ОУ.

3.8.8.4 Функционирование контроллера последовательного интерфейса по ГОСТ Р 52070 в режиме ОУ

Для работы блока в режиме ОУ, необходимо:

- задать время паузы между сообщениями (см. регистр SETTING1);
- задать время ожидания следующего слова (см. регистр SETTING1);
- задать время ожидания ОС от ОУ (см. регистр SETTING2);
- задать времена 1,25; 1,5; 1,75 и 2,25 мкс (см. регистр SETTING3);

|    |          |       |      | Микросхема интегральная 5023ВС016 |
|----|----------|-------|------|-----------------------------------|
|    |          |       |      | Техническое описание              |
| ст | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

70

Техническое описание

Версия 2.04 от 01.09.2017 г.

71

Формат А4

— задать времена 0,5 мкс (см. регистр SETTING2);

— задать настройки для битов OC (см. регистр EP1);

— ERROR (ошибки чётности в принятых данных);

— задать адрес ОУ (см. регистр SETTING0);

Регистр содержит КС и поля состояния:

— TIMEOUT (произошёл тайм-аут).

регистре ЕР2.

Лист

№ докум.

Подп.

Дата

Копировал

— задать поле NOACTTIME (см. регистр SETTING2);

— задать адрес первого байта области памяти с СД (см. регистр ЕРО);

— установить режим работы блока как ОУ (см. регистр SETTINGO).

Для транзакции формата 5 принятое СД хранится в регистре ЕР1.

Принятые КС, которые предназначены для данного ОУ, хранятся в

ОУ функционирует одновременно в каналах А и В, вследствие чего

Таблица 3.8.26 — Формат записи принятых данных

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 19 | _                    |                                                                                         |
| 18      |                      | с какого канала был принято слово;<br>0 — с канала A;<br>1 — с канала B;                |
| 17      | 1 1 1/1/11/11/1/11   | бит принадлежности слова к командному слову или слову данных; 0 — командное, 1 — данные |
| 16      | DATAERR              | бит ошибки принятых данных                                                              |
| 15 – 0  | DATA                 | принятые данные                                                                         |

Монитор принимает независимо по обоим каналам.

#### 3.8.8.6 Инженерные регистры

Инженерные регистры находятся по адресу со смещением 0х100.

Включение режима происходит по записи в регистр по адресу 0x100 слова 0xDEADBEEE.

В регистре по адресу 0х104 задается режим работы. Формат записи принятых данных показан в таблице 3.8.27.

Таблица 3.8.27 — Формат записи принятых данных

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита Наименован<br>бита |       | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                          |  |
|---------------------------|-------|------------------------------------------------------------------------------------------------------------------|--|
| 31 - 7                    | _     |                                                                                                                  |  |
| 6-5                       | MODE  | задает в какое слово вносить ошибку — командное слово или слово данных; 01 — командное слово; 10 — слово данных; |  |
| 4-0                       | COUNT | задает порядковый номер слова, в которое нужно внести ошибку                                                     |  |

3.9 Контроллер интерфейса SpaceWire

3.9.1 Описание функционирования контроллера интерфейса SpaceWire

Структурная схема контроллера интерфейса SpaceWire представлена на рисунке 3.9.1.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 72   |

Копировал

Формат А4

- Link-контролера;
- контроллера DMA;
- блока регистров;
- блок памяти First in/First out (FIFO) принимаемых данных RX FIFO;
- блок памяти TX FIFO передаваемых данных;
- приёмника SpaceWire;
- передатчика SpaceWire;
- блока пересинхронизации.

## 3.9.1.1 Link-контроллер

Инв. № дубл.

Взам. инв. №

Подп. и дата

. № подл.

Link-контроллер осуществляет соединение по каналу SpaceWire. Управление Link-контроллером производится битами регистра CONTROL.

При установке бита linkstart в состояние «1» контроллер осуществляет соединение с удаленным интерфейсом. При возникновении ошибки в случае ошибки чётности или разъединении линии контроллер сбрасывается и снова устанавливает соединение, если бит linkstart все еще находится в состоянии «1».

Если бит linkstart равен «0», а бит autostart — «1», то контроллер ожидает начала передачи с другого конца линии и далее выдает сигнал подтверждения.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023ВС016 Техническое описание Версия 2.04 от 01.09.2017 г.

Если бит linkdisable paвeн «1», текущее соединение закрывается, и новое не устанавливается вне зависимости от состояния бита linkstart.

Соединение не может быть установлено, если память RXFIFO заполнена.

Регистр Status отражает текущее состояние Link-контроллера. Если соединение обрывается из-за ошибки, то выставляется соответствующий бит в данном регистре. Для сброса бита ошибки необходимо записать «1» в регистр Status.

#### 3.9.1.2 Приём данных

Принимаемые данные передаются по шине АНВ в ОЗУ СБИС СРU. Блок RXFIFO используется для хранения принимаемых данных, пока блок контроллера DMA не будет готов для передачи данных по шине АНВ. Передача по шине SpaceWire будет производиться до заполнения памяти RXFIFO. В случае возникновения ошибки в середине пакета выставляется бит ошибки в блоке RXFIFO.

Для корректного приёма данных частота системного тактового сигнала должна быть не менее частоты SW CLK /4.

#### 3.9.1.3 Передача данных

Передача данных из ОЗУ СБИС СРU осуществляется по шине АНВ. Для пересинхронизации данных с тактовым сигналом SpaceWire используется блок ТХГІГО. В случае возникновения ошибки соединения при передаче данных выставляется бит ЕОР.

Передача данных осуществляется по внешнему тактовому сигналу SW\_CLK. Скорость передачи задаётся с помощью делителя, коэффициент деления которого записывается в регистр TXScaler. После сброса значение данного регистра равно 10. Инициализация соединения всегда осуществляется на частоте SW\_CLK /10.

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г. Лист

74

#### 3.9.2 Контроллер BUS MASTER

#### 3.9.2.1 Описание контроллера BUS MASTER

Приём и передача пакетов данных осуществляется по шине АНВ. При этом контроллер SpaceWire является ведущим устройством. Для приёма и передачи данных используется два отдельных канала DMA.

Каждый канал управляется с помощью собственной таблицы дескрипторов.

Таблица дескрипторов расположена в ОЗУ СБИС СРU. Адрес начала таблицы дескрипторов для каждого канала задаётся в соответствующих регистрах контроллера.

Размер таблицы дескрипторов равен 32, при этом размер каждого дескриптора равен 8 байтам. Адрес первого дескриптора в памяти должен быть выровнен относительно 256 байт.

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

Если контроллер DMA считывает дескриптор без активированного бита EN, он завершает обработку дескрипторов в канале. Пользователь может запустить канал снова установкой нового дескриптора.

## 3.9.2.2 Формат дескриптора

Дескриптор состоит из двух 32-битных слов. В первом содержится размер передаваемых по DMA данных и набор флагов. Второе слово содержит адрес в памяти передаваемых данных. Этот адрес должен быть выровнен относительно 4 байт. Описание бит дескриптора приведено в таблице 3.9.1.

нв. № подл. Иодп. и дата Взам. инв. № Инв. № дубл.

Лист

№ докум.

Микросхема интегральная 5023BC016
Техническое описание
Подп. Дата Версия 2.04 от 01.09.2017 г.

Лист

75

| № бита | Описание                                                                                                                                                                                         |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 – 0 | (RX, enable) — количество байт, которые необходимо принять (RX, completed) — количество принятых байт (TX, enable) — количество байт, которые необходимо передать (TX, completed) — неопределено |
| 16     | EN: установлено в «1», когда дескриптор разрешено пользователем, но еще не завершен контроллером                                                                                                 |
| 17     | WR: прерывание списка дескрипторов. При чтении данного бита контроллер начинает выборку данных с начала таблицы                                                                                  |
| 18     | IE: разрешение прерывания и выставления статуса по завершении дескриптора                                                                                                                        |
| 19     | DONE: выставляется в «1», когда дескриптор завершен                                                                                                                                              |
| 20     | (RX, completed) EOP: выставляется в «1», если получен признак EOP в конце пакета (TX, enable) EOP: выставляется в «1», если необходимо отправить EOP в конце пакета                              |
| 21     | (RX, completed) EEP: выставляется в «1», если получен признак EEP в конце пакета (TX, enable) EEP: выставляется в «1», если необходимо отправить признак EEP в конце пакета                      |

#### 3.9.3 Регистры контроллера интерфейса SpaceWire

#### 3.9.3.1 Состав регистров контроллера интерфейса SpaceWire

Адреса и функциональные назначения регистров контроллера интерфейса SpaceWire приведены в таблице 3.9.2.

Назначения разрядов регистров контроллера интерфейса SpaceWire приведены в таблицах 3.9.3 – 3.9.11.

Таблица 3.9.2 — Адреса и функциональные назначения регистров контроллера интерфейса SpaceWire

| Смеще- | Название регистра | Тип | Значение по сбросу | Описание                                           |
|--------|-------------------|-----|--------------------|----------------------------------------------------|
| 1      | 2                 | 3   | 4                  | 5                                                  |
| 0x00   | CONTROL           | RW  | 0x05000000         | Регистр управления                                 |
| 0x04   | STATUS            | RO  | 0x00004000         | Регистр статуса                                    |
| 0x08   | TXSCALER          | RW  | 0x00000009         | Регистр делителя клоков                            |
| 0x0C   | TIMECODE          | RW  | 0x00000000         | Регистр временных меток                            |
| 0x10   | RXDESCPTR         | RW  | 0x00000000         | Регистр указателя на таблицу дескрипторов приёма   |
| 0x14   | TXDESCPTR         | RW  | 0x00000000         | Регистр указателя на таблицу дескрипторов передачи |
| 0x18   | TXSCALERLINK      | RW  | 0x00000009         | Регистр делителя тактовых сигналов во время Link   |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

76

Продолжение таблицы 3.9.2

| 1    | 2              | 3  | 4          | 5                                                                                |
|------|----------------|----|------------|----------------------------------------------------------------------------------|
| 0x1C | RESETTIME      | RW | 0x00000280 | Регистр задания времени ожидания при Link (6,4 мкс) в тактах системной частоты   |
| 0x20 | DISCONNECTTIME | RW | 0x00000055 | Регистр задания времени таймаута приёмника (850 нс) (в тактах системной частоты) |
| 0x24 | ENDIANNESS     | RW | 0x00000000 | Регистр задания эндианности на приёме и на передаче                              |

# 3.9.3.2 Регистр CONTROL

# Таблица 3.9.3 — Описание регистра CONTROL

| № бита  | Наименование бита       | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-------------------------|-----------------------------------------------------------------------------------------|
| 31 – 28 | _                       | _                                                                                       |
| 27 – 24 | DESCTABLESIZE           | Размер таблицы дескрипторов, доступен только на чтение                                  |
| 23 - 24 | _                       |                                                                                         |
| 13      | INT_EN_RX_PACKET        | Разрешение прерывания при приёме пакета по завершению работы ТХ дескриптора             |
| 12      | INT_EN_TX_DSCR_COMPLETE | Разрешение прерывания по завершению ТХ дескриптора при IE = «1»                         |
| 11      | INT_EN_RX_DSCR_COMPLETE | Разрешение прерывания по завершению RX дескриптора при IE = «1»                         |
| 10      | INT_EN_TIME_CODE        | Разрешение прерывания при приёме временных меток                                        |
| 9       | INT_EN_LINK_UP_DOWN     | Разрешение прерывания при установке соединения                                          |
| 8       | CAN CEL_TX_DMA          | Запись «1» прерывает работу TXDMA и RXDMA                                               |
| 7       | RESTART_TX_DMA          | Запись «1» запускает ТХDMA                                                              |
| 6       | RESTART_RX_DMA          | Запись «1» запускает RXDMA                                                              |
| 5       | ALLOW_TIMECODE_TX       | Разрешение передачи временных меток                                                     |
| 4       | LINK_DISABLE            | Linkdisable; запись «1» запрещает работу Link контроллера.                              |
| 3       | LINK_AUTOSTART          | Autostart; Запись «1» разрешает автоматическую установку соединения в случае потери.    |
| 2       | LINK_START              | Linkstart; запись «1» разрешает установку соединения.                                   |
| 1       | RESET_DMA               | Запись «1» сбрасывает контроллер DMA                                                    |
| 0       | RESET_AMBA              | Запись «1» сбрасывает контроллер                                                        |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

77

# Таблица 3.9.4 — Описание регистра STATUS

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                    |
|--------|-------------------|------------------------------------------------------------------------------------------------------------|
| 14     | RXFIFO_EMPTY      | (только чтение) — память RXFIFO не содержит данных, и последний пакет был отправлен по RXDMA               |
| 13     | PACKET_RX         | Получен пакет. Для сброса бита необходимо записать «1»                                                     |
| 12     | TX_COMPLETE       | ТХ дескриптор завершен при $IE = «1»$ . Для сброса бита необходимо записать «1»                            |
| 11     | RX_COMPLETE       | RX дескриптор завершен при $IE = «1»$ . Для сброса бита необходимо записать «1»                            |
| 10     | RECEIVED_TIMECODE | Получен пакет с временной меткой. Для сброса бита необходимо записать «1»                                  |
| 9      |                   |                                                                                                            |
| 8      | AHB_ERR           | Ошибка шины АНВ. Для сброса необходимо сбросить контроллер DMA.                                            |
| 7      | TX_DMA_RUNNING    | TXDMA запущен (только чтение).                                                                             |
| 6      | RX_DMA_RUNNING    | RXDMA запущен (только чтение).                                                                             |
| 5      | CREDIT_ERR        | Ошибка credit. Для сброса бита необходимо записать «1»                                                     |
| 4      | ESCAPE_ERR        | Ошибка escape. Для сброса бита необходимо записать «1»                                                     |
| 3      | PARITY_ERR        | Ошибка четности. Для сброса бита необходимо записать «1»                                                   |
| 2      | DISCONNECT_ERR    | Ошибка соединения. Для сброса бита необходимо записать «1»                                                 |
| 1-0    | LINK_STATUS       | Статус Link контроллера: 0 = выключен, 1 = старт, 2 = соединение установлено, 3 = запущен (только чтение). |

## 3.9.3.4 Регистр TXSCALER

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.9.5 — Описание регистра TXSCALER

| № бита | Наименование | Функциональное назначение бита, краткое описание бита |
|--------|--------------|-------------------------------------------------------|
|        | бита         | назначения и принимаемых значений                     |
| 7 – 0  | DIVISOR      | Делитель частоты тактового сигнала передатчика — 1    |

# 3.9.3.5 Регистр RXDESCPTR

# Таблица 3.9.6 — Описание регистра RXDESCPTR

| № бита          | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|-----------------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 7          |                      | Адрес начала таблицы дескрипторов                                                       |
| 8-3             |                      | Номер дескриптора                                                                       |
| $\frac{3}{2-0}$ |                      | Зарезервировано. Должны быть нулевые значения                                           |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 78   |

Копировал

Формат А4

# Таблица 3.9.7 — Описание регистра TXDESCPTR

| № бита | Наименование | Функциональное назначение бита, краткое описание бита |
|--------|--------------|-------------------------------------------------------|
| № Оита | бита         | назначения и принимаемых значений                     |
| 31 – 8 | DSCR_ADDR    | Адрес начала таблицы дескрипторов                     |
| 7 – 3  | DSCR_NUM     | Номер дескриптора                                     |
| 2-0    |              | Зарезервировано. Должны быть нулевые значения         |

#### 3.9.3.7 Регистр TXSCALERLINK

## Таблица 3.9.8 — Описание регистра TXSCALERLINK

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 8 |                      | Зарезервировано. Читаются нулевые значения                                              |
| 7 – 0  | DIVISOR              | TxScalerLink                                                                            |

## 3.9.3.8 Регистр RESETTIME

## Таблица 3.9.9 — Описание регистра RESETTIME

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 11 |                      | Зарезервировано. Читаются нулевые значения                                              |
| 10-0    | RESET_TIME           | ResetTime                                                                               |

## 3.9.3.9 Регистр DISCONNECTTIME

# Таблица 3.9.10 — Описание регистра DISCONNECTTIME

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 8 |                   | Зарезервировано. Читаются нулевые значения                                              |
| 7 – 0  | DISCONNECT_TIME   | DisconnectTime                                                                          |

## 3.9.3.10 Peгистр ENDIANNESS

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.9.11 — Описание регистра ENDIANNESS

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 2 |                      | Зарезервировано. Читаются нулевые значения                                              |
| 1      | RX_ENDIAN            | RxEndianness. Значение 0 — little endian, 1 — big endian                                |
| 0      | TX_ENDIAN            | TxEndianness. Значение 0 — little endian, 1 — big endian                                |

|     |      |          |       |      | Микросхема интегральная 5023ВС016                    | Лист |
|-----|------|----------|-------|------|------------------------------------------------------|------|
| Изм | Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 79   |

Копировал

Формат А4

- 3.10 Контроллер прямого доступа к памяти
- 3.10.1 Общее описание
- 3.10.1.1 Введение

Контроллер ПДП используется для автоматической передачи данных между интерфейсами SPI и UART и интерфейсами памяти (внутренней либо внешней), либо из памяти в память.

Контроллер ПДП имеет 24 канала, часть из которых жестко привязана к определённым блокам периферии (остальные каналы могут быть использованы только для передачи данных из одной области памяти в другую).

Соответствие каналов контроллера ПДП периферийным блокам приведено в таблице 3.10.1.

Таблица 3.10.1 — Перечень каналов контроллера ПДП

| Номера канала | Описание                                  |
|---------------|-------------------------------------------|
| 0             | Интерфейс SPI 1 TX                        |
| 1             | Интерфейс SPI 1 RX                        |
| 2             | Интерфейс SPI 2 TX                        |
| 3             | Интерфейс SPI 2 RX                        |
| 4             | Интерфейс UART 1 TX                       |
| 5             | Интерфейс UART 1 RX                       |
| 6             | Интерфейс UART 2 TX                       |
| 7             | Интерфейс UART 2 RX                       |
| 8             | Интерфейс UART 3 TX                       |
| 9             | Интерфейс UART 3 RX                       |
| 10            | Интерфейс UART 4 TX                       |
| 11            | Интерфейс UART 4 RX                       |
| 12            | Интерфейс UART 5 TX                       |
| 13            | Интерфейс UART 5 RX                       |
| 14            | Интерфейс UART 6 TX                       |
| 15            | Интерфейс UART 6 RX                       |
| 16 – 23       | Каналы, не привязанные к блокам периферии |

3.10.1.2 Основные характеристики контроллера DMA

Основные характеристики контроллера DMA:

a) 24 канала DMA;

Инв. № дубл.

Взам. инв. №

Подп. и дата

| ,,, |        |          |       |      |                                   |      |
|-----|--------|----------|-------|------|-----------------------------------|------|
| И:  | м Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 80   |
|     |        |          |       |      | Техническое описание              |      |
| Г   |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |

- в) каждый канал DMA имеет программируемый уровень приоритета;
- г) каждый уровень приоритета обрабатывается, исходя из уровня приоритета, определяемого номером канала DMA;
  - д) поддержка различного типа передачи данных:
    - память память;
    - 2) память периферия;
    - 3) периферия память;
  - е) поддержка различных типов DMA циклов;
  - ж) поддержка передачи данных различной разрядности;
- з) каждому каналу DMA доступна первичная и альтернативная структура управляющих данных;
  - и) все управляющие данные канала хранятся в системной памяти;
  - к) разрядность данных приёмника равна разрядности данных передатчика;
- л) количество передач в одном цикле DMA может программироваться от 1 до 1024;
  - м) инкремент адреса передачи может быть больше чем разрядность данных.
    - 3.10.2 Описание функционирования контроллера DMA
    - 3.10.2.1 Правила арбитража DMA

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

Контроллер содержит четыре разряда, которые определяют количество транзакций по шине АНВ до повторения арбитража (переарбитрации). Это значение задаётся параметром R, количество транзакций одного канала до переарбитрации при этом равно 2R.

Таблица 3.10.2 содержит возможную периодичность арбитража в единицах передач по шине АНВ.

Изм Лист № докум. Подп. Дата

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

| Значение R    | Периодичность переарбитража |
|---------------|-----------------------------|
| 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 > 2R (N — номер передачи) и, если результат деления 2R на N не целое число, контроллер всегда выполняет последовательность из 2R передач до тех пор, пока не станет верным N < 2R. Контроллер выполняет оставшиеся N передач в конце цикла DMA.

Значение R задаётся в управляющей структуре канала, описание которой приведено ниже.

## 3.10.2.2 Приоритет

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

При проведении арбитража определяется канал для обслуживания в следующем цикле DMA. На выбор следующего канала влияют:

- номер канала;
- уровень приоритета, присвоенного каналу.

Каждому каналу по умолчанию может быть присвоен низкий или высокий уровень приоритета. Присвоение уровня приоритета осуществляется установкой или сбросом разряда chnl\_priority\_set.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Канал номер 0 имеет высший уровень приоритета; уровень приоритета снижается с увеличением номера канала.

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



Рисунок 3.10.1 — Алгоритм выбора следующего канала на обслуживание

3.10.2.3 Типы циклов DMA

Тодп. и дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

#### 3.10.2.3.1 Общее описание типов циклов DMA

Разряды cycle ctrl определяют, как контроллер будет выполнять циклы DMA. Описание значений этих разрядов приведено в таблице 3.10.3.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              | 00   |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 83   |
|     |      |          |       |      | Копировал                         | ΔΔ   |

| cycle_ctrl | Описание                                                                                                      |
|------------|---------------------------------------------------------------------------------------------------------------|
| b000       | Структура управляющих данных канала в запрещённом состоянии                                                   |
| b001       | Обычный цикл DMA                                                                                              |
| b010       | Авто-запрос                                                                                                   |
| b011       | Режим «пинг-понг»                                                                                             |
| b100       | Взаимодействие с памятью в режиме scatter-gather с использованием первичных управляющих данных канала         |
| b101       | Взаимодействие с памятью в режиме scatter-gather с использованием альтернативных управляющих данных канала    |
| b110       | Взаимодействие с периферией в режиме scatter-gather с использованием первичных управляющих данных канала      |
| b111       | Взаимодействие с периферией в режиме scatter-gather с использованием альтернативных управляющих данных канала |

Примечание — Разряды cycle\_ctrl находятся в области памяти, отведённой под channel\_cfg.

Для всех типов циклов DMA повторный арбитраж происходит после 2R передач DMA.

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

Предусмотрены следующие типы циклов DMA:

- недействительный;
- основной;
- авто-запрос;
- «пинг-понг»;
- работа с памятью в режиме scatter-gather;
- работа с периферией в режиме scatter-gather.

#### 3.10.2.3.2 Недействительный цикл

После окончания цикла DMA контроллер устанавливает тип цикла «недействительный» для предотвращения повторного выполнения цикла DMA.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
| 1   |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 84   |

Инв. № дубл.

Взам. инв. №

Подп. и дата

Формат А4

#### 3.10.2.3.3 Основной цикл

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

Таблица 3.10.4 — Описание шагов обработки цикла DMA в режиме «Основной цикл»

| Номер<br>шага | Описание                                                                                                                                                                                                                                                                                            |  |  |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1             | Контроллер выполняет 2R передач. Если число оставшихся передач 0, контроллер переходит к шагу 3                                                                                                                                                                                                     |  |  |  |  |
| 2             | Осуществление арбитража: — если высокоприоритетный канал выдает запрос на обработку, то контроллер начинает обслуживание этого канала; — если периферийный блок или программное обеспечение выдает запрос на обработку (повторный запрос на обработку по каналу), то контроллер переходит к шагу 1. |  |  |  |  |
| 3             | Контроллер устанавливает прерывание канала DMA. Это указывает центральному процессору на завершение цикла DMA. Данный режим используется для работы с блоками SPI и UART                                                                                                                            |  |  |  |  |

#### 3.10.2.3.4 Авто-запрос

Инв. № дубл.

Взам. инв. №

Подп. и дата

Функционируя в режиме «Авто-запрос», контроллер ожидает получения одиночного запроса на обработку для разрешения работы и выполнения цикла DMA. Это позволяет выполнять передачу больших пакетов данных без существенного увеличения времени отклика на обслуживание высокоприоритетных запросов и не требует множественных запросов на обработку от процессора или периферийных блоков.

Контроллер позволяет выбрать для использования первичную или альтернативную структуру управляющих данных канала. После того, как разрешено функционирование канала и контроллер получил запрос на обработку, цикл DMA отрабатывается как показано в таблице 3.10.5.

| Из                  | м Лист | № докум. | Подп. | Дата | Микросхема интегральная 5023.<br>Техническое описание<br>Версия 2.04 от 01.09.2017 г. | BC016 | Лист<br>85 |
|---------------------|--------|----------|-------|------|---------------------------------------------------------------------------------------|-------|------------|
| Копировал Формат А4 |        |          |       |      |                                                                                       |       |            |

| Номер<br>шага | Описание                                                                                                                                                                                                                                                                                            |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | Контроллер выполняет 2R передач для канала С. Если число оставшихся передач равно нулю, контроллер переходит к шагу 3                                                                                                                                                                               |
| 2             | Осуществление арбитража: — если высокоприоритетный канал выдает запрос на обработку, то контроллер начинает обслуживание этого канала; — если периферийный блок или программное обеспечение выдает запрос на обработку (повторный запрос на обработку по каналу), то контроллер переходит к шагу 1. |
| 3             | Контроллер устанавливает прерывание канала DMA, указывает центральному процессору на завершение цикла DMA                                                                                                                                                                                           |

Отличие от режима «основной» заключается в том, что в режиме «Авто-запуск» контроллер осуществляет запуск 2R транзакций по одному запросу от блока периферии, в то время как основной режим осуществляет одну транзакцию по соответствующему ему запросу.

#### 3.10.2.3.5 Режим «Пинг-понг»

В режиме «Пинг-понг» контроллер выполняет цикл DMA, используя одну из структур управляющих данных (первичную), а затем выполняет еще один цикл DMA, используя другую структуру управляющих данных (альтернативную).

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

Рисунок 3.10.2 содержит диаграмму функционирования контроллера в режиме «пинг-понг».

Шаг А состоит из следующих действий:

- процессор устанавливает первичную структуру управляющих данных для шага «А»;
- процессор устанавливает альтернативную структуру управляющих данных для шага «В». Это позволит контроллеру переключиться к шагу «В» незамедлительно после выполнения шага «А», при условии, что контроллер не получит запрос на обработку от высокоприоритетного канала;
  - контроллер получает запрос и выполняет 4 передачи DMA;

| L |      |      |          |       |      | Микросхема интегральная 5023BC016                    | Лист |
|---|------|------|----------|-------|------|------------------------------------------------------|------|
| И | зм Ј | Пист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 86   |

Инв. № дубл.

Взам. инв. №

Подп. и дата

- контроллер выполняет оставшиеся 2 передачи DMA;
- контроллер устанавливает прерывание канала DMA и входит в процедуру арбитража.



Рисунок 3.10.2 — Диаграмма функционирования контроллера в режиме «пингпонг»

После выполнения шага «А» процессор может установить первичные управляющие данные канала для шага «С». Это позволит контроллеру переключиться к шагу «С» незамедлительно после выполнения шага «В», при условии, что контроллер не получит запрос на обработку от высокоприоритетного канала.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

Тодп. и дата

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подл.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подп.

Лист

№ докум.

Подп.

После получения нового запроса на обработку от канала при условии его наивысшего приоритета исполняется шаг «В», который состоит из следующих действий:

- контроллер выполняет 4 передачи DMA;
- контроллер выполняет арбитраж. После получения запроса на обработку от этого же канала контроллер продолжает цикл в ситуации отсутствия высокоприоритетных запросов;
  - контроллер выполняет 4 передачи DMA;
- контроллер выполняет арбитраж. После получения запроса на обработку от этого же канала контроллер продолжает цикл в ситуации отсутствия высокоприоритетных запросов;
  - контроллер выполняет оставшиеся 4 передачи DMA;
- контроллер устанавливает прерывание канала DMA и переходит к процедуре арбитража.

После выполнения шага «В» процессор может установить альтернативные управляющие данные канала для шага «D».

После получения нового запроса на обработку от канала при условии его наивысшего приоритета выполняется шаг «С», который состоит из следующих действий:

- контроллер выполняет две передачи DMA;
- контроллер устанавливает прерывание канала DMA и входит в процедуру арбитража.

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

После получения нового запроса на обработку от канала при условии его наивысшего приоритета исполняется шаг «D», который состоит из следующих действий:

— контроллер выполняет 4 передачи DMA;

*Д*ата

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

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

— контроллер устанавливает прерывание канала DMA и входит в процедуру арбитража.

После получения нового запроса на обработку от канала при условии его наивысшего приоритета исполняется шаг «Е», который состоит из следующих действий:

- контроллер выполняет 4 передачи DMA;
- контроллер выполняет арбитраж. После получения запроса на обработку от этого же канала контроллер продолжает цикл в ситуации отсутствия высокоприоритетных запросов;
  - контроллер выполняет оставшиеся 3 передачи DMA;
- контроллер устанавливает прерывание канала DMA и входит в процедуру арбитража.
  - 3.10.2.3.6 Работа с памятью в режиме Scatter-gather

В режиме «Scatter-gather» контроллер, получая начальный запрос на обработку, выполняет четыре передачи DMA, используя первичные управляющие данные. По окончании этих передач контроллер начинает цикл DMA, используя альтернативные управляющие данные. Затем контроллер выполняет дополнительно четыре передачи DMA, используя первичные управляющие данные.

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

- процессор переведёт контроллер в режим «Основной» во время цикла с альтернативной структурой;
  - контроллер считает «неправильную» структуру управляющих данных.

Примечание — После исполнения контроллером N передач с использованием первичных управляющих данных, последний аннулирует управляющие путём установки поля cycle\_ctrl в 3'b000.

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

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подп.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Таблица 3.10.6 содержит формат заполнения областей памяти channel\_cfg, значения которых определяются константами и областей, значения которых определяются пользователем.

Таблица 3.10.6 — Заполнение областей памяти в режиме scatter-gather

| № бита  | Обозначение   | Значение     | Описание                                                           |
|---------|---------------|--------------|--------------------------------------------------------------------|
|         | ,             | Области с ко | онстантными значениями                                             |
| 31 – 30 | dst_inc       | b'10         | Контроллер производит инкремент адреса пословно                    |
| 29 – 28 | dst_size      | b'10         | Контроллер осуществляет передачу пословно                          |
| 27 – 26 | src_inc       | b'10         | Контроллер производит инкремент адреса пословно                    |
| 25 - 24 | src_size      | b'10         | Контроллер осуществляет передачу пословно                          |
| 17 – 14 | R_power       | b'0010       | Контроллер выполняет 4 передачи DMA                                |
| 3       | next_useburst | b'0          | Для данного режима этот разряд должен быть равен 0                 |
| 2-0     | cycle_ctrl    | b'100        | Контролер функционирует в режиме scatter-gather с периферией       |
|         | Области       | со значения  | ми, определяемыми пользователем                                    |
| 23 – 21 | dst_prot_ctrl | _            | Определяет состояние HPROT при записи данных в приёмник            |
| 20 – 18 | src_prot_ctrl | _            | Определяет состояние HPROT при чтении данных из источника          |
| 13 – 4  | N_minus_1     | $N^{1)}$     | Настраивает контроллер на выполнение N передач DMA, где N кратно 4 |

<sup>&</sup>lt;sup>1)</sup> Так как поле R\_power задает значение 4, то необходимо задавать значение N, кратное 4. Число, равное N/4 — это количество итераций, которое нужно настраивать альтернативные управляющие данные.

Рисунок 3.10.3 содержит диаграмму функционирования в режиме работы scatter-gather с памятью.

#### Инициализация:

Инв. № дубл.

Взам. инв. №

Подп. и дата

- основной настройкой для активации копий A, B, C и D являются операции:  $\text{cycle\_ctrl} = \text{b100}, \ 2^{\text{R}} = 4, \ \text{N} = 16;$
- запись основного источника данных в память осуществляется с помощью структуры, указанной в таблице 3.10.7.

|     |      |          | ·     |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 90   |

Таблица 3.10.7 — Структура основного источника данных в памяти

| Шаг | src_data_end_ptr | dst_data_end_ptr | channel_cfg                           | Неиспользуемый |
|-----|------------------|------------------|---------------------------------------|----------------|
| A   | 0x0A000000       | 0x0AE00000       | $cycle\_ctrl = b101,$ $2R = 4, N = 3$ | 0xXXXXXXXX     |
| В   | 0x0B000000       | 0x0BE00000       | $cycle\_ctrl = b101,$ $2R = 2, N = 8$ | 0xXXXXXXXX     |
| С   | 0x0C000000       | 0x0CE00000       | $cycle\_ctrl = b101,$ $2R = 8, N = 5$ | 0xXXXXXXXX     |
| D   | 0x0D000000       | 0x0DE00000       | $cycle\_ctrl = b101,$ $2R = 4, N = 4$ | 0xXXXXXXXX     |

Транзакция памяти в режиме scatter-gather:

#### Основной

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.



Рисунок 3.10.3 — Пример работы контроллера DMA в режиме scatter-gather с памятью

Инициализация состоит из следующих действий:

— процессор настраивает первичную структуру управляющих данных для работы в режиме работы scatter-gather с памятью путем установки поля cycle\_ctrl в

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

Формат А4

Лист

91

b100. Так как управляющие данные канала состоят из четырёх слов, необходимо

задать 2R равным 4. На рисунке 3.10.3 количество задач равно 4, следовательно,

начинают исполняться при получении контроллером запроса на обслуживание по

передачи DMA. Эти передачи записывают альтернативную структуру управляющих

памяти с адресом, указанным в поле src data end ptr;

dma req[] или запроса от процессора.

Порядок выполнения следующий:

— процессор записывает управляющие данные для шагов A, B, C, D в область

процессор разрешает работу канала DMA. Передачи в данном режиме

— по получению запроса на обслуживание контроллер выполняет четыре

N равно 16;

– контроллер устанавливает cycle ctrl первичных управляющих данных в b000 для индикации о том, что эта структура управляющих данных является «неправильной»;

- контроллер генерирует автозапрос для канала, после чего проводит процедуру арбитража;
  - контроллер выполняет шаг «D», используя основной цикл DMA;
- контроллер устанавливает прерывание канала DMA и входит в процедуру арбитража.

#### 3.10.2.3.7 Режим работы «Scatter-gather» с периферией

В режиме работы «Scatter-gather» с периферией контроллер, получая начальный запрос на обработку, выполняет четыре передачи DMA, используя первичные управляющие данные. По окончании этих передач контроллер начинает цикл DMA, используя альтернативные управляющие данные без осуществления арбитража и не устанавливая сигнал dma active[C] в 0.

Примечание — Это единственный случай, при котором контроллер не осуществляет процедуру арбитража после выполнения передачи DMA, используя

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

структуры

Примечание — После исполнения контроллером N передач с использованием первичных управляющих ОН делает ЭТИ управляющие данных, данные «неправильными» путем установки cycle ctrl в 3'b000.

Контроллер устанавливает прерывание в режиме работы «Scatter-gather» с периферией только по окончании основного цикла передачи DMA.

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

Таблица 3.10.8 содержит формат областей памяти channel cfg которые должны быть определены константами, и областей, значения которых определяются пользователем.

Таблица 3.10.8 — Заполнение областей памяти в режиме «Scatter-gather» при работе с периферией

| № бита  | Обозначение                                                                                                                                                                      | Значение        | Описание                                                                                                              |  |  |  |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         | Области с константными значениями                                                                                                                                                |                 |                                                                                                                       |  |  |  |  |
| 31 – 30 | dst_inc                                                                                                                                                                          | b'10            | Контроллер производит инкремент адреса пословно                                                                       |  |  |  |  |
| 29 – 28 | dst_size                                                                                                                                                                         | b'10            | Контроллер осуществляет передачу пословно                                                                             |  |  |  |  |
| 27 – 26 | src_inc                                                                                                                                                                          | b'10            | Контроллер производит инкремент адреса пословно                                                                       |  |  |  |  |
| 25 – 24 | src_size                                                                                                                                                                         | b'10            | Контроллер осуществляет передачу пословно                                                                             |  |  |  |  |
| 17 – 14 | R_power                                                                                                                                                                          | b'0010          | Контроллер выполняет 4 передачи DMA                                                                                   |  |  |  |  |
| 2-0     | cycle_ctrl                                                                                                                                                                       | b'100           | Контролер функционирует в режиме scatter-gather с периферией                                                          |  |  |  |  |
|         | Област                                                                                                                                                                           | ги со значения  | ями, определяемыми пользователем                                                                                      |  |  |  |  |
| 23 – 21 | dst_prot_ctrl                                                                                                                                                                    | _               | Определяет состояние HPROT при записи данных в приёмник                                                               |  |  |  |  |
| 20 – 18 | src_prot_ctrl                                                                                                                                                                    | _               | Определяет состояние HPROT при чтении данных из источника                                                             |  |  |  |  |
| 13 – 4  | N_minus_1                                                                                                                                                                        | N <sup>1)</sup> | Настраивает контроллер на выполнение N передач DMA, где N кратно 4                                                    |  |  |  |  |
| 3       | next_useburst                                                                                                                                                                    | _               | При установке в 1 контроллер установит chnl_useburst_set[C]в 1 после выполнения передачи с альтернативной структурой. |  |  |  |  |
|         | 1) Так как поле R_power задает значение 4, то необходимо задавать значение N, кратное 4.  Число, равное N/4, это количество итераций настройки альтернативных управляющих данных |                 |                                                                                                                       |  |  |  |  |

Число, равное N/4, это количество итераций настройки альтернативных управляющих данных.

№ докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023ВС016 Техническое описание Версия 2.04 от 01.09.2017 г.

94



Таблица 3.10.9 — Структура основного источника данных в памяти

| Шаг | src_data_end_ptr | dst_data_end_ptr | channel_cfg                                    | Неиспользуемый |
|-----|------------------|------------------|------------------------------------------------|----------------|
| A   | 0x0A000000       | 0x0AE00000       | cycle_ctrl = b111,<br>$2^{R} = 4, N = 3$       | 0xXXXXXXXX     |
| В   | 0x0B000000       | 0x0BE00000       | cycle_ctrl = b111,<br>$2^{R} = 2, N = 8$       | 0xXXXXXXXX     |
| С   | 0x0C000000       | 0x0CE00000       | cycle_ctrl = b111,<br>$2^{R} = 8, N = 5$       | 0xXXXXXXXX     |
| D   | 0x0D000000       | 0x0DE00000       | cycle_ctrl = $b001$ ,<br>$2^{R} = 4$ , $N = 4$ | 0xXXXXXXXX     |

Транзакция с периферией в режиме scattergather:

#### Основной

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.



Рисунок 3.10.4 — Диаграмма функционирования контроллера DMA в режиме «Scatter-gather» с периферией

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

Формат А4

Лист

96

контроллером запроса на обслуживание по dma req[]. Передачи выполняются следующим образом: — по получению запроса на обслуживание, контроллер выполняет 4 передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага А; — контроллер выполняет шаг «А»; — по окончании контроллер проводит процедуру арбитража; — контроллер выполняет четыре передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага «В»; — контроллер выполняет шаг «В». Для завершения задачи периферия должна установить последовательно три запроса; Инв. № дубл. по окончании контроллер проводит процедуру арбитража; — контроллер выполняет четыре передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага «С»; Взам. инв. № — контроллер выполняет шаг «С»; — по окончании контроллер проводит процедуру арбитража; — после выставления периферией нового запроса на обслуживание, при условии, что этот запрос является наиболее приоритетным, процесс продолжается; Подп. и дата — контроллер выполняет четыре передачи DMA. Эти передачи записывают альтернативную структуру управляющих данных для шага «D»; нв. № подл. Микросхема интегральная 5023ВС016 Лист Техническое описание 97 Версия 2.04 от 01.09.2017 г. Лист № докум. Подп. *Д*ата

Копировал

Инициализация состоит в следующем:

— процессор настраивает первичную структуру управляющих данных для

— процессор записывает управляющие данные для шагов «А», «В», «С», «D»

получении

Формат А4

при

работы в режиме «Scatter-gather» с периферией путём установки cycle ctrl в b110.

Так как управляющие данные канала состоят из 4 слов, необходимо установить 2R

в 4. В этом примере количество задач равно 4 и поэтому N установлен в 16;

Передачи в данном режиме начинают исполняться

в область памяти с адресом, указанным в поле src data end ptr;

процессор разрешает работу канала DMA.

- контроллер устанавливает поле cycle\_ctrl первичных управляющих данных в b000 для индикации ошибочной структуры данных;
  - контроллер выполняет шаг «D», используя основной цикл DMA;
  - контроллер устанавливает прерывание и входит в процедуру арбитража.

Индикация ошибок.

При получении контроллером DMA по шине AHB ответа об ошибке, он выполняет следующие действия:

- отключает канал, связанный с ошибкой;
- устанавливает флаг dma err в состояние «1».

После обнаружения процессором флага dma\_err, процессор определяет номер канала, который был активен в момент появления ошибки. Для этого он осуществляет следующее:

- чтение perистра chnl\_enable\_set с целью создания списка отключенных каналов. Если канал установил флаг dma\_done[], то контроллер отключает канал. Программа, выполняемая процессором, должна всегда хранить данные о каналах, которые недавно установили флаги прерывания;
- процессор должен сравнить список выключенных каналов, полученный в шаге 1, с данными о каналах, которые недавно устанавливали флаги прерывания. Канал, по которому отсутствуют данные об установке флага прерывания, является каналом, с которым связана ошибка.
  - 3.10.3 Программное управление модулем
  - 3.10.3.1 Структура управляющих данных канала

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

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Рисунок 3.10.5 иллюстрирует область памяти, необходимую контроллеру для структур управляющих данных канала, при использовании всех 32 каналов и опциональной альтернативной структуры управляющих данных.



Рисунок 3.10.5 — Карта памяти управляющих данных для 32 каналов памяти

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Пример, показанный на рисунке 3.10.5, использует 1 кБ системной памяти. В этом примере контроллер использует младшие 0х10 разрядов адреса для доступа ко всем элементам структуры управляющих данных, и поэтому базовый адрес структуры должен быть 0хХХХХХХООО, далее 0хХХХХХХООО, далее 0хХХХХХХООО, далее 0хХХХХХХСОО.

Возможно установить базовый адрес для первичной структуры управляющих данных путём записи соответствующего значения в регистр ctrl\_base\_ptr.

|    |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|----|--------|----------|-------|------|-----------------------------------|------|
|    |        |          |       |      | Техническое описание              | 00   |
| Из | и Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 99   |

Таблица 3.10.10 содержит формат представления разрядов адреса, обеспечивающих контроллеру DMA доступ к различным элементам структуры управляющих данных, в зависимости от количества каналов, используемых в контроллере.

Таблица 3.10.10 — Формат представления разрядов адреса, обеспечивающих контроллеру DMA доступ к различным элементам структуры управляющих данных

| Количество каналов,           |     |      |      | Разряды ад | peca |      |           |
|-------------------------------|-----|------|------|------------|------|------|-----------|
| используемых в<br>контроллере | [9] | [8]  | [7]  | [6]        | [5]  | [4]  | [3:0]     |
| 1                             |     |      |      |            |      | A    |           |
| 2                             |     |      |      |            | A    | C[0] | 0x0       |
| 3 – 4                         |     |      |      | A          | C[1] | C[0] | 0x0 $0x4$ |
| 5 – 8                         |     |      | A    | C[2]       | C[1] | C[0] | 0x4 $0x8$ |
| 9 – 16                        |     | A    | C[3] | C[2]       | C[1] | C[0] | UAG       |
| 17 - 32                       | A   | C[4] | C[3] | C[2]       | C[1] | C[0] |           |

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

- при А = 0 используется первичная структура управляющих данных;
- при A = 1 используется альтернативная структура управляющих данных.

Значения C[x:0] определяют выбор канала DMA.

Address[3:0] задает один из управляющих элементов:

- 0x0 указатель конца данных источника;
- 0x4 указатель конца данных приёмника;
- 0x8 конфигурация управляющих данных;
- 0хС адрес, недоступный контроллеру.

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

Примечание — Нет необходимости в вычислении базового адреса альтернативной структуры управляющих данных, так как perucтp alt\_ctrl\_base\_ptr содержит эту информацию.

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Рисунок 3.10.6 демонстрирует пример реализации контроллера с использованием трёх каналов DMA и с альтернативной структурой управляющих данных.



Рисунок 3.10.6 — Карта памяти для трех каналов DMA, включая альтернативную структуру: Destination end pointer — указатель конца данных приёмника; Source end pointer — указатель конца данных источника; Control — управление

В указанном выше примере используется 128 байт системной памяти. Контроллер DMA использует младшие 0x06 разрядов адреса для доступа ко всем элементам структуры управляющих данных. Следовательно, базовый адрес структуры должен быть 0xXXXXXXX00, далее 0xXXXXXX80.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лис |
|-----|------|----------|-------|------|-----------------------------------|-----|
|     |      |          |       |      | Техническое описание              |     |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 10  |

Тодп. и дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

чв. № подл.

- указатель конца данных приёмника;
- разряды управления;
- вычисление адреса.

Инв. № дубл.

Взам. инв. №

Подп. и дата

#### 3.10.3.2 Указатель конца данных источника

Область памяти src\_data\_end\_ptr содержит указатель на последний адрес месторасположения данных источника. Формат указателя конца данных источника содержится в таблице 3.10.11.

Таблица 3.10.11 — Указатель конца данных источника

| № бита | Функциональное имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|--------|-------------------------|--------------------------------------------------------------------------------------------|
| 31 - 0 | src_data_end_ptr        | Указатель последнего адреса данных источника                                               |

Перед тем, как контроллер выполнит передачу DMA, необходимо определить область памяти, отводимую под указатель конца данных источника. Контроллер DMA считывает значение этой области перед началом 2R передач.

Примечание — Контроллер не имеет доступа по записи в эту область памяти.

## 3.10.3.3 Указатель конца данных приёмника

Область памяти dst\_data\_end\_ptr содержит указатель на последний адрес данных приёмника.

Таблица 3.10.12 содержит формат указателя конца данных приёмника.

Таблица 3.10.12 — Указатель конца данных приёмника

| № бита | Функциональное<br>имя бита | Расшифровка функционального имени бита, краткое описание назначения и принимаемых значений |
|--------|----------------------------|--------------------------------------------------------------------------------------------|
| 31 – 0 | dst_data_end_ptr           | Указатель на последний адрес данных приёмника                                              |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 102  |

Копировал

Формат А4

Перед тем, как контроллер выполнит передачу DMA, необходимо определить область памяти, в которой содержится последний адрес данных приёмника. Контроллер DMA считывает значение этой области перед началом 2R передачи.

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

#### 3.10.3.4 Разряды управления

Область памяти под названием channel\_cfg обеспечивает управление каждой передачей DMA.

Наименования разрядов области памяти channel\_cfg содержатся в таблице 3.10.13.

Таблица 3.10.13 — Название разрядов области памяти channel\_cfg

| № бита | 31 | 30     | 29 | 28       | 27 | 26      | 25 | 24            | 23 - 21 | 20 – 18      | 17 – 14 | 13 – 4  | 3             | 2-0        |
|--------|----|--------|----|----------|----|---------|----|---------------|---------|--------------|---------|---------|---------------|------------|
| Доступ |    |        |    |          |    |         |    |               |         |              |         |         |               |            |
| Сброс  |    |        |    |          |    |         |    |               |         |              |         |         |               |            |
|        |    | dst_mc |    | dst_size |    | src_inc | 1  | ust_prot_curi | 1       | src_prot_cur |         | K_power | next_useburst | cycle_ctrl |

Назначение разрядов этой области памяти содержится в таблице 3.10.14.

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

Таблица 3.10.14 — Назначение разрядов области памяти channel\_cfg

Описание

№ бита

Взам. инв. № Инв. № дубл.

Подп. и дата

Инв. N<u>е</u> подп.

Наименование

|     | 1        | 2                | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |            |
|-----|----------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|     |          |                  | Шаг инкремента адреса приёмника.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |
|     | 31 – 30  | dst_src          | Шаг инкремента адреса зависит от разрядности данных источника.  Разрядность данных источника = байт:  b00 = байт;  b01 = полуслово (16 разрядов);  b10 = слово (32 разряда);  b11 = нет инкремента. Адрес остается равным значению области памяти dst_data_end_ptr.  Разрядность данных источника = полуслово:  b00 = зарезервировано;  b01 = полуслово;  b10 = слово;  b11 = нет инкремента. Адрес остается равным значению области памяти dst_data_end_ptr.  Разрядность данных источника = слово:  b00 = зарезервировано;  b01 = зарезервировано;  b01 = слово (32 разряда);  b11 = нет инкремента. Адрес остается равным значению области памяти dst data_end_ptr. |            |
|     |          |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |
|     | 29 – 28  | dst_size         | Размерность данных приёмника Примечание: Значение этого поля должно быть равно значению поля src_size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |
|     | 27 – 26  | src_inc          | Шаг инкремента адреса источника. Шаг инкремента адреса зависит от разрядности данных источника. Разрядность данных источника = байт: b00 = байт; b01 = полуслово; b10 = слово (32 разряда); b11 = нет инкремента. Адрес остается равным значению области памяти src_data_end_ptr. Разрядность данных источника = полуслово: b00 = зарезервировано b01 = полуслово b10 = слово b11 = нет инкремента. Адрес остается равным значению области памяти src_data_end_ptr. Разрядность данных источника = слово: b00 = зарезервировано; b01 = зарезервировано; b10 = слово; b11 = нет инкремента. Адрес остается равным значению области памяти src_data_end_ptr              |            |
|     | , I      | 1 1              | Muunooyotta tuumoonast vas 5000BC046                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 11075      |
| Изп | л Лист N | № докум. Подп. Д | Техническое описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ucm<br>104 |

| 1  | Прод   | олжение 1 | паблиц   | ы 3.1                                                                | 0.14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|----|--------|-----------|----------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|    | 1      |           | 2        |                                                                      | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| 7  | 25 – 2 | 4 src_    | _size    | b0<br>b0<br>b1                                                       | дает размерность данных источника: 0 = байт; 1 = полуслово (в русском обычно слово); 0 = слово (в русском обычно двойное слово); 1 = зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
| 2  | 23 – 2 | 1 dst_p   | rot_ctrl | да<br>Ра<br>0 =<br>1 =<br>Ра<br>0 =<br>1 =<br>Ра                     | дает состояние HPROT[3:1], когда контроллер записывает нные в приёмник.  зряд 23 управляет разрядом HPROT[3]:  = HPROT[3] в состоянии «0» и доступ не кэшируется;  = HPROT[3] в состоянии «1» и доступ кэшируется.  зряд 22управляет разрядом HPROT[2]:  = HPROT[2] в состоянии «0» и доступ не буферизуется;  = HPROT[2] в состоянии «1» и доступ буферизуется.  зряд 21управляет разрядом HPROT[1]:  = HPROT[1] в состоянии «0» и доступ непривилегированный  = HPROT[1] в состоянии «1» и доступ привилегированный                                                                                                                                                                                                                                                          | Ξ,  |
|    | 20 – 1 | 8 src_p   | rot_ctrl | да<br>Ра<br>0 =<br>1 =<br>Ра<br>0 =<br>1 =<br>Ра                     | дает состояние HPROT[3:1], когда контроллер считывает нные из источника.  зряд 20управляет разрядом HPROT[3]:  = HPROT[3] в состоянии 0 и доступ не кэшируется;  = HPROT[3] в состоянии «1» и доступ кэшируется.  зряд 19 управляет разрядом HPROT[2]:  = HPROT[2] в состоянии «0» и доступ не буферизуется;  = HPROT[2] в состоянии «1» и доступ буферизуется.  зряд 18управляет разрядом HPROT[1]:  = HPROT[1] в состоянии «0» и доступ непривилегированный  = HPROT[1] в состоянии «1» и доступ привилегированный                                                                                                                                                                                                                                                           | · · |
|    | 17 – 1 | 4 R_p     | oower    | пр<br>Вс<br>b0<br>b0<br>b0<br>b0<br>b0<br>b0<br>b0<br>b1<br>b1<br>b1 | дает количество передач DMA до выполнения контроллером оцедуры арбитража. В воможные значения: 000 — арбитраж производится после каждой передачи DMA 001 — арбитраж производится после двух передач DMA; 010 — арбитраж производится после четырех передач DMA; 011 — арбитраж производится после восьми передач DMA; 100 — арбитраж производится после 16 передач DMA; 101 — арбитраж производится после 32 передач DMA; 110 — арбитраж производится после 64 передач DMA; 111 — арбитраж производится после 128 передач DMA; 000 — арбитраж производится после 256 передач DMA; 001 — арбитраж производится после 512 передач DMA; 010 — b1111 - арбитраж производится после 1024 передач MA. Арбитраж не производится, так как максимальное личество передач DMA равно 1024 |     |
|    |        |           |          |                                                                      | Микросхема интегральная 5023ВС016                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Л   |
|    |        |           |          |                                                                      | Техническое описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1   |
| М. | Лист   | № докум.  | Подп.    | Дата                                                                 | Версия 2.04 от 01.09.2017 г.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1   |

| Перед мыполнением цикла DMA эти разряды указывают обиес количество передач DMA, на которых остоит шикл DMA. Необходимо установить эти разрядна в значение, соответствующее размеру желаемого шикла DMA. 10-разрядное число плюс 1 задаст количество передач DMA. Возможные значение в реосрази DMA; воюоооооооо = 1 передача DMA; воюооооооо = 1 передача DMA; воюооооооо = 1 а передачи DMA; воюооооооо = 3 передачи DMA; воюооооооо = 4 передачи DMA; воюооооооо = 4 передачи DMA; воюоооооо = 4 передачи DMA; воюоооооо = 6 передач DMA. Контролиср обновит это поле перед тем, как произвести процесс арбитража, Это пояковуят контролисру хранить количество оставшихся передач DMA до завершения шикла DMA. Контролируел, пе установиси ли си на контролиср закеривает цикл DMA, непользуя альтернативные управляющие данные.  Примечание: Перед закеристием цикла DMA, использующего альтернативные управляющие ранные. Примечание: Перед закеристием цикла DMA, использующего альтернативные управляющие ранные, контроллер установливает chall useburst seafCl в значение «Ф», сели контистно оставшихся передач DMA меньше, чем 2R. Установка пехт useburst разряда опредължет, будет и контроллер, пололительно переопредсятт разряд chall useburst seafCl. Если контроллер рыполняет шикл DMA в режиме работы с периферией, то после окогчания используют альтернативные управляющие данные, происходит следующее в зависимости от сестояния пехт цекърна.  3 пехт_useburst  3 пехт_useburst  1 — контроллер выполняет значение chal_useburst_set[C] Если сhal_useburst_set[C] установлен в «Ф», то для всех оставшихся циклов DMA в режиме работы с периферией «Исполнение с изменением конфигурации», контроллер отвечает на запрось по dna гед[], пир выполнении ицклов DMA в режиме работы с периферией «Исполнение конфигурации» контроллер разичурет только на запрось по dna гед[] пир выполнении ицклов DMA он использует альтернативные управляющие данные.   Микросхема интегральная 5023ВС016   Микросхема интегральн | Прод   | олжение 1 |          | ы 3.1                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| Контролирует, не установлен ли chnl_useburst_set[C] в состояние «1»; ссли контроллер функционирует в режиме scatter-gather с периферией и, ссли контроллер завершает цикл DMA, использув альтернативные управляющие данные.  Примечание: Перед завершением цикла DMA, использующего альтернативны управляющие данные, контроллер устанавливает chnl_useburst_set[C] в значение «0», ссли количество оставшихся передач DMA меньше, чем 2R. Установка пехt_useburst разряда определяет, будет ли контроллер дополнительно переопределять разряд chnl_useburst_set[C].  Если контроллер выполняет цикл DMA в режиме работы scatter-gather с периферией, то после окончания цикла, использующего альтернативные управляющие данные, происходит следующее в зависимости от состояния пехt_useburst:  0 — контроллер изменяет значение 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 он использует альтернативные управляющие данные.  Микросхема интегральная 5023BC016  Техническое описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 13 - 4 | 4 n_mi    | _        | ко<br>Не<br>со<br>10<br>Вс<br>b0<br>b0<br>b0<br>b0<br>b0<br>b0                                                                                        | личество передач DMA, из которых состоит цикл DMA. собходимо установить эти разряды в значение, ответствующее размеру желаемого цикла DMAразрядное число плюс 1 задает количество передач DMA. озможные значения:  0000000000 = 1 передача DMA;  000000001 = 2 передачи DMA;  000000010 = 3 передачи DMA;  000000011 = 4 передачи DMA;  0000000100 = 5 передач DMA;  .  111111111 = 1024 передачи DMA.  онтроллер обновит это поле перед тем, как произвести проце битража. Это позволяет контроллеру хранить количество                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                         |
| Техническое описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 3      | next_t    | iseburst | Ко<br>«1<br>пе<br>ал<br>Пр<br>Пе<br>уп<br>сh<br>пе<br>оп<br>ра<br>Ес<br>ga<br>ал<br>зап<br>0 -<br>ch<br>ци<br>из<br>dn<br>ис<br>1 -<br>со<br>ра<br>ко | онтролирует, не установлен ли chnl_useburst_set[C] в состояные, если контроллер функционирует в режиме scatter-gather с риферией и, если контроллер завершает цикл DMA, использытернативные управляющие данные.  Воимечание:  вред завершением цикла DMA, использующего альтернативная равляющие данные, контроллер устанавливает nl_useburst_set[C] в значение «О», если количество оставших редач DMA меньше, чем 2R. Установка next_useburst разряд ределяет, будет ли контроллер дополнительно переопределя зряд chnl_useburst_set[C].  Вли контроллер выполняет цикл DMA в режиме работы scatter с периферией, то после окончания цикла, использующеть втернативные управляющие данные, происходит следующее висимости от состояния next_useburst:  — контроллер не изменяет значение chnl_useburst_set[C]. Если nl_useburst_set[C] установлен в «О», то для всех оставшихся клов DMA в режиме работы с периферией «Исполнение с менением конфигурации», контроллер отвечает на запросы па_req[] и dma_sreq[], при выполнении циклов DMA он пользует альтернативные управляющие данные.  — контроллер изменяет значение chnl_useburst_set[C] в стояние «1». Поэтому для оставшихся циклов DMA в режим боты с периферией «Исполнение с изменением конфигураци нтроллер реагирует только на запросы по dma_req[], при полнении циклов DMA он использует альтернативные | ные<br>сся<br>а<br>тъ<br>ег-<br>го<br>в |
| Mark Uram 100 danus Hade Hama III Den Denitir / Ditam III DU /III / 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |           |          |                                                                                                                                                       | Техническое описание                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Л                                       |

| Прооолже      | ние таблиць   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | 2             | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2-0           | cycle_ctrl    | Режим работы при выполнении цикла DMA: b000 Стоп. Означает, что структура управляющих данных является «неправильной»; b001 Основной. Контроллер должен получить новый запрос для окончания цикла DMA, перед этим он должен выполнить процедуру арбитража; b010 Авто-запрос. Контролле автоматически осуществляет запрос на обработку по соответствующему каналу в течение процедуры арбитража. Это означает, что начального запроса на обработку достаточно для выполнения цикла DMA; b011 Пинг-понг. Контроллер выполняет цикл DMA использую одну из структуру управляющих данных. По окончании выполнения цикла DMA, контроллер выполняет следующий ци DMA, используя другую структуру. Контроллер сигнализирует об окончании каждого цикла DMA, позволяя процессору перенастраивать неактивную структуру данных. Контроллер продолжает выполнять циклы DMA, до тех пор, пока он не прочитает «неправильную» структуру данных или пока процессор не изменит cycle_ctrl поле в состояние b001 или b 010 b100 Режим работы scatter-gather с памятью. Смотрите соответствующий раздел. При работе контроллера в данном режиме значение этого поля в первичной структуре управляющих данных должно быть b100; b101 Режим работы scatter-gather с памятью. Смотрите соответствующий раздел. При работе контроллера в данном режиме значение этого поля в альтернативной структуре управляющих данных должно быть b110; b111 Режим работы scatter-gather с периферией. Смотрите соответствующий раздел. При работе контроллера в данном режиме значение этого поля в первичной структуре управляющих данных должно быть b110; b111 Режим работы scatter-gather с периферией. Смотрите соответствующий раздел. При работе контроллера в данном режиме значение этого поля в первичной структуре управляющих данных должно быть b110; b111 Режим работь контроллера в данном режиме значение этого поля в альтернативной структуре управляющих данных должно быть b110; |
| В наг         | иапе пикпа D  | b111<br>МА или 2R передачи DMA контроллер считывает значен                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               |               | ила или 2R передачи Била контроллер считывает значеной памяти. После выполнения 2R или N передач он сохрани                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|               |               | channel_cfg в системную память.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               |               | поддерживает значений dst_size, отличных от значен                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| src_size. E   | сли контрол   | плер обнаруживает неравные значения этих полей,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| использует    | значение src  | z_size в качестве размера данных и приёмника, и источник                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| при ближай    | ішем обновл   | ении поля n_minus_1, он также устанавливает значение по                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| dst_size, par | вное src_size | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|               |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|               |               | Микросхема интегральная 5023ВС016                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Взам. инв. № Инв. № дубл.

Инв. № подл. Подп. и дата

После выполнения контроллером N передач, контроллер устанавливает значение поля cycle\_ctrl в b000, делая тем самым channel\_cfg данные «неправильными». Это позволяет избежать повторения выполненной передачи DMA.

#### 3.10.3.5 Вычисление адреса

Для вычисления адреса источника передачи 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). src\_inc = b11 \ and \ dst\_inc = b11 — адрес источника = src\_data\_end\_ptr - (n\_minus\_1 << 2).
```

Таблица 3.10.15 содержит перечень адресов приёмника цикла DMA для шести слов с пословным инкрементом.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Таблица 3.10.15 — Адреса приёмника цикла DMA для шести слов с пословным инкрементом

| Начальные значения channel_cfg перед циклом DMA         |                        |         |                       |       |  |  |  |
|---------------------------------------------------------|------------------------|---------|-----------------------|-------|--|--|--|
| src_size=b10, dst_inc=b10, n_minus_1=b101, cycle_ctrl=1 |                        |         |                       |       |  |  |  |
|                                                         | Указатель конца данных | Счётчик | Отличие <sup>1)</sup> | Адрес |  |  |  |
|                                                         | 0x2AC                  | 5       | 0x14                  | 0x298 |  |  |  |
|                                                         | 0x2AC                  | 4       | 0x10                  | 0x29C |  |  |  |
| DMA передачи                                            | 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\_1=0, cycle\_ctrl=0

Таблица 3.10.16 содержит перечень адресов приёмника для передач DMA 12 байт с использованием «полусловного» инкремента.

Таблица 3.10.16 — Цикл DMA для 12 байт с «полусловным» инкрементом

| DMA передачи       | Указатель конца данных                                         | Счётчик                    | Отличие1)   | Адрес                   |
|--------------------|----------------------------------------------------------------|----------------------------|-------------|-------------------------|
|                    | 0x5E7                                                          | 11                         | 0x16        | 0x5D1                   |
|                    | 0x5E7                                                          | 10                         | 0x14        | 0x5D3                   |
|                    | 0x5E7                                                          | 9                          | 0x12        | 0x5D5                   |
|                    | 0x5E7                                                          | 8                          | 0x10        | 0x5D7                   |
|                    | 0x5E7                                                          | 7                          | 0xE         | 0x5D9<br>0x5DB<br>0x5DD |
|                    | 0x5E7                                                          | 6                          | 0xC         |                         |
|                    | 0x5E7                                                          | 5                          | 0xA         |                         |
|                    | 0x5E7                                                          | 4                          | 0x8         | 0x5DF                   |
| Значения channel   | _cfg после 2R передач DMA                                      |                            |             | ·                       |
| src_size=b00, dst_ | inc=b01, n_minus_1=b011, cy                                    | ycle_ctrl=1,               | R_power=b11 |                         |
|                    | 0x5E7                                                          | 3                          | 0x6         | 0x5E1                   |
|                    | 0x5E7                                                          | 2                          | 0x4         | 0x5E3                   |
|                    | 0x5E7                                                          | 1                          | 0x2         | 0x5E5                   |
|                    | 0x5E7                                                          | 0                          | 0x0         | 0x5E7                   |
| Конечные значен    | ия channel_cfg после цикла l                                   | DMA                        |             | ·                       |
| src_size=b00, dst_ | inc=b01, n_minus_1=0, cycle                                    | _ctrl=0 <sup>2)</sup> , R_ | _power=b11  |                         |
| соответствующее    | олученное после сдвига вле edst_inc. ия цикла DMA контроллер д |                            |             |                         |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| 1зм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

 $<sup>^{1)}</sup>$  Это значение, полученное после сдвига влево значения счётчика на количество разрядов, соответствующее  $dst_i$ nc.

# 3.10.3.6 Основные положения регистровой модели контроллера DMA Основные положения регистровой модели контроллера:

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

В таблице 3.10.17 представлен перечень регистров контроллера DMA.

Таблица 3.10.17 — Перечень регистров контроллера DMA

| Смещение | Название регистра | Тип | Значение по сбросу       | Описание                                                                                    |
|----------|-------------------|-----|--------------------------|---------------------------------------------------------------------------------------------|
| 1        | 2                 | 3   | 4                        | 5                                                                                           |
| 0x0      | STATUS            | RO  | 0x-0nn0000 <sup>1)</sup> | DMA -> STATUS<br>Статусный регистр DMA                                                      |
| 0x004    | CFG               | WO  | _                        | DMA -> CFG<br>Регистр конфигурации DMA                                                      |
| 0x008    | CTRL_BASE_PTR     | RW  | 0x00000000               | DMA -> CTRL_BASE_PTR. Регистр базового адреса управляющих данных каналов                    |
| 0x00C    | ALT_CTRL_BASE_PTR | RO  | 0x000000nn <sup>2)</sup> | DMA -> ALT_CTRL_BASE_PTR. Регистр базового адреса альтернативных управляющих данных каналов |
| 0x010    | WAITONREQ_STATUS  | RO  | 0x00000000               | DMA -> WAITONREQ_STATUS. Регистр статуса ожидания запроса на обработку каналов              |
| 0x014    | CHNL_SW_REQUEST   | WO  | _                        | DMA -> CHNL_SW_REQUEST. Регистр программного запроса на обработку каналов                   |
| 0x018    | CHNL_USEBURST_SET | RW  | 0x00000000               | DMA -> CHNL_USEBURST_SET. Регистр установки пакетного обмена каналов                        |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

110

|                                                                                                                                                                                                                                     |                   |    |                | Kananob                                                                                                  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----|----------------|----------------------------------------------------------------------------------------------------------|--|
| 0x020                                                                                                                                                                                                                               | CHNL_REQ_MASK_SET | RW | 0x00000000     | DMA -> CHNL_REQ_MASK_SET Регистр маскирования запросов на обслуживание каналов                           |  |
| 0x024                                                                                                                                                                                                                               | CHNL_REQ_MASK_CLR | wo | _              | DMA -> CHNL_REQ_MASK_CLR Регистр очистки маскирования запросов на обслуживание каналов                   |  |
| 0x028                                                                                                                                                                                                                               | CHNL_ENABLE_SET   | RW | 0x00000000     | DMA -> CHNL_ENABLE_SET. Регистр установки разрешения каналов                                             |  |
| 0x02C                                                                                                                                                                                                                               | CHNL_ENABLE_CLR   | wo | _              | DMA -> CHNL_ENABLE_CLR. Регистр сброса разрешения каналов                                                |  |
| 0x030                                                                                                                                                                                                                               | CHNL_PRI_ALT_SET  | RW | 0x00000000     | DMA -> CHNL_PRI_ALT_SET. Регистр установки первичной/альтернативной структуры управляющих данных каналов |  |
| 0x034                                                                                                                                                                                                                               | CHNL_PRI_ALT_CLR  | WO | _              | DMA -> CHNL_PRI_ALT_CLR. Регистр сброса первичной/альтернативной структуры управляющих данных каналов    |  |
| 0x038                                                                                                                                                                                                                               | CHNL_PRIORITY_SET | RW | 0x00000000     | DMA -> CHNL_PRIORITY_SET. установки приоритета каналов                                                   |  |
| 0x03C                                                                                                                                                                                                                               | CHNL_PRIORITY_CLR | wo | _              | DMA -> CHNL_PRIORITY_CLR. Регистр сброса приоритета каналов                                              |  |
| 0x040-<br>0x048                                                                                                                                                                                                                     | _                 | _  | _              | Зарезервировано                                                                                          |  |
| 0x04C                                                                                                                                                                                                                               | ERR_CLR           | RW | 0x00000000     | DMA -> ERR_CLR. Регистр сброса флага ошибки                                                              |  |
| 0x050-<br>0xDFC                                                                                                                                                                                                                     | _                 | _  | _              | Зарезервировано                                                                                          |  |
| 1) Значение по сбросу зависит от количества каналов DMA, использованных в контроллере, а также от того, интегрирована ли схема тестирования. 2) Значение по сбросу зависит от количества каналов DMA, использованных в контроллере. |                   |    |                |                                                                                                          |  |
| 3.10.3.7 Регистр STATUS (статусный регистр DMA)                                                                                                                                                                                     |                   |    |                |                                                                                                          |  |
| Регистр STATUS имеет доступ только на чтение. При чтении регистр возвращает состояние контроллера DMA. Если контроллер находится в состоянии                                                                                        |                   |    |                |                                                                                                          |  |
| . *                                                                                                                                                                                                                                 | •                 | •  | VIA. LUJIH KUH | пинкотого в котпрола фонторт                                                                             |  |
| сброса, то чтение регистра запрещено.                                                                                                                                                                                               |                   |    |                |                                                                                                          |  |

3

WO

4

5 DMA -> CHNL\_USEBURST\_CLR

Регистр сброса пакетного обмена

каналов

Продолжение таблицы 3.10.17

CHNL\_USEBURST\_CLR

0x01C

Инв. № дубл.

Взам. инв. №

Подп. и дата

Инв. № подл.

Лист

№ докум.

Подп.

Дата

Лист

111

Микросхема интегральная 5023ВС016

Техническое описание

Версия 2.04 от 01.09.2017 г.

Таблица 3.10.18 содержит формат данных, содержащихся в регистре STATUS.

В таблице 3.10.19 содержится назначение разрядов регистра dma status.

Таблица 3.10.18 — Формат данных, содержащихся в регистре STATUS

| № бита | 31 – 28     | 27 – 21 | 20 – 16      | 15 – 8 | 7 – 4 | 3 – 1 | 0             |
|--------|-------------|---------|--------------|--------|-------|-------|---------------|
| Доступ | RO          | U       | RO           | U      | RO    | U     | RO            |
| Сброс  | 0           | 0       | 0            | 0      | 0     | 0     | 0             |
|        | test_status | _       | chnls_minus1 | _      | state | ı     | master_enable |

#### Ттаблица 3.10.19 — Описание регистра dma status

| № бита    | Наименование  | Функциональное назначение бита, краткое описание бита назначения                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Jan Orlia | бита          | и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31 – 28   | test_status   | Значение при чтении: $0x0 = $ контроллер не имеет интегрированной схемы тестирования; $0x1 = $ контроллер имеет интегрированную схему тестирования; $0x2 - 0xF = $ не определено                                                                                                                                                                                                                                                                                                                                                                                   |
| 27 - 21   |               | Не определено                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 20 – 16   | chnls_minus1  | Количество доступных каналов DMA минус 1.<br>Например: b00000 = контроллер поддерживает 1 канал DMA;<br>b00001 = контроллер поддерживает 2 канала DMA;<br>b00010 = контроллер поддерживает 3 канала DMA;<br>b11111 = контроллер имеет 32 канала DMA                                                                                                                                                                                                                                                                                                                |
| 15 – 8    | _             | Не определено                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7 – 4     | state         | Текущее состояние автомата управления контроллера. Состояние может быть одним из следующих: b0000 = в покое; b0001 = чтение управляющих данных канала; b0010 = чтение указателя конца данных источника; b0011 = чтение указателя конца данных приёмника; b0100 = чтение данных источника; b0101 = запись данных в приёмник; b0110 = ожидание запроса на выполнение DMA; b0111 = запись управляющих данных канала; b1000 = приостановлен; b1001 = выполнен; b1010 = режим работы с периферией «Исполнение с изменением конфигурации»; b1011 - b1111 = не определено |
| 3 – 1     | _             | Не определено                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0         | master_enable | Состояние контроллера: 0 = функционирование контроллера запрещено; 1 = функционирование контроллера разрешено.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 3.10.3.8 Регистр CFG (регистр конфигурации DMA)

Инв. № дубл.

Взам. инв. №

Подп. и дата

Регистр CFG имеет доступ только на запись. Регистр определяет состояние контроллера.

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|--------|----------|-------|------|-----------------------------------|------|
|     |        |          |       |      | Техническое описание              |      |
| Изі | 1 Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 112  |

Копировал

Таблица 3.10.20 — Формат данных регистра CFG

| № бита | 31 – 8 | 7 – 5          | 4-1 | 0             |
|--------|--------|----------------|-----|---------------|
| Доступ | U      | WO             | U   | WO            |
| Сброс  | 0      | 0              | 0   | 0             |
|        | _      | chnl_prot_ctrl | _   | master_enable |

#### Таблица 3.10.21 — Описание регистра dma cfg

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита  |  |
|--------|-------------------|--------------------------------------------------------|--|
| 21 0   |                   | назначения и принимаемых значений                      |  |
| 31 – 8 |                   | Не определено, следует записывать 0.                   |  |
|        |                   | Определяет уровни индикации сигналов HPROT[3:1]        |  |
|        |                   | защиты шины AHB-Lite:                                  |  |
|        |                   | Разряд 7 управляет сигналом HPROT[3] с целью индикации |  |
|        |                   | о появлении доступа с кэшированием;                    |  |
|        |                   | Разряд 6 управляет сигналом HPROT[2] с целью индикации |  |
|        |                   | о появлении доступа с буферизацией;                    |  |
| 7 - 5  | -5 chnl_prot_ctrl | Разряд 5 управляет сигналом HPROT[1] с целью индикации |  |
|        |                   | о появлении привилегированного доступа.                |  |
|        |                   | Примечание:                                            |  |
|        |                   | Если разряд[n] = 1, то соответствующий сигнал HPROT в  |  |
|        |                   | состоянии «1»;                                         |  |
|        |                   | Если разряд[n] = 0, то соответствующий сигнал HPROT в  |  |
|        |                   | состоянии «0».                                         |  |
| 4 – 1  | _                 | Не определено. Следует записывать 0.                   |  |
|        |                   | Определяет состояние контроллера:                      |  |
| 0      | master_enable     | 0 — запрещает работу контроллера;                      |  |
|        |                   | 1 — разрешает работу контроллера.                      |  |

3.10.3.9 Регистр CTRL\_BASE\_PTR (регистр базового адреса управляющих данных каналов)

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

Примечание — Контроллер не содержит внутреннюю память для хранения управляющих данных каналов.

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

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 113  |

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

Если контроллер находится в состоянии сброса, то чтение регистра запрещено. Таблица 3.10.22 содержит конфигурацию регистра ctrl base ptr.

Таблица 3.10.22 — Конфигурация регистра ctrl\_base\_ptr

| № бита | 31 – 10       | 9-0 |
|--------|---------------|-----|
| Доступ | RW            | U   |
| Сброс  | 0             | 0   |
|        | ctrl_base_ptr | _   |

Таблица 3.10.23 содержит назначение разрядов регистра ctrl base ptr.

Таблица 3.10.23 — Описание регистра ctrl base ptr

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

| № бита  | Наименование  | Функциональное назначение бита, краткое описание бита              |
|---------|---------------|--------------------------------------------------------------------|
| л⊻оита  | бита          | назначения и принимаемых значений                                  |
| 31 – 10 | ctrl_base_ptr | Указатель на базовый адрес первичной структуры управляющих данных. |
| 9-0     | -             | Не определено. Следует записывать 0.                               |

3.10.3.10 Регистр ALT\_CTRL\_BASE\_PTR (регистр базового адреса альтернативных управляющих данных каналов)

Регистр ALT\_CTRL\_BASE\_PTR имеет доступ только на чтение. Регистр возвращает при чтении указатель базового адреса альтернативных управляющих данных каналов. Если контроллер находится в состоянии сброса, то чтение регистра запрещено. Этот регистр позволяет не производить вычисления базового адреса альтернативных управляющих данных каналов.

Таблица 3.10.24 содержит конфигурацию разрядов регистра базового адреса альтернативных управляющих данных каналов.

Таблица 3.10.24 — Конфигурация разрядов регистра базового адреса альтернативных управляющих данных каналов

| № бита | 31 – 0            |
|--------|-------------------|
| Доступ | RO                |
| Сброс  | 0                 |
|        | Alt_ctrl_base_ptr |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 114  |

Копировал

Таблица 3.10.25 — Описание регистра alt\_ctrl\_base\_ptr

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | alt_ctrl_base_ptr | Указатель базового адреса альтернативной структуры управляющих данных                   |

3.10.3.11 Регистр WAITONREQ\_STATUS (регистр статуса ожидания запроса на обработку каналов)

Регистр WAITONREQ\_STATUS имеет доступ только на чтение. Регистр возвращает при чтении состояние сигналов dma\_waitonreq[]. Если контроллер находится в состоянии сброса, то чтение регистра запрещено.

Таблица 3.10.26 содержит конфигурацию регистра статуса ожидания запроса на обработку каналов.

Таблица 3.10.26 — Конфигурация разрядов регистра статуса ожидания запроса на обработку каналов

| № бита | 23                                           | •••• | 2                                           | 1                                           | 0                                           |
|--------|----------------------------------------------|------|---------------------------------------------|---------------------------------------------|---------------------------------------------|
| Доступ | RO                                           |      | RO                                          | RO                                          | RO                                          |
| Сброс  | 0                                            |      | 0                                           | 0                                           | 0                                           |
|        | dma_waitonreg_status<br>for dma_waitnreg[23] | :    | dma_waitonreg_status<br>for dma_waitnreg[2] | dma_waitonreg_status<br>for dma_waitnreg[1] | dma_waitonreg_status<br>for dma_waitnreg[0] |

Таблица 3.10.27 содержит конфигурацию разрядов регистра статуса ожидания запроса на обработку каналов.

Таблица 3.10.27 — Описание регистра dma waitonreg status

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование бита    | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                               |
|--------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 0 | dma_waitonreq_status | Состояние сигналов ожидания запроса на обработку каналов DMA. При чтении: Разряд [C] = 0 означает, что dma_waitonreq[C] в состоянии «0» Разряд [C] = 1 означает, что dma_waitonreq[C] в состоянии «1» |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 115  |

Копировал

3.10.3.12 Регистр CHNL\_SW\_REQUEST (регистр программного запроса на обработку каналов)

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

Таблица 3.10.28 содержит конфигурацию разрядов регистра программного запроса на обработку каналов.

Таблица 3.10.28 — Регистр программного запроса на обработку каналов

| № бита | 31 – 24 | 23                                  | <br>2                              | 1                                  | 0                                  |
|--------|---------|-------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| Доступ | U       | WO                                  | <br>WO                             | WO                                 | WO                                 |
| Сброс  | 0       | 0                                   | <br>0                              | 0                                  | 0                                  |
|        | I       | Cgnl_sw_request for<br>channel [23] | Cgnl_sw_request for<br>channel [2] | Cgnl_sw_request for<br>channel [1] | Cgnl_sw_request for<br>channel [0] |

Таблица 3.10.29 содержит назначение разрядов регистра chnl\_sw\_request.

Таблица 3.10.29 — Описание регистра chnl sw request

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 0 | chnl_sw_request   | Устанавливает соответствующий разряд для генерации программного запроса на выполнение цикла DMA по соответствующему каналу DMA. При записи: Разряд [C] = 0 означает, что запрос на выполнение цикла DMA по каналу «С» не будет установлен; Разряд [C] = 1 означает, что запрос на выполнение цикла DMA по каналу «С» будет установлен. Запись разряда, соответствующего нереализованному каналу, означает, что запрос на выполнение цикла DMA не будет установлен |

3.10.3.13 Регистр CHNL\_USEBURST\_SET (регистр установки пакетного обмена каналов)

Perucтр CHNL\_USEBURST\_SET имеет доступ на чтение и запись. Регистр отключает выполнение одиночных запросов по установке dma\_sreq[], и поэтому

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 116  |

Копировал

будут обрабатываться и исполняться только запросы по dma\_req[]. Регистр возвращает при чтении состояние установок пакетного обмена.

Таблица 3.10.30 содержит конфигурацию разрядов регистра установки пакетного обмена каналов.

Таблица 3.10.30 — Конфигурация разрядов регистра установки пакетного обмена каналов

| № бита | 31 - 24 | 23                                    |          | 2                                    | 1                                    | 0                                    |
|--------|---------|---------------------------------------|----------|--------------------------------------|--------------------------------------|--------------------------------------|
| Доступ | U       | WO                                    |          | WO                                   | WO                                   | WO                                   |
| Сброс  | 0       | 0                                     |          | 0                                    | 0                                    | 0                                    |
|        | ı       | Chnl_useburst_set<br>for channel [23] | <u>:</u> | Chnl_useburst_set<br>for channel [2] | Chnl_useburst_set<br>for channel [1] | Chnl_useburst_set<br>for channel [0] |

Таблица 3.10.31 содержит конфигурацию разрядов регистра chnl\_useburst\_set.

Таблица 3.10.31 — Описание регистра chnl useburst set

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 0 | chnl_useburst_set    | Отключает обработку запросов на выполнение циклов DMA от dma_sreq[] и возвращает при чтении состоянии этих настроек. При чтении:  Разряд [C] = 0 означает, что канал DMA C выполняет циклы DMA в ответ на запросы, полученные от dma_sreq[] и dma_req[]. Контроллер выполняет одиночные передачи или 2R передач. Разряд [C] = 1 означает, что канал DMA C выполняет циклы DMA в ответ на запросы, полученные только от dma_req[]. Контроллер выполняет 2R передач. При записи:  Разряд [C] = 0 не дает эффекта. Необходимо использовать chil_useburst_clr регистр и установить соответствующий разряд C в 0;  Разряд [C] = 1 отключает возможность обрабатывать запросы на выполнение циклов DMA, полученные от dma_sreq[]. Контроллер выполняет 2R передач.  Запись разряда, соответствующего нереализованному каналу, не даёт эффекта. |

После выполнения предпоследней передачи из 2R передач, в том случае, если число оставшихся передач (N) меньше чем 2R, контроллер сбрасывает разряд chnl\_useburst\_set в «0». Это позволяет выполнять оставшиеся передачи, используя dma\_sreq[] и dma\_req[].

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 117  |

Примечание — При программировании channel\_cfg значением N меньшим, чем 2R, запрещена установка соответствующего разряда chnl\_useburst\_set в случае, если периферийный блок не поддерживает сигнал dma\_req[].

В режиме работы с периферией «исполнение с изменением конфигурации», если разряд next\_useburst установлен в channel\_cfg, то контроллер устанавливает chnl\_useburst\_set[C] в «1» после окончания цикла DMA, использующего альтернативные управляющие данные.

3.10.3.14 Perucтp CHNL\_USEBURST\_CLR (регистр сброса пакетного обмена каналов) Perucтp CHNL\_USEBURST\_CLR имеет доступ только на запись. Perucтp разрешает выполнение одиночных запросов по установке dma sreq[].

Таблица 3.10.32 содержит конфигурацию разрядов регистра сброса пакетного обмена каналов.

Таблица 3.10.32 — Конфигурация разрядов регистра сброса пакетного обмена каналов

| № бита | 31 – 24 | 23                                    | <br>2                                    | 1                                    | 0                                    |
|--------|---------|---------------------------------------|------------------------------------------|--------------------------------------|--------------------------------------|
| Доступ | U       | WO                                    | <br>WO                                   | WO                                   | WO                                   |
| Сброс  | 0       | 0                                     | <br>0                                    | 0                                    | 0                                    |
|        | 1       | Chnl_useburst_clr<br>for channel [23] | <br>Chnl_useburst_clr<br>for channel [2] | Chnl_useburst_clr<br>for channel [1] | Chnl_useburst_clr<br>for channel [0] |

Таблица 3.10.33 содержит назначение разрядов регистра chnl useburst clr.

Таблица 3.10.33 — Описание регистра chnl useburst clr

| № бита | Наименование      | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻онта | бита              | назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23 – 0 | chnl_useburst_clr | Установка соответствующего разряда разрешает обработку запросов на выполнение циклов DMA от dma_sreq[]. При записи: Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_useburst_set регистр для отключения обработки запросов от dma_sreq[]; Разряд [C] = 1 разрешает обрабатывать запросы на выполнение циклов DMA, полученные от dma_sreq[]. Запись разряда, соответствующего нереализованному каналу, не даёт никакого эффекта. |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

118

3.10.3.15 Регистр CHNL\_REQ\_MASK\_SET (регистр маскирования запросов на обслуживание каналов)

Регистр CHNL\_REQ\_MASK\_SET имеет доступ на чтение и запись. Регистр отключает установку запросов на выполнение циклов DMA на dma\_sreq[] и dma\_req[]. Регистр возвращает при чтении состояние установок маскирования запросов от dma\_sreq[] и dma\_req[] на обслуживание каналов.

Таблица 3.10.34 содержит конфигурацию разрядов регистра маскирования запросов на обслуживание каналов.

Таблица 3.10.34 — Конфигурация разрядов регистра маскирования запросов на обслуживание каналов

| № бита | 31 – 24 | 23                                                    | <br>2                                                    | 1                                                    | 0                                                    |
|--------|---------|-------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|
| Доступ | U       | WO                                                    | <br>WO                                                   | WO                                                   | WO                                                   |
| Сброс  | 0       | 0                                                     | <br>0                                                    | 0                                                    | 0                                                    |
|        | I       | Chnl_reg_mask_set<br>for dma_reg and<br>dma_sreg [23] | <br>Chnl_reg_mask_set<br>for dma_reg and<br>dma_sreg [2] | Chnl_reg_mask_set<br>for dma_reg and<br>dma_sreg [1] | Chnl_reg_mask_set<br>for dma_reg and<br>dma_sreg [0] |

Таблица 3.10.35 содержит назначение разрядов регистра chnl\_req\_mask\_set.

Таблица 3.10.35 — Описание регистра chnl\_req\_mask\_set

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| № Оита | таименование оита | назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23 – 0 | chnl_req_mask_set | Отключает обработку запросов по dma_sreq[] и dma_req[] на выполнение циклов DMA от каналов и возвращает при чтении состоянии этих настроек. При чтении: Разряд [C] = 0 означает, что канал DMA C выполняет циклы DMA в ответ на поступающие запросы; Разряд [C] = 1 означает, что канал DMA C не выполняет циклы DMA в ответ на поступающие запросы. При записи: Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_req_mask_clr регистр для разрешения установки запросов; Разряд [C] = 1 отключает установку запросов на выполнение циклов DMA, по dma_sreq[] и dma_req[]. Запись разряда, соответствующего нереализованному каналу, не даёт никакого эффекта. |

119

3.10.3.16 Регистр CHNL\_REQ\_MASK\_CLR (регистр очистки маскирования запросов на обслуживание каналов)

Perистр CHNL\_REQ\_MASK\_CLR имеет доступ только на запись. Perистр разрешает установку запросов на выполнение циклов DMA на dma\_sreq[] и dma\_req[].

Таблица 3.10.36 содержит конфигурацию разрядов регистра очистки маскирования запросов на обслуживание каналов.

Таблица 3.10.36 — Конфигурация разрядов регистра очистки маскирования запросов на обслуживание каналов

| № бита | 31 – 24 | 23                                                    |   | 2                                                    | 1                                                    | 0                                                    |
|--------|---------|-------------------------------------------------------|---|------------------------------------------------------|------------------------------------------------------|------------------------------------------------------|
| Доступ | U       | WO                                                    |   | WO                                                   | WO                                                   | WO                                                   |
| Сброс  | 0       | 0                                                     |   | 0                                                    | 0                                                    | 0                                                    |
|        | I       | Chnl_reg_mask_clr<br>for dma_reg and<br>dma_sreg [23] | : | Chnl_reg_mask_clr<br>for dma_reg and<br>dma_sreg [2] | Chnl_reg_mask_clr<br>for dma_reg and<br>dma_sreg [1] | Chnl_reg_mask_clr<br>for dma_reg and<br>dma_sreg [0] |

Таблица 3.10.37 содержит назначение разрядов регистра chnl req mask clr.

Таблица 3.10.37 — Описание регистра chnl\_req\_mask\_clr

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 0 | chnl_req_mask_clr | Установка соответствующего разряда разрешает установку запросов по dma_sreq[] и dma_req[] на выполнение циклов DMA от каналов. При записи: Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_req_mask_set регистр для отключения установки запросов; Разряд [C] = 1 разрешает установку запросов на выполнение циклов DMA, по dma_sreq[] и dma_req[]. Запись разряда, соответствующего нереализованному каналу, не даёт никакого эффекта. Разряд [C] = 1 отключает установку запросов на выполнение циклов DMA, по dma_sreq[] и dma_req[]. Запись разряда, соответствующего нереализованному каналу, не даёт эффекта. |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

3.10.3.17 Регистр CHNL\_ENABLE\_SET (регистр установки разрешения каналов)

Регистр CHNL\_ENABLE\_SET имеет доступ на чтение и запись. Регистр разрешает работу каналов DMA. Регистр возвращает при чтении состояние разрешений работы каналов DMA.

Таблица 3.10.38 содержит конфигурацию разрядов регистра установки разрешения каналов.

Таблица 3.10.38 — Конфигурация разрядов регистра установки разрешения каналов

| № бита | 31 – 24 | 23                                  |   | 2                                  | 1                                  | 0                                  |
|--------|---------|-------------------------------------|---|------------------------------------|------------------------------------|------------------------------------|
| Доступ | U       | WO                                  |   | WO                                 | WO                                 | WO                                 |
| Сброс  | 0       | 0                                   |   | 0                                  | 0                                  | 0                                  |
|        | I       | Chnl_enable_set<br>for cgannel [23] | : | Chnl_enable_set<br>for cgannel [2] | Chnl_enable_set<br>for cgannel [1] | Chnl_enable_set<br>for cgannel [0] |

Таблица 3.10.39 содержит назначение разрядов регистра chnl\_enable\_set.

Таблица 3.10.39 — Описание регистра chnl enable set

запрещает функционирование каналов DMA.

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                        |
|--------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 0 | chnl_enable_set      | Разрешает работу каналов DMA и возвращает при чтении состоянии этих настроек. При чтении: Разряд [C] = 0 означает, что канал DMA C отключен; Разряд [C] = 1 означает, что функционирование канала DMA C разрешено. При записи: Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_enable_clr регистр для отключения канала; Разряд [C] = 1 разрешает работу канала DMA C. Запись разряда, соответствующего нереализованному каналу, не дает эффекта. |

3.10.3.18 Perистр CHNL\_ENABLE\_CLR (регистр сброса разрешения каналов) Perистр CHNL\_ENABLE\_CLR имеет доступ только на запись. Регистр

Таблица 3.10.40 содержит конфигурацию разрядов регистра сброса разрешения каналов.

|    |        |          |       |      | Микросхема интегральная 5023ВС016                    | Лист |
|----|--------|----------|-------|------|------------------------------------------------------|------|
| Из | м Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 121  |

Таблица 3.10.40 — Конфигурация разрядов регистр сброса разрешения каналов

| № бита | 31 – 24 | 23                                  | <br>2                                  | 1                                  | 0                                  |
|--------|---------|-------------------------------------|----------------------------------------|------------------------------------|------------------------------------|
| Доступ | U       | WO                                  | <br>WO                                 | WO                                 | WO                                 |
| Сброс  | 0       | 0                                   | <br>0                                  | 0                                  | 0                                  |
|        | I       | Chnl_enable_clr<br>for cgannel [23] | <br>Chnl_enable_clr<br>for cgannel [2] | Chnl_enable_clr<br>for cgannel [1] | Chnl_enable_clr<br>for cgannel [0] |

Таблица 3.10.41 содержит назначение разрядов регистра chnl enable clr.

Таблица 3.10.41 — Описание регистра chnl enable clr

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

| № бита           | Наименование бита                  | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| № бита<br>23 – 0 | Наименование бита  chnl_enable_clr | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений  Установка соответствующего разряда запрещает работу соответствующего канала DMA.  При записи:  Разряд [С] = 0 не дает эффекта. Необходимо использовать chnl_enable_set регистр для разрешения работы канала;  Разряд [С] = 1 запрещает работу канала DMA С.  Запись разряда, соответствующего нереализованному каналу, не дает никакого эффекта.  Примечание:  Контроллер может отключить канал DMA, установив соответствующий разряд в следующих случаях:  — при завершении цикла DMA;  — при чтении из channel_cfg с полем cycle_ctrl установленным вb000; |
|                  |                                    | — при появлении ошибки на шине AHB-Lite.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

3.10.3.19 Регистр CHNL\_PRI\_ALT\_SET (регистр установки первичной/альтернативной структуры управляющих данных каналов)

Регистр CHNL\_PRI\_ALT\_SET имеет доступ на запись и чтение. Регистр разрешает работу канала DMA с использованием альтернативной структуры управляющих данных. Результатом чтения регистра является состояние каналов DMA (какую структуру управляющих данных использует каждый канал DMA).

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

 Микросхема интегральная 5023BC016
 Лист

 Техническое описание
 Техническое описание

 Изм Лист
 № докум.
 Подп.

 Дата
 Версия 2.04 от 01.09.2017 г.
 122

Формат А4

Копировал

## Таблица 3.10.42 — Конфигурация разрядов регистра установки первичной/альтернативной структуры управляющих данных каналов

| № бита | 31 – 24 | 23                   |   | 2                    | 1                   | 0       |
|--------|---------|----------------------|---|----------------------|---------------------|---------|
| Доступ | U       | WO                   |   | WO                   | WO                  | WO      |
| Сброс  | 0       | 0                    |   | 0                    | 0                   | 0       |
|        |         |                      |   |                      |                     |         |
|        |         | _set<br>[23]         |   | _set<br>[2]          | set                 | set [0] |
|        |         | · —                  |   | ! <del>-</del>       |                     | . —     |
|        |         | l_pri_alt<br>cgannel |   | l_pri_alt<br>cgannel | _pri_alt<br>cgannel | cgannel |
|        |         | · —                  |   | `-                   |                     |         |
|        | I       | Chr                  | : | Chr                  | Chr                 | Chr     |

Таблица 3.10.43 содержит назначение разрядов регистра chnl\_pri\_alt\_set.

## Таблица 3.10.43 — Описание регистра chnl\_pri\_alt\_set

| № оита                                                                                                                                     | ленование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений  Установка соответствующего разряда подключает использование альтернативных управляющих данных для соответствующего канала DMA, чтение возвращает состояние этих настроек.  При чтении:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gama.                                                                                                                                      |                   | альтернативных управляющих данных для соответствующего канала DMA, чтение возвращает состояние этих настроек. При чтении:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| одл. и дата Взам. инв. № дубл. и дата Сhnl <sup>-</sup> . | _pri_alt_set      | Разряд [С] = 0 означает, что канал DMA С использует первичную структуру управляющих данных; Разряд [С] = 1 означает, что канал DMA С использует альтернативную структуру управляющих данных. При записи: Разряд [С] = 0 не дает эффекта. Необходимо использовать chnl_pri_alt_clr регистр для сброса разряда [С] в 0; Разряд [С] = 1 подключает использование альтернативной структуры управляющих данных каналом DMA С. Запись разряда, соответствующего нереализованному каналу, не даёт никакого эффекта. Примечание — Контроллер может переключить значение разряда chnl_pri_alt_set[С] в следующих случаях: — при завершении 4-х передач DMA указанных в первичной структуре управляющих данных при выполнении цикла DMA в режимах работы с памятью или периферией «исполнение с изменением конфигурации»; — при завершении всех передач DMA указанных в первичной структуре управляющих данных при выполнении цикла DMA в режиме «Пинг-понг»; — при завершении всех передач DMA указанных в альтернативной структуре управляющих данных при выполнении цикла DMA в режиме «Пинг-понг»; — при завершении всех передач DMA указанных в альтернативной структуре управляющих данных при выполнении цикла DMA в режимах: |

123

3.10.3.20 Регистр CHNL\_PRI\_ALT\_CLR (регистр сброса первичной/альтернативной структуры управляющих данных каналов)

Регистр CHNL\_PRI\_ALT\_CLR имеет доступ только на запись. Регистр разрешает работу канала DMA с использованием первичной структуры управляющих данных.

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

Таблица 3.10.44 — Конфигурация разрядов регистра сброса первичной/альтернативной структуры управляющих данных каналов

| № бита | 31 – 24 | 23                   | <br>2                | 1                   | 0                    |
|--------|---------|----------------------|----------------------|---------------------|----------------------|
| Доступ | U       | WO                   | <br>WO               | WO                  | WO                   |
| Сброс  | 0       | 0                    | <br>0                | 0                   | 0                    |
|        |         |                      |                      |                     |                      |
|        |         | clr<br>23]           | clr<br>[2]           | _clr.               | _clr<br>[0]          |
|        |         | 122                  | —                    |                     |                      |
|        |         | L_pri_alt<br>cgannel | L_pri_alt<br>cgannel | _pri_alt<br>cgannel | l_pri_alt<br>cgannel |
|        |         | · ·                  | nl_f                 | Tall                | nl_r<br>r cg         |
|        | 1       | Chnl                 | Chnl]<br>for (       | Chnl<br>for         | Chnl<br>for          |

Таблица 3.10.45 содержит назначение разрядов регистра chnl\_pri\_alt\_clr.

Таблица 3.10.45— Описание регистра chnl\_pri\_alt\_clr

|          | TT               | A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| № бита   | Наименование     | Функциональное назначение бита, краткое описание бита назначения и                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Ji_ Oniu | бита             | принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23 – 0   | chnl_pri_alt_clr | Установка соответствующего разряда подключает использование первичных управляющих данных для соответствующего канала DMA. При записи: «Разряд [C] = 0» не даёт эффекта. Необходимо использовать chnl_pri_alt_set регистр для выбора альтернативных управляющих данных; «Разряд [C] = 1» подключает использование первичной структуры управляющих данных каналом DMA C. Запись разряда, соответствующего нереализованному каналу, не даёт эффекта. Примечание — Контроллер может изменять значение разряда chnl_pri_alt_clr[C] в случаях завершения следующих передач: — 4-х передач DMA указанных в первичной структуре управляющих данных при выполнении цикла DMA в режиме «Scatter-gather»; — всех передач DMA указанных в первичной структуре управляющих данных при выполнении цикла DMA в режиме «пинг-понг»; — всех передач DMA указанных в альтернативной структуре управляющих данных при выполнении цикла DMA в режиме «пинг-понг»; «Scatter-gather» с памятью; «Scatter-gather» с периферией |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

3.10.3.21 Регистр CHNL\_PRIORITY\_SET (регистр установки приоритета каналов)

Регистр CHNL\_PRIORITY\_SET имеет доступ на запись и чтение. Регистр позволяет присвоить высокий приоритет каналу DMA. Чтение регистра возвращает состояние приоритета каналов DMA.

Таблица 3.10.46 содержит конфигурацию разрядов регистра установки приоритета каналов.

Таблица 3.10.46 — Конфигурация разрядов регистра установки приоритета каналов

| № бита | 31 – 24 | 23                                    | <br>2                                    | 1                                    | 0                                    |
|--------|---------|---------------------------------------|------------------------------------------|--------------------------------------|--------------------------------------|
| Доступ | U       | WO                                    | <br>WO                                   | WO                                   | WO                                   |
| Сброс  | 0       | 0                                     | <br>0                                    | 0                                    | 0                                    |
|        | I       | Chnl_prioriti_set<br>for cgannel [23] | <br>Chnl_prioriti_set<br>for cgannel [2] | Chnl_prioriti_set<br>for cgannel [1] | Chnl_prioriti_set<br>for cgannel [0] |

Таблица 3.10.47 содержит назначение разрядов регистра chnl priority set.

Таблица 3.10.47 — Описание регистра chnl\_priority\_set

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 0 | chnl_priority_set | Установка высокого приоритета каналу DMA, чтение возвращает состояние приоритета каналов DMA. При чтении: Разряд [C] = 0 означает, что каналу DMA «С» присвоен уровень приоритета по умолчанию; Разряд [C] = 1 означает, что каналу DMA «С» присвоен высокий уровень приоритета. При записи: Разряд [C] = 0 не дает эффекта. Необходимо использовать chnl_priority_clr регистр для установки каналу С уровня приоритета по умолчанию; Разряд [C] = 1 устанавливает каналу DMA «С» высокий уровень приоритета. Запись разряда, соответствующего нереализованному каналу, не дает эффекта. |

3.10.3.22 Perистр CHNL\_PRIORITY\_CLR (регистр сброса приоритета каналов) Регистр CHNL\_PRIORITY\_CLR имеет доступ только на запись. Регистр позволяет присвоить каналу DMA-уровень приоритета по умолчанию.

| Микросхема интегральная в<br>Техническое описан |      |
|-------------------------------------------------|------|
| Подп. Дата Версия 2.04 om 01.09.201             | 10.5 |

Таблица 3.10.48 содержит конфигурацию разрядов регистра сброса приоритета каналов.

Таблица 3.10.48 — Конфигурация разрядов регистра сброса приоритета каналов

| № бита | 31 – 24 | 23                                    |   | 2                                    | 1                                    | 0                                    |
|--------|---------|---------------------------------------|---|--------------------------------------|--------------------------------------|--------------------------------------|
| Доступ | U       | WO                                    |   | WO                                   | WO                                   | WO                                   |
| Сброс  | 0       | 0                                     |   | 0                                    | 0                                    | 0                                    |
|        | I       | Chnl_prioriti_clr<br>for cgannel [23] | : | Chnl_prioriti_clr<br>for cgannel [2] | Chnl_prioriti_clr<br>for cgannel [1] | Chnl_prioriti_clr<br>for cgannel [0] |

Таблица 3.10.49 содержит назначение разрядов регистра chnl\_priority\_clr.

Таблица 3.10.49 — Описание регистра chnl priority clr

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                               |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 0 | chnl_priority_clr | Установка разряда присваивает соответствующему каналу DMA уровень приоритета по умолчанию. При записи: Разряд [C] = 0 не даёт эффекта. Необходимо использовать chnl_priority_set регистр для установки каналу «С» высокого уровня приоритета. Разряд [C] = 1 устанавливает каналу DMA «С» уровень приоритета по умолчанию. Запись разряда, соответствующего нереализованному каналу, не дает эффекта. |

## 3.10.3.23 Регистр ERR CLR (регистр сброса флага ошибки)

Регистр ERR\_CLR имеет доступ на запись и чтение. Регистр позволяет сбрасывать сигнал dma\_err в «0». Чтение регистра возвращает состояние сигнала dma\_err.

Таблица 3.10.50 содержит конфигурацию разрядов регистра сброса флага ошибки.

Таблица 3.10.50 — Конфигурация разрядов регистра сброса флага ошибки

| № бита | 31 – 1 | 0       |
|--------|--------|---------|
| Доступ | U      | RW      |
| Сброс  | 0      | 0       |
|        | _      | err_clr |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 126  |

Копировал

Таблица 3.10.51 — Описание регистра err clr

| № бита | Наименование      | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| л⊻онта | бита              | назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 31 – 1 | _                 | Не определено. Следует записывать 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 23 – 0 | chnl_priority_clr | Установка сигнала в состояние 0, чтение возвращает состояние сигнала (флага) dma_err. При чтении: Разряд [C] = 0 означает, что dma_err находится в состоянии «0»; Разряд [C] = 1 означает, что dma_err находится в состоянии «1». При записи: Разряд [C] = 0 не дает эффекта. Состояние dma_err останется неизменным; Разряд [C] = 1 сбрасывает сигнал (флаг) dma_err в состояние «0». Для целей тестирования возможно использовать регистр err_set, чтобы установить сигнал dma_err в состояние «1». Примечание: При сбросе сигнала dma_err одновременно с появлением ошибки на шине АНВ-Lite, то приоритет отдается ошибке и, следовательно, значение регистра (и dma_err) останется неизменным (несброшенным). |  |  |

#### 3.11 Контроллер интерфейса SPI

#### 3.11.1 Общие положения

Инв. № дубл.

Взам. инв. №

Подп. и дата

SPI интерфейса Контроллер интерфейса выполняет функции последовательной синхронной связи в режиме ведущего и ведомого устройства и обеспечивает обмен данными ведущим c подключенным ведомым или периферийным устройством в соответствии с одним из протоколов:

- интерфейс SPI фирмы Motorola;
- интерфейс SSI фирмы Texas Instruments;
- интерфейс Microwire фирмы National Semiconductor.

Как в ведущем, так и в ведомом режиме работы модуль SPI обеспечивает:

- преобразование данных, размещенных во внутреннем буфере FIFO передатчика (восемь 16-разрядных ячеек данных), ИЗ параллельного последовательный формат;
- преобразование данных из последовательного в параллельный формат и их запись в аналогичный буфер FIFO приёмника (восемь 16-разрядный ячеек данных).

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 127  |
|     |      |          |       |      |                                   |      |

Копировал

|              | -                                                                                    | — програм    | ммируе  | мая дл  | тельность инфо  | ормационн                     | ого кад        | ра от 4 | до 16 бит  | •    |  |  |
|--------------|--------------------------------------------------------------------------------------|--------------|---------|---------|-----------------|-------------------------------|----------------|---------|------------|------|--|--|
|              | — независимое маскирование прерываний от буфера FIFO передатчика,                    |              |         |         |                 |                               |                |         |            |      |  |  |
|              | буфера FIFO приёмника, а также по переполнению буфера приёмника;                     |              |         |         |                 |                               |                |         |            |      |  |  |
|              | <ul> <li>доступна возможность тестирования по шлейфу, соединяющему вход с</li> </ul> |              |         |         |                 |                               |                |         |            |      |  |  |
|              | выход                                                                                | OM;          |         |         |                 |                               |                |         |            |      |  |  |
|              | -                                                                                    | — поддер:    | жка пря | імого , | оступа к памяти | и (DMA).                      |                |         |            |      |  |  |
|              | (                                                                                    | Структурн    | ая схем | иа мод  | ля SPI представ | влена на ри                   | ісунке 3       | 3.11.1. |            |      |  |  |
| ia.          | (                                                                                    | Состав мо    | дуля: н | езавис  | мые буферы пр   | оиёма и пер                   | редачи (       | (8 ячее | к по 16 би | т) с |  |  |
| u dam        | организацией доступа типа FIFO.                                                      |              |         |         |                 |                               |                |         |            |      |  |  |
| Подп. и дата | ,                                                                                    | 3 11 3 Про   | грамми  | пуемь   | е параметры ин  | терфейса S                    | SPI            |         |            |      |  |  |
| бл.          |                                                                                      | _            | _       |         |                 |                               |                | IOTVT ( | быть зала  | аны  |  |  |
| Инв. № дубл. | Следующие ключевые параметры интерфейса SPI могут быть программно:                   |              |         |         |                 |                               |                |         |            |      |  |  |
| Инв.         |                                                                                      |              | функц   | ионир   | вания перифер   | рийного vo                    | стройсть       | ва —    | велушее    | или  |  |  |
| . No         | ведом                                                                                | _            | 47      | г       | -w              |                               | - TP 0-11-0-11 |         | 204) 400   |      |  |  |
| Взам. инв. № |                                                                                      |              | ение ил | іи запт | т функциониро   | вания:                        |                |         |            |      |  |  |
| Вза          |                                                                                      |              |         |         | ного кадра;     | ,                             |                |         |            |      |  |  |
|              |                                                                                      | — скорост    |         |         | _               |                               |                |         |            |      |  |  |
| ıa           |                                                                                      |              | _       |         | тового сигнала  | , <b>.</b>                    |                |         |            |      |  |  |
| u dama       |                                                                                      | -            | -       |         |                 |                               |                |         |            |      |  |  |
| Подп. и д    | -                                                                                    | — размер     | олока д | цанных  | — от 4 до 16 би | ИТ;                           |                |         |            |      |  |  |
|              | -                                                                                    | — маскир     | ование  | преры   | аний.           |                               |                |         |            |      |  |  |
| le nod.      |                                                                                      |              |         |         | Микросхе        | ема интегра                   | льная 50       | )23BC01 | 6          | Лист |  |  |
| Инв. № подл. | Изм Лист                                                                             | No gokva     | Подп.   | Дата    | T               | ехническое<br>ерсия 2.04 от ( | описание       | Э       |            | 128  |  |  |
| 1            | , iown Tucill                                                                        | 112 OONYIWI. | 110011. |         | опировал        | ,                             |                |         | ормат А4   |      |  |  |
|              |                                                                                      |              |         |         |                 |                               |                |         |            |      |  |  |

Модуль SPI формирует сигналы прерываний по следующим событиям:

— переполнение буфера FIFO приёмника;

3.11.2 Основные характеристики интерфейса SPI

Интерфейс SPI имеет следующие характеристики:

— программное управление скоростью обмена;

— функционирование в ведущем и в ведомом режимах;

— необходимость обслуживания буферов FIFO приёмника и передатчика;

— наличие данных в буфере FIFO приёмника по истечении времени таймаута.

— программный выбор одного из интерфейсов обмена: SPI, Microwire, SSI;

#### 3.11.4 Характеристики интерфейса SPI фирмы Motorola

Последовательный синхронный интерфейс SPI фирмы Motorola обеспечивает:

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

Интерфейс Microwire фирмы National Semiconductors обеспечивает полудуплексный обмен данными с использованием восьмибитных управляющих последовательностей.

Интерфейс SSI фирмы Texas Instruments обеспечивает:

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



Рисунок 3.11.1 — Структурная схема модуля SPI

Изм Лист № докум. Подп. Дата

Тодп. и дата

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

129

Взам. инв. №

нв. № подл.

#### 3.11.5 Функциональное описание интерфейса SPI

#### 3.11.5.1 Общие сведения об интерфейсе SPI

Модуль SPI содержит программируемые делители частоты, формирующие тактовый сигнал обмена данными SPI\_SCK. Скорость передачи данных может достигать более 2 МГц, в зависимости от частоты SPICLK и характеристик подключенного периферийного устройства.

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

Модуль формирует четыре независимо маскируемых прерывания:

- SPITXINTR запрос на обслуживание буфера передатчика;
- SPIRXINTR запрос на обслуживание буфера приёмника;
- SPIRORINTR переполнение приёмного буфера FIFO;
- SPIRTINTR таймаут ожидания чтения данных из приёмного FIFO.

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

Модуль формирует сигналы запроса на прямой доступ к памяти (DMA) для совместной работы с контроллером DMA.

В зависимости от режима работы модуля сигнал SPISSOUT используется либо для кадровой синхронизации (интерфейс SSI, активное состояние — высокий уровень), либо для выбора ведомого режима (интерфейсы SPI и Microwire, активное состояние — низкий уровень).

## 3.11.5.2 Блок формирования тактового сигнала

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

Путём записи значения в регистр SPICPSR можно задать коэффициент предварительного деления частоты в диапазоне от 2 до 254 с шагом 2. Так как младший значащий разряд коэффициента деления не используется, то исключается

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Сформированный описанным образом сигнал далее поступает на второй делитель частоты, с выхода которого и снимается тактовый сигнал обмена данными SPI\_SCK.

Коэффициент деления второго делителя задается программно в диапазоне от 1 до 256, путем записи соответствующего значения в регистр управления SPICRO.

#### 3.11.5.3 Буфер FIFO передатчика

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

#### 3.11.5.4 Буфер FIFO приёмника

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

## 3.11.5.5 Блок приёма и передачи данных

В режиме ведущего устройства модуль формирует тактовый сигнал обмена данными SPI\_SCK для подключенных ведомых устройств. Как было описано ранее, данный сигнал формируется путём деления частоты сигнала SPICLK.

Блок передатчика последовательно считывает данные из буфера FIFO передатчика и производит их преобразование из параллельной формы в последовательную. Далее поток последовательных данных и элементов кадровой синхронизации, тактированный сигналом SPI\_SCK, передаётся по линии SPI\_MOSI к подключенным ведомым устройствам.

Изм Лист № докум. Подп. Дата

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

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

При этом блок передатчика, тактируемый этим внешним сигналом, считывает данные из буфера FIFO, преобразует их из параллельной формы в последовательную, после чего выдает поток последовательных данных и элементов кадровой синхронизации в линию SPI\_MOSI.

Аналогично, блок приёмника выполняет преобразование данных, поступающих с линии SPI\_MISO синхронно с сигналом SPI\_SCK, из последовательной в параллельную форму, после чего загружает их в буфер FIFO приёмника, откуда последние могут быть считаны процессором.

#### 3.11.5.6 Блок формирования прерываний

Модуль SPI генерирует независимые маскируемые прерывания с активным высоким уровнем. Кроме того, формируется комбинированное прерывание путём объединения указанных независимых прерываний по схеме ИЛИ.

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

## 3.11.5.7 Интерфейс прямого доступа к памяти

Модуль обеспечивает интерфейс с контроллером DMA согласно схеме взаимодействия приёмопередатчика и контроллера DMA.

## 3.11.6 Функционирование модуля SPI

## 3.11.6.1 Конфигурирование приёмопередатчика

После сброса функционирование блоков приёмопередатчика запрещается до выполнения процедуры задания конфигурации.

| 1 |     |      |          |       |      |
|---|-----|------|----------|-------|------|
|   | Изм | Лист | № докум. | Подп. | Дата |

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Для этого необходимо выбрать ведущий или ведомый режим работы устройства, а также используемый протокол передачи данных (SPI фирмы Motorola, SSI фирмы Texas Instruments, либо Microwire фирмы National Semiconductor), после чего записать необходимую информацию в регистры управления CR0 и CR1.

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

#### 3.11.6.2 Разрешение работы приёмопередатчика

Разрешение осуществляется путём установки бита SSE регистра управления CR1. Буфер FIFO передатчика может быть либо проинициализирован путём записи в него до восьми 16-разрядных слов заблаговременно перед установкой этого бита, либо может заполняться передаваемыми данными в процедуре обслуживания прерывания.

После разрешения работы модуля приёмопередатчик начинает обмен данными по линиям SPI\_MOSI и SPI\_MISO.

#### 3.11.6.3 Соотношения между тактовыми сигналами

Инв. № дубл.

Взам. инв. №

Подп. и дата

В модуле имеется ограничение на соотношение между частотами тактовых сигналов CPU\_CLK и SPICLK. Частота SPICLK должна быть меньше или равна частоте CPU\_CLK

$$FSPICLK \leq FPCLK.$$
 (2)

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

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

|    |        |          |       |      | Микросхема интегральная 5023ВС016 | Л | lucm |
|----|--------|----------|-------|------|-----------------------------------|---|------|
|    |        |          |       |      | Техническое описание              |   | 122  |
| Из | и Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | - | 133  |

Копировал

Выбор частоты тактового сигнала SPICLK должен обеспечивать поддержку требуемого диапазона скоростей обмена данными. Отношение минимальной частоты сигнала SPICLK к максимальной частоте сигнала SPI\_SCK в режиме ведомого устройства равно 12, в режиме ведущего — двум.

Так, в режиме ведущего устройства для обеспечения максимальной скорости обмена 1,8432 Мбит/с частота сигнала SPICLK должна составлять не менее 3,6864 МГц. В этом случае в регистр CPSR должно быть записано значение 2, а поле SCR[7:0] регистра CR0 должно быть установлено в «0».

В режиме ведомого устройства для обеспечения той же информационной скорости необходимо использовать тактовый сигнал SPICLK с частотой не менее 22,12 МГц. При этом в регистр CPSR должно быть записано значение 12, а поле SCR[7:0] регистра CR0 должно быть установлено в «0».

3.11.6.4 Программирование регистра управления CR0

Регистр CR0 выполняет следующие функции:

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

Скорость информационного обмена зависит от частоты внешнего тактового сигнала и коэффициента деления блока формирования тактового сигнала. Последний задаётся совместно значением поля SerialClockRate (SCR) регистра SPICR и значением поля CPSDVSR (clockprescaledivisorvalue — коэффициент деления тактового сигнала) регистра SPICPSR.

Формат информационного кадра задаётся путём установки значения поля FRF, а размер слова данных — путём установки значения поля DSS регистра SPICR0.

Для протокола SPI фирмы Motorola также задаются полярность и фаза сигнала (биты SPH и SPO).

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Регистр SPICR1 выполняет следующие функции:

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

Выбор ведущего режима осуществляется путём записи «0» в поле MS регистра SPICR1 (это значение устанавливается после сброса автоматически).

Запись «1» в поле MS переводит приёмопередатчик в режим ведомого устройства. В этом режиме разрешение или запрещение формирования сигнала передатчика SPI MOSI SOD осуществляется путём установки бита (Slave mode Output Disable — запрет линии SPI\_MOSI для ведомого режима) регистра CR1. Указанная функция полезна при подключении к одной линии нескольких подчинённых устройств.

Для того чтобы разрешить функционирование приёмопередатчика, необходимо установить в 1 бит Synchronous Serial Port Enable (SSE).

#### 3.11.6.6 Формирование тактового сигнала обмена данными

Тактовый сигнал обмена данными формируется путём деления частоты тактового сигнала SPICLK. На первом этапе формирования частота этого сигнал делится на четный коэффициент CPSDVSR, лежащий в диапазоне от 2 до 254, доступный для программирования через регистр CPSR. Сформированный сигнал далее поступает на делитель частоты с коэффициентом (1 + SCR) от 1 до 256, где значение SCR доступно для программирования через CR0.

Частота выходного тактового сигнала обмена данными SPI SCK определяется следующим соотношением

$$FSPISCKOUT = FSPICLK / (CPSDVR \cdot (1 + SCR)). \tag{3}$$

Например, в случае, если частота сигнала SPICLK составляет 3,6864 МГц, а значение CPSDVSR = 2, частота сигнала SPI\_SCK лежит в интервале от 7,2 к $\Gamma$ ц до 1,8432 МГц.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |
|     |      |          |       |      | Копировал                         |

135

Лист

копировал

Инв. № дубл.

Взам. инв. №

Подп. и дата

Каждый информационный кадр содержит в зависимости от запрограммированного значения от 4 до 16 бит данных. Передача данных начинается со старшего значащего разряда. Возможно выбрать три базовых структуры построения кадра:

- SSI фирмы Texas Instruments;
- SPI фирмы Motorola;
- Microwire фирмы National Semiconductor.

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

В режимах SPI и Microwire выходной сигнал кадровой синхронизации передатчика SPI\_SS имеет активный низкий уровень и поддерживается в низком уровне в течение всего периода передачи информационного кадра.

В режиме построения кадра SSI перед началом каждого информационного кадра на выходе SPI\_SS формируется импульс с длительностью, равной одному тактовому интервалу обмена данными. В этом режиме приёмопередатчик SPI, равно как и ведомые периферийные устройства, передаёт данные в линию по переднему фронту сигнала SPI\_SCK, а считывает данные из линии по заднему фронту этого сигнала.

В отличие от полнодуплексных режимов передачи данных SSI и SPI, режим Microwire фирмы National Semiconductor использует специальный способ обмена данными между ведущим и ведомым устройством, функционирующий в режиме полудуплекса. В указанном режиме на внешнее ведомое устройство перед началом передачи информационного кадра посылается специальная восьмибитная управляющая последовательность. В течение всего времени передачи этой последовательности приёмник не обрабатывает каких-либо входных данных. После того, как сигнал передан и декодирован ведомым устройством, оно выдерживает

| Изм Лис | т № докум. | Подп. | Дата |
|---------|------------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

№ подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

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

#### 3.11.6.8 Формат синхронного обмена SSI фирмы Texas Instruments

Временные диаграммы, отображающие формат синхронного обмена протокола SSI (единичный обмен) представлены на рисунке 3.11.2.



Рисунок 3.11.2 — Временные диаграммы, отображающие формат синхронного обмена протокола SSI (единичный обмен)

В режиме синхронного обмена SSI при неактивном приёмопередатчике SPI сигналы SPI\_SCK и SPI\_SS переводятся в низкий логический уровень, а линия передачи данных SPI\_MOSI поддерживается в третьем состоянии.

После появления хотя бы одного элемента в буфере FIFO передатчика сигнал SPI\_SS переводится в высокий логический уровень на время, соответствующее одному периоду сигнала SPI\_SCK. Значение из буфера FIFO, при этом переносится в сдвиговый регистр блока передатчика. По следующему переднему фронту сигнала SPI\_SCK старший значащий разряд информационного кадра (4 – 16 бит данных) выдаётся на выход линии SPI\_MOSI и т.д.

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

чв. № подл.

В режиме приёма данных как модуль SPI, так и ведомое внешнее устройство последовательно загружают биты данных в сдвиговый регистр по заднему фронту сигнала SPI\_SCK. Принятые данные переносятся из сдвигового регистра в буфер FIFO после загрузки в него младшего значащего бита данных по очередному переднему фронту сигнала SPI\_SCK.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
| 1   |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 137  |

Копировал

Временные диаграммы последовательного синхронного обмена по протоколу SSI фирмы Texas Instruments представлены на рисунке 3.11.3.



Рисунок 3.11.3 — Формат синхронного обмена протокола SSI (непрерывный обмен)

#### 3.11.6.9 Формат синхронного обмена SPI фирмы Motorola

Интерфейс SPI фирмы Motorola организован посредством четырех сигнальных линий, при этом сигнал SPI\_SS выполняет функцию выбора ведомого устройства. Главной особенностью протокола SPI является возможность выбора состояния и фазы сигнала SPI\_SCK в режиме ожидания (неактивном приёмопередатчике) путём задания значений бит SPO и SPH регистра управления SPISCRO.

#### 3.11.6.10 Выбор полярности тактового сигнала

Для выбора полярности тактового сигнала используется бит SPO.

Если бит SPO равен «0», то в режиме ожидания линия SPI\_SCK переводится в низкий логический уровень. В противном случае при отсутствии обмена данными линия SPI\_SCK переводится в высокий логический уровень.

## 3.11.6.11 Выбор фазы тактового сигнала

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Для выбора фазы тактового сигнала используется бит SPH.

Значение бита SPH определяет фронт тактового сигнала, по которому осуществляется выборка данных и изменение состояния на выходе линии.

В случае если бит SPH установлен в «0», регистрация данных приёмником осуществляется после первого обнаружения фронта тактового сигнала, в противном случае — после второго.

 Микросхема интегральная 5023BC016
 Лист

 Техническое описание
 Техническое описание

 Изм Лист № докум.
 Подп. Дата

Временные диаграммы последовательного синхронного обмена в режиме SPI c SPO = 0, SPH = 0 показаны на рисунках: 3.11.4 — одиночный обмен и 3.11.5 — непрерывный обмен.



Рисунок 3.11.4 — Формат синхронного обмена протокола SPI, SPO=0, SPH=0 (одиночный обмен)

Примечание — На рисунке буквой Q обозначен сигнал с неопределённым уровнем.



Рисунок 3.11.5 — Формат синхронного обмена протокола SPI, SPO = 0, SPH = 0 (непрерывный обмен)

В данном режиме во время ожидания приёмопередатчика:

— сигнал SPI\_SCK имеет низкий логический уровень,

Тодп. и дата

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подп.

- сигнал SPI\_SS имеет высокий логический уровень,
- сигнал SPI\_MOSI переводится в высокоимпедансное состояние.

Если функционирование модуля разрешено и в буфере FIFO передатчика содержатся корректные данные, сигнал SPI\_SS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SPI\_MISO ведущего. Контакт передатчика SPIMOSI переходит из высокоимпедансного в активное состояние.

Лист

139

По истечении полутакта сигнала SPI\_SCK на линии SPI\_MOSI формируется значение первого бита передаваемых данных. К этому моменту должны быть сформированы данные на линиях обмена как ведущего, так и ведомого устройства. По истечении следующего полутакта сигнал SPI\_SCK переводится в высокий логический уровень. Далее данные регистрируются по переднему фронту и выдаются в линию по

заднему фронту сигнала SPI\_SCK.

В случае передачи одного слова данных после приёма его последнего бита линия SPI\_SS переводится в высокий логический уровень по истечении одного периода тактового сигнала SPI\_SCK.

режиме непрерывной передачи данных на линии SPI SS должны формироваться импульсы высокого логического уровня между передачами каждого из слов данных. Это связано с тем, что в режиме SPH = 0 линия выбора ведомого устройства в низком уровне блокирует запись в сдвиговый регистр. Поэтому ведущее устройство должно переводить линию SPI\_SS в высокий уровень по окончании передачи каждого кадра, разрешая таким образом запись новых данных. По окончании приёма последнего бита блока данных линия SPI\_SS переводится в состояние, соответствующее режиму ожидания, по истечении одного такта сигнала SPI SCK.

3.11.6.13 Формат синхронного обмена SPI фирмы Motorola, SPO = 0, SPH = 1 Временные диаграммы последовательного синхронного обмена в режиме SPI с SPO = 0, SPH = 1 содержатся на рисунке 3.11.6 — одиночный и непрерывный обмен.

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подл.



Рисунок 3.11.6 — Формат синхронного обмена протокола SPI, SPO=0, SPH=1

Микросхема интегральная 5023ВС016 Лист Техническое описание 140 Версия 2.04 от 01.09.2017 г. Лист № докум. Подп. Дата

Примечание — На рисунке буквой Q обозначен сигнал с неопределённым уровнем.

В данном режиме во время ожидания приёмопередатчика:

- сигнал SPI\_SCK имеет низкий логический уровень;
- сигнал SPI\_SS имеет высокий логический уровень;
- сигнал SPI\_MOSI переводится в высокоимпедансное состояние.

Если функционирование модуля разрешено и в буфере FIFO передатчика содержатся корректные данные, сигнал SPI\_SS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SPI\_MISO ведущего. Выходной контакт передатчика SPIMOSI переходит из высокоимпедансного в активное состояние.

По истечении полутакта сигнала SPI\_SCK на линиях обмена как ведущего, так и ведомого устройств будут сформированы значения первых бит передаваемых данных. В это же время включается линия SPI\_SCK и на ней формируется передний фронт сигнала.

Далее данные регистрируются по заднему фронту и выдаются в линию по переднему фронту сигнала SPI\_SCK.

В случае передачи одного слова данных после приёма его последнего бита линия SPI\_SS переводится в высокий логический уровень по истечении одного периода тактового сигнала SPI\_SCK.

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

3.11.6.14 Формат синхронного обмена SPI фирмы Motorola, SPO = 1, SPH = 0 Временные диаграммы последовательного синхронного обмена в режиме SPI с SPO = 1, SPH = 0 показаны на рисунках: 3.11.7 — одиночный обмен и 3.11.8 — непрерывный обмен.

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подп.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.



Рисунок 3.11.7 — Формат синхронного обмена протокола SPI, SPO = 1, SPH = 0 (одиночный обмен)

Примечание — На рисунке буквой Q обозначен сигнал с неопределённым уровнем.



Рисунок 3.11.8 — Формат синхронного обмена протокола SPI, SPO = 1, SPH = 0 (непрерывный обмен)

В данном режиме во время ожидания приёмопередатчика:

- сигнал SPI\_SCK имеет высокий логический уровень;
- сигнал SPI\_SS имеет высокий логический уровень;

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

чв. № подл.

— сигнал SPI\_MOSI переводится в высокоимпедансное состояние.

Если функционирование модуля разрешено и в буфере FIFO передатчика содержатся корректные данные, сигнал SPI\_SS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SPI\_MISO ведущего. Выходной контакт передатчика SPIMOSI переходит из высокоимпедансного в активное состояние.

По истечении полутакта сигнала SPI\_SCK, на линии SPI\_MOSI формируется значение первого бита передаваемых данных. К этому моменту должны быть сформированы данные на линиях обмена как ведущего, так и ведомого устройства. По истечении следующего полутакта сигнал SPI\_SCK переводится в низкий логический уровень.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 142  |

Копировал

Далее данные регистрируются по заднему фронту и выдаются в линию по переднему фронту сигнала SPI\_SCK.

В случае передачи одного слова данных после приёма его последнего бита линия SPI\_SS переводится в высокий логический уровень по истечении одного периода тактового сигнала SPI\_SCK.

В режиме непрерывной передачи данных на линии SPI\_SS должны формироваться импульсы высокого логического уровня между передачами каждого из слов данных. Это связано с тем, что в режиме SPH = 0 линия выбора ведомого устройства в низком уровне блокирует запись в сдвиговый регистр. Поэтому ведущее устройство должно переводить линию SPI\_SS в высокий уровень по окончании передачи каждого кадра, разрешая таким образом запись новых данных. По окончании приёма последнего бита блока данных линия SPI\_SS переводится в состояние, соответствующее режиму ожидания, по истечении одного такта сигнала SPI\_SCK.

3.11.6.15 Формат синхронного обмена SPI фирмы Motorola, SPO = 1, SPH = 1 Временные диаграммы последовательного синхронного обмена в режиме SPI с SPO = 1, SPH = 1 показаны на рисунке 3.11.9 — одиночный и непрерывный обмен.



Рисунок 3.11.9 — Формат синхронного обмена протокола SPI, SPO=1, SPH=1 Примечание — На рисунке буквой Q обозначен сигнал с неопределённым уровнем.

В данном режиме во время ожидания приёмопередатчика:

- сигнал SPI\_SCK имеет высокий логический уровень;
- сигнал SPI\_SS имеет высокий логический уровень;

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

— сигнал SPI\_MOSI переводится в высокоимпедансное состояние.

|    |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|----|--------|----------|-------|------|-----------------------------------|------|
|    |        |          |       |      | Техническое описание              | 4.40 |
| Из | л Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 143  |

Копировал

нв. № подл. и дата Взам. инв. № Инв. № дубл. Подп. и дата.

Если функционирование модуля разрешено и в буфере FIFO передатчика содержатся корректные данные, сигнал SPI\_SS переводится в низкий логический уровень, что указывает на начало обмена данными и разрешает передачу данных от ведомого устройства на входную линию SPI\_MISO ведущего. Выходной контакт передатчика SPI\_MOSI переходит из высокоимпедансного в активное состояние.

По истечении полутакта сигнала SPI\_SCK на линиях обмена как ведущего, так и ведомого устройств сформированы значения первых бит передаваемых данных. В это же время включается линия SPI\_SCK и на ней формируется передний фронт сигнала.

Далее данные регистрируются по переднему фронту и выдаются в линию по заднему фронту сигнала SPI\_SCK.

В случае передачи одного слова данных после приёма его последнего бита линия SPI\_SS переводится в высокий логический уровень по истечении одного периода тактового сигнала SPI\_SCK.

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

3.11.6.16 Формат синхронного обмена Microwire фирмы National Semiconductor

Временные диаграммы последовательного синхронного обмена в режиме SPI показаны на рисунке 3.11.10 — одиночный обмен и на рисунке 3.11.11 — непрерывный обмен.



Рисунок 3.11.10 — Формат синхронного обмена протокола Microwire (одиночный обмен)

Микросхема интегральная 5023BC016
Техническое описание

Язм Лист № докум. Подп. Дата
Версия 2.04 от 01.09.2017 г.

Лист

144

— сигнал SPI SS имеет высокий логический уровень;

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

— сигнал SPI\_MOSI переводится в высокоимпедансное состояние.

Переход в режим информационного обмена происходит после записи управляющего байта в буфер FIFO передатчика. По заднему фронту сигнала SPI\_SS данные из буфера переносятся в регистр сдвига блока передатчика, откуда, начиная со старшего значащего разряда, последовательно выдаются в линию SPI MOSI. Линия SPI SS остается в низком логическом уровне в течение всей передачи кадра. Линия SPI\_MISO при этом находится в высокоимпедансном состоянии.

Внешнее ведомое устройство осуществляет приём бит данных по переднему фронту сигнала SPI SCK. По окончании приёма последнего бита управляющей последовательности она декодируется в течение одного тактового интервала, после чего ведомое устройство передает запрошенные данные в адрес модуля SPI. Биты данных выдаются в линию SPI\_MISO по заднему фронту сигнала SPI\_SCK. Ведущее устройство, в свою очередь, регистрирует их по переднему фронту этого тактового сигнала. В случае одиночного информационного обмена по окончании приёма последнего бита слова данных сигнал SPI\_SS переводится в высокий уровень на

Микросхема интегральная 5023ВС016 Техническое описание Версия 2.04 от 01.09.2017 г. № докум. Подп. Дата

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

Примечание — Внешнее устройство может перевести линию приёмника в третье состояние по заднему фронту сигнала SPI\_SCK после приёма последнего бита слова данных, либо после перевода линии SPI\_SS в высокий логический уровень.

Непрерывный обмен данными начинается и заканчивается так же, как и одиночный обмен. Однако линия SPI\_SS удерживается в низком логическом уровне в течение всего сеанса передачи данных. Управляющий байт следующего информационного кадра передается сразу же после приёма младшего значащего разряда текущего кадра. Данные из сдвигового регистра передаются в буфер приёмника после регистрации младшего разряда очередного слова по заднему фронту сигнала SPI\_SCK.



Рисунок 3.11.11 — Формат синхронного обмена протокола Microwire (непрерывный обмен)

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

3.11.6.17 Требования к временным параметрам сигнала SPI\_SS относительно тактового сигнала SPI\_SCK в режиме Microwire

Модуль SPI, работающий в режиме Microwire как ведомое устройство, регистрирует данные по переднему фронту сигнала SPI\_SCK после установки сигнала SPI\_SS в низкий логический уровень. Ведущие устройства, формирующие сигнал SPI\_SCK, должны гарантировать достаточное время установки и удержания сигнала SPI\_SS по отношению к переднему фронту сигнала SPI\_SCK.

Данные требования иллюстрирует рисунок 3.11.12. По отношению к переднему фронту сигнала SPI\_SCK, по которому осуществляется регистрация

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 146  |

Копировал

Формат А4



Рисунок 3.11.12 — Формат Microwire, требования к времени установки и удержания сигнала

### 3.11.7 Интерфейс прямого доступа к памяти

Инв. № дубл.

Взам. инв. №

Подп. и дата

Модуль SPI предоставляет интерфейс подключения к контроллеру прямого доступа к памяти. Функционирование в данном режиме контролируется регистром управления DMASPIDMACR.

Интерфейс DMA включает в себя следующие сигналы для приёма:

- SPIMISOMASREQ запрос передачи отдельного символа, инициируется приёмопередатчиком. Сигнал переводится в активное состояние в случае, если буфер FIFO приёмника содержит по меньшей мере один символ;
- SPIMISOMABREQ запрос блочного обмена данными, инициируется модулем приёмопередатчика. Сигнал переходит в активное состояние в случае, если буфер FIFO приёмника содержит четыре или более символов;
- SPIMISOMACLR сброс запроса на DMA, инициируется контроллером DMA с целью сброса принятого запроса. В случае, если был запрошен блочный обмен данными, сигнал сброса формируется в ходе передачи последнего символа данных в блоке;

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 147  |

Копировал

Формат А4

Интерфейс DMA включает в себя следующие сигналы для передачи:

— SPIMOSIMASREQ — запрос передачи отдельного символа, инициируется

модулем приёмопередатчика. Сигнал переводится в активное состояние в случае,

если буфер FIFO передатчика содержит по меньшей мере одну свободную ячейку;

— SPIMOSIMABREQ — запрос блочного обмена данными, инициируется модулем приёмопередатчика. Сигнал переводится в активное состояние в случае, если буфер FIFO передатчика содержит четыре или менее символов;

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

Сигналы блочного и одноэлементного обмена данными не являются взаимоисключающими, они могут быть инициированы одновременно. Например, в случае, если заполнение данными буфера приёмника превышает пороговое значение четыре, формируются как сигнал запроса одноэлементного обмена, так и сигнал запроса блочного обмена данными. В случае, если количество данных в буфере приёма меньше порогового значения, формируется только запрос одноэлементного обмена. Это бывает полезно в ситуациях, при которых объём данных меньше размера блока. Пусть, например, нужно принять 19 символов. Тогда контроллер DMA осуществит четыре передачи блоков по четыре символа, а оставшиеся три символа передаст в ходе трёх одноэлементных обменов.

Примечание — Для оставшихся трёх символов контроллер SPI не инициирует процедуру блочного обмена.

Каждый инициированный приёмопередатчиком сигнал запроса DMA остаётся активным до момента его сброса соответствующим сигналом DMACLR.

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

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

148

Таблица 3.11.1 — Параметры срабатывания запросов блочного обмена данными в режиме DMA

|                   | Длина блока об                                     | мена данными                                   |
|-------------------|----------------------------------------------------|------------------------------------------------|
| Пороговый уровень | Буфер передатчика (количество незаполненных ячеек) | Буфер приёмника (количество заполненных ячеек) |
| 1/2               | 4                                                  | 4                                              |

Рисунок 3.11.13 отображает временные диаграммы одноэлементного и блочного запросов DMA, в том числе действие сигнала DMACLR.

Все сигналы должны быть синхронизированы с PCLK.



Рисунок 3.11.13 — Временные диаграммы обмена в режиме DMA

3.11.8 Программное управление модулем

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

чв. № подл.

3.11.8.1 Общая информация и описание регистров контроллера SPI

В микросхеме реализовано четыре модуля SPI, базовые адреса каждого модуля указаны в таблице 3.11.2.

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

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

- адреса со смещениями в диапазоне 0x028 0x07C и 0xFD0 0xFDC зарезервированы для перспективных расширений возможностей модуля;
- адреса со смещениями в диапазоне 0x080-0x088 зарезервированы для тестирования.

Данные о регистрах модуля SPI приведены в таблице 3.11.2.

| L |      |      |          |       |      |                                   |      |
|---|------|------|----------|-------|------|-----------------------------------|------|
|   |      |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|   |      |      |          |       |      | Техническое описание              |      |
| į | Изм. | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 149  |

| Смещение | Наименование | Тип | Значение после сброса | Размер,<br>бит | Описание                                                                                      |
|----------|--------------|-----|-----------------------|----------------|-----------------------------------------------------------------------------------------------|
| 0x000    | CR0          | RW  | 0x0000                | 16             | Регистр SPIх -> CR0 управления 0                                                              |
| 0x004    | CR1          | RW  | 0x0                   | 4              | Регистр SPIх -> CR1 управления 1                                                              |
| 0x008    | DR           | RW  | 0x                    | 16             | Буфера FIFO приёмника (чтение)<br>Буфер FIFO передатчика (запись)<br>SPIx -> DR               |
| 0x00C    | SR           | RO  | 0x03                  | 3              | Регистр SPIx -> SR состояния                                                                  |
| 0x010    | CPSR         | RW  | 0x00                  | 8              | Регистр SPIx -> CPSR делителя тактовой частоты                                                |
| 0x014    | IMSC         | RW  | 0x0                   | 4              | Регистр SPIx -> IMSC маски прерывания                                                         |
| 0x018    | RIS          | RO  | 0x8                   | 4              | Регистр SPIх -> RIS состояния прерываний без учёта маскирования                               |
| 0x01C    | MIS          | RO  | 0x0                   | 4              | Регистр SPIх -> MIS состояния прерываний с учётом маскирования                                |
| 0x020    | ICR          | WO  | 0x0                   | 4              | Регистр SPIx -> ICR сброса прерывания                                                         |
| 0x024    | DMACR        | RW  | 0x0                   | 2              | Регистр SPIх -> DMACR управления прямым доступом к памяти оу: RW – чтение и запись. RO только |

Примечание — В поле «тип» указан вид доступа к регистру: RW – чтение и запись, RO только чтение, WO – только запись.

### 3.11.8.2 Регистр SPIx -> CR0

Регистр SPIх -> CR0 является регистром управления и содержит пять групп битовых полей, предназначенных для управления блоками модуля SPI. Описание регистра представлено в таблице 3.11.3

Таблица 3.11.3 — Описание регистра SPIх -> CR0

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                     |
|---------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1       | 2                    | 3                                                                                                                                                                                                                                                                                                           |
| 31 – 16 | _                    | Зарезервировано                                                                                                                                                                                                                                                                                             |
| 15 – 8  | SCR                  | Скорость последовательного обмена. Значение поля SCR используется при формировании тактового сигнала обмена данными. Информационная скорость удовлетворяет соотношению: F_SPI_SCK/(CPSDVR · (1 + SCR)), где CPSDVR — четное число в диапазоне от 2 до 254 (см. регистр SPICPSR), а SCR — число от 0 до 255. |
| 7       | SPH                  | Фаза сигнала SPICLKOUT (используется только в режиме обмена SPI фирмы Motorola). См. раздел «Формат SPI фирмы Motorola».                                                                                                                                                                                    |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

150

Продолжение таблицы 3.11.3

| 1     | 2   |                         | 3                               |
|-------|-----|-------------------------|---------------------------------|
|       | ano |                         | PISCKOUT (используется только в |
| 6     | SPO |                         | ы Motorola). см. раздел «Формат |
|       |     | синхронного обмена SPI  | 1 1                             |
|       |     | Формат информационног   | -                               |
|       |     | 00 — протокол SPI фирмі |                                 |
| 5-4   | FRF | 01 — протокол SSI фирмі |                                 |
|       |     | 10 — протокол Microwire | е фирмы National Semiconductor; |
|       |     | 11 — резерв.            |                                 |
|       |     | Размер слова данных:    |                                 |
|       |     | 0000 — резерв           | 1000 — 9 бит                    |
|       |     | 0001 — резерв           | 1001 — 10 бит                   |
|       |     | 0010 — резерв           | 1010 — 11 бит                   |
| 3 – 0 | DSS | 0011 — 4 бита           | 1011 — 12 бит                   |
|       |     | 0100 — 5 бит            | 1100 — 13 бит                   |
|       |     | 0101 — 6 бит            | 1101 — 14 бит                   |
|       |     | 0110 — 7 бит            | 1110 — 15 бит                   |
|       |     | 0111 — 8 бит            | 1111 — 16 бит                   |

## 3.11.8.3 Регистр SPIх -> CR1

Регистр SPIх -> CR1 является регистром управления и содержит четыре группы битовых полей, предназначенных для управления блоками модуля SPI. Описание регистра представлено в таблице 3.11.4.

Таблица 3.11.4 — Описание регистра SPIх -> CR1

| № бита  | Наименование |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ji Onia | бита         | принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1       | 2            | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15 – 4  |              | Резерв, при чтении результат не определён. При записи следует устанавливать в «0»                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3       | SOD          | Запрет выходных линий в режиме ведомого устройства. Бит используется только в режиме ведомого устройства (MS = 1). Это позволяет организовать двусторонний обмен данными в системах, содержащих одно ведущее и несколько ведомых устройств. Бит SOD следует установить в случае, если данный ведомый модуль SPI не должен в настоящее время осуществлять передачу данных в линию SPI_MOSI. При этом линии обмена данных ведомых устройств можно соединить параллельно.  0 — управление линией SPI_MOSI в ведомом режиме разрешено.  1 — управление линией SPI_MOSI в ведомом режиме запрещено. |
| 2       | MS           | Выбор ведущего или ведомого режима работы: 0 — режим работы ведущего; 1 — режим работы ведомого.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1       | SSE          | Разрешение работы приёмопередатчика: 0 — функционирование запрещено; 1 — функционирование разрешено.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

151

Продолжение таблицы 3.11.4

| 1 | 2   | 3                                                                                                                                                                    |  |  |  |
|---|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0 | LDM | Тестирование по шлейфу: 0 — нормальный режим функционирования приёмопередатчика; 1 — выход регистра сдвига передатчика соединен со входом регистра сдвига приёмника. |  |  |  |

#### 3.11.8.4 Регистр SPIx -> DR

Регистр SPIх -> DR является регистром данных. Регистр SPIDR имеет разрядность 16 бит и предназначен для чтения принятых и записи передаваемых данных.

Операция чтения обеспечивает доступ к последней несчитанной ячейке буфера FIFO приёмника. Запись данных в этот буфер FIFO осуществляет блок приёмника.

Операция записи позволяет занести очередное слово в буфер FIFO передатчика. Извлечение данных из этого буфера осуществляет блок передатчика. При этом извлечённые данные помещаются в регистр сдвига передатчика, откуда последовательно выдаются на линию SPI\_MOSI с заданной скоростью информационного обмена.

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

В режиме обмена данными Microwire фирмы National Semiconductor модуль SPI по умолчанию работает с восьмиразрядными информационными словами (старший значащий байт игнорируется). Размер принимаемых данных задаётся программно. Буфера FIFO приёмника и передатчика автоматически не очищаются даже в случае, если бит SSE установлен в «0». Это позволяет заполнить буфер передатчика необходимой информацией заблаговременно, перед разрешением работы модуля. Описание регистра представлено в таблице 3.11.5.

Изм Лист № докум. Подп. Дата

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Таблица 3.11.5 — Описание регистра DR

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                               |
|--------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 – 0 | DATA              | Принимаемые данные (чтение). Передаваемые данные (запись). В случае если выбран размер информационного слова менее 16 бит, перед записью в регистр SPIDR необходимо обеспечить выравнивание данных по правой границе. Блок передатчика игнорирует неиспользуемые биты. Принятые информационные слова автоматически выравниваются по правой границе в блоке приёмника. |

### 3.11.8.5 Регистр SPIx -> SR

Регистр SPIх -> SR является регистром состояния и доступен только для чтения и содержит информацию о состоянии буферов FIFO приёмника и передатчика, и занятости модуля SPI. Описание регистра SPIх -> SR представлено в таблице 3.11.6.

Таблица 3.11.6 — Описание регистра SPIx -> SR

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                     |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 – 5 | _                 | •                                                                                                                                                           |
| 4      | BSY               | Флаг активности модуля:  0 — модуль SPI не активен;  1 — модуль SPI в настоящее время передаёт и/или принимает данные, либо буфер FIFO передатчика не пуст. |
| 3      | RFF<br>RNE<br>TNF | Буфер FIFO приёмника заполнен: 0 — не заполнен; 1 — заполнен.                                                                                               |
| 2      |                   | Буфер FIFO приёмника не пуст:<br>0 — пуст;<br>1 — не пуст.                                                                                                  |
| 1      |                   | Буфер FIFO передатчика не заполнен:<br>0 — заполнен;<br>1 — не заполнен.                                                                                    |
| 0      | TFE               | Буфер FIFO передатчика пуст:<br>0 — не пуст;<br>1 — пуст.                                                                                                   |

# 3.11.8.6 Регистр SPIх -> CPSR

Инв. № дубл.

Взам. инв. №

Подп. и дата

Регистр SPIх -> CPSR является регистром делителя тактовой частоты. Регистр SPIх -> CPSR используется для установки параметров делителя тактовой частоты. Записываемое значение должно быть целым числом в диапазоне от 2 до 254.

|     |               |          |       |      | Микросхема интегральная 5023ВС016 | Лист     |
|-----|---------------|----------|-------|------|-----------------------------------|----------|
|     |               |          |       |      | Техническое описание              | $\vdash$ |
| Изг | <i>и</i> Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 153      |

Младший значащий разряд регистра принудительно устанавливается в ноль. Если записать в регистр SPICPSR нечетное число, его последующее чтение даст результатом это число, но с установленным в ноль младшим битом. Описание регистра SPIx -> CPSR представлено в таблице 3.11.7.

Таблица 3.11.7 — Описание регистра SPIх -> CPSR

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                             |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 - 8 |                   |                                                                                                                                                                                     |
| 1-0    |                   | Коэффициент деления тактовой частоты. Записываемое значение должно быть целым числом в диапазоне от 2 до 254. Младший значащий разряд регистра принудительно устанавливается в ноль |

### 3.11.8.7 Регистр SPIх -> IMSC

Регистр SPIх -> IMSC предназначен для установки и сброса маски прерывания. При чтении выдаётся текущее значение маски. При записи производится установка или сброс маски на соответствующее прерывание. При этом запись «1» в разряд разрешает соответствующее прерывание, запись «0» — запрещает.

После сброса все биты регистра маски устанавливаются в нулевое состояние. Описание регистра SPIх -> IMSC представлено в таблице 3.11.8.

Таблица 3.11.8 — Описание регистра SPIx -> IMSC

| № бита   | Наименование бита     | Функциональное назначение бита, краткое описание бита             |
|----------|-----------------------|-------------------------------------------------------------------|
| Ji_ Oniu | Tianwellobaline on ta | назначения и принимаемых значений                                 |
| 31 – 4   | _                     |                                                                   |
|          |                       | Маска прерывания по заполнению на 50% и менее буфера FIFO         |
| 3        | TXIM                  | передатчика.                                                      |
| 3        | ΙΛΠνι                 | 1 — не маскирована.                                               |
|          |                       | 0 — маскирована                                                   |
|          |                       | Маска прерывания по заполнению на 50% и менее буфера FIFO         |
| 2        | DVIM                  | приёмника.                                                        |
|          | RXIM                  | 1 — не маскирована.                                               |
|          |                       | 0 — маскирована                                                   |
|          |                       | Маска прерывания по таймауту приёмника (буфер FIFO приёмника      |
| 1        | RTIM                  | не пуст и не было попуток его чтения в течение времени таймаута). |
| 1        | K I IIVI              | 1 — не маскирована.                                               |
|          |                       | 0 — маскирована                                                   |
|          |                       | Маска прерывания по переполнению буфера приёмника.                |
| 0        | RORIM                 | 1 — не маскирована.                                               |
|          |                       | 0 — маскирована                                                   |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

154

Регистр SPIx RIS — регистр состояния прерываний. Этот регистр доступен только для чтения и содержит текущее состояние прерываний без учёта маскирования. Данные, записываемые в регистр, игнорируются. Описание регистра SPIx -> RIS представлено в таблице 3.11.9.

Таблица 3.11.9 — Описание регистра SPIx -> RIS

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 4 | _                 |                                                                                         |
| 3      | TXRIS             | Состояние до маскирования прерывания SPITXINTR                                          |
| 2      | RXRIS             | Состояние до маскирования прерывания SPIRXINTR                                          |
| 1      | RTRIS             | Состояние до маскирования прерывания SPIRTINTR                                          |
| 0      | RORRIS            | Состояние до маскирования прерывания SPIRORINTR                                         |

## 3.11.8.9 Регистр SPIх -> MIS

Регистр SPIх -> MIS - регистр маскированного состояния прерываний. Этот регистр доступен только для чтения и содержит текущее состояние прерываний с учетом маскирования. Данные, записываемые в регистр, игнорируются. Описание регистра SPIх -> MIS представлено в таблице 3.11.10.

Таблица 3.11.10 — Описание регистра SPIх -> MIS

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 – 4 | I                 |                                                                                         |
| 3      | TXMIS             | Состояние маскированного прерывания SPITXINTR                                           |
| 2      | RXMIS             | Состояние маскированного прерывания SPIRXINTR                                           |
| 1      | RTMIS             | Состояние маскированного прерывания SPIRTINTR                                           |
| 0      | RORMIS            | Состояние маскированного прерывания SPIRORINTR                                          |

# 3.11.8.10 Регистр SPIх -> ICR

Инв. № дубл.

Взам. инв. №

Подп. и дата

Регистр SPIх -> ICR предназначен для сброса прерываний. Этот регистр доступен только для записи и предназначен для сброса признака прерывания по заданному событию путём записи «1» в соответствующий бит. Запись в любой из

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 155  |

Копировал

Таблица 3.11.11 — Описание регистра SPIх -> ICR

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 31 - 2 |                   |                                                                                         |
| 1      | RTIC              | Сброс прерывания SPIRTINTR                                                              |
| 0      | RORIC             | Сброс прерывания SPIRORINTR                                                             |

### 3.11.8.11 Регистр SPIх -> DMACR

Регистр SPIx -> DMACR предназначен для управления прямым доступом к памяти. Регистр доступен по чтению и записи. После сброса все биты регистра SPIx -> DMACR обнуляются. Описание регистра SPIx -> DMACR представлено в таблице 3.11.12.

Таблица 3.11.12 — Описание регистра SPIx -> DMACR

| No     | Наименование | Функциональное назначение бита, краткое описание бита назначения и                                                                    |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------|
| бита   | бита         | принимаемых значений                                                                                                                  |
| 31 - 2 |              | Резерв. Не модифицируется. При чтении выдаются нули.                                                                                  |
| 1      |              | Использование DMA при передаче. Если бит установлен в 1, разрешено формирование запросов DMA для обслуживания буфера FIFO передатчика |
| 0      |              | Использование DMA при приёме. Если бит установлен в 1, разрешено формирование запросов DMA для обслуживания буфера FIFO приёмника     |

# 3.11.9 Прерывания модуля

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подп.

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

Сигналы запроса на прерывание:

- SPIRXINTR запрос на обслуживание буфера FIFO приёмника. Прерывание по заполнению буфера FIFO приёмника формируется в случае, если буфер приёмника содержит четыре или более несчитанных слов данных;
- SPITXINTR запрос на обслуживание буфера FIFO передатчика. Прерывание по заполнению буфера FIFO передатчика формируется в случае, если буфер передатчика содержит четыре или менее корректных слов данных. Состояние

| L |     |      |          |       |      |                                                      |      |
|---|-----|------|----------|-------|------|------------------------------------------------------|------|
| ſ |     |      |          |       |      | Микросхема интегральная 5023ВС016                    | Лист |
|   | Изм | Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 156  |
|   |     |      | •        |       |      | Копировал Формат А4                                  |      |

Инв. № дубл. SPITICR; — SPIINTR — логическое ИЛИ сигналов Взам. инв. № Подп. и дата устройств. нв. № подл. Микросхема интегральная 5023ВС016 Техническое описание Версия 2.04 от 01.09.2017 г. Лист № докум. Подп. Дата

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

- SPIRORINTR переполнение буфера FIFO приёмника. Прерывание по переполнению буфера FIFO приёмника формируется в случае, если буфер уже заполнен и блоком приёмника осуществлена попытка записать в него еще одно слово. При этом принятое слово данных регистрируется в регистре сдвига приёмника, но в буфер приёмника не заносится;
- SPIRTINTR таймаут приёмника. Прерывание по таймауту приёмника возникает в случае, если буфер FIFO приёмника не пуст, и на вход приёмника не поступало новых данных в течение периода времени, необходимого для передачи 32 бит. Данный механизм гарантирует, что пользователь будет знать о наличии в буфере приёмника необработанных данных. Прерывание по таймауту снимается либо после считывания данных из буфера приёмника до его опустошения, либо после приёма новых слов данных по входной линии SPI\_MISO. Кроме того, оно может быть снято путём записи «1» в бит RTIC регистра сброса прерывания
- SPIRXINTR, SPITXINTR, SPIRTINTR и SPIRORINTR. Все описанные сигналы запроса на прерывание скомбинированы в общую линию путем объединения по схеме ИЛИ сигналов SPIRXINTR, SPIRTINTR и SPIRORINTR с учетом маскирования. Общий выход может быть подключен к системному контроллеру прерывания, что позволит ввести дополнительное маскирование запросов на уровне периферийных

Каждый из независимых сигналов запроса на прерывание может быть маскирован путём установки соответствующего бита в регистре маски SPIIMSC.

157

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

Прерывания от приёмника и передатчика SPIRXINTR и SPITXINTR выведены отдельно от прерываний по изменению состояния устройства. Это позволяет использовать данные сигналы запроса для обеспечения чтения и записи данных согласованно с достижением заданного порога заполнения буферов FIFO приёмника и передатчика.

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

- 3.12 Контроллер интерфейса UART
- 3.12.1 Общие положения

Модуль универсального асинхронного приёмопередатчика UART представляет собой периферийное устройство микросхемы.

- 3.12.2 Основные характеристики интерфейса UART
- 3.12.2.1 Общие характеристики

Модуль UART содержит независимые буферы приёма (16 x 12) и передачи (16 x 8) типа FIFO, что позволяет снизить интенсивность прерываний центрального процессора.

Программное отключение FIFO позволяет ограничить размер буфера одним байтом.

Программное управление скоростью обмена. Обеспечивается возможность деления тактовой частоты опорного генератора в диапазоне (1 x 16 – 65535 x 16). Допускается использование нецелых коэффициентов деления частоты, что позволяет использовать любой опорный генератор с частотой более 3,6864 МГц.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

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

Независимое маскирование прерываний от буфера FIFO передатчика, буфера FIFO приёмника, по таймауту приёмника, по изменению линий состояния модема, а также в случае обнаружения ошибки.

Поддержка прямого доступа к памяти.

Обнаружение ложных стартовых бит.

Формирование и обнаружения сигнала разрыва линии.

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

Полностью программируемый асинхронный последовательный интерфейс с характеристиками:

- **—** данные длиной 5, 6, 7 или 8 бит;
- формирование и контроль четности (проверочный бит выставляется по чётности, нечётности, имеет фиксированное значение, либо не передаётся);
  - формирование 1 или 2 стоповых бит;
  - скорость передачи данных от 0 до UARTCLK/16 Бод.

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

3.12.2.2 Программируемые параметры

Следующие ключевые параметры могут быть заданы программно:

- скорость передачи данных целая и дробная часть числа;
- количество бит данных;
- количество стоповых бит;
- режим контроля чётности;
- разрешение или запрет использования буферов FIFO (глубина очереди данных 32 элемента или один элемент, соответственно);

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

— порог срабатывания прерывания по заполнению буферов FIFO (1/8, 1/4, 1/2,

тактового

промышленного

значение — 1,8432 МГц) может быть задана в диапазоне 1,42 – 2,12 МГц для

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

генератора

стандарта

(номинальное

асинхронного

внутреннего

режим аппаратного управления потоком данных.

OT

3.12.2.3 Отличия от контроллера UART 16C650

приёмопередатчика 16С650 следующими характеристиками:

отличается

в режиме пониженного энергопотребления;

3/4 u 7/8);

— частота

Контроллер

Инв. № дубл. Подп. и дата.

Взам. инв. №

нв. № подл. Подп. и дата

помощью внутренней памяти FIFO, позволяющей сохранить до 16 байт независимо для режимов приёма и передачи.

Модуль приёмопередатчика:

- содержит программируемый генератор, формирующий тактовый сигнал одновременно для передачи и для приёма данных на основе внутреннего тактового сигнала UARTCLK;
- обеспечивает возможности, сходные с возможностями индустриального стандарта контроллера UART 16C650;
- позволяет осуществлять обмен информацией в режиме UART с максимальной скоростью до 921600 бит/с.

Режим работы приёмопередатчика и скорость обмена данными контролируются регистром управления линией UARTLCR\_H и регистрами делителя скорости передачи данных — целой части (UARTIBRD) и дробной части (UARTFBRD).

Устройство может формировать следующие сигналы:

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

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

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

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

### 3.12.3 Описание функционирования интерфейса UART

Рисунок 3.12.1 показывает структурную схему универсального асинхронного приёмопередатчика UART.



Рисунок 3.12.1 — Структурная схема универсального асинхронного приёмопередатчика UART

# 3.12.3.1 Генератор тактового сигнала приёмопередатчика

u dama

№ дубл.

Инв.

инв.

Взам.

Подп. и дата

нв. № подл.

Генератор содержит счётчики без цепи сброса, формирующие внутренние тактовые сигнал Baud16.

Сигнал Baud16 используется для синхронизации схем управления приёмником и передатчиком последовательного обмена данными. Он представляет собой последовательность импульсов с шириной, равной одному периоду сигнала UARTCLK и частотой, в 16 раз выше скорости передачи данных.

|     |      |          | Ī     |      |                                                       |           |      |
|-----|------|----------|-------|------|-------------------------------------------------------|-----------|------|
|     |      |          |       |      | Микросхема интегральная 5023E<br>Техническое описание | 3C016     | Лист |
| Изм | Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г.  |           | 162  |
|     |      |          |       |      | Копировал                                             | Формат А4 |      |

Буфер передатчика имеет разрядность 8 бит, глубину 32 слова, схему организации доступа типа FIFO.

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

Существует возможность запретить буфер FIFO передатчика, в этом случае он будет функционировать как однобайтовый буферный регистр.

### 3.12.3.3 Буфер FIFO приёмника

Буфер приёмника имеет ширину 12 бит, глубину 32 слова, схему организации доступа типа FIFO.

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

Буфер FIFO приёмника может быть запрещён, в этом случае он будет действовать как однобайтовый буферный регистр.

### 3.12.3.4 Блок передатчика

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

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

# 3.12.3.5 Блок приёмника

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

| . № подл. Подп. и дата |   |  |
|------------------------|---|--|
| ₹                      | 3 |  |
| Инв                    | _ |  |

Инв. № дубл.

Взам. инв. №

 Микросхема интегральная 5023BC016

 Техническое описание

 М Лист
 № докум.
 Подп.
 Дата
 Версия 2.04 от 01.09.2017 г.

Формат А4

Лист

163

#### 3.12.3.6 Блок формирования прерываний

Блок генерирует независимые маскируемые прерывания с активным высоким уровнем. Кроме того, формируется комбинированное прерывание путём объединения указанных независимых прерываний по схеме «ИЛИ».

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

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

## 3.12.3.7 Модуль обеспечения прямого доступа к памяти

Модуль обеспечивает интерфейс с контроллером DMA согласно схеме взаимодействия приёмопередатчика и контроллера DMA.

## 3.12.3.8 Блок и регистры синхронизации

Контроллер поддерживает как асинхронный, так и синхронный режимы работы тактовых генераторов CPU\_CLK и UARTCLK. Регистры синхронизации и логика квитирования постоянно находятся в активном состоянии. Это практически не отражается на характеристиках устройства и занимаемой площади.

Синхронизация сигналов управления осуществляется в обоих направлениях потока данных, то есть как из области действия CPU\_CLK в область действия UARTCLK, так и наоборот.

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

### 3.12.4.1 Сброс модуля

Приёмопередатчик и энкодер/декодер могут быть сброшены общим сигналом сброса процессора. Значения регистров после сброса описаны в разделе «Программное управление модулем».

#### 3.12.4.2 Тактовые сигналы

Частота тактового сигнала UARTCLK должна обеспечивать поддержку требуемого диапазона скоростей передачи данных

$$F_UARTCLK(min) \ge 16 \cdot baud\_rate\_max,$$
 (4)

$$F \ UARTCLK(max) \le 16 \cdot 65535 \cdot baud \ rate \ min.$$
 (5)

Например, для поддержки скорости передачи данных в диапазоне от 110 до 460800 Бод частота UARTCLK должна находиться в интервале от 7,3728 М $\Gamma$ ц до 115,34 М $\Gamma$ ц.

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

Существует ограничение на соотношение между тактовыми частотами CPU\_CLK и UARTCLK. Частота UARTCLK должна быть не более, чем в 5/3 раз выше частоты CPU\_CLK

$$F_{\_}UARTCLK \le 5/3 \cdot F_{\_}CPU_{\_}CLK. \tag{6}$$

Например, при работе в режиме UART с максимальной скоростью передачи данных 921600 бод, при частоте UARTCLK 14,7456 МГц, частота CPU\_CLK должна быть не менее 8,85276 МГц. Это гарантирует, что контроллер UART будет иметь достаточно времени для записи принятых данных в буфер FIFO.

В реализации контроллера в процессоре на вход модуля UART (UARTCLK) подаётся системная частота.

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. Nº подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

приёмопередатчика

Управляющая информация хранится в регистре управления линией UARTLCR. Этот регистр имеет внутреннюю ширину 30 бит, однако внешний доступ по шине APB к нему осуществляется через следующие регистры:

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

### 3.12.4.4 Коэффициент деления частоты

Коэффициент деления для формирования скорости передачи данных состоит из 22 бит, при этом 16 бит выделено для представления его целой части, а 6 бит — дробной части. Возможность задания нецелых коэффициентов деления позволяет осуществлять обмен данными со стандартными информационными скоростями, при этом используя в качестве UARTCLK тактовый сигнал с произвольной частотой более 3,6864 МГц.

Целая часть коэффициента деления записывается в 16-битный регистр UARTIBRD. Шестиразрядная дробная часть записывается в регистр UARTFBRD. Значение коэффициента деления связано с содержимым указанных регистров следующим образом:

Коэффициент деления

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

в. № подл.

 $UARTCLK/(16 \cdot скорость передачи данных) = BRD_I + BRD_F,$  (7) где BRD\_I — целая часть;

BRD\_F — дробная часть коэффициента деления.

Формат представления коэффициента деления представлен на рисунке 3.12.2.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

#### 16-бит целое число

6-бит дробная часть

Рисунок 3.12.2 — Формат представления коэффициента деления

Шестибитное значение, записываемое в регистр UARTFBRD, вычисляется путём выделения дробной части требуемого коэффициента деления, умножения ее на 64 (то есть на 2n, где n — ширина регистра UARTFBRD) и округления до ближайшего целого числа

$$M = integer (BRD_F \cdot 2n + 0.5), \tag{8}$$

где integer (.) – операция отсечения дробной части числа, n = 6.

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

#### 3.12.4.5 Передача и приём данных

Инв. № дубл.

Взам. инв. №

Подп. и дата

1в. № подл.

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

передачи данные заносятся в буфер FIFO передатчика. Если функционирование приёмопередатчика разрешено, начинается передача информационного кадра с параметрами, указанными в регистре управления линией UARTLCR H. Передача данных продолжается до опустошения буфера FIFO передатчика. После записи элемента в буфер FIFO передатчика сигнал BUSY переходит в высокое состояние. Это состояние сохраняется в течение всего времени передачи данных. В низкое состояние сигнал BUSY переходит только после того, как буфер FIFO передатчика станет пуст, а последний бит данных (включая стоповые биты) будет передан. Сигнал BUSY может находиться в высоком состоянии даже в случае, если приёмопередатчик будет переведён из разрешённого состояния в запрещённое.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| 1зм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

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

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

Стартовый бит считается достоверным в случае, если сигнал на линии UART\_RXD сохраняет низкий логический уровень в течение восьми отсчётов сигнала Baud16 с момента включения счётчика. В противном случае переход в ноль рассматривается как ложный старт и игнорируется.

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

В завершение производится проверка присутствия корректного стопового бита (высокий логический уровень сигнала UART\_RXD). В случае если последнее условие не выполняется, устанавливается признак ошибки формирования кадра. После того, как слово данных принято полностью, оно заносится в буфер FIFO приёмника, наряду с четырьмя битами признаков ошибки, связанных с принятым словом (таблица 3.12.1).

#### 3.12.4.6 Биты ошибки

Инв. № дубл.

Взам. инв. №

Подп. и дата

в. № подл.

Три бита признаков ошибки, ассоциированные с принятым символом данных, заносятся в разряды [10...8] слова данных в буфере FIFO приёмника. Также предусмотрен признак ошибки переполнения буфера FIFO в разряде 11 слова данных.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Таблица 3.12.1 — Описание слова данных в FIFO-буфере приёмника

| Бит буфера FIFO | Назначение                  |
|-----------------|-----------------------------|
| 11              | Признак переполнения буфера |
| 10              | Ошибка – «разрыв линии»     |
| 9               | Ошибка проверки на чётность |
| 8               | Ошибка формирования кадра   |
| 7 – 0           | Принятые данные             |

### 3.12.4.7 Бит переполнения буфера

Бит переполнения непосредственно не связан с конкретным символом в буфере приёмника. Признак переполнения фиксируется в случае, если буфер FIFO заполнен к моменту, когда очередной символ данных полностью принят (находится в регистре сдвига). При этом данные из регистра сдвига не попадают в буфер приёмника и теряются с началом приёма очередного символа. Как только в буфере приёмника появляется свободное место, очередной принятый символ данных заносится в буфер FIFO вместе с текущим значением признака переполнения. После успешной записи данных в буфер признак переполнения сбрасывается.

# 3.12.4.8 Запрет буфера FIFO

Инв. № дубл.

Взам. инв. №

Подп. и дата

в. № подл.

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

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

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 169  |

Копировал

## 3.12.4.9 Проверка по шлейфу

Проверка по шлейфу (замыкание выхода передатчика на вход приёмника) выполняется путём установки в «1» бита LBE в регистре управления контроллером UARTCR.

### 3.12.4.10 Проверка по шлейфу

Инв. № дубл.

Взам. инв. №

Подп. и дата

Проверка по шлейфу выполняется после установки в «1» бита LBE регистра управления контроллером UARTCR с одновременной установкой в «1» бита SIRTEST регистра управления тестированием UARTTCR.

В этом режиме данные, передаваемые на выход nSIROUT, должны подаваться на вход SIRIN.

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

Временная диаграмма кадра передачи данных приведена на рисунке 3.12.3.



Рисунок 3.12.3 — Временная диаграмма кадра передачи данных

# 3.12.4.11 Интерфейс прямого доступа к памяти (DMA)

Модуль универсального асинхронного приёмопередатчика оснащён интерфейсом подключения к контроллеру прямого доступа к памяти. Функционирование в данном режиме контролируется регистром управления DMAUARTDMACR.

Интерфейс DMA включает в себя сигналы для приёма:

— UARTRXDMASREQ — запрос передачи отдельного символа, инициируется контроллером UART. Размер символа в режиме приёма данных — до 12 бит. Сигнал переводится в активное состояние в случае, если буфер FIFO приёмника содержит по меньшей мере один символ;

|   |         |            |       |      | Микросхема интегральная 5023ВС016 | Лист |
|---|---------|------------|-------|------|-----------------------------------|------|
|   |         |            |       |      | Техническое описание              |      |
| И | зм Лисг | п № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 170  |

— UARTRXDMABREQ — запрос блочного обмена данными, инициируется

— UARTRXDMACLR — сброс запроса на DMA, инициируется модулем

превысило

передачи

заданный

символа,

модулем приёмопередатчика. Сигнал переходит в активное состояние в случае, если

программируется индивидуально для каждого буфера FIFO путём записи значения

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

блочный обмен данными, сигнал сброса формируется в ходе передачи последнего

инициируется модулем приёмопередатчика. Размер символа в режиме передачи

приёмника

Интерфейс DMA включает в себя сигналы для передачи:

заполнение

в регистр UARTIFLS;

символа данных в блоке.

буфера

FIFO

— UARTTXDMASREQ — запрос

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

Пусть, например, нужно принять 19 символов, а порог заполнения буфера FIFO установлен равным четырём. Тогда контроллер DMA осуществит четыре передачи блоков по четыре символа, а оставшиеся три символа передаст в ходе трёх одноэлементных обменов.

Примечание — Для оставшихся трёх символов контроллер UART не может инициировать процедуру блочного обмена.

Каждый инициированный приёмопередатчиком сигнал запроса DMA остаётся активным до момента его сброса соответствующим сигналом DMACLR.

После снятия сигнала сброса модуль приёмопередатчика вновь получает возможность сформировать запрос на DMA в случае выполнения описанных выше условий. Все запросы DMA снимаются после запрета работы приёмопередатчика, а также в случае установки в ноль бита управления DMATXDMAE или RXDMAE в регистре управления DMAUARTDMACR.

В случае запрета буферов FIFO устройство способно передавать и принимать только одиночные символы; как следствие, контроллер может инициировать DMA только в одноэлементном режиме. При этом модуль в состоянии формировать только сигналы управления DMAUARTRXDMASREQ и UARTTXDMASREQ. Для информации о запрете буферов FIFO см. описание регистра управления линией UARTLCR\_H.

Когда буферы FIFO включены, обмен данными может производиться в ходе как одноэлементных, так и блочных передач данных, в зависимости от установленной величины порога заполнения буферов и их фактического заполнения. Таблица 3.12.2 показывает значения параметров срабатывания запросов блочного обмена UARTRXDMABREQ и UARTTXDMABREQ в зависимости от порога заполнения буфера.

нв. № подл. и дата Взам. инв. № Инв. № дубл. П

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

| Пополову у у у повоуу | Длина блока обмена данными    |                             |  |  |  |  |  |
|-----------------------|-------------------------------|-----------------------------|--|--|--|--|--|
| Пороговый уровень     | Буфер передатчика (количество | Буфер приёмника (количество |  |  |  |  |  |
| 1/8                   | 28                            | 4                           |  |  |  |  |  |
| 1/4                   | 24                            | 8                           |  |  |  |  |  |
| 1/2                   | 16                            | 16                          |  |  |  |  |  |
| 3/4                   | 8                             | 24                          |  |  |  |  |  |
| 7/8                   | 4                             | 28                          |  |  |  |  |  |

В регистре управления DMAUARTDMACR предусмотрен бит DMAONERR, который позволяет запретить DMA от приёмника в случае активного состояния линии прерывания ПО обнаружению ошибки UARTEINTR. При ЭТОМ **DMA** соответствующие запроса UARTRXDMASREO линии UARTRXDMABREQ переводятся в неактивное состояние (маскируются) до сброса UARTEINTR. На линии запроса DMA, обслуживающие передатчик, состояние UARTEINTR не влияет.

На рисунке 3.12.4 показаны временные диаграммы одноэлементного и блочного запросов DMA, в том числе действие сигнала DMACLR. Все сигналы должны быть синхронизированы с CPU\_CLK. В интересах ясности изложения предполагается, что синхронизация сигналов запроса DMA в контроллере DMA не производится.



Инв. № дубл.

Взам. инв. №

Подп. и дата

чв. № подл.

Рисунок 3.12.4 — Временные диаграммы одноэлементного и блочного запросов DMA

Необходимо иметь в виду, что при получении сигнала UARTTXDMABREQ контроллер DMA будет производить 2R\_power транзакций независимо от уровня заполнения FIFO, поэтому при неверной настройке коэффициента R\_power может

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 173  |

Копировал

Формат А4

- 3.12.5 Прерывания
- 3.12.5.1 Общие положения

В модуле UART предусмотрено 9 маскируемых источников прерываний. В результате формируется один общий сигнал, представляющий собой комбинацию независимых сигналов, объединённых по схеме ИЛИ.

Сигналы запроса на прерывание:

- UARTRXINTR прерывание от приёмника;
- UARTTXINTR прерывание от передатчика;
- UARTRTINTR прерывание по таймауту приёмника;
- UARTEINTR ошибка;
- UARTOEINTR переполнение буфера;
- UARTBEINTR прерывание приёма разрыв линии;
- UARTPEINTR ошибка контроля чётности;
- UARTFEINTR ошибка в структуре кадра.

UARTINTR — логическое ИЛИ сигналов UARTRXINTR, UARTTXINTR, UARTRTINTR и UARTEINTR. Каждый из независимых сигналов запроса на прерывание может быть маскирован путём установки соответствующего бита в регистре маски UARTIMSC. Установка бита в «1» разрешает соответствующее прерывание, в «0» — запрещает.

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

Прерывания от приёмника и передатчика UARTRXINTR и UARTTXINTR выведены отдельно от прерываний по изменению состояния устройства. Это позволяет использовать сигналы запроса UARTRXINTR и UARTTXINTR для

Изм Лист № докум. Подп. Дата

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

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

#### **3.12.5.2 UARTRXINTR**

Состояние прерывания otприёмника может случае измениться возникновения одного из следующих событий:

- буфер FIFO разрешён, и его заполнение достигло заданного порогового значения. В этом случае линия прерывания переходит в высокое состояние. Сигнал прерывания переходит в низкое состояние после чтения данных из буфера приёмника до тех пор, пока его заполнение не станет меньше порога, либо после сброса прерывания;
- буфер FIFO запрещён (имеет размер один символ), принят один символ данных. При этом линия прерывания переходит в высокое состояние. Сигнал прерывания переходит в низкое состояние после чтения одного байта данных, либо после сброса прерывания.

#### **3.12.5.3 UARTTXINTR**

Инв. № дубл.

Взам. инв. №

Подп. и дата

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

- буфер FIFO разрешён и его заполнение меньше или равно заданному пороговому значению. В этом случае линия прерывания переходит в высокое состояние. Сигнал прерывания переходит в низкое состояние после записи данных в буфера передатчика до тех пор, пока его заполнение не станет больше порога, либо после сброса прерывания;
- буфер FIFO запрещён (имеет размер один символ), данные в буферном регистре передатчика отсутствуют. При этом линия прерывания переходит в высокое состояние.

|     |        |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|--------|----------|-------|------|-----------------------------------|
|     |        |          |       |      | Техническое описание              |
| Изи | 1 Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

175

Лист

Сигнал прерывания переходит в низкое состояние после записи одного байта данных, либо после сброса прерывания.

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

Примечание — Прерывание передатчика срабатывает по фронту, а не по уровню сигнала.

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

#### **3.12.5.4 UARTRTINTR**

Прерывание по таймауту приёмника возникает в случае, если буфер FIFO приёмника не пуст, и на вход приёмника не поступало новых данных в течение периода времени, необходимого для передачи 32 бит.

Прерывание по таймауту снимается либо после считывания данных из буфера приёмника до его опустошения (или считывания одного байта в случае, если буфер FIFO запрещён), либо путём записи «1» в соответствующий бит регистра сброса прерывания UARTICR.

#### **3.12.5.5 UARTEINTR**

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

Оно может быть вызвано рядом факторов:

- ошибка в структуре кадра;
- ошибка контроля чётности;
- разрыв линии;

Инв. № дубл.

Взам. инв. №

Подп. и дата

— переполнение буфера.

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

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

#### 3.12.5.6 UARTINTR

Все описанные сигналы запроса на прерывание скомбинированы в общую линию путём объединения по схеме «ИЛИ» сигналов UARTRXINTR, UARTRXINTR и UARTEINTR с учётом маскирования. Общий выход может быть подключен к системному контроллеру прерывания, что позволит ввести дополнительное маскирование запросов на уровне периферийных устройств.

- 3.12.6 Программное управление модулем
- 3.12.6.1 Общая информация, применимая ко всем регистрам контроллера

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

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

- запрещено изменение значений не определённых в документе разрядов регистров;
- все биты регистров (за исключением специально оговоренных случаев) устанавливаются в значение «0» после сброса по включению питания или системного сброса.

Столбец «Тип» таблицы 3.12.3 определяет режим доступа к регистру в соответствии с обозначениями:

- RW чтение и запись;
- RO только чтение;
- WO только запись.

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г. Лист 177

Формат А4

## 3.12.6.2 Обобщённые данные о регистрах устройства

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Данные о регистрах модуля универсального асинхронного приёмопередатчика приведены в таблице3.12.3.

Таблица 3.12.3 — Описание регистров модуля универсального асинхронного приёмопередатчика UARTx

| Смещение    | Название<br>регистра | Тип | Значение по сбросу | Ширина | Описание                                                                    |
|-------------|----------------------|-----|--------------------|--------|-----------------------------------------------------------------------------|
| 0x000       | DR                   | RW  | 0x                 | 12/8   | UARTx -> DR<br>Регистр данных                                               |
| 0x004       | RSR_ECR              | RW  | 0x0                | 4/0    | UARTx -> RSR_ECR<br>Регистр состояния приёмника / Сброс<br>ошибки приёмника |
| 0x008-0x014 |                      |     |                    |        | Зарезервировано                                                             |
| 0x018       | FR                   | RO  | 0b-10010           | 9      | UARTx -> FR<br>Регистр флагов                                               |
| 0x01C       |                      |     |                    |        | Зарезервировано                                                             |
| 0x020       | _                    |     |                    |        | Зарезервировано                                                             |
| 0x024       | IBRD                 | RW  | 0x0000             | 16     | UARTx -> IBRD Целая часть делителя скорости обмена данными                  |
| 0x028       | FBRD                 | RW  | 0x00               | 6      | UARTx -> FBRD Дробная часть делителя скорости обмена данными                |
| 0x02C       | LCR H                | RW  | 0x00               | 8      | UARTx -> LCR_H Регистр управления линией                                    |
| 0x030       | CR                   | RW  | 0x0300             | 16     | UARTx -> CR Регистр управления                                              |
| 0x034       | IFLS                 | RW  | 0x12               | 6      | UARTx -> IFLS Регистр порога прерывания по заполнению буфера FIFO           |
| 0x038       | FMSC                 | RW  | 0x000              | 11     | UARTx -> IMSC<br>Регистр маски прерывания                                   |
| 0x03C       | RIS                  | RO  | 0x00-              | 11     | UARTx -> RIS<br>Регистр состояния прерываний                                |
| 0x040       | MIS                  | RO  | 0x00-              | 11     | UARTx -> MIS Регистр состояния прерываний с маскированием                   |
| 0x044       | ICR                  | wo  | _                  | 11     | UARTx -> ICR<br>Регистр сброса прерывания                                   |
| 0x048       | DMACR                | RW  | 0x00               | 3      | UARTx -> DMACR Регистр управления DMA                                       |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023ВС016 Техническое описание Версия 2.04 от 01.09.2017 г.

178

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

В противном случае, записанное слово фиксируется в буферный регистр передатчика (последний элемент буфера FIFO).

Операция записи в регистр инициирует передачу данных. Слово данных предваряется стартовым битом, дополняется битом контроля чётности (если режим контроля четности включен) и стоповым битом. Сформированное слово отправляется в линию передачи данных.

В ходе приёма данных, если буфер FIFO приёмника разрешён, байт данных и четыре бита состояния (разрыв, ошибка формирования кадра, чётность, переполнение) сохраняются в 12-битном буфере.

В противном случае байт данных и биты состояния записываются в буферный регистр (последний элемент буфера FIFO).

Полученные из линии связи байты данных считывается путём чтения из регистра DR принятых данных совместно с соответствующими битами состояния. Информация о состоянии также может быть получена путём чтения регистра UARTRSR/UARTECR (таблица 3.12.4).

Таблица 3.12.4 — Описание регистра UARTx->DR

|         | 1            |                                                                       |
|---------|--------------|-----------------------------------------------------------------------|
| № бита  | Наименование | Функциональное назначение бита, краткое описание назначения и         |
|         | бита         | принимаемых значений                                                  |
| 1       | 2            | 3                                                                     |
| 15 - 12 |              | Резерв                                                                |
|         | OE           | Переполнение буфера приёмника. Бит устанавливается в «1» в случае,    |
| 11      |              | если на вход приёмника поступают данные, когда буфер заполнен.        |
|         |              | Сбрасывается в «0» после того, как в буфере появится свободное место  |
|         | BE           | Разрыв линии. Устанавливается в «1» при обнаружении признака разрыва  |
|         |              | линии, т.е. в случае наличия низкого логического уровня на входе      |
|         |              | приёмника в течение времени, большего чем длительность передачи       |
|         |              | полного слова данных (включая стартовый, стоповый биты и бит проверки |
| 10      |              | на чётность). При включенном FIFO данная ошибка ассоциируется с       |
|         |              | последним символом, поступившим в буфер. В случае обнаружения         |
|         |              | разрыва линии в буфер загружается только один нулевой символ, приём   |
|         |              | данных возобновляется только после перехода линии в логическую «1» и  |
|         |              | последующего обнаружения корректного стартового бита                  |
| Ī       | <u> </u>     |                                                                       |

Изм Лист № докум. Подп. Дата

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

179

| Продо. | лжение | таб | лицы | 3.12.4 |
|--------|--------|-----|------|--------|
|        |        |     |      |        |

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

| 1   | 2    | 3                                                                                                                                                                                                                                                                            |
|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | PE   | Ошибка контроля чётности. Устанавливается в «1» в случае, если чётность принятого символа данных не соответствует установкам бит EPS и SPS в регистре управления линией UARTLCR_H. При включенном FIFO данная ошибка ассоциируется с последним символом, поступившим в буфер |
| 8   | FE   | Ошибка в структуре кадра. Устанавливается в «1» в случае, если в принятом символе не обнаружен корректный стоповый бит (корректный стоповый бит равен 1). При включенном FIFO данная ошибка ассоциируется с последним символом, поступившим в буфер                          |
| 7-0 | DATA | Принимаемые данные (чтение).<br>Передаваемые данные (запись)                                                                                                                                                                                                                 |

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

3.12.6.4 Регистр UARTx -> RSR\_ECR (регистр состояния приёмника/сброса ошибки)

Состояние приёмника также может быть считано из регистра UARTx -> RSR\_ECR. В этом случае информация о состоянии признаков разрыва линии, ошибки контроля чётности и ошибки в структуре кадра относится к последнему символу, считанному из регистра данных DR.

С другой стороны, признак переполнения буфера устанавливается немедленно после возникновения этого состояния (и не связан с последним считанным из регистра DR байтом данных).

Запись в регистр UARTx -> RSR\_ECR приводит к сбросу признаков ошибок переполнения, чётности, структуры кадра, разрыва линии. Кроме того, все эти признаки устанавливаются в «0» после сброса устройства.

Таблица 3.12.5 содержит описание регистров UARTx -> RSR\_ECR.

| № бита | Наименование<br>бита                                                                                                                                                                                                                                                                                                                                               | Функциональное назначение бита, краткое описание назначения и принимаемых значений.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 – 4  |                                                                                                                                                                                                                                                                                                                                                                    | Резерв, при чтении результат не определен.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3      | Переполнение буфера приёмника. Бит устанавливается в «1» в случае, если на вход приёмника поступают данные, в то время как буфер заполнен. Сбрасывается в «0» после записи в регистр UARTECR. Содержимое буфера остается верным, так как перезаписан был только регистр сдвига. Центральный процессор должен считать данные для того, чтобы освободить буфер 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 необходимо считать данные, принятые из линии, путём обращения к регистру данных DR. Противоположная последовательность действий не допускается, так как регистр UARTRSR обновляет свое состояние только после чтения регистра DR. Вместе с тем, информация о состоянии приёмника может быть получена непосредственно из регистра данных DR.
- 2. Запись в регистр UARTRSR/UARTECR любого кода сбрасывает признаки ошибок формирования кадра, проверки на четность, разрыва линии и переполнения буфера.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 181  |

## 3.12.6.5 Регистр UARTx -> FR (регистр флагов)

После сброса биты регистра флагов TXFF, RXFF и BUSY устанавливаются в 0, а биты TXFE и RXFE — в 1. В таблице 3.12.6 представлено описание регистра UARTFR.

Таблица 3.12.6 — Описание регистра UARTx -> FR

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                               |  |
|--------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15 – 9 | _                    | Резерв. Не модифицируется. При чтении заполняются нулями                                                                                                                                                                                                                                                                                                         |  |
| 8      | RI                   | Инверсия линии nUARTRI                                                                                                                                                                                                                                                                                                                                           |  |
| 7      | TXFE                 | Буфер FIFO передатчика пуст. Значение бита зависит от состояния бита FEN регистра управления линией UARTLCR_H. Если буфер FIFO запрещён, бит устанавливается в «1» когда буферный регистр передатчика пуст. В противном случае он равен 1 если пуст буфер FIFO передатчика. Данный бит не даёт никакой информации о наличии данных в регистре сдвига передатчика |  |
| 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-0    | _                    | Не используются                                                                                                                                                                                                                                                                                                                                                  |  |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

Описание регистра UARTBIRD показано в таблице 3.12.7.

Таблица 3.12.7 — Описание регистра UARTBIRD

| № бита  | Наименование | Функциональное назначение бита, краткое описание назначения и     |
|---------|--------------|-------------------------------------------------------------------|
| M2 Onta | бита         | принимаемых значений                                              |
|         |              | Целая часть коэффициента деления частоты для формирования         |
| 15 - 0  | BAUDDIV INT  | тактового сигнала передачи данных. После сброса устанавливается в |
|         |              | «0».                                                              |

3.12.6.7 Регистр UARTx -> FBRD (регистр дробной части делителя скорости передачи данных)

Таблица 3.12.8 содержит описание регистра UARTx -> FBRD.

Таблица 3.12.8 — Описание регистра UARTx -> FBRD

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений.                                                |
|--------|----------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 5-0    | BAUDDIV_FRAC         | Дробная часть коэффициента деления частоты для формирования тактового сигнала передачи данных. После сброса устанавливается в «0». |

Коэффициент деления вычисляется по формуле

$$BAUDDIV = FUARTCLK/(16 \cdot Baud_rate), \tag{9}$$

где FUARTCLK — тактовая частота контроллера UART,

Baud\_rate — требуемая скорость передачи данных.

Коэффициент BAUDDIV состоит из целой и дробной частей — BAUDDIV INT и BAUDDIV FRAC, соответственно.

Примечания:

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

- 1. Изменение содержимого регистров UARTIBRD и UARTFBRD вступают в силу только после завершения передачи и приёма текущего символа данных;
- 2. Минимальный допустимый коэффициент деления равен 1, максимальный 65535 (216 1). Таким образом, значение UARTIBRD, равное 0, является недопустимым, при этом значение регистра UARTFBRD игнорируется;
- 3. При UARTIBRD, равном 65535 (0xFFFF), значение UARTFBRD не может быть больше нуля. Невыполнение этого условия приведёт к прерыванию приёма или передачи.

Микросхема интегральная 5023BC016
Техническое описание
Изм Лист № докум. Подп. Дата
Версия 2.04 от 01.09.2017 г.

Копировал

Формат А4

Лист

183

Пример вычисления коэффициента деления

Пусть требуемая скорость передачи данных составляет 230400 бит/с, частота тактового сигнала UARTCLK равна 4 МГц. Тогда:

коэффициент деления =  $(4 \cdot 106) / (16 \cdot 230400) = 1,085$ .

Таким образом, BRDI = 1, BRDF = 0.085.

Следовательно, значение, записываемое в регистр UARTBFRD, равно:

 $m = integer ((0.085 \cdot 64) + 0.5) = 5.$ 

Реальное значение коэффициента деления = 1 + 5/64 = 1,078.

Реальная скорость передачи данных =  $(4 \cdot 106) / (16 \cdot 1,078) = 231911$  бит/с.

Ошибка установки скорости =  $(231911 - 230400) / 230400 \cdot 100 \% = 0,656 \%$ .

Максимальная ошибка установки скорости передачи данных с использованием шестиразрядного регистра UARTBFRD =  $1/64 \cdot 100 \% = 1,56 \%$ . Такая ошибка возникает в случае m = 1, при этом разница накапливается в течение 64 тактовых интервалов.

#### 3.12.6.8 Регистр UARTx -> LCR\_H (регистр управления линией)

Данный регистр обеспечивает доступ к разрядам с 29 по 22 регистра UARTLCR. При сбросе все биты регистра UARTLCR\_Н обнуляются.

Таблица 3.12.9 содержит назначение разрядов регистра UARTLCR\_H.

Таблица 3.12.9 — Описание регистра UARTx -> LCR\_H

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений                                                                                                                                                                                                                                                                                 |
|--------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | 2                    | 3                                                                                                                                                                                                                                                                                                                                                                  |
| 15 – 8 |                      | Резерв. Не модифицируется. При чтении выдаются нули.                                                                                                                                                                                                                                                                                                               |
| 7      | SPS                  | Передача бита чётности с фиксированным значением. 0 — запрещена; 1 — на месте бита чётности передается инверсное значение бита EPS, оно же проверяется при приёме данных. (При EPS = 0 на месте бита четности передается 1, при EPS = 1 — передается 0). Значение бита SPS не играет роли в случае, если битом PEN формирование и проверка бита чётности запрещён. |
| 6-5    | WLEN                 | Длина слова — количество передаваемых или принимаемых информационных бит в кадре: 0b11 — 8 бит; 0b10 — 7 бит; 0b01 — 6 бит; 0b00 — 5 бит.                                                                                                                                                                                                                          |

Изм Лист № докум. Подп. Дата

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

184

| Продола | жение табли | <i>цы 3.12.</i> |
|---------|-------------|-----------------|
| 1       | 2           |                 |
|         |             | Donnarijai      |

| 1 | 2    | 3                                                                     |
|---|------|-----------------------------------------------------------------------|
|   |      | Разрешение работы буфера FIFO приёмника и передатчика.                |
| 4 | FEN  | 0 — запрещено;                                                        |
|   |      | 1 — разрешено.                                                        |
|   |      | Режим передачи двух стоповых бит.                                     |
|   |      | 0 — один стоповый бит;                                                |
| 3 | STP2 | 1— два стоповых бита.                                                 |
|   |      | Приёмник не проверяет наличие дополнительного стопового бита в        |
|   |      | кадре.                                                                |
|   |      | Четность/нечетность.                                                  |
|   | EPS  | 0 — бит четности дополняет количество единиц в                        |
| 2 | LIS  | информационной части кадра до нечётного;                              |
|   |      | 1 — до чётного числа. Значение бита EPS не играет роли в случае, если |
|   |      | битом PEN формирование и проверка бита чётности запрещена.            |
|   |      | Разрешение проверки четности.                                         |
| 1 | PEN  | 0 — кадр не содержит бита четности;                                   |
| 1 |      | 1 — бит чётности передается в кадре и проверяется при приёме          |
|   |      | данных.                                                               |
|   |      | Разрыв линии. Если этот бит установлен в «1», то по завершении        |
|   |      | передачи текущего символа на выходе UARTTXD устанавливается           |
|   |      | низкий уровень сигнала. Для правильного выполнения этой операции      |
| 0 | BRK  | программное обеспечение должно обеспечить передачу сигнала            |
|   |      | разрыва в течение, как минимум, времени передачи двух                 |
|   |      | информационных кадров. В нормальном режиме функционирования           |
|   |      | бит должен быть установлен в «0».                                     |

Содержимое регистров UARTLCR H, UARTIBRD и UARTFBRD совместно образует общий 30-разрядный регистр UARTLCR, который обновляется по стробу, формируемому при записи в UARTLCR\_H. Таким образом, для того, чтобы изменение параметров коэффициента деления частоты обмена данными вступило в силу, после изменения значения регистров UARTIBRD и/или UARTFBRD необходимо осуществить запись данных в регистр UARTLCR H.

Примечание — Изменение значений трёх регистров можно осуществить корректно двумя способами:

- запись UARTIBRD, запись UARTFBRD, запись UARTLCR H;
- запись UARTFBRD, запись UARTIBRD, запись UARTLCR H.

Для того, чтобы изменить значение лишь одного из регистров (UARTIBRD или UARTFBRD), необходимо выполнить запись UARTIBRD (или UARTFBRD), запись UARTLCR H.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

1в. № подл.

Микросхема интегральная 5023ВС016 Техническое описание Версия 2.04 от 01.09.2017 г.

185

Таблица 3.12.10 — Управление режимом контроля четности

| PEN | EPS | SPS | Бит контроля чётности            |  |
|-----|-----|-----|----------------------------------|--|
| 0   | X   | X   | Не передается, не проверяется    |  |
| 1   | 1   | 0   | Проверка чётности слова данных   |  |
| 1   | 0   | 0   | Проверка нечётности слова данных |  |
| 1   | 0   | 1   | Бит чётности постоянно равен 1   |  |
| 1   | 1   | 1   | Бит чётности постоянно равен 0   |  |

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

Инв. № дубл.

Взам. инв. №

Подп. и дата

- 1) Регистры UARTLCR\_H, UARTIBRD и UARTFBRD не должны изменяться при следующих условиях:
  - при разрешённой работе приёмопередатчика;
- во время завершения приёма или передачи данных в процессе остановки (перевода в запрещённое состояние) приёмопередатчика;
- 2) Целостность данных в буферах FIFO не гарантируется в следующих случаях:
  - после установки бита разрыва линии BRK;
- если программное обеспечение произвело остановку приёмопередатчика при наличии данных в буферах FIFO после его повторного перевода в разрешённое состояние.

# 3.12.6.9 Регистр UARTx -> CR (регистр управления)

После сброса все биты регистра управления UARTx -> CR, за исключением бит 9 и 8 устанавливаются в нулевое состояние. Биты 9 и 8 устанавливаются в единичное состояние.

Назначение разрядов регистра управления приведено в таблице 3.12.11.

Таблица 3.12.11 — Описание регистра управления UARTx -> CR

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений |
|---------|----------------------|------------------------------------------------------------------------------------|
| 1       | 2                    | 3                                                                                  |
| 15 – 10 | _                    |                                                                                    |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 186  |

Копировал

Формат А4

|   |                                                                                        | ı            |                                                                                                |  |  |  |  |  |
|---|----------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------|--|--|--|--|--|
|   |                                                                                        |              | Передача разрешена. Установка бита в «1» разрешает работу                                      |  |  |  |  |  |
|   |                                                                                        | TXE          | передатчика. Передача осуществляется по интерфейсу асинхронного                                |  |  |  |  |  |
|   | 8                                                                                      |              | последовательного обмена. В случае перевода приёмопередатчик в                                 |  |  |  |  |  |
|   |                                                                                        |              | запрещённое состояние в ходе передачи данных, он завершает передачу                            |  |  |  |  |  |
|   |                                                                                        |              | текущего символа: перед остановкой.                                                            |  |  |  |  |  |
|   |                                                                                        |              | 0 — запрещено;                                                                                 |  |  |  |  |  |
|   | 7                                                                                      | LBE          | 1 — шлейф разрешён. выходная линия передатчика UARTTXD коммутируется на вход                   |  |  |  |  |  |
|   | ,                                                                                      | LDE          | приёмника UARTRXD.                                                                             |  |  |  |  |  |
|   |                                                                                        |              | После сброса бит устанавливается в «0»                                                         |  |  |  |  |  |
|   | 6 – 3                                                                                  |              | Резерв. Не модифицируется. При чтении выдаются нули.                                           |  |  |  |  |  |
|   | 2                                                                                      | _            | Не используется. Должны быть нули.                                                             |  |  |  |  |  |
|   | 1                                                                                      | _            | Не используется. Должны быть нули.                                                             |  |  |  |  |  |
|   |                                                                                        |              | Разрешение работы приёмопередатчика:                                                           |  |  |  |  |  |
|   |                                                                                        |              | 0 — функционирование запрещено. Перед остановкой завершается                                   |  |  |  |  |  |
|   | 0                                                                                      | UARTEN       | приём и/или передача обрабатываемого в текущий момент символа.                                 |  |  |  |  |  |
|   |                                                                                        |              | 1 — функционирование разрешено. Производится обмен данными либо по линиям асинхронного обмена. |  |  |  |  |  |
| 1 |                                                                                        | _            | по липили исинаропного обмени.                                                                 |  |  |  |  |  |
|   | Π                                                                                      | римечания:   |                                                                                                |  |  |  |  |  |
|   | 1)                                                                                     | ) Для того,  | чтобы разрешить передачу данных, необходимо установить в                                       |  |  |  |  |  |
|   | логичес                                                                                | скую 1 биты  | TXE и UARTEN. Аналогично, для разрешения приёма данных                                         |  |  |  |  |  |
|   | необход                                                                                | димо устано  | вить в 1 биты RXE и UARTEN.                                                                    |  |  |  |  |  |
|   | 2)                                                                                     | ) Рекоменду  | ется следующая последовательность действий для                                                 |  |  |  |  |  |
|   | програм                                                                                | ммирования   | регистров управления:                                                                          |  |  |  |  |  |
| ļ | _                                                                                      | – остановиті | ь работу приёмопередатчика;                                                                    |  |  |  |  |  |
|   | <ul> <li>дождаться окончания приёма и/или передачи текущего символа данных;</li> </ul> |              |                                                                                                |  |  |  |  |  |
|   | _                                                                                      | – сброс бу   | фера передатчика путём установки бита FEN регистра                                             |  |  |  |  |  |
|   | UARTL                                                                                  | .CR_Н в 0;   |                                                                                                |  |  |  |  |  |
|   | _                                                                                      | – изменение  | настроек регистра UARTCR;                                                                      |  |  |  |  |  |
|   |                                                                                        |              |                                                                                                |  |  |  |  |  |

последовательного обмена

остановкой.

3 Приём разрешён. Установка бита в «1» разрешает работу приёмника.

В случае перевода приёмопередатчика в запрещённое состояние в ходе

Приём данных осуществляется по интерфейсу асинхронного

приёма данных, он завершает приём текущего символа перед

Продолжение таблицы 3.12.11

**RXE** 

9

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Лист

№ докум.

Подп.

Дата

- возобновление работы приёмопередатчика.

Микросхема интегральная 5023ВС016

Техническое описание Версия 2.04 от 01.09.2017 г. Лист

187

Perucтр UARTx -> IFLS используется для установки порогового значения заполнения буферов передатчика и приёмника, по достижению которых UARTRXINTR, генерируется сигнал UARTTXINTR прерывания или соответственно. Прерывание генерируется в момент перехода величины заполнения буфера через заданное значение.

После сброса В регистре устанавливается порог, соответствующий заполнению половины буфера. Описание регистра UARTx -> IFLS и значения представлен в таблице 3.12.12.

Таблица 3.12.12 — Описание регистра UARTx -> IFLS

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений                                                                                                                                             |
|--------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 6 | _                    |                                                                                                                                                                                                                                |
| 5-3    | RXIFLSEL             | Порог прерывания по заполнению буфера приёмника: b000 = буфер заполнен на 1/8; b001 = буфер заполнен на 1/4; b010 = буфер заполнен на 1/2; b011 = буфер заполнен на 3/4; b100 = буфер заполнен на 7/8; b101 - b111 = резерв.   |
| 2-0    | TXIFLSEL             | Порог прерывания по заполнению буфера передатчика: b000 = буфер заполнен на 1/8; b001 = буфер заполнен на 1/4; b010 = буфер заполнен на 1/2; b011 = буфер заполнен на 3/4; b100 = буфер заполнен на 7/8; b101 - b111 = резерв. |

3.12.6.11 Регистр UARTx -> IMSC (регистр установки сброса маски прерывания)

При чтении регистра UARTx -> IMSC выдается текущее значение маски. При записи производится установка или сброс маски на соответствующее прерывание.

После сброса все биты регистра маски устанавливаются в нулевое состояние. Назначение бит регистра UARTx -> IMSC содержится в таблице 3.12.13.

| 1    |       |           |       |        |                                                      |           |      |
|------|-------|-----------|-------|--------|------------------------------------------------------|-----------|------|
|      |       |           |       |        | Микросхема интегральная 5023E                        | 3C016     | Лист |
| 140  |       | No Bounds | По 3- | //amaa | Техническое описание<br>Версия 2.04 от 01.09.2017 г. |           | 188  |
| VI3I | Jiucm | № докум.  | Подп. | Дата   | Копировал                                            | Формат А4 | ,00  |

| № бита  | Наименование | Функциональное назначение бита, краткое описание назначения и                           |
|---------|--------------|-----------------------------------------------------------------------------------------|
|         | бита         | принимаемых значений.                                                                   |
| 31 - 11 | _            |                                                                                         |
| 10      | OEIM         | Маска прерывания по переполнению буфера UARTOEINTR: 1 — установлена; 0 — сброшена.      |
| 9       | BEIM         | Маска прерывания по разрыву линии UARTBEINTR: 1 —установлена; 0 — сброшена.             |
| 8       | PEIM         | Маска прерывания по ошибке контроля чётности UARTPEINTR: 1 — установлена; 0 — сброшена. |
| 7       | FEIM         | Маска прерывания по ошибке в структуре кадра UARTFEINTR: 1 — установлена; 0 — сброшена. |
| 6       | RTIM         | Маска прерывания по таймауту приёма данных UARTRTINTR: 1 — установлена; 0 — сброшена.   |
| 5       | TXIM         | Маска прерывания от передатчика UARTTXINTR.<br>1 — установлена; 0 — сброшена.           |
| 4       | RXIM         | Маска прерывания от приёмника UARTRXINTR. 1 — установлена; 0 — сброшена.                |
| 3-0     | <del>-</del> | Не используется.                                                                        |

#### 3.12.6.12 Регистр UARTx -> RIS (регистр состояния прерываний)

Регистр UARTx -> RIS доступен только для чтения и содержит текущее состояние прерываний без учета маскирования. Данные, записываемые в регистр UARTx -> RIS, игнорируются.

Предупреждение — После сброса все биты регистра, за исключением бит прерывания по состоянию модема (биты с 3 по 0), устанавливаются в «0». Значение бит прерывания по состоянию модема после сброса не определено.

Описание регистра UARTx -> RIS представлено в таблице 3.12.14.

Таблица 3.12.14 — Описание регистра UARTx -> RIS

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений |
|---------|----------------------|------------------------------------------------------------------------------------|
| 1       | 2                    | 3                                                                                  |
| 31 – 11 | _                    |                                                                                    |
| 10      | OERIS                | Состояние прерывания по переполнению буфера UARTOEINTR.                            |
| 9       | BERIS                | Состояние прерывания по разрыву линии UARTBEINTR.                                  |
| 8       | PERIS                | Состояние прерывания по ошибке контроля чётности UARTPEINTR.                       |
| 7       | FERIS                | Состояние прерывания по ошибке в структуре кадра UARTFEINTR.                       |
| 6       | RTRIS                | Состояние прерывания по таймауту приёма данных UARTRTINTR.                         |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

189

Продолжение таблицы 3.12.4

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

| 1   | 2     | 3                                               |
|-----|-------|-------------------------------------------------|
| 5   | TXRIS | Состояние прерывания от передатчика UARTTXINTR. |
| 4   | RXRIS | Состояние прерывания от приёмника UARTRXINTR.   |
| 3-0 | _     | Не используется                                 |

3.12.6.13 Регистр UARTx -> MIS (регистр маскированного состояния прерываний)

Регистр UARTx -> MIS доступен только для чтения и содержит текущее состояние прерываний с учетом маскирования. Данные, записываемые в регистр, игнорируются.

После сброса все биты регистра, за исключением бит прерывания по состоянию модема (биты с 3 по 0), устанавливаются в «0». Значение бит прерывания по состоянию модема после сброса не определено.

Описание регистра UARTx -> MIS представлено в таблице 3.12.15.

Таблица 3.12.15 — Описание регистра UARTx -> MIS

|         | TT           |                                                                            |
|---------|--------------|----------------------------------------------------------------------------|
| № бита  | Наименование | Функциональное назначение бита, краткое описание назначения и              |
| л⊻оита  | бита         | принимаемых значений.                                                      |
| 31 – 11 | _            |                                                                            |
| 10      | OEMIS        | Маскированное состояние прерывания по переполнению буфера UARTOEINTR.      |
| 9       | BEMIS        | Маскированное состояние прерывания по разрыву линии UARTBEINTR.            |
| 8       | PEMIS        | Маскированное состояние прерывания по ошибке контроля чётности UARTPEINTR. |
| 7       | FEMIS        | Маскированное состояние прерывания по ошибке в структуре кадра UARTFEINTR. |
| 6       | RTMIS        | Маскированное состояние прерывания по таймауту приёма данных UARTRTINTR.   |
| 5       | TXMIS        | Маскированное состояние прерывания от передатчика UARTTXINTR.              |
| 4       | RXMIS        | Маскированное состояние прерывания от приёмника UARTRXINTR.                |
| 3 – 0   | 0            | Не используется. Должны быть нули.                                         |

# 3.12.6.14 Регистр UARTx -> ICR (регистр сброса прерываний)

Регистр UARTx -> ICR доступен только для записи и предназначен для сброса признака прерывания по заданному событию путём записи «1» в соответствующий бит. Запись нуля в любой из разрядов регистра игнорируется.

|     |      |          |       |      | Микросхема интегральная 5023ВС016                         | Лист    |
|-----|------|----------|-------|------|-----------------------------------------------------------|---------|
| -   |      |          |       |      | тикросхема интегральная 302360010<br>Техническое описание | Jideili |
| Изл | Лист | № докум. | Подп. | Дата | Версия 2.04 om 01.09.2017 e.                              | 190     |

Копировал

Таблица 3.12.16 — Описание регистра UARTx -> ICR

| № бита  | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений |
|---------|----------------------|------------------------------------------------------------------------------------|
| 31 – 11 | _                    |                                                                                    |
| 10      | OEIC                 | Сброс прерывания по переполнению буфера UARTOEINTR.                                |
| 9       | BEIC                 | Сброс прерывания по разрыву линии UARTBEINTR.                                      |
| 8       | PEIC                 | Сброс прерывания по ошибке контроля чётности UARTPEINTR.                           |
| 7       | FEIC                 | Сброс прерывания по ошибке в структуре кадра UARTFEINTR.                           |
| 6       | RTIC                 | Сброс прерывания по таймауту приёма данных UARTRTINTR.                             |
| 5       | TXIC                 | Сброс прерывания от передатчика UARTTXINTR.                                        |
| 4       | RXIC                 | Сброс прерывания от приёмника UARTRXINTR.                                          |
| 3-0     | _                    | Не используется. Должны быть нули.                                                 |

3.12.6.15 Регистр UARTx -> DMACR (регистр управления прямым доступом к памяти)

Регистр UARTx -> DMACR доступен по чтению и записи. После сброса все биты регистра обнуляются.

Описание регистра UARTx -> DMACR представлено в таблице 3.12.17.

Таблица 3.12.17 — Описание регистра UARTx -> DMACR

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание назначения и принимаемых значений                                                                        |
|--------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 3 | _                    |                                                                                                                                                           |
| 2      | DMAONERR             | Если бит установлен в «1», то в случае возникновения прерывания по обнаружению ошибки блокируются запросы DMA от приёмника UARTRXDMASREQ и UARTRXDMABREQ. |
| 1      | TXDMAE               | Использование DMA при передаче. Если бит установлен в «1», то разрешено формирование запросов DMA для обслуживания буфера FIFO передатчика.               |
| 0      | RXDMAE               | Использование DMA при приёме. Если бит установлен в «1», то разрешено формирование запросов DMA для обслуживания буфера FIFO приёмника.                   |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

#### 3.13.1 Общее описание

Таймер общего назначения представляет собой 32-битный счётчик с обратным отсчётом.

Когда счётчик доходит до 0, происходит генерация сигнала прерывания ТІМЕRІNТ. Сигнал прерывания удерживается в активном состоянии до сброса регистра статуса прерывания INTCLEAR.

Если счётчик дошёл до 0, и в тот же момент программа очистила предыдущий статус прерывания, то статус прерывания устанавливается в «1».

Структурная схема таймера представлена на рисунке 3.13.1.



Рисунок 3.13.1 — Структурная схема таймера АРВ

В таблице 3.13.1 приведено распределение адресного пространства таймера APB

Таблица 3.13.1 — Регистры интерфейса таймера

Тодп. и дата.

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

| Смещение | Наименование<br>регистра | Тип | Значение по<br>сбросу | Описание                                                                                   |
|----------|--------------------------|-----|-----------------------|--------------------------------------------------------------------------------------------|
| 0x000    | CTRL                     | RW  | 0x0                   | [3] Разрешение прерывания таймера;<br>[2] Всегда «0»;<br>[1] Всегда «0»;<br>[0] Включение. |
| 0x004    | VALUE                    | RW  | 0x00000000            | [31:0] Текущее значение                                                                    |
| 0x008    | RELOAD                   | RW  | 0x00000000            | [31:0] Значение перезапуска. Запись в этот регистр задает текущее значение.                |
| 0x00C    | INTCLEAR                 | RW  | 0x00000000            | Регистр сброса прерывания                                                                  |

|     |      |          |       |      | Микросхема интегральная 5023BC016                    | Лист |
|-----|------|----------|-------|------|------------------------------------------------------|------|
| Изм | Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 192  |

Копировал

Формат А4

#### 3.14 Сторожевой таймер

Тодп. и дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подп.

#### 3.14.1 Описание сторожевого таймера

Сторожевой таймер позволяет сбросить систему в случае отказа программного обеспечения. Пользователь может включать или выключать таймер по собственному усмотрению.

Сторожевой таймер представляет собой 32-битный счётчик с обратным отсчётом, который инициализируется из регистра WDOGLOAD. Счётчик может быть сброшен любой записью в регистр WDOGINTCLR. Когда счётчик достигает значение «0» без сброса его записью в регистр WDOGINTCLR генерируется прерывание и счётчик устанавливается в значение WDOGLOAD. Далее продолжается обратный отсчёт. Если счётчик повторно достигает значения «0» без сброса любой записью в регистр WDOGINTCLR, то сторожевой таймер устанавливает сигнал WDOGRES сброса процессора.

На рисунке 3.14.1 представлена диаграмма состояний сторожевого таймера.

#### 3.14.2 Регистры сторожевого таймера (Watchdog)

Формат регистров сторожевого таймера (Watchdog) приведён в таблице 3.14.1.



| Смещение | Наименование<br>регистра | Тип | Значение по сбросу | Описание                              |
|----------|--------------------------|-----|--------------------|---------------------------------------|
| 0x00     | WDOGLOAD                 | RW  | 0xFFFFFFF          |                                       |
| 0x04     | WDOGVALUE                | RO  | 0xFFFFFFF          |                                       |
| 0x08     | WDOGCONTROL              | RW  | 0x0                |                                       |
| 0x0C     | WDOGINTCLR               | WO  | _                  | Описание регистров                    |
| 0x10     | WDOGRIS                  | RO  | 0x0                | содержится в отдельных таблицах ниже. |
| 0x14     | WDOGMIS                  | RO  | 0x0                | raomique mine.                        |
| 0xC00    | WDOGLOCK                 | RW  | 0x0                |                                       |
| 0xF00    | WDOGITCR                 | RW  | 0x0                |                                       |
| 0xF04    | WDOGITOP                 | WO  | 0x0                |                                       |

#### 3.14.2.1 WDOGLOAD (Watchdog Load Register)

32-битный регистр WDOGLOAD, хранит начальное значение счётчика. Когда происходит запись в этот регистр, счётчик сразу инициируется новым значением. Минимальное допустимое значение счёта составляет 0х00000001.

#### 3.14.2.2 WDOGVALUE (Watchdog Value Register)

WDOGVALUE — текущее значение счётчика.

# 3.14.2.3 WDOGCONTROL (Watchdog Control Register)

WDOGCONTROL — регистр программного управления сторожевым таймером, доступный для чтения и записи. Описание регистра WDOGCONTROL приведено в таблице 3.14.2.

Таблица 3.14.2 — Описание регистра WDOGCONTROL

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | _     | Функциональное назначение бита, краткое описание бита назначения и                                                                                                                                                                                                  |
|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | бита  | принимаемых значений                                                                                                                                                                                                                                                |
| 31 - 2 | _     |                                                                                                                                                                                                                                                                     |
| 1      | RESEN | Разрешает выход сброса сторожевого таймера WDOGRES. Работает как маска по функции «Логическое И» для этого выхода. Устанавливается в «1» для включения сброса, в «0» — для выключения.                                                                              |
| 0      | INTEN | Разрешает выход прерывания WDOGINT. Устанавливается в «1» для включения счётчика и срабатывания прерывания и в «0» — для выключения счётчика и выключения прерывания. Если счётчик был выключен, то после включения он инициируется значением из регистра WDOGLOAD. |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 194  |

Копировал

Формат А4

Запись любого значения в регистр WDOGINTCLR приводит к сбросу прерывания сторожевого таймера и сброса счётчика в значение из регистра WDOGLOAD.

#### 3.14.2.5 WDOGRIS (Watchdog Raw Interrupt Status Register)

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

Описание регистра WDOGRIS приведено в таблице 3.14.3.

Таблица 3.14.3 — Описание регистра WDOGRIS

| № бита | Наименование<br>бита      | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|---------------------------|-----------------------------------------------------------------------------------------|
| 31 – 1 | _                         | Зарезервировано                                                                         |
| 0      | Raw Watchdog<br>Interrupt | Значение немаскированного бита прерывания                                               |

#### 3.14.2.6 WDOGMIS (Watchdog Interrupt Status Register)

Регистр прерывания WDOGMIS доступен только для чтения. Регистр сигнализирует о появлении маскированного прерывания из счётчика. Это значение получается путём вычисления логического «И» со значениями первичного прерывания (rawinterrupt) из регистра WDORIS и бита включения прерывания INTEN из регистра управления WDOGCONTOL.

Описание регистра WDOGMIS приведено в таблице 3.14.4.

Таблица 3.14.4 — Описание регистра WDOGMIS

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование | Функциональное назначение бита, краткое описание бита |  |
|--------|--------------|-------------------------------------------------------|--|
| л⊻онта | бита         | назначения и принимаемых значений                     |  |
| 31 – 1 | _            | Зарезервировано                                       |  |
| 0      | Watchdog     | Значение маскированного бита прерывания               |  |
|        | Interrupt    | эначение маскированного онта прерывания               |  |

# 3.14.2.7 WDOGLOCK (Watchdog Lock Register)

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

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 195  |

Копировал

Описание регистра WDOGLOCK приведено в таблице 3.14.5.

Таблица 3.14.5 — Описание регистра WDOGLOCK

| № бита | Наименование бита            | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                 |
|--------|------------------------------|-------------------------------------------------------------------------------------------------------------------------|
| 31 – 1 | _                            | Зарезервировано                                                                                                         |
| 0      | Register Write enable status | <ul> <li>3апись во все регистры разрешена, значение по умолчанию.</li> <li>запись во все регистры запрещена.</li> </ul> |

#### 3.14.2.8 WDOGITCR

Peructp Watchdog Integration Test Control Register (WDOGITCR) поддерживает однобитовый чтение. Это регистр, который включает модуль интеграционного тестирования.

В режиме интеграционного тестирования порты WDOGINT и WDOGRES управляются из регистра WDOGITOP.

Описание регистра WDOGITCR приведено в таблице 3.14.6.

Таблица 3.14.6 — Описание регистра WDOGITCR

| № бита | Наименование бита                                                               | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| 31 – 1 | ŀ                                                                               | Зарезервировано                                                                         |
| 0      | Integration Test Module Enable – включение модуля интеграционного тестирования. | Когда установлен в «1», переводит сторожевой таймер в состояние тестирования.           |

#### **3.14.2.9 WDOGITOP**

Инв. № дубл.

Взам. инв. №

Подп. и дата

Perucrp Watchdog Integration Test Output Set Register (WDOGITOP) доступен только для записи. В режиме тестирования данные, находящиеся в данном регистре напрямую управляют выходными портами сброса и прерываний.

Описание регистра WDOGITOP приведено в таблице 3.14.7.

|     |      |          |       |      | Микросхема интегральная 5023BC016                    | Лист |
|-----|------|----------|-------|------|------------------------------------------------------|------|
| Изм | Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 om 01.09.2017 г. | 196  |
|     |      | -        | •     | #    | Копировал Формат М                                   |      |

Таблица 3.14.7 — Описание регистра WDOGITOP

| № бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-----------------------------------------------------------------------------------------|
| 31 – 2 | Зарезервировано.                                                                        |
| 1      | Выходное значение порта WDOGINT в режиме тестирования.                                  |
| 0      | Выходное значение порта WDOGRES в режиме тестирования.                                  |

- 3.15 Передатчик телеметрической информации
- 3.15.1 Описание структуры передатчика телеметрической информации

Структурная схема передатчика телеметрической информации приведена на рисунке 3.15.1.



Рисунок 3.15.1 — Структурная схема ПдТМИ

ПдТМИ состоит из следующих составляющих блоков:

- блок кодеров LDPC;
- турбо-кодер (ТК);

Тодп. и дата

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подл.

- кодер Рида-Соломона (РСК);
- блок сериалайзера (БС). Передатчик телеметрии позволяет передавать битовый поток напрямую без кодирования, при этом используется блок сериалайзера;

| ист № докум. | Подп. | Дата        | Версия 2.04 от 01.09.2017 г.      | 197   |
|--------------|-------|-------------|-----------------------------------|-------|
|              |       |             |                                   |       |
|              |       |             | Техническое описание              | 40-   |
|              |       | <del></del> | Микросхема интегральная 5023ВС016 | Лист  |
|              |       |             |                                   | · _ · |

- блок рандомизатора (БР);
- блок вставки синхромаркера (БВС);
- сверточный кодер (СК).

# 3.15.2 Описание работы интерфейса передатчика телеметрической информации

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

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

Кодирование битового потока осуществляется одним из алгоритмов помехозащищенного кодирования (LDPC-кодер, Turbo-кодер, кодер Рида-Соломона). Кодированный поток поступает на блок рандомизатора, далее на блок вставки синхромаркера, далее на сверточный кодер. При этом программная настройка позволяет пропускать данные насквозь без использования кодирования, рандомизации или без свёрточного кодирования.

Структура блоков помехозащищённого кодирования и рандомизатора подробно описана в соответствующих разделах (п. 3.15.2.1 – 3.15.2.5).

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

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

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

После прохождения через блоки кодирования, данные поступают на выходной буфер типа FIFO, откуда передаются на внешнюю шину при наличии входного тактового сигнала ТМ\_СLКІ. Отслеживать состояние заполненности буфера можно по специальному флагу, выставление которого свидетельствует о том, что буфер пуст. Размер выходного буфера FIFO равен 256 бит.

Передача данных осуществляется по однобитной шине TM\_DOUT и тактируется внешним тактовым сигналом TM\_CLKI. По возрастающему фронту сигнала TM\_CLKI на шину TM\_DOUT выдается следующий бит кодированного потока данных и сигнал TM\_DOUT\_VALID принимает значение «высокий уровень». Логическая «1» кодируется на шине высоким уровнем, а логический «0» - низким уровнем сигнала. Максимальное значение частоты входного тактового сигнала FTM\_CLKI, определяющей скорость выходного битового потока, зависит от включенных кодеков, но при любых настройках не должно быть более половины системной частоты FSYS

$$FTM\_CLKI \le FSYS/2. \tag{10}$$

Информация о выходном интерфейсе физического уровня обобщена в таблице 3.15.1.

Таблица 3.15.1 — Выходной интерфейс передатчика телеметрической информации

Инв. № дубл.

Взам. инв. №

Подп. и дата

| Наименование сигнала | Направление | Функциональное назначение                                              |
|----------------------|-------------|------------------------------------------------------------------------|
| TM_CLKI              | Вход        | Входной тактовый сигнал                                                |
| TM_DOUT_VALID Выход  |             | Признак наличия данных на шине                                         |
| TM_DOUT              | Выход       | Выходные данные, обновляются по возрастающему фронту тактового сигнала |

Временная диаграмма выходных сигналов изображена на рисунке 3.15.2.

|     |      |          |       |      | Микросхема интегральная 5023Е | 3C016     | Лист |
|-----|------|----------|-------|------|-------------------------------|-----------|------|
|     |      |          |       |      | Техническое описание          |           | 400  |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.  |           | 199  |
|     |      |          |       |      | Копировал                     | Формат А4 |      |



Рисунок 3.15.2 — Выходной интерфейс передатчика телеметрической информации

#### 3.15.2.1 Кодер Рида-Соломона

Данный блок реализует алгоритм помехоустойчивого кодирования Рида-Соломона.

Кодер Рида-Соломона описывается в стандарте CCSDS-131.0-B-2.

В соответствии с данными стандартами кодер Рида-Соломона имеет следующие характеристики:

объём символа — 8 бит;

Тодп. и дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

- объём кодового слова 255 символов;
- поддержка кодов с параметрами E = 8 (255, 239) и E = 16 (255, 223);
- полином поля:  $F(x) = x^8 + x^7 + x^2 + x + 1$ ;
- генераторный полином кода E=8:  $g_{esa}(x) = \prod_{i=120}^{135} (x \alpha^{11i}) = \sum_{k=0}^{16} g_{j} x^{j};$
- генераторный полином кода E=16:  $g_{esa}(x) = \prod_{i=1}^{143} (x \alpha^{11i}) = \sum_{k=0}^{32} g_j x^j.$

В коде с параметрами (255,239) первые 239 символов являются информативными, оставшиеся 16 содержат проверочные данные. Код позволяет исправлять 8 символов в кодовом слове.

В коде с параметрами (255,223) первые 223 символов являются информативными, оставшиеся 32 содержат проверочные данные. Код позволяет исправлять 16 символов в кодовом слове.

Структурная схема кодера Рида-Соломона изображена на рисунке 3.15.3.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.



Рисунок 3.15.3 — Структурная схема кодера Рида-Соломона

#### 3.15.2.2 Турбо-кодер

В соответствии со стандартом CCSDS в турбо-кодере содержится два составляющих турбо-кодер нерекурсивных сверточных кодера, каждый из которых имеет небольшое количество состояний, генерируют проверочные символы. Вместе с проверочными символами в формировании выходной последовательности турбо-кодера участвуют незакодированные входные информационные биты. Нерекурсивные сверточные энкодеры, образованные сдвиговыми регистрами с обратными связями. Обратные связи регистров задаются векторами G0, а прямые связи — векторами G1, G2 и G3. Ключевое отличие этих энкодеров от базового сверточного кодера — рекурсивность, то есть наличие обратных связей.

В соответствии со стандартом CCSDS турбо-кодер имеет следующие основные характеристики:

- обратный вектор для всех скоростей кодирования G0 = 10011;
- прямой вектор для обеих составляющих кодера и скоростей кодирования 1/2 и 1/3 G1 = 11011. При скорости кодирования 1/2 все символы, кроме символов с выходов G1 обоих компонентов кодера, выбиваются. Без выбивания скорость кодирования составляет 1/3;
- прямые вектора для скорости 1/4: G2 = 10101, G3 = 11111, для 1-го сверточного кодера и G1 = 11011 для 2-го сверточного кодера. Скорость кодирования на этих выходах без выбивания составляет 1/4;
- прямые вектора для скорости 1/6: G1 = 11011, G2 = 10101, G3 = 11111 для 1-го сверточного кодера, G3 = 11111 для 2-го сверточного кодера. Скорость кодирования на этих выходах без выбивания составляет 1/6.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| 1зм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |

Low Density Parity Check Code (LDPC-кодер) реализует алгоритм помехоустойчивого кодирования LDPC NASA CCSDS C2 (8160, 7136) и полностью совместим со стандартом GSFC–STD–9100 (Low Density Parity Check Code for Rate 7/8).

LDPC энкодер состоит из блока управления и блока умножения на генерирующую матрицу. Структура блока умножения на генерирующую матрицу показана на рисунке 3.15.4.

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



Рисунок 3.15.4 — Структура блока умножения на генерирующую матрицу

# 3.15.2.4 Рандомизатор

Инв. № дубл.

Взам. инв.

Подп. и дата

чв. № подл.

Рандомизатор (блок наложения ПСП) выполняет кодирование данных в соответствии со стандартами CCSDS-131.0-В-2. Блок выполняет скремблирование — обратимое преобразование цифрового потока без изменения скорости передачи с целью получения свойств случайной последовательности.

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|--------|----------|-------|------|-----------------------------------|------|
|     |        |          |       |      | Техническое описание              | 200  |
| Изі | л Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 202  |

После скремблирования появление «1» и «0» в выходной последовательности равновероятны. Рандомизация является обратимым процессом, исходное сообщение можно восстановить, применив обратный алгоритм.

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

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

соответствии со стандартом, полиномом рандомизатора является:  $h(x) = x^8 + x^7 + x^5 + x^3 + 1$ , используемый как в виде линейного сдвигового регистра с обратными связями Фибоначчи, инициализируемой между фреймами.

Структурная схема рандомизатора показана на рисунке 3.15.5.



Рисунок 3.15.5 — Структурная схема рандомизатора

# 3.15.2.5 Сверточный кодер

Тодп. и дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

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

Структурная схема сверточного кодера без прореживания изображена на рисунке 3.15.6.

Микросхема интегральная 5023ВС016 Лист Техническое описание 203 Версия 2.04 от 01.09.2017 г. Пист № докум. Подп. *Д*ата

Рисунок 3.15.6 — Структура сверточного энкодера без прореживания

Схема сверточного кодера с прореживанием описывается в стандарте CCSDS-131.0-В-1. Четыре различных схемы прореживания битов предоставляют выбор большинства необходимых скоростей кодирования (2/3, 3/4, 5/6 или 7/8) и соответствующих уровней коррекции ошибок.

Структурная схема сверточного кодера с прореживанием изображена на рисунке 3.15.7.



Рисунок 3.15.7 — Структура сверточного кодера с прореживанием

Образующими многочленами обоих сверточных кодеров являются  $G1 = 1111001 \ (171 \ OCT)$  и  $G2 = 1011011 \ (133 \ OCT)$ .

Блоком поддерживается перфорация до скоростей 2/3, 3/4, 5/6 и 7/8. Порядок следования битов:

- при скорости 2/3: C1(1), C2(1), C2(2) ...
- при скорости 3/4: C1(1), C2(1), C2(2), C1(3) ...
- при скорости 5/6: C1(1), C2(1), C2(2), C1(3), C2(4), C1(5) ...
- при скорости 7/8: C1(1), C2(1), C2(2), C2(3), C2(4), C1(5), C2(6), C1(7) ...

где C1(n) и C2(n) — биты, сформированные при помощи многочленов G1 и G2 соответственно.

Изм Лист № докум. Подп. Дата

Тодп. и дата

Инв. № дубл.

Взам. инв.

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

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

- отключить блоки кодирования записью в регистр GLOBAL\_ENABLE значения «0». Это необходимо для того, чтобы вносимые изменения вступили в силу после включения блоков, т.к. обновление параметров блоков происходит по переходу GLOBAL\_ENABLE из «0» в «1»;
- с помощью регистра CODER\_SEL включить в работу необходимый блок помехозащищённого кодирования, рандомизатора, сверточный кодер;
- произвести настройку кодирующих блоков в регистре CODER\_CONFIG. Каждый блок может работать в одном из нескольких режимов, поддерживаемых стандартом;
- произвести настройку синхромаркера. В регистре MARKER\_AND\_FRAME\_SIZE необходимо настроить период вставки синхромаркера и его размер в битах (не более 192 бит). Для работы в соответствии со стандартом CCSDS необходимо настроить период вставки синхромаркера (размер фрейма) в зависимости от выбранных кодеков. То есть, задаваемый период должен быть равен размеру фрейма после проведения кодирования (таблица 3.15.2). Регистры MARKER1 MARKER6 определяют содержимое синхромаркера;

Инв. № дубл.

Взам. инв. №

Подп. и дата

Таблица 3.15.2 — Данные для определения размеров фрейма в зависимости от выбранного кодера и его режима работы

| Тип кодера             | Размер фрейма информационных данных на входе энкодера (в байтах) | Размер фрейма на выходе энкодера (в битах) |
|------------------------|------------------------------------------------------------------|--------------------------------------------|
| 1                      | 2                                                                | 3                                          |
| Reed-Solomon (255,239) | 239                                                              | 255x8 = 2040                               |
| Reed-Solomon (255,223) | 223                                                              | 255x8 = 2040                               |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изи | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 205  |

Копировал

| 223x8x2 + 4x2 = 3576  |
|-----------------------|
|                       |
| 223x8x3 + 4x3 = 5364  |
| 223x8x4 + 4x4 = 7152  |
| 223x8x6 + 4x6 = 10728 |
| 8160                  |
|                       |

- настроить дескрипторы на передачу. Для управления каждым дескриптором используется два регистра DSCRx PTR и DSCRx FLAG SIZE Регистр DSCRx PTR задает адрес начала области пользовательской памяти, с которого начнется вычитывание данных для передачи блоки кодирования. Регистр DSCRx FLAG SIZE определяет количество вычитываемых байт (от 1 до 2048) и включает дескриптор в работу;
- запустить блоки кодирования в работу записью в GLOBAL\_ENABLE значения «1». После этого открытые дескрипторы начнут вычитывание данных. Первым начинает работу дескриптор с номером 1. Также после включения следует сбросить флаг опустошения FIFO путём записи в регистр PHY\_FIFO\_UNDERRUN значения «1». Это позволит отслеживать состояние передающего буфера во время работы;
- по завершению работы дескриптора вызывается прерывание. Для обоих дескрипторов используется один общий вектор прерывания. Определить, какой из дескрипторов завершил работу и готов для дальнейшей настройки, можно по состоянию бита DATA\_PRES в регистре DSCRx\_FLAG\_SIZE. Если необходимо передавать поток данных большего размера, чем может быть помещён в два дескриптора, потребуется повторное открытие дескриптора после его закрытия. При этом для обеспечения непрерывности битового потока на выходе блока дескриптор должен быть повторно настроен до того, как второй дескриптор завершит работу;
- после того, как все необходимые данные были переданы из пользовательской памяти и отправлены на физический уровень, будет выставлен в «1» флаг PHY\_FIFO\_UNDERRUN. Это свидетельствует о том, что блоки кодирования полностью завершили обработку и передачу данных. Если флаг

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

чв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

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

#### 3.15.4 Регистры передатчика телеметрической информации

Перечень регистров передатчика телеметрической информации приведён в таблице 3.15.3. Описание регистров общего назначения приведено в таблицах 3.15.4 — 3.15.11.

Таблица 3.15.3 — Перечень регистров передатчика телеметрической информации

| Смещение    | Название регистра     | Тип | Значение по сбросу | Описание                                     |
|-------------|-----------------------|-----|--------------------|----------------------------------------------|
| 0x00        | DSCR1_PTR             | RW  | 0                  | Дескриптор 1: указатель на область памяти.   |
| 0x04        | DSCR1_FLAG_SIZE       | RW  | 0                  | Дескриптор 1: флаги и размер области памяти. |
| 0x08        | DSCR2_PTR             | RW  | 0                  | Дескриптор 2: указатель на область памяти.   |
| 0x0C        | DSCR2_FLAG_SIZE       | RW  | 0                  | Дескриптор 2: флаги и размер области памяти. |
| 0x10        | GLOBAL_ENABLE         | RW  | 0                  | Включение блока в режим передачи.            |
| 0x14        | CODER_SEL             | RW  | 0                  | Выбор энкодеров.                             |
| 0x18        | PHY_FIFO_UNDERRUN     | RW  | 0                  | Флаг опустошения FIFO.                       |
| 0x1C        | MARKER_AND_FRAME_SIZE | RW  | 0                  | Размер фрейма и размер синхромаркера.        |
| 0x20        | MARKER1               | RW  | 0                  | Содержимое синхромаркера.                    |
| 0x24        | MARKER2               | RW  | 0                  | Содержимое синхромаркера.                    |
| 0x28        | MARKER3               | RW  | 0                  | Содержимое синхромаркера.                    |
| 0x2C        | MARKER4               | RW  | 0                  | Содержимое синхромаркера.                    |
| 0x30        | MARKER5               | RW  | 0                  | Содержимое синхромаркера.                    |
| 0x34        | MARKER6               | RW  | 0                  | Содержимое синхромаркера.                    |
| 0x38        | CODERS_CONFIG         | RW  | 0                  | Настройки энкодеров.                         |
| 0x3C-0xFFFF | _                     |     |                    | Не используется, читается 0.                 |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Таблица 3.15.4 — Описание регистров DSCR1\_PTR, DSCR2\_PTR

| № бита  | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                          |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Nº Onia | бита         | назначения и принимаемых значений                                                                                                                              |
| 31 – 2  | DSCR_PTR     | указатель на начало передаваемой области данных во внутренней памяти. Начало области должно быть выровнено по 4-байтной границе, младшие 2 бита указателя нули |
| 1 – 0   |              |                                                                                                                                                                |

#### 3.15.4.2 Регистры DSCR1 FLAG SIZE, DSCR2 FLAG SIZE

Таблица 3.15.5 — Описание регистров DSCR1\_FLAG\_SIZE, DSCR2\_FLAG\_SIZE

| № бита              | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31                  | DATA_PRES<br>(RW)    | следует записать «1», когда данные этого дескриптора готовы для передачи. Когда GLOBAL_ENABLE = 1, то данный дескриптор будет задействован, и данные, на которые ссылается этот дескриптор, будут считываться из внутренней памяти и записываться во внутренние буферы энкодеров. В этот момент изменение полей DSCR_PTR и DATA_SIZE дескриптора не оказывает влияния. Когда все данные считаются и запишутся во внутренние буферы, в поле DATA_PRES будет аппаратно записан 0. |
| 30 – 11             | _                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10-0 DATA_SIZE (RW) |                      | размер передаваемой области данных в байтах минус 1. Например, если 0, то передаём 1 байт, если 1, то передаём 2 байта, если 2047 — передаём 2048 байт.                                                                                                                                                                                                                                                                                                                         |

Примечание — Если установлены флаги DATA\_PRES в двух дескрипторах, и аппаратный блок не работает ни с одним из них (это может быть только в первый момент после включения блока через GLOBAL\_ENABLE), то первым для передачи выбирается дескриптор номер 1 (DSCR1).

# 3.15.4.3 Регистр GLOBAL\_ENABLE

Инв. № дубл.

Взам. инв. №

Подп. и дата

Таблица 3.15.6 — Описание регистра GLOBAL\_ENABLE

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                           |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 1 | ı                 |                                                                                                                                                                   |
| 0      | (RW)              | <ul> <li>0 — все энкодеры, FIFO, АНВ контроллер находятся в асинхронном сбросе.</li> <li>1 — включение всех модулей, ответственных за передачу данных.</li> </ul> |

Примечание — Конфигурация энкодеров, которая задается через регистры CODER\_SEL, MARKER\_AND\_FRAME\_SIZE, MARKER1-6, CODERS\_CONFIG,

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 208  |

Копировал

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

#### 3.15.4.4 Регистр PHY FIFO UNDERRUN

Таблица 3.15.7 — Описание регистра PHY\_FIFO\_UNDERRUN

| № бита | Наименование бита           | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 1 | -                           | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0      | PHY_FIFO_UNDERRUN<br>(RW1C) | флаг опустошения асинхронного FIFO, нет данных для передачи на физический уровень. В этом случае сигнал TM_DOUT_VALID устанавливается в «0». Это может происходить вследствие длительного формирования данных для передачи во внутренней памяти, когда флаги DATA_PRES обоих дескрипторов находятся в нуле длительное время. Чтобы этого избежать, необходимо либо оптимизировать работу программы, либо уменьшить частоту следования выходных данных за счёт снижения тактовой частоты на входе TM_CLKI |

Примечание — В самом начале работы при переходе GLOBAL ENABLE из нуля в единицу, флаг устанавливается в «1», необходимо подождать, пока данные будут подаваться в выходной блок FIFO и далее сбросить флаг.

# 3.15.4.5 Регистр CODER SEL

Инв. № дубл.

Взам. инв. №

Подп. и дата

Таблица 3.15.8 — Описание регистра CODER\_SEL

| № бита | Наименование бита     | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                           |
|--------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 4 |                       |                                                                                                                                                   |
| 3      | RAND_SEL (RW)         | 1 — выбор рандомизатора;                                                                                                                          |
| 2      | CONV_SEL (RW)         | 1 — выбор сверточного энкодера;                                                                                                                   |
| 1-0    | BIG_CODER_SEL<br>(RW) | выбор одного из энкодеров в цепочке: 1 — выбор LDPC-энкодера; 2 — выбор Turbo-энкодера; 3 — выбор RS-энкодера; 0 — ни один из перечисленных выше. |

|    |        |          |       |      | Микросхема интегральная 5023                         | BBC016    | Лист |
|----|--------|----------|-------|------|------------------------------------------------------|-----------|------|
| Из | м Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 om 01.09.2017 г. |           | 209  |
|    |        |          |       |      | Копировал                                            | Формат А4 |      |

### 3.15.4.6 Peгистр MARKER\_AND\_FRAME\_SIZE

Таблица 3.15.9 — Описание регистра MARKER\_AND\_FRAME\_SIZE

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|---------|-------------------|-----------------------------------------------------------------------------------------|
| 31 - 24 | _                 |                                                                                         |
| 23 – 16 | MARKER_SIZE (RW)  | размер тела синхромаркера в битах                                                       |
| 15 – 0  | FRAME_SIZE (RW)   | период вставки синхромаркера в битах                                                    |

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

- 1. Размер фрейма определяется типом используемого помехозащищённого кодера. Пользователь должен высчитать размер фрейма с учётом дополнительных бит создаваемых энкодером, и записать нужное значение в поле FRAME\_SIZE. Таблица 3.15.9 содержит данные для определения размеров фрейма в случае применения всевозможных типов кодеров.
  - 2. Если размер маркера равен 0, то синхромаркер не вставляется.

#### 3.15.4.7 Регистры MARKER1 – MARKER6

Таблица 3.15.10 — Описание регистров MARKER1 - MARKER6

| № бита | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                              |  |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|        | бита         | назначения и принимаемых значений                                                                                                                                  |  |
| 31 – 0 | MARKER (RW)  | содержимое синхромаркера. Первым передается бит с номером 0 регистра MARKER1, последним, если размер синхромаркера выставлен 192 бита, 31-ый бит регистра MARKER6. |  |

# 3.15.4.8 Peгистр CODERS\_CONFIG(RW)

# Таблица 3.15.11 — Описание регистра EXTMEM CTRL

| № бита    | Наименование | Функциональное назначение бита, краткое описание бита     |
|-----------|--------------|-----------------------------------------------------------|
| J 12 OHTU | бита         | назначения и принимаемых значений                         |
| 1         | 2            | 3                                                         |
| 31 - 25   | -            |                                                           |
|           |              | Тип LDPC энкодера:                                        |
| 24        | LDPC_Type    | 0 — (8160 ,7136);                                         |
|           |              | Для корректной работы в этом поле должно быть значение 0. |
| 23 - 18   | _            |                                                           |
|           |              | тип энкодера RS:                                          |
|           | RS_Type      | [16] 0 - (255,239);                                       |
| 17 – 16   |              | 1 - (255,223);                                            |
|           |              | [17] 0 — обычный;                                         |
|           |              | 1 — dual basis converted.                                 |
| 15 – 10   | _            |                                                           |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

210

| 1     | 2          | 3                                                                                                                |
|-------|------------|------------------------------------------------------------------------------------------------------------------|
| 9 – 8 | Turbo_rate | тип Turbo кодера: 0 — rate 1/2; 2 — rate 1/4; 1 — rate 1/3; 3 — rate 1/6.                                        |
| 7 – 3 | -          |                                                                                                                  |
| 2-0   | Conv_rate  | тип сверточного энкодера: 2 — rate 2/3; 3 — rate 3/4; 5 — rate 5/6; 7 — rate 7/8; остальные значения — rate 1/2. |

- 3.16 Приёмник телекомандной информации
- 3.16.1 Общее описание приёмника телекомандной информации

Структурная схема приёмника телекомандной информации приведена на рисунке 3.16.1.



Рисунок 3.16.1 — Структурная схема ПрТКИ

Приёмник телекомандной информации состоит из следующих функциональных блоков:

декодера Витерби;

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

чв. № подл.

блока поиска синхромаркера (БПС);

|     |      |          |       |      | Микросхема интегральная 5023 |
|-----|------|----------|-------|------|------------------------------|
|     |      |          |       |      | Техническое описание         |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г. |

Лист 211

5023BC016

— блока дерандомизатора (БД).

3.16.2 Описание работы интерфейса приёмника телекомандной информации Функциональный блок приёмника телекомандной информации позволяет принимать битовый поток данных, закодированных в соответствии со стандартом

CCSDS, осуществлять его декодирование и сохранять полученные данные в

пользовательской памяти.

Инв. № дубл.

Взам. инв. №

Подп. и дата

Интерфейс физического уровня содержит сигнал входного тактового сигнала TC\_CLKI, сигнал активности данных TC\_ACT и шину данных TC\_DIN. Логическая «1» на шине данных передаётся в виде высокого уровня сигнала, логический «0» — в виде низкого уровня. Данные с шины считываются в блок по возрастающему фронту сигнала TC\_CLKI. Высокий уровень сигнала TC\_ACT свидетельствует о наличии данных на шине в момент прихода возрастающего фронта сигнала TC\_CLKI. Для корректной работы декодеров блока частота тактового входного сигнала FTC\_CLKI должна быть меньше системной тактовой частоты FSYS в соответствии с условием

$$FTC\_CLKI \le 0,4 \cdot FSYS. \tag{11}$$

Информация о входном интерфейсе физического уровня обобщена в таблице 3.16.1.

Таблица 3.16.1 — Входной интерфейс приёмника телекомандной информации

| Наименование сигнала | Направление | Функциональное назначение                                             |  |  |
|----------------------|-------------|-----------------------------------------------------------------------|--|--|
| TC_CLKI              | Вход        | Входной тактовый сигнал                                               |  |  |
| TC_ACT               | Вход        | Признак наличия данных на шине                                        |  |  |
| TC_DIN               | Вход        | Входные данные, считываются по возрастающему фронту тактового сигнала |  |  |

Временная диаграмма сигналов входного интерфейса изображена на рисунке 3.16.2.

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|--------|----------|-------|------|-----------------------------------|------|
|     |        |          |       |      | Техническое описание              |      |
| Изг | 1 Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 212  |



Рисунок 3.16.2 — Входной интерфейс приёмника телекомандной информации Буфер FIFO, получающий входной битовый поток, имеет размер 256 бит.

Входной битовый поток поступает из входного FIFO на блок поиска синхромаркера либо напрямую, либо после прохождения через сверточный декодер Витерби. В соответствии со стандартом синхромаркер представляет из себя фиксированную последовательность из 16 бит, значение которой устанавливается программно. Если во входном потоке встречается указанная последовательность, это трактуется блоком БПС как начало фрейма, и он передаётся для дальнейшей обработки.

Декодер БЧХ позволяет найти и исправить одну битовую ошибку на 7 байт данных из поступающего битового потока. Каждый восьмой байт в принимаемом фрейме используется в качестве контрольной суммы для поиска и исправления битовой ошибки в предыдущих 7 байтах. В связи с такой логикой работы размер полезных данных в каждом фрейме должен быть кратен 7 байтам.

Если БЧХ декодер обнаруживает неисправимую ошибку (что должно проявляться в случае, если в пакете из 7 байт искажено более 2 бит данных), на этом приём фрейма завершается, при этом в принимающем дескрипторе выставляется флаг ошибки (см. описание ниже).

Исправленные данные поступают на блок дерандомизатора, который производит дескремблирование данных.

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

Изм Лист № докум. Подп. Дата

Тодп. и дата.

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Передача декодированных данных в область пользовательской памяти осуществляется за счёт системы дескрипторов. Поддерживается до шестнадцати дескрипторов, каждый из которых при открытии позволяет принять от 1 до 1024 байт декодированных данных. При приёме битового потока дескрипторы используются последовательно, то есть при завершении работы дескриптора с номером N, активен становится дескриптор с номером N + 1, если он был до этого настроен на работу. Если же этот дескриптор не был открыт к моменту переключения на него, приём данных остановится и при наличии данных на входном интерфейсе произойдет переполнение входного FIFO.

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

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

По закрытию каждого дескриптора происходит вызов прерывания. Блоком приёма телекоманд используется единственный вектор прерывания.

# 3.16.2.1 Декодер Витерби

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

| 1 |     |      |          |       |      |  |
|---|-----|------|----------|-------|------|--|
|   | Изм | Лист | № докум. | Подп. | Дата |  |

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Декодер Витерби состоит из следующих функциональных блоков:

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

На рисунке 3.16.3 представлена структурная схема декодера Витерби.



Рисунок 3.16.3 — Структурная схема декодера Витерби

Декодер Витерби обладает следующими характеристиками:

- порождающие полиномы кода g1 = 171OCT, g2 = 133OCT, K = 7;
- скорости декодирования 1/2, 2/3, 3/4, 5/6, 7/8;
- возможность декодирования жестких и трёх- и четырёхуровневых «мягких» решений;
  - глубина декодирования 128 бит.

# 3.16.2.2 БЧХ декодер

Инв. № дубл.

Взам. инв. №

Подп. и дата

1в. № подл.

Блок предназначен для декодирования кода БЧХ с порождающим полиномом  $g(x) = x^7 + x^6 + x^2 + 1$  согласно стандарту CCSDS 231.0-B-2. Он выполняет вычисление синдрома и исправление одной ошибки путём перебора ее возможных позиций. Блок выдает предупреждение о неисправимой ошибке, если вычисленному синдрому не соответствует ни одна из возможных позиций ошибочного бита.

На рисунке 3.16.4 показана функциональная схема декодера БЧХ.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              | 0.45 |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 215  |

Копировал

Формат А4



Рисунок 3.16.4 — Функциональная схема декодера БЧХ

### 3.16.2.3 Дерандомизатор

Тодп. и дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

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

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

Блок выполнен согласно стандарту CCSDS 231.0-В-2 и использует псевдослучайную последовательность с порождающим полиномом  $h(x) = x^8 + x^6 + x^4 + x^3 + x^2 + x + 1$ . Структурная схема дерандомизатора показана на рисунке 3.16.5.



Рисунок 3.16.5 — Структурная схема дерандомизатора

3.16.3 Программная модель управления приёмником телекомандной информации

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

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 216  |

Копировал

регистров на шине АРВ. Последовательность действий в общем случае описана ниже:

- а) отключить блоки приёмника телекоманд записью в регистр GLOBAL\_ENABLE значения «0». Это необходимо для того, чтобы вносимые изменения вступили в силу после включения блоков, т.к. обновление параметров блоков происходит по переходу GLOBAL ENABLE из «0» в «1»;
- б) произвести настройку блока поиска синхромаркера. Содержимое стартовой последовательности задаётся в регистре START\_SEQ, содержимое хвостовой последовательности задаётся в регистрах TAIL1\_SEQ и TAIL2\_SEQ. Путём задания специального бита в регистре START\_SEQ можно включить разрешение единичной битовой ошибки в стартовой последовательности. В этом случае последовательность бит, отличающаяся одним разрядом от установленной в регистре, также будет считаться корректной стартовой последовательностью;
- в) произвести включение/отключение отдельных функциональных блоков: БЧХ-декодера, рандомизатора. Блоки включаются в соответствующих полях регистра CODER\_SEL. Регистр GLOBAL\_ENABLE используется для включения декодеров в работу, при этом обновлённые значения из регистров CODER\_SEL окажут влияние только по переходу содержимого GLOBAL ENABLE из «0» в «1»;
- г) запустить блоки приёмника телекоманд в работу записью в GLOBAL ENABLE значения «1»;
- д) задать номер активного дескриптора в регистре DSCR\_CURRENT. Приём данных начнётся с данного дескриптора;

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

- е) включить необходимые дескрипторы в работу. Для включения каждого дескриптора используется по два регистра. Регистр DSCR\_PTRx используется для указания начала области пользовательской памяти, в которую будет производиться запись декодированных данных. Для открытия дескриптора регистр DSCR\_FLAG\_SIZEx используется следующим образом:
  - 1) задается размер дескриптора в поле DATA\_SIZE (от 1 до 1024 Б);
  - 2) дескриптор включается в работу записью «1» в поле DSCR\_READY;

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 217  |

- ж) по мере поступления данных на вход блока приёмника телекоманд активный в настоящий момент дескриптор будет производить запись данных в пользовательскую память после прохождения их через декодирующие модули. Дескриптор будет закрыт в одном из случаев:
  - 1) количество принятых данных превысило выделенный в дескрипторе размер;
  - 2) фрейм завершился до того, как количество принятых данных превысило выделенный в дескрипторе размер;
  - 3) декодером БЧХ была обнаружена неисправимая ошибка при приёме пакета;
  - 4) в каждом из перечисленных случаев управление будет передано следующему по номеру дескриптору;
  - 5) если следующий дескриптор в этот момент открыт, поступающие далее на вход данные продолжат записываться в пользовательскую память в соответствии с указанным в дескрипторе адресом;
  - 6) если же следующий дескриптор закрыт, данные не будут переданы в пользовательскую память, и, если в буфере FIFO закончится место для приёма последующих данных, будет выставлен флаг переполнения FIFO в регистре PHY\_FIFO\_OVERFLOW. После того, как произошло переполнение, дальнейший приём будет корректен только после перезапуска модулей приёмника телекоманд записью в GLOBAL\_ENABLE значений «0» и «1» последовательно;
    - з) после закрытия дескриптора происходят следующие события:
      - 1) выставляется прерывание;

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

2) в поле DATA\_SIZE регистра DSCR\_FLAG\_SIZEх записывается количество принятых дескриптором данных;

 Микросхема интегральная 5023ВС016
 Лист

 Техническое описание
 Техническое описание

 Изм Лист
 № докум.
 Подп.
 Дата

Микросхема интегральная 5023ВС016
Техническое описание
Версия 2.04 от 01.09.2017 г.
218

- 3) поле DSCR\_READY регистра DSCR\_FLAG\_SIZEx сбрасывается в «0»;
- 4) в поле DSCR\_FLAGS регистра DSCR\_FLAG\_SIZEх записывается значение флагов о получении начала фрейма, конца фрейма или ошибки декодирования;
- 5) поле DSCR\_NUM регистра DSCR\_CURRENT инкрементируется. Если до этого значение DSCR\_NUM было равно 15, в него запишется значение «0»;
- и) после обработки полученных данных с помощью завершившего работу дескриптора необходимо заново перезапустить дескриптор (см. пункт 5) для приёма последующих поступающих данных.
  - 3.16.4 Описание регистров приёмника телекомандной информации

Состав регистров приёмника телекомандной информации приведено в таблице 3.16.2.

Описание регистров приёмника телекомандной информации приведены в таблицах 3.16.3 – 3.16.10.

Таблица 3.16.2 — Состав регистров приёмника телекомандной информации

| Смещение    | Название регистра | Тип | Значение по сбросу | Описание                                                         |
|-------------|-------------------|-----|--------------------|------------------------------------------------------------------|
| 0x00 - 0x7C | DSCR_TBL          | RW  | 0                  | Таблица дескрипторов: 16 дескрипторов (2 слова один дескриптор). |
| 0x80        | DSCR_CURRENT      | RW  | 0                  | Текущий дескриптор.                                              |
| 0x84        | GLOBAL_ENABLE     | RW  | 0                  | Вкл. блока в режим приёма данных.                                |
| 0x88        | CODER_SEL         | RW  | 0                  | Настройка декодеров                                              |
| 0x0C        | PHY_FIFO_OVERFLOW | RW  | 0                  | Флаг переполнения FIFO                                           |
| 0x90        | START_SEQ         | RW  | 0                  | Содержимое стартовой последовательности                          |
| 0x94        | TAIL_SEQ1         | RW  | 0                  | Содержимое хвостовой последовательности                          |
| 0x98        | TAIL_SEQ2         | RW  | 0                  | Содержимое хвостовой последовательности                          |
| 0x9C-0xFFFF | -                 |     |                    | Не используется, читается 0.                                     |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

219

DSCR\_TBL — таблица дескрипторов — 16 дескрипторов. Каждый дескриптор состоит из двух регистров. Первый регистр DSCR\_PTR, второй — DSCR\_FLAG\_SIZE.

### 3.16.4.1 Регистры DSCR PTR

Таблица 3.16.3 — Описание регистра DSCR\_PTR

| № бита | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                                                       |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻онта | бита         | назначения и принимаемых значений                                                                                                                                                           |
| 31 – 2 |              | указатель на начало области во внутренней памяти, предназначенной для записи принятых данных. Начало области должно быть выровнено по 4 байтной границе, младшие 2 бита указателя — нулевые |
| 1 - 0  | _            |                                                                                                                                                                                             |

### 3.16.4.2 Регистры DSCR\_FLAG\_SIZE

Инв. № дубл.

Взам. инв. №

Подп. и дата

#### Таблица 3.16.4 — Описание регистра DSCR\_FLAG\_SIZE

| No   | бита       | Наименование       | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • ,_ | 01114      | бита               | назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 31         | DSCR_READY<br>(RW) | нужно программно установить в «1», когда область памяти, на которую указывает этот дескриптор, освобождена и готова для записи принятых данных. Когда все принятые данные записаны в область, на которую указывает этот дескриптор, то в этот бит аппаратно сбрасывается в «0»                                                                                                                                                                                                                                        |
| 30   | <b>−19</b> | _                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18   | – 16       | DSCR_FLAGS<br>(RW) | [16] — SOF: устанавливается в «1», если записанные принятые данные содержат первый байт фрейма. Используется для случаев, когда принятый фрейм записывается в несколько дескрипторов [17] — EOF: устанавливается в «1», если записанные принятые данные содержат последний байт фрейма. Используется для случаев, когда принятый фрейм записывается в несколько дескрипторов [18] — Error: флаг ошибки устанавливается в «1», если принятый фрейм завершается не маркером хвоста, а неисправимой ошибкой БЧХ-декодера |
| 15   | - 10       | _                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | -0         | DATA_SIZE (RW)     | Размер области, в которую будут записываться принятые данные. «О» означает, что размер области памяти 1024 Б. Если размер пакета принятых данных меньше размера области, то по окончанию записи данных в это поле будет аппаратно записан размер записанных данных. Если размер пакета больше, то поле останется без изменения, а остаток данных запишется в следующий дескриптор                                                                                                                                     |

Флаги записываются аппаратно, когда все принятые данные записаны в область, на которую указывает этот дескриптор.

|     |      |          |       |      | Микросх <u>е</u> ма интегральная 5023BC016           | Лист |
|-----|------|----------|-------|------|------------------------------------------------------|------|
| Изм | Лист | № докум. | Подп. | Дата | Техническое описание<br>Версия 2.04 от 01.09.2017 г. | 220  |

Таблица 3.16.5 — Описание регистра DSCR\_CURRENT

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                |
|--------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | WORK_FLAG<br>(RO)    | устанавливается в «1», если текущий дескриптор находится в работе и устанавливается в «0», когда текущий дескриптор не готов, то есть когда флаг текущего дескриптора DSCR_READY находится в «0».      |
| 30 – 4 | _                    |                                                                                                                                                                                                        |
| 3-0    |                      | номер текущего дескриптора, RO, когда WORK_FLAG равен «1», и автоматически инкрементируется после отработки дескриптора. Когда WORK_FLAG равен «0», то номер дескриптора можно перезаписать программно |

#### 3.16.4.4 Perистр GLOBAL ENABLE

Таблица 3.16.6 — Описание регистра GLOBAL ENABLE

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                           |
|--------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31 – 1 | _                    |                                                                                                                                   |
| 0      |                      | 0 — все декодеры, FIFO, AHB-контроллер находятся в асинхронном сбросе. 1 — включение всех модулей, ответственных за приём данных. |

Примечание — Конфигурация декодеров, которая задаётся через регистры CODER\_SEL, START\_SEQ, TAIL\_SEQ1, TAIL\_SEQ2 загружается только в момент перехода GLOBAL\_ENABLE из нуля в единицу. Если менять значения этих регистров во время, когда GLOBAL\_ENABLE = 1, то это не повлияет на работу блока. Чтобы новые значения вступили в силу, требуется пересбросить блок через GLOBAL\_ENABLE.

## 3.16.4.5 Peгистр CODER\_SEL

Инв. № дубл.

Взам. инв. №

Подп. и дата

Таблица 3.16.7 — Описание регистра CODER\_SEL

| № бита  | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                |
|---------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 1       | 2                 | 3                                                                                                                                      |
| 31 – 17 | _                 |                                                                                                                                        |
| 16      | HARD_SOFT (RW)    | Опция для декодера Витерби. 0 — жесткие решения (ширина шины данных равна 1 бит), 1 — мягкие решения (ширина шины данных равна 3 бита) |
| 15 – 3  | _                 |                                                                                                                                        |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              | 204  |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 221  |

| 1 | 2             | 3                                                              |
|---|---------------|----------------------------------------------------------------|
| 2 | CONV_SEL (RW) | 1 — выбор сверточного кодера Витерби                           |
| 1 | BCH_SEL (RW)  | 1 — выбор декодера БЧХ, исправляет одну ошибку в 7 байт данных |
| 0 | RAND_SEL (RW) | 1 — выбор рандомизатора                                        |

#### 3.16.4.6 Регистр PHY\_FIFO\_OVERFLOW

#### Таблица 3.16.8 — Описание регистра PHY FIFO OVERFLOW

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                    |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 – 1 | _                 |                                                                                                                                                                                                                            |
| 0      | PHY_FIFO_OVERFLOW | флаг переполнения памяти асинхронного блока FIFO, когда дескрипторы не готовы к приёму данных, а GLOBAL_ENABLE равен 1, то данные накапливаются в FIFO. При переполнении необходимо сделать пересброс через GLOBAL_ENABLE. |

### 3.16.4.7 Peгистр START\_SEQ

Инв. № дубл.

Взам. инв. №

Подп. и дата

### Таблица 3.16.9 — Описание регистра START SEQ

| № бита  | Наименование | Функциональное назначение бита, краткое описание бита                                                                      |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------|
| л⊻опта  | бита         | назначения и принимаемых значений                                                                                          |
| 31      | ALLOW_1_ERR  | 1 — позволить единичную ошибку в маркере начала фрейма.                                                                    |
| 31      | (RW)         | Значение по сбросу: 0                                                                                                      |
| 30 - 16 | _            |                                                                                                                            |
| 15 – 0  |              | маркер начала фрейма. Первый принятый бит сравнивается с 15 битом START_SEQ, последний принятый бит сравнивается с 0 битом |

# 3.16.4.8 Регистры TAIL\_SEQ1, TAIL\_SEQ2

### Таблица 3.16.10 — Описание регистров TAIL\_SEQ1, TAIL\_SEQ2

| № бита | Наименование | Функциональное назначение бита, краткое описание бита                                                                                         |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻оита | бита         | назначения и принимаемых значений                                                                                                             |
| 31 – 0 | I AIL_SEQ    | маркер конца фрейма. Первый принятый бит сравнивается с 31 битом регистра TAIL_SEQ1, последний принятый бит сравнивается с 0 битом TAIL_SEQ2. |

# 3.17 Специализированный вычислитель с плавающей точкой

Блок специализированного вычислителя выполняет операции сложения/вычитания, а также умножения чисел с плавающей запятой. Доступ к специализированному вычислителю осуществляется по шине AMBA через регистры.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 222  |

Таблица 3.17.1 — Описание регистров специализированного вычислителя

| Смещение    | Название регистра | Тип | Значение по сбросу | Описание                                     |
|-------------|-------------------|-----|--------------------|----------------------------------------------|
| 0x00        | ADD_SUB           | RW  | 0                  | Выбор режима сложение/вычитание              |
| 0x04        | ADD_A             | RW  | 0                  | Операнд А для операции<br>сложения/вычитания |
| 0x08        | ADD_B             | RW  | 0                  | Операнд В для операции<br>сложения/вычитания |
| 0x0C        | MUL_A             | RW  | 0                  | Первый множитель для операции умножения      |
| 0x10        | MUL_B             | RW  | 0                  | Второй множитель для операции умножения      |
| 0x14        | CONTROL           | RW  | 0                  | Регистр управления                           |
| 0x18        | ADD_OUT           | RO  | 0                  | Результат операции сложения                  |
| 0x1C        | MUL_OUT           | RO  | 0                  | Результат операции умножения                 |
| 0x20-0xFFFF | _                 |     |                    | Не используется, читается 0                  |

### 3.17.1 Описание регистров

### 3.17.1.1 Регистр ADD\_SUB

Таблица 3.17.2 — Описание регистра ADD\_SUB

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 1 | _                    |                                                                                         |
| 0      | ADD_SUB              | 0 — будет выполняться операция вычитания.<br>1 — будет выполняться операция сложения    |

## 3.17.1.2 Регистр ADD A

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.17.3 — Описание регистра ADD\_A

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 | ADD_A                | значение первого слагаемого для операции сложения, в формате float.                     |

# 3.17.1.3 Регистр ADD\_B

# Таблица 3.17.4 — Описание регистра ADD\_B

| № бита | Наименование | Функциональное назначение бита, краткое описание бита              |
|--------|--------------|--------------------------------------------------------------------|
| л⊻оита | бита         | назначения и принимаемых значений                                  |
| 31 – 0 | ADD_B        | значение второго слагаемого для операции сложения, в формате float |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 223  |

# 3.17.1.4 Регистр MUL\_A

# Таблица 3.17.5 — Описание регистра MUL\_A

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 - 0 | MUL_A                | значение первого множителя для операции умножения, в формате float                      |

### 3.17.1.5 Регистр MUL\_B

### Таблица 3.17.6 — Описание регистра MUL\_B

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 0 |                      | значение второго множителя для операции умножения, в формате float                      |

### 3.17.1.6 Peгистр CONTROL

### Таблица 3.17.7 — Описание регистра CONTROL

| № бита | Наименование                            | Функциональное назначение бита, краткое описание бита       |
|--------|-----------------------------------------|-------------------------------------------------------------|
| л⊻онта | бита                                    | назначения и принимаемых значений                           |
| 31 – 4 | ı                                       |                                                             |
| 3      | MUL_DONE                                | принимает значение «1» после завершения операции умножения, |
| 3      | MIOL_DONE                               | сбрасывается в «0» после чтения регистра                    |
| 2      | $\Delta$ I II I I I I I I I I I I I I I | принимает значение «1» после завершения операции сложения,  |
|        |                                         | сбрасывается в «0» после чтения регистра                    |
| 1      | MUL (W)                                 | запись «1» запускает выполнение операции умножения          |
|        |                                         |                                                             |
| 0      | ADD (W)                                 | запись «1» запускает выполнение операции сложения           |

### 3.17.1.7 Регистр ADD\_OUT

### Таблица 3.17.8 — Описание регистра ADD\_OUT

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                         |
|--------|----------------------|-----------------------------------------------------------------------------------------------------------------|
| 31 – 0 |                      | результат операции сложения. Результат доступен через 5 тактов системной частоты после записи в регистр CONTROL |

# 3.17.1.8 Регистр MUL\_OUT

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.17.9 — Описание регистра MUL\_OUT

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                         |
|--------|----------------------|-----------------------------------------------------------------------------------------------------------------|
| 31 – 0 |                      | результат операции умножения. Результат доступен через 4 такта системной частоты после записи в регистр CONTROL |

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист     |
|-----|--------|----------|-------|------|-----------------------------------|----------|
|     |        |          |       |      | Техническое описание              | $\vdash$ |
| Изі | и Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 224      |

Контроллер интерфейса CAN поддерживает протоколы CAN 20.A и CAN 2.0 В. Структурная схема контроллера изображена на рисунке 3.18.1.



Рисунок 3.18.1 — Структурная схема контроллера интерфейса CAN

#### 3.18.1 Общее описание

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Контроллер может функционировать в базовом и расширенном режимах. Расширенный режим поддерживает расширения протокола CAN 2.0В. Базовый режим имеет более простой интерфейс управления контроллером через регистры, но поддерживает только сообщения стандартного формата Standard Frame Format (SFF). Расширенный режим поддерживает помимо стандартного также и расширенный формат сообщений Extended Frame Format (EFF).

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

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 225  |

Как в базовом, так и в расширенном режимах работы контроллер может находиться либо в состоянии сброса, либо в рабочем состоянии. Состояние сброса используется для настройки параметров контроллера, а рабочий режим — для передачи и приёма данных по интерфейсу CAN.

#### 3.18.2 Базовый режим работы

Список регистров для базового режима работы контроллера приведён в таблице 3.18.1. Функциональность регистра, расположенного по определённому адресу, зависит от того, находится контроллер в состоянии сброса либо в рабочем состоянии.

Описание некоторых регистров контроллера CAN приведено в таблицах 3.18.2 - 3.18.5.

Таблица 3.18.1 — Обобщенные данные о регистрах контроллера CAN в базовом режиме

| Смеще- | Название<br>регистра | Тип | Значение по сбросу | Описание                                                                 |
|--------|----------------------|-----|--------------------|--------------------------------------------------------------------------|
| 1      | 2                    | 3   | 4                  | 5                                                                        |
| 0x00   | Control              | RW  | 0x21               | Контрольный регистр                                                      |
| 0x04   | Command              | WO  | 0xFF               | Регистр команд                                                           |
| 0x08   | Status               | RO  | 0x0C               | Регистр статуса                                                          |
| 0x0C   | Interrupt            | RO  | 0xE0               | Регистр прерываний                                                       |
| 0x10   | Aceptance_code       | RW  | 0x00               | Регистр приёмного кода. Только в состоянии сброса                        |
| 0x14   | Aceptance_mask       | RW  | 0x00               | Регистр приёмной маски. Только в состоянии сброса                        |
| 0x18   | Bus_timing_0         | RW  | 0x00               | Первый регистр временных параметров шины.<br>Только в состоянии сброса   |
| 0x1C   | Bus_timing_1         | RW  | 0x00               | Второй регистр временных параметров шины. Только в состоянии сброса      |
| 0x20   | Reserved             |     | 0x00               |                                                                          |
| 0x24   | Reserved             |     | 0x00               |                                                                          |
| 0x28   | TX_id1               | RW  | 0xFF               | Первый регистр заголовка пакета для передачи. Только в рабочем состоянии |
| 0x2C   | TX_id2_rtr_dlc       | RW  | 0xFF               | Второй регистр заголовка пакета для передачи. Только в рабочем состоянии |

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 om 01.09.2017 г.

| Продолжение | таблицы | 3.18.1 |
|-------------|---------|--------|
| 1           | ,       |        |

| 1    | 2              | 3  | 4    | 5                                            |  |  |
|------|----------------|----|------|----------------------------------------------|--|--|
| 0x30 | TX_data_byte_1 | RW | 0xFF |                                              |  |  |
| 0x34 | TX_data_byte_2 | RW | 0xFF |                                              |  |  |
| 0x38 | TX_data_byte_3 | RW | 0xFF |                                              |  |  |
| 0x3C | TX_data_byte_4 | RW | 0xFF | Daywaray oo yanayy ta ya yayara yag yanayayy |  |  |
| 0x40 | TX_data_byte_5 | RW | 0xFF | Регистры содержимого пакета для передачи     |  |  |
| 0x44 | TX_data_byte_6 | RW | 0xFF |                                              |  |  |
| 0x48 | TX_data_byte_7 | RW | 0xFF |                                              |  |  |
| 0x4C | TX_data_byte_8 | RW | 0xFF |                                              |  |  |
| 0x50 | RX_id1         | RO | 0x00 | Первый регистр заголовка пакета для приёма   |  |  |
| 0x54 | RX_id2_rtr_dlc | RO | 0x00 | Второй регистр заголовка пакета для приёма   |  |  |
| 0x58 | RX_data_byte_1 | RO | 0x00 |                                              |  |  |
| 0x5C | RX_data_byte_2 | RO | 0x00 |                                              |  |  |
| 0x60 | RX_data_byte_3 | RO | 0x00 |                                              |  |  |
| 0x64 | RX_data_byte_4 | RO | 0x00 | Daywaray as yanyu tara yaywa ta a yayara     |  |  |
| 0x68 | RX_data_byte_5 | RO | 0x00 | Регистры содержимого принимаемого пакета     |  |  |
| 0x6C | RX_data_byte_6 | RO | 0x00 |                                              |  |  |
| 0x70 | RX_data_byte_7 | RO | 0x00 |                                              |  |  |
| 0x74 | RX_data_byte_8 | RO | 0x00 |                                              |  |  |
| 0x78 | Reserved       |    | 0x00 |                                              |  |  |
| 0x7C | Clock_divider  | RW | 0x00 | Регистр делителя рабочей частоты             |  |  |

# 3.18.2.1 Контрольный регистр Control

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

Таблица 3.18.2 — Описание регистра Control

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

| № бита | Наименование бита         | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|---------------------------|-----------------------------------------------------------------------------------------|
| 1      | 2                         | 3                                                                                       |
| 7 – 5  | _                         | Зарезервировано                                                                         |
| 4      | Overrun Interrupt Enable  | Включение прерывания переполнения. 1 — включено, 0 — отключено.                         |
| 3      | Error Interrupt Enable    | Включение прерывания ошибки. 1 — включено, 0 — отключено.                               |
| 2      | Transmit Interrupt Enable | Включение прерывания передачи. 1 — включено, 0 — отключено.                             |

|     |      |          |       |      | Mu |
|-----|------|----------|-------|------|----|
|     |      |          |       |      |    |
| Изм | Лист | № докум. | Подп. | Дата |    |

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

227

#### Продолжение таблицы 3.18.2

Инв. № дубл.

Взам. инв. №

Подп. и дата

| 1 | 2                        | 3                                                                                                                                                                                                                            |
|---|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | Receive Interrupt Enable | Включение прерывания приёма. 1 — включено,                                                                                                                                                                                   |
| 1 | Receive interrupt Enable | 0 — отключено.                                                                                                                                                                                                               |
| 0 | Reset request            | Запись «1» в этот бит прерывает любую текущую передачу данных и переводит контроллер в состояние сброса. Запись «0» переводит контроллер в рабочее состояние. По умолчанию активно состояние сброса, бит имеет значение «1». |

#### 3.18.2.2 Регистр команд Command

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

Таблица 3.18.3 — Описание регистра Command

| № бита | Наименование бита      | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|------------------------|-----------------------------------------------------------------------------------------|
| 7 – 4  | -                      | Зарезервировано                                                                         |
| 3      | Clear data overrun     | Запись «1» очищает бит переполнения (Data overrun status) в регистре статуса            |
| 2      | Release receive buffer | Запись «1» очищает приёмный буфер для новых данных                                      |
| 1      | Abort transmission     | Запись «1» прерывает передачу, которая еще не была запущена                             |
| 0      | Transmission request   | Запись «1» запускает передачу сообщения в буфер для отправки (TX buffer)                |

Передача данных начинается с помощью записи «1» в бит Transmission request. Передача может быть прервана только с помощью записи «1» в бит Receive Interrupt Enable и только если передача еще не была начата. В противном случае она не будет остановлена, но не будет автоматически перезапущена в случае, если произойдет ошибка.

Запись в бит Release receive buffer следует производить после вычитывания содержимого приёмного буфера, чтобы освободить его. Если в FIFO присутствует следующее принятое сообщение, будет сгенерировано новое прерывание приёма (если оно было включено в регистре Control), и бит Receive buffer status в регистре Status будет выставлен повторно.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              | 000  |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 228  |
|     |      |          |       |      | 1/                                |      |

# 3.18.2.3 Регистр статуса Status

Регистр статуса доступен только на чтение и отражает текущее состояние контроллера.

Функциональное назначение бита, краткое описание бита

Таблица 3.18.4 — Описание регистра Status

№ бита Наименование бита

Инв. № дубл.

Взам. инв. №

Подп. и дата

|   |                        | назначения и принимаемых значений                                                                                                                                                                                                                                                       |
|---|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 | Bus status             | Значение «1» если контроллер не подключен к шине CAN и не участвует в активности на шине                                                                                                                                                                                                |
| 6 | Error Status           | Значение «1» когда хотя бы один из счётчиков ошибок превысил значение CPU warning limit = 96                                                                                                                                                                                            |
| 5 | Transmit status        | Значение «1» во время передачи сообщения контроллером                                                                                                                                                                                                                                   |
| 4 | Receive status         | Значение «1» во время приёма сообщения контроллером                                                                                                                                                                                                                                     |
| 3 | Transmission complete  | Значение «1» когда предыдущее сообщение было успешно передано Бит сбрасывается в «0» сразу после начала передачи и не устанавливается в «1» до тех пор, пока сообщение не будет успешно передано.                                                                                       |
| 2 | Transmit buffer status | Значение «1» означает, что запись в передающий буфер разрешена Во время передачи сообщения передающий буфер запирается и бит имеет значение «0». Если контроллер не передает сообщения, бит имеет значение «1» и возможен запуск следующих сообщений на передачу.                       |
| 1 | Data overrun status    | Значение «1» означает, что сообщение было потеряно из-за отсутствия свободного места в FIFO Бит означает, что полученное контроллером сообщение было утеряно, поскольку в приёмном FIFO отсутствовало свободное место. Данный бит устанавливается в момент вычитывания данных из FIFO.  |
| 0 | Receive buffer status  | Значение «1» означает, что в приёмном FIFO присутствуют принятые сообщения Бит сбрасывается в «0», если была подана команда Release receive buffer через бит в регистре Command. Если при этом в приёмном FIFO присутствуют последующие сообщения, бит будет установлен в «1» повторно. |

# 3.18.2.4 Регистр прерываний Interrupt

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

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 229  |

| № бита | Наименование бита      | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений      |
|--------|------------------------|----------------------------------------------------------------------------------------------|
| 7 – 4  | _                      | Зарезервировано                                                                              |
| 3      | Data overrun interrupt | Устанавливается в «1» когда бит Data overrun status в регистре Status переходит из «0» в «1» |
| 2      | Error interrupt        | Устанавливается значение «1» если изменяется статус шины или статус ошибки                   |
| 1      | Transmit interrupt     | Устанавливается значение «1» в момент освобождения передающего буфера                        |
| 0      | Receive interrupt      | Устанавливается значение «1», если в приёмном FIFO присутствуют принятые сообщения           |

Данный регистр сбрасывается после каждого чтения за исключением бита Receive interrupt, который сбрасывается только после передачи команды Release receive buffer записью в регистр Command.

#### 3.18.2.5 Регистры передающего буфера

Инв. № дубл.

Взам. инв. №

Подп. и дата

Содержимое передающего буфера формируется с помощью записи в регистры с адресами от 0x28 до 0x4C, как показано в таблице 3.18.6. Данные регистры формируют сообщение стандартного формата (SFF). Все эти регистры доступны на запись только когда контроллер находится в рабочем состоянии.

Таблица 3.18.6 — Формат регистров, формирующих содержимое передающего буфера

| Смеще- | Има попиство   | Назначение бит |      |      |      |       |       |       |       |  |
|--------|----------------|----------------|------|------|------|-------|-------|-------|-------|--|
| ние    | Имя регистра   | 7              | 6    | 5    | 4    | 3     | 2     | 1     | 0     |  |
| 0x28   | TX_id1         | ID.10          | ID.9 | ID.8 | ID.7 | ID.6  | ID.5  | ID.4  | ID.3  |  |
| 0x2C   | TX_id2_rtr_dlc | ID.2           | ID.1 | ID.0 | RTR  | DLC.3 | DLC.2 | DLC.1 | DLC.0 |  |
| 0x30   | TX_data_byte_1 | TX byte 1      |      |      |      |       |       |       |       |  |
| 0x34   | TX_data_byte_2 | TX byte 2      |      |      |      |       |       |       |       |  |
| 0x38   | TX_data_byte_3 | TX byte        | 3    |      |      |       |       |       |       |  |
| 0x3C   | TX_data_byte_4 | TX byte 4      |      |      |      |       |       |       |       |  |
| 0x40   | TX_data_byte_5 | TX byte        | 5    |      |      |       |       |       |       |  |
| 0x44   | TX_data_byte_6 | TX byte 6      |      |      |      |       |       |       |       |  |
| 0x48   | TX_data_byte_7 | TX byte 7      |      |      |      |       |       |       |       |  |
| 0x4C   | TX_data_byte_8 | TX byte        | 8    |      |      |       |       |       |       |  |

Если бит RTR установлен в «1», ни один байт данных не будет передан в сообщении. При этом бит DLC будет передан и должен быть корректно установлен. Поле DLC может иметь значение большее 8, но при этом в сообщении будет

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 230  |

#### 3.18.2.6 Регистры приёмного буфера

Приёмное FIFO имеет размер 64 байта. Значения 10 байт этого FIFO, формирующие наиболее раннее из принятых сообщений, доступны на чтение через регистры с адресами 0x50-0x74. Значение бит регистров приёмного буфера идентично по структуре регистрам передающего буфера, показанным в таблице 3.18.6.

#### 3.18.2.7 Фильтрация принимаемых сообщений

Контроллер может производить фильтрацию принимаемых сообщений, используя регистры Acceptance\_code и Acceptance\_mask. Сообщения могут быть отфильтрованы на основе содержимого их идентификаторов. Старшие 8 из 11 бит идентификатора принятого сообщения сравниваются с содержимым регистра Acceptance\_code, если соответствующий бит в регистре Acceptance\_mask сброшен в «О». Если в результате все такие биты совпадают, принятое сообщение сохраняется в приёмном FIFO.

### 3.18.3 Расширенный режим работы

Список регистров для расширенного режима работы контроллера приведён в таблице 3.18.7. Функциональность регистра, расположенного по определённому адресу, зависит от того, находится контроллер в состоянии сброса либо в рабочем состоянии, а также от выбранного формата сообщений (SFF/EFF).

Таблица 3.18.7 — Обобщенные данные о регистрах контроллера CAN в расширенном режиме

| Сме- | Название регистра | Тип | Значение по сбросу | Описание              |
|------|-------------------|-----|--------------------|-----------------------|
| 1    | 2                 | 3   | 4                  | 5                     |
| 0x00 | Mode              | RW  | 0x21               | Регистр режима работы |
| 0x04 | Command           | WO  | 0xFF               | Регистр команд        |
| 0x08 | Status            | RO  | 0x0C               | Регистр статуса       |
| 0x0C | Interrupt         | RO  | 0xE0               | Регистр прерываний    |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

231

| 1    | 2                               | 3   | 4        | 5                                                                                          |
|------|---------------------------------|-----|----------|--------------------------------------------------------------------------------------------|
| 0x10 | Interrupt_enable                | RW  | 0x00     | Регистр включения прерываний                                                               |
| 0x14 | Reserved                        |     | 0x00     |                                                                                            |
| 0x18 | Bus_timing_0                    | RW  | 0x00     | Первый регистр временных параметров шины. Доступен на запись только в состоянии сброс      |
| 0x1C | Bus_timing_1                    | RW  | 0x00     | Второй регистр временных параметров шины. Доступен на запись только в состоянии сброс      |
| 0x20 | Reserved                        |     | 0x00     |                                                                                            |
| 0x24 | Reserved                        |     | 0x00     |                                                                                            |
| 0x28 | Reserved                        |     | 0xFF     |                                                                                            |
| 0x2C | Arbitration_lost_ capture       | RO  | 0xFF     | Регистр хранения позиции потер<br>арбитрации                                               |
| 0x30 | Error_code_ capture             | RO  | 0xFF     | Регистр кода ошибки                                                                        |
| 0x34 | Error_warning_ limit            | RW  | 0xFF     | Регистр максимального количест предупреждений. Доступен на запись только в состоянии сброс |
| 0x38 | RX_error_counter                | RW  | 0xFF     | Счётчик ошибок при приёме. Доступен на запись только в состоянии сброса                    |
| 0x3C | TX_error_counter                | RW  | 0xFF     | Счётчик ошибок при передаче.<br>Доступен на запись только в<br>состоянии сброса            |
| 0x40 | FI_SFF/FI_EFF/Acceptance_code_0 | RW  | 0xFF     | В зависимости от состояния контроллера и формата сообщен данные регистры имеют различн     |
| 0x44 | ID_1/Acceptance_code_1          | RW  | 0xFF     | назначение. В состоянии сброса часть регист  задает приёмный код и маску.                  |
| 0x48 | ID_2/Acceptance_ code_2         | RW  | 0xFF     | В рабочем состоянии при записи формируется содержимое сообщения для передачи, при          |
| 0x4C | Data_1/ID_3/Acceptance_code_3   | RW  | 0xFF     | чтении - вычитывается значение принятого сообщения.  Назначение регистров различно         |
| 0x50 | Data_2/ID_4/Acceptance_mask_0   | RW  | 0x00     | стандартного (SFF) и расширенн                                                             |
| 0x54 | Data_3/Data_1/Acceptance_mask_1 | RW  | 0x00     | (EFF) форматов сообщения.                                                                  |
| 0x58 | Data_4/Data_2/Acceptance_mask_2 | RW  | 0x00     |                                                                                            |
| I    | I                               | l   |          |                                                                                            |
|      |                                 | Мик | осхема и | нтегральная 5023ВС016                                                                      |
| _    |                                 | - 1 |          | ческое описание                                                                            |

Инв. № дубл.

Взам. инв. №

Подп. и дата

Инв. N<u>9</u> подл.

### Продолжение таблицы 3.18.7

| 1    | 2                               | 3  | 4    | 5                                      |
|------|---------------------------------|----|------|----------------------------------------|
| 0x5C | Data_5/Data_3/Acceptance_mask_3 | RW | 0x00 |                                        |
| 0x60 | Data_6/Data_4                   | RW | 0x00 |                                        |
| 0x64 | Data_7/Data_5                   | RW | 0x00 |                                        |
| 0x68 | Data_8/Data_6                   | RW | 0x00 |                                        |
| 0x6C | FIFO_1/Data_7                   | RW | 0x00 |                                        |
| 0x70 | FIFO_2/Data_8                   | RW | 0x00 |                                        |
| 0x74 | RX_message_ counter             | RO | 0x00 | Регистр счётчика принимаемых сообщений |
| 0x78 | Reserved                        |    | 0x00 |                                        |
| 0x7C | Clock_divider                   | RW | 0x00 | Регистр делителя рабочей частоты       |

### 3.18.3.1 Регистр режима Mode

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

Таблица 3.18.8 — Описание регистра Mode

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование бита      | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                     |
|--------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 – 4  | -                      | Зарезервировано                                                                                                                                                                                                             |
| 3      | Acceptance filter mode | Значение «1» — режим одиночной фильтрации, «0» — режим двойной фильтрации                                                                                                                                                   |
| 2      | Self test mode         | Запись «1» переводит контроллер в режим самодиагностики                                                                                                                                                                     |
| 1      | Listen only mode       | Запись «1» переводит контроллер в состояние прослушивания шины                                                                                                                                                              |
| 0      | Reset mode             | Запись «1» в этот бит прерывает любую текущую передачу данных и переводит контроллер в состояние сброса. Запись «0» переводит контроллер в рабочее состояние. По умолчанию активно состояние сброса, бит имеет значение «1» |

Биты 1-3 доступны на запись только в состоянии сброса.

В состоянии прослушивания шины (listen only mode) контроллер не будет посылать подтверждение приёма сообщений. При этом контроллер продолжает реагировать на ошибки на шине.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 233  |

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

#### 3.18.3.2 Регистр команд Command

Запись бит данного регистра запускает одно из действий, поддерживаемых ядром контроллера. Описание регистра Command приведено в таблице 3.18.9.

Таблица 3.18.9 — Описание регистра Command

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

не. № подл.

| № бита | Наименование бита      | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|------------------------|-----------------------------------------------------------------------------------------|
| 7 – 5  | _                      | Зарезервировано                                                                         |
| 4      | Self reception request | Запись «1» запускает передачу и одновременно приём сообщения                            |
| 3      | Clear data overrun     | Запись «1» очищает бит переполнения (Data overrun status) в регистре статуса            |
| 2      | Release receive buffer | Запись «1» очищает приёмный буфер для новых данных                                      |
| 1      | Abort transmission     | Запись «1» прерывает передачу, которая еще не была запущена                             |
| 0      | Transmission request   | Запись «1» запускает передачу сообщения в буфер для отправки (TX buffer)                |

Передача данных начинается с помощью записи «1» в бит Reset request. Передача может быть прервана только с помощью записи «1» в бит Receive Interrupt Enable и только если передача еще не была начата. В противном случае она не будет остановлена, но не будет автоматически перезапущена в случае, если произойдет ошибка.

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

Запись в бит Release receive buffer следует производить после вычитывания содержимого приёмного буфера, чтобы освободить его. Если в FIFO присутствует следующее принятое сообщение, будет сгенерировано новое прерывание приёма (если оно было включено в perистре Interrupt\_enable), и бит Receive buffer status в регистре Status будет выставлен повторно.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 234  |

Запись бита Self reception request в режиме Self test mode позволяет проверить функциональность контроллера в случае отсутствия других устройств на шине. Сообщение будет одновременно передаваться и приниматься, при этом будут одновременно сгенерированы прерывания приёма и передачи.

#### 3.18.3.3 Регистр статуса Status

Регистр статуса в расширенном режиме идентичен по структуре регистру статуса в базовом режиме.

#### 3.18.3.4 Регистр прерываний Interrupt

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

Таблица 3.18.10 — Описание регистра Interrupt

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

| № бита | Наименование бита          | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений        |
|--------|----------------------------|------------------------------------------------------------------------------------------------|
| 7 – 4  | _                          | Зарезервировано                                                                                |
| 7      | Bus error interrupt        | Устанавливается в «1» если на шине обнаружена ошибка                                           |
| 6      | Arbitration lost interrupt | Устанавливается в «1» при потере арбитрации контроллером                                       |
| 5      | Error passive interrupt    | Устанавливается в «1» когда контроллер переходит между состояниями активной и пассивной ошибки |
| 4      | _                          | Зарезервировано                                                                                |
| 3      | Data overrun interrupt     | Устанавливается в «1» когда бит Data overrun status в регистре Status переходит из «0» в «1»   |
| 2      | Error warning interrupt    | Устанавливается значение «1» если изменяется статус шины или статус ошибки                     |
| 1      | Transmit interrupt         | Устанавливается значение «1» в момент освобождения передающего буфера                          |
| 0      | Receive interrupt          | Устанавливается значение «1», если в приёмном FIFO присутствуют принятые сообщения             |

Данный регистр сбрасывается после каждого чтения за исключением бита Receive interrupt, который сбрасывается только после передачи команды Release receive buffer записью в регистр Command.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|------|-----------------------------------|
|     |      |          |       |      | Техническое описание              |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      |
|     |      |          |       |      |                                   |

235

Данный регистр включает и отключает различные источники прерываний. Если прерывание активно, соответствующий бит в регистре Interrupt может быть выставлен, и будет активироваться сигнал прерывания. Описание регистра Interrupt enable приведено в таблице 3.18.11.

Таблица 3.18.11 — Описание регистра Interrupt\_enable

| № бита | Наименование бита          | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений        |
|--------|----------------------------|------------------------------------------------------------------------------------------------|
| 7      | Bus error interrupt        | Устанавливается в «1» если на шине обнаружена ошибка                                           |
| 6      | Arbitration lost interrupt | Устанавливается в «1» при потере арбитрации контроллером                                       |
| 5      | Error passive interrupt    | Устанавливается в «1» когда контроллер переходит между состояниями активной и пассивной ошибки |
| 4      |                            | Зарезервировано                                                                                |
| 3      | Data overrun interrupt     | Устанавливается в «1» когда бит Data overrun status в регистре Status переходит из «0» в «1»   |
| 2      | Error warning interrupt    | Устанавливается значение «1» если изменяется статус шины или статус ошибки                     |
| 1      | Transmit interrupt         | Устанавливается значение «1» в момент освобождения передающего буфера                          |
| 0      | Receive interrupt          | Устанавливается значение «1», если в приёмном FIFO присутствуют принятые сообщения             |

3.18.3.6 Регистр хранения позиции потери арбитрации Arbitration\_lost\_capture Когда контроллер теряет арбитрацию, данный регистр захватывает битовую позицию процессора битового потока. Регистр не будет изменять значение до тех пор, пока он не будет вычитан. Описание регистра Arbitration\_lost\_capture приведено в таблице 3.18.12.

Таблица 3.18.12 — Описание регистра Arbitration\_lost\_capture

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |  |  |  |  |
|--------|-------------------|-----------------------------------------------------------------------------------------|--|--|--|--|
| 7 - 5  |                   | Зарезервировано                                                                         |  |  |  |  |
| 4-0    | Bit number        | Бит, в котором была потеряна арбитрация                                                 |  |  |  |  |

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|--------|----------|-------|------|-----------------------------------|------|
|     |        |          |       |      | Техническое описание              |      |
| Изі | л Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 236  |

### 3.18.3.7 Регистр кода ошибки Error\_code\_capture

Когда возникает ошибка на шине данный регистр устанавливается в зависимости от того, какого рода ошибка произошла: произошла ли она в течение передачи или приёма, и в какой части фрейма это произошло. Регистр не будет изменять значение до тех пор, пока он не будет вычитан. Описание регистра Error\_code\_capture приведено в таблице 3.18.13.

Таблица 3.18.13 — Описание регистра Error code capture

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита   | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Jul Onia | бита         | назначения и принимаемых значений                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7 – 6    | Error Code   | Код ошибки: 0 — Bit error 1 — Form error 2 — Stuff error 3 — другое                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5        | Direction    | Бит, в котором была потеряна арбитрация                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4-0      | Segment      | Местоположение ошибки внутри фрейма:       0x03 — Start of frame;       0x08 — CRC sequence;         0x02 — ID.28 - ID.21;       0x18 — CRC delimiter;         0x06 — ID.20 - ID.18;       0x19 — Acknowledge slot;         0x04 — Bit SRTR;       0x1B — Acknowledge delimiter;         0x05 — Bit IDE;       0x1A — End of frame;         0x07 — ID.17 - ID.13;       0x12 — Intermission;         0x0E — ID.4 - ID.0;       0x11 — Active error flag;         0x0C — Bit RTR;       0x16 — Passive error flag;         0x0D — Reserved bit 1;       0x13 — Tolerate dominant bits;         0x09 — Reserved bit 0;       0x17 — Error delimiter;         0x0A — Data field;       0x1C — Overload flag. |

3.18.3.8 Регистр максимального количества предупреждений Error\_warning\_limit

Регистр позволяет установить значение максимального допустимого количества предупреждений. По умолчанию имеет значение 96. Доступен на запись только в состоянии сброса.

# 3.18.3.9 Регистр счётчика ошибок при приёме RX\_error\_counter

Регистр показывает значение счётчика ошибок на приёме. В состоянии сброса доступен на запись. Отключение шины сбрасывает этот счётчик в «0».

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 237  |
|     |      |          |       |      |                                   |      |

Копировал

Формат А4

#### 3.18.3.10 Регистр счётчика ошибок при передаче TX\_error\_counter

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

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

#### 3.18.3.11 Регистры передающего буфера

Инв. № дубл.

Взам. инв. №

Подп. и дата

Содержимое передающего буфера формируется с помощью записи в регистры с адресами от 0х40 до 0х70, как показано в таблице 3.18.14. Расположение регистров зависит от формата передаваемого сообщения (SFF/EFF). Все эти регистры доступны на запись только когда контроллер находится в рабочем состоянии. В состоянии сброса по данным адресам расположены регистры приёмного фильтра сообщений.

Таблица 3.18.14 — Регистры, формирующие содержимое передающего буфера в стандартном и расширенном сообщениях

| Смещение | SFF                  | EFF                  |
|----------|----------------------|----------------------|
| 0x40     | TX frame information | TX frame information |
| 0x44     | TX ID 1              | TX ID 1              |
| 0x48     | TX ID 2              | TX ID 2              |
| 0x4C     | TX data 1            | TX ID 3              |
| 0x50     | TX data 2            | TX ID 4              |
| 0x54     | TX data 3            | TX data 1            |
| 0x58     | TX data 4            | TX data 2            |
| 0x5C     | TX data 5            | TX data 3            |
| 0x60     | TX data 6            | TX data 4            |
| 0x64     | TX data 7            | TX data 5            |
| 0x68     | TX data 8            | TX data 6            |
| 0x6C     |                      | TX data 7            |
| 0x70     |                      | TX data 8            |

Регистр формата фрейма (TX frame information), представленный в таблице 3.18.15, имеет одинаковую структуру для стандартных и расширенных фреймов.

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 238  |

| № бита | Наименование | Функциональное назначение бита, краткое описание бита          |  |  |  |  |  |
|--------|--------------|----------------------------------------------------------------|--|--|--|--|--|
| л⊻онта | бита         | назначения и принимаемых значений                              |  |  |  |  |  |
| 7      | FF           | Задает формат передаваемого фрейма. 1 — Extended Frame Format  |  |  |  |  |  |
| /      | LL           | (EFF), 0 — Standard Frame Format (SFF)                         |  |  |  |  |  |
| 6      | RTR          | Необходимо установить в 1 для передачи фрейма, содержащего     |  |  |  |  |  |
| 6      | KIK          | запрос на удаленную передачу                                   |  |  |  |  |  |
| 5      | _            |                                                                |  |  |  |  |  |
| 4      | _            |                                                                |  |  |  |  |  |
| 3      | DLC.3        | П                                                              |  |  |  |  |  |
| 2      | DLC.2        | Поле определяет длину передаваемого сообщения. Должно          |  |  |  |  |  |
| 1      | DLC.1        | принимать значения от 0 до 8. Если поле имеет значение большее |  |  |  |  |  |
| 0      | DLC.0        | 8, будет передано 8 Б                                          |  |  |  |  |  |

Регистры, задающие поле идентификатора фрейма, различаются для стандартного и расширенного форматов фрейма. Регистры для стандартного фрейма описаны в таблице 3.18.16, для расширенного — в таблице 3.18.17.

Таблица 3.18.16 — Описание регистров идентификатора для стандартного формата фрейма (SFF)

| Аддр. | Регистр | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x44  | TX ID 1 | ID.28 | ID.27 | ID.26 | ID.25 | ID.24 | ID.23 | ID.22 | ID.21 |
| 0x48  | TX ID 2 | ID.20 | ID.19 | ID.18 | _     | _     | _     | _     | _     |

Таблица 3.18.17 — Описание регистров идентификатора для расширенного формата фрейма (EFF)

| Аддр. | Регистр | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x44  | TX ID 1 | ID.28 | ID.27 | ID.26 | ID.25 | ID.24 | ID.23 | ID.22 | ID.21 |
| 0x48  | TX ID 2 | ID.20 | ID.19 | ID.18 | ID.17 | ID.16 | ID.15 | ID.14 | ID.13 |
| 0x4C  | TX ID 3 | ID.12 | ID.11 | ID.10 | ID.9  | ID.8  | ID.7  | ID.6  | ID.5  |
| 0x50  | TX ID 4 | ID.4  | ID.3  | ID.2  | ID.1  | ID.0  | _     | _     | _     |

Содержимое полей данных для стандартного фрейма задается регистрами по адресам 0x4C - 0x68 и для расширенного фрейма — по адресам 0x54 - 0x70. Данные передаются, начиная с наиболее значимого бита (MSB) по младшему адресу.

### 3.18.3.12 Регистры приёмного буфера

Инв. № дубл.

Взам. инв. №

Подп. и дата

Содержимое приёмного буфера можно прочитать из регистров по адресам от 0x40 до 0x70, как показано в таблице 3.18.18. Расположение регистров зависит от формата передаваемого сообщения (SFF/EFF). Все эти регистры доступны на чтение

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 239  |

Копировал

Формат А4

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

Таблица 3.18.18 — Регистры, отображающие содержимое приёмного буфера в стандартном и расширенном сообщениях

| Смещение | SFF                                | EFF                  |
|----------|------------------------------------|----------------------|
| 0x40     | RX frame information               | RX frame information |
| 0x44     | RX ID 1                            | RX ID 1              |
| 0x48     | RX ID 2                            | RX ID 2              |
| 0x4C     | RX data 1                          | RX ID 3              |
| 0x50     | RX data 2                          | RX ID 4              |
| 0x54     | RX data 3                          | RX data 1            |
| 0x58     | RX data 4                          | RX data 2            |
| 0x5C     | RX data 5                          | RX data 3            |
| 0x60     | RX data 6                          | RX data 4            |
| 0x64     | RX data 7                          | RX data 5            |
| 0x68     | RX data 8                          | RX data 6            |
| 0x6C     | RX FI следующего сообщения в FIFO  | RX data 7            |
| 0x70     | RX ID1 следующего сообщения в FIFO | RX data 8            |

Регистр формата фрейма (RX frame information), представленный в таблице 3.18.19, имеет одинаковую структуру для стандартных и расширенных фреймов.

Таблица 3.18.19 — Описание регистра RX frame information

Инв. № дубл.

Взам. инв. №

Подп. и дата

| № бита | Наименование | Функциональное назначение бита, краткое описание бита                                        |
|--------|--------------|----------------------------------------------------------------------------------------------|
| л⊻оита | бита         | назначения и принимаемых значений                                                            |
| 7      |              | Формат принимаемого фрейма. 1 — Extended Frame Format (EFF), 0 — Standard Frame Format (SFF) |
| 6      | RTR          | Имеет значение «1», если принятый фрейм имеет формат RTR                                     |
| 5      | _            |                                                                                              |
| 4      | _            |                                                                                              |
| 3      | DLC.3        |                                                                                              |
| 2      | DLC.2        | Co vanner va verezana saŭ varre ve proventa do aŭ va                                         |
| 1      | DLC.1        | Содержит количество байт данных в принятом фрейме                                            |
| 0      | DLC.0        |                                                                                              |
|        |              |                                                                                              |

Регистры, содержащие поле идентификатора фрейма, различаются для стандартного и расширенного форматов фрейма. Регистры для стандартного фрейма описаны в таблице 3.18.20, для расширенного — в таблице Таблица 3.18.21.

| -  |      |      |          |       |      |                                   |      |
|----|------|------|----------|-------|------|-----------------------------------|------|
|    |      |      |          |       |      |                                   |      |
| L  |      |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
| L  |      |      |          |       |      | Техническое описание              | 0.40 |
| И. | зм Л | lucm | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 240  |
|    |      |      |          |       |      | 10                                |      |

| Аддр. | Регистр | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x44  | TX ID 1 | ID.28 | ID.27 | ID.26 | ID.25 | ID.24 | ID.23 | ID.22 | ID.21 |
| 0x48  | TX ID 2 | ID.20 | ID.19 | ID.18 | RTR   | _     | _     | _     | _     |

Таблица 3.18.21 — Описание регистров идентификатора для расширенного формата фрейма (EFF)

| Аддр. | Регистр | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x44  | TX ID 1 | ID.28 | ID.27 | ID.26 | ID.25 | ID.24 | ID.23 | ID.22 | ID.21 |
| 0x48  | TX ID 2 | ID.20 | ID.19 | ID.18 | ID.17 | ID.16 | ID.15 | ID.14 | ID.13 |
| 0x4C  | TX ID 3 | ID.12 | ID.11 | ID.10 | ID.9  | ID.8  | ID.7  | ID.6  | ID.5  |
| 0x50  | TX ID 4 | ID.4  | ID.3  | ID.2  | ID.1  | ID.0  | RTR   | _     | _     |

Содержимое полей данных для стандартного фрейма содержится в регистрах по адресам 0x4C - 0x68 и для расширенного фрейма — по адресам 0x54 - 0x70.

#### 3.18.3.13 Фильтрация принимаемых сообщений

Фильтр принимаемых сообщений используется, чтобы отфильтровывать сообщения, не соответствующие определённым условиям. Если сообщение отфильтровано, оно не будет помещаться в приёмное FIFO и будет недоступно через регистры.

В расширенном режиме работы существует два различных режима фильтрации: одиночная и двойная фильтрация. Режим фильтрации определяется битом Acceptance filter mode в регистре Mode. В одиночном режиме используется один фильтр размером 4 байта. В двойном режиме используются два фильтра меньшего размера, и, если хотя бы один из этих фильтров не отсеивает сообщение, оно помещается в приёмное FIFO.

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

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

1нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

241

Таблица 3.18.22 — Регистры фильтра принимаемых сообщений

| Смещение | Регистр                  |
|----------|--------------------------|
| 0x40     | Acceptance code 0 (ACR0) |
| 0x44     | Acceptance code 1 (ACR1) |
| 0x48     | Acceptance code 2 (ACR2) |
| 0x4C     | Acceptance code 3 (ACR3) |
| 0x50     | Acceptance mask 0 (AMR0) |
| 0x54     | Acceptance mask 1 (AMR1) |
| 0x58     | Acceptance mask 2 (AMR2) |
| 0x5C     | Acceptance mask 3 (AMR3) |

3.18.3.13.1 Одиночный режим фильтрации, стандартные фреймы

Регистры ACR0-3 сравниваются с содержимым входящего сообщения в следующем порядке:

- ACR0.7-0 & ACR1.7-5 сравниваются с ID.28-18;
- ACR1.4 сравнивается с битом RTR;
- ACR1.3-0 не используются;
- ACR2 & ACR3 сравниваются с байтами данных 1 и 2.

Соответствующие биты в регистрах AMR, выставленные в «1», означают, что значения данных бит могут быть любыми для приёма сообщения.

3.18.3.13.2 Одиночный режим фильтрации, расширенные фреймы

Регистры ACR0-3 сравниваются с содержимым входящего сообщения в следующем порядке:

- ACR0.7-0 & ACR1.7-0 сравниваются с ID.28-13;
- ACR2.7-0 сравнивается с ID.12-0;
- ACR3.2 сравнивается с битом RTR;
- ACR3.1-0 не используются.

Соответствующие биты в регистрах AMR, выставленные в «1», означают, что значения данных бит могут быть любыми для приёма сообщения.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Инв. № дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

нв. № подл.

3.18.3.13.3 Двойной режим фильтрации, стандартные фреймы

Регистры ACR0-3 сравниваются с содержимым входящего сообщения в следующем порядке:

#### Фильтр 1:

- ACR0.7-0 & ACR1.7-5 сравниваются с ID.28-18;
- ACR1.4 сравнивается с битом RTR;
- ACR1.3-0 сравниваются со старшим полубайтом байта данных 1;
- ACR3.3-0 сравниваются с младшим полубайтом байта данных 1; Фильтр 2:
- ACR2.7-0 & ACR3.7-5 сравниваются с ID.28-18;
- ACR3.4 сравниваются с битом RTR.

Соответствующие биты в регистрах AMR, выставленные в «1», означают, что значения данных бит могут быть любыми для приёма сообщения.

3.18.3.13.4 Двойной режим фильтрации, расширенные фреймы

Регистры ACR0-3 сравниваются с содержимым входящего сообщения в следующем порядке:

Фильтр 1:

— ACR0.7-0 & ACR1.7-0 сравниваются с ID.28-13.

Фильтр 2:

— ACR2.7-0 & ACR3.7-0 сравниваются с ID.28-13.

Соответствующие биты в регистрах AMR, выставленные в «1», означают, что значения данных бит могут быть любыми для приёма сообщения.

3.18.3.14 Регистр счётчика принимаемых сообщений RX message counter Регистр содержит количество сообщений, которые в настоящий момент находятся в приёмном FIFO. Старшие 3 бита регистра всегда имеют значение «0».

3.18.4 Общие регистры для базового и расширенного режимов работы

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

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Данный регистр в текущей конфигурации контроллера используется только для выбора режима работы — базового или расширенного. Поля, задающие частоту, управляют выводом clkout, который ни к чему не подключен. Описание полей регистра Clock\_divider приводится в таблице 3.18.23.

Таблица 3.18.23 — Описание регистра Clock divider

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 7      | CAN mode          | 1 — расширенный режим, 0 — базовый режим                                                |
| 6 – 4  | -                 | Зарезервировано                                                                         |
| 3      | Clock off         | Отключение вывода clkout                                                                |
| 2-0    | Clock divisor     | Выбор частоты (не используется)                                                         |

3.18.4.2 Первый регистр временных параметров Bus\_timing\_0 Описание полей регистра Bus\_timing\_0 приводится в таблице 3.18.24.

Таблица 3.18.24 — Описание регистра Bus\_timing\_0

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 7 – 6  | SJW               | Synchronization jump width                                                              |
| 5-0    | BRP               | Предделитель Baud rate                                                                  |

Период тактового сигнала контроллера CAN определяется по формуле

$$tscl = 2 \cdot tclk \cdot (BRP + 1), \tag{12}$$

где tclk — период системной частоты.

Инв. № дубл.

Взам. инв. №

Подп. и дата

Величина SJW определяет, сколько периодов tscl необходимо для одной пересинхронизации.

3.18.4.3 Второй регистр временных параметров Bus\_timing\_1

Описание полей perистра Bus\_timing\_1 приводится в таблице 3.18.25.

Таблица 3.18.25 — Описание регистра Bus timing 1

| № бита | Наименование бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|-------------------|-----------------------------------------------------------------------------------------|
| 7      | SAM               | 1 — шина сэмплируется 3 раза,<br>0 — единичное сэмплирование                            |
| 6 – 4  | TSEG2             | Time segment 2                                                                          |
| 3-0    | TSEG1             | Time segment 1                                                                          |

|     |      |          |       |      | Микросхема интегральная 5023ВС016 | Лист |
|-----|------|----------|-------|------|-----------------------------------|------|
|     |      |          |       |      | Техническое описание              |      |
| Изм | Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 244  |

Копировал

Формат А4

Длительность битового периода на шине CAN определяется системной частотой CAN и временными сегментами Time segment 1 и 2:

$$ttseg1 = tscl \cdot (TSEG1 + 1) \tag{13}$$

$$ttseg2 = tscl \cdot (TSEG2 + 1) \tag{14}$$

$$tbit = ttseg1 + ttseg2 + tscl (15)$$

Сэмплирование производится между TSEG1 и TSEG2 в битовом периоде.

### 3.19 Контроллер интерфейса I<sup>2</sup>C

Контроллер интерфейса  $I^2C$  реализует функции мастера на шине. Блок  $I^2C$ -мастер расположен на шине AMBA APB. Он является совместимым со стандартом Philips  $I^2C$ . Поддерживается режим скорости Standard (100 кбит/с) и режим Fast (400 кбит/с). На обеих линиях шины  $I^2C$  должны присутствовать внешние резисторы, подтягивающие линию к высокому уровню. Структурная схема блока представлена на рисунке 3.19.1.



#### 3.19.1.1 Протокол передачи

Шина  $I^2$ С является простой 2-проводной последовательной шиной с поддержкой нескольких мастеров с поддержкой детектирования коллизий и арбитрацией.

Шина состоит из последовательной линии данных (SDA) и последовательной линии тактового сигнала (SCL). Стандартом  $I^2C$  определяются 3 режима скорости: Standard (100 кбит/с), Fast (400 кбит/с) и High speed (3,4 Мбит/с), из них блоком поддерживаются первые два.

Транзакция на шине I<sup>2</sup>C начинается со стартового условия (START). Условие START определяется как переход с высокого на низкий уровень на линии SDA в момент, когда на линии SCL высокий уровень. Транзакция оканчивается условием STOP, определяемым как переход с низкого на высокий уровень на линии SDA в момент, когда на линии SCL высокий уровень. Эти условия всегда генерируются мастером на шине. Шина считается занятой после условия START и свободной после определённого количества времени после условия STOP. Время, между условием STOP и последующим условием START определяется в спецификации I<sup>2</sup>C и зависит от скорости шины.

На рисунке 3.19.2 изображена транзакция записи данных на шине  $I^2C$ . Сначала мастер генерирует условие START и затем передаёт 7-битный адрес подчинённого устройства (slave). За адресом следует  $R/\overline{W}$  бит, определяющий направление передачи. В случае, изображённом на рисунке 3.19.2, бит  $R/\overline{W}$  имеет значение «0», что соответствует операции записи. После того, как мастер передаёт адрес и бит  $R/\overline{W}$ , он освобождает линию SDA. Приёмник подтягивает линию SDA к низкому уровню для подтверждения передачи. Если приёмник не подтверждает передачу, мастер может сгенерировать условие STOP для того, чтобы прервать транзакцию, либо начать новую транзакцию сгенерировав повторное условие START.

После того, как первый байт был подтверждён приёмником, мастер передаёт байт данных. Если бит  $R/\overline{W}$  был установлен в «1», мастер должен был действовать как приёмник в течение этой фазы транзакции. После того, как байт данных был

Изм Лист № докум. Подп. Дата

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

Если скорость на шине слишком велика для подчинённого устройства, оно может растянуть период тактового сигнала, удерживая сигнал на линии SCL на низком уровне после того, как мастер установил на линии значение SCL в низкий уровень.



Рисунок 3.19.2 — Полная транзакция на шине I<sup>2</sup>C

#### 3.19.1.2 Генерация тактового сигнала

Блок I<sup>2</sup>C-мастер использует регистр предделителя частоты на линии SCL, содержащий значение Prescale. Значение предделителя рассчитывается по формуле

$$Prescale = FSYS / (5 \cdot FSCL) - 1, \tag{16}$$

где FSCL имеет значение 100 кГц для режима скорости Standard и 400 кГц для режима Fast.

То есть для системной частоты 80 МГц значение предделителя будет равно

Prescale = 80 MΓ
$$\mu$$
 / (5 · 100 κΓ $\mu$ ) – 1 = 159 = 0x9F. (17)

Значение предделителя частоты может быть изменено только когда блок отключен. В связи с особенностями синхронизации минимальное рекомендуемое значение делителя равно трём. Таким образом минимальная системная частота для функционирования в режиме скорости Standard равна 2 МГц. При этом системная частота, равная 2 МГц, приведёт к несоответствию требованиям на минимальное время setup, равное 100 нс в режиме скорости Fast.

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|
|     |      |          |       |      |

Тодп. и дата.

Инв. Nº дубл.

Взам. инв. №

Подп. и дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

#### 3.19.1.3 Программная модель управления блоком

Тодп. и дата.

Инв. № дубл.

Взам. инв. №

Подп. и дата

нв. № подл.

Блок  $I^2$ С-мастер инициализируется посредством записи значения Prescale в регистр предделителя и дальнейшего включения блока в работу путём установки бита EN в регистре Control. Прерывания включаются путём записи бита IEN в регистре Control.

Чтобы записать байт данных в подчинённое устройство, мастер должен сгенерировать условие START и послать адрес устройства со значением бита  $R/\overline{W}$  равным 0. После того, как подчинённое устройство подтверждает адрес, мастер передает данные, ожидает подтверждения и генерирует условие STOP.

Последовательность действий пользователя, необходимая для записи байта данных, слудующая:

- 1) выполнить битовый сдвиг адреса подчинённого устройства на одну позицию влево, записать полученное значение в регистр  $Tx_Rx$ . Младший бит регистра, соответствующий биту  $R/\overline{W}$ , установлен в «0»;
- 2) сгенерировать условие START и послать содержимое регистра Tx\_Rx, установив биты STA\_RxACK и WR в регистр Com\_Stat;
- 3) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
- 4) прочитать бит STA\_RxACK в регистре Com\_Stat. Если STA\_RxACK в нуле, это значит, что подчинённое устройство подтвердило транзакцию и можно перейти к п. 5. Если же STA\_RxACK имеет значение «1», подчинённое устройство не подтвердило транзакцию, нужно перейти к п. 1;
  - 5) записать значение передаваемого байта данных в регистр Tx\_Rx;

 Микросхема интегральная 5023BC016
 Лист

 Техническое описание
 Техническое описание

 Изм Лист
 № докум.
 Подп.
 Дата

Копировал

Формат А4

- 6) послать данные в подчинённое устройство и сгенерировать условие STOP посредством установки битов STO\_BUSY и WR в регистр Com\_Stat;
- 7) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
- 8) убедиться, что подчиненное устройство подтвердило данные, прочитав бит STA\_RxACK в регистре Com\_Stat. STA\_RxACK должен иметь значение «0».

Чтобы прочитать байт данных из внешней памяти, работающей по интерфейсу  $I^2C$ , большая часть приведённой выше последовательности действий повторяется. Записываемые данные в этом случае являются адресом в памяти. После того, как адрес был записан, мастер генерирует условие START и читает данные из подчинённого устройства.

Последовательность действий, которую нужно осуществить, чтобы прочитать из внешней  $I^2$ С-памяти:

- 1) выполнить битовый сдвиг адреса подчинённого устройства на одну позицию влево, записать полученное значение в регистр  $Tx_Rx$ . Младший бит регистра, соответствующий биту  $R/\overline{W}$ , установлен в «0»;
- 2) сгенерировать условие START и послать содержимое регистра Tx\_Rx, установив биты STA\_RxACK и WR в регистр Com\_Stat;
- 3) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
- 4) прочитать бит STA\_RxACK в регистре Com\_Stat. Если STA\_RxACK в нуле, это значит, что подчинённое устройство подтвердило транзакцию и можно перейти к п. 5. Если же STA\_RxACK имеет значение «1», подчинённое устройство не подтвердило транзакцию, нужно перейти к п. 1;
- 5) записать адрес в устройстве, который нужно будет прочитать из памяти, в регистр Tx\_Rx;
- 6) установить бит WR в регистр Com\_Stat. Условие STOP не должно генерироваться;
- 7) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

- 8) прочитать бит STA\_RxACK в регистре Com\_Stat. Значение бита должно быть «0»;
- 9) снова выполнить битовый сдвиг адреса подчинённого устройства на одну позицию влево, записать полученное значение в регистр Tx\_Rx. Младший бит регистра, соответствующий биту  $R/\overline{W}$ , установить в «1» (признак транзакции чтения);
- 10) установить биты STA\_RxACK и WR в регистр Com\_Stat для того, чтобы сгенерировать повторное условие START;
- 11) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
- 12) прочитать бит STA\_RxACK в регистре Com\_Stat. Подчинённое устройство должно подтвердить транзакцию (значение бита «0»);
- 13) подготовиться к приёму данных из  $I^2C$ -памяти; Установить биты  $RD_AL$ , ACK и STO BUSY в регистре Com Stat. Установка бита ACK приводит к условию NACK для принятых данных, что означает окончание транзакции;
- 14) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
  - 15) принятые данные могут быть прочитаны из регистра Тх Rx.

Чтобы выполнить последовательное чтение нескольких байт, мастер должен продвигаться между п. 13 и п. 15 не устанавливая бит ACK и STO\_BUSY в п. 13. Для того, чтобы завершить последовательный приём данных, эти биты необходимо установить в «1». Не все подчинённые устройства могут поддерживать режим последовательного чтения.

Чтобы записать байт данных в устройство, требующее адресации (например,  $I^{2}$ С-память), сначала мастер адресует устройство и указывает записываемых данных. После того, как подчинённое устройство подтверждает первую часть транзакции, записываемые данные передаются без повторной генерации условия START.

Необходимо выполнить нижеприведённую последовательность действий:

Микросхема интегральная 5023ВС016 Техническое описание Версия 2.04 от 01.09.2017 г. Лист № докум. Подп. *Д*ата

- 2) сгенерировать условие START и послать содержимое регистра Tx\_Rx, установив биты STA\_RxACK и WR в регистр Com\_Stat;
- 3) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
- 4) прочитать бит STA\_RxACK в регистре Com\_Stat. Если STA\_RxACK в нуле, это значит, что подчинённое устройство подтвердило транзакцию и можно перейти к п. 5. Если же STA\_RxACK имеет значение «1», подчинённое устройство не подтвердило транзакцию, нужно перейти к п. 1;
- 5) записать адрес в устройства, который нужно будет прочитать из памяти, в регистр Tx\_Rx;
  - 6) установить бит WR в регистр Com\_Stat;
- 7) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
- 8) прочитать бит STA\_RxACK в регистре Com\_Stat. Значение бита должно быть «0»;
  - 9) записать байт данных в регистр Тх\_Rx;
- 10) установить биты WR и STO\_BUSY в регистр Com\_Stat для того, чтобы послать байт данных и затем сгенерировать условие STOP;
- 11) дождаться прерывания, либо момента времени, когда бит TIP в регистре Com\_Stat станет равным нулю;
- 12) проверить бит STA\_RxACK в регистре Com\_Stat. Если запись прошла успешно, подчинённое устройство должно подтвердить транзакцию.

Инв. № подл. Подп. и дата Взам. инв. № Инв. № дубл. Подп. и дата.

Изм Лист № докум. Подп. Дата

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

# 3.19.2 Описание регистров блока I<sup>2</sup>C-мастер

# Таблица 3.19.1 — Структура регистров блока I<sup>2</sup>C-мастер

| Смещение | Название регистра | Тип | Значение по<br>сбросу | Описание                             |
|----------|-------------------|-----|-----------------------|--------------------------------------|
| 0x00     | Clock_prescale    | RW  | 0                     | Регистр делителя частоты             |
| 0x04     | Control           | RW  | 0                     | Регистр управления                   |
| 0x08     | Tx_Rx             | RW  | 0                     | Регистр переданных и принятых данных |
| 0x0C     | Com_Stat          | RW  | 0                     | Регистр команд и статуса             |

# 3.19.2.1 Регистр Clock\_prescale

## Таблица 3.19.2 — Описание регистра Clock\_prescale

| № бита  | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                           |
|---------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| л⊻онта  | бита         | назначения и принимаемых значений                                                                                                                                                                                                               |
| 31 – 16 | _            |                                                                                                                                                                                                                                                 |
| 15 – 0  |              | Значение по сбросу 0xFFFF. Значение используется для задания периода тактового сигнала на линии SCL. Значение может быть изменено только если бит EN в регистре Control установлен в «0». Минимальное рекомендуемое значение этого поля равно 3 |

### 3.19.2.2 Регистр Control

### Таблица 3.19.3 — Описание регистра Control

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений |
|--------|----------------------|-----------------------------------------------------------------------------------------|
| 31 – 8 | _                    |                                                                                         |
| 7      | EN                   | $1$ — Перевод блока $I^2$ С в рабочий режим                                             |
| 6      | IEN                  | 1 — Включение прерывания, происходящего по завершению транзакции                        |
| 5-0    | _                    |                                                                                         |

# 3.19.2.3 Регистр Tx\_Rx

Инв. № дубл.

Взам. инв. №

Подп. и дата

# Таблица 3.19.4 — Описание регистра Tx\_Rx

| № бита | Наименование<br>бита | Функциональное назначение бита, краткое описание бита назначения и принимаемых значений                                                                                                                                                                                                                                       |  |  |
|--------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 – 8 | _                    |                                                                                                                                                                                                                                                                                                                               |  |  |
| 7-0    | DATA                 | Данные для передачи и прёма. По записи: старшие 7 бит слова данных, которые будут переданы по шине $I^2C$ . При этом значение первого бита $R/\overline{W}$ определяет направление транзакции: 1 — чтение из подчинённого устройства, 0 — запись в подчинённое устройство. По чтению: последний байт, принятый по шине $I^2C$ |  |  |

|     |        |          |       |      | Микросхема интегральная 5023ВС016 | Лист     |
|-----|--------|----------|-------|------|-----------------------------------|----------|
|     |        |          |       |      | Техническое описание              | $\vdash$ |
| Изі | и Лист | № докум. | Подп. | Дата | Версия 2.04 от 01.09.2017 г.      | 252      |
| · · |        |          |       |      | M                                 |          |

# 3.19.2.4 Регистр Com\_Stat

# Таблица 3.19.5 — Описание регистра Com\_Stat

|        | Наименование | Функциональное назначение бита, краткое описание бита                                                                                                                                                                                                                                                                         |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| № бита |              | , ±                                                                                                                                                                                                                                                                                                                           |
| 21 0   | бита         | назначения и принимаемых значений                                                                                                                                                                                                                                                                                             |
| 31 – 8 | _            |                                                                                                                                                                                                                                                                                                                               |
| 7      | STA_ RxACK   | По записи: генерация условия START на шине, либо повторного условия START По чтению: принятое значение бита подтверждения (acknowledge).                                                                                                                                                                                      |
|        |              | 0 — подчинённое устройство подтвердило транзакцию,                                                                                                                                                                                                                                                                            |
|        |              | 1 — подтверждение не было получено                                                                                                                                                                                                                                                                                            |
|        |              | По записи: генерация условия STOP на шине                                                                                                                                                                                                                                                                                     |
| 6      | STO_BUSY     | По чтению: бит выставляется в «1» если на шине было обнаружено условие START и сбрасывается в «0» если было обнаружено условие STOP                                                                                                                                                                                           |
| 5      | RD_ AL       | По записи: чтение из подчинённого устройства По чтению: устанавливается в «1», когда блок потерял арбитрацию. Данное условие наступает в случае, если обнаружено условие STOP, которое не было запрошено, либо если мастер выставляет высокий уровень на линии SDA, но уровень на линии SDA остается в низком состоянии       |
| 4      | WR           | Запись в подчинённое устройство                                                                                                                                                                                                                                                                                               |
| 3      | ACK          | Используется, когда мастер является приёмником. 0 — послать АСК, 1 — послать NACK                                                                                                                                                                                                                                             |
| 2      | _            |                                                                                                                                                                                                                                                                                                                               |
| 1      | TIP          | Имеет значение «1», когда происходит передача данных и «0» — когда транзакция завершается. Также этот бит выставляется, когда блок генерирует условие STOP                                                                                                                                                                    |
| 0      | IACK_ IF     | По записи: очищает флаг прерывания (IF) в регистре Com_Stat По чтению: бит выставляется, когда транзакция завершена, либо, когда теряется арбитрация. Если установлен бит IEN в регистре Control, в этот момент будет сгенерировано прерывание. Новые прерывания также будут генерироваться даже если этот бит не был сброшен |

| Подп. и дата.          |   |
|------------------------|---|
| Инв. № дубл.           |   |
| Взам. инв. №           |   |
| . № подл. Подп. и дата |   |
| Инв. № подл.           | ı |

|     |      |          |       |             | Микросхема интегральная 5023ВС016 |
|-----|------|----------|-------|-------------|-----------------------------------|
|     |      |          |       |             | Техническое описание              |
| 1зм | Лист | № докум. | Подп. | <i>Дата</i> | Версия 2.04 от 01.09.2017 г.      |

По вопросам поставки микросхем и технической поддержки обращайтесь в ООО «НПП «Цифровые решения»:



ТТТТТ ООО «НПП «Цифровые решения»

111250, г. Москва, ул. 2-я Синичкина, д.9а, стр. 7 Почтовый адрес: 105066 Россия, г. Москва, а/я 18

Телефон: +7 (495) 978-2870 Факс: +7 (495) 745-4218 e-mail: support@dsol.ru www.dsol.ru

| Подп. и дата. | ı   |      |          |       |      |           |           |             |
|---------------|-----|------|----------|-------|------|-----------|-----------|-------------|
| Инв. № дубл.  |     |      |          |       |      |           |           |             |
| Взам. инв. №  |     |      |          |       |      |           |           |             |
| Подп. и дата  |     |      |          |       |      |           |           |             |
| Инв. Nº подл. | Изм | Лист | № докум. | Подп. | Дата |           |           | Лист<br>254 |
|               |     |      |          |       |      | Копировал | Формат А4 |             |

| Пер             | ечен | нь сокращений и условных обозначений                                         |
|-----------------|------|------------------------------------------------------------------------------|
| БВС             |      | Блок вставки синхромаркера                                                   |
| БПС             |      | Блок поиска синхромаркера                                                    |
| ГС              |      | Граничное сканирование                                                       |
| ВС              |      | Специализированный вычислитель с плавающей запятой                           |
| BCO             |      | -                                                                            |
| ВСФ             |      | Воздействие специальных факторов                                             |
| КС              |      | Командное слово                                                              |
| КВП             |      | Контроллер внешней памяти                                                    |
| КШ              |      | Контроллер шины                                                              |
| M               |      | Режим монитора                                                               |
| МКПД            |      | Мультиплексный канал передачи данных                                         |
| ОЗУ             |      | Оперативное запоминающие устройство                                          |
| OC              |      | Ответное слово                                                               |
| ОУ              |      | Оконечное устройство                                                         |
| ПДП             |      | Прямой доступ к памяти                                                       |
| ПдТМИ           |      | Передатчик телеметрической информации                                        |
| ПрТКИ           |      | Приёмник телекомандной информации                                            |
| CT              |      | Сторожевой таймер                                                            |
| ФК              |      | Функциональный контроль                                                      |
| ФТС             |      | Формирователь тактовых сигналов и сигналов сброса                            |
| ARM             |      | Advanced RISK Machine                                                        |
|                 |      | Advanced Microcontroller Bus Architecture, Advanced High performance Bus     |
|                 | —    | Advanced Microcontroller Bus Architecture, Advanced Peripheral Bus           |
| AHB<br>BusMUX   |      | Advanced High performance Bus                                                |
| AHB-APB         |      | Advanced High performance Bus - Advanced Peripheral Bus                      |
| CCSDS           |      | Consultative Committee for Space Data Systems                                |
| CAN             |      | Controller Area Network                                                      |
| CLK             |      | Тактовый сигнал системной частоты                                            |
| CPSDVSR         |      | clockprescaledivisorvalue – коэффициент деления тактового сигнала            |
| CPU             |      | ЦПУ, центральное процессорное устройство, микропроцессор                     |
| CPU CORE        |      | ядро микропроцессора                                                         |
| DMA             |      | Direct Memory Access                                                         |
| EDAC            |      | Error Detection and Correction                                               |
| EPS             |      | Electric Power Steering                                                      |
| FIFO            |      | First in/First out                                                           |
| FLASH           | —    | Перепрограммируемая постоянная память                                        |
| FPU             | —    | Floating Point unit                                                          |
| GPIO            | —    | General Input-Output Port                                                    |
| $I^2C$          |      | Inter-Integrated Circuit                                                     |
| JTAG            |      | Joint Test Action Group (аппаратный интерфейс на базе стандарта IEEE 1149.1) |
| LDPC            |      | Low Density Parity Check Code код с малой плотностью проверок на четность)   |
| NMI             |      | Non-Maskable Interrupt                                                       |
|                 |      |                                                                              |
|                 |      | Микросхема интегральная 5023BC016 Лист<br>Техническое описание               |
| Изм Лист № доку | /M.  | Подп. Дата Версия 2.04 om 01.09.2017 г. 255                                  |
| •               |      | Копировал Форман М                                                           |

Взам. инв. № Инв. № дубл.

Инв. № подл. Подп. и дата

| NVIC  | — Nested Vectory Interrupt Controller                                                     |
|-------|-------------------------------------------------------------------------------------------|
| PCCU  | — Portable Command and Control Unit                                                       |
| QDU   | — Квадратурный преобразователь                                                            |
| RISC  | <ul> <li>Reduced instruction set computer</li> </ul>                                      |
| RST   | — сигнал сброса                                                                           |
| SCL   | <ul><li>— линия тактового сигала</li></ul>                                                |
| SDA   | <ul> <li>последовательная линия данных</li> </ul>                                         |
| SOD   | — Slave mode Output Disable — запрет линии SPI_MOSI для ведомого режима                   |
| SPI   | — Serial Peripheral Interface (последовательный периферийный интерфейс)                   |
| SRAM  | <ul> <li>Synchronous Random Access Memory</li> </ul>                                      |
| SCR   | — SerialClockRate – скорость информационного обмена                                       |
| SSE   | — Synchronous Serial Port Enable – разрешение последовательного синхронного порта         |
| SSI   | <ul> <li>— Synchronous Serial Interface (синхронно-последовательный интерфейс)</li> </ul> |
| UART  | — Universal Asynchronous receiver-transmitter (универсальный асинхронный                  |
|       | приёмопередатчик)                                                                         |
| UTIME | — Таймер временных отсчётов                                                               |
|       |                                                                                           |
|       |                                                                                           |
|       |                                                                                           |
|       |                                                                                           |
|       |                                                                                           |
|       |                                                                                           |
|       |                                                                                           |

| Изм | Лист | № докум. | Подп. | Дата |
|-----|------|----------|-------|------|

Взам. инв. № Инв. № дубл.

Подп. и дата

Инв. № подл.

Микросхема интегральная 5023BC016 Техническое описание Версия 2.04 от 01.09.2017 г.

# Перечень ссылочных документов

| Обозначение документов, на | Наименования документов                                   |  |  |
|----------------------------|-----------------------------------------------------------|--|--|
| которые дана ссылка        |                                                           |  |  |
| ГОСТ Р 52070-2003          | Единая система конструкторской документации. Текстовые    |  |  |
| 10011 32070-2003           | документы.                                                |  |  |
|                            | Комплексная система общих технических требований. Изделия |  |  |
| ГОСТ В 20.39.412 - 97      | электронной техники, квантовой электроники и              |  |  |
| 1 OC1 B 20.39.412 - 97     | электротехнические военного назначения. Общие технические |  |  |
|                            | требования.                                               |  |  |
| АЕЯР.431290.994 ТУ         | Микросхема интегральная 5023ВС016 Технические условия     |  |  |

| дл. Подп. и дата Взам. инв. №   Инв. № дубл.   Подп. и дата. |   |                                                                                    |             |
|--------------------------------------------------------------|---|------------------------------------------------------------------------------------|-------------|
| Подп. и дата                                                 |   |                                                                                    |             |
|                                                              |   |                                                                                    |             |
|                                                              |   |                                                                                    |             |
|                                                              | 1 | ема интегральная 5023BC016<br>Техническое описание<br>Зерсия 2.04 om 01.09.2017 г. | Лист<br>257 |

# Перечень изменений

| Версия | Дата             | Описание                                                                                                                                                                                                                                          |
|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.0    | 22 июня 2017     | Исходная версия                                                                                                                                                                                                                                   |
| 2.01   | 29 июня 2017     | Внесены изменения в раздел 1.2. Исправлен рисунок 1.2.1. Исправлена таблица 1.2.1. Внесены исправления в раздел 3.1 (описание функциональных блоков). Внесены изменения в раздел 3.19. Изменён рисунок 3.19.1. Исправлены таблицы 3.19.1 – 3.19.5 |
| 2.02   | 07 июля 2017     | Изменены рисунки: 1.2.1; 3.1.1. Исправлены таблицы: 1.2.1; 1.2.2; 1.3.3; 3.2.1; 3.3.2; 3.4.13. Внесены изменения в раздел 3.11. Изменены рисунки 3.11.1 – 3.11.13. Внесены исправления в Перечень сокращений и условных обозначений               |
| 2.03   | 14 июля 2017     | Внесены изменения в рисунки 1.2.1 и 3.1.1                                                                                                                                                                                                         |
| 2.04   | 01 сентября 2017 | Исправлен рисунок 1.2.1.<br>Исправлены таблицы 1.2.1 и 1.2.2<br>Внесены изменения в раздел 3.1 и пункт 3.4.1.23.                                                                                                                                  |
|        |                  |                                                                                                                                                                                                                                                   |

| Подп. и дата. |     |      |          |       |      |                                                                                                     |                  |             |
|---------------|-----|------|----------|-------|------|-----------------------------------------------------------------------------------------------------|------------------|-------------|
| Инв. № дубл.  |     |      |          |       |      |                                                                                                     |                  |             |
| Взам. инв. №  |     |      |          |       |      |                                                                                                     |                  |             |
| Подп. и дата  |     |      |          |       |      |                                                                                                     |                  |             |
| Инв. Nº подл. | Изм | Лист | № докум. | Подп. | Дата | Микросхема интегральная 5023BC<br>Техническое описание<br>Версия 2.04 от 01.09.2017 г.<br>Копировал | 016<br>Формат А4 | Лист<br>258 |

|                   |        |          |                              |                   | Лист ре | егистрации                                     | и изменени                          | ıй<br>                                            |         |      |
|-------------------|--------|----------|------------------------------|-------------------|---------|------------------------------------------------|-------------------------------------|---------------------------------------------------|---------|------|
|                   | Изм.   |          | эмера лис<br>заме-<br>ненных | тов (стр<br>новых | аннупи- | Всего<br>листов<br>(страниц)<br>в<br>документе | Номер<br>документа                  | Входящий номер сопроводительного документа и дата | Подпись | Дата |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| 1                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| l                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| 1                 |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
|                   |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| $\left\{ \right.$ |        |          |                              |                   |         |                                                |                                     |                                                   |         |      |
| ŀ                 |        |          |                              |                   |         | Микросх                                        | ема интегр                          | ральная 5023BC016                                 |         | Лист |
|                   | Изм Пи | ст № док | VM.                          | одп. Д            | ama     |                                                | <b>Техническо</b><br>Версия 2.04 оп | е описание                                        |         | 259  |