Заглавная страница Избранные статьи Случайная статья Познавательные статьи Новые добавления Обратная связь КАТЕГОРИИ: АрхеологияБиология Генетика География Информатика История Логика Маркетинг Математика Менеджмент Механика Педагогика Религия Социология Технологии Физика Философия Финансы Химия Экология ТОП 10 на сайте Приготовление дезинфицирующих растворов различной концентрацииТехника нижней прямой подачи мяча. Франко-прусская война (причины и последствия) Организация работы процедурного кабинета Смысловое и механическое запоминание, их место и роль в усвоении знаний Коммуникативные барьеры и пути их преодоления Обработка изделий медицинского назначения многократного применения Образцы текста публицистического стиля Четыре типа изменения баланса Задачи с ответами для Всероссийской олимпиады по праву Мы поможем в написании ваших работ! ЗНАЕТЕ ЛИ ВЫ?
Влияние общества на человека
Приготовление дезинфицирующих растворов различной концентрации Практические работы по географии для 6 класса Организация работы процедурного кабинета Изменения в неживой природе осенью Уборка процедурного кабинета Сольфеджио. Все правила по сольфеджио Балочные системы. Определение реакций опор и моментов защемления |
Разрешение работы интерфейса внешнего программирования
Программирование NVM через PDI требует разрешения работы, что можно сделать следующим образом. · Запишите в регистр RESET контроллера PDI значение 0x59 (сигнатура сброса). · Запишите корректный NVM-ключ в PDI. · Дождитесь равенства единицы бита NVMEN регистра статуса PDI (PDI STATUS). Если бит NVMEN в регистре PDI STATUS станет равным единице, это означает, что интерфейс NVM готов для использования контроллером PDI. Программирование NVM Адресация NVM После разрешения работы интерфейса PDI NVM все запоминающие устройства МК становятся доступными в адресном пространстве PDI. В дальнейших упоминаниях о чтении и записи памяти данных или памяти программ полагается использование адресации в соответствии с картой памяти, представленной на рисунке 30.4. Контроллер PDI использует только побайтную адресацию. Это означает, что любой адрес памяти является адресом байта. При заполнении страничного буфера Flash-памяти или EEPROM, для определения адресуемой ячейки страничного буфера используются только младшие биты адреса. В остальных случаях, в целях гарантирования корректности отображения адресов, требуется указание полного адреса страницы Flash-памяти или EEPROM. Занятость NVM Во время программирования (стирание страницы и запись страницы), когда NVM находится в занятом состоянии, блокируется возможность чтения всей NVM. NVM-команды NVM-команды, которые можно использовать для доступа к энергонезависимым запоминающим устройствам при внешнем программировании, представлены в таблице 30.5. Для внешнего программирования доступен более обширный набор команд, чем при самопрограммировании. При внешнем программировании, для исполнения команд с запуском по действию необходимо установить бит CMDEX в регистре NVM CTRLA. Исполнение команд с запуском по чтению происходит при выполнении инструкций прямого или косвенного чтения (LDS или LD) из PDI (чтение PDI). Наконец, команды с запуском по записи исполняются при выполнении инструкции прямой или косвенной записи (STS или ST) из PDI (запись PDI). Детальное описание алгоритма выполнения каждой NVM-команды представлено в подразделах 30.12.3.1…30.12.3.11. Возможность выполнения большинства команд зависит от состояния Lock-бит. После активизации защиты от чтения и записи можно выполнить только команды стирания всей памяти и проверки CRC Flash-памяти.
Таблица 30.5. NVM-команды, доступные при внешнем программировании
Прим.:
· Если fuse-бит EESAVE запрограммирован, выполнение команды стирания всей памяти не повлияет на содержимое EEPROM. Стирание всей памяти Данная команда предназначена для стирания Flash-памяти программ, EEPROM и Lock-бит. При необходимости из этого перечня можно исключить EEPROM. Для этого нужно запрограммировать fuse-бит EESAVE (см. 4.16.5 "FUSEBYTE5 - конфигурационный байт 5 энергонезависимой памяти"). Данная инструкция не влияет на сигнатурный код пользователя, калибровочные данные и Fuse-биты. · Запишите в регистр NVM CMD команду стирания всей памяти. · Установите бит CMDEX в регистре NVM CTRLA с использованием привязанной ко времени последовательности CCP. Сразу после запуска этой операции происходит отключение PDIBUS, а бит NVMEN в регистре PDI STATUS вплоть до завершения операции имеет нулевое значение. Убедиться в возобновлении работы PDIBUS можно путем опроса бита NVMEN (должен быть равен 1). Флаг BUSY в регистре NVM STATUS вплоть до завершения операции остается равным единице. Чтение NVM Данная команда предназначена для чтения Flash-памяти, EEPROM, Fuse-бит, сигнатурного кода и калибровочных данных. · Запишите в регистр NVM CMD команду чтения NVM. · Прочитайте выбранный адрес памяти путем выполнения операции чтение PDI. Для чтения различных секторов памяти также можно использовать команды чтения EEPROM, чтения Fuse-бит, чтения сигнатурного кода и чтения калибровочных данных. Алгоритм выполнения этих команд идентичен команде чтения NVM.
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Последнее изменение этой страницы: 2016-12-30; просмотров: 357; Нарушение авторского права страницы; Мы поможем в написании вашей работы! infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 3.21.104.109 (0.009 с.) |