## 完成SPI Verilog程序训练;

数据输入是在时钟沿的上升沿进入;

数据进来是在时钟沿的下降沿;

链接:

https://v.youku.com/v\_show/id\_XMTcwNzEzNTQyMA==.html? spm=a2h0k.11417342.soresults.dtitle

一次发送8byte;;

将数据和命令存储到RAM中去;

M9K代表 9K的RAM;

画出程序框图;

用Verilog描述,将RAM用 reg代替;

使用独热码来表示系统的状态;

BUG统计:

- 1. 独热码的状态, 要注意有多少个状态就要用多少位;
- 2. 独热码状态要不同

```
output
                                          spi sck,
33
          output
                                          spi_sdo
                                              spi_sdi
34
          //input
          );
          localparam
                                      SCK_COUNT_Half = CLK_FRE/SPI_FRE/2;
36
                                     IDLE = 5'b0_0001;
WAIT = 5'b0_0010;
READ_MEM = 5'b0_0100;
37
          localparam
          localparam
39
         localparam
                                     WRITE_REG = 5'b0_1000;
40
         localparam
41
          localparam
                                           \overline{\text{STOP}} = 5'b1 0000;
42
43
     localparam
                                    REG0 = 8'h01;
          localparam
                                       REG1 = 8'h02;
      localparam
                                      REG2 = 8'h03:
45
                                      REG3 = 8'h04;
46
         localparam
47
48
          reg [4:0]
                                     state;
49
          //FSM
51 🛱
          always @ (posedge clk_i) begin
52
            if(!rst n)
53
53
54
55
E
                  state <= IDLE;
              else begin
                 case (state)
```

3. SCK一直有输出

## 4. 状态一直在WRITE\_REG

timescale 用法: <a href="https://blog.csdn.net/super\_haifeng/article/details/50110371">https://blog.csdn.net/super\_haifeng/article/details/50110371</a>