2955|2

172

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

vrilog下,有什么办法可以简便地对相同的模块赋不同的初值? [复制链接]

需要做一个含24个计数器的小应用,每个计数器的结构是一样的,但是初始值不相同,有什么办法可以简便地对相同的模块赋不同的初值?
parameter可以作为模块的输入吗??

module CPS_PWM(CLK,Uref,PWM);
        parameter counter_limit = 1000000;
        parameter Dir1 = 0, Dir2 = 0, Dir3 = 1, Dir4 = 1, Dir5 = 0, Dir6 = 1, Dir7 = 1, Dir8 = 0;
       
        input CLK;
        input[15:0] Uref;
        output[7:0] PWM;
        wire[15:0] C1,C2,C3,C4;//P arm CPS
        wire[15:0] C5,C6,C7,C8;//N arm CPS       
       
        UD_Counter UD1(CLK,Dir1,C1,0,Dir1);
        UD_Counter UD2(CLK,Dir2,C2,(counter_limit/2)/2,Dir2);
        UD_Counter UD3(CLK,Dir3,C3,(counter_limit/2),Dir3);
        UD_Counter UD4(CLK,Dir4,C4,(counter_limit/2)*3/2,Dir4);
       
        UD_Counter UD5(CLK,Dir5,C5,(counter_limit/2)/4,Dir5);
        UD_Counter UD6(CLK,Dir6,C6,(counter_limit/2)*3/4,Dir6);
        UD_Counter UD7(CLK,Dir7,C7,(counter_limit/2)*5/4,Dir7);
        UD_Counter UD8(CLK,Dir8,C8,(counter_limit/2)*7/4,Dir8);

       
endmodule

module UD_Counter(CLK,Dir,Counter_ini,Dir_ini);
        input CLK;
        reg Dir;
        reg[15:0] Counter;
       
        initial
        begin
                Counter = Counter_ini;
                Dir = Dir_ini;
        end
       
        always@ (posedge CLK)
        begin
                if(Dir == 0)
                        Counter = Counter + 1;
                else
                        Counter = Counter - 1;
        end
endmodule


此帖出自FPGA/CPLD论坛

最新回复

可以参考一下这篇帖子https://bbs.eeworld.com.cn/thread-475866-1-1.html  详情 回复 发表于 2017-6-24 11:22
点赞 关注
 

回复
举报

6423

帖子

17

TA的资源

版主

沙发
 
可以参考一下这篇帖子https://bbs.eeworld.com.cn/thread-475866-1-1.html
此帖出自FPGA/CPLD论坛

点评

谢谢  详情 回复 发表于 2017-6-25 21:16
个人签名training
 
 

回复

172

帖子

0

TA的资源

一粒金砂(中级)

板凳
 
白丁 发表于 2017-6-24 11:22
可以参考一下这篇帖子https://bbs.eeworld.com.cn/thread-475866-1-1.html

谢谢
此帖出自FPGA/CPLD论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表