使用ISE编译一个verilog HDL代码文档出现如下警告:
WARNING:Xst:737 - Found 8-bit latch for signal <count>. Latches may be generated from incomplete case or if statements. We do not recommend the use of latches in FPGA/CPLD designs, as they may lead to timing problems.
该文档内容如下:
module operation(
input rst_n,
input add,
input subtract,
output [7:0] q
);
reg [7:0] count;
always @ (add or subtract or rst_n)
begin
if(!rst_n)
count <= 0;
else if(!add)
count <= count + 1;
else if(!subtract)
count <= count - 1;
end
assign q = count;
endmodule
请问大虾们,这个警告怎么解决呢?先谢谢了。
共2条
1/1 1 跳转至页
额~解决了,代码修改如下:
module operation(
input clk_1M,
input rst_n,
input add,
input subtract,
output [7:0] q
);
reg [7:0] count;
always @ (posedge clk_1M or rst_n)
begin
if(!rst_n)
count <= 0;
else if(!add)
count <= count + 1;
else if(!subtract)
count <= count - 1;
end
assign q = count;
endmodule
说明:这是一个检测按键的module。我之前写成了组合逻辑电路,现改为时序逻辑电路就对了。看来需要深入了解组合逻辑电路和时序逻辑电路的语法以及应用场合。
module operation(
input clk_1M,
input rst_n,
input add,
input subtract,
output [7:0] q
);
reg [7:0] count;
always @ (posedge clk_1M or rst_n)
begin
if(!rst_n)
count <= 0;
else if(!add)
count <= count + 1;
else if(!subtract)
count <= count - 1;
end
assign q = count;
endmodule
说明:这是一个检测按键的module。我之前写成了组合逻辑电路,现改为时序逻辑电路就对了。看来需要深入了解组合逻辑电路和时序逻辑电路的语法以及应用场合。
共2条
1/1 1 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 基于ArduinoUNO开发板的AT24C02读写测试被打赏¥16元 | |
| TCS3472S传感器及其色彩检测被打赏¥19元 | |
| 【S32DS】S32K3 RTD7.0.1 HSE 组件配置报错问题解决被打赏¥27元 | |
| 【S32K3XX】MCME 启动 CORE1被打赏¥23元 | |
| AG32VH407下温度大气压传感器及其检测被打赏¥20元 | |
| AG32VH407下光照强度传感器BH1750及其检测被打赏¥22元 | |
| AT32VH407下使用温湿度传感器DHT22进行检测被打赏¥20元 | |
| DIY一个婴儿澡盆温度计被打赏¥34元 | |
| 【FreeRtos】FreeRtos+MPU region 配置规则被打赏¥23元 | |
| 【分享开发笔记,赚取电动螺丝刀】三分钟快速上手驱动墨水屏(ArduinoIDE)被打赏¥28元 | |
我要赚赏金
