18c2ecf20Sopenharmony_ciST Ericsson abx500 pinmux controller
28c2ecf20Sopenharmony_ci
38c2ecf20Sopenharmony_ciRequired properties:
48c2ecf20Sopenharmony_ci- compatible: "stericsson,ab8500-gpio",  "stericsson,ab8540-gpio",
58c2ecf20Sopenharmony_ci	      "stericsson,ab8505-gpio", "stericsson,ab9540-gpio",
68c2ecf20Sopenharmony_ci
78c2ecf20Sopenharmony_ciPlease refer to pinctrl-bindings.txt in this directory for details of the
88c2ecf20Sopenharmony_cicommon pinctrl bindings used by client devices, including the meaning of the
98c2ecf20Sopenharmony_ciphrase "pin configuration node".
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_ciST Ericsson's pin configuration nodes use the generic pin multiplexing
128c2ecf20Sopenharmony_ciand pin configuration bindings, see pinctrl-bindings.txt
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_ciExample board file extract:
158c2ecf20Sopenharmony_ci
168c2ecf20Sopenharmony_ci&pinctrl_abx500 {
178c2ecf20Sopenharmony_ci	pinctrl-names = "default";
188c2ecf20Sopenharmony_ci	pinctrl-0 = <&sysclkreq2_default_mode>, <&sysclkreq3_default_mode>, <&gpio3_default_mode>, <&sysclkreq6_default_mode>, <&pwmout1_default_mode>, <&pwmout2_default_mode>, <&pwmout3_default_mode>, <&adi1_default_mode>, <&dmic12_default_mode>, <&dmic34_default_mode>, <&dmic56_default_mode>, <&sysclkreq5_default_mode>, <&batremn_default_mode>, <&service_default_mode>, <&pwrctrl0_default_mode>, <&pwrctrl1_default_mode>, <&pwmextvibra1_default_mode>, <&pwmextvibra2_default_mode>, <&gpio51_default_mode>, <&gpio52_default_mode>, <&gpio53_default_mode>, <&gpio54_default_mode>, <&pdmclkdat_default_mode>;
198c2ecf20Sopenharmony_ci
208c2ecf20Sopenharmony_ci	sysclkreq2 {
218c2ecf20Sopenharmony_ci		sysclkreq2_default_mode: sysclkreq2_default {
228c2ecf20Sopenharmony_ci			default_mux {
238c2ecf20Sopenharmony_ci				function = "sysclkreq";
248c2ecf20Sopenharmony_ci				groups = "sysclkreq2_d_1";
258c2ecf20Sopenharmony_ci			};
268c2ecf20Sopenharmony_ci			default_cfg {
278c2ecf20Sopenharmony_ci				pins = "GPIO1";
288c2ecf20Sopenharmony_ci				bias-disable;
298c2ecf20Sopenharmony_ci			};
308c2ecf20Sopenharmony_ci		};
318c2ecf20Sopenharmony_ci	};
328c2ecf20Sopenharmony_ci	sysclkreq3 {
338c2ecf20Sopenharmony_ci		sysclkreq3_default_mode: sysclkreq3_default {
348c2ecf20Sopenharmony_ci			default_mux {
358c2ecf20Sopenharmony_ci				function = "sysclkreq";
368c2ecf20Sopenharmony_ci				groups = "sysclkreq3_d_1";
378c2ecf20Sopenharmony_ci			};
388c2ecf20Sopenharmony_ci			default_cfg {
398c2ecf20Sopenharmony_ci				pins = "GPIO2";
408c2ecf20Sopenharmony_ci				output-low;
418c2ecf20Sopenharmony_ci			};
428c2ecf20Sopenharmony_ci		};
438c2ecf20Sopenharmony_ci	};
448c2ecf20Sopenharmony_ci	gpio3 {
458c2ecf20Sopenharmony_ci		gpio3_default_mode: gpio3_default {
468c2ecf20Sopenharmony_ci			default_mux {
478c2ecf20Sopenharmony_ci				function = "gpio";
488c2ecf20Sopenharmony_ci				groups = "gpio3_a_1";
498c2ecf20Sopenharmony_ci			};
508c2ecf20Sopenharmony_ci			default_cfg {
518c2ecf20Sopenharmony_ci				pins = "GPIO3";
528c2ecf20Sopenharmony_ci				output-low;
538c2ecf20Sopenharmony_ci			};
548c2ecf20Sopenharmony_ci		};
558c2ecf20Sopenharmony_ci	};
568c2ecf20Sopenharmony_ci	sysclkreq6 {
578c2ecf20Sopenharmony_ci		sysclkreq6_default_mode: sysclkreq6_default {
588c2ecf20Sopenharmony_ci			default_mux {
598c2ecf20Sopenharmony_ci				function = "sysclkreq";
608c2ecf20Sopenharmony_ci				groups = "sysclkreq6_d_1";
618c2ecf20Sopenharmony_ci			};
628c2ecf20Sopenharmony_ci			default_cfg {
638c2ecf20Sopenharmony_ci				pins = "GPIO4";
648c2ecf20Sopenharmony_ci				bias-disable;
658c2ecf20Sopenharmony_ci			};
668c2ecf20Sopenharmony_ci		};
678c2ecf20Sopenharmony_ci	};
688c2ecf20Sopenharmony_ci	pwmout1 {
698c2ecf20Sopenharmony_ci		pwmout1_default_mode: pwmout1_default {
708c2ecf20Sopenharmony_ci			default_mux {
718c2ecf20Sopenharmony_ci				function = "pwmout";
728c2ecf20Sopenharmony_ci				groups = "pwmout1_d_1";
738c2ecf20Sopenharmony_ci			};
748c2ecf20Sopenharmony_ci			default_cfg {
758c2ecf20Sopenharmony_ci				pins = "GPIO14";
768c2ecf20Sopenharmony_ci				output-low;
778c2ecf20Sopenharmony_ci			};
788c2ecf20Sopenharmony_ci		};
798c2ecf20Sopenharmony_ci	};
808c2ecf20Sopenharmony_ci	pwmout2 {
818c2ecf20Sopenharmony_ci		pwmout2_default_mode: pwmout2_default {
828c2ecf20Sopenharmony_ci			pwmout2_default_mux {
838c2ecf20Sopenharmony_ci				function = "pwmout";
848c2ecf20Sopenharmony_ci				groups = "pwmout2_d_1";
858c2ecf20Sopenharmony_ci			};
868c2ecf20Sopenharmony_ci			pwmout2_default_cfg {
878c2ecf20Sopenharmony_ci				pins = "GPIO15";
888c2ecf20Sopenharmony_ci				output-low;
898c2ecf20Sopenharmony_ci			};
908c2ecf20Sopenharmony_ci		};
918c2ecf20Sopenharmony_ci	};
928c2ecf20Sopenharmony_ci	pwmout3 {
938c2ecf20Sopenharmony_ci		pwmout3_default_mode: pwmout3_default {
948c2ecf20Sopenharmony_ci			pwmout3_default_mux {
958c2ecf20Sopenharmony_ci				function = "pwmout";
968c2ecf20Sopenharmony_ci				groups = "pwmout3_d_1";
978c2ecf20Sopenharmony_ci			};
988c2ecf20Sopenharmony_ci			pwmout3_default_cfg {
998c2ecf20Sopenharmony_ci				pins = "GPIO16";
1008c2ecf20Sopenharmony_ci				output-low;
1018c2ecf20Sopenharmony_ci			};
1028c2ecf20Sopenharmony_ci		};
1038c2ecf20Sopenharmony_ci	};
1048c2ecf20Sopenharmony_ci	adi1 {
1058c2ecf20Sopenharmony_ci
1068c2ecf20Sopenharmony_ci		adi1_default_mode: adi1_default {
1078c2ecf20Sopenharmony_ci			adi1_default_mux {
1088c2ecf20Sopenharmony_ci				function = "adi1";
1098c2ecf20Sopenharmony_ci				groups = "adi1_d_1";
1108c2ecf20Sopenharmony_ci			};
1118c2ecf20Sopenharmony_ci			adi1_default_cfg1 {
1128c2ecf20Sopenharmony_ci				pins = "GPIO17","GPIO19","GPIO20";
1138c2ecf20Sopenharmony_ci				bias-disable;
1148c2ecf20Sopenharmony_ci			};
1158c2ecf20Sopenharmony_ci			adi1_default_cfg2 {
1168c2ecf20Sopenharmony_ci				pins = "GPIO18";
1178c2ecf20Sopenharmony_ci				output-low;
1188c2ecf20Sopenharmony_ci			};
1198c2ecf20Sopenharmony_ci		};
1208c2ecf20Sopenharmony_ci	};
1218c2ecf20Sopenharmony_ci	dmic12 {
1228c2ecf20Sopenharmony_ci		dmic12_default_mode: dmic12_default {
1238c2ecf20Sopenharmony_ci			dmic12_default_mux {
1248c2ecf20Sopenharmony_ci				function = "dmic";
1258c2ecf20Sopenharmony_ci				groups = "dmic12_d_1";
1268c2ecf20Sopenharmony_ci			};
1278c2ecf20Sopenharmony_ci			dmic12_default_cfg1 {
1288c2ecf20Sopenharmony_ci				pins = "GPIO27";
1298c2ecf20Sopenharmony_ci				output-low;
1308c2ecf20Sopenharmony_ci			};
1318c2ecf20Sopenharmony_ci			dmic12_default_cfg2 {
1328c2ecf20Sopenharmony_ci				pins = "GPIO28";
1338c2ecf20Sopenharmony_ci				bias-disable;
1348c2ecf20Sopenharmony_ci			};
1358c2ecf20Sopenharmony_ci		};
1368c2ecf20Sopenharmony_ci	};
1378c2ecf20Sopenharmony_ci	dmic34 {
1388c2ecf20Sopenharmony_ci		dmic34_default_mode: dmic34_default {
1398c2ecf20Sopenharmony_ci			dmic34_default_mux {
1408c2ecf20Sopenharmony_ci				function = "dmic";
1418c2ecf20Sopenharmony_ci				groups = "dmic34_d_1";
1428c2ecf20Sopenharmony_ci			};
1438c2ecf20Sopenharmony_ci			dmic34_default_cfg1 {
1448c2ecf20Sopenharmony_ci				pins = "GPIO29";
1458c2ecf20Sopenharmony_ci				output-low;
1468c2ecf20Sopenharmony_ci			};
1478c2ecf20Sopenharmony_ci			dmic34_default_cfg2 {
1488c2ecf20Sopenharmony_ci				pins = "GPIO30";
1498c2ecf20Sopenharmony_ci				bias-disable;{
1508c2ecf20Sopenharmony_ci
1518c2ecf20Sopenharmony_ci			};
1528c2ecf20Sopenharmony_ci		};
1538c2ecf20Sopenharmony_ci	};
1548c2ecf20Sopenharmony_ci	dmic56 {
1558c2ecf20Sopenharmony_ci		dmic56_default_mode: dmic56_default {
1568c2ecf20Sopenharmony_ci			dmic56_default_mux {
1578c2ecf20Sopenharmony_ci				function = "dmic";
1588c2ecf20Sopenharmony_ci				groups = "dmic56_d_1";
1598c2ecf20Sopenharmony_ci			};
1608c2ecf20Sopenharmony_ci			dmic56_default_cfg1 {
1618c2ecf20Sopenharmony_ci				pins = "GPIO31";
1628c2ecf20Sopenharmony_ci				output-low;
1638c2ecf20Sopenharmony_ci			};
1648c2ecf20Sopenharmony_ci			dmic56_default_cfg2 {
1658c2ecf20Sopenharmony_ci				pins = "GPIO32";
1668c2ecf20Sopenharmony_ci				bias-disable;
1678c2ecf20Sopenharmony_ci			};
1688c2ecf20Sopenharmony_ci		};
1698c2ecf20Sopenharmony_ci	};
1708c2ecf20Sopenharmony_ci	sysclkreq5 {
1718c2ecf20Sopenharmony_ci		sysclkreq5_default_mode: sysclkreq5_default {
1728c2ecf20Sopenharmony_ci			sysclkreq5_default_mux {
1738c2ecf20Sopenharmony_ci				function = "sysclkreq";
1748c2ecf20Sopenharmony_ci				groups = "sysclkreq5_d_1";
1758c2ecf20Sopenharmony_ci			};
1768c2ecf20Sopenharmony_ci			sysclkreq5_default_cfg {
1778c2ecf20Sopenharmony_ci				pins = "GPIO42";
1788c2ecf20Sopenharmony_ci				output-low;
1798c2ecf20Sopenharmony_ci			};
1808c2ecf20Sopenharmony_ci		};
1818c2ecf20Sopenharmony_ci	};
1828c2ecf20Sopenharmony_ci	batremn {
1838c2ecf20Sopenharmony_ci		batremn_default_mode: batremn_default {
1848c2ecf20Sopenharmony_ci			batremn_default_mux {
1858c2ecf20Sopenharmony_ci				function = "batremn";
1868c2ecf20Sopenharmony_ci				groups = "batremn_d_1";
1878c2ecf20Sopenharmony_ci			};
1888c2ecf20Sopenharmony_ci			batremn_default_cfg {
1898c2ecf20Sopenharmony_ci				pins = "GPIO43";
1908c2ecf20Sopenharmony_ci				bias-disable;
1918c2ecf20Sopenharmony_ci			};
1928c2ecf20Sopenharmony_ci		};
1938c2ecf20Sopenharmony_ci	};
1948c2ecf20Sopenharmony_ci	service {
1958c2ecf20Sopenharmony_ci		service_default_mode: service_default {
1968c2ecf20Sopenharmony_ci			service_default_mux {
1978c2ecf20Sopenharmony_ci				function = "service";
1988c2ecf20Sopenharmony_ci				groups = "service_d_1";
1998c2ecf20Sopenharmony_ci			};
2008c2ecf20Sopenharmony_ci			service_default_cfg {
2018c2ecf20Sopenharmony_ci				pins = "GPIO44";
2028c2ecf20Sopenharmony_ci				bias-disable;
2038c2ecf20Sopenharmony_ci			};
2048c2ecf20Sopenharmony_ci		};
2058c2ecf20Sopenharmony_ci	};
2068c2ecf20Sopenharmony_ci	pwrctrl0 {
2078c2ecf20Sopenharmony_ci		pwrctrl0_default_mux: pwrctrl0_mux {
2088c2ecf20Sopenharmony_ci			pwrctrl0_default_mux {
2098c2ecf20Sopenharmony_ci				function = "pwrctrl";
2108c2ecf20Sopenharmony_ci				groups = "pwrctrl0_d_1";
2118c2ecf20Sopenharmony_ci			};
2128c2ecf20Sopenharmony_ci		};
2138c2ecf20Sopenharmony_ci		pwrctrl0_default_mode: pwrctrl0_default {
2148c2ecf20Sopenharmony_ci			pwrctrl0_default_cfg {
2158c2ecf20Sopenharmony_ci				pins = "GPIO45";
2168c2ecf20Sopenharmony_ci				bias-disable;
2178c2ecf20Sopenharmony_ci			};
2188c2ecf20Sopenharmony_ci		};
2198c2ecf20Sopenharmony_ci	};
2208c2ecf20Sopenharmony_ci	pwrctrl1 {
2218c2ecf20Sopenharmony_ci		pwrctrl1_default_mux: pwrctrl1_mux {
2228c2ecf20Sopenharmony_ci			pwrctrl1_default_mux {
2238c2ecf20Sopenharmony_ci				function = "pwrctrl";
2248c2ecf20Sopenharmony_ci				groups = "pwrctrl1_d_1";
2258c2ecf20Sopenharmony_ci			};
2268c2ecf20Sopenharmony_ci		};
2278c2ecf20Sopenharmony_ci		pwrctrl1_default_mode: pwrctrl1_default {
2288c2ecf20Sopenharmony_ci			pwrctrl1_default_cfg {
2298c2ecf20Sopenharmony_ci				pins = "GPIO46";
2308c2ecf20Sopenharmony_ci				bias-disable;
2318c2ecf20Sopenharmony_ci			};
2328c2ecf20Sopenharmony_ci		};
2338c2ecf20Sopenharmony_ci	};
2348c2ecf20Sopenharmony_ci	pwmextvibra1 {
2358c2ecf20Sopenharmony_ci		pwmextvibra1_default_mode: pwmextvibra1_default {
2368c2ecf20Sopenharmony_ci			pwmextvibra1_default_mux {
2378c2ecf20Sopenharmony_ci				function = "pwmextvibra";
2388c2ecf20Sopenharmony_ci				groups = "pwmextvibra1_d_1";
2398c2ecf20Sopenharmony_ci			};
2408c2ecf20Sopenharmony_ci			pwmextvibra1_default_cfg {
2418c2ecf20Sopenharmony_ci				pins = "GPIO47";
2428c2ecf20Sopenharmony_ci				bias-disable;
2438c2ecf20Sopenharmony_ci			};
2448c2ecf20Sopenharmony_ci		};
2458c2ecf20Sopenharmony_ci	};
2468c2ecf20Sopenharmony_ci	pwmextvibra2 {
2478c2ecf20Sopenharmony_ci		pwmextvibra2_default_mode: pwmextvibra2_default {
2488c2ecf20Sopenharmony_ci			pwmextvibra2_default_mux {
2498c2ecf20Sopenharmony_ci				function = "pwmextvibra";
2508c2ecf20Sopenharmony_ci				groups = "pwmextvibra2_d_1";
2518c2ecf20Sopenharmony_ci			};
2528c2ecf20Sopenharmony_ci			pwmextvibra1_default_cfg {
2538c2ecf20Sopenharmony_ci				pins = "GPIO48";
2548c2ecf20Sopenharmony_ci				bias-disable;
2558c2ecf20Sopenharmony_ci			};
2568c2ecf20Sopenharmony_ci		};
2578c2ecf20Sopenharmony_ci	};
2588c2ecf20Sopenharmony_ci	gpio51 {
2598c2ecf20Sopenharmony_ci		gpio51_default_mode: gpio51_default {
2608c2ecf20Sopenharmony_ci				gpio51_default_mux {
2618c2ecf20Sopenharmony_ci				function = "gpio";
2628c2ecf20Sopenharmony_ci				groups = "gpio51_a_1";
2638c2ecf20Sopenharmony_ci			};
2648c2ecf20Sopenharmony_ci			gpio51_default_cfg {
2658c2ecf20Sopenharmony_ci				pins = "GPIO51";
2668c2ecf20Sopenharmony_ci				output-low;
2678c2ecf20Sopenharmony_ci			};
2688c2ecf20Sopenharmony_ci		};
2698c2ecf20Sopenharmony_ci	};
2708c2ecf20Sopenharmony_ci	gpio52 {
2718c2ecf20Sopenharmony_ci		gpio52_default_mode: gpio52_default {
2728c2ecf20Sopenharmony_ci			gpio52_default_mux {
2738c2ecf20Sopenharmony_ci				function = "gpio";
2748c2ecf20Sopenharmony_ci				groups = "gpio52_a_1";
2758c2ecf20Sopenharmony_ci			};
2768c2ecf20Sopenharmony_ci			gpio52_default_cfg {
2778c2ecf20Sopenharmony_ci				pins = "GPIO52";
2788c2ecf20Sopenharmony_ci				bias-pull-down;
2798c2ecf20Sopenharmony_ci			};
2808c2ecf20Sopenharmony_ci		};
2818c2ecf20Sopenharmony_ci	};
2828c2ecf20Sopenharmony_ci	gpio53 {
2838c2ecf20Sopenharmony_ci		gpio53_default_mode: gpio53_default {
2848c2ecf20Sopenharmony_ci			gpio53_default_mux {
2858c2ecf20Sopenharmony_ci				function = "gpio";
2868c2ecf20Sopenharmony_ci				groups = "gpio53_a_1";
2878c2ecf20Sopenharmony_ci			};
2888c2ecf20Sopenharmony_ci			gpio53_default_cfg {
2898c2ecf20Sopenharmony_ci				pins = "GPIO53";
2908c2ecf20Sopenharmony_ci				bias-pull-down;
2918c2ecf20Sopenharmony_ci			};
2928c2ecf20Sopenharmony_ci		};
2938c2ecf20Sopenharmony_ci	};
2948c2ecf20Sopenharmony_ci	gpio54 {
2958c2ecf20Sopenharmony_ci		gpio54_default_mode: gpio54_default {
2968c2ecf20Sopenharmony_ci			gpio54_default_mux {
2978c2ecf20Sopenharmony_ci				function = "gpio";
2988c2ecf20Sopenharmony_ci				groups = "gpio54_a_1";
2998c2ecf20Sopenharmony_ci			};
3008c2ecf20Sopenharmony_ci			gpio54_default_cfg {
3018c2ecf20Sopenharmony_ci				pins = "GPIO54";
3028c2ecf20Sopenharmony_ci				output-low;
3038c2ecf20Sopenharmony_ci			};
3048c2ecf20Sopenharmony_ci		};
3058c2ecf20Sopenharmony_ci	};
3068c2ecf20Sopenharmony_ci	pdmclkdat {
3078c2ecf20Sopenharmony_ci		pdmclkdat_default_mode: pdmclkdat_default {
3088c2ecf20Sopenharmony_ci			pdmclkdat_default_mux {
3098c2ecf20Sopenharmony_ci				function = "pdm";
3108c2ecf20Sopenharmony_ci				groups = "pdmclkdat_d_1";
3118c2ecf20Sopenharmony_ci			};
3128c2ecf20Sopenharmony_ci			pdmclkdat_default_cfg {
3138c2ecf20Sopenharmony_ci				pins = "GPIO55", "GPIO56";
3148c2ecf20Sopenharmony_ci				bias-disable;
3158c2ecf20Sopenharmony_ci			};
3168c2ecf20Sopenharmony_ci		};
3178c2ecf20Sopenharmony_ci	};
3188c2ecf20Sopenharmony_ci};
319