summaryrefslogtreecommitdiff
path: root/arch/arm/mach-mx6
diff options
context:
space:
mode:
authorGary Zhang <b13634@freescale.com>2012-02-28 14:50:07 +0800
committerGary Zhang <b13634@freescale.com>2012-02-28 14:50:07 +0800
commit1e79126ffdc9f225356f5b9962c10162e889fb3c (patch)
tree3c51ed6081c423e1028befef0f1952b6d96506f0 /arch/arm/mach-mx6
parente58051f5edac2d636b3e0b33a5a328ec75d7349f (diff)
ENGR00175219-2 MX6Q_SABRESD: add wm8958 support
add wm8958 codec support Signed-off-by: Gary Zhang <b13634@freescale.com>
Diffstat (limited to 'arch/arm/mach-mx6')
-rw-r--r--arch/arm/mach-mx6/board-mx6q_sabresd.c178
1 files changed, 61 insertions, 117 deletions
diff --git a/arch/arm/mach-mx6/board-mx6q_sabresd.c b/arch/arm/mach-mx6/board-mx6q_sabresd.c
index 3d351d6045e6..8ffcba5ef9f1 100644
--- a/arch/arm/mach-mx6/board-mx6q_sabresd.c
+++ b/arch/arm/mach-mx6/board-mx6q_sabresd.c
@@ -51,6 +51,8 @@
#include <linux/regulator/consumer.h>
#include <linux/regulator/machine.h>
#include <linux/regulator/fixed.h>
+#include <linux/mfd/wm8994/pdata.h>
+#include <linux/mfd/wm8994/gpio.h>
#include <mach/common.h>
#include <mach/hardware.h>
@@ -105,6 +107,8 @@
#define MX6Q_SABRESD_CHARGE_CHG_2_B IMX_GPIO_NR(3, 13)
#define MX6Q_SABRESD_CHARGE_UOK_B IMX_GPIO_NR(1, 27)
#define MX6Q_SABRESD_CHARGE_DOK_B IMX_GPIO_NR(2, 24)
+#define MX6Q_SABRESD_WM8958_4V2_EN IMX_GPIO_NR(4, 10)
+#define MX6Q_SABRESD_WM8958_HP_DET IMX_GPIO_NR(7, 8)
#define MX6Q_SABRESD_GPS_EN IMX_GPIO_NR(3, 0)
#define MX6Q_SABRESD_AUX_3V15_EN IMX_GPIO_NR(6, 9)
@@ -122,14 +126,14 @@ extern int __init mx6q_sabresd_init_pfuze100(u32 int_gpio);
static iomux_v3_cfg_t mx6q_sabresd_pads[] = {
/* AUDMUX */
- MX6Q_PAD_SD2_DAT0__AUDMUX_AUD4_RXD,
- MX6Q_PAD_SD2_DAT3__AUDMUX_AUD4_TXC,
- MX6Q_PAD_SD2_DAT2__AUDMUX_AUD4_TXD,
- MX6Q_PAD_SD2_DAT1__AUDMUX_AUD4_TXFS,
+ MX6Q_PAD_CSI0_DAT4__AUDMUX_AUD3_TXC,
+ MX6Q_PAD_CSI0_DAT5__AUDMUX_AUD3_TXD,
+ MX6Q_PAD_CSI0_DAT6__AUDMUX_AUD3_TXFS,
+ MX6Q_PAD_CSI0_DAT7__AUDMUX_AUD3_RXD,
/* CAN1 */
MX6Q_PAD_KEY_ROW2__CAN1_RXCAN,
- MX6Q_PAD_KEY_COL2__CAN1_TXCAN,
+ /* MX6Q_PAD_KEY_COL2__CAN1_TXCAN, */
MX6Q_PAD_GPIO_2__GPIO_1_2, /* STNDBY */
MX6Q_PAD_GPIO_7__GPIO_1_7, /* NERR */
@@ -219,7 +223,7 @@ static iomux_v3_cfg_t mx6q_sabresd_pads[] = {
/* GPIO7 */
MX6Q_PAD_GPIO_17__GPIO_7_12, /* USB Hub Reset */
- /* I2C1, SGTL5000 */
+ /* I2C1, WM8958 */
MX6Q_PAD_CSI0_DAT8__I2C1_SDA,
MX6Q_PAD_CSI0_DAT9__I2C1_SCL,
@@ -336,6 +340,10 @@ static iomux_v3_cfg_t mx6q_sabresd_pads[] = {
MX6Q_PAD_ENET_RXD0__GPIO_1_27, /* UOK_B */
MX6Q_PAD_EIM_CS1__GPIO_2_24, /* DOK_B */
+ /* WM8958 */
+ MX6Q_PAD_KEY_COL2__GPIO_4_10, /* CODEC_PWR_EN */
+ MX6Q_PAD_SD3_RST__GPIO_7_8, /* HEADPHONE_DET */
+
/*GPS AUX_3V15_EN*/
MX6Q_PAD_NANDF_WP_B__GPIO_6_9,
};
@@ -473,11 +481,38 @@ static void spi_device_init(void)
ARRAY_SIZE(imx6_sabresd_spi_nor_device));
}
-static struct mxc_audio_platform_data mx6_sabresd_audio_data;
+static struct imx_ssi_platform_data mx6_sabresd_ssi_pdata = {
+ .flags = IMX_SSI_DMA | IMX_SSI_SYN,
+};
+
+static struct platform_device mx6_sabresd_audio_device = {
+ .name = "imx-wm8958",
+};
-static int mx6_sabresd_sgtl5000_init(void)
+static struct mxc_audio_platform_data wm8958_data = {
+ .ssi_num = 1,
+ .src_port = 2,
+ .ext_port = 3,
+ .hp_gpio = -1,
+};
+
+static struct wm8994_pdata wm8958_pdata = {
+ .gpio_defaults = {
+ [0] = WM8994_GP_FN_GPIO | WM8994_GPN_DB,
+ [1] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [2] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [3] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [4] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [5] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [7] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [8] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [9] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ [10] = WM8994_GP_FN_GPIO | WM8994_GPN_DB | WM8994_GPN_PD,
+ },
+};
+
+static int mxc_wm8958_init(void)
{
-/*
struct clk *clko;
struct clk *new_parent;
int rate;
@@ -487,40 +522,30 @@ static int mx6_sabresd_sgtl5000_init(void)
pr_err("can't get CLKO clock.\n");
return PTR_ERR(clko);
}
- new_parent = clk_get(NULL, "ahb");
+ new_parent = clk_get(NULL, "ipg_perclk");
if (!IS_ERR(new_parent)) {
clk_set_parent(clko, new_parent);
clk_put(new_parent);
}
- rate = clk_round_rate(clko, 16000000);
- if (rate < 8000000 || rate > 27000000) {
- pr_err("Error:SGTL5000 mclk freq %d out of range!\n", rate);
+ rate = clk_round_rate(clko, 8250000);
+ if (rate < 4000000 || rate > 12500000) {
+ pr_err("Error:WM8958 mclk1 freq %d out of range!\n", rate);
clk_put(clko);
return -1;
}
- mx6_sabresd_audio_data.sysclk = rate;
+ wm8958_data.sysclk = rate;
clk_set_rate(clko, rate);
clk_enable(clko);
-*/
- return 0;
-}
-static struct imx_ssi_platform_data mx6_sabresd_ssi_pdata = {
- .flags = IMX_SSI_DMA | IMX_SSI_SYN,
-};
-
-static struct mxc_audio_platform_data mx6_sabresd_audio_data = {
- .ssi_num = 1,
- .src_port = 2,
- .ext_port = 4,
- .init = mx6_sabresd_sgtl5000_init,
- .hp_gpio = -1,
-};
+ /* enable wm8958 4.2v power supply */
+ gpio_request(MX6Q_SABRESD_WM8958_4V2_EN, "aud_4v2");
+ gpio_direction_output(MX6Q_SABRESD_WM8958_4V2_EN, 1);
+ msleep(1);
+ gpio_set_value(MX6Q_SABRESD_WM8958_4V2_EN, 1);
-static struct platform_device mx6_sabresd_audio_device = {
- .name = "imx-sgtl5000",
-};
+ return 0;
+}
static void mx6q_csi0_cam_powerdown(int powerdown)
{
@@ -610,7 +635,8 @@ static struct fsl_mxc_lightsensor_platform_data ls_data = {
static struct i2c_board_info mxc_i2c0_board_info[] __initdata = {
{
- I2C_BOARD_INFO("sgtl5000", 0x0a),
+ I2C_BOARD_INFO("wm8958", 0x1a),
+ .platform_data = &wm8958_pdata,
},
{
I2C_BOARD_INFO("ov5642", 0x3c),
@@ -926,95 +952,13 @@ static struct platform_device sabresd_vmmc_reg_devices = {
},
};
-#ifdef CONFIG_SND_SOC_SGTL5000
-
-static struct regulator_consumer_supply sgtl5000_sabresd_consumer_vdda = {
- .supply = "VDDA",
- .dev_name = "0-000a",
-};
-
-static struct regulator_consumer_supply sgtl5000_sabresd_consumer_vddio = {
- .supply = "VDDIO",
- .dev_name = "0-000a",
-};
-
-static struct regulator_consumer_supply sgtl5000_sabresd_consumer_vddd = {
- .supply = "VDDD",
- .dev_name = "0-000a",
-};
-
-static struct regulator_init_data sgtl5000_sabresd_vdda_reg_initdata = {
- .num_consumer_supplies = 1,
- .consumer_supplies = &sgtl5000_sabresd_consumer_vdda,
-};
-
-static struct regulator_init_data sgtl5000_sabresd_vddio_reg_initdata = {
- .num_consumer_supplies = 1,
- .consumer_supplies = &sgtl5000_sabresd_consumer_vddio,
-};
-
-static struct regulator_init_data sgtl5000_sabresd_vddd_reg_initdata = {
- .num_consumer_supplies = 1,
- .consumer_supplies = &sgtl5000_sabresd_consumer_vddd,
-};
-
-static struct fixed_voltage_config sgtl5000_sabresd_vdda_reg_config = {
- .supply_name = "VDDA",
- .microvolts = 2500000,
- .gpio = -1,
- .init_data = &sgtl5000_sabresd_vdda_reg_initdata,
-};
-
-static struct fixed_voltage_config sgtl5000_sabresd_vddio_reg_config = {
- .supply_name = "VDDIO",
- .microvolts = 3300000,
- .gpio = -1,
- .init_data = &sgtl5000_sabresd_vddio_reg_initdata,
-};
-
-static struct fixed_voltage_config sgtl5000_sabresd_vddd_reg_config = {
- .supply_name = "VDDD",
- .microvolts = 0,
- .gpio = -1,
- .init_data = &sgtl5000_sabresd_vddd_reg_initdata,
-};
-
-static struct platform_device sgtl5000_sabresd_vdda_reg_devices = {
- .name = "reg-fixed-voltage",
- .id = 0,
- .dev = {
- .platform_data = &sgtl5000_sabresd_vdda_reg_config,
- },
-};
-
-static struct platform_device sgtl5000_sabresd_vddio_reg_devices = {
- .name = "reg-fixed-voltage",
- .id = 1,
- .dev = {
- .platform_data = &sgtl5000_sabresd_vddio_reg_config,
- },
-};
-
-static struct platform_device sgtl5000_sabresd_vddd_reg_devices = {
- .name = "reg-fixed-voltage",
- .id = 2,
- .dev = {
- .platform_data = &sgtl5000_sabresd_vddd_reg_config,
- },
-};
-
-#endif /* CONFIG_SND_SOC_SGTL5000 */
-
static int imx6q_init_audio(void)
{
mxc_register_device(&mx6_sabresd_audio_device,
- &mx6_sabresd_audio_data);
+ &wm8958_data);
imx6q_add_imx_ssi(1, &mx6_sabresd_ssi_pdata);
-#ifdef CONFIG_SND_SOC_SGTL5000
- platform_device_register(&sgtl5000_sabresd_vdda_reg_devices);
- platform_device_register(&sgtl5000_sabresd_vddio_reg_devices);
- platform_device_register(&sgtl5000_sabresd_vddd_reg_devices);
-#endif
+
+ mxc_wm8958_init();
return 0;
}