УВЕЛИЧЕНИЕ БЫСТРОДЕЙСТВИЯ ПРОГРАММ

Ускорить выполнение можно только определив, где теряется время. Для этого необходимо определить, какие циклы процессор выполняет наиболее часто. Основное влияние на снижение затрат времени часто выполняемого цикла оказывает счетчик числа циклов. Таким образом, важно определить, как часто выполняются команды, и работать далее с циклами в порядке частоты их выполнения.

После того, как уточнено, какие циклы выполняются наиболее часто, время их выполнения можно уменьшить, используя следующие правила:

*  Исключение избыточных операций;

*  Реорганизация цикла так, чтобы уменьшалось число команд перехода;

*  Использование линейной способности команд вместо подпрограмм;

*  Использование для временного хранения стек вместо определенных адресов памяти;

*  Назначение регистров таким образом, чтобы получить максимальный выигрыш от специализированных команд, как 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, умножение, деление, сравнение, получение дополнения до двух (отрицательного числа) и расширение. Для удобства те команды, принадлежность которых к конкретной категории неясна, повторяются во всех категориях, к которым они могли бы быть отнесены.

 

ЛОГИЧЕСКИЕ КОМАНДЫ

Эта группа включает следующие команды: логическое И, логическое ИЛИ, логическое ИСКЛЮЧАЮЩЕЕ ИЛИ, логическое НЕ (дополнение), сдвиг, циклический сдвиг и проверку. Она включает также те арифметические команды (такие, как сложение с аккумулятора с самим собой), которые выполняют логические функции.

 

КОМАНДЫ ПЕРЕДАЧИ ДАННЫХ

Эта группа включает команды загрузки, запоминания, пересылки, обмена, ввода, вывода, очистки и установки. Кроме того, она включает арифметические команды (такие как вычитание аккумулятора из самого себя), которые заносят определенное значение или содержимое какого-либо регистра в аккумулятора или другой регистр назначения, не изменяя при этом данных.

 

КОМАНДЫ ПЕРЕХОДА

Эта группа включает следующие виды переходов:

 Команды безусловного перехода

· Перейти косвенно;

· Перейти по индексу, предполагая, что базовый адрес таблицы адресов находится в регистрах Н и L, а индекс в аккумуляторе;

· Перейти и связать, т.е. передать управление по адресу DEST, сохранив текущее состояние счетчика команд в регистрах Н и L.

 Команды условного перехода

· Перейти при равенстве нулю;

· Перейти при неравенстве нулю;

· Перейти, если значения равны;

· Перейти, если значения не равны;

· Перейти, если значение положительное;

· Перейти, если значение отрицательное;

· Переходы с учетом знака;

· Перейти, если больше (без учета знака), т.е. если операнды не равны и при сравнении не требуется заема;

· Перейти, если значение не больше (без учета знака), т.е. если сравниваемые операнды равны или при их сравнении требуется заем;

· Перейти, если значение меньше (без учета знака), т.е. если сравнение без знака требует заема;

· Перейти, если значение не меньше (без учета знака), т.е. если сравнение без знака не требует заема.

·

КОМАНДЫ ПРОПУСКА

В микропроцессорах 8080 или 8085 команда пропуска может быть выполнена с помощью команды перехода с соответствующем адресом назначения. Этот адрес назначения должен указывать на команду, следующую после той, которая стоит непосредственно за командой перехода. Действительное число пропускаемых байтов будет меняться, так как команды микропроцессоров 8080 и 8085 могут иметь длину 1-3 байта.

 

Дата: 2019-05-28, просмотров: 20.