Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
57ada4c5
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
57ada4c5
编写于
11年前
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'asoc/topic/ab8500' into asoc-next
上级
3d0be4a5
166a34d2
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
45 addition
and
47 deletion
+45
-47
sound/soc/codecs/ab8500-codec.c
sound/soc/codecs/ab8500-codec.c
+45
-47
未找到文件。
sound/soc/codecs/ab8500-codec.c
浏览文件 @
57ada4c5
...
...
@@ -126,6 +126,8 @@ struct ab8500_codec_drvdata_dbg {
/* Private data for AB8500 device-driver */
struct
ab8500_codec_drvdata
{
struct
regmap
*
regmap
;
/* Sidetone */
long
*
sid_fir_values
;
enum
sid_state
sid_status
;
...
...
@@ -166,49 +168,35 @@ static inline const char *amic_type_str(enum amic_type type)
*/
/* Read a register from the audio-bank of AB8500 */
static
unsigned
int
ab8500_codec_read_reg
(
struct
snd_soc_codec
*
codec
,
unsigned
int
reg
)
static
int
ab8500_codec_read_reg
(
void
*
context
,
unsigned
int
reg
,
unsigned
int
*
value
)
{
struct
device
*
dev
=
context
;
int
status
;
unsigned
int
value
=
0
;
u8
value8
;
status
=
abx500_get_register_interruptible
(
codec
->
dev
,
AB8500_AUDIO
,
status
=
abx500_get_register_interruptible
(
dev
,
AB8500_AUDIO
,
reg
,
&
value8
);
if
(
status
<
0
)
{
dev_err
(
codec
->
dev
,
"%s: ERROR: Register (0x%02x:0x%02x) read failed (%d).
\n
"
,
__func__
,
(
u8
)
AB8500_AUDIO
,
(
u8
)
reg
,
status
);
}
else
{
dev_dbg
(
codec
->
dev
,
"%s: Read 0x%02x from register 0x%02x:0x%02x
\n
"
,
__func__
,
value8
,
(
u8
)
AB8500_AUDIO
,
(
u8
)
reg
);
value
=
(
unsigned
int
)
value8
;
}
*
value
=
(
unsigned
int
)
value8
;
return
value
;
return
status
;
}
/* Write to a register in the audio-bank of AB8500 */
static
int
ab8500_codec_write_reg
(
struct
snd_soc_codec
*
codec
,
unsigned
int
reg
,
unsigned
int
value
)
static
int
ab8500_codec_write_reg
(
void
*
context
,
unsigned
int
reg
,
unsigned
int
value
)
{
int
status
;
struct
device
*
dev
=
context
;
status
=
abx500_set_register_interruptible
(
codec
->
dev
,
AB8500_AUDIO
,
return
abx500_set_register_interruptible
(
dev
,
AB8500_AUDIO
,
reg
,
value
);
if
(
status
<
0
)
dev_err
(
codec
->
dev
,
"%s: ERROR: Register (%02x:%02x) write failed (%d).
\n
"
,
__func__
,
(
u8
)
AB8500_AUDIO
,
(
u8
)
reg
,
status
);
else
dev_dbg
(
codec
->
dev
,
"%s: Wrote 0x%02x into register %02x:%02x
\n
"
,
__func__
,
(
u8
)
value
,
(
u8
)
AB8500_AUDIO
,
(
u8
)
reg
);
return
status
;
}
static
const
struct
regmap_config
ab8500_codec_regmap
=
{
.
reg_read
=
ab8500_codec_read_reg
,
.
reg_write
=
ab8500_codec_write_reg
,
};
/*
* Controls - DAPM
*/
...
...
@@ -2312,17 +2300,17 @@ static int ab8500_codec_set_dai_tdm_slot(struct snd_soc_dai *dai,
case
0
:
break
;
case
1
:
slot
=
f
ind_first_bit
((
unsigned
long
*
)
&
tx_mask
,
32
);
slot
=
f
fs
(
tx_mask
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF1
,
mask
,
slot
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF3
,
mask
,
slot
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF2
,
mask
,
slot
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF4
,
mask
,
slot
);
break
;
case
2
:
slot
=
f
ind_first_bit
((
unsigned
long
*
)
&
tx_mask
,
32
);
slot
=
f
fs
(
tx_mask
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF1
,
mask
,
slot
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF3
,
mask
,
slot
);
slot
=
f
ind_next_bit
((
unsigned
long
*
)
&
tx_mask
,
32
,
slot
+
1
);
slot
=
f
ls
(
tx_mask
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF2
,
mask
,
slot
);
snd_soc_update_bits
(
codec
,
AB8500_DASLOTCONF4
,
mask
,
slot
);
break
;
...
...
@@ -2353,18 +2341,18 @@ static int ab8500_codec_set_dai_tdm_slot(struct snd_soc_dai *dai,
case
0
:
break
;
case
1
:
slot
=
f
ind_first_bit
((
unsigned
long
*
)
&
rx_mask
,
32
);
slot
=
f
fs
(
rx_mask
);
snd_soc_update_bits
(
codec
,
AB8500_ADSLOTSEL
(
slot
),
AB8500_MASK_SLOT
(
slot
),
AB8500_ADSLOTSELX_AD_OUT_TO_SLOT
(
AB8500_AD_OUT3
,
slot
));
break
;
case
2
:
slot
=
f
ind_first_bit
((
unsigned
long
*
)
&
rx_mask
,
32
);
slot
=
f
fs
(
rx_mask
);
snd_soc_update_bits
(
codec
,
AB8500_ADSLOTSEL
(
slot
),
AB8500_MASK_SLOT
(
slot
),
AB8500_ADSLOTSELX_AD_OUT_TO_SLOT
(
AB8500_AD_OUT3
,
slot
));
slot
=
f
ind_next_bit
((
unsigned
long
*
)
&
rx_mask
,
32
,
slot
+
1
);
slot
=
f
ls
(
rx_mask
);
snd_soc_update_bits
(
codec
,
AB8500_ADSLOTSEL
(
slot
),
AB8500_MASK_SLOT
(
slot
),
...
...
@@ -2485,9 +2473,13 @@ static int ab8500_codec_probe(struct snd_soc_codec *codec)
dev_dbg
(
dev
,
"%s: Enter.
\n
"
,
__func__
);
snd_soc_codec_set_cache_io
(
codec
,
0
,
0
,
SND_SOC_REGMAP
);
/* Setup AB8500 according to board-settings */
pdata
=
dev_get_platdata
(
dev
->
parent
);
codec
->
control_data
=
drvdata
->
regmap
;
if
(
np
)
{
if
(
!
pdata
)
pdata
=
devm_kzalloc
(
dev
,
...
...
@@ -2532,11 +2524,9 @@ static int ab8500_codec_probe(struct snd_soc_codec *codec)
}
/* Override HW-defaults */
ab8500_codec_write_reg
(
codec
,
AB8500_ANACONF5
,
snd_soc_write
(
codec
,
AB8500_ANACONF5
,
BIT
(
AB8500_ANACONF5_HSAUTOEN
));
ab8500_codec_write_reg
(
codec
,
AB8500_SHORTCIRCONF
,
snd_soc_write
(
codec
,
AB8500_SHORTCIRCONF
,
BIT
(
AB8500_SHORTCIRCONF_HSZCDDIS
));
/* Add filter controls */
...
...
@@ -2567,9 +2557,6 @@ static int ab8500_codec_probe(struct snd_soc_codec *codec)
static
struct
snd_soc_codec_driver
ab8500_codec_driver
=
{
.
probe
=
ab8500_codec_probe
,
.
read
=
ab8500_codec_read_reg
,
.
write
=
ab8500_codec_write_reg
,
.
reg_word_size
=
sizeof
(
u8
),
.
controls
=
ab8500_ctrls
,
.
num_controls
=
ARRAY_SIZE
(
ab8500_ctrls
),
.
dapm_widgets
=
ab8500_dapm_widgets
,
...
...
@@ -2588,10 +2575,21 @@ static int ab8500_codec_driver_probe(struct platform_device *pdev)
/* Create driver private-data struct */
drvdata
=
devm_kzalloc
(
&
pdev
->
dev
,
sizeof
(
struct
ab8500_codec_drvdata
),
GFP_KERNEL
);
if
(
!
drvdata
)
return
-
ENOMEM
;
drvdata
->
sid_status
=
SID_UNCONFIGURED
;
drvdata
->
anc_status
=
ANC_UNCONFIGURED
;
dev_set_drvdata
(
&
pdev
->
dev
,
drvdata
);
drvdata
->
regmap
=
devm_regmap_init
(
&
pdev
->
dev
,
NULL
,
&
pdev
->
dev
,
&
ab8500_codec_regmap
);
if
(
IS_ERR
(
drvdata
->
regmap
))
{
status
=
PTR_ERR
(
drvdata
->
regmap
);
dev_err
(
&
pdev
->
dev
,
"%s: Failed to allocate regmap: %d
\n
"
,
__func__
,
status
);
return
status
;
}
dev_dbg
(
&
pdev
->
dev
,
"%s: Register codec.
\n
"
,
__func__
);
status
=
snd_soc_register_codec
(
&
pdev
->
dev
,
&
ab8500_codec_driver
,
ab8500_codec_dai
,
...
...
@@ -2606,7 +2604,7 @@ static int ab8500_codec_driver_probe(struct platform_device *pdev)
static
int
ab8500_codec_driver_remove
(
struct
platform_device
*
pdev
)
{
dev_
info
(
&
pdev
->
dev
,
"%s Enter.
\n
"
,
__func__
);
dev_
dbg
(
&
pdev
->
dev
,
"%s Enter.
\n
"
,
__func__
);
snd_soc_unregister_codec
(
&
pdev
->
dev
);
...
...
This diff is collapsed.
Click to expand it.
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录
新手
引导
客服
返回
顶部