blob: 1256c12f720a06bdea563d2f82677e2ad01652b0 [file] [log] [blame]
/* Copyright (c) 2011-2012, Code Aurora Forum. 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/init.h>
#include <linux/ioport.h>
#include <linux/platform_device.h>
#include <linux/bootmem.h>
#include <linux/gpio.h>
#include <asm/mach-types.h>
#include <asm/mach/mmc.h>
#include <mach/msm_bus_board.h>
#include <mach/board.h>
#include <mach/gpiomux.h>
#include <mach/socinfo.h>
#include <mach/board_asustek.h>
#include "devices.h"
#include "board-flo.h"
#if defined(CONFIG_KS8851) || defined(CONFIG_KS8851_MODULE)
static struct gpiomux_setting gpio_eth_config = {
.pull = GPIOMUX_PULL_NONE,
.drv = GPIOMUX_DRV_8MA,
.func = GPIOMUX_FUNC_GPIO,
};
/* The SPI configurations apply to GSBI 5*/
static struct gpiomux_setting gpio_spi_config = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_12MA,
.pull = GPIOMUX_PULL_NONE,
};
/* The SPI configurations apply to GSBI 5 chip select 2*/
static struct gpiomux_setting gpio_spi_cs2_config = {
.func = GPIOMUX_FUNC_3,
.drv = GPIOMUX_DRV_12MA,
.pull = GPIOMUX_PULL_NONE,
};
struct msm_gpiomux_config apq8064_ethernet_configs[] = {
{
.gpio = 43,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_eth_config,
[GPIOMUX_ACTIVE] = &gpio_eth_config,
}
},
};
#endif
/* Chip selects for SPI clients */
static struct gpiomux_setting gpio_spi_cs_config = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_12MA,
.pull = GPIOMUX_PULL_UP,
};
/* Chip selects for EPM SPI clients */
static struct gpiomux_setting gpio_epm_spi_cs_config = {
.func = GPIOMUX_FUNC_6,
.drv = GPIOMUX_DRV_12MA,
.pull = GPIOMUX_PULL_UP,
};
#ifdef CONFIG_MSM_VCAP
static struct gpiomux_setting gpio_vcap_config[] = {
{
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_3,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_4,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_5,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_6,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_7,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_8,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_9,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
{
.func = GPIOMUX_FUNC_A,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
},
};
struct msm_gpiomux_config vcap_configs[] = {
{
.gpio = 20,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[7],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[7],
}
},
{
.gpio = 25,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[2],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[2],
}
},
{
.gpio = 24,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[1],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[1],
}
},
{
.gpio = 19,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[8],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[8],
}
},
{
.gpio = 21,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[7],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[7],
}
},
{
.gpio = 18,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[9],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[9],
}
},
{
.gpio = 11,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[10],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[10],
}
},
{
.gpio = 10,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[9],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[9],
}
},
{
.gpio = 9,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[2],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[2],
}
},
{
.gpio = 8,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[3],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[3],
}
},
#if 0
{
.gpio = 7,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[7],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[7],
}
},
#endif
{
.gpio = 6,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[7],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[7],
}
},
{
.gpio = 80,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[2],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[2],
}
},
{
.gpio = 85,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[4],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[4],
}
},
{
.gpio = 84,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[3],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[3],
}
},
{
.gpio = 5,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[2],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[2],
}
},
{
.gpio = 4,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[3],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[3],
}
},
{
.gpio = 3,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[6],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[6],
}
},
{
.gpio = 2,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[5],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[5],
}
},
{
.gpio = 82,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[4],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[4],
}
},
{
.gpio = 83,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[4],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[4],
}
},
{
.gpio = 87,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[2],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[2],
}
},
{
.gpio = 13,
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_vcap_config[6],
[GPIOMUX_ACTIVE] = &gpio_vcap_config[6],
}
},
};
#endif
static struct gpiomux_setting wpc_pok_pin_setting = {
.func = GPIOMUX_FUNC_GPIO,
.pull = GPIOMUX_PULL_UP,
.dir = GPIOMUX_IN,
};
static struct gpiomux_setting stat_pin_setting = {
.func = GPIOMUX_FUNC_GPIO,
.pull = GPIOMUX_PULL_NONE,
.dir = GPIOMUX_IN,
};
static struct gpiomux_setting acok_pin_setting = {
.func = GPIOMUX_FUNC_GPIO,
.pull = GPIOMUX_PULL_NONE,
.dir = GPIOMUX_IN,
};
struct msm_gpiomux_config wpc_pok_configs[] = {
{
.gpio = 34,
.settings = {
[GPIOMUX_SUSPENDED] = &wpc_pok_pin_setting,
[GPIOMUX_ACTIVE] = &wpc_pok_pin_setting,
}
},
};
struct msm_gpiomux_config smb345_pin_configs[] = {
{
.gpio = 22,
.settings = {
[GPIOMUX_SUSPENDED] = &stat_pin_setting,
[GPIOMUX_ACTIVE] = &stat_pin_setting,
}
},
{
.gpio = 23,
.settings = {
[GPIOMUX_SUSPENDED] = &acok_pin_setting,
[GPIOMUX_ACTIVE] = &acok_pin_setting,
}
},
};
static struct gpiomux_setting gpio_i2c_config = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting gpio_i2c_config_sus = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_KEEPER,
};
static struct gpiomux_setting mbhc_hs_detect = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting cdc_mclk = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
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 slimbus = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_KEEPER,
};
static struct gpiomux_setting gsbi1_uart_config = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_16MA,
.pull = GPIOMUX_PULL_NONE,
};
/*
static struct gpiomux_setting ext_regulator_config = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
.dir = GPIOMUX_OUT_LOW,
};
*/
static struct gpiomux_setting gsbi7_func1_cfg = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting gsbi7_func2_cfg = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting gsbi3_suspended_cfg = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_KEEPER,
};
static struct gpiomux_setting gsbi3_active_cfg = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting mdp_vsync_suspend_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting mdp_vsync_active_cfg = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
};
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 gpiomux_setting gsbi5_suspended_cfg = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_12MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting gsbi5_active_cfg = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_12MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting sx150x_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting sx150x_active_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
#ifdef CONFIG_USB_EHCI_MSM_HSIC
static struct gpiomux_setting cyts_sleep_sus_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_6MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting cyts_sleep_act_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_6MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting cyts_int_act_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_UP,
};
static struct gpiomux_setting cyts_int_sus_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct msm_gpiomux_config cyts_gpio_configs[] __initdata = {
{ /* TS INTERRUPT */
.gpio = 6,
.settings = {
[GPIOMUX_ACTIVE] = &cyts_int_act_cfg,
[GPIOMUX_SUSPENDED] = &cyts_int_sus_cfg,
},
},
{ /* TS SLEEP */
.gpio = 33,
.settings = {
[GPIOMUX_ACTIVE] = &cyts_sleep_act_cfg,
[GPIOMUX_SUSPENDED] = &cyts_sleep_sus_cfg,
},
},
};
static struct msm_gpiomux_config cyts_gpio_alt_config[] __initdata = {
{ /* TS INTERRUPT */
.gpio = 6,
.settings = {
[GPIOMUX_ACTIVE] = &cyts_int_act_cfg,
[GPIOMUX_SUSPENDED] = &cyts_int_sus_cfg,
},
},
{ /* TS SLEEP */
.gpio = 12,
.settings = {
[GPIOMUX_ACTIVE] = &cyts_sleep_act_cfg,
[GPIOMUX_SUSPENDED] = &cyts_sleep_sus_cfg,
},
},
};
static struct msm_gpiomux_config msm8960_mdp_vsync_configs[] __initdata = {
{
.gpio = 0,
.settings = {
[GPIOMUX_ACTIVE] = &mdp_vsync_active_cfg,
[GPIOMUX_SUSPENDED] = &mdp_vsync_suspend_cfg,
},
},
};
static struct gpiomux_setting hsic_act_cfg = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting hsic_sus_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
.dir = GPIOMUX_OUT_LOW,
};
static struct gpiomux_setting hsic_wakeup_act_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_DOWN,
.dir = GPIOMUX_IN,
};
static struct gpiomux_setting hsic_wakeup_sus_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
.dir = GPIOMUX_IN,
};
static struct msm_gpiomux_config apq8064_hsic_configs[] = {
{
.gpio = 88, /*HSIC_STROBE */
.settings = {
[GPIOMUX_ACTIVE] = &hsic_act_cfg,
[GPIOMUX_SUSPENDED] = &hsic_sus_cfg,
},
},
{
.gpio = 89, /* HSIC_DATA */
.settings = {
[GPIOMUX_ACTIVE] = &hsic_act_cfg,
[GPIOMUX_SUSPENDED] = &hsic_sus_cfg,
},
},
{
.gpio = 47, /* wake up */
.settings = {
[GPIOMUX_ACTIVE] = &hsic_wakeup_act_cfg,
[GPIOMUX_SUSPENDED] = &hsic_wakeup_sus_cfg,
},
},
};
#endif
static struct gpiomux_setting mxt_reset_sus_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_6MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting mxt_reset_act_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_6MA,
.pull = GPIOMUX_PULL_UP,
};
static struct gpiomux_setting mxt_int_sus_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting mxt_int_act_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_UP,
};
static struct msm_gpiomux_config apq8064_hdmi_configs[] __initdata = {
{
.gpio = 69,
.settings = {
[GPIOMUX_ACTIVE] = &hdmi_active_1_cfg,
[GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg,
},
},
{
.gpio = 70,
.settings = {
[GPIOMUX_ACTIVE] = &hdmi_active_1_cfg,
[GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg,
},
},
{
.gpio = 71,
.settings = {
[GPIOMUX_ACTIVE] = &hdmi_active_1_cfg,
[GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg,
},
},
{
.gpio = 72,
.settings = {
[GPIOMUX_ACTIVE] = &hdmi_active_2_cfg,
[GPIOMUX_SUSPENDED] = &hdmi_suspend_cfg,
},
},
};
static struct msm_gpiomux_config apq8064_gsbi_configs[] __initdata = {
{
.gpio = 8, /* GSBI3 I2C QUP SDA */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi3_suspended_cfg,
[GPIOMUX_ACTIVE] = &gsbi3_active_cfg,
},
},
{
.gpio = 9, /* GSBI3 I2C QUP SCL */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi3_suspended_cfg,
[GPIOMUX_ACTIVE] = &gsbi3_active_cfg,
},
},
{
.gpio = 18, /* GSBI1 UART TX */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi1_uart_config,
},
},
{
.gpio = 19, /* GSBI1 UART RX */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi1_uart_config,
},
},
#if defined(CONFIG_KS8851) || defined(CONFIG_KS8851_MODULE)
{
.gpio = 52, /* GSBI5 QUP SPI_DATA_MISO */
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_spi_config,
},
},
{
.gpio = 31, /* GSBI5 QUP SPI_CS2_N */
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_spi_cs2_config,
},
},
#endif
{
.gpio = 30, /* FP CS */
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_spi_cs_config,
},
},
{
.gpio = 32, /* EPM CS */
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_epm_spi_cs_config,
},
},
{
.gpio = 82, /* GSBI7 UART2 TX */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi7_func2_cfg,
},
},
{
.gpio = 83, /* GSBI7 UART2 RX */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi7_func1_cfg,
},
},
{
.gpio = 21, /* GSBI1 QUP I2C_CLK */
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_i2c_config_sus,
[GPIOMUX_ACTIVE] = &gpio_i2c_config,
},
},
{
.gpio = 20, /* GSBI1 QUP I2C_DATA */
.settings = {
[GPIOMUX_SUSPENDED] = &gpio_i2c_config_sus,
[GPIOMUX_ACTIVE] = &gpio_i2c_config,
},
},
};
static struct msm_gpiomux_config apq8064_slimbus_config[] __initdata = {
{
.gpio = 40, /* slimbus clk */
.settings = {
[GPIOMUX_SUSPENDED] = &slimbus,
},
},
{
.gpio = 41, /* slimbus data */
.settings = {
[GPIOMUX_SUSPENDED] = &slimbus,
},
},
};
static struct gpiomux_setting spkr_i2c = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_KEEPER,
};
static struct msm_gpiomux_config mpq8064_spkr_i2s_config[] __initdata = {
{
.gpio = 47, /* spkr i2c sck */
.settings = {
[GPIOMUX_SUSPENDED] = &spkr_i2c,
},
},
{
.gpio = 48, /* spkr_i2s_ws */
.settings = {
[GPIOMUX_SUSPENDED] = &spkr_i2c,
},
},
{
.gpio = 49, /* spkr_i2s_dout */
.settings = {
[GPIOMUX_SUSPENDED] = &spkr_i2c,
},
},
{
.gpio = 50, /* spkr_i2s_mclk */
.settings = {
[GPIOMUX_SUSPENDED] = &spkr_i2c,
},
},
};
static struct msm_gpiomux_config apq8064_audio_codec_configs[] __initdata = {
{
.gpio = 38,
.settings = {
[GPIOMUX_SUSPENDED] = &mbhc_hs_detect,
},
},
{
.gpio = 39,
.settings = {
[GPIOMUX_SUSPENDED] = &cdc_mclk,
},
},
};
/* Config Headphone detect and Hook detect pin */
static struct gpiomux_setting hs_detect = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting hs_hook_detect = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting hs_db_detect = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct msm_gpiomux_config apq8064_headphone_configs[] = {
{
.gpio = 85,
.settings = {
[GPIOMUX_SUSPENDED] = &hs_db_detect,
},
},
{
.gpio = 45,
.settings = {
[GPIOMUX_SUSPENDED] = &hs_detect,
},
},
{
.gpio = 62,
.settings = {
[GPIOMUX_SUSPENDED] = &hs_hook_detect,
},
},
};
/* External 3.3 V regulator enable */
/*static struct msm_gpiomux_config apq8064_ext_regulator_configs[] __initdata = {
{
.gpio = APQ8064_EXT_3P3V_REG_EN_GPIO,
.settings = {
[GPIOMUX_SUSPENDED] = &ext_regulator_config,
},
},
};*/
static struct gpiomux_setting ap2mdm_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting mdm2ap_status_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting mdm2ap_errfatal_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_16MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting mdm2ap_pblrdy = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_16MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting ap2mdm_soft_reset_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting ap2mdm_wakeup = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct msm_gpiomux_config mdm_configs[] __initdata = {
/* AP2MDM_STATUS */
{
.gpio = 48,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_cfg,
}
},
/* MDM2AP_STATUS */
{
.gpio = 49,
.settings = {
[GPIOMUX_ACTIVE] = &mdm2ap_status_cfg,
[GPIOMUX_SUSPENDED] = &mdm2ap_status_cfg,
}
},
/* MDM2AP_ERRFATAL */
{
.gpio = 19,
.settings = {
[GPIOMUX_SUSPENDED] = &mdm2ap_errfatal_cfg,
}
},
/* AP2MDM_ERRFATAL */
{
.gpio = 18,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_cfg,
}
},
/* AP2MDM_SOFT_RESET, aka AP2MDM_PON_RESET_N */
{
.gpio = 27,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_soft_reset_cfg,
}
},
/* AP2MDM_WAKEUP */
{
.gpio = 35,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_wakeup,
}
},
/* MDM2AP_PBL_READY*/
{
.gpio = 46,
.settings = {
[GPIOMUX_SUSPENDED] = &mdm2ap_pblrdy,
}
},
};
static struct msm_gpiomux_config mdm_i2s_configs[] __initdata = {
/* AP2MDM_STATUS */
{
.gpio = 48,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_cfg,
}
},
/* MDM2AP_STATUS */
{
.gpio = 49,
.settings = {
[GPIOMUX_SUSPENDED] = &mdm2ap_status_cfg,
}
},
/* MDM2AP_ERRFATAL */
{
.gpio = 19,
.settings = {
[GPIOMUX_SUSPENDED] = &mdm2ap_errfatal_cfg,
}
},
/* AP2MDM_ERRFATAL */
{
.gpio = 18,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_cfg,
}
},
/* AP2MDM_SOFT_RESET, aka AP2MDM_PON_RESET_N */
{
.gpio = 0,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_soft_reset_cfg,
}
},
#if 0
/* AP2MDM_WAKEUP */
{
.gpio = 44,
.settings = {
[GPIOMUX_SUSPENDED] = &ap2mdm_wakeup,
}
},
#endif
/* MDM2AP_PBL_READY*/
{
.gpio = 81,
.settings = {
[GPIOMUX_SUSPENDED] = &mdm2ap_pblrdy,
}
},
};
static struct gpiomux_setting mi2s_act_cfg = {
.func = GPIOMUX_FUNC_1,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting mi2s_sus_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct msm_gpiomux_config mpq8064_mi2s_configs[] __initdata = {
{
.gpio = 27, /* mi2s ws */
.settings = {
[GPIOMUX_ACTIVE] = &mi2s_act_cfg,
[GPIOMUX_SUSPENDED] = &mi2s_sus_cfg,
},
},
{
.gpio = 28, /* mi2s sclk */
.settings = {
[GPIOMUX_ACTIVE] = &mi2s_act_cfg,
[GPIOMUX_SUSPENDED] = &mi2s_sus_cfg,
},
},
{
.gpio = 29, /* mi2s dout3 */
.settings = {
[GPIOMUX_ACTIVE] = &mi2s_act_cfg,
[GPIOMUX_SUSPENDED] = &mi2s_sus_cfg,
},
},
{
.gpio = 30, /* mi2s dout2 */
.settings = {
[GPIOMUX_ACTIVE] = &mi2s_act_cfg,
[GPIOMUX_SUSPENDED] = &mi2s_sus_cfg,
},
},
{
.gpio = 31, /* mi2s dout1 */
.settings = {
[GPIOMUX_ACTIVE] = &mi2s_act_cfg,
[GPIOMUX_SUSPENDED] = &mi2s_sus_cfg,
},
},
{
.gpio = 32, /* mi2s dout0 */
.settings = {
[GPIOMUX_ACTIVE] = &mi2s_act_cfg,
[GPIOMUX_SUSPENDED] = &mi2s_sus_cfg,
},
},
{
.gpio = 33, /* mi2s mclk */
.settings = {
[GPIOMUX_ACTIVE] = &mi2s_act_cfg,
[GPIOMUX_SUSPENDED] = &mi2s_sus_cfg,
},
},
};
static struct msm_gpiomux_config apq8064_mxt_configs[] __initdata = {
{ /* TS INTERRUPT */
.gpio = 6,
.settings = {
[GPIOMUX_ACTIVE] = &mxt_int_act_cfg,
[GPIOMUX_SUSPENDED] = &mxt_int_sus_cfg,
},
},
{ /* TS RESET */
.gpio = 33,
.settings = {
[GPIOMUX_ACTIVE] = &mxt_reset_act_cfg,
[GPIOMUX_SUSPENDED] = &mxt_reset_sus_cfg,
},
},
};
static struct msm_gpiomux_config wcnss_5wire_interface[] = {
{
.gpio = 64,
.settings = {
[GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg,
[GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg,
},
},
{
.gpio = 65,
.settings = {
[GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg,
[GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg,
},
},
{
.gpio = 66,
.settings = {
[GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg,
[GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg,
},
},
{
.gpio = 67,
.settings = {
[GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg,
[GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg,
},
},
{
.gpio = 68,
.settings = {
[GPIOMUX_ACTIVE] = &wcnss_5wire_active_cfg,
[GPIOMUX_SUSPENDED] = &wcnss_5wire_suspend_cfg,
},
},
};
static struct msm_gpiomux_config mpq8064_gsbi5_i2c_configs[] __initdata = {
{
.gpio = 53, /* GSBI5 I2C QUP SDA */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi5_suspended_cfg,
[GPIOMUX_ACTIVE] = &gsbi5_active_cfg,
},
},
{
.gpio = 54, /* GSBI5 I2C QUP SCL */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi5_suspended_cfg,
[GPIOMUX_ACTIVE] = &gsbi5_active_cfg,
},
},
};
static struct gpiomux_setting ir_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_UP,
};
static struct gpiomux_setting ir_active_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_UP,
};
static struct msm_gpiomux_config mpq8064_ir_configs[] __initdata = {
{
.gpio = 88, /* GPIO IR */
.settings = {
[GPIOMUX_SUSPENDED] = &ir_suspended_cfg,
[GPIOMUX_ACTIVE] = &ir_active_cfg,
},
},
};
static struct msm_gpiomux_config sx150x_int_configs[] __initdata = {
{
.gpio = 81,
.settings = {
[GPIOMUX_SUSPENDED] = &sx150x_suspended_cfg,
[GPIOMUX_ACTIVE] = &sx150x_active_cfg,
},
},
};
#ifdef CONFIG_MMC_MSM_SDC2_SUPPORT
static struct gpiomux_setting sdc2_clk_active_cfg = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting sdc2_cmd_data_0_3_active_cfg = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_UP,
};
static struct gpiomux_setting sdc2_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting sdc2_data_1_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_UP,
};
static struct msm_gpiomux_config apq8064_sdc2_configs[] __initdata = {
{
.gpio = 59,
.settings = {
[GPIOMUX_ACTIVE] = &sdc2_clk_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc2_suspended_cfg,
},
},
{
.gpio = 57,
.settings = {
[GPIOMUX_ACTIVE] = &sdc2_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc2_suspended_cfg,
},
},
#if 0
{
.gpio = 62,
.settings = {
[GPIOMUX_ACTIVE] = &sdc2_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc2_suspended_cfg,
},
},
#endif
{
.gpio = 61,
.settings = {
[GPIOMUX_ACTIVE] = &sdc2_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc2_data_1_suspended_cfg,
},
},
{
.gpio = 60,
.settings = {
[GPIOMUX_ACTIVE] = &sdc2_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc2_suspended_cfg,
},
},
{
.gpio = 58,
.settings = {
[GPIOMUX_ACTIVE] = &sdc2_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc2_suspended_cfg,
},
},
};
#endif
#ifdef CONFIG_MMC_MSM_SDC4_SUPPORT
static struct gpiomux_setting sdc4_clk_active_cfg = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting sdc4_cmd_data_0_3_active_cfg = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_UP,
};
static struct gpiomux_setting sdc4_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
};
static struct gpiomux_setting sdc4_data_1_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_UP,
};
static struct msm_gpiomux_config apq8064_sdc4_configs[] __initdata = {
{
.gpio = 68,
.settings = {
[GPIOMUX_ACTIVE] = &sdc4_clk_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc4_suspended_cfg,
},
},
{
.gpio = 67,
.settings = {
[GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc4_suspended_cfg,
},
},
{
.gpio = 66,
.settings = {
[GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc4_suspended_cfg,
},
},
{
.gpio = 65,
.settings = {
[GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc4_data_1_suspended_cfg,
},
},
{
.gpio = 64,
.settings = {
[GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc4_suspended_cfg,
},
},
{
.gpio = 63,
.settings = {
[GPIOMUX_ACTIVE] = &sdc4_cmd_data_0_3_active_cfg,
[GPIOMUX_SUSPENDED] = &sdc4_suspended_cfg,
},
},
};
#endif
#ifdef CONFIG_MMC_MSM_SDC3_SUPPORT
static struct gpiomux_setting apq8064_sdc3_card_det_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_UP,
};
static struct msm_gpiomux_config apq8064_sdc3_configs[] __initdata = {
{
.gpio = 26,
.settings = {
[GPIOMUX_SUSPENDED] = &apq8064_sdc3_card_det_cfg,
[GPIOMUX_ACTIVE] = &apq8064_sdc3_card_det_cfg,
},
},
};
#endif
#ifdef CONFIG_MACH_ASUSTEK
static struct gpiomux_setting gpio_keys_active_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_UP,
};
static struct gpiomux_setting gpio_keys_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_UP,
};
static struct msm_gpiomux_config asustek_pwr_keys_configs[] __initdata = {
{ .gpio = 26,
.settings = {
[GPIOMUX_ACTIVE] = &gpio_keys_active_cfg,
[GPIOMUX_SUSPENDED] = &gpio_keys_suspended_cfg,
},
},
};
static struct msm_gpiomux_config asustek_gpio_keys_configs[] __initdata = {
{ .gpio = 15,
.settings = {
[GPIOMUX_ACTIVE] = &gpio_keys_active_cfg,
[GPIOMUX_SUSPENDED] = &gpio_keys_suspended_cfg,
},
},
{
.gpio = 36,
.settings = {
[GPIOMUX_ACTIVE] = &gpio_keys_active_cfg,
[GPIOMUX_SUSPENDED] = &gpio_keys_suspended_cfg,
},
},
};
static struct gpiomux_setting pcbid_pins_active_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting pcbid_pins_suspended_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct msm_gpiomux_config asustek_pcbid_pins_configs[] __initdata = {
{
.gpio = 57,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 59,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 12,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 1,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 14,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 53,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 51,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 28,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 86,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 37,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 13,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
{
.gpio = 2,
.settings = {
[GPIOMUX_ACTIVE] = &pcbid_pins_active_cfg,
[GPIOMUX_SUSPENDED] = &pcbid_pins_suspended_cfg,
},
},
};
#endif
static struct gpiomux_setting ts_init_config = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
.dir = GPIOMUX_IN,
};
static struct gpiomux_setting ts_reset_config = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
//add touch gpio
static struct msm_gpiomux_config msm8064_ts_gpio_config[] __initdata = {
{
.gpio = 6, /* tp IRQ*/
.settings = {
[GPIOMUX_SUSPENDED] = &ts_init_config,
[GPIOMUX_ACTIVE]= &ts_init_config,
},
},
{
.gpio = 31, /* tp reset*/
.settings = {
[GPIOMUX_SUSPENDED] = &ts_reset_config,
[GPIOMUX_ACTIVE]= &ts_reset_config,
},
},
};
static struct gpiomux_setting nfc_bcm2079x_irq_cfg = { // NFC_IRQ
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_DOWN,
.dir = GPIOMUX_IN,
};
static struct msm_gpiomux_config apq8064_bcm2079x_nfc_configs[] __initdata = {
{
.gpio = 32,
.settings = {
[GPIOMUX_SUSPENDED] = &nfc_bcm2079x_irq_cfg,
},
},
};
static struct gpiomux_setting sp_clk_config = {
.func = GPIOMUX_FUNC_2,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting sp_gpio_config = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_NONE,
.dir = GPIOMUX_IN,
};
//add slimport gpio
static struct msm_gpiomux_config msm8064_sp_gpio_config[] __initdata = {
{
.gpio = 7, /* SP_CBL_DET */
.settings = {
[GPIOMUX_SUSPENDED] = &sp_gpio_config,
[GPIOMUX_ACTIVE]= &sp_gpio_config,
},
},
{
.gpio = 44, /* SP_INT */
.settings = {
[GPIOMUX_SUSPENDED] = &sp_gpio_config,
[GPIOMUX_ACTIVE]= &sp_gpio_config,
},
},
{
.gpio = 50, /* slimport 27M clock */
.settings = {
[GPIOMUX_SUSPENDED] = &sp_clk_config,
[GPIOMUX_ACTIVE]= &sp_clk_config,
},
},
{
.gpio = 77, /* APQ_USB_ID */
.settings = {
[GPIOMUX_SUSPENDED] = &sp_gpio_config,
[GPIOMUX_ACTIVE]= &sp_gpio_config,
}
},
};
static struct gpiomux_setting gsbi4_suspended = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_KEEPER,
};
static struct gpiomux_setting gsbi4_sda_active = {
.func = GPIOMUX_FUNC_9,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct gpiomux_setting gsbi4_scl_active = {
.func = GPIOMUX_FUNC_A,
.drv = GPIOMUX_DRV_8MA,
.pull = GPIOMUX_PULL_NONE,
};
static struct msm_gpiomux_config asustek_gsbi4_configs[] __initdata = {
{
.gpio = 10, /* GSBI4 I2C SDA */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi4_suspended,
[GPIOMUX_ACTIVE] = &gsbi4_sda_active,
},
},
{
.gpio = 11, /* GSBI4 I2C SCL */
.settings = {
[GPIOMUX_SUSPENDED] = &gsbi4_suspended,
[GPIOMUX_ACTIVE] = &gsbi4_scl_active,
},
},
};
static struct gpiomux_setting gpio_bat_low_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.pull = GPIOMUX_PULL_NONE,
};
static struct msm_gpiomux_config gpio_bat_low_configs[] __initdata = {
{
.gpio = 29,
.settings = {
[GPIOMUX_ACTIVE] = &gpio_bat_low_cfg,
[GPIOMUX_SUSPENDED] = &gpio_bat_low_cfg,
},
},
};
#ifdef CONFIG_INPUT_LID
static struct gpiomux_setting asustek_hall_sensor_cfg = {
.func = GPIOMUX_FUNC_GPIO,
.drv = GPIOMUX_DRV_2MA,
.pull = GPIOMUX_PULL_UP,
};
static struct msm_gpiomux_config asustek_hall_sensor_configs[] __initdata = {
{
.gpio = 36,
.settings = {
[GPIOMUX_SUSPENDED] = &asustek_hall_sensor_cfg,
[GPIOMUX_ACTIVE] = &asustek_hall_sensor_cfg,
},
},
};
#endif
void __init apq8064_init_gpiomux(void)
{
int rc;
int platform_version = socinfo_get_platform_version();
#ifdef CONFIG_MACH_ASUSTEK
hw_rev revision = HW_REV_INVALID;
revision = asustek_get_hw_rev();
#endif
rc = msm_gpiomux_init(NR_GPIO_IRQS);
if (rc) {
pr_err(KERN_ERR "msm_gpiomux_init failed %d\n", rc);
return;
}
msm_gpiomux_install(msm8960_mdp_vsync_configs,
ARRAY_SIZE(msm8960_mdp_vsync_configs));
msm_gpiomux_install(wcnss_5wire_interface,
ARRAY_SIZE(wcnss_5wire_interface));
if (machine_is_mpq8064_cdp() || machine_is_mpq8064_hrd() ||
machine_is_mpq8064_dtv()) {
msm_gpiomux_install(mpq8064_gsbi5_i2c_configs,
ARRAY_SIZE(mpq8064_gsbi5_i2c_configs));
#ifdef CONFIG_MSM_VCAP
msm_gpiomux_install(vcap_configs,
ARRAY_SIZE(vcap_configs));
#endif
msm_gpiomux_install(sx150x_int_configs,
ARRAY_SIZE(sx150x_int_configs));
} else {
#if defined(CONFIG_KS8851) || defined(CONFIG_KS8851_MODULE)
msm_gpiomux_install(apq8064_ethernet_configs,
ARRAY_SIZE(apq8064_ethernet_configs));
#endif
msm_gpiomux_install(apq8064_gsbi_configs,
ARRAY_SIZE(apq8064_gsbi_configs));
}
#ifdef CONFIG_MACH_ASUSTEK
if (machine_is_apq8064_flo() || machine_is_apq8064_deb()) {
msm_gpiomux_install(asustek_pcbid_pins_configs,
ARRAY_SIZE(asustek_pcbid_pins_configs));
if (revision == HW_REV_B) {
msm_gpiomux_install(asustek_gpio_keys_configs,
ARRAY_SIZE(asustek_gpio_keys_configs));
}
msm_gpiomux_install(asustek_pwr_keys_configs,
ARRAY_SIZE(asustek_pwr_keys_configs));
}
#endif
msm_gpiomux_install(gpio_bat_low_configs,
ARRAY_SIZE(gpio_bat_low_configs));
msm_gpiomux_install(apq8064_slimbus_config,
ARRAY_SIZE(apq8064_slimbus_config));
msm_gpiomux_install(apq8064_audio_codec_configs,
ARRAY_SIZE(apq8064_audio_codec_configs));
if (machine_is_mpq8064_cdp() || machine_is_mpq8064_hrd() ||
machine_is_mpq8064_dtv()) {
msm_gpiomux_install(mpq8064_spkr_i2s_config,
ARRAY_SIZE(mpq8064_spkr_i2s_config));
}
pr_debug("%s(): audio-auxpcm: Include GPIO configs"
" as audio is not the primary user"
" for these GPIO Pins\n", __func__);
if (machine_is_mpq8064_cdp() || machine_is_mpq8064_hrd() ||
machine_is_mpq8064_dtv())
msm_gpiomux_install(mpq8064_mi2s_configs,
ARRAY_SIZE(mpq8064_mi2s_configs));
/*
msm_gpiomux_install(apq8064_ext_regulator_configs,
ARRAY_SIZE(apq8064_ext_regulator_configs));
*/
if (machine_is_apq8064_flo() || machine_is_apq8064_deb()) {
if (SOCINFO_VERSION_MINOR(platform_version) == 1)
msm_gpiomux_install(mdm_i2s_configs,
ARRAY_SIZE(mdm_i2s_configs));
else
msm_gpiomux_install(mdm_configs,
ARRAY_SIZE(mdm_configs));
}
if (machine_is_apq8064_flo() || machine_is_apq8064_deb()) {
if (SOCINFO_VERSION_MINOR(platform_version) == 1) {
msm_gpiomux_install(cyts_gpio_alt_config,
ARRAY_SIZE(cyts_gpio_alt_config));
} else {
msm_gpiomux_install(cyts_gpio_configs,
ARRAY_SIZE(cyts_gpio_configs));
}
}
#ifdef CONFIG_USB_EHCI_MSM_HSIC
if (machine_is_apq8064_flo() || machine_is_apq8064_deb())
msm_gpiomux_install(apq8064_hsic_configs,
ARRAY_SIZE(apq8064_hsic_configs));
#endif
if (machine_is_apq8064_cdp() || machine_is_apq8064_liquid())
msm_gpiomux_install(apq8064_mxt_configs,
ARRAY_SIZE(apq8064_mxt_configs));
msm_gpiomux_install(apq8064_hdmi_configs,
ARRAY_SIZE(apq8064_hdmi_configs));
if (machine_is_mpq8064_cdp())
msm_gpiomux_install(mpq8064_ir_configs,
ARRAY_SIZE(mpq8064_ir_configs));
#ifdef CONFIG_MMC_MSM_SDC2_SUPPORT
msm_gpiomux_install(apq8064_sdc2_configs,
ARRAY_SIZE(apq8064_sdc2_configs));
#endif
#ifdef CONFIG_MMC_MSM_SDC4_SUPPORT
msm_gpiomux_install(apq8064_sdc4_configs,
ARRAY_SIZE(apq8064_sdc4_configs));
#endif
#ifdef CONFIG_MMC_MSM_SDC3_SUPPORT
msm_gpiomux_install(apq8064_sdc3_configs,
ARRAY_SIZE(apq8064_sdc3_configs));
#endif
//add touch
msm_gpiomux_install(msm8064_ts_gpio_config,
ARRAY_SIZE(msm8064_ts_gpio_config));
msm_gpiomux_install(smb345_pin_configs,
ARRAY_SIZE(smb345_pin_configs));
switch (revision) {
case HW_REV_B:
case HW_REV_C:
case HW_REV_D:
case HW_REV_E:
msm_gpiomux_install(wpc_pok_configs,
ARRAY_SIZE(wpc_pok_configs));
break;
default:
break;
}
if (machine_is_apq8064_flo() || machine_is_apq8064_deb())
msm_gpiomux_install(apq8064_bcm2079x_nfc_configs,
ARRAY_SIZE(apq8064_bcm2079x_nfc_configs));
#ifdef CONFIG_SLIMPORT_ANX7808
msm_gpiomux_install(msm8064_sp_gpio_config,
ARRAY_SIZE(msm8064_sp_gpio_config));
#endif
msm_gpiomux_install(apq8064_headphone_configs,
ARRAY_SIZE(apq8064_headphone_configs));
msm_gpiomux_install(asustek_gsbi4_configs,
ARRAY_SIZE(asustek_gsbi4_configs));
#ifdef CONFIG_INPUT_LID
if (machine_is_apq8064_flo() || machine_is_apq8064_deb()) {
if ((revision == HW_REV_C) || (revision == HW_REV_D) || (revision == HW_REV_E)) {
msm_gpiomux_install(asustek_hall_sensor_configs,
ARRAY_SIZE(asustek_hall_sensor_configs));
}
}
#endif
}