Язык ассемблера для ibm pc и программирования

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

Просмотр DJVU-файла онлайн

Распознанный текст из DJVU-файла

В. Н. Пильщиков Программирование на языке ассемблера! ВМ РС МОСКВА а «ДИАЛОГ-МИФИ» а 1999 ББК 32.973 УДК 681.325.5 П32 1БВ1ч 5-86404-051-7 Книга представляет собой учебное пособие по языку ассемблер для персональных компьютеров типа 1ВМ РС. Подробно рассмотрены команды этих ЭВМ, конструкция языка и методы программирования на нем. Изложение сопровождается многочисленными примерами. Для студентов и преподавателей ВУЗов, для всех желающих детально изучить язык ассемблер и приемы программирования на нем.

ББК 32.9 Учебно-справочное издание Владимир Николаевич Пильщиков Программирование иа языке ассемблера 1ВМ РС Редактор О. А. Голубев Макет и обложка Н. В. Дмитриевой Корректор Л. М. Плясова Лицензия ЛР 1ч 071568 от 25.12.97. Подписано в печать 14.12.99. Формат 60х84/16. Бум. офс. Печать офс. Гарнитура Таймс.

Уел. печ. л. 16.74. Уч.- изд. л. 17.4. Доп. тираж 5 000 зкз. Заказ 7ЧО %. Акционерное общество «ДИАЛОГ-МИФИ» 115409, Москва, ул. Москворечье, 31, корп. 2 Подольская типография 142ИО, г. Подольск, Московская обл., ул. Кирова, 25 1БВХ 5-86404-051-7 © В. Н. Пильщиков, 1994-99 Ю Оригинал-макет, оформление обложки.

Они предназначены для людей, они пояс)е)ют смысл прогрвзшы. Комментарием считается любая строка, начинающаяся со знака «точка с запятой» (перед ним может быть любое число пробелов) либо пустая строка (точнее, строка, в которой нет иных симвачов, кроме пробелов). В комментариях можмо испачьювать любые симвачы, в том числе и русские буквы. Например, комментариями являются 1-я и 3-я строки в следующеы тексте: ;это хоюэвхтархя ию ах,о ИОЧ вх,з Предложемия-комментарии обычно используются лля пояснения не одной команды (это можмо сделать, ьак увидим, в самой команде), а целой группы команд, следующих за этим комментарием: ъачисаеахв с ИОД)аэв) дивпог миФи 24 програмыярояаяае яа языке ассеывяеда!ВЫ рс Пустые же строки обычно используются для того, чтобы отделить одну часть программы от друзой, чтобы сделать нагляднее деление программы на части.

Такая ьгетка, считается, метит следующую команду прогрщшы. Эта возможность полезна, по крайней мере, в двух случаях: когда команду надо поыетить двухи или более метками и когда ыетка очень длинная и потому остальная часть команды слишком сильно сдвигается вправо, что плохо смотрится. Пример: хнхтхвпхяхтхон: хьв! ьпп вх,ьх 26 Программярояаяио яа язмяо ассемблера IВМ рп 2.2.4. Ссылки назад и вперед Теперь сделаем несколько замечаний о ыетках и именах. Во-первых, метки команд и имена (коистаит, переиеииых и т.

Источник

Язык ассемблера для ibm pc и программирования

Ассемблер для IBM PC 2

1. Введение в семейство персональных компьютеров IBM PC

Введение
Биты и байты
ASCII код
Двойные числа
Шеснадцатеричное представление
Сегменты
Регистры
Архитектура персональных компьютеров
Основные положения на память
Вопросы для самопроверки

2. Выполнение программы

Введение
Начало работы
Просмотр памяти
Пример машинных кодов: непосредственные данные
Пример машинных кодов: определенные данные
Машинная адресация
Пример машинных кодов: определение размера памяти
Свойства отладчика
Основные положения на память
Вопросы для самопроверки

3. Формат языка ассемблера

Введение
Комментарии
Формат кодирования
Псевдокоманды
Указатели памяти и регистров
Инициализация программы
Пример исходной программы
Основные положения на память
Вопросы для самопроверки

4. Ассемблирование и выполнение программы

Введение
Ввод программы
Подготовка программы для выполнения
Ассемблирование программы
Компановка загрузочного модуля
Выполнение программы
Пример исходной программы

Ассемблер для IBM PC 3

Файл перекрестных ссылок
Основные положения на память
Вопросы для самопроверки

5. Определение данных

Введение
Псевдокоманды определения данных
Определение байта (DB)
Определение слова (DW)
Определение двойного слова (DD)
Определение «четверного» слова (DQ)
Определение десяти байт (DT)
Непосредственные операнды
Псевдокоманда (директива) EQU
Основные положения на память
Вопросы для самопроверки

6. Программные COM-файлы

Введение
Различия между EXE- и COM-файлами
Пример COM-файла
COM-стек
Отладка
Основные положения на память
Вопросы для самопроверки

7. Логика и организация программы

Введение
Команда JMP
Команда LOOP
Флаговый регистр
Команды условного перехода
Процедуры и вызовы (CALL)
Стековый сегмент
Программа: команды длинной пересылки
Логические команды: AND, OR, XOR, TEST, NOT
Программа: изменение нижнего и верхнего регистров
Сдвиги и ротация
Организация программы
Основные положения на память
Вопросы для самопроверки

8. Работы с экраном I: Основные возможности

Введение
Команда прерывания: INT
Установка курсора
Очистка экрана
Команды экрана и клавиатуры: Базовая DOS
Ввод на экран: стандарт DOS

Ассемблер для IBM PC 4

Программа: Ввод набора ASCII символов
Ввод с клавиатуры: Базовая DOS
Программа: Ввод имен с клавиатуры и вывод на экран
Команды экрана и клавиатуры: Расширенная DOS
Вывод на экран: Расширенная DOS
Ввод с клавиатуры: Расширенная DOS
Использование CR, LF, TAB для вывода на экран
Основные положения на память
Вопросы для самопроверки

9. Работа с экраном II: Расширенные возможности

Введение
Байт атрибутов
Прерывания BIOS
Программа: мигание, видеореверс, скроллинг
Расширенные ASCII коды
Другие команды ввода/вывода DOS
BIOS INT 16H для ввода с клавиатуры
Дополнительные функциональные клавиши
Основные положения на память
Вопросы для самопроверки

10. Работа с экраном III: Цвет и графика

Введение
Текстовый (алфавитно-цифровой) режим
Графический режим
Режим средней разрешающей возможности
Программа: Установка цвета и графического режима
Основные положения на память
Вопросы для самопроверки

11. Обработка строк

Введение
Особенности команд обработки строк
REP: Префикс повторения строки
MOVS: Пересылка строки
LODS: Загрузка строки
STOS: Сохранение строки
CMPS: Сравнение строк
SCAS: Сканирование строки
Сканирование и замена
Альтернативное кодирование
Дублирование шаблона (образца)
Программа: Выравнивание справа при выводе на экран
Основные положения на память
Вопросы для самопроверки

12. Арифметика I: Обработка двоичных данных

Ассемблер для IBM PC 5

Сложение и вычитание
Беззнаковые и знаковые данные
Умножение
Сдвиг регистров DX:AX
Деление
Преобразование знака
Процессоры Intel 8087 и 80287
Основные положения на память
Вопросы для самопроверки

13. Арифметика II: Обработка ASCII и BCD данных

Введение
ASCII формат
Двоично-десятичный формат (BCD)
Преобразование ASCII формата в двоичный формат
Преобразование двоичного формата в ASCII формат
Сдвиг и округление
Программа: Расчет зарплаты
Основные положения на память
Вопросы для самопроверки

14. Обработка таблиц

Введение
Определение таблиц
Прямой табличный доступ
Поиск в таблице
Команда перекодировки (трансляции) (XLAT)
Программа: Вывод шестнадцатеричных и ASCII кодов
Программа: Сортировка элементов таблицы
Операторы TYPE, LENGTH и SIZE
Основные положения на память
Вопросы для самопроверки

15. Дисковая память I: Организация

Введение
Объем диска
Каталог
Таблица распределения файлов (FAT)
Основные положения на память
Вопросы для самопроверки

16. Дисковая память II: Функции базовой DOS

Введение
Управляющий блок файла: FCB
Использование FCB для создания дискового файла
Программа: FCB для создания дискового файла
Последовательное чтение дискового файла
Программа: FCB для чтения дискового файла
Прямой доступ

Ассемблер для IBM PC 6

Программа: Прямое чтение дискового файла
Прямой блочный доступа
Программа: Прямое чтение блока
Абсолютный дисковый ввод/вывод
Другие возможности
Программа: Выборочное удаление файлов
Основные положения на память
Вопросы для самопроверки

17. Дисковая память III: Функции расширенной DOS

Введение
Строка ASCIIZ
Номер файла и коды возврата по ошибкам
Создание дискового файла
Программа: Использование номера для чтения файла
ASCII файлы
Другие функции расширенной DOS
Основные положения на память
Вопросы для самопроверки

18. Дисковая память IV: Команды ввода/вывода BIOS

Введение
Дисковые команды BIOS
Байт состояния
Программа: Использование BIOS для чтения секторов
Основные положения на память
Вопросы для самопроверки

Введение
Управляющие символы для печати
Использование расширенной DOS для печати
Программа: Постраничная печать с заголовками
Печать ASCII файлов и управление табуляций
Печать с использованием базовой DOS
Специальные команды принтера
Печать с использованием BIOS INT 17H
Основные положения на память
Вопросы для самопроверки

Введение
Простое макроопределение
Использование параметров в макрокомандах
Комментарии
Использование макро внутри макроопределения
Директива LOCAL
Подключение библиотеки макроопределений
Конкатенация (&)

Ассемблер для IBM PC 7

Повторение: REPT, IRP и IRPC
Условные директивы
Директива EXITM
Макрокоманды, использующие IF и IFNDEF условия
Макрокоманды, использующие IFIDN условие
Основные положения на память
Вопросы для самопроверки

21. Связь между подпрограммами

22. Загрузчик программ

Введение
COMМAND.COM
Префикс программного сегмента
Выполнение COM-программы
Выполнение EXE-программы
Пример EXE-программы
Функция загрузки или выполнения программ

23. BIOS и DOS прерывания

Введение
Обслуживание прерываний
BIOS прерывания
DOS прерывания
Функции DOS INT 21H
Резидентные программы
Порты
Генерация звука

24. Справочник по директивам ассемблера

Введение
Индексная память
Команды ассемблера
Директивы ассемблера

25. Справочник по командам ассемблера

Ассемблер для IBM PC 8

Введение
Обозначение регистров
Байт режима адресации
Двухбайтовые команды
Трехбайтовые команды
Четырехбайтовые команды
Команды в алфавитном порядке

1. ASCII коды
2. Шестнадцатерично-десятичные преобразования
3. Зарезервированные слова
4. Режимы ассемблирования и компановки

Ответы на некоторые вопросы

Ассемблер для IBM PC 9

Ассемблер для IBM PC 10

ъ Знакомство с руководством по IBM PC.

ъ Дискета, содержащая транслятор с языка ассемблера, пред
почтительно, но не обязательно, последней версии.

ъ Копию операционной системы PC-DOS или MS-DOS, лучше пос
ледней версии.

Cледующее является не обязательным для данной темы:

ъ Опыт программирования. Хотя эти знания могут помочь
быстрее освоить некоторые идеи программирования, они
не обязательны.

ъ Хорошие знания в электронике или схемотехнике. Данная
книга дает всю необходимую информацию об архитектуре
PC, которая требуется для программирования на языке
ассемблера.

Данная книга приследует две цели: она является учебником,
a так же постоянным справочным пособием для работы. Чтобы
наиболее эффективно восполнить затраты на микрокомпьютер и
программное обеспечение, необходимо тщательно прорабатывать
каждую главу и перечитывать материал, котоpый не сразу ясен.
Ключевые моменты находятся в примерах программ, их следует
преобразовать в выполнимые модули и выполнить их.
Прорабатывайте упражнения, приведенные в конце каждой главы.

Ассемблер для IBM PC 11

Первые восемь глав составляют базовый материал для данной
книги и для языка ассемблера. После этих глав можно
продолжить с глав 9, 11, 12, 14, 15, 19, 20 или 21.
Связанными являются главы с 8 по 10, 12 и 13, с 15 по 18,
главы с 22 по 25 cодержат справочный материал.
Когда вы завертшите работу с книгой, вы сможете:

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

Изучение языка ассемблера и создание работающих программ
— это захватывающий процесс. Затраченное время и усилия
несомненно будут вознаграждены.

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

Ассемблер для IBM PC 12

Ассемблер для IBM PC 1

ГЛАВА 1. Введение в семейство персональных компьютеров IBM PC

Введение в семейство персональных компьютеров IBM PC

Цель: объяснить особенности технических средств микрокомпью
тера и организации программного обеспечения.

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

Ассемблер для IBM PC 2

байту в памяти, компьютер проверяет этот байт. Если число
включенных битов является четным, система выдает сообщение
об ошибке. Ошибка четности может явится результатом сбоя
оборудования или случайным явлением, в любом случае, это
бывает крайне редко.
Может появится вопрос, откуда компьютер «знает», что
значения бит 01000001 представляют букву A. Когда на клавиа
туре нажата клавиша A, система принимает сигнал от этой
конкретной клавиши в байт памяти. Этот сигнал устанавливает
биты в значения 01000001. Можно переслать этот байт в памяти
и, если передать его на экран или принтер, то будет
сгенерирована буква A.
По соглажению биты в байте пронумерованы от 0 до 7 справа
налево, как это показано для буквы A:

Номера бит: 7 6 5 4 3 2 1 0
Значения бит: 0 1 0 0 0 0 0 1

Число 2 в десятой степени равно 1024, что составляет
один килобайт и обозначается буквой К. Например, компьютер с
памятью в 512К содержит 512 х 1024, т.е. 524288 байт.
Процессор в PC и в совместимых моделях использует 16-
битовую архитектуру, поэтому он имеет доступ к 16-битовым
значениям как в памяти, так и в регистрах. 16-битовое
(двухбайтовое) поле называется словом. Биты в слове
пронумерованы от 0 до 15 справа налево, как это показано для
букв PC:

Номера бит: 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Значения бит: 0 1 0 1 0 0 0 0 0 1 0 0 0 0 1 1

Для целей стандартизации в микрокомпьютерах используется
aмериканский национальный стандартный код для обмена информа
цией ASCII (American National Standard Code for Information
Interchange). Читается как «аски» код (прим. переводчика).
Именно по этой причине комбинация бит 01000001 обозначает
букву A. Наличие стандартного кода облегчает обмен данными
между различными устройствами компьютера. 8-битовый
рассширенный ASCII-код, используемый в PC обеспечивает
представление 256 символов, включая символы для нацио
нальных алфавитов. В приложении 1 приведен список символов
ASCII кода, а в главе 8 показано как вывести на экран боль
шинство из 256 символов.

Ассемблер для IBM PC 3

Так как компьютер может различить только нулевое и единич
ное состояние бита, то он работает системе исчисления с
базой 2 или в двоичной системе. Фактически бит унаследовал
cвое название от английского «BInary digiT» (двоичная
цифра).
Сочетанием двоичных цифр (битов) можно представить любое
значение. Значение двоичного числа определяется относитель
ной позицией каждого бита и наличием единичных битов. Ниже
показано восьмибитовое число содержащее все единичные биты:

Позиционные веса: 128 64 32 16 8 4 2 1
Включенные биты: 1 1 1 1 1 1 1 1

— если программа определяет элемент данных для арифмети
ческих целей, то 01000001 представляет двоичное число
эквивалентное десятичному числу 65;

— если программа определяет элемент данных (один или бо
лее смежных байт), имея в виду описательный характер,
как, например, заголовок, тогда 01000001 представляет
собой букву или «строку».

Пи програмировании это различие становится понятным, так
как назначение каждого элемента данных определено.
Двоичное число неограничено только восьмью битами. Так
как процессор 8088 использует 16-битовую архитектуру, oн
автоматически оперирует с 16-битовыми числами. 2 в степени
16 минус 1 дает значение 65535, а немного творческого
программирования позволит обрабатывать числа до 32 бит (2 в
степени 32 минус 1 равно 4294967295) и даже больше.

Микрокомпьютер выполняет арифметические действия только в
двоичном формате. Поэтому программист на языке ассемблера
должен быть знаком с двоичным форматом и двоичным сложением:

0 + 0 = 0
1 + 0 = 1
1 + 1 = 10
1 + 1 + 1 = 11

Ассемблер для IBM PC 4

Обратное внимание на перенос единичного бита в последних
двух операциях. Теперь, давайте сложим 01000001 и 00101010.
Букву A и символ *? Нет, число 65 и число 42:

01000001 65
00101010 42
01101011 107

Проверьте, что двоичная сумма 01101011 действительно
равна 107. Рассмотрим другой пример:

00111100 60
00110101 53
01110001 113

Все представленные выше двоичные числа имеют положитель
ные значения, что обозначается нулевым значением самого
левого (старшего) разряда. Отрицательные двоичные числа
содержат единичный бит в старшем разряде и выражаются двоич
ным дополнением. Т.е., для представления отрицательного
двоичного числа необходимо инвертировать все биты и
прибавить 1. Рассмотрим пример:

Если прибавить единичные значения к числу 10111111, 65 не
получится. Фактически двоичное число считается отрицатель
ным, если его старший бит равен 1. Для определения абсолют
ного значения отрицательного двоичного числа, необходимо
повторить предыдущие операции: инвертировать все биты и
прибавить 1:

Двоичное значение: 10111111
Инверсия: 01000000
Плюс 1: 01000001 (равно +65)

01000001 (+65)
10111111 (-65)
(1)00000000

Ассемблер для IBM PC 5

Все восемь бит имеют нулевое значение. Перенос единичного

Источник

Поделиться с друзьями
admin
Оцените автора
( Пока оценок нет )
Как переводится?
Adblock
detector