В МК семейства 68HC12 реализован иной, более совершенный режим отладки BDM (Background Debug Mode), что в переводе означает «фоновый режим отладки». Этот режим позволяет выполнить основные процедуры отладки — просмотр и модификацию содержимого регистров и ячеек памяти без останова выполнения прикладной программы.
В процессе отладки МК обменивается данными с персональным компьютером, используя последовательный интерфейс с оригинальным протоколом. Для подключения микроконтроллера, который установлен на плате проектируемого устройства, к персональному компьютеру разработан унифицированный интерфейс, который носит название «BDM порт» (рис. 3.5). Стандартизация линий связи и типа разъема интерфейса отладки BDM позволяет разрабатывать универсальные программные пакеты и аппаратные средства отладки так, что любая аппаратная платформа на основе МК семейства 68HC12, в том числе и плата собственной разработки, способна работать под управлением любой интегрированной среды разработки для 68HC12/HCS12.
Рис. 3.5.Цоколевка разъема BDM порта
Используя порт BDM, встроенный в МК блок отладки принимает от персонального компьютера команды отладки и возвращает в персональный компьютер запрашиваемые данные. Часть команд отладки может выполняться только аппаратными средствами блока BDM, без остановки выполнения прикладной программы. При этом используются «холостые» машинные циклы внутренних магистралей, когда исполняемая прикладная программа не производит обращения к памяти. Если такие «холостые» циклы не возникают в течение 128 машинных циклов, то блок BDM захватывает последующие циклы для выполнения поступившей команды отладки. При этом выполнение прикладной программы слегка притормаживается. Обсуждаемые так называемые аппаратные команды отладки могут поступать в блок BDM от персонального компьютера не чаще, чем 1 раз в 150 машинных циклов. Перечень аппаратных команд отладки представлен в табл. 3.3. В табл. 3.4. дано описание этих команд.
№ команды |
Имя команды |
Код операции |
Данные |
1 |
BACKGROUND |
90 |
– (нет) |
2 |
READ_BD_BYTE |
E4 |
16 бит адреса, 16 бит данных (вывод) |
3 |
STATUS |
E4 |
FF01, 00000000 (вывод) |
4 |
|
|
FF01, 10000000 (вывод) |
5 |
|
|
FF01, 110000000 (вывод) |
6 |
READ_BD_WORD |
EC |
16 бит адреса, 16 бит данных (вывод) |
7 |
READ_BYTE |
E0 |
16 бит адреса, 16 бит данных (вывод) |
8 |
READ_WORD |
E8 |
16 бит адреса, 16 бит данных (вывод) |
9 |
WRITE_BD_BYTE |
C4 |
16 бит адреса, 16 бит данных (ввод) |
10 |
ENABLE_FIRMWARE |
C4 |
FF01, 1xxxxxxx (ввод) |
11 |
WRITE_BD_ WORD |
CC |
16 бит адреса, 16 бит данных (ввод) |
12 |
WRITE_BYTE |
C0 |
16 бит адреса, 16 бит данных (ввод) |
13 |
WRITE_ WORD |
C8 |
16 бит адреса, 16 бит данных (ввод) |
Табл. 3.3.Команды отладки, исполняемые аппаратными средствами модуля отладки BDM
№ команды по табл.3.3 |
Описание команды |
1 |
Ввод в режим отладки с использованием монитора BDM |
2 |
Чтение байта из области памяти блока BDM. Адрес указан в команде. Если адрес четный, то искомый байт содержится в старшем байте возвращаемого 16-ти разрядного слова. Если адрес нечетный, то искомый байт в младшем байте 16-разрядного слова. |
3 |
Частный случай команды READ_BD_BYTE. Производится чтение регистра состояния модуля BDM. Считанный код 00000000 означает, что МК не может быть переведен в режим отладки и работает только под управлением прикладной программы. |
4 |
Частный случай команды READ_BD_BYTE. Производится чтение регистра состояния модуля BDM. Считанный код 10000000 означает, что режим отладки разрешен и МК может быть переведен в режим отладки инструкцией BACKGROUND из табл. 3.3. |
5 |
Частный случай команды READ_BD_BYTE. Производится чтение регистра состояния модуля BDM. Считанный код 11000000 означает, что МК находится в режиме отладки. |
6 |
Чтение 16 разрядного слова из области памяти блока BDM по указанному в команде адресу. Адрес должен быть четным и указывать на старший байт возвращаемого из МК слова. |
7 |
Чтение байта из области памяти МК. Адрес указан в команде. Если адрес четный, то искомый байт содержится в старшем байте возвращаемого 16-тиразрядного слова. Если адрес нечетный, то искомый байт в младшем байте 16 разрядного слова. |
8 |
Чтение слова из области памяти МК по указанному в команде адресу. Адрес должен быть четным и указывать на старший байт возвращаемого из МК слова. |
9 |
Запись байта в область памяти блока BDM. Если в команде указан четный адрес, то байт для записи содержится в старшем байте передаваемого 16-тиразрядного слова. Если адрес нечетный, то байт для записи — в младшем байте 16 разрядного слова. |
10 |
Частный случай команды WRITE_BD_BYTE. Производится запись в регистр состояния STATUS модуля BDM. Передаваемый в регистр состояния код 1xxxxxxx разрешает работу программно аппаратных средств модуля отладки BDM. Для перевода МК в режим отладки необходимо далее подать команду BACKGROUND из табл. 3.3. |
11 |
Запись слова в область памяти блока BDM по указанному в команде адресу. Адрес должен быть четным и указывать на старший байт передаваемого в память BDM слова. |
12 |
Запись байта в область памяти МК. Если в команде указан четный адрес, то байт для записи содержится в старшем байте передаваемого 16-ти разрядного слова. Если адрес нечетный, то байт для записи — в младшем байте 16-разрядного слова. |
13 |
Запись слова в область памяти МК по указанному в команде адресу. Адрес должен быть четным и указывать на старший байт передаваемого в память МК слова. |
Табл. 3.4.Описание аппаратных команд модуля отладки BDM
Читать дальше