OS-VVM (Диплом)/Описание тестовой программы — различия между версиями
Материал из Wiki
(→3Anticollision3) |
(→4Anticollision4) |
||
Строка 155: | Строка 155: | ||
** signal CoilModulation : out std_logic - огибающая; | ** signal CoilModulation : out std_logic - огибающая; | ||
− | === | + | === COMPATIBILITY WRITE === |
− | + | COMPATIBILITY WRITE — совместимая запись | |
− | * Подаёт | + | * Подаёт первую часть команды на драйвер (вычисляет код команды, добавляет CRC) |
+ | * Контролирует паузу между запросом и ответом | ||
+ | * Подаёт вторую часть команды на драйвер (вычисляет код команды, добавляет CRC) | ||
* Контролирует паузу между запросом и ответом | * Контролирует паузу между запросом и ответом | ||
* Принимает ответ и сравнивает его с ожидаемым ответом (используя UID) | * Принимает ответ и сравнивает его с ожидаемым ответом (используя UID) | ||
Строка 166: | Строка 168: | ||
Интерфейс: | Интерфейс: | ||
*Входы | *Входы | ||
− | + | ** Arg : in natural - адрес (0-15) | |
− | ** Arg : in natural - | + | ** Data : in integer_vector(4 downto 1) — 4 байта |
− | ** | + | |
*Выходы | *Выходы | ||
** Error : out boolean (true = ошибка, false= всё Ок). | ** Error : out boolean (true = ошибка, false= всё Ок). |
Версия 22:24, 10 марта 2013
Проект Диплом
- Спецификация ИМС
- Тестовый план
- Описание тестовой программы
Литература
- Метрики и процессы покрытия (en)
- Coverage Examples (Practice) (en)
- Requirements Writing Guidelines (en)
* OS-VVM *
Содержание |
Архитектура тестбенча
|
---|
Рисунок — Архитектура тестбенча (edit) |
Описание процедур/функций
Driver
Драйвер преобразует последовательность бит, передаваемых ему командой в огибающую.
Интерфейс:
- data_size : in natural - размер передаваемых данных;
- data : in bit_vector - входной сигнал;
- signal output : out std_logic - выходной сигнал (огибающая);
Responder
Респондер преобразует выходной сигнал DUT в последовательность бит. Запускается при получении стартового бита ответа.
Интерфейс:
- signal tdata_mod : in std_logic - сигнал из DUT;
- signal out_data : out std_logic_vector(1 to 164) - выходной сигнал респондера;
- signal bit_num : out integer - количество бит, полученных респондером;
Pause
Pause ждет ответ DUT и считает периоды.
Интерфейс:
- signal tdata_mod : in std_logic - сигнал из DUT;
- signal clk_num : out integer - количество периодов;
Reset
Reset останавливает clock генератор на указанное время.
Интерфейс:
- wait_time : in time - время сброса(при 0 - бесконечно);
- signal stop : out bit - сигнал остановки clock генератора;
WUPA
WUPA - запрос всех карт;
- Подаёт соответствующую команду на драйвер (0х52)
- Контролирует паузу между запросом и ответом
- Принимает ответ и сравнивает его с ожидаемым ответом (используя UID)
- Выдаёт ошибку (Error=true), если
- Пауза не соответствует спецификации
- Ошибка в данных ответа
Интерфейс:
- Входы
- —
- Выходы
- Error : out boolean (true = ошибка, false= всё Ок).
- Сигналы
- signal tdata_mod : in std_logic - сигнал, идущий с выхода DUT;
- signal CoilModulation : out std_logic - огибающая;
REQA
REQA — запрос карты
- Подаёт соответствующую команду на драйвер (0х26)
- Контролирует паузу между запросом и ответом
- Принимает ответ и сравнивает его с ожидаемым ответом (используя UID)
- Выдаёт ошибку (Error=true), если
- Пауза не соответствует спецификации
- Ошибка в данных ответа
Интерфейс:
- Входы
- —
- Выходы
- Error : out boolean (true = ошибка, false= всё Ок).
- Сигналы
- signal tdata_mod : in std_logic - сигнал, идущий с выхода DUT;
- signal CoilModulation : out std_logic - огибающая;
Anticollision
Anticollision — Антиколлизия и select 1/2 каскадного уровня
- Подаёт соответствующую команду на драйвер (вычисляет код команды, добавляет 0x88 для 1 уровня, добавляет BCC и CRC)
- Контролирует паузу между запросом и ответом
- Принимает ответ и сравнивает его с ожидаемым ответом (используя UID)
- Выдаёт ошибку (Error=true), если
- Пауза не соответствует спецификации
- Ошибка в данных ответа
Интерфейс:
- Входы
- Level : in bit — каскадный уровень 1/2 (0=0х93, 1=0х95)
- Arg : in natural - аргумент (0х20-0х67)
- UID : in integer_vector(6 downto 0) — UID (7 байт, 6-MSB, 0-LSB)
- Выходы
- Error : out boolean (true = ошибка, false= всё Ок).
- Сигналы
- signal tdata_mod : in std_logic - сигнал, идущий с выхода DUT;
- signal CoilModulation : out std_logic - огибающая;
READ
READ - чтение
- Подаёт соответствующую команду на драйвер (вычисляет код команды, добавляет CRC)
- Контролирует паузу между запросом и ответом
- Принимает ответ и сравнивает его с ожидаемым ответом (используя UID)
- Выдаёт ошибку (Error=true), если
- Пауза не соответствует спецификации
- Ошибка в данных ответа
Интерфейс:
- Входы
- Arg : in natural - адрес (0-15)
- Выходы
- Error : out boolean (true = ошибка, false= всё Ок).
- Сигналы
- signal tdata_mod : in std_logic - сигнал, идущий с выхода DUT;
- signal CoilModulation : out std_logic - огибающая;
HALT
HALT — перевод в состояние ожидания
- Подаёт соответствующую команду на драйвер ('50' '00' + CRC)
- Контролирует паузу между запросом и ответом
- Принимает ответ и сравнивает его с ожидаемым ответом (используя UID)
- Выдаёт ошибку (Error=true), если
- Пауза не соответствует спецификации
- Ошибка в данных ответа
Интерфейс:
- Входы
- —
- Выходы
- Error : out boolean (true = ошибка, false= всё Ок).
- Сигналы
- signal tdata_mod : in std_logic - сигнал, идущий с выхода DUT;
- signal CoilModulation : out std_logic - огибающая;
WRITE
WRITE — запись
- Подаёт соответствующую команду на драйвер (вычисляет код команды, добавляет CRC)
- Контролирует паузу между запросом и ответом
- Принимает ответ и сравнивает его с ожидаемым ответом (используя UID)
- Выдаёт ошибку (Error=true), если
- Пауза не соответствует спецификации
- Ошибка в данных ответа
Интерфейс:
- Входы
- Arg : in natural - аргумент (0х20-0х67)
- Data : in integer_vector(4 downto 1) — 4 байта
- Выходы
- Error : out boolean (true = ошибка, false= всё Ок).
- Сигналы
- signal tdata_mod : in std_logic - сигнал, идущий с выхода DUT;
- signal CoilModulation : out std_logic - огибающая;
COMPATIBILITY WRITE
COMPATIBILITY WRITE — совместимая запись
- Подаёт первую часть команды на драйвер (вычисляет код команды, добавляет CRC)
- Контролирует паузу между запросом и ответом
- Подаёт вторую часть команды на драйвер (вычисляет код команды, добавляет CRC)
- Контролирует паузу между запросом и ответом
- Принимает ответ и сравнивает его с ожидаемым ответом (используя UID)
- Выдаёт ошибку (Error=true), если
- Пауза не соответствует спецификации
- Ошибка в данных ответа
Интерфейс:
- Входы
- Arg : in natural - адрес (0-15)
- Data : in integer_vector(4 downto 1) — 4 байта
- Выходы
- Error : out boolean (true = ошибка, false= всё Ок).
- Сигналы
- signal tdata_mod : in std_logic - сигнал, идущий с выхода DUT;
- signal CoilModulation : out std_logic - огибающая;