码迷,mamicode.com
首页 > 其他好文 > 详细

jchdl - RTL实例 - Adder4Carry

时间:2018-11-09 13:51:16      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:img   auth   ros   建模   car   lan   col   技术分享   http   

https://mp.weixin.qq.com/s/j4zLmjKgau2vRXVNfm0SIA

 
带进位的加法。
 
参考链接
 
1.创建Adder4Carry.java, 并生成构造方法和logic()方法
 
2. 根据逻辑原理,添加输入输出接口
?技术分享图片?
输入输出线作为类成员存在。使用注解标明是input port还是output port。
 
3. 在构造方法中搜集输入输出线并调用construct()方法(可以直接根据输入输出接口,生成该构造函数)
?技术分享图片?
首先调用父类即Module类的构造方法,以构建模块hierarchy。
然后逐个把输入输出参数与input/output port对应上。
然后调用construct()方法构造模块(调用一次logic()方法,搜集模块的assign/always代码块、子模块)。
 
4. 在logic()方法中创建assign/always代码块,以及子模块
?技术分享图片?
这里包含一个assign代码块:当发生a, b,cin的变化事件时,执行lambda表达式的方法,以更新cout, s的值。
 
这里使用了concat组合,因为cout为Bit类型,而Bit类型为基本类型,较为简单。所以先转换为Bits然后再行与其他线组合。
 
可以将cout, cin声明为Bits类型,但宽度为1,这样写起来较为简单。
?技术分享图片?
 
5. 创建inst静态方法方便后续使用
 
6. 创建main方法执行验证
?技术分享图片?
运行结果为:
?技术分享图片?
 
7. 生成Verilog
生成定制化模块名:
 
调用toVerilog()方法生成Verilog实现。
 
执行结果如下:
 
?技术分享图片?

jchdl - RTL实例 - Adder4Carry

标签:img   auth   ros   建模   car   lan   col   技术分享   http   

原文地址:https://www.cnblogs.com/wjcdx/p/9934541.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!