| /* Copyright (c) 2012-2013, The Linux Foundation. All rights reserved. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 and |
| * only version 2 as published by the Free Software Foundation. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| */ |
| |
| #include <linux/gpio.h> |
| #include <linux/init.h> |
| #include <linux/ioport.h> |
| #include <mach/board.h> |
| #include <mach/gpio.h> |
| #include <mach/gpiomux.h> |
| #include <mach/socinfo.h> |
| |
| #define KS8851_IRQ_GPIO 94 |
| |
| #define WLAN_CLK 40 |
| #define WLAN_SET 39 |
| #define WLAN_DATA0 38 |
| #define WLAN_DATA1 37 |
| #define WLAN_DATA2 36 |
| |
| static struct gpiomux_setting ap2mdm_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_LOW, |
| }; |
| |
| static struct gpiomux_setting mdm2ap_status_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_LOW, |
| }; |
| |
| static struct gpiomux_setting mdm2ap_errfatal_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_LOW, |
| }; |
| |
| static struct gpiomux_setting mdm2ap_pblrdy = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_IN, |
| }; |
| |
| |
| static struct gpiomux_setting ap2mdm_soft_reset_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_LOW, |
| }; |
| |
| static struct gpiomux_setting ap2mdm_wakeup = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_LOW, |
| }; |
| |
| static struct msm_gpiomux_config mdm_configs[] __initdata = { |
| /* AP2MDM_STATUS */ |
| { |
| .gpio = 105, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &ap2mdm_cfg, |
| } |
| }, |
| /* MDM2AP_STATUS */ |
| { |
| .gpio = 46, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &mdm2ap_status_cfg, |
| } |
| }, |
| /* MDM2AP_ERRFATAL */ |
| { |
| .gpio = 82, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &mdm2ap_errfatal_cfg, |
| } |
| }, |
| /* AP2MDM_ERRFATAL */ |
| { |
| .gpio = 106, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &ap2mdm_cfg, |
| } |
| }, |
| /* AP2MDM_SOFT_RESET, aka AP2MDM_PON_RESET_N */ |
| { |
| .gpio = 24, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &ap2mdm_soft_reset_cfg, |
| } |
| }, |
| /* AP2MDM_WAKEUP */ |
| { |
| .gpio = 104, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &ap2mdm_wakeup, |
| } |
| }, |
| /* MDM2AP_PBL_READY*/ |
| { |
| .gpio = 80, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &mdm2ap_pblrdy, |
| } |
| }, |
| }; |
| |
| static struct gpiomux_setting gpio_uart_config = { |
| .func = GPIOMUX_FUNC_2, |
| .drv = GPIOMUX_DRV_16MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_HIGH, |
| }; |
| |
| static struct gpiomux_setting slimbus = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_KEEPER, |
| }; |
| |
| #if defined(CONFIG_KS8851) || defined(CONFIG_KS8851_MODULE) |
| static struct gpiomux_setting gpio_eth_config = { |
| .pull = GPIOMUX_PULL_UP, |
| .drv = GPIOMUX_DRV_2MA, |
| .func = GPIOMUX_FUNC_GPIO, |
| }; |
| |
| static struct gpiomux_setting gpio_spi_cs2_config = { |
| .func = GPIOMUX_FUNC_4, |
| .drv = GPIOMUX_DRV_6MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting gpio_spi_config = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_12MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| static struct gpiomux_setting gpio_spi_susp_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting gpio_spi_cs1_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_6MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct msm_gpiomux_config msm_eth_configs[] = { |
| { |
| .gpio = KS8851_IRQ_GPIO, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_eth_config, |
| } |
| }, |
| }; |
| #endif |
| |
| static struct gpiomux_setting gpio_suspend_config[] = { |
| { |
| .func = GPIOMUX_FUNC_GPIO, /* IN-NP */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }, |
| { |
| .func = GPIOMUX_FUNC_GPIO, /* O-LOW */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_LOW, |
| }, |
| }; |
| |
| static struct gpiomux_setting gpio_epm_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_HIGH, |
| }; |
| |
| static struct gpiomux_setting gpio_epm_marker_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_HIGH, |
| }; |
| |
| static struct gpiomux_setting wcnss_5wire_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting wcnss_5wire_active_cfg = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_6MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting wcnss_5gpio_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting wcnss_5gpio_active_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_6MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting ath_gpio_active_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting ath_gpio_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting gpio_i2c_config = { |
| .func = GPIOMUX_FUNC_3, |
| /* |
| * Please keep I2C GPIOs drive-strength at minimum (2ma). It is a |
| * workaround for HW issue of glitches caused by rapid GPIO current- |
| * change. |
| */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| |
| static struct gpiomux_setting gpio_i2c_act_config = { |
| .func = GPIOMUX_FUNC_3, |
| /* |
| * Please keep I2C GPIOs drive-strength at minimum (2ma). It is a |
| * workaround for HW issue of glitches caused by rapid GPIO current- |
| * change. |
| */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting lcd_en_act_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_HIGH, |
| }; |
| |
| static struct gpiomux_setting lcd_en_sus_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting atmel_resout_sus_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_6MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting atmel_resout_act_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_6MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting atmel_int_act_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting atmel_int_sus_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting taiko_reset = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_6MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_OUT_LOW, |
| }; |
| |
| static struct gpiomux_setting taiko_int = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| static struct gpiomux_setting hap_lvl_shft_suspended_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting hap_lvl_shft_active_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| static struct msm_gpiomux_config hap_lvl_shft_config[] __initdata = { |
| { |
| .gpio = 86, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &hap_lvl_shft_suspended_config, |
| [GPIOMUX_ACTIVE] = &hap_lvl_shft_active_config, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_touch_configs[] __initdata = { |
| { |
| .gpio = 60, /* TOUCH RESET */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &atmel_resout_act_cfg, |
| [GPIOMUX_SUSPENDED] = &atmel_resout_sus_cfg, |
| }, |
| }, |
| { |
| .gpio = 61, /* TOUCH IRQ */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &atmel_int_act_cfg, |
| [GPIOMUX_SUSPENDED] = &atmel_int_sus_cfg, |
| }, |
| }, |
| |
| }; |
| |
| static struct gpiomux_setting hsic_sus_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting hsic_act_cfg = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_12MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| |
| static struct gpiomux_setting hsic_hub_act_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| .dir = GPIOMUX_IN, |
| }; |
| |
| static struct gpiomux_setting hsic_resume_act_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| .dir = GPIOMUX_OUT_LOW, |
| }; |
| |
| static struct gpiomux_setting hsic_resume_susp_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| |
| static struct msm_gpiomux_config msm_hsic_configs[] = { |
| { |
| .gpio = 144, /*HSIC_STROBE */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hsic_act_cfg, |
| [GPIOMUX_SUSPENDED] = &hsic_sus_cfg, |
| }, |
| }, |
| { |
| .gpio = 145, /* HSIC_DATA */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hsic_act_cfg, |
| [GPIOMUX_SUSPENDED] = &hsic_sus_cfg, |
| }, |
| }, |
| { |
| .gpio = 80, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hsic_resume_act_cfg, |
| [GPIOMUX_SUSPENDED] = &hsic_resume_susp_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_hsic_hub_configs[] = { |
| { |
| .gpio = 50, /* HSIC_HUB_INT_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hsic_hub_act_cfg, |
| [GPIOMUX_SUSPENDED] = &hsic_sus_cfg, |
| }, |
| }, |
| }; |
| |
| static struct gpiomux_setting mhl_suspend_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting mhl_active_1_cfg = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| .dir = GPIOMUX_OUT_HIGH, |
| }; |
| |
| static struct gpiomux_setting hdmi_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting hdmi_active_1_cfg = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting hdmi_active_2_cfg = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_16MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct msm_gpiomux_config msm_mhl_configs[] __initdata = { |
| { |
| /* mhl-sii8334 pwr */ |
| .gpio = 12, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &mhl_suspend_config, |
| [GPIOMUX_ACTIVE] = &mhl_active_1_cfg, |
| }, |
| }, |
| { |
| /* mhl-sii8334 intr */ |
| .gpio = 82, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &mhl_suspend_config, |
| [GPIOMUX_ACTIVE] = &mhl_active_1_cfg, |
| }, |
| }, |
| }; |
| |
| |
| static struct msm_gpiomux_config msm_hdmi_configs[] __initdata = { |
| { |
| .gpio = 31, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hdmi_active_1_cfg, |
| [GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 32, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hdmi_active_1_cfg, |
| [GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 33, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hdmi_active_1_cfg, |
| [GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 34, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &hdmi_active_2_cfg, |
| [GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg, |
| }, |
| }, |
| }; |
| |
| static struct gpiomux_setting gpio_uart7_active_cfg = { |
| .func = GPIOMUX_FUNC_3, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| |
| static struct gpiomux_setting gpio_uart7_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct msm_gpiomux_config msm_blsp2_uart7_configs[] __initdata = { |
| { |
| .gpio = 41, /* BLSP2 UART7 TX */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_uart7_active_cfg, |
| [GPIOMUX_SUSPENDED] = &gpio_uart7_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 42, /* BLSP2 UART7 RX */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_uart7_active_cfg, |
| [GPIOMUX_SUSPENDED] = &gpio_uart7_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 43, /* BLSP2 UART7 CTS */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_uart7_active_cfg, |
| [GPIOMUX_SUSPENDED] = &gpio_uart7_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 44, /* BLSP2 UART7 RFR */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_uart7_active_cfg, |
| [GPIOMUX_SUSPENDED] = &gpio_uart7_suspend_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_rumi_blsp_configs[] __initdata = { |
| { |
| .gpio = 45, /* BLSP2 UART8 TX */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_uart_config, |
| }, |
| }, |
| { |
| .gpio = 46, /* BLSP2 UART8 RX */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_uart_config, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_lcd_configs[] __initdata = { |
| { |
| .gpio = 58, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &lcd_en_act_cfg, |
| [GPIOMUX_SUSPENDED] = &lcd_en_sus_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_epm_configs[] __initdata = { |
| { |
| .gpio = 81, /* EPM enable */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_epm_config, |
| }, |
| }, |
| { |
| .gpio = 85, /* EPM MARKER2 */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_epm_marker_config, |
| }, |
| }, |
| { |
| .gpio = 96, /* EPM MARKER1 */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_epm_marker_config, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_blsp_configs[] __initdata = { |
| #if defined(CONFIG_KS8851) || defined(CONFIG_KS8851_MODULE) |
| { |
| .gpio = 0, /* BLSP1 QUP SPI_DATA_MOSI */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_config, |
| [GPIOMUX_SUSPENDED] = &gpio_spi_susp_config, |
| }, |
| }, |
| { |
| .gpio = 1, /* BLSP1 QUP SPI_DATA_MISO */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_config, |
| [GPIOMUX_SUSPENDED] = &gpio_spi_susp_config, |
| }, |
| }, |
| { |
| .gpio = 3, /* BLSP1 QUP SPI_CLK */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_config, |
| [GPIOMUX_SUSPENDED] = &gpio_spi_susp_config, |
| }, |
| }, |
| { |
| .gpio = 9, /* BLSP1 QUP SPI_CS2A_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_cs2_config, |
| [GPIOMUX_SUSPENDED] = &gpio_spi_susp_config, |
| }, |
| }, |
| { |
| .gpio = 8, /* BLSP1 QUP SPI_CS1_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_cs1_config, |
| [GPIOMUX_SUSPENDED] = &gpio_spi_susp_config, |
| }, |
| }, |
| #endif |
| { |
| .gpio = 6, /* BLSP1 QUP2 I2C_DAT */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| [GPIOMUX_ACTIVE] = &gpio_i2c_act_config, |
| }, |
| }, |
| { |
| .gpio = 7, /* BLSP1 QUP2 I2C_CLK */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| [GPIOMUX_ACTIVE] = &gpio_i2c_act_config, |
| }, |
| }, |
| { |
| .gpio = 83, /* BLSP11 QUP I2C_DAT */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| }, |
| }, |
| { |
| .gpio = 84, /* BLSP11 QUP I2C_CLK */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| }, |
| }, |
| { |
| .gpio = 4, /* BLSP2 UART TX */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_uart_config, |
| }, |
| }, |
| { |
| .gpio = 5, /* BLSP2 UART RX */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_uart_config, |
| }, |
| }, |
| { /* NFC */ |
| .gpio = 29, /* BLSP1 QUP6 I2C_DAT */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| }, |
| }, |
| { /* NFC */ |
| .gpio = 30, /* BLSP1 QUP6 I2C_CLK */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| }, |
| }, |
| { |
| .gpio = 53, /* BLSP2 QUP4 SPI_DATA_MOSI */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_config, |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 54, /* BLSP2 QUP4 SPI_DATA_MISO */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_config, |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 56, /* BLSP2 QUP4 SPI_CLK */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_config, |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 55, /* BLSP2 QUP4 SPI_CS0_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &gpio_spi_config, |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm8974_slimbus_config[] __initdata = { |
| { |
| .gpio = 70, /* slimbus clk */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &slimbus, |
| }, |
| }, |
| { |
| .gpio = 71, /* slimbus data */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &slimbus, |
| }, |
| }, |
| }; |
| |
| static struct gpiomux_setting cam_settings[] = { |
| { |
| .func = GPIOMUX_FUNC_1, /*active 1*/ /* 0 */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }, |
| |
| { |
| .func = GPIOMUX_FUNC_1, /*suspend*/ /* 1 */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }, |
| |
| { |
| .func = GPIOMUX_FUNC_1, /*i2c suspend*/ /* 2 */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_KEEPER, |
| }, |
| |
| { |
| .func = GPIOMUX_FUNC_GPIO, /*active 0*/ /* 3 */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }, |
| |
| { |
| .func = GPIOMUX_FUNC_GPIO, /*suspend 0*/ /* 4 */ |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }, |
| }; |
| |
| static struct gpiomux_setting sd_card_det_active_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_NONE, |
| .dir = GPIOMUX_IN, |
| }; |
| |
| static struct gpiomux_setting sd_card_det_sleep_config = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_UP, |
| .dir = GPIOMUX_IN, |
| }; |
| |
| static struct msm_gpiomux_config sd_card_det __initdata = { |
| .gpio = 62, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sd_card_det_active_config, |
| [GPIOMUX_SUSPENDED] = &sd_card_det_sleep_config, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_sensor_configs[] __initdata = { |
| { |
| .gpio = 15, /* CAM_MCLK0 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 16, /* CAM_MCLK1 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 17, /* CAM_MCLK2 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 18, /* WEBCAM1_RESET_N / CAM_MCLK3 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &cam_settings[4], |
| }, |
| }, |
| { |
| .gpio = 19, /* CCI_I2C_SDA0 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 20, /* CCI_I2C_SCL0 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 21, /* CCI_I2C_SDA1 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 22, /* CCI_I2C_SCL1 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 23, /* FLASH_LED_EN */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 24, /* FLASH_LED_NOW */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 25, /* WEBCAM2_RESET_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 26, /* CAM_IRQ */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 27, /* OIS_SYNC */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 28, /* WEBCAM1_STANDBY */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 89, /* CAM1_STANDBY_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 90, /* CAM1_RST_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 91, /* CAM2_STANDBY_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 92, /* CAM2_RST_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_sensor_configs_dragonboard[] __initdata = { |
| { |
| .gpio = 15, /* CAM_MCLK0 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 16, /* CAM_MCLK1 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 17, /* CAM_MCLK2 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 18, /* WEBCAM1_RESET_N / CAM_MCLK3 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &cam_settings[4], |
| }, |
| }, |
| { |
| .gpio = 19, /* CCI_I2C_SDA0 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 20, /* CCI_I2C_SCL0 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 21, /* CCI_I2C_SDA1 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 22, /* CCI_I2C_SCL1 */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0], |
| }, |
| }, |
| { |
| .gpio = 23, /* FLASH_LED_EN */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 24, /* FLASH_LED_NOW */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 25, /* WEBCAM2_RESET_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 26, /* CAM_IRQ */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &cam_settings[1], |
| }, |
| }, |
| { |
| .gpio = 27, /* OIS_SYNC */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[0], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 28, /* WEBCAM1_STANDBY */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 89, /* CAM1_STANDBY_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 90, /* CAM1_RST_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 91, /* CAM2_STANDBY_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| { |
| .gpio = 94, /* CAM2_RST_N */ |
| .settings = { |
| [GPIOMUX_ACTIVE] = &cam_settings[3], |
| [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1], |
| }, |
| }, |
| }; |
| |
| static struct gpiomux_setting auxpcm_act_cfg = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| |
| |
| static struct gpiomux_setting auxpcm_sus_cfg = { |
| .func = GPIOMUX_FUNC_1, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| /* Primary AUXPCM port sharing GPIO lines with Primary MI2S */ |
| static struct msm_gpiomux_config msm8974_pri_pri_auxpcm_configs[] __initdata = { |
| { |
| .gpio = 65, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 66, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 67, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 68, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| }; |
| |
| /* Primary AUXPCM port sharing GPIO lines with Tertiary MI2S */ |
| static struct msm_gpiomux_config msm8974_pri_ter_auxpcm_configs[] __initdata = { |
| { |
| .gpio = 74, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 75, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 76, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 77, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm8974_sec_auxpcm_configs[] __initdata = { |
| { |
| .gpio = 79, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 80, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 81, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| { |
| .gpio = 82, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &auxpcm_sus_cfg, |
| [GPIOMUX_ACTIVE] = &auxpcm_act_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config wcnss_5wire_interface[] = { |
| { |
| .gpio = 36, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 37, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 38, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 39, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 40, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config wcnss_5gpio_interface[] = { |
| { |
| .gpio = 36, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5gpio_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5gpio_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 37, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5gpio_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5gpio_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 38, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5gpio_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5gpio_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 39, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5gpio_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5gpio_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 40, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &wcnss_5gpio_active_cfg, |
| [GPIOMUX_SUSPENDED] = &wcnss_5gpio_suspend_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config ath_gpio_configs[] = { |
| { |
| .gpio = 51, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &ath_gpio_active_cfg, |
| [GPIOMUX_SUSPENDED] = &ath_gpio_suspend_cfg, |
| }, |
| }, |
| { |
| .gpio = 79, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &ath_gpio_active_cfg, |
| [GPIOMUX_SUSPENDED] = &ath_gpio_suspend_cfg, |
| }, |
| }, |
| }; |
| |
| static struct msm_gpiomux_config msm_taiko_config[] __initdata = { |
| { |
| .gpio = 63, /* SYS_RST_N */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &taiko_reset, |
| }, |
| }, |
| { |
| .gpio = 72, /* CDC_INT */ |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &taiko_int, |
| }, |
| }, |
| }; |
| |
| static struct gpiomux_setting sdc3_clk_actv_cfg = { |
| .func = GPIOMUX_FUNC_2, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| |
| static struct gpiomux_setting sdc3_cmd_data_0_3_actv_cfg = { |
| .func = GPIOMUX_FUNC_2, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting sdc3_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting sdc3_data_1_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct msm_gpiomux_config msm8974_sdc3_configs[] __initdata = { |
| { |
| /* DAT3 */ |
| .gpio = 35, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc3_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc3_suspend_cfg, |
| }, |
| }, |
| { |
| /* DAT2 */ |
| .gpio = 36, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc3_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc3_suspend_cfg, |
| }, |
| }, |
| { |
| /* DAT1 */ |
| .gpio = 37, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc3_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc3_data_1_suspend_cfg, |
| }, |
| }, |
| { |
| /* DAT0 */ |
| .gpio = 38, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc3_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc3_suspend_cfg, |
| }, |
| }, |
| { |
| /* CMD */ |
| .gpio = 39, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc3_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc3_suspend_cfg, |
| }, |
| }, |
| { |
| /* CLK */ |
| .gpio = 40, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc3_clk_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc3_suspend_cfg, |
| }, |
| }, |
| }; |
| |
| static void msm_gpiomux_sdc3_install(void) |
| { |
| msm_gpiomux_install(msm8974_sdc3_configs, |
| ARRAY_SIZE(msm8974_sdc3_configs)); |
| } |
| |
| #ifdef CONFIG_MMC_MSM_SDC4_SUPPORT |
| static struct gpiomux_setting sdc4_clk_actv_cfg = { |
| .func = GPIOMUX_FUNC_2, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_NONE, |
| }; |
| |
| static struct gpiomux_setting sdc4_cmd_data_0_3_actv_cfg = { |
| .func = GPIOMUX_FUNC_2, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct gpiomux_setting sdc4_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_2MA, |
| .pull = GPIOMUX_PULL_DOWN, |
| }; |
| |
| static struct gpiomux_setting sdc4_data_1_suspend_cfg = { |
| .func = GPIOMUX_FUNC_GPIO, |
| .drv = GPIOMUX_DRV_8MA, |
| .pull = GPIOMUX_PULL_UP, |
| }; |
| |
| static struct msm_gpiomux_config msm8974_sdc4_configs[] __initdata = { |
| { |
| /* DAT3 */ |
| .gpio = 92, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc4_suspend_cfg, |
| }, |
| }, |
| { |
| /* DAT2 */ |
| .gpio = 94, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc4_suspend_cfg, |
| }, |
| }, |
| { |
| /* DAT1 */ |
| .gpio = 95, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc4_data_1_suspend_cfg, |
| }, |
| }, |
| { |
| /* DAT0 */ |
| .gpio = 96, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc4_suspend_cfg, |
| }, |
| }, |
| { |
| /* CMD */ |
| .gpio = 91, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc4_suspend_cfg, |
| }, |
| }, |
| { |
| /* CLK */ |
| .gpio = 93, |
| .settings = { |
| [GPIOMUX_ACTIVE] = &sdc4_clk_actv_cfg, |
| [GPIOMUX_SUSPENDED] = &sdc4_suspend_cfg, |
| }, |
| }, |
| }; |
| |
| static void msm_gpiomux_sdc4_install(void) |
| { |
| msm_gpiomux_install(msm8974_sdc4_configs, |
| ARRAY_SIZE(msm8974_sdc4_configs)); |
| } |
| #else |
| static void msm_gpiomux_sdc4_install(void) {} |
| #endif /* CONFIG_MMC_MSM_SDC4_SUPPORT */ |
| |
| static struct msm_gpiomux_config apq8074_dragonboard_ts_config[] __initdata = { |
| { |
| /* BLSP1 QUP I2C_DATA */ |
| .gpio = 2, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| }, |
| }, |
| { |
| /* BLSP1 QUP I2C_CLK */ |
| .gpio = 3, |
| .settings = { |
| [GPIOMUX_SUSPENDED] = &gpio_i2c_config, |
| }, |
| }, |
| }; |
| |
| void __init msm_8974_init_gpiomux(void) |
| { |
| int rc; |
| |
| rc = msm_gpiomux_init_dt(); |
| if (rc) { |
| pr_err("%s failed %d\n", __func__, rc); |
| return; |
| } |
| |
| pr_err("%s:%d socinfo_get_version %x\n", __func__, __LINE__, |
| socinfo_get_version()); |
| if (socinfo_get_version() >= 0x20000) |
| msm_tlmm_misc_reg_write(TLMM_SPARE_REG, 0xf); |
| |
| #if defined(CONFIG_KS8851) || defined(CONFIG_KS8851_MODULE) |
| if (!(of_board_is_dragonboard() && machine_is_apq8074())) |
| msm_gpiomux_install(msm_eth_configs, \ |
| ARRAY_SIZE(msm_eth_configs)); |
| #endif |
| msm_gpiomux_install(msm_blsp_configs, ARRAY_SIZE(msm_blsp_configs)); |
| msm_gpiomux_install(msm_blsp2_uart7_configs, |
| ARRAY_SIZE(msm_blsp2_uart7_configs)); |
| msm_gpiomux_install(wcnss_5wire_interface, |
| ARRAY_SIZE(wcnss_5wire_interface)); |
| if (of_board_is_liquid()) |
| msm_gpiomux_install_nowrite(ath_gpio_configs, |
| ARRAY_SIZE(ath_gpio_configs)); |
| msm_gpiomux_install(msm8974_slimbus_config, |
| ARRAY_SIZE(msm8974_slimbus_config)); |
| |
| msm_gpiomux_install(msm_touch_configs, ARRAY_SIZE(msm_touch_configs)); |
| msm_gpiomux_install(hap_lvl_shft_config, |
| ARRAY_SIZE(hap_lvl_shft_config)); |
| |
| if (of_board_is_dragonboard() && machine_is_apq8074()) |
| msm_gpiomux_install(msm_sensor_configs_dragonboard, \ |
| ARRAY_SIZE(msm_sensor_configs_dragonboard)); |
| else |
| msm_gpiomux_install(msm_sensor_configs, \ |
| ARRAY_SIZE(msm_sensor_configs)); |
| |
| msm_gpiomux_install(&sd_card_det, 1); |
| |
| if (machine_is_apq8074() && (of_board_is_liquid() || \ |
| of_board_is_dragonboard())) |
| msm_gpiomux_sdc3_install(); |
| |
| if (!(of_board_is_dragonboard() && machine_is_apq8074())) |
| msm_gpiomux_sdc4_install(); |
| |
| msm_gpiomux_install(msm_taiko_config, ARRAY_SIZE(msm_taiko_config)); |
| |
| msm_gpiomux_install(msm_hsic_configs, ARRAY_SIZE(msm_hsic_configs)); |
| msm_gpiomux_install(msm_hsic_hub_configs, |
| ARRAY_SIZE(msm_hsic_hub_configs)); |
| |
| msm_gpiomux_install(msm_hdmi_configs, ARRAY_SIZE(msm_hdmi_configs)); |
| if (of_board_is_fluid()) |
| msm_gpiomux_install(msm_mhl_configs, |
| ARRAY_SIZE(msm_mhl_configs)); |
| |
| if (of_board_is_liquid() || |
| (of_board_is_dragonboard() && machine_is_apq8074())) |
| msm_gpiomux_install(msm8974_pri_ter_auxpcm_configs, |
| ARRAY_SIZE(msm8974_pri_ter_auxpcm_configs)); |
| else |
| msm_gpiomux_install(msm8974_pri_pri_auxpcm_configs, |
| ARRAY_SIZE(msm8974_pri_pri_auxpcm_configs)); |
| |
| if (of_board_is_cdp()) |
| msm_gpiomux_install(msm8974_sec_auxpcm_configs, |
| ARRAY_SIZE(msm8974_sec_auxpcm_configs)); |
| else if (of_board_is_liquid() || of_board_is_fluid() || |
| of_board_is_mtp()) |
| msm_gpiomux_install(msm_epm_configs, |
| ARRAY_SIZE(msm_epm_configs)); |
| |
| msm_gpiomux_install_nowrite(msm_lcd_configs, |
| ARRAY_SIZE(msm_lcd_configs)); |
| |
| if (of_board_is_rumi()) |
| msm_gpiomux_install(msm_rumi_blsp_configs, |
| ARRAY_SIZE(msm_rumi_blsp_configs)); |
| |
| if (socinfo_get_platform_subtype() == PLATFORM_SUBTYPE_MDM) |
| msm_gpiomux_install(mdm_configs, |
| ARRAY_SIZE(mdm_configs)); |
| |
| if (of_board_is_dragonboard() && machine_is_apq8074()) |
| msm_gpiomux_install(apq8074_dragonboard_ts_config, |
| ARRAY_SIZE(apq8074_dragonboard_ts_config)); |
| } |
| |
| static void wcnss_switch_to_gpio(void) |
| { |
| /* Switch MUX to GPIO */ |
| msm_gpiomux_install(wcnss_5gpio_interface, |
| ARRAY_SIZE(wcnss_5gpio_interface)); |
| |
| /* Ensure GPIO config */ |
| gpio_direction_input(WLAN_DATA2); |
| gpio_direction_input(WLAN_DATA1); |
| gpio_direction_input(WLAN_DATA0); |
| gpio_direction_output(WLAN_SET, 0); |
| gpio_direction_output(WLAN_CLK, 0); |
| } |
| |
| static void wcnss_switch_to_5wire(void) |
| { |
| msm_gpiomux_install(wcnss_5wire_interface, |
| ARRAY_SIZE(wcnss_5wire_interface)); |
| } |
| |
| u32 wcnss_rf_read_reg(u32 rf_reg_addr) |
| { |
| int count = 0; |
| u32 rf_cmd_and_addr = 0; |
| u32 rf_data_received = 0; |
| u32 rf_bit = 0; |
| |
| wcnss_switch_to_gpio(); |
| |
| /* Reset the signal if it is already being used. */ |
| gpio_set_value(WLAN_SET, 0); |
| gpio_set_value(WLAN_CLK, 0); |
| |
| /* We start with cmd_set high WLAN_SET = 1. */ |
| gpio_set_value(WLAN_SET, 1); |
| |
| gpio_direction_output(WLAN_DATA0, 1); |
| gpio_direction_output(WLAN_DATA1, 1); |
| gpio_direction_output(WLAN_DATA2, 1); |
| |
| gpio_set_value(WLAN_DATA0, 0); |
| gpio_set_value(WLAN_DATA1, 0); |
| gpio_set_value(WLAN_DATA2, 0); |
| |
| /* Prepare command and RF register address that need to sent out. |
| * Make sure that we send only 14 bits from LSB. |
| */ |
| rf_cmd_and_addr = (((WLAN_RF_READ_REG_CMD) | |
| (rf_reg_addr << WLAN_RF_REG_ADDR_START_OFFSET)) & |
| WLAN_RF_READ_CMD_MASK); |
| |
| for (count = 0; count < 5; count++) { |
| gpio_set_value(WLAN_CLK, 0); |
| |
| rf_bit = (rf_cmd_and_addr & 0x1); |
| gpio_set_value(WLAN_DATA0, rf_bit ? 1 : 0); |
| rf_cmd_and_addr = (rf_cmd_and_addr >> 1); |
| |
| rf_bit = (rf_cmd_and_addr & 0x1); |
| gpio_set_value(WLAN_DATA1, rf_bit ? 1 : 0); |
| rf_cmd_and_addr = (rf_cmd_and_addr >> 1); |
| |
| rf_bit = (rf_cmd_and_addr & 0x1); |
| gpio_set_value(WLAN_DATA2, rf_bit ? 1 : 0); |
| rf_cmd_and_addr = (rf_cmd_and_addr >> 1); |
| |
| /* Send the data out WLAN_CLK = 1 */ |
| gpio_set_value(WLAN_CLK, 1); |
| } |
| |
| /* Pull down the clock signal */ |
| gpio_set_value(WLAN_CLK, 0); |
| |
| /* Configure data pins to input IO pins */ |
| gpio_direction_input(WLAN_DATA0); |
| gpio_direction_input(WLAN_DATA1); |
| gpio_direction_input(WLAN_DATA2); |
| |
| for (count = 0; count < 2; count++) { |
| gpio_set_value(WLAN_CLK, 1); |
| gpio_set_value(WLAN_CLK, 0); |
| } |
| |
| rf_bit = 0; |
| for (count = 0; count < 6; count++) { |
| gpio_set_value(WLAN_CLK, 1); |
| gpio_set_value(WLAN_CLK, 0); |
| |
| rf_bit = gpio_get_value(WLAN_DATA0); |
| rf_data_received |= (rf_bit << (count * 3 + 0)); |
| |
| if (count != 5) { |
| rf_bit = gpio_get_value(WLAN_DATA1); |
| rf_data_received |= (rf_bit << (count * 3 + 1)); |
| |
| rf_bit = gpio_get_value(WLAN_DATA2); |
| rf_data_received |= (rf_bit << (count * 3 + 2)); |
| } |
| } |
| |
| gpio_set_value(WLAN_SET, 0); |
| wcnss_switch_to_5wire(); |
| |
| return rf_data_received; |
| } |