1
linux/drivers/pinctrl/qcom/pinctrl-x1e80100.c
Stephan Gerhold 602cb14e31 pinctrl: qcom: x1e80100: Bypass PDC wakeup parent for now
On X1E80100, GPIO interrupts for wakeup-capable pins have been broken since
the introduction of the pinctrl driver. This prevents keyboard and touchpad
from working on most of the X1E laptops. So far we have worked around this
by manually building a kernel with the "wakeup-parent" removed from the
pinctrl node in the device tree, but we cannot expect all users to do that.

Implement a similar workaround in the driver by clearing the wakeirq_map
for X1E80100. This avoids using the PDC wakeup parent for all GPIOs
and handles the interrupts directly in the pinctrl driver instead.

The PDC driver needs additional changes to support X1E80100 properly.
Adding a workaround separately first allows to land the necessary PDC
changes through the normal release cycle, while still solving the more
critical problem with keyboard and touchpad on the current stable kernel
versions. Bypassing the PDC is enough for now, because we have not yet
enabled the deep idle states where using the PDC becomes necessary.

Cc: stable@vger.kernel.org
Fixes: 05e4941d97 ("pinctrl: qcom: Add X1E80100 pinctrl driver")
Signed-off-by: Stephan Gerhold <stephan.gerhold@linaro.org>
Reviewed-by: Johan Hovold <johan+linaro@kernel.org>
Tested-by: Johan Hovold <johan+linaro@kernel.org>
Reviewed-by: Konrad Dybcio <konradybcio@kernel.org>
Reviewed-by: Abel Vesa <abel.vesa@linaro.org>
Link: https://lore.kernel.org/20240830-x1e80100-bypass-pdc-v1-1-d4c00be0c3e3@linaro.org
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
2024-09-02 11:07:48 +02:00

1882 lines
56 KiB
C

// SPDX-License-Identifier: GPL-2.0-only
/*
* Copyright (c) 2023 Qualcomm Innovation Center, Inc. All rights reserved.
*/
#include <linux/module.h>
#include <linux/of.h>
#include <linux/platform_device.h>
#include "pinctrl-msm.h"
#define REG_SIZE 0x1000
#define PINGROUP(id, f1, f2, f3, f4, f5, f6, f7, f8, f9) \
{ \
.grp = PINCTRL_PINGROUP("gpio" #id, \
gpio##id##_pins, \
ARRAY_SIZE(gpio##id##_pins)), \
.funcs = (int[]){ \
msm_mux_gpio, /* gpio mode */ \
msm_mux_##f1, \
msm_mux_##f2, \
msm_mux_##f3, \
msm_mux_##f4, \
msm_mux_##f5, \
msm_mux_##f6, \
msm_mux_##f7, \
msm_mux_##f8, \
msm_mux_##f9 \
}, \
.nfuncs = 10, \
.ctl_reg = REG_SIZE * id, \
.io_reg = 0x4 + REG_SIZE * id, \
.intr_cfg_reg = 0x8 + REG_SIZE * id, \
.intr_status_reg = 0xc + REG_SIZE * id, \
.intr_target_reg = 0x8 + REG_SIZE * id, \
.mux_bit = 2, \
.pull_bit = 0, \
.drv_bit = 6, \
.i2c_pull_bit = 13, \
.egpio_enable = 12, \
.egpio_present = 11, \
.oe_bit = 9, \
.in_bit = 0, \
.out_bit = 1, \
.intr_enable_bit = 0, \
.intr_status_bit = 0, \
.intr_target_bit = 5, \
.intr_target_kpss_val = 3, \
.intr_raw_status_bit = 4, \
.intr_polarity_bit = 1, \
.intr_detection_bit = 2, \
.intr_detection_width = 2, \
}
#define SDC_QDSD_PINGROUP(pg_name, ctl, pull, drv) \
{ \
.grp = PINCTRL_PINGROUP(#pg_name, \
pg_name##_pins, \
ARRAY_SIZE(pg_name##_pins)), \
.ctl_reg = ctl, \
.io_reg = 0, \
.intr_cfg_reg = 0, \
.intr_status_reg = 0, \
.intr_target_reg = 0, \
.mux_bit = -1, \
.pull_bit = pull, \
.drv_bit = drv, \
.oe_bit = -1, \
.in_bit = -1, \
.out_bit = -1, \
.intr_enable_bit = -1, \
.intr_status_bit = -1, \
.intr_target_bit = -1, \
.intr_raw_status_bit = -1, \
.intr_polarity_bit = -1, \
.intr_detection_bit = -1, \
.intr_detection_width = -1, \
}
#define UFS_RESET(pg_name, offset) \
{ \
.grp = PINCTRL_PINGROUP(#pg_name, \
pg_name##_pins, \
ARRAY_SIZE(pg_name##_pins)), \
.ctl_reg = offset, \
.io_reg = offset + 0x4, \
.intr_cfg_reg = 0, \
.intr_status_reg = 0, \
.intr_target_reg = 0, \
.mux_bit = -1, \
.pull_bit = 3, \
.drv_bit = 0, \
.oe_bit = -1, \
.in_bit = -1, \
.out_bit = 0, \
.intr_enable_bit = -1, \
.intr_status_bit = -1, \
.intr_target_bit = -1, \
.intr_raw_status_bit = -1, \
.intr_polarity_bit = -1, \
.intr_detection_bit = -1, \
.intr_detection_width = -1, \
}
static const struct pinctrl_pin_desc x1e80100_pins[] = {
PINCTRL_PIN(0, "GPIO_0"),
PINCTRL_PIN(1, "GPIO_1"),
PINCTRL_PIN(2, "GPIO_2"),
PINCTRL_PIN(3, "GPIO_3"),
PINCTRL_PIN(4, "GPIO_4"),
PINCTRL_PIN(5, "GPIO_5"),
PINCTRL_PIN(6, "GPIO_6"),
PINCTRL_PIN(7, "GPIO_7"),
PINCTRL_PIN(8, "GPIO_8"),
PINCTRL_PIN(9, "GPIO_9"),
PINCTRL_PIN(10, "GPIO_10"),
PINCTRL_PIN(11, "GPIO_11"),
PINCTRL_PIN(12, "GPIO_12"),
PINCTRL_PIN(13, "GPIO_13"),
PINCTRL_PIN(14, "GPIO_14"),
PINCTRL_PIN(15, "GPIO_15"),
PINCTRL_PIN(16, "GPIO_16"),
PINCTRL_PIN(17, "GPIO_17"),
PINCTRL_PIN(18, "GPIO_18"),
PINCTRL_PIN(19, "GPIO_19"),
PINCTRL_PIN(20, "GPIO_20"),
PINCTRL_PIN(21, "GPIO_21"),
PINCTRL_PIN(22, "GPIO_22"),
PINCTRL_PIN(23, "GPIO_23"),
PINCTRL_PIN(24, "GPIO_24"),
PINCTRL_PIN(25, "GPIO_25"),
PINCTRL_PIN(26, "GPIO_26"),
PINCTRL_PIN(27, "GPIO_27"),
PINCTRL_PIN(28, "GPIO_28"),
PINCTRL_PIN(29, "GPIO_29"),
PINCTRL_PIN(30, "GPIO_30"),
PINCTRL_PIN(31, "GPIO_31"),
PINCTRL_PIN(32, "GPIO_32"),
PINCTRL_PIN(33, "GPIO_33"),
PINCTRL_PIN(34, "GPIO_34"),
PINCTRL_PIN(35, "GPIO_35"),
PINCTRL_PIN(36, "GPIO_36"),
PINCTRL_PIN(37, "GPIO_37"),
PINCTRL_PIN(38, "GPIO_38"),
PINCTRL_PIN(39, "GPIO_39"),
PINCTRL_PIN(40, "GPIO_40"),
PINCTRL_PIN(41, "GPIO_41"),
PINCTRL_PIN(42, "GPIO_42"),
PINCTRL_PIN(43, "GPIO_43"),
PINCTRL_PIN(44, "GPIO_44"),
PINCTRL_PIN(45, "GPIO_45"),
PINCTRL_PIN(46, "GPIO_46"),
PINCTRL_PIN(47, "GPIO_47"),
PINCTRL_PIN(48, "GPIO_48"),
PINCTRL_PIN(49, "GPIO_49"),
PINCTRL_PIN(50, "GPIO_50"),
PINCTRL_PIN(51, "GPIO_51"),
PINCTRL_PIN(52, "GPIO_52"),
PINCTRL_PIN(53, "GPIO_53"),
PINCTRL_PIN(54, "GPIO_54"),
PINCTRL_PIN(55, "GPIO_55"),
PINCTRL_PIN(56, "GPIO_56"),
PINCTRL_PIN(57, "GPIO_57"),
PINCTRL_PIN(58, "GPIO_58"),
PINCTRL_PIN(59, "GPIO_59"),
PINCTRL_PIN(60, "GPIO_60"),
PINCTRL_PIN(61, "GPIO_61"),
PINCTRL_PIN(62, "GPIO_62"),
PINCTRL_PIN(63, "GPIO_63"),
PINCTRL_PIN(64, "GPIO_64"),
PINCTRL_PIN(65, "GPIO_65"),
PINCTRL_PIN(66, "GPIO_66"),
PINCTRL_PIN(67, "GPIO_67"),
PINCTRL_PIN(68, "GPIO_68"),
PINCTRL_PIN(69, "GPIO_69"),
PINCTRL_PIN(70, "GPIO_70"),
PINCTRL_PIN(71, "GPIO_71"),
PINCTRL_PIN(72, "GPIO_72"),
PINCTRL_PIN(73, "GPIO_73"),
PINCTRL_PIN(74, "GPIO_74"),
PINCTRL_PIN(75, "GPIO_75"),
PINCTRL_PIN(76, "GPIO_76"),
PINCTRL_PIN(77, "GPIO_77"),
PINCTRL_PIN(78, "GPIO_78"),
PINCTRL_PIN(79, "GPIO_79"),
PINCTRL_PIN(80, "GPIO_80"),
PINCTRL_PIN(81, "GPIO_81"),
PINCTRL_PIN(82, "GPIO_82"),
PINCTRL_PIN(83, "GPIO_83"),
PINCTRL_PIN(84, "GPIO_84"),
PINCTRL_PIN(85, "GPIO_85"),
PINCTRL_PIN(86, "GPIO_86"),
PINCTRL_PIN(87, "GPIO_87"),
PINCTRL_PIN(88, "GPIO_88"),
PINCTRL_PIN(89, "GPIO_89"),
PINCTRL_PIN(90, "GPIO_90"),
PINCTRL_PIN(91, "GPIO_91"),
PINCTRL_PIN(92, "GPIO_92"),
PINCTRL_PIN(93, "GPIO_93"),
PINCTRL_PIN(94, "GPIO_94"),
PINCTRL_PIN(95, "GPIO_95"),
PINCTRL_PIN(96, "GPIO_96"),
PINCTRL_PIN(97, "GPIO_97"),
PINCTRL_PIN(98, "GPIO_98"),
PINCTRL_PIN(99, "GPIO_99"),
PINCTRL_PIN(100, "GPIO_100"),
PINCTRL_PIN(101, "GPIO_101"),
PINCTRL_PIN(102, "GPIO_102"),
PINCTRL_PIN(103, "GPIO_103"),
PINCTRL_PIN(104, "GPIO_104"),
PINCTRL_PIN(105, "GPIO_105"),
PINCTRL_PIN(106, "GPIO_106"),
PINCTRL_PIN(107, "GPIO_107"),
PINCTRL_PIN(108, "GPIO_108"),
PINCTRL_PIN(109, "GPIO_109"),
PINCTRL_PIN(110, "GPIO_110"),
PINCTRL_PIN(111, "GPIO_111"),
PINCTRL_PIN(112, "GPIO_112"),
PINCTRL_PIN(113, "GPIO_113"),
PINCTRL_PIN(114, "GPIO_114"),
PINCTRL_PIN(115, "GPIO_115"),
PINCTRL_PIN(116, "GPIO_116"),
PINCTRL_PIN(117, "GPIO_117"),
PINCTRL_PIN(118, "GPIO_118"),
PINCTRL_PIN(119, "GPIO_119"),
PINCTRL_PIN(120, "GPIO_120"),
PINCTRL_PIN(121, "GPIO_121"),
PINCTRL_PIN(122, "GPIO_122"),
PINCTRL_PIN(123, "GPIO_123"),
PINCTRL_PIN(124, "GPIO_124"),
PINCTRL_PIN(125, "GPIO_125"),
PINCTRL_PIN(126, "GPIO_126"),
PINCTRL_PIN(127, "GPIO_127"),
PINCTRL_PIN(128, "GPIO_128"),
PINCTRL_PIN(129, "GPIO_129"),
PINCTRL_PIN(130, "GPIO_130"),
PINCTRL_PIN(131, "GPIO_131"),
PINCTRL_PIN(132, "GPIO_132"),
PINCTRL_PIN(133, "GPIO_133"),
PINCTRL_PIN(134, "GPIO_134"),
PINCTRL_PIN(135, "GPIO_135"),
PINCTRL_PIN(136, "GPIO_136"),
PINCTRL_PIN(137, "GPIO_137"),
PINCTRL_PIN(138, "GPIO_138"),
PINCTRL_PIN(139, "GPIO_139"),
PINCTRL_PIN(140, "GPIO_140"),
PINCTRL_PIN(141, "GPIO_141"),
PINCTRL_PIN(142, "GPIO_142"),
PINCTRL_PIN(143, "GPIO_143"),
PINCTRL_PIN(144, "GPIO_144"),
PINCTRL_PIN(145, "GPIO_145"),
PINCTRL_PIN(146, "GPIO_146"),
PINCTRL_PIN(147, "GPIO_147"),
PINCTRL_PIN(148, "GPIO_148"),
PINCTRL_PIN(149, "GPIO_149"),
PINCTRL_PIN(150, "GPIO_150"),
PINCTRL_PIN(151, "GPIO_151"),
PINCTRL_PIN(152, "GPIO_152"),
PINCTRL_PIN(153, "GPIO_153"),
PINCTRL_PIN(154, "GPIO_154"),
PINCTRL_PIN(155, "GPIO_155"),
PINCTRL_PIN(156, "GPIO_156"),
PINCTRL_PIN(157, "GPIO_157"),
PINCTRL_PIN(158, "GPIO_158"),
PINCTRL_PIN(159, "GPIO_159"),
PINCTRL_PIN(160, "GPIO_160"),
PINCTRL_PIN(161, "GPIO_161"),
PINCTRL_PIN(162, "GPIO_162"),
PINCTRL_PIN(163, "GPIO_163"),
PINCTRL_PIN(164, "GPIO_164"),
PINCTRL_PIN(165, "GPIO_165"),
PINCTRL_PIN(166, "GPIO_166"),
PINCTRL_PIN(167, "GPIO_167"),
PINCTRL_PIN(168, "GPIO_168"),
PINCTRL_PIN(169, "GPIO_169"),
PINCTRL_PIN(170, "GPIO_170"),
PINCTRL_PIN(171, "GPIO_171"),
PINCTRL_PIN(172, "GPIO_172"),
PINCTRL_PIN(173, "GPIO_173"),
PINCTRL_PIN(174, "GPIO_174"),
PINCTRL_PIN(175, "GPIO_175"),
PINCTRL_PIN(176, "GPIO_176"),
PINCTRL_PIN(177, "GPIO_177"),
PINCTRL_PIN(178, "GPIO_178"),
PINCTRL_PIN(179, "GPIO_179"),
PINCTRL_PIN(180, "GPIO_180"),
PINCTRL_PIN(181, "GPIO_181"),
PINCTRL_PIN(182, "GPIO_182"),
PINCTRL_PIN(183, "GPIO_183"),
PINCTRL_PIN(184, "GPIO_184"),
PINCTRL_PIN(185, "GPIO_185"),
PINCTRL_PIN(186, "GPIO_186"),
PINCTRL_PIN(187, "GPIO_187"),
PINCTRL_PIN(188, "GPIO_188"),
PINCTRL_PIN(189, "GPIO_189"),
PINCTRL_PIN(190, "GPIO_190"),
PINCTRL_PIN(191, "GPIO_191"),
PINCTRL_PIN(192, "GPIO_192"),
PINCTRL_PIN(193, "GPIO_193"),
PINCTRL_PIN(194, "GPIO_194"),
PINCTRL_PIN(195, "GPIO_195"),
PINCTRL_PIN(196, "GPIO_196"),
PINCTRL_PIN(197, "GPIO_197"),
PINCTRL_PIN(198, "GPIO_198"),
PINCTRL_PIN(199, "GPIO_199"),
PINCTRL_PIN(200, "GPIO_200"),
PINCTRL_PIN(201, "GPIO_201"),
PINCTRL_PIN(202, "GPIO_202"),
PINCTRL_PIN(203, "GPIO_203"),
PINCTRL_PIN(204, "GPIO_204"),
PINCTRL_PIN(205, "GPIO_205"),
PINCTRL_PIN(206, "GPIO_206"),
PINCTRL_PIN(207, "GPIO_207"),
PINCTRL_PIN(208, "GPIO_208"),
PINCTRL_PIN(209, "GPIO_209"),
PINCTRL_PIN(210, "GPIO_210"),
PINCTRL_PIN(211, "GPIO_211"),
PINCTRL_PIN(212, "GPIO_212"),
PINCTRL_PIN(213, "GPIO_213"),
PINCTRL_PIN(214, "GPIO_214"),
PINCTRL_PIN(215, "GPIO_215"),
PINCTRL_PIN(216, "GPIO_216"),
PINCTRL_PIN(217, "GPIO_217"),
PINCTRL_PIN(218, "GPIO_218"),
PINCTRL_PIN(219, "GPIO_219"),
PINCTRL_PIN(220, "GPIO_220"),
PINCTRL_PIN(221, "GPIO_221"),
PINCTRL_PIN(222, "GPIO_222"),
PINCTRL_PIN(223, "GPIO_223"),
PINCTRL_PIN(224, "GPIO_224"),
PINCTRL_PIN(225, "GPIO_225"),
PINCTRL_PIN(226, "GPIO_226"),
PINCTRL_PIN(227, "GPIO_227"),
PINCTRL_PIN(228, "GPIO_228"),
PINCTRL_PIN(229, "GPIO_229"),
PINCTRL_PIN(230, "GPIO_230"),
PINCTRL_PIN(231, "GPIO_231"),
PINCTRL_PIN(232, "GPIO_232"),
PINCTRL_PIN(233, "GPIO_233"),
PINCTRL_PIN(234, "GPIO_234"),
PINCTRL_PIN(235, "GPIO_235"),
PINCTRL_PIN(236, "GPIO_236"),
PINCTRL_PIN(237, "GPIO_237"),
PINCTRL_PIN(238, "UFS_RESET"),
PINCTRL_PIN(239, "SDC2_CLK"),
PINCTRL_PIN(240, "SDC2_CMD"),
PINCTRL_PIN(241, "SDC2_DATA"),
};
#define DECLARE_MSM_GPIO_PINS(pin) \
static const unsigned int gpio##pin##_pins[] = { pin }
DECLARE_MSM_GPIO_PINS(0);
DECLARE_MSM_GPIO_PINS(1);
DECLARE_MSM_GPIO_PINS(2);
DECLARE_MSM_GPIO_PINS(3);
DECLARE_MSM_GPIO_PINS(4);
DECLARE_MSM_GPIO_PINS(5);
DECLARE_MSM_GPIO_PINS(6);
DECLARE_MSM_GPIO_PINS(7);
DECLARE_MSM_GPIO_PINS(8);
DECLARE_MSM_GPIO_PINS(9);
DECLARE_MSM_GPIO_PINS(10);
DECLARE_MSM_GPIO_PINS(11);
DECLARE_MSM_GPIO_PINS(12);
DECLARE_MSM_GPIO_PINS(13);
DECLARE_MSM_GPIO_PINS(14);
DECLARE_MSM_GPIO_PINS(15);
DECLARE_MSM_GPIO_PINS(16);
DECLARE_MSM_GPIO_PINS(17);
DECLARE_MSM_GPIO_PINS(18);
DECLARE_MSM_GPIO_PINS(19);
DECLARE_MSM_GPIO_PINS(20);
DECLARE_MSM_GPIO_PINS(21);
DECLARE_MSM_GPIO_PINS(22);
DECLARE_MSM_GPIO_PINS(23);
DECLARE_MSM_GPIO_PINS(24);
DECLARE_MSM_GPIO_PINS(25);
DECLARE_MSM_GPIO_PINS(26);
DECLARE_MSM_GPIO_PINS(27);
DECLARE_MSM_GPIO_PINS(28);
DECLARE_MSM_GPIO_PINS(29);
DECLARE_MSM_GPIO_PINS(30);
DECLARE_MSM_GPIO_PINS(31);
DECLARE_MSM_GPIO_PINS(32);
DECLARE_MSM_GPIO_PINS(33);
DECLARE_MSM_GPIO_PINS(34);
DECLARE_MSM_GPIO_PINS(35);
DECLARE_MSM_GPIO_PINS(36);
DECLARE_MSM_GPIO_PINS(37);
DECLARE_MSM_GPIO_PINS(38);
DECLARE_MSM_GPIO_PINS(39);
DECLARE_MSM_GPIO_PINS(40);
DECLARE_MSM_GPIO_PINS(41);
DECLARE_MSM_GPIO_PINS(42);
DECLARE_MSM_GPIO_PINS(43);
DECLARE_MSM_GPIO_PINS(44);
DECLARE_MSM_GPIO_PINS(45);
DECLARE_MSM_GPIO_PINS(46);
DECLARE_MSM_GPIO_PINS(47);
DECLARE_MSM_GPIO_PINS(48);
DECLARE_MSM_GPIO_PINS(49);
DECLARE_MSM_GPIO_PINS(50);
DECLARE_MSM_GPIO_PINS(51);
DECLARE_MSM_GPIO_PINS(52);
DECLARE_MSM_GPIO_PINS(53);
DECLARE_MSM_GPIO_PINS(54);
DECLARE_MSM_GPIO_PINS(55);
DECLARE_MSM_GPIO_PINS(56);
DECLARE_MSM_GPIO_PINS(57);
DECLARE_MSM_GPIO_PINS(58);
DECLARE_MSM_GPIO_PINS(59);
DECLARE_MSM_GPIO_PINS(60);
DECLARE_MSM_GPIO_PINS(61);
DECLARE_MSM_GPIO_PINS(62);
DECLARE_MSM_GPIO_PINS(63);
DECLARE_MSM_GPIO_PINS(64);
DECLARE_MSM_GPIO_PINS(65);
DECLARE_MSM_GPIO_PINS(66);
DECLARE_MSM_GPIO_PINS(67);
DECLARE_MSM_GPIO_PINS(68);
DECLARE_MSM_GPIO_PINS(69);
DECLARE_MSM_GPIO_PINS(70);
DECLARE_MSM_GPIO_PINS(71);
DECLARE_MSM_GPIO_PINS(72);
DECLARE_MSM_GPIO_PINS(73);
DECLARE_MSM_GPIO_PINS(74);
DECLARE_MSM_GPIO_PINS(75);
DECLARE_MSM_GPIO_PINS(76);
DECLARE_MSM_GPIO_PINS(77);
DECLARE_MSM_GPIO_PINS(78);
DECLARE_MSM_GPIO_PINS(79);
DECLARE_MSM_GPIO_PINS(80);
DECLARE_MSM_GPIO_PINS(81);
DECLARE_MSM_GPIO_PINS(82);
DECLARE_MSM_GPIO_PINS(83);
DECLARE_MSM_GPIO_PINS(84);
DECLARE_MSM_GPIO_PINS(85);
DECLARE_MSM_GPIO_PINS(86);
DECLARE_MSM_GPIO_PINS(87);
DECLARE_MSM_GPIO_PINS(88);
DECLARE_MSM_GPIO_PINS(89);
DECLARE_MSM_GPIO_PINS(90);
DECLARE_MSM_GPIO_PINS(91);
DECLARE_MSM_GPIO_PINS(92);
DECLARE_MSM_GPIO_PINS(93);
DECLARE_MSM_GPIO_PINS(94);
DECLARE_MSM_GPIO_PINS(95);
DECLARE_MSM_GPIO_PINS(96);
DECLARE_MSM_GPIO_PINS(97);
DECLARE_MSM_GPIO_PINS(98);
DECLARE_MSM_GPIO_PINS(99);
DECLARE_MSM_GPIO_PINS(100);
DECLARE_MSM_GPIO_PINS(101);
DECLARE_MSM_GPIO_PINS(102);
DECLARE_MSM_GPIO_PINS(103);
DECLARE_MSM_GPIO_PINS(104);
DECLARE_MSM_GPIO_PINS(105);
DECLARE_MSM_GPIO_PINS(106);
DECLARE_MSM_GPIO_PINS(107);
DECLARE_MSM_GPIO_PINS(108);
DECLARE_MSM_GPIO_PINS(109);
DECLARE_MSM_GPIO_PINS(110);
DECLARE_MSM_GPIO_PINS(111);
DECLARE_MSM_GPIO_PINS(112);
DECLARE_MSM_GPIO_PINS(113);
DECLARE_MSM_GPIO_PINS(114);
DECLARE_MSM_GPIO_PINS(115);
DECLARE_MSM_GPIO_PINS(116);
DECLARE_MSM_GPIO_PINS(117);
DECLARE_MSM_GPIO_PINS(118);
DECLARE_MSM_GPIO_PINS(119);
DECLARE_MSM_GPIO_PINS(120);
DECLARE_MSM_GPIO_PINS(121);
DECLARE_MSM_GPIO_PINS(122);
DECLARE_MSM_GPIO_PINS(123);
DECLARE_MSM_GPIO_PINS(124);
DECLARE_MSM_GPIO_PINS(125);
DECLARE_MSM_GPIO_PINS(126);
DECLARE_MSM_GPIO_PINS(127);
DECLARE_MSM_GPIO_PINS(128);
DECLARE_MSM_GPIO_PINS(129);
DECLARE_MSM_GPIO_PINS(130);
DECLARE_MSM_GPIO_PINS(131);
DECLARE_MSM_GPIO_PINS(132);
DECLARE_MSM_GPIO_PINS(133);
DECLARE_MSM_GPIO_PINS(134);
DECLARE_MSM_GPIO_PINS(135);
DECLARE_MSM_GPIO_PINS(136);
DECLARE_MSM_GPIO_PINS(137);
DECLARE_MSM_GPIO_PINS(138);
DECLARE_MSM_GPIO_PINS(139);
DECLARE_MSM_GPIO_PINS(140);
DECLARE_MSM_GPIO_PINS(141);
DECLARE_MSM_GPIO_PINS(142);
DECLARE_MSM_GPIO_PINS(143);
DECLARE_MSM_GPIO_PINS(144);
DECLARE_MSM_GPIO_PINS(145);
DECLARE_MSM_GPIO_PINS(146);
DECLARE_MSM_GPIO_PINS(147);
DECLARE_MSM_GPIO_PINS(148);
DECLARE_MSM_GPIO_PINS(149);
DECLARE_MSM_GPIO_PINS(150);
DECLARE_MSM_GPIO_PINS(151);
DECLARE_MSM_GPIO_PINS(152);
DECLARE_MSM_GPIO_PINS(153);
DECLARE_MSM_GPIO_PINS(154);
DECLARE_MSM_GPIO_PINS(155);
DECLARE_MSM_GPIO_PINS(156);
DECLARE_MSM_GPIO_PINS(157);
DECLARE_MSM_GPIO_PINS(158);
DECLARE_MSM_GPIO_PINS(159);
DECLARE_MSM_GPIO_PINS(160);
DECLARE_MSM_GPIO_PINS(161);
DECLARE_MSM_GPIO_PINS(162);
DECLARE_MSM_GPIO_PINS(163);
DECLARE_MSM_GPIO_PINS(164);
DECLARE_MSM_GPIO_PINS(165);
DECLARE_MSM_GPIO_PINS(166);
DECLARE_MSM_GPIO_PINS(167);
DECLARE_MSM_GPIO_PINS(168);
DECLARE_MSM_GPIO_PINS(169);
DECLARE_MSM_GPIO_PINS(170);
DECLARE_MSM_GPIO_PINS(171);
DECLARE_MSM_GPIO_PINS(172);
DECLARE_MSM_GPIO_PINS(173);
DECLARE_MSM_GPIO_PINS(174);
DECLARE_MSM_GPIO_PINS(175);
DECLARE_MSM_GPIO_PINS(176);
DECLARE_MSM_GPIO_PINS(177);
DECLARE_MSM_GPIO_PINS(178);
DECLARE_MSM_GPIO_PINS(179);
DECLARE_MSM_GPIO_PINS(180);
DECLARE_MSM_GPIO_PINS(181);
DECLARE_MSM_GPIO_PINS(182);
DECLARE_MSM_GPIO_PINS(183);
DECLARE_MSM_GPIO_PINS(184);
DECLARE_MSM_GPIO_PINS(185);
DECLARE_MSM_GPIO_PINS(186);
DECLARE_MSM_GPIO_PINS(187);
DECLARE_MSM_GPIO_PINS(188);
DECLARE_MSM_GPIO_PINS(189);
DECLARE_MSM_GPIO_PINS(190);
DECLARE_MSM_GPIO_PINS(191);
DECLARE_MSM_GPIO_PINS(192);
DECLARE_MSM_GPIO_PINS(193);
DECLARE_MSM_GPIO_PINS(194);
DECLARE_MSM_GPIO_PINS(195);
DECLARE_MSM_GPIO_PINS(196);
DECLARE_MSM_GPIO_PINS(197);
DECLARE_MSM_GPIO_PINS(198);
DECLARE_MSM_GPIO_PINS(199);
DECLARE_MSM_GPIO_PINS(200);
DECLARE_MSM_GPIO_PINS(201);
DECLARE_MSM_GPIO_PINS(202);
DECLARE_MSM_GPIO_PINS(203);
DECLARE_MSM_GPIO_PINS(204);
DECLARE_MSM_GPIO_PINS(205);
DECLARE_MSM_GPIO_PINS(206);
DECLARE_MSM_GPIO_PINS(207);
DECLARE_MSM_GPIO_PINS(208);
DECLARE_MSM_GPIO_PINS(209);
DECLARE_MSM_GPIO_PINS(210);
DECLARE_MSM_GPIO_PINS(211);
DECLARE_MSM_GPIO_PINS(212);
DECLARE_MSM_GPIO_PINS(213);
DECLARE_MSM_GPIO_PINS(214);
DECLARE_MSM_GPIO_PINS(215);
DECLARE_MSM_GPIO_PINS(216);
DECLARE_MSM_GPIO_PINS(217);
DECLARE_MSM_GPIO_PINS(218);
DECLARE_MSM_GPIO_PINS(219);
DECLARE_MSM_GPIO_PINS(220);
DECLARE_MSM_GPIO_PINS(221);
DECLARE_MSM_GPIO_PINS(222);
DECLARE_MSM_GPIO_PINS(223);
DECLARE_MSM_GPIO_PINS(224);
DECLARE_MSM_GPIO_PINS(225);
DECLARE_MSM_GPIO_PINS(226);
DECLARE_MSM_GPIO_PINS(227);
DECLARE_MSM_GPIO_PINS(228);
DECLARE_MSM_GPIO_PINS(229);
DECLARE_MSM_GPIO_PINS(230);
DECLARE_MSM_GPIO_PINS(231);
DECLARE_MSM_GPIO_PINS(232);
DECLARE_MSM_GPIO_PINS(233);
DECLARE_MSM_GPIO_PINS(234);
DECLARE_MSM_GPIO_PINS(235);
DECLARE_MSM_GPIO_PINS(236);
DECLARE_MSM_GPIO_PINS(237);
static const unsigned int ufs_reset_pins[] = { 238 };
static const unsigned int sdc2_clk_pins[] = { 239 };
static const unsigned int sdc2_cmd_pins[] = { 240 };
static const unsigned int sdc2_data_pins[] = { 241 };
enum x1e80100_functions {
msm_mux_gpio,
msm_mux_RESOUT_GPIO,
msm_mux_aon_cci,
msm_mux_aoss_cti,
msm_mux_atest_char,
msm_mux_atest_char0,
msm_mux_atest_char1,
msm_mux_atest_char2,
msm_mux_atest_char3,
msm_mux_atest_usb,
msm_mux_audio_ext,
msm_mux_audio_ref,
msm_mux_cam_aon,
msm_mux_cam_mclk,
msm_mux_cci_async,
msm_mux_cci_i2c,
msm_mux_cci_timer0,
msm_mux_cci_timer1,
msm_mux_cci_timer2,
msm_mux_cci_timer3,
msm_mux_cci_timer4,
msm_mux_cmu_rng0,
msm_mux_cmu_rng1,
msm_mux_cmu_rng2,
msm_mux_cmu_rng3,
msm_mux_cri_trng,
msm_mux_dbg_out,
msm_mux_ddr_bist,
msm_mux_ddr_pxi0,
msm_mux_ddr_pxi1,
msm_mux_ddr_pxi2,
msm_mux_ddr_pxi3,
msm_mux_ddr_pxi4,
msm_mux_ddr_pxi5,
msm_mux_ddr_pxi6,
msm_mux_ddr_pxi7,
msm_mux_edp0_hot,
msm_mux_edp0_lcd,
msm_mux_edp1_hot,
msm_mux_edp1_lcd,
msm_mux_eusb0_ac,
msm_mux_eusb1_ac,
msm_mux_eusb2_ac,
msm_mux_eusb3_ac,
msm_mux_eusb5_ac,
msm_mux_eusb6_ac,
msm_mux_gcc_gp1,
msm_mux_gcc_gp2,
msm_mux_gcc_gp3,
msm_mux_i2s0_data0,
msm_mux_i2s0_data1,
msm_mux_i2s0_sck,
msm_mux_i2s0_ws,
msm_mux_i2s1_data0,
msm_mux_i2s1_data1,
msm_mux_i2s1_sck,
msm_mux_i2s1_ws,
msm_mux_ibi_i3c,
msm_mux_jitter_bist,
msm_mux_mdp_vsync0,
msm_mux_mdp_vsync1,
msm_mux_mdp_vsync2,
msm_mux_mdp_vsync3,
msm_mux_mdp_vsync4,
msm_mux_mdp_vsync5,
msm_mux_mdp_vsync6,
msm_mux_mdp_vsync7,
msm_mux_mdp_vsync8,
msm_mux_pcie3_clk,
msm_mux_pcie4_clk,
msm_mux_pcie5_clk,
msm_mux_pcie6a_clk,
msm_mux_pcie6b_clk,
msm_mux_phase_flag,
msm_mux_pll_bist,
msm_mux_pll_clk,
msm_mux_prng_rosc0,
msm_mux_prng_rosc1,
msm_mux_prng_rosc2,
msm_mux_prng_rosc3,
msm_mux_qdss_cti,
msm_mux_qdss_gpio,
msm_mux_qspi00,
msm_mux_qspi01,
msm_mux_qspi02,
msm_mux_qspi03,
msm_mux_qspi0_clk,
msm_mux_qspi0_cs0,
msm_mux_qspi0_cs1,
msm_mux_qup0_se0,
msm_mux_qup0_se1,
msm_mux_qup0_se2,
msm_mux_qup0_se3,
msm_mux_qup0_se4,
msm_mux_qup0_se5,
msm_mux_qup0_se6,
msm_mux_qup0_se7,
msm_mux_qup1_se0,
msm_mux_qup1_se1,
msm_mux_qup1_se2,
msm_mux_qup1_se3,
msm_mux_qup1_se4,
msm_mux_qup1_se5,
msm_mux_qup1_se6,
msm_mux_qup1_se7,
msm_mux_qup2_se0,
msm_mux_qup2_se1,
msm_mux_qup2_se2,
msm_mux_qup2_se3,
msm_mux_qup2_se4,
msm_mux_qup2_se5,
msm_mux_qup2_se6,
msm_mux_qup2_se7,
msm_mux_sd_write,
msm_mux_sdc4_clk,
msm_mux_sdc4_cmd,
msm_mux_sdc4_data0,
msm_mux_sdc4_data1,
msm_mux_sdc4_data2,
msm_mux_sdc4_data3,
msm_mux_sys_throttle,
msm_mux_tb_trig,
msm_mux_tgu_ch0,
msm_mux_tgu_ch1,
msm_mux_tgu_ch2,
msm_mux_tgu_ch3,
msm_mux_tgu_ch4,
msm_mux_tgu_ch5,
msm_mux_tgu_ch6,
msm_mux_tgu_ch7,
msm_mux_tmess_prng0,
msm_mux_tmess_prng1,
msm_mux_tmess_prng2,
msm_mux_tmess_prng3,
msm_mux_tsense_pwm1,
msm_mux_tsense_pwm2,
msm_mux_tsense_pwm3,
msm_mux_tsense_pwm4,
msm_mux_usb0_dp,
msm_mux_usb0_phy,
msm_mux_usb0_sbrx,
msm_mux_usb0_sbtx,
msm_mux_usb1_dp,
msm_mux_usb1_phy,
msm_mux_usb1_sbrx,
msm_mux_usb1_sbtx,
msm_mux_usb2_dp,
msm_mux_usb2_phy,
msm_mux_usb2_sbrx,
msm_mux_usb2_sbtx,
msm_mux_vsense_trigger,
msm_mux__,
};
static const char * const gpio_groups[] = {
"gpio0", "gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7",
"gpio8", "gpio9", "gpio10", "gpio11", "gpio12", "gpio13", "gpio14",
"gpio15", "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21",
"gpio22", "gpio23", "gpio24", "gpio25", "gpio26", "gpio27", "gpio28",
"gpio29", "gpio30", "gpio31", "gpio32", "gpio33", "gpio34", "gpio35",
"gpio36", "gpio37", "gpio38", "gpio39", "gpio40", "gpio41", "gpio42",
"gpio43", "gpio44", "gpio45", "gpio46", "gpio47", "gpio48", "gpio49",
"gpio50", "gpio51", "gpio52", "gpio53", "gpio54", "gpio55", "gpio56",
"gpio57", "gpio58", "gpio59", "gpio60", "gpio61", "gpio62", "gpio63",
"gpio64", "gpio65", "gpio66", "gpio67", "gpio68", "gpio69", "gpio70",
"gpio71", "gpio72", "gpio73", "gpio74", "gpio75", "gpio76", "gpio77",
"gpio78", "gpio79", "gpio80", "gpio81", "gpio82", "gpio83", "gpio84",
"gpio85", "gpio86", "gpio87", "gpio88", "gpio89", "gpio90", "gpio91",
"gpio92", "gpio93", "gpio94", "gpio95", "gpio96", "gpio97", "gpio98",
"gpio99", "gpio100", "gpio101", "gpio102", "gpio103", "gpio104",
"gpio105", "gpio106", "gpio107", "gpio108", "gpio109", "gpio110",
"gpio111", "gpio112", "gpio113", "gpio114", "gpio115", "gpio116",
"gpio117", "gpio118", "gpio119", "gpio120", "gpio121", "gpio122",
"gpio123", "gpio124", "gpio125", "gpio126", "gpio127", "gpio128",
"gpio129", "gpio130", "gpio131", "gpio132", "gpio133", "gpio134",
"gpio135", "gpio136", "gpio137", "gpio138", "gpio139", "gpio140",
"gpio141", "gpio142", "gpio143", "gpio144", "gpio145", "gpio146",
"gpio147", "gpio148", "gpio149", "gpio150", "gpio151", "gpio152",
"gpio153", "gpio154", "gpio155", "gpio156", "gpio157", "gpio158",
"gpio159", "gpio160", "gpio161", "gpio162", "gpio163", "gpio164",
"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", "gpio210", "gpio211", "gpio212",
"gpio213", "gpio214", "gpio215", "gpio216", "gpio217", "gpio218",
"gpio219", "gpio220", "gpio221", "gpio222", "gpio223", "gpio224",
"gpio225", "gpio226", "gpio227", "gpio228", "gpio229", "gpio230",
"gpio231", "gpio232", "gpio233", "gpio234", "gpio235", "gpio236",
"gpio237",
};
static const char * const RESOUT_GPIO_groups[] = {
"gpio160",
};
static const char * const aon_cci_groups[] = {
"gpio235", "gpio236",
};
static const char * const aoss_cti_groups[] = {
"gpio60", "gpio61", "gpio62", "gpio63",
};
static const char * const atest_char_groups[] = {
"gpio181",
};
static const char * const atest_char0_groups[] = {
"gpio185",
};
static const char * const atest_char1_groups[] = {
"gpio184",
};
static const char * const atest_char2_groups[] = {
"gpio188",
};
static const char * const atest_char3_groups[] = {
"gpio182",
};
static const char * const atest_usb_groups[] = {
"gpio9", "gpio10", "gpio35", "gpio38", "gpio41", "gpio42",
"gpio43", "gpio44", "gpio45", "gpio46", "gpio47", "gpio48",
"gpio49", "gpio50", "gpio51", "gpio52", "gpio53", "gpio54",
"gpio58", "gpio59", "gpio65", "gpio66", "gpio67", "gpio72",
"gpio73", "gpio74", "gpio75", "gpio80", "gpio81", "gpio83",
};
static const char * const audio_ext_groups[] = {
"gpio134", "gpio142",
};
static const char * const audio_ref_groups[] = {
"gpio142",
};
static const char * const cam_aon_groups[] = {
"gpio100",
};
static const char * const cam_mclk_groups[] = {
"gpio96", "gpio97", "gpio98", "gpio99",
};
static const char * const cci_async_groups[] = {
"gpio111", "gpio112", "gpio113",
};
static const char * const cci_i2c_groups[] = {
"gpio101", "gpio102", "gpio103", "gpio104", "gpio105", "gpio106",
};
static const char * const cci_timer0_groups[] = {
"gpio109",
};
static const char * const cci_timer1_groups[] = {
"gpio110",
};
static const char * const cci_timer2_groups[] = {
"gpio111",
};
static const char * const cci_timer3_groups[] = {
"gpio112",
};
static const char * const cci_timer4_groups[] = {
"gpio113",
};
static const char * const cmu_rng0_groups[] = {
"gpio48",
};
static const char * const cmu_rng1_groups[] = {
"gpio47",
};
static const char * const cmu_rng2_groups[] = {
"gpio46",
};
static const char * const cmu_rng3_groups[] = {
"gpio45",
};
static const char * const cri_trng_groups[] = {
"gpio187",
};
static const char * const dbg_out_groups[] = {
"gpio51",
};
static const char * const ddr_bist_groups[] = {
"gpio54", "gpio55", "gpio56", "gpio57",
};
static const char * const ddr_pxi0_groups[] = {
"gpio9", "gpio38",
};
static const char * const ddr_pxi1_groups[] = {
"gpio10", "gpio41",
};
static const char * const ddr_pxi2_groups[] = {
"gpio42", "gpio43",
};
static const char * const ddr_pxi3_groups[] = {
"gpio44", "gpio45",
};
static const char * const ddr_pxi4_groups[] = {
"gpio46", "gpio47",
};
static const char * const ddr_pxi5_groups[] = {
"gpio48", "gpio49",
};
static const char * const ddr_pxi6_groups[] = {
"gpio50", "gpio51",
};
static const char * const ddr_pxi7_groups[] = {
"gpio52", "gpio53",
};
static const char * const edp0_hot_groups[] = {
"gpio119",
};
static const char * const edp0_lcd_groups[] = {
"gpio120",
};
static const char * const edp1_hot_groups[] = {
"gpio120",
};
static const char * const edp1_lcd_groups[] = {
"gpio115", "gpio119",
};
static const char * const eusb0_ac_groups[] = {
"gpio168",
};
static const char * const eusb1_ac_groups[] = {
"gpio177",
};
static const char * const eusb2_ac_groups[] = {
"gpio186",
};
static const char * const eusb3_ac_groups[] = {
"gpio169",
};
static const char * const eusb5_ac_groups[] = {
"gpio187",
};
static const char * const eusb6_ac_groups[] = {
"gpio178",
};
static const char * const gcc_gp1_groups[] = {
"gpio71", "gpio72",
};
static const char * const gcc_gp2_groups[] = {
"gpio64", "gpio73",
};
static const char * const gcc_gp3_groups[] = {
"gpio74", "gpio82",
};
static const char * const i2s0_data0_groups[] = {
"gpio136",
};
static const char * const i2s0_data1_groups[] = {
"gpio137",
};
static const char * const i2s0_sck_groups[] = {
"gpio135",
};
static const char * const i2s0_ws_groups[] = {
"gpio138",
};
static const char * const i2s1_data0_groups[] = {
"gpio140",
};
static const char * const i2s1_data1_groups[] = {
"gpio142",
};
static const char * const i2s1_sck_groups[] = {
"gpio139",
};
static const char * const i2s1_ws_groups[] = {
"gpio141",
};
static const char * const ibi_i3c_groups[] = {
"gpio0", "gpio1", "gpio32", "gpio33", "gpio36", "gpio37", "gpio68",
"gpio69",
};
static const char * const jitter_bist_groups[] = {
"gpio42",
};
static const char * const mdp_vsync0_groups[] = {
"gpio114",
};
static const char * const mdp_vsync1_groups[] = {
"gpio114",
};
static const char * const mdp_vsync2_groups[] = {
"gpio115",
};
static const char * const mdp_vsync3_groups[] = {
"gpio115",
};
static const char * const mdp_vsync4_groups[] = {
"gpio109",
};
static const char * const mdp_vsync5_groups[] = {
"gpio110",
};
static const char * const mdp_vsync6_groups[] = {
"gpio111",
};
static const char * const mdp_vsync7_groups[] = {
"gpio112",
};
static const char * const mdp_vsync8_groups[] = {
"gpio113",
};
static const char * const pcie3_clk_groups[] = {
"gpio144",
};
static const char * const pcie4_clk_groups[] = {
"gpio147",
};
static const char * const pcie5_clk_groups[] = {
"gpio150",
};
static const char * const pcie6a_clk_groups[] = {
"gpio153",
};
static const char * const pcie6b_clk_groups[] = {
"gpio156",
};
static const char * const phase_flag_groups[] = {
"gpio6", "gpio7", "gpio8", "gpio11", "gpio12", "gpio13",
"gpio14", "gpio15", "gpio16", "gpio17", "gpio18", "gpio19",
"gpio20", "gpio21", "gpio22", "gpio23", "gpio24", "gpio25",
"gpio26", "gpio27", "gpio39", "gpio40", "gpio76", "gpio77",
"gpio78", "gpio181", "gpio182", "gpio184", "gpio185",
"gpio186", "gpio187", "gpio188",
};
static const char * const pll_bist_groups[] = {
"gpio28",
};
static const char * const pll_clk_groups[] = {
"gpio35",
};
static const char * const prng_rosc0_groups[] = {
"gpio186",
};
static const char * const prng_rosc1_groups[] = {
"gpio188",
};
static const char * const prng_rosc2_groups[] = {
"gpio182",
};
static const char * const prng_rosc3_groups[] = {
"gpio181",
};
static const char * const qdss_cti_groups[] = {
"gpio18", "gpio19", "gpio23", "gpio27", "gpio161", "gpio162",
"gpio215", "gpio217",
};
static const char * const qdss_gpio_groups[] = {
"gpio96", "gpio97", "gpio98", "gpio99", "gpio100", "gpio101",
"gpio102", "gpio103", "gpio104", "gpio105", "gpio106", "gpio107",
"gpio108", "gpio109", "gpio110", "gpio111", "gpio112", "gpio113",
"gpio219", "gpio220", "gpio221", "gpio222", "gpio223", "gpio224",
"gpio225", "gpio226", "gpio227", "gpio228", "gpio229", "gpio230",
"gpio231", "gpio232", "gpio233", "gpio234", "gpio235", "gpio236",
};
static const char * const qspi00_groups[] = {
"gpio128",
};
static const char * const qspi01_groups[] = {
"gpio129",
};
static const char * const qspi02_groups[] = {
"gpio130",
};
static const char * const qspi03_groups[] = {
"gpio131",
};
static const char * const qspi0_clk_groups[] = {
"gpio127",
};
static const char * const qspi0_cs0_groups[] = {
"gpio132",
};
static const char * const qspi0_cs1_groups[] = {
"gpio133",
};
static const char * const qup0_se0_groups[] = {
"gpio0", "gpio1", "gpio2", "gpio3",
};
static const char * const qup0_se1_groups[] = {
"gpio4", "gpio5", "gpio6", "gpio7",
};
static const char * const qup0_se2_groups[] = {
"gpio8", "gpio9", "gpio10", "gpio11", "gpio17", "gpio18", "gpio19",
};
static const char * const qup0_se3_groups[] = {
"gpio12", "gpio13", "gpio14", "gpio15", "gpio21", "gpio22", "gpio23",
};
static const char * const qup0_se4_groups[] = {
"gpio16", "gpio17", "gpio18", "gpio19",
};
static const char * const qup0_se5_groups[] = {
"gpio20", "gpio21", "gpio22", "gpio23",
};
static const char * const qup0_se6_groups[] = {
"gpio24", "gpio25", "gpio26", "gpio27",
};
static const char * const qup0_se7_groups[] = {
"gpio12", "gpio13", "gpio14", "gpio15",
};
static const char * const qup1_se0_groups[] = {
"gpio32", "gpio33", "gpio34", "gpio35",
};
static const char * const qup1_se1_groups[] = {
"gpio36", "gpio37", "gpio38", "gpio39",
};
static const char * const qup1_se2_groups[] = {
"gpio40", "gpio41", "gpio42", "gpio43", "gpio49", "gpio50", "gpio51",
};
static const char * const qup1_se3_groups[] = {
"gpio33", "gpio34", "gpio35", "gpio44", "gpio45", "gpio46", "gpio47",
};
static const char * const qup1_se4_groups[] = {
"gpio48", "gpio49", "gpio50", "gpio51",
};
static const char * const qup1_se5_groups[] = {
"gpio52", "gpio53", "gpio54", "gpio55",
};
static const char * const qup1_se6_groups[] = {
"gpio56", "gpio57", "gpio58", "gpio59",
};
static const char * const qup1_se7_groups[] = {
"gpio52", "gpio53", "gpio54", "gpio55",
};
static const char * const qup2_se0_groups[] = {
"gpio64", "gpio65", "gpio66", "gpio67",
};
static const char * const qup2_se1_groups[] = {
"gpio68", "gpio69", "gpio70", "gpio71",
};
static const char * const qup2_se2_groups[] = {
"gpio72", "gpio73", "gpio74", "gpio75", "gpio81", "gpio82", "gpio83",
};
static const char * const qup2_se3_groups[] = {
"gpio65", "gpio66", "gpio67", "gpio76", "gpio77", "gpio78", "gpio79",
};
static const char * const qup2_se4_groups[] = {
"gpio80", "gpio81", "gpio82", "gpio83",
};
static const char * const qup2_se5_groups[] = {
"gpio84", "gpio85", "gpio86", "gpio87",
};
static const char * const qup2_se6_groups[] = {
"gpio88", "gpio89", "gpio90", "gpio91",
};
static const char * const qup2_se7_groups[] = {
"gpio84", "gpio85", "gpio86", "gpio87",
};
static const char * const sd_write_groups[] = {
"gpio162",
};
static const char * const sdc4_clk_groups[] = {
"gpio127",
};
static const char * const sdc4_cmd_groups[] = {
"gpio132",
};
static const char * const sdc4_data0_groups[] = {
"gpio128",
};
static const char * const sdc4_data1_groups[] = {
"gpio129",
};
static const char * const sdc4_data2_groups[] = {
"gpio130",
};
static const char * const sdc4_data3_groups[] = {
"gpio131",
};
static const char * const sys_throttle_groups[] = {
"gpio39", "gpio94",
};
static const char * const tb_trig_groups[] = {
"gpio133", "gpio137",
};
static const char * const tgu_ch0_groups[] = {
"gpio81",
};
static const char * const tgu_ch1_groups[] = {
"gpio65",
};
static const char * const tgu_ch2_groups[] = {
"gpio66",
};
static const char * const tgu_ch3_groups[] = {
"gpio67",
};
static const char * const tgu_ch4_groups[] = {
"gpio68",
};
static const char * const tgu_ch5_groups[] = {
"gpio69",
};
static const char * const tgu_ch6_groups[] = {
"gpio83",
};
static const char * const tgu_ch7_groups[] = {
"gpio80",
};
static const char * const tmess_prng0_groups[] = {
"gpio92",
};
static const char * const tmess_prng1_groups[] = {
"gpio93",
};
static const char * const tmess_prng2_groups[] = {
"gpio94",
};
static const char * const tmess_prng3_groups[] = {
"gpio95",
};
static const char * const tsense_pwm1_groups[] = {
"gpio34",
};
static const char * const tsense_pwm2_groups[] = {
"gpio34",
};
static const char * const tsense_pwm3_groups[] = {
"gpio34",
};
static const char * const tsense_pwm4_groups[] = {
"gpio34",
};
static const char * const usb0_dp_groups[] = {
"gpio122",
};
static const char * const usb0_phy_groups[] = {
"gpio121",
};
static const char * const usb0_sbrx_groups[] = {
"gpio163",
};
static const char * const usb0_sbtx_groups[] = {
"gpio164", "gpio165",
};
static const char * const usb1_dp_groups[] = {
"gpio124",
};
static const char * const usb1_phy_groups[] = {
"gpio123",
};
static const char * const usb1_sbrx_groups[] = {
"gpio172",
};
static const char * const usb1_sbtx_groups[] = {
"gpio173", "gpio174",
};
static const char * const usb2_dp_groups[] = {
"gpio126",
};
static const char * const usb2_phy_groups[] = {
"gpio125",
};
static const char * const usb2_sbrx_groups[] = {
"gpio181",
};
static const char * const usb2_sbtx_groups[] = {
"gpio182", "gpio183",
};
static const char * const vsense_trigger_groups[] = {
"gpio38",
};
static const struct pinfunction x1e80100_functions[] = {
MSM_PIN_FUNCTION(gpio),
MSM_PIN_FUNCTION(RESOUT_GPIO),
MSM_PIN_FUNCTION(aon_cci),
MSM_PIN_FUNCTION(aoss_cti),
MSM_PIN_FUNCTION(atest_char),
MSM_PIN_FUNCTION(atest_char0),
MSM_PIN_FUNCTION(atest_char1),
MSM_PIN_FUNCTION(atest_char2),
MSM_PIN_FUNCTION(atest_char3),
MSM_PIN_FUNCTION(atest_usb),
MSM_PIN_FUNCTION(audio_ext),
MSM_PIN_FUNCTION(audio_ref),
MSM_PIN_FUNCTION(cam_aon),
MSM_PIN_FUNCTION(cam_mclk),
MSM_PIN_FUNCTION(cci_async),
MSM_PIN_FUNCTION(cci_i2c),
MSM_PIN_FUNCTION(cci_timer0),
MSM_PIN_FUNCTION(cci_timer1),
MSM_PIN_FUNCTION(cci_timer2),
MSM_PIN_FUNCTION(cci_timer3),
MSM_PIN_FUNCTION(cci_timer4),
MSM_PIN_FUNCTION(cmu_rng0),
MSM_PIN_FUNCTION(cmu_rng1),
MSM_PIN_FUNCTION(cmu_rng2),
MSM_PIN_FUNCTION(cmu_rng3),
MSM_PIN_FUNCTION(cri_trng),
MSM_PIN_FUNCTION(dbg_out),
MSM_PIN_FUNCTION(ddr_bist),
MSM_PIN_FUNCTION(ddr_pxi0),
MSM_PIN_FUNCTION(ddr_pxi1),
MSM_PIN_FUNCTION(ddr_pxi2),
MSM_PIN_FUNCTION(ddr_pxi3),
MSM_PIN_FUNCTION(ddr_pxi4),
MSM_PIN_FUNCTION(ddr_pxi5),
MSM_PIN_FUNCTION(ddr_pxi6),
MSM_PIN_FUNCTION(ddr_pxi7),
MSM_PIN_FUNCTION(edp0_hot),
MSM_PIN_FUNCTION(edp0_lcd),
MSM_PIN_FUNCTION(edp1_hot),
MSM_PIN_FUNCTION(edp1_lcd),
MSM_PIN_FUNCTION(eusb0_ac),
MSM_PIN_FUNCTION(eusb1_ac),
MSM_PIN_FUNCTION(eusb2_ac),
MSM_PIN_FUNCTION(eusb3_ac),
MSM_PIN_FUNCTION(eusb5_ac),
MSM_PIN_FUNCTION(eusb6_ac),
MSM_PIN_FUNCTION(gcc_gp1),
MSM_PIN_FUNCTION(gcc_gp2),
MSM_PIN_FUNCTION(gcc_gp3),
MSM_PIN_FUNCTION(i2s0_data0),
MSM_PIN_FUNCTION(i2s0_data1),
MSM_PIN_FUNCTION(i2s0_sck),
MSM_PIN_FUNCTION(i2s0_ws),
MSM_PIN_FUNCTION(i2s1_data0),
MSM_PIN_FUNCTION(i2s1_data1),
MSM_PIN_FUNCTION(i2s1_sck),
MSM_PIN_FUNCTION(i2s1_ws),
MSM_PIN_FUNCTION(ibi_i3c),
MSM_PIN_FUNCTION(jitter_bist),
MSM_PIN_FUNCTION(mdp_vsync0),
MSM_PIN_FUNCTION(mdp_vsync1),
MSM_PIN_FUNCTION(mdp_vsync2),
MSM_PIN_FUNCTION(mdp_vsync3),
MSM_PIN_FUNCTION(mdp_vsync4),
MSM_PIN_FUNCTION(mdp_vsync5),
MSM_PIN_FUNCTION(mdp_vsync6),
MSM_PIN_FUNCTION(mdp_vsync7),
MSM_PIN_FUNCTION(mdp_vsync8),
MSM_PIN_FUNCTION(pcie3_clk),
MSM_PIN_FUNCTION(pcie4_clk),
MSM_PIN_FUNCTION(pcie5_clk),
MSM_PIN_FUNCTION(pcie6a_clk),
MSM_PIN_FUNCTION(pcie6b_clk),
MSM_PIN_FUNCTION(phase_flag),
MSM_PIN_FUNCTION(pll_bist),
MSM_PIN_FUNCTION(pll_clk),
MSM_PIN_FUNCTION(prng_rosc0),
MSM_PIN_FUNCTION(prng_rosc1),
MSM_PIN_FUNCTION(prng_rosc2),
MSM_PIN_FUNCTION(prng_rosc3),
MSM_PIN_FUNCTION(qdss_cti),
MSM_PIN_FUNCTION(qdss_gpio),
MSM_PIN_FUNCTION(qspi00),
MSM_PIN_FUNCTION(qspi01),
MSM_PIN_FUNCTION(qspi02),
MSM_PIN_FUNCTION(qspi03),
MSM_PIN_FUNCTION(qspi0_clk),
MSM_PIN_FUNCTION(qspi0_cs0),
MSM_PIN_FUNCTION(qspi0_cs1),
MSM_PIN_FUNCTION(qup0_se0),
MSM_PIN_FUNCTION(qup0_se1),
MSM_PIN_FUNCTION(qup0_se2),
MSM_PIN_FUNCTION(qup0_se3),
MSM_PIN_FUNCTION(qup0_se4),
MSM_PIN_FUNCTION(qup0_se5),
MSM_PIN_FUNCTION(qup0_se6),
MSM_PIN_FUNCTION(qup0_se7),
MSM_PIN_FUNCTION(qup1_se0),
MSM_PIN_FUNCTION(qup1_se1),
MSM_PIN_FUNCTION(qup1_se2),
MSM_PIN_FUNCTION(qup1_se3),
MSM_PIN_FUNCTION(qup1_se4),
MSM_PIN_FUNCTION(qup1_se5),
MSM_PIN_FUNCTION(qup1_se6),
MSM_PIN_FUNCTION(qup1_se7),
MSM_PIN_FUNCTION(qup2_se0),
MSM_PIN_FUNCTION(qup2_se1),
MSM_PIN_FUNCTION(qup2_se2),
MSM_PIN_FUNCTION(qup2_se3),
MSM_PIN_FUNCTION(qup2_se4),
MSM_PIN_FUNCTION(qup2_se5),
MSM_PIN_FUNCTION(qup2_se6),
MSM_PIN_FUNCTION(qup2_se7),
MSM_PIN_FUNCTION(sd_write),
MSM_PIN_FUNCTION(sdc4_clk),
MSM_PIN_FUNCTION(sdc4_cmd),
MSM_PIN_FUNCTION(sdc4_data0),
MSM_PIN_FUNCTION(sdc4_data1),
MSM_PIN_FUNCTION(sdc4_data2),
MSM_PIN_FUNCTION(sdc4_data3),
MSM_PIN_FUNCTION(sys_throttle),
MSM_PIN_FUNCTION(tb_trig),
MSM_PIN_FUNCTION(tgu_ch0),
MSM_PIN_FUNCTION(tgu_ch1),
MSM_PIN_FUNCTION(tgu_ch2),
MSM_PIN_FUNCTION(tgu_ch3),
MSM_PIN_FUNCTION(tgu_ch4),
MSM_PIN_FUNCTION(tgu_ch5),
MSM_PIN_FUNCTION(tgu_ch6),
MSM_PIN_FUNCTION(tgu_ch7),
MSM_PIN_FUNCTION(tmess_prng0),
MSM_PIN_FUNCTION(tmess_prng1),
MSM_PIN_FUNCTION(tmess_prng2),
MSM_PIN_FUNCTION(tmess_prng3),
MSM_PIN_FUNCTION(tsense_pwm1),
MSM_PIN_FUNCTION(tsense_pwm2),
MSM_PIN_FUNCTION(tsense_pwm3),
MSM_PIN_FUNCTION(tsense_pwm4),
MSM_PIN_FUNCTION(usb0_dp),
MSM_PIN_FUNCTION(usb0_phy),
MSM_PIN_FUNCTION(usb0_sbrx),
MSM_PIN_FUNCTION(usb0_sbtx),
MSM_PIN_FUNCTION(usb1_dp),
MSM_PIN_FUNCTION(usb1_phy),
MSM_PIN_FUNCTION(usb1_sbrx),
MSM_PIN_FUNCTION(usb1_sbtx),
MSM_PIN_FUNCTION(usb2_dp),
MSM_PIN_FUNCTION(usb2_phy),
MSM_PIN_FUNCTION(usb2_sbrx),
MSM_PIN_FUNCTION(usb2_sbtx),
MSM_PIN_FUNCTION(vsense_trigger),
};
/*
* Every pin is maintained as a single group, and missing or non-existing pin
* would be maintained as dummy group to synchronize pin group index with
* pin descriptor registered with pinctrl core.
* Clients would not be able to request these dummy pin groups.
*/
static const struct msm_pingroup x1e80100_groups[] = {
[0] = PINGROUP(0, qup0_se0, ibi_i3c, _, _, _, _, _, _, _),
[1] = PINGROUP(1, qup0_se0, ibi_i3c, _, _, _, _, _, _, _),
[2] = PINGROUP(2, qup0_se0, _, _, _, _, _, _, _, _),
[3] = PINGROUP(3, qup0_se0, _, _, _, _, _, _, _, _),
[4] = PINGROUP(4, qup0_se1, _, _, _, _, _, _, _, _),
[5] = PINGROUP(5, qup0_se1, _, _, _, _, _, _, _, _),
[6] = PINGROUP(6, qup0_se1, phase_flag, _, _, _, _, _, _, _),
[7] = PINGROUP(7, qup0_se1, phase_flag, _, _, _, _, _, _, _),
[8] = PINGROUP(8, qup0_se2, phase_flag, _, _, _, _, _, _, _),
[9] = PINGROUP(9, qup0_se2, _, atest_usb, ddr_pxi0, _, _, _, _, _),
[10] = PINGROUP(10, qup0_se2, _, atest_usb, ddr_pxi1, _, _, _, _, _),
[11] = PINGROUP(11, qup0_se2, phase_flag, _, _, _, _, _, _, _),
[12] = PINGROUP(12, qup0_se3, qup0_se7, phase_flag, _, _, _, _, _, _),
[13] = PINGROUP(13, qup0_se3, qup0_se7, phase_flag, _, _, _, _, _, _),
[14] = PINGROUP(14, qup0_se3, qup0_se7, phase_flag, _, _, _, _, _, _),
[15] = PINGROUP(15, qup0_se3, qup0_se7, phase_flag, _, _, _, _, _, _),
[16] = PINGROUP(16, qup0_se4, phase_flag, _, _, _, _, _, _, _),
[17] = PINGROUP(17, qup0_se4, qup0_se2, phase_flag, _, _, _, _, _, _),
[18] = PINGROUP(18, qup0_se4, qup0_se2, phase_flag, _, qdss_cti, _, _, _, _),
[19] = PINGROUP(19, qup0_se4, qup0_se2, phase_flag, _, qdss_cti, _, _, _, _),
[20] = PINGROUP(20, qup0_se5, _, phase_flag, _, _, _, _, _, _),
[21] = PINGROUP(21, qup0_se5, qup0_se3, _, phase_flag, _, _, _, _, _),
[22] = PINGROUP(22, qup0_se5, qup0_se3, _, phase_flag, _, _, _, _, _),
[23] = PINGROUP(23, qup0_se5, qup0_se3, phase_flag, _, qdss_cti, _, _, _, _),
[24] = PINGROUP(24, qup0_se6, phase_flag, _, _, _, _, _, _, _),
[25] = PINGROUP(25, qup0_se6, phase_flag, _, _, _, _, _, _, _),
[26] = PINGROUP(26, qup0_se6, phase_flag, _, _, _, _, _, _, _),
[27] = PINGROUP(27, qup0_se6, phase_flag, _, qdss_cti, _, _, _, _, _),
[28] = PINGROUP(28, pll_bist, _, _, _, _, _, _, _, _),
[29] = PINGROUP(29, _, _, _, _, _, _, _, _, _),
[30] = PINGROUP(30, _, _, _, _, _, _, _, _, _),
[31] = PINGROUP(31, _, _, _, _, _, _, _, _, _),
[32] = PINGROUP(32, qup1_se0, ibi_i3c, _, _, _, _, _, _, _),
[33] = PINGROUP(33, qup1_se0, ibi_i3c, qup1_se3, _, _, _, _, _, _),
[34] = PINGROUP(34, qup1_se0, qup1_se3, tsense_pwm1, tsense_pwm2, tsense_pwm3, tsense_pwm4, _, _, _),
[35] = PINGROUP(35, qup1_se0, qup1_se3, pll_clk, atest_usb, _, _, _, _, _),
[36] = PINGROUP(36, qup1_se1, ibi_i3c, _, _, _, _, _, _, _),
[37] = PINGROUP(37, qup1_se1, ibi_i3c, _, _, _, _, _, _, _),
[38] = PINGROUP(38, qup1_se1, vsense_trigger, atest_usb, ddr_pxi0, _, _, _, _, _),
[39] = PINGROUP(39, qup1_se1, sys_throttle, phase_flag, _, _, _, _, _, _),
[40] = PINGROUP(40, qup1_se2, phase_flag, _, _, _, _, _, _, _),
[41] = PINGROUP(41, qup1_se2, atest_usb, ddr_pxi1, _, _, _, _, _, _),
[42] = PINGROUP(42, qup1_se2, jitter_bist, atest_usb, ddr_pxi2, _, _, _, _, _),
[43] = PINGROUP(43, qup1_se2, _, atest_usb, ddr_pxi2, _, _, _, _, _),
[44] = PINGROUP(44, qup1_se3, _, atest_usb, ddr_pxi3, _, _, _, _, _),
[45] = PINGROUP(45, qup1_se3, cmu_rng3, _, atest_usb, ddr_pxi3, _, _, _, _),
[46] = PINGROUP(46, qup1_se3, cmu_rng2, _, atest_usb, ddr_pxi4, _, _, _, _),
[47] = PINGROUP(47, qup1_se3, cmu_rng1, _, atest_usb, ddr_pxi4, _, _, _, _),
[48] = PINGROUP(48, qup1_se4, cmu_rng0, _, atest_usb, ddr_pxi5, _, _, _, _),
[49] = PINGROUP(49, qup1_se4, qup1_se2, _, atest_usb, ddr_pxi5, _, _, _, _),
[50] = PINGROUP(50, qup1_se4, qup1_se2, _, atest_usb, ddr_pxi6, _, _, _, _),
[51] = PINGROUP(51, qup1_se4, qup1_se2, dbg_out, atest_usb, ddr_pxi6, _, _, _, _),
[52] = PINGROUP(52, qup1_se5, qup1_se7, atest_usb, ddr_pxi7, _, _, _, _, _),
[53] = PINGROUP(53, qup1_se5, qup1_se7, _, atest_usb, ddr_pxi7, _, _, _, _),
[54] = PINGROUP(54, qup1_se5, qup1_se7, ddr_bist, atest_usb, _, _, _, _, _),
[55] = PINGROUP(55, qup1_se5, qup1_se7, ddr_bist, _, _, _, _, _, _),
[56] = PINGROUP(56, qup1_se6, ddr_bist, _, _, _, _, _, _, _),
[57] = PINGROUP(57, qup1_se6, ddr_bist, _, _, _, _, _, _, _),
[58] = PINGROUP(58, qup1_se6, atest_usb, _, _, _, _, _, _, _),
[59] = PINGROUP(59, qup1_se6, atest_usb, _, _, _, _, _, _, _),
[60] = PINGROUP(60, aoss_cti, _, _, _, _, _, _, _, _),
[61] = PINGROUP(61, aoss_cti, _, _, _, _, _, _, _, _),
[62] = PINGROUP(62, aoss_cti, _, _, _, _, _, _, _, _),
[63] = PINGROUP(63, aoss_cti, _, _, _, _, _, _, _, _),
[64] = PINGROUP(64, qup2_se0, gcc_gp2, _, _, _, _, _, _, _),
[65] = PINGROUP(65, qup2_se0, qup2_se3, tgu_ch1, atest_usb, _, _, _, _, _),
[66] = PINGROUP(66, qup2_se0, qup2_se3, tgu_ch2, atest_usb, _, _, _, _, _),
[67] = PINGROUP(67, qup2_se0, qup2_se3, tgu_ch3, atest_usb, _, _, _, _, _),
[68] = PINGROUP(68, qup2_se1, ibi_i3c, tgu_ch4, _, _, _, _, _, _),
[69] = PINGROUP(69, qup2_se1, ibi_i3c, tgu_ch5, _, _, _, _, _, _),
[70] = PINGROUP(70, qup2_se1, _, _, _, _, _, _, _, _),
[71] = PINGROUP(71, qup2_se1, gcc_gp1, _, _, _, _, _, _, _),
[72] = PINGROUP(72, qup2_se2, gcc_gp1, atest_usb, _, _, _, _, _, _),
[73] = PINGROUP(73, qup2_se2, gcc_gp2, atest_usb, _, _, _, _, _, _),
[74] = PINGROUP(74, qup2_se2, gcc_gp3, atest_usb, _, _, _, _, _, _),
[75] = PINGROUP(75, qup2_se2, atest_usb, _, _, _, _, _, _, _),
[76] = PINGROUP(76, qup2_se3, phase_flag, _, _, _, _, _, _, _),
[77] = PINGROUP(77, qup2_se3, phase_flag, _, _, _, _, _, _, _),
[78] = PINGROUP(78, qup2_se3, phase_flag, _, _, _, _, _, _, _),
[79] = PINGROUP(79, qup2_se3, _, _, _, _, _, _, _, _),
[80] = PINGROUP(80, qup2_se4, tgu_ch7, atest_usb, _, _, _, _, _, _),
[81] = PINGROUP(81, qup2_se4, qup2_se2, tgu_ch0, atest_usb, _, _, _, _, _),
[82] = PINGROUP(82, qup2_se4, qup2_se2, gcc_gp3, _, _, _, _, _, _),
[83] = PINGROUP(83, qup2_se4, qup2_se2, tgu_ch6, atest_usb, _, _, _, _, _),
[84] = PINGROUP(84, qup2_se5, qup2_se7, _, _, _, _, _, _, _),
[85] = PINGROUP(85, qup2_se5, qup2_se7, _, _, _, _, _, _, _),
[86] = PINGROUP(86, qup2_se5, qup2_se7, _, _, _, _, _, _, _),
[87] = PINGROUP(87, qup2_se5, qup2_se7, _, _, _, _, _, _, _),
[88] = PINGROUP(88, qup2_se6, _, _, _, _, _, _, _, _),
[89] = PINGROUP(89, qup2_se6, _, _, _, _, _, _, _, _),
[90] = PINGROUP(90, qup2_se6, _, _, _, _, _, _, _, _),
[91] = PINGROUP(91, qup2_se6, _, _, _, _, _, _, _, _),
[92] = PINGROUP(92, tmess_prng0, _, _, _, _, _, _, _, _),
[93] = PINGROUP(93, tmess_prng1, _, _, _, _, _, _, _, _),
[94] = PINGROUP(94, sys_throttle, tmess_prng2, _, _, _, _, _, _, _),
[95] = PINGROUP(95, tmess_prng3, _, _, _, _, _, _, _, _),
[96] = PINGROUP(96, cam_mclk, qdss_gpio, _, _, _, _, _, _, _),
[97] = PINGROUP(97, cam_mclk, qdss_gpio, _, _, _, _, _, _, _),
[98] = PINGROUP(98, cam_mclk, qdss_gpio, _, _, _, _, _, _, _),
[99] = PINGROUP(99, cam_mclk, qdss_gpio, _, _, _, _, _, _, _),
[100] = PINGROUP(100, cam_aon, qdss_gpio, _, _, _, _, _, _, _),
[101] = PINGROUP(101, cci_i2c, qdss_gpio, _, _, _, _, _, _, _),
[102] = PINGROUP(102, cci_i2c, qdss_gpio, _, _, _, _, _, _, _),
[103] = PINGROUP(103, cci_i2c, qdss_gpio, _, _, _, _, _, _, _),
[104] = PINGROUP(104, cci_i2c, qdss_gpio, _, _, _, _, _, _, _),
[105] = PINGROUP(105, cci_i2c, qdss_gpio, _, _, _, _, _, _, _),
[106] = PINGROUP(106, cci_i2c, qdss_gpio, _, _, _, _, _, _, _),
[107] = PINGROUP(107, qdss_gpio, _, _, _, _, _, _, _, _),
[108] = PINGROUP(108, qdss_gpio, _, _, _, _, _, _, _, _),
[109] = PINGROUP(109, cci_timer0, mdp_vsync4, qdss_gpio, _, _, _, _, _, _),
[110] = PINGROUP(110, cci_timer1, mdp_vsync5, qdss_gpio, _, _, _, _, _, _),
[111] = PINGROUP(111, cci_timer2, cci_async, mdp_vsync6, qdss_gpio, _, _, _, _, _),
[112] = PINGROUP(112, cci_timer3, cci_async, mdp_vsync7, qdss_gpio, _, _, _, _, _),
[113] = PINGROUP(113, cci_timer4, cci_async, mdp_vsync8, qdss_gpio, _, _, _, _, _),
[114] = PINGROUP(114, mdp_vsync0, mdp_vsync1, _, _, _, _, _, _, _),
[115] = PINGROUP(115, mdp_vsync3, mdp_vsync2, edp1_lcd, _, _, _, _, _, _),
[116] = PINGROUP(116, _, _, _, _, _, _, _, _, _),
[117] = PINGROUP(117, _, _, _, _, _, _, _, _, _),
[118] = PINGROUP(118, _, _, _, _, _, _, _, _, _),
[119] = PINGROUP(119, edp0_hot, edp1_lcd, _, _, _, _, _, _, _),
[120] = PINGROUP(120, edp1_hot, edp0_lcd, _, _, _, _, _, _, _),
[121] = PINGROUP(121, usb0_phy, _, _, _, _, _, _, _, _),
[122] = PINGROUP(122, usb0_dp, _, _, _, _, _, _, _, _),
[123] = PINGROUP(123, usb1_phy, _, _, _, _, _, _, _, _),
[124] = PINGROUP(124, usb1_dp, _, _, _, _, _, _, _, _),
[125] = PINGROUP(125, usb2_phy, _, _, _, _, _, _, _, _),
[126] = PINGROUP(126, usb2_dp, _, _, _, _, _, _, _, _),
[127] = PINGROUP(127, qspi0_clk, sdc4_clk, _, _, _, _, _, _, _),
[128] = PINGROUP(128, qspi00, sdc4_data0, _, _, _, _, _, _, _),
[129] = PINGROUP(129, qspi01, sdc4_data1, _, _, _, _, _, _, _),
[130] = PINGROUP(130, qspi02, sdc4_data2, _, _, _, _, _, _, _),
[131] = PINGROUP(131, qspi03, sdc4_data3, _, _, _, _, _, _, _),
[132] = PINGROUP(132, qspi0_cs0, sdc4_cmd, _, _, _, _, _, _, _),
[133] = PINGROUP(133, qspi0_cs1, tb_trig, _, _, _, _, _, _, _),
[134] = PINGROUP(134, audio_ext, _, _, _, _, _, _, _, _),
[135] = PINGROUP(135, i2s0_sck, _, _, _, _, _, _, _, _),
[136] = PINGROUP(136, i2s0_data0, _, _, _, _, _, _, _, _),
[137] = PINGROUP(137, i2s0_data1, tb_trig, _, _, _, _, _, _, _),
[138] = PINGROUP(138, i2s0_ws, _, _, _, _, _, _, _, _),
[139] = PINGROUP(139, i2s1_sck, _, _, _, _, _, _, _, _),
[140] = PINGROUP(140, i2s1_data0, _, _, _, _, _, _, _, _),
[141] = PINGROUP(141, i2s1_ws, _, _, _, _, _, _, _, _),
[142] = PINGROUP(142, i2s1_data1, audio_ext, audio_ref, _, _, _, _, _, _),
[143] = PINGROUP(143, _, _, _, _, _, _, _, _, _),
[144] = PINGROUP(144, pcie3_clk, _, _, _, _, _, _, _, _),
[145] = PINGROUP(145, _, _, _, _, _, _, _, _, _),
[146] = PINGROUP(146, _, _, _, _, _, _, _, _, _),
[147] = PINGROUP(147, pcie4_clk, _, _, _, _, _, _, _, _),
[148] = PINGROUP(148, _, _, _, _, _, _, _, _, _),
[149] = PINGROUP(149, _, _, _, _, _, _, _, _, _),
[150] = PINGROUP(150, pcie5_clk, _, _, _, _, _, _, _, _),
[151] = PINGROUP(151, _, _, _, _, _, _, _, _, _),
[152] = PINGROUP(152, _, _, _, _, _, _, _, _, _),
[153] = PINGROUP(153, pcie6a_clk, _, _, _, _, _, _, _, _),
[154] = PINGROUP(154, _, _, _, _, _, _, _, _, _),
[155] = PINGROUP(155, _, _, _, _, _, _, _, _, _),
[156] = PINGROUP(156, pcie6b_clk, _, _, _, _, _, _, _, _),
[157] = PINGROUP(157, _, _, _, _, _, _, _, _, _),
[158] = PINGROUP(158, _, _, _, _, _, _, _, _, _),
[159] = PINGROUP(159, _, _, _, _, _, _, _, _, _),
[160] = PINGROUP(160, RESOUT_GPIO, _, _, _, _, _, _, _, _),
[161] = PINGROUP(161, qdss_cti, _, _, _, _, _, _, _, _),
[162] = PINGROUP(162, sd_write, qdss_cti, _, _, _, _, _, _, _),
[163] = PINGROUP(163, usb0_sbrx, _, _, _, _, _, _, _, _),
[164] = PINGROUP(164, usb0_sbtx, _, _, _, _, _, _, _, _),
[165] = PINGROUP(165, usb0_sbtx, _, _, _, _, _, _, _, _),
[166] = PINGROUP(166, _, _, _, _, _, _, _, _, _),
[167] = PINGROUP(167, _, _, _, _, _, _, _, _, _),
[168] = PINGROUP(168, eusb0_ac, _, _, _, _, _, _, _, _),
[169] = PINGROUP(169, eusb3_ac, _, _, _, _, _, _, _, _),
[170] = PINGROUP(170, _, _, _, _, _, _, _, _, _),
[171] = PINGROUP(171, _, _, _, _, _, _, _, _, _),
[172] = PINGROUP(172, usb1_sbrx, _, _, _, _, _, _, _, _),
[173] = PINGROUP(173, usb1_sbtx, _, _, _, _, _, _, _, _),
[174] = PINGROUP(174, usb1_sbtx, _, _, _, _, _, _, _, _),
[175] = PINGROUP(175, _, _, _, _, _, _, _, _, _),
[176] = PINGROUP(176, _, _, _, _, _, _, _, _, _),
[177] = PINGROUP(177, eusb1_ac, _, _, _, _, _, _, _, _),
[178] = PINGROUP(178, eusb6_ac, _, _, _, _, _, _, _, _),
[179] = PINGROUP(179, _, _, _, _, _, _, _, _, _),
[180] = PINGROUP(180, _, _, _, _, _, _, _, _, _),
[181] = PINGROUP(181, usb2_sbrx, prng_rosc3, phase_flag, _, atest_char, _, _, _, _),
[182] = PINGROUP(182, usb2_sbtx, prng_rosc2, phase_flag, _, atest_char3, _, _, _, _),
[183] = PINGROUP(183, usb2_sbtx, _, _, _, _, _, _, _, _),
[184] = PINGROUP(184, phase_flag, _, atest_char1, _, _, _, _, _, _),
[185] = PINGROUP(185, phase_flag, _, atest_char0, _, _, _, _, _, _),
[186] = PINGROUP(186, eusb2_ac, prng_rosc0, phase_flag, _, _, _, _, _, _),
[187] = PINGROUP(187, eusb5_ac, cri_trng, phase_flag, _, _, _, _, _, _),
[188] = PINGROUP(188, prng_rosc1, phase_flag, _, atest_char2, _, _, _, _, _),
[189] = PINGROUP(189, _, _, _, _, _, _, _, _, _),
[190] = PINGROUP(190, _, _, _, _, _, _, _, _, _),
[191] = PINGROUP(191, _, _, _, _, _, _, _, _, _),
[192] = PINGROUP(192, _, _, _, _, _, _, _, _, _),
[193] = PINGROUP(193, _, _, _, _, _, _, _, _, _),
[194] = PINGROUP(194, _, _, _, _, _, _, _, _, _),
[195] = PINGROUP(195, _, _, _, _, _, _, _, _, _),
[196] = PINGROUP(196, _, _, _, _, _, _, _, _, _),
[197] = PINGROUP(197, _, _, _, _, _, _, _, _, _),
[198] = PINGROUP(198, _, _, _, _, _, _, _, _, _),
[199] = PINGROUP(199, _, _, _, _, _, _, _, _, _),
[200] = PINGROUP(200, _, _, _, _, _, _, _, _, _),
[201] = PINGROUP(201, _, _, _, _, _, _, _, _, _),
[202] = PINGROUP(202, _, _, _, _, _, _, _, _, _),
[203] = PINGROUP(203, _, _, _, _, _, _, _, _, _),
[204] = PINGROUP(204, _, _, _, _, _, _, _, _, _),
[205] = PINGROUP(205, _, _, _, _, _, _, _, _, _),
[206] = PINGROUP(206, _, _, _, _, _, _, _, _, _),
[207] = PINGROUP(207, _, _, _, _, _, _, _, _, _),
[208] = PINGROUP(208, _, _, _, _, _, _, _, _, _),
[209] = PINGROUP(209, _, _, _, _, _, _, _, _, _),
[210] = PINGROUP(210, _, _, _, _, _, _, _, _, _),
[211] = PINGROUP(211, _, _, _, _, _, _, _, _, _),
[212] = PINGROUP(212, _, _, _, _, _, _, _, _, _),
[213] = PINGROUP(213, _, _, _, _, _, _, _, _, _),
[214] = PINGROUP(214, _, _, _, _, _, _, _, _, _),
[215] = PINGROUP(215, _, qdss_cti, _, _, _, _, _, _, _),
[216] = PINGROUP(216, _, _, _, _, _, _, _, _, _),
[217] = PINGROUP(217, _, qdss_cti, _, _, _, _, _, _, _),
[218] = PINGROUP(218, _, _, _, _, _, _, _, _, _),
[219] = PINGROUP(219, _, qdss_gpio, _, _, _, _, _, _, _),
[220] = PINGROUP(220, _, qdss_gpio, _, _, _, _, _, _, _),
[221] = PINGROUP(221, _, qdss_gpio, _, _, _, _, _, _, _),
[222] = PINGROUP(222, _, qdss_gpio, _, _, _, _, _, _, _),
[223] = PINGROUP(223, _, qdss_gpio, _, _, _, _, _, _, _),
[224] = PINGROUP(224, _, qdss_gpio, _, _, _, _, _, _, _),
[225] = PINGROUP(225, _, qdss_gpio, _, _, _, _, _, _, _),
[226] = PINGROUP(226, _, qdss_gpio, _, _, _, _, _, _, _),
[227] = PINGROUP(227, _, qdss_gpio, _, _, _, _, _, _, _),
[228] = PINGROUP(228, _, qdss_gpio, _, _, _, _, _, _, _),
[229] = PINGROUP(229, qdss_gpio, _, _, _, _, _, _, _, _),
[230] = PINGROUP(230, qdss_gpio, _, _, _, _, _, _, _, _),
[231] = PINGROUP(231, qdss_gpio, _, _, _, _, _, _, _, _),
[232] = PINGROUP(232, qdss_gpio, _, _, _, _, _, _, _, _),
[233] = PINGROUP(233, qdss_gpio, _, _, _, _, _, _, _, _),
[234] = PINGROUP(234, qdss_gpio, _, _, _, _, _, _, _, _),
[235] = PINGROUP(235, aon_cci, qdss_gpio, _, _, _, _, _, _, _),
[236] = PINGROUP(236, aon_cci, qdss_gpio, _, _, _, _, _, _, _),
[237] = PINGROUP(237, _, _, _, _, _, _, _, _, _),
[238] = UFS_RESET(ufs_reset, 0xf9000),
[239] = SDC_QDSD_PINGROUP(sdc2_clk, 0xf2000, 14, 6),
[240] = SDC_QDSD_PINGROUP(sdc2_cmd, 0xf2000, 11, 3),
[241] = SDC_QDSD_PINGROUP(sdc2_data, 0xf2000, 9, 0),
};
static const struct msm_gpio_wakeirq_map x1e80100_pdc_map[] = {
{ 0, 72 }, { 2, 70 }, { 3, 71 }, { 6, 123 }, { 7, 67 }, { 11, 85 },
{ 13, 86 }, { 15, 68 }, { 18, 122 }, { 19, 69 }, { 21, 158 }, { 23, 143 },
{ 24, 126 }, { 26, 129 }, { 27, 144 }, { 28, 77 }, { 29, 78 }, { 30, 92 },
{ 31, 159 }, { 32, 145 }, { 33, 115 }, { 34, 130 }, { 35, 146 }, { 36, 147 },
{ 38, 113 }, { 39, 80 }, { 43, 148 }, { 47, 149 }, { 51, 79 }, { 53, 89 },
{ 55, 81 }, { 59, 87 }, { 64, 90 }, { 65, 106 }, { 66, 142 }, { 67, 88 },
{ 68, 151 }, { 71, 91 }, { 75, 152 }, { 79, 153 }, { 80, 125 }, { 81, 128 },
{ 83, 154 }, { 84, 137 }, { 85, 155 }, { 87, 156 }, { 91, 157 }, { 92, 138 },
{ 93, 139 }, { 94, 140 }, { 95, 141 }, { 113, 84 }, { 121, 73 }, { 123, 74 },
{ 125, 75 }, { 129, 76 }, { 131, 82 }, { 134, 83 }, { 141, 93 }, { 144, 94 },
{ 145, 95 }, { 147, 96 }, { 148, 97 }, { 150, 102 }, { 151, 103 }, { 153, 104 },
{ 154, 100 }, { 156, 105 }, { 157, 107 }, { 163, 98 }, { 166, 112 }, { 172, 99 },
{ 175, 114 }, { 181, 101 }, { 184, 116 }, { 193, 117 }, { 196, 108 }, { 203, 133 },
{ 208, 134 }, { 212, 120 }, { 213, 150 }, { 214, 121 }, { 215, 118 }, { 217, 109 },
{ 219, 119 }, { 220, 110 }, { 221, 111 }, { 222, 124 }, { 224, 131 }, { 225, 132 },
{ 228, 135 }, { 230, 136 }, { 232, 162 },
};
static const struct msm_pinctrl_soc_data x1e80100_pinctrl = {
.pins = x1e80100_pins,
.npins = ARRAY_SIZE(x1e80100_pins),
.functions = x1e80100_functions,
.nfunctions = ARRAY_SIZE(x1e80100_functions),
.groups = x1e80100_groups,
.ngroups = ARRAY_SIZE(x1e80100_groups),
.ngpios = 239,
.wakeirq_map = x1e80100_pdc_map,
/* TODO: Enabling PDC currently breaks GPIO interrupts */
.nwakeirq_map = 0,
/* .nwakeirq_map = ARRAY_SIZE(x1e80100_pdc_map), */
.egpio_func = 9,
};
static int x1e80100_pinctrl_probe(struct platform_device *pdev)
{
return msm_pinctrl_probe(pdev, &x1e80100_pinctrl);
}
static const struct of_device_id x1e80100_pinctrl_of_match[] = {
{ .compatible = "qcom,x1e80100-tlmm", },
{ },
};
static struct platform_driver x1e80100_pinctrl_driver = {
.driver = {
.name = "x1e80100-tlmm",
.of_match_table = x1e80100_pinctrl_of_match,
},
.probe = x1e80100_pinctrl_probe,
.remove_new = msm_pinctrl_remove,
};
static int __init x1e80100_pinctrl_init(void)
{
return platform_driver_register(&x1e80100_pinctrl_driver);
}
arch_initcall(x1e80100_pinctrl_init);
static void __exit x1e80100_pinctrl_exit(void)
{
platform_driver_unregister(&x1e80100_pinctrl_driver);
}
module_exit(x1e80100_pinctrl_exit);
MODULE_DESCRIPTION("QTI X1E80100 TLMM pinctrl driver");
MODULE_LICENSE("GPL");
MODULE_DEVICE_TABLE(of, x1e80100_pinctrl_of_match);