Commit c74803ee authored by Jonathan Marek's avatar Jonathan Marek Committed by Linus Walleij
Browse files

pinctrl: qcom: sm8450: Add egpio support



This mirrors egpio support added for sc7280. This change is necessary for
gpios 165 to 209 to be driven by APSS.

Signed-off-by: default avatarJonathan Marek <jonathan@marek.ca>
Link: https://lore.kernel.org/r/20220210131210.24605-1-jonathan@marek.ca


Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 8d4c0d18
Loading
Loading
Loading
Loading
+61 −45
Original line number Diff line number Diff line
@@ -46,6 +46,8 @@
		.mux_bit = 2,			\
		.pull_bit = 0,			\
		.drv_bit = 6,			\
		.egpio_enable = 12,		\
		.egpio_present = 11,		\
		.oe_bit = 9,			\
		.in_bit = 0,			\
		.out_bit = 1,			\
@@ -567,6 +569,7 @@ enum sm8450_functions {
	msm_mux_ddr_pxi2,
	msm_mux_ddr_pxi3,
	msm_mux_dp_hot,
	msm_mux_egpio,
	msm_mux_gcc_gp1,
	msm_mux_gcc_gp2,
	msm_mux_gcc_gp3,
@@ -719,6 +722,17 @@ static const char * const gpio_groups[] = {
	"gpio207", "gpio208", "gpio209",
};

static const char * const egpio_groups[] = {
	"gpio165", "gpio166", "gpio167", "gpio168", "gpio169", "gpio170",
	"gpio171", "gpio172", "gpio173", "gpio174", "gpio175", "gpio176",
	"gpio177", "gpio178", "gpio179", "gpio180", "gpio181", "gpio182",
	"gpio183", "gpio184", "gpio185", "gpio186", "gpio187", "gpio188",
	"gpio189", "gpio190", "gpio191", "gpio192", "gpio193", "gpio194",
	"gpio195", "gpio196", "gpio197", "gpio198", "gpio199", "gpio200",
	"gpio201", "gpio202", "gpio203", "gpio204", "gpio205", "gpio206",
	"gpio207", "gpio208", "gpio209",
};

static const char * const aon_cam_groups[] = {
	"gpio108",
};
@@ -1285,6 +1299,7 @@ static const struct msm_function sm8450_functions[] = {
	FUNCTION(ddr_pxi2),
	FUNCTION(ddr_pxi3),
	FUNCTION(dp_hot),
	FUNCTION(egpio),
	FUNCTION(gcc_gp1),
	FUNCTION(gcc_gp2),
	FUNCTION(gcc_gp3),
@@ -1571,51 +1586,51 @@ static const struct msm_pingroup sm8450_groups[] = {
	[162] = PINGROUP(162, qlink2_request, _, _, _, _, _, _, _, _),
	[163] = PINGROUP(163, qlink2_enable, _, _, _, _, _, _, _, _),
	[164] = PINGROUP(164, qlink2_wmss, _, _, _, _, _, _, _, _),
	[165] = PINGROUP(165, _, _, _, _, _, _, _, _, _),
	[166] = PINGROUP(166, _, _, _, _, _, _, _, _, _),
	[167] = PINGROUP(167, _, _, _, _, _, _, _, _, _),
	[168] = PINGROUP(168, _, _, _, _, _, _, _, _, _),
	[169] = PINGROUP(169, _, _, _, _, _, _, _, _, _),
	[170] = PINGROUP(170, _, _, _, _, _, _, _, _, _),
	[171] = PINGROUP(171, _, _, _, _, _, _, _, _, _),
	[172] = PINGROUP(172, _, _, _, _, _, _, _, _, _),
	[173] = PINGROUP(173, _, _, _, _, _, _, _, _, _),
	[174] = PINGROUP(174, _, _, _, _, _, _, _, _, _),
	[175] = PINGROUP(175, _, _, _, _, _, _, _, _, _),
	[176] = PINGROUP(176, _, _, _, _, _, _, _, _, _),
	[177] = PINGROUP(177, _, _, _, _, _, _, _, _, _),
	[178] = PINGROUP(178, _, _, _, _, _, _, _, _, _),
	[179] = PINGROUP(179, _, _, _, _, _, _, _, _, _),
	[180] = PINGROUP(180, _, _, _, _, _, _, _, _, _),
	[181] = PINGROUP(181, _, _, _, _, _, _, _, _, _),
	[182] = PINGROUP(182, _, _, _, _, _, _, _, _, _),
	[183] = PINGROUP(183, _, _, _, _, _, _, _, _, _),
	[184] = PINGROUP(184, _, _, _, _, _, _, _, _, _),
	[185] = PINGROUP(185, _, _, _, _, _, _, _, _, _),
	[186] = PINGROUP(186, _, _, _, _, _, _, _, _, _),
	[187] = PINGROUP(187, _, _, _, _, _, _, _, _, _),
	[188] = PINGROUP(188, _, qdss_gpio, _, _, _, _, _, _, _),
	[189] = PINGROUP(189, _, qdss_gpio, _, _, _, _, _, _, _),
	[190] = PINGROUP(190, qdss_gpio, _, _, _, _, _, _, _, _),
	[191] = PINGROUP(191, qdss_gpio, _, _, _, _, _, _, _, _),
	[192] = PINGROUP(192, _, qdss_gpio, _, _, _, _, _, _, _),
	[193] = PINGROUP(193, _, qdss_gpio, _, _, _, _, _, _, _),
	[194] = PINGROUP(194, _, qdss_gpio, _, _, _, _, _, _, _),
	[195] = PINGROUP(195, _, qdss_gpio, _, _, _, _, _, _, _),
	[196] = PINGROUP(196, _, qdss_gpio, _, _, _, _, _, _, _),
	[197] = PINGROUP(197, _, qdss_gpio, _, _, _, _, _, _, _),
	[198] = PINGROUP(198, _, qdss_gpio, _, _, _, _, _, _, _),
	[199] = PINGROUP(199, _, qdss_gpio, _, _, _, _, _, _, _),
	[200] = PINGROUP(200, _, qdss_gpio, _, _, _, _, _, _, _),
	[201] = PINGROUP(201, _, qdss_gpio, _, _, _, _, _, _, _),
	[202] = PINGROUP(202, qdss_gpio, _, _, _, _, _, _, _, _),
	[203] = PINGROUP(203, qdss_gpio, _, _, _, _, _, _, _, _),
	[204] = PINGROUP(204, qdss_gpio, _, _, _, _, _, _, _, _),
	[205] = PINGROUP(205, qdss_gpio, _, _, _, _, _, _, _, _),
	[206] = PINGROUP(206, qup5, _, _, _, _, _, _, _, _),
	[207] = PINGROUP(207, qup5, _, _, _, _, _, _, _, _),
	[208] = PINGROUP(208, cci_i2c, _, _, _, _, _, _, _, _),
	[209] = PINGROUP(209, cci_i2c, _, _, _, _, _, _, _, _),
	[165] = PINGROUP(165, _, _, _, _, _, _, _, _, egpio),
	[166] = PINGROUP(166, _, _, _, _, _, _, _, _, egpio),
	[167] = PINGROUP(167, _, _, _, _, _, _, _, _, egpio),
	[168] = PINGROUP(168, _, _, _, _, _, _, _, _, egpio),
	[169] = PINGROUP(169, _, _, _, _, _, _, _, _, egpio),
	[170] = PINGROUP(170, _, _, _, _, _, _, _, _, egpio),
	[171] = PINGROUP(171, _, _, _, _, _, _, _, _, egpio),
	[172] = PINGROUP(172, _, _, _, _, _, _, _, _, egpio),
	[173] = PINGROUP(173, _, _, _, _, _, _, _, _, egpio),
	[174] = PINGROUP(174, _, _, _, _, _, _, _, _, egpio),
	[175] = PINGROUP(175, _, _, _, _, _, _, _, _, egpio),
	[176] = PINGROUP(176, _, _, _, _, _, _, _, _, egpio),
	[177] = PINGROUP(177, _, _, _, _, _, _, _, _, egpio),
	[178] = PINGROUP(178, _, _, _, _, _, _, _, _, egpio),
	[179] = PINGROUP(179, _, _, _, _, _, _, _, _, egpio),
	[180] = PINGROUP(180, _, _, _, _, _, _, _, _, egpio),
	[181] = PINGROUP(181, _, _, _, _, _, _, _, _, egpio),
	[182] = PINGROUP(182, _, _, _, _, _, _, _, _, egpio),
	[183] = PINGROUP(183, _, _, _, _, _, _, _, _, egpio),
	[184] = PINGROUP(184, _, _, _, _, _, _, _, _, egpio),
	[185] = PINGROUP(185, _, _, _, _, _, _, _, _, egpio),
	[186] = PINGROUP(186, _, _, _, _, _, _, _, _, egpio),
	[187] = PINGROUP(187, _, _, _, _, _, _, _, _, egpio),
	[188] = PINGROUP(188, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[189] = PINGROUP(189, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[190] = PINGROUP(190, qdss_gpio, _, _, _, _, _, _, _, egpio),
	[191] = PINGROUP(191, qdss_gpio, _, _, _, _, _, _, _, egpio),
	[192] = PINGROUP(192, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[193] = PINGROUP(193, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[194] = PINGROUP(194, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[195] = PINGROUP(195, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[196] = PINGROUP(196, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[197] = PINGROUP(197, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[198] = PINGROUP(198, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[199] = PINGROUP(199, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[200] = PINGROUP(200, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[201] = PINGROUP(201, _, qdss_gpio, _, _, _, _, _, _, egpio),
	[202] = PINGROUP(202, qdss_gpio, _, _, _, _, _, _, _, egpio),
	[203] = PINGROUP(203, qdss_gpio, _, _, _, _, _, _, _, egpio),
	[204] = PINGROUP(204, qdss_gpio, _, _, _, _, _, _, _, egpio),
	[205] = PINGROUP(205, qdss_gpio, _, _, _, _, _, _, _, egpio),
	[206] = PINGROUP(206, qup5, _, _, _, _, _, _, _, egpio),
	[207] = PINGROUP(207, qup5, _, _, _, _, _, _, _, egpio),
	[208] = PINGROUP(208, cci_i2c, _, _, _, _, _, _, _, egpio),
	[209] = PINGROUP(209, cci_i2c, _, _, _, _, _, _, _, egpio),
	[210] = UFS_RESET(ufs_reset, 0xde000),
	[211] = SDC_QDSD_PINGROUP(sdc2_clk, 0xd6000, 14, 6),
	[212] = SDC_QDSD_PINGROUP(sdc2_cmd, 0xd6000, 11, 3),
@@ -1651,6 +1666,7 @@ static const struct msm_pinctrl_soc_data sm8450_tlmm = {
	.ngpios = 211,
	.wakeirq_map = sm8450_pdc_map,
	.nwakeirq_map = ARRAY_SIZE(sm8450_pdc_map),
	.egpio_func = 9,
};

static int sm8450_tlmm_probe(struct platform_device *pdev)