当前位置: 首页 > article >正文

fpga系列 HDL:verilog 常见错误与注意事项 quartus13 bug 初始失效 reg *** = 1;

代码

  • 顶层模块
module bug(
	input wire clk,
	output wire BitOut
);

	reg BitIn = 1;
    
    Encoder encoder (
		 .clk(clk),
       .BitIn(BitIn),
       .BitOut(BitOut) 
    );
endmodule
  • 内部逻辑模块
module Encoder(
	input wire clk,
	input wire BitIn,
   output reg BitOut  
);
    always @(posedge clk) begin
        if (BitIn)
            BitOut <= 1'b1;  
        else
            BitOut <= 1'b0;
    end
endmodule

quartus13 综合结果

  • 在quartus13中综合得到的BitIn为0:
    在这里插入图片描述

quartus18 综合结果

在这里插入图片描述

修改方法

module bug(
    input wire clk,
    output wire BitOut
);

    reg BitIn;  
    // 不给 BitIn 初始值,而是通过时序逻辑赋值。(或者用wire BitIn=1;)
    always @(posedge clk) begin
        BitIn <= 1; 
    end

    Encoder encoder (
        .clk(clk),
        .BitIn(BitIn),
        .BitOut(BitOut)
    );
    
endmodule

http://www.kler.cn/a/519715.html

相关文章:

  • PyCharm接入DeepSeek实现AI编程
  • 【Linux】IPC:匿名管道、命名管道、共享内存
  • 八股文 (一)
  • HTML从入门到精通:链接与图像标签全解析
  • 类与对象(下)
  • 单片机基础模块学习——按键
  • Solon Cloud Gateway 开发:Helloword
  • HTMLCSS :下雪了
  • Kafka运维宝典 (四)- Kafka 常用命令介绍
  • Vue.js 传递路由参数和查询参数
  • 传输层协议TCP与UDP:深入解析与对比
  • 「 机器人 」利用冲程对称性调节实现仿生飞行器姿态与方向控制
  • Formality:时序变换(四)(寄存器合并)
  • React将props传递给一个组件
  • 设计模式Python版 抽象工厂模式
  • sqlzoo答案4:SELECT within SELECT Tutorial
  • 【Leetcode刷题记录】15.三数之和
  • 【2024年华为OD机试】(A卷,200分)- 农场施肥 (JavaScriptJava PythonC/C++)
  • 2025年美赛(MCM/ICM)赛题浅析——助攻快速选题
  • 小智 AI 聊天机器人
  • Python读写各类数据文件
  • 学习数据结构(1)算法复杂度
  • JavaScript系列(44)--微服务架构实现详解
  • 【25考研】中科院软件考研复试难度分析!
  • leetcode 1358. 包含所有三种字符的子字符串数目
  • 【PostgreSQL内核学习 —— (WindowAgg(一))】