Системное программирование. Конспект лекций


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


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

  • команды на отображение/изменение состояния/содержимого компонентов модели;
  • команды задания точек останова;
  • команды моделирования прерываний;
  • команды установки режима выполнения;
  • команда окончания работы.

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

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

  • передаче управления по заданному адресу;
  • чтении данных по заданному адресу;
  • записи данных по заданному адресу.

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

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



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



  • Запуск Интерпретатора.
  • Открытие исходных файлов - результатов работы Кросс-Ассемблера и файлов с управляющей информацией (описание файлов - внешних устройств, программа поступления прерываний, описание фрагментов памяти и отдельных ячеек и т.п.).
  • Считывание управляющей информации.
  • Установка начальных значений для компонентов модели (содержимое памяти, регистры, счетчик модельного времени).
  • Интерактивное задание/корректировка управляющей информации (режим выполнения, точки останова и т.п.).
  • Автоматический режим?
  • Если установлен пошаговый (не автоматический) режим выполнения, выполняется ввод и обработка команд оператора в интерактивном режиме. Эта обработка может заканчиваться либо продолжением выполнения интерпретатора в пошаговом или автоматическом режиме, либо завершением его работы по команде оператора.
  • Если установлен автоматический режим выполнения, но текущее значение регистра - счетчика адреса совпадает с одной из заданных точек останова, также выполняется ввод и обработка команд оператора в интерактивном режиме.
  • Проверяется счетчик модельного времени сравнивается с временем поступления первого прерывания в списке прерываний.
  • Если счетчик модельного времени больше или равен времени поступления первого прерывания в списке, выполняется сохранение текущего состояния и занесение в регистр-счетчик адреса секции обработки прерывания данного типа.
  • Первый элемент удаляется их списка прерываний и происходит возврат на начало итерации обработки команды.
  • Если прерывание не поступило, выбирается первый байт команды (при отладке по объектному модулю) или ее мнемоника (при отладке по исходному тексту).
  • Код операции или мнемоника команды ищется в таблице команд.
  • При неуспешном поиске Интерпретатор заканчивается с сообщением об ошибке.
  • Выбор операндов из кода команды или из текста оператора.
  • Проверка правильности кодирования операндов, проверка корректности обращения к памяти.
  • При ошибках в операндах или в обращении к памяти Интерпретатор заканчивается с сообщением об ошибке.
  • Задан ли для адреса операнда останов при обращении? Если да - возврат на выполнение команд в интерактивном режиме.
  • Интерпретация команды и запись результата
  • Вычисление и занесение в регистр-счетчик адреса следующей команды.
  • Проверка, является ли адрес в регистре-счетчике адреса адресом 1-го байта команды
  • Если это не так, Интерпретатор заканчивается с сообщением об ошибке.
  • Модификация счетчика модельного времени и переход на выполнение следующей команды.

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


    • при обнаружении ошибки в программе;
    • при вводе оператором интерактивной команды завершения работы;
    • при обработке команды останова (HALT) в программе.


    x


    Содержание раздела