在Carbide项目中,测试报出了一个错误,就是由于在设置LED灯的时候,间隔的时间过长,导致了三色灯在呼吸的时候不够平整,因此需要进行修改。
第一次处理的思路是由于其取值是通过一个数组进行取值,因此通过改变数组的数值,来进行调整,在设备树中,相应的声明如下:
qcom,duty-pcts
在设备树中,这个数组保存的就是亮度取值百分比,程序通过解析设备树中这个数组中的值,对灯的亮度进行设置。
在多添加几个数据之后,发现在闪烁的时候,灯光的闪烁变得很不正常,在echo值到brightness节点后,灯先是正常的亮起,之后开始无规则的闪烁,则经如此,怀疑是频率的问题,同时对以下声明进行了调整:
qcom,ramp-step-ms
在以上的这个数值中,设置的是每一步更改亮度的时间,单位是ms,初始的时候,设置为225ms,由于时间过长,导致效果很不自然,因此调整到100ms以下效果最好。
经过这个调整之后,发现情况仍然没有改观,LED灯仍然是在进行不规则的闪烁,因此开始怀疑是数组的大小不足,导致数组出现了溢出的现象,则到驱动中的leds-qpnp.c这个文件中进行查找
先查看了probe函数中对于节点的遍历,之后根据获取节点值中的num_duty_pcts 这一项数据,找到了其他获取它的函数,其中有一个是
qpnp_num_init
由于在设备树中设置RGB三色灯的模式为pwm,因此推测这个函数一定会被调用,后跟踪至一个函数
qpnp_rgb_init
经过打出的log得知,这个函数是经过
qpnp_rgb_init -> qpnp_led_initialize -> probe
也就是说这个函数一定会被调用,对于qpnp_pwm_init这个函数的以下这两个字段
start_idx
lut_max_size
该数组的大小为63,并没有溢出。
之后,在高通网站上查询了相关文档,找到了以下两个文档
80-nm328-29_g
80-nm328-35_e
这两个文档中对于在设备树中出现的
qcom,lut-flags
这个字段有详细的解释,同时也有图来进行说明配置,由此得知需要延时,可以通过设置
qcom,pause-lo
qcom,pasue-hi
这两个字段来控制在高电平和低电平的延时时间,从而解决了问题。