码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【FPGA】计数器 —— 时序逻辑


    小边想要日更!盲猜明天就会断hh,因为明晚我应该在疯狂看计网。。

    文章目录

    • 1. 设计输入
    • 2. 功能仿真
    • 3. 板子调试

    • 时序逻辑基本概念:输出还与时钟信号相关

      • D触发器 - 也就是有“记忆”特性,能存储电平状态

        image-20220918164451433
    • 计数器基本概念,基本4位加法器结构图

    • 计数值与技术时间之间的关系

    1. 设计输入

    设计一个以每隔1s闪烁的LED灯(亮灭各500ms)

    image-20220919193029125

    CK在一般系统中非常稳定50MHz —— 一周期20ns

    那~ 就+(500ms/20ns) = 25*10^6次 这要多少位计数器呢?

    image-20220919185529979

    计数器核心代码 ——

    module ledfash (
        //端口
        Clk,
        Reset_n, //复位
        Led
    );
        //端口定义
        input Clk;
        input Reset_n;
        output reg Led;
        
        reg[24:0] counter;
        
        always@(posedge Clk or negedge Reset_n)
        if(!Reset_n) begin
            counter <= 0;
            Led <=0;
            end
        else if(counter == 24999999) begin
            Led <= !Led;
            counter <= 0;
            end
        else     
            counter <= counter + 1'd1;
    endmodule
    

    学习新语法,争做新青年

    • posedge clk这是时序逻辑描述的标准模式

      • poseedge时钟上升沿作为敏感信号
      • negedge时钟下降沿到来会会工作
    • <= 是非阻塞赋值,你暂且理解为=,下篇blog详谈

    • Led 要在 always块中赋值,需要定义为reg型,否则会爆红

    • 两条语句用begin-end括起来,作用相当于{}

    • 24999999: 0-1,1-2 … 24999999-0

    推荐分开写,有利于综合器分析 ——

        always@(posedge Clk or negedge Reset_n)
        if(!Reset_n) 
            counter <= 0;
    	else if(counter == 24999999) 
            counter <= 0;
        else     
            counter <= counter + 1'd1;
            
        always@(posedge Clk or negedge Reset_n)
        if(!Reset_n) 
            Led <=0;
    else if(counter == 24999999) 
            Led <= !Led;
    

    分析综合~ 嗯嗯,没啥错误

    2. 功能仿真

    `timescale 1ns/1ns
    
    module led_flash_tb();
        //激励信号
        reg Clk;
        reg Reset_n;
        wire Led;
        
    led_flash led_flash_inst(
        //连线
        .Clk(Clk),
        .Reset_n(Reset_n), 
        .Led(Led)
    );
    
        initial Clk = 1;
        always #10 Clk = !Clk; //每延时10s,翻转
        
        initial begin
            Reset_n = 0;
            #201;
            Reset_n = 1;
            #2000000000;
            $stop;
        end
    endmodule
    
    image-20220919200116979

    3. 板子调试

    管脚约束

    image-20220919200940958

    ctrl + s → Generate bitstream

    Okk啦~

  • 相关阅读:
    Java版工程行业管理系统源码-专业的工程管理软件- 工程项目各模块及其功能点清单
    企业微信机器人还能这么玩?
    《研发效能(DevOps)工程师(中级)认证》证书查询方式和路径丨IDCF
    孩子没有感统失调的表现,还有必要做感统训练吗?
    机器人编程初学者教程书:开启智能之旅的全方位指南
    风电场统计数据名词
    小鼠与人类ID转换
    自定义 C++ 和 CUDA 扩展
    linux系统常用命令
    java中常用的集合
  • 原文地址:https://blog.csdn.net/qq_54851255/article/details/126941185
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号