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
nexedi
linux
Commits
2b48f86b
Commit
2b48f86b
authored
Oct 24, 2013
by
Mark Brown
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'asoc/topic/tlv320aic23' into asoc-next
parents
a5f0ac4a
4aa11d67
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
34 additions
and
50 deletions
+34
-50
sound/soc/codecs/tlv320aic23.c
sound/soc/codecs/tlv320aic23.c
+34
-50
No files found.
sound/soc/codecs/tlv320aic23.c
View file @
2b48f86b
...
@@ -24,6 +24,7 @@
...
@@ -24,6 +24,7 @@
#include <linux/delay.h>
#include <linux/delay.h>
#include <linux/pm.h>
#include <linux/pm.h>
#include <linux/i2c.h>
#include <linux/i2c.h>
#include <linux/regmap.h>
#include <linux/slab.h>
#include <linux/slab.h>
#include <sound/core.h>
#include <sound/core.h>
#include <sound/pcm.h>
#include <sound/pcm.h>
...
@@ -37,11 +38,27 @@
...
@@ -37,11 +38,27 @@
/*
/*
* AIC23 register cache
* AIC23 register cache
*/
*/
static
const
u16
tlv320aic23_reg
[]
=
{
static
const
struct
reg_default
tlv320aic23_reg
[]
=
{
0x0097
,
0x0097
,
0x00F9
,
0x00F9
,
/* 0 */
{
0
,
0x0097
},
0x001A
,
0x0004
,
0x0007
,
0x0001
,
/* 4 */
{
1
,
0x0097
},
0x0020
,
0x0000
,
0x0000
,
0x0000
,
/* 8 */
{
2
,
0x00F9
},
0x0000
,
0x0000
,
0x0000
,
0x0000
,
/* 12 */
{
3
,
0x00F9
},
{
4
,
0x001A
},
{
5
,
0x0004
},
{
6
,
0x0007
},
{
7
,
0x0001
},
{
8
,
0x0020
},
{
9
,
0x0000
},
};
static
const
struct
regmap_config
tlv320aic23_regmap
=
{
.
reg_bits
=
7
,
.
val_bits
=
9
,
.
max_register
=
TLV320AIC23_RESET
,
.
reg_defaults
=
tlv320aic23_reg
,
.
num_reg_defaults
=
ARRAY_SIZE
(
tlv320aic23_reg
),
.
cache_type
=
REGCACHE_RBTREE
,
};
};
static
const
char
*
rec_src_text
[]
=
{
"Line"
,
"Mic"
};
static
const
char
*
rec_src_text
[]
=
{
"Line"
,
"Mic"
};
...
@@ -171,7 +188,7 @@ static const struct snd_soc_dapm_route tlv320aic23_intercon[] = {
...
@@ -171,7 +188,7 @@ static const struct snd_soc_dapm_route tlv320aic23_intercon[] = {
/* AIC23 driver data */
/* AIC23 driver data */
struct
aic23
{
struct
aic23
{
enum
snd_soc_control_type
control_type
;
struct
regmap
*
regmap
;
int
mclk
;
int
mclk
;
int
requested_adc
;
int
requested_adc
;
int
requested_dac
;
int
requested_dac
;
...
@@ -532,7 +549,9 @@ static int tlv320aic23_suspend(struct snd_soc_codec *codec)
...
@@ -532,7 +549,9 @@ static int tlv320aic23_suspend(struct snd_soc_codec *codec)
static
int
tlv320aic23_resume
(
struct
snd_soc_codec
*
codec
)
static
int
tlv320aic23_resume
(
struct
snd_soc_codec
*
codec
)
{
{
snd_soc_cache_sync
(
codec
);
struct
aic23
*
aic23
=
snd_soc_codec_get_drvdata
(
codec
);
regcache_mark_dirty
(
aic23
->
regmap
);
regcache_sync
(
aic23
->
regmap
);
tlv320aic23_set_bias_level
(
codec
,
SND_SOC_BIAS_STANDBY
);
tlv320aic23_set_bias_level
(
codec
,
SND_SOC_BIAS_STANDBY
);
return
0
;
return
0
;
...
@@ -540,10 +559,9 @@ static int tlv320aic23_resume(struct snd_soc_codec *codec)
...
@@ -540,10 +559,9 @@ static int tlv320aic23_resume(struct snd_soc_codec *codec)
static
int
tlv320aic23_probe
(
struct
snd_soc_codec
*
codec
)
static
int
tlv320aic23_probe
(
struct
snd_soc_codec
*
codec
)
{
{
struct
aic23
*
aic23
=
snd_soc_codec_get_drvdata
(
codec
);
int
ret
;
int
ret
;
ret
=
snd_soc_codec_set_cache_io
(
codec
,
7
,
9
,
aic23
->
control_type
);
ret
=
snd_soc_codec_set_cache_io
(
codec
,
7
,
9
,
SND_SOC_REGMAP
);
if
(
ret
<
0
)
{
if
(
ret
<
0
)
{
dev_err
(
codec
->
dev
,
"Failed to set cache I/O: %d
\n
"
,
ret
);
dev_err
(
codec
->
dev
,
"Failed to set cache I/O: %d
\n
"
,
ret
);
return
ret
;
return
ret
;
...
@@ -552,16 +570,6 @@ static int tlv320aic23_probe(struct snd_soc_codec *codec)
...
@@ -552,16 +570,6 @@ static int tlv320aic23_probe(struct snd_soc_codec *codec)
/* Reset codec */
/* Reset codec */
snd_soc_write
(
codec
,
TLV320AIC23_RESET
,
0
);
snd_soc_write
(
codec
,
TLV320AIC23_RESET
,
0
);
/* Write the register default value to cache for reserved registers,
* so the write to the these registers are suppressed by the cache
* restore code when it skips writes of default registers.
*/
snd_soc_cache_write
(
codec
,
0x0A
,
0
);
snd_soc_cache_write
(
codec
,
0x0B
,
0
);
snd_soc_cache_write
(
codec
,
0x0C
,
0
);
snd_soc_cache_write
(
codec
,
0x0D
,
0
);
snd_soc_cache_write
(
codec
,
0x0E
,
0
);
/* power on device */
/* power on device */
tlv320aic23_set_bias_level
(
codec
,
SND_SOC_BIAS_STANDBY
);
tlv320aic23_set_bias_level
(
codec
,
SND_SOC_BIAS_STANDBY
);
...
@@ -586,9 +594,6 @@ static int tlv320aic23_probe(struct snd_soc_codec *codec)
...
@@ -586,9 +594,6 @@ static int tlv320aic23_probe(struct snd_soc_codec *codec)
snd_soc_write
(
codec
,
TLV320AIC23_ACTIVE
,
0x1
);
snd_soc_write
(
codec
,
TLV320AIC23_ACTIVE
,
0x1
);
snd_soc_add_codec_controls
(
codec
,
tlv320aic23_snd_controls
,
ARRAY_SIZE
(
tlv320aic23_snd_controls
));
return
0
;
return
0
;
}
}
...
@@ -599,21 +604,19 @@ static int tlv320aic23_remove(struct snd_soc_codec *codec)
...
@@ -599,21 +604,19 @@ static int tlv320aic23_remove(struct snd_soc_codec *codec)
}
}
static
struct
snd_soc_codec_driver
soc_codec_dev_tlv320aic23
=
{
static
struct
snd_soc_codec_driver
soc_codec_dev_tlv320aic23
=
{
.
reg_cache_size
=
ARRAY_SIZE
(
tlv320aic23_reg
),
.
reg_word_size
=
sizeof
(
u16
),
.
reg_cache_default
=
tlv320aic23_reg
,
.
probe
=
tlv320aic23_probe
,
.
probe
=
tlv320aic23_probe
,
.
remove
=
tlv320aic23_remove
,
.
remove
=
tlv320aic23_remove
,
.
suspend
=
tlv320aic23_suspend
,
.
suspend
=
tlv320aic23_suspend
,
.
resume
=
tlv320aic23_resume
,
.
resume
=
tlv320aic23_resume
,
.
set_bias_level
=
tlv320aic23_set_bias_level
,
.
set_bias_level
=
tlv320aic23_set_bias_level
,
.
controls
=
tlv320aic23_snd_controls
,
.
num_controls
=
ARRAY_SIZE
(
tlv320aic23_snd_controls
),
.
dapm_widgets
=
tlv320aic23_dapm_widgets
,
.
dapm_widgets
=
tlv320aic23_dapm_widgets
,
.
num_dapm_widgets
=
ARRAY_SIZE
(
tlv320aic23_dapm_widgets
),
.
num_dapm_widgets
=
ARRAY_SIZE
(
tlv320aic23_dapm_widgets
),
.
dapm_routes
=
tlv320aic23_intercon
,
.
dapm_routes
=
tlv320aic23_intercon
,
.
num_dapm_routes
=
ARRAY_SIZE
(
tlv320aic23_intercon
),
.
num_dapm_routes
=
ARRAY_SIZE
(
tlv320aic23_intercon
),
};
};
#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
/*
/*
* If the i2c layer weren't so broken, we could pass this kind of data
* If the i2c layer weren't so broken, we could pass this kind of data
* around
* around
...
@@ -631,8 +634,11 @@ static int tlv320aic23_codec_probe(struct i2c_client *i2c,
...
@@ -631,8 +634,11 @@ static int tlv320aic23_codec_probe(struct i2c_client *i2c,
if
(
aic23
==
NULL
)
if
(
aic23
==
NULL
)
return
-
ENOMEM
;
return
-
ENOMEM
;
aic23
->
regmap
=
devm_regmap_init_i2c
(
i2c
,
&
tlv320aic23_regmap
);
if
(
IS_ERR
(
aic23
->
regmap
))
return
PTR_ERR
(
aic23
->
regmap
);
i2c_set_clientdata
(
i2c
,
aic23
);
i2c_set_clientdata
(
i2c
,
aic23
);
aic23
->
control_type
=
SND_SOC_I2C
;
ret
=
snd_soc_register_codec
(
&
i2c
->
dev
,
ret
=
snd_soc_register_codec
(
&
i2c
->
dev
,
&
soc_codec_dev_tlv320aic23
,
&
tlv320aic23_dai
,
1
);
&
soc_codec_dev_tlv320aic23
,
&
tlv320aic23_dai
,
1
);
...
@@ -660,29 +666,7 @@ static struct i2c_driver tlv320aic23_i2c_driver = {
...
@@ -660,29 +666,7 @@ static struct i2c_driver tlv320aic23_i2c_driver = {
.
id_table
=
tlv320aic23_id
,
.
id_table
=
tlv320aic23_id
,
};
};
#endif
module_i2c_driver
(
tlv320aic23_i2c_driver
);
static
int
__init
tlv320aic23_modinit
(
void
)
{
int
ret
;
#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
ret
=
i2c_add_driver
(
&
tlv320aic23_i2c_driver
);
if
(
ret
!=
0
)
{
printk
(
KERN_ERR
"Failed to register TLV320AIC23 I2C driver: %d
\n
"
,
ret
);
}
#endif
return
ret
;
}
module_init
(
tlv320aic23_modinit
);
static
void
__exit
tlv320aic23_exit
(
void
)
{
#if defined(CONFIG_I2C) || defined(CONFIG_I2C_MODULE)
i2c_del_driver
(
&
tlv320aic23_i2c_driver
);
#endif
}
module_exit
(
tlv320aic23_exit
);
MODULE_DESCRIPTION
(
"ASoC TLV320AIC23 codec driver"
);
MODULE_DESCRIPTION
(
"ASoC TLV320AIC23 codec driver"
);
MODULE_AUTHOR
(
"Arun KS <arunks@mistralsolutions.com>"
);
MODULE_AUTHOR
(
"Arun KS <arunks@mistralsolutions.com>"
);
...
...
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