Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
cdde51b9
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 4 年多
通知
15
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看板
提交
cdde51b9
编写于
4月 10, 2015
作者:
R
Rafael J. Wysocki
浏览文件
操作
浏览文件
下载
差异文件
Merge back earlier cpuidle material for v4.1.
上级
e5e02de0
993c592d
变更
24
隐藏空白更改
内联
并排
Showing
24 changed file
with
249 addition
and
72 deletion
+249
-72
arch/arm/include/asm/cpuidle.h
arch/arm/include/asm/cpuidle.h
+23
-0
arch/arm/kernel/cpuidle.c
arch/arm/kernel/cpuidle.c
+132
-1
arch/arm/mach-davinci/cpuidle.c
arch/arm/mach-davinci/cpuidle.c
+0
-1
arch/arm/mach-imx/cpuidle-imx6q.c
arch/arm/mach-imx/cpuidle-imx6q.c
+0
-1
arch/arm/mach-imx/cpuidle-imx6sl.c
arch/arm/mach-imx/cpuidle-imx6sl.c
+0
-1
arch/arm/mach-imx/cpuidle-imx6sx.c
arch/arm/mach-imx/cpuidle-imx6sx.c
+0
-1
arch/arm/mach-omap2/cpuidle44xx.c
arch/arm/mach-omap2/cpuidle44xx.c
+0
-1
arch/arm/mach-s3c64xx/cpuidle.c
arch/arm/mach-s3c64xx/cpuidle.c
+1
-1
arch/arm/mach-tegra/cpuidle-tegra20.c
arch/arm/mach-tegra/cpuidle-tegra20.c
+0
-1
arch/arm/mach-tegra/cpuidle-tegra30.c
arch/arm/mach-tegra/cpuidle-tegra30.c
+0
-1
arch/arm64/configs/defconfig
arch/arm64/configs/defconfig
+1
-1
arch/arm64/include/asm/cpuidle.h
arch/arm64/include/asm/cpuidle.h
+6
-3
arch/arm64/kernel/cpuidle.c
arch/arm64/kernel/cpuidle.c
+1
-1
drivers/cpuidle/Kconfig
drivers/cpuidle/Kconfig
+1
-6
drivers/cpuidle/Kconfig.arm
drivers/cpuidle/Kconfig.arm
+19
-9
drivers/cpuidle/Kconfig.arm64
drivers/cpuidle/Kconfig.arm64
+0
-13
drivers/cpuidle/Makefile
drivers/cpuidle/Makefile
+1
-4
drivers/cpuidle/cpuidle-arm.c
drivers/cpuidle/cpuidle-arm.c
+62
-21
drivers/cpuidle/cpuidle-at91.c
drivers/cpuidle/cpuidle-at91.c
+0
-1
drivers/cpuidle/cpuidle-exynos.c
drivers/cpuidle/cpuidle-exynos.c
+0
-1
drivers/cpuidle/cpuidle-kirkwood.c
drivers/cpuidle/cpuidle-kirkwood.c
+0
-1
drivers/cpuidle/cpuidle-ux500.c
drivers/cpuidle/cpuidle-ux500.c
+0
-1
drivers/cpuidle/cpuidle-zynq.c
drivers/cpuidle/cpuidle-zynq.c
+0
-1
include/asm-generic/vmlinux.lds.h
include/asm-generic/vmlinux.lds.h
+2
-0
未找到文件。
arch/arm/include/asm/cpuidle.h
浏览文件 @
cdde51b9
#ifndef __ASM_ARM_CPUIDLE_H
#ifndef __ASM_ARM_CPUIDLE_H
#define __ASM_ARM_CPUIDLE_H
#define __ASM_ARM_CPUIDLE_H
#include <asm/proc-fns.h>
#ifdef CONFIG_CPU_IDLE
#ifdef CONFIG_CPU_IDLE
extern
int
arm_cpuidle_simple_enter
(
struct
cpuidle_device
*
dev
,
extern
int
arm_cpuidle_simple_enter
(
struct
cpuidle_device
*
dev
,
struct
cpuidle_driver
*
drv
,
int
index
);
struct
cpuidle_driver
*
drv
,
int
index
);
...
@@ -25,4 +27,25 @@ static inline int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
...
@@ -25,4 +27,25 @@ static inline int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
*/
*/
#define ARM_CPUIDLE_WFI_STATE ARM_CPUIDLE_WFI_STATE_PWR(UINT_MAX)
#define ARM_CPUIDLE_WFI_STATE ARM_CPUIDLE_WFI_STATE_PWR(UINT_MAX)
struct
device_node
;
struct
cpuidle_ops
{
int
(
*
suspend
)(
int
cpu
,
unsigned
long
arg
);
int
(
*
init
)(
struct
device_node
*
,
int
cpu
);
};
struct
of_cpuidle_method
{
const
char
*
method
;
struct
cpuidle_ops
*
ops
;
};
#define CPUIDLE_METHOD_OF_DECLARE(name, _method, _ops) \
static const struct of_cpuidle_method __cpuidle_method_of_table_##name \
__used __section(__cpuidle_method_of_table) \
= { .method = _method, .ops = _ops }
extern
int
arm_cpuidle_suspend
(
int
index
);
extern
int
arm_cpuidle_init
(
int
cpu
);
#endif
#endif
arch/arm/kernel/cpuidle.c
浏览文件 @
cdde51b9
...
@@ -10,8 +10,28 @@
...
@@ -10,8 +10,28 @@
*/
*/
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <asm/proc-fns.h>
#include <linux/of.h>
#include <linux/of_device.h>
#include <asm/cpuidle.h>
extern
struct
of_cpuidle_method
__cpuidle_method_of_table
[];
static
const
struct
of_cpuidle_method
__cpuidle_method_of_table_sentinel
__used
__section
(
__cpuidle_method_of_table_end
);
static
struct
cpuidle_ops
cpuidle_ops
[
NR_CPUS
];
/**
* arm_cpuidle_simple_enter() - a wrapper to cpu_do_idle()
* @dev: not used
* @drv: not used
* @index: not used
*
* A trivial wrapper to allow the cpu_do_idle function to be assigned as a
* cpuidle callback by matching the function signature.
*
* Returns the index passed as parameter
*/
int
arm_cpuidle_simple_enter
(
struct
cpuidle_device
*
dev
,
int
arm_cpuidle_simple_enter
(
struct
cpuidle_device
*
dev
,
struct
cpuidle_driver
*
drv
,
int
index
)
struct
cpuidle_driver
*
drv
,
int
index
)
{
{
...
@@ -19,3 +39,114 @@ int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
...
@@ -19,3 +39,114 @@ int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
return
index
;
return
index
;
}
}
/**
* arm_cpuidle_suspend() - function to enter low power idle states
* @index: an integer used as an identifier for the low level PM callbacks
*
* This function calls the underlying arch specific low level PM code as
* registered at the init time.
*
* Returns -EOPNOTSUPP if no suspend callback is defined, the result of the
* callback otherwise.
*/
int
arm_cpuidle_suspend
(
int
index
)
{
int
ret
=
-
EOPNOTSUPP
;
int
cpu
=
smp_processor_id
();
if
(
cpuidle_ops
[
cpu
].
suspend
)
ret
=
cpuidle_ops
[
cpu
].
suspend
(
cpu
,
index
);
return
ret
;
}
/**
* arm_cpuidle_get_ops() - find a registered cpuidle_ops by name
* @method: the method name
*
* Search in the __cpuidle_method_of_table array the cpuidle ops matching the
* method name.
*
* Returns a struct cpuidle_ops pointer, NULL if not found.
*/
static
struct
cpuidle_ops
*
__init
arm_cpuidle_get_ops
(
const
char
*
method
)
{
struct
of_cpuidle_method
*
m
=
__cpuidle_method_of_table
;
for
(;
m
->
method
;
m
++
)
if
(
!
strcmp
(
m
->
method
,
method
))
return
m
->
ops
;
return
NULL
;
}
/**
* arm_cpuidle_read_ops() - Initialize the cpuidle ops with the device tree
* @dn: a pointer to a struct device node corresponding to a cpu node
* @cpu: the cpu identifier
*
* Get the method name defined in the 'enable-method' property, retrieve the
* associated cpuidle_ops and do a struct copy. This copy is needed because all
* cpuidle_ops are tagged __initdata and will be unloaded after the init
* process.
*
* Return 0 on sucess, -ENOENT if no 'enable-method' is defined, -EOPNOTSUPP if
* no cpuidle_ops is registered for the 'enable-method'.
*/
static
int
__init
arm_cpuidle_read_ops
(
struct
device_node
*
dn
,
int
cpu
)
{
const
char
*
enable_method
;
struct
cpuidle_ops
*
ops
;
enable_method
=
of_get_property
(
dn
,
"enable-method"
,
NULL
);
if
(
!
enable_method
)
return
-
ENOENT
;
ops
=
arm_cpuidle_get_ops
(
enable_method
);
if
(
!
ops
)
{
pr_warn
(
"%s: unsupported enable-method property: %s
\n
"
,
dn
->
full_name
,
enable_method
);
return
-
EOPNOTSUPP
;
}
cpuidle_ops
[
cpu
]
=
*
ops
;
/* structure copy */
pr_notice
(
"cpuidle: enable-method property '%s'"
" found operations
\n
"
,
enable_method
);
return
0
;
}
/**
* arm_cpuidle_init() - Initialize cpuidle_ops for a specific cpu
* @cpu: the cpu to be initialized
*
* Initialize the cpuidle ops with the device for the cpu and then call
* the cpu's idle initialization callback. This may fail if the underlying HW
* is not operational.
*
* Returns:
* 0 on success,
* -ENODEV if it fails to find the cpu node in the device tree,
* -EOPNOTSUPP if it does not find a registered cpuidle_ops for this cpu,
* -ENOENT if it fails to find an 'enable-method' property,
* -ENXIO if the HW reports a failure or a misconfiguration,
* -ENOMEM if the HW report an memory allocation failure
*/
int
__init
arm_cpuidle_init
(
int
cpu
)
{
struct
device_node
*
cpu_node
=
of_cpu_device_node_get
(
cpu
);
int
ret
;
if
(
!
cpu_node
)
return
-
ENODEV
;
ret
=
arm_cpuidle_read_ops
(
cpu_node
,
cpu
);
if
(
!
ret
&&
cpuidle_ops
[
cpu
].
init
)
ret
=
cpuidle_ops
[
cpu
].
init
(
cpu_node
,
cpu
);
of_node_put
(
cpu_node
);
return
ret
;
}
arch/arm/mach-davinci/cpuidle.c
浏览文件 @
cdde51b9
...
@@ -17,7 +17,6 @@
...
@@ -17,7 +17,6 @@
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <linux/io.h>
#include <linux/io.h>
#include <linux/export.h>
#include <linux/export.h>
#include <asm/proc-fns.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <mach/cpuidle.h>
#include <mach/cpuidle.h>
...
...
arch/arm/mach-imx/cpuidle-imx6q.c
浏览文件 @
cdde51b9
...
@@ -9,7 +9,6 @@
...
@@ -9,7 +9,6 @@
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <linux/module.h>
#include <linux/module.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/proc-fns.h>
#include "common.h"
#include "common.h"
#include "cpuidle.h"
#include "cpuidle.h"
...
...
arch/arm/mach-imx/cpuidle-imx6sl.c
浏览文件 @
cdde51b9
...
@@ -9,7 +9,6 @@
...
@@ -9,7 +9,6 @@
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <linux/module.h>
#include <linux/module.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/proc-fns.h>
#include "common.h"
#include "common.h"
#include "cpuidle.h"
#include "cpuidle.h"
...
...
arch/arm/mach-imx/cpuidle-imx6sx.c
浏览文件 @
cdde51b9
...
@@ -10,7 +10,6 @@
...
@@ -10,7 +10,6 @@
#include <linux/cpu_pm.h>
#include <linux/cpu_pm.h>
#include <linux/module.h>
#include <linux/module.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/proc-fns.h>
#include <asm/suspend.h>
#include <asm/suspend.h>
#include "common.h"
#include "common.h"
...
...
arch/arm/mach-omap2/cpuidle44xx.c
浏览文件 @
cdde51b9
...
@@ -17,7 +17,6 @@
...
@@ -17,7 +17,6 @@
#include <linux/clockchips.h>
#include <linux/clockchips.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/proc-fns.h>
#include "common.h"
#include "common.h"
#include "pm.h"
#include "pm.h"
...
...
arch/arm/mach-s3c64xx/cpuidle.c
浏览文件 @
cdde51b9
...
@@ -16,7 +16,7 @@
...
@@ -16,7 +16,7 @@
#include <linux/export.h>
#include <linux/export.h>
#include <linux/time.h>
#include <linux/time.h>
#include <asm/
proc-fns
.h>
#include <asm/
cpuidle
.h>
#include <mach/map.h>
#include <mach/map.h>
...
...
arch/arm/mach-tegra/cpuidle-tegra20.c
浏览文件 @
cdde51b9
...
@@ -27,7 +27,6 @@
...
@@ -27,7 +27,6 @@
#include <linux/module.h>
#include <linux/module.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/proc-fns.h>
#include <asm/smp_plat.h>
#include <asm/smp_plat.h>
#include <asm/suspend.h>
#include <asm/suspend.h>
...
...
arch/arm/mach-tegra/cpuidle-tegra30.c
浏览文件 @
cdde51b9
...
@@ -27,7 +27,6 @@
...
@@ -27,7 +27,6 @@
#include <linux/module.h>
#include <linux/module.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/proc-fns.h>
#include <asm/smp_plat.h>
#include <asm/smp_plat.h>
#include <asm/suspend.h>
#include <asm/suspend.h>
...
...
arch/arm64/configs/defconfig
浏览文件 @
cdde51b9
...
@@ -48,7 +48,7 @@ CONFIG_CMDLINE="console=ttyAMA0"
...
@@ -48,7 +48,7 @@ CONFIG_CMDLINE="console=ttyAMA0"
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
CONFIG_COMPAT=y
CONFIG_COMPAT=y
CONFIG_CPU_IDLE=y
CONFIG_CPU_IDLE=y
CONFIG_ARM
64
_CPUIDLE=y
CONFIG_ARM_CPUIDLE=y
CONFIG_NET=y
CONFIG_NET=y
CONFIG_PACKET=y
CONFIG_PACKET=y
CONFIG_UNIX=y
CONFIG_UNIX=y
...
...
arch/arm64/include/asm/cpuidle.h
浏览文件 @
cdde51b9
...
@@ -4,10 +4,10 @@
...
@@ -4,10 +4,10 @@
#include <asm/proc-fns.h>
#include <asm/proc-fns.h>
#ifdef CONFIG_CPU_IDLE
#ifdef CONFIG_CPU_IDLE
extern
int
cpu_init_idle
(
unsigned
int
cpu
);
extern
int
arm_cpuidle_init
(
unsigned
int
cpu
);
extern
int
cpu_suspend
(
unsigned
long
arg
);
extern
int
cpu_suspend
(
unsigned
long
arg
);
#else
#else
static
inline
int
cpu_init_idle
(
unsigned
int
cpu
)
static
inline
int
arm_cpuidle_init
(
unsigned
int
cpu
)
{
{
return
-
EOPNOTSUPP
;
return
-
EOPNOTSUPP
;
}
}
...
@@ -17,5 +17,8 @@ static inline int cpu_suspend(unsigned long arg)
...
@@ -17,5 +17,8 @@ static inline int cpu_suspend(unsigned long arg)
return
-
EOPNOTSUPP
;
return
-
EOPNOTSUPP
;
}
}
#endif
#endif
static
inline
int
arm_cpuidle_suspend
(
int
index
)
{
return
cpu_suspend
(
index
);
}
#endif
#endif
arch/arm64/kernel/cpuidle.c
浏览文件 @
cdde51b9
...
@@ -15,7 +15,7 @@
...
@@ -15,7 +15,7 @@
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/cpu_ops.h>
#include <asm/cpu_ops.h>
int
cpu_init_idle
(
unsigned
int
cpu
)
int
arm_cpuidle_init
(
unsigned
int
cpu
)
{
{
int
ret
=
-
EOPNOTSUPP
;
int
ret
=
-
EOPNOTSUPP
;
struct
device_node
*
cpu_node
=
of_cpu_device_node_get
(
cpu
);
struct
device_node
*
cpu_node
=
of_cpu_device_node_get
(
cpu
);
...
...
drivers/cpuidle/Kconfig
浏览文件 @
cdde51b9
...
@@ -29,15 +29,10 @@ config DT_IDLE_STATES
...
@@ -29,15 +29,10 @@ config DT_IDLE_STATES
bool
bool
menu "ARM CPU Idle Drivers"
menu "ARM CPU Idle Drivers"
depends on ARM
depends on ARM
|| ARM64
source "drivers/cpuidle/Kconfig.arm"
source "drivers/cpuidle/Kconfig.arm"
endmenu
endmenu
menu "ARM64 CPU Idle Drivers"
depends on ARM64
source "drivers/cpuidle/Kconfig.arm64"
endmenu
menu "MIPS CPU Idle Drivers"
menu "MIPS CPU Idle Drivers"
depends on MIPS
depends on MIPS
source "drivers/cpuidle/Kconfig.mips"
source "drivers/cpuidle/Kconfig.mips"
...
...
drivers/cpuidle/Kconfig.arm
浏览文件 @
cdde51b9
#
#
# ARM CPU Idle drivers
# ARM CPU Idle drivers
#
#
config ARM_CPUIDLE
bool "Generic ARM/ARM64 CPU idle Driver"
select DT_IDLE_STATES
help
Select this to enable generic cpuidle driver for ARM.
It provides a generic idle driver whose idle states are configured
at run-time through DT nodes. The CPUidle suspend backend is
initialized by calling the CPU operations init idle hook
provided by architecture code.
config ARM_BIG_LITTLE_CPUIDLE
config ARM_BIG_LITTLE_CPUIDLE
bool "Support for ARM big.LITTLE processors"
bool "Support for ARM big.LITTLE processors"
depends on ARCH_VEXPRESS_TC2_PM || ARCH_EXYNOS
depends on ARCH_VEXPRESS_TC2_PM || ARCH_EXYNOS
depends on MCPM
depends on MCPM
&& !ARM64
select ARM_CPU_SUSPEND
select ARM_CPU_SUSPEND
select CPU_IDLE_MULTIPLE_DRIVERS
select CPU_IDLE_MULTIPLE_DRIVERS
select DT_IDLE_STATES
select DT_IDLE_STATES
...
@@ -16,51 +26,51 @@ config ARM_BIG_LITTLE_CPUIDLE
...
@@ -16,51 +26,51 @@ config ARM_BIG_LITTLE_CPUIDLE
config ARM_CLPS711X_CPUIDLE
config ARM_CLPS711X_CPUIDLE
bool "CPU Idle Driver for CLPS711X processors"
bool "CPU Idle Driver for CLPS711X processors"
depends on ARCH_CLPS711X || COMPILE_TEST
depends on ARCH_CLPS711X
&& !ARM64
|| COMPILE_TEST
help
help
Select this to enable cpuidle on Cirrus Logic CLPS711X SOCs.
Select this to enable cpuidle on Cirrus Logic CLPS711X SOCs.
config ARM_HIGHBANK_CPUIDLE
config ARM_HIGHBANK_CPUIDLE
bool "CPU Idle Driver for Calxeda processors"
bool "CPU Idle Driver for Calxeda processors"
depends on ARM_PSCI
depends on ARM_PSCI
&& !ARM64
select ARM_CPU_SUSPEND
select ARM_CPU_SUSPEND
help
help
Select this to enable cpuidle on Calxeda processors.
Select this to enable cpuidle on Calxeda processors.
config ARM_KIRKWOOD_CPUIDLE
config ARM_KIRKWOOD_CPUIDLE
bool "CPU Idle Driver for Marvell Kirkwood SoCs"
bool "CPU Idle Driver for Marvell Kirkwood SoCs"
depends on MACH_KIRKWOOD
depends on MACH_KIRKWOOD
&& !ARM64
help
help
This adds the CPU Idle driver for Marvell Kirkwood SoCs.
This adds the CPU Idle driver for Marvell Kirkwood SoCs.
config ARM_ZYNQ_CPUIDLE
config ARM_ZYNQ_CPUIDLE
bool "CPU Idle Driver for Xilinx Zynq processors"
bool "CPU Idle Driver for Xilinx Zynq processors"
depends on ARCH_ZYNQ
depends on ARCH_ZYNQ
&& !ARM64
help
help
Select this to enable cpuidle on Xilinx Zynq processors.
Select this to enable cpuidle on Xilinx Zynq processors.
config ARM_U8500_CPUIDLE
config ARM_U8500_CPUIDLE
bool "Cpu Idle Driver for the ST-E u8500 processors"
bool "Cpu Idle Driver for the ST-E u8500 processors"
depends on ARCH_U8500
depends on ARCH_U8500
&& !ARM64
help
help
Select this to enable cpuidle for ST-E u8500 processors
Select this to enable cpuidle for ST-E u8500 processors
config ARM_AT91_CPUIDLE
config ARM_AT91_CPUIDLE
bool "Cpu Idle Driver for the AT91 processors"
bool "Cpu Idle Driver for the AT91 processors"
default y
default y
depends on ARCH_AT91
depends on ARCH_AT91
&& !ARM64
help
help
Select this to enable cpuidle for AT91 processors
Select this to enable cpuidle for AT91 processors
config ARM_EXYNOS_CPUIDLE
config ARM_EXYNOS_CPUIDLE
bool "Cpu Idle Driver for the Exynos processors"
bool "Cpu Idle Driver for the Exynos processors"
depends on ARCH_EXYNOS
depends on ARCH_EXYNOS
&& !ARM64
select ARCH_NEEDS_CPU_IDLE_COUPLED if SMP
select ARCH_NEEDS_CPU_IDLE_COUPLED if SMP
help
help
Select this to enable cpuidle for Exynos processors
Select this to enable cpuidle for Exynos processors
config ARM_MVEBU_V7_CPUIDLE
config ARM_MVEBU_V7_CPUIDLE
bool "CPU Idle Driver for mvebu v7 family processors"
bool "CPU Idle Driver for mvebu v7 family processors"
depends on ARCH_MVEBU
depends on ARCH_MVEBU
&& !ARM64
help
help
Select this to enable cpuidle on Armada 370, 38x and XP processors.
Select this to enable cpuidle on Armada 370, 38x and XP processors.
drivers/cpuidle/Kconfig.arm64
已删除
100644 → 0
浏览文件 @
e5e02de0
#
# ARM64 CPU Idle drivers
#
config ARM64_CPUIDLE
bool "Generic ARM64 CPU idle Driver"
select DT_IDLE_STATES
help
Select this to enable generic cpuidle driver for ARM64.
It provides a generic idle driver whose idle states are configured
at run-time through DT nodes. The CPUidle suspend backend is
initialized by calling the CPU operations init idle hook
provided by architecture code.
drivers/cpuidle/Makefile
浏览文件 @
cdde51b9
...
@@ -17,15 +17,12 @@ obj-$(CONFIG_ARM_ZYNQ_CPUIDLE) += cpuidle-zynq.o
...
@@ -17,15 +17,12 @@ obj-$(CONFIG_ARM_ZYNQ_CPUIDLE) += cpuidle-zynq.o
obj-$(CONFIG_ARM_U8500_CPUIDLE)
+=
cpuidle-ux500.o
obj-$(CONFIG_ARM_U8500_CPUIDLE)
+=
cpuidle-ux500.o
obj-$(CONFIG_ARM_AT91_CPUIDLE)
+=
cpuidle-at91.o
obj-$(CONFIG_ARM_AT91_CPUIDLE)
+=
cpuidle-at91.o
obj-$(CONFIG_ARM_EXYNOS_CPUIDLE)
+=
cpuidle-exynos.o
obj-$(CONFIG_ARM_EXYNOS_CPUIDLE)
+=
cpuidle-exynos.o
obj-$(CONFIG_ARM_CPUIDLE)
+=
cpuidle-arm.o
###############################################################################
###############################################################################
# MIPS drivers
# MIPS drivers
obj-$(CONFIG_MIPS_CPS_CPUIDLE)
+=
cpuidle-cps.o
obj-$(CONFIG_MIPS_CPS_CPUIDLE)
+=
cpuidle-cps.o
###############################################################################
# ARM64 drivers
obj-$(CONFIG_ARM64_CPUIDLE)
+=
cpuidle-arm64.o
###############################################################################
###############################################################################
# POWERPC drivers
# POWERPC drivers
obj-$(CONFIG_PSERIES_CPUIDLE)
+=
cpuidle-pseries.o
obj-$(CONFIG_PSERIES_CPUIDLE)
+=
cpuidle-pseries.o
...
...
drivers/cpuidle/cpuidle-arm
64
.c
→
drivers/cpuidle/cpuidle-arm.c
浏览文件 @
cdde51b9
/*
/*
* ARM64 generic CPU idle driver.
* ARM
/ARM
64 generic CPU idle driver.
*
*
* Copyright (C) 2014 ARM Ltd.
* Copyright (C) 2014 ARM Ltd.
* Author: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
* Author: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
...
@@ -9,7 +9,7 @@
...
@@ -9,7 +9,7 @@
* published by the Free Software Foundation.
* published by the Free Software Foundation.
*/
*/
#define pr_fmt(fmt) "CPUidle arm
64
: " fmt
#define pr_fmt(fmt) "CPUidle arm: " fmt
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <linux/cpumask.h>
#include <linux/cpumask.h>
...
@@ -17,13 +17,14 @@
...
@@ -17,13 +17,14 @@
#include <linux/kernel.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/of.h>
#include <linux/slab.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include "dt_idle_states.h"
#include "dt_idle_states.h"
/*
/*
* arm
64
_enter_idle_state - Programs CPU to enter the specified state
* arm_enter_idle_state - Programs CPU to enter the specified state
*
*
* dev: cpuidle device
* dev: cpuidle device
* drv: cpuidle driver
* drv: cpuidle driver
...
@@ -32,8 +33,8 @@
...
@@ -32,8 +33,8 @@
* Called from the CPUidle framework to program the device to the
* Called from the CPUidle framework to program the device to the
* specified target state selected by the governor.
* specified target state selected by the governor.
*/
*/
static
int
arm
64
_enter_idle_state
(
struct
cpuidle_device
*
dev
,
static
int
arm_enter_idle_state
(
struct
cpuidle_device
*
dev
,
struct
cpuidle_driver
*
drv
,
int
idx
)
struct
cpuidle_driver
*
drv
,
int
idx
)
{
{
int
ret
;
int
ret
;
...
@@ -49,7 +50,7 @@ static int arm64_enter_idle_state(struct cpuidle_device *dev,
...
@@ -49,7 +50,7 @@ static int arm64_enter_idle_state(struct cpuidle_device *dev,
* call the CPU ops suspend protocol with idle index as a
* call the CPU ops suspend protocol with idle index as a
* parameter.
* parameter.
*/
*/
ret
=
cpu
_suspend
(
idx
);
arm_cpuidle
_suspend
(
idx
);
cpu_pm_exit
();
cpu_pm_exit
();
}
}
...
@@ -57,8 +58,8 @@ static int arm64_enter_idle_state(struct cpuidle_device *dev,
...
@@ -57,8 +58,8 @@ static int arm64_enter_idle_state(struct cpuidle_device *dev,
return
ret
?
-
1
:
idx
;
return
ret
?
-
1
:
idx
;
}
}
static
struct
cpuidle_driver
arm
64
_idle_driver
=
{
static
struct
cpuidle_driver
arm_idle_driver
=
{
.
name
=
"arm
64
_idle"
,
.
name
=
"arm_idle"
,
.
owner
=
THIS_MODULE
,
.
owner
=
THIS_MODULE
,
/*
/*
* State at index 0 is standby wfi and considered standard
* State at index 0 is standby wfi and considered standard
...
@@ -68,32 +69,33 @@ static struct cpuidle_driver arm64_idle_driver = {
...
@@ -68,32 +69,33 @@ static struct cpuidle_driver arm64_idle_driver = {
* handler for idle state index 0.
* handler for idle state index 0.
*/
*/
.
states
[
0
]
=
{
.
states
[
0
]
=
{
.
enter
=
arm
64
_enter_idle_state
,
.
enter
=
arm_enter_idle_state
,
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
power_usage
=
UINT_MAX
,
.
power_usage
=
UINT_MAX
,
.
name
=
"WFI"
,
.
name
=
"WFI"
,
.
desc
=
"ARM
64
WFI"
,
.
desc
=
"ARM WFI"
,
}
}
};
};
static
const
struct
of_device_id
arm
64
_idle_state_match
[]
__initconst
=
{
static
const
struct
of_device_id
arm_idle_state_match
[]
__initconst
=
{
{
.
compatible
=
"arm,idle-state"
,
{
.
compatible
=
"arm,idle-state"
,
.
data
=
arm
64
_enter_idle_state
},
.
data
=
arm_enter_idle_state
},
{
},
{
},
};
};
/*
/*
* arm
64
_idle_init
* arm_idle_init
*
*
* Registers the arm
64
specific cpuidle driver with the cpuidle
* Registers the arm specific cpuidle driver with the cpuidle
* framework. It relies on core code to parse the idle states
* framework. It relies on core code to parse the idle states
* and initialize them using driver data structures accordingly.
* and initialize them using driver data structures accordingly.
*/
*/
static
int
__init
arm
64
_idle_init
(
void
)
static
int
__init
arm_idle_init
(
void
)
{
{
int
cpu
,
ret
;
int
cpu
,
ret
;
struct
cpuidle_driver
*
drv
=
&
arm64_idle_driver
;
struct
cpuidle_driver
*
drv
=
&
arm_idle_driver
;
struct
cpuidle_device
*
dev
;
/*
/*
* Initialize idle states data, starting at index 1.
* Initialize idle states data, starting at index 1.
...
@@ -101,22 +103,61 @@ static int __init arm64_idle_init(void)
...
@@ -101,22 +103,61 @@ static int __init arm64_idle_init(void)
* let the driver initialization fail accordingly since there is no
* let the driver initialization fail accordingly since there is no
* reason to initialize the idle driver if only wfi is supported.
* reason to initialize the idle driver if only wfi is supported.
*/
*/
ret
=
dt_init_idle_driver
(
drv
,
arm
64
_idle_state_match
,
1
);
ret
=
dt_init_idle_driver
(
drv
,
arm_idle_state_match
,
1
);
if
(
ret
<=
0
)
if
(
ret
<=
0
)
return
ret
?
:
-
ENODEV
;
return
ret
?
:
-
ENODEV
;
ret
=
cpuidle_register_driver
(
drv
);
if
(
ret
)
{
pr_err
(
"Failed to register cpuidle driver
\n
"
);
return
ret
;
}
/*
/*
* Call arch CPU operations in order to initialize
* Call arch CPU operations in order to initialize
* idle states suspend back-end specific data
* idle states suspend back-end specific data
*/
*/
for_each_possible_cpu
(
cpu
)
{
for_each_possible_cpu
(
cpu
)
{
ret
=
cpu_init_idle
(
cpu
);
ret
=
arm_cpuidle_init
(
cpu
);
/*
* Skip the cpuidle device initialization if the reported
* failure is a HW misconfiguration/breakage (-ENXIO).
*/
if
(
ret
==
-
ENXIO
)
continue
;
if
(
ret
)
{
if
(
ret
)
{
pr_err
(
"CPU %d failed to init idle CPU ops
\n
"
,
cpu
);
pr_err
(
"CPU %d failed to init idle CPU ops
\n
"
,
cpu
);
return
ret
;
goto
out_fail
;
}
dev
=
kzalloc
(
sizeof
(
*
dev
),
GFP_KERNEL
);
if
(
!
dev
)
{
pr_err
(
"Failed to allocate cpuidle device
\n
"
);
goto
out_fail
;
}
dev
->
cpu
=
cpu
;
ret
=
cpuidle_register_device
(
dev
);
if
(
ret
)
{
pr_err
(
"Failed to register cpuidle device for CPU %d
\n
"
,
cpu
);
kfree
(
dev
);
goto
out_fail
;
}
}
}
}
return
cpuidle_register
(
drv
,
NULL
);
return
0
;
out_fail:
while
(
--
cpu
>=
0
)
{
dev
=
per_cpu
(
cpuidle_devices
,
cpu
);
cpuidle_unregister_device
(
dev
);
kfree
(
dev
);
}
cpuidle_unregister_driver
(
drv
);
return
ret
;
}
}
device_initcall
(
arm
64
_idle_init
);
device_initcall
(
arm_idle_init
);
drivers/cpuidle/cpuidle-at91.c
浏览文件 @
cdde51b9
...
@@ -19,7 +19,6 @@
...
@@ -19,7 +19,6 @@
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <linux/io.h>
#include <linux/io.h>
#include <linux/export.h>
#include <linux/export.h>
#include <asm/proc-fns.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#define AT91_MAX_STATES 2
#define AT91_MAX_STATES 2
...
...
drivers/cpuidle/cpuidle-exynos.c
浏览文件 @
cdde51b9
...
@@ -19,7 +19,6 @@
...
@@ -19,7 +19,6 @@
#include <linux/of.h>
#include <linux/of.h>
#include <linux/platform_data/cpuidle-exynos.h>
#include <linux/platform_data/cpuidle-exynos.h>
#include <asm/proc-fns.h>
#include <asm/suspend.h>
#include <asm/suspend.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
...
...
drivers/cpuidle/cpuidle-kirkwood.c
浏览文件 @
cdde51b9
...
@@ -21,7 +21,6 @@
...
@@ -21,7 +21,6 @@
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <linux/io.h>
#include <linux/io.h>
#include <linux/export.h>
#include <linux/export.h>
#include <asm/proc-fns.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#define KIRKWOOD_MAX_STATES 2
#define KIRKWOOD_MAX_STATES 2
...
...
drivers/cpuidle/cpuidle-ux500.c
浏览文件 @
cdde51b9
...
@@ -19,7 +19,6 @@
...
@@ -19,7 +19,6 @@
#include <linux/platform_device.h>
#include <linux/platform_device.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#include <asm/proc-fns.h>
static
atomic_t
master
=
ATOMIC_INIT
(
0
);
static
atomic_t
master
=
ATOMIC_INIT
(
0
);
static
DEFINE_SPINLOCK
(
master_lock
);
static
DEFINE_SPINLOCK
(
master_lock
);
...
...
drivers/cpuidle/cpuidle-zynq.c
浏览文件 @
cdde51b9
...
@@ -28,7 +28,6 @@
...
@@ -28,7 +28,6 @@
#include <linux/init.h>
#include <linux/init.h>
#include <linux/cpuidle.h>
#include <linux/cpuidle.h>
#include <linux/platform_device.h>
#include <linux/platform_device.h>
#include <asm/proc-fns.h>
#include <asm/cpuidle.h>
#include <asm/cpuidle.h>
#define ZYNQ_MAX_STATES 2
#define ZYNQ_MAX_STATES 2
...
...
include/asm-generic/vmlinux.lds.h
浏览文件 @
cdde51b9
...
@@ -167,6 +167,7 @@
...
@@ -167,6 +167,7 @@
#define IOMMU_OF_TABLES() OF_TABLE(CONFIG_OF_IOMMU, iommu)
#define IOMMU_OF_TABLES() OF_TABLE(CONFIG_OF_IOMMU, iommu)
#define RESERVEDMEM_OF_TABLES() OF_TABLE(CONFIG_OF_RESERVED_MEM, reservedmem)
#define RESERVEDMEM_OF_TABLES() OF_TABLE(CONFIG_OF_RESERVED_MEM, reservedmem)
#define CPU_METHOD_OF_TABLES() OF_TABLE(CONFIG_SMP, cpu_method)
#define CPU_METHOD_OF_TABLES() OF_TABLE(CONFIG_SMP, cpu_method)
#define CPUIDLE_METHOD_OF_TABLES() OF_TABLE(CONFIG_CPU_IDLE, cpuidle_method)
#define EARLYCON_OF_TABLES() OF_TABLE(CONFIG_SERIAL_EARLYCON, earlycon)
#define EARLYCON_OF_TABLES() OF_TABLE(CONFIG_SERIAL_EARLYCON, earlycon)
#define KERNEL_DTB() \
#define KERNEL_DTB() \
...
@@ -501,6 +502,7 @@
...
@@ -501,6 +502,7 @@
CLKSRC_OF_TABLES() \
CLKSRC_OF_TABLES() \
IOMMU_OF_TABLES() \
IOMMU_OF_TABLES() \
CPU_METHOD_OF_TABLES() \
CPU_METHOD_OF_TABLES() \
CPUIDLE_METHOD_OF_TABLES() \
KERNEL_DTB() \
KERNEL_DTB() \
IRQCHIP_OF_MATCH_TABLE() \
IRQCHIP_OF_MATCH_TABLE() \
EARLYCON_OF_TABLES()
EARLYCON_OF_TABLES()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录