FPGA|Verilog-SPI驱动

最近准备蓝桥杯FPGA的竞赛,因为感觉官方出的IIC的驱动代码思路非常好,写的内容非常有逻辑并且规范。也想学习一下SPI的协议,所以准备自己照着写一下。直到我打开他们给出的SPI底层驱动,我整个人傻眼了,我只能说,嗯,这个SPI驱动和之前的IIC驱动一定不是一个人写的,本次给出的SPI驱动真的太差劲了,我虽然按照他的思路写了,但是感觉写下来非常难受,还是咬牙坚持下来了,下面我们就来分析一下官方给的SPI的驱动代码的不足之处:

  1. 状态机的设置非常不合理

  2. 使用两段式状态机,组合逻辑里面竟然使用非阻塞赋值...这是最低级的错误了(在图片中展示了)

  3. 时钟分频不准确(放入图片)

    虽然始终不精确,50分频变为52,但是因为差的不多,不太影响通信

  4. 状态机设置转换条件不明确

    第一眼看都不知道怎么个转换关系

全部代码:

通过网盘分享的文件:spi_master.v

链接: https://pan.baidu.com/s/1riRYdltzmhM4Uz5GDlOCng?pwd=a77h 提取码: a77h

--来自百度网盘超级会员v8的分享

总结

虽然能够运行,但是官方给的代码质量确实太低了

相关推荐
博览鸿蒙3 小时前
FPGA 设计全流程科普,要用到的开发工具有哪些?
fpga开发
雨洛lhw6 小时前
相位可调分频器实现精准时钟同步
fpga开发·时间同步·时钟分频·相位可调
碎碎思14 小时前
KRS(Kratos Robotics Stack):让 Zynq / FPGA 机器人开发真正“跑”起来
fpga开发·机器人
Terasic友晶科技16 小时前
Altera FPGA 的 Avalon MM总线接口规范介绍(精简版)
fpga开发·接口·sopc·avalon总线
啊阿狸不会拉杆16 小时前
《数字信号处理》第10章-数字信号处理中的有限字长效应
算法·matlab·fpga开发·信号处理·数字信号处理·dsp
代码无bug抓狂人16 小时前
(蓝桥杯省B)R格式
c语言·蓝桥杯
雨洛lhw1 天前
24bit AD采样高效数据打包方案解析
fpga开发·数据打包方式·ddr突发读写注意事项
XiaoChaoZhiNeng1 天前
Xilinx Vivado18.3 Modelsim 库编译与仿真
fpga开发
llz_1122 天前
16届蓝桥杯B组 C++题解
c++·算法·蓝桥杯
Flamingˢ2 天前
FPGA 显示系统学习路线:从 VGA 到 RGB TFT
学习·fpga开发