Kernel-4.18.0-80.el8_leds-pm8058

Qualcomm PM8058 LED driver

The Qualcomm PM8058 is a multi-functional device which contains
an LED driver block for up to six LEDs: three normal LEDs, two
“flash” LEDs and one “keypad backlight” LED. The names are
quoted because sometimes these LED drivers are used for wildly
different things than flash or keypad backlight: their names
are more of a suggestion than a hard-wired usecase.

Hardware-wise the different LEDs support slightly different
output currents. The “flash” LEDs do not need to charge nor
do they support external triggers. They are just powerful LED
drivers.

The LEDs appear as children to the PM8058 device, with the
proper compatible string. For the PM8058 bindings see:
mfd/qcom-pm8xxx.txt.

Each LED is represented as a sub-node of the syscon device. Each
node’s name represents the name of the corresponding LED.

LED sub-node properties:

Required properties:

  • compatible: one of
    “qcom,pm8058-led” (for the normal LEDs at 0x131, 0x132 and 0x133)
    “qcom,pm8058-keypad-led” (for the “keypad” LED at 0x48)
    “qcom,pm8058-flash-led” (for the “flash” LEDs at 0x49 and 0xFB)

Optional properties:

  • label: see Documentation/devicetree/bindings/leds/common.txt
  • default-state: see Documentation/devicetree/bindings/leds/common.txt
  • linux,default-trigger: see Documentation/devicetree/bindings/leds/common.txt

Example:

qcom,ssbi@500000 {
pmicintc: pmic@0 {
compatible = “qcom,pm8058”;
led@48 {
compatible = “qcom,pm8058-keypad-led”;
reg = <0x48>;
label = “pm8050:white:keypad”;
default-state = “off”;
};
led@131 {
compatible = “qcom,pm8058-led”;
reg = <0x131>;
label = “pm8058:red”;
default-state = “off”;
};
led@132 {
compatible = “qcom,pm8058-led”;
reg = <0x132>;
label = “pm8058:yellow”;
default-state = “off”;
linux,default-trigger = “mmc0”;
};
led@133 {
compatible = “qcom,pm8058-led”;
reg = <0x133>;
label = “pm8058:green”;
default-state = “on”;
linux,default-trigger = “heartbeat”;
};
};
};