spmi: add generic SPMI controller binding documentation
authorJosh Cartwright <joshc@codeaurora.org>
Wed, 12 Feb 2014 19:44:23 +0000 (13:44 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 15 Feb 2014 19:55:28 +0000 (11:55 -0800)
Signed-off-by: Josh Cartwright <joshc@codeaurora.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Documentation/devicetree/bindings/spmi/spmi.txt [new file with mode: 0644]

diff --git a/Documentation/devicetree/bindings/spmi/spmi.txt b/Documentation/devicetree/bindings/spmi/spmi.txt
new file mode 100644 (file)
index 0000000..462a42f
--- /dev/null
@@ -0,0 +1,41 @@
+System Power Management Interface (SPMI) Controller
+
+This document defines a generic set of bindings for use by SPMI controllers.  A
+controller is modelled in device tree as a node with zero or more child nodes,
+each representing a unique slave on the bus.
+
+Required properties:
+- #address-cells : must be set to 2
+- #size-cells : must be set to 0
+
+Child nodes:
+
+An SPMI controller node can contain zero or more child nodes representing slave
+devices on the bus.  Child 'reg' properties are specified as an address, type
+pair.  The address must be in the range 0-15 (4 bits).  The type must be one of
+SPMI_USID (0) or SPMI_GSID (1) for Unique Slave ID or Group Slave ID respectively.
+These are the identifiers "statically assigned by the system integrator", as
+per the SPMI spec.
+
+Each child node must have one and only one 'reg' entry of type SPMI_USID.
+
+#include <dt-bindings/spmi/spmi.h>
+
+       spmi@.. {
+               compatible = "...";
+               reg = <...>;
+
+               #address-cells = <2>;
+               #size-cells <0>;
+
+               child@0 {
+                       compatible = "...";
+                       reg = <0 SPMI_USID>;
+               };
+
+               child@7 {
+                       compatible = "...";
+                       reg = <7 SPMI_USID
+                              3 SPMI_GSID>;
+               };
+       };