LED 使用

前言

ROC-RK3399-PC 开发板上有 2 个 LED 灯,如下表所示:

_images/led_port.jpg

以设备的方式控制 LED可通过使用 LED 设备子系统或者直接操作 GPIO 控制该 LED。

标准的 Linux 专门为 LED 设备定义了 LED 子系统。 在 ROC-RK3399-PC 开发板中的两个 LED 均以设备的形式被定义。

用户可以通过 /sys/class/leds/ 目录控制这两个 LED。

开发板上的 LED 的默认状态为:

  • Blue: 系统上电时打开

  • Yellow:用户自定义

用户可以通过 echo 向其 brightness属性输入命令控制每一个 LED:

root@firefly:~# echo 0 > /sys/class/leds/firefly\:blue\:power/brightness  //蓝灯灭
root@firefly:~# echo 1 > /sys/class/leds/firefly\:yellow\:user/brightness  //蓝灯亮

使用trigger 方式控制 LED

Trigger 包含多种方式可以控制LED,这里就用两个例子来说明

  • Simple trigger LED

  • Complex trigger LED

更详细的说明请参考 leds-class.txt 。

首先我们需要知道定义多少个LED,同时对应的LED的属性是什么。

在 kernel/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dtsi 文件中定义LED节点,具体定义如下:

leds {
    compatible = "gpio-leds";
    power {
        label = "firefly:blue:power";
        linux,default-trigger = "ir-power-click";
        default-state = "on";
        gpios = <&gpio2 27 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";pinctrl-0 = <&led_power>;
    };
    user {
        label = "firefly:yellow:user";
        linux,default-trigger = "ir-user-click";
        default-state = "off";
        gpios = <&gpio0 13 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";
        pinctrl-0 = <&led_user>;
    };
};

注意:compatible 的值要跟 drivers/leds/leds-gpio.c 中的 .compatible 的值要保持一致。

Simple trigger LED

按名字来是看就是简单的触发方式控制LED,如下就默认打开蓝灯,ROC-RK3399-PC 开机后蓝灯就亮

(1)定义 LED 触发器 在kernel/drivers/leds/trigger/led-firefly-demo.c 文件中有如下添加

DEFINE_LED_TRIGGER(ledtrig_default_control);

(2)注册该触发器

led_trigger_register_simple("ir-user-click", &ledtrig_default_control);

(3)控制 LED 的亮。

led_trigger_event(ledtrig_default_control, LED_FULL);   //yellow led on

(4)打开LED demo

led-firefly-demo默认没有打开,如果需要的话可以使用以下补丁打开demo驱动:

diff --git a/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dts b/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dts
index 0b1c902b32fa..6a6a17c3b2f1 100644
--- a/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dts
+++ b/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dts
@@ -4,4 +4,9 @@
 / {
        model = "Firefly roc-rk3399-pc";
        compatible = "firefly,roc-rk3399-pc", "rockchip,rk3399";
-};
\ No newline at end of file
+
+       led_demo: led_demo {
+               status = "okay";
+               compatible = "firefly,rk3399-led";
+       };
+};
diff --git a/drivers/leds/trigger/Makefile b/drivers/leds/trigger/Makefile
index 49e4e6e8271a..14f5cfff1b48 100644
--- a/drivers/leds/trigger/Makefile
+++ b/drivers/leds/trigger/Makefile
@@ -1,3 +1,4 @@
+obj-y          +=led-firefly-demo.o
 obj-$(CONFIG_LEDS_TRIGGER_TIMER)       += ledtrig-timer.o
 obj-$(CONFIG_LEDS_TRIGGER_ONESHOT)     += ledtrig-oneshot.o
 obj-$(CONFIG_LEDS_TRIGGER_IDE_DISK)    += ledtrig-ide-disk.o

Complex trigger LED

如下是trigger方式控制LED复杂一点的例子,timer trigger 就是让LED达到不断亮灭的效果

我们需要在内核把timer trigger配置上

在 kernel 路径下使用 make menuconfig ,按照如下方法将timer trigger驱动选中。

Device Drivers
--->LED Support
   --->LED Trigger support
      --->LED Timer Trigger

保存配置并编译内核,把kernel.img 烧到ROC-RK3399-PC板子上 我们可以使用串口输入命令,就可以看到蓝灯不停的间隔闪烁

echo "timer" > sys/class/leds/firefly\:blue\:power/trigger

用户还可以使用 cat 命令获取 trigger 的可用值:

root@firefly:~# cat /sys/class/leds/firefly\:blue\:power/trigger
none rc-feedback kbd-scrolllock kbd-numlock kbd-capslock kbd-kanalock
kbd-shiftlock kbd-altgrlock kbd-ctrllock kbd-altlock kbd-shiftllock kbd-shiftrlo