Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
c1e08adc
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
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看板
提交
c1e08adc
编写于
6月 24, 2006
作者:
R
Russell King
提交者:
Russell King
6月 24, 2006
浏览文件
操作
浏览文件
下载
差异文件
Merge ep93xx branch
上级
52e3e772
1f64eb37
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
188 addition
and
1 deletion
+188
-1
arch/arm/mach-ep93xx/Makefile
arch/arm/mach-ep93xx/Makefile
+1
-1
arch/arm/mach-ep93xx/clock.c
arch/arm/mach-ep93xx/clock.c
+156
-0
arch/arm/mach-ep93xx/core.c
arch/arm/mach-ep93xx/core.c
+28
-0
include/asm-arm/arch-ep93xx/ep93xx-regs.h
include/asm-arm/arch-ep93xx/ep93xx-regs.h
+2
-0
include/asm-arm/arch-ep93xx/platform.h
include/asm-arm/arch-ep93xx/platform.h
+1
-0
未找到文件。
arch/arm/mach-ep93xx/Makefile
浏览文件 @
c1e08adc
#
# Makefile for the linux kernel.
#
obj-y
:=
core.o
obj-y
:=
core.o
clock.o
obj-m
:=
obj-n
:=
obj-
:=
...
...
arch/arm/mach-ep93xx/clock.c
0 → 100644
浏览文件 @
c1e08adc
/*
* arch/arm/mach-ep93xx/clock.c
* Clock control for Cirrus EP93xx chips.
*
* Copyright (C) 2006 Lennert Buytenhek <buytenh@wantstofly.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or (at
* your option) any later version.
*/
#include <linux/kernel.h>
#include <linux/clk.h>
#include <linux/err.h>
#include <linux/string.h>
#include <asm/div64.h>
#include <asm/hardware.h>
#include <asm/io.h>
struct
clk
{
char
*
name
;
unsigned
long
rate
;
int
users
;
u32
enable_reg
;
u32
enable_mask
;
};
static
struct
clk
clk_pll1
=
{
.
name
=
"pll1"
,
};
static
struct
clk
clk_f
=
{
.
name
=
"fclk"
,
};
static
struct
clk
clk_h
=
{
.
name
=
"hclk"
,
};
static
struct
clk
clk_p
=
{
.
name
=
"pclk"
,
};
static
struct
clk
clk_pll2
=
{
.
name
=
"pll2"
,
};
static
struct
clk
clk_usb_host
=
{
.
name
=
"usb_host"
,
.
enable_reg
=
EP93XX_SYSCON_CLOCK_CONTROL
,
.
enable_mask
=
EP93XX_SYSCON_CLOCK_USH_EN
,
};
static
struct
clk
*
clocks
[]
=
{
&
clk_pll1
,
&
clk_f
,
&
clk_h
,
&
clk_p
,
&
clk_pll2
,
&
clk_usb_host
,
};
struct
clk
*
clk_get
(
struct
device
*
dev
,
const
char
*
id
)
{
int
i
;
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
clocks
);
i
++
)
{
if
(
!
strcmp
(
clocks
[
i
]
->
name
,
id
))
return
clocks
[
i
];
}
return
ERR_PTR
(
-
ENOENT
);
}
int
clk_enable
(
struct
clk
*
clk
)
{
if
(
!
clk
->
users
++
&&
clk
->
enable_reg
)
{
u32
value
;
value
=
__raw_readl
(
clk
->
enable_reg
);
__raw_writel
(
value
|
clk
->
enable_mask
,
clk
->
enable_reg
);
}
return
0
;
}
void
clk_disable
(
struct
clk
*
clk
)
{
if
(
!--
clk
->
users
&&
clk
->
enable_reg
)
{
u32
value
;
value
=
__raw_readl
(
clk
->
enable_reg
);
__raw_writel
(
value
&
~
clk
->
enable_mask
,
clk
->
enable_reg
);
}
}
unsigned
long
clk_get_rate
(
struct
clk
*
clk
)
{
return
clk
->
rate
;
}
void
clk_put
(
struct
clk
*
clk
)
{
}
static
char
fclk_divisors
[]
=
{
1
,
2
,
4
,
8
,
16
,
1
,
1
,
1
};
static
char
hclk_divisors
[]
=
{
1
,
2
,
4
,
5
,
6
,
8
,
16
,
32
};
static
char
pclk_divisors
[]
=
{
1
,
2
,
4
,
8
};
/*
* PLL rate = 14.7456 MHz * (X1FBD + 1) * (X2FBD + 1) / (X2IPD + 1) / 2^PS
*/
static
unsigned
long
calc_pll_rate
(
u32
config_word
)
{
unsigned
long
long
rate
;
int
i
;
rate
=
14745600
;
rate
*=
((
config_word
>>
11
)
&
0x1f
)
+
1
;
/* X1FBD */
rate
*=
((
config_word
>>
5
)
&
0x3f
)
+
1
;
/* X2FBD */
do_div
(
rate
,
(
config_word
&
0x1f
)
+
1
);
/* X2IPD */
for
(
i
=
0
;
i
<
((
config_word
>>
16
)
&
3
);
i
++
)
/* PS */
rate
>>=
1
;
return
(
unsigned
long
)
rate
;
}
void
ep93xx_clock_init
(
void
)
{
u32
value
;
value
=
__raw_readl
(
EP93XX_SYSCON_CLOCK_SET1
);
if
(
!
(
value
&
0x00800000
))
{
/* PLL1 bypassed? */
clk_pll1
.
rate
=
14745600
;
}
else
{
clk_pll1
.
rate
=
calc_pll_rate
(
value
);
}
clk_f
.
rate
=
clk_pll1
.
rate
/
fclk_divisors
[(
value
>>
25
)
&
0x7
];
clk_h
.
rate
=
clk_pll1
.
rate
/
hclk_divisors
[(
value
>>
20
)
&
0x7
];
clk_p
.
rate
=
clk_h
.
rate
/
pclk_divisors
[(
value
>>
18
)
&
0x3
];
value
=
__raw_readl
(
EP93XX_SYSCON_CLOCK_SET2
);
if
(
!
(
value
&
0x00080000
))
{
/* PLL2 bypassed? */
clk_pll2
.
rate
=
14745600
;
}
else
if
(
value
&
0x00040000
)
{
/* PLL2 enabled? */
clk_pll2
.
rate
=
calc_pll_rate
(
value
);
}
else
{
clk_pll2
.
rate
=
0
;
}
clk_usb_host
.
rate
=
clk_pll2
.
rate
/
(((
value
>>
28
)
&
0xf
)
+
1
);
printk
(
KERN_INFO
"ep93xx: PLL1 running at %ld MHz, PLL2 at %ld MHz
\n
"
,
clk_pll1
.
rate
/
1000000
,
clk_pll2
.
rate
/
1000000
);
printk
(
KERN_INFO
"ep93xx: FCLK %ld MHz, HCLK %ld MHz, PCLK %ld MHz
\n
"
,
clk_f
.
rate
/
1000000
,
clk_h
.
rate
/
1000000
,
clk_p
.
rate
/
1000000
);
}
arch/arm/mach-ep93xx/core.c
浏览文件 @
c1e08adc
...
...
@@ -433,10 +433,37 @@ static struct platform_device ep93xx_rtc_device = {
};
static
struct
resource
ep93xx_ohci_resources
[]
=
{
[
0
]
=
{
.
start
=
EP93XX_USB_PHYS_BASE
,
.
end
=
EP93XX_USB_PHYS_BASE
+
0x0fff
,
.
flags
=
IORESOURCE_MEM
,
},
[
1
]
=
{
.
start
=
IRQ_EP93XX_USB
,
.
end
=
IRQ_EP93XX_USB
,
.
flags
=
IORESOURCE_IRQ
,
},
};
static
struct
platform_device
ep93xx_ohci_device
=
{
.
name
=
"ep93xx-ohci"
,
.
id
=
-
1
,
.
dev
=
{
.
dma_mask
=
(
void
*
)
0xffffffff
,
.
coherent_dma_mask
=
0xffffffff
,
},
.
num_resources
=
ARRAY_SIZE
(
ep93xx_ohci_resources
),
.
resource
=
ep93xx_ohci_resources
,
};
void
__init
ep93xx_init_devices
(
void
)
{
unsigned
int
v
;
ep93xx_clock_init
();
/*
* Disallow access to MaverickCrunch initially.
*/
...
...
@@ -450,4 +477,5 @@ void __init ep93xx_init_devices(void)
amba_device_register
(
&
uart3_device
,
&
iomem_resource
);
platform_device_register
(
&
ep93xx_rtc_device
);
platform_device_register
(
&
ep93xx_ohci_device
);
}
include/asm-arm/arch-ep93xx/ep93xx-regs.h
浏览文件 @
c1e08adc
...
...
@@ -115,6 +115,8 @@
#define EP93XX_SYSCON_CLOCK_USH_EN 0x10000000
#define EP93XX_SYSCON_HALT EP93XX_SYSCON_REG(0x08)
#define EP93XX_SYSCON_STANDBY EP93XX_SYSCON_REG(0x0c)
#define EP93XX_SYSCON_CLOCK_SET1 EP93XX_SYSCON_REG(0x20)
#define EP93XX_SYSCON_CLOCK_SET2 EP93XX_SYSCON_REG(0x24)
#define EP93XX_SYSCON_DEVICE_CONFIG EP93XX_SYSCON_REG(0x80)
#define EP93XX_SYSCON_DEVICE_CONFIG_CRUNCH_ENABLE 0x00800000
#define EP93XX_SYSCON_SWLOCK EP93XX_SYSCON_REG(0xc0)
...
...
include/asm-arm/arch-ep93xx/platform.h
浏览文件 @
c1e08adc
...
...
@@ -8,6 +8,7 @@ void ep93xx_map_io(void);
void
ep93xx_init_irq
(
void
);
void
ep93xx_init_time
(
unsigned
long
);
void
ep93xx_init_devices
(
void
);
void
ep93xx_clock_init
(
void
);
extern
struct
sys_timer
ep93xx_timer
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录