123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- * Microchip PIC32 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.
- PIC32 'pin configuration node' is a node of a group of pins which can be
- used for a specific device or function. This node represents configuraions of
- pins, optional function, and optional mux related configuration.
- Required properties for pin controller node:
- - compatible: "microchip,pic32mada-pinctrl"
- - reg: Address range of the pinctrl registers.
- - clocks: Clock specifier (see clock bindings for details)
- 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.
- - bias-pull-down: Enable weak pull-down.
- - input-enable: Set the pin as an input.
- - output-low: Set the pin as an output level low.
- - output-high: Set the pin as an output level high.
- - microchip,digital: Enable digital I/O.
- - microchip,analog: Enable analog I/O.
- Example:
- pic32_pinctrl: pinctrl@1f801400{
- #address-cells = <1>;
- #size-cells = <1>;
- compatible = "microchip,pic32mzda-pinctrl";
- reg = <0x1f801400 0x400>;
- clocks = <&rootclk PB1CLK>;
- pinctrl_uart2: pinctrl_uart2 {
- uart2-tx {
- pins = "G9";
- function = "U2TX";
- microchip,digital;
- output-low;
- };
- uart2-rx {
- pins = "B0";
- function = "U2RX";
- microchip,digital;
- input-enable;
- };
- };
- };
- uart2: serial@1f822200 {
- compatible = "microchip,pic32mzda-uart";
- reg = <0x1f822200 0x50>;
- pinctrl-names = "default";
- pinctrl-0 = <&pinctrl_uart2>;
- };
|