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

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

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2924|回复: 2

[原创] 关于vhdl的信号和变量以及Verilog的阻塞和非阻塞赋值的一些思考

[复制链接]
发表于 2015-4-23 09:30:25 | 显示全部楼层 |阅读模式

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

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

x
最近在看Xilinx公司的ug687-xst-userguide,里边有这样一段程序:   signal count_r : std_logic_vector(2 downto 0) := (others => '0');
   process(a)

begin

   count_r <= "000";

   for i in 0 to 7 loop

   if (a(i) = '0') then

   count <= count + 1;

end if;

end loop;

count <= count_r;

end process;
我给仿真了一下,发现count在每次a变化的时候就加1,而不是计算a中0的个数,百思不得其解。
然后尝试将signal改为variable,如下:
   process(a)

   variable count_r : std_logic_vector(2 downto 0);

begin

   count_r := "000";

   for i in 0 to 7 loop

   if (a(i) = '0') then

   count <= count + 1;

end if;

end loop;

count <= count_r;

end process;

仿真结果正确。
这让我想到了Verilog里的阻塞和非阻塞赋值,代码如下:
   always @ (a) begin

   cnt = 0;

   //cnt <= 0;
      for(i=0;i<8;i=i+1)begin

   if(a[i] == 1'b1)begin

   cnt = cnt + 1;

   //cnt <= cnt + 1;

end

end
   end

当采用非阻塞赋值时,结果和vhdl里用信号赋值一样;
当采用阻塞赋值时,结果和vhdl里用变量赋值一样,功能正确。

Verilog里的阻塞和非阻塞赋值让很多初学者都很纠结,觉得无法理解,个人觉得这对了,连Xilinx的大神们在写文档里的程序的时候
也是随心所欲,会有考虑遗漏的时候,更何况我等初哥
无标题.png
无标题.png
 楼主| 发表于 2015-4-23 09:31:20 | 显示全部楼层
仿真图不小心插进去了,而且重复了,请见谅。
 楼主| 发表于 2015-4-23 09:41:06 | 显示全部楼层
写的有点匆忙,第二段程序有误,修改如下:
   process(a)
           variable count_r : std_logic_vector(2 downto 0);
        begin
           count_r := "000";
           for i in 0 to 7 loop
                   if (a(i) = '0') then
                           count_r := count_r + 1;
                        end if;
                end loop;
                count <= count_r;
        end process;
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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


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

GMT+8, 2024-12-23 04:36 , Processed in 0.030322 second(s), 9 queries , Gzip On, Redis On.

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