

### Виды симуляции

#### По детальности симуляции

- Функциональный
  - Интерпретация
  - Бинарная трансляция
- Потактовый
- Логический





#### Fetch:

• Загрузка инструкций из памяти



#### Decode:

• Декодирование загруженной инструкции



#### Decode:

• Декодирование загруженной инструкции

#### Оптимизация:

• Уже декодированные инструкции можно кешировать

Что делать с самомодифицирующимся кодом?



#### **Execute:**

• Выполнение инструкции



#### **Execute:**

• Выполнение инструкции

#### Оптимизация:

• Заменить switch на таблицу переходов

Не ухудшится ли производительность из-за перехода по косвенности?



#### Write back:

• Запись результатов выполнения инструкции



#### Write back:

• Запись результатов выполнения инструкции

#### Оптимизация:

• Кешировать транслированные адреса



#### **Advance PC:**

• Продвижение вперед program counter (регистр-указатель на инструкцию)



Можем ли мы ускорить симуляцию если интерпретировать не одну инструкцию, а сразу несколько?

Можем ли мы ускорить симуляцию если интерпретировать не одну инструкцию, а сразу несколько?

Да, делать бинарную трансляцию

1. Разбиваем последовательность инструкций на базовые блоки

**Базовый блок** — последовательность инструкций или кода, имеющую одну точку входа и одну точку



2. Транслируем базовый блок гостевой архитектуры в базовый блок архитектуры хоста



Что еще на ваш взгляд можно добавить для улучшения эффективности бинарной трансляции?

Что еще на ваш взгляд можно добавить для улучшения эффективности бинарной трансляции?

- Оптимизация базовых блоков:
  - Пропуск пор инструкций
  - Объединение инструкций

Какие проблемы вы видите у бинарной трансляции?

Какие проблемы вы видите у бинарной трансляции?

- Самомодифицирующийся код
- Изменение адресов для jump и branch инструкций
- Ограниченность оптимизаций

#### Готов или не готов?

RISC-V Architecture Test – фреймворк архитектурных тестов

Референсные модели: SAIL и SPIKE

#### А как печатать?

print — одна из первых функций при изучении языков программирования, но далеко не первая при создании новой платформы

Почему?



### Пытаемся выводить

Печать – операция ввода/вывода, т.е. работа с периферией

Как бы вы это реализовали в процессоре?

### Пытаемся выводить

Печать – операция ввода/вывода, т.е. работа с периферией

Как бы вы это реализовали в процессоре?

- Специальная инструкция
- Memory-mapped IO
- Что-то среднее

### Задание: пишем симулятор

Реализуйте симулятор rv32i процессора без привилегированных инструкций

ecall – semihosting ebreak – остановка fence.i – nop

Входной формат: образ памяти и адрес \_start

#### To be continued ...

#### На следующем занятии

- Узнаем как отличается производительность разных симуляторов
- Познакомимся с LLVM-based тестовым генератором