

#### **iSCALARE**



Лаборатория суперкомпьютерных технологий для биомедицины, фармакологии и малоразмерных структур

# Языки разработки моделей и аппаратуры

Григорий Речистов

grigory.rechistov@phystech.edu

#### На предыдущих лекциях:

- Цели симуляции
- Алгоритмы моделирования
- Проблемы, связанные с симуляцией устройств

#### На этой лекции:

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

# Вопрос

На каком языке программирования должен быть написан симулятор?

## Классификация компонент:

#### Графический интерфейс





Интерфейс командной строки





Интерпретатор скриптов







# Использование языков общего назначения (С, С++...)

- Используется ООП
- Написание моделей «с нуля»
- Особенности языков
  - Специфика int (int32\_t, int64\_t)
  - thread safety
  - malloc/free

#### Решения

- Создание библиотек, реализующих общие примитивы моделирования (SystemC/TLM)
- Использование специализированных языков написания моделей (DML)

## DML (1/2)



8

06.05.2014

### DML(2/2)

```
dml 1.2;
device simple dml device;
parameter desc = "Simple DML device";
parameter documentation = "This is an implementation of
simple DML device.";
bank regs {
      parameter register size = 4;
       register r1 @ 0x1000;
       register r2 @ 0x1004;
```

## Абстракции аппаратуры (1/2)

- Сигналы логический уровень (0, 1, X, Z)
- Шины передача групп бит
- Операции над отдельными битами
- Транзакции отображение направления сигнала
- Абстракции хранения данных: группы регистров, банки памяти

# Абстракции аппаратуры (2/2)

- Карты памяти
- Задержки событий разные для различных действий

## Разработка процессора (1/2)





#### Примеры:

- LISA
- ISDL
- SimGen

int 13h





Дизассемблер Симулятор

Документация

# Разработка процессора (2/2)

#### Недостатки:

- Генерируется не самый быстрый код
- Код может быть не компактен
- Модель может работать медленнее

#### Преимущества:

- Скорость создания/ модификации
- Согласованность

# Verilog

Phil Moorby & Prabhu Goel «Automated Integrated Design Systems», 1984 г.

Netlist — логически эквивалентное описание, состоящее из элементарных логических примитивов

#### Команды:

- Синтезируемые представленные в аппаратуре
- Несинтезируемые для отладки и симуляции

#### VHDL

- Был разработан в 1983 г. по заказу Министерства обороны США
- Первоначально предназначался для моделирования, но позже появилась и синтезируемое подмножество

# Литература

- Architecture implementation using the machine description language LISA / O. Schliebusch et al. — 2002 http://ieeexplore.ieee.org/lpdocs/epic03/wrapper.htm?arnumber=994928.
- Hadjiyiannis G., Hanono S., Devadas S. ISDL: An Instruction Set Description Language for Retargetability. — 1997 http://www.caa.lcs.mit.edu/~devadas/pubs/isdl.ps

# На следующей лекции:

Контрольная работа

#### Спасибо за внимание!

Все материалы курса выкладываются на сайте лаборатории: <a href="http://iscalare.mipt.ru/material/course\_materials/">http://iscalare.mipt.ru/material/course\_materials/</a>

Замечание: все торговые марки и логотипы, использованные в данном материале, яв<mark>ляются собс</mark>твенностью их владельцев. Представленная здесь точка зрения отражает личное мнение автора, не выступающего от лица какой-либо организации.