Firefly-RK3128 开发板上有 2 个 LED 灯,如下表所示:
可通过使用 LED 设备子系统或者直接操作 GPIO 控制该 LED。
标准的 Linux 专门为 LED 设备定义了 LED 子系统。 在 Firefly-RK3128 开发板中的两个 LED 均以设备的形式被定义。
用户可以通过 /sys/class/leds/
目录控制这两个 LED。
更详细的说明请参考 leds-class.txt 。
开发板上的 LED 的默认状态为:
用户可以通过 echo 向其 trigger 属性输入命令控制每一个 LED:
root@firefly:~ # echo none >/sys/class/leds/firefly:blue:power/trigger root@firefly:~ # echo default-on >/sys/class/leds/firefly:blue:power/trigger
用户还可以使用 cat 命令获取 trigger 的可用值:
root@firefly:~ # cat /sys/class/leds/firefly:blue:power/trigger none [ir-power-click] test_ac-online test_battery-charging-or-full test_battery-charging test_battery-full test_battery-charging-blink-full-solid test_usb-online mmc0 mmc1 mmc2 backlight default-on rfkill0 rfkill1 rfkill2
在内核中操作 LED 的步骤如下:
1、在 dts 文件中定义 LED 节点“leds” 在 kernel/arch/arm/boot/dts/rk3128-fireprime.dts 文件中定义LED节点,具体定义如下:
leds { compatible = "gpio-leds"; power { label = "firefly:blue:power"; linux,default-trigger = "ir-power-click"; default-state = "on"; gpios = <&gpio1 GPIO_C7 GPIO_ACTIVE_LOW>;}; user { label = "firefly:yellow:user"; linux,default-trigger = "ir-user-click"; default-state = "off"; gpios = <&gpio1 GPIO_C6 GPIO_ACTIVE_LOW>; }; };
注意:compatible 的值要跟 drivers/leds/leds-gpio.c 中的 .compatible 的值要保持一致。
2、在驱动文件包含头文件
#include
3、在驱动文件中控制 LED。
(1)、定义 LED 触发器
DEFINE_LED_TRIGGER(ledtrig_ir_click);
(2)、注册该触发器
led_trigger_register_simple("ir-power-click", &ledtrig_ir_click);
(3)、控制 LED 的亮灭。
led_trigger_event(ledtrig_ir_click, LED_FULL); //亮 led_trigger_event(ledtrig_ir_click, LED_OFF); //灭
全部0条评论
快来发表一下你的评论吧 !