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
022aa51e
Commit
022aa51e
authored
Nov 08, 2013
by
Mark Brown
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'asoc/topic/twl6040' into asoc-next
parents
88cb5111
290c348e
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
7 additions
and
19 deletions
+7
-19
sound/soc/codecs/twl6040.c
sound/soc/codecs/twl6040.c
+7
-19
No files found.
sound/soc/codecs/twl6040.c
View file @
022aa51e
...
@@ -54,12 +54,7 @@ enum twl6040_dai_id {
...
@@ -54,12 +54,7 @@ enum twl6040_dai_id {
#define TWL6040_OUTHF_0dB 0x03
#define TWL6040_OUTHF_0dB 0x03
#define TWL6040_OUTHF_M52dB 0x1D
#define TWL6040_OUTHF_M52dB 0x1D
/* Shadow register used by the driver */
#define TWL6040_CACHEREGNUM (TWL6040_REG_STATUS + 1)
#define TWL6040_REG_SW_SHADOW 0x2F
#define TWL6040_CACHEREGNUM (TWL6040_REG_SW_SHADOW + 1)
/* TWL6040_REG_SW_SHADOW (0x2F) fields */
#define TWL6040_EAR_PATH_ENABLE 0x01
struct
twl6040_jack_data
{
struct
twl6040_jack_data
{
struct
snd_soc_jack
*
jack
;
struct
snd_soc_jack
*
jack
;
...
@@ -135,8 +130,6 @@ static const u8 twl6040_reg[TWL6040_CACHEREGNUM] = {
...
@@ -135,8 +130,6 @@ static const u8 twl6040_reg[TWL6040_CACHEREGNUM] = {
0x00
,
/* REG_HFOTRIM 0x2C */
0x00
,
/* REG_HFOTRIM 0x2C */
0x09
,
/* REG_ACCCTL 0x2D */
0x09
,
/* REG_ACCCTL 0x2D */
0x00
,
/* REG_STATUS 0x2E (ro) */
0x00
,
/* REG_STATUS 0x2E (ro) */
0x00
,
/* REG_SW_SHADOW 0x2F - Shadow, non HW register */
};
};
/* List of registers to be restored after power up */
/* List of registers to be restored after power up */
...
@@ -220,12 +213,8 @@ static int twl6040_read_reg_volatile(struct snd_soc_codec *codec,
...
@@ -220,12 +213,8 @@ static int twl6040_read_reg_volatile(struct snd_soc_codec *codec,
if
(
reg
>=
TWL6040_CACHEREGNUM
)
if
(
reg
>=
TWL6040_CACHEREGNUM
)
return
-
EIO
;
return
-
EIO
;
if
(
likely
(
reg
<
TWL6040_REG_SW_SHADOW
))
{
value
=
twl6040_reg_read
(
twl6040
,
reg
);
value
=
twl6040_reg_read
(
twl6040
,
reg
);
twl6040_write_reg_cache
(
codec
,
reg
,
value
);
twl6040_write_reg_cache
(
codec
,
reg
,
value
);
}
else
{
value
=
twl6040_read_reg_cache
(
codec
,
reg
);
}
return
value
;
return
value
;
}
}
...
@@ -246,7 +235,7 @@ static bool twl6040_is_path_unmuted(struct snd_soc_codec *codec,
...
@@ -246,7 +235,7 @@ static bool twl6040_is_path_unmuted(struct snd_soc_codec *codec,
return
priv
->
dl2_unmuted
;
return
priv
->
dl2_unmuted
;
default:
default:
return
1
;
return
1
;
}
;
}
}
}
/*
/*
...
@@ -261,8 +250,7 @@ static int twl6040_write(struct snd_soc_codec *codec,
...
@@ -261,8 +250,7 @@ static int twl6040_write(struct snd_soc_codec *codec,
return
-
EIO
;
return
-
EIO
;
twl6040_write_reg_cache
(
codec
,
reg
,
value
);
twl6040_write_reg_cache
(
codec
,
reg
,
value
);
if
(
likely
(
reg
<
TWL6040_REG_SW_SHADOW
)
&&
if
(
twl6040_is_path_unmuted
(
codec
,
reg
))
twl6040_is_path_unmuted
(
codec
,
reg
))
return
twl6040_reg_write
(
twl6040
,
reg
,
value
);
return
twl6040_reg_write
(
twl6040
,
reg
,
value
);
else
else
return
0
;
return
0
;
...
@@ -555,7 +543,7 @@ static const struct snd_kcontrol_new hfr_mux_controls =
...
@@ -555,7 +543,7 @@ static const struct snd_kcontrol_new hfr_mux_controls =
SOC_DAPM_ENUM
(
"Route"
,
twl6040_hf_enum
[
1
]);
SOC_DAPM_ENUM
(
"Route"
,
twl6040_hf_enum
[
1
]);
static
const
struct
snd_kcontrol_new
ep_path_enable_control
=
static
const
struct
snd_kcontrol_new
ep_path_enable_control
=
SOC_DAPM_SINGLE
(
"Switch"
,
TWL6040_REG_SW_SHADOW
,
0
,
1
,
0
);
SOC_DAPM_SINGLE
_VIRT
(
"Switch"
,
1
);
static
const
struct
snd_kcontrol_new
auxl_switch_control
=
static
const
struct
snd_kcontrol_new
auxl_switch_control
=
SOC_DAPM_SINGLE
(
"Switch"
,
TWL6040_REG_HFLCTL
,
6
,
1
,
0
);
SOC_DAPM_SINGLE
(
"Switch"
,
TWL6040_REG_HFLCTL
,
6
,
1
,
0
);
...
@@ -1100,7 +1088,7 @@ static void twl6040_mute_path(struct snd_soc_codec *codec, enum twl6040_dai_id i
...
@@ -1100,7 +1088,7 @@ static void twl6040_mute_path(struct snd_soc_codec *codec, enum twl6040_dai_id i
break
;
break
;
default:
default:
break
;
break
;
}
;
}
}
}
static
int
twl6040_digital_mute
(
struct
snd_soc_dai
*
dai
,
int
mute
)
static
int
twl6040_digital_mute
(
struct
snd_soc_dai
*
dai
,
int
mute
)
...
...
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