aboutsummaryrefslogtreecommitdiffstats
path: root/sound
diff options
context:
space:
mode:
Diffstat (limited to 'sound')
-rw-r--r--sound/soc/codecs/wm8994_herring.c56
-rwxr-xr-xsound/soc/codecs/wm8994_samsung.c26
-rwxr-xr-xsound/soc/codecs/wm8994_samsung.h5
3 files changed, 84 insertions, 3 deletions
diff --git a/sound/soc/codecs/wm8994_herring.c b/sound/soc/codecs/wm8994_herring.c
index 78ec973..70f0e07 100644
--- a/sound/soc/codecs/wm8994_herring.c
+++ b/sound/soc/codecs/wm8994_herring.c
@@ -447,6 +447,40 @@ struct gain_info_t recording_gain_table[RECORDING_GAIN_NUM] = {
},
};
+struct gain_info_t gain_code_table[VOICECALL_GAIN_NUM] = {
+ { /* RCV */
+ .mode = VOICECALL_RCV | GAIN_DIVISION_BIT,
+ .reg = WM8994_LEFT_LINE_INPUT_1_2_VOLUME, /* 18h */
+ .mask = WM8994_IN1L_VOL_MASK,
+ .gain = WM8994_IN1L_VU | 0x18
+ }, {/* SPK */
+ .mode = VOICECALL_SPK | GAIN_DIVISION_BIT,
+ .reg = WM8994_LEFT_LINE_INPUT_1_2_VOLUME, /* 18h */
+ .mask = WM8994_IN1L_VOL_MASK,
+ .gain = WM8994_IN1L_VU | 0x11
+ }, {
+ .mode = VOICECALL_SPK | GAIN_DIVISION_BIT,
+ .reg = WM8994_SPEAKER_VOLUME_LEFT, /* 26h */
+ .mask = WM8994_SPKOUTL_VOL_MASK,
+ .gain = WM8994_SPKOUT_VU | 0x37
+ }, {/* HP */
+ .mode = VOICECALL_HP | GAIN_DIVISION_BIT,
+ .reg = WM8994_RIGHT_LINE_INPUT_1_2_VOLUME, /* 1Ah */
+ .mask = WM8994_IN1R_VOL_MASK,
+ .gain = WM8994_IN1R_VU | 0x1F
+ }, {
+ .mode = VOICECALL_HP | GAIN_DIVISION_BIT,
+ .reg = WM8994_LEFT_OUTPUT_VOLUME, /* 1Ch */
+ .mask = WM8994_HPOUT1L_VOL_MASK,
+ .gain = WM8994_HPOUT1_VU | 0x33
+ }, {
+ .mode = VOICECALL_HP | GAIN_DIVISION_BIT,
+ .reg = WM8994_RIGHT_OUTPUT_VOLUME, /* 1Dh */
+ .mask = WM8994_HPOUT1R_VOL_MASK,
+ .gain = WM8994_HPOUT1_VU | 0x33
+ },
+};
+
/* S5P_SLEEP_CONFIG must be controlled by codec if codec use XUSBTI */
int wm8994_configure_clock(struct snd_soc_codec *codec, int en)
{
@@ -2252,8 +2286,9 @@ void wm8994_set_voicecall_bluetooth(struct snd_soc_codec *codec)
int wm8994_set_codec_gain(struct snd_soc_codec *codec, u16 mode, u16 device)
{
+ struct wm8994_priv *wm8994 = codec->drvdata;
int i;
- int gain_set_bits = COMMON_SET_BIT;
+ u32 gain_set_bits = COMMON_SET_BIT;
u16 val;
struct gain_info_t *default_gain_table_p = NULL;
int table_num = 0;
@@ -2342,7 +2377,8 @@ int wm8994_set_codec_gain(struct snd_soc_codec *codec, u16 mode, u16 device)
}
DEBUG_LOG("Set gain mode = 0x%x, device = 0x%x, gain_bits = 0x%x,\
- table_num=%d\n", mode, device, gain_set_bits, table_num);
+ table_num=%d, gain_code = %d\n",
+ mode, device, gain_set_bits, table_num, wm8994->gain_code);
/* default gain table setting */
for (i = 0; i < table_num; i++) {
@@ -2354,6 +2390,22 @@ int wm8994_set_codec_gain(struct snd_soc_codec *codec, u16 mode, u16 device)
}
}
+ if (wm8994->gain_code) {
+ gain_set_bits &= ~(COMMON_SET_BIT);
+ gain_set_bits |= GAIN_DIVISION_BIT;
+ default_gain_table_p = gain_code_table;
+ table_num = GAIN_CODE_NUM;
+
+ for (i = 0; i < table_num; i++) {
+ if ((default_gain_table_p + i)->mode == gain_set_bits) {
+ val = wm8994_read(codec, (default_gain_table_p + i)->reg);
+ val &= ~((default_gain_table_p + i)->mask);
+ val |= (default_gain_table_p + i)->gain;
+ wm8994_write(codec, (default_gain_table_p + i)->reg, val);
+ }
+ }
+
+ }
return 0;
}
diff --git a/sound/soc/codecs/wm8994_samsung.c b/sound/soc/codecs/wm8994_samsung.c
index c872249..7eadc6a 100755
--- a/sound/soc/codecs/wm8994_samsung.c
+++ b/sound/soc/codecs/wm8994_samsung.c
@@ -133,6 +133,8 @@ select_mic_route universal_wm8994_mic_paths[] = {
select_clock_control universal_clock_controls = wm8994_configure_clock;
+int gain_code;
+
/*
* Implementation of I2C functions
*/
@@ -1190,6 +1192,28 @@ struct snd_soc_dai wm8994_dai = {
.ops = &wm8994_ops,
};
+static int __init gain_code_setup(char *str)
+{
+
+ gain_code = 0;
+
+ if (!strcmp(str, "")) {
+ pr_info("gain_code field is empty. use default value\n");
+ return 0;
+ }
+
+ if (!strcmp(str, "1"))
+ gain_code = 1;
+
+ return 0;
+}
+__setup("gain_code=", gain_code_setup);
+
+int gain_code_check(void)
+{
+ return gain_code;
+}
+
/*
* initialise the WM8994 driver
* register the mixer and dsp interfaces with the kernel
@@ -1229,6 +1253,8 @@ static int wm8994_init(struct wm8994_priv *wm8994_private,
wm8994->ringtone_active = RING_OFF;
wm8994->pdata = pdata;
+ wm8994->gain_code = gain_code_check();
+
wm8994->universal_clock_control(codec, CODEC_ON);
wm8994->codec_clk = clk_get(NULL, "usb_osc");
diff --git a/sound/soc/codecs/wm8994_samsung.h b/sound/soc/codecs/wm8994_samsung.h
index 0967f5b..a42ec56 100755
--- a/sound/soc/codecs/wm8994_samsung.h
+++ b/sound/soc/codecs/wm8994_samsung.h
@@ -49,6 +49,7 @@ extern struct snd_soc_dai wm8994_dai;
#define RECORDING_MODE (0x01 << 2)
#define FMRADIO_MODE (0x01 << 3)
+#define GAIN_DIVISION_BIT (0x01 << 16)
#define COMMON_SET_BIT (0x01 << 0)
#define PLAYBACK_RCV (0x01 << 1)
#define PLAYBACK_SPK (0x01 << 2)
@@ -74,7 +75,7 @@ extern struct snd_soc_dai wm8994_dai;
#define PLAYBACK_GAIN_NUM 39
#define VOICECALL_GAIN_NUM 26
#define RECORDING_GAIN_NUM 16
-
+#define GAIN_CODE_NUM 6
/*
* Definitions of enum type
*/
@@ -119,6 +120,7 @@ struct wm8994_priv {
select_clock_control universal_clock_control;
struct wm8994_platform_data *pdata;
struct clk *codec_clk;
+ int gain_code;
};
struct gain_info_t {
@@ -161,4 +163,5 @@ void wm8994_set_voicecall_headset(struct snd_soc_codec *codec);
void wm8994_set_voicecall_speaker(struct snd_soc_codec *codec);
void wm8994_set_voicecall_bluetooth(struct snd_soc_codec *codec);
int wm8994_set_codec_gain(struct snd_soc_codec *codec, u16 mode, u16 device);
+extern int gain_code_check(void);
#endif