* Re: [PATCH v3 4/4] pinctrl: qcom: eliza: Split QUP1_SE4 lanes
[not found] ` <20260423-fix-eliza-pinctrl-v3-4-68b24893ae63@pm.me>
@ 2026-05-11 18:04 ` Bjorn Andersson
0 siblings, 0 replies; only message in thread
From: Bjorn Andersson @ 2026-05-11 18:04 UTC (permalink / raw)
To: Alexander Koskovich
Cc: Linus Walleij, Rob Herring, Krzysztof Kozlowski, Conor Dooley,
Abel Vesa, Konrad Dybcio, linux-arm-msm, linux-gpio, devicetree,
linux-kernel
On Thu, Apr 23, 2026 at 04:43:46AM +0000, Alexander Koskovich wrote:
> QUP1_SE4 shares GPIO_36 & GPIO_37 for both L0/L1 and L3/L2 so the
> function name cannot be the same or the alternate function cannot
> be selected.
>
> Split them up into individual lane functions so boards can specify.
>
This works, but it forces the DeviceTree source author to write a state
per pin even though these are typically configured in pairs.
What we did for hawi was to use the naming: qup1_se4_01 and qup1_se4_23
to express the two possible function pairs.
I don't have any strong opinions on how to proceed with this platform
(eliza), but I'm hoping we can follow the pair-wise scheme going
forward.
Regards,
Bjorn
> Signed-off-by: Alexander Koskovich <akoskovich@pm.me>
> ---
> drivers/pinctrl/qcom/pinctrl-eliza.c | 30 ++++++++++++++++++++++++------
> 1 file changed, 24 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/pinctrl/qcom/pinctrl-eliza.c b/drivers/pinctrl/qcom/pinctrl-eliza.c
> index 8f74756771b8..40e263e35b45 100644
> --- a/drivers/pinctrl/qcom/pinctrl-eliza.c
> +++ b/drivers/pinctrl/qcom/pinctrl-eliza.c
> @@ -568,7 +568,10 @@ enum eliza_functions {
> msm_mux_qup1_se2_l3_mira,
> msm_mux_qup1_se2_l3_mirb,
> msm_mux_qup1_se3,
> - msm_mux_qup1_se4,
> + msm_mux_qup1_se4_l0,
> + msm_mux_qup1_se4_l1,
> + msm_mux_qup1_se4_l2,
> + msm_mux_qup1_se4_l3,
> msm_mux_qup1_se5,
> msm_mux_qup1_se6,
> msm_mux_qup1_se6_l1_mira,
> @@ -1017,8 +1020,20 @@ static const char *const qup1_se3_groups[] = {
> "gpio44", "gpio45", "gpio46", "gpio47",
> };
>
> -static const char *const qup1_se4_groups[] = {
> - "gpio36", "gpio37", "gpio37", "gpio36",
> +static const char *const qup1_se4_l0_groups[] = {
> + "gpio36",
> +};
> +
> +static const char *const qup1_se4_l1_groups[] = {
> + "gpio37",
> +};
> +
> +static const char *const qup1_se4_l2_groups[] = {
> + "gpio37",
> +};
> +
> +static const char *const qup1_se4_l3_groups[] = {
> + "gpio36",
> };
>
> static const char *const qup1_se5_groups[] = {
> @@ -1321,7 +1336,10 @@ static const struct pinfunction eliza_functions[] = {
> MSM_PIN_FUNCTION(qup1_se2_l3_mira),
> MSM_PIN_FUNCTION(qup1_se2_l3_mirb),
> MSM_PIN_FUNCTION(qup1_se3),
> - MSM_PIN_FUNCTION(qup1_se4),
> + MSM_PIN_FUNCTION(qup1_se4_l0),
> + MSM_PIN_FUNCTION(qup1_se4_l1),
> + MSM_PIN_FUNCTION(qup1_se4_l2),
> + MSM_PIN_FUNCTION(qup1_se4_l3),
> MSM_PIN_FUNCTION(qup1_se5),
> MSM_PIN_FUNCTION(qup1_se6),
> MSM_PIN_FUNCTION(qup1_se6_l1_mira),
> @@ -1418,8 +1436,8 @@ static const struct msm_pingroup eliza_groups[] = {
> [33] = PINGROUP(33, qup1_se1, ibi_i3c, host2wlan_sol, gcc_gp3, _, _, _, _, _, _, _),
> [34] = PINGROUP(34, qup1_se1, qup1_se5, tb_trig_sdc1, ddr_bist_start, qdss_gpio_tracedata, _, _, _, _, _, _),
> [35] = PINGROUP(35, qup1_se1, qup1_se5, tb_trig_sdc2, gcc_gp2, qdss_gpio_tracedata, _, _, _, _, _, _),
> - [36] = PINGROUP(36, qup1_se4, qup1_se4, ibi_i3c, _, _, _, _, _, _, _, _),
> - [37] = PINGROUP(37, qup1_se4, qup1_se4, ibi_i3c, _, _, _, _, _, _, _, _),
> + [36] = PINGROUP(36, qup1_se4_l0, qup1_se4_l3, ibi_i3c, _, _, _, _, _, _, _, _),
> + [37] = PINGROUP(37, qup1_se4_l1, qup1_se4_l2, ibi_i3c, _, _, _, _, _, _, _, _),
> [38] = PINGROUP(38, _, _, _, _, _, _, _, _, _, _, _),
> [39] = PINGROUP(39, _, _, _, _, _, _, _, _, _, _, _),
> [40] = PINGROUP(40, qup1_se6, qup1_se2, qup1_se6_l3_mira, _, qdss_gpio_tracedata, gnss_adc1, ddr_pxi1, _, _, _, _),
>
> --
> 2.53.0
>
>
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2026-05-11 18:04 UTC | newest]
Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20260423-fix-eliza-pinctrl-v3-0-68b24893ae63@pm.me>
[not found] ` <20260423-fix-eliza-pinctrl-v3-4-68b24893ae63@pm.me>
2026-05-11 18:04 ` [PATCH v3 4/4] pinctrl: qcom: eliza: Split QUP1_SE4 lanes Bjorn Andersson
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox