| /* Copyright (c) 2010-2011, 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/kernel.h> |
| #include <linux/platform_device.h> |
| #include <linux/gpio.h> |
| #include <linux/delay.h> |
| #include <linux/debugfs.h> |
| #include <linux/mfd/pmic8058.h> |
| #include <linux/pmic8058-othc.h> |
| #include <linux/mfd/pmic8901.h> |
| #include <linux/mfd/msm-adie-codec.h> |
| #include <linux/regulator/pmic8058-regulator.h> |
| #include <linux/regulator/pmic8901-regulator.h> |
| #include <linux/regulator/consumer.h> |
| #include <linux/regulator/machine.h> |
| |
| #include <mach/qdsp6v2/audio_dev_ctl.h> |
| #include <mach/mpp.h> |
| #include <sound/apr_audio.h> |
| #include <asm/mach-types.h> |
| #include <asm/uaccess.h> |
| |
| #include "snddev_icodec.h" |
| #include "snddev_ecodec.h" |
| #include "timpani_profile_8x60.h" |
| #include "snddev_hdmi.h" |
| #include "snddev_mi2s.h" |
| #include "snddev_virtual.h" |
| |
| #ifdef CONFIG_DEBUG_FS |
| static struct dentry *debugfs_hsed_config; |
| static void snddev_hsed_config_modify_setting(int type); |
| static void snddev_hsed_config_restore_setting(void); |
| #endif |
| |
| /* GPIO_CLASS_D0_EN */ |
| #define SNDDEV_GPIO_CLASS_D0_EN 227 |
| |
| /* GPIO_CLASS_D1_EN */ |
| #define SNDDEV_GPIO_CLASS_D1_EN 229 |
| |
| #define SNDDEV_GPIO_MIC2_ANCR_SEL 294 |
| #define SNDDEV_GPIO_MIC1_ANCL_SEL 295 |
| #define SNDDEV_GPIO_HS_MIC4_SEL 296 |
| |
| #define DSP_RAM_BASE_8x60 0x46700000 |
| #define DSP_RAM_SIZE_8x60 0x2000000 |
| static int dspcrashd_pdata_8x60 = 0xDEADDEAD; |
| |
| static struct resource resources_dspcrashd_8x60[] = { |
| { |
| .name = "msm_dspcrashd", |
| .start = DSP_RAM_BASE_8x60, |
| .end = DSP_RAM_BASE_8x60 + DSP_RAM_SIZE_8x60, |
| .flags = IORESOURCE_DMA, |
| }, |
| }; |
| |
| struct platform_device msm_device_dspcrashd_8x60 = { |
| .name = "msm_dspcrashd", |
| .num_resources = ARRAY_SIZE(resources_dspcrashd_8x60), |
| .resource = resources_dspcrashd_8x60, |
| .dev = { .platform_data = &dspcrashd_pdata_8x60 }, |
| }; |
| |
| static struct resource msm_cdcclk_ctl_resources[] = { |
| { |
| .name = "msm_snddev_tx_mclk", |
| .start = 108, |
| .end = 108, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "msm_snddev_rx_mclk", |
| .start = 109, |
| .end = 109, |
| .flags = IORESOURCE_IO, |
| }, |
| }; |
| |
| static struct platform_device msm_cdcclk_ctl_device = { |
| .name = "msm_cdcclk_ctl", |
| .num_resources = ARRAY_SIZE(msm_cdcclk_ctl_resources), |
| .resource = msm_cdcclk_ctl_resources, |
| }; |
| |
| static struct resource msm_aux_pcm_resources[] = { |
| |
| { |
| .name = "aux_pcm_dout", |
| .start = 111, |
| .end = 111, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "aux_pcm_din", |
| .start = 112, |
| .end = 112, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "aux_pcm_syncout", |
| .start = 113, |
| .end = 113, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "aux_pcm_clkin_a", |
| .start = 114, |
| .end = 114, |
| .flags = IORESOURCE_IO, |
| }, |
| }; |
| |
| static struct platform_device msm_aux_pcm_device = { |
| .name = "msm_aux_pcm", |
| .num_resources = ARRAY_SIZE(msm_aux_pcm_resources), |
| .resource = msm_aux_pcm_resources, |
| }; |
| |
| static struct resource msm_mi2s_gpio_resources[] = { |
| |
| { |
| .name = "mi2s_ws", |
| .start = 101, |
| .end = 101, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "mi2s_sclk", |
| .start = 102, |
| .end = 102, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "mi2s_mclk", |
| .start = 103, |
| .end = 103, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "fm_mi2s_sd", |
| .start = 107, |
| .end = 107, |
| .flags = IORESOURCE_IO, |
| }, |
| }; |
| |
| static struct platform_device msm_mi2s_device = { |
| .name = "msm_mi2s", |
| .num_resources = ARRAY_SIZE(msm_mi2s_gpio_resources), |
| .resource = msm_mi2s_gpio_resources, |
| }; |
| |
| /* Must be same size as msm_icodec_gpio_resources */ |
| static int msm_icodec_gpio_defaults[] = { |
| 0, |
| 0, |
| }; |
| |
| static struct resource msm_icodec_gpio_resources[] = { |
| { |
| .name = "msm_icodec_speaker_left", |
| .start = SNDDEV_GPIO_CLASS_D0_EN, |
| .end = SNDDEV_GPIO_CLASS_D0_EN, |
| .flags = IORESOURCE_IO, |
| }, |
| { |
| .name = "msm_icodec_speaker_right", |
| .start = SNDDEV_GPIO_CLASS_D1_EN, |
| .end = SNDDEV_GPIO_CLASS_D1_EN, |
| .flags = IORESOURCE_IO, |
| }, |
| }; |
| |
| static struct platform_device msm_icodec_gpio_device = { |
| .name = "msm_icodec_gpio", |
| .num_resources = ARRAY_SIZE(msm_icodec_gpio_resources), |
| .resource = msm_icodec_gpio_resources, |
| .dev = { .platform_data = &msm_icodec_gpio_defaults }, |
| }; |
| |
| static struct regulator *s3; |
| static struct regulator *mvs; |
| |
| static int msm_snddev_enable_dmic_power(void) |
| { |
| int ret; |
| |
| s3 = regulator_get(NULL, "8058_s3"); |
| if (IS_ERR(s3)) { |
| ret = -EBUSY; |
| goto fail_get_s3; |
| } |
| |
| ret = regulator_set_voltage(s3, 1800000, 1800000); |
| if (ret) { |
| pr_err("%s: error setting voltage\n", __func__); |
| goto fail_s3; |
| } |
| |
| ret = regulator_enable(s3); |
| if (ret) { |
| pr_err("%s: error enabling regulator\n", __func__); |
| goto fail_s3; |
| } |
| |
| mvs = regulator_get(NULL, "8901_mvs0"); |
| if (IS_ERR(mvs)) |
| goto fail_mvs0_get; |
| |
| ret = regulator_enable(mvs); |
| if (ret) { |
| pr_err("%s: error setting regulator\n", __func__); |
| goto fail_mvs0_enable; |
| } |
| return ret; |
| |
| fail_mvs0_enable: |
| regulator_put(mvs); |
| mvs = NULL; |
| fail_mvs0_get: |
| regulator_disable(s3); |
| fail_s3: |
| regulator_put(s3); |
| s3 = NULL; |
| fail_get_s3: |
| return ret; |
| } |
| |
| static void msm_snddev_disable_dmic_power(void) |
| { |
| int ret; |
| |
| if (mvs) { |
| ret = regulator_disable(mvs); |
| if (ret < 0) |
| pr_err("%s: error disabling vreg mvs\n", __func__); |
| regulator_put(mvs); |
| mvs = NULL; |
| } |
| |
| if (s3) { |
| ret = regulator_disable(s3); |
| if (ret < 0) |
| pr_err("%s: error disabling regulator s3\n", __func__); |
| regulator_put(s3); |
| s3 = NULL; |
| } |
| } |
| |
| #define PM8901_MPP_3 (2) /* PM8901 MPP starts from 0 */ |
| |
| static int config_class_d0_gpio(int enable) |
| { |
| int rc; |
| |
| if (enable) { |
| rc = pm8901_mpp_config_digital_out(PM8901_MPP_3, |
| PM8901_MPP_DIG_LEVEL_MSMIO, 1); |
| |
| if (rc) { |
| pr_err("%s: CLASS_D0_EN failed\n", __func__); |
| return rc; |
| } |
| |
| rc = gpio_request(SNDDEV_GPIO_CLASS_D0_EN, "CLASSD0_EN"); |
| |
| if (rc) { |
| pr_err("%s: spkr pamp gpio pm8901 mpp3 request" |
| "failed\n", __func__); |
| pm8901_mpp_config_digital_out(PM8901_MPP_3, |
| PM8901_MPP_DIG_LEVEL_MSMIO, 0); |
| return rc; |
| } |
| |
| gpio_direction_output(SNDDEV_GPIO_CLASS_D0_EN, 1); |
| gpio_set_value(SNDDEV_GPIO_CLASS_D0_EN, 1); |
| |
| } else { |
| pm8901_mpp_config_digital_out(PM8901_MPP_3, |
| PM8901_MPP_DIG_LEVEL_MSMIO, 0); |
| gpio_set_value(SNDDEV_GPIO_CLASS_D0_EN, 0); |
| gpio_free(SNDDEV_GPIO_CLASS_D0_EN); |
| } |
| return 0; |
| } |
| |
| static int config_class_d1_gpio(int enable) |
| { |
| int rc; |
| |
| if (enable) { |
| rc = gpio_request(SNDDEV_GPIO_CLASS_D1_EN, "CLASSD1_EN"); |
| |
| if (rc) { |
| pr_err("%s: Right Channel spkr gpio request" |
| " failed\n", __func__); |
| return rc; |
| } |
| |
| gpio_direction_output(SNDDEV_GPIO_CLASS_D1_EN, 1); |
| gpio_set_value(SNDDEV_GPIO_CLASS_D1_EN, 1); |
| |
| } else { |
| gpio_set_value(SNDDEV_GPIO_CLASS_D1_EN, 0); |
| gpio_free(SNDDEV_GPIO_CLASS_D1_EN); |
| } |
| return 0; |
| } |
| |
| static atomic_t pamp_ref_cnt; |
| |
| static int msm_snddev_poweramp_on(void) |
| { |
| int rc; |
| |
| if (atomic_inc_return(&pamp_ref_cnt) > 1) |
| return 0; |
| |
| pr_debug("%s: enable stereo spkr amp\n", __func__); |
| rc = config_class_d0_gpio(1); |
| if (rc) { |
| pr_err("%s: d0 gpio configuration failed\n", __func__); |
| goto config_gpio_fail; |
| } |
| rc = config_class_d1_gpio(1); |
| if (rc) { |
| pr_err("%s: d1 gpio configuration failed\n", __func__); |
| goto config_gpio_fail; |
| } |
| config_gpio_fail: |
| return rc; |
| } |
| |
| static void msm_snddev_poweramp_off(void) |
| { |
| if (atomic_dec_return(&pamp_ref_cnt) == 0) { |
| pr_debug("%s: disable stereo spkr amp\n", __func__); |
| config_class_d0_gpio(0); |
| config_class_d1_gpio(0); |
| msleep(30); |
| } |
| } |
| |
| /* Regulator 8058_l10 supplies regulator 8058_ncp. */ |
| static struct regulator *snddev_reg_ncp; |
| static struct regulator *snddev_reg_l10; |
| |
| static atomic_t preg_ref_cnt; |
| |
| static int msm_snddev_voltage_on(void) |
| { |
| int rc; |
| pr_debug("%s\n", __func__); |
| |
| if (atomic_inc_return(&preg_ref_cnt) > 1) |
| return 0; |
| |
| snddev_reg_l10 = regulator_get(NULL, "8058_l10"); |
| if (IS_ERR(snddev_reg_l10)) { |
| pr_err("%s: regulator_get(%s) failed (%ld)\n", __func__, |
| "l10", PTR_ERR(snddev_reg_l10)); |
| return -EBUSY; |
| } |
| |
| rc = regulator_set_voltage(snddev_reg_l10, 2600000, 2600000); |
| if (rc < 0) |
| pr_err("%s: regulator_set_voltage(l10) failed (%d)\n", |
| __func__, rc); |
| |
| rc = regulator_enable(snddev_reg_l10); |
| if (rc < 0) |
| pr_err("%s: regulator_enable(l10) failed (%d)\n", __func__, rc); |
| |
| snddev_reg_ncp = regulator_get(NULL, "8058_ncp"); |
| if (IS_ERR(snddev_reg_ncp)) { |
| pr_err("%s: regulator_get(%s) failed (%ld)\n", __func__, |
| "ncp", PTR_ERR(snddev_reg_ncp)); |
| return -EBUSY; |
| } |
| |
| rc = regulator_set_voltage(snddev_reg_ncp, 1800000, 1800000); |
| if (rc < 0) { |
| pr_err("%s: regulator_set_voltage(ncp) failed (%d)\n", |
| __func__, rc); |
| goto regulator_fail; |
| } |
| |
| rc = regulator_enable(snddev_reg_ncp); |
| if (rc < 0) { |
| pr_err("%s: regulator_enable(ncp) failed (%d)\n", __func__, rc); |
| goto regulator_fail; |
| } |
| |
| return rc; |
| |
| regulator_fail: |
| regulator_put(snddev_reg_ncp); |
| snddev_reg_ncp = NULL; |
| return rc; |
| } |
| |
| static void msm_snddev_voltage_off(void) |
| { |
| int rc; |
| pr_debug("%s\n", __func__); |
| |
| if (!snddev_reg_ncp) |
| goto done; |
| |
| if (atomic_dec_return(&preg_ref_cnt) == 0) { |
| rc = regulator_disable(snddev_reg_ncp); |
| if (rc < 0) |
| pr_err("%s: regulator_disable(ncp) failed (%d)\n", |
| __func__, rc); |
| regulator_put(snddev_reg_ncp); |
| |
| snddev_reg_ncp = NULL; |
| } |
| |
| done: |
| if (!snddev_reg_l10) |
| return; |
| |
| rc = regulator_disable(snddev_reg_l10); |
| if (rc < 0) |
| pr_err("%s: regulator_disable(l10) failed (%d)\n", |
| __func__, rc); |
| |
| regulator_put(snddev_reg_l10); |
| |
| snddev_reg_l10 = NULL; |
| } |
| |
| static int msm_snddev_enable_amic_power(void) |
| { |
| int ret = 0; |
| #ifdef CONFIG_PMIC8058_OTHC |
| |
| if (machine_is_msm8x60_fluid()) { |
| |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_0, |
| OTHC_SIGNAL_ALWAYS_ON); |
| if (ret) |
| pr_err("%s: Enabling amic power failed\n", __func__); |
| |
| ret = gpio_request(SNDDEV_GPIO_MIC2_ANCR_SEL, "MIC2_ANCR_SEL"); |
| if (ret) { |
| pr_err("%s: spkr pamp gpio %d request failed\n", |
| __func__, SNDDEV_GPIO_MIC2_ANCR_SEL); |
| return ret; |
| } |
| gpio_direction_output(SNDDEV_GPIO_MIC2_ANCR_SEL, 0); |
| |
| ret = gpio_request(SNDDEV_GPIO_MIC1_ANCL_SEL, "MIC1_ANCL_SEL"); |
| if (ret) { |
| pr_err("%s: mic1 ancl gpio %d request failed\n", |
| __func__, SNDDEV_GPIO_MIC1_ANCL_SEL); |
| gpio_free(SNDDEV_GPIO_MIC2_ANCR_SEL); |
| return ret; |
| } |
| gpio_direction_output(SNDDEV_GPIO_MIC1_ANCL_SEL, 0); |
| |
| } else { |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_2, |
| OTHC_SIGNAL_ALWAYS_ON); |
| if (ret) |
| pr_err("%s: Enabling amic power failed\n", __func__); |
| } |
| #endif |
| return ret; |
| } |
| |
| static void msm_snddev_disable_amic_power(void) |
| { |
| #ifdef CONFIG_PMIC8058_OTHC |
| int ret; |
| if (machine_is_msm8x60_fluid()) { |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_0, |
| OTHC_SIGNAL_OFF); |
| gpio_free(SNDDEV_GPIO_MIC1_ANCL_SEL); |
| gpio_free(SNDDEV_GPIO_MIC2_ANCR_SEL); |
| } else |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_2, OTHC_SIGNAL_OFF); |
| |
| if (ret) |
| pr_err("%s: Disabling amic power failed\n", __func__); |
| #endif |
| } |
| |
| static int msm_snddev_enable_anc_power(void) |
| { |
| int ret = 0; |
| #ifdef CONFIG_PMIC8058_OTHC |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_2, |
| OTHC_SIGNAL_ALWAYS_ON); |
| if (ret) |
| pr_err("%s: Enabling anc micbias 2 failed\n", __func__); |
| |
| if (machine_is_msm8x60_fluid()) { |
| |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_0, |
| OTHC_SIGNAL_ALWAYS_ON); |
| if (ret) |
| pr_err("%s: Enabling anc micbias 0 failed\n", __func__); |
| |
| ret = gpio_request(SNDDEV_GPIO_MIC2_ANCR_SEL, "MIC2_ANCR_SEL"); |
| if (ret) { |
| pr_err("%s: mic2 ancr gpio %d request failed\n", |
| __func__, SNDDEV_GPIO_MIC2_ANCR_SEL); |
| return ret; |
| } |
| gpio_direction_output(SNDDEV_GPIO_MIC2_ANCR_SEL, 1); |
| |
| ret = gpio_request(SNDDEV_GPIO_MIC1_ANCL_SEL, "MIC1_ANCL_SEL"); |
| if (ret) { |
| pr_err("%s: mic1 ancl gpio %d request failed\n", |
| __func__, SNDDEV_GPIO_MIC1_ANCL_SEL); |
| gpio_free(SNDDEV_GPIO_MIC2_ANCR_SEL); |
| return ret; |
| } |
| gpio_direction_output(SNDDEV_GPIO_MIC1_ANCL_SEL, 1); |
| |
| } |
| #endif |
| return ret; |
| } |
| |
| static void msm_snddev_disable_anc_power(void) |
| { |
| #ifdef CONFIG_PMIC8058_OTHC |
| int ret; |
| |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_2, OTHC_SIGNAL_OFF); |
| |
| if (machine_is_msm8x60_fluid()) { |
| ret |= pm8058_micbias_enable(OTHC_MICBIAS_0, |
| OTHC_SIGNAL_OFF); |
| gpio_free(SNDDEV_GPIO_MIC2_ANCR_SEL); |
| gpio_free(SNDDEV_GPIO_MIC1_ANCL_SEL); |
| } |
| |
| if (ret) |
| pr_err("%s: Disabling anc power failed\n", __func__); |
| #endif |
| } |
| |
| static int msm_snddev_enable_amic_sec_power(void) |
| { |
| #ifdef CONFIG_PMIC8058_OTHC |
| int ret; |
| |
| if (machine_is_msm8x60_fluid()) { |
| |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_2, |
| OTHC_SIGNAL_ALWAYS_ON); |
| if (ret) |
| pr_err("%s: Enabling amic2 power failed\n", __func__); |
| |
| ret = gpio_request(SNDDEV_GPIO_HS_MIC4_SEL, |
| "HS_MIC4_SEL"); |
| if (ret) { |
| pr_err("%s: spkr pamp gpio %d request failed\n", |
| __func__, SNDDEV_GPIO_HS_MIC4_SEL); |
| return ret; |
| } |
| gpio_direction_output(SNDDEV_GPIO_HS_MIC4_SEL, 1); |
| } |
| #endif |
| |
| msm_snddev_enable_amic_power(); |
| return 0; |
| } |
| |
| static void msm_snddev_disable_amic_sec_power(void) |
| { |
| #ifdef CONFIG_PMIC8058_OTHC |
| int ret; |
| if (machine_is_msm8x60_fluid()) { |
| |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_2, |
| OTHC_SIGNAL_OFF); |
| if (ret) |
| pr_err("%s: Disabling amic2 power failed\n", __func__); |
| |
| gpio_free(SNDDEV_GPIO_HS_MIC4_SEL); |
| } |
| #endif |
| |
| msm_snddev_disable_amic_power(); |
| } |
| |
| static int msm_snddev_enable_dmic_sec_power(void) |
| { |
| int ret; |
| |
| ret = msm_snddev_enable_dmic_power(); |
| if (ret) { |
| pr_err("%s: Error: Enabling dmic power failed\n", __func__); |
| return ret; |
| } |
| #ifdef CONFIG_PMIC8058_OTHC |
| ret = pm8058_micbias_enable(OTHC_MICBIAS_2, OTHC_SIGNAL_ALWAYS_ON); |
| if (ret) { |
| pr_err("%s: Error: Enabling micbias failed\n", __func__); |
| msm_snddev_disable_dmic_power(); |
| return ret; |
| } |
| #endif |
| return 0; |
| } |
| |
| static void msm_snddev_disable_dmic_sec_power(void) |
| { |
| msm_snddev_disable_dmic_power(); |
| |
| #ifdef CONFIG_PMIC8058_OTHC |
| pm8058_micbias_enable(OTHC_MICBIAS_2, OTHC_SIGNAL_OFF); |
| #endif |
| } |
| |
| static struct adie_codec_action_unit iearpiece_48KHz_osr256_actions[] = |
| EAR_PRI_MONO_8000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry iearpiece_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = iearpiece_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(iearpiece_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile iearpiece_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = iearpiece_settings, |
| .setting_sz = ARRAY_SIZE(iearpiece_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_iearpiece_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE), |
| .name = "handset_rx", |
| .copp_id = 0, |
| .profile = &iearpiece_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| }; |
| |
| static struct platform_device msm_iearpiece_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_iearpiece_data }, |
| }; |
| |
| static struct adie_codec_action_unit imic_48KHz_osr256_actions[] = |
| AMIC_PRI_MONO_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry imic_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = imic_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(imic_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile imic_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = imic_settings, |
| .setting_sz = ARRAY_SIZE(imic_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_imic_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "handset_tx", |
| .copp_id = 1, |
| .profile = &imic_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_power, |
| .pamp_off = msm_snddev_disable_amic_power, |
| }; |
| |
| static struct platform_device msm_imic_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_imic_data }, |
| }; |
| |
| static struct snddev_icodec_data snddev_fluid_ispkr_mic_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "speaker_mono_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &imic_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_power, |
| .pamp_off = msm_snddev_disable_amic_power, |
| }; |
| |
| static struct platform_device msm_fluid_ispkr_mic_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_fluid_ispkr_mic_data }, |
| }; |
| |
| |
| static struct adie_codec_action_unit headset_ab_cpls_48KHz_osr256_actions[] = |
| HEADSET_AB_CPLS_48000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry headset_ab_cpls_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = headset_ab_cpls_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(headset_ab_cpls_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile headset_ab_cpls_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = headset_ab_cpls_settings, |
| .setting_sz = ARRAY_SIZE(headset_ab_cpls_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_ihs_stereo_rx_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE), |
| .name = "headset_stereo_rx", |
| .copp_id = 0, |
| .profile = &headset_ab_cpls_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| }; |
| |
| static struct platform_device msm_headset_stereo_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_ihs_stereo_rx_data }, |
| }; |
| |
| static struct adie_codec_action_unit headset_anc_48KHz_osr256_actions[] = |
| ANC_HEADSET_CPLS_AMIC1_AUXL_RX1_48000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry headset_anc_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = headset_anc_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(headset_anc_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile headset_anc_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = headset_anc_settings, |
| .setting_sz = ARRAY_SIZE(headset_anc_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_anc_headset_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE | SNDDEV_CAP_ANC), |
| .name = "anc_headset_stereo_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &headset_anc_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_anc_power, |
| .pamp_off = msm_snddev_disable_anc_power, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| }; |
| |
| static struct platform_device msm_anc_headset_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_anc_headset_data }, |
| }; |
| |
| static struct adie_codec_action_unit ispkr_stereo_48KHz_osr256_actions[] = |
| SPEAKER_PRI_STEREO_48000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry ispkr_stereo_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ispkr_stereo_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(ispkr_stereo_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile ispkr_stereo_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ispkr_stereo_settings, |
| .setting_sz = ARRAY_SIZE(ispkr_stereo_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_ispkr_stereo_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE), |
| .name = "speaker_stereo_rx", |
| .copp_id = 0, |
| .profile = &ispkr_stereo_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| }; |
| |
| static struct platform_device msm_ispkr_stereo_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_ispkr_stereo_data }, |
| }; |
| |
| static struct adie_codec_action_unit idmic_mono_48KHz_osr256_actions[] = |
| DMIC1_PRI_MONO_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry idmic_mono_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = idmic_mono_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(idmic_mono_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile idmic_mono_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = idmic_mono_settings, |
| .setting_sz = ARRAY_SIZE(idmic_mono_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_ispkr_mic_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "speaker_mono_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &idmic_mono_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| }; |
| |
| static struct platform_device msm_ispkr_mic_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_ispkr_mic_data }, |
| }; |
| |
| static struct adie_codec_action_unit iearpiece_ffa_48KHz_osr256_actions[] = |
| EAR_PRI_MONO_8000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry iearpiece_ffa_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = iearpiece_ffa_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(iearpiece_ffa_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile iearpiece_ffa_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = iearpiece_ffa_settings, |
| .setting_sz = ARRAY_SIZE(iearpiece_ffa_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_iearpiece_ffa_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE), |
| .name = "handset_rx", |
| .copp_id = 0, |
| .profile = &iearpiece_ffa_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| }; |
| |
| static struct platform_device msm_iearpiece_ffa_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_iearpiece_ffa_data }, |
| }; |
| |
| static struct snddev_icodec_data snddev_imic_ffa_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "handset_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &idmic_mono_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| }; |
| |
| static struct platform_device msm_imic_ffa_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_imic_ffa_data }, |
| }; |
| |
| static struct adie_codec_action_unit dual_mic_endfire_8KHz_osr256_actions[] = |
| DMIC1_PRI_STEREO_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry dual_mic_endfire_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = dual_mic_endfire_8KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE(dual_mic_endfire_8KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile dual_mic_endfire_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = dual_mic_endfire_settings, |
| .setting_sz = ARRAY_SIZE(dual_mic_endfire_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_dual_mic_endfire_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "handset_dual_mic_endfire_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &dual_mic_endfire_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| }; |
| |
| static struct platform_device msm_hs_dual_mic_endfire_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_dual_mic_endfire_data }, |
| }; |
| |
| static struct snddev_icodec_data snddev_dual_mic_spkr_endfire_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "speaker_dual_mic_endfire_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &dual_mic_endfire_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| }; |
| |
| static struct platform_device msm_spkr_dual_mic_endfire_device = { |
| .name = "snddev_icodec", |
| .id = 15, |
| .dev = { .platform_data = &snddev_dual_mic_spkr_endfire_data }, |
| }; |
| |
| static struct adie_codec_action_unit dual_mic_broadside_8osr256_actions[] = |
| HS_DMIC2_STEREO_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry dual_mic_broadside_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = dual_mic_broadside_8osr256_actions, |
| .action_sz = ARRAY_SIZE(dual_mic_broadside_8osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile dual_mic_broadside_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = dual_mic_broadside_settings, |
| .setting_sz = ARRAY_SIZE(dual_mic_broadside_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_hs_dual_mic_broadside_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "handset_dual_mic_broadside_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &dual_mic_broadside_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_sec_power, |
| .pamp_off = msm_snddev_disable_dmic_sec_power, |
| }; |
| |
| static struct platform_device msm_hs_dual_mic_broadside_device = { |
| .name = "snddev_icodec", |
| .id = 21, |
| .dev = { .platform_data = &snddev_hs_dual_mic_broadside_data }, |
| }; |
| |
| static struct snddev_icodec_data snddev_spkr_dual_mic_broadside_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "speaker_dual_mic_broadside_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &dual_mic_broadside_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_sec_power, |
| .pamp_off = msm_snddev_disable_dmic_sec_power, |
| }; |
| |
| static struct platform_device msm_spkr_dual_mic_broadside_device = { |
| .name = "snddev_icodec", |
| .id = 18, |
| .dev = { .platform_data = &snddev_spkr_dual_mic_broadside_data }, |
| }; |
| |
| static struct adie_codec_action_unit |
| fluid_dual_mic_endfire_8KHz_osr256_actions[] = |
| FLUID_AMIC_DUAL_8000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry fluid_dual_mic_endfire_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = fluid_dual_mic_endfire_8KHz_osr256_actions, |
| .action_sz = |
| ARRAY_SIZE(fluid_dual_mic_endfire_8KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile fluid_dual_mic_endfire_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = fluid_dual_mic_endfire_settings, |
| .setting_sz = ARRAY_SIZE(fluid_dual_mic_endfire_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_fluid_dual_mic_endfire_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "handset_dual_mic_endfire_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &fluid_dual_mic_endfire_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_sec_power, |
| .pamp_off = msm_snddev_disable_amic_sec_power, |
| }; |
| |
| static struct platform_device msm_fluid_hs_dual_mic_endfire_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_fluid_dual_mic_endfire_data }, |
| }; |
| |
| static struct snddev_icodec_data snddev_fluid_dual_mic_spkr_endfire_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "speaker_dual_mic_endfire_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &fluid_dual_mic_endfire_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_sec_power, |
| .pamp_off = msm_snddev_disable_amic_sec_power, |
| }; |
| |
| static struct platform_device msm_fluid_spkr_dual_mic_endfire_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_fluid_dual_mic_spkr_endfire_data }, |
| }; |
| |
| static struct adie_codec_action_unit |
| fluid_dual_mic_broadside_8KHz_osr256_actions[] = |
| FLUID_AMIC_DUAL_BROADSIDE_8000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry fluid_dual_mic_broadside_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = fluid_dual_mic_broadside_8KHz_osr256_actions, |
| .action_sz = |
| ARRAY_SIZE(fluid_dual_mic_broadside_8KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile fluid_dual_mic_broadside_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = fluid_dual_mic_broadside_settings, |
| .setting_sz = ARRAY_SIZE(fluid_dual_mic_broadside_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_fluid_dual_mic_broadside_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "handset_dual_mic_broadside_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &fluid_dual_mic_broadside_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_power, |
| .pamp_off = msm_snddev_disable_amic_power, |
| }; |
| |
| static struct platform_device msm_fluid_hs_dual_mic_broadside_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_fluid_dual_mic_broadside_data }, |
| }; |
| |
| static struct snddev_icodec_data snddev_fluid_dual_mic_spkr_broadside_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "speaker_dual_mic_broadside_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &fluid_dual_mic_broadside_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_power, |
| .pamp_off = msm_snddev_disable_amic_power, |
| }; |
| |
| static struct platform_device msm_fluid_spkr_dual_mic_broadside_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_fluid_dual_mic_spkr_broadside_data }, |
| }; |
| |
| static struct snddev_hdmi_data snddev_hdmi_stereo_rx_data = { |
| .capability = SNDDEV_CAP_RX , |
| .name = "hdmi_stereo_rx", |
| .copp_id = HDMI_RX, |
| .channel_mode = 0, |
| .default_sample_rate = 48000, |
| }; |
| |
| static struct platform_device msm_snddev_hdmi_stereo_rx_device = { |
| .name = "snddev_hdmi", |
| .dev = { .platform_data = &snddev_hdmi_stereo_rx_data }, |
| }; |
| |
| static struct snddev_mi2s_data snddev_mi2s_fm_tx_data = { |
| .capability = SNDDEV_CAP_TX , |
| .name = "fmradio_stereo_tx", |
| .copp_id = MI2S_TX, |
| .channel_mode = 2, /* stereo */ |
| .sd_lines = MI2S_SD3, /* sd3 */ |
| .sample_rate = 48000, |
| }; |
| |
| static struct platform_device msm_mi2s_fm_tx_device = { |
| .name = "snddev_mi2s", |
| .dev = { .platform_data = &snddev_mi2s_fm_tx_data }, |
| }; |
| |
| static struct snddev_mi2s_data snddev_mi2s_fm_rx_data = { |
| .capability = SNDDEV_CAP_RX , |
| .name = "fmradio_stereo_rx", |
| .copp_id = MI2S_RX, |
| .channel_mode = 2, /* stereo */ |
| .sd_lines = MI2S_SD3, /* sd3 */ |
| .sample_rate = 48000, |
| }; |
| |
| static struct platform_device msm_mi2s_fm_rx_device = { |
| .name = "snddev_mi2s", |
| .id = 1, |
| .dev = { .platform_data = &snddev_mi2s_fm_rx_data }, |
| }; |
| |
| static struct adie_codec_action_unit iheadset_mic_tx_osr256_actions[] = |
| HEADSET_AMIC2_TX_MONO_PRI_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry iheadset_mic_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = iheadset_mic_tx_osr256_actions, |
| .action_sz = ARRAY_SIZE(iheadset_mic_tx_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile iheadset_mic_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = iheadset_mic_tx_settings, |
| .setting_sz = ARRAY_SIZE(iheadset_mic_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_headset_mic_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "headset_mono_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &iheadset_mic_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| }; |
| |
| static struct platform_device msm_headset_mic_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_headset_mic_data }, |
| }; |
| |
| static struct adie_codec_action_unit |
| ihs_stereo_speaker_stereo_rx_48KHz_osr256_actions[] = |
| SPEAKER_HPH_AB_CPL_PRI_STEREO_48000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry |
| ihs_stereo_speaker_stereo_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ihs_stereo_speaker_stereo_rx_48KHz_osr256_actions, |
| .action_sz = |
| ARRAY_SIZE(ihs_stereo_speaker_stereo_rx_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile ihs_stereo_speaker_stereo_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ihs_stereo_speaker_stereo_rx_settings, |
| .setting_sz = ARRAY_SIZE(ihs_stereo_speaker_stereo_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_ihs_stereo_speaker_stereo_rx_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE), |
| .name = "headset_stereo_speaker_stereo_rx", |
| .copp_id = 0, |
| .profile = &ihs_stereo_speaker_stereo_rx_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| }; |
| |
| static struct platform_device msm_ihs_stereo_speaker_stereo_rx_device = { |
| .name = "snddev_icodec", |
| .id = 22, |
| .dev = { .platform_data = &snddev_ihs_stereo_speaker_stereo_rx_data }, |
| }; |
| |
| /* define the value for BT_SCO */ |
| |
| static struct snddev_ecodec_data snddev_bt_sco_earpiece_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE), |
| .name = "bt_sco_rx", |
| .copp_id = PCM_RX, |
| .channel_mode = 1, |
| }; |
| |
| static struct snddev_ecodec_data snddev_bt_sco_mic_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "bt_sco_tx", |
| .copp_id = PCM_TX, |
| .channel_mode = 1, |
| }; |
| |
| struct platform_device msm_bt_sco_earpiece_device = { |
| .name = "msm_snddev_ecodec", |
| .dev = { .platform_data = &snddev_bt_sco_earpiece_data }, |
| }; |
| |
| struct platform_device msm_bt_sco_mic_device = { |
| .name = "msm_snddev_ecodec", |
| .dev = { .platform_data = &snddev_bt_sco_mic_data }, |
| }; |
| |
| static struct adie_codec_action_unit itty_mono_tx_actions[] = |
| TTY_HEADSET_MONO_TX_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry itty_mono_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = itty_mono_tx_actions, |
| .action_sz = ARRAY_SIZE(itty_mono_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile itty_mono_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = itty_mono_tx_settings, |
| .setting_sz = ARRAY_SIZE(itty_mono_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_itty_mono_tx_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE | SNDDEV_CAP_TTY), |
| .name = "tty_headset_mono_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &itty_mono_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| }; |
| |
| static struct platform_device msm_itty_mono_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_itty_mono_tx_data }, |
| }; |
| |
| static struct adie_codec_action_unit itty_mono_rx_actions[] = |
| TTY_HEADSET_MONO_RX_8000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry itty_mono_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = itty_mono_rx_actions, |
| .action_sz = ARRAY_SIZE(itty_mono_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile itty_mono_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = itty_mono_rx_settings, |
| .setting_sz = ARRAY_SIZE(itty_mono_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_itty_mono_rx_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE | SNDDEV_CAP_TTY), |
| .name = "tty_headset_mono_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &itty_mono_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| }; |
| |
| static struct platform_device msm_itty_mono_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_itty_mono_rx_data }, |
| }; |
| |
| static struct adie_codec_action_unit linein_pri_actions[] = |
| LINEIN_PRI_STEREO_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry linein_pri_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = linein_pri_actions, |
| .action_sz = ARRAY_SIZE(linein_pri_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile linein_pri_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = linein_pri_settings, |
| .setting_sz = ARRAY_SIZE(linein_pri_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_linein_pri_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "linein_pri_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &linein_pri_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| }; |
| |
| static struct platform_device msm_linein_pri_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_linein_pri_data }, |
| }; |
| |
| static struct adie_codec_action_unit auxpga_lp_lo_actions[] = |
| LB_AUXPGA_LO_STEREO; |
| |
| static struct adie_codec_hwsetting_entry auxpga_lp_lo_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = auxpga_lp_lo_actions, |
| .action_sz = ARRAY_SIZE(auxpga_lp_lo_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile auxpga_lp_lo_profile = { |
| .path_type = ADIE_CODEC_LB, |
| .settings = auxpga_lp_lo_settings, |
| .setting_sz = ARRAY_SIZE(auxpga_lp_lo_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_auxpga_lp_lo_data = { |
| .capability = SNDDEV_CAP_LB, |
| .name = "speaker_stereo_lb", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &auxpga_lp_lo_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_ANALOG, |
| }; |
| |
| static struct platform_device msm_auxpga_lp_lo_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_auxpga_lp_lo_data }, |
| }; |
| |
| static struct adie_codec_action_unit auxpga_lp_hs_actions[] = |
| LB_AUXPGA_HPH_AB_CPLS_STEREO; |
| |
| static struct adie_codec_hwsetting_entry auxpga_lp_hs_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = auxpga_lp_hs_actions, |
| .action_sz = ARRAY_SIZE(auxpga_lp_hs_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile auxpga_lp_hs_profile = { |
| .path_type = ADIE_CODEC_LB, |
| .settings = auxpga_lp_hs_settings, |
| .setting_sz = ARRAY_SIZE(auxpga_lp_hs_settings), |
| }; |
| |
| static struct snddev_icodec_data snddev_auxpga_lp_hs_data = { |
| .capability = SNDDEV_CAP_LB, |
| .name = "hs_stereo_lb", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &auxpga_lp_hs_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_ANALOG, |
| }; |
| |
| static struct platform_device msm_auxpga_lp_hs_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &snddev_auxpga_lp_hs_data }, |
| }; |
| |
| #ifdef CONFIG_MSM8X60_FTM_AUDIO_DEVICES |
| static struct adie_codec_action_unit ftm_headset_mono_rx_actions[] = |
| HPH_PRI_AB_CPLS_MONO; |
| |
| static struct adie_codec_hwsetting_entry ftm_headset_mono_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_headset_mono_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_headset_mono_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_headset_mono_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_headset_mono_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_headset_mono_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_headset_mono_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_headset_mono_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_headset_mono_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_headset_mono_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_headset_mono_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_headset_mono_diff_rx_actions[] = |
| HEADSET_MONO_DIFF_RX; |
| |
| static struct adie_codec_hwsetting_entry ftm_headset_mono_diff_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_headset_mono_diff_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_headset_mono_diff_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_headset_mono_diff_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_headset_mono_diff_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_headset_mono_diff_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_headset_mono_diff_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_headset_mono_diff_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_headset_mono_diff_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_headset_mono_diff_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_headset_mono_diff_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_spkr_mono_rx_actions[] = |
| SPEAKER_PRI_STEREO_48000_OSR_256; |
| |
| static struct adie_codec_hwsetting_entry ftm_spkr_mono_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_spkr_mono_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_spkr_mono_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_spkr_mono_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_spkr_mono_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_spkr_mono_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_spkr_mono_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_spkr_mono_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_spkr_mono_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_spkr_mono_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_spkr_mono_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_spkr_l_rx_actions[] = |
| FTM_SPKR_L_RX; |
| |
| static struct adie_codec_hwsetting_entry ftm_spkr_l_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_spkr_l_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_spkr_l_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_spkr_l_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_spkr_l_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_spkr_l_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_spkr_l_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_spkr_l_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_spkr_l_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_spkr_l_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_spkr_l_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_spkr_r_rx_actions[] = |
| SPKR_R_RX; |
| |
| static struct adie_codec_hwsetting_entry ftm_spkr_r_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_spkr_r_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_spkr_r_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_spkr_r_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_spkr_r_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_spkr_r_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_spkr_r_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_spkr_r_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_spkr_r_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_spkr_r_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_spkr_r_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_spkr_mono_diff_rx_actions[] = |
| SPKR_MONO_DIFF_RX; |
| |
| static struct adie_codec_hwsetting_entry ftm_spkr_mono_diff_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_spkr_mono_diff_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_spkr_mono_diff_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_spkr_mono_diff_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_spkr_mono_diff_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_spkr_mono_diff_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_spkr_mono_diff_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_spkr_mono_diff_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_spkr_mono_diff_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_spkr_mono_diff_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_spkr_mono_diff_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_headset_mono_l_rx_actions[] = |
| HPH_PRI_AB_CPLS_MONO_LEFT; |
| |
| static struct adie_codec_hwsetting_entry ftm_headset_mono_l_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_headset_mono_l_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_headset_mono_l_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_headset_mono_l_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_headset_mono_l_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_headset_mono_l_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_headset_mono_l_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_headset_mono_l_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_headset_mono_l_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_headset_mono_l_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_headset_mono_l_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_headset_mono_r_rx_actions[] = |
| HPH_PRI_AB_CPLS_MONO_RIGHT; |
| |
| static struct adie_codec_hwsetting_entry ftm_headset_mono_r_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_headset_mono_r_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_headset_mono_r_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_headset_mono_r_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_headset_mono_r_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_headset_mono_r_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_headset_mono_r_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_headset_mono_r_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_headset_mono_r_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_headset_mono_r_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_headset_mono_r_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_linein_l_tx_actions[] = |
| LINEIN_MONO_L_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_linein_l_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_linein_l_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_linein_l_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_linein_l_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_linein_l_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_linein_l_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_linein_l_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_linein_l_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_linein_l_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_linein_l_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_linein_l_tx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_linein_r_tx_actions[] = |
| LINEIN_MONO_R_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_linein_r_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_linein_r_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_linein_r_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_linein_r_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_linein_r_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_linein_r_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_linein_r_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_linein_r_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_linein_r_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_linein_r_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_linein_r_tx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_aux_out_rx_actions[] = |
| AUX_OUT_RX; |
| |
| static struct adie_codec_hwsetting_entry ftm_aux_out_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_aux_out_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_aux_out_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_aux_out_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_aux_out_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_aux_out_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_aux_out_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_aux_out_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_aux_out_rx_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_aux_out_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_aux_out_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_dmic1_left_tx_actions[] = |
| DMIC1_LEFT_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_dmic1_left_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_dmic1_left_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_dmic1_left_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_dmic1_left_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_dmic1_left_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_dmic1_left_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_dmic1_left_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_dmic1_left_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_dmic1_left_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_dmic1_left_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_dmic1_left_tx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_dmic1_right_tx_actions[] = |
| DMIC1_RIGHT_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_dmic1_right_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_dmic1_right_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_dmic1_right_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_dmic1_right_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_dmic1_right_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_dmic1_right_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_dmic1_right_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_dmic1_right_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_dmic1_right_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_dmic1_right_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_dmic1_right_tx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_dmic1_l_and_r_tx_actions[] = |
| DMIC1_LEFT_AND_RIGHT_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_dmic1_l_and_r_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_dmic1_l_and_r_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_dmic1_l_and_r_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_dmic1_l_and_r_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_dmic1_l_and_r_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_dmic1_l_and_r_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_dmic1_l_and_r_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_dmic1_l_and_r_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_dmic1_l_and_r_tx_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_dmic1_l_and_r_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_dmic1_l_and_r_tx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_dmic2_left_tx_actions[] = |
| DMIC2_LEFT_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_dmic2_left_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_dmic2_left_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_dmic2_left_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_dmic2_left_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_dmic2_left_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_dmic2_left_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_dmic2_left_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_dmic2_left_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_dmic2_left_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_dmic2_left_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_dmic2_left_tx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_dmic2_right_tx_actions[] = |
| DMIC2_RIGHT_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_dmic2_right_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_dmic2_right_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_dmic2_right_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_dmic2_right_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_dmic2_right_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_dmic2_right_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_dmic2_right_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_dmic2_right_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_dmic2_right_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_dmic2_right_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_dmic2_right_tx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_dmic2_l_and_r_tx_actions[] = |
| DMIC2_LEFT_AND_RIGHT_TX; |
| |
| static struct adie_codec_hwsetting_entry ftm_dmic2_l_and_r_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_dmic2_l_and_r_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_dmic2_l_and_r_tx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_dmic2_l_and_r_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_dmic2_l_and_r_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_dmic2_l_and_r_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_dmic2_l_and_r_tx_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_dmic2_l_and_r_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_dmic2_l_and_r_tx_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_dmic_power, |
| .pamp_off = msm_snddev_disable_dmic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_dmic2_l_and_r_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_dmic2_l_and_r_tx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_handset_mic1_aux_in_actions[] = |
| HANDSET_MIC1_AUX_IN; |
| |
| static struct adie_codec_hwsetting_entry ftm_handset_mic1_aux_in_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_handset_mic1_aux_in_actions, |
| .action_sz = ARRAY_SIZE(ftm_handset_mic1_aux_in_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_handset_mic1_aux_in_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_handset_mic1_aux_in_settings, |
| .setting_sz = ARRAY_SIZE(ftm_handset_mic1_aux_in_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_handset_mic1_aux_in_data = { |
| .capability = SNDDEV_CAP_TX, |
| .name = "ftm_handset_mic1_aux_in", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_handset_mic1_aux_in_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| /* Assumption is that inputs are not tied to analog mic, so |
| * no need to enable mic bias. |
| */ |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_handset_mic1_aux_in_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_handset_mic1_aux_in_data}, |
| }; |
| |
| static struct snddev_mi2s_data snddev_mi2s_sd0_rx_data = { |
| .capability = SNDDEV_CAP_RX , |
| .name = "mi2s_sd0_rx", |
| .copp_id = MI2S_RX, |
| .channel_mode = 2, /* stereo */ |
| .sd_lines = MI2S_SD0, /* sd0 */ |
| .sample_rate = 48000, |
| }; |
| |
| static struct platform_device ftm_mi2s_sd0_rx_device = { |
| .name = "snddev_mi2s", |
| .dev = { .platform_data = &snddev_mi2s_sd0_rx_data }, |
| }; |
| |
| static struct snddev_mi2s_data snddev_mi2s_sd1_rx_data = { |
| .capability = SNDDEV_CAP_RX , |
| .name = "mi2s_sd1_rx", |
| .copp_id = MI2S_RX, |
| .channel_mode = 2, /* stereo */ |
| .sd_lines = MI2S_SD1, /* sd1 */ |
| .sample_rate = 48000, |
| }; |
| |
| static struct platform_device ftm_mi2s_sd1_rx_device = { |
| .name = "snddev_mi2s", |
| .dev = { .platform_data = &snddev_mi2s_sd1_rx_data }, |
| }; |
| |
| static struct snddev_mi2s_data snddev_mi2s_sd2_rx_data = { |
| .capability = SNDDEV_CAP_RX , |
| .name = "mi2s_sd2_rx", |
| .copp_id = MI2S_RX, |
| .channel_mode = 2, /* stereo */ |
| .sd_lines = MI2S_SD2, /* sd2 */ |
| .sample_rate = 48000, |
| }; |
| |
| static struct platform_device ftm_mi2s_sd2_rx_device = { |
| .name = "snddev_mi2s", |
| .dev = { .platform_data = &snddev_mi2s_sd2_rx_data }, |
| }; |
| |
| /* earpiece */ |
| static struct adie_codec_action_unit ftm_handset_adie_lp_rx_actions[] = |
| EAR_PRI_MONO_LB; |
| |
| static struct adie_codec_hwsetting_entry ftm_handset_adie_lp_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_handset_adie_lp_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_handset_adie_lp_rx_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile ftm_handset_adie_lp_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_handset_adie_lp_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_handset_adie_lp_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_handset_adie_lp_rx_data = { |
| .capability = (SNDDEV_CAP_RX | SNDDEV_CAP_VOICE), |
| .name = "ftm_handset_adie_lp_rx", |
| .copp_id = 0, |
| .profile = &ftm_handset_adie_lp_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_handset_adie_lp_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_handset_adie_lp_rx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_headset_l_adie_lp_rx_actions[] = |
| FTM_HPH_PRI_AB_CPLS_MONO_LB_LEFT; |
| |
| static struct adie_codec_hwsetting_entry ftm_headset_l_adie_lp_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_headset_l_adie_lp_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_headset_l_adie_lp_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_headset_l_adie_lp_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_headset_l_adie_lp_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_headset_l_adie_lp_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_headset_l_adie_lp_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_headset_l_adie_lp_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_headset_l_adie_lp_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_headset_l_adie_lp_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_headset_l_adie_lp_rx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_headset_r_adie_lp_rx_actions[] = |
| FTM_HPH_PRI_AB_CPLS_MONO_LB_RIGHT; |
| |
| static struct adie_codec_hwsetting_entry ftm_headset_r_adie_lp_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_headset_r_adie_lp_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_headset_r_adie_lp_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_headset_r_adie_lp_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_headset_r_adie_lp_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_headset_r_adie_lp_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_headset_r_adie_lp_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_headset_r_adie_lp_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_headset_r_adie_lp_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .voltage_on = msm_snddev_voltage_on, |
| .voltage_off = msm_snddev_voltage_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_headset_r_adie_lp_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_headset_r_adie_lp_rx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_spkr_l_rx_lp_actions[] = |
| FTM_SPKR_L_RX; |
| |
| static struct adie_codec_hwsetting_entry ftm_spkr_l_rx_lp_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_spkr_l_rx_lp_actions, |
| .action_sz = ARRAY_SIZE(ftm_spkr_l_rx_lp_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_spkr_l_rx_lp_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_spkr_l_rx_lp_settings, |
| .setting_sz = ARRAY_SIZE(ftm_spkr_l_rx_lp_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_spkr_l_rx_lp_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_spk_l_adie_lp_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_spkr_l_rx_lp_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_spk_l_adie_lp_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_spkr_l_rx_lp_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_spkr_r_adie_lp_rx_actions[] = |
| FTM_SPKR_RX_LB; |
| |
| static struct adie_codec_hwsetting_entry ftm_spkr_r_adie_lp_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_spkr_r_adie_lp_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_spkr_r_adie_lp_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_spkr_r_adie_lp_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_spkr_r_adie_lp_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_spkr_r_adie_lp_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_spkr_r_adie_lp_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_spk_r_adie_lp_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_spkr_r_adie_lp_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_spk_r_adie_lp_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_spkr_r_adie_lp_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_spkr_adie_lp_rx_actions[] = |
| FTM_SPKR_RX_LB; |
| |
| static struct adie_codec_hwsetting_entry ftm_spkr_adie_lp_rx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_spkr_adie_lp_rx_actions, |
| .action_sz = ARRAY_SIZE(ftm_spkr_adie_lp_rx_actions), |
| }, |
| }; |
| |
| static struct adie_codec_dev_profile ftm_spkr_adie_lp_rx_profile = { |
| .path_type = ADIE_CODEC_RX, |
| .settings = ftm_spkr_adie_lp_rx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_spkr_adie_lp_rx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_spkr_adie_lp_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "ftm_spk_adie_lp_rx", |
| .copp_id = PRIMARY_I2S_RX, |
| .profile = &ftm_spkr_adie_lp_rx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_poweramp_on, |
| .pamp_off = msm_snddev_poweramp_off, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_spk_adie_lp_rx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_spkr_adie_lp_rx_data}, |
| }; |
| |
| static struct adie_codec_action_unit ftm_handset_dual_tx_lp_actions[] = |
| FTM_AMIC_DUAL_HANDSET_TX_LB; |
| |
| static struct adie_codec_hwsetting_entry ftm_handset_dual_tx_lp_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_handset_dual_tx_lp_actions, |
| .action_sz = ARRAY_SIZE(ftm_handset_dual_tx_lp_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile ftm_handset_dual_tx_lp_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_handset_dual_tx_lp_settings, |
| .setting_sz = ARRAY_SIZE(ftm_handset_dual_tx_lp_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_handset_dual_tx_lp_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "handset_mic1_handset_mic2", |
| .copp_id = 1, |
| .profile = &ftm_handset_dual_tx_lp_profile, |
| .channel_mode = 2, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_power, |
| .pamp_off = msm_snddev_disable_amic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_handset_dual_tx_lp_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_handset_dual_tx_lp_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_handset_mic_adie_lp_tx_actions[] = |
| FTM_HANDSET_LB_TX; |
| |
| static struct adie_codec_hwsetting_entry |
| ftm_handset_mic_adie_lp_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_handset_mic_adie_lp_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_handset_mic_adie_lp_tx_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile ftm_handset_mic_adie_lp_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_handset_mic_adie_lp_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_handset_mic_adie_lp_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_handset_mic_adie_lp_tx_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "ftm_handset_mic_adie_lp_tx", |
| .copp_id = 1, |
| .profile = &ftm_handset_mic_adie_lp_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .pamp_on = msm_snddev_enable_amic_power, |
| .pamp_off = msm_snddev_disable_amic_power, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_handset_mic_adie_lp_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_handset_mic_adie_lp_tx_data }, |
| }; |
| |
| static struct adie_codec_action_unit ftm_headset_mic_adie_lp_tx_actions[] = |
| FTM_HEADSET_LB_TX; |
| |
| static struct adie_codec_hwsetting_entry |
| ftm_headset_mic_adie_lp_tx_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = ftm_headset_mic_adie_lp_tx_actions, |
| .action_sz = ARRAY_SIZE(ftm_headset_mic_adie_lp_tx_actions), |
| } |
| }; |
| |
| static struct adie_codec_dev_profile ftm_headset_mic_adie_lp_tx_profile = { |
| .path_type = ADIE_CODEC_TX, |
| .settings = ftm_headset_mic_adie_lp_tx_settings, |
| .setting_sz = ARRAY_SIZE(ftm_headset_mic_adie_lp_tx_settings), |
| }; |
| |
| static struct snddev_icodec_data ftm_headset_mic_adie_lp_tx_data = { |
| .capability = (SNDDEV_CAP_TX | SNDDEV_CAP_VOICE), |
| .name = "ftm_headset_mic_adie_lp_tx", |
| .copp_id = PRIMARY_I2S_TX, |
| .profile = &ftm_headset_mic_adie_lp_tx_profile, |
| .channel_mode = 1, |
| .default_sample_rate = 48000, |
| .dev_vol_type = SNDDEV_DEV_VOL_DIGITAL, |
| }; |
| |
| static struct platform_device ftm_headset_mic_adie_lp_tx_device = { |
| .name = "snddev_icodec", |
| .dev = { .platform_data = &ftm_headset_mic_adie_lp_tx_data }, |
| }; |
| #endif /* CONFIG_MSM8X60_FTM_AUDIO_DEVICES */ |
| |
| static struct snddev_virtual_data snddev_uplink_rx_data = { |
| .capability = SNDDEV_CAP_RX, |
| .name = "uplink_rx", |
| .copp_id = VOICE_PLAYBACK_TX, |
| }; |
| |
| static struct platform_device msm_uplink_rx_device = { |
| .name = "snddev_virtual", |
| .dev = { .platform_data = &snddev_uplink_rx_data }, |
| }; |
| |
| static struct snddev_hdmi_data snddev_hdmi_non_linear_pcm_rx_data = { |
| .capability = SNDDEV_CAP_RX , |
| .name = "hdmi_pass_through", |
| .default_sample_rate = 48000, |
| .on_apps = 1, |
| }; |
| |
| static struct platform_device msm_snddev_hdmi_non_linear_pcm_rx_device = { |
| .name = "snddev_hdmi", |
| .dev = { .platform_data = &snddev_hdmi_non_linear_pcm_rx_data }, |
| }; |
| |
| |
| #ifdef CONFIG_DEBUG_FS |
| static struct adie_codec_action_unit |
| ihs_stereo_rx_class_d_legacy_48KHz_osr256_actions[] = |
| HPH_PRI_D_LEG_STEREO; |
| |
| static struct adie_codec_hwsetting_entry |
| ihs_stereo_rx_class_d_legacy_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = |
| ihs_stereo_rx_class_d_legacy_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE |
| (ihs_stereo_rx_class_d_legacy_48KHz_osr256_actions), |
| } |
| }; |
| |
| static struct adie_codec_action_unit |
| ihs_stereo_rx_class_ab_legacy_48KHz_osr256_actions[] = |
| HPH_PRI_AB_LEG_STEREO; |
| |
| static struct adie_codec_hwsetting_entry |
| ihs_stereo_rx_class_ab_legacy_settings[] = { |
| { |
| .freq_plan = 48000, |
| .osr = 256, |
| .actions = |
| ihs_stereo_rx_class_ab_legacy_48KHz_osr256_actions, |
| .action_sz = ARRAY_SIZE |
| (ihs_stereo_rx_class_ab_legacy_48KHz_osr256_actions), |
| } |
| }; |
| |
| static void snddev_hsed_config_modify_setting(int type) |
| { |
| struct platform_device *device; |
| struct snddev_icodec_data *icodec_data; |
| |
| device = &msm_headset_stereo_device; |
| icodec_data = (struct snddev_icodec_data *)device->dev.platform_data; |
| |
| if (icodec_data) { |
| if (type == 1) { |
| icodec_data->voltage_on = NULL; |
| icodec_data->voltage_off = NULL; |
| icodec_data->profile->settings = |
| ihs_stereo_rx_class_d_legacy_settings; |
| icodec_data->profile->setting_sz = |
| ARRAY_SIZE(ihs_stereo_rx_class_d_legacy_settings); |
| } else if (type == 2) { |
| icodec_data->voltage_on = NULL; |
| icodec_data->voltage_off = NULL; |
| icodec_data->profile->settings = |
| ihs_stereo_rx_class_ab_legacy_settings; |
| icodec_data->profile->setting_sz = |
| ARRAY_SIZE(ihs_stereo_rx_class_ab_legacy_settings); |
| } |
| } |
| } |
| |
| static void snddev_hsed_config_restore_setting(void) |
| { |
| struct platform_device *device; |
| struct snddev_icodec_data *icodec_data; |
| |
| device = &msm_headset_stereo_device; |
| icodec_data = (struct snddev_icodec_data *)device->dev.platform_data; |
| |
| if (icodec_data) { |
| icodec_data->voltage_on = msm_snddev_voltage_on; |
| icodec_data->voltage_off = msm_snddev_voltage_off; |
| icodec_data->profile->settings = headset_ab_cpls_settings; |
| icodec_data->profile->setting_sz = |
| ARRAY_SIZE(headset_ab_cpls_settings); |
| } |
| } |
| |
| static ssize_t snddev_hsed_config_debug_write(struct file *filp, |
| const char __user *ubuf, size_t cnt, loff_t *ppos) |
| { |
| char *lb_str = filp->private_data; |
| char cmd; |
| |
| if (get_user(cmd, ubuf)) |
| return -EFAULT; |
| |
| if (!strcmp(lb_str, "msm_hsed_config")) { |
| switch (cmd) { |
| case '0': |
| snddev_hsed_config_restore_setting(); |
| break; |
| |
| case '1': |
| snddev_hsed_config_modify_setting(1); |
| break; |
| |
| case '2': |
| snddev_hsed_config_modify_setting(2); |
| break; |
| |
| default: |
| break; |
| } |
| } |
| return cnt; |
| } |
| |
| static int snddev_hsed_config_debug_open(struct inode *inode, struct file *file) |
| { |
| file->private_data = inode->i_private; |
| return 0; |
| } |
| |
| static const struct file_operations snddev_hsed_config_debug_fops = { |
| .open = snddev_hsed_config_debug_open, |
| .write = snddev_hsed_config_debug_write |
| }; |
| #endif |
| |
| static struct platform_device *snd_devices_ffa[] __initdata = { |
| &msm_iearpiece_ffa_device, |
| &msm_imic_ffa_device, |
| &msm_ispkr_stereo_device, |
| &msm_snddev_hdmi_stereo_rx_device, |
| &msm_headset_mic_device, |
| &msm_ispkr_mic_device, |
| &msm_bt_sco_earpiece_device, |
| &msm_bt_sco_mic_device, |
| &msm_headset_stereo_device, |
| &msm_itty_mono_tx_device, |
| &msm_itty_mono_rx_device, |
| &msm_mi2s_fm_tx_device, |
| &msm_mi2s_fm_rx_device, |
| &msm_hs_dual_mic_endfire_device, |
| &msm_spkr_dual_mic_endfire_device, |
| &msm_hs_dual_mic_broadside_device, |
| &msm_spkr_dual_mic_broadside_device, |
| &msm_ihs_stereo_speaker_stereo_rx_device, |
| &msm_anc_headset_device, |
| &msm_auxpga_lp_hs_device, |
| &msm_auxpga_lp_lo_device, |
| &msm_linein_pri_device, |
| &msm_icodec_gpio_device, |
| &msm_snddev_hdmi_non_linear_pcm_rx_device, |
| }; |
| |
| static struct platform_device *snd_devices_surf[] __initdata = { |
| &msm_iearpiece_device, |
| &msm_imic_device, |
| &msm_ispkr_stereo_device, |
| &msm_snddev_hdmi_stereo_rx_device, |
| &msm_headset_mic_device, |
| &msm_ispkr_mic_device, |
| &msm_bt_sco_earpiece_device, |
| &msm_bt_sco_mic_device, |
| &msm_headset_stereo_device, |
| &msm_itty_mono_tx_device, |
| &msm_itty_mono_rx_device, |
| &msm_mi2s_fm_tx_device, |
| &msm_mi2s_fm_rx_device, |
| &msm_ihs_stereo_speaker_stereo_rx_device, |
| &msm_auxpga_lp_hs_device, |
| &msm_auxpga_lp_lo_device, |
| &msm_linein_pri_device, |
| &msm_icodec_gpio_device, |
| &msm_snddev_hdmi_non_linear_pcm_rx_device, |
| }; |
| |
| static struct platform_device *snd_devices_fluid[] __initdata = { |
| &msm_iearpiece_device, |
| &msm_imic_device, |
| &msm_ispkr_stereo_device, |
| &msm_snddev_hdmi_stereo_rx_device, |
| &msm_headset_stereo_device, |
| &msm_headset_mic_device, |
| &msm_fluid_ispkr_mic_device, |
| &msm_bt_sco_earpiece_device, |
| &msm_bt_sco_mic_device, |
| &msm_mi2s_fm_tx_device, |
| &msm_mi2s_fm_rx_device, |
| &msm_fluid_hs_dual_mic_endfire_device, |
| &msm_fluid_spkr_dual_mic_endfire_device, |
| &msm_fluid_hs_dual_mic_broadside_device, |
| &msm_fluid_spkr_dual_mic_broadside_device, |
| &msm_anc_headset_device, |
| &msm_auxpga_lp_hs_device, |
| &msm_auxpga_lp_lo_device, |
| &msm_icodec_gpio_device, |
| &msm_snddev_hdmi_non_linear_pcm_rx_device, |
| }; |
| |
| static struct platform_device *snd_devices_common[] __initdata = { |
| &msm_aux_pcm_device, |
| &msm_cdcclk_ctl_device, |
| &msm_mi2s_device, |
| &msm_uplink_rx_device, |
| &msm_device_dspcrashd_8x60, |
| }; |
| |
| #ifdef CONFIG_MSM8X60_FTM_AUDIO_DEVICES |
| static struct platform_device *snd_devices_ftm[] __initdata = { |
| &ftm_headset_mono_rx_device, |
| &ftm_headset_mono_l_rx_device, |
| &ftm_headset_mono_r_rx_device, |
| &ftm_headset_mono_diff_rx_device, |
| &ftm_spkr_mono_rx_device, |
| &ftm_spkr_l_rx_device, |
| &ftm_spkr_r_rx_device, |
| &ftm_spkr_mono_diff_rx_device, |
| &ftm_linein_l_tx_device, |
| &ftm_linein_r_tx_device, |
| &ftm_aux_out_rx_device, |
| &ftm_dmic1_left_tx_device, |
| &ftm_dmic1_right_tx_device, |
| &ftm_dmic1_l_and_r_tx_device, |
| &ftm_dmic2_left_tx_device, |
| &ftm_dmic2_right_tx_device, |
| &ftm_dmic2_l_and_r_tx_device, |
| &ftm_handset_mic1_aux_in_device, |
| &ftm_mi2s_sd0_rx_device, |
| &ftm_mi2s_sd1_rx_device, |
| &ftm_mi2s_sd2_rx_device, |
| &ftm_handset_mic_adie_lp_tx_device, |
| &ftm_headset_mic_adie_lp_tx_device, |
| &ftm_handset_adie_lp_rx_device, |
| &ftm_headset_l_adie_lp_rx_device, |
| &ftm_headset_r_adie_lp_rx_device, |
| &ftm_spk_l_adie_lp_rx_device, |
| &ftm_spk_r_adie_lp_rx_device, |
| &ftm_spk_adie_lp_rx_device, |
| &ftm_handset_dual_tx_lp_device, |
| }; |
| #else |
| static struct platform_device *snd_devices_ftm[] __initdata = {}; |
| #endif |
| |
| |
| void __init msm_snddev_init(void) |
| { |
| int i; |
| int dev_id; |
| |
| atomic_set(&pamp_ref_cnt, 0); |
| atomic_set(&preg_ref_cnt, 0); |
| |
| for (i = 0, dev_id = 0; i < ARRAY_SIZE(snd_devices_common); i++) |
| snd_devices_common[i]->id = dev_id++; |
| |
| platform_add_devices(snd_devices_common, |
| ARRAY_SIZE(snd_devices_common)); |
| |
| /* Auto detect device base on machine info */ |
| if (machine_is_msm8x60_surf() || machine_is_msm8x60_fusion()) { |
| for (i = 0; i < ARRAY_SIZE(snd_devices_surf); i++) |
| snd_devices_surf[i]->id = dev_id++; |
| |
| platform_add_devices(snd_devices_surf, |
| ARRAY_SIZE(snd_devices_surf)); |
| } else if (machine_is_msm8x60_ffa() || |
| machine_is_msm8x60_fusn_ffa()) { |
| for (i = 0; i < ARRAY_SIZE(snd_devices_ffa); i++) |
| snd_devices_ffa[i]->id = dev_id++; |
| |
| platform_add_devices(snd_devices_ffa, |
| ARRAY_SIZE(snd_devices_ffa)); |
| } else if (machine_is_msm8x60_fluid()) { |
| for (i = 0; i < ARRAY_SIZE(snd_devices_fluid); i++) |
| snd_devices_fluid[i]->id = dev_id++; |
| |
| platform_add_devices(snd_devices_fluid, |
| ARRAY_SIZE(snd_devices_fluid)); |
| } else if (machine_is_msm8x60_surf()) { |
| for (i = 0; i < ARRAY_SIZE(snd_devices_ftm); i++) |
| snd_devices_ftm[i]->id = dev_id++; |
| |
| platform_add_devices(snd_devices_ftm, |
| ARRAY_SIZE(snd_devices_ftm)); |
| } |
| |
| #ifdef CONFIG_DEBUG_FS |
| debugfs_hsed_config = debugfs_create_file("msm_hsed_config", |
| S_IFREG | S_IRUGO, NULL, |
| (void *) "msm_hsed_config", &snddev_hsed_config_debug_fops); |
| #endif |
| } |