123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- *ST pin controller.
- Each multi-function pin is controlled, driven and routed through the
- PIO multiplexing block. Each pin supports GPIO functionality (ALT0)
- and multiple alternate functions(ALT1 - ALTx) that directly connect
- the pin to different hardware blocks.
- When a pin is in GPIO mode, Output Enable (OE), Open Drain(OD), and
- Pull Up (PU) are driven by the related PIO block.
- ST pinctrl driver controls PIO multiplexing block and also interacts with
- gpio driver to configure a pin.
- GPIO bank can have one of the two possible types of interrupt-wirings.
- First type is via irqmux, single interrupt is used by multiple gpio banks. This
- reduces number of overall interrupts numbers required. All these banks belong to
- a single pincontroller.
- _________
- | |----> [gpio-bank (n) ]
- | |----> [gpio-bank (n + 1)]
- [irqN]-- | irq-mux |----> [gpio-bank (n + 2)]
- | |----> [gpio-bank (... )]
- |_________|----> [gpio-bank (n + 7)]
- Second type has a dedicated interrupt per gpio bank.
- [irqN]----> [gpio-bank (n)]
- Pin controller node:
- Required properties:
- - compatible : should be "st,stih407-<pio-block>-pinctrl"
- - st,syscfg : Should be a phandle of the syscfg node.
- - st,retime-pin-mask : Should be mask to specify which pins can be retimed.
- If the property is not present, it is assumed that all the pins in the
- bank are capable of retiming. Retiming is mainly used to improve the
- IO timing margins of external synchronous interfaces.
- - ranges : defines mapping between pin controller node (parent) to gpio-bank
- node (children).
- Optional properties:
- - interrupts : Interrupt number of the irqmux. If the interrupt is shared
- with other gpio banks via irqmux.
- a irqline and gpio banks.
- - reg : irqmux memory resource. If irqmux is present.
- - reg-names : irqmux resource should be named as "irqmux".
- GPIO controller/bank node.
- Required properties:
- - gpio-controller : Indicates this device is a GPIO controller
- - #gpio-cells : Must be two.
- - First cell: specifies the pin number inside the controller
- - Second cell: specifies whether the pin is logically inverted.
- - 0 = active high
- - 1 = active low
- - st,bank-name : Should be a name string for this bank as specified in
- datasheet.
- Optional properties:
- - interrupts : Interrupt number for this gpio bank. If there is a dedicated
- interrupt wired up for this gpio bank.
- - interrupt-controller : Indicates this device is a interrupt controller. GPIO
- bank can be an interrupt controller iff one of the interrupt type either via
- irqmux or a dedicated interrupt per bank is specified.
- - #interrupt-cells: the value of this property should be 2.
- - First Cell: represents the external gpio interrupt number local to the
- gpio interrupt space of the controller.
- - Second Cell: flags to identify the type of the interrupt
- - 1 = rising edge triggered
- - 2 = falling edge triggered
- - 3 = rising and falling edge triggered
- - 4 = high level triggered
- - 8 = low level triggered
- for related macros look in:
- include/dt-bindings/interrupt-controller/irq.h
- Example:
- pin-controller-sbc {
- #address-cells = <1>;
- #size-cells = <1>;
- compatible = "st,stih407-sbc-pinctrl";
- st,syscfg = <&syscfg_sbc>;
- reg = <0x0961f080 0x4>;
- reg-names = "irqmux";
- interrupts = <GIC_SPI 188 IRQ_TYPE_NONE>;
- interrupt-names = "irqmux";
- ranges = <0 0x09610000 0x6000>;
- pio0: gpio@09610000 {
- gpio-controller;
- #gpio-cells = <2>;
- interrupt-controller;
- #interrupt-cells = <2>;
- reg = <0x0 0x100>;
- st,bank-name = "PIO0";
- };
- ...
- pin-functions nodes follow...
- };
- Contents of function subnode node:
- ----------------------
- Required properties for pin configuration node:
- - st,pins : Child node with list of pins with configuration.
- Below is the format of how each pin conf should look like.
- <bank offset mux mode rt_type rt_delay rt_clk>
- Every PIO is represented with 4-7 parameters depending on retime configuration.
- Each parameter is explained as below.
- -bank : Should be bank phandle to which this PIO belongs.
- -offset : Offset in the PIO bank.
- -mux : Should be alternate function number associated this pin.
- Use same numbers from datasheet.
- -mode :pin configuration is selected from one of the below values.
- IN
- IN_PU
- OUT
- BIDIR
- BIDIR_PU
- -rt_type Retiming Configuration for the pin.
- Possible retime configuration are:
- ------- -------------
- value args
- ------- -------------
- NICLK <delay> <clk>
- ICLK_IO <delay> <clk>
- BYPASS <delay>
- DE_IO <delay> <clk>
- SE_ICLK_IO <delay> <clk>
- SE_NICLK_IO <delay> <clk>
- - delay is retime delay in pico seconds as mentioned in data sheet.
- - rt_clk :clk to be use for retime.
- Possible values are:
- CLK_A
- CLK_B
- CLK_C
- CLK_D
- Example of mmcclk pin which is a bi-direction pull pu with retime config
- as non inverted clock retimed with CLK_B and delay of 0 pico seconds:
- pin-controller {
- ...
- mmc0 {
- pinctrl_mmc: mmc {
- st,pins {
- mmcclk = <&PIO13 4 ALT4 BIDIR_PU NICLK 0 CLK_B>;
- ...
- };
- };
- ...
- };
- };
- sdhci0:sdhci@fe810000{
- ...
- interrupt-parent = <&pio3>;
- #interrupt-cells = <2>;
- interrupts = <3 IRQ_TYPE_LEVEL_HIGH>; /* Interrupt line via PIO3-3 */
- interrupt-names = "card-detect";
- pinctrl-names = "default";
- pinctrl-0 = <&pinctrl_mmc>;
- };
|