NoC路由器RTL代码
2023-04-07 16:49:37 2.27MB NoC 路由器
1
用于检测时钟频率,用一个基准50MHz时钟检测其他时钟,结果频率用10进制表示
2022-12-28 09:38:55 2KB verilog  RTL
1
iic从机RTL代码,可综合,AISC程序,已经流过片了,并在FPGA上进行了原型验证
2022-07-15 09:04:43 27KB RTL verilo
1
博文【异步FIFO的设计和功能验证】的源码,包含异步FIFO模块的RTL代码文件、Testbench 代码文件、tcl和makefile脚本文件
2022-06-13 18:46:57 9KB 异步FIFO 源码 RTL
1
最近一个项目需要做I2C的slave,在opencores.org上面找到了一个I2C的代码,不过是master的。 下载来看看,发现里面有一个I2C slave的行为级代码。 于是自己根据这个代码改写了一个I2C slave RTL的代码,并修改了原来那个设计的testbench,将rtl的Slave替换了原来的behavior的Slave,在modelsim里面作了前仿,完全通过。还有一个myram.v文件,是一个register file,和slave相连,存储数据用的。 用synplify做综合,使用x3s400-4的器件,占用LUT<100,速度接近200MHz。性能比较优化。 代码做了详尽的注释,语言采用verilog,并且写了仿真的脚本。解压了直接运行simbehav.bat就可以了。如果modelsim安装的时候注册了环境变量(path),脚本调用modelsim,输入run -all即可看到仿真结果。 虽然不是很复杂,不过对于广大需要做I2C的RTL slave的工程师来说,还是很有参考价值的。 1、 设计流程 将I2C slave的行为模型改为rtl模型。 进行等效仿真,直到波形一致,通过timing check,数据正确。 再进行rtl优化设计 2、 注意要点 a) 时钟的设计 b) 对于restart condition的时序是否正确 c) 3、 进度 a) 11-12:initial状态的bitcnt不对,需要认真比对/设计 b) 11-13:initial基本解决(sda_in的问题)。Sda三态冲突,原因不明。比对原设计 c) 11-14:sda三态冲突解决,原因为sda在初始化时没有将sda_oen赋值(由sm赋值,但是sm没有做async reset)。同时注意verilog的大小写敏感。 d) 11-15:仿真出现错误:read出来的数据非期望值。写入逻辑完全正确。Read时由于sda_oe在sm中有一个cycle_pulse的延迟,导致了mem_do[7]串行移出时错位。在更改了sm的代码风格后再研究解决方法。 e) 11-16:仿真完全匹配波形。计划:优化结构,提高稳定性sm改为每个时钟打一下。 关于I2C的SDA三态转换: Master在发送完第8个bit后随后将sda释放(posedge后大概1/4 scl周期),此时slave需要在第九个bit对应的scl的posedge拉低sda。
2022-01-06 13:20:09 201KB opencores I2C slave rtl代码
1
erilog RTL代码新手上路教程.pdf Verilog RTL代码新手上路教程.pdf (827.38 KB, 下载次数: 130 ) 2012-12-25 17:28 上传 点击文件名下载附件 【新手教程】Verilog RTL代码新手上路教程.pdf
2021-12-12 14:12:59 827KB Verilog RTL 代码 新手上路
1
现在大部分公司做数字芯片开发都需要用到Verilog,在RTL 代码即将完成时,有必要使用vcs + DVE去查看经过仿真后的CASE代码覆盖率,保证代码本身是没问题的。
2021-09-23 18:44:11 23KB regression 代码覆盖率
1
nlint 工具,做verilog 代码检查使用,支持window10 。自己一直在使用。
2021-07-23 18:03:06 72.28MB nlint window10 fpga
1
根据14443和HDLC协议编写的可综合CRC Verilog代码,可以当验证ip使用。
2021-04-24 09:40:33 2KB crc crc16 14443 hdlc
1
兼容opencores.org的I2C slave的RTL代码.7z
2021-02-03 23:22:54 133KB 兼容opencores.org的
1