Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OS
U-Boot.Mirror
提交
a2f34be7
U
U-Boot.Mirror
项目概览
OS
/
U-Boot.Mirror
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
U-Boot.Mirror
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
a2f34be7
编写于
12月 27, 2003
作者:
W
wdenk
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Cleanup
上级
7cb22f97
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
42 addition
and
47 deletion
+42
-47
cpu/mips/incaip_clock.c
cpu/mips/incaip_clock.c
+42
-47
未找到文件。
cpu/mips/incaip_clock.c
浏览文件 @
a2f34be7
...
...
@@ -40,33 +40,28 @@
* frequency of the CPU. Don't use the macros, which are set to init the CPU
* frequency in the ROM code.
*/
uint
incaip_get_cpuclk
(
void
)
uint
incaip_get_cpuclk
(
void
)
{
/*-------------------------------------------------------------------------*/
/* CPU Clock Input Multiplexer (MUX I) */
/* Multiplexer MUX I selects the maximum input clock to the CPU. */
/*-------------------------------------------------------------------------*/
if
(
*
((
volatile
ulong
*
)
INCA_IP_CGU_CGU_MUXCR
)
&
INCA_IP_CGU_CGU_MUXCR_MUXI
)
{
/* MUX I set to 150 MHz clock */
return
150000000
;
}
else
{
/* MUX I set to 100/133 MHz clock */
if
(
*
((
volatile
ulong
*
)
INCA_IP_CGU_CGU_DIVCR
)
&
0x40
)
{
/* Division value is 1/3, maximum CPU operating */
/* frequency is 133.3 MHz */
return
130000000
;
}
else
{
/* Division value is 1/4, maximum CPU operating */
/* frequency is 100 MHz */
return
100000000
;
}
}
/*-------------------------------------------------------------------------*/
/* CPU Clock Input Multiplexer (MUX I) */
/* Multiplexer MUX I selects the maximum input clock to the CPU. */
/*-------------------------------------------------------------------------*/
if
(
*
((
volatile
ulong
*
)
INCA_IP_CGU_CGU_MUXCR
)
&
INCA_IP_CGU_CGU_MUXCR_MUXI
)
{
/* MUX I set to 150 MHz clock */
return
150000000
;
}
else
{
/* MUX I set to 100/133 MHz clock */
if
(
*
((
volatile
ulong
*
)
INCA_IP_CGU_CGU_DIVCR
)
&
0x40
)
{
/* Division value is 1/3, maximum CPU operating */
/* frequency is 133.3 MHz */
return
130000000
;
}
else
{
/* Division value is 1/4, maximum CPU operating */
/* frequency is 100 MHz */
return
100000000
;
}
}
}
/*******************************************************************************
...
...
@@ -83,36 +78,36 @@ uint incaip_get_cpuclk(void)
* frequency in the ROM code.
* The calculation for the
*/
uint
incaip_get_fpiclk
(
void
)
uint
incaip_get_fpiclk
(
void
)
{
uint
clkCPU
;
uint
clkCPU
;
clkCPU
=
incaip_get_cpuclk
();
clkCPU
=
incaip_get_cpuclk
();
switch
(
*
((
volatile
ulong
*
)
INCA_IP_CGU_CGU_DIVCR
)
&
0xC
)
{
case
0x4
:
return
clkCPU
>>
1
;
/* devided by 2 */
break
;
case
0x8
:
return
clkCPU
>>
2
;
/* devided by 4 */
break
;
default:
return
clkCPU
;
break
;
}
switch
(
*
((
volatile
ulong
*
)
INCA_IP_CGU_CGU_DIVCR
)
&
0xC
)
{
case
0x4
:
return
clkCPU
>>
1
;
/* devided by 2 */
break
;
case
0x8
:
return
clkCPU
>>
2
;
/* devided by 4 */
break
;
default:
return
clkCPU
;
break
;
}
}
int
incaip_set_cpuclk
(
void
)
int
incaip_set_cpuclk
(
void
)
{
extern
void
ebu_init
(
long
);
extern
void
cgu_init
(
long
);
uchar
tmp
[
64
];
ulong
cpuclk
;
if
(
getenv_r
(
"cpuclk"
,
tmp
,
sizeof
(
tmp
))
>
0
)
{
cpuclk
=
simple_strtoul
(
tmp
,
NULL
,
10
)
*
1000000
;
ebu_init
(
cpuclk
);
cgu_init
(
cpuclk
);
if
(
getenv_r
(
"cpuclk"
,
tmp
,
sizeof
(
tmp
))
>
0
)
{
cpuclk
=
simple_strtoul
(
tmp
,
NULL
,
10
)
*
1000000
;
ebu_init
(
cpuclk
);
cgu_init
(
cpuclk
);
}
return
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录