Аналитический обзор книги Л. А. Левенталь, У. Сэйвилл "Программирование на языке ассемблера для микропроцессоров 8080 и 8085"
Категория реферата: Рефераты по информатике, программированию
Теги реферата: дипломная работа по праву, время реферат
Добавил(а) на сайт: Богдана.
Предыдущая страница реферата | 1 2 3 4 5 6 7 8 9 10 11 | Следующая страница реферата
НАПИСАНИЕ ПРОГРАММ, РАБОТАЮЩИХ ПО ПРЕРЫВАНИЯМ
В большинстве систем прерывания 8080 и 8085 используются команды RST и входные сигналы, которые передают управление по определенным адресам памяти. Все команды RST и входные сигналы сохраняют старое значение программного счетчика в вершине стека, но не сохраняют автоматически остальные регистры. Слово состояния процессора (PSW) содержит аккумулятор (старший байт) и флаги (младший байт). Прерывания должны быть разрешены явно с помощью команды EI непосредственно перед командой RET, заканчивающей обслуживающую программу. Команда EI задерживает действительное разрешение прерываний на один такт команды во избежания лишней записи адреса возврата в стек.
УВЕЛИЧЕНИЕ БЫСТРОДЕЙСТВИЯ ПРОГРАММ
Ускорить выполнение можно только определив, где теряется время. Для этого необходимо определить, какие циклы процессор выполняет наиболее часто. Основное влияние на снижение затрат времени часто выполняемого цикла оказывает счетчик числа циклов. Таким образом, важно определить, как часто выполняются команды, и работать далее с циклами в порядке частоты их выполнения.
После того, как уточнено, какие циклы выполняются наиболее часто, время их выполнения можно уменьшить, используя следующие правила:
Исключение избыточных операций;
Реорганизация цикла так, чтобы уменьшалось число команд перехода;
Использование линейной способности команд вместо подпрограмм;
Использование для временного хранения стек вместо определенных адресов памяти;
Назначение регистров таким образом, чтобы получить максимальный выигрыш от специализированных команд, как LHLD,SHLD,XCHG,XTHL и PCHL;
Везде, где возможно, для работы с 16-разрядными данными использование 16-разряднвх команд;
Использование команд MVI M, INR M и DCR M для работы с данными памяти;
Использование команд MOV, MVI, INR, DCR, INX, DCX, SHLD, LHLD, XCHG, XTHL, PUSH, POP, PCHL и SPHL для работы с данными в регистрах;
Использование RST,PCHL или RET в качестве коротких команд перехода;
Организация последовательности условных переходов таким образом, чтобы была минимизация среднего времени выполнения;
Проверка на условия, при которых последовательность команд не выполняется, и обход этой последовательности для случая выполнения условий.
Обычный путь к снижению времени выполнения состоит в замене длинных последовательностей команд таблицами. Если не предусмотрены специальные выходы или не введены элементы логики программы, то с помощью отдельного просмотра таблицы могут выполняться те же операции, что и с помощью последовательности команд. Ценой этого является необходимость в расходах на дополнительную память, но при ее наличии это может быть оправдано. Если емкость памяти достаточна, то поиск в таблице может быть рациональным подходом, даже если многие записи ее одинаковы. Кроме того, что ускоряется работа, поиск в таблице обычно легче программировать и проще изменять.
УМЕНЬШЕНИЕ ДЛИНЫ ПРОГРАММЫ
Длину программы можно значительно уменьшить, выделив общие последовательности команд и заменив их подпрограммами. В результате получается одна копия этих команд вместо нескольких копий.
Поиск по таблице обычно требует большего объема памяти, но снижает время выполнения.
ГЛАВА 2. РЕАЛИЗАЦИЯ ДОПОЛНИТЕЛЬНЫХ КОМАНД И СПОСОБОВ АДРЕСАЦИИ
В этой главе показано, как реализовать команды и способы адресации, которые не входят в набор команд 8080 или 8085. Конечно, нет выбора команд, который включал бы все возможные комбинации. Разработчик должен выбирать набор команд, исходя из того, сколько кодов операций доступно, насколько легко могут быть выполнены дополнительные комбинации и как часто они могут использоваться. Описание дополнительных команд и способов адресации не означает, что основной набор команд является неполным или же плохо разработанным.
РАСШИРЕНИЕ НАБОРА КОМАНД
Команды делятся на следующие группы: арифметические, логические, передачи данных, перехода, пропуска, вызова подпрограммы, возврата из подпрограммы и смешанные. Типы операндов для каждого типа команд обсуждаются в соответствующем порядке: байт, слово, десятичный операнд, разряд, число, составной операнд. При обсуждении способов адресации используется следующий порядок: прямая, косвенная, непосредственная, индексная, регистровая, автоиндексирование с предварительным увеличением адреса, автоиндексирование с предварительным уменьшением адреса, автоиндексирование с последующем уменьшением адреса, косвенная с предварительным индексированием, и косвенная с последующем индексированием .
АРИФМЕТИЧЕСКИЕ КОМАНДЫ
В эту группу включены следующие команды: сложение, сложение с флагом переноса, вычитание, вычитание при перестановке операндов, вычитание с флагом переноса (заем), увеличение на 1, уменьшение на 1, умножение, деление, сравнение, получение дополнения до двух (отрицательного числа) и расширение. Для удобства те команды, принадлежность которых к конкретной категории неясна, повторяются во всех категориях, к которым они могли бы быть отнесены.
ЛОГИЧЕСКИЕ КОМАНДЫ
Эта группа включает следующие команды: логическое И, логическое ИЛИ, логическое ИСКЛЮЧАЮЩЕЕ ИЛИ, логическое НЕ (дополнение), сдвиг, циклический сдвиг и проверку. Она включает также те арифметические команды (такие, как сложение с аккумулятора с самим собой), которые выполняют логические функции.
КОМАНДЫ ПЕРЕДАЧИ ДАННЫХ
Эта группа включает команды загрузки, запоминания, пересылки, обмена, ввода, вывода, очистки и установки. Кроме того, она включает арифметические команды (такие как вычитание аккумулятора из самого себя), которые заносят определенное значение или содержимое какого-либо регистра в аккумулятора или другой регистр назначения, не изменяя при этом данных.
КОМАНДЫ ПЕРЕХОДА
Эта группа включает следующие виды переходов:
Команды безусловного перехода
Перейти косвенно;
Рекомендуем скачать другие рефераты по теме: гражданин реферат, курсовые работы бесплатно.
Предыдущая страница реферата | 1 2 3 4 5 6 7 8 9 10 11 | Следующая страница реферата