0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于74HC595开发板的LED控制方法

电子设计 来源:工程师曾玲 作者:博客园 2019-10-03 13:56 次阅读

1基础理论部分

1.1分频

分频,是的,这个概念也很重要。分频是指将一单一频率信号的频率降低为原来的1/N,就叫N分频。实现分频的电路或装置称为“分频器”,如把33MHZ的信号2分频得到16.5MHZ的信号,3分频得到11MHZ的信号,10分频得到3.3MHZ的信号。

分频主要是相对于主晶振来说,用不到那么高的频率,开发板一般根据具体需要会加入晶振,一般若是功耗较高可选用50MHz,其他情况可以相对调整,如24MHz等等。那么分频的典型应用,二分频,四分频,八分频,还有任意分频。

对于分频,我们可以利用quartus ii 自带的PLL进行分频,这样会占用一定的资源,也可以利用计数器实现一定的分频,注意,FPGA中不同于其他的CPU,没有计时器的概念,只有计数器。

1.2 LED

LED(light emitting diode),发光二极管,简称LED,是一种能够将电能转化成可见光的固态的半导体器件,可以直接把电转换成光。可以用在电路及仪器中作指示灯,或者组成文字或数字显示等。有不同化合物制成的二极管如砷,镓,磷等化合物制成,不同的化合物组合会显示不同颜色的光。

在设计LED的驱动电路时,不能直接接到3.3V或者5V来点亮,LED有额定电流,超过这个额定电流,LED就会烧掉,反接也会烧掉。一般的LED的额定电流从10mA~1A不等。FPGA开发采用的LED主要是贴片0805或者0603等,额定电路一般从10mA~30mA.

1.3 74HC595

开发板上面的LED控制是用串入并出/串出的移位寄存器74HC595芯片,芯片在电路中的接入情况如图5.1所示,实物图如图5.2所示。其中MR引脚直接接高电平,不进行复位。串出引脚9不接,不进行串出引脚的使用。输出使能引脚13直接接地,手册上建议。11和12引脚分别为移位寄存器时钟输入和存储时钟输入,分别引出。

图5.1 LED部分电路图

图5.2 实物图

2 verilog代码实现部分

2.1 74HC595 控制部分

14行定义了一个全局参数WIDTH = 8,用来控制程序下面所有的有关于数量的使用。

59行和60行分别定义了时钟信号和时钟使能信号,其中时钟信号sclk时钟周期前半段为低电平,后半段为高电平,可以实现对数据的中间采样,时钟使能信号led_time可以控制数据和时钟对齐。48行的state是一个状态改变的寄存器,只要数据一更新,state就有效。

75行定义了update_input信号用来检测输入数据的变化。

状态转换部分,在case语句中先检测state的初始位,然后进入循环操作,检测update_input是否使能,使能更新state,不使能保持state,更新后开始输出位数计数器led_cnt的计数

在121到123行,对输出的三路信号进行了约束限制,这种方法值的借鉴,在用不到时不输出信号,用到时输出信号,最大量的节省时钟。Led_data_out是先从高位输出到低位。

2.2 LED数据产生部分

在模块声明处,仍旧使用全局定义变量,控制模块中常量的使用。

计数模块,产生时钟使能信号。

Reg型变量Led_out_cnt是用来控制LED变化, 每当时钟信号使能开始计数,板卡上面一共有8个LED,所以计数8个即可。

LED解码部分,通过上面的led_out_cnt信号进行解码,控制LED的流水操作。

3 modelsim验证部分

3.1 led_generate 模块仿真

43行产生时钟信号,通过PERIOD进行周期控制。49~51产生复位信号,当时钟两次下降沿后复位信号拉高。56行用来监测led_out输出的时间,生成的脚本文件如图5.3所示。

图5.3仿真波形

图5.4是利用脚本文件生成,可以观察到实现了流水功能,且时间间隔1s;

图5.4 脚本生成文件

3.2 led_74HC595 模块仿真

前半部分和上述都一样,可以作为固定部分,大家可以自行复制即可。59行到63行增加了系统输入信号初始化部分。在输入信号输入前,最好最安全就是进行一次初始化。

75行到87行是对输入进行模拟输入,并监测led_data-out信号,输出的结果如图5.5所示,由图可以看到时间间隔为120ns。

图5.6是仿真波形,可以看到时钟led_sclk每次采样在输入信号的正中间位置,最大程度保证采样可靠。

图5.5 脚本文件

图5.6 仿真波形

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • led
    led
    +关注

    关注

    240

    文章

    23100

    浏览量

    657783
  • 74HC595
    +关注

    关注

    7

    文章

    191

    浏览量

    30777
收藏 人收藏

    评论

    相关推荐

    74HC595

    74L系列芯片74HC595
    发表于 08-17 17:01

    74hc595难题。。

    本帖最后由 陈梦 于 2013-3-8 13:00 编辑 小弟初接触74hc595,想问一下如何用一个89c51和一个74hc595控制七个灯亮呢?希望各位能帮帮!!谢谢!!!
    发表于 03-08 12:59

    74HC595的工作原理是什么,怎么使用

    本系列教程以AVR单片机为对象,介绍单片机的快速开发方法。参考教材:《单片机技术及应用项目教程》 栾秋平 电子工业出版社 2019.6 第1版本文介绍74HC595的使用方法。一、认知
    发表于 11-29 08:27

    单片机IO直连控制74HC595

    最近在调74HC595,单片机IO直连控制74HC595,单片机输出3.3v, 而74HC595是5v供电。发现74HC595输出时好时坏,
    发表于 12-02 07:20

    74HC595怎么使用

    一、74HC595使用方法74HC595的数据端Q0--Q7:八位并行输出端,可以直接控制数码管的8个段。Q7:级联输出端。将它接下一个595
    发表于 12-07 06:46

    如何使用HAL 库的SPI实现74HC595芯片控制

    使用HAL 库的SPI实现74HC595芯片控制先简单看一下原理图:原理图是简单的级联方式,如图所示可用三个字节,例如:先写入第一个字节0000 0000控制的数据是右边74HC595
    发表于 12-07 07:17

    74HC595芯片的运用原理是什么

    并行输出数据三态输出(三态:低电平、高电平和高阻态)输出寄存器可以直接清除具有100MHz的移位频率能串行输出控制下一级级联芯片输出端的输出可以被保流二、74HC595的引脚说明芯片数据端说明:Q0...
    发表于 12-07 07:00

    MCU驱动74hc595方法

    MCU驱动74hc595下图关于595数据手册上的介绍,使用比较简单两片级联控制扩展IO输出端口,可以用最少三个GPIO控制16路输出单片机驱动59
    发表于 02-08 06:04

    基于74HC595的串行数码管显示实验

    今天学习小王子开发板基于74HC595串行数码管显示实验基于74HC595串行数码管显示实验1 认识74HC595串行数码2 了解锁存脉冲信号【RCLK】和时钟脉冲信号【SCLK】锁存
    发表于 03-01 06:34

    利用74HC595实现多位LED显示的新方法

            本文介绍了应用移位寄存器芯片74HC595 实现LED 动、静态显示的基本原理。提出了一种用74HC595 实现多位
    发表于 09-09 08:39 349次下载

    74hc595应用电路

    74hc595应用电路
    发表于 01-12 00:04 3705次阅读
    <b class='flag-5'>74hc595</b>应用电路

    74HC595驱动8个LED电路

    74HC595驱动8个LED电路
    发表于 02-25 15:43 7945次阅读
    <b class='flag-5'>74HC595</b>驱动8个<b class='flag-5'>LED</b>电路

    74hc595的主要功能(74hc595引脚图及功能_工作原理及电压_典型应用电路)

    本文主要介绍74hc595的主要功能(74hc595引脚图及功能_工作原理及电压_典型应用电路)。应用电路:74HC595驱动LED的电路设计、基于
    发表于 12-08 15:37 29.1w次阅读
    <b class='flag-5'>74hc595</b>的主要功能(<b class='flag-5'>74hc595</b>引脚图及功能_工作原理及电压_典型应用电路)

    任务7:74HC595的使用方法

    本系列教程以AVR单片机为对象,介绍单片机的快速开发方法。参考教材:《单片机技术及应用项目教程》 栾秋平 电子工业出版社 2019.6 第1版本文介绍74HC595的使用方法。一、认知
    发表于 11-19 14:51 42次下载
    任务7:<b class='flag-5'>74HC595</b>的使用<b class='flag-5'>方法</b>

    使用HAL 库的SPI实现74HC595芯片控制

    使用HAL 库的SPI实现74HC595芯片控制先简单看一下原理图:原理图是简单的级联方式,如图所示可用三个字节,例如:先写入第一个字节0000 0000控制的数据是右边74HC595
    发表于 11-24 09:51 20次下载
    使用HAL 库的SPI实现<b class='flag-5'>74HC595</b>芯片<b class='flag-5'>控制</b>