Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
6f83d30a
cloud-kernel
项目概览
openanolis
/
cloud-kernel
接近 2 年 前同步成功
通知
170
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
6f83d30a
编写于
9月 22, 2015
作者:
S
Stephen Boyd
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'clk-fixes' into clk-next
* clk-fixes: clk: samsung: fix cpu clock's flags checking
上级
7001b3f9
9e294bf8
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
5 addition
and
5 deletion
+5
-5
drivers/clk/samsung/clk-cpu.c
drivers/clk/samsung/clk-cpu.c
+5
-5
未找到文件。
drivers/clk/samsung/clk-cpu.c
浏览文件 @
6f83d30a
...
...
@@ -164,7 +164,7 @@ static int exynos_cpuclk_pre_rate_change(struct clk_notifier_data *ndata,
* the values for DIV_COPY and DIV_HPM dividers need not be set.
*/
div0
=
cfg_data
->
div0
;
if
(
test_bit
(
CLK_CPU_HAS_DIV1
,
&
cpuclk
->
flags
)
)
{
if
(
cpuclk
->
flags
&
CLK_CPU_HAS_DIV1
)
{
div1
=
cfg_data
->
div1
;
if
(
readl
(
base
+
E4210_SRC_CPU
)
&
E4210_MUX_HPM_MASK
)
div1
=
readl
(
base
+
E4210_DIV_CPU1
)
&
...
...
@@ -185,7 +185,7 @@ static int exynos_cpuclk_pre_rate_change(struct clk_notifier_data *ndata,
alt_div
=
DIV_ROUND_UP
(
alt_prate
,
tmp_rate
)
-
1
;
WARN_ON
(
alt_div
>=
MAX_DIV
);
if
(
test_bit
(
CLK_CPU_NEEDS_DEBUG_ALT_DIV
,
&
cpuclk
->
flags
)
)
{
if
(
cpuclk
->
flags
&
CLK_CPU_NEEDS_DEBUG_ALT_DIV
)
{
/*
* In Exynos4210, ATB clock parent is also mout_core. So
* ATB clock also needs to be mantained at safe speed.
...
...
@@ -206,7 +206,7 @@ static int exynos_cpuclk_pre_rate_change(struct clk_notifier_data *ndata,
writel
(
div0
,
base
+
E4210_DIV_CPU0
);
wait_until_divider_stable
(
base
+
E4210_DIV_STAT_CPU0
,
DIV_MASK_ALL
);
if
(
test_bit
(
CLK_CPU_HAS_DIV1
,
&
cpuclk
->
flags
)
)
{
if
(
cpuclk
->
flags
&
CLK_CPU_HAS_DIV1
)
{
writel
(
div1
,
base
+
E4210_DIV_CPU1
);
wait_until_divider_stable
(
base
+
E4210_DIV_STAT_CPU1
,
DIV_MASK_ALL
);
...
...
@@ -225,7 +225,7 @@ static int exynos_cpuclk_post_rate_change(struct clk_notifier_data *ndata,
unsigned
long
mux_reg
;
/* find out the divider values to use for clock data */
if
(
test_bit
(
CLK_CPU_NEEDS_DEBUG_ALT_DIV
,
&
cpuclk
->
flags
)
)
{
if
(
cpuclk
->
flags
&
CLK_CPU_NEEDS_DEBUG_ALT_DIV
)
{
while
((
cfg_data
->
prate
*
1000
)
!=
ndata
->
new_rate
)
{
if
(
cfg_data
->
prate
==
0
)
return
-
EINVAL
;
...
...
@@ -240,7 +240,7 @@ static int exynos_cpuclk_post_rate_change(struct clk_notifier_data *ndata,
writel
(
mux_reg
&
~
(
1
<<
16
),
base
+
E4210_SRC_CPU
);
wait_until_mux_stable
(
base
+
E4210_STAT_CPU
,
16
,
1
);
if
(
test_bit
(
CLK_CPU_NEEDS_DEBUG_ALT_DIV
,
&
cpuclk
->
flags
)
)
{
if
(
cpuclk
->
flags
&
CLK_CPU_NEEDS_DEBUG_ALT_DIV
)
{
div
|=
(
cfg_data
->
div0
&
E4210_DIV0_ATB_MASK
);
div_mask
|=
E4210_DIV0_ATB_MASK
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录