当单片机遇到这颗LED驱动芯片,

最近和一个小伙伴调试一个驱动芯片

这是一颗简单的 LED 驱动芯片,串行LED 驱动芯片

芯片驱动核心时序如下

e1071ebb85248d832cb2e9c5f4d40f7d.jpeg

常规的LED驱动方式是一个GPIO口控制一个 LED 灯,如果要控制LED灯的亮度的话,GPIO口还需要具备PWM的功能。

这颗芯片的特点是串联式的,可以使用一个 GPIO 通过发送编码信号来控制一串的 LED 灯。

这里面有一个核心的问题

就是逻辑 1 和逻辑 0 需要的最短时间是 0.3us,如果我们用单片机延时的话,那必然在发送的时候需要延时一段时间,这段时间单片机的核心就被占用无法做其他工作了。

那如果用 SPI 来编码的话,SPI 要求的频率是  1/0.3u = 3333333HZ。

fe3351dfef2ad83198ef8e20319c155d.png

逻辑1发送SPI数据:0x6,对应二进制 110 

逻辑0发送SPI数据:0x4,对应二进制100

问题是很多常见的单片机不能设置这样的 SPI 频率,普通的单片机时钟频率大部分都是 100HZ 的倍数。

当然了,在众多的串行LED芯片中,是有其他频率时间供我们选择的。

➵➵➵➵➵➵➵➵➵➵➵➵➵➵➵

直接用单片机延时拉高拉低GPIO口来实现这个时序的话

逻辑 1 发送:拉高 GPIO ,延时 0.6 us,拉低 GPIO ,延时 0.3us

逻辑 1 发送:拉高 GPIO ,延时 0.3 us,拉低 GPIO ,延时 0.6us

问题来了,我们用的一颗赛元微的单片机,在执行 for 指令的时候,就会出现执行很慢,直接跑到 ms 级别(因为这样的限制,这个方案直接被否决了)。

我查了下这颗芯片的内核,用的是51的内核,但我在使用51单片机没有遇到这样的问题。

使用这样方案的话

发送一个字节需要延时:0.9us * 8 = 7.2us

一个LED 灯需要发送3个字节:7.2us * 3 = 21.6us

如果我们硬件设计10个LED 灯,那就需要延时 216us

➵➵➵➵➵➵➵➵➵➵➵➵➵➵➵

还有一种方案是用定时器中断来完成的,跟一个大佬讨论了这个芯片的时序,我们交流下来的方法是这样的

d52e913ecf75d7e273f434d1e540eb10.jpeg

核心的思想是在第二种方案的基础发送逻辑1和逻辑0的时候,不要使用延时的方式,而在定时器中断中去完成。

这个方案的难点在软件的处理上需要复杂一些,发送LED数据和操作逻辑1和0的时候有点异步的思想。

➵➵➵➵➵➵➵➵➵➵➵➵➵➵➵

浅谈了下这颗芯片的操作,大家有其他想法,欢迎评论讨论

ce7c410f081b7fb916cc40440a51c074.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值