Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
d269a36a
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
d269a36a
编写于
5月 08, 2014
作者:
J
Jason Cooper
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'mvebu/soc-pmsu' into mvebu/soc
上级
d0de9323
02e7b067
变更
6
显示空白变更内容
内联
并排
Showing
6 changed file
with
185 addition
and
28 deletion
+185
-28
Documentation/devicetree/bindings/arm/armada-370-xp-pmsu.txt
Documentation/devicetree/bindings/arm/armada-370-xp-pmsu.txt
+6
-8
Documentation/devicetree/bindings/arm/armada-cpu-reset.txt
Documentation/devicetree/bindings/arm/armada-cpu-reset.txt
+14
-0
arch/arm/mach-mvebu/Makefile
arch/arm/mach-mvebu/Makefile
+1
-1
arch/arm/mach-mvebu/common.h
arch/arm/mach-mvebu/common.h
+1
-0
arch/arm/mach-mvebu/cpu-reset.c
arch/arm/mach-mvebu/cpu-reset.c
+103
-0
arch/arm/mach-mvebu/pmsu.c
arch/arm/mach-mvebu/pmsu.c
+60
-19
未找到文件。
Documentation/devicetree/bindings/arm/armada-370-xp-pmsu.txt
浏览文件 @
d269a36a
...
...
@@ -4,17 +4,15 @@ Available on Marvell SOCs: Armada 370 and Armada XP
Required properties:
- compatible: "marvell,armada-370-xp-pmsu"
- compatible: should be "marvell,armada-370-pmsu", whereas
"marvell,armada-370-xp-pmsu" is deprecated and will be removed
- reg: Should contain PMSU registers location and length. First pair
for the per-CPU SW Reset Control registers, second pair for the
Power Management Service Unit.
- reg: Should contain PMSU registers location and length.
Example:
armada-370-xp-pmsu@d0022000 {
compatible = "marvell,armada-370-xp-pmsu";
reg = <0xd0022100 0x430>,
<0xd0020800 0x20>;
armada-370-xp-pmsu@22000 {
compatible = "marvell,armada-370-pmsu";
reg = <0x22000 0x1000>;
};
Documentation/devicetree/bindings/arm/armada-cpu-reset.txt
0 → 100644
浏览文件 @
d269a36a
Marvell Armada CPU reset controller
===================================
Required properties:
- compatible: Should be "marvell,armada-370-cpu-reset".
- reg: should be register base and length as documented in the
datasheet for the CPU reset registers
cpurst: cpurst@20800 {
compatible = "marvell,armada-370-cpu-reset";
reg = <0x20800 0x20>;
};
arch/arm/mach-mvebu/Makefile
浏览文件 @
d269a36a
...
...
@@ -3,7 +3,7 @@ ccflags-$(CONFIG_ARCH_MULTIPLATFORM) := -I$(srctree)/$(src)/include \
AFLAGS_coherency_ll.o
:=
-Wa
,-march
=
armv7-a
obj-y
+=
system-controller.o mvebu-soc-id.o
obj-y
+=
system-controller.o mvebu-soc-id.o
cpu-reset.o
obj-$(CONFIG_MACH_MVEBU_V7)
+=
board-v7.o
obj-$(CONFIG_MACH_DOVE)
+=
dove.o
obj-$(CONFIG_ARCH_MVEBU)
+=
coherency.o coherency_ll.o pmsu.o
...
...
arch/arm/mach-mvebu/common.h
浏览文件 @
d269a36a
...
...
@@ -18,6 +18,7 @@
#include <linux/reboot.h>
void
mvebu_restart
(
enum
reboot_mode
mode
,
const
char
*
cmd
);
int
mvebu_cpu_reset_deassert
(
int
cpu
);
void
armada_xp_cpu_die
(
unsigned
int
cpu
);
...
...
arch/arm/mach-mvebu/cpu-reset.c
0 → 100644
浏览文件 @
d269a36a
/*
* Copyright (C) 2014 Marvell
*
* Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
*
* This file is licensed under the terms of the GNU General Public
* License version 2. This program is licensed "as is" without any
* warranty of any kind, whether express or implied.
*/
#define pr_fmt(fmt) "mvebu-cpureset: " fmt
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/of_address.h>
#include <linux/io.h>
#include <linux/resource.h>
#include "armada-370-xp.h"
static
void
__iomem
*
cpu_reset_base
;
static
size_t
cpu_reset_size
;
#define CPU_RESET_OFFSET(cpu) (cpu * 0x8)
#define CPU_RESET_ASSERT BIT(0)
int
mvebu_cpu_reset_deassert
(
int
cpu
)
{
u32
reg
;
if
(
!
cpu_reset_base
)
return
-
ENODEV
;
if
(
CPU_RESET_OFFSET
(
cpu
)
>=
cpu_reset_size
)
return
-
EINVAL
;
reg
=
readl
(
cpu_reset_base
+
CPU_RESET_OFFSET
(
cpu
));
reg
&=
~
CPU_RESET_ASSERT
;
writel
(
reg
,
cpu_reset_base
+
CPU_RESET_OFFSET
(
cpu
));
return
0
;
}
static
int
mvebu_cpu_reset_map
(
struct
device_node
*
np
,
int
res_idx
)
{
struct
resource
res
;
if
(
of_address_to_resource
(
np
,
res_idx
,
&
res
))
{
pr_err
(
"unable to get resource
\n
"
);
return
-
ENOENT
;
}
if
(
!
request_mem_region
(
res
.
start
,
resource_size
(
&
res
),
np
->
full_name
))
{
pr_err
(
"unable to request region
\n
"
);
return
-
EBUSY
;
}
cpu_reset_base
=
ioremap
(
res
.
start
,
resource_size
(
&
res
));
if
(
!
cpu_reset_base
)
{
pr_err
(
"unable to map registers
\n
"
);
release_mem_region
(
res
.
start
,
resource_size
(
&
res
));
return
-
ENOMEM
;
}
cpu_reset_size
=
resource_size
(
&
res
);
return
0
;
}
int
__init
mvebu_cpu_reset_init
(
void
)
{
struct
device_node
*
np
;
int
res_idx
;
int
ret
;
np
=
of_find_compatible_node
(
NULL
,
NULL
,
"marvell,armada-370-cpu-reset"
);
if
(
np
)
{
res_idx
=
0
;
}
else
{
/*
* This code is kept for backward compatibility with
* old Device Trees.
*/
np
=
of_find_compatible_node
(
NULL
,
NULL
,
"marvell,armada-370-xp-pmsu"
);
if
(
np
)
{
pr_warn
(
FW_WARN
"deprecated pmsu binding
\n
"
);
res_idx
=
1
;
}
}
/* No reset node found */
if
(
!
np
)
return
-
ENODEV
;
ret
=
mvebu_cpu_reset_map
(
np
,
res_idx
);
of_node_put
(
np
);
return
ret
;
}
early_initcall
(
mvebu_cpu_reset_init
);
arch/arm/mach-mvebu/pmsu.c
浏览文件 @
d269a36a
...
...
@@ -16,44 +16,56 @@
* other SOC units
*/
#define pr_fmt(fmt) "mvebu-pmsu: " fmt
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/of_address.h>
#include <linux/io.h>
#include <linux/smp.h>
#include <linux/resource.h>
#include <asm/smp_plat.h>
#include "common.h"
#include "pmsu.h"
static
void
__iomem
*
pmsu_mp_base
;
static
void
__iomem
*
pmsu_reset_base
;
#define PMSU_BOOT_ADDR_REDIRECT_OFFSET(cpu) ((cpu * 0x100) + 0x24)
#define PMSU_RESET_CTL_OFFSET(cpu) (cpu * 0x8)
#define PMSU_BASE_OFFSET 0x100
#define PMSU_REG_SIZE 0x1000
#define PMSU_BOOT_ADDR_REDIRECT_OFFSET(cpu) ((cpu * 0x100) + 0x124)
static
struct
of_device_id
of_pmsu_table
[]
=
{
{.
compatible
=
"marvell,armada-370-xp-pmsu"
},
{
.
compatible
=
"marvell,armada-370-pmsu"
,
},
{
.
compatible
=
"marvell,armada-370-xp-pmsu"
,
},
{
/* end of list */
},
};
static
void
mvebu_pmsu_set_cpu_boot_addr
(
int
hw_cpu
,
void
*
boot_addr
)
{
writel
(
virt_to_phys
(
boot_addr
),
pmsu_mp_base
+
PMSU_BOOT_ADDR_REDIRECT_OFFSET
(
hw_cpu
));
}
#ifdef CONFIG_SMP
int
armada_xp_boot_cpu
(
unsigned
int
cpu_id
,
void
*
boot_addr
)
{
int
reg
,
hw_cpu
;
int
hw_cpu
,
ret
;
if
(
!
pmsu_mp_base
||
!
pmsu_reset_base
)
{
if
(
!
pmsu_mp_base
)
{
pr_warn
(
"Can't boot CPU. PMSU is uninitialized
\n
"
);
return
1
;
return
-
ENODEV
;
}
hw_cpu
=
cpu_logical_map
(
cpu_id
);
writel
(
virt_to_phys
(
boot_addr
),
pmsu_mp_base
+
PMSU_BOOT_ADDR_REDIRECT_OFFSET
(
hw_cpu
));
mvebu_pmsu_set_cpu_boot_addr
(
hw_cpu
,
boot_addr
);
/* Release CPU from reset by clearing reset bit*/
reg
=
readl
(
pmsu_reset_base
+
PMSU_RESET_CTL_OFFSET
(
hw_cpu
));
reg
&=
(
~
0x1
);
writel
(
reg
,
pmsu_reset_base
+
PMSU_RESET_CTL_OFFSET
(
hw_cpu
));
ret
=
mvebu_cpu_reset_deassert
(
hw_cpu
);
if
(
ret
)
{
pr_warn
(
"unable to boot CPU: %d
\n
"
,
ret
);
return
ret
;
}
return
0
;
}
...
...
@@ -62,16 +74,45 @@ int armada_xp_boot_cpu(unsigned int cpu_id, void *boot_addr)
static
int
__init
armada_370_xp_pmsu_init
(
void
)
{
struct
device_node
*
np
;
struct
resource
res
;
int
ret
=
0
;
np
=
of_find_matching_node
(
NULL
,
of_pmsu_table
);
if
(
np
)
{
if
(
!
np
)
return
0
;
pr_info
(
"Initializing Power Management Service Unit
\n
"
);
pmsu_mp_base
=
of_iomap
(
np
,
0
);
pmsu_reset_base
=
of_iomap
(
np
,
1
);
of_node_put
(
np
);
if
(
of_address_to_resource
(
np
,
0
,
&
res
))
{
pr_err
(
"unable to get resource
\n
"
);
ret
=
-
ENOENT
;
goto
out
;
}
return
0
;
if
(
of_device_is_compatible
(
np
,
"marvell,armada-370-xp-pmsu"
))
{
pr_warn
(
FW_WARN
"deprecated pmsu binding
\n
"
);
res
.
start
=
res
.
start
-
PMSU_BASE_OFFSET
;
res
.
end
=
res
.
start
+
PMSU_REG_SIZE
-
1
;
}
if
(
!
request_mem_region
(
res
.
start
,
resource_size
(
&
res
),
np
->
full_name
))
{
pr_err
(
"unable to request region
\n
"
);
ret
=
-
EBUSY
;
goto
out
;
}
pmsu_mp_base
=
ioremap
(
res
.
start
,
resource_size
(
&
res
));
if
(
!
pmsu_mp_base
)
{
pr_err
(
"unable to map registers
\n
"
);
release_mem_region
(
res
.
start
,
resource_size
(
&
res
));
ret
=
-
ENOMEM
;
goto
out
;
}
out:
of_node_put
(
np
);
return
ret
;
}
early_initcall
(
armada_370_xp_pmsu_init
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录