# GearBox\_24\_32 使用说明

#### 前言

GearBox变速箱,这里指的是RTL里非整数的位宽转换模块。本模块将24bit的信号(带使能)转换到32bit(带使能)。因为是低位宽转高位宽,可以在同一个时钟域下完成转换,只不过输入与输出的使能占比不同。如果想要输出也是连续的流,可以在后面加一个异步fifo或RAM整流。

### 数据传输结构

数据的输入输出关系如下图所示。

data\_in[23:0]

| A2 | B2 | C2 | D2 | E2 | F2 | G2 | H2 |
|----|----|----|----|----|----|----|----|
| A1 | B1 | C1 | D1 | E1 | F1 | G1 | H1 |
| A0 | В0 | C0 | D0 | E0 | F0 | G0 | Н0 |

data\_temp[47:0]

| B2 | C2 | D2 | E2 | F2 | G2 | H2 |
|----|----|----|----|----|----|----|
| B1 | C1 | D1 | E1 | F1 | G1 | H1 |
| В0 | C0 | D0 | E0 | F0 | G0 | H0 |
| A2 | B2 | C2 | D2 | E2 | F2 | G2 |
| A1 | B1 | C1 | D1 | E1 | F1 | G1 |
| A0 | В0 | C0 | D0 | E0 | F0 | G0 |

data\_out[31:0]

| В0 | C1 | D2 |
|----|----|----|
| A2 | C0 | D1 |
| A1 | B2 | D0 |
| Α0 | B1 | C2 |

| F0 | G1 | H2 |
|----|----|----|
| E2 | G0 | H1 |
| E1 | F2 | Н0 |
| E0 | F1 | G2 |

### 输入连续时序图

随着数据输入的信号有data\_en和data\_in\_last。data\_en代表当前clock数据有效,data\_in\_last为行结束信号,高电平代表一行的数据传输结束,并且会重置内部计数器,内部计数器的作用为判断当前data\_in为输入的哪一个相位。



正常来讲,每4个输入就会有3个输出,当然data\_in\_last允许出现在数据比例异常的情况。也就是说最后一组数据只有1/2/3个输入,输出会有1/2/3个(只不过最后一个clock的数据不是占满32bit,不满的时候高位补0。虽然可以设置mask信号来作为byte的使能,但是这无疑增加了模块的复杂性,尤其是考虑数据传输中间的某一个clock出现mask没有全部使能的情况)。具体的输入输出关系可以参考下面的时序图。

下图为data\_in\_last出现在第1相位:



#### 下图为data in last出现在第2相位:



#### 下图为data\_in\_last出现在第3相位:



## 输入断续的时序图

当然,更进一步的是本模块可以支持输入使能断续的转换,每个相位之间的clock间隔可以不等(比如第一相位和第二相位间隔2个clock,第二相位和第三相位间隔3个clock)。

下图为输入断续下data\_in\_last出现在第0相位:



断续输入的data\_in\_last出现在其他相位的时序图就不再赘述,读者可以推断。