

# РУКОВОДСТВО ПО ЭКСПЛУАТАЦИИ Мультиклеточный процессор MultiClet R1

Mультиклеточные процессоры: MCp042R100102-LQ256



#### Аннотация

Микропроцессор MCp042R100102-LQ256 имеет в своем составе мультиклеточное процессорное ядро. Ядро МП содержит 4 клетки - когерентных процессорных блоков, объединенных интеллектуальной коммутационной средой. МП имеют динамически реконфигурируемое ядро, распределение вычислительных ресурсов (клеток) по задачам производится согласно алгоритму заложенному в исполняемой программе. При этом один и тот же код может выполняться любым количеством и комбинацией клеток. Мультиклеточный процессор предназначен для решения широкого круга задач управления и цифровой обработки сигналов в приложениях, требующих минимального энергопотребления и высокой производительности.

#### Особенности:

- Число клеток 4
- Разрядность процессора 32/64 бита
- ПП(на кристалле) 256 Кбайт
- ПД(на кристалле)  $256~{
  m Kбайт}$
- блок операций над числами с плавающей запятой (в каждой клетке)
- Тактовая частота до 100 МГц;
- Производительность процессора 24 FLOPS/МГц;

#### Общие характеристики:

- Kopπyc LQFP-256
- Условия эксплуатации (-60 ...+125°C)
- Максим. потребл. мощность:
- ядра 1,05Вт на частоте 100МГц
- выходных каскадов портов 80мВт
- Напряжение питания (раздельное): ядра 1,8В, выходных каскадов — 3,3В

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

- 2 интерфейса SPI с селектором «ведомых» устройств (в режиме «ведущий»)
- 4 универсальных асинхронных приёмопередатчика UART с FIFO на прием/передачу
- 2 интерфейса I2C (один «ведомый» и один «ведущий»)
- интерфейс I2S («ведомый»/ «ведущий»)
- Ethernet MAC контроллер 10/100Mб/с
- USB 2.0 HS (device), внешний интерфейс ULPI
- часы реального времени с календарем
- 4 таймера общего назначения
- 6 портов ввода-вывода, общее количество вводов-выводов – 166
- 4-х канальный контроллер ШИМ
- сторожевой таймер
- АЦП(16 бит, 48 Квыб/с, 8 каналов)
- ЦАП(12 бит, 100 Мвыб/с, 1 канал)



# Содержание

www.multiclet.com

| 1 | 1.1 |        | ж сокращений                            |   |
|---|-----|--------|-----------------------------------------|---|
|   | 1.2 |        | ятые условные обозначения               |   |
| 2 | Опт | исание |                                         |   |
| _ | 2.1 |        | яные технические характеристики         |   |
|   | 2.1 |        | ктура МП                                |   |
|   | 2.2 | Струг  | riypa Mili                              | T |
| 3 | Цен | траль  | ное процессорное устройство             | 1 |
|   | 3.1 | Орган  | изация вычислительного процесса         | 1 |
|   | 3.2 | Механ  | низмы реализации                        | 1 |
|   |     | 3.2.1  | Идентификация команд                    | 1 |
|   |     | 3.2.2  | Организация буфера команд               | 1 |
|   |     | 3.2.3  | Управление коммутационной средой        | 2 |
|   | 3.3 | Струк  | ктура и организация клетки              | 2 |
|   |     | 3.3.1  | Устройство выборки команд               | 2 |
|   |     | 3.3.2  | Устройство управления                   | 2 |
|   |     | 3.3.3  | Буфер команд                            | 2 |
|   |     | 3.3.4  | Коммутационное устройство               | 2 |
|   |     | 3.3.5  | Целочисленное АЛУ                       | 2 |
|   |     | 3.3.6  | АЛУ с плавающей точкой                  | 2 |
|   |     | 3.3.7  | Блок доступа к памяти данных            | 2 |
|   |     | 3.3.8  | Мультиплексор результатов               | 2 |
|   |     | 3.3.9  | Набор регистров                         | 2 |
|   |     | 3.3.10 | Контроллер прерываний и отладочный блок | 2 |
|   | 3.4 | Регис  | тры                                     | 2 |
|   | 3.5 | Контр  | ооллер прерываний                       | 3 |
|   |     | 3.5.1  | Структура контроллера прерываний        | 3 |
|   |     | 3.5.2  | Регистры контроллера прерываний         | 3 |
|   |     | 3.5.3  | Порядок обработки прерываний            | 3 |
|   | 3.6 | Систе  | мный таймер                             | 3 |
|   |     | 3.6.1  | Режимы работы                           | 3 |
|   |     |        |                                         |   |
| 4 | Сре | едства | динамической реконфигурации             | 4 |
| 5 | Орі | ганиза | ция памяти                              | 4 |
|   | -   |        |                                         |   |

Все права защищены  $\bigcirc$  OAO «Мультиклет» 2010-2015



|   | 5.1 | Карта   |                                                               | 43 |
|---|-----|---------|---------------------------------------------------------------|----|
|   | 5.2 | Комм    | утатор                                                        | 46 |
|   | 5.3 | Контр   | ооллер транзакций данных (DTC)                                | 49 |
| 6 | Сис | стема : | гактирования                                                  | 52 |
|   |     | 6.0.1   | Описание работы системы тактирования                          | 52 |
|   |     | 6.0.2   | Описание работы модуля коммутации                             | 53 |
|   |     | 6.0.3   | Таблицы выбора коэффициентов R, N, K                          | 54 |
|   |     | 6.0.4   | Порядок работы с блоком PLL                                   | 54 |
|   |     | 6.0.5   | Регистры системы тактирования                                 | 56 |
| 7 | Апі | ларатн  | ая система отладки и тестирования                             | 59 |
|   | 7.1 | Контр   | ооллер (tap)                                                  | 59 |
|   | 7.2 | Канал   | ı доступа к памяти (jtag_mem)                                 | 61 |
|   | 7.3 | Канал   | и доступа к регистрам общего назначение и регистрам системной |    |
|   |     | периф   | рерии (jtag_gpr)                                              | 62 |
|   | 7.4 | Канал   | ı доступа к устройствам на шине АМВА (ahb_jtag)               | 63 |
|   | 7.5 | Модул   | ть отладки ПО (jtag_dbg)                                      | 65 |
|   | 7.6 | Регис   | тр периферийного сканирования (bsr)                           | 70 |
| 8 | Пер | оифері  | ийные устройства                                              | 71 |
|   | 8.1 | Порт    | ввода-вывода (GPIO)                                           | 72 |
|   |     | 8.1.1   | Краткие характеристики                                        | 72 |
|   |     | 8.1.2   | Функционирование GPIO                                         | 72 |
|   |     | 8.1.3   | Описание регистров                                            | 74 |
|   | 8.2 | Контр   | ооллер шины внешней памяти (MCTRL0)                           | 76 |
|   |     | 8.2.1   | Краткие характеристики                                        | 76 |
|   |     | 8.2.2   | Интерфейс PROM                                                | 77 |
|   |     | 8.2.3   | Интерфейс I/O                                                 | 80 |
|   |     | 8.2.4   | Интерфейс SRAM                                                | 82 |
|   |     | 8.2.5   | Интерфейс SDRAM                                               | 84 |
|   |     | 8.2.6   | Использование сигнализации готовности шины                    | 87 |
|   |     | 8.2.7   | Ошибки доступа                                                | 88 |
|   |     | 8.2.8   | Подключение PROM, SRAM, SDRAM памяти различной разряд-        |    |
|   |     |         | ности                                                         | 89 |
|   |     | 8.2.9   | Описание регистров                                            | 92 |
|   | 8.3 | Интер   | офейс UART(UARTx)                                             | 95 |
|   |     | 8.3.1   | Краткие характеристики                                        | 95 |



|     | 8.3.2 | Передача данных                                             | 95  |
|-----|-------|-------------------------------------------------------------|-----|
|     | 8.3.3 | Прием данных                                                | 97  |
|     | 8.3.4 | Установка скорости передачи                                 | 98  |
|     | 8.3.5 | Режимы самотестирования                                     | 98  |
|     |       | 8.3.5.1 Режим самотестирования на уровне интерфейсных линий | 98  |
|     |       | 8.3.5.2 Режим самотестирования на уровне данных             | 98  |
|     | 8.3.6 | Формирование прерываний                                     | 98  |
|     |       | 8.3.6.1 Режим отложенных прерываний приемника               | 99  |
|     | 8.3.7 | Описание регистров                                          | 100 |
| 8.4 | Интер | офейс SPI(SPIx)                                             | 102 |
|     | 8.4.1 | Краткие характеристики                                      | 102 |
|     | 8.4.2 | Трех-проводный режим                                        | 104 |
|     | 8.4.3 | Прием и передача данных                                     | 104 |
|     | 8.4.4 | Тактовый сигнал SCK                                         | 104 |
|     | 8.4.5 | Работа в режиме «ведущий»                                   | 104 |
|     | 8.4.6 | Работа в режиме «ведомый»                                   | 105 |
|     | 8.4.7 | Описание регистров                                          | 106 |
| 8.5 | Интер | офейс $I^2C$ «ведущий» (I2C0)                               | 109 |
|     | 8.5.1 | Краткие характеристики                                      | 109 |
|     | 8.5.2 | Общее описание протокола приема-передачи                    | 110 |
|     | 8.5.3 | Генерация несущей частоты                                   | 111 |
|     | 8.5.4 | Алгоритм работы с интерфейсом                               | 111 |
|     |       | 8.5.4.1 Запись данных                                       | 112 |
|     |       | 8.5.4.2 Чтение данных                                       | 112 |
|     | 8.5.5 | Описание регистров                                          | 114 |
| 8.6 | Интер | офейс $I^2C$ «ведомый» (I2C1)                               | 116 |
|     | 8.6.1 | Краткие характеристики                                      | 116 |
|     | 8.6.2 | Общее описание протокола приема-передачи                    | 117 |
|     | 8.6.3 | Генерация несущей частоты                                   | 118 |
|     | 8.6.4 | Алгоритм работы с интерфейсом                               | 118 |
|     |       | 8.6.4.1 Прием данных от «ведущего»                          | 118 |
|     |       | 8.6.4.2 Передача данных «ведущему»                          | 119 |
|     | 8.6.5 | Описание регистров                                          | 120 |
| 8.7 | Контр | роллер $I^2S(\mathrm{I2Sx})$                                | 122 |
|     | 8.7.1 | Краткие характеристики                                      | 122 |
|     | 8.7.2 | Общее описание шины $I^2S$                                  | 122 |
|     | 8.7.3 | Особенности текушей реализации $I^2S$                       | 123 |



|      | 8.7.4   | Описание регистров                                            | 124 |
|------|---------|---------------------------------------------------------------|-----|
| 8.8  | Тайме   | р общего назначения(GPTIMx)                                   | 126 |
|      | 8.8.1   | Краткие характеристики                                        | 126 |
|      | 8.8.2   | Алгоритм работы                                               | 126 |
|      | 8.8.3   | Описание регистров                                            | 128 |
| 8.9  | Контр   | оллер Ethernet(Ethernet0)                                     | 130 |
|      | 8.9.1   | Краткие характеристики                                        | 130 |
|      | 8.9.2   | Тактирование                                                  | 130 |
|      | 8.9.3   | КПДП передатчика                                              | 131 |
|      |         | 8.9.3.1 Установка дескриптора                                 | 131 |
|      |         | 8.9.3.2 Подготовка данных для передачи                        | 131 |
|      |         | 8.9.3.3 Передача данных                                       | 132 |
|      |         | 8.9.3.4 Работа с дескриптором после окончания передачи данных | 132 |
|      | 8.9.4   | КПДП приемника                                                | 132 |
|      |         | 8.9.4.1 Установка дескриптора                                 | 133 |
|      |         | 8.9.4.2 Прием данных                                          | 133 |
|      |         | 8.9.4.3 Работа с дескриптором после окончания приема данных . | 134 |
|      |         | 8.9.4.4 Ошибки приема на шине АНВ                             | 134 |
|      |         | 8.9.4.5 Допустимые МАС адреса                                 | 134 |
|      | 8.9.5   | MDIO интерфейс                                                | 135 |
|      |         | 8.9.5.1 Прерывания РНҮ                                        | 135 |
|      | 8.9.6   | Описание регистров                                            | 136 |
| 8.10 | Контр   | оллер USB(USBx)                                               | 139 |
|      | 8.10.1  | Краткие характеристики                                        | 139 |
|      | 8.10.2  | Обзор системы                                                 | 140 |
|      | 8.10.3  | РНҮ интерфейс                                                 | 141 |
|      | 8.10.4  | Speed Negotiation Engine(SNE)                                 | 141 |
|      | 8.10.5  | Serial Interface Engine(SIE)                                  | 141 |
|      | 8.10.6  | Буферы конечной точки                                         | 141 |
|      | 8.10.7  | AMBA Interface Engine(AIE)                                    | 142 |
|      | 8.10.8  | Синхронизация                                                 | 142 |
|      | 8.10.9  | Формирование сброса                                           | 142 |
|      | 8.10.10 | ПДП операции                                                  | 142 |
|      | 8.10.11 | Конечные точки типа OUT                                       | 143 |
|      | 8.10.12 | Конечные точки типа IN                                        | 145 |
|      | 8.10.13 | Конечные точки                                                | 146 |
|      | 8.10.14 | Управляющие конечные точки                                    | 146 |



|              |      | $8.10.15\Pi$ акетные конечные точки              | 146 |
|--------------|------|--------------------------------------------------|-----|
|              |      | 8.10.16 Конечные точки по прерываниям            | 146 |
|              |      | 8.10.17 Изохронные конечные точки                | 146 |
|              |      | 8.10.18 Описание регистров                       | 147 |
|              | 8.11 | Контроллер PWM(PWMx)                             | 151 |
|              |      | 8.11.1 Краткие характеристики                    | 151 |
|              |      | 8.11.2 Инициализация ШИМ                         | 151 |
|              |      | 8.11.3 Режимы работы ШИМ                         | 152 |
|              |      | 8.11.4 Прерывания ШИМ                            | 152 |
|              |      | 8.11.5 Длительность импульса ШИМ                 | 152 |
|              |      | 8.11.6 Описание регистров                        | 153 |
|              | 8.12 | Часы реального времени RTC                       | 155 |
|              | 8.13 | Аналого-цифровой преобразователь(ADCx)           | 156 |
|              |      | 8.13.1 Краткие характеристики                    | 156 |
|              |      | 8.13.2 Описание регистров                        | 158 |
|              | 8.14 | Цифро-аналоговый преобразователь(DACx)           | 160 |
|              |      | 8.14.1 Краткие характеристики                    | 160 |
|              |      | 8.14.2 Описание регистров                        | 161 |
| 9            | Наз  | начение выводов процессора                       | 162 |
|              | 9.1  | Назначение выводов процессора в корпусе QFP256   | 162 |
|              | 9.2  | Диаграмма выводов процессора в корпусе QFP256    | 168 |
| 10           | Эле  | ектрические параметры                            | 169 |
|              | 10.1 | Электрические характеристики портов ввода-вывода | 169 |
| 11           | Лис  | ст регистрации изменений                         | 171 |
| $\mathbf{A}$ | При  | иложение. Руководство по применению              |     |
|              | сло  | жно-функциональных блоков(СФБ) «GAISLER»         | 172 |



# 1 Условные обозначения и сокращения

## 1.1 Список сокращений

```
СФБ — сложно-функциональный блок;
M\Pi — микропроцессор;
\Pi O — программное обеспечение;
MSb — старший значащий бит;
MSB — старший значащий байт;
LSb — младший значащий бит;
LSB — младший значащий байт;
ОЗУ — оперативное запоминающее устройство;
\Pi Y — периферийное устройство;
\Pi\PiУ — центральное процессорное устройство;
ФБО — физический блок ОЗУ;
\Pi\Pi — память программ;
\Pi Д — память данных;
ФНЧ — фильтр нижних частот;
КДВП — контроллер доступа к внешней памяти;
\Pi \Pi \Pi — прямой доступ к памяти;
РОН — регистр(ы) общего назначения;
```

# 1.2 Принятые условные обозначения

'1', '0'— состояние логической единицы, логического нуля, соответственно;

REG(BIT) — такая запись используется для указания бита в регистре, где REG - название регистра, а BIT - обозначение бита или группы битов в нем. Например, "бит I2CxCR(EN)" означает, что идет указание на бит EN регистра I2CxCR, а



"I2CxPSC(PSC)" указывает на группу битов PSC. Что бы подробнее узнать об указанных регистрах и битах, надо смотреть описание этих регистров;

PUx, BLOCKx, PUxREG — В обозначении регистров, наименовании ПУ, блоков МП может использоваться символ "x". Это замещение номера, например, есть несколько идентичных периферийных блоков UART с номерами 0,1 и т.д. Для UART0 "x" - 0. Если есть регистр I2CxCR, то для блока I2C0, регистр будет именоваться I2C0CR.

www.multiclet.com UM HDL50002 Rev:101 09.07.2015 8-172



# 2 Описание

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

| Условное обозначение                                            | m MCp042R100102-LQ256              |
|-----------------------------------------------------------------|------------------------------------|
| Основное функциональное назначение                              | 64-разрядная микро-ЭВМ             |
| Максимальная тактовая частота ядра, МГц                         | 100                                |
| Мультиклеточное ядро                                            | 4 клетки 32/64 разряда             |
| Блок вычисления чисел с плавающей точкой(соответствует ieee754) | двойной точности                   |
| Производительность пиковая                                      | 24 MFLOPS/MΓц                      |
| Встроенная память СОЗУ, Кбайт                                   | 512                                |
| Внешняя шина памяти, бит                                        | 32                                 |
| Внешняя шина памяти, типы памяти                                | PROM, SRAM, SDRAM, IO              |
| USB 2.0 HS device, mt.                                          | 1                                  |
| UART, mt.                                                       | 4                                  |
| SPI, mt.                                                        | 2                                  |
| I2C                                                             | 1 ведущий, 1 ведомый               |
| I2S                                                             | 1 ведущий/ведомый (прием/передача) |
| PWM, каналов                                                    | 4                                  |
| Ethernet 10/100, mt.                                            | 1                                  |
| ЦАП, 12 бит, 125Msps, каналов                                   | 1                                  |
| АЦП, 16 бит, 48Ksps, каналов                                    | 8                                  |
| Пользовательские вводы-выводы, шт.                              | 159                                |



# 2.2 Структура МП



Рис. 1: Общая структура МП



## МП имеет следующие основные части:

- центральное процессорное устройство (ЦПУ);
- периферийные устройства. В качестве шины периферийных устройств используется шина AMBA 2.0;
- оперативные запоминающие устройства типа СОЗУ.



# 3 Центральное процессорное устройство



Рис. 2: Структурная схема ЦПУ

## ЦПУ в своем составе имеет:

- 4-х клеточное вычислительное ядро;
- коммутатор памяти;
- системные устройства;
- коммутатор системных регстров;
- аппаратную систему отладки ПО.

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



## 3.1 Организация вычислительного процесса

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

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

Первый – запись его командой-источником в общедоступные регистры и/или память, имя которых при использовании задают в поле операнда команды—приемника (фоннеймановская модель процессора). Как следствие, решение задачи подобным процессором достигается пошаговым целенаправленным изменением состояния вычислительной системы. Этот процесс изменения состояний диктуется исполнением последовательности команд строго в заданном порядке, который определяют в процессе программирования.

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

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



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

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

Промежуточное представление в виде триад образуется записями с тремя полями: <op><arg1><arg2>,

где: op – поле кода операции; arg1 – поле первого операнда; arg2 – поле второго операнда.

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

```
L1: a:=b+c;
    i:=a*f-g;
    a:=i/h;
    goto L2;
```

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

Номер триады op arg1 arg2 0 +b \* (0)1 f 2 (1) g 3 (2) h 4 (2)

:=

goto

(3)

a

L2

5

6

Таблица 1.

Имена – это указатели на таблицу символов, а числа в скобках – это указатели (ссылки) на триады.

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



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

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

Таблица 2.

| Номер триады | op               | arg1 | arg2 |
|--------------|------------------|------|------|
| 0            | rd               |      | b    |
| 1            | $_{ m rd}$       |      | С    |
| 2            | $_{\mathrm{rd}}$ |      | f    |
| 3            | $_{\mathrm{rd}}$ |      | g    |
| 4            | $_{\mathrm{rd}}$ |      | h    |
| 5            | +                | 5    | 4    |
| 6            | *                | 1    | 4    |
| 7            | -                | 1    | 4    |
| 8            | /                | 1    | 4    |
| 9            | :=               | 2    | 4    |
| 10           | :=               | 2    | i    |
| 11           | goto             | L2   | a    |

Последнюю команду параграфа отмечают управляющим признаком «конец параграфа». Максимальное значение ссылки (окно видимости результата исполненной команды) определяется размером ее поля в команде и равно 2\*p-1, где p – размер поля ссылки в битах.

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

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

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



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

В третьих, естественная реализация параллелизма предполагает использование нескольких процессорных устройств. Так как исполняемая команда не имеет информации о потребителях получаемых результатов, ее результаты должны рассылаться всем потенциальным потребителям, а команды-приемники должны отбирать требуемые им результаты из общего потока. Ядро мультиклеточного процессора, учитывающее эти особенности, состоит из совокупности идентичных процессорных блоков (клеток), объединённых однонаправленной полносвязной коммутационной средой (SB). Каждая клетка включает устройство управления (CU), буфер команд (BUF) и набор исполнительных устройств (EU). Обобщенная структура ядра мультиклеточного процессора приведена на рис.3.



Рис. 3: Обобщенная структура ядра мультиклеточного процессора

Процесс исполнения команды включает три этапа:

- 1. выборки командных слов;
- 2. отбор результатов;
- 3. исполнения команд.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 16-172



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

Начиная с первой команды очередного параграфа, устройства управления всех клеток группы мультиклеточного процессора, совместно исполняющей программу (task-группа), синхронно выбирают и декодируют группу последовательно размещенных команд выполняемого параграфа. При этом первая клетка группы выбирает первую команду последовательности, вторая — вторую и т.д. Если среди выбранных команд есть команда с признаком «конец параграфа», то последующие выбранные команды группы считаются невалидными и не декодируются.

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

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

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

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

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



## 3.2 Механизмы реализации

## 3.2.1 Идентификация команд

Известно, что любая команда выполняется за конечное число тактов и, если в качестве тега использовать некоторое число, то через определенное время это значение будет свободно и оно может быть присвоено очередной выбираемой команде. Очевидно также, что для того чтобы определить значение, которым идентифицируются запрашиваемые результаты необходимо чтобы значения тегов образовывали последовательность и присваивались в порядке размещения команд. А именно, тег очередной команды должен быть на единицу больше тега предыдущей команды. А их общее количество (Tmax) должно быть не менее окна видимости, чтобы обеспечить гарантированное отсутствие блокировки. Таким образом, тег i-ой команды при выборке ее i-ой клеткой может быть представлен как  $tag(i):=(tag(i-k)+k)mod\ Tmax$ , где: k – количество клеток в группе. Ограничение ширины окна выбранных команд требует запоминания состояния значения метки (занято, незанято) для того чтобы обеспечить возможность повторного использования значения тега. Механизмом, управляющим процессом назначения тегов и обеспечивающим приостановку процесса выборки при занятости значения служит память занятых тегов (BTM).

Сопоставим каждому значению тега бит, который равен единице, если это значение занято, и нулю, если оно свободно. Бит устанавливается в единицу при записи в буфер команды, которой назначено данное значение тега, и сбрасывается после её выполнения (передачи результата в коммутатор). Регистр, образованный Ттах +1 битами (от 0 до Ттах), каждый из которых соответствует одному значению тега, называется памятью занятых тегов. При этом, занятость конкретного і-го значения тега определяется содержимым ВТМ(i).

Управляется регистр указателем  $ifd\_tag$ , значение которого присваивается очередной выбранной команде в качестве тега. В исходном состоянии ВТМ обнулен. Значение указателя  $ifd\_tag$  указывает на начальное значение тега. В нулевой клетке группы оно будет равно нулю, во второй единице, в третьей двойке и т.д. Начиная очередной цикл выборки команд, клетка анализирует содержимое  $BTM(ifd\_tag)$ . Если оно равно '1', то выборка в этой и других клетках группы приостанавливается до тех пор, пока оно не станет равным нулю. Если оно равно '0' во всех клетках группы, то выбранной команде присваивается  $tag:=ifd\_tag$ , которое записывается вместе с ней в буфер. После записи команды в буфер значение BTM(tag) устанавливается в '1', значение  $ifd\_tag$  устанавливается равным  $(ifd\_tag+1)$  mod Tmax и клетка приступает к выбору следу-



ющей команды.

## 3.2.2 Организация буфера команд

Буфер команд – это массив из 1 строк, где

$$m < l < Tmax + 1$$

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

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

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

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

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

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

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



#### 3.2.3 Управление коммутационной средой

Каждое коммутационное устройство состоит из двух блоков памяти запросов и блока памяти результатов. Каждый блок памяти запросов представляет собой регистр размером Tmax+1 бит, в котором при запросе результата с тегом ј для использования операнда, в ј-том бите регистра записывают единицу («запрос установлен»), а после выдачи результата с этим тегом в ј-тый бит записывают ноль («запрос снят»). В первом блоке записываются запросы на получение первого операнда, во втором – второго. Запись запросов и последующее решение по выдаче операндов принимаются независимо, т.е. возможна одновременная выдача операндов в буфер команд с различными тегами. Память результатов состоит из Tmax +1 строк, каждая из которых содержит два поля: значения результата; признака готовности результата.

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

Строка коммутатора считается готовой выдать результат, если одновременно есть хотя бы один запрос на этот результат и готово его значение. Из всех строк, готовых к выдаче, выбирается строка с самым "старым"результатом и его значение вместе с тегом, равным номеру строки, выдаётся в буфер команд в качестве операнда. Одновременно сбрасывается признак запроса. Признак готовности и поле значения при этом не изменяются. Таким образом, учитывается, что результат может потребоваться командам, декодируемым позже. Сбрасывается признак готовности результата в і-той строке при назначении тега с этим значением новой команде. Необходимым условием этого является выполнение всех запросов на і-тый результат, т.е. і-тые строки первой и второй памяти запросов должны быть нулевые. Иначе процесс выборки и декодирования задерживается до выполнения всех запросов на і-тый результат.

## 3.3 Структура и организация клетки

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



клеточного микропроцессора см. на рис.2.

В состав клетки (см на рис.4) входят следующие устройства:

- 1. Устройство выборки команд IDU (Instruction Distribution Unit).
- 2. Устройство управления CU (Control Unit).
- 3. Коммутационное устройство SU (Switch Unit).
- 4. Буфер команд(BUF).
- 5. Целочисленное АЛУ.
- 6. АЛУ с плавающей точкой.
- 7. Блок доступа к памяти данных DMS (Data Memory Service).
- 8. Мультиплексор результатов МUХ.
- 9. Набор регистров GPR (General-Purpose Registers).
- 10. Контроллер прерываний IC (Interrupt Controller).
- 11. Отладочный блок JTAG-GPR.

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

#### 3.3.1 Устройство выборки команд

После сигнала сброса все клетки микропроцессора автоматически конфигурируются в единую task—группу и начинают выборку параграфа с начального адреса. При этом устройства выборки команд клеток группы согласованно читают фрагмент памяти программ, содержащий не менее k очередных команд, которые размещаются на регистрах команд клеток, а именно i — тая команда размещается на регистре команд i — той клетки. Размещение команды сопровождается формированием признака готовности команды к декодированию. Выборка команд конвейеризирована. Одновременно, если среди выбранных k команд не было отмеченных управляющим признаком «конец параграфа», в IDU клеток формируются и записываются новые значения регистров адреса, для согласованного чтения следующего фрагмента памяти программ.

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





Рис. 4: Структурная схема клетки

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

## 3.3.2 Устройство управления

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

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 22-172



хронно и изменяется циклически от 0 до Ттах.

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

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

Одновременно в клетке формируется и передаётся в устройство выборки команд сигнал готовности клетки к приёму следующей команды. Формирование сигнала приостанавливается, если хотя бы в одной клетке группы:

- 1. Значение тега занято;
- 2. Установлен режим контроля очередности чтения/записи, а декодируемая команда команда чтения и в буфере есть не выполненные команды чтения предыдущего параграфа;
- 3. Установлен режим контроля очередности чтения/записи, а декодируемая команда команда записи и в буфере есть не выполненные команды записи предыдущего параграфа;
- 4. В буфере команд есть свободное место.

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

- 1. Если выбранная команда чтение регистра.
- 2. Если для выбранной команды требуется только константа и/или значение регистра ( команды SET, GET, JMP или IRM).
- 3. Если выбранная команда чтение из памяти по известному адресу, содержащемуся в константе и/или регистре, и блок DMS не занят.

Также устройство управления может самостоятельно выполнять обращение к блоку



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

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

Изменение текущей конфигурации процессора возможно только после выполнения всех команд текущего параграфа. Для задания конфигурации, отличных от конфигурации по умолчанию, сначала устанавливается в «1» бит 7 (бит разрешения реконфигурации) и бит 8 (бит признака очистки буферов) регистра PSW. Далее мультиклеточный микропроцессор будет функционировать следующим образом:

- 1. Текущий параграф («параграф 1») продолжит выполняться со «старым» значением PSW.
- 2. Фактическое значение PSW обновится (т.е. установятся биты 7 и 8) только при переходе на следующий параграф («параграф 2»).
- 3. Внутри параграфа 2 программа должна установить новые значения регистров конфигурации процессора (ICR, PSW и NEWADDR).
- 4. Поскольку установлен бит 8 регистра PSW, выполнение параграфа 2 не завершится, пока не не будут выполнены все команды, находящиеся в буферах.
- 5. По завершении параграфа 2 регистры конфигурации принимают значения, заданные программой, и формируется новый набор task-групп.
- 6. Каждая task-группа, работая независимо, начинает выполнение программы со «своего» адреса, заданного ей через регистр NEWADDR.

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

#### 3.3.3 Буфер команд

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



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

- 1. Известны значения всех необходимых операндов.
- 2. Соответствующее исполнительное устройство готово к приёму команды.
- 3. В буферном устройстве нет более приоритетных (более «старых») команд, готовых к выполнению.

В буферном устройстве формируется и выдаётся устройству управления сигнал готовности буферного устройства к записи декодируемой команды, имеющий два состояния «да» и «нет», указывающие на его готовность, анализируются коды операций команд, находящихся в буферном устройстве, и формируют сигналы наличия команд чтения и записи, которые имеют два состояния «да» и «нет», указывающие на наличие или отсутствие соответствующих команд в буферном устройстве. Эти сигналы выдаются в мультиклеточный процессор, где одноименные сигналы, полученные от всех клеток объединяют схемами ИЛИ и формируют, соответственно, общие сигналы наличия команд чтения и записи. Очерёдность выполнения команд внутри параграфа подчиняется следующим правилам:

- 1. Если включён контроль очерёдности чтения/записи, выполнение команд записи не начнётся, пока не завершится выполнение всех команд чтения в текущем параграфе, а выполнение команд чтения не начнется, пока не будут выполнены все команды записи предыдущих параграфов.
- 2. При выполнении команд записи в регистры общего назначения, индексные и служебные регистры, записываемые значения помещаются в регистры только по окончании декодирования всех команд текущего параграфа, и перед выборкой команд следующего параграфа. Следует заметить, что адрес следующего параграфа также хранится в одном из служебных регистров (NEWADDR), с аналогичной логикой работы.
- 3. При выполнении команд записи в периферийные регистры, записываемые значения помещаются в регистры непосредственно в момент выполнения команды.
- 4. Во всех других случаях очерёдность выполнения команд определяется исключитель-



но готовностью значений аргументов команд, готовностью исполнительных устройств клетки и наличием других («более старых») готовых команд.

#### 3.3.4 Коммутационное устройство

Состав и функционирование коммутационного устройства изложены в разделах выше.

#### 3.3.5 Целочисленное АЛУ

Целочисленное АЛУ предназначено для выполнения команд над целочисленными операндами, при этом операнды могут быть представлены в следующих форматах (в зависимости от команды):

64-битные;

32-битные;

16-битные;

8-битные;

упакованные 32-битные;

упакованные 16-битные.

Структурно целочисленное АЛУ состоит из двух частей:

умножитель – конвейеризированный блок, предназначенный для выполнения команды умножения;

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

## 3.3.6 АЛУ с плавающей точкой

АЛУ с плавающей точкой предназначено для выполнения команд над операндами, представленными в формате чисел с плавающей запятой одинарной (32 бита) или двойной точности (64 бита) в соответствии с требованиями стандарта IEEE-754. Структурно АЛУ с плавающей точкой состоит из трёх частей:

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



- 2. делитель двойной точности блок, предназначенный для выполнения команд деления и извлечения квадратного корня над операндами, представленными в формате чисел с плавающей точкой двойной точности;
- 3. вычислитель FASM блок, предназначенный для выполнения остальных команд из набора команд над операндами, представленными в формате чисел с плавающей точкой одинарной или двойной точности.

АЛУ с плавающей точкой аппаратно оптимизирован для выполнения команд комплексного умножения операндов, представленных в формате чисел с плавающей точкой одинарной точности. Оптимизация достигается за счёт одновременного выполнения операций умножения и сложения, входящих в состав команды комплексного умножения.

Делители одинарной и двойной точности — неконвейеризированные, поэтому, АЛУ с плавающей точкой не может принять на выполнение следующую команду деления или извлечения квадратного корня, пока не будет выполнена предыдущая.

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

#### 3.3.7 Блок доступа к памяти данных

#### 3.3.8 Мультиплексор результатов

Обеспечивает приоритетную выдачу результатов в коммутационные устройства, если одновременно готовы результаты выполнения команд целочисленного АЛУ, АЛУ с плавающей точкой, DMS, либо результат получен непосредственно из устройства управления. По приоритету выдачи результата исполнительные устройства распределяются следующим образом:

- 1. Устройство управления;
- 2. АЛУ с плавающей точкой;
- 3. DMS;
- 4. Целочисленное АЛУ.

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



## 3.3.9 Набор регистров

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

В состав каждой клетки входит свой блок регистров (GPR), включающий:

- набор регистров общего назначения,
- набор индексных регистров,
- регистр управления микропроцессора PSW,
- регистр адреса возврата из прерываний IRETADDR,
- регистр принудительного запуска прерываний FORCE,
- регистр адреса обработчика прерываний IHOOKADDR,
- регистр модификации индексных регистров REGMOD,
- регистр адреса текущего параграфа CURRENTADDR,
- регистр адреса следующего параграфа NEWADDR,
- регистр предыдущего значения PSW LASTPSW,
- регистр конфигурации ICR.

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

#### 3.3.10 Контроллер прерываний и отладочный блок

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



## 3.4 Регистры

Все регистры, кроме системных, имеют ширину 64 бита. Чтение/запись регистров происходит с помощью специализированных команд.

РОН, индексные регистры и управляющие регистры имеют копии в каждой клетке. Эта особенность является необходимостью, т.к. при реконфигурации необходимо иметь набор регистров в каждой клетке. Системные регистры находятся в устройствах, таких как системный таймер, PLL и т.д. Это разделяемые ресурсы МП.



| №       | Название                          | Примечание                                                 |
|---------|-----------------------------------|------------------------------------------------------------|
|         | РОН, инде                         | ксные регистры (дублируются в каждой клетке)               |
| 0-7     | нет                               | регистры общего назначения (РОН)                           |
| 8-15    | нет                               | индексные регистры                                         |
|         | Системные регистры                | (существуют в одном экземпляре в системных устройствах)    |
| 16      | PLLCR                             | регистр управления генератором                             |
| 17      | PLLSTR                            | регистр состояния генератора                               |
| 18      | PLLTMCR                           | регистр управления модулем коммутации системы тактирования |
| 19      | SWCH0_CTRL                        | управления каналом памяти 0                                |
| 20      | SWCH1_CTRL                        | управления каналом памяти 1                                |
| 21      | SWCH2_CTRL                        | управления каналом памяти 2                                |
| 22      | SWCH3_CTRL                        | управления каналом памяти 3                                |
| 23      | ST0PRDR                           | период системного таймера 0                                |
| 24      | ST1PRDR                           | период системного таймера 1                                |
| 25      | ST2PRDR                           | период системного таймера 2                                |
| $^{26}$ | ST3PRDR                           | период системного таймера 3                                |
| 27      | ST0CR                             | регистр управления таймера 0                               |
| 28      | ST1CR                             | регистр управления таймера 1                               |
| $^{29}$ | ST2CR                             | регистр управления таймера 2                               |
| 30      | ST3CR                             | регистр управления таймера 3                               |
| 31      | зарезервировано                   |                                                            |
| 32      | ST0VAL                            | текущее значение таймера 0                                 |
| 33      | ST1VAL                            | текущее значение таймера 1                                 |
| 34      | ST2VAL                            | текущее значение таймера 2                                 |
| 35      | ST3VAL                            | текущее значение таймера 3                                 |
| 36-38   | зарезервировано                   |                                                            |
| 39      | DTC_STEP_INDX                     | регистр управления инкрементацией адресов DTC              |
| 40      | DTC_CTRL                          | регистр управления DTC                                     |
| 41      | DTC_ST                            | регистр состояния DTC                                      |
| 42      | $\mathrm{DTC}_{-}\mathrm{IMASK0}$ | регистр маски 0 DTC                                        |
| 43      | DTC_IMASK1                        | регистр маски 1 DTC                                        |
| 44      | DTC_DATA                          | регистр данных DTC                                         |
| 45      | DTC_S_ADDR                        | адрес источника                                            |
| 46      | DTC_D_ADDR                        | адрес приёмника                                            |
| 47      | ROM_CTRL                          | регистр управления и статуса внешнего ПЗУ                  |
|         | Управлян                          | ощие регистры (дублируются в каждой клетке)                |
| 48      | PSW                               | регистр управления процессором                             |
| 49      | INTR                              | регистр прерываний                                         |
| 50      | MSKR                              | регистр маски прерываний                                   |
| 51      | ER                                | регистр ошибок                                             |
| 52      | IRETADDR                          | регистр адреса возврата из прерываний                      |
| 53      | FORCE                             | регистр принудительного запуска прерываний                 |
| 54      | зарезервировано                   |                                                            |
| 55      | IHOOKADDR                         | адрес обработчика прерываний                               |
| 56      | INTNUM                            | регистр номера прерывания                                  |
| 57      | REGMOD                            | регистр модификации индексных регистров                    |
| 58      | зарезервировано                   |                                                            |
| 59      | CURRENTADDR                       | регистр адреса текущего параграфа                          |
| 60      | NEWADDR                           | регистр адреса следующего параграфа                        |
| 61      | LASTPSW                           | регистр предыдущего значения PSW                           |
| 62      | DFADDR                            | регистр аварийного перехода                                |
| 63      | ICR                               | регистр информационной связанности                         |

Таблица 4: Регистры процессора



## 3.5 Контроллер прерываний

Контроллер прерываний входит в состав каждой клетки. В МП контроллеры прерывания работают как один в выделенной группе клеток. В группе клеток контроллеры прерываний не могут быть разделены или сконфигурированы отдельно. Система прерываний МП допускает обработку 44 прерываний. Источник с номером «0» имеет наивысший приоритет при обработке прерываний.

## Структура прерываний

Прерывания можно условно разделить на две группы: системные прерывания и прерывания от периферии. Системные прерывания занимают адреса с 0 по 15 в контроллере прерываний и являются более приоритетными по сравнению с прерывания от периферии. Системные прерывания с номерами с 0 по 4 являются немаскируемыми. Прерывания от периферии занимают адреса с 16 по 63.

| 0  | II (DATA41)                                        |
|----|----------------------------------------------------|
| 0  | Немаскируемое внешнее прерывание (ENMI)            |
| 1  | зарезервировано                                    |
| 2  | Немаскируемое исключение в аппаратной части (PERE) |
| 3  | Немаскируемое программное исключение (PRGE)        |
| 4  | зарезервировано                                    |
| 5  | зарезервировано                                    |
| 6  | Маскируемое прерывание - внешний сигнал wake_up    |
| 7  | Маскируемое прерывание от контроллера транзакций   |
| 8  | Маскируемое прерывание от системного таймера (ST0) |
| 9  | Маскируемое прерывание от системного таймера (ST1) |
| 10 | Маскируемое прерывание от системного таймера (ST2) |
| 11 | Маскируемое прерывание от системного таймера (ST3) |
| 12 | Маскируемое программное прерывание (SW0)           |
| 13 | Маскируемое программное прерывание (SW1)           |
| 14 | Маскируемое программное прерывание (SW2)           |
| 15 | Маскируемое программное прерывание (SW3)           |
| 16 | Маскируемое прерывание от ADC0                     |
| 17 | Маскируемое прерывание от DAC0                     |
| 18 | Маскируемое прерывание от ADC1                     |
| 19 | Маскируемое прерывание от DAC1                     |
| 20 | Маскируемое прерывание от UART0                    |
| 21 | Маскируемое прерывание от UART1                    |
| 22 | Маскируемое прерывание от UART2                    |
| 23 | Маскируемое прерывание от UART3                    |
| 24 | Маскируемое прерывание от I2C0                     |
| 25 | Маскируемое прерывание от I2C1                     |
| 26 | Маскируемое прерывание от SP10                     |
| 27 | Маскируемое прерывание от SPI1                     |
| 28 | Маскируемое прерывание от I2S0                     |
| 29 | Mаскируемое прерывание от GPTIM0                   |
|    | ı                                                  |



| 30 | Mаскируемое прерывание от GPTIM1    |
|----|-------------------------------------|
| 31 | Mаскируемое прерывание от GPTIM2    |
| 32 | Mаскируемое прерывание от GPTIM3    |
| 33 | Маскируемое прерывание от WDT       |
| 34 | Маскируемое прерывание от RTC       |
| 35 | Mаскируемое прерывание от GPIOA     |
| 36 | Mаскируемое прерывание от GPIOB     |
| 37 | Mаскируемое прерывание от GPIOC     |
| 38 | Mаскируемое прерывание от GPIOD     |
| 39 | Mаскируемое прерывание от GPIOE     |
| 40 | Mаскируемое прерывание от GPIOF     |
| 41 | Mаскируемое прерывание от ETHERNET0 |
| 42 | Маскируемое прерывание от USB0      |
| 43 | Маскируемое прерывание от USB0_EPI  |
| 44 | Маскируемое прерывание от USB0_EPO  |
| 45 | Маскируемое прерывание от PWM0      |
| 46 | Маскируемое прерывание от STAT      |
|    |                                     |
| 63 |                                     |



## 3.5.1 Структура контроллера прерываний



Рис. 5: Блок-схема контроллера прерываний

Контроллер прерываний выполняет следующие функции:

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

Из клетки на контроллер прерываний приходят 4 сигнала об ошибках в ходе выполнения программы, по которым в обработчике исключений формируется сигнал PRGE:

- II выбрана несуществующая инструкция;
- OV возникло переполнение при попытке разделить на 0 в блоке операций с числами с плавающей запятой;
- ISQRT попытка взять корень из отрицательного числа в блоке операций с числами с плавающей запятой;
- FNAN в ходе операции с числами с плавающей запятой или на входе блока операций с числами с плавающей запятой возникло число = NAN.

С шины периферийных устройств на обработчик исключений поступают сигналы HRESP, состояние линий которых говорит об ошибках или их отсутствии при обращении по шине. При наличии ошибки формируется сигнал PERE.

Так же каждая клетка формирует сигнал int\_st - прерывание от системного таймера. и SWI - программно-формируемое прерывание. С шины периферийных устройств при-



ходят сигналы запроса прерывания от каждого периферийного устройства. С вводов/выводов МП приходят сигналы /enmi – внешнее немаскируемое прерывание и wake\_up - сигнал вывода МП из «спящего» режима внешней системой.

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

Для работы системы прерывания и функционирования программ обработки прерываний имеются следующие регистры:

| Регистр            | Доступ | Описание                                |
|--------------------|--------|-----------------------------------------|
| INTR               | RW     | Регистр прерываний                      |
| MSKR RW Регистр ма |        | Регистр маски прерываний                |
| FORCE              | W      | Регистр установки прерывания            |
| INTNUM             | R      | Регистр номера выработанного прерывания |
| ER                 | R      | Регистр ошибок                          |

Все регистры имеют разрядность 64 бита. Номера бит во всех регистрах кроме INTNUM и ER, которые имеет другую структуру, соответствуют номерам прерываний.

## Регистр INTR.

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

| INTR       | Регистр прерываний |      |  |
|------------|--------------------|------|--|
| Номер бита | 63 47              | 46 0 |  |
| Описание   | зарезервировано    | INTR |  |

 $63 \dots 47$  зарезервировано

46 ... 0 номер выработанного прерывания



## Регистр MSKR.

Регистр MSKR доступен как для чтения, так и для записи. Для разрешения прерываний с определенными номерами, необходимо выставить в 1 соответствующие биты данного регистра. Биты 0-3 являются немаскируемыми.

| MSKR       | Регистр маски прерываний |      |                 |
|------------|--------------------------|------|-----------------|
| Номер бита | 63 47                    | 46 4 | 30              |
| Описание   | зарезервировано          | MSKR | зарезервировано |

63 ... 47 зарезервировано

46 ...4 номер маскируемого прерывания

3 ...0 зарезервировано



#### Peructp FORCE.

Регистр FORCE доступен только для записи. Запись 1 в какие-либо биты данного регистра сформируют единичный импульс на вход регистра прерываний, что в свою очередь вызовет установку соответствующих бит в регистре INTR. На следующем такте после записи 1 в какие-либо биты данного регистра, все биты данного регистра будут сброшены в 0.

| FORCE      | Регистр устано  | вки прерываний |
|------------|-----------------|----------------|
| Номер бита | 63 47           | 46 0           |
| Описание   | зарезервировано | FORCE          |

63 ... 47 зарезервировано

46 ... 0 номер принудительного прерывания

#### Регистр INTNUM.

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

| INTNUM     | Регистр управл  | ения каналом коммутатора |
|------------|-----------------|--------------------------|
| Номер бита | 63 6            | 5 0                      |
| Описание   | зарезервировано | INTNUM                   |

63 ... 6 зарезервировано

5 ... 0 номер самого приоритетного прерывания на момент чтения регистра

#### Регистр ЕR.

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

| ER          | Регист | р управа | тень         | ія ка | нало | м комм  | утатора  |
|-------------|--------|----------|--------------|-------|------|---------|----------|
| Номер бита  | 63 7   | 6 5      | 4            | 3     | 2    | 1       | 0        |
| Описание    | _      | HRESP    | II           | OV    | _    | ISQRT   | FNAN     |
| 637         | _      | ě        | заре         | езерв | upc  | вано    |          |
| $6 \dots 5$ | HRE    | SP o     | оши          | бка   | прі  | и обраг | цении п  |
|             |        | 5        | вл           | тотс  | яп   | ризнак  | ом нали  |
| 4           | II     | I        | зыб          | рана  | не   | сущест  | вующая   |
| 3           | ov     | I        | 303E         | икл   | о п  | ереполн | ение пр  |
|             |        | I        | още          | ей за | гип  | гой     |          |
| 2           | _      | ě        | $ap\epsilon$ | гзерв | upc  | вано    |          |
| 1           | ISQI   | RT 1     | юп           | ытка  | в3.  | ять кор | ень из   |
|             |        | 3        | запя         | нтой  |      |         |          |
| 0           | FNA    | N i      | зхс          | де о  | пер  | ации с  | числам   |
|             |        | (        | спл          | аван  | още  | ей запя | гой возі |



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

В случае возникновения события, вызывающего запрос на обработку прерывания, оно фиксируется в регистре INTR. Регистр MSKR является фильтром, который допускает или нет сигналы из регистра INTR к дальнейшей обработке. После регистра MSKR сигналы попадают в схему определения приоритета, где происходит определение самого приоритетного прерывания в данном такте, его номер заносится в регистр INTNUM. На выходе контроллера прерывания сигнал int переходит в активное состояние. Клетка фиксирует активный уровень сигнала запроса обработки прерывания. Переход в обработчик прерывания происходит в конце параграфа, когда завершаются все записи в память и регистры, если таковые были в параграфе.

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

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

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



## 3.6 Системный таймер

Системный таймер предназначен для формирования заданных периодических или однократных временных интервалов. Таймер представляет собой инкрементирующий счетчик с делителем тактового сигнала на входе. Конечное значение счетчика записывается в регистр периода таймера, управление осуществляется через регистр STxCR, счет начинается с нуля. По истечении заданного временного интервала формируется запрос на обработку прерывания.



Рис. 6: Блок-схема системного таймера

На рис.6 изображена блок-схема таймера. Ниже приведены формулы для расчета частоты и периода интервалов, формируемых системным таймером. Значения PREDIV и CNTVAL задаются в регистрах STxCR и STxPRDR соответственно.

• период формируемого интервала:

$$T = T_{clk} \cdot (PREDIV + 1) \cdot (CNTVAL + 1);$$

• частота следования временных интервалов:

$$F = \frac{F_{clk}}{(PREDIV + 1) \cdot (CNTVAL + 1)};$$

#### 3.6.1 Режимы работы

• Однократное формирование временного интервала – таймер запускается пользователем (в бит STxCR(EN)='1'), а по достижении счетчиком таймера значения,

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 38-172



заданного в регистре периода таймера, таймером выдается запрос на обработку прерывания, после этого бит STxCR(EN) устанавливается в '0', и таймер останавливается до следующей записи значения '1' в STxCR(EN);

• Периодическая генерация временных интервалов – таймер запускается и останавливается пользователем (в бит STxCR(EN) записывается соответствующее значение). По достижении счетчиком таймера значения, заданного в регистре периода таймера, таймером выдается запрос обработки прерывания, счетчик перезагружается значением '0', и работа таймера продолжается до того, как пользователь запишет значение '0'в бит STxCR(EN).

При записи в регистр STxPRDR новое значение периода будет установлено и счетчик начнет считать с нуля. При записи в STxCR(PREDIV) новое значение предделителя будет загружено и счетчик начнет считать с нуля. Настоятельно рекомендуется перед изменением режима работы таймера сначала остановить его, записав STxCR(EN)='0', потом задать новые значения в регистре STxCR. Режим работы системного таймера устанавливается в STxCR(MD). Доступно 4 системных таймера: ST0, ST1, ST2, ST3.

| STxPRDR             | Пе | риод                                                                                 | цси | стем | ног | таі | імер | a |  |  |  |  |  |   |      |    |  |  |  |  |  |  |  |  |  |
|---------------------|----|--------------------------------------------------------------------------------------|-----|------|-----|-----|------|---|--|--|--|--|--|---|------|----|--|--|--|--|--|--|--|--|--|
| Номер бита          | 31 | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 1 0 |     |      |     |     |      |   |  |  |  |  |  |   |      |    |  |  |  |  |  |  |  |  |  |
| Начальное состояние |    | _                                                                                    |     |      |     |     |      |   |  |  |  |  |  |   |      |    |  |  |  |  |  |  |  |  |  |
| Описание            |    |                                                                                      |     |      |     |     |      |   |  |  |  |  |  | I | PERI | OD |  |  |  |  |  |  |  |  |  |

0-31 PERIOD Период системного таймера

| STxCR               | Pe | гист    | руп                                                                                | рав | лени | ясь | істе: | мноі | о та | йме | ра |      |     |  |  |  |   |  |  |  |  |   |   |  |    |    |
|---------------------|----|---------|------------------------------------------------------------------------------------|-----|------|-----|-------|------|------|-----|----|------|-----|--|--|--|---|--|--|--|--|---|---|--|----|----|
| Номер бита          | 31 | 30      | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |     |      |     |       |      |      |     |    |      |     |  |  |  |   |  |  |  |  |   |   |  |    |    |
| Начальное состояние |    | 0 - 0 0 |                                                                                    |     |      |     |       |      |      |     |    |      |     |  |  |  | 0 |  |  |  |  |   |   |  |    |    |
| Описание            |    |         |                                                                                    |     |      |     |       |      |      |     | I  | PREI | OIV |  |  |  |   |  |  |  |  | _ | _ |  | MD | EN |

| 0    | EN     | Разрещение работы системного таймера ('0'- запрещено, '1'- разрешено) |
|------|--------|-----------------------------------------------------------------------|
| 1    | MD     | Выбор режима работы таймера ('0'- однократный, '1'- многократный)     |
| 2-7  | _      | зарезервировано                                                       |
| 8-31 | PREDIV | Предделитель системного таймера                                       |

| STxVAL              | Te | кущ | ее зі | наче | ние | сист | емн | ого | тайг | иера | ì  |    |    |    |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |  |
|---------------------|----|-----|-------|------|-----|------|-----|-----|------|------|----|----|----|----|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|--|
| Номер бита          | 31 | 30  | 29    | 28   | 27  | 26   | 25  | 24  | 23   | 22   | 21 | 20 | 19 | 18 | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | L C |  |
| Начальное состояние |    |     |       |      |     |      |     |     |      |      |    |    |    |    | 0    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |  |
| Описание            |    |     |       |      |     |      |     |     |      |      |    |    |    |    | VALU | JΕ |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |  |

0-31 VALUE Текущее значение системного таймера

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 39 - 172



# 4 Средства динамической реконфигурации

Код для мультиклеточного ядра не зависит от количества клеток, которыми он будет исполняться, вычислительные ресурсы мультиклеточного ядра можно распределять во время работы, управление происходит программно. Способность мультиклеточной архитектуры перераспределять свои ресурсы называется — динамической реконфигурацией. Например, клетки мультиклеточного ядра могут быть, как угодно распределены для выполнения какого-либо алгоритма или его части. Группа - это часть клеток мультиклеточного ядра, которые связаны между собой для выполнения какого-либо или части алгоритма независимо от других клеток. В группе может находиться 1 и более клеток. Когда мультиклеточное ядро разделяет группу на части - это называется декомпозиция. Процесс объединения в группу - композиция. На рис. 7 показано как 4-х клеточное ядро со временем реконфигурируется (пример). Клетки, выполняющие одну задачу, имеют одно цветовое заполнение.



Рис. 7: Распределение вычислительных ресурсов

Архитектура мультиклеточного процессора не налагает каких-либо ограничений на ко-



личество групп и количество клеток в группе. Все клетки могут быть объединены в одну группу. Может быть сформировано n групп, в каждой будет по одной клетке. Конкретное распределение клеток по группам определяется программистом и может неоднократно программно меняться в процессе вычислений.

Для управления динамической реконфигурацией используются: регистр перехода (NEWADDR) и регистр информационной связанности (ICR).

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

| NEWADDR    | Регистр перехо  | да  |      |      |      |          |
|------------|-----------------|-----|------|------|------|----------|
| Номер бита | 63 36           | 35  | 34   | 33   | 32   | 31 0     |
| Описание   | зарезервировано | C0  | C1   | C2   | С3   | NEWADE   |
| 63 36      |                 | aan | 0000 | care | 0000 |          |
|            | <del></del>     | _   | -    | eup  |      |          |
| 35         | C0              | кле | тка  | для  | кот  | орой пр  |
| 34         | C1              | кле | тка  | для  | кот  | орой пр  |
| 33         | C2              | кле | тка  | для  | кот  | орой пре |
| 32         | C3              | кле | тка  | для  | кот  | орой пре |
| 310        | NEWADDR         | адр | ес п | eper | сода |          |

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

| ICR          | Регистр инфор   | мацион  | ной свя | занност | и      |                 |          |          |        |       |
|--------------|-----------------|---------|---------|---------|--------|-----------------|----------|----------|--------|-------|
| Номер бита   | 63 36           | 35      | 34      | 33      | 32     | 31 4            | 3        | 2        | 1      | 0     |
| Описание     | зарезервировано | C0_G    | C1_G    | $C2\_G$ | C3_G   | зарезервировано | C0_EN    | C1_EN    | C2_EN  | C3_EN |
| 6336         | _               | зарезер | виров   | ано     |        |                 |          |          |        |       |
| 35           | $C0_G$          | клетка  | войде   | т в сос | тав гр | уппы ('1' - вой | ідет в с | остав)   |        |       |
| 34           | $C1\_G$         | клетка  | войде   | т в сос | тав гр | уппы ('1' - вой | ідет в с | остав)   |        |       |
| 33           | $C2\_G$         | клетка  | войде   | т в сос | тав гр | уппы ('1' - вой | ідет в с | остав)   |        |       |
| 32           | $C3\_G$         | клетка  | войде   | т в сос | тав гр | уппы ('1' - вой | ідет в с | остав)   |        |       |
| $31 \dots 4$ | _               | зарезер | виров   | ано     |        |                 |          |          |        |       |
| 3            | ${ m C0\_EN}$   | разреш  | ение р  | аботы   | клетк  | и в составе гр  | уппы('1  | ' - разр | ешено) |       |
| 2            | $C1\_EN$        | разреш  | ение р  | аботы   | клетк  | и в составе гр  | уппы('1  | ' - разр | ешено) |       |
| 1            | $C2\_EN$        | разреш  | ение р  | аботы   | клетк  | и в составе гр  | уппы('1  | ' - разр | ешено) |       |
| 0            | $C3$ _ $EN$     | разреш  | ение р  | аботы   | клетк  | и в составе гр  | уппы('1  | ' - разр | ешено) |       |

Если i и j клетки после динамической реконфигурации будут входить в одну группу, то  $ICR(Ci\_G) = ICR(Cj\_G) = '1'$ , где x номер условной группы. Если они в разных группах, то  $ICR(Ci\_G) = ICR(Cj\_G) = '0'$ . ICR позволяет каждой клетке выбрать из всей совокупности управляющих сигналов и результатов команд мультиклеточного процессора только те, которые относятся к ее группе. В исходном состоянии все клетки образуют одну группу и, следовательно, ICR во всех битах содержит '1'. Новое содержимое ICR формируется только программно при динамической реконфигурации мультиклеточного процессора. При этом, для обеспечения корректной работы необходимо,



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

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

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 42-172$ 



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

Память для МП с программной точки зрения представляет собой массив с байтовой адресацией, диапазон адресов:  $[0, 2^{32}]$ . Память не разделена на страницы и доступна вся сразу. Так же нет разделения на ПП(память программ) и ПД(память данных), но есть ограничения по размещению данных и программ, которые описаны ниже.

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

На рис.8 приведена карта памяти М $\Pi$ . На карте памяти можно выделить несколько зон:

- память на кристалле МП;
- внешнее ОЗУ;
- внешнее ПЗУ;
- область устройств ввода/вывода;
- область отображения адресов 0х00000000-0х40000000;
- шина периферийных устройств.

#### Память на кристалле МП.

Представляет собой СОЗУ.

Номер блока можно вычислить по следующей формуле:

$$n = \left\lceil \frac{A_b}{2^{16}} \right\rceil + \left\lceil \frac{A_b \mod 32}{8} \right\rceil, \ A_b = [0, 2^{18} - 1]$$





Рис. 8: Карта памяти

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

В диапазоне 0x00040000-0x00080000 память разбита на одинаковые по объему 4 региона. Но физически представляет собой 16 блоков  $64 \times 2^{11}$ , которые позволяют иметь одновременный доступ к данным, расположенным в соседних блоках. Не рекомендуется



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

Номер блока можно вычислить по следующей формуле:

$$n = \left\lceil \frac{A_b}{2^{16}} \right\rceil + \left\lceil \frac{A_b \mod 32}{4} \right\rceil, \ A_b = [2^{18}, 2^{19} - 1]$$

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

#### Внешнее ОЗУ, внешнее ПЗУ, область устройств ввода/вывода

Для доступа к данным зонам используется специализированная шина внешней памяти. Описание интерфейса приведено в главе о периферийных устройствах (п.8). Возможно выполнять, хранить данные в данных зонах. Но следует учитывать, что это существенно снизит производительность МП, т.к. 4 клетки за один такт могут запрашивать в памяти до 32 байт информации, максимальная ширина шины внешней памяти - 32 бита (4 байта), скорость работы зависит от внешних компонентов и тактовой частоты МП.

#### Область отображения адресов

Данная зона используется контроллером ПДП на периферийной шине. ЦПУ так же может обратиться по адресам в этой зоне. Описание контроллера приведено в главе о периферийных устройствах (п.??). Контроллер является «ведомым» устройством на периферийной шине.

#### Шина периферийных устройств

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 45-172



# 5.2 Коммутатор



Рис. 9: Структура коммутатора

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 46-172



Номер канала коммутатора, который обслуживает адрес, можно найти по следующей формуле:

$$n = \left\lceil \frac{A_b \mod 32}{4} \right\rceil$$

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

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

| №  | Название клиентского канала               | Примечание                                          |
|----|-------------------------------------------|-----------------------------------------------------|
| 0  | $\mathrm{C0}_{-}\mathrm{I}_{-}\mathrm{0}$ | Каналы запроса инструкций клетками.                 |
| 1  | C0_I_1                                    | Каждый канал запрашивает 32 бита инструкции.        |
| 2  | C1_I_0                                    |                                                     |
| 3  | C1_I_1                                    |                                                     |
| 4  | C2_I_0                                    |                                                     |
| 5  | C2_I_1                                    |                                                     |
| 6  | C3_I_0                                    |                                                     |
| 7  | C3_I_1                                    |                                                     |
| 8  | $C0_D$                                    | Каналы запроса данных клетками                      |
| 9  | C1_D                                      |                                                     |
| 10 | $\mathrm{C2}_{-}\mathrm{D}$               |                                                     |
| 11 | C3_D                                      |                                                     |
| 12 | DTC_INDEX                                 | Канал запроса от контроллера транзакций             |
| 13 | AMBA_DMA_INDEX                            | Канал запроса от DMA канала периферийной шины       |
| 14 | JTAG_MEM_INDEX                            | Канал запроса от аппаратной системы отладки по JTAG |

Таблица 5: Клиентские каналы коммутатора

| №  | Название порта памяти | Примечание                                                   |
|----|-----------------------|--------------------------------------------------------------|
| 0  | R0_0                  | Порты блоков памяти регионов 0-3.                            |
| 1  | R0_1                  | 32-х битные блоки памяти.                                    |
| 2  | R1_0                  |                                                              |
| 3  | R1_1                  |                                                              |
| 4  | R2_0                  |                                                              |
| 5  | R2_1                  |                                                              |
| 6  | R3_0                  |                                                              |
| 7  | R3_1                  |                                                              |
| 8  | R4                    | Порты блоков памяти регионов 4-7                             |
| 9  | R5                    | 64-х битные блоки памяти.                                    |
| 10 | R6                    |                                                              |
| 11 | R7                    |                                                              |
| 12 | AMBA                  | Порт шины AMBA, обслуживающей адресное пространство после R7 |

Таблица 6: Порты памяти каналов коммутатора

Коммутатор в каждом канале имеет аппарат определения приоритетов. Клиентские каналы разделены на 4 типа:

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 47-172



- каналы инструкций;
- каналы данных;
- канал АМВА;
- канал DTC.

Каждому порту памяти в канале коммутатора устанавливается приоритет по типу канала. Внутри каналов инструкций и данных приоритет фиксированный и зависит от номера клетки осуществляющей запрос. Настройка приоритета осуществляется системным регистром SWCHx\_CTRL (где х-номер канала коммутатора). Также при определении приоритетного канала учитывается время, когда запрос поступил. Т.е. один клиентский канал не может постоянно удерживать канал коммутатора. Если такому каналу запрашивается массив данных, то при возникновении запроса от каналов с меньшим приоритетом, он будет разрывать длинный запрос от канала с наибольшим приоритетом. Например, если порядок запроса с одного и того же адреса клиентскими каналами был следующим (в скобках запросы, возникшие в одно время): 0; (3, 2); 1; 3; 3 и при этом запрос от канала 0 длится достаточно долго, что успевают прийти все запросы от менее приоритетных каналов, в последовательности, указанной выше, то порядок обслуживания будет следующим: 0, 2, 0, 1, 0, 3, 0, 3, 0, 3, 0 . . . .

| SWCHx_CTRL    | *     |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
|---------------|-------|------------------------------------------------------------------------------------------------------|----------|---------|----------|-------------|----------|-------|------|------|------|------|------|--|--|--|
| Номер бита    | 25 24 | 23 22                                                                                                | 21 20    | 1918    | 17 16    | 15 14       | 13 12    | 11 10 | 9 8  | 7 6  | 5 4  | 3 2  | 1 0  |  |  |  |
| Описание      | AMBA  | R7                                                                                                   | R6       | R5      | R4       | R3_1        | R3_0     | R2_1  | R2_0 | R1_1 | R1_0 | R0_1 | R0_0 |  |  |  |
| 25 24         | AMBA  | Для вс                                                                                               | ех полей | i:      |          |             |          |       |      |      |      |      |      |  |  |  |
| $23 \dots 22$ | R7    | 11 - пр                                                                                              | иоритет  | канала  | AMBA     | $(N_{2}13)$ |          |       |      |      |      |      |      |  |  |  |
| 21 20         | R6    | 10 - приоритет канала DTC (№12)<br>01 - приоритет каналов запроса данных (№№ 811)                    |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 1918          | R5    | 01 - пр                                                                                              | иоритет  | каналог | з запрос | а данны     | x (№ № 8 | 811)  |      |      |      |      |      |  |  |  |
| 1716          | R4    | 00 - приоритет каналов запроса данных (лем втг)<br>00 - приоритет каналов запроса инструкций (№№ 0т) |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 15 14         | R3 1  | 00 - приоритет каналов запроса инструкций (№№ 07)                                                    |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 1312          | R3_0  |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 11 10         | R2 1  |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 98            | R2_0  |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 76            | R1_1  |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 54            | R1 0  |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 32            | R0_1  |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |
| 10            | R0 0  |                                                                                                      |          |         |          |             |          |       |      |      |      |      |      |  |  |  |



# 5.3 Контроллер транзакций данных (DTC)

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

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

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

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

| DTC_CTRL      | Регистр | управл | ения         |           |            |          |          |
|---------------|---------|--------|--------------|-----------|------------|----------|----------|
| Номер бита    | 31      | 30 27  | 26           | 25 24     | 23 12      | 112      | 10       |
| Описание      | START   | MSK    | REG          | MODE      | NUMBLK     | NUMEL    | ELSIZE   |
| 31            | START   | Ус     | станов       | вка этого | о бита в 1 | запуск   | ает DTC  |
| $30 \dots 27$ | MSK     | M      | аска б       | битов ре  | гистра со  | стояния  | , генери |
|               |         | C      | ответ        | ствует (  | битам ТС   | , TBC,   | ТЕС и 1  |
| 26            | REG     | П      | ри уст       | ановке    | в 1 указы  | вает, чт | о даннь  |
|               |         | П      | осле о       | бработк   | и очеред:  | ного эле | мента т  |
| 2524          | MODE    | Ре     | жим          | работы:   |            |          |          |
|               |         | 00     | — пр         | ограммі   | ный запу   | ск транз | акции;   |
|               |         | 01     | — за         | пуск по   | прерываі   | нию и пр | оиостан  |
|               |         | 10     | — за         | пуск по   | прерываі   | нию и пр | оиостан  |
|               |         | 11     | — за         | пуск по   | прерываі   | нию и пр | риостан  |
| 2312          | NUMBI   | LK 4:  | исло б       | блоков в  | транзакі   | ции      |          |
| 112           | NUMEI   | L Y    | исло з       | лементо   | в в блоке  | е        |          |
| 10            | ELSIZE  | Pa     | азмер        | элемент   | a:         |          |          |
|               |         | 00     | - 1 6        | байт;     |            |          |          |
|               |         | 01     | <b>—</b> 2 ( | байта;    |            |          |          |
|               |         | 10     | - 4          | байта     |            |          |          |



# Peructp состояния $DTC\_ST$

При записи в регистр состояния биты, в которые записывается 1, сбрасываются в 0. Сброс бита TIP приводит к принудительному завершению транзакции и переустановке всех внутренних счётчиков.

При записи в регистр состояния биты, в которые записывается 1, сбрасываются в 0. Если биты MODE регистра управления установлены в значение, отличное от "00 запись 1 в бит TIP регистра статуса приводит к прерыванию транзакции. В случае работы DTC в режиме программного запуска (MODE=00) прерывание транзакции не предусмотрено.

| $_{ m DTC\_ST}$ | Регистр состояния                             |                                |     |                                                                      |       |                 |       |     |  |
|-----------------|-----------------------------------------------|--------------------------------|-----|----------------------------------------------------------------------|-------|-----------------|-------|-----|--|
| Номер бита      | 31                                            | 30                             | 29  | 28                                                                   | 27    | 26 16           | 15 10 | 9 0 |  |
| Описание        | TIP                                           | TC                             | TBC | TEC                                                                  | EMERR | зарезервировано | NBLK  | NEL |  |
|                 |                                               |                                |     |                                                                      |       |                 |       |     |  |
| 31              | Т                                             | TIР идёт выполнение транзакции |     |                                                                      |       |                 |       |     |  |
| 30              | Т                                             | $^{\rm C}$                     |     | транзакция завершена                                                 |       |                 |       |     |  |
| 29              | Т                                             | $_{\mathrm{BC}}$               |     | передача очередного блока завершена                                  |       |                 |       |     |  |
| 28              | Т                                             | EC                             |     | передача очередного элемента завершена                               |       |                 |       |     |  |
| 27              | E                                             | MEF                            | RR  | при выполнении транзакции обнаружена ошибка доступа к внешней памяти |       |                 |       |     |  |
| $15 \dots 10$   | N                                             | BLK                            |     | число переданных блоков                                              |       |                 |       |     |  |
| 90              | NEL число переданных элементов текущего блока |                                |     |                                                                      |       |                 |       | юка |  |

## Регистр маски прерываний DTC IMASK

Регистр DTC\_IMASK состоит из двух регистров, DTC\_IMASK0 и DTC\_IMASK1, и доступен как для чтения, так и для записи. Для разрешения работы DTC по прерываниям с определенными номерами, необходимо выставить в 1 биты данного регистра, номера которых соответствуют номерам прерываний. При этом биты 63 ...32 содержатся в IMASK1, а биты 31 ...0 — в IMASK0.

| DTC_IMASK0 | Регистр маски прерываний | DTC_IMASK1 | Регистр маски прерываний |
|------------|--------------------------|------------|--------------------------|
| Номер бита | 31 0                     | Номер бита | 31 0                     |
| Описание   | IMASK0                   | Описание   | IM ASK1                  |

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 50 - 172



# Perucтр данных DTC\_DATA

| DTC_DATA   | Регистр данных |
|------------|----------------|
| Номер бита | 31 0           |
| Описание   | DATA           |

В данном регистре размещается очередной считанный элемент. Если установлен бит REG регистра DTC\_CTRL, после чтения очередного элемента и помещения его в DTC\_DATA, устанавливается бит TEC в регистре состояния и транзакция приостанавливается. Для продолжения работы DTC необходимо сбросить этот бит.

# ${\tt Peructph}$ DTC S ADDR и DTC D ADDR

| DTC_S_ADDR | Регистр адреса источника |  |  |  |  |
|------------|--------------------------|--|--|--|--|
| Номер бита | 31 0                     |  |  |  |  |
| Описание   | DTC_S_ADDR               |  |  |  |  |

| DTC_D_ADDR | Регистр адреса приёмника |  |  |  |  |
|------------|--------------------------|--|--|--|--|
| Номер бита | 310                      |  |  |  |  |
| Описание   | DTC_D_ADDR               |  |  |  |  |

# Регистр шага адресов DTC STEP

| DTC_STEP   | Регистр шага адресов |          |          |  |  |  |  |  |
|------------|----------------------|----------|----------|--|--|--|--|--|
| Номер бита | 31 20                | 1910     | 9 0      |  |  |  |  |  |
| Описание   | зарезервировано      | STEP_DST | STEP_SRC |  |  |  |  |  |

19 ...10 STEP\_DST приращение адреса начала блока приемника 9 ...0 STEP\_SRC приращение адреса начала блока источника



# 6 Система тактирования

В составе МП имеется генератор для формирования системного сигнала тактирования. Генератор формирует стабильный тактовый сигнал в диапазоне частот от 20МГц до 300МГц. Синтезатор основан на схеме ФАПЧ с целочисленными коэффициентами деления синтезируемой частоты. Частота опорного сигнала от 8 до 15 МГц.

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



Рис. 10: Система тактирования

На рис.10 приведена блок-схема системы тактирования МП. В МП существует 2 частотных домена: домен системной частоты  $F_{sys}$  который тактирует все системы МП и домен альтернативной тактовой частоты для счетчиков часов реального времени (ЧРВ).

#### 6.0.1 Описание работы системы тактирования

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 52 - 172



Частота  $F_{sys}$  рассчитывается по следующей формуле:

$$F_{out} = F_{ref} \cdot N \cdot \frac{1}{R} \cdot \frac{1}{K}$$

- R = 1, 2, 4, 8 коэффициент деления опорной частоты (определяется битами PLLCR(RCNT));
- N = [2, 131] коэффициент деления внутреннего генератора (определяется битами PLLCR(NCNT));
- K = 1, 2, 4, 8, 16 коэффициент деления выходного делителя (определяется битами PLLCR(MXVCO)).

При этом частота сравнения (на входе фазо-частотного детектора):

$$F_{cmp} = \frac{1}{R} \cdot F_{ref}$$

Частота внутреннего генератора, управляемого напряжением (ГУН):

$$F_{vco} = N \cdot \frac{1}{R} \cdot F_{ref}$$

Выходная частота:

$$F_{out} = \frac{1}{K} \cdot F_{vco}$$

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

$$1MHz < F_{cmp} < 16MHz$$

$$20MHz < F_{vco} < 340MHz$$

#### Пример расчета.

 $F_{ref}=15MHz$  и требуется выходная частота около 130MHz. Задаем R=1. Далее выбираем K=2, тогда ГУН будет работать на частоте около  $2\cdot 130MHz=260MHz$ . Определяем N:  $\frac{260}{15MHz}=17,33$ . Тогда получаем:

- при  $R=1, K=2, N=17, F_{out}=\frac{17\cdot15MHz}{2}=127, 5MHz.$  В этом случае PLLCR(RCNT)=000b, PLLCR(MXVCO)=1100b, PLLCR(RCNT)=0x0D.
- при  $R=1, K=2, N=18, F_{out}=\frac{18\cdot15MHz}{2}=135MHz.$ В этом случае PLLCR(RCNT)=000b, PLLCR(MXVCO)=1100b, PLLCR(RCNT)=0x0E.

#### 6.0.2 Описание работы модуля коммутации



#### 6.0.3 Таблицы выбора коэффициентов R, N, K

| Коэффициент R | Биты управления делителем опорной частоты |         |         |            |  |  |  |  |
|---------------|-------------------------------------------|---------|---------|------------|--|--|--|--|
|               | rent(2)                                   | rent(1) | rent(0) | Значение R |  |  |  |  |
|               | 0                                         | X       | X       | 1          |  |  |  |  |
|               | 1                                         | 0       | 0       | 2          |  |  |  |  |
|               | 1                                         | 0       | 1       | 4          |  |  |  |  |
|               | 1                                         | 1       | 0       | 8          |  |  |  |  |
|               | 1                                         | 1       | 1       | 16         |  |  |  |  |

| Коэффициент N | Биты управления делителя в петле обратной связи |         |         |         |         |         |         |            |
|---------------|-------------------------------------------------|---------|---------|---------|---------|---------|---------|------------|
|               | nent(6)                                         | nent(5) | nent(4) | nent(3) | ncnt(2) | nent(1) | nent(0) | Значение N |
|               | 0                                               | 0       | 0       | 0       | 0       | 0       | 0       | 2          |
|               | 0                                               | 0       | 0       | 0       | 0       | 0       | 1       | 3          |
|               | 0                                               | 0       | 0       | 0       | 0       | 1       | 0       | 6          |
|               | 0                                               | 0       | 0       | 0       | 0       | 1       | 1       | 7          |
|               | 0                                               | 0       | 0       | 0       | 1       | 0       | 0       | 8          |
|               |                                                 |         |         |         |         |         |         |            |
|               | 1                                               | 1       | 1       | 1       | 1       | 1       | 0       | 130        |
|               | 1                                               | 1       | 1       | 1       | 1       | 1       | 1       | 131        |

На основании данной таблицы можно составить формулу:

При ncnt(0 ... 6) = 0 следует, что N = 2

При  $\mathrm{ncnt}(0 \dots 6) = 1$  следует, что  $\mathrm{N} = 3$ 

При  $\mathrm{ncnt}(0 \dots 6) = 2 \dots 127$  следует, что  $\mathrm{N} = \mathrm{ncnt}(0 \dots 6) + 4$ 

| Коэффициент К | Биты управления мультиплексором выходного сигнал |          |          |          |            |  |  |  |
|---------------|--------------------------------------------------|----------|----------|----------|------------|--|--|--|
|               | mxvco(3)                                         | mxvco(2) | mxvco(1) | mxvco(0) | Значение К |  |  |  |
|               | 0                                                | X        | X        | X        | Fref       |  |  |  |
|               | 1                                                | 0        | X        | X        | 1          |  |  |  |
|               | 1                                                | 1        | 0        | 0        | 2          |  |  |  |
|               | 1                                                | 1        | 0        | 1        | 4          |  |  |  |
|               | 1                                                | 1        | 1        | 0        | 8          |  |  |  |
|               | 1                                                | 1        | 1        | 1        | 16         |  |  |  |

#### 6.0.4 Порядок работы с блоком PLL

#### Включение после сброса или подачи питания

- 1) Установить биты PLLCR(NCNT) и PLLCR(RCNT) в нужное значение
- 2) Установить бит PLLCR(EN) в '1'
- 3) Дождаться установки бита PLLSTR(LOCK) в '1'
- 4) Переключиться на нужную частоту установкой битов PLLCR(MXVCO)

#### Смена частоты

- 1) Установить третий бит MXVCO, т.е. PLLCR[11] в '0', чтобы переключиться на Fref
- 2) Изменить биты PLLCR(NCNT) и PLLCR(RCNT)
- 3) Установить третий бит MXVCO, т.е. PLLCR[11] в '1', чтобы переключиться на новую частоту

#### Выключение блока

- 1) Установить третий бит MXVCO, т.е. PLLCR[11] в '0', чтобы переключиться на Fref
- 2) Дождаться установки бита PLLSTR(REFACTIVE) в '1'

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 54 - 172



3) Установить бит PLLCR(EN) в '0'



# 6.0.5 Регистры системы тактирования

| PLLCR      | Регистр управления генератора |         |            |       |        |       |         |    |       |       |      |
|------------|-------------------------------|---------|------------|-------|--------|-------|---------|----|-------|-------|------|
| Номер бита | 31 24                         | 23      | 22         | 21    | 20     | 1918  | 17 16   | 15 | 14 12 | 11 8  | 6 0  |
| Описание   | _                             | LOCK_LS | LOCK_RANGE | PDDLY | IRMODE | CPCTR | LOCKDLY | EN | RCNT  | MXVCO | NCNT |

| 31 24         | _          | зарезервировано                                                           |
|---------------|------------|---------------------------------------------------------------------------|
|               | Па         | раметры для подстройки генератора                                         |
| 23            | LOCK LS    | настройки блока детектора захвата:                                        |
|               | _          | 0 - при частоте после делителя опорного сигнала [4,20]МГц                 |
|               |            | 1 - при частоте после делителя опорного сигнала $[1,8]{ m M}\Gamma{ m u}$ |
| 22            | LOCK_RANGE | настройка блока детектора захвата (разъяснение по исполь-                 |
|               |            | зованию см. ниже)                                                         |
| 21            | PDDLY      | изменение длительности сигнала сброса фазочастотного де-                  |
|               |            | тектора, нс:                                                              |
|               |            | 0 - 1нс                                                                   |
|               |            | 1 - 0,5нс                                                                 |
| 20            | IRMODE     | настройка тока:                                                           |
|               |            | 0 - выходной ток температурно-стабилизированный, с низкой                 |
|               |            | зависимостью от напряжения питания vdda                                   |
|               |            | 1 - выходной ток температурно-стабилизированный, с высо-                  |
|               |            | кой зависимостью от напряжения питания vdda                               |
| 1918          | CPCTR      | выбор величины тока в блоке ГПЗ, мкА                                      |
|               |            | 00 - 4;                                                                   |
|               |            | 01 - 2;                                                                   |
|               |            | 10 - 8;                                                                   |
|               |            | 11 - 6;                                                                   |
| $17 \dots 16$ | LOCKDLY    | настройка детектора захвата опорной частоты, задержка в                   |
|               |            | тактах опорной частоты до установления сигнала lock:                      |
|               |            | 00 - 8;                                                                   |
|               |            | 01 - 16;                                                                  |
|               |            | 10 - 32;                                                                  |
|               |            | 11 - 64;                                                                  |
|               |            | Биты управления генератором                                               |
| 15            | EN         | включение блока                                                           |
| $14\dots 12$  | RCNT       | коэффициент деления опорной частоты                                       |
| 118           | MXVCO      | коэффициент деления выходного делителя                                    |
| 60            | NCNT       | коэффициент деления внутреннего генератора                                |



#### Пояснение по использованию бита PLLCR(LOCK RANGE).

Блок детектора захвата опорной частоты устанавливает выходной сигнал PLLSTR(LOCK) в '1', когда длительность сигнала ошибки по частоте сформированного сигнала  $F_{ref}$  не превышает время  $T_{error}$ . Время  $T_{error}$  зависит от коэффициента деления PLLCR(RCNT), значения сигналов PLLCR(LOCK\_LS) и PLLCR(LOCKDLY) согласно формуле:

$$T_{error} = min(T_{error\%}, T_{errorA})$$

#### Таблица выбора значения $T_{error\%}$

| PLLCR(RCNT) | $T_{error\%}$ (PLLCR(LOCK_RANGE) = '0') | $T_{error\%}$ (PLLCR(LOCK_RANGE) = '1') |
|-------------|-----------------------------------------|-----------------------------------------|
|             | значения $T_{error\%}$ даны в процентах | от периода $F_{ref}$                    |
| 1           | 1,5%                                    | 8%                                      |
| 2           | 2%                                      | 12%                                     |
| 4           | 3%                                      | 14%                                     |
| 8           | 3%                                      | 15%                                     |
| 16          | 3%                                      | 16%                                     |

#### Таблица выбора значения $T_{errorA}$

| PLLCR(LOCK_RANGE) | $T_{errorA} (PLLCR(LOCK\_LS) = '0')$ | $T_{errorA} (PLLCR(LOCK\_LS) = '1')$ |
|-------------------|--------------------------------------|--------------------------------------|
| 1                 | 7нс                                  | 12нс                                 |
| 2                 | 40нс                                 | 70нс                                 |

Пример настройки параметров генератора.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 57-172



| PLLSTR     | Регист | р состояния і | енератора |      |
|------------|--------|---------------|-----------|------|
| Номер бита | 313    | 2             | 1         | 0    |
| Описание   | _      | REFACTIVE     | FREFLOW   | LOCK |

| 31 3 | _         | зарезервировано                                                            |
|------|-----------|----------------------------------------------------------------------------|
| 2    | REFACTIVE | наличие опорного тактового сигнала на входе генератора ('1'                |
|      |           | - подано)                                                                  |
| 1    | FREFLOW   | частота опорного тактового сигнала ниже $150\mathrm{k}\Gamma$ ц ('1' - ча- |
|      |           | стота ниже 150кГц, '0' - частота больше 190кГц)                            |
| 0    | LOCK      | частота на выходе генератора стабильно ('1' - частота ста-                 |
|      |           | бильна)                                                                    |

| PLLTMCR    | Регистр | Регистр управления модулем коммутации |      |      |      |       |       |         |         |         |  |  |  |  |  |  |
|------------|---------|---------------------------------------|------|------|------|-------|-------|---------|---------|---------|--|--|--|--|--|--|
| Номер бита | 3124    | 23                                    | 2215 | 1411 | 107  | 6     | 5     | 42      | 1       | 0       |  |  |  |  |  |  |
| Описание   | _       | EN                                    | _    | SELA | SELB | CFGOA | CFGOB | SELOCUR | INVERTA | INVERTB |  |  |  |  |  |  |

| 3124       | _       | зарезервировано                                      |
|------------|---------|------------------------------------------------------|
| 23         | EN      | разрешение работы ('1' - включен, '0' - выключен)    |
| 2215       | _       | зарезервировано                                      |
| 1411       | SELA    | управление мультиплексором канала А:                 |
|            |         | 0100 - $F_{ref}$                                     |
|            |         | $1001 - F_{sys}$                                     |
|            |         | остальные значения зарезервированы                   |
| 107        | SELB    | управление мультиплексором канала В:                 |
|            |         | 0100 - $F_{ref}$                                     |
|            |         | $1001 - F_{sys}$                                     |
|            |         | остальные значения зарезервированы                   |
| 6          | CFGOA   | управление состоянием выходного буфера А ('0' - зна- |
|            |         | чение тока выходного буфера зависит от значения      |
|            |         | PLLTMCR(SELOCUR) '1' значенине выходного тока -      |
|            |         | 240мкА)                                              |
| 5          | CFGOB   | управление состоянием выходного буфера В ('0' - зна- |
|            |         | чение тока выходного буфера зависит от значения      |
|            |         | PLLTMCR(SELOCUR) '1' значенине выходного тока -      |
|            |         | 240мкА)                                              |
| $4\dots 2$ | SELOCUR | управление током выходных буферов                    |
|            |         | 000 - $2,0$ мА                                       |
|            |         | 001 - 4,8 мА                                         |
|            |         | 010 - 7,7 мА                                         |
|            |         | 011 - 10,6 мА                                        |
|            |         | 100 - 4,0 мА                                         |
|            |         | 101 - 9,6 мА                                         |
|            |         | 110 - 15,4 мА                                        |
|            |         | 111 - 21,2 мА                                        |
| 1          | INVERTA | инвертирование сигнала канал А('1' - инвертирован)   |
| 0          | INVERTB | инвертирование сигнала канал В('1' - инвертирован)   |
|            |         |                                                      |



# 7 Аппаратная система отладки и тестирования

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



Рис. 11: Компоненты системы отладки и тестирования в МП

# 7.1 Контроллер (tap)

Интерфейс доступа по стандарту ieee1149.1 (JTAG). Контроллер сконфигурирован на поддержку 11 каналов, т.е. есть доступ к 11 блоками, обеспечивающим тестирование МП и отладку ПО. На рис.11 они изображены с заливкой.

| 0 | jtag_gpr0    |
|---|--------------|
| 1 | jtag_gpr1    |
| 2 | $jtag\_gpr2$ |
| 3 | jtag_gpr3    |
| 4 | jtag_dbg0    |

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 59-172



| 5  | jtag_dbg1    |
|----|--------------|
| 6  | $jtag\_dbg2$ |
| 7  | $jtag\_dbg3$ |
| 8  | bsr          |
| 9  | ahb_jtag     |
| 10 | $jtag\_mem$  |

Длина инструкций, поддерживаемых tap контроллером, составляет - 8 бит.

| Команда         | код (НЕХ)         | Блок, к которому относится команда |
|-----------------|-------------------|------------------------------------|
| SAMPLE          | $0 \times 0.1$    | bsr                                |
| PRELOAD         | $0 \times 02$     |                                    |
| IDCODE          | $0 \times 04$     |                                    |
| HIGHZ           | $0 \times 05$     |                                    |
| INTEST          | $0 \times 08$     |                                    |
| EXTEST          | $0 \times 09$     |                                    |
| BYPASS          | 0xff              |                                    |
| AMBA_ADDR       | 0x80              | ahb_jtag                           |
| AMBA_DATA       | 0x81              |                                    |
| MEM_ADDR        | 0xC0              | jtag_mem                           |
| MEM_DATA        | 0xC1              |                                    |
| CELL0_REGS_ADDR | 0xC4              | jtag_gpr0                          |
| CELL1_REGS_ADDR | 0xC5              | jtag_gpr1                          |
| CELL2_REGS_ADDR | 0xC6              | jtag_gpr2                          |
| CELL3_REGS_ADDR | 0xC7              | jtag_gpr3                          |
| CELLO_REGS_DATA | 0xC8              | jtag_gpr0                          |
| CELL1_REGS_DATA | 0xC9              | jtag_gpr1                          |
| CELL2_REGS_DATA | 0xCA              | jtag_gpr2                          |
| CELL3_REGS_DATA | $0 \mathrm{xCB}$  | jtag_gpr3                          |
| DBG0_ADDR       | $0 \times E0$     | jtag_dbg0                          |
| DBG1_ADDR       | 0xE1              | jtag_dbg1                          |
| DBG2_ADDR       | $0 \mathrm{xE} 2$ | jtag_dbg2                          |
| DBG3_ADDR       | 0xE3              | jtag_dbg3                          |
| DBG0_DATA       | 0xE4              | jtag_dbg0                          |
| DBG1_DATA       | 0xE5              | jtag_dbg1                          |
| DBG2_DATA       | 0xE6              | jtag_dbg2                          |
| DBG3_DATA       | 0xE7              | jtag_dbg3                          |

Внешний интерфейс соответствует стандарту ieee1149.1 и включает в себя пять сигналов: ntrst (активный уровень на входе М $\Pi$  - '0'), tck, tms, tdi, tdo.



# 7.2 Канал доступа к памяти (jtag mem)

Предназначен для доступа к устройствам памяти, находящимся во всем доступном МП диапазоне адресов. Является одним из клиентских каналов коммутатора. Доступ осуществляется через расширенные команды JTAG.

Через jtag\_mem возможно одновременно записать или считать 4 последовательно расположенных байта из любого доступного места адресного пространства МП.

#### Запись/чтение производятся следующим образом:

- перевести контроллер tap в состояние приема команд (в соответствии со стандартом ieee1149.1);
- передать команду MEM\_ADDR (она переключит tap на работу с блоком jtag\_mem);
- перевести контроллер tap в состояние приема данных;
- передать данные, содержащие адрес и режим работы;
- перевести контроллер tap в состояние приема команд;
- передать команду MEM DATA;
- перевести контроллер tap в состояние приема данных;
- передать/принять данные;

#### Структура поля данных, передаваемого после MEM ADDR

| Номер бита | 34           | 33 | 32    | 31   | 30   | 29  | 28   | 27    | 26     | 25 24 | 23    | 22   | 21   | 20  | 19  | 18  | 17  | 16  | 15  | 1  | 4  | 13  | 12    | 11  | 10   | 9   | 8   | 7   | 6    | 5  | 4 | 3 2 | 2 1 | 0 |
|------------|--------------|----|-------|------|------|-----|------|-------|--------|-------|-------|------|------|-----|-----|-----|-----|-----|-----|----|----|-----|-------|-----|------|-----|-----|-----|------|----|---|-----|-----|---|
| Описание   | RW           | RW | _MODE |      |      |     |      |       |        |       |       |      |      |     |     |     | ADI | DR  |     |    |    |     |       |     |      |     |     |     |      |    |   |     |     |   |
|            |              |    |       |      |      |     |      |       |        |       |       |      |      |     |     |     |     |     |     |    |    |     |       |     |      |     |     |     |      |    |   |     |     |   |
| 34         | RW           |    | I     | Зыб  | op j | реж | има  | ı ('1 | ' - 38 | апись | , '0' | - Ч  | тені | ие) |     |     |     |     |     |    |    |     |       |     |      |     |     |     |      |    |   |     |     |   |
| 32-33      | $RW_{\perp}$ | МО | DE I  | Зыб  | ор   | реж | им   | аза   | писи   | ı. 00 | ) -   | заре | езер | eup | ова | но, | 01t | ) - | заг | ис | ат | ьД  | ані   | ые  | c    | 0-3 | 1 б | ит, | , 10 | Эb | - |     |     |   |
|            |              |    | 3     | вапи | сат  | ьт  | льн  | о то  | чку    | оста  | нова  | a (3 | 3 би | т в | пол | е д | анн | ых  | дл  | яз | ап | иси | 1), I | .1b | - 38 | ипи | сат | ъд  | цан  | ны | e |     |     |   |
|            |              |    | I     | 1 ТО | чку  | ост | ганс | ва    |        |       |       |      |      |     |     |     |     |     |     |    |    |     |       |     |      |     |     |     |      |    |   |     |     |   |
| 0.31       | $\Delta$ DD  | R  |       | Δπъ  | ec   |     |      |       |        |       |       |      |      |     |     |     |     |     |     |    |    |     |       |     |      |     |     |     |      |    |   |     |     |   |

#### Структура поля данных, передаваемого после МЕМ DATA в режиме записи

| Номер бита | 32 31 3 | 0 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                |
|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Описание   | BP      | DATA                                                                                                                                                                             |
| 34         | BP      | Точка останова ('1' - установлена, '0' - не установлена). Может быть установлена только для данных в диапазоне 0х00000000-0х0004000, для остальных адресов будет проигнорирована |
| 0-31       | DATA    | Данные для записи                                                                                                                                                                |

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 61-172



# 7.3 Канал доступа к регистрам общего назначение и регистрам системной периферии (jtag gpr)

Канал доступа к регистрам общего назначение и регистрам системной периферии. Доступ осуществляется через расширенные команды JTAG.

Через jtag\_gpr возможно одновременно записать или считать один регистр МП. В каждой клетке присутствует свой канал доступа к регистрам. В МП содержимое регистров может быть разным в разных группах клеток.

#### Запись/чтение производятся следующим образом(х - номер клетки):

- перевести контроллер tap в состояние приема команд (в соответсвии со стандартом ieee1149.1);
- передать команду CELLx\_REGS\_ADDR (она переключит tap на работу с блоком jtag gprx);
- перевести контроллер tap в состояние приема данных;
- передать данные, содержащие адрес и режим работы;
- перевести контроллер tap в состояние приема команд;
- передать команду CELLx REGS DATA;
- перевести контроллер tap в состояние приема данных;
- передать/принять данные;

#### Структура поля данных, передаваемого после CELLx REGS ADDR

|            |     |     |    |      |      |      |       |       |       |     |         |       |     |      |    |     |     |     |    |    |    | -  |    |     | _   |   |   |   |   |     |   |   |   |
|------------|-----|-----|----|------|------|------|-------|-------|-------|-----|---------|-------|-----|------|----|-----|-----|-----|----|----|----|----|----|-----|-----|---|---|---|---|-----|---|---|---|
| Номер бита | 34  | 33  | 32 | 31   | 30   | 29 2 | 28 27 | 26    | 25    | 24  | 23      | 22    | 21  | 20   | 19 | 18  | 17  | 16  | 15 | 14 | 13 | 1: | 11 | . 1 | 0 9 | 8 | 7 | 6 | 5 | 4 3 | 2 | 1 | 0 |
| Описание   | RW  | -   |    |      |      |      |       |       |       |     |         |       |     |      |    |     | ADI | DR  |    |    |    |    |    |     |     |   |   |   |   |     |   |   |   |
| 34         | RW  | V   |    | Выб  | бор  | реж  | има   | ('1'  | - заі | ись | , '0    | , - д | тег | ние) |    |     |     |     |    |    |    |    |    |     |     |   |   |   |   |     |   |   |   |
| 32-33      | _   |     |    | заре | езер | eup  | ован  | o, nc | ле н  | е в | $ocn_I$ | рин   | им  | aem  | ся | cuc | meл | иой |    |    |    |    |    |     |     |   |   |   |   |     |   |   |   |
| 0.91       | A T | T D |    | Α.   |      |      |       |       |       |     |         |       |     |      |    |     |     |     |    |    |    |    |    |     |     |   |   |   |   |     |   |   |   |

# Структура поля данных, передаваемого после CELLx\_REGS\_DATA в режиме записи

```
    Номер бита
    63...0

    Описание
    DATA

    0-63
    DATA

    Данные для записи
```

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 62-172



# 7.4 Канал доступа к устройствам на шине AMBA (ahb jtag)

Доступ к любому устройству на шине AMBA. Доступ осуществляется через расширенные команды JTAG. ahb\_jtag позволяет осуществлять пакетную передачу данных. При этом существуют следующие ограничения:

- размер пакета не должен превышать 1КБайт;
- чтение/запись осуществляется словами по 32 бита;

#### Запись/чтение производятся следующим образом:

- перевести контроллер tap в состояние приема команд (в соответсвии со стандартом ieee1149.1);
- передать команду AMBA ADDR;
- перевести контроллер tap в состояние приема данных;
- передать данные, содержащие адрес и режим работы;
- перевести контроллер tap в состояние приема команд;
- передать команду АМВА DATA;
- перевести контроллер tap в состояние приема данных;
- передать/принять данные;

#### Структура поля данных, передаваемого после AMBA ADDR

| Номер бита | 34         | 33  | 32    | 31  | 30  | 29 | 28 | 27  | 26 | 25           | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17  | 16  | 15   | 14    | 13   | 12   | 11   | 10   | 9  | 8   | 7   | 6  | 5 4  | 1 3 | 2 | 1 | 0 |
|------------|------------|-----|-------|-----|-----|----|----|-----|----|--------------|----|----|----|----|----|------|------|-----|-----|------|-------|------|------|------|------|----|-----|-----|----|------|-----|---|---|---|
| Описание   | RW         | RW  | _MODE |     |     |    |    |     |    |              |    |    |    |    |    |      |      | ADE | PR  |      |       |      |      |      |      |    |     |     |    |      |     |   |   |   |
|            | RW<br>RW 1 | MOI | DE B  | ыбо | ррр | еж |    | зап |    | апи<br>и. 00 | ,  |    |    |    | /  | 10лу | 'СЛС | во  | (16 | i би | т), : | 10 Ь | - C. | пово | o (3 | 26 | бит | a), | 11 | .b - |     |   |   |   |

0-31 ADDR Адрес в диапазоне адресов выделенных периферийной шине

# Структура поля данных, передаваемого после AMBA\_DATA в режиме записи

| Номер бита | 32  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Описание   | SEQ |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DAT | PA . |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

32 SEQ '1' - режим пакетной передачи, адрес обращения будет инкрементированное значения переданного после команды AMBA\_ADDR адреса или инкрементированное значение адреса, полученного при предыдущем обращении. При выполнении операции чтения, в бите SEQ, принимаемых данных, '1' будет означать, что данные валидны, '0' - транзакция по шине периферийных устройств не завершена. '0' - адрес, к которому обращаются, будет взят из поля ADDR, переданного в данных после команды AMBA\_ADDR



0-31 DATA данные, порядок байтов big-endian (от старшего к младшему), при размере данный меньше  $32\,$  бит, выравнивание к MSB

www.multiclet.com  $UM\_HDL50002$  Rev:101 09.07.2015 64-172



# 7.5 Модуль отладки ПО (jtag dbg)



Рис. 12: Блок-схема модуля отладки ПО

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

Ядро МП содержи 4 модуля jtag\_dbg, которые анализируют информацию на шинах данных и инструкций каждого ядра. Модули работают независимо. Каждый модуль вырабатывает сигнал останова системы, эти сигналы по ИЛИ образуют один системный сигнал останова.

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

#### Запись/чтение производятся следующим образом:

- перевести контроллер tap в состояние приема команд (в соответсвии со стандартом ieee1149.1);
- передать команду DBGx\_ADDR (она переключит на работу с конкретным блоком jtag\_dbgx);
- перевести контроллер tap в состояние приема данных;
- передать данные, содержащие адрес и режим работы;
- перевести контроллер tap в состояние приема команд;
- передать команду DBGx DATA;



- перевести контроллер tap в состояние приема данных;
- передать/принять данные;

# Структура поля данных, передаваемого после DBGx ADDR

|            | Стр | уктура по | ра поля данных, передаваемого после DBGx_ADDR                         |  |  |  |  |  |  |
|------------|-----|-----------|-----------------------------------------------------------------------|--|--|--|--|--|--|
| Номер бита | 34  | 33 32     | 31 0                                                                  |  |  |  |  |  |  |
| Описание   | RW  | _         | ADDR                                                                  |  |  |  |  |  |  |
| 34         | RV  | V I       | Зыбор режима ('1' - запись, '0' - чтение)                             |  |  |  |  |  |  |
| 32-33      | _   | á         | зарезервировано                                                       |  |  |  |  |  |  |
| 0 - 31     | ΑI  | DDR A     | Адрес в регистра:                                                     |  |  |  |  |  |  |
|            |     | C         | $0x01 - R_CMD$                                                        |  |  |  |  |  |  |
|            |     | C         | $0$ x $0$ 2 - R_STAT                                                  |  |  |  |  |  |  |
|            |     | C         | 0x03 - R_AC                                                           |  |  |  |  |  |  |
|            |     | C         | $0x04 - R_AC_C$                                                       |  |  |  |  |  |  |
|            |     | C         | $0x05 - R\_CB\_ST$                                                    |  |  |  |  |  |  |
|            |     | C         | x06 - R_CT_STAT                                                       |  |  |  |  |  |  |
|            |     | C         | $0x08-0x10$ - таблицы условий останова $ARR\_CT[x]$ , где $= [0,7]$   |  |  |  |  |  |  |
|            |     | C         | $1 \times 20$ -0 $1 \times 20$ - адреса циклического буфера $[0,511]$ |  |  |  |  |  |  |

#### Структура поля данных, передаваемого после DBGx DATA

|            | Стр | уктура поля данных, передаваемого после DBGx_DATA |
|------------|-----|---------------------------------------------------|
| Номер бита | 260 | 2590                                              |
| Описание   | _   | DATA                                              |
| 260        |     | 20002200000000000                                 |

260 — зарезервировано
 259-0 DATA содержание зависит от регистра, к которому обращаются. Данные смещены вправо к 0 биту. Регистры описаны ниже.



# jtag dbg состоит из следующих частей:

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

#### Управление и связь

Данная часть представлена интерфейсным модулем JTAG, который отвечает за прием/передачу команд, регистром управления  $R_CMD$  и регистром статуса  $R_STAT$ . Загрузка/выгрузка информации производится внешней системой по интерфейсу JTAG. Возможно разрешить работу любой из частей  $jtag_dbg$  и системы вцелом, принудительно остановить систему. Полная остановка системы определяется по наличию сигнала  $R_STAT(CMPLT) = '1'$ . Только после этого можно изменять память  $M\Pi$ , регистры и т.д. Иначе возможны коллизии и, как следствие, непредсказуемые действия  $M\Pi$ .

| $R_C$       | MD               | Регистр управления           |                                        |                                                            |               |            |           |        |            |      |                   |  |  |  |
|-------------|------------------|------------------------------|----------------------------------------|------------------------------------------------------------|---------------|------------|-----------|--------|------------|------|-------------------|--|--|--|
| Номер       | бита             | 8                            | 7                                      | 6                                                          | 5             | 4          | 3         | 2      | 1          | 0    |                   |  |  |  |
| Описа       | ние              | EN_AC1_BP                    | EN_AC0_BP                              | EN_CB_BP                                                   | CLR_BP        | EN         |           |        |            |      |                   |  |  |  |
| 8<br>7<br>6 | EN<br>EN         | _AC1_BP<br>_AC0_BP<br>_CB_BP | разрешение<br>разрешение<br>разрешение | е точки оста                                               | анова по 0-м  | иу счетчи: | ку адресо | в кома |            |      |                   |  |  |  |
| 5           | EN               | $_{ m CT}_{ m BP}$           | разрешение                             | разрешение точек останова по таблице условий канала данных |               |            |           |        |            |      |                   |  |  |  |
| 4           | EN               | _I_BP                        | разрешение                             | е точек оста                                               | нова по ад    | ресу инстр | рукции    |        |            |      |                   |  |  |  |
| 3           | $^{\mathrm{CB}}$ | _MOD                         | режим буф                              | ера команд                                                 | : '1' - фикса | ация всех  | адресов к | оманд  | , '0' - фи | ксац | ия только началь- |  |  |  |
|             |                  |                              | ных адресо                             | в параграф                                                 | ОВ            |            |           |        |            |      |                   |  |  |  |
| 2           | $_{ m HA}$       | LT                           | принудител                             | ьный остан                                                 | ов системы    | I          |           |        |            |      |                   |  |  |  |
| 1           | CLI              | R_BP                         | сброс сработавших точек останова       |                                                            |               |            |           |        |            |      |                   |  |  |  |
| 0           | EN               |                              | разрешение                             | е работы си                                                | стемы отла    | дки        |           |        |            |      |                   |  |  |  |



|            |                |         |          |        |         |          | _           |
|------------|----------------|---------|----------|--------|---------|----------|-------------|
| R_STAT     | Регистр        | статуса |          |        |         |          | ]           |
| Номер бита | . 5            | 4       | 3        | 2      | 1       | 0        |             |
| Описание   | AC_BP          | CB_BP   | CT_BP    | I_BP   | HALT    | CMPLT    | ]           |
|            |                |         |          |        |         |          | _           |
| 5          | AC_BP          | остан   | ювка сч  | етчик  | у инст  | рукции   |             |
| 4          | ${\rm CB\_BP}$ | остан   | ювка по  | колы   | цевому  | буферу   | y           |
| 3          | $CT_BP$        | остан   | ювка по  | табли  | ице усл | говий ка | анала данны |
| 2          | $I_BP$         | остан   | ювка по  | адрес  | су инст | грукции  | Ī           |
| 1          | $_{ m HALT}$   | прин    | удитель  | ная ос | станові | ка систе | мы          |
| 0          | CMPLT          | пара    | граф за: | верше  | н       |          |             |

#### Детектор точек останова по адресу команды

Детектор получает данные с канала инструкций и позволяет остановить систему при обнаружении признака останова у выбранной команды. Признаки останова можно записать только для команд, расположенных в диапазоне адресов 0x00000000-0x0004000. Сигнал останова возникает тогда, когда выбрана команда с признаком останова.

#### Блок подсчета выборок определенного параграфа

Регистр установки счетчика адресов

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

| Номер бита     | 127 96 | 95 64  | 63 32     | 31 0     |                                                                    |
|----------------|--------|--------|-----------|----------|--------------------------------------------------------------------|
| Описание       | CNT1   | CNT0   | ADDR1     | ADDR0    |                                                                    |
|                |        |        |           |          |                                                                    |
| $96 \dots 127$ | CNT1   | зна    | чение 1-: | го счетч | чика кол-ва совпадений адреса при котором будет произведен останов |
| $64 \dots 95$  | CNT0   | зна (  | чение 0-  | го счетч | чика кол-ва совпадений адреса при котором будет произведен останов |
| $32 \dots 63$  | ADDI   | R1 адр | ес инстр  | укции г  | по которому ведет подсчет 1-й счетчик                              |
| $0 \dots 31$   | ADDI   | R0 адр | ес инстр  | укции г  | по которому ведет подсчет 0-й счетчик                              |



CNT0

| $_{ m AC}_{ m C}$ | Счетчик | и адресов |
|-------------------|---------|-----------|
| Номер бита        | 63 32   | 31 0      |
| Описание          | CNT1    | CNT0      |
| 32 6              | 3 CNT   | '1 1-й с  |

#### Циклический буфер выбранных команд

0-й счетчик кол-ва совпадений адреса

Буфер получает информацию с канала инструкций. Выполняет функции тарссировщика. Команды фиксируются согласно R СМD(СВ МОD). В буфер может быть записано до 512 длинных команд (64бита). Сигнал останова возникает тогда, когда буфер переполнился. При этом буфер может продолжать принимать информацию, счетчик переполнений инкрементируется.

| $R_CB$        | Состояние ци | иклического буфера команд |
|---------------|--------------|---------------------------|
| Номер бита    | 2416         | 15 0                      |
| Описание      | OVL_CNT      | POS_CNT                   |
|               |              |                           |
| $16 \dots 24$ | OVL_CNT      | ' текущая позиция в б     |
| $0 \dots 15$  | POS CNT      | кол-во переполнений       |

#### Блок останова по условиям

www.multiclet.com

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

| ARR_CT          | Таблица условий |         |                        |           |            |         |       |                                            |  |  |  |
|-----------------|-----------------|---------|------------------------|-----------|------------|---------|-------|--------------------------------------------|--|--|--|
| Номер бита      | 260 197         | 196 133 | 132 69                 | 68 37     | 36 5       | 4 1     | 0     | ]                                          |  |  |  |
| Описание [      | _               | OPRND   | MSK                    | ADDR_E    | ADDR_B     | OC      | RW    |                                            |  |  |  |
| 197 260         | _               | sape    | зервиров               | ано       |            |         |       |                                            |  |  |  |
| $133 \dots 196$ | OPRNI           | Э дан:  | ные для о              | перации,  | 64 бита    |         |       |                                            |  |  |  |
| $69 \dots 132$  | MSK             | мас     | ка на вход             | цные дані | ные, 64 бі | та, вы  | лоня  | кэтэн                                      |  |  |  |
|                 |                 | опер    | оация лог              | ического  | И с данн   | ыми, м  | аска  | учитывается                                |  |  |  |
|                 |                 | при     | всех опер              | ациях О   | С в котор  | ых ана  | лизи  | ируется значение данных                    |  |  |  |
| $37 \dots 68$   | ADDR            | _Е кон  | ечный адр              | ес блока  | данных     | значени | я ко  | эторых анализируются, 32 бита              |  |  |  |
| 536             | ADDR            | _       | альный ад<br>(ой) анаи |           |            | к или 8 | дрес  | с конкретной ячейки памяти значения(е) кот |  |  |  |
| $1 \dots 4$     | $^{ m OC}$      | код     | операции               | , условия | останова   | а или ф | рунк  | иция, которая выполняется над OPRND и вхо  |  |  |  |
|                 |                 | ным     | и данным               | ии из ука | занного а  | дреса:  |       |                                            |  |  |  |
|                 |                 |         |                        | производ  | дится, есл | и на п  | ине   | данных была произведена операция указанна  |  |  |  |
|                 |                 | вW      |                        |           |            |         |       |                                            |  |  |  |
|                 |                 |         |                        | • '       |            |         |       | данных появилось значение равное OPRND     |  |  |  |
|                 |                 | 0x3     | - останов              | производ  | цится, есл | и на ш  | ине , | данных появилось значение больше OPRND     |  |  |  |
|                 |                 | 0x4     | - останов              | производ  | цится, есл | и на ш  | ине , | данных появилось значение меньше OPRND     |  |  |  |
|                 |                 | 0x5     | - останов              | производ  | цится, есл | и логи  | ческ  | ое И данных и OPRND дало результат ноль    |  |  |  |



0 RW тип операции на шине данных '1' - чтение, '0' - запись

# 7.6 Регистр периферийного сканирования (bsr)

Регистр периферийного сканирования поддерживает все обязательные команды по стандарту ieee1149.1.

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 70-172$ 



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

| Периферийное устройство | Базовый адрес |
|-------------------------|---------------|
| ADC0                    | 0xC01D0000    |
| ADC1                    | 0xC01D0100    |
| DAC0                    | 0xC01D1000    |
| DAC1                    | 0xC01D1100    |
| ETHERNET0               | 0xC0005000    |
| EXTMEM                  | 0xC00EE000    |
| GPIOA                   | 0xC00F0000    |
| GPIOB                   | 0xC00F0100    |
| GPIOC                   | 0xC00F0200    |
| GPIOD                   | 0xC01F0300    |
| GPIOE                   | 0xC01F0400    |
| GPIOF                   | 0xC01F0500    |
| GPTIM0                  | 0xC0010000    |
| GPTIM1                  | 0xC0010100    |
| GPTIM2                  | 0xC0110000    |
| GPTIM3                  | 0xC0110100    |
| I2C0                    | 0xC0001000    |
| I2C1                    | 0xC0001100    |
| I2S0                    | 0xC0002000    |
| PWM0                    | 0xC0112000    |
| RTC                     | 0xC001F000    |
| SPI0                    | 0xC0104000    |
| SPI1                    | 0xC0108000    |
| STAT                    | 0xC01E1000    |
| UART0                   | 0xC0000100    |
| UART1                   | 0xC0000200    |
| UART2                   | 0xC0100100    |
| UART3                   | 0xC0100200    |
| WDT                     | 0xC00E0000    |

Таблица 7: Базовые адреса периферийных устройств



# 8.1 Порт ввода-вывода (GPIO)

### 8.1.1 Краткие характеристики

- МП содержит 1 порт на 32 бита, 2 порта по 30 бит, 1 порт 28 бит, 1 порт на 24 бит и 1 порт на 22 бита;
- каждый бит порта может быть индивидуально настроен на ввод или вывод и может опционально генерировать прерывания;
- запрос прерывания может формироваться по уровню либо по фронту (передний-/задний) сигнала;
- вводы-выводы портов могут переключаться на альтернативную функцию;



Рис. 13: Блок-схема і-ой линии GPIO

#### 8.1.2 Функционирование GPIO

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 72 - 172



вательно включенных триггеров, чтобы исключить возможность возникновения метастабильности. Синхронизированное значение может быть прочитано из регистра принимаемых данных (GPIOxIN) порта ввода-вывода. Разрешение вывода управляется через регистр разрешения передачи (GPIOxDIR). Логическая единица ('1') в данном разряде порта ввода вывода конфигурирует соответствующую ей линию на вывод. Выходное значение берется из регистра передаваемых данных (GPIOxOUT) порта ввода-вывода.

Каждая линия порта ввода-вывода может быть сконфигурирована на формирование прерывания. Формирование прерывания управляется тремя регистрами: регистром маски прерываний (GPIOxMSK), регистром настройки прерывания по событию, полярности сигнала (GPIOxPOL) и регистром настройки прерывания по событию, составляющая сигнала (GPIOxEDG). Для разрешения прерывания, соответствующий бит в маске прерываний должен быть установлен ('1'). Если регистр составляющей сигнала сброшен ('0'), то прерывание формируется по уровню сигнала. Если регистр полярности сигнала сброшен ('0'), то прерывание возникает при активном низком уровне сигнала, если же регистр полярности сигнала установлен ('1'), то прерывание возникает при активном высоком уровне сигнала. Если регистр составляющей сигнала установлен ('1'), то прерывание формируется по фронту сигнала. Если регистр полярности сигнала сброшен ('0'), то прерывание возникает по переднему фронту сигнала, если же регистр полярности сигнала установлен ('1'), то прерывание возникает по заднему фронту сигнала.

Каждый вывод порта ввода-вывода может быть совместно использован для других типов сигналов, выполняющих альтернативные функции. Для разрешения задания альтернативных функций какой-либо линией порта необходимо в регистре разрешения альтернативных функций (GPIOxBPS) установить соответствующий бит ('1'). Описание всех вводов-выводов МП смотрите в п.9

Важное замечание: если альтернативная функция битов порта GPIO, задаваемая через BPS - выход, то биты порта конфигурируются в соответствии с направлением BPS. Если альтернативная функция битов порта GPIO, задаваемая через BPS - вход, то биты порта конфигурируются в соответствии с направлением DIR. Таким образом, если установлен бит в DIR в "1 то установка в BPS "1"для текущего бита не позволит ему сконфигурироваться на вход(только на выход). В этом случае необходимо сначала сконфигурировать бит в DIR в "0"и из такого положения с помощью BPS регистра бит конфигурируется на любое направление для альтернативной функции.



## 8.1.3 Описание регистров

Порты ввода-вывода общего назначения:

GPIOA: базовый адрес - 0xC00F 0000; ширина порта - 30 разрядов.

GPIOB: базовый адрес - 0xC00F 0100; ширина порта - 30 разрядов.

GPIOC: базовый адрес - 0xC00F 0200; ширина порта - 24 разряда.

GPIOD: базовый адрес - 0xC01F 0300; ширина порта - 32 разряда.

GPIOE: базовый адрес - 0xC01F 0400; ширина порта - 28 разрядов.

GPIOF: базовый адрес - 0xC01F 0500; ширина порта - 22 разряда.

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра.

| Регистр  | Смещение адреса | Доступ | Описание                                                       |
|----------|-----------------|--------|----------------------------------------------------------------|
| GPIOxIN  | 00 h            | R      | Регистр принимаемых данных.                                    |
| GPIOxOUT | 04h             | RW     | Регистр передаваемых данных.                                   |
| GPIOxDIR | 08 h            | RW     | Регистр разрешения передачи.                                   |
| GPIOxMSK | 0Ch             | RW     | Регистр маски прерываний.                                      |
| GPIOxPOL | 10 h            | RW     | Регистр настройки прерывания по событию, полярность сигнала.   |
| GPIOxEDG | 14h             | RW     | Регистр настройки прерывания по событию, составляющая сигнала. |
| GPIOxBPS | 18 h            | RW     | Регистр разрешения альтернативных функций                      |

| GPIOxIN             | Pe | гист | рпр | ини | мае | мых | дан | ных |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние | 0  | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Описание            |    |      |     |     |     |     |     |     |    |    |    |    |    |    | DAT | ГΑ |    |    |    | •  |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 DATA Регистр принимаемых данных. Каждый разряд регистра соответствует каждой линии порта.

| GPIOxOUT            | Pe | гист | рпе | ред | авае | мых | дан | ны | C  |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|------|-----|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26  | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние | 0  | 0    | 0   | 0   | 0    | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Описание            |    |      |     |     |      |     |     |    |    |    |    |    |    |    | DAT | ГΑ |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 DATA Регистр передаваемых данных. Каждый разряд регистра соответствует каждой линии порта.



| GPIOxDIR            | Pe | гист | рра | зрег | пені | ия п | еред | ачи |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|------|------|------|------|-----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28   | 27   | 26   | 25   | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние | 0  | 0    | 0   | 0    | 0    | 0    | 0    | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Описание            |    |      |     |      |      |      |      |     |    |    |    |    |    |    | DAT | ГΑ |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 DATA Регистр разрешения передачи. Каждый разряд регистра соответствует каждой линии порта. Если любой разряд регистра установлен в '1', то у соответствующей линии порта передача данных разрешена, если же разряд установлен в '0'- передача запрещена.

| GPIOxMSK            | Pe | гист | рма | ски | пре | рыв | ани | й  |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27  | 26  | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние | 0  | 0    | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Описание            |    |      |     |     |     |     |     |    |    |    |    |    |    |    | DAT | ГΑ |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 DATA Регистр маски прерываний. Каждый разряд регистра соответствует каждой линии порта. Если любой разряд регистра установлен в '1', то у соответствующей линии порта разрешено прерывание по событию, если же разряд установлен в '0'- прерывание по событию запрещено.

| GPIOxPOL            | Pe | гист | рна | стр | эйки | пр | ерын | зани | япо | соб | ыти | ю, г | голя | рно | сть с | сигн | ала |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|------|----|------|------|-----|-----|-----|------|------|-----|-------|------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26 | 25   | 24   | 23  | 22  | 21  | 20   | 19   | 18  | 17    | 16   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние | 0  | 0    | 0   | 0   | 0    | 0  | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0     | 0    | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Описание            |    |      |     |     |      |    |      |      |     |     |     |      |      |     | DAT   | ГА   |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 DATA Регистр настройки прерывания по событию, полярность сигнала. Каждый разряд регистра соответствует каждой линии порта. Если любой разряд регистра установлен в '1', то соответствующая линия порта формирует прерывание по переднему фронту/высокому уровню, если же разряд установлен в '0'- формирует прерывание по заднему фронту/низкому уровню. Выбор фронта или уровня зависит от настройки соответствующего бита в регистре GPIOxEDG.

| GPIOxEDG            | Per | гист | рна | стро | эйки | пре | рын | зани | япс | cof | ыти | ю, с | оста | вля | юща | я с | игна | ла |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|-----|------|-----|------|------|-----|-----|------|-----|-----|-----|------|------|-----|-----|-----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31  | 30   | 29  | 28   | 27   | 26  | 25  | 24   | 23  | 22  | 21  | 20   | 19   | 18  | 17  | 16  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние | 0   | 0    | 0   | 0    | 0    | 0   | 0   | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Описание            |     |      |     |      |      |     |     |      |     |     |     |      |      |     | DAT | ГΑ  |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 DATA Регистр настройки прерывания по событию, составляющая сигнала. Каждый разряд регистра соответствует каждой линии порта. Если любой разряд регистра установлен в '1', то соответствующая линия порта формирует прерывание по фронту, если же разряд установлен в '0'- формирует прерывание уровню.

| GPIOxBPS            | Per | гист | р ра | зреі | пені | ия а. | льте | рна | гивн | ых | фун | кци | й  |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|-----|------|------|------|------|-------|------|-----|------|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31  | 30   | 29   | 28   | 27   | 26    | 25   | 24  | 23   | 22 | 21  | 20  | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние | 0   | 0    | 0    | 0    | 0    | 0     | 0    | 0   | 0    | 0  | 0   | 0   | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Описание            |     |      |      |      |      |       |      |     |      |    |     |     |    |    | DA' | ГΑ |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 DATA Регистр разрешения альтернативных функций. Каждый разряд регистра соответствует каждой линии порта. Если любой разряд регистра установлен в '1', то у соответствующей линии порта выполнение альтернативной функции разрешено, если же разряд установлен в '0'- выполнение альтернативной функции запрещено.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 75-172



# 8.2 Контроллер шины внешней памяти (MCTRL0)

## 8.2.1 Краткие характеристики

- поддерживает работу с памятью типа: PROM, SRAM, SDRAM;
- автоматическая регенерация SDRAM;
- внешняя шина данных до 32 бит;
- работа с устройствами ввода/вывода (І/О);



Рис. 14: Контроллер шины внешней памяти

Контроллер может управлять 2-мя банками PROM, одним банком I/O, 4-мя банками SRAM и двумя банками SDRAM.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 76 - 172



## 8.2.2 Интерфейс PROM

Временные диаграммы работы с PROM памятью похожи на диаграммы работы с RAM память. Отличие состоит в том, что циклы работы PROM могут иметь до 15 циклов задержки.

Ниже приведены диаграммы работы интерфейса.

### Диаграммы чтения:



Рис. 15: Диаграмма непоследовательного чтения РКОМ



Рис. 16: Диаграмма последовательного чтения PROM

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 77-172





Рис. 17: Диаграмма чтения PROM с 2-мя циклами задержки

## Диграммы записи:



Рис. 18: Диаграмма записи PROM (без циклов задержки)





Рис. 19: Диаграмма записи PROM (2 цикла задержки)

В зависимости от того в какую половину (верхнюю или нижнюю) области памяти PROM происходит обращение задействуются выводы ROMSN[1:0]. Если обращение происходит в нижнюю половину адресов, то задействуется вывод ROMSN[0]. Если обращение происходит в верхнюю половину адресов, то задействуется вывод ROMSN[1].



## 8.2.3 Интерфейс І/О

Временные диаграммы работы с I/O памятью похожи на диаграммы работы с RAM/ROM памятью. Отличие состоит в том, что дополнительные циклы задержки могут быть добавлены путем перевода состояния вывода BRDYN в логический "0". Сигнал выбора IOSN интерфейса памяти I/O задерживается на 1 такт для обеспечения стабильности адреса до перехода сигнала IOSN в логическую "1".

Ниже приведены диаграммы работы интерфейса.

### Диаграммы чтения:



Рис. 20: Диаграмма чтения I/O памяти (без циклов задержки)



# Диграммы записи:



Рис. 21: Диаграмма записи І/О памяти (без циклов задержки)



## 8.2.4 Интерфейс SRAM

Область памяти SRAM можеть иметь максимальный размер 256 Мегабайт. Из них младшие 256 Мегабайт могут занимать до 4-х банков SRAM, старшую половину занимает SDRAM, если она включена. Но есть бит MCFG2(SI), и если этот бит установлен в '1', то в младших 256 Мегабайтах области размещения RAM памяти размещается SDRAM. Размер банков SRAM программируется двоичными шагами от 8 Кбайт до 256 Мегабайт.

Ниже приведены иллюстрации размещения SRAM и SDRAM памяти:

| Значения битов                       | Расположение памяти SRAM и SDRAM |
|--------------------------------------|----------------------------------|
| 1) SRAM включена,<br>SDRAM выключена | 0x2000 0000 SRAM                 |
| MCFG2(SE) = 0                        | 0x3000 0000                      |
| MCFG2(SI) = 0                        | 0×4000 0000                      |
| 2) SRAM включена,<br>SDRAM включена  | 0x2000 0000 SRAM                 |
| MCFG2(SE) = 1                        | 0×3000 0000                      |
| MCFG2(SI) = 0                        | 0x4000 0000 SDRAM                |
| 3) SRAM выключена,<br>SDRAM включена | 0x2000 0000 SDRAM                |
| MCFG2(SE) = 1                        | 0×3000 0000                      |
| MCFG2(SI) = 1                        | 0×4000 0000                      |

Рис. 22: Взаимное размещение SRAM и SDRAM памяти в RAM области карты памяти

Чтение из памяти SRAM состоит из двух циклов чтения данных и задержками от 0 до 3 (устанавливаются пользователем). При непоследовательном чтении добавляется lead-out цикл для предотвращения несогласованности на шине из-за медленного переключения памяти или I/O устройств.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 82-172



Ниже приведены диаграммы работы интерфейса.



Рис. 23: Диаграмма непоследовательного чтения SRAM памяти



Рис. 24: Диаграмма записи SRAM памяти (без циклов задержки)



## 8.2.5 Интерфейс SDRAM

Размещение памяти SDRAM в области RAM карты памяти процессора происходит в соответствии с рис. 22. Доступно 2 банка памяти SDRAM с максимальным размером банка в 256 Мегабайт, начиная от 4 Мегабайт с двоичным шагом и позволяет работать с 8-12 битным адресом столбца и 13 битным адресом строки. SDRAM контроллер работает только в 32-х битном формате по шине данных. Контроллер поддерживает mobile SDRAM.

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

Когда включен SDRAM контроллер, то прозводятся автоматически инициализационные последовательности PRECHARGE, 2x AUTO-REFRESH, LOAD-MODE-REG во всех банках одновременно. Когда включено функционирование mobile SDRAM, то инициализационная последовательность прикрепляется по команде LOAD-EXTMODE-REG. Контроллер программирует SDRAM на последовательное чтение страниц памяти и одиночную локальную запись.

### Конфигурация временных параметров

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

| Функция                               | Параметр   | Диапазон | Размерность |
|---------------------------------------|------------|----------|-------------|
| RAS/CAS задержка                      | Tcas, Trcd | 2-3      | такт        |
| Предварительная зарядка для включения | Trp        | 2-3      | такт        |
| Период команды автообновления         | Trfc       | 3-11     | такт        |
| Период автообновления                 | Trf        | 10-32768 | такт        |

В случае включения поддержки mobile SDRAM появляется дополнительный параметр Txsr для настройки в регистре MCFG4.

Txsr задает задержку между окончанием режима самообновления и началом команды.

#### Обновление

Контроллер SDRAM содержит функцию обновления, которая периодически посылает команду AUTO-REFRESH в каждый банк SDRAM. Период между командами обновления записывается в тактах в регистре MCFG3. В зависимости от типа SDRAM необходимый период обычно от 7,8 до 15,6 мкс (соответствует 780 и 1560 тактам на частоте 100 МГц). Период обновления формируется по формуле:

$$Trefresh = (SDRRV + 1)/Tsysclk$$

Функция обновления включается установкой MCFG2(31) в '1'.



#### Самообновление

"Режим самообновления" используется для сохранения данных в SDRAM памяти, когда остальная система отключена. В этом случае SDRAM сохраняет данные без внешнего тактирования и обновление происходит внутри нее. Область памяти, которую необходимо обновлять в ходе операции самообновления определяется в расширенном регистре режима. Эти настройки могут быть изменены путем установки значений в MCFG4(PASR). Расширенный регистр режима памяти SDRAM автоматически обновится при изменении MCFG4(PASR). Поддерживаются следующие режимы частичного самообновления: полный, наполовину, одна четвертая, одна восьмая, одна шестнадцатая области памяти. "Режим частичного самообновления"поддерживается только при разрешенном функционировании mobile SDRAM. Для разрешения функционирования режима самообновления установите MCFG4(PMODE) в '010'. Контроллер будет в режиме самообновления после каждого доступа к памяти (когда контроллер в режиме ожидания в течение 16 тактов), пока не будет установлен MCFG4(PMODE) в '0'. При выходе из данного режима контроллер произведет задержку на период Txsr и команду AUTO-REFRESH до того как любой доступ к памяти будет разрешен. Минимальная длительность данного режима определяется Tras.

#### Режим отключения

Когда установлен "Режим отключения" все входные и выходные буферы, за исключением SDCKE, отключаются. Все данные SDRAM сохраняются в течение данной операции. Для включения "режима отключения" установите MCFG4(PMODE) в '001'. Контроллер будет выходить в "режим отключения" после каждого доступа к памяти (когда контроллер в режиме ожидания в течение 16 тактов), пока не будет установлен MCFG4(PMODE) в '0'. Команда REFRESH еще будет выдана в этом режиме. При выходе из данного режима задержка в один такт будет выдана до любого команды к памяти.

#### Режим глубокого отключения

"Режим глубокого отключения" используется для достижения максимальной экономии энергии за счет отключения питания области памяти. Данные SDRAM не будут сохранены при переходе в данный режим. Для перехода в данный режим установите МСГG4(PMODE) в '101'. Для выхода из данного режима установите МСГG4(PMODE) в '0'. На попытки доступа к памяти контроллер будет выдавать ERROR на шину AMBA в данном режиме.

#### Температурная компенсация режима самообновления

Температурная компенсация частоты регенерации памяти устанавливается в MCFG4(TCSR). Расширенный регистр режимов автоматически обновится при изменении битов MCFG4(TCSR).

## Команды SDRAM



Контроллер SDRAM выдавать 4 команды, записаннхы в поле MCFG2(SDRAM CMD): PRE-CHARGE, AUTO-REFRESH, LOAD-MOD-REG(LMR), LOAD-EXTMODE-REG(EMR). Если выполнена команда LMR, то CAS задержка будет установлена как запрограммировано в MCFG2, остальные поля также будут исправлены: последовательное очередное чтение страниц, одиночная локальная запись, последовательная очередь. Если выполнена команда EMR, то будут использоваться параметры установленные в MCFG4(DS, TCSR, PASR). Для выполнения команды EMR бит MCFG4(EMR) должен быть установлен в '1'. Поле MCFG2(SDRAM CMD) будет очищено после выполнения команды. При изменении CAS задержки необходимо выставлять команду LOAD-MODE-REGISTER.

#### Циклы чтения

Цикл чтения начинается после выполнения команды ACTIVATE для желаемого банка и строки, следующей за командой READ после CAS задержки. Режим чтения пачками осуществляется при приходе соответсвующего запроса на шине AHB.

Между циклами чтения не висят открытые банки.

#### Циклы записи

Циклы записи аналогичны циклам чтения, только для активации записи необходима команда WRITE. Запись пачками формируется по соответствующему запросу на шине АНВ без циклов простоя.

### Подключение шины адреса

Шина адреса подключается выводами A[14:2], для адресации банков используются выводы A[16:15].

#### Шина данных

Шина данных состоит из 32 линий, которые подключаются к линиям данных внешней памяти SDRAM. SDRAM память должна иметь 32 линии данных, также SDRAM шина данных в 32 линии может быть составлена из двух устройств памяти с шиной данных в 16 бит.

#### Тактирование

Для синхронизации SDRAM можно использовать сигнал системной тактовой частоты доступный на ножке SYS\_CLK.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 86-172



#### 8.2.6 Использование сигнализации готовности шины

Сигнал готовности шины памяти BRDYN используется для памяти PROM, I/O и сигнализирует о том, что память (либо устройство ввода-вывода) завершила выполнение запрашиваемой операции. Доступ к памяти всегда будет иметь по крайней мере установленные циклы задержки в регистрах MCFG1 и MCFG2, но если исполнение операции задерживается и память снимает в '0' сигнал BRDYN, то цикл доступа будет растянут до момента установки BRDYN в '1'. Ниже представлены временные диаграммы работы:



Рис. 25: Диаграмма чтения PROM, I/O с одним дополнительным циклом data2(цикл lead-out только для I/O)



Рис. 26: Диаграмма чтения PROM, I/O с одним предустановленным циклом задержки и одним циклом задержки сформированным BRDYN

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 87 - 172



### 8.2.7 Ошибки доступа

Ошибка доступа может быть просигнализирована выставлением сигнала BEXCN, который устанавливается вместе с данными. Если использование сигнала BEXCN установкой MCFG1(BEXCN) в '1', то ошибки в ответ будут формироваться на шине AMBA. BEXCN активируется для всех областей внешней памяти(PROM, I/O, RAM). Ниже представлены временные диаграммы работы:



Рис. 27: Диаграмма чтения PROM, I/O, RAM с BEXCN



Рис. 28: Диаграмма записи PROM, I/O, RAM с BEXCN (IOSN цикл не устанавливается в lead-in цикле для I/O памяти)

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 88 - 172

Внешние соединения и компоненты



## 8.2.8 Подключение PROM, SRAM, SDRAM памяти различной разрядности

Ниже представлены схемы подключения внешней памяти:

8 бит D[31:24] MCTRL0 **PROM PROM** em\_romsn[1:0] A[27:0]  $em\_iosn$ em\_oen 8 бит em\_writen SRAM D[31:24] em\_ramoen[3:0] em\_wrn[0] em\_wrn[1:0] SRAM A[27:0] em\_mben[3:0] Конфигурация em\_ramsn[3:0] и управление  ${\tt em\_read}$ em bexcn ◀ Передача данных em\_brdyn ◀ SDRAM em\_data[31:0] em\_addr[29:0]

Рис. 29: Схема подключения PROM, SRAM в 8-ми битном формате



#### Внешние соединения и компоненты



Рис. 30: Схема подключения PROM, SRAM в 16-ти битном формате



#### Внешние соединения и компоненты



Рис. 31: Схема подключения SDRAM



### 8.2.9 Описание регистров

Базовый адрес MCFG - 0xC00E E000

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

| Регистр | Смещение адреса | Доступ | Описание                                       |
|---------|-----------------|--------|------------------------------------------------|
| MCFG1   | $00\mathrm{h}$  | RW     | Регистр конфигурации памяти PROM, IO памяти    |
| MCFG2   | 04h             | RW     | Регистр конфигурации памяти SRAM, SDRAM памяти |
| MCFG3   | 08h             | RW     | Период обновления памяти SDRAM                 |
| MCFG4   | 0ch             | RW     | Регистр управления питанием внешней памяти     |

| MCFG1               | Pe | гист | р ко | нфи | гур    | ациі | и па  | мяті | τРΕ | ROM         | , IO          | пам | ити  | [  |    |    |    |    |    |    |      |    |            |           |   |               |     |      |              |
|---------------------|----|------|------|-----|--------|------|-------|------|-----|-------------|---------------|-----|------|----|----|----|----|----|----|----|------|----|------------|-----------|---|---------------|-----|------|--------------|
| Номер бита          | 31 | 30   | 29   | 28  | 27     | 26   | 25    | 24   | 23  | 22          | 21            | 20  | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11   | 10 | 9          | 8         | 7 | 6             | 5 4 | 3 2  | 2 1 0        |
| Начальное состояние |    | _    |      |     | -      | 0    | 0     | -    |     | 11          | 11            |     | -    |    |    |    | _  |    |    |    | -    | -  | -          | _         |   | 1111          | 1   | 1111 |              |
| Описание            |    |      |      |     | IOBUSW | BRDY | BEXCN | _    |     | EATHORITY C | IO WALISTALES |     | IOEN |    |    |    |    |    |    |    | PWEN |    | THOUSE FAC | ROM WIDIN |   | PROM WRITE WS |     |      | PROM READ WS |

| 29-31   | =             | зарезервировано.                                                                                              |
|---------|---------------|---------------------------------------------------------------------------------------------------------------|
| 27 - 28 | IOBUSW        | Установка разрядности IO памяти ('00' - 8, '01' - 16, '10' - 32).                                             |
| 26      | IBRDY         | Разрешение сигнализации готовности шины для IO памяти(BRDYN) ('0'- запрещено, '1'- разрешено).                |
| 25      | BEXCN         | Разрешение сигнализации ошибок на шине ('0'- запрещено, '1'- разрешено).                                      |
| 24      | =             | зарезервировано.                                                                                              |
| 20-23   | IO WAITSTATES | Установка количества задержек для работы с памятью IO ('0000' - 0, '0001' - 1, '0010' - 2 '1111' - 15).       |
| 19      | IOEN          | Разрешение доступа к шине памяти Ю ('0'- запрещено, '1'- разрешено).                                          |
| 12-18   | _             | зарезервировано.                                                                                              |
| 11      | PWEN          | Разрешение записи в память PROM ('0'- запрещено, '1'- разрешено).                                             |
| 10      | =             | зарезервировано.                                                                                              |
| 8-9     | PROM WIDTH    | Установка разрядности памяти PROM ('00' - 8, '01' - 16, '10' - 32). Начальное значение при                    |
|         |               | подаче питания устанавливается в зависимости от состояния вывода процессора $PROM\WID$ ('0' - 8, '1' - 16).   |
| 4-7     | PROM WRITE WS | Установка количества задержек для циклов записи памяти PROM ('0000' - 0, '0001' - 1, '0010' - 2 '1111' - 15). |
| 0-3     | PROM READ WS  | Установка количества задержек для циклов чтения памяти PROM ('0000' - 0, '0001' - 1, '0010' - 2 '1111' - 15). |

| MCFG2               | Pe   | гист | р ко | нфи        | гура | ации | паг | итки         | SR | AM      | , SD        | RA            | Мπ | амя | ги |    |    |    |    |    |               |    |   |   |       |     |           |              |             |
|---------------------|------|------|------|------------|------|------|-----|--------------|----|---------|-------------|---------------|----|-----|----|----|----|----|----|----|---------------|----|---|---|-------|-----|-----------|--------------|-------------|
| Номер бита          | 31   | 30   | 29   | 28         | 27   | 26   | 25  | 24           | 23 | 22      | 21          | 20            | 19 | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11            | 10 | 9 | 8 | 7     | 6   | 5 4       | 3 2          | 1 0         |
| Начальное состояние | -    | -    |      | _          |      | -    |     | _            |    | -       | -           | -             | -  | 0   | -  | -  | -  | -  | -  |    | _             | -  |   | - | -     | -   | _         | _            | _           |
| Описание            | SDRF | TRP  |      | SDRAM TRFC |      | TCAS |     | SDRAM BANKSZ |    | 100 111 | SDRAM COESZ | CIND AND COME | 2  | D64 | ı  | MS | -  | SE | IS |    | RAM BANK SIZE |    |   | - | RBRDY | RMW | RAM WIDTH | RAM WRITE WS | RAM READ WS |

31 SDRF Разрешение обновления SDRAM ('0'- запрещено, '1'- разрешено) .

27-29 SDRAM TRFC — Установка задержки Trfc, которая равна (3+значение данного поля) тактов.



| 26    | TCAS          | Установка циклов задержки CAS ('0'- 2 цикла, '1'- 1 цикл). После выбора команды LOAD COMMAND REGISTER будет выполнено в то же время. Также устанавливается RAS/CAS задержка (Trcd). |
|-------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23-25 | SDRAM_BANKSZ  | Установка размера банка SDRAM памяти ('000' - 4 Мегабайт, '001' - 8 Мбайт, '010' - 16 Мбайт '111' - 512 Мбайт).                                                                     |
| 21-22 | SDRAM_COLSZ   | Установка размера столбца SDRAM памяти ('00' - 256 байт, '01' - 512, '10' - 1024, '11' - 4096(если MCFG2(23-25)='111') иначе 2048).                                                 |
| 19-20 | SDRAM CMD     | Установка команды SDRAM ('01' - PRECHARGE, '10' - AUTO REFRESH, '11' - LOAD COMMAND REGISTER). Бит сбрасывается в '0' после выполнения команды.                                     |
| 18    | D64           | Конфигурация контроллера памяти SDRAM ('0'- 32 бита, '1'- 64 бита).                                                                                                                 |
| 17    | _             | зарезервировано.                                                                                                                                                                    |
| 16    | MS            | Поддержка режима Mobile SDR ('0'- запрещено, '1'- разрешено). Бит доступен только для                                                                                               |
| 15    |               | чтения.                                                                                                                                                                             |
|       |               | зарезервировано.                                                                                                                                                                    |
| 14    | SE            | Разерешение работы SDRAM контроллера ('0'- запрещено, '1'- разрешено).                                                                                                              |
| 13    | SI            | Запрещение работы SRAM если $\mathrm{MCFG2}(14)=1.$                                                                                                                                 |
| 9-12  | RAM BANK SIZE | Установка размера для каждого RAM банка('0000' - 8 Килобайт, '0001' - 16 Килобайт,<br>'1111' - 256 Мегабайт).                                                                       |
| 8     | _             | зарезервировано.                                                                                                                                                                    |
| 7     | RBRDY         | Разрешение сигнализации готовности шины для RAM памяти.                                                                                                                             |
| 6     | RMW           | Разрешение циклов чтение-модификация-запись для записи полуслов по 16 бит в 32-х битную область с поддержкой строба записи (без строба записи байта).                               |
| 4-5   | RAM WIDTH     | Установка разрядности памяти RAM ('00' - 8, '01' - 16, '10' - 32).                                                                                                                  |
| 2-3   | RAM WRITE WS  | Установка количества задержек для циклов записи памяти RAM ('00' - 0, '01' - 1, '10' - 2, '11' - 3).                                                                                |
| 0-1   | RAM READ WS   | Установка количества задержек для циклов чтения памяти RAM ('00' - 0, '01' - 1, '10' - 2, '11' - 3).                                                                                |

| MCFG3               | Пе | риод | ц обі | новл | ени | я па | мят | иSI | RA  | М   |    |     |      |      |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |
|---------------------|----|------|-------|------|-----|------|-----|-----|-----|-----|----|-----|------|------|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|
| Номер бита          | 31 | 30   | 29    | 28   | 27  | 26   | 25  | 24  | 23  | 22  | 21 | 20  | 19   | 18   | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | . 0 |
| Начальное состояние |    |      | _     |      |     |      |     |     |     |     |    |     | _    |      |    |     |    |    |    |    |    |    |   |   |   | _ |   |   |   |     |     |
| Описание            |    |      | _     |      |     |      |     |     | SDI | RAM | RE | FRE | SH F | RELC | AD | VAL | UE |    |    |    |    |    |   |   |   | _ |   |   |   |     |     |

 27-31
 —
 зарезервировано.

 12-26
 SDRRV
 Период обновления SDRAM.

 0-11
 —
 зарезервировано.

Период между командами AUTO-REFRESH формируется по следующей формуле:

# Trefresh = (SDRRV + 1)/Tsysclk

| MCFG4       |                  | Регистр управлени | я питанием внешней памяти                                                          |                             |  |  |  |  |  |  |  |  |  |  |
|-------------|------------------|-------------------|------------------------------------------------------------------------------------|-----------------------------|--|--|--|--|--|--|--|--|--|--|
| Номер бита  |                  | 31 30 29 28 27    | 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12                                       | 11 10 9 8 7 6 5 4 3 2 1 0   |  |  |  |  |  |  |  |  |  |  |
| Начальное о | остояние         | -                 | _                                                                                  | _                           |  |  |  |  |  |  |  |  |  |  |
| Описание    |                  | _                 | SDRAM REFRESH RELOAD VALUE                                                         | _                           |  |  |  |  |  |  |  |  |  |  |
| 31          | ME               | Установка ф       | рункционального режима SDRAM ('0'- Standard SE                                     | DRAM, '1'- Mobile SDRAM).   |  |  |  |  |  |  |  |  |  |  |
| 30          | $^{\mathrm{CE}}$ | Разрешение        | азрешение тактирования SDRAM ('0'- запрещено, '1'- разрешено). Данный бит доступен |                             |  |  |  |  |  |  |  |  |  |  |
|             |                  | только для        | олько для чтения в случае, если MCFG4(PMODE) не равен '00'.                        |                             |  |  |  |  |  |  |  |  |  |  |
| 29          | EMR              | Если данны        | ий бит равен '1', то команда LOAD-COMMAND                                          | -REGISTER, выполняемая      |  |  |  |  |  |  |  |  |  |  |
|             |                  | в регистре        | MCFG2(SDRAM CMD) будет интерпретирован                                             | а как LOAD EXTENDED         |  |  |  |  |  |  |  |  |  |  |
|             |                  | COMMANE           | REGISTER.                                                                          |                             |  |  |  |  |  |  |  |  |  |  |
| 24-28       | _                | зарезервиро       | вано.                                                                              |                             |  |  |  |  |  |  |  |  |  |  |
| 20-23       | TXSR             | Установка з       | адержки Txsr, которая будет соответствовать значе                                  | ению данного поля в систем- |  |  |  |  |  |  |  |  |  |  |
|             |                  | ных тактах.       |                                                                                    |                             |  |  |  |  |  |  |  |  |  |  |
| 19          | _                | зарезервиро       | вано.                                                                              |                             |  |  |  |  |  |  |  |  |  |  |
| 16-18       | PMOL             | )E Установка р    | ежима управления питанием:                                                         |                             |  |  |  |  |  |  |  |  |  |  |



```
'00' - нет
                '01' - снижение энергопотребления (данные сохраняются, но нет доступа к памяти)
                '10' - самообновление
                '11' - выключение энергопотребления (данные не сохраняются)
7-15
                зарезервировано.
5-6
       DS
                Установка нагрузочной способности выходных каскадов:
                '00' - полная
                '01' - наполовину
               '10' - одна четверть
                '11' - три четверти
       TCSR
3-4
               Резерв для температурной компенсации самообновления:
                '00' - 70^{\circ}C
                '01' - 45°C
                '10' - 15°C
                '11' - 85°C
0-2
       PASR
               Установка частичного самообновления SDRAM:
                '000' - полное (банки 0,1,2,3)
                '001' - наполовину (банки 0,1)
                '010' - на четверть (банк 0)
                '101' - на одну восьмую (половина банка 0 с {
m MSB}=0)
                '110' - на одну шестнадцатую (четверть банка 0 с {\rm MSB}=00)
```



# 8.3 Интерфейс UART(UARTx)

## 8.3.1 Краткие характеристики

- полнодуплексный режим;
- отдельные буферы FIFO глубиной 32 байта для приема и передачи;
- слово данных 8 бит, фиксированное;
- настраиваемый контроль четности;
- 1 стоп-бит;
- аппаратный контроль потока данных (CTS, RTS);



Рис. 32: Блок-схема UARTx

На рис.32 приведена блок-схема контроллера последовательного интерфейса UART.

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

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

Для включения передатчика и разрешения его работы предназначен бит UARTxCR(TE). Данные для передачи записываются в буфер FIFO передачи. Пользователю доступен

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 95 - 172



только вход FIFO. Обращение к нему происходит через UARTxDATA. Ширина буфера - 8 бит, глубина - 32 байта.

Из буфера FIFO данные поступают в сдвиговый регистр, из которого они побитно (LSB) появляются на выходе ТХ. Старт-бит, стоп-бит и бит контроля четности (если разрешен) формируются автоматически. На рис.33 показаны возможные варианты формата передаваемых данных, для данного контроллера.



Рис. 33: Формат пакета данных

После завершения передачи последнего слова данных из буфера FIFO, после формирования стоп-бита, выход ТХ устанавливается в состояние логической '1', устанавливается признак пустого сдвигового регистра UARTxST(TS). После этого бит автоматически установится в состояние логического '0' как только данные появляются в буфере FIFO. Если буфер FIFO пуст, то выставляется бит UARTxST(TE). О заполнении буфера сигнализируют биты UARTxST(TF) - буфер полон и UARTxST(TH) - меньше половины буфера заполнено. Для контроля заполнения буфера FIFO существует счетчик - UARTxST(TCNT).

Существует несколько механизмов формирования запросов прерывания по событиям буфера: если установлен бит UARTxCR(TF), то прерывания вырабатываются если буфер FIFO передатчика заполнен менее чем наполовину; если установлен бит UARTxCR(TI), то будет выработано единичное прерывание в момент, когда буфер FIFO передатчика опустеет.

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

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 96-172



Если разрешен аппаратный контроль потока данных, то данные из сдвигового регистра будут передаваться только если СТS в состоянии логического '0'. Если в процессе передачи сигнал выставить в состояние логической '1', то передача прекратиться, возобновиться только, когда СТS вернуть в состояние логического '0'.

### 8.3.3 Прием данных

Для включения приемника и разрешения его работы предназначен бит UARTxCR(RE). Принятые данные записываются в буфер FIFO приема. Пользователю в обычном режиме доступен только выход буфера FIFO. Обращение к нему происходит через UARTxDATA. Ширина буфера - 8 бит, глубина - 32 байта. Принимаемый сигнал проходит цифровой фильтр нижних частот.

Приемник следит за состоянием сигнала на входе и в случае перехода сигнала из состояния логической '1' в состояние '0' начинается прием данных. Через  $\frac{T_{UART}}{2}$  фиксируется состояние входного сигнала, где  $T_{UART}$  - период одного бита слова данных. Если не будет зафиксирован стартовый бит, то приемник перейдет обратно в режим ожидания. Если стартовый бит принят, то произойдет прием оставшихся бит слова данных и служебных бит. После приема последнего бита, данные помещаются в буфер FIFO, устанавливается бит UARTxST(DR). В регистре UARTxST устанавливаются биты ошибок приема, если таковые зафиксированы. Биты ошибок очищаются только программно.

В случае, если в сдвиговом регистре находятся принятые данные и буфер FIFO полон, а на входе приемника зафиксирован старт бит, то данные в сдвиговом регистре будут потеряны. При этом будет установлен бит UARTxST(OV).

О заполнении буфера сигнализируют биты UARTxST(RF) - буфер полон и UARTxST(RH) - половина или больше половины буфера заполнено. Для контроля заполнения буфера FIFO существует счетчик - UARTxST(RCNT).

Существует несколько механизмов формирования запросов прерывания для режима приема данных: если установлен бит UARTxCR(RF), то прерывания вырабатываются если буфер FIFO приемника заполнен наполовину или более чем наполовину; если установлен бит UARTxCR(RI), то будет вырабатываться единичное прерывание в моменты, когда принят очередной байт данных.

Если разрешен аппаратный контроль потока данных и буфер FIFO полон, то RTS перейдет в состояние логической '1'. Как только из буфера будет считано хотя бы одно слово данных, RTS автоматически перейдет в состояние логического '0'.



### 8.3.4 Установка скорости передачи

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

$$BRDIV = \frac{F_{sys}}{8 \cdot F_{UART} - 1};$$

#### 8.3.5 Режимы самотестирования

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

### 8.3.5.1 Режим самотестирования на уровне интерфейсных линий

В данном режиме внутри микросхемы выход передатчика UART коммутируется со входом приемника, а сигнал CTS коммутируется с RTS. Включение этого режима происходит путем установки бита UARTxCR(LB).

### 8.3.5.2 Режим самотестирования на уровне данных

В данном режиме разрешается запись в буфер FIFO приема и чтение из буфера FIFO передачи. Чтение и запись осуществляются через регистр UARTxFIFODBG. Включение этого режима происходит путем установки бита UARTxCR(LB).

#### 8.3.6 Формирование прерываний

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

От сдвигового регистра передатчика:

- работа передатчика разрешена: установлен бит UARTxCR(TE);
- прерывания от передатчика разрешены: установлен бит UARTxCR(TI).

От буфера FIFO передачи:

- работа передатчика разрешена: установлен бит UARTxCR(TE);
- прерывания от буфера разрешены: установлен бит UARTxCR(TF);



От сдвигового регистра приемника:

- работа приемника разрешена: установлен бит UARTxCR(RE);
- прерывания от передатчика разрешены: установлен бит UARTxCR(RI).

От буфера FIFO приема:

- работа приемника разрешена: установлен бит UARTxCR(RE);
- прерывания от буфера разрешены: установлен бит UARTxCR(RF);

## 8.3.6.1 Режим отложенных прерываний приемника

Режим включается установкой бита UARTxCR(DI). Прерывание от приемника формируется только в случае образование паузы после приема последнего слова данных. Пауза равна времени приема 4,5 слов данных. Если разрешено прерывание от буфера FIFO приема, то прерывание от сдвигового регистра будут очищаться. Активными будут только прерывания от буфера.

Примечание: разрешение данного режима не влияет на формирование запроса прерывания при получении символа прекращения транзакции.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 99 - 172



### 8.3.7 Описание регистров

Базовый адрес UART0 - 0xC000 0100 Базовый адрес UART1 - 0xC000 0200 Базовый адрес UART2 - 0xC010 0100 Базовый адрес UART3 - 0xC010 0200

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

| Регистр   | Смещение адреса | Доступ | Описание                                       |
|-----------|-----------------|--------|------------------------------------------------|
| UARTxDATA | $00\mathrm{h}$  | RW     | Регистр данных (FIFO)                          |
| UARTxST   | 04h             | R      | Регистр состояния                              |
| UARTxCR   | 08h             | RW     | Регистр управления                             |
| UARTxDBR  | 0ch             | RW     | Регистр коэффициента делителя тактовой частоты |

| UARTxDATA           | Per | гист | рда | нны | x  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |    |    |   |     |
|---------------------|-----|------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|----|----|---|-----|
| Номер бита          | 31  | 30   | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 0 |
| Начальное состояние |     |      |     |     |    |    |    |    |    |    |    |    |    |    | _  |    |    |    |    |    |    |    |   |   |   |   |   |    |    |   |     |
| Описание            |     |      |     |     |    |    |    |    |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | DA | ТА |   |     |

8-31 — *зарезервировано* 0-7 DATA Регистр данных. При записи является входом 32 байтового буфера FIFO передатчика. При чтении является входом 32 байтового буфера FIFO приемника.

| UARTxST             | Per | гист | р со | стоя | ния |    |    |    |    |    |    |    |    |    |    |               |      |      |    |    |    |    |            |    |   |   |    |    |    |    |            |                   |
|---------------------|-----|------|------|------|-----|----|----|----|----|----|----|----|----|----|----|---------------|------|------|----|----|----|----|------------|----|---|---|----|----|----|----|------------|-------------------|
| Номер бита          | 31  | 30   | 29   | 28   | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15   | 14   | 13 | 12 | 11 | 10 | 9          | 8  | 7 | 6 | 5  | 4  | 3  | 2  | 1          | 0                 |
| Начальное состояние |     |      | -    | _    |     |    |    |    | _  | -  |    |    |    |    |    |               | _    |      |    |    |    | _  | _          | _  | - | - | -  | -  | -  | _  | _          | $\left[ -\right]$ |
| Описание            |     |      | RC   | NT   |     |    |    |    | ТС | NΤ |    |    |    |    | 30 | <i>през</i> е | рвир | 06a1 | 10 |    |    | RF | $_{ m LE}$ | RH | Ħ | Æ | PE | OV | BR | TE | $_{ m TS}$ | DR                |

| 26-31 | RCNT             | Счетчик данных FIFO приемника                                      |
|-------|------------------|--------------------------------------------------------------------|
| 20-25 | TCNT             | Счетчик данных FIFO передатчика                                    |
| 11-19 | _                | зарезервировано                                                    |
| 10    | RF               | FIFO приемника заполнен                                            |
| 9     | $\mathrm{TF}$    | FIFO передатчика заполнен                                          |
| 8     | RH               | FIFO приемника заполнен наполовину или более чем наполовину        |
| 7     | $\mathrm{TH}$    | FIFO передатчика заполнен менее чем наполовину                     |
| 6     | FE               | Ошибка формата принятых данных                                     |
| 5     | PE               | Ошибка контроля четности принятых данных                           |
| 4     | ov               | Один или более символов принятых данных потерян из-за переполнения |
| 3     | $_{\mathrm{BR}}$ | Специальный символ завершения обмена получен (BREAK)               |
| 2     | TE               | FIFO передатчика пуст                                              |
| 1     | TS               | Сдвиговый регистр передатчика пуст                                 |
| 0     | DR               | Новые символы зафиксированы в регистре приемника                   |



| UARTxCR        |                  | Pe | истр             | управ | лен  | ия Т | J <b>AR</b> ′ | Г    |      |       |     |       |       |     |      |     |       |       |       |       |       |       |       |                 |                  |      |      |      |     |   |    |    |   |
|----------------|------------------|----|------------------|-------|------|------|---------------|------|------|-------|-----|-------|-------|-----|------|-----|-------|-------|-------|-------|-------|-------|-------|-----------------|------------------|------|------|------|-----|---|----|----|---|
| Номер бита     |                  | 31 | 30 2             | 9 28  | 27   | 26   | 25            | 24   | 23   | 22    | 2   | 1 2   | 0 1   | 9   | 18   | 17  | 16    | 15    | 14    | 13    | 12    | 11    | 10    | 9               | 8                | 7    | 6    | 5    | 4   | 3 | 2  | 1  | Г |
| Начальное сост | ояние            |    |                  |       |      |      |               |      | _    | -     |     |       |       |     |      |     |       |       | _     | _     | _     | _     | _     | _               | _                | _    | _    | _    | _   | _ |    | _  | Ŀ |
| Описание       |                  | FA |                  |       |      |      |               | зар  | зерв | upo   | ван | 10    |       |     |      |     |       |       | R     | ā     | BI    |       | RF    | TF              |                  | IB   | F    | PE   | PS  | F | RI | TE | į |
| 31             | FA               | ]  | Разре            | шени  | ие и | спо  | льзо          | ван  | ия ] | FIF   | O   | прі   | иемі  | нин | ка и | пє  | еред  | цатч  | ика   | ı ('0 | '- 38 | апре  | еще   | но,             | , <sub>1</sub> , | ра   | зрє  | еше  | но) |   |    |    |   |
| 15-30          | _                |    | зарез            | ервиј | ров  | ано  |               |      |      |       |     |       |       |     |      |     |       |       |       |       |       |       |       |                 |                  |      |      |      |     |   |    |    |   |
| 14             | SI               |    | Разре<br>решен   |       | ие п | рер  | ыва           | кин  | по   | пус   | стс | му    | рег   | ис: | тру  | сді | виг   | а пе  | ред   | атч   | ика   | ('0   | '– 38 | апр             | ещ               | ено  | , '1 | '– p | аз- |   |    |    |   |
| 13             | DI               |    | Задер<br>греще   | жані  |      |      |               |      |      | эи∈   | ЭМ  | ник   | a (4  | CI  | имв  | ола | a +   | 4 6   | бита  | И     | ет    | нов   | ого   | си              | мво              | ола) | (')  | 0'–  | за- |   |    |    |   |
| 12             | ВІ               |    | Разре            |       |      | -    | -             |      |      | пр    | ие  | му    | сим   | во. | ла I | 3R  | EΑ    | К (   | 0'-   | зап   | рец   | цено  | o, '1 | ,_ <sub>1</sub> | раз              | реп  | іен  | o)   |     |   |    |    |   |
| 11             | _                |    | варез            | ервир | ров  | ано  |               |      |      |       |     |       |       |     |      |     |       |       |       |       |       |       |       |                 |                  |      |      |      |     |   |    |    |   |
| 10             | RF               | ]  | Разре            | шени  | ие г | рер  | ыва           | ния  | по   | FΠ    | FC  | ) пр  | ием   | ни  | ика  | ('0 | ,- s  | апр   | еще   | ено,  | '1'-  | - pa  | зре   | ше              | но)              |      |      |      |     |   |    |    |   |
| 9              | TF               | ]  | Разре            | шени  | ие г | рер  | ыва           | ния  | по   | FΠ    | FC  | ) пе  | ред   | ат  | чик  | a ( | 'o'-  | заі   | трег  | цен   | o, ': | 1'- ] | разј  | реш             | ене              | o)   |      |      |     |   |    |    |   |
| 8              | _                | ě  | варез            | ервир | ров  | ано  |               |      |      |       |     |       |       |     |      |     |       |       |       |       |       |       |       |                 |                  |      |      |      |     |   |    |    |   |
| 7              | LB               |    | Зклю<br>чена)    | чени  | ев   | нут  | ренн          | ей ( | обра | тн    | ой  | пе    | гли   | ДЛ  | зя с | ам  | оте   | СТИ]  | рова  | ния   | ı ('( | )'- ( | от к. | тюг             | чен              | a, ' | 1'–  | вкј  | тю- |   |    |    |   |
| 6              | FL               | ]  | Разре            | шени  | ле у | пра  | авле          | ния  | пот  | око   | ом  | да    | нны   | х ( | (CT  | S/  | RТ    | S) (  | ·0 ·– | зап   | per   | цен,  | , '1' | – p             | азр              | еш   | ен)  |      |     |   |    |    |   |
| 5              | ΡЕ               | ]  | Разре            | шени  | ие в | онт  | рол           | я че | тно  | сти   | а ( | ,0,-  | заг   | ιрε | еще  | Ι,  | 1'-   | pas   | врец  | тен)  |       |       |       |                 |                  |      |      |      |     |   |    |    |   |
| 4              | $_{\mathrm{PS}}$ | J  | Зыбо             | ртиг  | та ғ | сонт | рол           | я че | тно  | СТИ   | и ( | 'o '– | на    | че  | тно  | СТІ | , , . | l'- 1 | а н   | ече   | гно   | сть)  | )     |                 |                  |      |      |      |     |   |    |    |   |
| 3              | ΤI               |    | Разре<br>''0'- з |       |      |      |               |      |      |       |     | гчиг  | ка в  | M   | оме  | нт, | KO    | гда   | бус   | þер   | пеј   | реда  | атчі  | ика             | FI               | FO   | ОΠ   | уст  | еет |   |    |    |   |
| 2              | RI               | ]  | Разре            | шени  | ие п | рер  | ыва           | ния  | прі  | ем    | н   | ика   | по і  | рі  | пни  | гин | о сі  | имв   | ола   | ('0'  | - за  | пре   | ещен  | ю,              | '1'-             | рa   | зре  | еше  | но) |   |    |    |   |
| 1              | TE               | ]  | Разре            | шени  | ие р | оабс | ты            | тере | дат  | чи    | ка  | ('0   | '– за | апр | рещ  | ена | a, '  | 1'- 1 | разр  | еш    | ена   | )     |       |                 |                  |      |      |      |     |   |    |    |   |
| 0              | RE               | ]  | Разре            | шени  | ие р | оабс | ты            | при  | емн  | ика   | a ( | ·0 '- | зап   | pe  | еще  | ıa, | '1'-  | - pa  | зре   | шен   | a)    |       |       |                 |                  |      |      |      |     |   |    |    |   |
| II A DTL-DDD   |                  | D  |                  |       | d    | ***  | no ===        |      |      | 0.77- |     | # -   |       |     |      |     |       |       |       |       |       |       |       |                 |                  |      |      |      |     |   |    | 7  |   |

| UARTxBDR            | Per | гист | р ко | эфф | оици | ента | дел | ите | лят  | акт  | овой  | і час | тоті | ы  |    |    |    |    |    |    |    |    |   |   |   |    |    |   |   |   |     |
|---------------------|-----|------|------|-----|------|------|-----|-----|------|------|-------|-------|------|----|----|----|----|----|----|----|----|----|---|---|---|----|----|---|---|---|-----|
| Номер бита          | 31  | 30   | 29   | 28  | 27   | 26   | 25  | 24  | 23   | 22   | 21    | 20    | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5  | 4 | 3 | 2 | 1 0 |
| Начальное состояние |     |      |      |     |      |      |     |     |      | _    | -     |       |      |    |    |    |    |    |    |    |    |    |   |   |   | _  |    |   |   |   |     |
| Описание            |     |      |      |     |      |      |     |     | заре | зерв | вирое | зан о |      |    |    |    |    |    |    |    |    |    |   |   | В | RD | IV |   |   |   |     |

12-31 — зарезервировано 0-11 ВRDIV Коэффициент деления системной частоты для формирования требуемой скорости обмена данными BRDIV = Fsys/BR\*8, где Fsys в  $\Gamma$ ц, а BR в бит/с



# 8.4 Интерфейс SPI(SPIx)

## 8.4.1 Краткие характеристики

- может работать в режимах «ведущий» или «ведомый»;
- поддерживаются все режимы SPI, а также трехпроводной режим, в котором используется одна двунаправленная линия данных;
- настраиваемая длина слова данных;
- отдельные буферы FIFO глубиной 32 слова для приема и передачи;
- устанавливаемый пользователем формат слова данных LSB или MSB;
- устанавливаемые пользователем полярность CPOL и фаза CPHA тактового сигнала;
- устанавливаемая пользователем скорость обмена данными.



Рис. 34: Блок-схема SPIx

Интерфейс SPI является полно-дуплексным. Передача начинается как только «ведущий» перевел сигнал SLVSEL у соответствующего «ведомого» в активное состояние, так же SCK выведена из неактивного состояния.

Данные передаются «ведущим» по линии MOSI, принимаются по MISO.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 102-172



В системе с одним «ведущим» и одним «ведомым» можно не управлять сигналом SLVSEL, он может всегда находиться в активном состоянии.

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

В процессе приема или передачи, данные меняются при изменении состояния SCK. Значения начального состояния и активного фронта SCK определяют режим работы SPI. На рис.35 приведены диаграммы режимов работы SPI при передаче 0х55 в режиме MSB. Стоит отметить, что данные должны быть готовы в буфере передачи до первой смены состояния SCK.

При работе в режиме «ведомый» передача данных по линии MISO будет задержана так как необходимо синхронизировать передатчик. Смотрите описание в п.8.4.6.



Рис. 35: Режимы работы SPI

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 103-172



## 8.4.2 Трех-проводный режим

Контроллер интерфейса может быть настроен на работу в трехпроводном режиме (смотрите регистр SPIxCR(TWEN)). Работа будет происходить в полудуплексном режиме. В данном режиме используется одна двунаправленная линия приема-передачи данных вместо двух однонаправленных для приема и передачи.

Для обмена данными используется линия MOSI, MISO в данном режиме не задействуется. Направление обмена данными выбирается в регистре SPIxCR(TTO).

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

### 8.4.3 Прием и передача данных

Контроллер интерфейса имеет отдельные регистры и буферы FIFO для приема и передачи. Разрядность буфера FIFO - 32 бита, глубина - 32 слова. Разрядность слова данных определяется в SPIxCR(TWEN). Если в буфере передачи есть свободное место, то устанавливается бит в регистре SPIxST(NF), в буфер можно посылать данные. Если в буфере приема содержится хотя бы одно полностью принятое слово, то устанавливается бит в регистре SPIxST(NE). Если возникла ситуация, что принято 33 и более слов данных, то устанавливается бит SPIxST(OV). При работе в режиме «ведомого» контроллер интерфейса может детектировать ситуацию, когда он был выбран «ведущим» (SPISEL принял значение логический '0'), а в буфере передачи нет данных. В этом случае устанавливается бит в регистре SPIxST(UN).

#### 8.4.4 Тактовый сигнал SCK

Генерировать сигнал SCK контроллер интерфейса может только при работе в режиме «ведущего». Параметры для генератора SCK задаются в регистре SPIxCR.

$$F_{SCK} = \frac{F_{sys}}{(4 - (2 \cdot FACT))(PM + 1)}, \quad DIV16 = 0;$$
 
$$F_{SCK} = \frac{F_{sys}}{16(4 - (2 \cdot FACT))(PM + 1)}, \quad DIV16 = 1;$$

### 8.4.5 Работа в режиме «ведущий»

В данном режиме как только данные появляются в буфере FIFO передачи, они сразу передаются. Если данные переданы и буфер передачи пуст, то SCK не подается.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 104-172



Если во время работы в данном режиме сигнал SPISEL примет значение логический '0', контроллер интерфейса прекратит передачу данных и установит бит в регистре SPIxST(MME). Бит разрешения работы в режиме «ведущий» в регистре SPIxCR(MS) сбрасывается.

Поведение контроллера интерфейса при изменении сигнала SPISEL определяется в регистре SPIxCR(IGSEL).

### 8.4.6 Работа в режиме «ведомый»

В данном режиме контроллер интерфейса не управляет линями интерфейса пока сигнал SPISEL от «ведущий» не примет значение логический '0'. Как только это произошло, MISO конфигурируется как выход и этот выход принимает состояние соответствующее первому биту данных буфера FIFO передачи. Если контроллер интерфейса работает в трех-проводном режиме, то ожидается окончание приема слова по линии MOSI и после этого MOSI конфигурируется как выход. Если буфер передачи пуст, то линия передачи принимает состояние логической '1'.

Частота SCK в данном режиме должна удовлетворять следующему условию:

$$F_{SCK} \leq \frac{F_{sys}}{8};$$

Передатчик контроллера интерфейса синхронизируется от внешнего SCK, поэтому новые данные на линии MISO появятся только через 2 периода  $F_{sys}$  после фронта SCK.

Так же контроллер интерфейса может применять внутренний фильтр для SCK, это управляется регистром SPIxCR(PM). SPIxCR(PM) определяет какое время, выраженное в периодах  $F_{sys}$  сигнал SCK должен быть стабилен. При каждом увеличении PM на 1 задержка выдачи очередных данных на линию MISO увеличивается на 2 периода  $F_{sys}$ . Так же необходимо увеличивать период SCK на это же значение, рассчитанной из условий, упомянутых выше.

Если буфер передатчика пуст, а сигнал SPISEL в активном уровне и «ведущий» подает сигнал тактирования, то на выходе передатчика будет постоянно выдаваться '1'.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 105-172



#### 8.4.7 Описание регистров

Базовый адрес SPI0 - 0xC010 2000 Базовый адрес SPI1 - 0xC010 2100.

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра. Биты в статусных регистрах очищаются записью в них '1' если очистка бита возможна.

| Регистр | Смещение адреса | Доступ | Описание                           |
|---------|-----------------|--------|------------------------------------|
| SPIxCFG | 00h             | RW     | Регистр установок конфигурации     |
| SPIxCR  | 20h             | RW     | Регистр управления                 |
| SPIxST  | 24h             | RW     | Регистр состояния                  |
| SPIxMSK | 28h             | RW     | Регистр маски                      |
| SPIxCMD | 2Ch             | RW     | Регистр команд                     |
| SPIxTX  | 30h             | W      | Регистр передаваемых данных        |
| SPIxRX  | 34h             | R      | Регистр принимаемых данных         |
| SPIxSS  | 38h             | RW     | Регистр выбора ведомого устройства |

| SPIxCFG             | Регистр конфигурации                                                                                                                    |  |  |  |  |  |  |  |    |     |     |   |     |   |       |      |  |   |     |    |  |  |  |   |   |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|----|-----|-----|---|-----|---|-------|------|--|---|-----|----|--|--|--|---|---|--|--|
| Номер бита          | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3 |  |  |  |  |  |  |  |    |     |     |   |     | 3 | 2   1 | 1 0  |  |   |     |    |  |  |  |   |   |  |  |
| Начальное состояние | 0x3                                                                                                                                     |  |  |  |  |  |  |  |    |     | 0   |   | 0   | ( | )     | 0    |  |   | 0x2 | 0  |  |  |  | 0 |   |  |  |
|                     |                                                                                                                                         |  |  |  |  |  |  |  |    |     |     |   | WEN |   |       | SSEN |  |   |     |    |  |  |  |   |   |  |  |
| Описание            | SSSZ                                                                                                                                    |  |  |  |  |  |  |  | N. | IAX | WLE | N | H   |   | -     | Š    |  | F | DEP | ТН |  |  |  | _ | - |  |  |

24 - 31SSSZчисло линий выборок ведомого устройства 20-23 MAXWLEN максимальная поддерживаемая длина слова данных (0-32) разрешение трёхпроводного режима ('1' - разрешено, '0' - запрещено) 19 TWEN 17-18 зарезервировано 16 SSENразрешение сигналов выбора ведомого устройства ('1' - разрешено, '0' - запрещено) 8-15 FDEPTH глубина FIFO RX, TX 0 - 7зарезервировано

| SPIxCR              | Pe | гист | руп  | рав  | лени  | гя  |    |    |    |                                                      |    |  |  |   |   |  |      |   |      |   |   |    |     |   |  |     |   |   |
|---------------------|----|------|------|------|-------|-----|----|----|----|------------------------------------------------------|----|--|--|---|---|--|------|---|------|---|---|----|-----|---|--|-----|---|---|
| Номер бита          | 31 | 30   | 29   | 28   | 27    | 26  | 25 | 24 | 23 | 3 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 |    |  |  |   |   |  |      |   |      |   | 3 | 2  | 1 0 |   |  |     |   |   |
| Начальное состояние | 0  | 0    | 0    | 0    | 0     | 0   | 0  | 0  |    | (                                                    | )  |  |  | 0 |   |  | 0    | 0 | 0    | 0 |   | 0  |     | 0 |  | 0   |   | 0 |
| Описание            | -  | LOOP | CPOL | CPHA | DIV16 | REV | MS | EN |    | LF                                                   | EΝ |  |  | Р | M |  | TWEN | - | FACT | - | C | cG |     | _ |  | TTO | - | _ |

```
31
                 зарезервировано
30
        LOOP
                 режим самотестирования ('1' - разрешено, '0' - запрещено)
^{29}
        CPOL
                 состояние SCK в режиме ожидания ('1' - логическая 1, '0' - логический 0)
        CPHA
                 настройка фазы синхросигнала ('1' - данные будут прочитаны на втором переходе состоя-
                 ния SCK, '0' - данные будут прочитаны при первом переходе состояния SCK)
        DIV16
                 разрешение делителя на 16 (только в режиме ведущего) ('1' - разрешено, '0' - запрещено)
27
                 направление передачи ('1' - MSB, '0' - LSB)
26
        REV
25
        MS
                 выбор режима ('1' - ведущий, '0' - ведомый)
        EN
                 разрешение работы ('1' - разрешено, '0' - запрещено)
20-23
       LEN
                 длина слова данных 0x0 - длина слова 32 бита 0x1-0x2 - недопустимые значения 0x3-0xf -
                 4-16 бит соответственно
                 режим предделителя (только в режиме ведущего): если DIV16 = 0: F_{sck} =
16 - 19
       PM
                 \frac{F_{sys}}{(4-(2\cdot FACT))\cdot (PM+1)} если DIV16 = 1: F_{sck} = \frac{F_{sys}}{16\cdot (4-(2\cdot FACT))\cdot (PM+1)}
```



| 15   | TWEN                  | трёхпроводной режим ('1' - разрешено, '0' - запрещено)                                 |
|------|-----------------------|----------------------------------------------------------------------------------------|
| 14   | _                     | зарезервировано                                                                        |
| 13   | $\operatorname{FACT}$ | режим предделителя частоты (1 - совместимость с МСР83хх )                              |
| 12   | _                     | зарезервировано                                                                        |
| 7-11 | l CG                  | прекращение подачи сигнала SCK после передачи каждого слова данных на N периодов       |
|      |                       | (только в режиме ведущего)                                                             |
| 4-6  | _                     | зарезервировано                                                                        |
| 3    | TTO                   | порядок передачи при работе по трёхпроводной линии ('1' - ведомый передаёт первый, '0' |
|      |                       | - ведущий передаёт первый)                                                             |
| 0-2  | =                     | зарезервировано                                                                        |
|      |                       |                                                                                        |

| SPIxST              | Pe  | гистр с | остоя                                                                                                                                                                                   | кины   |    |      |      |    |    |    |      |      |      |    |    |    |    |     |    |    |                 |
|---------------------|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----|------|------|----|----|----|------|------|------|----|----|----|----|-----|----|----|-----------------|
| Номер бита          | 31  | 30   29 | 28                                                                                                                                                                                      | 27 2   | 25 | 24 2 | 3 22 | 21 | 20 | 19 | 18 1 | 7 10 | 3 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8  | 7 6 5 4 3 2 1 0 |
| Начальное состояние | 0   |         |                                                                                                                                                                                         |        |    |      |      |    |    |    |      |      |      | 0  |    |    |    |     |    |    |                 |
| Описание            | TIP |         |                                                                                                                                                                                         |        |    |      | _    |    |    |    |      |      |      | 11 | -  | OV | NN | MME | NE | NF | _               |
| 31 TIP              |     | перед   | (ля всех разрядов регистра: ('1' - наличие признака, '0' - отсутствие признака) ередаётся слово данных. Этот бит не сбрасывается пока не будут переданы все данные з буфера передатчика |        |    |      |      |    |    |    |      |      |      |    |    |    |    |     |    |    |                 |
| 15-30 —             |     | зарез   | ерві                                                                                                                                                                                    | грован | 0  |      |      |    |    |    |      |      |      |    |    |    |    |     |    |    |                 |

| 14 | LT  | последнее слово данных передано, буфер передатчика пуст и в SPIxCMD записан бит LST   |
|----|-----|---------------------------------------------------------------------------------------|
|    |     | (бит очищается записью '1')                                                           |
| 13 | _   | зарезервировано                                                                       |
| 12 | ov  | буфер приемника заполнен, новые данные игнорируются (бит очищается записью '1')       |
| 11 | UN  | признак запроса от «ведущего» (только в режиме «ведомого»). Бит равен '1' если сигнал |
|    |     | SPISEL в активном состоянии и подается сигнал тактирования от ведущего                |
| 10 | MME | ошибка при работе в системе с несколькими ведущими (возникает, когда в режиме веду-   |
|    |     | щего появляется сигнал SPISEL)                                                        |
| 9  | NE  | буфер приемника содержит данные                                                       |

| 9   | NE | оуфер приемника содержит данные         |
|-----|----|-----------------------------------------|
| 8   | NF | буфер передатчика имеет свободное место |
| 0-7 | _  | зарезервировано                         |

| SPIxMSK             | Pe   | гист | рма | ски |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |     |      |     |     |   |   |   |   |   |   |   |
|---------------------|------|------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|-----|------|-----|-----|---|---|---|---|---|---|---|
| Номер бита          | 31   | 30   | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12  | 11  | 10   | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| Начальное состояние | 0    |      |     |     |    |    |    | •  |    | 0  | •  |    |    |    |    |    |    | 0   | 0  | 0   | 0   | 0    | 0   | 0   |   |   |   | ( | ) |   |   |
| Описание            | TIPE |      |     |     |    |    |    |    |    | _  |    |    |    |    |    |    |    | LTE | -  | OVE | UNE | MMEE | NEE | NFE |   |   |   | _ | _ |   |   |

| Juncanne | L .  |                                                                                                                                                                                             |
|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31       | TIPE | Для всех разрядов регистра: ('1' - прерывание разрешено , '0' - прерывание запрещено) если установлен этот бит, то генерируется прерывание когда бит SPIxST(TIP) переключается из '0' в '1' |
| 15-30    | _    | зарезервировано                                                                                                                                                                             |
| 14       | LTE  | если установлен этот бит, то генерируется прерывание когда бит $SPIxST(LT)$ переключается из '0' в '1'                                                                                      |
| 13       | _    | зарезервировано                                                                                                                                                                             |
| 12       | OVE  | если установлен этот бит, то генерируется прерывание когда бит SPIxST(OV) переключается из '0' в '1'                                                                                        |
| 11       | UNE  | если установлен этот бит, то генерируется прерывание когда бит $SPIxST(UN)$ переключается из '0' в '1'                                                                                      |
| 10       | MMEE | если установлен этот бит, то генерируется прерывание когда бит $SPIxST(MME)$ переключается из $'0'$ в $'1'$                                                                                 |
| 9        | NEE  | если установлен этот бит, то генерируется прерывание когда бит $SPIxST(NE)$ переключается из '0' в '1'                                                                                      |
| 8        | NFE  | если установлен этот бит, то генерируется прерывание когда бит $SPIxST(NF)$ переключается из '0' в '1'                                                                                      |
| 0-7      | _    | зарезервировано                                                                                                                                                                             |



| SPIxCMD             | Pe | гист | ркс | ман | д  |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |    |      |     |     | 0  |    |    |    |    | 0   |    |    |    |    |    |    |    |    |    | 0  |    |    |   |   |   |   |   |   |   |   |   |   |
| Описание            |    |      |     |     | _  |    |    |    |    | LST |    |    |    |    |    |    |    |    |    | _  |    |    |   |   |   |   |   |   |   |   |   |   |

23-31 — зарезервировано

22 LST После того, как этот бит будет установлен в единицу, будет разрешена установка бита SPIxST(LT) когда слово передано и буфер передатчика пуст. Если разрешена работа в трехпроводном режиме, бит SPIxST(LT) установится в единицу после завершения передачи всех данных. Этот бит автоматически очищается, когда бит SPIxST(LT) устанавливается в единицу и всегда вычитывается как '0'

0-21 — зарезервировано

| SPIxTX              | Pe | гист | рпе | ред | авае | мых | дан | ных | C  |    |    |    |    |    |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|------|-----|-----|-----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |    |      |     |     |      |     |     |     |    |    |    |    |    |    | 0    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Описание            |    |      |     |     |      |     |     |     |    |    |    |    |    | ,  | ГДА' | ΤА |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 TDATA данные для передачи, ширина и порядок следования битов определяется в регистре SPIxCR. Данные действительны, если SPIxST(NF) = '1'. для REV = '0' SPIxCR - LSB размещается в бите 0, для REV = '1' SPIxCR - MSB размещается в бите 31 При 8 битном слове байт 0xAB на передачу получит следующее расположение: для REV = '0' - 0x0000000AB, для REV = '1' - 0xAB0000000

| SPIxRX              | Per | гист | рпр | ини | мае | мых | дан | ных |    |    |    |    |    |    |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|-----|------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31  | 30   | 29  | 28  | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |     |      |     |     |     |     |     |     |    |    |    |    |    |    | 0    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Описание            |     |      |     |     |     |     |     |     |    |    |    |    |    |    | RDA' | ΤА |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

0-31 RDATA принятые данные, ширина и порядок следования битов определяются в регистре SPIxCR. Данные действительны, если NE = '1' в регистре SPIxST. для REV = '0' SPIxCR - MSB размещается в бите 15 (при ширине слова 4-16 бит), для REV = '1' SPIxCR - LSB размещается в бите 16 (при ширине слова 4-16 бит). При 8 битном слове байт 0xAB получит

| SPIxSS              | Pe | гист | рвь | ыбор | аве | дом | ого ; | устр | ойс | тва |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |    |      |
|---------------------|----|------|-----|------|-----|-----|-------|------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|--------|----|------|
| Номер бита          | 31 | 30   | 29  | 28   | 27  | 26  | 25    | 24   | 23  | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2  | 1 (  |
| Начальное состояние |    |      |     |      |     |     |       |      |     |     |    |    |    | 0  |    |    |    |    |    |    |    |    |   |   |   |   |   |   |        |    | 0    |
| Описание            |    |      |     |      |     |     |       |      |     |     |    |    |    | _  |    |    |    |    |    |    |    |    |   |   |   |   |   |   | $\neg$ | SL | VSEI |

следующее расположение: для  $\mathrm{REV} = \mathrm{'0'}$  -  $0\mathrm{x}0000\mathrm{AB00}$ , для  $\mathrm{REV} = \mathrm{'1'}$  -  $0\mathrm{x}000\mathrm{AB0000}$ 

3-31 — зарезервировано

0-2 SLVSEL номер подчиненного устройства, с которым необходимо произвести обмен данными

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 108-172



# 8.5 Интерфейс $I^2C$ «ведущий» (I2C0)

# 8.5.1 Краткие характеристики

- работает в режиме «ведущий»;
- совместим со стандартом Philips  $I^2C$ ;
- поддерживает 7-ми и 10-ти битную адресацию;
- скорость обмена 100кбит/с и 400кбит/с;
- требуется установка внешних подтягивающих резисторов на линии SCL и SDA.



Рис. 36: Блок-схема I2C0 («ведущий»)

В МП I2C0 работает только в режиме «ведущий».

 $I^2C$ простой двухпроводной последовательный интерфейс с возможностью работы нескольких «ведущих» на одной физической линии. Интерфейс обеспечивает детектирование коллизий и арбитраж.  $I^2C$  имеет 2 физических линии SDA (serial data line) и SCL (serial clock line).

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 109-172



#### 8.5.2 Общее описание протокола приема-передачи



Рис. 37: Транзакция на шине  $I^2C$ 

Прием-передача данных осуществляется побайтно.

Начало транзакции по шине  $I^2C$  определяется состоянием «START» на линиях SDA, SLC: переход линии SDA из состояния '1' в состояние '0' при состоянии SCL - '1'.

Окончание транзакции определяется состоянием «STOP» на линиях SDA, SLC: переход линии SDA из состояния '0' в состояние '1' при состоянии SCL - '1'.

Состояния «START», «STOP» формируются только «ведущим» шины. После формирования состояния «START» «ведущим» шины, шина считается занятой и освобождается только после формирования, занявшим ее «ведущим» состояния «STOP». Время между «STOP» и «START» определяется стандартом I2C и зависит от текущей скорости ее работы.

На рис. 37 приведены примеры состояния линий SDA, SLC при транзакциях. «Ведущий» шины формирует состояние «START» и передает 7-ми битный адрес «ведомого» устройства. После адреса следует бит  $R/\overline{W}$  определяющий направление передачи данных ('1' - чтение из «ведомого» устройства, '0' - запись в «ведомое» устройство). После передачи адреса и бита  $R/\overline{W}$ , «ведущий» шины освобождает линию SDA, а «ведомый» должен привести линию SDA в состояние '0'. Если этого не произошло, то считается, что не принят сигнал ACK (подтверждение) от «ведомого». «Ведущий» шины мо-

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 110-172



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

Если от «ведомого» принят сигнал ACK, то начинается передача данных, направление которой было опеределено битом  $R/\overline{W}$ . Данные могут передаваться до тех пор, пока приемник на каждый переданный байт информации отвечает ACK. Т.е. после передачи каждого байта данных, передатчик освобождает на один период SLC линию SDA, что бы приемник мог сообщить принят или не принят им байт информации или готов или не готов он принимать следующий. После ответа NAK (во время ожидания ACK подана '1') «ведущий» формирует состояние «STOP». «Ведущий» так же может прервать транзакцию, сформировав состояние «STOP».

# 8.5.3 Генерация несущей частоты

Контроллер  $I^2C$  формирует две частоты: для внешнего тактирования по линии SCL и для тактирования внутренних блоков в пять раз превышающую частоту на линии SCL. Для рассчета значения коэффициента деления предделителя частоты тактирования контроллера (I2CxPSC(PSC)) используется следующая формула:

$$PSC = \frac{F_{sys}}{5 \cdot F_{SCL}} - 1$$

Коэффициента деления предделителя может быть изменен только при отключенном контроллере  $I^2C$  (бит I2CxCR(EN)).

Минимально рекомендуемое значение коэффициента равно 3, что бы соблюдались допуски протокола по синхронизации. Это так же накладывает ограничение на минимальную частоту тактирования контроллера. При скорости обмена 100кбит/с минимальная рекомендуемая частота тактирования будет равной 2МГц. Но при скорости обмена 400кбит/с частота 2МГц будет недостаточной для соблюдения требования ко времени установки данных. Исходя из этого частота тактирования контроллера должна быть не менее 20МГц.

#### 8.5.4 Алгоритм работы с интерфейсом

Для разрешения работы контроллера надо записать в I2CxPSC(PSC) необходимое значение и установить бит I2CxCR(EN) = '1'. Прерывания разрешаются битом I2CxCR(IEN).

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 111-172



#### 8.5.4.1 Запись данных

Для передачи байта данных в «ведомое» устройство, «ведущий»  $I^2C$  должен сформировать состояние «START» на линиях SDA, SCL, послать адрес «ведомого» устройства и признак направления  $R/\overline{W}=$  '0'. «Ведомое» устройство должно ответить посылкой АСК. Затем «ведущий» посылает байт данных, ждет сигнала АСК и формирует состояние «STOP».

- записать байт данных содержащий адрес «ведомого» и  $R/\overline{W}=$  '0' в I2CxTX;
- сформировать состояние «START» на линиях SDA, SCL, записав биты I2CxCMD(WR) = '0' и I2CxCMD(STA) = '1';
- подождать пока бит I2CxST(TIP) примет значение '0';
- прочитать бит I2CxST(RxACK). Если бит равен '0', то «ведомый» принял информацию, можно продолжать дальше транзакцию. Если бит равен '1', повторить пункты сначала, «ведомый» по каким-то причинам не принял информацию;
- записать данные для передачи в I2CxTX;
- сформировать состояние «STOP» I2CxCMD(WR) = '1' и I2CxCMD(STO) = '1';
- подождать пока бит I2CxST(TIP) примет значение '0';
- прочитать бит I2CxST(RxACK). Если бит равен '0', то «ведомый» принял данные.

#### 8.5.4.2 Чтение данных

Для чтения байта данных с произвольного адреса в «ведомом» устройстве, «ведущий»  $I^2C$  должен сформировать состояние «START» на линиях SDA, SCL, послать адрес «ведомого» устройства и признак направления  $R/\overline{W}=$  '0'. За тем «ведущий» посылает байт(ы) содержащие внутренний адрес для «ведомого» устройства. Повторно формирует состояние «START» на линиях SDA, SCL, посылает адрес «ведомого» устройства и признак направления  $R/\overline{W}=$  '1'. Принимает байт(ы) данных от «ведомого», отвечая АСК. После принятия последнего байта данных отвечает NACK. Формирует состояние «STOP».

Стоит помнить, что регистр I2CxRX перезаписывается каждый раз, когда принимается новый байт данных.

ullet записать байт данных содержащий адрес «ведомого» и  $R/\overline{W}=$  '0' в I2CxTX;



- сформировать состояние «START» на линиях SDA, SCL, записав биты I2CxCMD(WR) = '1' и I2CxCMD(STA) = '1';
- подождать пока бит I2CxST(TIP) примет значение '0';
- прочитать бит I2CxST(RxACK). Если бит равен '0', то «ведомый» принял информацию, можно продолжать дальше транзакцию. Если бит равен '1', повторить пункты сначала, «ведомый» по каким-то причинам не принял информацию;
- записать данные для передачи в I2CxTX и установить бит I2CxCMD(WR) = '1';
- подождать пока бит I2CxST(TIP) примет значение '0';
- прочитать бит I2CxST(RxACK). Если бит равен '0', то «ведомый» принял информацию, можно продолжать дальше транзакцию. Если бит равен '1', повторить пункты сначала, «ведомый» по каким-то причинам не принял информацию;
- повторить предыдущие 3 пункта до тех пор, пока не будут переданы все байты, содержащие внутренний адрес в «ведомом»;
- записать байт данных содержащий адрес «ведомого» и  $R/\overline{W}=$  '1' в I2CxTX;
- сформировать состояние «STOP» I2CxCMD(WR) = '1' и I2CxCMD(STO) = '1';
- сформировать состояние «START» на линиях SDA, SCL, записав биты I2CxCMD(WR) = '1' и I2CxCMD(STA) = '1';
- подождать пока бит I2CxST(TIP) примет значение '0';
- прочитать бит I2CxST(RxACK). Если бит равен '0', то «ведомый» принял информацию, можно продолжать дальше транзакцию. Если бит равен '1', повторить пункты сначала, «ведомый» по каким-то причинам не принял информацию;
- прочитать байт данных из «ведомого», установив I2CxCMD(RD) = '1', I2CxCMD(STO) = '1', I2CxCMD(ACK) = '1';
- подождать пока бит I2CxST(TIP) примет значение '0';
- прочитать данные из регистра I2CxRX, сохранить в ПД.
- если требуется прочитать несколько байт данных из «ведомого» то необходимо повторять предыдущие 3 пункта но не устанавливать I2CxCMD(STO) = '1', I2CxCMD(ACK) = '1' до тех пор, пока не будет считано требуемое количество байт данных;

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 113-172



# 8.5.5 Описание регистров

Базовый адрес I2C0 - 0xC000 1000.

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

| Регистр | Смещение адреса | Доступ | Описание                              |
|---------|-----------------|--------|---------------------------------------|
| I2CxPSC | 00 h            | RW     | Регистр предделителя тактовой частоты |
| I2CxCR  | 04h             | RW     | Регистр управления                    |
| I2CxTX  | 08 h            | W      | Регистр передаваемых данных           |
| I2CxRX  | 08 h            | R      | Регистр принимаемых данных            |
| I2CxCMD | 0Ch             | W      | Регистр команд                        |
| I2CxST  | 0Ch             | R      | Регистр состояния                     |

| I2CxPSC             | Per | гист | рпр | едд | елит | еля |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
|---------------------|-----|------|-----|-----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
| Номер бита          | 31  | 30   | 29  | 28  | 27   | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |     |      |     |     |      |     |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |
| Описание            |     |      |     |     |      |     |    | _  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PS | SC |   |   |   |   |   |   |   |   |

16-31 — *зарезервировано* 0-15 PSC значение предделителя

| I2CxCR              | Per | гист | руп | рав | лени | я  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |     |   |   |   |     |     |
|---------------------|-----|------|-----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|-----|---|---|---|-----|-----|
| Номер бита          | 31  | 30   | 29  | 28  | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6   | 5 | 4 | 3 | 2 1 | 1 0 |
| Начальное состояние |     |      |     |     |      |    |    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |   |   |    |     |   |   |   |     |     |
| Описание            |     |      |     |     |      |    |    |    |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   |   | EN | IEN |   |   | _ |     |     |

8-31 — зарезервировано

7 ЕМ разрешение работы контроллера ('1' - разрешено, '0' - запрещено)

6 IEN разрешение прерывания по завершению передачи ('1' - разрешено, '0' - запрещено)

0-5 — зарезервировано

| I2CxTX              | Pe | гист | рпе | ред | авае | мых | даг | ных |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    |     |    |   |   |    |
|---------------------|----|------|-----|-----|------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----|-----|----|---|---|----|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4   | 3  | 2 | 1 | 0  |
| Начальное состояние |    |      |     |     |      |     |     |     |    |    |    |    |    |    |    | 0  | ,  | •  |    |    |    |    |   |   |   |   |    |     |    |   |   |    |
| Описание            |    |      |     |     |      |     |     |     |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   |   |   |   | TI | CAC | ГΑ |   |   | RW |

8-31 — зарезервировано

7 ТДАТА старшие 7 бит передаваемых данных

0-6 RW бит  $R/\overline{W}$  при передачи адреса «ведомого», в остальных случаях – младший бит данных

| I2CxRX              | Per | гист | рпр | ини | мае | мых | дан | ных |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |     |   |     |
|---------------------|-----|------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-----|---|-----|
| Номер бита          | 31  | 30   | 29  | 28  | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 0 |
| Начальное состояние |     |      |     |     |     |     |     |     |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |   |   |   |   |   |     |     |   |     |
| Описание            |     |      |     |     |     |     |     |     |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   |   |   |   | I | RDA | AΤΑ |   |     |

8-31 — зарезервировано

0-7 RDATA последний принятый байт данных



| I2CxCMD      |            | Регистр команд                                                                                                                                      |
|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Номер бита   | Î          | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |
| Начальное со | остояние   | 0                                                                                                                                                   |
| Описание     |            |                                                                                                                                                     |
| 8-31         | _          | зарезервировано                                                                                                                                     |
| 7            | STA        | сформировать последовательность START(RESTART) ('1' — сформировать)                                                                                 |
| 6            | STO        | сформировать последовательность STOP ('1' — сформировать)                                                                                           |
| 5            | $^{ m RD}$ | чтение из ведомого устройства ('1' — считать)                                                                                                       |
| 4            | WR         | запись в ведомое устройство ('1' — записать)                                                                                                        |
| 3            | ACK        | подтверждение получения данных ('0' – ACK, '1' – NACK)                                                                                              |
| 1-2          | _          | зарезервировано                                                                                                                                     |
| 0            | IACK       | сброс бита $I2CxST(IF)$ ('1' — сбросить)                                                                                                            |

| I2CxST              | Pe | гист | рс | остоя | ния |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |     |       |   |   |   |     |   |
|---------------------|----|------|----|-------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|-----|-------|---|---|---|-----|---|
| Номер бита          | 31 | 30   | 29 | 28    | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 ( | 5 5   | 4 | 3 | 2 | 1   | 0 |
| Начальное состояние |    |      |    | •     |     |    |    |    |    |    |    |    |    |    | (  | )  |    |    |    |    |    |    |   |     |     |       |   |   |   |     | _ |
|                     |    |      |    |       |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | - 1 |     | 1     |   |   |   |     |   |
| Описание            |    |      |    |       |     |    |    |    |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   | Ι.  | RxA | 3   5 | ] | _ |   | TIP | - |

| 8-31 | _     | зарезервировано                                                                    |
|------|-------|------------------------------------------------------------------------------------|
| 7    | RxACK | принят АСК                                                                         |
| 6    | BUSY  | шина занята (обнаружено состояние START, сбрасывается при обнаружении STOP)        |
| 5    | AL    | потеря контроля над шиной                                                          |
| 2-4  | _     | зарезервировано                                                                    |
| 1    | TIP   | признак передачи данных, и формирования STOP                                       |
| 0    | IF    | байт передан или потерян контроль над линией. Если бит I2CxCR(IEN) = '1', то будут |
|      |       | возникать запросы прерывания. Новые прерывания будут возникать даже если этот бит  |
|      |       | не был очищен                                                                      |

www.multiclet.com UM\_HDL50002 Rev: 101 09.07.2015 115-172



# 8.6 Интерфейс $I^2C$ «ведомый» (I2C1)

# 8.6.1 Краткие характеристики

- работает в режиме «ведомый»;
- совместим со стандартом Philips  $I^2C$ ;
- поддерживает 7-ми битную адресацию;
- скорость обмена 100кбит/с и 400кбит/с;
- требуется установка внешних подтягивающих резисторов на линии SCL и SDA.



Рис. 38: Блок-схема I2C1 («ведомый»)

В МП I2C1 работает только в режиме «ведомый».

 $I^2C$ простой двухпроводной последовательный интерфейс с возможностью работы нескольких «ведущих» на одной физической линии. Интерфейс обеспечивает детектирование коллизий и арбитраж.  $I^2C$  имеет 2 физических линии SDA (serial data line) и SCL (serial clock line).

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 116-172



# 8.6.2 Общее описание протокола приема-передачи



Рис. 39: Транзакция на шине  $I^2C$ 

Прием-передача данных осуществляется побайтно.

Начало транзакции по шине  $I^2C$  определяется состоянием «START» на линиях SDA, SCL: переход линии SDA из состояния '1' в состояние '0' при состоянии SCL - '1'.

Окончание транзакции определяется состоянием «STOP» на линиях SDA, SLC: переход линии SDA из состояния '0' в состояние '1' при состоянии SCL - '1'.

Состояния «START», «STOP» формируются только «ведущим» шины. После формирования состояния «START» «ведущим» шины, шина считается занятой и освобождается только после формирования, занявшим ее «ведущим» состояния «STOP». Время между «STOP» и «START» определяется стандартом I2C и зависит от текущей скорости ее работы.

На рис. 39 приведены примеры состояния линий SDA, SLC при транзакциях. «Ведущий» шины формирует состояние «START» и передает 7-ми битный адрес «ведомого» устройства. После адреса следует бит  $R/\overline{W}$  определяющий направление передачи данных ('1' - чтение из «ведомого» устройства, '0' - запись в «ведомое» устройство). После передачи адреса и бита  $R/\overline{W}$ , «ведущий» шины освобождает линию SDA, а «ведомый» должен привести линию SDA в состояние '0'. Если этого не произошло, то считается, что не принят сигнал ACK (подтверждение) от «ведомого». «Ведущий» шины мо-

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 117-172



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

Если от «ведомого» принят сигнал АСК, то начинается передача данных, направление которой было определено битом  $R/\overline{W}$ . Данные могут передаваться до тех пор, пока приемник на каждый переданный байт информации отвечает АСК. Т.е. после передачи каждого байта данных, передатчик освобождает на один период SLC линию SDA, что бы приемник мог сообщить принят или не принят им байт информации или готов или не готов он принимать следующий. После ответа NAK (во время ожидания АСК подана '1') «ведущий» формирует состояние «STOP». «Ведущий» так же может прервать транзакцию, сформировав состояние «STOP».

#### 8.6.3 Генерация несущей частоты

Контроллер  $I^2C$  I2C1 тактируется из вне. Сигналы SDA и SCL проходят через синхронизатор и ФНЧ. Их состояния синхронизируются с системной частотой  $F_{sys}$ . Это накладывает ограничение на минимальное значение частоты  $F_{sys}$ , она должна не менее, чем в 8 раз превышать частоту обмена по шине. Рекомендуется для скорости 100кбит/с  $F_{sys} \geq 2MHz$ , для скорости 400кбит/с  $F_{sys} \geq 6MHz$ .

#### 8.6.4 Алгоритм работы с интерфейсом

Интерфейс имеет четыре режима, которые определяются в регистре I2CxCR. Они определяют поведение контроллера после приема или передачи байта данных. Состояния регистрируются в регистре I2CxST. Они же являются источниками запросов прерываний от контроллера.

#### 8.6.4.1 Прием данных от «ведущего»

После приема байта данных контроллер будет отвечать NAK на все последующие, до тех пор пока не будет считан регистр I2CxRX. ACK автоматически формируется при считывании I2CxRX. Байты данных, которые не были подтверждены ACK, не сохраняются в I2CxRX.

Поведение контроллера после приема байта данных задается битом I2CxCR(RMOD).

Если I2CxCR(RMOD) = '0', то контроллер ожидает реакции «ведущего» шины. Будет принимать данные в сдвиговый регистр и отвечать на каждый байт данных NAK, до



тех пор пока не будет считан регистр I2CxRX.

Если I2CxCR(RMOD) = '1', то контроллер блокирует линию SCL и удерживает ее в состоянии '0' до тех пор пока не будет считан регистр I2CxRX и очищен бит I2CxST(REC) (очищается автоматически при чтении I2CxRX).

## 8.6.4.2 Передача данных «ведущему»

Передача данных «ведущему» управляется битом I2CxCR(TV). Если бит равен '1', то после принятия адреса контроллер подтвердит его состоянием АСК и начнет передавать данные расположенные в регистре I2CxTX. После того как байт данных был передан, биту I2CxCR(TV) присваивается значение I2CxCR(TAV). Это позволяет отправлять один и тот же байт на все запросы, без траты процессорного времени.

Поведение контроллера после передачи байта данных «ведущему» и получение от него ACK. Если «ведущий» ответил NAK, то контроллер перейдет в состояние ожидания состояния START на линиях SLC, SDA. Бит I2CxST(NAK) примет значение '1'.

Если I2CxCR(TMOD) = '0', то после ответа ACK «ведущим», контроллер продолжает ждать действий от «ведущего». Если он продолжит операции считывания данных из «ведомого», то контроллер будет отправлять данные, которые будут находиться в регистре I2CxTX.

Если I2CxCR(TMOD) = '1', то после ответа ACK «ведущим», контроллер блокирует линию SCL и удерживает ее в состоянии '0' до тех пор пока бит I2CxCR(TV) не будет равен '1'. Пользоваться этим режимом следует осторожно т.к. «ведущий» шины не имеет возможности управлять сигналом SCL, а так же работа шины зависит от программного алгоритма написанного пользователем для системы в которой работает «ведомое» устройство.

Если I2CxCR(TAV) равен '1', то поведения в контроллера при любом значении бита I2CxCR(TMOD) будет одинаковым.



# 8.6.5 Описание регистров

Базовый адрес I2C1 - 0xC000 1100.

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра.

| Регистр | Смещение адреса | Доступ | Описание                    |
|---------|-----------------|--------|-----------------------------|
| I2CxSAD | 00 h            | RW     | Регистр адреса «ведомого»   |
| I2CxCR  | 04h             | RW     | Регистр управления          |
| I2CxST  | 08 h            | RW     | Регистр состояния           |
| I2CxMSK | 0Ch             | RW     | Регистр маски               |
| I2CxRX  | 10 h            | R      | Регистр принимаемых данных  |
| I2CxTX  | 14h             | W      | Регистр передаваемых данных |

| I2CxSAD             | Pe | гис                                                                                                              | тр  | ηг  | eca  | ι «B | едог | 10го | <b>»</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |          |     |   |
|---------------------|----|------------------------------------------------------------------------------------------------------------------|-----|-----|------|------|------|------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|----------|-----|---|
| Номер бита          | 31 | Perucry адреса «ведомого»  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |     |     |      |      |      |      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |          |     |   |
| Начальное состояние |    |                                                                                                                  |     |     |      |      |      | ,    |          |    |    |    |    |    |    | 0  |    |    | •  |    |    |    |    |   |   |   |   |   |     |          |     |   |
| Описание            |    |                                                                                                                  |     |     |      |      |      |      |          |    |    |    |    | _  |    |    |    |    |    |    |    |    |    |   |   |   |   | 5 | SLV | ADD:     | R   |   |
|                     |    |                                                                                                                  |     |     |      |      |      |      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |          |     |   |
|                     |    | 1 1 1                                                                                                            |     |     |      |      |      |      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |          |     |   |
|                     |    |                                                                                                                  |     |     |      |      |      |      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |          |     |   |
|                     |    |                                                                                                                  |     |     |      |      |      |      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |          |     |   |
| I2CxCR              | Pe | гис                                                                                                              | тр  | упј | оавл | тен: | ия   |      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |          |     |   |
| Номер бита          | 31 | 30                                                                                                               | ) 2 | 9   | 28   | 27   | 26   | 25   | 24       | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3        | 2 1 | 0 |
| Начальное состояние |    |                                                                                                                  |     |     |      |      |      |      |          |    |    |    |    | 0  |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     | U        |     | 0 |
|                     |    |                                                                                                                  |     |     |      |      |      |      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | 40D | <u>Q</u> |     |   |

| Tra ranbiloc c | OCTONINC | U U                                                                                      |        | 0     |     | 10 |
|----------------|----------|------------------------------------------------------------------------------------------|--------|-------|-----|----|
| Описание       |          | <del>-</del>                                                                             | RMOD   | AL AL | TAV | N. |
| 5-31           | _        | зарезервировано                                                                          |        |       |     |    |
| 4              | RMOL     | Э режим приема данных ('1' - «ведомый» принимает данные и удерживает SCL в '0'           | дот    | ex    |     |    |
|                |          | пор пока данные из I2CxRX не будут считаны (АСК будет послан сформирован                 | ı), '0 | , _   |     |    |
|                |          | «ведомый» принимает данные и формирует NAK для данного байта информации                  | ид     | ля    |     |    |
|                |          | всех последующих, до тех пор пока не будет считан регистр I2CxRX)                        |        |       |     |    |
| 3              | TMOL     | ) режим передачи данных ('1' - «ведомый» передает один и тот же байт данных и фор        | миру   | ет    |     |    |
|                |          | NAK на все запросы после, до тех пор пока I2CxCR(TV) = '0', '0' - «ведомый» пе           | ереда  | ет    |     |    |
|                |          | один байт и удерживает ${ m SCL}$ в '0' до тех пор пока ${ m I2CxCR}({ m TV})={ m '0'})$ |        |       |     |    |
| 2              | TV       | подтверждение передачи ('1' - подтверждает факт передачи данных (после передачи          | и бай  | та    |     |    |
|                |          | данных автоматически принимает значение '0'), '0' - формируется NAK или удержи           | вает   | ся    |     |    |
|                |          | SCL в '0' в зависимости от I2CxCR(TMOD))                                                 |        |       |     |    |
| 1              | TAV      | передача данных всегда подтверждена ('1' - разрешено, '0' - запрещено)                   |        |       |     |    |
| 0              | EN       | разрешение работы контроллера ('1' - разрешено, '0' - запрещено, линии SCL, SDA          | АвЗ    | - M   |     |    |
|                |          | состоянии)                                                                               |        |       |     |    |
|                |          |                                                                                          |        |       |     |    |

| I2CxST              | Pe | гист | р со | стоя | ния |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |                   |     |
|---------------------|----|------|------|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-------------------|-----|
| Номер бита          | 31 | 30   | 29   | 28   | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1                 | 0   |
| Начальное состояние |    |      |      |      |     |    |    |    |    |    |    |    | •  |    | 0  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |                   |     |
| Описание            |    |      |      |      |     |    |    |    |    |    |    |    |    | _  |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | REC | $_{\mathrm{TRA}}$ | NAK |

```
3-31 — зарезервировано
2 REC байт принят ('1' - принят (автоматически очищается, когда считан регистр I2CxRX), '0' - не принят)
1 TRA байт передан ('1' - передан (очищается записью '1' в I2CxST(TRA)))
```



0 NAK сформирован NAK на запрос ('1' - сформирован NAK)). Если адрес «ведомого» не совпадает с I2CxSAD, то отправка NAK не имеет влияния на этот бит

| I2CxMSK             | Регистр маски                                                                                                                                       |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Номер бита          | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |
| Начальное состояние | U                                                                                                                                                   |
| Описание            |                                                                                                                                                     |

| 3-31 | _    | зарезервировано                                                                      |
|------|------|--------------------------------------------------------------------------------------|
| 2    | RECE | разрешение формирования прерывание по I2CxST(REC) ('1' - разрешено, '0' - запрещено) |
| 1    | TRAE | разрешение формирования прерывание по I2CxST(TRA) ('1' - разрешено, '0' - запрещено) |
| 0    | NAKE | разрешение формирования прерывание по I2CxST(NAK) ('1' - разрешено, '0' - запрещено) |

| I2CxTX              | Pe | гист | рпе | ред | авае | мых | дан | ных | ζ  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |     |   |   |   |
|---------------------|----|------|-----|-----|------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-----|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
| Начальное состояние |    |      |     | •   |      |     |     |     |    |    |    |    |    |    | 0  |    |    |    |    | ,  |    |    |   |   |   |   |   |     |     |   |   | ٦ |
| Описание            |    |      |     |     |      |     |     |     |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | ΓDΑ | AΤΑ |   |   |   |

8-31 — зарезервировано

0-7 ТДАТА старшие 7 бит передаваемых данных

| I2CxRX              | Pe | гист | рпр | ини | мае | мых | дан | ных |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |     |   |   |   |
|---------------------|----|------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-----|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
| Начальное состояние |    |      |     |     |     |     |     |     |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |   |   |   |   |   |     |     |   |   |   |
| Описание            |    |      |     |     |     |     |     |     |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | RD2 | ΑТА |   |   |   |

8-31 — зарезервировано

0-7 RDATA последний принятый байт данных

www.multiclet.com UM\_HDL50002 Rev: 101 09.07.2015 121-172



# 8.7 Контроллер $I^2S(I2Sx)$

## 8.7.1 Краткие характеристики

- реализует приемник данных, работающий в режиме «ведущий»;
- совместим со стандартом Philips  $I^2S$ ;
- выбор разрядности сэмпла: от 16 до 32 бит;
- предделитель синхронизирующей частоты;

# **8.7.2** Общее описание шины $I^2S$

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

Поскольку передатчик и приемник имеют одинаковые тактовые сигналы для передачи данных, передатчик, как ведущее устройство, должен генерировать сигнал синхронизации, сигнал данных и селекционный сигнал. Однако, в сложных системах, может быть несколько передатчиков и приемников и это затрудняет определение ведущего устройства. В таких системах, как правило, существуют ведущие системы управления цифровыми звуковыми потоками данных между различными устройствами. Тогда, передатчики, должны генерировать данные под управлением внешнего синхросигнала и выступать в качестве ведомых устройств. В общем случае  $I^2S$  интерфейс состоит из двух раздельных ядер - передатчика и приемника. Оба могут работать в режиме или ведущего или ведомого. Для передачи звука по  $I^2S$  в одну сторону требуется как минимум 3 линии:

- Bit clock SCK (тактирование);
- Word select WS (линия выбора канала);
- Data line SD (линия передачи аудио данных).

Сигналы WS и SCK создает только ведущее устройство (рис. 40).





Рис. 40: Направление сигналов  $I^2S$ 



Рис. 41: Временная диаграмма сигналов  $I^2S$ 

Временная диаграмма сигналов  $I^2S$  представлена на рис. 41:

Линия WS указывает, данные какого канала сейчас передаются, низкий уровень ('0') соответствует левому каналу, высокий ('1') — правому, изменение WS происходит на отрицательном фронте SCK. Передатчик изменяет значение линии данных SD при отрицательном фронте сигнала SCK, приемник считывает при положительном. Старший бит слова передается на втором положительном фронте сигнала SCK после изменения сигнала WS.

# 8.7.3 Особенности текущей реализации $I^2S$

На передачу контроллер  $I^2S$  функционирует в полном объеме. На прием в текущей версии процессора недоступен буфер приема на чтение. Поэтому в текущей версии процессора необходимо программно определять входное значение. Т.е. с помощью GPIOxIN определять текущий уровень тактирующего сигнала и снимать значение с линии данных (все сигналы кроме линии данных на прием работают штатно).

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 123-172



# 8.7.4 Описание регистров

Базовый адрес  $I^2S$ - 0хС010 2000

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

| Регистр  | Смещение адреса | Доступ | Описание                    |
|----------|-----------------|--------|-----------------------------|
| I2SxCFG  | 00h             | RW     | Регистр настройки приемника |
| I2SxMSK  | 04h             | RW     | Регистр маски прерываний    |
| I2SxINT  | 08h             | RW     | Регистр прерываний          |
| I2SxDATA | 0Ch-8Ch         | W      | Регистр данных (32 строки)  |

| I2SxCFG              | Регистр настройки приемника                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Номер бита           | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Начальное состояние  | 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Описание             | RES PSC - WS NAME OF THE PROPERTY OF THE PROPE |
| 22-31 —<br>16-21 RES | зарезервировано<br>количество бит в записываемых аудио данных (размер сэмпла)(16-32 бит)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| 16-21 | RES   | количество бит в записываемых аудио данных (размер сэмпла)(16-32 бит)           |
|-------|-------|---------------------------------------------------------------------------------|
| 8-15  | PSC   | значение делителя передающей частоты                                            |
| 3-7   | _     | зарезервировано                                                                 |
| 2     | SWAP  | установка записи левого канала ('1' - в нечетные адреса, '0' - в четные адреса) |
| 1     | INTEN | разрешение прерываний ('1' - разрешены, '0' - запрещены)                        |
| 0     | RXEN  | разрешение работы ('1' - разрешены, '0' - запрещены)                            |
|       |       |                                                                                 |

| I2SxMSK             | Per | гист | рма | аски | пре | рыв | аниі | ă  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |     |     |
|---------------------|-----|------|-----|------|-----|-----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|-----|-----|
| Номер бита          | 31  | 30   | 29  | 28   | 27  | 26  | 25   | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 1   | 0   |
| Начальное состояние |     |      |     |      |     |     |      |    |    |    |    |    |    | (  | )  |    |    |    |    |    |    |    |   |   |   |   |   |   |     | 0   | 0   |
|                     |     |      |     |      |     |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     | SBF | BF  |
| Описание            |     |      |     |      |     |     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     | H   | LS. |

Для всех разрядов регистра: ('1' - разрешение, '0' - запрет)

2-31 — зарезервировано

1 HSBF верхний буфер аудио данных заполнен 0 LSBF нижний буфер аудио данных заполнен

| I2SxINT             | Pe | гист | рпр | еры | ван | ий |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |              |              |
|---------------------|----|------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|--------------|--------------|
| Номер бита          | 31 | 30   | 29  | 28  | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 2 | 1            | 0            |
| Начальное состояние |    |      |     |     |     |    |    |    |    |    |    |    |    | (  | )  |    |    |    |    |    |    |    |   |   |   |   |   |   |     | 0            | 0            |
|                     |    |      |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     | $\mathbf{r}$ | $\mathbf{r}$ |
|                     |    |      |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     | [ L          | [E4          |
|                     |    |      |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     | ISBF         | SB           |
| Описание            |    |      |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     | ΙΞ.          | Ä            |

Для всех разрядов регистра: ('1' - разрешение, '0' - запрет)

2-31 — зарезервировано

1 HSBF\_ST верхний буфер аудио данных заполнен 0 LSBF\_ST нижний буфер аудио данных заполнен

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 124-172



| I2SxTX              | Per | гист | рпе | реда | ачи |    |    |    |    |    |    |    |    |            |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |
|---------------------|-----|------|-----|------|-----|----|----|----|----|----|----|----|----|------------|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|
| Номер бита          | 31  | 30   | 29  | 28   | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18         | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 |
| Начальное состояние |     |      |     |      |     |    |    |    |    |    |    |    |    |            | 0   |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |
| Описание            |     |      |     |      |     |    |    |    |    |    |    |    |    | <b>T</b> . | X_C | UT | ,  |    |    |    |    |    |   |   |   |   |   |   |   |   |     |

0-31  ${
m TX\_OUT}$  данные на передачу



# 8.8 Таймер общего назначения(GPTIMx)

# 8.8.1 Краткие характеристики

- представляет собой декрементирующий 32-х битный счетчик;
- предделитель 16 бит;
- однократный и непрерывный режимы счета.



Рис. 42: Блок-схема GPTIMx

Исполнительная часть таймера состоит из предделителя и таймера. Предделитель и таймер представляют собой декрементирующие счетчики с регистрами начальных значений, из которых оно загружается в счетчик после достижения им значение -1. На рис.42 приведена блок-схема GPTIMx.

#### 8.8.2 Алгоритм работы

Таймер начинает счет после установки бита TIMxCR(EN) = '1'. Внутренний тактовый сигнал после предделителя подается на счетчик таймера. Как только его значение становится –1, формируется запрос обработки прерывания - бит TIMxCR(IP) принимает значение = '1', значение TIMxCNTPER(CNTPER) загружается в регистр текущего

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 126-172



значения счетчика TIMxCNTVAL(CNTVAL). Если установлен непрерывный режим работы счетчика (бит TIMxCR(RS) = '1'), то эти события периодически повторяются. Если установлен однократный режим работы (бит TIMxCR(RS) = '0'), то возобновление счета не происходит, счетчик не декрементируется.

В любой момент таймер может быть перезагружен его начальным значением, при установке бита TIMxCR(LD) = '1'.

Период таймера можно вычислить по следующей формуле:

$$T_{GPTIM} = T_{sus} \cdot (PSCPER + 1) \cdot CNTPER,$$

$$PSCPER \geq 2(GPTIM1,GPTIM3) \quad PSCPER \geq 4(GPTIM0,GPTIM2)$$

Следует особо обратить внимание на то, что значение TIMxPSCPER(PSCPER) не должно быть меньше 2 (или 4).

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 127 - 172



# 8.8.3 Описание регистров

Базовые адреса регистров GPTIMx:

GPTIM0 - 0xC001 0000

GPTIM1 - 0xC001 0100

GPTIM2 - 0xC011 0000

GPTIM3 - 0xC011 0100

Для получения реального адреса регистра необходимо к базовому (начальному) адресу на шине прибавить смещение адреса регистра. GPTIM0 - 4 канала, GPTIM1 - 2 канала, GPTIM2 - 4 канала, GPTIM3 - 2 канала. Для каждого следующего канала у таймера общего назначения вводятся свои регистры TIMxCNTVAL, TIMxCNTPER, TIMxCR. Например для канала 2 необходимо к адресу каждого из трех регистров добавить смещение 10h(итоговые адреса будут 20h, 24h, 28h).

| Регистр    | Смещение адреса | Доступ | Описание                                 |
|------------|-----------------|--------|------------------------------------------|
| TIMxPSCVAL | 00h             | RW     | Регистр текущего значения предделителя   |
| TIMxPSCPER | 04h             | RW     | Регистр начального значения предделителя |
| TIMxCNTVAL | 10h             | RW     | Регистр текущего значения таймера        |
| TIMxCNTPER | 14h             | RW     | Регистр начального значения таймера      |
| TIMxCR     | 18h             | RW     | Регистр управления                       |

| TIMxPSCVAL          | Pe | гист | рте | куш | цего | знач | ени | япр | едд | елит | еля |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|------|------|-----|-----|-----|------|-----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26   | 25  | 24  | 23  | 22   | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |    |      |     |     |      |      |     |     |     |      |     |    |    |    | 0  |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
| Описание            |    |      |     |     |      |      |     | _   | -   |      |     |    |    |    |    |    |    |    |    |    |    | ]  | PSC | VA | L |   |   |   |   |   |   |   |

16-31 – зарезервировано
 0-15 PSCVAL текущее значение счетчика предделителя

| TIMxPSCPER          | Pe | гист | рна | чал | ьног | озн | аче | кин | пред | цдел | ите. | пя | -  |    |    | -  |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-----|------|-----|-----|-----|------|------|------|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26  | 25  | 24  | 23   | 22   | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |    |      |     |     |      |     |     |     |      |      |      |    |    |    | 0  |    | •  |    |    |    |    |    |     |    |   |   |   |   |   |   |   | ٦ |
| Описание            |    |      |     |     |      |     |     | _   | _    |      |      |    |    |    |    |    |    |    |    |    |    | ]  | PSC | PE | R |   |   |   |   |   |   | ٦ |

16-31 — *зарезервировано* 0-15 PSCPER начального значение предделителя (период предделителя)

| TIMxCNTVAL          | Per | гист                                                                                | рте | куш | его | знач | ени | я та | ймеј | pa |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |
|---------------------|-----|-------------------------------------------------------------------------------------|-----|-----|-----|------|-----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|
| Номер бита          | 31  | 30                                                                                  | 29  | 28  | 27  | 26   | 25  | 24   | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| Начальное состояние |     | 31 30 29 28 27 20 25 24 23 22 21 20 19 18 17 10 15 14 15 12 11 10 9 8 7 0 5 4 3 2 1 |     |     |     |      |     |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |
| Описание            |     |                                                                                     |     |     |     |      |     | -    | -    |    |    |    |    |    |    |    |    |    |    |    |    | (  | CNT | VA. | L |   |   |   |   |   |   |

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 128-172



| TIMxCNTPER          | Per | гист | рна | чал | ьног | озн | ачеі | ния | тайм | гера |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |
|---------------------|-----|------|-----|-----|------|-----|------|-----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|
| Номер бита          | 31  | 30   | 29  | 28  | 27   | 26  | 25   | 24  | 23   | 22   | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| Начальное состояние |     |      |     |     |      |     |      |     |      |      |    |    |    |    | 0  |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |
| Описание            |     |      |     |     |      |     |      | _   | _    |      |    |    |    |    |    |    |    |    |    |    |    | C  | ONT | PE. | R |   |   |   |   |   |   |

16-31 — зарезервировано

0-15 СМТРЕК начального значение счетчика предделителя (период предделителя)

| TIMxC  | CR       |       | Регистр управления                                                                                                                              |    |
|--------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Номер  | бига     |       | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1 | 0  |
| Началь | ное сост | ояние | 0                                                                                                                                               |    |
| Описан | ие       |       | —                                                                                                                                               | ΞN |
|        |          |       |                                                                                                                                                 |    |
|        | 5-31     | _     | зарезервировано                                                                                                                                 |    |
|        | 4        | IΡ    | признак сформированного прерывания ('1' - сформировано, '0' - нет запроса прерывания),                                                          |    |
|        |          |       | очищается записью '1' в этот бит                                                                                                                |    |
|        | 3        | IE    | разрешение формирования прерывания ('1' - разрешено, '0' - запрещено)                                                                           |    |
|        | 2        | LD    | перезагрузка таймера ('1' - загрузить TIMxCNTPER(CNTPER) в                                                                                      |    |
|        |          |       | TIMxCNTVAL(CNTVAL)                                                                                                                              |    |
|        | 1        | RS    | режим работы таймера ('1' - непрерывный, '0' - однократный)                                                                                     |    |
|        | 1        | 100   |                                                                                                                                                 |    |
|        | 0        | EN    | разрешение работы таймера ('1' - разрешено. '0' - запрешено)                                                                                    |    |

www.multiclet.com UM\_HDL50002 Rev: 101 09.07.2015 129-172



# 8.9 Контроллер Ethernet(Ethernet0)

# 8.9.1 Краткие характеристики

- поддерживает скорость 10/100МБит/с
- полнодуплексный, полудуплексный режимы работы;
- прямой канал доступа к ОЗУ;
- поддержка интерфейсов RMII;
- имеет интерфейс MDIO;
- соответствует стандарту IEEE 802.3-2002 и IEEE 802.3Q-2003

Контроллер Ethernet0 состоит из функциональных модулей:

- контроллер прямого доступа к памяти (КПДП)
- MDIO

КПДП используется для передачи данных между внутренней памятью МП и контроллером Ethernet0. Все принятые и сформированные для передачи пакеты данных хранятся во внутренней памяти МП. Приемник и передатчик имеют раздельные КПДП.

MDIO используется для конфигурации и управления внешним преобразователем среды (PHY).

Ethernet0 поддерживает следующие стандарты: IEEE 802.3-2002 и IEEE 802.3Q- 2003 (опционально, см. таблицу комплектации МП). Контроллер не поддерживает пакеты типа 0х8808, они не будут приниматься.

Приемник и передатчик Ethernet0 связаны с внешним преобразователем среды по интерфейсу Reduced Media Independent Interface (RMII).

Размер таблиц дескрипторов приемника и передатчика - 1КБ.

#### 8.9.2 Тактирование

Приемник и передатчик Ethernet0 тактируются внешним преобразователем среды, для приемника и передатчика независимые тактовые сигналы и являются частью интерфейса RMII. Внутренние структуры управления тактируются системной частотой Fsys. Контроллером поддерживаются полудуплексные и полнодуплексные режимы работы, которые могут работать на скоростях передачи 10 и 100МБит/с. Минимальная Fsys

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 130-172



необходимая для корректной работы на скорости  $10{\rm MFut/c}$  -  $2.5{\rm M}\Gamma$ ц, для  $100{\rm MFut/c}$  -  $18{\rm M}\Gamma$ ц. Значения Fsys ниже требуемых может привести к потере пакетов.

#### 8.9.3 КПДП передатчика

Передатчик использует дескрипторы размещенные во внутренней памяти МП. Нельзя изменять дескриптор во время передачи.

#### 8.9.3.1 Установка дескриптора

Дескриптор имеет указание на адрес по которому размещается блок данных и размер блока. Так же там содержится управляющая информация. Адрес блока данных должен быть выровнен на 32 бита. Дескриптор не должен изменяться пока контроллером Ethernet0 не будет установлен TD0(EN) = '0'.

| TD0        | Ethernet0 дес     | скриптор, часть 0 (смещение адреса 0х0)                                               |
|------------|-------------------|---------------------------------------------------------------------------------------|
| Номер бита | 31 30 29 28       | 8 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           |
| Описание   |                   | - AL UE IE WR EN LENGTH                                                               |
|            |                   |                                                                                       |
| 31-16      | _                 | зарезервировано                                                                       |
| 15         | AL                | пакет не передан, т.к. число попыток превысило максимальное                           |
| 14         | UE                | пакет передан некорректно, т.к. FIFO был заполнен не полностью                        |
| 13         | IE                | разрешение прерывания по завершении передачи пакета, вне зависимости от того был ли   |
|            |                   | он передан корректно или нет, при условии, что установлен бит ETHxCR(TI)              |
| 12         | WR                | разрешение указателю таблицы дескрипторов принять значение 0 после передачи данного   |
|            |                   | пакета ('1' - разрешено, '0' - запрещено). Если WR=0, то указатель таблицы дескрипто- |
|            |                   | ров инкрементируется на 8 и примет значение 0 только после того, как достигнет конца  |
|            |                   |                                                                                       |
|            |                   | таблицы дескрипторов.                                                                 |
| 11         | EN                | разрешение операций с дескриптором ('1' - разрешено, '0' - запрещено)                 |
| 10-0       | LENGTH            | размер блока данных для передачи в байтах                                             |
| TTD:       | Tu io             |                                                                                       |
| TD1        |                   | жриптор, часть 1 (смещение адреса 0х4)                                                |
| Номер бита | 31   30   29   28 |                                                                                       |
| Описание   |                   | ADDRESS -                                                                             |
| 91.0       | ADDDDGG           | v                                                                                     |
|            | ADDRESS           | указатель на начальный адрес в памяти, где размещены данные для передачи              |
| 1-0        | _                 | зарезервировано                                                                       |

#### 8.9.3.2 Подготовка данных для передачи

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 131-172



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

Для начала передачи данных, необходимо установить указатель на адрес таблицы дескрипторов и установить бит TD0(EN) в соответствующем дескрипторе. Адрес таблицы дескрипторов должен быть выровнен на 1КБ. Биты 31..10 содержат базовый адрес таблицы дескрипторов, 9..3 - указатель на конкретный дескриптор (в байтах). Указатель будет установлен в 0 как только он превысит значение 1КБ. В случае если в каком-то дескрипторе установлен бит TD0(WR)='1', то указатель на дескриптор примет значение 0 когда дойдет до этого дескриптора.

После установки адреса необходимо разрешить передачу данных  $CR(TX\_EN)='1'$ . Это означает, что все дескрипторы готовы, можно начать передачу данных.

#### 8.9.3.4 Работа с дескриптором после окончания передачи данных

Соответствующие статусные биты будут записаны в TD0 после завершения передачи пакета, описанного дескриптором. Пакет считается переданным успешно, если TD0(UE) и TD0(AL) имеют значение '0'. TD0(UE)='1', если во время передачи FIFO передатчика оказывался пустым. TD0(AL)='1' устанавливается, если во время передачи возникло коллизий больше, чем предусмотрено протоколом. Все остальные биты TD0 устанавливаются = '0' после завершения передачи пакета. TD1 остается без изменений. Бит TD0(EN) может быть использован как индикатор того, что дескриптор готов к использованию, т.к. контроллер Ethernetx автоматически устанавливает его в '0' после окончания передачи пакета. Помимо отображения информации в дескрипторе, в контроллер так же имеются биты статуса передатчика: ETHxST(TE) - ошибка передачи, ETHxST(TI) - запрос обработки прерывания, устанавливается каждый раз как передача была завершена успешно. ETHxST(TA) - ошибка обмена данными через периферийную шину. В этом случае передатчик будет остановлен.

#### 8.9.4 КПДП приемника

Приемник использует дескрипторы размещенные во внутренней памяти МП. КПДП приемника предназначен для приема данных по сети Ethernet.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 132-172



# 8.9.4.1 Установка дескриптора

Дескриптор имеет указание на адрес по которому размещается блок данных и размер блока. Так же там содержится управляющая информация. Адрес блока данных должен быть выровнен на 32 бита.

| TD0                    | Ethernet0 де | скриптор, часть 0 (смещение адреса 0х0)                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Номер бита             | 31 30 29 2   | 8 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Описание               |              | N                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31-27                  | _            | зарезервировано                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26                     | MC           | адрес назначения пакета является групповым (не транслируется)                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 - 19                | _            | зарезервировано                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18                     | LE           | ошибка, значение поля "длина пакета"не соответствует текущему числу принятых байтов                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17                     | OE           | ошибка, кадр был принят некорректно из-за переполнения буфера приемника                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16                     | CE           | ошибка CRC в кадре                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 15                     | FT           | ошибка, принят кадр больше максимального размера, лишняя часть отброшена ошибка, принято нечётное количество полубайтов                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 14                     | AE           | ошибка, принято нечётное количество полубайтов                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 13                     | ΙE           | разрешение прерываний ('1' - разрешено, '0' - запрещено). Прерывания буду вырабаты-                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 12                     | WR           | вырабатываться вне зависимости от того завершился ли приём пакета успешно или про-<br>изошла ошибка. разрешение указателю таблицы дескрипторов принять значение 0 после передачи данного<br>пакета ('1' - разрешено, '0' - запрещено). Если WR=0, то указатель таблицы дескрипто-<br>ров инкрементируется на 8 и примет значение 0 только после того, как достигнет конца<br>таблицы дескрипторов. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11                     | EN           | разрешение операций с дескриптором (поле устанавливается последним) ('1' - разрешено, '0' - запрещено)                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10-0                   | LENGTH       | размер блока данных для приема в байтах                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| TD1                    | Ethernet0 де | скриптор, часть 1 (смещение адреса 0х4)                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Номер бита<br>Описание | 31 30 29 2   | 8 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 ADDRESS ———————————————————————————————————                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31-2<br>1-0            | ADDRESS      | указатель на начальный адрес в памяти, где будут размещены принятые данные зарезервировано                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

# 8.9.4.2 Прием данных

Для начала приема данных, необходимо установить указатель на адрес таблицы дескрипторов и установить бит TD0(EN) в соответствующем дескрипторе. Адрес таблицы дескрипторов должен быть выровнен на 1КБ. Биты 31..10 содержат базовый адрес таблицы дескрипторов, 9..3 - указатель на конкретный дескриптор (в байтах). Указатель будет установлен в 0 как только он превысит значение 1КБ. В случае если в каком-то дескрипторе установлен бит TD0(WR)='1', то указатель на дескриптор примет значение 0 когда дойдет до этого дескриптора.

После установки адреса необходимо разрешить приём данных ETHxCR(RE)='1'. Это означает, что все дескрипторы готовы, можно начать передачу данных.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 133-172



#### 8.9.4.3 Работа с дескриптором после окончания приема данных

После завершения приема, бит TD0(EN) имеет значение '0'. Биты TD0(WR) и TD0(IE) также имеют значение '0'. Количество принятых байт отображается в TD0(LENGTH). Части Ethernet кадра содержат адрес назначения, адрес источника, тип и поля данных. Биты 17..14 в TD0 сигнализируют об ошибках приёма. После успешного приёма все 4 бита должны иметь значение '0'. Пакет меньше минимального размера в 64 байта не является принятым и отбрасывается. Текущий регистр приёма запрещается изменять до приёма первого пакета с допустимым размером. Бит ETHxST(TS) сигнализирует об ошибке приёма пакета меньше минимально размера. Бит ETHxST(IA) сигнализирует о приёме пакета с недопустимым MAK адресом. Бит TD0(FT) сигнализирует о приёме пакета больше максимально допустимого размера. Поле TD0(LENGTH) не гарантирует правильного приёма данных. Количество пустых байт до максимального размера пакета после слова, содержащего последний байт, записывается в память.

# 8.9.4.4 Ошибки приема на шине АНВ

Если произойдет ошибка на шине АНВ в момент чтения дескриптора или записи данных, то бит ETHxST(RA) будет установлен в "1"и приемник отключится. Текущий прием будет отклонен. Для включения приемника необходимо будет установить бит ETHxCR(RE) в "1".

#### 8.9.4.5 Допустимые МАС адреса

По умолчанию контроллер Ethernet принимает пакеты с любым одноадресным MAC или широковещательным. Многоадресный прием пакетов также может быть активирован. МАС адрес устанавливается в регистрах ETHxMACMSB и ETHxMACLSB. В случае использования многоадресной рассылки решение о приеме пакете принимается следующим образом: 1) считается ethernet crc от MAC адреса назначения пакета; 2) 6 младших бит полученного значения используются в качестве индекса бита в регистрах ETHxHASHMSB и ETHxHASHLSB; 3) если значение бита определенного на предыдущем шаге равно "1 то пакет принимается, в противном случае не принимается.



# 8.9.5 MDIO интерфейс

МDIO интерфейс обеспечивает доступ к регистрам настройки и статуса внешней микросхемы РНУ через двухпроводной интерфейс. MDIO интерфейс может быть использован для доступа от 1 до 32 РНУ, содержащих от 1 до 32 16-ти битных регистров. Чтение из РНУ происходит путем установки адреса РНУ и адреса считываемого регистра и установкой бита чтения в регистре ЕТНхМDIO(RD) в "1". Операция чтения завершится после того как бит ЕТНхМDIO(BU) станет равен "0". Если операция прошла успешно, то ЕТНхМDIO(LF) равен "0" и поле данных будет актуальным, в противном случае данный бит будет равен "1" и поле данных будет неопределенным значением. Операция записи осуществляется записью в ЕТНхМDIO 16-ти бит данных, установкой адреса РНУ и адреса записываемого регистра и установкой ЕТНхМDIO(WR) в "1". Операция завершается после того как ЕТНхМDIO(BU) стал равен "0"и считается успешной, если ЕТНхМDIO(LF) равен "0".

## 8.9.5.1 Прерывания РНҮ

Контроллер Ethernet поддерживает прерывания от PHY. Прерывания вырабатываются при установке "0" на линии MDINT. Изменение состояния PHY отображается в ETHxST(PS) установкой в "1"каждый раз при детектировании событий на этой линии.



 $\mathbf{ETHxCR}$ 

# 8.9.6 Описание регистров

Базовый адрес Ethernet<br/>0 - 0xC0005000

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

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

| Регистр     | Смещение адреса | Доступ | Описание                       |
|-------------|-----------------|--------|--------------------------------|
| ETHxCR      | 00h             | RW     | Регистр установок конфигурации |
| ETHxST      | 04h             | RW     | Регистр состояния              |
| ETHxMACMSB  | 08h             | RW     | МАС адрес старшая часть        |
| ETHxMACLSB  | 0Ch             | RW     | МАС адрес младшая часть        |
| ETHxMDIO    | 10h             | RW     | Регистр MDIO                   |
| ETHxTDP     | 14h             | RW     | Указатель дескриптора передачи |
| ETHxRDP     | 18h             | RW     | Указатель дескриптора приема   |
| ETHxHASHMSB | 20h             | RW     | Хэш таблица, старшая часть     |
| ETHxHASHLSB | 24h             | RW     | Хэш таблица, младшая часть     |

| Номер бита     |                  | 31 | 30 2    | 9 28    | 27   26  | 25    | 24     | 23 22  | 21    | 20   | 0 19   | 18    | 17      | 16  | 15   | 14   | 1     | 3 12   | 11  | 10   | 9    | 8    | 7          | 6    | 5    | 4   | 3  | 2 : |
|----------------|------------------|----|---------|---------|----------|-------|--------|--------|-------|------|--------|-------|---------|-----|------|------|-------|--------|-----|------|------|------|------------|------|------|-----|----|-----|
| Начальное сост | ояние            |    |         | 0       |          | 0     |        |        |       |      |        | 0     |         |     |      |      |       |        | 0   | 0    |      | 0    | 0          | 0    | 0    | 0   | 0  | 0 ( |
| Описание       |                  |    |         | _       |          | MC    |        |        |       |      |        | _     |         |     |      |      |       |        | ME  | PI   |      | _    | $_{ m SP}$ | RS   | PM   | FD  | RI |     |
| 26-31          | _                |    | зарез   | ервир   | овано    |       |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 25             | MC               |    | стату   | с мно   | гоадр    | есно  | го ре  | жима   | ı ('1 | l' - | разр   | еш    | ено,    | ,0, | - 3  | апј  | реп   | ено    | )   |      |      |      |            |      |      |     |    |     |
| 12-24          | _                |    | зарез   | epsup   | овано    |       |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 11             | ME               |    | разре   | шить    | прие     | имн   | огоа,  | дресн  | ых    | паі  | кетон  | з ('1 | . ' - ] | раз | реп  | іен  | ο, '  | 0' -   | зап | эеп  | ценс | )    |            |      |      |     |    |     |
| 10             | PΙ               |    | разре   | шить    | прери    | ыван  | п ки   | ри из  | мен   | ени  | ии ст  | ату   | сав     | неі | ине  | го   | РΗ    | Y (    | 1'- | pas  | зреі | цен  | ю,         | 'o'  | - 3a | пр  | е- |     |
|                |                  |    | щено    | )       |          |       |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 8-9            | _                |    | зарез   | epsup   | овано    |       |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 7              | $_{ m SP}$       |    | скоро   | сть (   | '1' - 10 | 0 M   | бит/   | c, '0' | - 10  | Μ    | [бит/  | (c)   |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 6              | RS               |    | сброс   | , бит   | будет    | очи   | щен    | посл   | е ок  | ОН   | чани   | я с   | брос    | ак  | сонт | грс  | лл    | ера,   | нин | акі  | иед  | ιру  | гие        | е ог | ер   | аци | И  |     |
|                |                  |    | не сл   | едует   | произ    | вод   | ить с  | конт   | рол   | ле   | ром    | пок   | а би    | тр  | аве  | н    | 1'    | ('1' - | ин  | ици  | иро  | эва  | ть         | сбр  | ос   | кон | I- |     |
|                |                  |    | тролл   | гера I  | Ethern   | et)   |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 5              | $_{\mathrm{PM}}$ |    | прием   | и всех  | к паке   | гові  | несм с | тря і  | іа а  | дре  | ес ус  | тро   | йсті    | зан | азі  | ач   | ени   | я ('   | 1'- | раз  | врег | пен  | ю,         | 'o ' | - 3a | пр  | е- |     |
|                |                  |    | щено    | )       |          |       |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 4              | FD               |    | полно   | одупл   | ексны    | йре   | жим    | ('1' - | pas   | вре: | шенс   | , '0  | , - з   | апр | ещ   | ене  | o)    |        |     |      |      |      |            |      |      |     |    |     |
| 3              | RI               |    | разре   | ешени   | е прер   | ыва   | ний    | прием  | нин   | ка   | ('1' - | pas   | врец    | пен | ы, , | 0,   | - 38  | пре    | щен | ы)   |      |      |            |      |      |     |    |     |
| 2              | TI               |    | разре   | ешени   | е прер   | ыва   | ний:   | перед  | атч   | ика  | a ('1' | - p   | азр     | еше | ны   | , '0 | ) ' - | запј   | ещ  | ены  | 1)   |      |            |      |      |     |    |     |
| 1              | RE               |    | разре   | ешени   | е при    | ма,   | бита   | втом   | ати   | чес  | ски с  | бра   | сыв     | ает | ся і | в '( | )' п  | осле   | зан | вері | шен  | КИ   | пр         | ием  | іа і | ак  | е- |     |
|                |                  |    | та. У   | стана   | влива    | гь бі | ат сл  | едует  | то    | льк  | ко по  | сле   | зап     | иси | 1 де | еск  | риг   | тор    | апр | ие   | ма   | ('1' | - J        | оазј | реп  | ен  | э, |     |
|                |                  |    | '0' - з | апреі   | щено)    |       |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
| 0              | TE               |    | разре   | ешени   | е пере   | дач   | и, би  | т авт  | ома   | ти   | ческ   | и сб  | брас    | ыва | ает  | ся   | в '(  | )' по  | сле | за   | вер  | ше   | ния        | н пе | ере  | дач | И  |     |
|                |                  |    | пакет   | а. Ус   | танавл   | ива   | ть би  | т сле  | дуе   | г т  | ольк   | опо   | сле     | заі | пис  | ид   | есь   | рип    | тор | ап   | еред | цач  | и (        | '1'· | - pa | азр | е- |     |
|                |                  |    | шено    | , '0' - | запре    | щен   | o)     |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |
|                |                  |    |         |         |          |       |        |        |       |      |        |       |         |     |      |      |       |        |     |      |      |      |            |      |      |     |    |     |



0

| ETHxST              | Per | гист | р со | стоя | ния |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |    |             |               |    |    |            |    |    |
|---------------------|-----|------|------|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|----|-------------|---------------|----|----|------------|----|----|
| Номер бита          | 31  | 30   | 29   | 28   | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7  | 6           | 5             | 4  | 3  | 2          | 1  | 0  |
| Начальное состояние |     |      |      |      |     |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |    |    |    |   | 0  | 0  | 0           | 0             | 0  | 0  | 0          | 0  | 0  |
| Описание            |     |      |      |      |     |    |    |    |    |    |    | _  |    |    |    |    |    |    |    |    |    |    |   | PS | IA | $_{\rm LS}$ | $\mathrm{TA}$ | RA | II | $_{ m RI}$ | TE | RE |

Для всех разрядов регистра: ('1' - наличие признака, '0' - отсутствие признака)

| 9 - 31 | _                | зарезервировано                                                                 |
|--------|------------------|---------------------------------------------------------------------------------|
| 8      | $_{\mathrm{PS}}$ | изменения статуса РНҮ                                                           |
| 7      | IA               | принят пакет с адресом не соответствующим МАС. Очищается записью '1'            |
| 6      | TS               | принят пакет данных меньше минимального размера. Очищается записью '1'          |
| 5      | TA               | ошибка передатчика при работе по каналу DMA. Коллизии на системной шине или при |
|        |                  | доступе к памяти. Очищается записью '1'                                         |
| 4      | RA               | ошибка приемника при работе по каналу DMA. Коллизии на системной шине или при   |
|        |                  | доступе к памяти. Очищается записью '1'                                         |
| 3      | TI               | пакет передан без ошибок. Очищается записью '1'                                 |
| $^2$   | RI               | пакет принят без ошибок. Очищается записью '1'                                  |
| 1      | TE               | перелача пакета прервалась ошибкой. Очишается записью '1'                       |

| ETHxMACMSB          | M  | AC a | дре | с, ст | арш | аяч | аст | ь  |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |    |    |   |   |   |   |   |   |   |
|---------------------|----|------|-----|-------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29  | 28    | 27  | 26  | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 | ) |
| Начальное состояние |    |      |     |       |     |     |     | (  | )  |    |    |    |    |    |    |    |    |    |    |    |    |      | (    | 0  |    |   |   |   |   |   |   | ٦ |
| Описание            |    |      |     |       |     |     |     | _  | _  |    |    |    |    |    |    |    |    |    |    |    |    | 47 3 | 2 би | ты | MA | C |   |   |   |   |   | ٦ |

RE прием пакета прервался ошибкой. Очищается записью '1'

16-31 — зарезервировано

0-15 МАСМSВ два самых старших байта МАС адреса

| ETHxMACLSB          | M  | AC a | адре | с, м. | ладі | пая | част | ъ  |    |    |    |    |    |     |     |      |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |
|---------------------|----|------|------|-------|------|-----|------|----|----|----|----|----|----|-----|-----|------|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|
| Номер бита          | 31 | 30   | 29   | 28    | 27   | 26  | 25   | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | . 0 |
| Начальное состояние |    |      |      |       |      |     |      |    |    |    |    |    |    |     | 0   |      |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |
| Описание            |    |      |      |       |      |     |      |    |    |    |    |    |    | 310 | бит | ы М. | AC |    |    |    |    |    |   |   |   |   |   |   |   |     |     |

16-31 — зарезервировано

0-15 м<br/>ACLSВ младшие байты м<br/>AC адреса

| ETHxMDIO            | Pe | гист | рΜ | DIO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |    |    |    |    |    |
|---------------------|----|------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|----|----|----|----|----|
| Номер бита          | 31 | 30   | 29 | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9  | 8  | 7  | 6 | 5 | 4  | 3  | 2  | 1  | 0  |
| Начальное состояние |    |      |    |     |    |    |    | -  | _  |    |    |    |    |    |    |    |    |    | _   |    |    |    |    | _  |    |   | - | -  | -  | -  | -  | -  |
| Описание            |    |      |    |     |    |    |    | DA | ТА |    |    |    |    |    |    |    |    | PH | YAD | DR |    | R  | EG | ΑD | DR |   |   | NV | BU | LF | RD | WR |

| 31-16 | DATA       | поле данных, которое может содержать принятые данные или данные на передачу                       |
|-------|------------|---------------------------------------------------------------------------------------------------|
| 15-11 | PHYADDR    | адрес РНҮ для доступа на чтение или запись                                                        |
| 10-6  | REGADDR    | адрес регистра для которого может быть осуществлена операция чтения или записи                    |
| 5     | _          | зарезервировано                                                                                   |
| 4     | NV         | после завершения операции $(\mathrm{ETHxMDIO}(\mathrm{BU})=0)$ данный бит показывает корректность |
|       |            | данных (1 - данные некорректны, 0 - данные корректны)                                             |
| 3     | $_{ m BU}$ | когда выполняется операция данный бит устанавливается в "1". После того как операция              |
|       |            | выполнена и есть функциональная связь данный бит будет установлен в "0"                           |
| 2     | $_{ m LF}$ | после завершения операции (ЕТНхМDIO(BU) = 0) данный бит устанавливается в "1" если                |
|       |            | отсутствует функциональная связь                                                                  |
| 1     | RD         | операция чтения данных                                                                            |
| 0     | WR         | операция записи данных                                                                            |

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 137-172$ 



| ETHXTD    | )P          | УК  | азат | ель               | десь | срип | тора        | пе  | реда | чи |     |     |     |     |     |     |    |     |     |    |      |      |    |        |     |     |     |     |     |      |     |     |   |
|-----------|-------------|-----|------|-------------------|------|------|-------------|-----|------|----|-----|-----|-----|-----|-----|-----|----|-----|-----|----|------|------|----|--------|-----|-----|-----|-----|-----|------|-----|-----|---|
| Номер бит | га          | 31  | 30   | 29                | 28   | 27   | 26          | 25  | 24   | 23 | 22  | 21  | 20  | 19  | 18  | 17  | 16 | 15  | 14  | 13 | 1    | 2    | 11 | 10     | 9   | 8   | 7   | 6   | 5   | 4 3  | 2   | 1   | 0 |
| Начальное | е состояние |     |      |                   |      |      |             |     |      |    |     |     | 0   |     |     |     |    |     |     |    |      |      |    |        | П   |     |     | 0   |     |      | T   | 0   |   |
| Описание  |             |     |      |                   |      |      |             |     |      |    | В   | ASE | ADI | OR  |     |     |    |     |     |    |      |      |    | $\Box$ | П   | I   | DES | CPN | VТ  |      | Т   | -   |   |
| 10-31     | BASEA       | DDI | R    |                   |      |      | дрес<br>исы |     |      |    |     |     |     |     |     |     |    |     | нтк | ад | pe   | c 02 | cΕ | )20(   | 000 | 0 - | ⊦ p | еал | ьн  | ый   | ад  | pec | 3 |
| 3-9       | DESCPI      | NT  |      | ука               | зат  | ель  | на          | дес | кри  | пт | ъp, | авт | ома | тич | еск | иии | кр | еме | нти | ру | етс. | яп   | ри | по     | лу  | чен | ии  | но  | вог | го г | іак | ета | t |
| 0-2       | _           |     |      | дан<br><i>зар</i> |      |      | рова        | іно |      |    |     |     |     |     |     |     |    |     |     |    |      |      |    |        |     |     |     |     |     |      |     |     |   |
| ETHxRD    | P           | Ук  | азат | ель,              | десь | срип | тора        | пр  | ием  | a  |     |     |     |     |     |     |    |     |     |    |      |      |    | _      | _   | _   |     |     |     |      |     |     |   |
| Номер бит | га          | 31  | 30   | 29                | 28   | 27   | 26          | 25  | 24   | 23 | 22  | 21  | 20  | 19  | 18  | 17  | 16 | 15  | 14  | 13 | 1    | 2    | 11 | 10     | 9   | 8   | 7   | 6   | 5   | 4 3  | 3 2 | 1   | 0 |

| Описан | ie .    | BASEADDR                                                         | DESCPNT           | -     |
|--------|---------|------------------------------------------------------------------|-------------------|-------|
| 10-31  | BASEADD | R базовый адрес дескрипторов. Необходимо выставлять адрес 0хE020 | 0000 + реальный г | адрес |
|        |         | в ПД, записываются только старшие биты $3110$                    |                   |       |
| 3-9    | DESCPNT | указатель на дескриптор, автоматически инкрементируется при по   | лучении нового па | акета |
|        |         | данных                                                           |                   |       |
| 0.2    | _       | anne aene una e au a                                             |                   |       |

| ETHxHASHMSB         | Хэ | ш та | абл и | ца, | стар | шая | час | ть |    |    |    |    |    |      |      |       |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------------------|----|------|-------|-----|------|-----|-----|----|----|----|----|----|----|------|------|-------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29    | 28  | 27   | 26  | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16    | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |    |      |       |     |      |     |     |    |    |    |    |    |    |      | 0    |       |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Описание            |    |      |       |     |      |     |     |    |    |    |    |    |    | Hash | tabl | e 64. | .32 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

31-0 HASHMSB Старшая часть хэш таблицы для многоадресных пакетов.

| ETHxHASHLSB         | Хэ | ш та | абли | ца, і | млад | цш ая | ча | сть |    |    |    |    |    |      |       |       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |
|---------------------|----|------|------|-------|------|-------|----|-----|----|----|----|----|----|------|-------|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|
| Номер бита          | 31 | 30   | 29   | 28    | 27   | 26    | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18   | 17    | 16    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 |
| Начальное состояние |    |      |      |       |      |       |    |     |    |    |    |    |    |      | 0     |       |    |    |    |    |    |    |   |   |   |   | , |   |   |   |     |
| Описание            |    |      |      |       |      |       |    |     |    |    |    |    |    | Hasl | ı tab | le 31 | 0  |    |    |    |    |    |   |   |   |   |   |   |   |   |     |

31-0 HASHLSB Младшая часть хэш таблицы для многоадресных пакетов.

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 138-172$ 



# 8.10 Контроллер USB(USBx)

# 8.10.1 Краткие характеристики

- 4 канала «IN»;
- 4 канала «ОUТ»;
- поддержка передач «Control», «Bulk», «Interrupt» и «Isochronous»;
- требуется внешний приёмопередатчик, подключаемый по интерфейсу ULPI;
- обмен данными с системной памятью по шине АНВ в режиме «Master»;
- внутренние буферы FIFO на приём и передачу снижают нагрузку на системную шину.



Рис. 43: Блок-схема USBx

Встроенный контроллер USB 2.0 поддерживает только функцию «Device» и реализует обмен в режиме Full Speed (12 Мбит/с) и High Speed (480 Мбит/с) с использованием внешнего приёмопередатчика, подключаемого по интерфейсу ULPI.

Для связи с шиной USB USBх использует внешний приёмопередатчик, подключаемый по ULPI (UTMI+ Low Pin Interface). Промежуточное хранение данных обеспечивают внутренние буферы FIFO общим объёмом 8 Кбайт (по 1 Кбайт на каждый канал). Принимаемые или передаваемые данные размещаются в буферах, находящихся в системной памяти. Информация о буферах хранится в таблице дескрипторов данных, также размещающейся в системной памяти. Доступ к памяти осуществляется по шине АНВ в режиме «ведущего».

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 139-172



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

Таким образом, если программа будет использовать USB, выводы МК, использующиеся для подключения ULPI, необходимо переключить на альтернативную функцию (с помощью регистра GPIOxBPS) сразу после запуска программы (т.е. выхода МК из сброса).

Передаваемые и принимаемые блоком USB данные хранятся в системной памяти.

Допустимо изменение следующих параметров:

- скорость работы USB;
- полярность USB;
- USB адрес(по умолчанию 0);
- установка глобального разрешения работы конечной точки;

## 8.10.2 Обзор системы

SNE (Speed Negotiation Engine) детектирует подключение мониторингом сигнала VBUS на USB соединителе. После обнаружения устойчивых 5 Вольт SNE ждет сброса и затем начинает высокоскоростное согласование (High-speed negotiation). После завершения согласования по скорости и процедуры сброса выбранный режим скорости работы (high-speed или full-speed) устанавливается в SIE (Serial Interface Engine), который начинает свою работу. SNE также детектирует и обрабатывает приостановку(suspend) и операции с режимами работы.

SIE включается после уведомления от SNE, что процедура сброса завершена. Затем ожидает прибывающих пакетов и обрабатывает их по стандарту USB 2.0. Данные записываются во внутренние буфера принадлежащие конечной точке приемнику.

AIE (AHB Interface Engine) предназначен для передачи данных по USB от внутренних буферов конечной точки на АНВ шину, используя дескриптор ПДП через интерфейс АНВ "ведущий".

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 140-172



### 8.10.3 РНҮ интерфейс

Контроллер поддерживает в качестве внешнего уровня PHY микросхемы с интерфейcom ULPI(UTMI+ Low Pin Interface).

- 8.10.4 Speed Negotiation Engine(SNE)
- 8.10.5 Serial Interface Engine(SIE)

## 8.10.6 Буферы конечной точки

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

Состояние буферов влияет на согласование посылаемое хосту в конце транзакции. В high-speed режиме пакетные (BULK) конечные точки на выход и управляющие (CONTROL) конечные точки на выход, которые находятся не в состоянии SETUP поддерживают PING протокол. Это означает, что в конце транзакции на выход к одной из этих конечных точек, устройство должно вернуть АСК, если возможен прием текущих данных и имеется место для другого пакета. Для USB контроллера это выполняется, когда второй буфер конечной точки пуст по завершению транзакции.

Если второй буфер не пуст, то взамен будет отправлен NYET. Если текущие данные не могут быть приняты (оба буфера не пусты когда пришел пакет), то будет отправлен NAK.

Для других типов конечных точек в высокоскоростном режиме и всех типов конечных точек в полноскоростном режиме вернется АСК, если данные приняты и не был получен NACK. Буфер конечной точки может быть сконфигурирован больше максимального значения по количеству данных для данной конечной точки. Для конечных точек типа IN при попытке записи данных объем, которых превышает размер буфера, будет сгенерировано несколько пакетов. Для конечных точек типа ОUТ большие буферы используются только для высоконагруженных конечных точек, где может произойти более одной транзакции на кадр. В этом случае данные из все пакетов в течение одного микрокадра записываются поочередно как прибыли в одиночный буфер и передаются через АНВ интерфейс. Все не высокозагруженные конечные точки также записывают один пакет в буфер.



# 8.10.7 AMBA Interface Engine(AIE)

## 8.10.8 Синхронизация

В контроллере имеется две области тактирования: АНВ и USB. АНВ область тактирования работает с такой же частотой, как и шина АНВ, тогда как USB область тактируется от ULPI. Граница между областями тактирования проходим между АІЕ, SIE и буферами конечных точек.

#### 8.10.9 Формирование сброса

Основной сброс (AMBA сброс) сбрасывает АНВ регистры, синхронизацию между USB и АНВ областями тактирования, USB PHY и USB SIE регистрами. Регистры конечной точки в SIE, согласно USB протоколу, сбрасываются когда получен USB сброс.

# 8.10.10 ПДП операции

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

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

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



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

Другой способ использования списка связности это установка у каждого дескриптора бита доступности, но при этом убедиться, что последний дескриптор выключен. Данный способ позволяет добавлять новые дескрипторы и включать их "на лету". На рис. 44 изображен пример структуры ПДП списка связности дескриптора в памяти:



Рис. 44: Структура ПДП списка связности дескриптора в памяти

#### 8.10.11 Конечные точки типа OUT

ПДП операции для конечных точек типа OUT формируются в соответствии с основным описанием представленным ранее. Небольшие отличия заключаются в индивидуальных битах и значении поля размер. Содержание всех слов дескриптора представлено в таблицах ниже.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 143-172



Когда разрешена работа дескриптора он выбирается контроллером, если бит доступности дескриптора установлен в "1"и как только буфер для соответствующей конечной точки содержит данные, полученные по USB, они будут записаны в память, начиная с адреса указанного в слове дескриптора - указатель на буфер данных. Содержимое одиночного внутреннего буфера всегда записывается в одиночный буфер дескриптора. Это всегда соответствует одиночному пакету USB, за исключением высоконагруженных изохронных и конечных точек по прерываниям. Количество записанных байт указывается в поле размер первого слова дескриптора, когда запись завершена, что отображается путем установки бита разрешения работы в "0". Затем SETUP бит также будет действителен. Когда бит разрешения работы установлен в "0"область памяти может быть использована снова.

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

Когда данные выбраны из внутреннего буфера он может использоваться SIE снова для приема нового пакета.

| OUT0       | USB OUT A    | ескриптор, часть 0 (смещение адреса 0х0)                                                                                             |
|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Номер бита | 31 30 29     | 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                         |
| Описание   |              | -   日   X   日   X   日   LENGTH                                                                                                       |
| 31-18      | _            | зарезервировано                                                                                                                      |
| 17         | SE           | данные были приняты из пакета SETUP взамен OUT.                                                                                      |
| 16         | _            | зарезервировано                                                                                                                      |
| 15         | IE           | разрешение прерываний ('1' - разрешено, '0' - запрещено). Прерывания буду вырабаты-                                                  |
|            |              | ваться после того как пакет для данного дескриптора считан во внутренние буферы и                                                    |
|            |              | обработан через SIE. Но это не означает, что пакет полностью передан.                                                                |
| 14         | NX           | указатель на следующий дескриптор действителен ('1' - действителен, '0' - не действите-                                              |
|            |              | лен).                                                                                                                                |
| 13         | EN           | разрешение операций с дескриптором (поле устанавливается последним) ('1' - разрешено,                                                |
|            |              | '0' - запрещено)                                                                                                                     |
| 12-0       | LENGTH       | размер блока принятых данных (данное поле действительно после выставления контрол-                                                   |
|            |              | лером бита EN в '0')                                                                                                                 |
| OUT1       | LIED OUT -   | ескриптор, часть 1 (смещение адреса 0x4)                                                                                             |
|            |              |                                                                                                                                      |
| Номер бита | 31   30   29 | 28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |
| Описание   |              | ADDRESS                                                                                                                              |
| 31-2       | ADDRESS      | указатель на начальный адрес в памяти, где будут размещены принятые данные                                                           |
| 1-0        | ADD RESS     |                                                                                                                                      |
| 1-0        | _            | зарезервировано                                                                                                                      |

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 144-172



| OUT2        | US | во  | UT | деск | срип | тор, | час | ть 2 | (см | еще | ение | адр  | eca  | 0x8) | )  |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|-------------|----|-----|----|------|------|------|-----|------|-----|-----|------|------|------|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| Номер бита  | 31 | 30  | 29 | 28   | 27   | 26   | 25  | 24   | 23  | 22  | 21   | 20   | 19   | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| Описание    |    |     |    |      |      |      |     |      |     |     |      |      |      | NI   | DP |    |    |    |    |    |    |    |   |   | , |   |   |   |   |   | _ |
| 31-2<br>1-0 | N  | IDP |    |      |      | ель  |     |      | цую | щи  | йд   | ескр | оип' | гор  |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

#### 8.10.12 Конечные точки типа IN

ПДП операции для конечных точек типа IN формируются в соответствии с основным описанием представленным ранее. Небольшие отличия заключаются в индивидуальных битах и значении поля размер. Содержание всех слов дескриптора представлено в таблицах ниже.

Когда разрешена работа дескриптора он выбирается контроллером, если бит доступности дескриптора установлен в "1"контроллер начинает обрабатывать дескриптор и выбирает количество байт, указанных в поле LENGTH, во внутренние буферы, принадлежащие конечной точке, как только бит доступности дескриптора установлен в "1".

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

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

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

Если итоговое количество байт больше, чем внутренний буфер, то пакет не посылается (данные из внутреннего буфера выбрасываются) и устанавливается в "1"бит ML для

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 145-172



последнего дескриптора. Затем выборка начинается снова.

| IN0        | USB IN десь | хриптор, часть 0 (смещение адреса 0х0)                                                                                               |
|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Номер бита | 31 30 29 2  | 28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |
| Описание   |             | - B Z ENGTH                                                                                                                          |
| 31-19      | _           | зарезервировано                                                                                                                      |
| 18         | МО          | данные из следующего дескриптора должны быть считаны в текущий внутренний буфе                                                       |
|            |             | ('1' - разрешено, '0' - запрещено)                                                                                                   |
| 17         | PΙ          | разрешение формирования прерываний, когда пакет полностью передан по USB ('1' - раз                                                  |
|            |             | решено, '0' - запрещено)                                                                                                             |
| 16         | ML          | индикация установкой данного бита в "1"попытки передачи данных размером больше бу                                                    |
|            |             | фера                                                                                                                                 |
| 15         | IE          | разрешение прерываний ('1' - разрешено, '0' - запрещено). Прерывания буду вырабаты                                                   |
|            |             | ваться после того как пакет для данного дескриптора считан во внутренние буферы                                                      |
|            |             | обработан через SIE. Но это не означает, что пакет полностью передан.                                                                |
| 14         | NX          | указатель на следующий дескриптор действителен ('1' - действителен, '0' - не действите                                               |
|            |             | лен).                                                                                                                                |
| 13         | EN          | разрешение операций с дескриптором (поле устанавливается последним) ('1' - разрешено                                                 |
|            |             | '0' - запрещено)                                                                                                                     |
| 12-0       | LENGTH      | размер блока данных на передачу                                                                                                      |
| IN1        | USB IN десь | криптор, часть 1 (смещение адреса 0x4)                                                                                               |
| Номер бита | 31 30 29 2  | 28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0 |
| Описание   |             | ADDRESS —                                                                                                                            |
| 31-2       | ADDRESS     | указатель на начальный адрес в памяти, где будут размещены данные на передачу                                                        |
| 1-0        | _           | зарезервировано                                                                                                                      |
| 1 0        |             | sup so op sup v ou no                                                                                                                |
| IN2        | USB IN десь | криптор, часть 2 (смещение адреса 0х8)                                                                                               |
| Номер бита | 31 30 29 2  | 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                         |
| Описание   |             | NDP _                                                                                                                                |
| 31-2       | NDP y       | казатель на следующий дескриптор                                                                                                     |
| 1-0        | - 3         | арезервировано                                                                                                                       |

- 8.10.13 Конечные точки
- 8.10.14 Управляющие конечные точки
- 8.10.15 Пакетные конечные точки
- 8.10.16 Конечные точки по прерываниям
- 8.10.17 Изохронные конечные точки



#### 8.10.18 Описание регистров

Базовый адрес USB - 0xFFFF 0000.

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра. Для конечных точек 1,2,3 необходимо использовать смещение для каждого регистра на 10h, 20h, 30h соответсвтенно. Например, для конечной точки 2 регистр USBxEN2\_CR\_OUT будет иметь смещение адреса 20h, а регистр USBxEN2\_ST\_IN смещение 12Ch.

| Регистр             | Смещение адреса | Доступ | Описание                                         |
|---------------------|-----------------|--------|--------------------------------------------------|
| USBxEP0_OUT_CR      | 00h             | RW     | Регистр управления конечной точки 0 на выход     |
| USBxEP0_OUT_DMA_CR  | 04h             | RW     | Регистр управления ПДП конечной точки 0 на выход |
| USBxEP0_OUT_DM_ADDR | 08h             | RW     | Регистр адреса ПДП конечной точки 0 на выход     |
| USBxEP0_IN_CR       | 100h            | RW     | Регистр управления конечной точки 0 на вход      |
| USBxEP0_IN_DMA_CR   | 104h            | RW     | Регистр управления ПДП конечной точки 0 на вход  |
| USBxEP0_IN_DMA_ADDR | 108 h           | RW     | Регистр адреса ПДП конечной точки 0 на вход      |
| USBxCR              | 200 h           | RW     | Регистр управления                               |
| USBxST              | 204h            | RW     | Регистр состояния                                |

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 147-172



| EP0_OUT     | $_{ m CR}$       | Регистр управления конечной точки 0 на               | вых    | од    |          |      |            |      |       |      |                 |      |     |      | _   |      |     |      | _    | _    |     |    |    |
|-------------|------------------|------------------------------------------------------|--------|-------|----------|------|------------|------|-------|------|-----------------|------|-----|------|-----|------|-----|------|------|------|-----|----|----|
| Номер бита  |                  | 31   30   29   28   27   26   25   24   23   22   21 | 20     | 19    | 18       | 17   | 16 15      | 14   | 13    | 12   | 2               | 11   | 10  | 9    | 8   | 7    | 6   |      | 4    | 3    | 2   | 1  | 0  |
| Начальное с | остояние         | 0                                                    | 0      | 0     | 0        |      |            |      |       | 0    |                 |      |     |      |     |      | L   | 0    |      | 0    | 0   | 0  | 0  |
| Описание    |                  | <del></del>                                          | I.I.   | G     | CS       |      |            |      | M     | AXF  | L               |      |     |      |     |      | L   | NT   | 1    | ГΤ   | EH  | ED | EV |
| 31-21       | _                | зарезервировано                                      |        |       |          |      |            |      |       |      |                 |      |     |      |     |      |     |      |      |      |     |    |    |
| 20          | PΙ               | разрешение прерываний на ках                         | кдыі   | й по  | элуч     | ен   | ный па     | кет  | по    | US   | В               | дл   | ЯК  | кон  | еч  | ной  | i 7 | гочі | ки ( | паі  | кет |    |    |
|             |                  | был записан во внутренний бус                        | þep)   | ('1   | ,<br>- 1 | раз  | решенс     | , '0 | , - : | запј | oe <sub>i</sub> | цеі  | ао) | ).   |     |      |     |      |      |      |     |    |    |
| 19          | _                | зарезервировано                                      |        |       |          |      |            |      |       |      |                 |      |     |      |     |      |     |      |      |      |     |    |    |
| 18          | $_{\mathrm{CS}}$ | разрешение возврата STALL д.                         | е вп   | гап   | ов с     | да   | нными      | и    | сост  | про  | ие              | M    | ву  | пр   | ав  | ЛЯІ  | ю   | цих  | П    | epe, | ца- |    |    |
|             |                  | чах('1' – разрешено, '0' - запре                     | ещен   | o).   | Авт      | ома  | атичес     | ки   | бит   | очі  | иш              | ae:  | гся | п    | ри  | пр   | иє  | еме  | СЛ   | еду  | ю-  |    |    |
|             |                  | щего маркера(token) SETUP. И                         | СПОЛ   | ьзу   | етс      | ядл  | ля коне    | ечн  | ых    | гоч  | ек,             | СК   | юн  | фи   | ту  | ри т | ро  | ван  | нь   | IX I | ак  |    |    |
|             |                  | управляющие.                                         |        |       |          |      |            |      |       |      |                 |      |     |      |     |      |     |      |      |      |     |    |    |
| 17-7        | MAX              | PL установка максимального разм                      | ера с  | ди    | гРОН     | 101  | o USB 1    | пак  | ета   | пос  | ы.              | тае  | M C | го   | ил  | и г  | ıp: | ини  | ма   | еме  | ого |    |    |
|             |                  | для данной конечной точки. N                         | Лакс   | има   | альн     | 10 E | возмож     | ны   | йр    | азм  | ер              | ΟZ   | ІИЕ | нон  | нС  | го   | п   | аке  | га   | paı  | зен |    |    |
|             |                  | 1024 байта.                                          |        |       |          |      |            |      | •     |      | •               |      |     |      |     |      |     |      |      | •    |     |    |    |
| 6-5         | NT               | установка количества дополни                         | тель   | ных   | к тр     | анз  | закций     | на   | ми    | кро  | ка              | др   | ДЈ  | пя   | вь  | ICO1 | ко  | ско  | po   | СТН  | ых  |    |    |
|             |                  | конечных точек и на кадр для і                       | лолн   | оск   | opo      | стн  | ных кон    | ечь  | ых    | точ  | ек              | :. Д | Įав | ны   | ıе  | бит  | ъ   | пр   | еді  | аз   | на- |    |    |
|             |                  | чены только для изохронных к                         | онеч   | ны    | хтС      | чен  | к.         |      |       |      |                 |      |     |      |     |      |     |      |      |      |     |    |    |
| 4-3         | TT               | установка типа работы конечно                        | йто    | ки    | : "00    | Эуг  | правляі    | ющ   | ая (  | СТІ  | RL              | ), ' | 01  | . из | ох  | :poi | нЕ  | ая(  | IS   | OC:  | Н), |    |    |
|             |                  | "10 пакетная(BULK), "11 по г                         | трер   | ыва   | ния      | м(1  | INTER      | RU   | PT    | ). Т | ол              | ьк   | O B | кон  | еч  | ны   | e   | точ  | ки   | T    | па  |    |    |
|             |                  | выход (OUT) должны устанав                           | лива   | атьс  | Ся в     | ти   | ип СТБ     | RL.  | В :   | этог | vi i            | слу  | ча  | е    | KOI | неч  | нә  | г    | гоч  | ка   | на  |    |    |
|             |                  | вход (IN) с этим же номером б                        | удет   | ав    | тома     | ати  | ически з   | зад  | ейс:  | гвон | зан             | ıa.  |     |      |     |      |     |      |      |      |     |    |    |
| 2           | EH               | остановка конечной точки ('1'                        | - o    | стаг  | нови     | ca i | включе     | на,  | ,0,   | - 0  | ост             | ан   | ові | ка   | вь  | ІКЛ  | ю   | чен  | a).  | Εc   | ли  |    |    |
|             |                  | данный бит установлен в "1 то в                      | все т  | ран   | сфе      | ры   | і к данн   | юй   | точ   | ке б | буд             | ут   | пС  | лу   | ча  | ιть  | ОΤ  | вет  | S    | ГΑΙ  | LL. |    |    |
| 1           | ED               | отключение конечной точки ('1                        | L' – ( | отк.  | люч      | енс  | 0, '0' - 1 | не   | ткј   | РӨІ  | ен              | o).  | E   | СЛИ  | ιд  | цани | ΗЬ  | ій б | бит  | уc   | та- |    |    |
|             |                  | новлен в "1 то все трансферы в                       | сдан   | ноі   | йто      | чке  | е будут    | по   | луч   | ать  | O               | гве  | тТ  | NΑ   | K.  |      |     |      |      |      |     |    |    |
| 0           | EV               | разрешение работы конечной т                         | очкі   | ı (': | 1' –     | раз  | зрешен     | o, ' | o, -  | зап  | pe              | ще   | но  | ). I | Ξc. | ли   | pa  | бот  | a :  | зап  | pe- |    |    |
|             |                  | щена, то все трансферы к данн                        | гой т  | тРО   | ке бу    | уду  | проиг      | нор  | иро   | ван  | ы               | без  | зс  | ОГЛ  | ıac | сова | λH  | ия.  |      |      |     |    |    |
|             |                  |                                                      |        |       |          |      |            |      |       |      |                 |      |     |      |     |      |     |      |      |      |     |    |    |

| EP0 OUT D      | M CR  | Регистр управления ПДП конечной точки 0 на выход                                                                                                     |
|----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Номер бита     |       | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1   0  |
| Начальное сост | ояние | 0                                                                                                                                                    |
| Описание       |       | AE                                                                                                                                                   |
| 31-11          | _     | зарезервировано                                                                                                                                      |
| 10             | AE    | Бит сигнализации ошибки на шине АНВ для данной конечной точки('0' – нет ошибки, '1' – есть ошибка).                                                  |
| 9-4            | _     | зарезервировано                                                                                                                                      |
| 3              | AD    | Отключение обработки дескрипторов(установка бита DA в '0') и отклонение текущей передачи(приема) ПДП('0' - запрещено, '1' - разрешено).              |
| 2              | ΑI    | Разрешение формирования прерываний, когда происходят ошибки на шине АНВ.                                                                             |
| 1              | IE    | Разрешение прерываний ПДП('0' – запрещено, '1' – разрешено). Каждый раз при приеме                                                                   |
|                |       | или передаче данных через дескриптор с установленным битом разрешения прерываний, прерывания будут формироваться когда установлен текущий бит в '1'. |
| 0              | DA    | Бит индикации включения (готовности) одного или нескольких дескрипторов ('0' – не готовы, '1' – готовы).                                             |
|                |       | 10111, 1 1010111,                                                                                                                                    |



| $EP0_OUT_DM_ADDR$   | Per | гист | рад | реса | ιПД | ЦΠ в | оне | чной | і тот | чки | 0 на | вы | сод |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |
|---------------------|-----|------|-----|------|-----|------|-----|------|-------|-----|------|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|
| Номер бита          | 31  | 30   | 29  | 28   | 27  | 26   | 25  | 24   | 23    | 22  | 21   | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1 | 0 |
| Начальное состояние |     |      |     |      |     |      |     |      |       |     |      |    |     | (  | )  |    |    |    |    |    |    |    |   |   |   |   |   |   |   | -   |   |
| Описание            |     |      |     |      |     |      |     |      |       |     |      |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |

31-2 DESCADDR Адрес следующего дескриптора

0-1 — зарезервировано

| EP0 IN     | CB               | Регистр управления конечной точки 0 на вход                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |
|------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| Номер бита |                  | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |
| Начальное  |                  | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |
| Описание   | cocronine        | - EBS MAXPL NT TT 匿品 A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |
| Описание   |                  | - HOO MAAPE NI II HE HE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |
| 31-21      | _                | зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 20         | PΙ               | разрешение прерываний на каждый полученный пакет по USB для конечной точки(пакет                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |
|            |                  | был записан во внутренний буфер) ('1' – разрешено, '0' - запрещено).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |
| 19         | _                | зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 18         | $^{\mathrm{CS}}$ | разрешение возврата STALL для этапов с данными и состоянием в управляющих переда-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |
|            |                  | чах ('1' – разрешено, '0' - запрещено). Автоматически бит очищается при приеме следую-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |
|            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 17-7       | MAXI             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            | .,               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 6-5        | NT               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 0-0        | 11 1             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 4.0        | mm               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
| 4-3        | TT               | разрешение прерываний на каждый полученный пакет по USB для конечной точки (пакет был записан во внутренний буфер) ('1' – разрешено, '0' - запрещено). зарезервировано разрешение возврата STALL для этапов с данными и состоянием в управляющих переда чах ('1' – разрешено, '0' - запрещено). Автоматически бит очищается при приеме следующего маркера (token) SETUP. Используется для конечных точек, сконфигурированных как управляющие. установка максимального размера одиночного USB пакета посылаемого или принимаемого для данной конечной точки. Максимально возможный размер одиночного пакета равел 1024 байта. установка количества дополнительных транзакций на микрокадр для высокоскоростных конечных точек и на кадр для полноскоростных конечных точек. Данные биты предназначены только для изохронных конечных точек. установка типа работы конечной точки: "00 управляющая (CTRL), "01 изохронная (ISOCH) "10 пакетная (BULK), "11 по прерываниям (INTERRUPT). Только конечные точки типа выход (ОUT) должны устанавливаться в тип СТRL. В этом случае конечная точка наход (IN) с этим же номером будет автоматически задействована. остановка конечной точки ('1' – остановка включена, '0' - остановка выключена). Если                                                                                                     |  |  |  |  |  |  |  |  |  |  |  |
|            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            |                  | разрешение возврата STALL для этапов с данными и состоянием в управляющих передачах ('1' — разрешено, '0' - запрещено). Автоматически бит очищается при приеме следующего маркера (token) SETUP. Используется для конечных точек, сконфигурированных как управляющие. установка максимального размера одиночного USB пакета посылаемого или принимаемого для данной конечной точки. Максимально возможный размер одиночного пакета равен 1024 байта. установка количества дополнительных транзакций на микрокадр для высокоскоростных конечных точек и на кадр для полноскоростных конечных точек. Данные биты предназначены только для изохронных конечных точек. установка типа работы конечной точки: "00 управляющая (CTRL), "01 изохронная (ISOCH), "10 пакетная (BULK), "11 по прерываниям (INTERRUPT). Только конечные точки типа выход (OUT) должны устанавливаться в тип CTRL. В этом случае конечная точка на вход (IN) с этим же номером будет автоматически задействована.                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |
| 2          | EH               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |
|            |                  | данный бит установлен в "1 то все трансферы к данной точке будут получать ответ STALL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |
| 1          | ED               | был записан во внутренний буфер) ('1' – разрешено, '0' - запрещено).  зарезервировано разрешение возврата STALL для этапов с данными и состоянием в управляющих передачах ('1' – разрешено, '0' - запрещено). Автоматически бит очищается при приеме следующего маркера (token) SETUP. Используется для конечных точек, сконфигурированных как управляющие.  установка максимального размера одиночного USB пакета посылаемого или принимаемого для данной конечной точки. Максимально возможный размер одиночного пакета равен 1024 байта.  установка количества дополнительных транзакций на микрокадр для высокоскоростных конечных точек и на кадр для полноскоростных конечных точек. Данные биты предназначены только для изохронных конечных точек.  установка типа работы конечной точки: "00 управляющая (CTRL), "01 изохронная (ISOCH), "10 пакетная (BULK), "11 по прерываниям (INTERRUPT). Только конечные точки типа выход (ОUT) должны устанавливаться в тип CTRL. В этом случае конечная точка на вход (IN) с этим же номером будет автоматически задействована.  остановка конечной точки ('1' – остановка включена, '0' - остановка выключена). Если данный бит установлен в "1 то все трансферы к данной точке будут получать ответ STALL.  отключение конечной точки ('1' – отключено, '0' - не отключено). Если данный бит уста- |  |  |  |  |  |  |  |  |  |  |  |
|            |                  | новлен в "1 то все трансферы к данной точке будут получать ответ NAK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |  |  |
| 0          | $\mathrm{EV}$    | разрешение работы конечной точки ('1' - разрешено, '0' - запрещено). Если работа запре-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |  |  |

| $EP0_IN_DM_ADDR$    | Регистр адреса ПДП конечной точки 0 на вход                                                                                                     |     |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Номер бита          | 31   30   29   28   27   26   25   24   23   22   21   20   19   18   17   16   15   14   13   12   11   10   9   8   7   6   5   4   3   2   1 | 1 0 |
| Начальное состояние | 0 -                                                                                                                                             | - 🗆 |
| Описание            | DESCADDR -                                                                                                                                      | -T  |

щена, то все трансферы к данной точке буду проигнорированы без согласования.

31-2 DESCADDR Адрес следующего дескриптора

0-1 — зарезервировано

| USBxCR              | Pe | гист | руп | рав        | лені | я  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |            |   |   |   |    |   |     |     |   |
|---------------------|----|------|-----|------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------------|---|---|---|----|---|-----|-----|---|
| Номер бита          | 31 | 30   | 29  | 28         | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8          | 7 | 6 | 5 | 4  | 3 | 2 1 | (   | ) |
| Начальное состояние | 0  | 0    | 0   | 0          | 0    |    |    |    |    |    | _  |    |    |    |    |    | -  | 0  | 0  | 0  |    | -  |   | 0          |   |   |   | -  |   |     | T - | ٦ |
| Описание            | SI | UI   | VI  | $_{ m SP}$ | H    |    |    |    |    |    | _  |    |    |    |    |    | FT | EP | DH | RW |    | TS |   | $_{ m TM}$ |   |   |   | UA |   |     | 1   | 3 |

- 31 SI разрешение прерываний при изменении состояния режима приостановки(suspend) ('0' запрещено, '1' разрешено).
- 30 UI разрешение прерываний при обнаружении сигнала сброса USB ('0' запрещено, '1' разрешено).
- 29 VI разрешение прерываний при изменении состояния VBUS ('0' запрещено, '1' разрешено).
- 28 SP разрешение прерываний при изменении скоростного режима ('0' запрещено, '1' разрешено).
- 27 FI разрешение прерываний при получении маркера начала кадра(SOF) ('0' запрещено, '1' разрешено).



| 26-16 | _  | зарезервировано                                                                         |
|-------|----|-----------------------------------------------------------------------------------------|
| 15    | FT | разрешение функционального тестового режима, который сокращает все счетчики, такие      |
|       |    | как сброс и таймеры до 8 системных циклов. ('0' – запрещено, '1' – разрешено).          |
| 14    | EP | разрешение включения подтяжки на линии $D+$ подключенной к хосту ('0' – запрещено, '1'  |
|       |    | – разрешено).                                                                           |
| 13    | DH | управление скоростными режимами ('0' - высокоскоростной режим, '1' - полноскоростной    |
|       |    | режим).                                                                                 |
| 12    | RW | запуск индикации удаленного сигнала wakeup. Данный бит переходит в состояние '0' по-    |
|       |    | сле завершения передачи удаленного сигнала wakeup в режиме приостановки(suspend) и      |
|       |    | немедленно если не в режиме приостановки.                                               |
| 11-9  | TS | выбор типа тестового режима('001' - Test_J, '010' - Test_K, '011' - Test_SE0_NAK, '100' |
|       |    | - Test_Packet).                                                                         |
| 8     | TM | разрешение режима тестирования, который нельзя отключить без сброса питания ядра ('0'   |
|       |    | – разрешено, '1' – запрещено)                                                           |
| 7-1   | UA | адрес назначенный устройству на USB шине.                                               |
| 0     | su | разрешение установки адреса USB из поля UA('0' - запрещено, '1' - разрешено).           |

| USBxST              | Pe | гист | р со | стоя | кині |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    |   |   |   |   |   |
|---------------------|----|------|------|------|------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----|---|---|---|---|---|
| Номер бита          | 31 | 30   | 29   | 28   | 27   | 26  | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
| Начальное состояние |    | -    | -    |      |      | _   | - ' |    | -  |    |    | _  |    |    | -  | -  | -  | -  |    | -  |    |    |   |   |   |   |    |   |   |   |   |   |
|                     |    | Ī    | Ž    |      |      | EPO | 5   |    |    |    |    |    |    |    | 1  | R  | В  |    |    |    |    |    |   |   |   |   |    |   |   |   |   |   |
| Описание            |    | Ę    | Z    |      |      | Ž   | Ž.  |    | -  |    |    | _  |    |    | S  | I  | 🖺  | SF |    | AF |    |    |   |   |   | I | FΝ |   |   |   |   |   |

| 31-28   | NEPI | количество реализованных конечных точек типа IN.                                         |
|---------|------|------------------------------------------------------------------------------------------|
| 27 - 24 | NEPO | количество реализованных конечных точек типа ОUТ.                                        |
| 23-18   | _    | зарезервировано                                                                          |
| 17      | SU   | индикация режима приостановки(suspend) ('0' - режим включен, '1' - режим отключен).      |
| 16      | UR   | индикация сигнала сброса USB ('0' - нет сброса, '1' - есть сброс). Бит очищается записью |
|         |      | '1'.                                                                                     |
| 15      | VB   | индикация корректного уровня напряжения на линии VBUS('0' - нет напряжения, '1' -        |
|         |      | есть напряжение).                                                                        |
| 14      | SP   | текущий скоростной режим шины ('0' – высокоскоростной(high speed), '1' – полноскорост-   |
|         |      | ной(full speed))                                                                         |
| 13-11   | AF   | количество дополнительных кадров, полуученных с текущим номером кадра.                   |
| 10-0    | FN   | значение последнего принятого маркера SOF.                                               |
|         |      |                                                                                          |



### 8.11 Контроллер PWM(PWMx)

#### 8.11.1 Краткие характеристики

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



Рис. 45: Блок-схема PWM

Контроллер ШИМ (PWM) предназначен для генерирования широтно-модулированных импульсов. PWM является 4-х канальным и имеет режим генерации одиночного импульса, а также допускает возможность изменения периода счётчика во время его работы (при соблюдении условий, описываемых в соответствующем пункте).

#### 8.11.2 Инициализация ШИМ

Для инициализации ШИМ необходимо задать в регистре PWM\_CR режим работы интерфейса и счётчика, а также выбрать каналы, работу которых мы хотим разрешить. Следующим шагом устанавливаем активный/неактивный уровень включённого/выключенного канала. Кроме того возможно разрешить прерывания соответствующего канала, а также возможно разрешение прерываний по переполнению счётчика.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 151-172



#### 8.11.3 Режимы работы ШИМ

Генерация импульсов ШИМ возможна в однократном или периодическом режиме, установка производится в бите PWM\_CR(PULSE\_MODE). Счётчик запускается в трёх режимах: инкрементирующий, декрементирующий и режим увеличения до максимального значения, а потом уменьшения до нуля. Установка режима работы счётчика производится в бите PWM\_CR(AUTO\_RELOAD). Разрешается активировать возможность изменения периода счётчика во время его работы в бите PWM\_CR(CNT\_MODE), но только при определённых условиях.

#### 8.11.4 Прерывания ШИМ

Прерывания бывают двух типов: по переполнению счётчика и по достижению счётчиком определённого канала значения регистра сравнения. Прерывания разрешаются в регистре управления, а запрос прерываний фиксируется в регистре PWM—INT.

#### 8.11.5 Длительность импульса ШИМ

Длительность активного уровня импульса ШИМ будет определяться как разность значения периода счётчика PWM\_CNT и значения регистра сравнения PWM\_CMPCHn, умноженная на произведение длительности одного такта процессора и значения предделителя PWM\_PSC.

$$T_{ACT} = (T_{cnt} - T_{cmpch}) \cdot T_{sys} \cdot (PSC + 1)$$



#### 8.11.6 Описание регистров

Базовый адрес PWM - 0xC001 2000.

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

**Примечание**: Регистры сравнения при n=[0;3] будут иметь следующие адреса смещения:

PWMxCMPCH0 - 0x20

PWMxCMPCH1 - 0x24

PWMxCMPCH2 - 0x28

PWMxCMPCH3 - 0x2C

| Регистр    | Смещение адреса | Доступ | Описание                           |
|------------|-----------------|--------|------------------------------------|
| PWMxCR     | 00h             | RW     | Регистр управления                 |
| PWMxINT    | 04h             | RW     | Регистр прерываний                 |
| PWMxCNTVAL | 08h             | RW     | Регистр текущего значения счётчика |
| PWMxPSC    | 0Ch             | RW     | Регистр значения предделителя      |
| PWMxCNT    | 10h             | RW     | Регистр периода счётчика           |
| PWMxCMPCHn | 0x20-0x2Ch      | RW     | Регистр периода счётчика           |

| PWMxCR              | Pe | гист | руп | грав | лени | я  |    |    |        |        |        |        |           |           |           |           |          |          |           |           |        |        |        |        |   |   |   |        |         |            |           |
|---------------------|----|------|-----|------|------|----|----|----|--------|--------|--------|--------|-----------|-----------|-----------|-----------|----------|----------|-----------|-----------|--------|--------|--------|--------|---|---|---|--------|---------|------------|-----------|
| Номер бита          | 31 | 30   | 29  | 28   | 27   | 26 | 25 | 24 | 23     | 22     | 21     | 20     | 19        | 18        | 17        | 16        | 15       | 14       | 13        | 12        | 11     | 10     | 9      | 8      | 7 | 6 | 5 | 4      | 3 2     | 1          | 0         |
| Начальное состояние |    |      |     | (    | )    |    |    |    | 0      | 0      | 0      | 0      | 0         | 0         | 0         | 0         | 0        | 0        | 0         | 0         | 0      | 0      | 0      | 0      |   | 0 |   | 0      | 0       | 0          | 0         |
|                     |    |      |     |      |      |    |    |    | H3MODE | H2MODE | HIMODE | HOMODE | N_CH3_IRQ | N_CH2_IRQ | N_CH1_IRQ | N_CH0_IRQ | UT_LVL_3 | UT_LVL_2 | OUT_LVL_1 | OLT_LVL_0 | H_EN_3 | H_EN_2 | H_EN_1 | H_EN_0 |   |   |   | VF_IRQ | NT_MODE | UTO_RELOAD | ULSE_MODE |
| Описание            |    |      |     |      | _    |    |    |    | Ü      | ರ      | Ü      | ರ      | 园         | 园         | 崮         | EN        | ರ        | 90       | □         | □         | ŭ      | ರ      | ಶ      | ŭ      |   | _ |   | Ó      |         | AI         | PI        |

| 24 - 31 | _                               | зарезервировано                                                                          |
|---------|---------------------------------|------------------------------------------------------------------------------------------|
| 23      | $\mathrm{CH3}\_\mathrm{MODE}$   | Установка активного уровня включенного канала 3 ('0' – логический 0, '1' – логическая 1) |
| 22      | $\mathrm{CH2}\_\mathrm{MODE}$   | Установка активного уровня включенного канала 2 ('0' – логический 0, '1' – логическая 1) |
| 21      | $\mathrm{CH1}_{-}\mathrm{MODE}$ | Установка активного уровня включенного канала 1 ('0' – логический 0, '1' – логическая 1) |
| 20      | $\mathrm{CH0}_{-}\mathrm{MODE}$ | Установка активного уровня включенного канала 0 ('0' – логический 0, '1' – логическая 1) |
| 19      | EN_CH3_IRQ                      | Разрешение прерывания канала 3 ('0' – запрещено, '1' – разрешено)                        |
| 18      | $EN_CH2_IRQ$                    | Разрешение прерывания канала 2 ('0' – запрещено, '1' – разрешено)                        |
| 17      | $EN_CH1_IRQ$                    | Разрешение прерывания канала 1 ('0' – запрещено, '1' – разрешено)                        |
| 16      | $EN_CH0_IRQ$                    | Разрешение прерывания канала 0 ('0' – запрещено, '1' – разрешено)                        |
| 15      | $OUT_LVL_3$                     | Установка неактивного уровня включенного канала 3 ('0' – логический 0, '1' – логическая  |
|         |                                 | 1)                                                                                       |
| 14      | $\mathrm{OUT}_\mathrm{LVL}_2$   | Установка неактивного уровня включенного канала 2 ('0' – логический 0, '1' – логическая  |
|         |                                 | 1)                                                                                       |
| 13      | OUT_LVL_1                       | Установка неактивного уровня включенного канала 1 ('0' – логический 0, '1' – логическая  |
|         |                                 | 1)                                                                                       |
| 12      | OUT_LVL_0                       | Установка неактивного уровня включенного канала 0 ('0' – логический 0, '1' – логическая  |
|         |                                 | 1)                                                                                       |
| 11      | $\mathrm{CH} \_\mathrm{EN3}$    | Разрешение работы канала 3 ('0' – запрещено, '1' – разрешено)                            |



| 10  | $\mathrm{CH}_{-}\mathrm{EN2}$ | Разрешение работы канала 2 ('0' – запрещено, '1' – разрешено)                          |
|-----|-------------------------------|----------------------------------------------------------------------------------------|
| 9   | CH_EN1                        | Разрешение работы канала 1 ('0' – запрещено, '1' – разрешено)                          |
| 8   | CH_EN0                        | Разрешение работы канала 0 ('0' – запрещено, '1' – разрешено)                          |
| 5-7 | _                             | зарезервировано                                                                        |
| 4   | $OVF_IRQ$                     | Разрешение прерывания по переполнению счётчика ('0' – запрещено, '1' – разрешено)      |
| 2-3 | $CNT\_MODE$                   | Установка режима работы счетчика: 10 - счетчик увеличивается до максимального значе-   |
|     |                               | ния, а потом уменьшается до нуля 01 - декрементирующий 00 - инкрементирующий           |
| 1   | AUTO_RELOAD                   | Разрешение изменения периода счетчика во время его работы ('0' - запрещено, '1' - раз- |
|     |                               | решено)                                                                                |
| 0   | PULSE MODE                    | Разрешение работы в однократном режиме ('0' - запрещено, '1' - разрешено)              |

| PWMxINT             | Pe | гист | рпр | рерь | іван | ий |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |     |     |    |    |
|---------------------|----|------|-----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|-----|-----|----|----|
| Номер бита          | 31 | 30   | 29  | 28   | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 4 | 3   | 2   | 1  | 0  |
| Начальное состояние |    |      |     |      |      |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |    |   |   |   |   |     | 0   | 0   | 0  | 0  |
|                     |    |      |     |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     | RQ  | RQ  | RO | RQ |
|                     |    |      |     |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     | 3_I | 2_I |    | _  |
| Описание            |    |      |     |      |      |    |    |    |    |    |    |    |    | —s |    |    |    |    |    |    |    |    |   |   |   |   |     | B   | H   | Ħ  | [흥 |

| 4-31 | _                              | зарезервировано                                     |
|------|--------------------------------|-----------------------------------------------------|
| 3    | $\mathrm{CH3} \_\mathrm{IRQ}$  | Счетчик канала 3 достиг значения регистра сравнения |
| 2    | ${ m CH2\_IRQ}$                | Счетчик канала 2 достиг значения регистра сравнения |
| 1    | $\mathrm{CH1}_{-}\mathrm{IRQ}$ | Счетчик канала 1 достиг значения регистра сравнения |
| 0    | CH0 IRQ                        | Счетчик канала 0 достиг значения регистра сравнения |

| PWMxCNTVAL          | Per | гист | р те | куш | его | знач | ени | ясч | ётчі | іка |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |
|---------------------|-----|------|------|-----|-----|------|-----|-----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|
| Номер бита          | 31  | 30   | 29   | 28  | 27  | 26   | 25  | 24  | 23   | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 |
| Начальное состояние |     |      |      |     |     |      |     | (   | )    |     |    |    |    |    |    |    |    |    |    |    |    |    | (  | 0  |    |   |   |   |   |   |   |
| Описание            |     |      |      |     |     |      |     |     |      |     |    |    |    |    |    |    |    |    |    |    |    | С  | NT | _V | \L |   |   |   |   |   |   |

 16-31
 —
 зарезервировано

 0-15
 CNT
 VAL
 Текущее значение счётчика

 PWMxPSC
 Регистрационного вережения предделителя

 Номер бита
 31
 30
 29
 28
 27
 26
 25
 24
 23
 22
 21
 20
 19
 18
 17
 16
 15
 14
 13
 12
 11
 10
 9
 8
 7
 6
 5
 4
 3
 2
 1
 0

 Описание
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 1
 <t

16-31 — *зарезервировано* 0-15 PSC Значение предделителя

| PWMxCNT             | Pe | гист | рпе | рио, | дас | чётч | ика |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |     |
|---------------------|----|------|-----|------|-----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|-----|
| Номер бита          | 31 | 30   | 29  | 28   | 27  | 26   | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6 | 5 | 4 | 3 | 2 1 | 1 0 |
| Начальное состояние |    |      |     |      |     |      |     | (  | )  |    |    |    |    |    |    |    |    |    |    |    |    |    | (  | 0  |    |   |   |   |   |     |     |
| Описание            |    |      |     |      |     |      |     | -  |    |    |    |    |    |    |    |    |    |    |    |    |    | С  | NT | ΡI | ER |   |   |   |   |     |     |

 16-31
 —
 зарезервировано

 0-15
 CNT
 РЕК
 Значение периода счётчика

| PWMxCMPCHn          | Per       | гист | р ср | авне | ения |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |
|---------------------|-----------|------|------|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|-----|
| Номер бита          | 31        | 30   | 29   | 28   | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 [ | 1 0 |
| Начальное состояние |           |      |      |      |      |    |    | C  | )  |    |    |    |    |    |    |    |    |    |    |    |    |    | ( | ) |   |   |   |   |   |     |     |
| Описание            | - CMP_VAL |      |      |      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |     |

16-31 — зарезервировано 0-15 СМР\_VAL Значение регистра сравнения канала

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 154-172$ 



# 8.12 Часы реального времени RTC

Раздел в разработке.

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 155-172$ 



## 8.13 Аналого-цифровой преобразователь (ADCx)

В процессоре МСр042R1100102-І данное ПУ отсутствует.

#### 8.13.1 Краткие характеристики

- 4 независимых канала с дельта-сигма преобразователями;
- максимальная частота тактирования 12МГц;
- частота преобразования до 48К выборок/с;
- разрешение 16 бит;
- программируемые усилители и аттенюаторы в каждом канале;



Рис. 46: Блок-схема АЦП

На рис.46 приведена блок-схема АЦП.

АЦП содержит 4 независимых канала с сигма-дельта преобразователями. На входе каждого канала имеется усилители с изменяемым коэффициентом усиления, он выбирается из фиксированного ряда. Значение коэффициентов описано в регистрах ADCxCHy(PGA) и ADCxCHy(BG).

Каждый канал можно включить/выключить отдельно битами ADCxCR(PD\_CHy), можно отключать сразу все преобразователи от входа битом ADCxCR(MUTE EN).

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 156-172



Частота выборок имеет фиксированные значения, они приведены в описании регистра ADCxCR(SAMPL). На рис.?? приведена диаграмма, поясняющая порядок преобразования входного сигнала.

Момент установки ADCxCHy(LRCK) в '1' совпадает с фиксированием значения входного сигнала и началом его преобразования в двоичный код. Так же в этот момент вырабатывается прерывания. При его возникновении из регистра ADCxCHy(DATA) необходимо забрать данные. Через период времени равный длительности преобразования данные в ADCxCHy(DATA) будут изменены.

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 157-172



 $\mathbf{ADCxCR}$ 

#### 8.13.2 Описание регистров

Базовый адрес ADC0 - 0xC01D 0100 Базовый адрес ADC1 - 0xC01D 0200

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

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

| Регистр | Смещение адреса | Доступ | Описание                         |
|---------|-----------------|--------|----------------------------------|
| ADCxCR  | 00h             | RW     | Регистр управления               |
| ADCxCH0 | 04h             | RW     | Регистр 0 канала преобразователя |
| ADCxCH1 | 08h             | RW     | Регистр 1 канала преобразователя |
| ADCxCH2 | 0ch             | RW     | Регистр 2 канала преобразователя |
| ADCxCH3 | 10h             | RW     | Регистр 3 канала преобразователя |

| Номер бита    | 31 30      | 29 28 27      | 26   25   24   23 | 22 21 2    | 20 19 18    | 17 16       |           |       |            |             |             |
|---------------|------------|---------------|-------------------|------------|-------------|-------------|-----------|-------|------------|-------------|-------------|
| Начальное сос | тояние     |               | _                 |            | 11          | 11b         |           |       |            |             |             |
| Описание      |            |               | _                 |            | PR          | .CR         |           |       |            |             |             |
|               |            |               |                   |            |             |             |           |       |            |             |             |
| Номер бита    | 15         | 14 13 12      | 11 10 9 8         | 7          | 6           | 5           | 4         | 3     | 2          | 1           | 0           |
| Начальное сос | тояние 00b | 10b           | 0000Ъ             | 0          | 0           | 0           | 0         | _     | 0          | 0           | 0           |
| Описание      | MUTE_      | SEL PM        | SAMPL             | PD_CH3     | PD_CH2      | PD_CH1      | PD_CH0    | L     | PD_BIAS    | SUSPEND     | MUTE_EN     |
| 20-31 —       |            | зарезервир    |                   |            |             |             |           |       |            |             |             |
| 16-19 PI      | RCR        | предделит     | ель системн       | ой частот  | ъ           |             |           |       |            |             |             |
| 14-15 M       | UTE_SEL    | 00 - отбрас   | сывается мл       | адший би   | іт; 01 - о  | тбрасыва    | ется 2 м  | лад   | ших бита   | а; 10 - отб | расывается  |
|               |            | 3 младших     | : бита; 11 -o     | гбрасыва   | ется 4 мл   | тадших б    | ита       |       |            |             |             |
| 12-13 PM      | M          | 00 - 60%; 0   | 01 - 80%; 10 -    | - 100%; 1  | 1 -120%     |             |           |       |            |             |             |
| 8-11 SA       | AMPL       | 0000 - 8K;    | 0001 - 11,025     | K; 0010 -  | 12K; 001    | 11 - 16K;   | 0100 - 22 | ,05   | K; 0101 -  | 24K; 0110   | - 32K; 0111 |
|               |            | - 44,1K; 10   |                   |            |             |             |           |       |            |             |             |
| 7 PI          | D_CH3      | отключени     | е канала пр       | еобразова  | ателя ('1   | ' - выкль   | очен)     |       |            |             |             |
| 6 PI          | D_CH2      | отключени     | е канала пр       | еобразова  | ателя ('1   | ' - выклн   | очен)     |       |            |             |             |
| 5 PI          | D_CH1      | отключени     | е канала пр       | еобразова  | ателя ('1   | ' - выклн   | очен)     |       |            |             |             |
| 4 PI          | D_CH0      | отключени     | іе канала пр      | еобразова  | ателя ('1   | ' - выкль   | очен)     |       |            |             |             |
| 3 —           |            | зарезервир    | овано             |            |             |             |           |       |            |             |             |
| 2 PI          | D_BIAS     | смещение      | тока преобра      | азователе  | ей ('1' - в | ыключен     | 1)        |       |            |             |             |
| 1 SU          | JSPEND     | отключени     | ıе АЦП ('1' -     | выключ     | ен)         |             |           |       |            |             |             |
| 0 M           | UTE_EN     | отключени     | е всех преоб      | бразовате  | елей от с   | игнальнь    | іх входов | 3 (': | l' - выклн | очены)      |             |
|               |            |               |                   |            |             |             | _         |       |            |             |             |
| ADCxCHy       | Структ     | гура регистро | в каналов пре     | еобразоват | еля (у = 0  | 0, 1, 2, 3) |           |       |            |             |             |
| Номер бита    | 31 30      | 29 28 27      | 26   25   24   23 | 22 21      | 20 19       | 18 17 1     | 3         |       |            |             |             |
| Начальное сос | тояние —   | 00            | 000b              | 000Ъ       | 0           |             |           |       |            |             |             |

| ADCxCHy             | Ст | рук | гура | рег | истр   | ов і | кана | лог | пре  | обр | азов | ател | я (у | r = 1 | 0, 1, 2 | (,3) |    |
|---------------------|----|-----|------|-----|--------|------|------|-----|------|-----|------|------|------|-------|---------|------|----|
| Номер бита          | 31 | 30  | 29   | 28  | 27     | 26   | 25   | 24  | 23   | 22  | 21   | 2    | 0    | 19    | 18      | 17   | 16 |
| Начальное состояние |    | _   |      |     | 00000Ь |      |      |     | 000Ъ |     |      | 0    |      |       |         |      |    |
| Описание            |    | _   |      |     | PGA    |      |      | BG  |      |     | LRCK |      |      |       |         |      |    |
|                     |    |     |      |     |        |      |      |     |      |     |      |      |      |       |         |      |    |
| Номер бита          | 15 | 14  | 13   | 12  | 11     | 10   | 9    | 8   | 7 6  | 5   | 4    | 3 2  | 1    | 0     |         |      |    |
| Начальное состояние |    |     | 0    |     |        |      |      |     |      |     |      |      |      |       |         |      |    |
| Описание            |    |     | DATA |     |        |      |      |     |      |     |      |      |      |       |         |      |    |

```
29-31 — зарезервировано
```

24-28 PGA установка коэф. усиления PGA (шаг - 1,5dB): 11111 - 21dB; ...; 00000 - -25.5dB

20-22 BG установка коэф. усиления BG: 000 - 0dB; 001 - 3dB; 010 - 6dB; 011 - 9dB; 100 - 12dB; 101 -

15dB; 110 - 18dB; 111 - 21dB



16 LRCK признак готовности результата

0-15 — DATA — результат преобразования в двоичном коде

www.multiclet.com UM\_HDL50002 Rev: 101 09.07.2015 159-172



## 8.14 Цифро-аналоговый преобразователь(DACx)

В процессоре МСр042R1100102-І данное ПУ отсутствует.

#### 8.14.1 Краткие характеристики

- 1 независимый канал;
- разрешение 12 бит;
- максимальная частота преобразования до 100 Мегавыборок/с;
- выход токовый, максимальный выходной ток канала преобразователя 16мА;

На рис.?? приведена блок-схема ЦАП. Выход ЦАП - токовый. Максимальная величина выходного тока регулируется резистором, подключаемым к выводу rref. Номинал резистора рассчитывается по следующей формуле:

$$R_{ref} = \frac{V_{ref} \cdot 4096}{I_{omax}}$$

 $I_{omax}$  - величина максимального значения тока, которое нужно установить.  $V_{ref}$  - величина напряжения внутреннего ИОН.

Величина выходного тока рассчитывается по следующей формуле:

$$I_{out} = DACxDATA(DATA) \cdot \frac{V_{ref}}{R_{ref}}$$

Если необходимо получить выход по напряжению, то между выходом ЦАП и шиной с нулевым потенциалом надо включить сопротивление номиналом 50-100 Ом.

Для начала работы необходимо установить бит DACxCR(PD) в состояние '0'.

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

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 160-172



#### 8.14.2 Описание регистров

Базовый адрес DAC0 - 0xC01D 1000

Базовый адрес DAC1 - 0xC01D 1100

Для получения реального адреса регистра надо к базовому (начальному) адресу на шине прибавить смещение адреса регистра

| Регистр  | Смещение адреса | Доступ | Описание                       |
|----------|-----------------|--------|--------------------------------|
| DACxCR   | 00h             | RW     | Регистр управления             |
| DACxDATA | 04h             | RW     | Регистр данных преобразователя |

| DACxCR              | Pe | гист | руп | рав | лені | я  |    |    |     |    |    |     |    |    |    |    |    |
|---------------------|----|------|-----|-----|------|----|----|----|-----|----|----|-----|----|----|----|----|----|
| Номер бита          | 31 | 30   | 29  | 28  | 27   | 26 | 25 | 24 | 23  | 22 | 21 | . 1 | 20 | 19 | 18 | 17 | 16 |
| Начальное состояние |    |      |     |     |      |    |    |    |     |    |    |     |    |    |    |    |    |
| Описание            |    |      |     |     |      |    |    |    | -   |    |    |     |    |    |    |    |    |
|                     |    |      |     |     |      |    |    |    |     |    |    |     |    |    |    |    |    |
| Номер бита          | 15 | 14   | 13  | 12  | 11   | 10 | 9  | 8  | 7 6 | 5  | 4  | 3   | 2  | 1  | 0  |    |    |
| Начальное состояние |    |      |     |     |      |    | 0  |    |     |    |    |     |    |    | 0  |    |    |
| Описание            |    |      |     |     |      |    | _  |    |     |    |    |     |    |    | PD |    |    |

1-31 — зарезервировано
0 PD режим пониженного энергопотребления ('1' - включен)

| DACxDATA            | Ст | рукт | гура | рег | истр | а да | нн | ых п | peot | раз | оват | еля |    |    |    |    |
|---------------------|----|------|------|-----|------|------|----|------|------|-----|------|-----|----|----|----|----|
| Номер бита          | 31 | 30   | 29   | 28  | 27   | 26   | 25 | 24   | 23   | 22  | 21   | 20  | 19 | 18 | 17 | 16 |
| Начальное состояние |    |      |      |     |      |      |    | -    |      |     |      |     |    |    |    |    |
| Описание            |    | _    |      |     |      |      |    |      |      |     |      |     |    |    |    |    |
|                     |    |      |      |     |      |      |    |      |      |     |      |     |    |    |    |    |
| Номер бита          | 15 | 14   | 13   | 12  | 11   | 10   | 9  | 8 7  | 6    | 5   | 4 3  | 3 2 | 1  | 0  |    |    |
| Начальное состояние |    | -    | _    |     |      |      |    |      | 0    |     |      |     |    |    |    |    |
| Описание            |    | -    | -    |     |      |      |    |      | DAT  | ГΑ  |      |     |    |    |    |    |

12-31 — зарезервировано

0-11 DATA данные в прямом двоичном коде, 0 - минимальный ток на выходе



# 9 Назначение выводов процессора

### 9.1 Назначение выводов процессора в корпусе QFP256

Внимание: раздел будет содержать коррекции после 14.07.2015!

| Условные (  | обозначения                            |
|-------------|----------------------------------------|
| S           | подсоединение к линиям электропитания  |
| i           | вход                                   |
| 0           | выход                                  |
| a           | вход/выход аналоговых сигналов         |
| nc          | не подсоединен                         |
| vdd         | 1.8В ядро                              |
| VSS         | gnd питания ядра                       |
| dvss        | 3.3В порты ввода/вывода                |
| dvdd        | gnd питания портов                     |
| vdd_pll     | 1.8B ядро PLL                          |
| $vss\_pll$  | gnd питания ядра PLL                   |
| avdd_pll    | 1.8B аналоговые блоки PLL              |
| avss_pll    | gnd питания аналоговых блоков PLL      |
| avss_dac    | gnd питания аналоговых блоков DAC      |
| av dd _d ac | 1.8B аналоговые блоки DAC              |
| vdd_conv    | 1.8В ядра конверторов (АЦП/ЦАП)        |
| vss_conv    | gnd питания ядер конверторов (АЦП/ЦАП) |
| avss_adc    | gnd питания аналоговых блоков DAC      |
| avdd_adc    | 1.8B аналоговые блоки DAC              |

| №  | Тип | Порт  | Бит порта | Альтернативная функ- | Примечания |
|----|-----|-------|-----------|----------------------|------------|
|    |     |       |           | ция                  |            |
| 1  | i/o |       | 0         | usb0_data[0]         |            |
| 2  | i/o |       | 1         | usb0_data[1]         |            |
| 3  | i/o | GPIOF | 2         | usb0_data[2]         |            |
| 4  | i/o | GPIOF | 3         | usb0_data[3]         |            |
| 5  | i/o |       | 4         | usb0_data[4]         |            |
| 6  | i/o |       | 5         | usb0_data[5]         |            |
| 7  | s   | dvss  |           |                      |            |
| 8  | i/o |       | 6         | usb0_data[6]         |            |
| 9  | i/o |       | 7         | usb0_data[7]         |            |
| 10 | i/o |       | 8         | usb0_nxt             |            |
| 11 | i/o | GPIOF | 9         | usb0_dir             |            |
| 12 | i/o |       | 10        | usb0_stp             |            |
| 13 | i/o |       | 11        | usb0_urstdrive       |            |
| 14 | i/o |       | 12        | usb0_reset           |            |
| 15 | i/o |       | 27        | em_bexcn             |            |
| 16 | i/o |       | 26        | em_brdyn             |            |
| 17 | i/o |       | 25        | $em\_sdram\_dqm[3]$  |            |
| 18 | i/o | GPIOE | 24        | $em\_sdram\_dqm[2]$  |            |
| 19 | i/o |       | 23        | $em\_sdram\_dqm[1]$  |            |
| 20 | i/o |       | 22        | $em\_sdram\_dqm[0]$  |            |
| 21 | i/o |       | 0         | em_ramsn[0]          |            |
| 22 | i/o | GPIOD | 31        | em_data[31]          |            |
| 23 | i/o | GPIOE | 21        | em_writen            |            |
| 24 | s   | vdd   |           |                      |            |
| 25 | s   | VSS   |           |                      |            |
| 26 | s   | dvss  |           |                      |            |
| 27 | s   | dvdd  |           |                      |            |

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 162-172$ 



| Nº | Тип | Порт      | Бит порта | Альтернативная функ-<br>ция | Примечания |
|----|-----|-----------|-----------|-----------------------------|------------|
| 28 | s   | vdd_pll   |           |                             |            |
| 29 | s   | vss_pll   |           |                             |            |
| 30 | s   | avdd_pll  |           |                             |            |
| 31 | s   | avss_pll  |           |                             |            |
| 32 | s   |           |           | pad_a                       |            |
| 33 | s   | avss_tpll |           |                             |            |
| 34 | s   | avdd_tpll |           |                             |            |
| 35 | s   |           |           | pad_b                       |            |
| 36 | s   | avss_tpll |           |                             |            |
| 37 | i/o |           | 20        | em_read                     |            |
| 38 | i/o |           | 19        | em oen                      |            |
| 39 | i/o | CDIOE     | 18        | em_iosn                     |            |
| 40 | i/o | GPIOE     | 17        | em_romsn[1]                 |            |
| 41 | i/o |           | 16        | em_romsn[0]                 |            |
| 42 | i/o |           | 15        | em_mben[3]                  |            |
| 43 | s   | vdd       |           |                             |            |
| 44 | s   | VSS       |           |                             |            |
| 45 | i/o |           | 14        | em mben[2]                  |            |
| 46 | i/o |           | 13        | em mben[1]                  |            |
| 47 | i/o |           | 12        | em mben[0]                  |            |
| 48 | i/o |           | 11        | em wrn[3]                   |            |
| 49 | i/o |           | 10        | em wrn[2]                   |            |
| 50 | i/o | GPIOE     | 6         | em ramoen[2]                |            |
| 51 | i/o |           | 5         | em ramoen[1]                |            |
| 52 | i/o |           | 4         | em ramoen[0]                |            |
| 53 | i/o |           | 3         | em_ramsn[3]                 |            |
| 54 | i/o |           | 2         | em ramsn[2]                 |            |
| 55 | i/o |           | 1         | em_ramsn[1]                 |            |
| 56 | s   | dvss      |           |                             |            |
| 57 | s   | dvdd      |           |                             |            |
| 58 | s   | vdd       |           |                             |            |
| 59 | s   | VSS       |           |                             |            |
| 60 | i/o |           | 30        | em data[30]                 |            |
| 61 | i/o |           | 29        | em_data[29]                 |            |
| 62 | i/o | GPIOD     | 28        | $em_{data[28]}$             |            |
| 63 | i/o |           | 27        | em_data[27]                 |            |
| 64 | s   | dvss      |           |                             |            |
| 65 | i/o |           | 9         | em wrn[1]                   |            |
| 66 | i/o | GPIOE     | 8         | em wrn[0]                   |            |
| 67 | i/o |           | 7         | em ramoen[3]                |            |
| 68 | i/o |           | 26        | em data[26]                 |            |
| 69 | i/o | GPIOD     | 25        | em data[25]                 |            |
| 70 | i/o |           | 24        | em_data[24]                 |            |
| 71 | s   | dvss      |           |                             |            |
| 72 | i/o |           | 23        | em data[23]                 |            |
| 73 | i/o |           | 22        | em data[22]                 |            |
| 74 | i/o |           | 21        | em data[21]                 |            |
| 75 | i/o |           | 20        | em_data[20]                 |            |
| 76 | i/o |           | 19        | em data[19]                 |            |
| 77 | i/o | GPIOD     | 18        | em data[18]                 |            |
| 1  | 1 ' | l         | I .       | 1 = 1 1                     | I          |



| Nº  | Тип        | Порт  | Бит порта | Альтернативная функ-<br>ция         | Примечания |
|-----|------------|-------|-----------|-------------------------------------|------------|
| 78  | i/o        |       | 17        | em_data[17]                         |            |
| 79  | i/o        |       | 16        | em_data[16]                         |            |
| 80  | i/o        |       | 15        | em_data[15]                         |            |
| 81  | i/o        |       | 14        | em_data[14]                         |            |
| 82  | s          | vdd   |           |                                     |            |
| 83  | s          | vss   |           |                                     |            |
| 84  | s          | dvss  |           |                                     |            |
| 85  | s          | dvdd  |           |                                     |            |
| 86  | i/o        |       | 13        | $em_{data}[13]$                     |            |
| 87  | i/o        |       | 12        | $em_{data[12]}$                     |            |
| 88  | i/o        |       | 11        | $ m em\_data[11]$                   |            |
| 89  | i/o        | GPIOD | 10        | $ m em\_data[10]$                   |            |
| 90  | i/o        | GIIOD | 9         | $em_{data}[9]$                      |            |
| 91  | i/o        |       | 8         | em_data[8]                          |            |
| 92  | i/o        |       | 7         | em_data[7]                          |            |
| 93  | i/o        |       | 6         | em_data[6]                          |            |
| 94  | s          | vdd   |           |                                     |            |
| 95  | s          | vss   |           |                                     |            |
| 96  | i/o        |       | 5         | em_data[5]                          |            |
| 97  | i/o        |       | 4         | em_data[4]                          |            |
| 98  | i/o        | GPIOD | 3         | em_data[3]                          |            |
| 99  | i/o        |       | 2         | em_data[2]                          |            |
| 100 | i/o        |       | 1         | em_data[1]                          |            |
| 101 | i/o        |       | 0         | em_data[0]                          |            |
| 102 | s          | dvss  |           |                                     |            |
| 103 | S          | dvdd  |           |                                     |            |
| 104 | S          | vdd   |           |                                     |            |
| 105 | S          | vss   |           |                                     |            |
| 106 | i/o        |       | 27        | i2s_ws                              |            |
| 107 | i/o        |       | 26        | i2s_sd                              |            |
| 108 | i/o        |       | 25        | i2s_sck                             |            |
| 109 | i/o        |       | 22        | uart2_txd                           |            |
| 110 | i/o        |       | 21        | uart2_rxd                           |            |
| 111 | i/o<br>i/o |       | 20        | em_sdram_casn                       |            |
|     |            |       | 19        | em_sdram_rasn                       |            |
| 113 | i/o<br>i/o | GPIOC | 18        | em_sdram_sdwen em_sdram_sdcsn[1]    |            |
| 114 | i/o        |       | 16        | em_sdram_sdcsn[0] em_sdram_sdcsn[0] |            |
| 116 | i/o        |       | 15        | em_sdram_sdcke[1]                   |            |
| 117 | i/o        |       | 14        | em_sdram_sdcke[0]                   |            |
| 118 | i/o        |       | 11        | uart0 txd                           |            |
| 119 | i/o        |       | 10        | uart0_txd                           |            |
| 120 | i/o        |       | 9         | clk out                             |            |
| 121 | i/o        |       | 8         | spi0 ssl[1]                         |            |
| 122 | s          | dvss  |           | - 11                                |            |
| 123 | i/o        |       | 7         | spi0 ssl[0]                         |            |
| 124 | i/o        |       | 6         | spi0 aready                         |            |
| 125 | i/o        |       | 5         | spi0 astart o                       |            |
|     | i/o        | GPIOC | 4         | spi0 astart i                       |            |
| 126 |            |       |           |                                     |            |



| №   | Тип | Порт   | Бит порта | Альтернативная функ-<br>ция | Примечания |
|-----|-----|--------|-----------|-----------------------------|------------|
| 128 | i/o |        | 2         | spi0 miso                   |            |
| 129 | i/o |        | 1         | spi0 mosi                   |            |
| 130 | i/o |        | 0         | spi0 sck                    |            |
| 131 | i/o |        | 29        | em addr[29]                 |            |
| 132 | i/o |        | 28        | em addr[28]                 |            |
| 133 | i/o | GPIOB  | 27        | em_addr[27]                 |            |
| 134 | i/o |        | 26        | em_addr[26]                 |            |
| 135 | s   | dvss   | 20        | oni_waar[20]                |            |
| 136 | i/o | Q V DD | 25        | em addr[25]                 |            |
| 137 | i/o |        | 24        | em_addr[24]                 |            |
| 138 | i/o |        | 23        | em addr[23]                 |            |
| 139 | i/o |        | 22        | em_addr[22]                 |            |
| 140 | i/o |        | 21        | em addr[21]                 |            |
| 141 | i/o | GPIOB  | 20        | em_addr[20]                 |            |
| 141 | i/o |        | 19        | em_addr[19]                 |            |
| 143 | i/o |        | 18        | em_addr[18]                 |            |
| 143 | i/o |        | 17        | em_addr[18]<br>em_addr[17]  |            |
| 144 |     |        | 16        | em_addr[16]                 |            |
|     | i/o |        | 10        | em_addr[10]                 |            |
| 146 | S   | vdd    |           |                             |            |
| 147 | s   | vss    |           |                             |            |
| 148 | s   | dvss   |           |                             |            |
| 149 | S   | dvdd   |           |                             |            |
| 150 | i/o |        | 15        | em_addr[15]                 |            |
| 151 | i/o |        | 14        | em_addr[14]                 |            |
| 152 | i/o |        | 13        | em_addr[13]                 |            |
| 153 | i/o |        | 12        | em_addr[12]                 |            |
| 154 | i/o | GPIOB  | 11        | em_addr[11]                 |            |
| 155 | i/o | 01102  | 10        | em_addr[10]                 |            |
| 156 | i/o |        | 9         | em_addr[9]                  |            |
| 157 | i/o |        | 8         | em_addr[8]                  |            |
| 158 | i/o |        | 7         | em_addr[7]                  |            |
| 159 | i/o |        | 6         | $ m em\_addr[6]$            |            |
| 160 | s   | vdd    |           |                             |            |
| 161 | s   | vss    |           |                             |            |
| 162 | i/o |        | 5         | $em\_addr[5]$               |            |
| 163 | i/o |        | 4         | $em_addr[4]$                |            |
| 164 | i/o | CDIOD  | 3         | $em_addr[3]$                |            |
| 165 | i/o | GPIOB  | 2         | $ m em\_addr[2]$            |            |
| 166 | i/o |        | 1         | $em\_addr[1]$               |            |
| 167 | i/o |        | 0         | $em\_addr[0]$               |            |
| 168 | i/o |        | 29        | pwm_out[3]                  |            |
| 169 | i/o |        | 28        | pwm_out[2]                  |            |
| 170 | i/o |        | 27        | pwm_out[1]                  |            |
| 171 | i/o |        | 26        | pwm out[0]                  |            |
| 172 | i/o | anio i | 25        | uart1 rtsn                  |            |
| 173 | i/o | GPIOA  | 24        | uart1 ctsn                  |            |
| 174 | i/o |        | 23        | uart1 txd                   |            |
| 175 | i/o |        | 22        | uart1 rxd                   |            |
| 176 | i/o |        | 21        | i2c0 sda                    |            |
| 177 | i/o |        | 20        | i2c0 scl                    |            |



| Nº  | Тип | Порт     | Бит порта | Альтернативная функ-<br>ция                 | Примечания         |
|-----|-----|----------|-----------|---------------------------------------------|--------------------|
| 178 | s   | dvss     |           |                                             |                    |
| 179 | s   | dvdd     |           |                                             |                    |
| 180 | s   | vdd      |           |                                             |                    |
| 181 | s   | vss      |           |                                             |                    |
| 182 | i/o |          | 19        | eth0_reset                                  |                    |
| 183 | i/o | CDIOA    | 18        | eth0_mdint                                  |                    |
| 184 | i/o | GPIOA    | 17        | eth0_mdc                                    |                    |
| 185 | i/o |          | 16        | eth0_mdio                                   |                    |
| 186 | s   | dvss     |           |                                             |                    |
| 187 | i/o |          | 15        | eth0_rx_clk                                 |                    |
| 188 | i/o |          | 14        | $\operatorname{eth0} \operatorname{rxd}[3]$ |                    |
| 189 | i/o |          | 13        | et h0 _ rx d[2]                             |                    |
| 190 | i/o | GPIOA    | 12        | $\operatorname{eth0} \operatorname{rxd}[1]$ |                    |
| 191 | i/o |          | 11        | et h0 _ rx d[0]                             |                    |
| 192 | i/o |          | 10        | eth0_rx_er                                  |                    |
| 193 | i/o |          | 9         | eth0_rx_dv                                  |                    |
| 194 | i   |          |           | en_rcfg                                     |                    |
| 195 | s   | dvss     |           |                                             |                    |
| 196 | s   | dvdd     |           |                                             |                    |
| 197 | i   |          |           | trst                                        | JTAG (IEEE 1149.1) |
| 198 | i   |          |           | tck                                         |                    |
| 199 | i   |          |           | tms                                         |                    |
| 200 | i   |          |           | st[0]                                       |                    |
| 201 | 0   |          |           | cr[0]                                       |                    |
| 202 | s   | dvss     |           |                                             |                    |
| 203 | i   |          |           | tdi                                         | JTAG (IEEE 1149.1) |
| 204 | 0   |          |           | tdo                                         |                    |
| 205 | i   |          |           | wakeup                                      |                    |
| 206 | i   |          |           | prom_width[0]                               |                    |
| 207 | i   |          |           | nmi                                         |                    |
| 208 | i   |          |           | reset                                       |                    |
| 209 | i   |          |           | rref                                        |                    |
| 210 | 0   |          |           | vref                                        |                    |
| 211 | 0   |          |           | dac[0]                                      |                    |
| 212 | 0   |          |           | dac[1]                                      |                    |
| 213 | S   | avss_dac |           |                                             |                    |
| 214 | s   | avdd_dac |           |                                             |                    |
| 215 | S   | vdd_conv |           |                                             |                    |
| 216 | S   | vss_conv |           |                                             |                    |
| 217 | 0   |          |           | vref_adc                                    |                    |
| 218 | i   |          |           | adc[0]                                      |                    |
| 219 | i   |          |           | adc[1]                                      |                    |
| 220 | i   |          |           | adc[2]                                      |                    |
| 221 | S   | avss_adc |           |                                             |                    |
| 222 | s   | avdd_adc |           | , (-)                                       |                    |
| 223 | i   |          |           | adc[3]                                      |                    |
| 224 | i   |          |           | adc[4]                                      |                    |
| 225 | i   |          |           | adc[5]                                      |                    |
| 226 | i   |          |           | adc[6]                                      |                    |
| 227 | i   |          |           | adc[7]                                      |                    |



| №   | Тип | Порт  | Бит порта | Альтернативная функ-                           | Примечания |
|-----|-----|-------|-----------|------------------------------------------------|------------|
|     |     |       |           | ция                                            |            |
| 228 | i   |       |           | $\operatorname{start}$ addr[1]                 |            |
| 229 | i/o |       | 8         | eth0_rx_crs                                    |            |
| 230 | i/o |       | 7         | eth0_tx_clk                                    |            |
| 231 | i/o | GPIOA | 6         | $eth0\_txd[3]$                                 |            |
| 232 | i/o | GPIOA | 5         | ${ m eth0\_txd[2]}$                            |            |
| 233 | i/o |       | 4         | ${ m eth0\_txd[1]}$                            |            |
| 234 | i/o |       | 3         | $\operatorname{eth0}_{-\operatorname{txd}}[0]$ |            |
| 235 | s   | dvss  |           |                                                |            |
| 236 | s   | dvdd  |           |                                                |            |
| 237 | s   | vdd   |           |                                                |            |
| 238 | s   | vss   |           |                                                |            |
| 239 | i   |       |           | osc_main_in                                    |            |
| 240 | 0   |       |           | osc main out                                   |            |
| 241 | s   | dvss  |           |                                                |            |
| 242 | i/o |       | 2         | eth0 tx er                                     |            |
| 243 | i/o | GPIOA | 1         | eth0_tx_en                                     |            |
| 244 | i/o |       | 0         | eth0_rx_col                                    |            |
| 245 | i   |       |           | osc32k in                                      |            |
| 246 | 0   |       |           | osc32k_out                                     |            |
| 247 | i   |       |           | usb clk                                        |            |
| 248 | i/o |       | 29        | rtc0 a                                         |            |
| 249 | i/o |       | 28        | i2c1_sda                                       |            |
| 250 | i/o |       | 27        | i2c1_scl                                       |            |
| 251 | i/o |       | 20        | spi1_spisel                                    |            |
| 252 | i/o | GPIOF | 19        | spi1_miso                                      |            |
| 253 | i/o |       | 18        | spi1_mosi                                      |            |
| 254 | i/o |       | 17        | spi1_sck                                       |            |
| 255 | i/o |       | 14        | uart3_txd                                      |            |
| 256 | i/o |       | 13        | uart3_rxd                                      |            |



### 9.2 Диаграмма выводов процессора в корпусе QFP256



Рис. 47: Диаграмма выводов процессора

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 168-172



# 10 Электрические параметры

## 10.1 Электрические характеристики портов ввода-вывода

Таблица 22: Электрические характеристики портов ввода-вывода

| Пара     | метр                                      | Условия                  | Мин.  | Тип. | Макс.  |
|----------|-------------------------------------------|--------------------------|-------|------|--------|
| $V_{IL}$ | Низкий уровень входного напряжения, В     | CMOS, LVTTL              | -0, 3 |      | 0,8    |
| $V_{IH}$ | Высокий уровень входного напряжения, В    |                          | 2,0   |      | 5.5    |
| $I_{IL}$ | Низкий уровень входного тока, мкА         | $V_{in} = V_{SS}$        | -10   |      | 10     |
| $I_{IH}$ | Высокий уровень входного тока, мкА        | $V_{in} = DVDD$          | -10   |      | 10     |
| $V_{OL}$ | Низкий уровень выходного напряжения, В    | $I_{OL} = -12 \text{mA}$ | 0     |      | 0, 4   |
| $V_{OH}$ | Высокий уровень выходного напряжения, В   | $I_{OH} = 12 \text{mA}$  | 2.4   |      | 3.6    |
|          | Подтягивающий резистор к высокому уровню, |                          | 68, 2 |      | 118, 1 |
|          | кОм                                       |                          |       |      |        |
|          | Подтягивающий резистор к низкому уровню,  |                          | 30, 2 |      | 80,6   |
|          | кОм                                       |                          |       |      |        |

Таблица 23: Электрические характеристики ЦАП

| Параметр    |                                             | Условия | Мин.  | Тип. | Макс. |
|-------------|---------------------------------------------|---------|-------|------|-------|
|             | Диапазон рабочих температур, °C             |         | -55   | -    | +125  |
| avss_dac    | Напряжение питания аналоговых частей ЦАП, В |         | -2,97 | 3, 3 | 3,63  |
| vdd_conv    | Напряжение питания цифровых частей ЦАП, В   |         | 1,62  | 1.8  | 1.98  |
| $I_{DACPD}$ | Ток потребления в неактивном режиме, мкА    |         | -     | -    | 10    |
| $I_{omax}$  | Максимальный выходной ток, мА               |         | -     | - 16 | 24    |
| ENOB        | Эффективное разрешение, бит                 |         | -     | -    | 9,5   |
| INL         | Интегральная нелинейность, бит              |         | -     | -    | -     |
| DNL         | Дифференциальная нелинейность, бит          |         | -     | -    | -     |

Таблица 24: Электрические характеристики АЦП

| Параметр     |                                                 | Условия      | Мин.  | Тип. | Макс. |
|--------------|-------------------------------------------------|--------------|-------|------|-------|
|              | Диапазон рабочих температур, °C                 |              | -55   | -    | +125  |
| avss_adc     | Напряжение питания аналоговых частей АЦП, В     |              | -2,97 | 3, 3 | 3,63  |
| vdd_conv     | Напряжение питания цифровых частей АЦП, В       |              | 1,62  | 1.8  | 1.98  |
| $I_{ADCPD}$  | Ток потребления в неактивном режиме по цепи vdd |              | -     | -    | 10    |
|              | conv, mkA                                       |              |       |      |       |
| $I_{ADCC}$   | Ток потребления в активном режиме по цепи vdd   | ADCxCR(PD) = | -     | -    | 7     |
|              | conv, MA                                        | 10           |       |      |       |
| $I_{ADCAPD}$ | Ток потребления в неактивном режиме по цепи     |              | -     | -    | 10    |
|              | avss_adc, мкA                                   |              |       |      |       |
| $I_{ADCA}$   | Ток потребления в активном режиме по цепи avss  |              | -     | -    | 5     |
|              | adc, мА                                         |              |       |      |       |
|              | Динамический диапазон, дБ                       |              | -     | 85   | -     |
|              | Входное сопротивление, кОм                      |              | -     | 30   | -     |

 $\verb|www.multiclet.com| UM\_HDL50002 \qquad Rev: 101 \qquad 09.07.2015 \qquad 169-172$ 



www.multiclet.com UM\_HDL50002 Rev: 101 09.07.2015 170-172



# 11 Лист регистрации изменений

| Номер | Версия | Дата       | Описание изменений                  | Номера страниц |
|-------|--------|------------|-------------------------------------|----------------|
| 1     | 0.1    | 09.07.2015 | Предварительная версия документации |                |
|       |        |            |                                     |                |
|       |        |            |                                     |                |
|       |        |            |                                     |                |
|       |        |            |                                     |                |

www.multiclet.com UM\_HDL50002 Rev: 101 09.07.2015 171-172



# А Приложение. Руководство по применению сложно-функциональных блоков(СФБ) «GAISLER»

ПРИЛОЖЕНИЕ НАХОДИТСЯ В РАЗДЕЛЕ САЙТА «ПОДДЕРЖКА  $\rightarrow$  TEXHИЧЕ-CKAЯ ДОКУМЕНТАЦИЯ И ПРОГРАММНОЕ ОБЕСПЕЧЕНИЕ» (www.multiclet.com/docs/grip.pdf)

www.multiclet.com UM HDL50002 Rev: 101 09.07.2015 172-172