Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
63ddcd7b
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
63ddcd7b
编写于
12年前
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'asoc/topic/wm8985' into asoc-next
上级
555df91a
5f3d25c0
无相关合并请求
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
23 deletion
+20
-23
sound/soc/codecs/wm8985.c
sound/soc/codecs/wm8985.c
+20
-23
未找到文件。
sound/soc/codecs/wm8985.c
浏览文件 @
63ddcd7b
...
@@ -830,33 +830,30 @@ static int wm8985_set_pll(struct snd_soc_dai *dai, int pll_id,
...
@@ -830,33 +830,30 @@ static int wm8985_set_pll(struct snd_soc_dai *dai, int pll_id,
struct
pll_div
pll_div
;
struct
pll_div
pll_div
;
codec
=
dai
->
codec
;
codec
=
dai
->
codec
;
if
(
freq_in
&&
freq_out
)
{
if
(
!
freq_in
||
!
freq_out
)
{
/* disable the PLL */
snd_soc_update_bits
(
codec
,
WM8985_POWER_MANAGEMENT_1
,
WM8985_PLLEN_MASK
,
0
);
}
else
{
ret
=
pll_factors
(
&
pll_div
,
freq_out
*
4
*
2
,
freq_in
);
ret
=
pll_factors
(
&
pll_div
,
freq_out
*
4
*
2
,
freq_in
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
}
/* disable the PLL before reprogramming it */
/* set PLLN and PRESCALE */
snd_soc_update_bits
(
codec
,
WM8985_POWER_MANAGEMENT_1
,
snd_soc_write
(
codec
,
WM8985_PLL_N
,
WM8985_PLLEN_MASK
,
0
);
(
pll_div
.
div2
<<
WM8985_PLL_PRESCALE_SHIFT
)
|
pll_div
.
n
);
if
(
!
freq_in
||
!
freq_out
)
/* set PLLK */
return
0
;
snd_soc_write
(
codec
,
WM8985_PLL_K_3
,
pll_div
.
k
&
0x1ff
);
snd_soc_write
(
codec
,
WM8985_PLL_K_2
,
(
pll_div
.
k
>>
9
)
&
0x1ff
);
/* set PLLN and PRESCALE */
snd_soc_write
(
codec
,
WM8985_PLL_K_1
,
(
pll_div
.
k
>>
18
));
snd_soc_write
(
codec
,
WM8985_PLL_N
,
/* set the source of the clock to be the PLL */
(
pll_div
.
div2
<<
WM8985_PLL_PRESCALE_SHIFT
)
snd_soc_update_bits
(
codec
,
WM8985_CLOCK_GEN_CONTROL
,
|
pll_div
.
n
);
WM8985_CLKSEL_MASK
,
WM8985_CLKSEL
);
/* set PLLK */
/* enable the PLL */
snd_soc_write
(
codec
,
WM8985_PLL_K_3
,
pll_div
.
k
&
0x1ff
);
snd_soc_update_bits
(
codec
,
WM8985_POWER_MANAGEMENT_1
,
snd_soc_write
(
codec
,
WM8985_PLL_K_2
,
(
pll_div
.
k
>>
9
)
&
0x1ff
);
WM8985_PLLEN_MASK
,
WM8985_PLLEN
);
snd_soc_write
(
codec
,
WM8985_PLL_K_1
,
(
pll_div
.
k
>>
18
));
}
/* set the source of the clock to be the PLL */
snd_soc_update_bits
(
codec
,
WM8985_CLOCK_GEN_CONTROL
,
WM8985_CLKSEL_MASK
,
WM8985_CLKSEL
);
/* enable the PLL */
snd_soc_update_bits
(
codec
,
WM8985_POWER_MANAGEMENT_1
,
WM8985_PLLEN_MASK
,
WM8985_PLLEN
);
return
0
;
return
0
;
}
}
...
...
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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录
反馈
建议
客服
返回
顶部