Firefly-RK3128主板LED子系统介绍

描述

LED 使用
前言

Firefly-RK3128 开发板上有 2 个 LED 灯,如下表所示:

Firefly

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

以设备的方式控制 LED

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

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

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

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

  • Blue: 系统上电时打开
  • Yellow:用户自定义

用户可以通过 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

在内核中操作 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); //

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

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分