162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (c) 2017, The Linux Foundation. All rights reserved. 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#include <linux/module.h> 762306a36Sopenharmony_ci#include <linux/of.h> 862306a36Sopenharmony_ci#include <linux/platform_device.h> 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include "pinctrl-msm.h" 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#define REG_SIZE 0x1000 1362306a36Sopenharmony_ci#define PINGROUP(id, f1, f2, f3, f4, f5, f6, f7, f8, f9) \ 1462306a36Sopenharmony_ci { \ 1562306a36Sopenharmony_ci .grp = PINCTRL_PINGROUP("gpio" #id, \ 1662306a36Sopenharmony_ci gpio##id##_pins, \ 1762306a36Sopenharmony_ci ARRAY_SIZE(gpio##id##_pins)), \ 1862306a36Sopenharmony_ci .funcs = (int[]){ \ 1962306a36Sopenharmony_ci msm_mux_gpio, /* gpio mode */ \ 2062306a36Sopenharmony_ci msm_mux_##f1, \ 2162306a36Sopenharmony_ci msm_mux_##f2, \ 2262306a36Sopenharmony_ci msm_mux_##f3, \ 2362306a36Sopenharmony_ci msm_mux_##f4, \ 2462306a36Sopenharmony_ci msm_mux_##f5, \ 2562306a36Sopenharmony_ci msm_mux_##f6, \ 2662306a36Sopenharmony_ci msm_mux_##f7, \ 2762306a36Sopenharmony_ci msm_mux_##f8, \ 2862306a36Sopenharmony_ci msm_mux_##f9 \ 2962306a36Sopenharmony_ci }, \ 3062306a36Sopenharmony_ci .nfuncs = 10, \ 3162306a36Sopenharmony_ci .ctl_reg = REG_SIZE * id, \ 3262306a36Sopenharmony_ci .io_reg = 0x4 + REG_SIZE * id, \ 3362306a36Sopenharmony_ci .intr_cfg_reg = 0x8 + REG_SIZE * id, \ 3462306a36Sopenharmony_ci .intr_status_reg = 0xc + REG_SIZE * id, \ 3562306a36Sopenharmony_ci .intr_target_reg = 0x8 + REG_SIZE * id, \ 3662306a36Sopenharmony_ci .mux_bit = 2, \ 3762306a36Sopenharmony_ci .pull_bit = 0, \ 3862306a36Sopenharmony_ci .drv_bit = 6, \ 3962306a36Sopenharmony_ci .oe_bit = 9, \ 4062306a36Sopenharmony_ci .in_bit = 0, \ 4162306a36Sopenharmony_ci .out_bit = 1, \ 4262306a36Sopenharmony_ci .intr_enable_bit = 0, \ 4362306a36Sopenharmony_ci .intr_status_bit = 0, \ 4462306a36Sopenharmony_ci .intr_target_bit = 5, \ 4562306a36Sopenharmony_ci .intr_target_kpss_val = 3, \ 4662306a36Sopenharmony_ci .intr_raw_status_bit = 4, \ 4762306a36Sopenharmony_ci .intr_polarity_bit = 1, \ 4862306a36Sopenharmony_ci .intr_detection_bit = 2, \ 4962306a36Sopenharmony_ci .intr_detection_width = 2, \ 5062306a36Sopenharmony_ci } 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_cistatic const struct pinctrl_pin_desc ipq8074_pins[] = { 5362306a36Sopenharmony_ci PINCTRL_PIN(0, "GPIO_0"), 5462306a36Sopenharmony_ci PINCTRL_PIN(1, "GPIO_1"), 5562306a36Sopenharmony_ci PINCTRL_PIN(2, "GPIO_2"), 5662306a36Sopenharmony_ci PINCTRL_PIN(3, "GPIO_3"), 5762306a36Sopenharmony_ci PINCTRL_PIN(4, "GPIO_4"), 5862306a36Sopenharmony_ci PINCTRL_PIN(5, "GPIO_5"), 5962306a36Sopenharmony_ci PINCTRL_PIN(6, "GPIO_6"), 6062306a36Sopenharmony_ci PINCTRL_PIN(7, "GPIO_7"), 6162306a36Sopenharmony_ci PINCTRL_PIN(8, "GPIO_8"), 6262306a36Sopenharmony_ci PINCTRL_PIN(9, "GPIO_9"), 6362306a36Sopenharmony_ci PINCTRL_PIN(10, "GPIO_10"), 6462306a36Sopenharmony_ci PINCTRL_PIN(11, "GPIO_11"), 6562306a36Sopenharmony_ci PINCTRL_PIN(12, "GPIO_12"), 6662306a36Sopenharmony_ci PINCTRL_PIN(13, "GPIO_13"), 6762306a36Sopenharmony_ci PINCTRL_PIN(14, "GPIO_14"), 6862306a36Sopenharmony_ci PINCTRL_PIN(15, "GPIO_15"), 6962306a36Sopenharmony_ci PINCTRL_PIN(16, "GPIO_16"), 7062306a36Sopenharmony_ci PINCTRL_PIN(17, "GPIO_17"), 7162306a36Sopenharmony_ci PINCTRL_PIN(18, "GPIO_18"), 7262306a36Sopenharmony_ci PINCTRL_PIN(19, "GPIO_19"), 7362306a36Sopenharmony_ci PINCTRL_PIN(20, "GPIO_20"), 7462306a36Sopenharmony_ci PINCTRL_PIN(21, "GPIO_21"), 7562306a36Sopenharmony_ci PINCTRL_PIN(22, "GPIO_22"), 7662306a36Sopenharmony_ci PINCTRL_PIN(23, "GPIO_23"), 7762306a36Sopenharmony_ci PINCTRL_PIN(24, "GPIO_24"), 7862306a36Sopenharmony_ci PINCTRL_PIN(25, "GPIO_25"), 7962306a36Sopenharmony_ci PINCTRL_PIN(26, "GPIO_26"), 8062306a36Sopenharmony_ci PINCTRL_PIN(27, "GPIO_27"), 8162306a36Sopenharmony_ci PINCTRL_PIN(28, "GPIO_28"), 8262306a36Sopenharmony_ci PINCTRL_PIN(29, "GPIO_29"), 8362306a36Sopenharmony_ci PINCTRL_PIN(30, "GPIO_30"), 8462306a36Sopenharmony_ci PINCTRL_PIN(31, "GPIO_31"), 8562306a36Sopenharmony_ci PINCTRL_PIN(32, "GPIO_32"), 8662306a36Sopenharmony_ci PINCTRL_PIN(33, "GPIO_33"), 8762306a36Sopenharmony_ci PINCTRL_PIN(34, "GPIO_34"), 8862306a36Sopenharmony_ci PINCTRL_PIN(35, "GPIO_35"), 8962306a36Sopenharmony_ci PINCTRL_PIN(36, "GPIO_36"), 9062306a36Sopenharmony_ci PINCTRL_PIN(37, "GPIO_37"), 9162306a36Sopenharmony_ci PINCTRL_PIN(38, "GPIO_38"), 9262306a36Sopenharmony_ci PINCTRL_PIN(39, "GPIO_39"), 9362306a36Sopenharmony_ci PINCTRL_PIN(40, "GPIO_40"), 9462306a36Sopenharmony_ci PINCTRL_PIN(41, "GPIO_41"), 9562306a36Sopenharmony_ci PINCTRL_PIN(42, "GPIO_42"), 9662306a36Sopenharmony_ci PINCTRL_PIN(43, "GPIO_43"), 9762306a36Sopenharmony_ci PINCTRL_PIN(44, "GPIO_44"), 9862306a36Sopenharmony_ci PINCTRL_PIN(45, "GPIO_45"), 9962306a36Sopenharmony_ci PINCTRL_PIN(46, "GPIO_46"), 10062306a36Sopenharmony_ci PINCTRL_PIN(47, "GPIO_47"), 10162306a36Sopenharmony_ci PINCTRL_PIN(48, "GPIO_48"), 10262306a36Sopenharmony_ci PINCTRL_PIN(49, "GPIO_49"), 10362306a36Sopenharmony_ci PINCTRL_PIN(50, "GPIO_50"), 10462306a36Sopenharmony_ci PINCTRL_PIN(51, "GPIO_51"), 10562306a36Sopenharmony_ci PINCTRL_PIN(52, "GPIO_52"), 10662306a36Sopenharmony_ci PINCTRL_PIN(53, "GPIO_53"), 10762306a36Sopenharmony_ci PINCTRL_PIN(54, "GPIO_54"), 10862306a36Sopenharmony_ci PINCTRL_PIN(55, "GPIO_55"), 10962306a36Sopenharmony_ci PINCTRL_PIN(56, "GPIO_56"), 11062306a36Sopenharmony_ci PINCTRL_PIN(57, "GPIO_57"), 11162306a36Sopenharmony_ci PINCTRL_PIN(58, "GPIO_58"), 11262306a36Sopenharmony_ci PINCTRL_PIN(59, "GPIO_59"), 11362306a36Sopenharmony_ci PINCTRL_PIN(60, "GPIO_60"), 11462306a36Sopenharmony_ci PINCTRL_PIN(61, "GPIO_61"), 11562306a36Sopenharmony_ci PINCTRL_PIN(62, "GPIO_62"), 11662306a36Sopenharmony_ci PINCTRL_PIN(63, "GPIO_63"), 11762306a36Sopenharmony_ci PINCTRL_PIN(64, "GPIO_64"), 11862306a36Sopenharmony_ci PINCTRL_PIN(65, "GPIO_65"), 11962306a36Sopenharmony_ci PINCTRL_PIN(66, "GPIO_66"), 12062306a36Sopenharmony_ci PINCTRL_PIN(67, "GPIO_67"), 12162306a36Sopenharmony_ci PINCTRL_PIN(68, "GPIO_68"), 12262306a36Sopenharmony_ci PINCTRL_PIN(69, "GPIO_69"), 12362306a36Sopenharmony_ci}; 12462306a36Sopenharmony_ci 12562306a36Sopenharmony_ci#define DECLARE_MSM_GPIO_PINS(pin) \ 12662306a36Sopenharmony_ci static const unsigned int gpio##pin##_pins[] = { pin } 12762306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(0); 12862306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(1); 12962306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(2); 13062306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(3); 13162306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(4); 13262306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(5); 13362306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(6); 13462306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(7); 13562306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(8); 13662306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(9); 13762306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(10); 13862306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(11); 13962306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(12); 14062306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(13); 14162306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(14); 14262306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(15); 14362306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(16); 14462306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(17); 14562306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(18); 14662306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(19); 14762306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(20); 14862306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(21); 14962306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(22); 15062306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(23); 15162306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(24); 15262306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(25); 15362306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(26); 15462306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(27); 15562306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(28); 15662306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(29); 15762306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(30); 15862306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(31); 15962306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(32); 16062306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(33); 16162306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(34); 16262306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(35); 16362306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(36); 16462306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(37); 16562306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(38); 16662306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(39); 16762306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(40); 16862306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(41); 16962306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(42); 17062306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(43); 17162306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(44); 17262306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(45); 17362306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(46); 17462306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(47); 17562306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(48); 17662306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(49); 17762306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(50); 17862306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(51); 17962306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(52); 18062306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(53); 18162306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(54); 18262306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(55); 18362306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(56); 18462306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(57); 18562306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(58); 18662306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(59); 18762306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(60); 18862306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(61); 18962306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(62); 19062306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(63); 19162306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(64); 19262306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(65); 19362306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(66); 19462306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(67); 19562306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(68); 19662306a36Sopenharmony_ciDECLARE_MSM_GPIO_PINS(69); 19762306a36Sopenharmony_ci 19862306a36Sopenharmony_cienum ipq8074_functions { 19962306a36Sopenharmony_ci msm_mux_atest_char, 20062306a36Sopenharmony_ci msm_mux_atest_char0, 20162306a36Sopenharmony_ci msm_mux_atest_char1, 20262306a36Sopenharmony_ci msm_mux_atest_char2, 20362306a36Sopenharmony_ci msm_mux_atest_char3, 20462306a36Sopenharmony_ci msm_mux_audio_rxbclk, 20562306a36Sopenharmony_ci msm_mux_audio_rxd, 20662306a36Sopenharmony_ci msm_mux_audio_rxfsync, 20762306a36Sopenharmony_ci msm_mux_audio_rxmclk, 20862306a36Sopenharmony_ci msm_mux_audio_txbclk, 20962306a36Sopenharmony_ci msm_mux_audio_txd, 21062306a36Sopenharmony_ci msm_mux_audio_txfsync, 21162306a36Sopenharmony_ci msm_mux_audio_txmclk, 21262306a36Sopenharmony_ci msm_mux_blsp0_i2c, 21362306a36Sopenharmony_ci msm_mux_blsp0_spi, 21462306a36Sopenharmony_ci msm_mux_blsp0_uart, 21562306a36Sopenharmony_ci msm_mux_blsp1_i2c, 21662306a36Sopenharmony_ci msm_mux_blsp1_spi, 21762306a36Sopenharmony_ci msm_mux_blsp1_uart, 21862306a36Sopenharmony_ci msm_mux_blsp2_i2c, 21962306a36Sopenharmony_ci msm_mux_blsp2_spi, 22062306a36Sopenharmony_ci msm_mux_blsp2_uart, 22162306a36Sopenharmony_ci msm_mux_blsp3_i2c, 22262306a36Sopenharmony_ci msm_mux_blsp3_spi, 22362306a36Sopenharmony_ci msm_mux_blsp3_spi0, 22462306a36Sopenharmony_ci msm_mux_blsp3_spi1, 22562306a36Sopenharmony_ci msm_mux_blsp3_spi2, 22662306a36Sopenharmony_ci msm_mux_blsp3_spi3, 22762306a36Sopenharmony_ci msm_mux_blsp3_uart, 22862306a36Sopenharmony_ci msm_mux_blsp4_i2c0, 22962306a36Sopenharmony_ci msm_mux_blsp4_i2c1, 23062306a36Sopenharmony_ci msm_mux_blsp4_spi0, 23162306a36Sopenharmony_ci msm_mux_blsp4_spi1, 23262306a36Sopenharmony_ci msm_mux_blsp4_uart0, 23362306a36Sopenharmony_ci msm_mux_blsp4_uart1, 23462306a36Sopenharmony_ci msm_mux_blsp5_i2c, 23562306a36Sopenharmony_ci msm_mux_blsp5_spi, 23662306a36Sopenharmony_ci msm_mux_blsp5_uart, 23762306a36Sopenharmony_ci msm_mux_burn0, 23862306a36Sopenharmony_ci msm_mux_burn1, 23962306a36Sopenharmony_ci msm_mux_cri_trng, 24062306a36Sopenharmony_ci msm_mux_cri_trng0, 24162306a36Sopenharmony_ci msm_mux_cri_trng1, 24262306a36Sopenharmony_ci msm_mux_cxc0, 24362306a36Sopenharmony_ci msm_mux_cxc1, 24462306a36Sopenharmony_ci msm_mux_dbg_out, 24562306a36Sopenharmony_ci msm_mux_gcc_plltest, 24662306a36Sopenharmony_ci msm_mux_gcc_tlmm, 24762306a36Sopenharmony_ci msm_mux_gpio, 24862306a36Sopenharmony_ci msm_mux_ldo_en, 24962306a36Sopenharmony_ci msm_mux_ldo_update, 25062306a36Sopenharmony_ci msm_mux_led0, 25162306a36Sopenharmony_ci msm_mux_led1, 25262306a36Sopenharmony_ci msm_mux_led2, 25362306a36Sopenharmony_ci msm_mux_mac0_sa0, 25462306a36Sopenharmony_ci msm_mux_mac0_sa1, 25562306a36Sopenharmony_ci msm_mux_mac1_sa0, 25662306a36Sopenharmony_ci msm_mux_mac1_sa1, 25762306a36Sopenharmony_ci msm_mux_mac1_sa2, 25862306a36Sopenharmony_ci msm_mux_mac1_sa3, 25962306a36Sopenharmony_ci msm_mux_mac2_sa0, 26062306a36Sopenharmony_ci msm_mux_mac2_sa1, 26162306a36Sopenharmony_ci msm_mux_mdc, 26262306a36Sopenharmony_ci msm_mux_mdio, 26362306a36Sopenharmony_ci msm_mux_pcie0_clk, 26462306a36Sopenharmony_ci msm_mux_pcie0_rst, 26562306a36Sopenharmony_ci msm_mux_pcie0_wake, 26662306a36Sopenharmony_ci msm_mux_pcie1_clk, 26762306a36Sopenharmony_ci msm_mux_pcie1_rst, 26862306a36Sopenharmony_ci msm_mux_pcie1_wake, 26962306a36Sopenharmony_ci msm_mux_pcm_drx, 27062306a36Sopenharmony_ci msm_mux_pcm_dtx, 27162306a36Sopenharmony_ci msm_mux_pcm_fsync, 27262306a36Sopenharmony_ci msm_mux_pcm_pclk, 27362306a36Sopenharmony_ci msm_mux_pcm_zsi0, 27462306a36Sopenharmony_ci msm_mux_pcm_zsi1, 27562306a36Sopenharmony_ci msm_mux_prng_rosc, 27662306a36Sopenharmony_ci msm_mux_pta1_0, 27762306a36Sopenharmony_ci msm_mux_pta1_1, 27862306a36Sopenharmony_ci msm_mux_pta1_2, 27962306a36Sopenharmony_ci msm_mux_pta2_0, 28062306a36Sopenharmony_ci msm_mux_pta2_1, 28162306a36Sopenharmony_ci msm_mux_pta2_2, 28262306a36Sopenharmony_ci msm_mux_pwm0, 28362306a36Sopenharmony_ci msm_mux_pwm1, 28462306a36Sopenharmony_ci msm_mux_pwm2, 28562306a36Sopenharmony_ci msm_mux_pwm3, 28662306a36Sopenharmony_ci msm_mux_qdss_cti_trig_in_a0, 28762306a36Sopenharmony_ci msm_mux_qdss_cti_trig_in_a1, 28862306a36Sopenharmony_ci msm_mux_qdss_cti_trig_in_b0, 28962306a36Sopenharmony_ci msm_mux_qdss_cti_trig_in_b1, 29062306a36Sopenharmony_ci msm_mux_qdss_cti_trig_out_a0, 29162306a36Sopenharmony_ci msm_mux_qdss_cti_trig_out_a1, 29262306a36Sopenharmony_ci msm_mux_qdss_cti_trig_out_b0, 29362306a36Sopenharmony_ci msm_mux_qdss_cti_trig_out_b1, 29462306a36Sopenharmony_ci msm_mux_qdss_traceclk_a, 29562306a36Sopenharmony_ci msm_mux_qdss_traceclk_b, 29662306a36Sopenharmony_ci msm_mux_qdss_tracectl_a, 29762306a36Sopenharmony_ci msm_mux_qdss_tracectl_b, 29862306a36Sopenharmony_ci msm_mux_qdss_tracedata_a, 29962306a36Sopenharmony_ci msm_mux_qdss_tracedata_b, 30062306a36Sopenharmony_ci msm_mux_qpic, 30162306a36Sopenharmony_ci msm_mux_rx0, 30262306a36Sopenharmony_ci msm_mux_rx1, 30362306a36Sopenharmony_ci msm_mux_rx2, 30462306a36Sopenharmony_ci msm_mux_sd_card, 30562306a36Sopenharmony_ci msm_mux_sd_write, 30662306a36Sopenharmony_ci msm_mux_tsens_max, 30762306a36Sopenharmony_ci msm_mux_wci2a, 30862306a36Sopenharmony_ci msm_mux_wci2b, 30962306a36Sopenharmony_ci msm_mux_wci2c, 31062306a36Sopenharmony_ci msm_mux_wci2d, 31162306a36Sopenharmony_ci msm_mux_NA, 31262306a36Sopenharmony_ci}; 31362306a36Sopenharmony_ci 31462306a36Sopenharmony_cistatic const char * const qpic_groups[] = { 31562306a36Sopenharmony_ci "gpio0", /* LCD_TE */ 31662306a36Sopenharmony_ci "gpio1", /* BUSY_N */ 31762306a36Sopenharmony_ci "gpio2", /* LCD_RS_N */ 31862306a36Sopenharmony_ci "gpio3", /* WE_N */ 31962306a36Sopenharmony_ci "gpio4", /* OE_N */ 32062306a36Sopenharmony_ci "gpio5", /* DATA[0] */ 32162306a36Sopenharmony_ci "gpio6", /* DATA[1] */ 32262306a36Sopenharmony_ci "gpio7", /* DATA[2] */ 32362306a36Sopenharmony_ci "gpio8", /* DATA[3] */ 32462306a36Sopenharmony_ci "gpio9", /* CS_CSR_LCD */ 32562306a36Sopenharmony_ci "gpio10", /* CLE */ 32662306a36Sopenharmony_ci "gpio11", /* NAND_CS_N */ 32762306a36Sopenharmony_ci "gpio12", /* DATA[4] */ 32862306a36Sopenharmony_ci "gpio13", /* DATA[5] */ 32962306a36Sopenharmony_ci "gpio14", /* DATA[6] */ 33062306a36Sopenharmony_ci "gpio15", /* DATA[7] */ 33162306a36Sopenharmony_ci "gpio16", /* DATA[8] */ 33262306a36Sopenharmony_ci "gpio17", /* ALE */ 33362306a36Sopenharmony_ci}; 33462306a36Sopenharmony_ci 33562306a36Sopenharmony_cistatic const char * const blsp5_i2c_groups[] = { 33662306a36Sopenharmony_ci "gpio0", "gpio2", 33762306a36Sopenharmony_ci}; 33862306a36Sopenharmony_ci 33962306a36Sopenharmony_cistatic const char * const blsp5_spi_groups[] = { 34062306a36Sopenharmony_ci "gpio0", "gpio2", "gpio9", "gpio16", 34162306a36Sopenharmony_ci}; 34262306a36Sopenharmony_ci 34362306a36Sopenharmony_cistatic const char * const wci2a_groups[] = { 34462306a36Sopenharmony_ci "gpio0", "gpio2", 34562306a36Sopenharmony_ci}; 34662306a36Sopenharmony_ci 34762306a36Sopenharmony_cistatic const char * const blsp3_spi3_groups[] = { 34862306a36Sopenharmony_ci "gpio0", "gpio2", "gpio9", 34962306a36Sopenharmony_ci}; 35062306a36Sopenharmony_ci 35162306a36Sopenharmony_cistatic const char * const burn0_groups[] = { 35262306a36Sopenharmony_ci "gpio0", 35362306a36Sopenharmony_ci}; 35462306a36Sopenharmony_ci 35562306a36Sopenharmony_cistatic const char * const pcm_zsi0_groups[] = { 35662306a36Sopenharmony_ci "gpio1", 35762306a36Sopenharmony_ci}; 35862306a36Sopenharmony_ci 35962306a36Sopenharmony_cistatic const char * const blsp5_uart_groups[] = { 36062306a36Sopenharmony_ci "gpio0", "gpio2", "gpio9", "gpio16", 36162306a36Sopenharmony_ci}; 36262306a36Sopenharmony_ci 36362306a36Sopenharmony_cistatic const char * const mac1_sa2_groups[] = { 36462306a36Sopenharmony_ci "gpio1", "gpio11", 36562306a36Sopenharmony_ci}; 36662306a36Sopenharmony_ci 36762306a36Sopenharmony_cistatic const char * const blsp3_spi0_groups[] = { 36862306a36Sopenharmony_ci "gpio1", "gpio3", "gpio4", 36962306a36Sopenharmony_ci}; 37062306a36Sopenharmony_ci 37162306a36Sopenharmony_cistatic const char * const burn1_groups[] = { 37262306a36Sopenharmony_ci "gpio1", 37362306a36Sopenharmony_ci}; 37462306a36Sopenharmony_ci 37562306a36Sopenharmony_cistatic const char * const mac0_sa1_groups[] = { 37662306a36Sopenharmony_ci "gpio3", "gpio4", 37762306a36Sopenharmony_ci}; 37862306a36Sopenharmony_ci 37962306a36Sopenharmony_cistatic const char * const qdss_cti_trig_out_b0_groups[] = { 38062306a36Sopenharmony_ci "gpio3", 38162306a36Sopenharmony_ci}; 38262306a36Sopenharmony_ci 38362306a36Sopenharmony_cistatic const char * const qdss_cti_trig_in_b0_groups[] = { 38462306a36Sopenharmony_ci "gpio4", 38562306a36Sopenharmony_ci}; 38662306a36Sopenharmony_ci 38762306a36Sopenharmony_cistatic const char * const blsp4_uart0_groups[] = { 38862306a36Sopenharmony_ci "gpio5", "gpio6", "gpio7", "gpio8", 38962306a36Sopenharmony_ci}; 39062306a36Sopenharmony_ci 39162306a36Sopenharmony_cistatic const char * const blsp4_i2c0_groups[] = { 39262306a36Sopenharmony_ci "gpio5", "gpio6", 39362306a36Sopenharmony_ci}; 39462306a36Sopenharmony_ci 39562306a36Sopenharmony_cistatic const char * const blsp4_spi0_groups[] = { 39662306a36Sopenharmony_ci "gpio5", "gpio6", "gpio7", "gpio8", 39762306a36Sopenharmony_ci}; 39862306a36Sopenharmony_ci 39962306a36Sopenharmony_cistatic const char * const mac2_sa1_groups[] = { 40062306a36Sopenharmony_ci "gpio5", "gpio6", 40162306a36Sopenharmony_ci}; 40262306a36Sopenharmony_ci 40362306a36Sopenharmony_cistatic const char * const qdss_cti_trig_out_b1_groups[] = { 40462306a36Sopenharmony_ci "gpio5", 40562306a36Sopenharmony_ci}; 40662306a36Sopenharmony_ci 40762306a36Sopenharmony_cistatic const char * const qdss_cti_trig_in_b1_groups[] = { 40862306a36Sopenharmony_ci "gpio6", 40962306a36Sopenharmony_ci}; 41062306a36Sopenharmony_ci 41162306a36Sopenharmony_cistatic const char * const cxc0_groups[] = { 41262306a36Sopenharmony_ci "gpio9", "gpio16", 41362306a36Sopenharmony_ci}; 41462306a36Sopenharmony_ci 41562306a36Sopenharmony_cistatic const char * const mac1_sa3_groups[] = { 41662306a36Sopenharmony_ci "gpio9", "gpio16", 41762306a36Sopenharmony_ci}; 41862306a36Sopenharmony_ci 41962306a36Sopenharmony_cistatic const char * const qdss_cti_trig_in_a1_groups[] = { 42062306a36Sopenharmony_ci "gpio9", 42162306a36Sopenharmony_ci}; 42262306a36Sopenharmony_ci 42362306a36Sopenharmony_cistatic const char * const qdss_cti_trig_out_a1_groups[] = { 42462306a36Sopenharmony_ci "gpio10", 42562306a36Sopenharmony_ci}; 42662306a36Sopenharmony_ci 42762306a36Sopenharmony_cistatic const char * const wci2c_groups[] = { 42862306a36Sopenharmony_ci "gpio11", "gpio17", 42962306a36Sopenharmony_ci}; 43062306a36Sopenharmony_ci 43162306a36Sopenharmony_cistatic const char * const qdss_cti_trig_in_a0_groups[] = { 43262306a36Sopenharmony_ci "gpio11", 43362306a36Sopenharmony_ci}; 43462306a36Sopenharmony_ci 43562306a36Sopenharmony_cistatic const char * const qdss_cti_trig_out_a0_groups[] = { 43662306a36Sopenharmony_ci "gpio12", 43762306a36Sopenharmony_ci}; 43862306a36Sopenharmony_ci 43962306a36Sopenharmony_cistatic const char * const qdss_traceclk_b_groups[] = { 44062306a36Sopenharmony_ci "gpio14", 44162306a36Sopenharmony_ci}; 44262306a36Sopenharmony_ci 44362306a36Sopenharmony_cistatic const char * const qdss_tracectl_b_groups[] = { 44462306a36Sopenharmony_ci "gpio15", 44562306a36Sopenharmony_ci}; 44662306a36Sopenharmony_ci 44762306a36Sopenharmony_cistatic const char * const pcm_zsi1_groups[] = { 44862306a36Sopenharmony_ci "gpio16", 44962306a36Sopenharmony_ci}; 45062306a36Sopenharmony_ci 45162306a36Sopenharmony_cistatic const char * const qdss_tracedata_b_groups[] = { 45262306a36Sopenharmony_ci "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21", "gpio22", 45362306a36Sopenharmony_ci "gpio23", "gpio24", "gpio25", "gpio26", "gpio27", "gpio28", "gpio29", 45462306a36Sopenharmony_ci "gpio30", "gpio31", 45562306a36Sopenharmony_ci}; 45662306a36Sopenharmony_ci 45762306a36Sopenharmony_cistatic const char * const led0_groups[] = { 45862306a36Sopenharmony_ci "gpio18", 45962306a36Sopenharmony_ci}; 46062306a36Sopenharmony_ci 46162306a36Sopenharmony_cistatic const char * const pwm0_groups[] = { 46262306a36Sopenharmony_ci "gpio18", "gpio21", "gpio25", "gpio29", "gpio63", 46362306a36Sopenharmony_ci}; 46462306a36Sopenharmony_ci 46562306a36Sopenharmony_cistatic const char * const led1_groups[] = { 46662306a36Sopenharmony_ci "gpio19", 46762306a36Sopenharmony_ci}; 46862306a36Sopenharmony_ci 46962306a36Sopenharmony_cistatic const char * const pwm1_groups[] = { 47062306a36Sopenharmony_ci "gpio19", "gpio22", "gpio26", "gpio30", "gpio64", 47162306a36Sopenharmony_ci}; 47262306a36Sopenharmony_ci 47362306a36Sopenharmony_cistatic const char * const led2_groups[] = { 47462306a36Sopenharmony_ci "gpio20", 47562306a36Sopenharmony_ci}; 47662306a36Sopenharmony_ci 47762306a36Sopenharmony_cistatic const char * const pwm2_groups[] = { 47862306a36Sopenharmony_ci "gpio20", "gpio23", "gpio27", "gpio31", "gpio66", 47962306a36Sopenharmony_ci}; 48062306a36Sopenharmony_ci 48162306a36Sopenharmony_cistatic const char * const blsp4_uart1_groups[] = { 48262306a36Sopenharmony_ci "gpio21", "gpio22", "gpio23", "gpio24", 48362306a36Sopenharmony_ci}; 48462306a36Sopenharmony_ci 48562306a36Sopenharmony_cistatic const char * const blsp4_i2c1_groups[] = { 48662306a36Sopenharmony_ci "gpio21", "gpio22", 48762306a36Sopenharmony_ci}; 48862306a36Sopenharmony_ci 48962306a36Sopenharmony_cistatic const char * const blsp4_spi1_groups[] = { 49062306a36Sopenharmony_ci "gpio21", "gpio22", "gpio23", "gpio24", 49162306a36Sopenharmony_ci}; 49262306a36Sopenharmony_ci 49362306a36Sopenharmony_cistatic const char * const wci2d_groups[] = { 49462306a36Sopenharmony_ci "gpio21", "gpio22", 49562306a36Sopenharmony_ci}; 49662306a36Sopenharmony_ci 49762306a36Sopenharmony_cistatic const char * const mac1_sa1_groups[] = { 49862306a36Sopenharmony_ci "gpio21", "gpio22", 49962306a36Sopenharmony_ci}; 50062306a36Sopenharmony_ci 50162306a36Sopenharmony_cistatic const char * const blsp3_spi2_groups[] = { 50262306a36Sopenharmony_ci "gpio21", "gpio22", "gpio23", 50362306a36Sopenharmony_ci}; 50462306a36Sopenharmony_ci 50562306a36Sopenharmony_cistatic const char * const pwm3_groups[] = { 50662306a36Sopenharmony_ci "gpio24", "gpio28", "gpio32", "gpio67", 50762306a36Sopenharmony_ci}; 50862306a36Sopenharmony_ci 50962306a36Sopenharmony_cistatic const char * const audio_txmclk_groups[] = { 51062306a36Sopenharmony_ci "gpio25", 51162306a36Sopenharmony_ci}; 51262306a36Sopenharmony_ci 51362306a36Sopenharmony_cistatic const char * const audio_txbclk_groups[] = { 51462306a36Sopenharmony_ci "gpio26", 51562306a36Sopenharmony_ci}; 51662306a36Sopenharmony_ci 51762306a36Sopenharmony_cistatic const char * const audio_txfsync_groups[] = { 51862306a36Sopenharmony_ci "gpio27", 51962306a36Sopenharmony_ci}; 52062306a36Sopenharmony_ci 52162306a36Sopenharmony_cistatic const char * const audio_txd_groups[] = { 52262306a36Sopenharmony_ci "gpio28", 52362306a36Sopenharmony_ci}; 52462306a36Sopenharmony_ci 52562306a36Sopenharmony_cistatic const char * const audio_rxmclk_groups[] = { 52662306a36Sopenharmony_ci "gpio29", 52762306a36Sopenharmony_ci}; 52862306a36Sopenharmony_ci 52962306a36Sopenharmony_cistatic const char * const atest_char0_groups[] = { 53062306a36Sopenharmony_ci "gpio29", 53162306a36Sopenharmony_ci}; 53262306a36Sopenharmony_ci 53362306a36Sopenharmony_cistatic const char * const audio_rxbclk_groups[] = { 53462306a36Sopenharmony_ci "gpio30", 53562306a36Sopenharmony_ci}; 53662306a36Sopenharmony_ci 53762306a36Sopenharmony_cistatic const char * const atest_char1_groups[] = { 53862306a36Sopenharmony_ci "gpio30", 53962306a36Sopenharmony_ci}; 54062306a36Sopenharmony_ci 54162306a36Sopenharmony_cistatic const char * const audio_rxfsync_groups[] = { 54262306a36Sopenharmony_ci "gpio31", 54362306a36Sopenharmony_ci}; 54462306a36Sopenharmony_ci 54562306a36Sopenharmony_cistatic const char * const atest_char2_groups[] = { 54662306a36Sopenharmony_ci "gpio31", 54762306a36Sopenharmony_ci}; 54862306a36Sopenharmony_ci 54962306a36Sopenharmony_cistatic const char * const audio_rxd_groups[] = { 55062306a36Sopenharmony_ci "gpio32", 55162306a36Sopenharmony_ci}; 55262306a36Sopenharmony_ci 55362306a36Sopenharmony_cistatic const char * const atest_char3_groups[] = { 55462306a36Sopenharmony_ci "gpio32", 55562306a36Sopenharmony_ci}; 55662306a36Sopenharmony_ci 55762306a36Sopenharmony_cistatic const char * const pcm_drx_groups[] = { 55862306a36Sopenharmony_ci "gpio33", 55962306a36Sopenharmony_ci}; 56062306a36Sopenharmony_ci 56162306a36Sopenharmony_cistatic const char * const mac1_sa0_groups[] = { 56262306a36Sopenharmony_ci "gpio33", "gpio34", 56362306a36Sopenharmony_ci}; 56462306a36Sopenharmony_ci 56562306a36Sopenharmony_cistatic const char * const mac0_sa0_groups[] = { 56662306a36Sopenharmony_ci "gpio33", "gpio34", 56762306a36Sopenharmony_ci}; 56862306a36Sopenharmony_ci 56962306a36Sopenharmony_cistatic const char * const pcm_dtx_groups[] = { 57062306a36Sopenharmony_ci "gpio34", 57162306a36Sopenharmony_ci}; 57262306a36Sopenharmony_ci 57362306a36Sopenharmony_cistatic const char * const pcm_fsync_groups[] = { 57462306a36Sopenharmony_ci "gpio35", 57562306a36Sopenharmony_ci}; 57662306a36Sopenharmony_ci 57762306a36Sopenharmony_cistatic const char * const mac2_sa0_groups[] = { 57862306a36Sopenharmony_ci "gpio35", "gpio36", 57962306a36Sopenharmony_ci}; 58062306a36Sopenharmony_ci 58162306a36Sopenharmony_cistatic const char * const qdss_traceclk_a_groups[] = { 58262306a36Sopenharmony_ci "gpio35", 58362306a36Sopenharmony_ci}; 58462306a36Sopenharmony_ci 58562306a36Sopenharmony_cistatic const char * const pcm_pclk_groups[] = { 58662306a36Sopenharmony_ci "gpio36", 58762306a36Sopenharmony_ci}; 58862306a36Sopenharmony_ci 58962306a36Sopenharmony_cistatic const char * const qdss_tracectl_a_groups[] = { 59062306a36Sopenharmony_ci "gpio36", 59162306a36Sopenharmony_ci}; 59262306a36Sopenharmony_ci 59362306a36Sopenharmony_cistatic const char * const atest_char_groups[] = { 59462306a36Sopenharmony_ci "gpio37", 59562306a36Sopenharmony_ci}; 59662306a36Sopenharmony_ci 59762306a36Sopenharmony_cistatic const char * const qdss_tracedata_a_groups[] = { 59862306a36Sopenharmony_ci "gpio37", "gpio38", "gpio39", "gpio40", "gpio41", "gpio42", "gpio43", 59962306a36Sopenharmony_ci "gpio44", "gpio45", "gpio46", "gpio47", "gpio48", "gpio49", "gpio50", 60062306a36Sopenharmony_ci "gpio51", "gpio52", 60162306a36Sopenharmony_ci}; 60262306a36Sopenharmony_ci 60362306a36Sopenharmony_cistatic const char * const blsp0_uart_groups[] = { 60462306a36Sopenharmony_ci "gpio38", "gpio39", "gpio40", "gpio41", 60562306a36Sopenharmony_ci}; 60662306a36Sopenharmony_ci 60762306a36Sopenharmony_cistatic const char * const blsp0_i2c_groups[] = { 60862306a36Sopenharmony_ci "gpio38", "gpio39", 60962306a36Sopenharmony_ci}; 61062306a36Sopenharmony_ci 61162306a36Sopenharmony_cistatic const char * const blsp0_spi_groups[] = { 61262306a36Sopenharmony_ci "gpio38", "gpio39", "gpio40", "gpio41", 61362306a36Sopenharmony_ci}; 61462306a36Sopenharmony_ci 61562306a36Sopenharmony_cistatic const char * const blsp1_uart_groups[] = { 61662306a36Sopenharmony_ci "gpio42", "gpio43", "gpio44", "gpio45", 61762306a36Sopenharmony_ci}; 61862306a36Sopenharmony_ci 61962306a36Sopenharmony_cistatic const char * const blsp1_i2c_groups[] = { 62062306a36Sopenharmony_ci "gpio42", "gpio43", 62162306a36Sopenharmony_ci}; 62262306a36Sopenharmony_ci 62362306a36Sopenharmony_cistatic const char * const blsp1_spi_groups[] = { 62462306a36Sopenharmony_ci "gpio42", "gpio43", "gpio44", "gpio45", 62562306a36Sopenharmony_ci}; 62662306a36Sopenharmony_ci 62762306a36Sopenharmony_cistatic const char * const blsp2_uart_groups[] = { 62862306a36Sopenharmony_ci "gpio46", "gpio47", "gpio48", "gpio49", 62962306a36Sopenharmony_ci}; 63062306a36Sopenharmony_ci 63162306a36Sopenharmony_cistatic const char * const blsp2_i2c_groups[] = { 63262306a36Sopenharmony_ci "gpio46", "gpio47", 63362306a36Sopenharmony_ci}; 63462306a36Sopenharmony_ci 63562306a36Sopenharmony_cistatic const char * const blsp2_spi_groups[] = { 63662306a36Sopenharmony_ci "gpio46", "gpio47", "gpio48", "gpio49", 63762306a36Sopenharmony_ci}; 63862306a36Sopenharmony_ci 63962306a36Sopenharmony_cistatic const char * const blsp3_uart_groups[] = { 64062306a36Sopenharmony_ci "gpio50", "gpio51", "gpio52", "gpio53", 64162306a36Sopenharmony_ci}; 64262306a36Sopenharmony_ci 64362306a36Sopenharmony_cistatic const char * const blsp3_i2c_groups[] = { 64462306a36Sopenharmony_ci "gpio50", "gpio51", 64562306a36Sopenharmony_ci}; 64662306a36Sopenharmony_ci 64762306a36Sopenharmony_cistatic const char * const blsp3_spi_groups[] = { 64862306a36Sopenharmony_ci "gpio50", "gpio51", "gpio52", "gpio53", 64962306a36Sopenharmony_ci}; 65062306a36Sopenharmony_ci 65162306a36Sopenharmony_cistatic const char * const pta2_0_groups[] = { 65262306a36Sopenharmony_ci "gpio54", 65362306a36Sopenharmony_ci}; 65462306a36Sopenharmony_ci 65562306a36Sopenharmony_cistatic const char * const wci2b_groups[] = { 65662306a36Sopenharmony_ci "gpio54", "gpio56", 65762306a36Sopenharmony_ci}; 65862306a36Sopenharmony_ci 65962306a36Sopenharmony_cistatic const char * const cxc1_groups[] = { 66062306a36Sopenharmony_ci "gpio54", "gpio56", 66162306a36Sopenharmony_ci}; 66262306a36Sopenharmony_ci 66362306a36Sopenharmony_cistatic const char * const blsp3_spi1_groups[] = { 66462306a36Sopenharmony_ci "gpio54", "gpio55", "gpio56", 66562306a36Sopenharmony_ci}; 66662306a36Sopenharmony_ci 66762306a36Sopenharmony_cistatic const char * const pta2_1_groups[] = { 66862306a36Sopenharmony_ci "gpio55", 66962306a36Sopenharmony_ci}; 67062306a36Sopenharmony_ci 67162306a36Sopenharmony_cistatic const char * const pta2_2_groups[] = { 67262306a36Sopenharmony_ci "gpio56", 67362306a36Sopenharmony_ci}; 67462306a36Sopenharmony_ci 67562306a36Sopenharmony_cistatic const char * const pcie0_clk_groups[] = { 67662306a36Sopenharmony_ci "gpio57", 67762306a36Sopenharmony_ci}; 67862306a36Sopenharmony_ci 67962306a36Sopenharmony_cistatic const char * const dbg_out_groups[] = { 68062306a36Sopenharmony_ci "gpio57", 68162306a36Sopenharmony_ci}; 68262306a36Sopenharmony_ci 68362306a36Sopenharmony_cistatic const char * const cri_trng0_groups[] = { 68462306a36Sopenharmony_ci "gpio57", 68562306a36Sopenharmony_ci}; 68662306a36Sopenharmony_ci 68762306a36Sopenharmony_cistatic const char * const pcie0_rst_groups[] = { 68862306a36Sopenharmony_ci "gpio58", 68962306a36Sopenharmony_ci}; 69062306a36Sopenharmony_ci 69162306a36Sopenharmony_cistatic const char * const cri_trng1_groups[] = { 69262306a36Sopenharmony_ci "gpio58", 69362306a36Sopenharmony_ci}; 69462306a36Sopenharmony_ci 69562306a36Sopenharmony_cistatic const char * const pcie0_wake_groups[] = { 69662306a36Sopenharmony_ci "gpio59", 69762306a36Sopenharmony_ci}; 69862306a36Sopenharmony_ci 69962306a36Sopenharmony_cistatic const char * const cri_trng_groups[] = { 70062306a36Sopenharmony_ci "gpio59", 70162306a36Sopenharmony_ci}; 70262306a36Sopenharmony_ci 70362306a36Sopenharmony_cistatic const char * const pcie1_clk_groups[] = { 70462306a36Sopenharmony_ci "gpio60", 70562306a36Sopenharmony_ci}; 70662306a36Sopenharmony_ci 70762306a36Sopenharmony_cistatic const char * const rx2_groups[] = { 70862306a36Sopenharmony_ci "gpio60", 70962306a36Sopenharmony_ci}; 71062306a36Sopenharmony_ci 71162306a36Sopenharmony_cistatic const char * const ldo_update_groups[] = { 71262306a36Sopenharmony_ci "gpio60", 71362306a36Sopenharmony_ci}; 71462306a36Sopenharmony_ci 71562306a36Sopenharmony_cistatic const char * const pcie1_rst_groups[] = { 71662306a36Sopenharmony_ci "gpio61", 71762306a36Sopenharmony_ci}; 71862306a36Sopenharmony_ci 71962306a36Sopenharmony_cistatic const char * const ldo_en_groups[] = { 72062306a36Sopenharmony_ci "gpio61", 72162306a36Sopenharmony_ci}; 72262306a36Sopenharmony_ci 72362306a36Sopenharmony_cistatic const char * const pcie1_wake_groups[] = { 72462306a36Sopenharmony_ci "gpio62", 72562306a36Sopenharmony_ci}; 72662306a36Sopenharmony_ci 72762306a36Sopenharmony_cistatic const char * const gcc_plltest_groups[] = { 72862306a36Sopenharmony_ci "gpio62", "gpio63", 72962306a36Sopenharmony_ci}; 73062306a36Sopenharmony_ci 73162306a36Sopenharmony_cistatic const char * const sd_card_groups[] = { 73262306a36Sopenharmony_ci "gpio63", 73362306a36Sopenharmony_ci}; 73462306a36Sopenharmony_ci 73562306a36Sopenharmony_cistatic const char * const pta1_1_groups[] = { 73662306a36Sopenharmony_ci "gpio64", 73762306a36Sopenharmony_ci}; 73862306a36Sopenharmony_ci 73962306a36Sopenharmony_cistatic const char * const rx1_groups[] = { 74062306a36Sopenharmony_ci "gpio64", 74162306a36Sopenharmony_ci}; 74262306a36Sopenharmony_ci 74362306a36Sopenharmony_cistatic const char * const pta1_2_groups[] = { 74462306a36Sopenharmony_ci "gpio65", 74562306a36Sopenharmony_ci}; 74662306a36Sopenharmony_ci 74762306a36Sopenharmony_cistatic const char * const gcc_tlmm_groups[] = { 74862306a36Sopenharmony_ci "gpio65", 74962306a36Sopenharmony_ci}; 75062306a36Sopenharmony_ci 75162306a36Sopenharmony_cistatic const char * const pta1_0_groups[] = { 75262306a36Sopenharmony_ci "gpio66", 75362306a36Sopenharmony_ci}; 75462306a36Sopenharmony_ci 75562306a36Sopenharmony_cistatic const char * const prng_rosc_groups[] = { 75662306a36Sopenharmony_ci "gpio66", 75762306a36Sopenharmony_ci}; 75862306a36Sopenharmony_ci 75962306a36Sopenharmony_cistatic const char * const sd_write_groups[] = { 76062306a36Sopenharmony_ci "gpio67", 76162306a36Sopenharmony_ci}; 76262306a36Sopenharmony_ci 76362306a36Sopenharmony_cistatic const char * const rx0_groups[] = { 76462306a36Sopenharmony_ci "gpio67", 76562306a36Sopenharmony_ci}; 76662306a36Sopenharmony_ci 76762306a36Sopenharmony_cistatic const char * const tsens_max_groups[] = { 76862306a36Sopenharmony_ci "gpio67", 76962306a36Sopenharmony_ci}; 77062306a36Sopenharmony_ci 77162306a36Sopenharmony_cistatic const char * const mdc_groups[] = { 77262306a36Sopenharmony_ci "gpio68", 77362306a36Sopenharmony_ci}; 77462306a36Sopenharmony_ci 77562306a36Sopenharmony_cistatic const char * const mdio_groups[] = { 77662306a36Sopenharmony_ci "gpio69", 77762306a36Sopenharmony_ci}; 77862306a36Sopenharmony_ci 77962306a36Sopenharmony_cistatic const char * const gpio_groups[] = { 78062306a36Sopenharmony_ci "gpio0", "gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7", 78162306a36Sopenharmony_ci "gpio8", "gpio9", "gpio10", "gpio11", "gpio12", "gpio13", "gpio14", 78262306a36Sopenharmony_ci "gpio15", "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21", 78362306a36Sopenharmony_ci "gpio22", "gpio23", "gpio24", "gpio25", "gpio26", "gpio27", "gpio28", 78462306a36Sopenharmony_ci "gpio29", "gpio30", "gpio31", "gpio32", "gpio33", "gpio34", "gpio35", 78562306a36Sopenharmony_ci "gpio36", "gpio37", "gpio38", "gpio39", "gpio40", "gpio41", "gpio42", 78662306a36Sopenharmony_ci "gpio43", "gpio44", "gpio45", "gpio46", "gpio47", "gpio48", "gpio49", 78762306a36Sopenharmony_ci "gpio50", "gpio51", "gpio52", "gpio53", "gpio54", "gpio55", "gpio56", 78862306a36Sopenharmony_ci "gpio57", "gpio58", "gpio59", "gpio60", "gpio61", "gpio62", "gpio63", 78962306a36Sopenharmony_ci "gpio64", "gpio65", "gpio66", "gpio67", "gpio68", "gpio69", 79062306a36Sopenharmony_ci}; 79162306a36Sopenharmony_ci 79262306a36Sopenharmony_cistatic const struct pinfunction ipq8074_functions[] = { 79362306a36Sopenharmony_ci MSM_PIN_FUNCTION(atest_char), 79462306a36Sopenharmony_ci MSM_PIN_FUNCTION(atest_char0), 79562306a36Sopenharmony_ci MSM_PIN_FUNCTION(atest_char1), 79662306a36Sopenharmony_ci MSM_PIN_FUNCTION(atest_char2), 79762306a36Sopenharmony_ci MSM_PIN_FUNCTION(atest_char3), 79862306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_rxbclk), 79962306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_rxd), 80062306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_rxfsync), 80162306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_rxmclk), 80262306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_txbclk), 80362306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_txd), 80462306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_txfsync), 80562306a36Sopenharmony_ci MSM_PIN_FUNCTION(audio_txmclk), 80662306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp0_i2c), 80762306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp0_spi), 80862306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp0_uart), 80962306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp1_i2c), 81062306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp1_spi), 81162306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp1_uart), 81262306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp2_i2c), 81362306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp2_spi), 81462306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp2_uart), 81562306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp3_i2c), 81662306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp3_spi), 81762306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp3_spi0), 81862306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp3_spi1), 81962306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp3_spi2), 82062306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp3_spi3), 82162306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp3_uart), 82262306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp4_i2c0), 82362306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp4_i2c1), 82462306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp4_spi0), 82562306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp4_spi1), 82662306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp4_uart0), 82762306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp4_uart1), 82862306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp5_i2c), 82962306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp5_spi), 83062306a36Sopenharmony_ci MSM_PIN_FUNCTION(blsp5_uart), 83162306a36Sopenharmony_ci MSM_PIN_FUNCTION(burn0), 83262306a36Sopenharmony_ci MSM_PIN_FUNCTION(burn1), 83362306a36Sopenharmony_ci MSM_PIN_FUNCTION(cri_trng), 83462306a36Sopenharmony_ci MSM_PIN_FUNCTION(cri_trng0), 83562306a36Sopenharmony_ci MSM_PIN_FUNCTION(cri_trng1), 83662306a36Sopenharmony_ci MSM_PIN_FUNCTION(cxc0), 83762306a36Sopenharmony_ci MSM_PIN_FUNCTION(cxc1), 83862306a36Sopenharmony_ci MSM_PIN_FUNCTION(dbg_out), 83962306a36Sopenharmony_ci MSM_PIN_FUNCTION(gcc_plltest), 84062306a36Sopenharmony_ci MSM_PIN_FUNCTION(gcc_tlmm), 84162306a36Sopenharmony_ci MSM_PIN_FUNCTION(gpio), 84262306a36Sopenharmony_ci MSM_PIN_FUNCTION(ldo_en), 84362306a36Sopenharmony_ci MSM_PIN_FUNCTION(ldo_update), 84462306a36Sopenharmony_ci MSM_PIN_FUNCTION(led0), 84562306a36Sopenharmony_ci MSM_PIN_FUNCTION(led1), 84662306a36Sopenharmony_ci MSM_PIN_FUNCTION(led2), 84762306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac0_sa0), 84862306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac0_sa1), 84962306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac1_sa0), 85062306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac1_sa1), 85162306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac1_sa2), 85262306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac1_sa3), 85362306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac2_sa0), 85462306a36Sopenharmony_ci MSM_PIN_FUNCTION(mac2_sa1), 85562306a36Sopenharmony_ci MSM_PIN_FUNCTION(mdc), 85662306a36Sopenharmony_ci MSM_PIN_FUNCTION(mdio), 85762306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcie0_clk), 85862306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcie0_rst), 85962306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcie0_wake), 86062306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcie1_clk), 86162306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcie1_rst), 86262306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcie1_wake), 86362306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcm_drx), 86462306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcm_dtx), 86562306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcm_fsync), 86662306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcm_pclk), 86762306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcm_zsi0), 86862306a36Sopenharmony_ci MSM_PIN_FUNCTION(pcm_zsi1), 86962306a36Sopenharmony_ci MSM_PIN_FUNCTION(prng_rosc), 87062306a36Sopenharmony_ci MSM_PIN_FUNCTION(pta1_0), 87162306a36Sopenharmony_ci MSM_PIN_FUNCTION(pta1_1), 87262306a36Sopenharmony_ci MSM_PIN_FUNCTION(pta1_2), 87362306a36Sopenharmony_ci MSM_PIN_FUNCTION(pta2_0), 87462306a36Sopenharmony_ci MSM_PIN_FUNCTION(pta2_1), 87562306a36Sopenharmony_ci MSM_PIN_FUNCTION(pta2_2), 87662306a36Sopenharmony_ci MSM_PIN_FUNCTION(pwm0), 87762306a36Sopenharmony_ci MSM_PIN_FUNCTION(pwm1), 87862306a36Sopenharmony_ci MSM_PIN_FUNCTION(pwm2), 87962306a36Sopenharmony_ci MSM_PIN_FUNCTION(pwm3), 88062306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_in_a0), 88162306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_in_a1), 88262306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_in_b0), 88362306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_in_b1), 88462306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_out_a0), 88562306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_out_a1), 88662306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_out_b0), 88762306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_cti_trig_out_b1), 88862306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_traceclk_a), 88962306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_traceclk_b), 89062306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_tracectl_a), 89162306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_tracectl_b), 89262306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_tracedata_a), 89362306a36Sopenharmony_ci MSM_PIN_FUNCTION(qdss_tracedata_b), 89462306a36Sopenharmony_ci MSM_PIN_FUNCTION(qpic), 89562306a36Sopenharmony_ci MSM_PIN_FUNCTION(rx0), 89662306a36Sopenharmony_ci MSM_PIN_FUNCTION(rx1), 89762306a36Sopenharmony_ci MSM_PIN_FUNCTION(rx2), 89862306a36Sopenharmony_ci MSM_PIN_FUNCTION(sd_card), 89962306a36Sopenharmony_ci MSM_PIN_FUNCTION(sd_write), 90062306a36Sopenharmony_ci MSM_PIN_FUNCTION(tsens_max), 90162306a36Sopenharmony_ci MSM_PIN_FUNCTION(wci2a), 90262306a36Sopenharmony_ci MSM_PIN_FUNCTION(wci2b), 90362306a36Sopenharmony_ci MSM_PIN_FUNCTION(wci2c), 90462306a36Sopenharmony_ci MSM_PIN_FUNCTION(wci2d), 90562306a36Sopenharmony_ci}; 90662306a36Sopenharmony_ci 90762306a36Sopenharmony_cistatic const struct msm_pingroup ipq8074_groups[] = { 90862306a36Sopenharmony_ci PINGROUP(0, qpic, blsp5_uart, blsp5_i2c, blsp5_spi, wci2a, 90962306a36Sopenharmony_ci blsp3_spi3, NA, burn0, NA), 91062306a36Sopenharmony_ci PINGROUP(1, qpic, pcm_zsi0, mac1_sa2, blsp3_spi0, NA, burn1, NA, NA, 91162306a36Sopenharmony_ci NA), 91262306a36Sopenharmony_ci PINGROUP(2, qpic, blsp5_uart, blsp5_i2c, blsp5_spi, wci2a, 91362306a36Sopenharmony_ci blsp3_spi3, NA, NA, NA), 91462306a36Sopenharmony_ci PINGROUP(3, qpic, mac0_sa1, blsp3_spi0, qdss_cti_trig_out_b0, NA, NA, 91562306a36Sopenharmony_ci NA, NA, NA), 91662306a36Sopenharmony_ci PINGROUP(4, qpic, mac0_sa1, blsp3_spi0, qdss_cti_trig_in_b0, NA, NA, 91762306a36Sopenharmony_ci NA, NA, NA), 91862306a36Sopenharmony_ci PINGROUP(5, qpic, blsp4_uart0, blsp4_i2c0, blsp4_spi0, mac2_sa1, 91962306a36Sopenharmony_ci qdss_cti_trig_out_b1, NA, NA, NA), 92062306a36Sopenharmony_ci PINGROUP(6, qpic, blsp4_uart0, blsp4_i2c0, blsp4_spi0, mac2_sa1, 92162306a36Sopenharmony_ci qdss_cti_trig_in_b1, NA, NA, NA), 92262306a36Sopenharmony_ci PINGROUP(7, qpic, blsp4_uart0, blsp4_spi0, NA, NA, NA, NA, NA, NA), 92362306a36Sopenharmony_ci PINGROUP(8, qpic, blsp4_uart0, blsp4_spi0, NA, NA, NA, NA, NA, NA), 92462306a36Sopenharmony_ci PINGROUP(9, qpic, blsp5_uart, blsp5_spi, cxc0, mac1_sa3, blsp3_spi3, 92562306a36Sopenharmony_ci qdss_cti_trig_in_a1, NA, NA), 92662306a36Sopenharmony_ci PINGROUP(10, qpic, qdss_cti_trig_out_a1, NA, NA, NA, NA, NA, NA, 92762306a36Sopenharmony_ci NA), 92862306a36Sopenharmony_ci PINGROUP(11, qpic, wci2c, mac1_sa2, qdss_cti_trig_in_a0, NA, NA, NA, 92962306a36Sopenharmony_ci NA, NA), 93062306a36Sopenharmony_ci PINGROUP(12, qpic, qdss_cti_trig_out_a0, NA, NA, NA, NA, NA, NA, 93162306a36Sopenharmony_ci NA), 93262306a36Sopenharmony_ci PINGROUP(13, qpic, NA, NA, NA, NA, NA, NA, NA, NA), 93362306a36Sopenharmony_ci PINGROUP(14, qpic, qdss_traceclk_b, NA, NA, NA, NA, NA, NA, NA), 93462306a36Sopenharmony_ci PINGROUP(15, qpic, qdss_tracectl_b, NA, NA, NA, NA, NA, NA, NA), 93562306a36Sopenharmony_ci PINGROUP(16, qpic, blsp5_uart, pcm_zsi1, blsp5_spi, cxc0, mac1_sa3, 93662306a36Sopenharmony_ci qdss_tracedata_b, NA, NA), 93762306a36Sopenharmony_ci PINGROUP(17, qpic, wci2c, qdss_tracedata_b, NA, NA, NA, NA, NA, NA), 93862306a36Sopenharmony_ci PINGROUP(18, led0, pwm0, qdss_tracedata_b, NA, NA, NA, NA, NA, NA), 93962306a36Sopenharmony_ci PINGROUP(19, led1, pwm1, NA, qdss_tracedata_b, NA, NA, NA, NA, NA), 94062306a36Sopenharmony_ci PINGROUP(20, led2, pwm2, NA, qdss_tracedata_b, NA, NA, NA, NA, NA), 94162306a36Sopenharmony_ci PINGROUP(21, pwm0, blsp4_uart1, blsp4_i2c1, blsp4_spi1, wci2d, mac1_sa1, 94262306a36Sopenharmony_ci blsp3_spi2, NA, qdss_tracedata_b), 94362306a36Sopenharmony_ci PINGROUP(22, pwm1, blsp4_uart1, blsp4_i2c1, blsp4_spi1, wci2d, mac1_sa1, 94462306a36Sopenharmony_ci blsp3_spi2, NA, qdss_tracedata_b), 94562306a36Sopenharmony_ci PINGROUP(23, pwm2, blsp4_uart1, blsp4_spi1, blsp3_spi2, NA, 94662306a36Sopenharmony_ci qdss_tracedata_b, NA, NA, NA), 94762306a36Sopenharmony_ci PINGROUP(24, pwm3, blsp4_uart1, blsp4_spi1, NA, qdss_tracedata_b, NA, 94862306a36Sopenharmony_ci NA, NA, NA), 94962306a36Sopenharmony_ci PINGROUP(25, audio_txmclk, pwm0, NA, qdss_tracedata_b, NA, NA, NA, NA, 95062306a36Sopenharmony_ci NA), 95162306a36Sopenharmony_ci PINGROUP(26, audio_txbclk, pwm1, NA, qdss_tracedata_b, NA, NA, NA, NA, 95262306a36Sopenharmony_ci NA), 95362306a36Sopenharmony_ci PINGROUP(27, audio_txfsync, pwm2, NA, qdss_tracedata_b, NA, NA, NA, 95462306a36Sopenharmony_ci NA, NA), 95562306a36Sopenharmony_ci PINGROUP(28, audio_txd, pwm3, NA, qdss_tracedata_b, NA, NA, NA, NA, 95662306a36Sopenharmony_ci NA), 95762306a36Sopenharmony_ci PINGROUP(29, audio_rxmclk, pwm0, atest_char0, NA, qdss_tracedata_b, 95862306a36Sopenharmony_ci NA, NA, NA, NA), 95962306a36Sopenharmony_ci PINGROUP(30, audio_rxbclk, pwm1, atest_char1, NA, qdss_tracedata_b, 96062306a36Sopenharmony_ci NA, NA, NA, NA), 96162306a36Sopenharmony_ci PINGROUP(31, audio_rxfsync, pwm2, atest_char2, NA, qdss_tracedata_b, 96262306a36Sopenharmony_ci NA, NA, NA, NA), 96362306a36Sopenharmony_ci PINGROUP(32, audio_rxd, pwm3, atest_char3, NA, NA, NA, NA, NA, NA), 96462306a36Sopenharmony_ci PINGROUP(33, pcm_drx, mac1_sa0, mac0_sa0, NA, NA, NA, NA, NA, NA), 96562306a36Sopenharmony_ci PINGROUP(34, pcm_dtx, mac1_sa0, mac0_sa0, NA, NA, NA, NA, NA, NA), 96662306a36Sopenharmony_ci PINGROUP(35, pcm_fsync, mac2_sa0, qdss_traceclk_a, NA, NA, NA, NA, NA, NA), 96762306a36Sopenharmony_ci PINGROUP(36, pcm_pclk, mac2_sa0, NA, qdss_tracectl_a, NA, NA, NA, NA, NA), 96862306a36Sopenharmony_ci PINGROUP(37, atest_char, NA, qdss_tracedata_a, NA, NA, NA, NA, NA, NA), 96962306a36Sopenharmony_ci PINGROUP(38, blsp0_uart, blsp0_i2c, blsp0_spi, NA, qdss_tracedata_a, 97062306a36Sopenharmony_ci NA, NA, NA, NA), 97162306a36Sopenharmony_ci PINGROUP(39, blsp0_uart, blsp0_i2c, blsp0_spi, NA, qdss_tracedata_a, 97262306a36Sopenharmony_ci NA, NA, NA, NA), 97362306a36Sopenharmony_ci PINGROUP(40, blsp0_uart, blsp0_spi, NA, qdss_tracedata_a, NA, NA, NA, 97462306a36Sopenharmony_ci NA, NA), 97562306a36Sopenharmony_ci PINGROUP(41, blsp0_uart, blsp0_spi, NA, qdss_tracedata_a, NA, NA, NA, 97662306a36Sopenharmony_ci NA, NA), 97762306a36Sopenharmony_ci PINGROUP(42, blsp1_uart, blsp1_i2c, blsp1_spi, NA, qdss_tracedata_a, 97862306a36Sopenharmony_ci NA, NA, NA, NA), 97962306a36Sopenharmony_ci PINGROUP(43, blsp1_uart, blsp1_i2c, blsp1_spi, NA, qdss_tracedata_a, 98062306a36Sopenharmony_ci NA, NA, NA, NA), 98162306a36Sopenharmony_ci PINGROUP(44, blsp1_uart, blsp1_spi, NA, qdss_tracedata_a, NA, NA, NA, 98262306a36Sopenharmony_ci NA, NA), 98362306a36Sopenharmony_ci PINGROUP(45, blsp1_uart, blsp1_spi, qdss_tracedata_a, NA, NA, NA, NA, 98462306a36Sopenharmony_ci NA, NA), 98562306a36Sopenharmony_ci PINGROUP(46, blsp2_uart, blsp2_i2c, blsp2_spi, qdss_tracedata_a, NA, 98662306a36Sopenharmony_ci NA, NA, NA, NA), 98762306a36Sopenharmony_ci PINGROUP(47, blsp2_uart, blsp2_i2c, blsp2_spi, NA, qdss_tracedata_a, 98862306a36Sopenharmony_ci NA, NA, NA, NA), 98962306a36Sopenharmony_ci PINGROUP(48, blsp2_uart, blsp2_spi, NA, qdss_tracedata_a, NA, NA, NA, 99062306a36Sopenharmony_ci NA, NA), 99162306a36Sopenharmony_ci PINGROUP(49, blsp2_uart, blsp2_spi, NA, qdss_tracedata_a, NA, NA, NA, 99262306a36Sopenharmony_ci NA, NA), 99362306a36Sopenharmony_ci PINGROUP(50, blsp3_uart, blsp3_i2c, blsp3_spi, NA, qdss_tracedata_a, 99462306a36Sopenharmony_ci NA, NA, NA, NA), 99562306a36Sopenharmony_ci PINGROUP(51, blsp3_uart, blsp3_i2c, blsp3_spi, NA, qdss_tracedata_a, 99662306a36Sopenharmony_ci NA, NA, NA, NA), 99762306a36Sopenharmony_ci PINGROUP(52, blsp3_uart, blsp3_spi, NA, qdss_tracedata_a, NA, NA, NA, 99862306a36Sopenharmony_ci NA, NA), 99962306a36Sopenharmony_ci PINGROUP(53, blsp3_uart, blsp3_spi, NA, NA, NA, NA, NA, NA, NA), 100062306a36Sopenharmony_ci PINGROUP(54, pta2_0, wci2b, cxc1, blsp3_spi1, NA, NA, NA, NA, NA), 100162306a36Sopenharmony_ci PINGROUP(55, pta2_1, blsp3_spi1, NA, NA, NA, NA, NA, NA, NA), 100262306a36Sopenharmony_ci PINGROUP(56, pta2_2, wci2b, cxc1, blsp3_spi1, NA, NA, NA, NA, NA), 100362306a36Sopenharmony_ci PINGROUP(57, pcie0_clk, NA, dbg_out, cri_trng0, NA, NA, NA, NA, NA), 100462306a36Sopenharmony_ci PINGROUP(58, pcie0_rst, NA, cri_trng1, NA, NA, NA, NA, NA, NA), 100562306a36Sopenharmony_ci PINGROUP(59, pcie0_wake, NA, cri_trng, NA, NA, NA, NA, NA, NA), 100662306a36Sopenharmony_ci PINGROUP(60, pcie1_clk, rx2, ldo_update, NA, NA, NA, NA, NA, NA), 100762306a36Sopenharmony_ci PINGROUP(61, pcie1_rst, ldo_en, NA, NA, NA, NA, NA, NA, NA), 100862306a36Sopenharmony_ci PINGROUP(62, pcie1_wake, gcc_plltest, NA, NA, NA, NA, NA, NA, NA), 100962306a36Sopenharmony_ci PINGROUP(63, sd_card, pwm0, NA, gcc_plltest, NA, NA, NA, NA, NA), 101062306a36Sopenharmony_ci PINGROUP(64, pta1_1, pwm1, NA, rx1, NA, NA, NA, NA, NA), 101162306a36Sopenharmony_ci PINGROUP(65, pta1_2, NA, gcc_tlmm, NA, NA, NA, NA, NA, NA), 101262306a36Sopenharmony_ci PINGROUP(66, pta1_0, pwm2, prng_rosc, NA, NA, NA, NA, NA, NA), 101362306a36Sopenharmony_ci PINGROUP(67, sd_write, pwm3, rx0, tsens_max, NA, NA, NA, NA, NA), 101462306a36Sopenharmony_ci PINGROUP(68, mdc, NA, NA, NA, NA, NA, NA, NA, NA), 101562306a36Sopenharmony_ci PINGROUP(69, mdio, NA, NA, NA, NA, NA, NA, NA, NA), 101662306a36Sopenharmony_ci}; 101762306a36Sopenharmony_ci 101862306a36Sopenharmony_cistatic const struct msm_pinctrl_soc_data ipq8074_pinctrl = { 101962306a36Sopenharmony_ci .pins = ipq8074_pins, 102062306a36Sopenharmony_ci .npins = ARRAY_SIZE(ipq8074_pins), 102162306a36Sopenharmony_ci .functions = ipq8074_functions, 102262306a36Sopenharmony_ci .nfunctions = ARRAY_SIZE(ipq8074_functions), 102362306a36Sopenharmony_ci .groups = ipq8074_groups, 102462306a36Sopenharmony_ci .ngroups = ARRAY_SIZE(ipq8074_groups), 102562306a36Sopenharmony_ci .ngpios = 70, 102662306a36Sopenharmony_ci}; 102762306a36Sopenharmony_ci 102862306a36Sopenharmony_cistatic int ipq8074_pinctrl_probe(struct platform_device *pdev) 102962306a36Sopenharmony_ci{ 103062306a36Sopenharmony_ci return msm_pinctrl_probe(pdev, &ipq8074_pinctrl); 103162306a36Sopenharmony_ci} 103262306a36Sopenharmony_ci 103362306a36Sopenharmony_cistatic const struct of_device_id ipq8074_pinctrl_of_match[] = { 103462306a36Sopenharmony_ci { .compatible = "qcom,ipq8074-pinctrl", }, 103562306a36Sopenharmony_ci { }, 103662306a36Sopenharmony_ci}; 103762306a36Sopenharmony_ci 103862306a36Sopenharmony_cistatic struct platform_driver ipq8074_pinctrl_driver = { 103962306a36Sopenharmony_ci .driver = { 104062306a36Sopenharmony_ci .name = "ipq8074-pinctrl", 104162306a36Sopenharmony_ci .of_match_table = ipq8074_pinctrl_of_match, 104262306a36Sopenharmony_ci }, 104362306a36Sopenharmony_ci .probe = ipq8074_pinctrl_probe, 104462306a36Sopenharmony_ci .remove = msm_pinctrl_remove, 104562306a36Sopenharmony_ci}; 104662306a36Sopenharmony_ci 104762306a36Sopenharmony_cistatic int __init ipq8074_pinctrl_init(void) 104862306a36Sopenharmony_ci{ 104962306a36Sopenharmony_ci return platform_driver_register(&ipq8074_pinctrl_driver); 105062306a36Sopenharmony_ci} 105162306a36Sopenharmony_ciarch_initcall(ipq8074_pinctrl_init); 105262306a36Sopenharmony_ci 105362306a36Sopenharmony_cistatic void __exit ipq8074_pinctrl_exit(void) 105462306a36Sopenharmony_ci{ 105562306a36Sopenharmony_ci platform_driver_unregister(&ipq8074_pinctrl_driver); 105662306a36Sopenharmony_ci} 105762306a36Sopenharmony_cimodule_exit(ipq8074_pinctrl_exit); 105862306a36Sopenharmony_ci 105962306a36Sopenharmony_ciMODULE_DESCRIPTION("Qualcomm ipq8074 pinctrl driver"); 106062306a36Sopenharmony_ciMODULE_LICENSE("GPL v2"); 106162306a36Sopenharmony_ciMODULE_DEVICE_TABLE(of, ipq8074_pinctrl_of_match); 1062