Методические указания к лабораторной работе CUU-2016 (1065526), страница 3
Текст из файла (страница 3)
Linux –
2.2 Начало работы.
Рис.4. Главное окно макета.
Запустив макет, слева вы увидете две вкладки. Одна из них(4) соответствует таблице переходов, другая(5) – оперативной памяти. Для переключения между ними просто кликните на нужную вкладку.
Сверху расположено основное меню, с помощью которого вы можете создать новый файл(1), открыть существующий файл(2) или сохранить файл(3).
Кнопки 6 и 7 предназначены для добавления/удаления строки в таблице переходов.
Кнопка 8 запустит программу.
2.3 Создание нового файла.
Нажмите на кнопку 1. Таблица переходов и ОП примут свое исходное состояние (при запуске макета они также находятся в исходном состоянии).
2.4 Открытие существующего файла.
Нажмите на кнопку 2. В диалоговом окне вам будет предложено выбрать файл, видны будут только файлы с расширением «.cuu». Файлы, созданные в предыдущей версии макета, не поддерживаются.
2.5 Сохранение файла.
Нажмите на кнопку 3, введите название файла и выберите папку для сохранения.
2.6 Работа с таблицей переходов.
Каждая строка таблицы переходов состоит из четырех полей:
-
Исходное состояние.
-
Следующее состояние.
-
Условия перехода.
-
Управляющие сигналы.
Исходное и следующее состояние должны быть указаны обязательно. Условия перехода и управляющие сигналы могут быть не указаны вообще, указаны оба или может быть заполнено только одно из этих полей. Также допускаются пустые строки, которые игнорируются при выполнении программы.
Исходное и следующее состояния задаются числами от 0 до 999. В документации состояния указываются в формате a<номер состояния>, например, a2.
Условия перехода задаются комбинацией флагов x4, x3, x2, x1, z, n, c, p и b, перечисленных через запятую. Флаг b может задаваться только отдельно от других. Условием может быть как значение флага 1, так и значение флага 0. Для задания отрицательного условия перед соответствующим флагом ставится знак “–“ или “!”.
Управляющие сигналы перечисляются через запятую. Управляющий сигнал задается буквой “y” и следующим за ней номером сигнала. После окончания ввода, сигналы автоматически сортируются по возрастанию, а также удаляются сигналы, не указанные в данном методическом пособии.
Буквы “x” и “y” набираются на английской раскладке клавиатуры. Количество запятых и пробелов в полях Условия перехода и Управляющих сигналы не ограничено , строка будет автоматически приведена к правильному формату. Также допускается использование верхнего регистра, который будет автоматически изменен на нижний.
Если в поле Условия перехода или Управляющие сигналы введены неверные данные, после окончания ввода соответствующее поле подсветится красным. После исправления данных красный контур исчезнет.
Добавление строки:
Выберите строку, кливнув на любое поле в ней и нажмите клавишу «Enter» или кнопку 6. Новая строка будет добавлена после выбранной строки. Для добавления строки перед первой строкой поместите курсор в начало первой строки(на нулевую позицию поля Исходное состояние) и нажмите клавишу «Enter» или кнопку 6.
Удаление строки:
Выберите строку и нажмите кнопку 7 ИЛИ поместите курсор в начало строки(на нулевую позицию поля Исходное состояние) и нажмите клавишу «Backspace».
Перемещение между полями осуществляется клавишами со стрелками или клавишами WASD(в последнем случае при перемещении вправо/влево позиция курсора в поле не учитывается), также можно выбрать поле с помощью курсора.
2.7 Работа с ОП.
Слева от таблицы ОП располагаются адреса страниц, сверху – адреса слов в странице. Таким образом, чтобы ввести байт данных по адресу(к примеру) 3A , нужно выбрать строку, соответствующую странице памяти с адресом 3, столбец, соответствующий слову с адресом А в странице и ввести нужный байт в ячейку на их пересечении.
Ввод данных можно производить непрерывно, после ввода байта данных курсор автоматически переместится в начало следующего байта. Вручную перемещение между байтами осуществляется с помощью клавиш со стрелками или курсора.
2.8 Выполнение программы.
Рис.5. Окно выполнения программы.
Для запуска программу нажмите кнопку 8. Если программа содержит ошибки (есть поля, подсвеченные красным), то выдастся сообщение об ошибках и программа запущена не будет.
После запуска программы будет сразу выполнен первый такт. В окне выполнения программы содержится информация о текущей строке программы, выполняемой микрооперации, а также информация о состоянии регистров и флагов до и после выполнения микрооперации.
Переход к следующему такту осуществляется с помощью клавиши «Enter» или кнопки 9.
Перемотка в конец программы осуществляется с помощью кнопки 10. Перемотка возможна только до 1000-го такта. Если программа выполняется циклически или содерит слишком большое количество тактов, после 1000-го такта можно воспользоваться пошаговым выполнением.
Вы в любой момет можете закрыть окно выполнения программы клавишей «Esc» или стандартной кнопкой закрытия окна.
2.9 Выход.
Закрытие макета осуществляется с помощью стандартной кнопки закрытия окна или любым другим методом, предусмотренным конкретной операционной системой. При закрытии будет вызвано диалоговое окно, уточняющее намерение выйти из программы. При выборе «Да» окно с макетом закроется, «Нет» закроет только диалоговое окно.
Данные при выходе из программы НЕ сохраняются автоматически.
3. Порядок выполнения работы.
-
Получить у преподавателя вариант задания(см. п. 4 - Варианты).
-
Разработать алгоритм решения задачи(см. рис.6.)
-
Разработать систему машинных команд(см п. 1.4 – Машинные команды и таблицу 8).
-
Разработать микропрограммы машинных операций(см. п 1.6. – Микрооперации и рис.7).
-
Разработать обобщенную программу работы ЦУУ(см. рис. 8), используя результаты выполнения пнуктов 2-4.
В микропрограмме необходимо предусмотреть:
-
Выборку машинных команд из оперативной памяти в регистр команд
-
Расшифровку кода операции выбранной команды и выполнение соответствующей операции
-
Переход к выбору и выполнению следующей команды программы.
-
Загрузку начального адреса в программный счетчик
-
Окончание вычислений после выполнения программы
-
Построить закодированный граф микропрограммы(см. рис.9), используя списки микроопераций и логических условий. Состояния указываются в формате a<номер состояния>.
-
Разработать управляющий автомат (в соответствии с закодированным графом) по схеме Мура или Мили и составить таблицу переходо(см таблицу 9). Сигналы возбуждения D6-D1 соответствуют битам следующего состояния, D6 – старший бит, D1 – младший. Сигнал возбуждения указывается в том случае, если соответствующий ему бит равен 1.
-
Синтезировать управляющий автомат(см. рис. 10) на основе ПЛМ и регистра, включенного в режим записи по тактовому сигналу:
-
Определить разрядность памяти управляющего автомата:
-
K = log2N (N – число состояний автомата).
-
Опредилить число m использующихся в микропрограмме управляющих сигналов.
-
Определить необходимое число ПЛМ ( каждая ПЛМ имеет 16 входов, 8 выходов и может реализовать до 68 конъюнкций).
-
Распределить между ПЛМ управляющие сигналы и сигналы возбуждения.
-
Для каждой ПЛМ построить таблицу соединений(см. таблицу 10).
На входы ПЛМ подаются коды состояния и осведомительные сигналы(условия), а с выхода снимаются сигналы возбуждения D6-D1 и управляющие сигналы. У первой ПЛМ на выходе будут только сигналы возбуждения.
-
Составить машинную программу в мнемокодах на основании алгоритма и набора машинных команд (см рис. 11).
-
Составить карту памяти(распределить страницы памяти между данными, командами, программой и подпрограммой, см рис. 12.).
-
Закодировать машинные команды в шестнадцатеричной системе счисления и составить программу в машинных кодах (в соответствии с картой памяти и выбранными машинными командами, см. таблицу 11).
-
Промоделировать работу ЦУУ с помощью электронного макета.
Содержание отчета.
-
Постановка задачи и исходные данные.
-
Алгоритм решения задачи.
-
Программа в мнемокодах.
-
Программа в машинных кодах.
-
Карта памяти.
-
Фотография памяти.
-
Обобщенная микропрограмма.
-
Закодированный граф микропрограммы.
-
Список переходов.
10. Таблицы соединений ПЛМ.
11. Протокол работы ЦУУ.
Пример отчета по лабораторной работе находится в файле ЦУУ.doc.
Примеры отдельных компонентов можно посмотреть в конце данного пособия.
4. Варианты.
Таблица 5.
Вариант | Код задания | Вариант | Код задания | Вариант | Код задания | Вариант | Код задания | Вариант | Код задания |
I | I-П3-I | 21 | 5-П2-7 | 41 | 9-П3-9 | 61 | 13-П2-5 | 81 | 1-Р-8 |
2 | 2-П2-2 | 22 | 6-П1-8 | 42 | 10-КР1-7 | 62 | 14-П3-6 | 82 | 2-П3-9 |
3 | 3-П1-3 | 23 | 7-КР2-9 | 43 | 11-П1-7 | 63 | 15-КР1-4 | 83 | 3- П3-8 |
4 | 4-КР2-4 | 24 | 8-КР1-1 | 44 | 12-П3-6 | 64 | 16-Р-3 | 84 | 4-Р-7 |
5 | 5-КPI-5 | 25 | 9-Р-2 | 45 | 13-КР1-5 | 65 | 1-П2-2 | 85 | 5-Р-6 |
6 | 6-Р-6 | 26 | 10-П3-3 | 46 | 14-Р-4 | 66 | 2 - Р-3 | 86 | 6-П3 -5 |
7 | 7-ПЗ-7 | 27 | 11-П2-4 | 47 | 15-П2-3 | 67 | 3-КР2-4 | 87 | 7-П2-4 |
8 | 8-П2-8 | 28 | 12-П1-5 | 48 | 16-КР1-2 | 68 | 4-П1-5 | 88 | 8-Р - 3 |
9 | 9-П1-9 | 29 | 13-КР2-6 | 49 | 1-КР1-1 | 69 | 5-П1-6 | 89 | 9-КР2-2 |
10 | 10-КР2 -1 | 30 | 14-КР1-7 | 50 | 2-П1-2 | 70 | 6-КР1-7 | 90 | 10-П1-1 |
11 | 11-KPI-2 | 31 | 15-Р-8 | 51 | 3-П2-3 | 71 | 7-Р-8 | 91 | 11-Р-2 |
12 | 12-P-3 | 32 | 16-П1-9 | 52 | 4-КР1-4 | 72 | 8-П1-9 | 92 | 12-КР2-3 |
13 | 13-ПЗ-4 | 33 | 1-П1-1 | 53 | 5-КР2-5 | 73 | 9-П2-8 | 93 | 13-П1-4 |
14 | 14-П2-5 | 34 | 2-КР2-2 | 54 | 6-П2-6 | 74 | 10-Р-9 | 94 | 14-П1-5 |
15 | 15-П1-6 | 35 | 3-КР1-3 | 55 | 7-КР1-7 | 75 | 11-П3-8 | 95 | 15-КР2-6 |
16 | 16 -П3-8 | 36 | 4-П2-4 | 56 | 8-П3-8 | 76 | 12-П2-7 | 96 | 16-Р-7 |
17 | 1-КР2-3 | 37 | 5-П3-5 | 57 | 9-КР1-9 | 77 | 13-Р-6 | 97 | 1-КР2-6 |
18 | 2-КР1-4 | 38 | 6-КР2-6 | 58 | 10-П2-8 | 78 | 14- КР2 -5 | 98 | 2-КР1-7 |
19 | 3-Р-5 | 39 | 7-П1-7 | 59 | 11-КР2-7 | 79 | 15-П3-6 | 99 | 3-Р-9 |
20 | 4-П3-6 | 40 | 8-КР2-8 | 60 | 12-КР1-6 | 80 | 16-Р-7 | 100 | 4-КР2-8 |
101 | 5-КР1-3 | 107 | 11-КР1-7 | 113 | 1-П1-9 | 119 | 7-П1-2 | 125 | 13-П1-2 |
102 | 6-Р-2 | 108 | 12-Р-8 | 114 | 2-П2-6 | 120 | 8-П2-4 | 126 | 14-П2-3 |
103 | 7-П3-1 | 109 | 13-П3-9 | 115 | 3-П3-7 | 121 | 9-П3-6 | 127 | 15-П3-4 |
104 | 8-КР1-9 | 110 | 14-КР1-1 | 116 | 4-КР1-6 | 122 | 10-КР1-5 | 128 | 16-КР1-5 |
105 | 9-Р-5 | 111 | 15-Р-2 | 117 | 5-КР2-1 | 123 | 11-КР2-3 | 129 | 1-КР2-6 |
106 | 10-КР2-6 | 112 | 16-КР2-7 | 118 | 6-Р-8 | 124 | 12-Р-1 | 130 | 2-Р - 7 |
Расшифровка кода задания: