Разработка библиотеки mySimpleComputer. Оперативная память, регистр флагов, декодирование операций.
Состав работы
|
|
|
|
|
|
|
|
|
|
Описание
Лабораторная работа 2. Разработка библиотеки mySimpleComputer. Оперативная
память, регистр флагов, декодирование операций.
Прочитайте главу 4 практикума по курсу «Организация ЭВМ и систем». Изучите принципы
работы разрядных операций в языке Си: как можно изменить значение указанного разряда
целой переменной или получить его значение. Вспомните, как сохранять информацию в файл
и считывать еѐ оттуда в бинарном виде.
2. Разработайте функции по взаимодействию с оперативной памятью, управлению регистром
флагов и кодированию/декодированию команд:
int sc_memoryInit () – инициализирует оперативную память Simple Computer, за-
давая всем еѐ ячейкам нулевые значения. В качестве «оперативной памяти» использу-
ется массив целых чисел, определенный статически в рамках библиотеки. Размер мас-
сива равен 100 элементам.
b. int sc_memorySet (int address, int value) – задает значение указанной
ячейки памяти как value. Если адрес выходит за допустимые границы, то устанавлива-
ется флаг «выход за границы памяти» и работа функции прекращается с ошибкой;
c. int sc_memoryGet (int address, int * value) – возвращает значение указан-
ной ячейки памяти в value. Если адрес выходит за допустимые границы, то устанавли-
вается флаг «выход за границы памяти» и работа функции прекращается с ошибкой.
Значение value в этом случае не изменяется.
d. int sc_memorySave (char * filename) – сохраняет содержимое памяти в файл в
бинарном виде (используя функцию write или fwrite);
int sc_memoryLoad (char * filename) – загружает из указанного файла содер-
жимое оперативной памяти (используя функцию read или fread);
f. int sc_regInit (void) – инициализирует регистр флагов нулевым значением;
g. int sc_regSet (int register, int value) – устанавливает значение указанно-
го регистра флагов. Для номеров регистров флагов должны использоваться маски, за-
даваемые макросами (#define). Если указан недопустимый номер регистра или некор-
ректное значение, то функция завершается с ошибкой.
h. int sc_regGet (int register, int * value) – возвращает значение указанного
флага. Если указан недопустимый номер регистра, то функция завершается с ошибкой.
i. int sc_commandEncode (int command, int operand, int * value) – кодиру-
ет команду с указанным номером и операндом и помещает результат в value. Если ука-
заны неправильные значения для команды или операнда, то функция завершается с
ошибкой. В этом случае значение value не изменяется.
j. int sc_commandDecode (int value, int * command, int * operand) – деко-
дирует значение как команду Simple Computer. Если декодирование невозможно, то
устанавливается флаг «ошибочная команда» и функция завершается с ошибкой.
память, регистр флагов, декодирование операций.
Прочитайте главу 4 практикума по курсу «Организация ЭВМ и систем». Изучите принципы
работы разрядных операций в языке Си: как можно изменить значение указанного разряда
целой переменной или получить его значение. Вспомните, как сохранять информацию в файл
и считывать еѐ оттуда в бинарном виде.
2. Разработайте функции по взаимодействию с оперативной памятью, управлению регистром
флагов и кодированию/декодированию команд:
int sc_memoryInit () – инициализирует оперативную память Simple Computer, за-
давая всем еѐ ячейкам нулевые значения. В качестве «оперативной памяти» использу-
ется массив целых чисел, определенный статически в рамках библиотеки. Размер мас-
сива равен 100 элементам.
b. int sc_memorySet (int address, int value) – задает значение указанной
ячейки памяти как value. Если адрес выходит за допустимые границы, то устанавлива-
ется флаг «выход за границы памяти» и работа функции прекращается с ошибкой;
c. int sc_memoryGet (int address, int * value) – возвращает значение указан-
ной ячейки памяти в value. Если адрес выходит за допустимые границы, то устанавли-
вается флаг «выход за границы памяти» и работа функции прекращается с ошибкой.
Значение value в этом случае не изменяется.
d. int sc_memorySave (char * filename) – сохраняет содержимое памяти в файл в
бинарном виде (используя функцию write или fwrite);
int sc_memoryLoad (char * filename) – загружает из указанного файла содер-
жимое оперативной памяти (используя функцию read или fread);
f. int sc_regInit (void) – инициализирует регистр флагов нулевым значением;
g. int sc_regSet (int register, int value) – устанавливает значение указанно-
го регистра флагов. Для номеров регистров флагов должны использоваться маски, за-
даваемые макросами (#define). Если указан недопустимый номер регистра или некор-
ректное значение, то функция завершается с ошибкой.
h. int sc_regGet (int register, int * value) – возвращает значение указанного
флага. Если указан недопустимый номер регистра, то функция завершается с ошибкой.
i. int sc_commandEncode (int command, int operand, int * value) – кодиру-
ет команду с указанным номером и операндом и помещает результат в value. Если ука-
заны неправильные значения для команды или операнда, то функция завершается с
ошибкой. В этом случае значение value не изменяется.
j. int sc_commandDecode (int value, int * command, int * operand) – деко-
дирует значение как команду Simple Computer. Если декодирование невозможно, то
устанавливается флаг «ошибочная команда» и функция завершается с ошибкой.
Дополнительная информация
2015 год Фульман
Похожие материалы
Лабораторная работа 2. Разработка библиотеки mySimpleComputer. Оперативная память, регистр флагов, декодирование операций.
orokysaki
: 20 марта 2023
Изучить принципы работы оперативной памяти. Познакомиться с разрядными операциями языка Си. Разработать библиотеку mySimpleComputer, включающую функции по декодированию команд, управлению регистрами и взаимодействию с оперативной памятью.
Задание на лабораторную работу
1. Прочитайте главу 4 практикума по курсу «Организация ЭВМ и систем». Изучите принципы работы разрядных операций в языке Си: как можно изменить значение указанного разряда целой переменной или получить его значение. Вспомните, как
350 руб.
Оперативная память. Исследование рынка оперативной памяти
Elfa254
: 29 сентября 2013
I. Основные сведения об оперативной памяти
1. Назначение
2. Характеристики
3. Разъемы SIMM и DIMM
4. Спецификация SDRAM PC100
a) Спецификация PC100. Ключевые моменты
b) SPD (Serial Presence Detect)
c) Синхронное выполнение
5. Типы высокоскоростной памяти
a) SDRAM
b) Enhanced SDRAM (ESDRAM)
c) DDR SDRAM (SDRAM II)
d) SLDRAM
e) RDRAM (Rambus DRAM)
f) Direct Rambus Memory System
6. Совместимость. О существующих форм-факторах
7. Производители чипов
Чипсет Intel 820
8
10 руб.
Магистрально-модульная архитектура ПК. Основные функции центрального процессора. Оперативная память
Elfa254
: 4 октября 2013
1. Дать понятие магистрально-модульной архитектуры ПК
Архитектура современных ПК основана на магистрально-модульном принципе. Модульный принцип позволяет потребителю самому комплектовать нужную ему конфигурацию компьютера и производить при необходимости ее модернизацию.
Модульная организация системы опирается на магистральный (шинный) принцип обмена информации. Магистраль или системная шина – это набор электронных линий связывающих воедино по адресации памяти, передачи данных и служебных си
5 руб.
Другие работы
Первая мировая война 1914—1918 годов и Февральская буржуазно-демократическая революция
Aronitue9
: 25 августа 2013
В 1914 году стачечное движение в Москве приняло массовые размеры. За шесть с половиной месяцев 1914 года в стачках участвовало 240 тысяч рабочих. 23 февраля (8 марта по новому стилю) 1914 года в Москве впервые был отмечен Международный день работниц.
Начавшаяся империалистическая война ослабила рабочее движение. В Москве в первые дни войны большевистские организации подверглись разгрому: многие товарищи были арестованы, иные высланы или мобилизованы в армию. На фронт ушло до 40% московских рабоч
19 руб.
СССР во второй половине 20-х гг.
Slolka
: 4 сентября 2013
В декабре 1925 г. состоялся XIV съезд ВКП (б), на котором были подведены итоги предыдущему развитию страны. Съезд отметил, что, несмотря на успехи восстановительного периода, экономика страны все еще оставалась отсталой. СССР оставался страной многоукладной, аграрной, промышленность давала лишь 32,4% всей продукции, а мелкое, в основном, единоличное хозяйство давало 67,6%. Преобладала легкая промышленность, тяжелая индустрия была развита слабо. В промышленности отсутствовал ряд важнейших отрасле
10 руб.
Техническая термодинамика КГУ 2020 Задача 3 Вариант 13
Z24
: 12 января 2026
Определить часовой расход пара D (килограммов в час) и удельный расход пара d (килограммов на киловатт — час) на конденсационную паровую турбину, работающую без регенерации теплоты, по заданной электрической мощности турбогенератора Nэл, давлению р1 и температуре t1 перегретого пара перед турбиной и относительному внутреннему КПД турбины ηoi. Давление пара в конденсаторе принять р2=4 кПа. Механический КПД турбины ηм и КПД электрогенератора ηэ принять ηм=ηэ=0,99. Определить также степень сухости
350 руб.
Суров Г.Я. Гидравлика и гидропривод в примерах и задачах Задача 14.2 Вариант 9
Z24
: 18 октября 2025
Определить необходимую подачу насоса и КПД гидропривода (схема на рис. 14.4), если КПД насоса ηн , рабочий объем гидромотора qм, частота вращения вала гидромотора nм , крутящий момент навалу гидромотора Мм, механический КПД гидромотора ηм.м = 0,8, объемный КПД гидромотора ηм.о = 0,90. Потери давления в распределителе Δрр = 0,25 МПа. Длина гидролиний l, внутренний диаметр линии d, количество поворотов m, коэффициент местного сопротивления одного поворота ζ = 0,2, коэффициент трения λ = 0,03. Плот
180 руб.