Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
30aae739
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看板
提交
30aae739
编写于
1月 13, 2009
作者:
B
Benjamin Herrenschmidt
浏览文件
操作
浏览文件
下载
差异文件
Merge commit 'kumar/kumar-next' into next
上级
37a76bd4
6fd8be4b
变更
11
显示空白变更内容
内联
并排
Showing
11 changed file
with
117 addition
and
55 deletion
+117
-55
arch/powerpc/boot/dts/mpc8544ds.dts
arch/powerpc/boot/dts/mpc8544ds.dts
+2
-2
arch/powerpc/boot/dts/mpc8572ds.dts
arch/powerpc/boot/dts/mpc8572ds.dts
+2
-2
arch/powerpc/boot/dts/mpc8572ds_camp_core0.dts
arch/powerpc/boot/dts/mpc8572ds_camp_core0.dts
+1
-1
arch/powerpc/boot/dts/mpc8572ds_camp_core1.dts
arch/powerpc/boot/dts/mpc8572ds_camp_core1.dts
+1
-1
arch/powerpc/include/asm/qe.h
arch/powerpc/include/asm/qe.h
+18
-1
arch/powerpc/kernel/asm-offsets.c
arch/powerpc/kernel/asm-offsets.c
+7
-0
arch/powerpc/kernel/head_fsl_booke.S
arch/powerpc/kernel/head_fsl_booke.S
+1
-5
arch/powerpc/mm/fsl_booke_mmu.c
arch/powerpc/mm/fsl_booke_mmu.c
+1
-8
arch/powerpc/mm/mmu_decl.h
arch/powerpc/mm/mmu_decl.h
+9
-2
arch/powerpc/platforms/fsl_uli1575.c
arch/powerpc/platforms/fsl_uli1575.c
+1
-0
arch/powerpc/sysdev/fsl_pci.c
arch/powerpc/sysdev/fsl_pci.c
+74
-33
未找到文件。
arch/powerpc/boot/dts/mpc8544ds.dts
浏览文件 @
30aae739
...
...
@@ -313,7 +313,7 @@
0x1000000
0x0
0x0
0xe1010000
0x0
0x10000
>;
clock
-
frequency
=
<
33333333
>;
interrupt
-
parent
=
<&
mpic
>;
interrupts
=
<
2
6
2
>;
interrupts
=
<
2
5
2
>;
interrupt
-
map
-
mask
=
<
0xf800
0x0
0x0
0x7
>;
interrupt
-
map
=
<
/*
IDSEL
0x0
*/
...
...
@@ -350,7 +350,7 @@
0x1000000
0x0
0x0
0xe1020000
0x0
0x10000
>;
clock
-
frequency
=
<
33333333
>;
interrupt
-
parent
=
<&
mpic
>;
interrupts
=
<
2
5
2
>;
interrupts
=
<
2
6
2
>;
interrupt
-
map
-
mask
=
<
0xf800
0x0
0x0
0x7
>;
interrupt
-
map
=
<
/*
IDSEL
0x0
*/
...
...
arch/powerpc/boot/dts/mpc8572ds.dts
浏览文件 @
30aae739
...
...
@@ -724,7 +724,7 @@
0x1000000
0x0
0x00000000
0
0xffc10000
0x0
0x00010000
>;
clock
-
frequency
=
<
33333333
>;
interrupt
-
parent
=
<&
mpic
>;
interrupts
=
<
2
6
2
>;
interrupts
=
<
2
5
2
>;
interrupt
-
map
-
mask
=
<
0xf800
0x0
0x0
0x7
>;
interrupt
-
map
=
<
/*
IDSEL
0x0
*/
...
...
@@ -761,7 +761,7 @@
0x1000000
0x0
0x00000000
0
0xffc20000
0x0
0x00010000
>;
clock
-
frequency
=
<
33333333
>;
interrupt
-
parent
=
<&
mpic
>;
interrupts
=
<
2
7
2
>;
interrupts
=
<
2
6
2
>;
interrupt
-
map
-
mask
=
<
0xf800
0x0
0x0
0x7
>;
interrupt
-
map
=
<
/*
IDSEL
0x0
*/
...
...
arch/powerpc/boot/dts/mpc8572ds_camp_core0.dts
浏览文件 @
30aae739
...
...
@@ -457,7 +457,7 @@
0x1000000
0x0
0x0
0xffc10000
0x0
0x10000
>;
clock
-
frequency
=
<
33333333
>;
interrupt
-
parent
=
<&
mpic
>;
interrupts
=
<
2
6
2
>;
interrupts
=
<
2
5
2
>;
interrupt
-
map
-
mask
=
<
0xf800
0x0
0x0
0x7
>;
interrupt
-
map
=
<
/*
IDSEL
0x0
*/
...
...
arch/powerpc/boot/dts/mpc8572ds_camp_core1.dts
浏览文件 @
30aae739
...
...
@@ -208,7 +208,7 @@
0x1000000 0x0 0x0 0xffc20000 0x0 0x10000>;
clock-frequency = <33333333>;
interrupt-parent = <&mpic>;
interrupts = <2
7
2>;
interrupts = <2
6
2>;
interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
interrupt-map = <
/* IDSEL 0x0 */
...
...
arch/powerpc/include/asm/qe.h
浏览文件 @
30aae739
...
...
@@ -624,7 +624,7 @@ struct ucc_slow_pram {
#define UCC_GETH_UCCE_RXF1 0x00000002
#define UCC_GETH_UCCE_RXF0 0x00000001
/* U
PSMR, when used as a
UART */
/* U
CC Protocol Specific Mode Register (UPSMR), when used for
UART */
#define UCC_UART_UPSMR_FLC 0x8000
#define UCC_UART_UPSMR_SL 0x4000
#define UCC_UART_UPSMR_CL_MASK 0x3000
...
...
@@ -652,6 +652,23 @@ struct ucc_slow_pram {
#define UCC_UART_UPSMR_TPM_EVEN 0x0002
#define UCC_UART_UPSMR_TPM_HIGH 0x0003
/* UCC Protocol Specific Mode Register (UPSMR), when used for Ethernet */
#define UCC_GETH_UPSMR_FTFE 0x80000000
#define UCC_GETH_UPSMR_PTPE 0x40000000
#define UCC_GETH_UPSMR_ECM 0x04000000
#define UCC_GETH_UPSMR_HSE 0x02000000
#define UCC_GETH_UPSMR_PRO 0x00400000
#define UCC_GETH_UPSMR_CAP 0x00200000
#define UCC_GETH_UPSMR_RSH 0x00100000
#define UCC_GETH_UPSMR_RPM 0x00080000
#define UCC_GETH_UPSMR_R10M 0x00040000
#define UCC_GETH_UPSMR_RLPB 0x00020000
#define UCC_GETH_UPSMR_TBIM 0x00010000
#define UCC_GETH_UPSMR_RES1 0x00002000
#define UCC_GETH_UPSMR_RMM 0x00001000
#define UCC_GETH_UPSMR_CAM 0x00000400
#define UCC_GETH_UPSMR_BRO 0x00000200
/* UCC Transmit On Demand Register (UTODR) */
#define UCC_SLOW_TOD 0x8000
#define UCC_FAST_TOD 0x8000
...
...
arch/powerpc/kernel/asm-offsets.c
浏览文件 @
30aae739
...
...
@@ -56,6 +56,10 @@
#include "head_booke.h"
#endif
#if defined(CONFIG_FSL_BOOKE)
#include "../mm/mmu_decl.h"
#endif
int
main
(
void
)
{
DEFINE
(
THREAD
,
offsetof
(
struct
task_struct
,
thread
));
...
...
@@ -382,6 +386,9 @@ int main(void)
DEFINE
(
PGD_T_LOG2
,
PGD_T_LOG2
);
DEFINE
(
PTE_T_LOG2
,
PTE_T_LOG2
);
#endif
#ifdef CONFIG_FSL_BOOKE
DEFINE
(
TLBCAM_SIZE
,
sizeof
(
struct
tlbcam
));
#endif
#ifdef CONFIG_KVM_EXIT_TIMING
DEFINE
(
VCPU_TIMING_EXIT_TBU
,
offsetof
(
struct
kvm_vcpu
,
...
...
arch/powerpc/kernel/head_fsl_booke.S
浏览文件 @
30aae739
...
...
@@ -389,10 +389,6 @@ skpinv: addi r6,r6,1 /* Increment */
#endif
#endif
mfspr
r3
,
SPRN_TLB1CFG
andi
.
r3
,
r3
,
0xfff
lis
r4
,
num_tlbcam_entries
@
ha
stw
r3
,
num_tlbcam_entries
@
l
(
r4
)
/*
*
Decide
what
sort
of
machine
this
is
and
initialize
the
MMU
.
*/
...
...
@@ -909,7 +905,7 @@ KernelSPE:
_GLOBAL
(
loadcam_entry
)
lis
r4
,
TLBCAM
@
ha
addi
r4
,
r4
,
TLBCAM
@
l
mulli
r5
,
r3
,
20
mulli
r5
,
r3
,
TLBCAM_SIZE
add
r3
,
r5
,
r4
lwz
r4
,
0
(
r3
)
mtspr
SPRN_MAS0
,
r4
...
...
arch/powerpc/mm/fsl_booke_mmu.c
浏览文件 @
30aae739
...
...
@@ -56,18 +56,11 @@
extern
void
loadcam_entry
(
unsigned
int
index
);
unsigned
int
tlbcam_index
;
unsigned
int
num_tlbcam_entries
;
static
unsigned
long
__cam0
,
__cam1
,
__cam2
;
#define NUM_TLBCAMS (16)
struct
tlbcam
{
u32
MAS0
;
u32
MAS1
;
u32
MAS2
;
u32
MAS3
;
u32
MAS7
;
}
TLBCAM
[
NUM_TLBCAMS
];
struct
tlbcam
TLBCAM
[
NUM_TLBCAMS
];
struct
tlbcamrange
{
unsigned
long
start
;
...
...
arch/powerpc/mm/mmu_decl.h
浏览文件 @
30aae739
...
...
@@ -75,6 +75,15 @@ extern void _tlbia(void);
#endif
/* CONFIG_PPC_MMU_NOHASH */
#ifdef CONFIG_PPC32
struct
tlbcam
{
u32
MAS0
;
u32
MAS1
;
u32
MAS2
;
u32
MAS3
;
u32
MAS7
;
};
extern
void
mapin_ram
(
void
);
extern
int
map_page
(
unsigned
long
va
,
phys_addr_t
pa
,
int
flags
);
extern
void
setbat
(
int
index
,
unsigned
long
virt
,
phys_addr_t
phys
,
...
...
@@ -90,8 +99,6 @@ extern unsigned int rtas_data, rtas_size;
struct
hash_pte
;
extern
struct
hash_pte
*
Hash
,
*
Hash_end
;
extern
unsigned
long
Hash_size
,
Hash_mask
;
extern
unsigned
int
num_tlbcam_entries
;
#endif
extern
unsigned
long
ioremap_bot
;
...
...
arch/powerpc/platforms/fsl_uli1575.c
浏览文件 @
30aae739
...
...
@@ -249,6 +249,7 @@ DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x5288, quirk_uli5288);
DECLARE_PCI_FIXUP_HEADER
(
PCI_VENDOR_ID_AL
,
0x5229
,
quirk_uli5229
);
DECLARE_PCI_FIXUP_FINAL
(
PCI_VENDOR_ID_AL
,
0x5249
,
quirk_final_uli5249
);
DECLARE_PCI_FIXUP_FINAL
(
PCI_VENDOR_ID_AL
,
0x1575
,
quirk_final_uli1575
);
DECLARE_PCI_FIXUP_RESUME
(
PCI_VENDOR_ID_AL
,
0x5229
,
quirk_uli5229
);
static
void
__devinit
hpcd_quirk_uli1575
(
struct
pci_dev
*
dev
)
{
...
...
arch/powerpc/sysdev/fsl_pci.c
浏览文件 @
30aae739
...
...
@@ -28,63 +28,104 @@
#include <sysdev/fsl_pci.h>
#if defined(CONFIG_PPC_85xx) || defined(CONFIG_PPC_86xx)
static
int
__init
setup_one_atmu
(
struct
ccsr_pci
__iomem
*
pci
,
unsigned
int
index
,
const
struct
resource
*
res
,
resource_size_t
offset
)
{
resource_size_t
pci_addr
=
res
->
start
-
offset
;
resource_size_t
phys_addr
=
res
->
start
;
resource_size_t
size
=
res
->
end
-
res
->
start
+
1
;
u32
flags
=
0x80044000
;
/* enable & mem R/W */
unsigned
int
i
;
pr_debug
(
"PCI MEM resource start 0x%016llx, size 0x%016llx.
\n
"
,
(
u64
)
res
->
start
,
(
u64
)
size
);
if
(
res
->
flags
&
IORESOURCE_PREFETCH
)
flags
|=
0x10000000
;
/* enable relaxed ordering */
for
(
i
=
0
;
size
>
0
;
i
++
)
{
unsigned
int
bits
=
min
(
__ilog2
(
size
),
__ffs
(
pci_addr
|
phys_addr
));
if
(
index
+
i
>=
5
)
return
-
1
;
out_be32
(
&
pci
->
pow
[
index
+
i
].
potar
,
pci_addr
>>
12
);
out_be32
(
&
pci
->
pow
[
index
+
i
].
potear
,
(
u64
)
pci_addr
>>
44
);
out_be32
(
&
pci
->
pow
[
index
+
i
].
powbar
,
phys_addr
>>
12
);
out_be32
(
&
pci
->
pow
[
index
+
i
].
powar
,
flags
|
(
bits
-
1
));
pci_addr
+=
(
resource_size_t
)
1U
<<
bits
;
phys_addr
+=
(
resource_size_t
)
1U
<<
bits
;
size
-=
(
resource_size_t
)
1U
<<
bits
;
}
return
i
;
}
/* atmu setup for fsl pci/pcie controller */
static
void
__init
setup_pci_atmu
(
struct
pci_controller
*
hose
,
struct
resource
*
rsrc
)
{
struct
ccsr_pci
__iomem
*
pci
;
int
i
;
int
i
,
j
,
n
;
pr_debug
(
"PCI memory map start 0x%016llx, size 0x%016llx
\n
"
,
(
u64
)
rsrc
->
start
,
(
u64
)
rsrc
->
end
-
(
u64
)
rsrc
->
start
+
1
);
pci
=
ioremap
(
rsrc
->
start
,
rsrc
->
end
-
rsrc
->
start
+
1
);
if
(
!
pci
)
{
dev_err
(
hose
->
parent
,
"Unable to map ATMU registers
\n
"
);
return
;
}
/* Disable all windows (except powar0 since its ignored) */
/* Disable all windows (except powar0 since it
'
s ignored) */
for
(
i
=
1
;
i
<
5
;
i
++
)
out_be32
(
&
pci
->
pow
[
i
].
powar
,
0
);
for
(
i
=
0
;
i
<
3
;
i
++
)
out_be32
(
&
pci
->
piw
[
i
].
piwar
,
0
);
/* Setup outbound MEM window */
for
(
i
=
0
;
i
<
3
;
i
++
)
if
(
hose
->
mem_resources
[
i
].
flags
&
IORESOURCE_MEM
){
resource_size_t
pci_addr_start
=
hose
->
mem_resources
[
i
].
start
-
hose
->
pci_mem_offset
;
pr_debug
(
"PCI MEM resource start 0x%016llx, size 0x%016llx.
\n
"
,
(
u64
)
hose
->
mem_resources
[
i
].
start
,
(
u64
)
hose
->
mem_resources
[
i
].
end
-
(
u64
)
hose
->
mem_resources
[
i
].
start
+
1
);
out_be32
(
&
pci
->
pow
[
i
+
1
].
potar
,
(
pci_addr_start
>>
12
));
out_be32
(
&
pci
->
pow
[
i
+
1
].
potear
,
0
);
out_be32
(
&
pci
->
pow
[
i
+
1
].
powbar
,
(
hose
->
mem_resources
[
i
].
start
>>
12
));
/* Enable, Mem R/W */
out_be32
(
&
pci
->
pow
[
i
+
1
].
powar
,
0x80044000
|
(
__ilog2
(
hose
->
mem_resources
[
i
].
end
-
hose
->
mem_resources
[
i
].
start
+
1
)
-
1
));
for
(
i
=
0
,
j
=
1
;
i
<
3
;
i
++
)
{
if
(
!
(
hose
->
mem_resources
[
i
].
flags
&
IORESOURCE_MEM
))
continue
;
n
=
setup_one_atmu
(
pci
,
j
,
&
hose
->
mem_resources
[
i
],
hose
->
pci_mem_offset
);
if
(
n
<
0
||
j
>=
5
)
{
pr_err
(
"Ran out of outbound PCI ATMUs for resource %d!
\n
"
,
i
);
hose
->
mem_resources
[
i
].
flags
|=
IORESOURCE_DISABLED
;
}
else
j
+=
n
;
}
/* Setup outbound IO window */
if
(
hose
->
io_resource
.
flags
&
IORESOURCE_IO
){
if
(
hose
->
io_resource
.
flags
&
IORESOURCE_IO
)
{
if
(
j
>=
5
)
{
pr_err
(
"Ran out of outbound PCI ATMUs for IO resource
\n
"
);
}
else
{
pr_debug
(
"PCI IO resource start 0x%016llx, size 0x%016llx, "
"phy base 0x%016llx.
\n
"
,
(
u64
)
hose
->
io_resource
.
start
,
(
u64
)
hose
->
io_resource
.
end
-
(
u64
)
hose
->
io_resource
.
start
+
1
,
(
u64
)
hose
->
io_base_phys
);
out_be32
(
&
pci
->
pow
[
i
+
1
].
potar
,
(
hose
->
io_resource
.
start
>>
12
));
out_be32
(
&
pci
->
pow
[
i
+
1
].
potear
,
0
);
out_be32
(
&
pci
->
pow
[
i
+
1
].
powbar
,
(
hose
->
io_base_phys
>>
12
));
out_be32
(
&
pci
->
pow
[
j
].
potar
,
(
hose
->
io_resource
.
start
>>
12
));
out_be32
(
&
pci
->
pow
[
j
].
potear
,
0
);
out_be32
(
&
pci
->
pow
[
j
].
powbar
,
(
hose
->
io_base_phys
>>
12
));
/* Enable, IO R/W */
out_be32
(
&
pci
->
pow
[
i
+
1
].
powar
,
0x80088000
out_be32
(
&
pci
->
pow
[
j
].
powar
,
0x80088000
|
(
__ilog2
(
hose
->
io_resource
.
end
-
hose
->
io_resource
.
start
+
1
)
-
1
));
}
}
/* Setup 2G inbound Memory Window @ 1 */
out_be32
(
&
pci
->
piw
[
2
].
pitar
,
0x00000000
);
out_be32
(
&
pci
->
piw
[
2
].
piwbar
,
0x00000000
);
out_be32
(
&
pci
->
piw
[
2
].
piwar
,
PIWAR_2G
);
iounmap
(
pci
);
}
static
void
__init
setup_pci_cmd
(
struct
pci_controller
*
hose
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录