Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
3aef6649
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 4 年多
通知
15
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
3aef6649
编写于
2月 16, 2016
作者:
M
Michael Turquette
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'clk-bcm2835' into clk-next
上级
70750ff2
79c1e2fc
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
9 addition
and
16 deletion
+9
-16
drivers/clk/bcm/clk-bcm2835.c
drivers/clk/bcm/clk-bcm2835.c
+9
-16
未找到文件。
drivers/clk/bcm/clk-bcm2835.c
浏览文件 @
3aef6649
...
...
@@ -1060,16 +1060,7 @@ static long bcm2835_pll_divider_round_rate(struct clk_hw *hw,
static
unsigned
long
bcm2835_pll_divider_get_rate
(
struct
clk_hw
*
hw
,
unsigned
long
parent_rate
)
{
struct
bcm2835_pll_divider
*
divider
=
bcm2835_pll_divider_from_hw
(
hw
);
struct
bcm2835_cprman
*
cprman
=
divider
->
cprman
;
const
struct
bcm2835_pll_divider_data
*
data
=
divider
->
data
;
u32
div
=
cprman_read
(
cprman
,
data
->
a2w_reg
);
div
&=
(
1
<<
A2W_PLL_DIV_BITS
)
-
1
;
if
(
div
==
0
)
div
=
256
;
return
parent_rate
/
div
;
return
clk_divider_ops
.
recalc_rate
(
hw
,
parent_rate
);
}
static
void
bcm2835_pll_divider_off
(
struct
clk_hw
*
hw
)
...
...
@@ -1107,13 +1098,15 @@ static int bcm2835_pll_divider_set_rate(struct clk_hw *hw,
struct
bcm2835_pll_divider
*
divider
=
bcm2835_pll_divider_from_hw
(
hw
);
struct
bcm2835_cprman
*
cprman
=
divider
->
cprman
;
const
struct
bcm2835_pll_divider_data
*
data
=
divider
->
data
;
u32
cm
;
int
ret
;
u32
cm
,
div
,
max_div
=
1
<<
A2W_PLL_DIV_BITS
;
ret
=
clk_divider_ops
.
set_rate
(
hw
,
rate
,
parent_rate
);
if
(
ret
)
return
ret
;
div
=
DIV_ROUND_UP_ULL
(
parent_rate
,
rate
);
div
=
min
(
div
,
max_div
);
if
(
div
==
max_div
)
div
=
0
;
cprman_write
(
cprman
,
data
->
a2w_reg
,
div
);
cm
=
cprman_read
(
cprman
,
data
->
cm_reg
);
cprman_write
(
cprman
,
data
->
cm_reg
,
cm
|
data
->
load_mask
);
cprman_write
(
cprman
,
data
->
cm_reg
,
cm
&
~
data
->
load_mask
);
...
...
@@ -1428,7 +1421,7 @@ bcm2835_register_pll_divider(struct bcm2835_cprman *cprman,
divider
->
div
.
reg
=
cprman
->
regs
+
data
->
a2w_reg
;
divider
->
div
.
shift
=
A2W_PLL_DIV_SHIFT
;
divider
->
div
.
width
=
A2W_PLL_DIV_BITS
;
divider
->
div
.
flags
=
0
;
divider
->
div
.
flags
=
CLK_DIVIDER_MAX_AT_ZERO
;
divider
->
div
.
lock
=
&
cprman
->
regs_lock
;
divider
->
div
.
hw
.
init
=
&
init
;
divider
->
div
.
table
=
NULL
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录