Различия между версиями 3 и 4
Версия 3 от 2015-04-30 20:43:36
Размер: 3411
Редактор: FrBrGeorge
Комментарий:
Версия 4 от 2015-04-30 20:54:16
Размер: 3713
Редактор: FrBrGeorge
Комментарий:
Удаления помечены так. Добавления помечены так.
Строка 55: Строка 55:
Получится что-то вроде такого
'''Computer.py''':
Получится что-то вроде такого '''myComputer.py''':
Строка 58: Строка 57:
import CPU
import Memory
import Terminal
import BIOS
import FPU
import myCPU
import myRegisters
import my
Memory
import myTerminal
import myBIOS
import myFPU
Строка 66: Строка 66:
А вот А вот какой-нибудь '''myFPU.py''':
{{{#!python
import myRegisters

}}}
Означает, что смоделированный сопроцессор не работает с памятью, а работает только с регистрами

/!\ TBC

Конструктор модельных машин

В курсе «Архитектура ЭВМ» есть такая тема: «модельные машины». Учебная трёхадресная машина на (неофициальном) сайте практикума АЯ.

А на самом деле нужен конструктор, чтобы любые машины проектировать.

Что можно сконструировать

В машине может быть ( /!\ TODO: выкинуть действительно лишнее, эшелонировать):

  • Память:
    • Память с абсолютными адресами
    • Аппаратный стек с адресацией относительно вершины
  • Регистры:
    • Регистры общего назначения
      • …в т. ч. привязанные к ABI (акккумулятор и прочее)
    • Вычисляемые регистры (SP, PC, Flags)
  • Инструкции:
    • Фиксированной длины с заданным количеством адресов
    • Переменной длины
    • Автоинкремент/автодекремент
    • Обращение к сопроцессору
    • Обращение к внешнему устройству
    • Прерывания
  • Способы адресации:
    • прямая абсолютная
    • прямая относительная
    • косвенная
    • двойная косвенная
  • Сопроцессор
    • ABI по хранению FP
  • Внешние устройства
    • Печать
    • Ввод
    • «Медленное» устройство для использования аппаратных прерываний"
    • «Быстрое» устройство для использования ПДП
    • ПЗУ

Реализация

Никакого GUI, всё программируется (например, на Python) с помощью API конструктора. Причём само объектное планирование API воссоздаёт архитектуру ЭВМ, в этом фишка!

Например, могут быть готовые модули, соответствующие подсистемам

  • Память
    • Побайтовая (для команд переменной длины и произвольных данных)
    • Пословная (с указанием структуры слова, например, трёхадресное), для машин с данными отдельно, командами отдельно
    • Пословная с несколькими вариантами трактовки слова
  • Регистры (отличаются тем, что их значение может измениться, даже если в команде они явно не заданы)
  • Стек
  • АЛУ
  • Сопроцессор
  • Внешние устройства
    • Шина
      • ПЗУ
      • терминал

Получится что-то вроде такого myComputer.py:

   1 import myCPU
   2 import myRegisters
   3 import myMemory
   4 import myTerminal
   5 import myBIOS
   6 import myFPU
   7 

А вот какой-нибудь myFPU.py:

   1 import myRegisters
   2 

Означает, что смоделированный сопроцессор не работает с памятью, а работает только с регистрами

/!\ TBC

FrBrGeorge/ActualEducationalTasks/ModelComputerConstructor (последним исправлял пользователь FrBrGeorge 2021-10-11 12:23:50)