2013-01-18 21:30:34 +00:00
|
|
|
* Allwinner A1X Pin Controller
|
|
|
|
|
|
|
|
The pins controlled by sunXi pin controller are organized in banks,
|
|
|
|
each bank has 32 pins. Each pin has 7 multiplexing functions, with
|
|
|
|
the first two functions being GPIO in and out. The configuration on
|
|
|
|
the pins includes drive strength and pull-up.
|
|
|
|
|
|
|
|
Required properties:
|
2017-02-27 22:29:56 +00:00
|
|
|
- compatible: Should be one of the following (depending on your SoC):
|
2014-04-22 13:38:06 +00:00
|
|
|
"allwinner,sun4i-a10-pinctrl"
|
|
|
|
"allwinner,sun5i-a10s-pinctrl"
|
|
|
|
"allwinner,sun5i-a13-pinctrl"
|
|
|
|
"allwinner,sun6i-a31-pinctrl"
|
2014-12-17 17:18:13 +00:00
|
|
|
"allwinner,sun6i-a31s-pinctrl"
|
2014-04-22 13:38:06 +00:00
|
|
|
"allwinner,sun6i-a31-r-pinctrl"
|
|
|
|
"allwinner,sun7i-a20-pinctrl"
|
2014-06-17 14:52:51 +00:00
|
|
|
"allwinner,sun8i-a23-pinctrl"
|
2014-06-17 14:52:52 +00:00
|
|
|
"allwinner,sun8i-a23-r-pinctrl"
|
2015-06-02 09:08:40 +00:00
|
|
|
"allwinner,sun8i-a33-pinctrl"
|
2015-12-16 16:39:42 +00:00
|
|
|
"allwinner,sun9i-a80-pinctrl"
|
|
|
|
"allwinner,sun9i-a80-r-pinctrl"
|
2015-09-22 15:38:55 +00:00
|
|
|
"allwinner,sun8i-a83t-pinctrl"
|
2015-12-04 21:24:41 +00:00
|
|
|
"allwinner,sun8i-h3-pinctrl"
|
2016-02-18 19:49:31 +00:00
|
|
|
"allwinner,sun8i-h3-r-pinctrl"
|
2016-03-08 09:37:59 +00:00
|
|
|
"allwinner,sun50i-a64-pinctrl"
|
2017-01-26 15:48:51 +00:00
|
|
|
"allwinner,sun50i-h5-r-pinctrl"
|
2016-09-07 14:53:57 +00:00
|
|
|
"nextthing,gr8-pinctrl"
|
2015-06-02 09:08:40 +00:00
|
|
|
|
2013-01-18 21:30:34 +00:00
|
|
|
- reg: Should contain the register physical address and length for the
|
|
|
|
pin controller.
|
|
|
|
|
2016-11-14 20:53:03 +00:00
|
|
|
- clocks: phandle to the clocks feeding the pin controller:
|
|
|
|
- "apb": the gated APB parent clock
|
|
|
|
- "hosc": the high frequency oscillator in the system
|
|
|
|
- "losc": the low frequency oscillator in the system
|
|
|
|
|
|
|
|
Note: For backward compatibility reasons, the hosc and losc clocks are only
|
|
|
|
required if you need to use the optional input-debounce property. Any new
|
|
|
|
device tree should set them.
|
|
|
|
|
|
|
|
Optional properties:
|
|
|
|
- input-debounce: Array of debouncing periods in microseconds. One period per
|
|
|
|
irq bank found in the controller. 0 if no setup required.
|
|
|
|
|
|
|
|
|
2013-01-18 21:30:34 +00:00
|
|
|
Please refer to pinctrl-bindings.txt in this directory for details of the
|
|
|
|
common pinctrl bindings used by client devices.
|
|
|
|
|
|
|
|
A pinctrl node should contain at least one subnodes representing the
|
|
|
|
pinctrl groups available on the machine. Each subnode will list the
|
|
|
|
pins it needs, and how they should be configured, with regard to muxer
|
|
|
|
configuration, drive strength and pullups. If one of these options is
|
|
|
|
not set, its actual value will be unspecified.
|
|
|
|
|
2016-10-20 13:49:04 +00:00
|
|
|
This driver supports the generic pin multiplexing and configuration
|
|
|
|
bindings. For details on each properties, you can refer to
|
|
|
|
./pinctrl-bindings.txt.
|
|
|
|
|
|
|
|
Required sub-node properties:
|
|
|
|
- pins
|
|
|
|
- function
|
|
|
|
|
|
|
|
Optional sub-node properties:
|
|
|
|
- bias-disable
|
|
|
|
- bias-pull-up
|
|
|
|
- bias-pull-down
|
|
|
|
- drive-strength
|
|
|
|
|
|
|
|
*** Deprecated pin configuration and multiplexing binding
|
|
|
|
|
2013-01-18 21:30:34 +00:00
|
|
|
Required subnode-properties:
|
|
|
|
|
|
|
|
- allwinner,pins: List of strings containing the pin name.
|
|
|
|
- allwinner,function: Function to mux the pins listed above to.
|
|
|
|
|
|
|
|
Optional subnode-properties:
|
|
|
|
- allwinner,drive: Integer. Represents the current sent to the pin
|
|
|
|
0: 10 mA
|
|
|
|
1: 20 mA
|
|
|
|
2: 30 mA
|
|
|
|
3: 40 mA
|
|
|
|
- allwinner,pull: Integer.
|
|
|
|
0: No resistor
|
|
|
|
1: Pull-up resistor
|
|
|
|
2: Pull-down resistor
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
|
2015-07-27 12:41:57 +00:00
|
|
|
pio: pinctrl@01c20800 {
|
2013-01-18 21:30:34 +00:00
|
|
|
compatible = "allwinner,sun5i-a13-pinctrl";
|
|
|
|
reg = <0x01c20800 0x400>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
uart1_pins_a: uart1@0 {
|
|
|
|
allwinner,pins = "PE10", "PE11";
|
|
|
|
allwinner,function = "uart1";
|
|
|
|
allwinner,drive = <0>;
|
|
|
|
allwinner,pull = <0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
uart1_pins_b: uart1@1 {
|
|
|
|
allwinner,pins = "PG3", "PG4";
|
|
|
|
allwinner,function = "uart1";
|
|
|
|
allwinner,drive = <0>;
|
|
|
|
allwinner,pull = <0>;
|
|
|
|
};
|
|
|
|
};
|
2015-07-27 12:41:57 +00:00
|
|
|
|
|
|
|
|
|
|
|
GPIO and interrupt controller
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
This hardware also acts as a GPIO controller and an interrupt
|
|
|
|
controller.
|
|
|
|
|
|
|
|
Consumers that would want to refer to one or the other (or both)
|
|
|
|
should provide through the usual *-gpios and interrupts properties a
|
|
|
|
cell with 3 arguments, first the number of the bank, then the pin
|
|
|
|
inside that bank, and finally the flags for the GPIO/interrupts.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
xio: gpio@38 {
|
|
|
|
compatible = "nxp,pcf8574a";
|
|
|
|
reg = <0x38>;
|
|
|
|
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
|
|
|
|
interrupt-parent = <&pio>;
|
|
|
|
interrupts = <6 0 IRQ_TYPE_EDGE_FALLING>;
|
|
|
|
interrupt-controller;
|
|
|
|
#interrupt-cells = <2>;
|
|
|
|
};
|
|
|
|
|
|
|
|
reg_usb1_vbus: usb1-vbus {
|
|
|
|
compatible = "regulator-fixed";
|
|
|
|
regulator-name = "usb1-vbus";
|
|
|
|
regulator-min-microvolt = <5000000>;
|
|
|
|
regulator-max-microvolt = <5000000>;
|
|
|
|
gpio = <&pio 7 6 GPIO_ACTIVE_HIGH>;
|
|
|
|
};
|