// SPDX-License-Identifier: GPL-2.0-or-later
/*
 * Copyright 2013 Linaro Ltd.
 */

#include "ste-nomadik-pinctrl.dtsi"

&pinctrl {
	/* Settings for all UART default and sleep states */
	uart0 {
		u0_a_1_default: u0_a_1_default {
			default_mux {
				function = "u0";
				groups = "u0_a_1";
			};
			default_cfg1 {
				pins = "GPIO0_AJ5", "GPIO2_AH4"; /* CTS+RXD */
				ste,config = <&in_pu>;
			};
			default_cfg2 {
				pins = "GPIO1_AJ3", "GPIO3_AH3"; /* RTS+TXD */
				ste,config = <&out_hi>;
			};
		};

		u0_a_1_sleep: u0_a_1_sleep {
			sleep_cfg1 {
				pins = "GPIO0_AJ5", "GPIO2_AH4"; /* CTS+RXD */
				ste,config = <&slpm_in_wkup_pdis>;
			};
			sleep_cfg2 {
				pins = "GPIO1_AJ3"; /* RTS */
				ste,config = <&slpm_out_hi_wkup_pdis>;
			};
			sleep_cfg3 {
				pins = "GPIO3_AH3"; /* TXD */
				ste,config = <&slpm_out_wkup_pdis>;
			};
		};
	};

	uart1 {
		u1rxtx_a_1_default: u1rxtx_a_1_default {
			default_mux {
				function = "u1";
				groups = "u1rxtx_a_1";
			};
			default_cfg1 {
				pins = "GPIO4_AH6"; /* RXD */
				ste,config = <&in_pu>;
			};
			default_cfg2 {
				pins = "GPIO5_AG6"; /* TXD */
				ste,config = <&out_hi>;
			};
		};

		u1rxtx_a_1_sleep: u1rxtx_a_1_sleep {
			sleep_cfg1 {
				pins = "GPIO4_AH6"; /* RXD */
				ste,config = <&slpm_in_wkup_pdis>;
			};
			sleep_cfg2 {
				pins = "GPIO5_AG6"; /* TXD */
				ste,config = <&slpm_out_wkup_pdis>;
			};
		};

		u1ctsrts_a_1_default: u1ctsrts_a_1_default {
			default_mux {
				function = "u1";
				groups = "u1ctsrts_a_1";
			};
			default_cfg1 {
				pins = "GPIO6_AF6"; /* CTS */
				ste,config = <&in_pu>;
			};
			default_cfg2 {
				pins = "GPIO7_AG5"; /* RTS */
				ste,config = <&out_hi>;
			};
		};

		u1ctsrts_a_1_sleep: u1ctsrts_a_1_sleep {
			sleep_cfg1 {
				pins = "GPIO6_AF6"; /* CTS */
				ste,config = <&slpm_in_wkup_pdis>;
			};
			sleep_cfg2 {
				pins = "GPIO7_AG5"; /* RTS */
				ste,config = <&slpm_out_hi_wkup_pdis>;
			};
		};
	};

	uart2 {
		u2rxtx_c_1_default: u2rxtx_c_1_default {
			default_mux {
				function = "u2";
				groups = "u2rxtx_c_1";
			};
			default_cfg1 {
				pins = "GPIO29_W2"; /* RXD */
				ste,config = <&in_pu>;
			};
			default_cfg2 {
				pins = "GPIO30_W3"; /* TXD */
				ste,config = <&out_hi>;
			};
		};

		u2rxtx_c_1_sleep: u2rxtx_c_1_sleep {
			sleep_cfg1 {
				pins = "GPIO29_W2"; /* RXD */
				ste,config = <&in_wkup_pdis>;
			};
			sleep_cfg2 {
				pins = "GPIO30_W3"; /* TXD */
				ste,config = <&out_wkup_pdis>;
			};
		};
	};

	/* Settings for all I2C default and sleep states */
	i2c0 {
		i2c0_a_1_default: i2c0_a_1_default {
			default_mux {
				function = "i2c0";
				groups = "i2c0_a_1";
			};
			default_cfg1 {
				pins = "GPIO147_C15", "GPIO148_B16"; /* SDA/SCL */
				ste,config = <&in_nopull>;
			};
		};

		i2c0_a_1_sleep: i2c0_a_1_sleep {
			sleep_cfg1 {
				pins = "GPIO147_C15", "GPIO148_B16"; /* SDA/SCL */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};
	};

	i2c1 {
		i2c1_b_2_default: i2c1_b_2_default {
			default_mux {
				function = "i2c1";
				groups = "i2c1_b_2";
			};
			default_cfg1 {
				pins = "GPIO16_AD3", "GPIO17_AD4"; /* SDA/SCL */
				ste,config = <&in_nopull>;
			};
		};

		i2c1_b_2_sleep: i2c1_b_2_sleep {
			sleep_cfg1 {
				pins = "GPIO16_AD3", "GPIO17_AD4"; /* SDA/SCL */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};
	};

	i2c2 {
		i2c2_b_1_default: i2c2_b_1_default {
			default_mux {
				function = "i2c2";
				groups = "i2c2_b_1";
			};
			default_cfg1 {
				pins = "GPIO8_AD5", "GPIO9_AE4"; /* SDA/SCL */
				ste,config = <&in_nopull>;
			};
		};

		i2c2_b_1_sleep: i2c2_b_1_sleep {
			sleep_cfg1 {
				pins = "GPIO8_AD5", "GPIO9_AE4"; /* SDA/SCL */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};

		i2c2_b_2_default: i2c2_b_2_default {
			default_mux {
				function = "i2c2";
				groups = "i2c2_b_2";
			};
			default_cfg1 {
				pins = "GPIO10_AF5", "GPIO11_AG4"; /* SDA/SCL */
				ste,config = <&in_nopull>;
			};
		};

		i2c2_b_2_sleep: i2c2_b_2_sleep {
			sleep_cfg1 {
				pins = "GPIO10_AF5", "GPIO11_AG4"; /* SDA/SCL */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};
	};

	i2c3 {
		i2c3_c_2_default: i2c3_c_2_default {
			default_mux {
				function = "i2c3";
				groups = "i2c3_c_2";
			};
			default_cfg1 {
				pins = "GPIO229_AG7", "GPIO230_AF7"; /* SDA/SCL */
				ste,config = <&in_nopull>;
			};
		};

		i2c3_c_2_sleep: i2c3_c_2_sleep {
			sleep_cfg1 {
				pins = "GPIO229_AG7", "GPIO230_AF7"; /* SDA/SCL */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};
	};

	/*
	 * Activating I2C4 will conflict with UART1 about the same pins so do not
	 * enable I2C4 and UART1 at the same time.
	 */
	i2c4 {
		i2c4_b_1_default: i2c4_b_1_default {
			default_mux {
				function = "i2c4";
				groups = "i2c4_b_1";
			};
			default_cfg1 {
				pins = "GPIO4_AH6", "GPIO5_AG6"; /* SDA/SCL */
				ste,config = <&in_nopull>;
			};
		};

		i2c4_b_1_sleep: i2c4_b_1_sleep {
			sleep_cfg1 {
				pins = "GPIO4_AH6", "GPIO5_AG6"; /* SDA/SCL */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};
	};

	/* Settings for all MMC/SD/SDIO default and sleep states */
	sdi0 {
		/* This is the external SD card slot, 4 bits wide */
		mc0_a_1_default: mc0_a_1_default {
			default_mux {
				function = "mc0";
				groups = "mc0_a_1";
			};
			default_cfg1 {
				pins =
				"GPIO18_AC2", /* CMDDIR */
				"GPIO19_AC1", /* DAT0DIR */
				"GPIO20_AB4"; /* DAT2DIR */
				ste,config = <&out_hi>;
			};
			default_cfg2 {
				pins = "GPIO22_AA3"; /* FBCLK */
				ste,config = <&in_nopull>;
			};
			default_cfg3 {
				pins = "GPIO23_AA4"; /* CLK */
				ste,config = <&out_lo>;
			};
			default_cfg4 {
				pins =
				"GPIO24_AB2", /* CMD */
				"GPIO25_Y4", /* DAT0 */
				"GPIO26_Y2", /* DAT1 */
				"GPIO27_AA2", /* DAT2 */
				"GPIO28_AA1"; /* DAT3 */
				ste,config = <&in_pu>;
			};
		};

		mc0_a_1_sleep: mc0_a_1_sleep {
			sleep_cfg1 {
				pins =
				"GPIO18_AC2", /* CMDDIR */
				"GPIO19_AC1", /* DAT0DIR */
				"GPIO20_AB4"; /* DAT2DIR */
				ste,config = <&slpm_out_hi_wkup_pdis>;
			};
			sleep_cfg2 {
				pins =
				"GPIO22_AA3", /* FBCLK */
				"GPIO24_AB2", /* CMD */
				"GPIO25_Y4", /* DAT0 */
				"GPIO26_Y2", /* DAT1 */
				"GPIO27_AA2", /* DAT2 */
				"GPIO28_AA1"; /* DAT3 */
				ste,config = <&slpm_in_wkup_pdis>;
			};
			sleep_cfg3 {
				pins = "GPIO23_AA4"; /* CLK */
				ste,config = <&slpm_out_lo_wkup_pdis>;
			};
		};

		mc0_a_2_default: mc0_a_2_default {
			default_mux {
				function = "mc0";
				groups = "mc0_a_2";
			};
			default_cfg1 {
				pins = "GPIO22_AA3"; /* FBCLK */
				ste,config = <&in_nopull>;
			};
			default_cfg2 {
				pins = "GPIO23_AA4"; /* CLK */
				ste,config = <&out_lo>;
			};
			default_cfg3 {
				pins =
				"GPIO24_AB2", /* CMD */
				"GPIO25_Y4", /* DAT0 */
				"GPIO26_Y2", /* DAT1 */
				"GPIO27_AA2", /* DAT2 */
				"GPIO28_AA1"; /* DAT3 */
				ste,config = <&in_pu>;
			};
		};

		mc0_a_2_sleep: mc0_a_2_sleep {
			sleep_cfg1 {
				pins =
				"GPIO22_AA3", /* FBCLK */
				"GPIO24_AB2", /* CMD */
				"GPIO25_Y4", /* DAT0 */
				"GPIO26_Y2", /* DAT1 */
				"GPIO27_AA2", /* DAT2 */
				"GPIO28_AA1"; /* DAT3 */
				ste,config = <&slpm_in_wkup_pdis>;
			};
			sleep_cfg2 {
				pins = "GPIO23_AA4"; /* CLK */
				ste,config = <&slpm_out_lo_wkup_pdis>;
			};
		};
	};

	sdi1 {
		/* This is the WLAN SDIO 4 bits wide */
		mc1_a_1_default: mc1_a_1_default {
			default_mux {
				function = "mc1";
				groups = "mc1_a_1";
			};
			default_cfg1 {
				pins = "GPIO208_AH16"; /* CLK */
				ste,config = <&out_lo>;
			};
			default_cfg2 {
				pins = "GPIO209_AG15"; /* FBCLK */
				ste,config = <&in_nopull>;
			};
			default_cfg3 {
				pins =
				"GPIO210_AJ15", /* CMD */
				"GPIO211_AG14", /* DAT0 */
				"GPIO212_AF13", /* DAT1 */
				"GPIO213_AG13", /* DAT2 */
				"GPIO214_AH15"; /* DAT3 */
				ste,config = <&in_pu>;
			};
		};

		mc1_a_1_sleep: mc1_a_1_sleep {
			sleep_cfg1 {
				pins = "GPIO208_AH16"; /* CLK */
				ste,config = <&slpm_out_lo_wkup_pdis>;
			};
			sleep_cfg2 {
				pins =
				"GPIO209_AG15", /* FBCLK */
				"GPIO210_AJ15", /* CMD */
				"GPIO211_AG14", /* DAT0 */
				"GPIO212_AF13", /* DAT1 */
				"GPIO213_AG13", /* DAT2 */
				"GPIO214_AH15"; /* DAT3 */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};

		mc1_a_2_default: mc1_a_2_default {
			default_mux {
				function = "mc1";
				groups = "mc1_a_2";
			};
			default_cfg1 {
				pins = "GPIO208_AH16"; /* CLK */
				ste,config = <&out_lo>;
			};
			default_cfg2 {
				pins =
				"GPIO210_AJ15", /* CMD */
				"GPIO211_AG14", /* DAT0 */
				"GPIO212_AF13", /* DAT1 */
				"GPIO213_AG13", /* DAT2 */
				"GPIO214_AH15"; /* DAT3 */
				ste,config = <&in_pu>;
			};
		};

		mc1_a_2_sleep: mc1_a_2_sleep {
			sleep_cfg1 {
				pins = "GPIO208_AH16"; /* CLK */
				ste,config = <&slpm_out_lo_wkup_pdis>;
			};
			sleep_cfg2 {
				pins =
				"GPIO210_AJ15", /* CMD */
				"GPIO211_AG14", /* DAT0 */
				"GPIO212_AF13", /* DAT1 */
				"GPIO213_AG13", /* DAT2 */
				"GPIO214_AH15"; /* DAT3 */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};
	};

	sdi2 {
		/* This is the eMMC 8 bits wide, usually PoP eMMC */
		mc2_a_1_default: mc2_a_1_default {
			default_mux {
				function = "mc2";
				groups = "mc2_a_1";
			};
			default_cfg1 {
				pins = "GPIO128_A5"; /* CLK */
				ste,config = <&out_lo>;
			};
			default_cfg2 {
				pins = "GPIO130_C8"; /* FBCLK */
				ste,config = <&in_nopull>;
			};
			default_cfg3 {
				pins =
				"GPIO129_B4", /* CMD */
				"GPIO131_A12", /* DAT0 */
				"GPIO132_C10", /* DAT1 */
				"GPIO133_B10", /* DAT2 */
				"GPIO134_B9", /* DAT3 */
				"GPIO135_A9", /* DAT4 */
				"GPIO136_C7", /* DAT5 */
				"GPIO137_A7", /* DAT6 */
				"GPIO138_C5"; /* DAT7 */
				ste,config = <&in_pu>;
			};
		};

		mc2_a_1_sleep: mc2_a_1_sleep {
			sleep_cfg1 {
				pins = "GPIO128_A5"; /* CLK */
				ste,config = <&out_lo_wkup_pdis>;
			};
			sleep_cfg2 {
				pins =
				"GPIO130_C8", /* FBCLK */
				"GPIO129_B4"; /* CMD */
				ste,config = <&in_wkup_pdis_en>;
			};
			sleep_cfg3 {
				pins =
				"GPIO131_A12", /* DAT0 */
				"GPIO132_C10", /* DAT1 */
				"GPIO133_B10", /* DAT2 */
				"GPIO134_B9", /* DAT3 */
				"GPIO135_A9", /* DAT4 */
				"GPIO136_C7", /* DAT5 */
				"GPIO137_A7", /* DAT6 */
				"GPIO138_C5"; /* DAT7 */
				ste,config = <&in_wkup_pdis>;
			};
		};
	};

	sdi4 {
		/* This is the eMMC 8 bits wide, usually PCB-mounted eMMC */
		mc4_a_1_default: mc4_a_1_default {
			default_mux {
				function = "mc4";
				groups = "mc4_a_1";
			};
			default_cfg1 {
				pins = "GPIO203_AE23"; /* CLK */
				ste,config = <&out_lo>;
			};
			default_cfg2 {
				pins = "GPIO202_AF25"; /* FBCLK */
				ste,config = <&in_nopull>;
			};
			default_cfg3 {
				pins =
				"GPIO201_AF24", /* CMD */
				"GPIO200_AH26", /* DAT0 */
				"GPIO199_AH23", /* DAT1 */
				"GPIO198_AG25", /* DAT2 */
				"GPIO197_AH24", /* DAT3 */
				"GPIO207_AJ23", /* DAT4 */
				"GPIO206_AG24", /* DAT5 */
				"GPIO205_AG23", /* DAT6 */
				"GPIO204_AF23"; /* DAT7 */
				ste,config = <&in_pu>;
			};
		};

		mc4_a_1_sleep: mc4_a_1_sleep {
			sleep_cfg1 {
				pins = "GPIO203_AE23"; /* CLK */
				ste,config = <&out_lo_wkup_pdis>;
			};
			sleep_cfg2 {
				pins =
				"GPIO202_AF25", /* FBCLK */
				"GPIO201_AF24", /* CMD */
				"GPIO200_AH26", /* DAT0 */
				"GPIO199_AH23", /* DAT1 */
				"GPIO198_AG25", /* DAT2 */
				"GPIO197_AH24", /* DAT3 */
				"GPIO207_AJ23", /* DAT4 */
				"GPIO206_AG24", /* DAT5 */
				"GPIO205_AG23", /* DAT6 */
				"GPIO204_AF23"; /* DAT7 */
				ste,config = <&slpm_in_wkup_pdis>;
			};
		};
	};

	/*
	 * Multi-rate serial ports (MSPs) - MSP3 output is internal and
	 * cannot be muxed onto any pins.
	 */
	msp0 {
		msp0txrxtfstck_a_1_default: msp0txrxtfstck_a_1_default {
			default_msp0_mux {
				function = "msp0";
				groups = "msp0txrx_a_1", "msp0tfstck_a_1";
			};
			default_msp0_cfg {
				pins =
				"GPIO12_AC4", /* TXD */
				"GPIO15_AC3", /* RXD */
				"GPIO13_AF3", /* TFS */
				"GPIO14_AE3"; /* TCK */
				ste,config = <&in_nopull>;
			};
		};
	};

	msp1 {
		msp1txrx_a_1_default: msp1txrx_a_1_default {
			default_mux {
				function = "msp1";
				groups = "msp1txrx_a_1", "msp1_a_1";
			};
			default_cfg1 {
				pins = "GPIO33_AF2";
				ste,config = <&out_lo>;
			};
			default_cfg2 {
				pins =
				"GPIO34_AE1",
				"GPIO35_AE2",
				"GPIO36_AG2";
				ste,config = <&in_nopull>;
			};
		};
	};

	msp2 {
		msp2_a_1_default: msp2_a_1_default {
			/* MSP2 usually used for HDMI audio */
			default_mux {
				function = "msp2";
				groups = "msp2_a_1";
			};
			default_cfg1 {
				pins =
				"GPIO193_AH27", /* TXD */
				"GPIO194_AF27", /* TCK */
				"GPIO195_AG28"; /* TFS */
				ste,config = <&in_pd>;
			};
			default_cfg2 {
				pins = "GPIO196_AG26"; /* RXD */
				ste,config = <&out_lo>;
			};
		};
	};

	musb {
		usb_a_1_default: usb_a_1_default {
			default_mux {
				function = "usb";
				groups = "usb_a_1";
			};
			default_cfg1 {
				pins =
				"GPIO256_AF28", /* NXT */
				"GPIO258_AD29", /* XCLK */
				"GPIO259_AC29", /* DIR */
				"GPIO260_AD28", /* DAT7 */
				"GPIO261_AD26", /* DAT6 */
				"GPIO262_AE26", /* DAT5 */
				"GPIO263_AG29", /* DAT4 */
				"GPIO264_AE27", /* DAT3 */
				"GPIO265_AD27", /* DAT2 */
				"GPIO266_AC28", /* DAT1 */
				"GPIO267_AC27"; /* DAT0 */
				ste,config = <&in_nopull>;
			};
			default_cfg2 {
				pins = "GPIO257_AE29"; /* STP */
				ste,config = <&out_hi>;
			};
		};

		usb_a_1_sleep: usb_a_1_sleep {
			sleep_cfg1 {
				pins =
				"GPIO256_AF28", /* NXT */
				"GPIO258_AD29", /* XCLK */
				"GPIO259_AC29"; /* DIR */
				ste,config = <&slpm_wkup_pdis_en>;
			};
			sleep_cfg2 {
				pins = "GPIO257_AE29"; /* STP */
				ste,config = <&slpm_out_hi_wkup_pdis>;
			};
			sleep_cfg3 {
				pins =
				"GPIO260_AD28", /* DAT7 */
				"GPIO261_AD26", /* DAT6 */
				"GPIO262_AE26", /* DAT5 */
				"GPIO263_AG29", /* DAT4 */
				"GPIO264_AE27", /* DAT3 */
				"GPIO265_AD27", /* DAT2 */
				"GPIO266_AC28", /* DAT1 */
				"GPIO267_AC27"; /* DAT0 */
				ste,config = <&slpm_in_wkup_pdis_en>;
			};
		};
	};
};