网站首页 > 技术文章 正文
阻塞赋值和非阻塞赋值在可综合的代码中不需要严格的区分,但是在仿真文件中就尤为重要。阻塞赋值是指,只有当前的赋值操作完成之后,后面的赋值操作才会发生;非阻塞赋值是指,当前块中的所有赋值操作完成后再计算各个变量的值,后续的赋值操作会覆盖之前的值。举个例子。
a、b和c的值分别为a=1, b=2, c=3。
a=b;
a=c;
b=a;
以上操作后,a的值为c,b的值为3。其过程是,a=b时,a的值被修改为2后才开始执行a=c;a=c执行后,a的值已经变成3,然后才开始执行b=a;执行b=a时,a的值已经为3,所以b的值为3。如果改为非阻塞赋值:
a<=b;
a<=c;
b<=a;
上述操作后,a的值为3,b的值为1,c的值为3。其过程是,a首先被赋值为b,接着a被赋值为c。上述过程之后最后一个对a的赋值有效。因为非阻塞赋值就像他的名字,不会等到a<=b结束后才执行a<=c,而是畅通无阻地向下执行,所以只有最后一个赋值是有效的。b<=a执行时,a还是1。只有当上述操作所在地块结束后,每个变量才会被赋值。
非阻塞赋值的行为也可以简单描述为:赋值语句块中,对同一个变量的赋值以最后一次赋值为准;当前赋值语句块结束之前,所有变量都保持原有的值;当赋值语句块结束时,所有变量被同时赋值。如a=1, b=2, c=3:
always @ (posedge clk) begin
a<=b;
a<=c;
a<=4'hf;
b<=a;
c<=b;
end
执行完毕后,a等于4'hf,b等于1,c等于2。
以下我仿真时使用的一个task的例子。
task tk_eset_wr(
input [`ESET_ADDR_WID: 0] depth,
input logic [`ESET_WID*`ESET_DEPTH-1: 0] data
);
localparam FACTOR = `ESET_WID / `REG_WID;
automatic reg [`ESET_WID*`ESET_DEPTH-1: 0] data_tmp=0;
mem_sel = 0;
mem_rst = 1'b1;
#(PERIOD*2) mem_rst = 1'b0;
repeat (`CH_PER_SUB) begin
data_tmp = data;
repeat (depth) begin
repeat (FACTOR) begin
@(posedge clk);
mem_wr = 1'b1;
mem_data = data_tmp[`ESET_WID*`ESET_DEPTH-1: `ESET_WID*`ESET_DEPTH-`REG_WID];
data_tmp = {data_tmp[`ESET_WID*`ESET_DEPTH-`REG_WID-1: 0], {`REG_WID{1'b0}} };
end
@(posedge clk);
mem_wr = 1'b0;
end
mem_sel++;
end
mem_wr <= 1'b0;
endtask : tk_eset_wr
上例中,task中没有延时控制语句,是阻塞赋值保证了data_temp的向左移位。mem_data = data_tmp[`TSET_MAP_WID*16-1: `TSET_MAP_WID*16-`REG_WID];首先将data_temp的一个段赋值给mem_data,只有当该赋值结束后,data_tmp的向左移位才会发生。
————————————————
版权声明:本文为CSDN博主「小苍蝇别闹」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yinyeyy/article/details/105605974
猜你喜欢
- 2024-10-25 什么是喉梗阻 反流性食管炎嗓子疼怎么办
- 2024-10-25 阻塞列队详解!让你轻松理解阻塞列队
- 2024-10-25 【健康科普】认识阻塞性睡眠呼吸暂停低通气综合征
- 2024-10-25 气象科普|阻塞高压为何方神圣?后期它将给我国制造多轮冷空气
- 2024-10-25 非阻塞算法CAS 非阻塞函数
- 2024-10-25 为什么网络 I/O 会被阻塞?I/O 到底是什么?
- 2024-10-25 如何用Java设计阻塞队列,再说说ArrayBlocking和LinkedBlocking
- 2024-10-25 使用 Python Socket 实现非阻塞 I/O入门讲解
- 2024-10-25 梗阻性无精子症:多种选择,何为最佳?
- 2024-10-25 焦耳小偷 一个神奇的电路 焦耳小偷电路需要注意的地方
你 发表评论:
欢迎- 最近发表
-
- 吴谨言专访大反转!痛批耍大牌后竟翻红,六公主七连发力显真诚
- 港股2月28日物业股涨幅榜:CHINAOVSPPT涨1.72%位居首位
- 港股2月28日物业股午盘:CHINAOVSPPT涨1.72%位居首位
- 港股3月2日物业股涨幅榜:CHINAOVSPPT涨1.03%位居首位
- 港股3月2日物业股午盘:CHINAOVSPPT涨1.03%
- 天赋与心痛的背后:邓鸣贺成长悲剧引发的深刻反思
- 冯小刚女儿徐朵追星范丞丞 同框合照曝光惹人羡,回应网友尽显亲民
- “资本大佬”王冉:51岁娶小17岁童瑶,并承诺余生为娇妻保驾护航
- 港股3月2日物业股午盘:CHINAOVSPPT涨1.03%位居首位
- 「IT之家开箱」vivo S15 图赏:双镜云窗,盛夏风光
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)