- •1. Введение
- •1.1. Знакомство с Cortex
- •1.2. Обзор семейства stm32
- •1.2.1. Многофункциональные увв
- •1.2.2. Безопасность
- •1.2.3. Защищенность
- •1.2.4. Разработка программ
- •1.2.5. Группы Performance Line и Access Line
- •2. Обзор процессоров Cortex
- •2.1. Версии архитектур arm
- •2.2. Процессор Cortex и цпу Cortex
- •2.3. Цпу Cortex
- •2.3.1. Конвейер
- •2.3.2. Модель программирования
- •2.3.2.1. Xpsr
- •2.3.3. Режимы работы цпу
- •2.3.4. Набор инструкций Thumb-2
- •2.3.5. Карта памяти
- •2.3.6. Доступ к фрагментированным данным
- •2.3.7. Метод "Bit Banding"
- •2.4. Процессор Cortex
- •2.4.1. Шины
- •2.4.2. Матрица шин
- •2.4.3. Системный таймер
- •2.4.4. Обработка прерываний
- •2.4.5. Контроллер вложенных векторизованных прерываний
- •2.4.5.1. Работа кввп при входе в исключительные ситуации и выходе из них
- •2.4.5.2. Улучшенные режимы обработки прерывания
- •2.4.5.2.1. Приостановка прерываний
- •2.4.5.2.2. Непрерывная обработка прерываний с исключением внутренних операций над стеком
- •2.4.5.2.3. Обработка опоздавшего высокоприоритетного прерывания
- •2.4.5.3. Конфигурация и использование кввп
- •2.4.5.3.1. Таблица векторов исключительных ситуаций
- •2.5. Режимы работы, влияющие на энергопотребление
- •2.5.1. Переход в экономичный режим работы
- •2.5.2. Отладочная система CoreSight
- •3. Схема включения
- •3.1. Типы корпусов
- •3.2. Напряжение питания
- •3.3. Схема сброса
- •3.3.1. Основная схема включения
- •3.4. Генераторы
- •3.4.1. Внешний высокочастотный генератор
- •3.4.2. Внешний низкочастотный генератор
- •3.4.3. Выход синхронизации
- •3.4.4. Выводы управления загрузкой и внутрисистемное программирование
- •3.4.5. Режимы загрузки
- •3.4.6. Отладочный порт
- •4. Архитектура системы микроконтроллеров stm32
- •4.1 Распределение памяти
- •4.2. Работа с максимальным быстродействием
- •4.2.1. Блок фазовой автоподстройки частоты
- •4.2.1.1. Настройка шин
- •4.2.2. Буфер Flash памяти
- •4.2.3. Прямой доступ к памяти
- •5. Устройства ввода-вывода
- •5.1. Увв общего назначения
- •5.1.1. Порты ввода-вывода общего назначения
- •5.1.1. Альтернативные функции
- •5.1.2. Сигнализация событий
- •5.1.2. Внешние прерывания
- •5.1.3. Ацп
- •5.1.3.1. Время преобразования и группы преобразования
- •5.1.3.2. Функция оконного компаратора
- •5.1.3.3. Базовая конфигурация ацп
- •5.1.3.4. Режимы сдвоенных преобразований
- •5.1.3.4.1. Режимы одновременного преобразования инжектированных групп и одновременного преобразования регулярных групп
- •5.1.3.5. Комбинированный режим одновременного преобразования регулярных/инжектированных групп
- •5.1.3.6. Режимы быстрых и медленных преобразований со смещением во времени
- •5.1.3.7. Режим поочередного запуска
- •5.1.4.1.1. Блок захвата/сравнения
- •5.1.4.1.2. Блок захвата
- •5.1.4.1.3. Режим измерения параметров шим-сигнала
- •5.1.4.1.4. Интерфейс энкодера
- •5.1.4.1.5. Режим сравнения
- •5.1.4.1.6. Режим широтно-импульсной модуляции
- •5.1.4.1.7. Режим одновибратора
- •5.1.4.2. Расширенный таймер
- •5.1.4.2.1. Функция экстренного отключения
- •5.1.4.2.2. Интерфейс датчика Холла
- •5.1.4.3. Синхронизированная работа таймеров
- •5.1.5. Часы реального времени и регистры с резервированием питания
- •5.1.6. Регистры с резервированием питания и вход вмешательства
- •5.2. Коммуникационные увв
- •5.2.1. Интерфейс spi
- •5.2.2. Модуль i2c
- •5.2.3. Модуль усапп
- •5.3. Модули сan и usb
- •5.3.1. Can-контроллер
- •.3.2. Модуль интерфейса usb
- •6. Экономичные режимы работы
- •6.1. Режим run
- •6.1.1. Буфер предварительной выборки и режим полуцикла
- •6.2. Экономичные режимы работы
- •6.2.1. Режим sleep
- •6.2.2. Режим stop
- •6.3. Режим standby
- •6.4. Потребляемый ток области с резервированием питания
- •6.5. Возможность отладки в экономичных режимах
- •7. Возможности по обеспечению безопасной работы
- •7.1. Управление сбросом
- •7.2. Контроль напряжения питания
- •7.3. Защищенная система синхронизации
- •7.4. Сторожевые таймеры
- •7.4.1. Оконный сторожевой таймер
- •7.4.2. Независимый сторожевой таймер
- •7.5. Особенности увв
- •8.1. Защита и программирование Flash памяти
- •8.2. Операции стирания и записи
- •8.3. Байты опций
- •8.3.1. Защита от записи
- •8.3.2. Защита от чтения
- •8.3.3. Конфигурационный байт
- •9. Инструментальные средства для проектирования
- •9.1. Оценочные средства
- •9.2. Библиотеки и протокольные стеки
- •9.3. Операционные системы реального времени
4.2. Работа с максимальным быстродействием
Помимо двух внешних генераторов, у STM32 имеется два внутренних RC-генератора. Сразу после сброса ядро Cortex синхронизируется внутренним высокочастотным генератором, номинальная рабочая частота которого составляет 8 МГц. Второй внутренний генератор - низкочастотный генератор на частоту 32,768 кГц. Данный генератор предназначен для совместной работы с часами реального времени и сторожевым таймером.
У МК STM32 используется достаточно сложная система синхронизации с двумя внешними и двумя внутренними генераторами, а также схемой ФАПЧ. В целях безопасности системы предусмотрена возможность мониторинга внешнего высокочастотного генератора
Процессор Cortex поддерживает возможность синхронизации внешним или внутренним высокочастотным генератором или от внутренней схемы ФАПЧ. Источником синхронизации схемы ФАПЧ может служить внутренний или внешний высокочастотный генератор. Таким образом, МК STM32 могут работать на частоте 72 МГц без использования внешнего генератора. Недостатком использования внутреннего генератора на частоту 8МГц является его невысокая точность и стабильность. Его нельзя использовать для синхронизации последовательных интерфейсов или для выполнения точных измерений временных интервалов. Независимо от выбранного генератора, чтобы добиться работы ядра Cortex на максимальной частоте 72 МГц, необходимо использовать ФАПЧ. Все регистры управления настройками генераторов, ФАПЧ и шин находятся в группе управления сбросом и синхронизацией (группа RCC).
Блок управления сбросом и синхронизацией воздействует на систему синхронизации, шинные преобразователи и домен с резервированием питания
4.2.1. Блок фазовой автоподстройки частоты
Сразу после сброса источником синхронизации ЦПУ является HSI-генератор. В таком состоянии МК его внутренний генератор отключен. Первым шагом по обеспечению работы STM32 с максимальным быстродействием является включение HSE-генератора и ожидание стабилизации его частоты.
После сброса МК STM32 работает от внутреннего высокочастотного генератора. Внешний генератор необходимо включить
RCC->CR |= 0x10000; //включение HSE
// Ожидание стабилизации частоты HSE-генератора while(!(RCC->CR &0x00020000)) { ; }
|
Включается внешний генератор с помощью регистра RCC_Control. Бит готовности сигнализирует о стабилизации частоты внешнего генератора. После того, как частота внешнего генератора станет стабильной, его можно выбрать как вход блока ФАПЧ. Выходная частота блока ФАПЧ зависит от заданного целочисленного значения коэффициента умножения частоты, которое хранится в регистре RCC_PLL_configuration. Если используется генератор на частоту 8 МГц, для генерации максимальной тактовой частоты 72 МГц необходимо задать коэффициент умножения 9. После настройки коэффициента умножения частоты, необходимо разрешить работу блока ФАПЧ посредством регистра управления. Как только выходная частота блока ФАПЧ станет стабильной, установится соответствующий флаг и выход ФАПЧ можно выбрать в качестве источника синхронизации ЦПУ Cortex.
После запуска HSE-генератора его сигнал можно подать на вход схемы ФАПЧ. По завершении переходных процессов внутри схемы ФАПЧ ее сигнал можно использовать для синхронизации системы
//Синхронизация HSE-генератором и умножением частоты на 9 RCC->CFGR = 0x001D0000; //Активизация ФАПЧ RCC->CR |= 0x01000000;
while(!(RCC->CR & 0x02000000)) { ; }
//Установка остальных полей управления RCC->CR |= 0x00000001;
//Установка остальных полей конфигурации RCC->CFGR |= 0x005D0402;
|