Commit d1c30115 authored by Shawn Guo's avatar Shawn Guo Committed by Linus Walleij

pinctrl: imx: update fsl,pins description in bindings doc

While commit e1641531 (pinctrl: imx: move hard-coding data into device
tree) moves to use DTC macro for imx pinctrl device tree setting, it
changes the semantics of fsl,pins without updating the bindings doc
properly.  Let's update the fsl,pins description to stop confusing
people.

While at it, the example in the document is updated, and the stale TODO
gets removed.
Signed-off-by: default avatarShawn Guo <shawn.guo@linaro.org>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent d3224ed1
...@@ -22,11 +22,12 @@ Required properties for iomux controller: ...@@ -22,11 +22,12 @@ Required properties for iomux controller:
Please refer to each fsl,<soc>-pinctrl.txt binding doc for supported SoCs. Please refer to each fsl,<soc>-pinctrl.txt binding doc for supported SoCs.
Required properties for pin configuration node: Required properties for pin configuration node:
- fsl,pins: two integers array, represents a group of pins mux and config - fsl,pins: each entry consists of 6 integers and represents the mux and config
setting. The format is fsl,pins = <PIN_FUNC_ID CONFIG>, PIN_FUNC_ID is a setting for one pin. The first 5 integers <mux_reg conf_reg input_reg mux_val
pin working on a specific function, which consists of a tuple of input_val> are specified using a PIN_FUNC_ID macro, which can be found in
<mux_reg conf_reg input_reg mux_val input_val>. CONFIG is the pad setting imx*-pinfunc.h under device tree source folder. The last integer CONFIG is
value like pull-up on this pin. the pad setting value like pull-up on this pin. And that's why fsl,pins entry
looks like <PIN_FUNC_ID CONFIG> in the example below.
Bits used for CONFIG: Bits used for CONFIG:
NO_PAD_CTL(1 << 31): indicate this pin does not need config. NO_PAD_CTL(1 << 31): indicate this pin does not need config.
...@@ -72,17 +73,18 @@ iomuxc@020e0000 { ...@@ -72,17 +73,18 @@ iomuxc@020e0000 {
/* shared pinctrl settings */ /* shared pinctrl settings */
usdhc4 { usdhc4 {
pinctrl_usdhc4_1: usdhc4grp-1 { pinctrl_usdhc4_1: usdhc4grp-1 {
fsl,pins = <1386 0x17059 /* MX6Q_PAD_SD4_CMD__USDHC4_CMD */ fsl,pins = <
1392 0x10059 /* MX6Q_PAD_SD4_CLK__USDHC4_CLK */ MX6QDL_PAD_SD4_CMD__SD4_CMD 0x17059
1462 0x17059 /* MX6Q_PAD_SD4_DAT0__USDHC4_DAT0 */ MX6QDL_PAD_SD4_CLK__SD4_CLK 0x10059
1470 0x17059 /* MX6Q_PAD_SD4_DAT1__USDHC4_DAT1 */ MX6QDL_PAD_SD4_DAT0__SD4_DATA0 0x17059
1478 0x17059 /* MX6Q_PAD_SD4_DAT2__USDHC4_DAT2 */ MX6QDL_PAD_SD4_DAT1__SD4_DATA1 0x17059
1486 0x17059 /* MX6Q_PAD_SD4_DAT3__USDHC4_DAT3 */ MX6QDL_PAD_SD4_DAT2__SD4_DATA2 0x17059
1493 0x17059 /* MX6Q_PAD_SD4_DAT4__USDHC4_DAT4 */ MX6QDL_PAD_SD4_DAT3__SD4_DATA3 0x17059
1501 0x17059 /* MX6Q_PAD_SD4_DAT5__USDHC4_DAT5 */ MX6QDL_PAD_SD4_DAT4__SD4_DATA4 0x17059
1509 0x17059 /* MX6Q_PAD_SD4_DAT6__USDHC4_DAT6 */ MX6QDL_PAD_SD4_DAT5__SD4_DATA5 0x17059
1517 0x17059>; /* MX6Q_PAD_SD4_DAT7__USDHC4_DAT7 */ MX6QDL_PAD_SD4_DAT6__SD4_DATA6 0x17059
}; MX6QDL_PAD_SD4_DAT7__SD4_DATA7 0x17059
>;
}; };
.... ....
}; };
...@@ -90,6 +92,3 @@ Refer to the IOMUXC controller chapter in imx6q datasheet, ...@@ -90,6 +92,3 @@ Refer to the IOMUXC controller chapter in imx6q datasheet,
0x17059 means enable hysteresis, 47KOhm Pull Up, 50Mhz speed, 0x17059 means enable hysteresis, 47KOhm Pull Up, 50Mhz speed,
80Ohm driver strength and Fast Slew Rate. 80Ohm driver strength and Fast Slew Rate.
User should refer to each SoC spec to set the correct value. User should refer to each SoC spec to set the correct value.
TODO: when dtc macro support is available, we can change above raw data
to dt macro which can get better readability in dts file.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment