The Cortina Gemini pin controller uses the standard pin control
bindings for muxing functions with groups so these bindings
should be entirely uncontroversial.

Cc: devicet...@vger.kernel.org
Signed-off-by: Linus Walleij <linus.wall...@linaro.org>
---
ChangeLog v1->v2:
- State that the pin controller must be a subnode of the
  system controller.
- Drop the phandle to the system controller: we can simply
  look up the parent.
---
 .../bindings/pinctrl/cortina,gemini-pinctrl.txt    | 59 ++++++++++++++++++++++
 1 file changed, 59 insertions(+)
 create mode 100644 
Documentation/devicetree/bindings/pinctrl/cortina,gemini-pinctrl.txt

diff --git 
a/Documentation/devicetree/bindings/pinctrl/cortina,gemini-pinctrl.txt 
b/Documentation/devicetree/bindings/pinctrl/cortina,gemini-pinctrl.txt
new file mode 100644
index 000000000000..61466c58faae
--- /dev/null
+++ b/Documentation/devicetree/bindings/pinctrl/cortina,gemini-pinctrl.txt
@@ -0,0 +1,59 @@
+Cortina Systems Gemini pin controller
+
+This pin controller is found in the Cortina Systems Gemini SoC family,
+see further arm/gemini.txt. It is a purely group-based multiplexing pin
+controller.
+
+The pin controller node must be a subnode of the system controller node.
+
+Required properties:
+- compatible: "cortina,gemini-pinctrl"
+
+Subnodes of the pin controller contain pin control multiplexing set-up.
+Please refer to pinctrl-bindings.txt for generic pin multiplexing nodes.
+
+Example:
+
+
+syscon {
+       compatible = "cortina,gemini-syscon";
+       ...
+       pinctrl {
+               compatible = "cortina,gemini-pinctrl";
+               pinctrl-names = "default";
+               pinctrl-0 = <&dram_default_pins>, <&system_default_pins>,
+                   <&vcontrol_default_pins>;
+
+               dram_default_pins: pinctrl-dram {
+                       mux {
+                               function = "dram";
+                               groups = "dramgrp";
+                       };
+               };
+               rtc_default_pins: pinctrl-rtc {
+                       mux {
+                               function = "rtc";
+                               groups = "rtcgrp";
+                       };
+               };
+               power_default_pins: pinctrl-power {
+                       mux {
+                               function = "power";
+                               groups = "powergrp";
+                       };
+               };
+               system_default_pins: pinctrl-system {
+                       mux {
+                               function = "system";
+                               groups = "systemgrp";
+                       };
+               };
+               (...)
+               uart_default_pins: pinctrl-uart {
+                       mux {
+                               function = "uart";
+                               groups = "uartrxtxgrp";
+                       };
+               };
+       };
+};
-- 
2.9.4

Reply via email to