
- •1. Архитектура микроконтроллеров avr и pic
- •Регистры общего назначения
- •Регистр состояния sreg микроконтроллеров avr
- •Внутренняя и внешняя память sram микроконтроллеров avr
- •Память программ
- •Память eeprom микроконтроллеров avr
- •Обработка прерываний
- •Управление прерываниями в микроконтроллерах avr
- •Регистр gimsk
- •Регистр gifr
- •Регистры timsk и tifr
- •Управление прерываниями в микроконтроллерах pic
- •Таймеры/счетчики
- •Таймеры/счетчики микроконтроллеров avr
- •Icr1 – регистр захвата по входу (при появлении на выводе icp фронта входного сигнала, определенного как активный, текущее состояние счетчика будет перенесено в этот регистр);
- •Модуль сср
- •Сторожевой таймер
- •2. Параллельные порты ввода/вывода
- •Последовательный ввод/вывод
- •Приемопередатчик uart микроконтроллеров avr
- •Настройка скорости передачи данных через uart
- •Приемопередатчик usart микроконтроллеров pic
- •Синхронная передача данных по интерфейсу spi
- •Регистры управления и состояния spi в микроконтроллерах avr
- •Регистры управления и состояния spi в микроконтроллерах pic
- •Синхронная передача данных по интерфейсу i2с
- •Протокол шины i2с
- •Адресация ведомых устройств
- •Работа с интерфейсом i2с в микроконтроллерах pic
- •Модуль шины can
- •3. Аналого-цифровое преобразование
- •Встроенный аналоговый компаратор
- •4. Программирование микроконтроллеров avr семейства Mega
- •Общие сведения
- •Защита кода и данных
- •Конфигурационные ячейки
- •Идентификатор
- •Калибровочные ячейки
- •Организация памяти программ и данных
- •Программирование по последовательному каналу
- •Переключение в режим программирования
- •Управление процессом программирования flash-памяти
- •Управление процессом программирования eeprom-памяти
- •Параллельное программирование
- •Переключение в режим параллельного программирования
- •Стирание кристалла
- •Программирование flash-памяти
- •Программирование eeprom-памяти
- •Программирование конфигурационных ячеек
- •Использование интерфейса jtag для программирования кристалла
- •Команды jtag, используемые при программировании
- •Артемий «Di Halt» Исламов (di_halt@mail.Ru)
Идентификатор
Все микроконтроллеры фирмы Atmel имеют три 8-битные ячейки, содержимое которых позволяет идентифицировать устройство. В первой ячейке содержится код производителя $00, во второй — код объема FLASH-памяти $01, а в третьей — код устройства $02. Как и конфигурационные ячейки, ячейки идентификатора расположены в отдельном адресном пространстве, доступ к которому возможен только в режиме программирования. Однако в отличие от конфигурационных ячеек ячейки идентификатора, по понятным причинам, доступны только для чтения.
Значение кода устройства у разных моделей может совпадать. Поэтому устройство следует идентифицировать только по совокупности значений ячеек $01 и $02, так как именно эта пара чисел является уникальной для каждого микроконтроллера.
Калибровочные ячейки
В калибровочные ячейки при изготовлении микроконтроллера заносятся калибровочные константы, предназначенные для подстройки на номинальную частоту внутреннего RС-генератора. Количество этих ячеек зависит от того, на скольких частотах может работать внутренний RC-генератор. В моделях ATmega8515x/8535x и ATmega8x/16x/32x/64x/128x имеется четыре 8-битных ячейки, а в остальных моделях —одна ячейка. Располагаются они в старших байтах адресного пространства ячеек идентификатора.
Загрузка калибровочной константы в регистр OSCCAL осуществляется аппаратно при нахождении микроконтроллера в состоянии сброса. Однако в моделях ATmega8515x/8535x и ATmega8x/16x/32x/64x/128x генератор автоматически калибруется только на частоту 1 МГц. Поэтому при использовании другой частоты RС-генератора его калибровку необходимо осуществлять вручную. Для этого программатор во время программирования должен прочитать содержимое калибровочной ячейки и занести его по какому-либо адресу FLASH-памяти программ. А программа должна после старта считать это значение из памяти программ и занести его в регистр OSCCAL.
Организация памяти программ и данных
В микроконтроллерах семейства Mega используется страничная организация памяти программ. При программировании весь объем FLASH-памяти разбивается на 16-битные страницы, размер которых, а также их количество зависят от объема памяти программ микроконтроллера.
Соответственно, при программировании памяти программ микроконтроллеров семейства Mega данные сначала загружаются в буфер страницы и только затем заносятся непосредственно в память программ. Прошивка всех ячеек страницы при этом осуществляется одновременно.
Аналогичным образом организована и EEPROM-память. Размер 8-битных страниц EEPROM-памяти.
Однако следует отметить, что во многих моделях страничная организация EEPROM-памяти используется только при программировании в параллельном режиме, а программирование по последовательному каналу осуществляется побайтно.
Программирование по последовательному каналу
В режиме программирования по последовательному каналу программирование памяти программ и данных осуществляется по последовательному интерфейсу SPI. Как правило, этот режим используется для программирования (перепрограммирования) микроконтроллера непосредственно в устройстве.
Схема включения микросхем в режиме программирования по последовательному каналу приведена на рис. 9.2. На этом же рисунке показано два варианта разводки колодки для подключения программатора, рекомендуемые компанией Atmel.
Рис. 9.2. Включение микроконтроллеров в режиме программирования по последовательному каналу
Как видно из рис. 9.2, для обмена данными между программатором и устройством используются три линии: SCK (тактовый сигнал), MOSI (вход данных) и MISO (выход данных).
Как и в рабочем режиме, при программировании по последовательному каналу микроконтроллеру требуется источник тактового сигнала. В качестве такового может использоваться любой из допустимых для микроконтроллера источников. При этом должно выполняться следующее условие: длительность импульсов как НИЗКОГО, так и ВЫСОКОГО уровня сигнала SCK должна быть больше 2 периодов тактового сигнала микроконтроллера.
Программирование осуществляется путем посылки 4-байтных команд на вывод MOSI микроконтроллера. Результат выполнения команд чтения снимается с вывода MISO микроконтроллера. Передача команд и выдача результатов их выполнения осуществляются от старшего бита к младшему. При этом “защелкивание” входных данных выполняется по нарастающему фронту сигнала SCK, а “защелкивание” выходных данных – по спадающему.