- •Аналоговые и цифровые устройства автоматики
- •Глава 1. Архитектура и устройство
- •1.1. Внутренняя организация мк
- •1.2. Назначение выводов микросхемы мк
- •1.3. Организация памяти в мк
- •1.4. Регистр состояния программы psw
- •1.5. Таймеры/счетчики, регистры tmod и tcon
- •1. 6. Режимы работы таймеров/счетчиков
- •Структура прерываний мк
- •1.8. Блок последовательного интерфейса мк
- •1.8.1. Последовательная передача информации
- •1.8.2. Последовательный порт однокристального мк
- •1.8.3. Регистр управления последовательным портом scon
- •1.8.4. Режимы работы последовательного порта
- •1.8.5. Асинхронный обмен (режимы 1,2,3) данными
- •1.8.6. Скорость приёма/передачи
- •1.8.7. Работа мк в локальной сети
- •1.9. Системный сброс однокристального мк
- •1.10. Режим пониженного энергопотребления мк
- •1.11. Нагрузочная способность портов ввода/вывода
- •1. 12. Расширение портов ввода/вывода
- •Глава 2. Система команд однокристальных мк семейства mcs51
- •Способы адресации операндов
- •2.2. Команды мк
- •2.3. Правила написания программ на языке assembler
- •Метка операция операнд(ы) комментарии
- •2.3.1. Метка
- •2.3.2. Операция
- •2.3.3. Операнды
- •2.3.4. Комментарий
- •2.4. Директивы ассемблера
- •2.4.1. Директивы символических определений
- •Пример:
- •Ozu_org xdata 0800h; Адрес начала области внешнего озу.
- •2.4.2. Директивы резервирования и инициализации памяти
- •2.4.3. Директивы управления состоянием ассемблера
- •Глава 3. Обработка данных в однокристальных микроконтроллерах
- •3.1. Обращение к внутренней, внешней памяти данных и памяти программ
- •3.2. Арифметические операции
- •3.3. Логические операции
- •3.4. Операции с битами
- •Глава 4. Взаимодействие однокристального мк с объектом управления
- •4.1. Программный опрос и ожидание срабатывания позиционных датчиков
- •4.2. Ожидание импульсного сигнала
- •4.3. Программирование таймеров/счетчиков и формирование дискретных управляющих сигналов
- •4.4. Программирование прерываний в микропроцессорном устройстве
- •4.5. Программирование последовательного порта
- •Глава 5. Аппаратные средства
- •5.1. Ввод информации с клавиатуры
- •5.1.1. Прямое подключение клавиш к разрядам порта мк
- •В блоке основной программы происходит инициализация системы, разрешение прерываний, а затем выполняется основная программа.
- •Применение шифратора для организации клавиатуры
- •Шифратора
- •5.1.3. Матричный способ подключения клавиатуры
- •5.1.4. Комбинированный способ организации клавиатуры
- •5.2. Отображение информации в микропроцессорном устройстве
- •5.2.1. Контроллер клавиатуры и дисплея к580вв79 ( intel 8279 )
- •5.2.2. Матричные светодиодные индикаторы
- •5.2.3. Жидкокристаллический дисплей
- •Ввод аналоговых сигналов в микропроцессорный контроллер
- •Ацп с параллельными цифровыми выходами
- •5.3.2. Применение ацп с последовательным выходом
- •5.3.3. Применение таблиц для вычисления функций
- •5.4. Формирование управляющих аналоговых сигналов
- •5.5. Построение ацп с использованием цап
- •5.6. Микропроцессорный контроллер как управляющее устройство в системах автоматического регулирования
- •Согласование дискретных датчиков и исполнительных механизмов с однокристальным мк
- •5.8. Контроль напряжения питания в микропроцессорных системах
- •Глава 6. Отладка программного обеспечения и программирование однокристальных мк
- •6.1. Интегрированная система отладки программного обеспечения для мк ProView
- •6.1.1. Оптимизирующий кросс - компилятор c51
- •6.1.2. Макроассемблер a51
- •6.1.4. Отладчик/симулятор WinSim51
- •6.2. Запуск ProView и создание файла проекта
- •Если в системе задействованы таймеры-счетчики, то удобно промоделировать их работу при разворачивании соответствующих окон Timer (рис.76).
- •В окне указаны источники и адреса векторов прерываний, их состояние и приоритет. Разрешенные прерывания отмечены словом Enable, неразрешенные - Not Enable.
- •Рассмотрим основные пункты раздела debug (отладка), представлены на рис. 84. Эти функции предназначены для выполнения процесса отладки прикладной программы пользователя.
- •6.3. Программирование однокристальных мк
- •Контрольные вопросы для закрепления материала
- •Заключение
- •Библиографический список
- •Глава 1. Архитектура и устройство однокристальных мк семейства mcs51………………………..6
- •Глава 6. Отладка программного обеспечения и программирование однокристальных мк ……….203
- •162600, Г.Череповец , пр. Луначарского, 5
Глава 6. Отладка программного обеспечения и программирование однокристальных мк
После написания управляющей прикладной программы на ассемблере наступает этап отладки: необходимо установить, что программа работоспособна; выявить, локализовать и устранить ошибки. Отладка программного обеспечения представляет собой отдельную сложную задачу, которая требует для своего выполнения высокого профессионализма и глубоких знаний разработчика. Отладка прикладного программного обеспечения осуществляется в несколько этапов. Простые синтаксические ошибки выявляются уже на этапе трансляции. Далее необходимо выполнить:
1). автономную отладку каждой процедуры в статическом режиме, позволяющую проверить правильность проводимых вычислений, правильность последовательности переходов внутри процедуры (отсутствие “зацикливания”) и т.п.;
2). комплексную отладку программного обеспечения в статическом режиме, позволяющую проверить правильность алгоритма управления (по последовательности формирования управляющих воздействий);
3). комплексную отладку в динамическом режиме без подключения объекта для определения реального времени выполнения программы и её отдельных фрагментов.
Отладка отдельных модулей проще и эффективнее отладки всей прикладной программы, поэтому переходить к этапу комплексной отладки целесообразно только после исчерпания всех средств автономной отладки.
Вышеперечисленные этапы осуществляются обычно с использованием кросс-систем. В состав кросс-систем входят программы-отладчики, моделирующие выполнение программ, написанных для микроконтроллеров. Такие программные имитаторы (симуляторы) позволяют эффективно отлаживать алгоритм функционирования контроллера и вычислительные процедуры.
Разработчику предоставлен доступ к любому ресурсу МК, имеется возможность покомандного и пофрагментного исполнения программ и останова по условию, а также подсчёта числа тактов выполнения тех или иных фрагментов программы, инициирования прерывания, дизассемблирования содержимого памяти программ и т.п.
Кросс - отладчики позволяют промоделировать практически все возможные варианты работы программы и тем самым убедиться в её работоспособности. На этом этапе возможна проверка работоспособности программы в нештатных ситуациях и в условиях поступления некорректных входных воздействий.
Мощные имитаторы должны позволять моделировать объекты и датчики, подключаемые к микроконтроллеру. При этом появляется возможность выполнять комплексную отладку программного обеспечения, не опасаясь, что возможные ошибки в программе, алгоритме или некорректные действия оператора приведут к выходу из строя технических средств разрабатываемой системы.
Главным недостатком кросс-систем является невозможность прогона программы в реальном масштабе времени.
Наиболее полная и комплексная отладка прикладного программного обеспечения совместно с аппаратными средствами контроллера может быть произведена на компьютере с так называемым внутрисхемным эмулятором.
Существует два вида эмуляторов:
- эмулятор ППЗУ;
- эмулятор процессора.
Первый вид используется для настройки контроллеров, использующих однокристальный МК, не имеющие своего внутреннего ПЗУ и работающие под управлением программы, записанной в микросхему внешнего УФППЗУ. Эмулятор ППЗУ содержит ОЗУ, в которое записывается прикладная отлаживаемая программа с помощью персонального компьютера. Аппаратно ОЗУ подключается в панель, где должна размещаться микросхема УФППЗУ. При включении питания контроллер начинает работать под управлением программы, записанной в ОЗУ. Если имеются ошибки, то разработчик переписывает программу в ОЗУ эмулятора, используя программное обеспечение персонального компьютера. Такой подход позволяет ускорить процесс отладки. Программирование УФППЗУ требует применения специального аппаратного программатора, а процесс стирания информации из УФППЗУ требует установки, имеющей источник ультрафиолетового излучения. Недостатком эмуляторов ППЗУ является невозможность отладки программы в пошаговом режиме.
Второй вид использует персональный компьютер для эмулирования работы самого однокристального МК с помощью специальной платы, подключаемой к системной шине, LPT или СОМ порту. Плата имеет ленточный кабель с разъемом, который подключается в панельку контроллера, где должен быть установлен однокристальный МК. В этом случае персональный компьютер полностью выполняет функции МК под управлением прикладной программы. Имеется возможность пошаговой отладки.