/MCDF

multi-channel data formatter

Primary LanguageVerilog

MCDF Specificion

multi-channel data formatter ##功能描述 多通道数据整形器(MCDF,multi-channel data formatter),它可以将上行(uplink)多个通道数据经过内部的FIFO,最终以数据包(data packet)的形式送出。用于处理上行数据和下行数据的接口协议不同,此外多通道数据整形器也有寄存器的读写接口,可以支持更多的控制功能。

##设计结构 从上图的MCDF的结构来看主要可以分为如下几个部分: 上行数据的通道从端(Channel Slave),负责接收上行数据,并且存储到与之对应的FIFO中。 仲裁器(Arbiter)可以选择从不同的FIFO中读取数据,进而将数据进一步传送至整形器(formatter)。 整形器(Formatter)将数据按照一定的接口时序送出至下行接收端。 控制寄存器(Control Registers)有专用的寄存器读写接口,负责接收命令并且对MCDF的功能做出修改。详细的寄存器描述在后面的寄存器描述部分。

###接口描述 ####系统信号接口 CLK(0):时钟信号。 RSTN(0):复位信号,低位有效。

####通道从端接口 CHx_DATA(31:0):通道数据输入。 CHx_VALID(0):通道数据有效标志信号,高位有效。 CHx_READY(0):通道数据接收信号,高位表示接收成功。

####整形器接口 FMT_CHID(1:0):整形数据包的通道ID号。 FMT_LENGTH(4:0):整形数据包长度信号。 FMT_REQ(0):整形数据包发送请求。 FMT_GRANT(0):整形数据包被允许发送的接受标示。 FMT_DATA(31:0):数据输出端口。 FMT_START(0):数据包起始标示。 FMT_END(0):数据包结束标示。

####控制寄存器接口 CMD(1:0):寄存器读写命令。 CMD_ADDR(7:0):寄存器地址。 CMD_DATA_IN(31:0):寄存器写入数据。 CMD_DATA_OUT(31:0):寄存器读出数据。

####接口时序 通道从端接口时序

当valid为高时,表示要写入数据。如果该时钟周期ready为高,则表示已经将数据写入;如果该时钟周期ready为低,则需要等到ready为高的时钟周期才可以成功将数据写入。

####整形器接口时序

整形器发送数据是按照数据包的形式发送的,可以选择数据包的长度有4、8、16和32。整形器必须完整发送完某一个通道的数据包,才可以转而准备发送下一个数据包,在发送数据包期间,fmd_chid和fmt_length应该保持不变,直到数据包发送完毕。

在整形器准备发送数据包时,首先应该将fmd_req置为高,同时等到接收端的fmt_grant。当fmd_grant变为高时,应该在下一个周期将fmt_req置为低。fmt_start也必须在接收到fmt_grant高有效的下一个时钟被置为高,且需要维持一个时钟周期,即一个时钟周期的脉冲信号。

在fmt_start被置为高有效的同一个周期,数据也同时传送,数据之间不允许有空闲周期,即应该连续发送数据,直到发送完最后一个数据,同时,fmd_end也应当被置为高,且保持一个时钟周期。

而相邻的数据包之间应该保持至少一个时钟周期的空闲,即fmd_end脉冲回复为低以后,至少需要经过一个时钟周期,fmd_req才可以被再次置为高。

####控制寄存器接口时序

控制寄存器接口上首先需要在每一个时钟解析cmd,当cmd为写指令时,即需要把数据cmd_data_in写入到cmd_addr对应的寄存器中;当cmd为读指令时,即需要从cmd_addr对应的寄存器中读取数据,在下一个周期,cmd_addr对应的寄存器数据被输送至cmd_data_out接口。

###寄存器描述

####地址0x00 通道1控制寄存器 32bits 读写寄存器 bit(0):通道使能信号。1为打开,0位关闭。复位值为1。 bit(2:1):优先级。0为最高,3为最低。复位值为3。 bit(5:3):数据包长度,解码对应表为, 0对应长度4, 1对应长度8,2对应长度16,3对应长度32,其它数值(4-7)均暂时对应长度32。复位值为0。 bit(31:6):保留位,无法写入。复位值为0。

####地址0x04 通道2控制寄存器 32bits 读写寄存器 同通道1控制寄存器描述。

####地址0x08 通道3控制寄存器 32bits 读写寄存器 同通道1控制寄存器描述。

####地址0x10 通道1状态寄存器 32bits 只读寄存器 bit(7:0):上行数据从端FIFO的可写余量,同FIFO的数据余量保持同步变化。复位值为FIFO的深度数。 bit(31:8):保留位,复位值为0。

####地址0x14 通道2状态寄存器 32bits 只读寄存器 同通道1状态寄存器描述。

####地址0x18 通道3状态寄存器 32bits 只读寄存器 同通道1状态寄存器描述。