Основные команды отладчика CodeView Microsoft
Поможем в ✍️ написании учебной работы
Поможем с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой

 

Для вызова отладчика CodeView следует набрать  в командной строке CV и, если необходимо, имена файлов, с которыми мы будем работать, например CV prog.exe. Затем нажать Enter. Отладчик выдаст на экран монитора листинг Вашей программы и установит курсор на первую команду программы. Нажмите F2. Справа от программы отобразятся регистры процессора. Нажимая клавишу F8, Вы будете исполнять программу по одной команде.

Управляющие клавиши

Alt − активизация строки меню в верхней части экрана.

Alt /F/X - выход из Code View.

Alt/R/R – рестарт программы (возвращение её в исходное состояние для повторного пуска с самого начала).

Ctrl/G – увеличение размера (каждый раз на одну строку информационного

окна с курсором).

Ctrl/T – уменьшение размера (каждый раз на одну строку информационного окна с курсором).

Esc− выход из меню.

Функциональные клавиши

F1 − вывод справочника.

F2 − вывод на экран информационного поля с содержимым регистров

процессора.

F3 − переключение вида основного информационного кадра (только

машинные команды, только исходный текст).

F4 − переключение на экран DOS и обратно.

F5 − выполнение программы до конца или до точки останова.

F6 − перевод курсора на информационное поле программы или на поле

     командной строки.

F7 − выполнение программы до курсора или до точки останова.

F8 − выполнение одной команды (подпрограммы и циклы выполняются

команда за командой).

F9 − установка или снятие точки останова в положение курсора.

F10 − выполнение одной команды (подпрограммы и циклы выполняются

как одна команда, если в них нет точки останова).

Команды командной строки

G seg: addr − выполнение программы до адреса seg: addr, точки останова

или конца программы. В качестве параметра seg может

использоваться обозначение сегментного регистра или число. По умолчанию seg = CS.

P n – выполнение n команд, с выполнением подпрограмм и циклов как

одной команды. По умолчанию n =1.

T n- выполнение n команд со входом в подпрограммы и циклы. По 

умолчанию n =1.

D type seg: addr L nmb − дамп nmb байтов в формате type начиная с адреса

seg: addr.

В качестве параметра seg может использоваться обозначение сегментного регистра или число. По умолчанию seg = CS. Параметр type (тип)- может принимать следующие значения:

− А − только коды ASCII;

− В − байты и коды ASCII, W- слова.

После выполнения одной команды D указанный тип остаётся

установленным. Между командой и типом не должно быть пробела.

D type seg: addr1 addr2 − дамп памяти от адреса seg: addr1 до адреса seg:

addr2. R reg- вывод содержимого регистра reg и запрос его изменение.

R reg= n- занесение в регистр reg значения n.

E type seg: addr n1 n2 …- занесение в память начиная с адреса seg: addr  

значений n1, n2 в формате type. Возможные значения type приведены в описании команды D. По умолчанию seg= DS. Между командой и типом не должно быть пробелов.

N radix − изменение системы счисления в параметрах командной строки.

Параметр radix может принимать значения 16 и 10. Команда N без параметра выводит действующее значение системы счисления.

BP seg: addr − установка точки останова по адресу seg: addr.

По умолчанию seg:= CS.

BP seg: addr ste p− установка точки останова по адресу seg: addr с

пропуском её при выполнении первых step раз. Команда используется при отладке многошаговых циклов.

BL − вывод списка точек останова с их адресами.

BCn − снятие точки останова с номером n.

BC * − снятие всех точек останова.

BDn − выключение (но не снятие) точки останова с номером n.

 

Библиографический список

 

1. Бройдо В.Л. Вычислительные системы, сети и телекоммуникации – СПб.: Питер, 2002. – 688 с.

2. Вычислительные системы сети и телекоммуникации. Пятибратов и др. – М.: ФИС, 2003.− 512 с.

3. Столингс, Вильям. Структурная организация и архитектура компьютерных систем.− М.: Изд. Дом «Вильямс», 2002. – 896  с.

4. Каган Б.М. Электронные вычислительные машины и системы. −  М.: Энергоатомиздат, 1991. − 592 с.                        

5. Скэнлон Л. Персональные ЭВМ IBM PC и XT. Программирование на языке Ассемблера. −  М.: Радио и связь, 1989.- 336 с.

6. Гилмор Ч. Введение в микропроцессорную технику. −  М.: Мир, 1984.- 334 с.

7. Зельцин Е. А. Цифровые интегральные микросхемы в информационно-измерительной аппаратуре. − Л.: Энергоатомиздат, 1986.- 280 с.

8. Пильщиков В. Н. Программирование на языке Ассемблера IBM PC. − М.: Диалог - МИФИ, 1996.- 340 с.

9. Русак И. М. Технические средства ПЭВМ справочник. − Минск.: Высш. шк. 1996.- 504 с.

10. Абель П. Язык Ассемблера для IBM PC и программирования. − М.: Высш. шк., 1992.- 447 с.

11. Лямин Л. В. Макроассемблер MASM. − М.: Радио и связь, 1994.- 320 с.

12. Рудаков П. И. Программирование на языке ассемблера IBM PC- 2-е изд., перабот. и доп. −  Обнинск.: Издательство “Принтер”, 1997.- 584 с.

13. Бредли Д. Программирование на языке ассемблера для персональной ЭВМ фирмы IBM. − М.: Радио и связь, 1988.- 448 с.

14. Фрир Дж. Построение вычислительных систем на базе перспективных микропроцессоров. −  М.: Мир, 1990.- 413 с.

15. Стрыгин В.В. Основы вычислительной, микропроцессорной техники и программирования. − М.: Высш. шк., 1989.- 479 с.

16.      Шило В. Л. Популярные цифровые микросхемы: справочник. − М.: Радио и связь, 1987.- 352 с.

17. Соломатин Н. М. Элементы ЦВМ. −  М.: Высш. шк., 1984.- 143 с.

18. Гук М. Интерфейсы ПК: справочник. −  СПб: Питер Ком, 1999.-416 с.

19. Бердышев Е. Технология ММХ. Новые возможности процессоров Р5 и Р6. −  М.: ДИАЛОГ-МИФИ, 1998-234 с.

20. Гук М. Процессоры Pentium 11. − Спб: Издат. "Питер" , 2000.- 480 с.

21. Гук М., Юров В. Процессоры Pentium 111, Athlon и другие - СПб: Издательство "Питер" , 2000.- 480 с.

22. Смит Б.Э., Джонсон М. Т. Архитектура и программирование процессора INTEL 80386 / Пер. с англ. Григорьева В.Л. – М.: Конкорд, 1992. - 334 с.

23. Фролов А.В., Фролов Г.В. Аппаратное обеспечение персонального компьютера. – М.: ДИАЛОГ - МИФИ, 1997. – 304 с.

24. Олифер В.Г., Олифер Н.А. Компьютерные сети. Принципы, технологии, протоколы. – СПб.: Издательство Питер, 1999. – 672 с.

25. Шатт С. Мир компьютерных сетей. – К.:BHV, 1996. – 288 с.

26. Гук М. Локальные сети NOVEL. – СПб.: Питер, 1996. – 288 с.

27. Корнеев В.В. Современные микропроцессоры. − М.: НОЛИДЖ, 2000. − 320 с.

28. Стандарты по локальным вычислительным сетям: Справочник. В.К.Щербо, В.М.Киреичев, С.И.Самойленко; под ред. С.И.Самойленко.- М.: Радио и связь, 1990. − 456 с.

29. Волоконная оптика в локальных и корпоративных сетях связи. А.Б.Семенов, АйТи. – М.: Компьютер-пресс, 1998. −340 с.

30. Персональные компьютеры в сетях ТСР/IР. Крейг Хант, перев. с англ. – BHV – Киев, 1998. − 350 с.

31. Высокопроизводительные сети. Энциклопедия пользователя. Марк А. Спортак и др.; перев. с англ. – Киев ДиаСоф, 1998. − 560 с.

32. Толковый словарь по вычислительной технике; перев. с англ. – М.: Издательский отдел “Русская редакция” ТОО ”Channel Trading LTD.”1995. −479 с.

 

 

 

Содержание

 

Введение.............................................................................................................. 6

1 Функциональное и структурное построение ПК............................................ 7

1.1 Основные понятия......................................................................................... 7

1.2 Программная модель процессора 8086.................................................... 14

1.2.1 Регистры общего назначения............................................................... 15

1.2.2 Сегментные регистры.............................................................................. 16

1.2.3 Регистры указателей и индексов............................................................. 17

1.2.4 Указатель команд IP.............................................................................. 18

1.2.5 Регистр флагов EF.................................................................................. 19

1.2.5.1 Флаги состояний.................................................................................. 19

1.2.5.2 Флаги управления................................................................................. 20

1.3 Вычисление адреса ячейки памяти............................................................. 21

1.4 Представление данных в ЭВМ................................................................... 22

2 Введение в язык Ассемблера......................................................................... 25

2.1 Формат команд Ассемблера....................................................................... 25

2.2 Режимы адресации операндов команд...................................................... 27

2.2.1 Регистровая и непосредственная адресация........................................... 28

2.2.2 Прямая адресация памяти....................................................................... 31

2.2.3 Косвенная регистровая адресация.......................................................... 32

2.2.4 Адресация по базе.................................................................................... 33

2.2.5 Прямая адресация с индексированием................................................... 33

2.2.6 Адресация по базе с индексированием................................................... 34

2.3   Задание данных в операторах исходной программы............................. 35

2.3.1 Идентификаторы данных и команд........................................................ 36

2.4 Псевдооператоры (директивы) Ассемблера..................................... 37

2.4.1   Псевдооператоры (директивы) определения типа данных.............. 37

2.4.2  Псевдооператоры определения сегмента / процедуры.............. 38

2.4.3 Псевдооператоры присваивания атрибута данным.................... 40

2.4.4 Псевдооператоры возвращающие значения................................. 40

2.4.5 Псевдооператоры (директивы) задания набора команд............ 41

2.4.6 Пример использования директив и команд в программе.................... 41

3 Система команд процессора 80386............................................................... 43

3.1 Подробное описание некоторых команд Ассемблера.............................. 46

3.1.1 Команды сложения - ADD, ADC............................................................. 46

3.1.2 Команды  безусловной передачи управления - CALL, RET, JMP........ 48

3.1.3 Команда сравнения источника и приемника - CMP.............................. 51

3.1.4 Команды преобразования типов данных – CBW, CWD,CDQ.............. 52

3.1.5 Команда уменьшения содержимого приемника - DEC.......................... 53

3.1.6 Команды деления - DIV, IDIV................................................................ 53

3.1.7 Команды умножения - MUL, IMUL....................................................... 55

3.1.8 Команда увеличения значения приемника – INC.................................. 56

3.1.9 Команда программного прерывания – INT........................................... 57

3.1.10 Команды условной передачи управления - Jxx................................... 58

3.1.11 Команда пересылки адреса - LEA........................................................ 61

3.1.12 Команда управления циклами - LOOP................................................ 62

3.1.13 Команда пересылки данных - MOV..................................................... 63

3.1.14 Команда возврата из процедур............................................................. 65

3.1.15 Команды обращения в стэк – POP, PUSH............................................ 65

3.1.16 Команды вычитания - SUB, SBB.......................................................... 69

3.1.17 Логические команды - AND, OR, XOR и TEST............................... 71

3.1.18 Команда обмена операндами - XCHG.................................................. 73

3.2 Команды процессоров Intel 8086 – Intel 80386....................................... 74

   Команды пересылки данных.................................................................... 76

  Арифметические команды........................................................................ 79

  Команды расширения знака...................................................................... 82

  Команды манипулирования битами......................................................... 82

  Команды  обработки  строк...................................................................... 86

  Команды управления программой........................................................... 91

4. Ввод, трансляция и исполнение программы............................................. 100

4.1 Разработка программы на языке Ассемблере......................................... 100

4.2 Ваша первая программа на Ассемблере................................................. 101

4.2.1 Ассемблирование вашей первой программы....................................... 102

4.2.2 Компоновка программы........................................................................ 104

4.2.3 Запуск вашей первой программы......................................................... 104

5 Примеры программ на языке ассемблера................................................. 106

5.1 Умножение двойных слов. (СОМ – программа)..................................... 106

5.2 Сложение чисел в ASCII-формате. (СОМ – программа)........................ 108

5.3 Многословное сложение (ЕХЕ – программа).......................................... 109

5.4 Преобразование шестнадцатеричной цифры в ASCII код..................... 111

5.5 Преобразование ASCII формата в двоичный формат............................ 113

6. Сообщения об ошибках MASM и LINK.................................................... 117

7 Отладчики программ................................................................................... 127

7.1 Назначение и функции отладчиков программ........................................ 127

7.2 Основные команды отладчика DEBUG................................................... 128

7.3 Основные команды отладчика CodeView Microsoft................................ 133

Библиографический список....................................................................    136

Дата: 2018-11-18, просмотров: 482.