
- •Санкт-петербургский государственный технический университет
- •Оглавление
- •Введение
- •1. Арифметические основы вычислительной техники
- •Позиционные системы счисления
- •1.2. Двоичная система счисления
- •1.3. Алгоритмы преобразования десятичных чисел в двоичные
- •В двоичную систему счисления методом вычитания
- •1.4. Восьмеричная и шестнадцатеричная системы счисления
- •Представление чисел в различных системах счисления
- •1.5. Представление символьной информации
- •Представление алфавитно-цифровых и управляющих символов в коде ascii
- •1.6. Представление отрицательных чисел
- •1.7. Сложение и вычитание двоичных чисел
- •Правила сложения двоичных чисел
- •Архитектура микроконтроллеров 80c51
- •Общие сведения о микроконтроллерах 80c51
- •2.2. Особенности архитектуры
- •2.3. Организация памяти
- •2.4. Программная память
- •2.5. Память данных
- •Адресное пространство внутренней памяти данных, доступное для побитовой адресации
- •Регистры специальных функций мк 80с51
- •2.6. Слово состояния программы
- •Формат слова состояния программы
- •2.7. Общая характеристика системы команд
- •Система команд микроконтроллеров семейства mcs-51
- •Команды, модифицирующие флаги psw
- •2.8. Способы адресации
- •2.9. Синхронизация процессора
- •А. Для всех команд, кроме movx; в. Для команды movx
- •2.10. Параллельные порты
- •2.11. Таймеры/счетчики
- •Альтернативные функции портов p0, p2 и p3 мк 80с51
- •Регистр управления режимом таймера/счетчика
- •Регистр управления таймера/счетчика
- •2.12. Последовательный порт
- •Регистр управления последовательного порта
- •Регистр управления мощностью
- •Программирование таймера 1 для обеспечения работы последовательного порта в режимах 1 и 3
- •2.13. Программный Счетчик
- •2.14. Стек
- •2.15. Подпрограммы
- •2.16. Система прерываний
- •Адреса векторов прерываний мк 80с51
- •Регистр разрешения прерываний
- •Регистр приоритетов прерываний
- •2.17. Аппаратный сброс
- •Включении электропитания
- •2.18. Энергосберегающие режимы работы
- •3. Технология программирования микроконтроллеров
- •3.1. Общие положения
- •3.2. Подготовка исходного текста программы
- •3.3. Трансляция программы
- •Трансляции программы
- •Ошибки в программе
- •3.4. Компоновка программы
- •3.5. Отладка программы
- •Литература
- •Система команд мк семейства mcs-51
- •Эмулятор пзу чип32-02
- •1. Назначение
- •2. Технические характеристики
- •3. Инструкция по эксплуатации
- •Англо-русский словарь специальных терминов и сокращений
- •195251, Г. Санкт-Петербург, ул. Политехническая, д. 29
3. Технология программирования микроконтроллеров
3.1. Общие положения
3.1.1. Программа микроконтроллера –это последовательность команд, каждая из которых представлена в программной памяти одним, двумя или тремя восьмиразрядными двоичными числами, первое из которых–это код операции, а второе и третье число–это либо абсолютный адрес операнда (номер ячейки памяти в которой находится операнд), либо относительный адрес (смещение относительно базового адреса), либо значение константы. В принципе, если знать архитектуру микроконтроллера, иметь алгоритм решаемой задачи и технические средства для записи двоичных чисел в программную память, то микроконтроллер можно запрограммировать, пользуясь только лишь списком машинных кодов команд. Однако, такая технология очень редко применяется на практике, вследствие чрезвычайно высокой трудоемкости программирования на уровне машинных кодов, а также из-за неудобной для человека формы представления результатов работы, что затрудняет поиск и исправление ошибок в программе.
3.1.2. Для повышения производительности и качества программирования микроконтроллеров на уровне системы команд широко используется язык ассемблера, который позволяет сделать исходный текст программы более наглядным и понятным для программиста, чем колонка двоичных чисел. Принципиальное отличие языка ассемблера от всех других языков программирования состоит в том, что этот язык оперирует только командами, которые непосредственно распознает центральный процессор микроконтроллера. По исходному тексту программы, написанной на языке ассемблера, всегда можно определить время ее исполнения и объем программной памяти, необходимый для хранения программы, так как точно известны длина (количество байтов) и время выполнения каждой команды.
Кроме языка ассемблера опытные разработчики применяют языки программирования высокого уровня (например, С51 и PL/M51), которые в данном учебном пособии не рассматриваются. Это сделано по двум причинам. Во-первых, учебное пособие является узко специализированным, и в число его задач не входит повышение эрудиции читателей в вопросах выбора языка программирования. Во-вторых, по мнению автора, для начинающих разработчиков программирование на языке ассемблера значительно полезнее, чем на языках высокого уровня, поскольку дает возможность лучше изучить архитектуру микроконтроллеров.
3.1.3. В настоящее время широко применяются технологии программирования микроконтроллеров с помощью персональных компьютеров, позволяющих автоматизировать многие трудоемкие процессы. Ниже рассмотрена одна из компьютерных технологий программирования, при использовании которой разработка программы состоит из следующих основных этапов (рис. 3.1):
1) декомпозиция программы,
2) разработка исходных текстов всех модулей программы с помощью текстового редактора,
3) трансляция исходных текстов модулей программы в объектные модули с помощью программы-транслятора,
4) компоновка объектных модулей вместе с библиотечными модулями в единый загрузочный модуль,
5) отладка программы с помощью эмулятора ПЗУ,
6) запись отлаженной программы в ПЗУ или внутреннюю программную память микроконтроллера с помощью программатора.
Для выполнения перечисленных выше работ достаточно иметь следующие аппаратные и программные средства:
любой IBM-совместимый персональный компьютер с операционной системойMSDOSверсии 3.30 или более поздней,
эмулятор ПЗУ,
программатор ПЗУ,
текстовый редактор,
транслятор,
компоновщик.
Технология программирования, описанная в учебном пособии, не является единственно возможной, однако именно она рекомендуется начинающим разработ-чикам микропроцессорных систем, поскольку эта технология очень проста и не требует дорогостоящих программно-аппаратных средств.
Рис. 3.1. Алгоритм программирования МК
3.1.4. Декомпозицией(decomposition) называется разбиение программы на модули (или другие структурные единицы), которые в дальнейшем будут разрабатываться параллельно. Этот этап работы не автоматизирован. Он выполняется на основе общего алгоритма функционирования микропроцессорной системы. Один из модулей программы является главным (в нем содержится программа, запускаемая при сбросе микроконтроллера), а остальные модули обеспечивают работу главного модуля (в них содержатся подпрограммы, которые могут вызываться как из главного, так и из других модулей программы). На этапе декомпозиции разрабатывается структурная схема программы, показывающая взаимосвязи отдельных модулей, а также производится распределение адресного пространства памяти данных между модулями.