mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-17 11:25:04 +08:00
e16415313c
Currently, all imx pinctrl drivers maintain a big array of struct imx_pin_reg which hard-codes data like register offset and mux mode setting for each pin function. Every time a new imx SoC support is added, we need to add such a big mount of data. With moving to single kernel build, it's only matter of time to be blamed on memory consuming. With DTC pre-processor support in place, the patch moves all these data into device tree by redefining the PIN_FUNC_ID in imxXX-pinfunc.h and changing the PIN_FUNC_ID parsing code a little bit. The pin id gets re-numbered based on mux register offset, or config register offset if the pin has no mux register, so that kernel can identify the pin id from register offsets provided by device tree. As a bonus point of the change, those arbitrary magic numbers standing for particular PIN_FUNC_ID in device tree sources are now replaced by macros to improve the readability of dts files. Signed-off-by: Shawn Guo <shawn.guo@linaro.org> Acked-by: Dong Aisheng <dong.aisheng@linaro.org> Acked-by: Linus Walleij <linus.walleij@linaro.org>
173 lines
3.7 KiB
Plaintext
173 lines
3.7 KiB
Plaintext
/*
|
|
* Copyright 2012 Sascha Hauer <s.hauer@pengutronix.de>, Pengutronix
|
|
* Copyright 2012 Steffen Trumtrar <s.trumtrar@pengutronix.de>, Pengutronix
|
|
*
|
|
* The code contained herein is licensed under the GNU General Public
|
|
* License. You may obtain a copy of the GNU General Public License
|
|
* Version 2 or later at the following locations:
|
|
*
|
|
* http://www.opensource.org/licenses/gpl-license.html
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
*/
|
|
|
|
#include "imx53.dtsi"
|
|
|
|
/ {
|
|
model = "TQ TQMa53";
|
|
compatible = "tq,tqma53", "fsl,imx53";
|
|
|
|
memory {
|
|
reg = <0x70000000 0x40000000>; /* Up to 1GiB */
|
|
};
|
|
|
|
regulators {
|
|
compatible = "simple-bus";
|
|
|
|
reg_3p3v: 3p3v {
|
|
compatible = "regulator-fixed";
|
|
regulator-name = "3P3V";
|
|
regulator-min-microvolt = <3300000>;
|
|
regulator-max-microvolt = <3300000>;
|
|
regulator-always-on;
|
|
};
|
|
};
|
|
};
|
|
|
|
&esdhc2 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_esdhc2_1>;
|
|
wp-gpios = <&gpio1 2 0>;
|
|
cd-gpios = <&gpio1 4 0>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&uart3 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_uart3_2>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&ecspi1 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_ecspi1_1>;
|
|
fsl,spi-num-chipselects = <4>;
|
|
cs-gpios = <&gpio2 30 0>, <&gpio3 19 0>,
|
|
<&gpio3 24 0>, <&gpio3 25 0>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&esdhc3 { /* EMMC */
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_esdhc3_1>;
|
|
vmmc-supply = <®_3p3v>;
|
|
non-removable;
|
|
bus-width = <8>;
|
|
status = "okay";
|
|
};
|
|
|
|
&iomuxc {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_hog>;
|
|
|
|
i2s {
|
|
pinctrl_i2s_1: i2s-grp1 {
|
|
fsl,pins = <
|
|
MX53_PAD_GPIO_19__GPIO4_5 0x10000 /* I2S_MCLK */
|
|
MX53_PAD_KEY_COL0__AUDMUX_AUD5_TXC 0x10000 /* I2S_SCLK */
|
|
MX53_PAD_KEY_ROW0__AUDMUX_AUD5_TXD 0x10000 /* I2S_DOUT */
|
|
MX53_PAD_KEY_COL1__AUDMUX_AUD5_TXFS 0x10000 /* I2S_LRCLK */
|
|
MX53_PAD_KEY_ROW1__AUDMUX_AUD5_RXD 0x10000 /* I2S_DIN */
|
|
>;
|
|
};
|
|
};
|
|
|
|
hog {
|
|
pinctrl_hog: hoggrp {
|
|
fsl,pins = <
|
|
MX53_PAD_EIM_CS1__IPU_DI1_PIN6 0x10000 /* VSYNC */
|
|
MX53_PAD_EIM_DA15__IPU_DI1_PIN4 0x10000 /* HSYNC */
|
|
MX53_PAD_PATA_DA_1__GPIO7_7 0x10000 /* LCD_BLT_EN */
|
|
MX53_PAD_PATA_DA_2__GPIO7_8 0x10000 /* LCD_RESET */
|
|
MX53_PAD_PATA_DATA5__GPIO2_5 0x10000 /* LCD_POWER */
|
|
MX53_PAD_PATA_DATA6__GPIO2_6 0x10000 /* PMIC_INT */
|
|
MX53_PAD_PATA_DATA14__GPIO2_14 0x10000 /* CSI_RST */
|
|
MX53_PAD_PATA_DATA15__GPIO2_15 0x10000 /* CSI_PWDN */
|
|
MX53_PAD_GPIO_0__GPIO1_0 0x10000 /* SYSTEM_DOWN */
|
|
MX53_PAD_GPIO_3__GPIO1_3 0x10000
|
|
>;
|
|
};
|
|
};
|
|
};
|
|
|
|
&uart1 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_uart1_2>;
|
|
fsl,uart-has-rtscts;
|
|
status = "disabled";
|
|
};
|
|
|
|
&uart2 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_uart2_1>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&can1 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_can1_2>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&can2 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_can2_1>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&i2c3 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_i2c3_1>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&cspi {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_cspi_1>;
|
|
fsl,spi-num-chipselects = <3>;
|
|
cs-gpios = <&gpio1 18 0>, <&gpio1 19 0>,
|
|
<&gpio1 21 0>;
|
|
status = "disabled";
|
|
};
|
|
|
|
&i2c2 {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_i2c2_1>;
|
|
status = "okay";
|
|
|
|
pmic: mc34708@8 {
|
|
compatible = "fsl,mc34708";
|
|
reg = <0x8>;
|
|
fsl,mc13xxx-uses-rtc;
|
|
interrupt-parent = <&gpio2>;
|
|
interrupts = <6 8>; /* PDATA_DATA6, low active */
|
|
};
|
|
|
|
sensor1: lm75@48 {
|
|
compatible = "lm75";
|
|
reg = <0x48>;
|
|
};
|
|
|
|
eeprom: 24c64@50 {
|
|
compatible = "at,24c64";
|
|
pagesize = <32>;
|
|
reg = <0x50>;
|
|
};
|
|
};
|
|
|
|
&fec {
|
|
pinctrl-names = "default";
|
|
pinctrl-0 = <&pinctrl_fec_1>;
|
|
phy-mode = "rmii";
|
|
status = "disabled";
|
|
};
|