hc
2024-05-13 9d77db3c730780c8ef5ccd4b66403ff5675cfe4e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
* Oxford Semiconductor OXNAS SoC Family Pin Controller
 
Please refer to pinctrl-bindings.txt, ../gpio/gpio.txt, and
../interrupt-controller/interrupts.txt for generic information regarding
pin controller, GPIO, and interrupt bindings.
 
OXNAS 'pin configuration node' is a node of a group of pins which can be
used for a specific device or function. This node represents configurations of
pins, optional function, and optional mux related configuration.
 
Required properties for pin controller node:
 - compatible: "oxsemi,ox810se-pinctrl" or "oxsemi,ox820-pinctrl"
 - oxsemi,sys-ctrl: a phandle to the system controller syscon node
 
Required properties for pin configuration sub-nodes:
 - pins: List of pins to which the configuration applies.
 
Optional properties for pin configuration sub-nodes:
----------------------------------------------------
 - function: Mux function for the specified pins.
 - bias-pull-up: Enable weak pull-up.
 
Example:
 
pinctrl: pinctrl {
   compatible = "oxsemi,ox810se-pinctrl";
 
   /* Regmap for sys registers */
   oxsemi,sys-ctrl = <&sys>;
 
   pinctrl_uart2: pinctrl_uart2 {
       uart2a {
           pins = "gpio31";
           function = "fct3";
       };
       uart2b {
           pins = "gpio32";
           function = "fct3";
       };
   };
};
 
uart2: serial@900000 {
   compatible = "ns16550a";
   reg = <0x900000 0x100000>;
   clocks = <&sysclk>;
   interrupts = <29>;
   reg-shift = <0>;
   fifo-size = <16>;
   reg-io-width = <1>;
   current-speed = <115200>;
   no-loopback-test;
   resets = <&reset 22>;
   pinctrl-names = "default";
   pinctrl-0 = <&pinctrl_uart2>;
};