Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
3d0be4a5
Commit
3d0be4a5
authored
Nov 08, 2013
by
Mark Brown
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'asoc/topic/88pm860x' into asoc-next
parents
3fec948e
f9ded3b2
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
71 additions
and
121 deletions
+71
-121
sound/soc/codecs/88pm860x-codec.c
sound/soc/codecs/88pm860x-codec.c
+13
-62
sound/soc/codecs/88pm860x-codec.h
sound/soc/codecs/88pm860x-codec.h
+58
-59
No files found.
sound/soc/codecs/88pm860x-codec.c
View file @
3d0be4a5
...
...
@@ -16,6 +16,7 @@
#include <linux/mfd/88pm860x.h>
#include <linux/slab.h>
#include <linux/delay.h>
#include <linux/regmap.h>
#include <sound/core.h>
#include <sound/pcm.h>
#include <sound/pcm_params.h>
...
...
@@ -140,6 +141,7 @@ struct pm860x_priv {
unsigned
int
filter
;
struct
snd_soc_codec
*
codec
;
struct
i2c_client
*
i2c
;
struct
regmap
*
regmap
;
struct
pm860x_chip
*
chip
;
struct
pm860x_det
det
;
...
...
@@ -269,48 +271,6 @@ static struct st_gain st_table[] = {
{
-
86
,
29
,
0
},
{
-
56
,
30
,
0
},
{
-
28
,
31
,
0
},
{
0
,
0
,
0
},
};
static
int
pm860x_volatile
(
unsigned
int
reg
)
{
BUG_ON
(
reg
>=
REG_CACHE_SIZE
);
switch
(
reg
)
{
case
PM860X_AUDIO_SUPPLIES_2
:
return
1
;
}
return
0
;
}
static
unsigned
int
pm860x_read_reg_cache
(
struct
snd_soc_codec
*
codec
,
unsigned
int
reg
)
{
unsigned
char
*
cache
=
codec
->
reg_cache
;
BUG_ON
(
reg
>=
REG_CACHE_SIZE
);
if
(
pm860x_volatile
(
reg
))
return
cache
[
reg
];
reg
+=
REG_CACHE_BASE
;
return
pm860x_reg_read
(
codec
->
control_data
,
reg
);
}
static
int
pm860x_write_reg_cache
(
struct
snd_soc_codec
*
codec
,
unsigned
int
reg
,
unsigned
int
value
)
{
unsigned
char
*
cache
=
codec
->
reg_cache
;
BUG_ON
(
reg
>=
REG_CACHE_SIZE
);
if
(
!
pm860x_volatile
(
reg
))
cache
[
reg
]
=
(
unsigned
char
)
value
;
reg
+=
REG_CACHE_BASE
;
return
pm860x_reg_write
(
codec
->
control_data
,
reg
,
value
);
}
static
int
snd_soc_get_volsw_2r_st
(
struct
snd_kcontrol
*
kcontrol
,
struct
snd_ctl_elem_value
*
ucontrol
)
{
...
...
@@ -1169,6 +1129,7 @@ static int pm860x_i2s_set_dai_fmt(struct snd_soc_dai *codec_dai,
static
int
pm860x_set_bias_level
(
struct
snd_soc_codec
*
codec
,
enum
snd_soc_bias_level
level
)
{
struct
pm860x_priv
*
pm860x
=
snd_soc_codec_get_drvdata
(
codec
);
int
data
;
switch
(
level
)
{
...
...
@@ -1182,17 +1143,17 @@ static int pm860x_set_bias_level(struct snd_soc_codec *codec,
if
(
codec
->
dapm
.
bias_level
==
SND_SOC_BIAS_OFF
)
{
/* Enable Audio PLL & Audio section */
data
=
AUDIO_PLL
|
AUDIO_SECTION_ON
;
pm860x_reg_write
(
codec
->
control_data
,
REG_MISC2
,
data
);
pm860x_reg_write
(
pm860x
->
i2c
,
REG_MISC2
,
data
);
udelay
(
300
);
data
=
AUDIO_PLL
|
AUDIO_SECTION_RESET
|
AUDIO_SECTION_ON
;
pm860x_reg_write
(
codec
->
control_data
,
REG_MISC2
,
data
);
pm860x_reg_write
(
pm860x
->
i2c
,
REG_MISC2
,
data
);
}
break
;
case
SND_SOC_BIAS_OFF
:
data
=
AUDIO_PLL
|
AUDIO_SECTION_RESET
|
AUDIO_SECTION_ON
;
pm860x_set_bits
(
codec
->
control_data
,
REG_MISC2
,
data
,
0
);
pm860x_set_bits
(
pm860x
->
i2c
,
REG_MISC2
,
data
,
0
);
break
;
}
codec
->
dapm
.
bias_level
=
level
;
...
...
@@ -1322,17 +1283,17 @@ int pm860x_hs_jack_detect(struct snd_soc_codec *codec,
pm860x
->
det
.
lo_shrt
=
lo_shrt
;
if
(
det
&
SND_JACK_HEADPHONE
)
pm860x_set_bits
(
codec
->
control_data
,
REG_HS_DET
,
pm860x_set_bits
(
pm860x
->
i2c
,
REG_HS_DET
,
EN_HS_DET
,
EN_HS_DET
);
/* headset short detect */
if
(
hs_shrt
)
{
data
=
CLR_SHORT_HS2
|
CLR_SHORT_HS1
;
pm860x_set_bits
(
codec
->
control_data
,
REG_SHORTS
,
data
,
data
);
pm860x_set_bits
(
pm860x
->
i2c
,
REG_SHORTS
,
data
,
data
);
}
/* Lineout short detect */
if
(
lo_shrt
)
{
data
=
CLR_SHORT_LO2
|
CLR_SHORT_LO1
;
pm860x_set_bits
(
codec
->
control_data
,
REG_SHORTS
,
data
,
data
);
pm860x_set_bits
(
pm860x
->
i2c
,
REG_SHORTS
,
data
,
data
);
}
/* sync status */
...
...
@@ -1350,7 +1311,7 @@ int pm860x_mic_jack_detect(struct snd_soc_codec *codec,
pm860x
->
det
.
mic_det
=
det
;
if
(
det
&
SND_JACK_MICROPHONE
)
pm860x_set_bits
(
codec
->
control_data
,
REG_MIC_DET
,
pm860x_set_bits
(
pm860x
->
i2c
,
REG_MIC_DET
,
MICDET_MASK
,
MICDET_MASK
);
/* sync status */
...
...
@@ -1366,7 +1327,7 @@ static int pm860x_probe(struct snd_soc_codec *codec)
pm860x
->
codec
=
codec
;
codec
->
control_data
=
pm860x
->
i2c
;
codec
->
control_data
=
pm860x
->
regmap
;
for
(
i
=
0
;
i
<
4
;
i
++
)
{
ret
=
request_threaded_irq
(
pm860x
->
irq
[
i
],
NULL
,
...
...
@@ -1380,14 +1341,6 @@ static int pm860x_probe(struct snd_soc_codec *codec)
pm860x_set_bias_level
(
codec
,
SND_SOC_BIAS_STANDBY
);
ret
=
pm860x_bulk_read
(
codec
->
control_data
,
REG_CACHE_BASE
,
REG_CACHE_SIZE
,
codec
->
reg_cache
);
if
(
ret
<
0
)
{
dev_err
(
codec
->
dev
,
"Failed to fill register cache: %d
\n
"
,
ret
);
goto
out
;
}
return
0
;
out:
...
...
@@ -1410,10 +1363,6 @@ static int pm860x_remove(struct snd_soc_codec *codec)
static
struct
snd_soc_codec_driver
soc_codec_dev_pm860x
=
{
.
probe
=
pm860x_probe
,
.
remove
=
pm860x_remove
,
.
read
=
pm860x_read_reg_cache
,
.
write
=
pm860x_write_reg_cache
,
.
reg_cache_size
=
REG_CACHE_SIZE
,
.
reg_word_size
=
sizeof
(
u8
),
.
set_bias_level
=
pm860x_set_bias_level
,
.
controls
=
pm860x_snd_controls
,
...
...
@@ -1439,6 +1388,8 @@ static int pm860x_codec_probe(struct platform_device *pdev)
pm860x
->
chip
=
chip
;
pm860x
->
i2c
=
(
chip
->
id
==
CHIP_PM8607
)
?
chip
->
client
:
chip
->
companion
;
pm860x
->
regmap
=
(
chip
->
id
==
CHIP_PM8607
)
?
chip
->
regmap
:
chip
->
regmap_companion
;
platform_set_drvdata
(
pdev
,
pm860x
);
for
(
i
=
0
;
i
<
4
;
i
++
)
{
...
...
sound/soc/codecs/88pm860x-codec.h
View file @
3d0be4a5
...
...
@@ -12,67 +12,66 @@
#ifndef __88PM860X_H
#define __88PM860X_H
/* The offset of these registers are 0xb0 */
#define PM860X_PCM_IFACE_1 0x00
#define PM860X_PCM_IFACE_2 0x01
#define PM860X_PCM_IFACE_3 0x02
#define PM860X_PCM_RATE 0x03
#define PM860X_EC_PATH 0x04
#define PM860X_SIDETONE_L_GAIN 0x05
#define PM860X_SIDETONE_R_GAIN 0x06
#define PM860X_SIDETONE_SHIFT 0x07
#define PM860X_ADC_OFFSET_1 0x08
#define PM860X_ADC_OFFSET_2 0x09
#define PM860X_DMIC_DELAY 0x0a
#define PM860X_PCM_IFACE_1 0xb0
#define PM860X_PCM_IFACE_2 0xb1
#define PM860X_PCM_IFACE_3 0xb2
#define PM860X_PCM_RATE 0xb3
#define PM860X_EC_PATH 0xb4
#define PM860X_SIDETONE_L_GAIN 0xb5
#define PM860X_SIDETONE_R_GAIN 0xb6
#define PM860X_SIDETONE_SHIFT 0xb7
#define PM860X_ADC_OFFSET_1 0xb8
#define PM860X_ADC_OFFSET_2 0xb9
#define PM860X_DMIC_DELAY 0xba
#define PM860X_I2S_IFACE_1 0x
0
b
#define PM860X_I2S_IFACE_2 0x
0
c
#define PM860X_I2S_IFACE_3 0x
0
d
#define PM860X_I2S_IFACE_4 0x
0
e
#define PM860X_EQUALIZER_N0_1 0x
0
f
#define PM860X_EQUALIZER_N0_2 0x
1
0
#define PM860X_EQUALIZER_N1_1 0x
1
1
#define PM860X_EQUALIZER_N1_2 0x
1
2
#define PM860X_EQUALIZER_D1_1 0x
1
3
#define PM860X_EQUALIZER_D1_2 0x
1
4
#define PM860X_LOFI_GAIN_LEFT 0x
1
5
#define PM860X_LOFI_GAIN_RIGHT 0x
1
6
#define PM860X_HIFIL_GAIN_LEFT 0x
1
7
#define PM860X_HIFIL_GAIN_RIGHT 0x
1
8
#define PM860X_HIFIR_GAIN_LEFT 0x
1
9
#define PM860X_HIFIR_GAIN_RIGHT 0x
1
a
#define PM860X_DAC_OFFSET 0x
1
b
#define PM860X_OFFSET_LEFT_1 0x
1
c
#define PM860X_OFFSET_LEFT_2 0x
1
d
#define PM860X_OFFSET_RIGHT_1 0x
1
e
#define PM860X_OFFSET_RIGHT_2 0x
1
f
#define PM860X_ADC_ANA_1 0x
2
0
#define PM860X_ADC_ANA_2 0x
2
1
#define PM860X_ADC_ANA_3 0x
2
2
#define PM860X_ADC_ANA_4 0x
2
3
#define PM860X_ANA_TO_ANA 0x
2
4
#define PM860X_HS1_CTRL 0x
2
5
#define PM860X_HS2_CTRL 0x
2
6
#define PM860X_LO1_CTRL 0x
2
7
#define PM860X_LO2_CTRL 0x
2
8
#define PM860X_EAR_CTRL_1 0x
2
9
#define PM860X_EAR_CTRL_2 0x
2
a
#define PM860X_AUDIO_SUPPLIES_1 0x
2
b
#define PM860X_AUDIO_SUPPLIES_2 0x
2
c
#define PM860X_ADC_EN_1 0x
2
d
#define PM860X_ADC_EN_2 0x
2
e
#define PM860X_DAC_EN_1 0x
2
f
#define PM860X_DAC_EN_2 0x
3
1
#define PM860X_AUDIO_CAL_1 0x
3
2
#define PM860X_AUDIO_CAL_2 0x
3
3
#define PM860X_AUDIO_CAL_3 0x
3
4
#define PM860X_AUDIO_CAL_4 0x
3
5
#define PM860X_AUDIO_CAL_5 0x
3
6
#define PM860X_ANA_INPUT_SEL_1 0x
3
7
#define PM860X_ANA_INPUT_SEL_2 0x
3
8
#define PM860X_I2S_IFACE_1 0x
b
b
#define PM860X_I2S_IFACE_2 0x
b
c
#define PM860X_I2S_IFACE_3 0x
b
d
#define PM860X_I2S_IFACE_4 0x
b
e
#define PM860X_EQUALIZER_N0_1 0x
b
f
#define PM860X_EQUALIZER_N0_2 0x
c
0
#define PM860X_EQUALIZER_N1_1 0x
c
1
#define PM860X_EQUALIZER_N1_2 0x
c
2
#define PM860X_EQUALIZER_D1_1 0x
c
3
#define PM860X_EQUALIZER_D1_2 0x
c
4
#define PM860X_LOFI_GAIN_LEFT 0x
c
5
#define PM860X_LOFI_GAIN_RIGHT 0x
c
6
#define PM860X_HIFIL_GAIN_LEFT 0x
c
7
#define PM860X_HIFIL_GAIN_RIGHT 0x
c
8
#define PM860X_HIFIR_GAIN_LEFT 0x
c
9
#define PM860X_HIFIR_GAIN_RIGHT 0x
c
a
#define PM860X_DAC_OFFSET 0x
c
b
#define PM860X_OFFSET_LEFT_1 0x
c
c
#define PM860X_OFFSET_LEFT_2 0x
c
d
#define PM860X_OFFSET_RIGHT_1 0x
c
e
#define PM860X_OFFSET_RIGHT_2 0x
c
f
#define PM860X_ADC_ANA_1 0x
d
0
#define PM860X_ADC_ANA_2 0x
d
1
#define PM860X_ADC_ANA_3 0x
d
2
#define PM860X_ADC_ANA_4 0x
d
3
#define PM860X_ANA_TO_ANA 0x
d
4
#define PM860X_HS1_CTRL 0x
d
5
#define PM860X_HS2_CTRL 0x
d
6
#define PM860X_LO1_CTRL 0x
d
7
#define PM860X_LO2_CTRL 0x
d
8
#define PM860X_EAR_CTRL_1 0x
d
9
#define PM860X_EAR_CTRL_2 0x
d
a
#define PM860X_AUDIO_SUPPLIES_1 0x
d
b
#define PM860X_AUDIO_SUPPLIES_2 0x
d
c
#define PM860X_ADC_EN_1 0x
d
d
#define PM860X_ADC_EN_2 0x
d
e
#define PM860X_DAC_EN_1 0x
d
f
#define PM860X_DAC_EN_2 0x
e
1
#define PM860X_AUDIO_CAL_1 0x
e
2
#define PM860X_AUDIO_CAL_2 0x
e
3
#define PM860X_AUDIO_CAL_3 0x
e
4
#define PM860X_AUDIO_CAL_4 0x
e
5
#define PM860X_AUDIO_CAL_5 0x
e
6
#define PM860X_ANA_INPUT_SEL_1 0x
e
7
#define PM860X_ANA_INPUT_SEL_2 0x
e
8
#define PM860X_PCM_IFACE_4 0x
3
9
#define PM860X_I2S_IFACE_5 0x
3
a
#define PM860X_PCM_IFACE_4 0x
e
9
#define PM860X_I2S_IFACE_5 0x
e
a
#define PM860X_SHORTS 0x3b
#define PM860X_PLL_ADJ_1 0x3c
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment