Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология Образование Политология Производство Психология Стандартизация Технологии |
Взаимодействие с человеком-оператором
Интерпретатор может выполняться в автоматическом или пошаговом режиме. В автоматическом режиме Интерпретатор моделирует выполнение команд программы без остановок до команды типа 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; Нарушение авторского права страницы