## Lab-2 矩阵乘法的 VerilogHDL 代码描述

一、题目 请使用 VerilogHDL 描述一个矩阵乘法 RTL 代码及其 testbench,需要满足以下功能:



- 从矩阵 a 中取 data\_in1,从矩阵 b 中取 data\_in2,完成两个矩阵相乘并将计算结果 data\_out 写入矩阵 c:
- 矩阵 a、b、c 规模均为 2×2, 三个矩阵均<mark>必须</mark>调用真<mark>双端口 SRAM IP</mark>完成;
- data 数据位宽为 16bit, 无符号数;
- 矩阵 a、b 的取数为时序电路形式,需花费 1 个时钟周期;
- 矩阵相乘结果以时序形式写入矩阵 c, 计算需花费 1 个时钟周期。
- 矩阵 a、b 中存放的数值均由 testbench 写入,数据可来自 txt,也可在 testbench 中指定,但必须支持数据更改,不可以直接在 RTL 代码中写固定数值;
- 矩阵 c 中的计算结果可以通过 testbench 写入 txt 中;
- 可使用状态机,也可以不使用,根据同学们自己习惯进行设计。
- 注意:三个存储器的分别使用三个时钟,建议在 testbench 中将时钟、相位等设为全部相同
- 代码必须可综合

## 1、RTL接口如下表所示(仅供参考,可根据实际情况进行更改):

| 引脚名称       | I/O | 位宽 | 功能说明                   |       |
|------------|-----|----|------------------------|-------|
| rst_n      | I   | 1  | 全局复位信号,低电平复位           |       |
| clk_a      | I   | 1  | 时钟 a                   |       |
| en_a       | I   | 1  | 使能信号 a,高电平工作           | 存储器 a |
| wea        | I   | 1  | 读写使用 a, 高电平使能写; 低电平使能读 | 的相关端  |
| addra      | I   | 8  | 地址 a                   |       |
| data_in_a  | I   | 16 | 数据输入端口 a               | Н     |
| data_out_a | О   | 16 | 数据输出端口 a               |       |
| clk_b      | I   | 1  | 时钟 b                   | 存储器b  |
| en_b       | I   | 1  | 使能信号 b, 高电平工作          | 的相关端  |
| web        | I   | 1  | 读写使用 b, 高电平使能写; 低电平使能读 |       |

| addrb      | I | 8  | 地址 b                   |                 |
|------------|---|----|------------------------|-----------------|
| data_in_b  | I | 16 | 数据输入端口 b               |                 |
| data_out_a | О | 16 | 数据输出端口 b               |                 |
| clk_c      | I | 1  | 时钟 c                   |                 |
| en_c       | I | 1  | 使能信号 c, 高电平工作          | 方/ <b>地</b> 思 . |
| wec        | I | 1  | 读写使用 c, 高电平使能写; 低电平使能读 | 存储器 c 的相关端      |
| addrc      | I | 8  | 地址 c                   |                 |
| data_in_c  | I | 16 | 数据输入端口 c               | Н               |
| data_out_c | О | 16 | 数据输出端口 c               |                 |

## 二、随堂验收

- 完成 RTL、testbench 代码。
- 实现上述要求的功能