Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
867a5a12
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看板
提交
867a5a12
编写于
3月 13, 2018
作者:
N
Neil Armstrong
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'topic/pll-fixes' into next/drivers
上级
f5edaefe
6c00e7b7
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
140 addition
and
201 deletion
+140
-201
drivers/clk/meson/axg.c
drivers/clk/meson/axg.c
+26
-95
drivers/clk/meson/clk-mpll.c
drivers/clk/meson/clk-mpll.c
+7
-0
drivers/clk/meson/clk-pll.c
drivers/clk/meson/clk-pll.c
+32
-9
drivers/clk/meson/clkc.h
drivers/clk/meson/clkc.h
+3
-0
drivers/clk/meson/gxbb.c
drivers/clk/meson/gxbb.c
+70
-96
drivers/clk/meson/gxbb.h
drivers/clk/meson/gxbb.h
+2
-1
未找到文件。
drivers/clk/meson/axg.c
浏览文件 @
867a5a12
...
...
@@ -21,98 +21,6 @@
static
DEFINE_SPINLOCK
(
meson_clk_lock
);
static
const
struct
pll_rate_table
sys_pll_rate_table
[]
=
{
PLL_RATE
(
24000000
,
56
,
1
,
2
),
PLL_RATE
(
48000000
,
64
,
1
,
2
),
PLL_RATE
(
72000000
,
72
,
1
,
2
),
PLL_RATE
(
96000000
,
64
,
1
,
2
),
PLL_RATE
(
120000000
,
80
,
1
,
2
),
PLL_RATE
(
144000000
,
96
,
1
,
2
),
PLL_RATE
(
168000000
,
56
,
1
,
1
),
PLL_RATE
(
192000000
,
64
,
1
,
1
),
PLL_RATE
(
216000000
,
72
,
1
,
1
),
PLL_RATE
(
240000000
,
80
,
1
,
1
),
PLL_RATE
(
264000000
,
88
,
1
,
1
),
PLL_RATE
(
288000000
,
96
,
1
,
1
),
PLL_RATE
(
312000000
,
52
,
1
,
2
),
PLL_RATE
(
336000000
,
56
,
1
,
2
),
PLL_RATE
(
360000000
,
60
,
1
,
2
),
PLL_RATE
(
384000000
,
64
,
1
,
2
),
PLL_RATE
(
408000000
,
68
,
1
,
2
),
PLL_RATE
(
432000000
,
72
,
1
,
2
),
PLL_RATE
(
456000000
,
76
,
1
,
2
),
PLL_RATE
(
480000000
,
80
,
1
,
2
),
PLL_RATE
(
504000000
,
84
,
1
,
2
),
PLL_RATE
(
528000000
,
88
,
1
,
2
),
PLL_RATE
(
552000000
,
92
,
1
,
2
),
PLL_RATE
(
576000000
,
96
,
1
,
2
),
PLL_RATE
(
600000000
,
50
,
1
,
1
),
PLL_RATE
(
624000000
,
52
,
1
,
1
),
PLL_RATE
(
648000000
,
54
,
1
,
1
),
PLL_RATE
(
672000000
,
56
,
1
,
1
),
PLL_RATE
(
696000000
,
58
,
1
,
1
),
PLL_RATE
(
720000000
,
60
,
1
,
1
),
PLL_RATE
(
744000000
,
62
,
1
,
1
),
PLL_RATE
(
768000000
,
64
,
1
,
1
),
PLL_RATE
(
792000000
,
66
,
1
,
1
),
PLL_RATE
(
816000000
,
68
,
1
,
1
),
PLL_RATE
(
840000000
,
70
,
1
,
1
),
PLL_RATE
(
864000000
,
72
,
1
,
1
),
PLL_RATE
(
888000000
,
74
,
1
,
1
),
PLL_RATE
(
912000000
,
76
,
1
,
1
),
PLL_RATE
(
936000000
,
78
,
1
,
1
),
PLL_RATE
(
960000000
,
80
,
1
,
1
),
PLL_RATE
(
984000000
,
82
,
1
,
1
),
PLL_RATE
(
1008000000
,
84
,
1
,
1
),
PLL_RATE
(
1032000000
,
86
,
1
,
1
),
PLL_RATE
(
1056000000
,
88
,
1
,
1
),
PLL_RATE
(
1080000000
,
90
,
1
,
1
),
PLL_RATE
(
1104000000
,
92
,
1
,
1
),
PLL_RATE
(
1128000000
,
94
,
1
,
1
),
PLL_RATE
(
1152000000
,
96
,
1
,
1
),
PLL_RATE
(
1176000000
,
98
,
1
,
1
),
PLL_RATE
(
1200000000
,
50
,
1
,
0
),
PLL_RATE
(
1224000000
,
51
,
1
,
0
),
PLL_RATE
(
1248000000
,
52
,
1
,
0
),
PLL_RATE
(
1272000000
,
53
,
1
,
0
),
PLL_RATE
(
1296000000
,
54
,
1
,
0
),
PLL_RATE
(
1320000000
,
55
,
1
,
0
),
PLL_RATE
(
1344000000
,
56
,
1
,
0
),
PLL_RATE
(
1368000000
,
57
,
1
,
0
),
PLL_RATE
(
1392000000
,
58
,
1
,
0
),
PLL_RATE
(
1416000000
,
59
,
1
,
0
),
PLL_RATE
(
1440000000
,
60
,
1
,
0
),
PLL_RATE
(
1464000000
,
61
,
1
,
0
),
PLL_RATE
(
1488000000
,
62
,
1
,
0
),
PLL_RATE
(
1512000000
,
63
,
1
,
0
),
PLL_RATE
(
1536000000
,
64
,
1
,
0
),
PLL_RATE
(
1560000000
,
65
,
1
,
0
),
PLL_RATE
(
1584000000
,
66
,
1
,
0
),
PLL_RATE
(
1608000000
,
67
,
1
,
0
),
PLL_RATE
(
1632000000
,
68
,
1
,
0
),
PLL_RATE
(
1656000000
,
68
,
1
,
0
),
PLL_RATE
(
1680000000
,
68
,
1
,
0
),
PLL_RATE
(
1704000000
,
68
,
1
,
0
),
PLL_RATE
(
1728000000
,
69
,
1
,
0
),
PLL_RATE
(
1752000000
,
69
,
1
,
0
),
PLL_RATE
(
1776000000
,
69
,
1
,
0
),
PLL_RATE
(
1800000000
,
69
,
1
,
0
),
PLL_RATE
(
1824000000
,
70
,
1
,
0
),
PLL_RATE
(
1848000000
,
70
,
1
,
0
),
PLL_RATE
(
1872000000
,
70
,
1
,
0
),
PLL_RATE
(
1896000000
,
70
,
1
,
0
),
PLL_RATE
(
1920000000
,
71
,
1
,
0
),
PLL_RATE
(
1944000000
,
71
,
1
,
0
),
PLL_RATE
(
1968000000
,
71
,
1
,
0
),
PLL_RATE
(
1992000000
,
71
,
1
,
0
),
PLL_RATE
(
2016000000
,
72
,
1
,
0
),
PLL_RATE
(
2040000000
,
72
,
1
,
0
),
PLL_RATE
(
2064000000
,
72
,
1
,
0
),
PLL_RATE
(
2088000000
,
72
,
1
,
0
),
PLL_RATE
(
2112000000
,
73
,
1
,
0
),
{
/* sentinel */
},
};
static
struct
meson_clk_pll
axg_fixed_pll
=
{
.
m
=
{
.
reg_off
=
HHI_MPLL_CNTL
,
...
...
@@ -129,6 +37,11 @@ static struct meson_clk_pll axg_fixed_pll = {
.
shift
=
16
,
.
width
=
2
,
},
.
frac
=
{
.
reg_off
=
HHI_MPLL_CNTL2
,
.
shift
=
0
,
.
width
=
12
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"fixed_pll"
,
...
...
@@ -151,11 +64,9 @@ static struct meson_clk_pll axg_sys_pll = {
},
.
od
=
{
.
reg_off
=
HHI_SYS_PLL_CNTL
,
.
shift
=
1
0
,
.
shift
=
1
6
,
.
width
=
2
,
},
.
rate_table
=
sys_pll_rate_table
,
.
rate_count
=
ARRAY_SIZE
(
sys_pll_rate_table
),
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"sys_pll"
,
...
...
@@ -381,6 +292,11 @@ static struct meson_clk_mpll axg_mpll0 = {
.
shift
=
25
,
.
width
=
1
,
},
.
misc
=
{
.
reg_off
=
HHI_PLL_TOP_MISC
,
.
shift
=
0
,
.
width
=
1
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"mpll0"
,
...
...
@@ -411,6 +327,11 @@ static struct meson_clk_mpll axg_mpll1 = {
.
shift
=
14
,
.
width
=
1
,
},
.
misc
=
{
.
reg_off
=
HHI_PLL_TOP_MISC
,
.
shift
=
1
,
.
width
=
1
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"mpll1"
,
...
...
@@ -441,6 +362,11 @@ static struct meson_clk_mpll axg_mpll2 = {
.
shift
=
14
,
.
width
=
1
,
},
.
misc
=
{
.
reg_off
=
HHI_PLL_TOP_MISC
,
.
shift
=
2
,
.
width
=
1
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"mpll2"
,
...
...
@@ -471,6 +397,11 @@ static struct meson_clk_mpll axg_mpll3 = {
.
shift
=
0
,
.
width
=
1
,
},
.
misc
=
{
.
reg_off
=
HHI_PLL_TOP_MISC
,
.
shift
=
3
,
.
width
=
1
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"mpll3"
,
...
...
drivers/clk/meson/clk-mpll.c
浏览文件 @
867a5a12
...
...
@@ -173,6 +173,13 @@ static int mpll_set_rate(struct clk_hw *hw,
reg
=
PARM_SET
(
p
->
width
,
p
->
shift
,
reg
,
n2
);
writel
(
reg
,
mpll
->
base
+
p
->
reg_off
);
p
=
&
mpll
->
misc
;
if
(
p
->
width
!=
0
)
{
reg
=
readl
(
mpll
->
base
+
p
->
reg_off
);
reg
=
PARM_SET
(
p
->
width
,
p
->
shift
,
reg
,
1
);
writel
(
reg
,
mpll
->
base
+
p
->
reg_off
);
}
if
(
mpll
->
lock
)
spin_unlock_irqrestore
(
mpll
->
lock
,
flags
);
else
...
...
drivers/clk/meson/clk-pll.c
浏览文件 @
867a5a12
...
...
@@ -34,6 +34,7 @@
#include <linux/delay.h>
#include <linux/err.h>
#include <linux/io.h>
#include <linux/math64.h>
#include <linux/module.h>
#include <linux/of_address.h>
#include <linux/slab.h>
...
...
@@ -51,9 +52,8 @@ static unsigned long meson_clk_pll_recalc_rate(struct clk_hw *hw,
{
struct
meson_clk_pll
*
pll
=
to_meson_clk_pll
(
hw
);
struct
parm
*
p
;
unsigned
long
parent_rate_mhz
=
parent_rate
/
1000000
;
unsigned
long
rate_mhz
;
u16
n
,
m
,
frac
=
0
,
od
,
od2
=
0
;
u64
rate
;
u16
n
,
m
,
frac
=
0
,
od
,
od2
=
0
,
od3
=
0
;
u32
reg
;
p
=
&
pll
->
n
;
...
...
@@ -74,17 +74,23 @@ static unsigned long meson_clk_pll_recalc_rate(struct clk_hw *hw,
od2
=
PARM_GET
(
p
->
width
,
p
->
shift
,
reg
);
}
p
=
&
pll
->
od3
;
if
(
p
->
width
)
{
reg
=
readl
(
pll
->
base
+
p
->
reg_off
);
od3
=
PARM_GET
(
p
->
width
,
p
->
shift
,
reg
);
}
rate
=
(
u64
)
m
*
parent_rate
;
p
=
&
pll
->
frac
;
if
(
p
->
width
)
{
reg
=
readl
(
pll
->
base
+
p
->
reg_off
);
frac
=
PARM_GET
(
p
->
width
,
p
->
shift
,
reg
);
rate_mhz
=
(
parent_rate_mhz
*
m
+
\
(
parent_rate_mhz
*
frac
>>
12
))
*
2
/
n
;
rate_mhz
=
rate_mhz
>>
od
>>
od2
;
}
else
rate_mhz
=
(
parent_rate_mhz
*
m
/
n
)
>>
od
>>
od2
;
return
rate_mhz
*
1000000
;
rate
+=
mul_u64_u32_shr
(
parent_rate
,
frac
,
p
->
width
);
}
return
div_u64
(
rate
,
n
)
>>
od
>>
od2
>>
od3
;
}
static
long
meson_clk_pll_round_rate
(
struct
clk_hw
*
hw
,
unsigned
long
rate
,
...
...
@@ -94,6 +100,13 @@ static long meson_clk_pll_round_rate(struct clk_hw *hw, unsigned long rate,
const
struct
pll_rate_table
*
rate_table
=
pll
->
rate_table
;
int
i
;
/*
* if the table is missing, just return the current rate
* since we don't have the other available frequencies
*/
if
(
!
rate_table
)
return
meson_clk_pll_recalc_rate
(
hw
,
*
parent_rate
);
for
(
i
=
0
;
i
<
pll
->
rate_count
;
i
++
)
{
if
(
rate
<=
rate_table
[
i
].
rate
)
return
rate_table
[
i
].
rate
;
...
...
@@ -109,6 +122,9 @@ static const struct pll_rate_table *meson_clk_get_pll_settings(struct meson_clk_
const
struct
pll_rate_table
*
rate_table
=
pll
->
rate_table
;
int
i
;
if
(
!
rate_table
)
return
NULL
;
for
(
i
=
0
;
i
<
pll
->
rate_count
;
i
++
)
{
if
(
rate
==
rate_table
[
i
].
rate
)
return
&
rate_table
[
i
];
...
...
@@ -215,6 +231,13 @@ static int meson_clk_pll_set_rate(struct clk_hw *hw, unsigned long rate,
writel
(
reg
,
pll
->
base
+
p
->
reg_off
);
}
p
=
&
pll
->
od3
;
if
(
p
->
width
)
{
reg
=
readl
(
pll
->
base
+
p
->
reg_off
);
reg
=
PARM_SET
(
p
->
width
,
p
->
shift
,
reg
,
rate_set
->
od3
);
writel
(
reg
,
pll
->
base
+
p
->
reg_off
);
}
p
=
&
pll
->
frac
;
if
(
p
->
width
)
{
reg
=
readl
(
pll
->
base
+
p
->
reg_off
);
...
...
drivers/clk/meson/clkc.h
浏览文件 @
867a5a12
...
...
@@ -41,6 +41,7 @@ struct pll_rate_table {
u16
n
;
u16
od
;
u16
od2
;
u16
od3
;
u16
frac
;
};
...
...
@@ -92,6 +93,7 @@ struct meson_clk_pll {
struct
parm
frac
;
struct
parm
od
;
struct
parm
od2
;
struct
parm
od3
;
const
struct
pll_setup_params
params
;
const
struct
pll_rate_table
*
rate_table
;
unsigned
int
rate_count
;
...
...
@@ -119,6 +121,7 @@ struct meson_clk_mpll {
struct
parm
n2
;
struct
parm
en
;
struct
parm
ssen
;
struct
parm
misc
;
spinlock_t
*
lock
;
};
...
...
drivers/clk/meson/gxbb.c
浏览文件 @
867a5a12
...
...
@@ -29,98 +29,6 @@
static
DEFINE_SPINLOCK
(
meson_clk_lock
);
static
const
struct
pll_rate_table
sys_pll_rate_table
[]
=
{
PLL_RATE
(
24000000
,
56
,
1
,
2
),
PLL_RATE
(
48000000
,
64
,
1
,
2
),
PLL_RATE
(
72000000
,
72
,
1
,
2
),
PLL_RATE
(
96000000
,
64
,
1
,
2
),
PLL_RATE
(
120000000
,
80
,
1
,
2
),
PLL_RATE
(
144000000
,
96
,
1
,
2
),
PLL_RATE
(
168000000
,
56
,
1
,
1
),
PLL_RATE
(
192000000
,
64
,
1
,
1
),
PLL_RATE
(
216000000
,
72
,
1
,
1
),
PLL_RATE
(
240000000
,
80
,
1
,
1
),
PLL_RATE
(
264000000
,
88
,
1
,
1
),
PLL_RATE
(
288000000
,
96
,
1
,
1
),
PLL_RATE
(
312000000
,
52
,
1
,
2
),
PLL_RATE
(
336000000
,
56
,
1
,
2
),
PLL_RATE
(
360000000
,
60
,
1
,
2
),
PLL_RATE
(
384000000
,
64
,
1
,
2
),
PLL_RATE
(
408000000
,
68
,
1
,
2
),
PLL_RATE
(
432000000
,
72
,
1
,
2
),
PLL_RATE
(
456000000
,
76
,
1
,
2
),
PLL_RATE
(
480000000
,
80
,
1
,
2
),
PLL_RATE
(
504000000
,
84
,
1
,
2
),
PLL_RATE
(
528000000
,
88
,
1
,
2
),
PLL_RATE
(
552000000
,
92
,
1
,
2
),
PLL_RATE
(
576000000
,
96
,
1
,
2
),
PLL_RATE
(
600000000
,
50
,
1
,
1
),
PLL_RATE
(
624000000
,
52
,
1
,
1
),
PLL_RATE
(
648000000
,
54
,
1
,
1
),
PLL_RATE
(
672000000
,
56
,
1
,
1
),
PLL_RATE
(
696000000
,
58
,
1
,
1
),
PLL_RATE
(
720000000
,
60
,
1
,
1
),
PLL_RATE
(
744000000
,
62
,
1
,
1
),
PLL_RATE
(
768000000
,
64
,
1
,
1
),
PLL_RATE
(
792000000
,
66
,
1
,
1
),
PLL_RATE
(
816000000
,
68
,
1
,
1
),
PLL_RATE
(
840000000
,
70
,
1
,
1
),
PLL_RATE
(
864000000
,
72
,
1
,
1
),
PLL_RATE
(
888000000
,
74
,
1
,
1
),
PLL_RATE
(
912000000
,
76
,
1
,
1
),
PLL_RATE
(
936000000
,
78
,
1
,
1
),
PLL_RATE
(
960000000
,
80
,
1
,
1
),
PLL_RATE
(
984000000
,
82
,
1
,
1
),
PLL_RATE
(
1008000000
,
84
,
1
,
1
),
PLL_RATE
(
1032000000
,
86
,
1
,
1
),
PLL_RATE
(
1056000000
,
88
,
1
,
1
),
PLL_RATE
(
1080000000
,
90
,
1
,
1
),
PLL_RATE
(
1104000000
,
92
,
1
,
1
),
PLL_RATE
(
1128000000
,
94
,
1
,
1
),
PLL_RATE
(
1152000000
,
96
,
1
,
1
),
PLL_RATE
(
1176000000
,
98
,
1
,
1
),
PLL_RATE
(
1200000000
,
50
,
1
,
0
),
PLL_RATE
(
1224000000
,
51
,
1
,
0
),
PLL_RATE
(
1248000000
,
52
,
1
,
0
),
PLL_RATE
(
1272000000
,
53
,
1
,
0
),
PLL_RATE
(
1296000000
,
54
,
1
,
0
),
PLL_RATE
(
1320000000
,
55
,
1
,
0
),
PLL_RATE
(
1344000000
,
56
,
1
,
0
),
PLL_RATE
(
1368000000
,
57
,
1
,
0
),
PLL_RATE
(
1392000000
,
58
,
1
,
0
),
PLL_RATE
(
1416000000
,
59
,
1
,
0
),
PLL_RATE
(
1440000000
,
60
,
1
,
0
),
PLL_RATE
(
1464000000
,
61
,
1
,
0
),
PLL_RATE
(
1488000000
,
62
,
1
,
0
),
PLL_RATE
(
1512000000
,
63
,
1
,
0
),
PLL_RATE
(
1536000000
,
64
,
1
,
0
),
PLL_RATE
(
1560000000
,
65
,
1
,
0
),
PLL_RATE
(
1584000000
,
66
,
1
,
0
),
PLL_RATE
(
1608000000
,
67
,
1
,
0
),
PLL_RATE
(
1632000000
,
68
,
1
,
0
),
PLL_RATE
(
1656000000
,
68
,
1
,
0
),
PLL_RATE
(
1680000000
,
68
,
1
,
0
),
PLL_RATE
(
1704000000
,
68
,
1
,
0
),
PLL_RATE
(
1728000000
,
69
,
1
,
0
),
PLL_RATE
(
1752000000
,
69
,
1
,
0
),
PLL_RATE
(
1776000000
,
69
,
1
,
0
),
PLL_RATE
(
1800000000
,
69
,
1
,
0
),
PLL_RATE
(
1824000000
,
70
,
1
,
0
),
PLL_RATE
(
1848000000
,
70
,
1
,
0
),
PLL_RATE
(
1872000000
,
70
,
1
,
0
),
PLL_RATE
(
1896000000
,
70
,
1
,
0
),
PLL_RATE
(
1920000000
,
71
,
1
,
0
),
PLL_RATE
(
1944000000
,
71
,
1
,
0
),
PLL_RATE
(
1968000000
,
71
,
1
,
0
),
PLL_RATE
(
1992000000
,
71
,
1
,
0
),
PLL_RATE
(
2016000000
,
72
,
1
,
0
),
PLL_RATE
(
2040000000
,
72
,
1
,
0
),
PLL_RATE
(
2064000000
,
72
,
1
,
0
),
PLL_RATE
(
2088000000
,
72
,
1
,
0
),
PLL_RATE
(
2112000000
,
73
,
1
,
0
),
{
/* sentinel */
},
};
static
const
struct
pll_rate_table
gxbb_gp0_pll_rate_table
[]
=
{
PLL_RATE
(
96000000
,
32
,
1
,
3
),
PLL_RATE
(
99000000
,
33
,
1
,
3
),
...
...
@@ -294,6 +202,11 @@ static struct meson_clk_pll gxbb_fixed_pll = {
.
shift
=
16
,
.
width
=
2
,
},
.
frac
=
{
.
reg_off
=
HHI_MPLL_CNTL2
,
.
shift
=
0
,
.
width
=
12
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"fixed_pll"
,
...
...
@@ -304,6 +217,17 @@ static struct meson_clk_pll gxbb_fixed_pll = {
},
};
static
struct
clk_fixed_factor
gxbb_hdmi_pll_pre_mult
=
{
.
mult
=
2
,
.
div
=
1
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"hdmi_pll_pre_mult"
,
.
ops
=
&
clk_fixed_factor_ops
,
.
parent_names
=
(
const
char
*
[]){
"xtal"
},
.
num_parents
=
1
,
},
};
static
struct
meson_clk_pll
gxbb_hdmi_pll
=
{
.
m
=
{
.
reg_off
=
HHI_HDMI_PLL_CNTL
,
...
...
@@ -330,6 +254,57 @@ static struct meson_clk_pll gxbb_hdmi_pll = {
.
shift
=
22
,
.
width
=
2
,
},
.
od3
=
{
.
reg_off
=
HHI_HDMI_PLL_CNTL2
,
.
shift
=
18
,
.
width
=
2
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"hdmi_pll"
,
.
ops
=
&
meson_clk_pll_ro_ops
,
.
parent_names
=
(
const
char
*
[]){
"hdmi_pll_pre_mult"
},
.
num_parents
=
1
,
.
flags
=
CLK_GET_RATE_NOCACHE
,
},
};
static
struct
meson_clk_pll
gxl_hdmi_pll
=
{
.
m
=
{
.
reg_off
=
HHI_HDMI_PLL_CNTL
,
.
shift
=
0
,
.
width
=
9
,
},
.
n
=
{
.
reg_off
=
HHI_HDMI_PLL_CNTL
,
.
shift
=
9
,
.
width
=
5
,
},
.
frac
=
{
/*
* On gxl, there is a register shift due to HHI_HDMI_PLL_CNTL1
* which does not exist on gxbb, so we compute the register
* offset based on the PLL base to get it right
*/
.
reg_off
=
HHI_HDMI_PLL_CNTL
+
4
,
.
shift
=
0
,
.
width
=
12
,
},
.
od
=
{
.
reg_off
=
HHI_HDMI_PLL_CNTL
+
8
,
.
shift
=
21
,
.
width
=
2
,
},
.
od2
=
{
.
reg_off
=
HHI_HDMI_PLL_CNTL
+
8
,
.
shift
=
23
,
.
width
=
2
,
},
.
od3
=
{
.
reg_off
=
HHI_HDMI_PLL_CNTL
+
8
,
.
shift
=
19
,
.
width
=
2
,
},
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"hdmi_pll"
,
...
...
@@ -356,8 +331,6 @@ static struct meson_clk_pll gxbb_sys_pll = {
.
shift
=
10
,
.
width
=
2
,
},
.
rate_table
=
sys_pll_rate_table
,
.
rate_count
=
ARRAY_SIZE
(
sys_pll_rate_table
),
.
lock
=
&
meson_clk_lock
,
.
hw
.
init
=
&
(
struct
clk_init_data
){
.
name
=
"sys_pll"
,
...
...
@@ -1601,6 +1574,7 @@ static struct clk_hw_onecell_data gxbb_hw_onecell_data = {
[
CLKID_VAPB_1
]
=
&
gxbb_vapb_1
.
hw
,
[
CLKID_VAPB_SEL
]
=
&
gxbb_vapb_sel
.
hw
,
[
CLKID_VAPB
]
=
&
gxbb_vapb
.
hw
,
[
CLKID_HDMI_PLL_PRE_MULT
]
=
&
gxbb_hdmi_pll_pre_mult
.
hw
,
[
NR_CLKS
]
=
NULL
,
},
.
num
=
NR_CLKS
,
...
...
@@ -1609,7 +1583,7 @@ static struct clk_hw_onecell_data gxbb_hw_onecell_data = {
static
struct
clk_hw_onecell_data
gxl_hw_onecell_data
=
{
.
hws
=
{
[
CLKID_SYS_PLL
]
=
&
gxbb_sys_pll
.
hw
,
[
CLKID_HDMI_PLL
]
=
&
gx
bb
_hdmi_pll
.
hw
,
[
CLKID_HDMI_PLL
]
=
&
gx
l
_hdmi_pll
.
hw
,
[
CLKID_FIXED_PLL
]
=
&
gxbb_fixed_pll
.
hw
,
[
CLKID_FCLK_DIV2
]
=
&
gxbb_fclk_div2
.
hw
,
[
CLKID_FCLK_DIV3
]
=
&
gxbb_fclk_div3
.
hw
,
...
...
@@ -1764,7 +1738,7 @@ static struct meson_clk_pll *const gxbb_clk_plls[] = {
static
struct
meson_clk_pll
*
const
gxl_clk_plls
[]
=
{
&
gxbb_fixed_pll
,
&
gx
bb
_hdmi_pll
,
&
gx
l
_hdmi_pll
,
&
gxbb_sys_pll
,
&
gxl_gp0_pll
,
};
...
...
drivers/clk/meson/gxbb.h
浏览文件 @
867a5a12
...
...
@@ -194,8 +194,9 @@
#define CLKID_VPU_1_DIV 130
#define CLKID_VAPB_0_DIV 134
#define CLKID_VAPB_1_DIV 137
#define CLKID_HDMI_PLL_PRE_MULT 141
#define NR_CLKS 14
1
#define NR_CLKS 14
2
/* include the CLKIDs that have been made part of the DT binding */
#include <dt-bindings/clock/gxbb-clkc.h>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录