在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 8295|回复: 19

[讨论] always的敏感信号是clk,描述语句中可以是“="的赋值语句吗?

[复制链接]
发表于 2012-12-11 21:12:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
本帖最后由 frankjintao 于 2012-12-11 21:16 编辑

DE1的开发板有个LED灯控PWM IP核实验。在PWM核中,有个always的敏感信号是psedge CLK时,描述语句中的左边的寄存器被“="赋值成什么电路?而且该描述语句怎么可以用"="给左边的寄存器赋值呢。按照常理来说,如果敏感信号一般是输入电平信号,描述语句应该采用“=”语句的呀?如果敏感信号是CLK,应该用"<="赋值。哪位大侠能解释下。以下是程序
module pwn(clk,
           reset_n,
           chipselect,
           address,
           write,
           writedata,
           read,
           byteenable,
           readdata,
           PWM_out);
input clk;
input reset_n;
input chipselect;
input [1:0]address;
input write;
input [31:0] writedata;
input read;
input [3:0] byteenable;
output [31:0] readdata;
output PWM_out;
reg [31:0] clock_divide_reg; //Internal register  clock divide
reg [31:0] duty_cycle_reg; //Internal register ;the clock less than duty_cycle_reg pwm_out will be output 1.otherwise will be 0
reg control_reg;
reg clock_divide_reg_selected;
reg duty_cycle_reg_selected;
reg control_reg_selected;
reg [31:0] PWM_counter;
reg [31:0] readdata;
reg PWM_out;
wire pwm_enable;
always @ (address)
begin
   clock_divide_reg_selected<=0;
   duty_cycle_reg_selected<=0;
   control_reg_selected<=0;
   case(address)
       2'b00:clock_divide_reg_selected<=1;
       2'b01:duty_cycle_reg_selected<=1;
       2'b10:control_reg_selected<=1;
    default:
        begin
         clock_divide_reg_selected<=0;
         duty_cycle_reg_selected<=0;
         control_reg_selected<=0;
        end
   endcase
end           
always @ (posedge clk or negedge reset_n)
begin
if(reset_n==1'b0)
   clock_divide_reg=0;
else
begin
    if(write & chipselect & clock_divide_reg_selected)
    begin
      if(byteenable[0])
        clock_divide_reg[7:0]=writedata[7:0];
      if(byteenable[1])
        clock_divide_reg[15:8]=writedata[15:8];
      if(byteenable[2])
        clock_divide_reg[23:16]=writedata[23:16];
      if(byteenable[3])
        clock_divide_reg[31:24]=writedata[31:24];
    end
end
end
always @ (posedge clk or negedge reset_n)
begin
if(reset_n==1'b0)
   duty_cycle_reg=0;
else
begin
    if(write & chipselect & duty_cycle_reg_selected)
    begin
      if(byteenable[0])
        duty_cycle_reg[7:0]=writedata[7:0];
      if(byteenable[1])
        duty_cycle_reg[15:8]=writedata[15:8];
      if(byteenable[2])
        duty_cycle_reg[23:16]=writedata[23:16];
      if(byteenable[3])
        duty_cycle_reg[31:24]=writedata[31:24];
    end
end
end
always @ (posedge clk or negedge reset_n)
begin
if(reset_n==1'b0)
   control_reg=0;
else
begin
    if(write & chipselect & control_reg_selected)
    begin
      if(byteenable[0])
        control_reg=writedata[0];
    end
end
end


最后3个always中的描述语句怎么用的是”=“语句赋值。高步懂。

我知道always行为描述的2输入与门电路,等等
input a,b;
output reg  out;
alwys @(a or b)
begin out=a&b;end//不是”<=“赋值。

pwm.rar

841 Bytes, 下载次数: 3 , 下载积分: 资产 -2 信元, 下载支出 2 信元

发表于 2012-12-11 22:17:16 | 显示全部楼层
建议你去看看语法,always在描述组合逻辑的时候用‘=’,在描述时序逻辑的时候使用‘<=',你上面的代码风格不好。。
发表于 2012-12-12 00:26:01 | 显示全部楼层
同学习。。。。
 楼主| 发表于 2012-12-12 10:33:23 | 显示全部楼层
这步是我写的。这是DE1官方的开发板配套的程序pwm.v文件。我也高不懂时序电路怎么可以用“=”来描述敏感信号是时钟的行为级表述。
发表于 2012-12-12 10:35:12 | 显示全部楼层
个人代码风格问题, 不严谨
 楼主| 发表于 2012-12-12 10:41:09 | 显示全部楼层
可是综合没有出错啊。而且是官方教材配套的程序。哎,,,,,真怕这个程序以后一直误导我
发表于 2012-12-12 16:37:18 | 显示全部楼层
always块里只有一个变量赋值,不存在阻塞的问题,所以没事
发表于 2012-12-12 16:42:25 | 显示全部楼层
首要原则是阻塞和非阻塞不要混用。
其次就跟2楼说的一样了。
不是不能那么用,用了语法上肯定不会报错的。只是遵守这些规则能降低错误率
发表于 2012-12-13 10:30:32 | 显示全部楼层
7L正解。不过说实在的,代码风格确实挺恶心的。。
发表于 2012-12-13 14:24:25 | 显示全部楼层
可以这么写,但千万不要这么写。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-25 22:45 , Processed in 0.021320 second(s), 6 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表