diff mbox series

[v1,1/2] dt-bindings: leds: Add bindings for intel LGM SOC

Message ID c9c963a2d03fbd03bd21f71f3d776ac5800cf6cc.1604331498.git.mallikarjunax.reddy@linux.intel.com
State New
Headers show
Series [v1,1/2] dt-bindings: leds: Add bindings for intel LGM SOC | expand

Commit Message

Reddy, MallikarjunaX Nov. 5, 2020, 9:43 a.m. UTC
Add DT bindings YAML schema for SSO controller driver
of Lightning Mountain(LGM) SoC.

Signed-off-by: Amireddy Mallikarjuna reddy <mallikarjunax.reddy@linux.intel.com>
---
 .../devicetree/bindings/leds/leds-lgm.yaml         | 116 +++++++++++++++++++++
 1 file changed, 116 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/leds/leds-lgm.yaml
diff mbox series

Patch

diff --git a/Documentation/devicetree/bindings/leds/leds-lgm.yaml b/Documentation/devicetree/bindings/leds/leds-lgm.yaml
new file mode 100644
index 000000000000..1acf1fa9643b
--- /dev/null
+++ b/Documentation/devicetree/bindings/leds/leds-lgm.yaml
@@ -0,0 +1,116 @@ 
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/leds/leds-lgm.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Intel LGM Soc LED SSO driver
+
+maintainers:
+  - Yixin.zhu@intel.com
+  - mallikarjunax.reddy@intel.com
+
+properties:
+ compatible:
+   const: intel,sso-led
+
+ reg:
+  maxItems: 1
+
+ clocks:
+  maxItems: 2
+
+ gpio-controller: true
+
+ '#gpio-cells':
+   const: 2
+
+ intel,sso-gpio-base:
+  $ref: /schemas/types.yaml#definitions/uint32
+  description:
+    Identifies the first gpio handled.
+
+ ngpios:
+  minimum: 0
+  maximum: 32
+  description:
+    Number of GPIOs this controller provides.
+
+ intel,sso-update-rate:
+  $ref: /schemas/types.yaml#definitions/uint32
+  description:
+    Blink frequency for SOUTs in Hz.
+
+ ssoled:
+    type: object
+    description:
+       This sub-node must contain a sub-node for each leds.
+
+    patternProperties:
+      "^led@[0-23]$":
+        type: object
+
+        properties:
+          intel,led-pin:
+            $ref: /schemas/types.yaml#/definitions/uint32
+            description:
+               This indicates the LED pin number.
+
+          intel,sso-brightness:
+            $ref: /schemas/types.yaml#/definitions/uint32
+            description: brightness level of the LED.
+            minimum: 0
+            maximum: 255
+
+          intel,sso-hw-trigger:
+            type: boolean
+            description: This property indicates Hardware driven/control LED.
+
+          intel,sso-hw-blink:
+            type: boolean
+            description: This property indicates Enable LED blink by Hardware.
+
+          intel,sso-blink-rate:
+            $ref: /schemas/types.yaml#/definitions/uint32
+            description: LED HW blink frequency.
+
+required:
+ - compatible
+ - reg
+ - clocks
+ - "#gpio-cells"
+ - gpio-controller
+
+additionalProperties: false
+
+examples:
+ - |
+   #include <dt-bindings/clock/intel,lgm-clk.h>
+
+   ssogpio: ssogpio@E0D40000 {
+     compatible = "intel,sso-led";
+     reg = <0xE0D40000 0x2E4>;
+     gpio-controller;
+     #gpio-cells = <2>;
+     ngpios = <32>;
+     pinctrl-names = "default";
+     pinctrl-0 = <&pinctrl_ledc>;
+     clocks = <&cgu0 LGM_GCLK_LEDC0>, <&afeclk>;
+     clock-names = "sso", "fpid";
+     intel,sso-update-rate = <250000>;
+
+     ssoled {
+        led0 {
+          label = "led0:green:gphy";
+          led-gpio = <&ssogpio 0 0>;
+          intel,led-pin = <0>;
+        };
+
+        led23 {
+          label = "led23:green:power_led";
+          led-gpio = <&ssogpio 23 0>;
+          intel,led-pin = <23>;
+          intel,sso-brightness = <0x255>;
+        };
+     };
+   };