46123 (Аналитический обзор книги Программирование на языке ассемблера для микропроцессоров 8080 и 8085), страница 4

2016-07-31СтудИзба

Описание файла

Документ из архива "Аналитический обзор книги Программирование на языке ассемблера для микропроцессоров 8080 и 8085", который расположен в категории "". Всё это находится в предмете "информатика" из , которые можно найти в файловом архиве . Не смотря на прямую связь этого архива с , его также можно найти и в других разделах. Архив можно найти в разделе "рефераты, доклады и презентации", в предмете "информатика, программирование" в общих файлах.

Онлайн просмотр документа "46123"

Текст 4 страницы из документа "46123"

ВВОДА - ВЫВОДА

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

  1. Смешивание портов ввода и вывода.

  1. Попытка выполнить операции, которые физически невозможны.

  1. Упущенные из вида неявных эффектов аппаратуры.

  1. Чтение или запись без проверки состояния.

  1. Игнорирование различия между вводом и выводом.

  1. Ошибка при сохранении копии выводимых данных.

  1. Чтение данных до того, как они стабилизируются, или во время их изменения.

  1. Отсутствие изменения полярности данных, которые передаются к устройству или от устройства, работающего с отрицательной логикой.

  1. Смешивание действительных портов ввода-вывода с внутренними регистрами интегральных схем ввода-вывода.

  1. Неправильное использование двунаправленных портов.

  1. Отсутствие очистки состояния после выполнения команды ввода-вывода.

РАСПРОСТРАНЕННЫЕ ОШИБКИ В

ПРОГРАММАХ ПРЕРЫВАНИЯ

Многие ошибки, связанные с прерываниями, зависят как от аппаратного, так и программного обеспечения. Самыми распространенными ошибками являются следующие.

  1. Отсутствие разрешения прерываний.

  1. Отсутствие сохранения регистров.

  1. Сохранение или восстановление регистров в неправильном порядке.

  1. Разрешение прерываний до инициализации приоритетов и других параметров системы прерываний.

  1. Неучет того, что реакция на прерывание включает сохранение счетчика команд в вершине стека.

  1. Отсутствие запрещения прерываний во время многобайтных передач или выполнения последовательности команд, которая не должна прерываться.

  1. Отсутствие разрешения прерываний после последовательности команд, которая должна выполняться без прерываний.

  1. Отсутствие очистки сигнала, вызывающего прерывание.

  1. Ошибка в общении с основной программой.

  1. Отсутствие сохранения и восстановления приоритетов.

  1. Отсутствие разрешения прерываний от дополнительных аппаратурных входов, которое выполняется с помощью очистки разрядов масок в регистре I.

  1. Неправильное использование разрядов разрешения прерываний в командах SIM.

ВВЕДЕНИЕ В ПРОГРАММНЫЙ РАЗДЕЛ

Программный раздел содержит наборы подпрограмм на языке ассемблера для микропроцессоров 8080 и 8085. Каждой подпрограмме предпосланы введение и комментарии; за каждой подпрограммой следует по крайней мере один пример ее использования. Введение содержит следующую информацию: назначение подпрограммы, процедуру ее выполнения, используемые регистры, время выполнения, размер памяти, необходимый для программы и ее данных, а также специальные случаи, входные и выходные условия.

Каждая подпрограмма сделана настолько общей, насколько это возможно.

Во всех подпрограммах был использован следующий метод передачи параметров:

  1. Первый 8-разрядный параметр передается в аккумуляторе, второй 8-разрядный параметр- регистре В, а третий- в регистре С.

  1. Первый 16-разрядный параметр передается в регистрах Н и L, при этом старший байт- в регистре Н. Второй 16-разрядный параметр передается в регистрах D и Е со старшим байтом в D.

  1. Большее число параметров передается в стеке, прямо или косвенно. Считается, что вход в подпрограмму осуществляется с помощью команды CALL, которая помещает адрес возврата в вершину стека и, следовательно, выше параметров.

Для большинства коротких подпрограмм было определено время выполнения.

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

Приводятся следующие подпрограммы:

  1. Преобразование кодов

  • Преобразование двоичных данных в код BCD;

  • Преобразование данных в коде BCD в двоичные;

  • Преобразование двоичных данных в шестнадцатеричные в коде ASCII;

  • Преобразование шестнадцатеричных данных в коде ASCII в двоичные;

  • Преобразование двоичного числа в десятичное к коде ASCII;

  • Преобразование десятичного числа в коде ASCII в двоичное;

  • Трансляция строчных букв в прописные;

  • Преобразование кода символа из системы ASCII в систему EBCDIC;

  • Преобразование кода символа из системы EBCDIC в систему ASCII.

  1. Работа с массивами и индексирование

  • Заполнение памяти;

  • Пересылка блоков;

  • Индексирование двухмерного массива байтов;

  • Индексирование двухмерного массива слов;

  • Индексирование N- мерного массива;

  1. Арифметические операции

  • 16- разрядное вычитание;

  • 16- разрядное умножение;

  • 16- разрядное деление;

  • 16- разрядное сравнение;

  • Двоичное сложение с повышенной точностью;

  • Двоичное вычитание с повышенной точностью;

  • Двоичное умножение с повышенной точностью;

  • Двоичное деление с повышенной точностью;

  • Двоичное сравнение с повышенной точностью;

  • Десятичное сложение с повышенной точностью;

  • Десятичное вычитание с повышенной точностью;

  • Десятичное умножение с повышенной точностью;

  • Десятичное деление с повышенной точностью;

  • Десятичное сравнение с повышенной точностью;

  1. Работа с разрядами и сдвиги

  • Установка разряда;

  • Очистка разряда;

  • Проверка разряда;

  • Выделение поля разрядов;

  • Запись поля разрядов;

  • Арифметический сдвиг вправо с повышенной точностью;

  • Логический сдвиг влево с повышенной точностью;

  • Логический сдвиг вправо с повышенной точностью;

  • Циклический сдвиг вправо с повышенной точностью;

  • Циклический сдвиг влево с повышенной точностью;

  1. Работа со строками

  • Сравнение строк;

  • Объединение строк;

  • Поиск позиции подстроки;

  • Копирование подстроки из строки;

  • Удаление подстроки из строки;

  • Вставка подстроки в строку;

  1. Операции с массивами

  • Суммирование 8-разрядного массива;

  • Суммирование 16-разрядного массива;

  • Поиск минимального элемента длиной 1 байт;

  • Поиск максимального элемента длиной 1 байт;

  • Двоичный поиск;

  • Быстрая сортировка;

  • Тест ОЗУ;

  • Таблица переходов;

  1. Ввод - вывод

  • Чтение строки с терминала;

  • Запись строки на устройство вывода;

  • Проверка и генерация 16-разрядного кода контроля по избыточности;

  • Диспетчер таблицы устройств ввода - вывода;

  • Инициализация портов ввода - вывода;

  • Задержка в миллисекундах;

  1. Прерывания

  • Небуферизованный ввод - вывод о прерываниям с использованием программируемого интерфейса связи 8251;

  • Небуферизованный ввод - вывод о прерываниям с использованием программируемого параллельного интерфейса 8255;

  • Буферизованный ввод - вывод о прерываниям с использованием программируемого интерфейса связи 8251;

  • Часы реального времени и календарь

АРИФМЕТИЧЕСКИЕ ОПЕРАЦИИ

  1. Шестнадцатиразрядное вычитание

Вычитаются два 16-разрядных числа. При этом флаг переноса действует как заем.

Процедура. Просто из уменьшаемого вычитается вычитаемое по одному байту за один раз, начиная с младших байтов. При вычитании старших байтов учитывается заем. При вычитании старших байтов устанавливаются флаги.

  1. Шестнадцатиразрядное умножение

Умножаются два 16-разрядных операнда и возвращается младшее по значению слово (16-разрядное) произведения.

Процедура. Используется обычный механизм сложения и сдвигов, при котором множимое добавляется к частичному произведению каждый раз, когда в множителе находится единичный разряд. Для правильного относительного расположения операндов и произведения в программе 15 раз осуществляется сдвиг влево множителя и промежуточного произведения (т.е. на число разрядов в множителе минус один). При этом старший (16-й) разряд произведения теряется.

  1. Шестнадцатиразрядное деление

Делятся два 16-разрядных операнда и возвращается частное и остаток. Имеются две входные точки: SDIV16 делит два 16-разрядных операнда со знаками, в то время как USDIV16 делит два 16-разрядных операнда без знаков. При делении на 0 флаг переноса устанавливается в 1, а частное и остаток равны 0; в противном случае флаг переноса очищается.

Процедура. Если операнды имеют знаки, то определяется знак частного и берутся абсолютные значения отрицательных операндов. Кроме того, должен сохраняться знак делимого, так как он определяет знак остатка. Затем с помощью алгоритма сдвигов и вычитания выполняется беззнаковое деление. Частное и делимое сдвигаются влево, при этом каждый раз, когда пробное вычитание было успешным, единичный разряд помещается в частное. Если операнды имели знаки, то программа должна превратить в отрицательное число (т.е. вычесть из 0) частное или остаток, если только они должны быть отрицательными. При делении без ошибок флаг переноса очищается, а при делении на 0 - устанавливается. Кроме того, если делитель равен 0, то частное и остаток также равны 0.

  1. Шестнадцатиразрядное сравнение

Сравниваются два 16-разрядных операнда и соответствующим образом устанавливаются флаги. Флаг нуля всегда указывает, были ли операнды равны. Если операнды были беззнаковые, то флаг переноса указывает, какой из них больше (флаг переноса = 1, если вычитаемое больше, и 0 - в противном случае). Если операнды имеют знаки, то флаг знака указывает, какой из них больше (флаг знака равен 1, если вычитаемое больше, и 0 - в противном случае); при этом учитывается переполнение по дополнению до двух, и если оно происходит, то флаг знака инвертируется.

Процедура. Сначала проверяется, может ли произойти переполнение по дополнению да двух. Это возможно только в том случае, если знаки операндов различаются. Если переполнение по дополнению до двух возможно, то вычитается младший байт вычитаемого из уменьшаемого. Если младшие байты равны, то устанавливаются то устанавливаются флаги по результату вычитания старших байтов. Если младшие байты не равны, перед выходом должен очистится флаг нуля (с помощью логической операции ИЛИ с 1, но при неизменных остальных флагах). Если переполнение по дополнению до двух может произойти, то устанавливается флаг знака по знаку уменьшаемого. Это выполняется с помощью загрузки в аккумулятор старшего байта уменьшаемого перед установкой флага знака.

  1. Двоичное сложение чисел с повышенной точностью

Складываются два многобайтовых двоичных числа. Числа хранятся в памяти таким образом, что их самые младшие по значению байты занимают самые младшие адреса. Сумма заменяет первое слагаемое.

Процедура. Сначала очищается флаг переноса, а затем складываются операнды, по байту за раз, начиная с самых младших по значению байтов. В конце флаг переноса отражает результат сложения самых старших байтов. Длина 0 вызывает немедленный выход без сложения.

  1. Двоичное вычитание чисел с повышенной точностью

Вычитаются два многобайтовых беззнаковых двоичных числа. Оба числа хранятся в памяти таким образом что их самые младшие по значению байты занимают самые младшие адреса. Разность замещает уменьшаемое. Длина чисел равна 255 байт или меньше.

Процедура. Сначала очищается флаг переноса, а затем вычисляются операнды, по байту за один раз, начиная с самых младших по значению байтов. В конце флаг переноса отражает результат вычитания самых старших байтов. Длина 0 вызывает немедленный выход без вычитания.

  1. Двоичное умножение чисел с повышенной точностью

Умножаются два многобайтовых беззнаковых двоичных числа. Оба числа хранятся в памяти таким образом что их самые младшие по значению байты занимают самые младшие адреса. Произведение замещает множимое. Длина чисел равна 255 байт или меньше. Чтобы сохранялась совместимость с другими двоичными операциями повышенной точности, возвращаются только младшие по значению байты произведения.

Процедура. Используется обычный механизм сложения и сдвигов, при котором множимое добавляется к частичному произведению каждый раз, когда в множителе находится единичный разряд. Промежуточное произведение и множимое сдвигаются на число разрядов в множимом плюс один; этот дополнительный цикл сдвигает окончательный флаг переноса в произведении. Полное беззнаковое промежуточное произведение двойной длины хранится в ячейках памяти и в множимом. Длина 0 вызывает немедленный выход без умножения.

  1. Двоичное деление чисел повышенной точности

Делятся два многобайтовых беззнаковых двоичных числа. Оба числа хранятся в памяти таким образом что их самые младшие по значению байты занимают самые младшие адреса. Частное замещает делимое; адрес младшего по значению байта остатка находится в регистрах H и L. Длина чисел равна 255 байт или меньше. Если нет ошибок, флаг переноса очищается; при попытке деления на ноль флаг переноса устанавливается в 1, делимое остается без изменения, а остаток равен 0.

Процедура. С помощью обычного алгоритма сдвигов и вычитания осуществляется деление, при этом сдвигается частное и делимое и 1 помещается в делимое каждый раз, когда вычитание успешно. Результат пробного вычитания хранится в дополнительном буфере; если пробное вычитание успешно, то указатели этого буфера и буфера делимого просто переключаются (т.е. буферы меняются местами). Если определяется, что делитель равен нулю, немедленно осуществляется выход из программы и устанавливается флаг переноса. В противном случае флаг переноса очищается.

  1. Двоичное сравнение чисел с повышенной точностью

Сравниваются два многобайтовых беззнаковых двоичных числа и соответствующим образом устанавливаются флаги. Флаг нуля всегда указывает, были ли операнды равны. Если операнды были беззнаковые, то флаг переноса указывает, какой из них больше (флаг переноса = 1, если вычитаемое больше, и 0 - в противном случае). Флаг переноса устанавливается в 1, если вычитаемое больше уменьшаемого; в противном случае флаг переноса очищается. Таким образом, флаги устанавливаются так же, как если бы вычитаемое вычиталось из уменьшаемого.

Процедура. Сравниваются операнды побайтно, начиная с самых старших байтов и продолжая до тех пор, пока не будут найдены неравные соответствующие байты. Если все байты равны, осуществляется выход с флагом нуля, установленном в 1. Заметим, что пи сравнении работа происходит с операндами, начиная с самых старших байтов, в то время как при вычитании - начиная с самых младших.

Свежие статьи
Популярно сейчас
Как Вы думаете, сколько людей до Вас делали точно такое же задание? 99% студентов выполняют точно такие же задания, как и их предшественники год назад. Найдите нужный учебный материал на СтудИзбе!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
5224
Авторов
на СтудИзбе
427
Средний доход
с одного платного файла
Обучение Подробнее