在夏老师书上看到两个例子,没明白,请教网友下:
1:
always@(a or b)
case(a)
1'b0: f=b;
1'b1: g=b;
endcase
书上说这段程序被综合后会和预先设想的不一致,怎么回事?
2:
always@(posedge clk or negedge rst)
if(rst)
a<=1'b0;
else
a<=b;
书上说此段程序产生了异步逻辑,没看懂
第二个好理解
always@(posedge clk or negedge rst)
if(rst)
a<=1'b0;
else
a<=b;
是异步复位的。
第一个
always@(a or b)
case(a)
1'b0: f=b;
1'b1: g=b;
endcase
是个分配器,a是选择端,b是输入,f和g是两路输出
打赏帖 | |
---|---|
嵌入式LinuxC语言程序调试和宏使用技巧被打赏50分 | |
让代码中包含最新的编译时间信息被打赏50分 | |
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】mcxa156使用低功耗定时器适配硬件RTC框架被打赏26分 | |
【STM32F769】AI之与本地deepseek对接被打赏50分 | |
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 |