Контроль передачи

Version 2 (Dmitry Smekhov, 02/27/2012 12:39 am)

1 1
h1. Контроль передачи
2 1
3 1
Надёжность передачи данных обеспечивают компоненты *prq_link_out* и *prq_link_in*
4 1
5 2 Dmitry Smekhov
Компонент *prq_link_out* содержит память для четырёх пакетов по 256 слов. Сигнал *tx_ready* разрешает запись пакета в память. Для записи пакета надо выставить *tx_data_title* - заголовок пакета. *tx_data* и *tx_data_we* - данные пакета - от 1 до 256 слов, *tx_data_eof* - конец пакета. После получения *tx_data_eof* блок памяти помечается как занятый. Блок будет помечен как свободный, только после прихода подтверждения о доставке пакета. Может быть записан пакет меньшей длины чем 256 слов, но передаются всегда пакеты длиной 256 слов.
6 1
7 1
Процесс *pr_stp* проверяет блоки данных на занятость. Если блок содержит пакет для передачи, то он передаётся. Если нет, то проверяется следующий блок. Возможна ситуация, когда будет заполнен только один блок данных. В этом случае он будет передан несколько раз до момента прихода подтверждения. Если заполнено два или больше блоков, то подтверждение должно успеть прийти в процессе передачи следующих блоков и повторной отправки пакета не произойдёт.
8 2 Dmitry Smekhov
9 2 Dmitry Smekhov
Сигнал *buf_empty( 3 downto 0 )* это флаги занятости блоков данных. Значение 1 - блок занят.
10 2 Dmitry Smekhov
Сигнал *flag_even( 3 downto 0 )* это флаг чётный/нечётный пакет. Он передаётся в бите *PKG_EVEN* слова команды.
11 2 Dmitry Smekhov
12 2 Dmitry Smekhov
Компонент *prq_link_in* также содержит память для четырёх пакетов по 256 слов. Принимаемый пакет записывается в память при выполнении следующих условий:
13 2 Dmitry Smekhov
* правильная контрольная сумма CRC1
14 2 Dmitry Smekhov
* правильная сигнатура: SIG=0x0B
15 2 Dmitry Smekhov
* пакет содержит данные: SOF=1
16 2 Dmitry Smekhov
* блок данных BUF_NUM свободен для записи
17 2 Dmitry Smekhov
* поле *PKG_EVEN* совпадает с ожидаемым для данного блока
18 2 Dmitry Smekhov
19 2 Dmitry Smekhov
Если процесс приёма данных завершается с сигналом *rx2link.pkg_good*=1, то блок данных помечается как содержащий данные.
20 2 Dmitry Smekhov
21 2 Dmitry Smekhov
Процесс *pr_stp_ready* анализирует флаг блока, если он содержит данные, то выставляется сигнал *rx_ready*=1. По этому сигналу данные должны быть прочитаны, после чтения пакета должен быть выставлен *rx_data_eof*=1, это помечает блок как свободный для записи, меняет ожидаемое значение *PKG_EVEN* и формирует подтверждение приёма блока данных.