Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология
Образование Политология Производство Психология Стандартизация Технологии


Взаимодействие с человеком-оператором



Интерпретатор может выполняться в автоматическом или пошаговом режиме. В автоматическом режиме Интерпретатор моделирует выполнение команд программы без остановок до команды типа HALT или до точки останова. В точке останова оператор может вводить команды, управляющие действиями Интерпретатора и выбрать режим продолжения выполнения. В пошаговом режиме Интерпретатор после выполнения каждой команды программы останавливается и предоставляет оператору возможность вводить команды управления. Командами управления работой Интерпретатора могут быть:

u команды на отображение/изменение состояния/содержимого компонентов модели;

u команды задания точек останова;

u команды моделирования прерываний;

u команды установки режима выполнения;

u команда окончания работы.

Отображаться должны состояния и значения всех составляющих программной модели ВС: регистров (РОН, счетчика адреса, состояния), заданных участков памяти и их признаков, счетчика модельного времени, программы поступления прерываний и т.д. Отображаемые значения также должны быть доступны для изменений. Отметим, что для интерактивного отображения/изменения должны быть доступны также байты признаков памяти. Изменение содержимого регистра-счетчика адреса равносильно передачи управления в программе.

Точки останова могут задаваться в исходном для Интерпретатора файле и вводиться/изменяться в ходе интерактивной отладки. Могут быть предусмотрены остановы при:

u передаче управления по заданному адресу;

u чтении данных по заданному адресу;

u записи данных по заданному адресу.

Связь отладки с исходным текстом. Такая связь безусловно удобно и может быть осуществлена относительно несложно, если выход 1-го прохода Кросс-Ассемблера передается на вход Интерпретатора. Выход 1-го прохода связывает операторы исходного текста с адресами памяти. Таким образом, по значению счетчика адреса в каждый момент выполнения программы можно найти в выходе 1-го прохода соответствующий оператор исходного текста. Если на вход Интерпретатора подается также сформированная 1-м проходом таблица символов, то есть возможность обращаться к переменным программы и к точкам передачи управления по символьным именам.

Можно ли обеспечить изменение прямо в ходе отладки исходного текста? Схема решения сводится к представленной на рисунке. В схеме остается только 1-й проход Кросс-Ассемблера. Выход его — исходный текст с разметкой адресов и таблица символов является основным входом Интерпретатора. Необходимость во 2-м проходе Кросс-Ассемблера отпадает. В начале выполнения Интерпретатор должен построить модель памяти, в которой он размещает, однако, только данные программы, но не команды. При работе Интерпретатор повторяет многие действия 2-го прохода Кросс-Ассемблера, читает не коды, а исходные тексты и распознает команду не по коду операции, а по мнемонике, и интерпретирует операнды не по кодам, а по исходным текстам. Изменения в исходном тексте оператора программы должны автоматически реплицироваться в соответствующем операторе (только в одном операторе! ) результата 1-го прохода, и тогда при следующем выполнении этого оператора будет моделироваться уже выполнение новой команды. Однако, поскольку в результате 1-го прохода каждый оператор уже привязывается к определенному адресу, возможность изменения должна ограничиваться тем, что длина новой команды обязательно равна длине старой команды. Более сложные изменения потребуют повторного выполнения 1-го прохода Кросс-Ассемблера.

 

Итоговая схема алгоритма функционирования Интерпретатора сводится к следующей:

 

 

F Блок1: Запуск Интерпретатора.

F Блок2: Открытие исходных файлов — результатов работы Кросс-Ассемблера и файлов с управляющей информацией (описание файлов — внешних устройств, программа поступления прерываний, описание фрагментов памяти и отдельных ячеек и т.п.).

F Блок3: Считывание управляющей информации.

F Блок4: Установка начальных значений для компонентов модели (содержимое памяти, регистры, счетчик модельного времени).

F Блок5: Интерактивное задание/корректировка управляющей информации (режим выполнения, точки останова и т.п.).

F Блок6: Автоматический режим?

F Блок7: Если установлен пошаговый (не автоматический) режим выполнения, выполняется ввод и обработка команд оператора в интерактивном режиме. Эта обработка может заканчиваться либо продолжением выполнения интерпретатора в пошаговом или автоматическом режиме, либо завершением его работы по команде оператора.

F Блок8: Если установлен автоматический режим выполнения, но текущее значение регистра — счетчика адреса совпадает с одной из заданных точек останова, также выполняется ввод и обработка команд оператора в интерактивном режиме.

F Блок9: Проверяется счетчик модельного времени сравнивается с временем поступления первого прерывания в списке прерываний.

F Блок10: Если счетчик модельного времени больше или равен времени поступления первого прерывания в списке, выполняется сохранение текущего состояния и занесение в регистр-счетчик адреса секции обработки прерывания данного типа.

F Блок11: Первый элемент удаляется их списка прерываний и происходит возврат на начало итерации обработки команды.

F Блок12: Если прерывание не поступило, выбирается первый байт команды (при отладке по объектному модулю) или ее мнемоника (при отладке по исходному тексту).

F Блок13: Код операции или мнемоника команды ищется в таблице команд.

F Блок14: При неуспешном поиске Интерпретатор заканчивается с сообщением об ошибке.

F Блок15: Выбор операндов из кода команды или из текста оператора.

F Блок16: Проверка правильности кодирования операндов, проверка корректности обращения к памяти.

F Блок17: При ошибках в операндах или в обращении к памяти Интерпретатор заканчивается с сообщением об ошибке.

 

F Блок18: Задан ли для адреса операнда останов при обращении? Если да — возврат на выполнение команд в интерактивном режиме.

F Блок19: Интерпретация команды и запись результата

F Блок20: Вычисление и занесение в регистр-счетчик адреса следующей команды.

F Блок21: Проверка, является ли адрес в регистре-счетчике адреса адресом 1-го байта команды

F Блок22: Если это не так, Интерпретатор заканчивается с сообщением об ошибке.

F Блок23: Модификация счетчика модельного времени и переход на выполнение следующей команды.

Окончание работы Интерпретатора может происходить:

u при обнаружении ошибки в программе;

u при вводе оператором интерактивной команды завершения работы;

u при обработке команды останова (HALT) в программе.

 

Лекция 18.
Ошибки программирования

Классификация ошибок программирования

Рассмотренные ошибки программирования могут быть разделены на следующие категории:

Перестановка операндов или частей операндов

К типичным ошибкам этого рода относятся:

u перестановка операндов, указывающих на источник и назначение в командах пересылки;

u перевертывание формата, в котором запоминаются 16-разрядные значения;

u изменение направления при вычитаниях и сравнениях.

Неправильное использование флагов

Типичные ошибки следующие:

u использование не того флага, который в данном конкретном случае должен проверяться (как, например, флага знака вместо флага переноса);

u условный переход после команд, которые не воздействуют на данный флаг;

u инвертирование условий перехода (особенно при использовании флага нуля);

u неправильный условный переход в случаях равенства и случайное изменение флага перед условным переходом.

Смешивание регистров и пар регистров

Типичная ошибка состоит в работе с регистром ( В, D или Н ) вместо пары регистров с аналогичным именем.

Смешивание адресов и данных

К типичным ошибкам относятся:

u использование непосредственной адресации вместо прямой адресации или наоборот;

u смешивание регистров с ячейками памяти, адресуемыми через пары регистров.


Поделиться:



Популярное:

Последнее изменение этой страницы: 2017-03-08; Просмотров: 697; Нарушение авторского права страницы


lektsia.com 2007 - 2024 год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! (0.016 с.)
Главная | Случайная страница | Обратная связь