Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
0a924200
Commit
0a924200
authored
Nov 21, 2014
by
Rafael J. Wysocki
Browse files
Options
Browse Files
Download
Plain Diff
Merge back earlier cpuidle material for 3.19-rc1.
Conflicts: drivers/cpuidle/dt_idle_states.c
parents
a74a5a33
b82b6cca
Changes
34
Hide whitespace changes
Inline
Side-by-side
Showing
34 changed files
with
75 additions
and
125 deletions
+75
-125
arch/arm/include/asm/cpuidle.h
arch/arm/include/asm/cpuidle.h
+0
-1
arch/arm/mach-davinci/cpuidle.c
arch/arm/mach-davinci/cpuidle.c
+0
-1
arch/arm/mach-imx/cpuidle-imx5.c
arch/arm/mach-imx/cpuidle-imx5.c
+0
-1
arch/arm/mach-imx/cpuidle-imx6q.c
arch/arm/mach-imx/cpuidle-imx6q.c
+1
-2
arch/arm/mach-imx/cpuidle-imx6sl.c
arch/arm/mach-imx/cpuidle-imx6sl.c
+1
-2
arch/arm/mach-omap2/cpuidle34xx.c
arch/arm/mach-omap2/cpuidle34xx.c
+0
-7
arch/arm/mach-omap2/cpuidle44xx.c
arch/arm/mach-omap2/cpuidle44xx.c
+2
-3
arch/arm/mach-s3c64xx/cpuidle.c
arch/arm/mach-s3c64xx/cpuidle.c
+0
-1
arch/arm/mach-shmobile/pm-sh7372.c
arch/arm/mach-shmobile/pm-sh7372.c
+0
-4
arch/arm/mach-tegra/cpuidle-tegra114.c
arch/arm/mach-tegra/cpuidle-tegra114.c
+0
-1
arch/arm/mach-tegra/cpuidle-tegra20.c
arch/arm/mach-tegra/cpuidle-tegra20.c
+1
-2
arch/arm/mach-tegra/cpuidle-tegra30.c
arch/arm/mach-tegra/cpuidle-tegra30.c
+0
-1
arch/mips/include/asm/idle.h
arch/mips/include/asm/idle.h
+0
-1
arch/sh/kernel/cpu/shmobile/cpuidle.c
arch/sh/kernel/cpu/shmobile/cpuidle.c
+0
-3
arch/x86/kernel/apm_32.c
arch/x86/kernel/apm_32.c
+0
-1
drivers/acpi/processor_idle.c
drivers/acpi/processor_idle.c
+2
-4
drivers/cpuidle/cpuidle-arm64.c
drivers/cpuidle/cpuidle-arm64.c
+0
-1
drivers/cpuidle/cpuidle-at91.c
drivers/cpuidle/cpuidle-at91.c
+0
-1
drivers/cpuidle/cpuidle-big_little.c
drivers/cpuidle/cpuidle-big_little.c
+2
-4
drivers/cpuidle/cpuidle-calxeda.c
drivers/cpuidle/cpuidle-calxeda.c
+0
-1
drivers/cpuidle/cpuidle-cps.c
drivers/cpuidle/cpuidle-cps.c
+2
-5
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-mvebu-v7.c
drivers/cpuidle/cpuidle-mvebu-v7.c
+2
-6
drivers/cpuidle/cpuidle-powernv.c
drivers/cpuidle/cpuidle-powernv.c
+2
-4
drivers/cpuidle/cpuidle-pseries.c
drivers/cpuidle/cpuidle-pseries.c
+0
-3
drivers/cpuidle/cpuidle-ux500.c
drivers/cpuidle/cpuidle-ux500.c
+1
-2
drivers/cpuidle/cpuidle-zynq.c
drivers/cpuidle/cpuidle-zynq.c
+0
-1
drivers/cpuidle/driver.c
drivers/cpuidle/driver.c
+0
-1
drivers/cpuidle/dt_idle_states.c
drivers/cpuidle/dt_idle_states.c
+1
-1
drivers/cpuidle/governors/ladder.c
drivers/cpuidle/governors/ladder.c
+1
-1
drivers/cpuidle/governors/menu.c
drivers/cpuidle/governors/menu.c
+1
-1
drivers/idle/intel_idle.c
drivers/idle/intel_idle.c
+54
-54
include/linux/cpuidle.h
include/linux/cpuidle.h
+2
-2
No files found.
arch/arm/include/asm/cpuidle.h
View file @
0a924200
...
@@ -15,7 +15,6 @@ static inline int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
...
@@ -15,7 +15,6 @@ static inline int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
.exit_latency = 1,\
.exit_latency = 1,\
.target_residency = 1,\
.target_residency = 1,\
.power_usage = p,\
.power_usage = p,\
.flags = CPUIDLE_FLAG_TIME_VALID,\
.name = "WFI",\
.name = "WFI",\
.desc = "ARM WFI",\
.desc = "ARM WFI",\
}
}
...
...
arch/arm/mach-davinci/cpuidle.c
View file @
0a924200
...
@@ -66,7 +66,6 @@ static struct cpuidle_driver davinci_idle_driver = {
...
@@ -66,7 +66,6 @@ static struct cpuidle_driver davinci_idle_driver = {
.
enter
=
davinci_enter_idle
,
.
enter
=
davinci_enter_idle
,
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
10000
,
.
target_residency
=
10000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"DDR SR"
,
.
name
=
"DDR SR"
,
.
desc
=
"WFI and DDR Self Refresh"
,
.
desc
=
"WFI and DDR Self Refresh"
,
},
},
...
...
arch/arm/mach-imx/cpuidle-imx5.c
View file @
0a924200
...
@@ -24,7 +24,6 @@ static struct cpuidle_driver imx5_cpuidle_driver = {
...
@@ -24,7 +24,6 @@ static struct cpuidle_driver imx5_cpuidle_driver = {
.
enter
=
imx5_cpuidle_enter
,
.
enter
=
imx5_cpuidle_enter
,
.
exit_latency
=
2
,
.
exit_latency
=
2
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"IMX5 SRPG"
,
.
name
=
"IMX5 SRPG"
,
.
desc
=
"CPU state retained,powered off"
,
.
desc
=
"CPU state retained,powered off"
,
},
},
...
...
arch/arm/mach-imx/cpuidle-imx6q.c
View file @
0a924200
...
@@ -53,8 +53,7 @@ static struct cpuidle_driver imx6q_cpuidle_driver = {
...
@@ -53,8 +53,7 @@ static struct cpuidle_driver imx6q_cpuidle_driver = {
{
{
.
exit_latency
=
50
,
.
exit_latency
=
50
,
.
target_residency
=
75
,
.
target_residency
=
75
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_TIMER_STOP
,
CPUIDLE_FLAG_TIMER_STOP
,
.
enter
=
imx6q_enter_wait
,
.
enter
=
imx6q_enter_wait
,
.
name
=
"WAIT"
,
.
name
=
"WAIT"
,
.
desc
=
"Clock off"
,
.
desc
=
"Clock off"
,
...
...
arch/arm/mach-imx/cpuidle-imx6sl.c
View file @
0a924200
...
@@ -40,8 +40,7 @@ static struct cpuidle_driver imx6sl_cpuidle_driver = {
...
@@ -40,8 +40,7 @@ static struct cpuidle_driver imx6sl_cpuidle_driver = {
{
{
.
exit_latency
=
50
,
.
exit_latency
=
50
,
.
target_residency
=
75
,
.
target_residency
=
75
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_TIMER_STOP
,
CPUIDLE_FLAG_TIMER_STOP
,
.
enter
=
imx6sl_enter_wait
,
.
enter
=
imx6sl_enter_wait
,
.
name
=
"WAIT"
,
.
name
=
"WAIT"
,
.
desc
=
"Clock off"
,
.
desc
=
"Clock off"
,
...
...
arch/arm/mach-omap2/cpuidle34xx.c
View file @
0a924200
...
@@ -265,7 +265,6 @@ static struct cpuidle_driver omap3_idle_driver = {
...
@@ -265,7 +265,6 @@ static struct cpuidle_driver omap3_idle_driver = {
.
enter
=
omap3_enter_idle_bm
,
.
enter
=
omap3_enter_idle_bm
,
.
exit_latency
=
2
+
2
,
.
exit_latency
=
2
+
2
,
.
target_residency
=
5
,
.
target_residency
=
5
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C1"
,
.
name
=
"C1"
,
.
desc
=
"MPU ON + CORE ON"
,
.
desc
=
"MPU ON + CORE ON"
,
},
},
...
@@ -273,7 +272,6 @@ static struct cpuidle_driver omap3_idle_driver = {
...
@@ -273,7 +272,6 @@ static struct cpuidle_driver omap3_idle_driver = {
.
enter
=
omap3_enter_idle_bm
,
.
enter
=
omap3_enter_idle_bm
,
.
exit_latency
=
10
+
10
,
.
exit_latency
=
10
+
10
,
.
target_residency
=
30
,
.
target_residency
=
30
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C2"
,
.
name
=
"C2"
,
.
desc
=
"MPU ON + CORE ON"
,
.
desc
=
"MPU ON + CORE ON"
,
},
},
...
@@ -281,7 +279,6 @@ static struct cpuidle_driver omap3_idle_driver = {
...
@@ -281,7 +279,6 @@ static struct cpuidle_driver omap3_idle_driver = {
.
enter
=
omap3_enter_idle_bm
,
.
enter
=
omap3_enter_idle_bm
,
.
exit_latency
=
50
+
50
,
.
exit_latency
=
50
+
50
,
.
target_residency
=
300
,
.
target_residency
=
300
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C3"
,
.
name
=
"C3"
,
.
desc
=
"MPU RET + CORE ON"
,
.
desc
=
"MPU RET + CORE ON"
,
},
},
...
@@ -289,7 +286,6 @@ static struct cpuidle_driver omap3_idle_driver = {
...
@@ -289,7 +286,6 @@ static struct cpuidle_driver omap3_idle_driver = {
.
enter
=
omap3_enter_idle_bm
,
.
enter
=
omap3_enter_idle_bm
,
.
exit_latency
=
1500
+
1800
,
.
exit_latency
=
1500
+
1800
,
.
target_residency
=
4000
,
.
target_residency
=
4000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C4"
,
.
name
=
"C4"
,
.
desc
=
"MPU OFF + CORE ON"
,
.
desc
=
"MPU OFF + CORE ON"
,
},
},
...
@@ -297,7 +293,6 @@ static struct cpuidle_driver omap3_idle_driver = {
...
@@ -297,7 +293,6 @@ static struct cpuidle_driver omap3_idle_driver = {
.
enter
=
omap3_enter_idle_bm
,
.
enter
=
omap3_enter_idle_bm
,
.
exit_latency
=
2500
+
7500
,
.
exit_latency
=
2500
+
7500
,
.
target_residency
=
12000
,
.
target_residency
=
12000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C5"
,
.
name
=
"C5"
,
.
desc
=
"MPU RET + CORE RET"
,
.
desc
=
"MPU RET + CORE RET"
,
},
},
...
@@ -305,7 +300,6 @@ static struct cpuidle_driver omap3_idle_driver = {
...
@@ -305,7 +300,6 @@ static struct cpuidle_driver omap3_idle_driver = {
.
enter
=
omap3_enter_idle_bm
,
.
enter
=
omap3_enter_idle_bm
,
.
exit_latency
=
3000
+
8500
,
.
exit_latency
=
3000
+
8500
,
.
target_residency
=
15000
,
.
target_residency
=
15000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C6"
,
.
name
=
"C6"
,
.
desc
=
"MPU OFF + CORE RET"
,
.
desc
=
"MPU OFF + CORE RET"
,
},
},
...
@@ -313,7 +307,6 @@ static struct cpuidle_driver omap3_idle_driver = {
...
@@ -313,7 +307,6 @@ static struct cpuidle_driver omap3_idle_driver = {
.
enter
=
omap3_enter_idle_bm
,
.
enter
=
omap3_enter_idle_bm
,
.
exit_latency
=
10000
+
30000
,
.
exit_latency
=
10000
+
30000
,
.
target_residency
=
30000
,
.
target_residency
=
30000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C7"
,
.
name
=
"C7"
,
.
desc
=
"MPU OFF + CORE OFF"
,
.
desc
=
"MPU OFF + CORE OFF"
,
},
},
...
...
arch/arm/mach-omap2/cpuidle44xx.c
View file @
0a924200
...
@@ -196,7 +196,6 @@ static struct cpuidle_driver omap4_idle_driver = {
...
@@ -196,7 +196,6 @@ static struct cpuidle_driver omap4_idle_driver = {
/* C1 - CPU0 ON + CPU1 ON + MPU ON */
/* C1 - CPU0 ON + CPU1 ON + MPU ON */
.
exit_latency
=
2
+
2
,
.
exit_latency
=
2
+
2
,
.
target_residency
=
5
,
.
target_residency
=
5
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
omap_enter_idle_simple
,
.
enter
=
omap_enter_idle_simple
,
.
name
=
"C1"
,
.
name
=
"C1"
,
.
desc
=
"CPUx ON, MPUSS ON"
.
desc
=
"CPUx ON, MPUSS ON"
...
@@ -205,7 +204,7 @@ static struct cpuidle_driver omap4_idle_driver = {
...
@@ -205,7 +204,7 @@ static struct cpuidle_driver omap4_idle_driver = {
/* C2 - CPU0 OFF + CPU1 OFF + MPU CSWR */
/* C2 - CPU0 OFF + CPU1 OFF + MPU CSWR */
.
exit_latency
=
328
+
440
,
.
exit_latency
=
328
+
440
,
.
target_residency
=
960
,
.
target_residency
=
960
,
.
flags
=
CPUIDLE_FLAG_
TIME_VALID
|
CPUIDLE_FLAG_
COUPLED
,
.
flags
=
CPUIDLE_FLAG_COUPLED
,
.
enter
=
omap_enter_idle_coupled
,
.
enter
=
omap_enter_idle_coupled
,
.
name
=
"C2"
,
.
name
=
"C2"
,
.
desc
=
"CPUx OFF, MPUSS CSWR"
,
.
desc
=
"CPUx OFF, MPUSS CSWR"
,
...
@@ -214,7 +213,7 @@ static struct cpuidle_driver omap4_idle_driver = {
...
@@ -214,7 +213,7 @@ static struct cpuidle_driver omap4_idle_driver = {
/* C3 - CPU0 OFF + CPU1 OFF + MPU OSWR */
/* C3 - CPU0 OFF + CPU1 OFF + MPU OSWR */
.
exit_latency
=
460
+
518
,
.
exit_latency
=
460
+
518
,
.
target_residency
=
1100
,
.
target_residency
=
1100
,
.
flags
=
CPUIDLE_FLAG_
TIME_VALID
|
CPUIDLE_FLAG_
COUPLED
,
.
flags
=
CPUIDLE_FLAG_COUPLED
,
.
enter
=
omap_enter_idle_coupled
,
.
enter
=
omap_enter_idle_coupled
,
.
name
=
"C3"
,
.
name
=
"C3"
,
.
desc
=
"CPUx OFF, MPUSS OSWR"
,
.
desc
=
"CPUx OFF, MPUSS OSWR"
,
...
...
arch/arm/mach-s3c64xx/cpuidle.c
View file @
0a924200
...
@@ -48,7 +48,6 @@ static struct cpuidle_driver s3c64xx_cpuidle_driver = {
...
@@ -48,7 +48,6 @@ static struct cpuidle_driver s3c64xx_cpuidle_driver = {
.
enter
=
s3c64xx_enter_idle
,
.
enter
=
s3c64xx_enter_idle
,
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"IDLE"
,
.
name
=
"IDLE"
,
.
desc
=
"System active, ARM gated"
,
.
desc
=
"System active, ARM gated"
,
},
},
...
...
arch/arm/mach-shmobile/pm-sh7372.c
View file @
0a924200
...
@@ -423,7 +423,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
...
@@ -423,7 +423,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
.
desc
=
"Core Standby Mode"
,
.
desc
=
"Core Standby Mode"
,
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
20
+
10
,
.
target_residency
=
20
+
10
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
sh7372_enter_core_standby
,
.
enter
=
sh7372_enter_core_standby
,
},
},
.
states
[
2
]
=
{
.
states
[
2
]
=
{
...
@@ -431,7 +430,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
...
@@ -431,7 +430,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
.
desc
=
"A3SM PLL ON"
,
.
desc
=
"A3SM PLL ON"
,
.
exit_latency
=
20
,
.
exit_latency
=
20
,
.
target_residency
=
30
+
20
,
.
target_residency
=
30
+
20
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
sh7372_enter_a3sm_pll_on
,
.
enter
=
sh7372_enter_a3sm_pll_on
,
},
},
.
states
[
3
]
=
{
.
states
[
3
]
=
{
...
@@ -439,7 +437,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
...
@@ -439,7 +437,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
.
desc
=
"A3SM PLL OFF"
,
.
desc
=
"A3SM PLL OFF"
,
.
exit_latency
=
120
,
.
exit_latency
=
120
,
.
target_residency
=
30
+
120
,
.
target_residency
=
30
+
120
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
sh7372_enter_a3sm_pll_off
,
.
enter
=
sh7372_enter_a3sm_pll_off
,
},
},
.
states
[
4
]
=
{
.
states
[
4
]
=
{
...
@@ -447,7 +444,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
...
@@ -447,7 +444,6 @@ static struct cpuidle_driver sh7372_cpuidle_driver = {
.
desc
=
"A4S PLL OFF"
,
.
desc
=
"A4S PLL OFF"
,
.
exit_latency
=
240
,
.
exit_latency
=
240
,
.
target_residency
=
30
+
240
,
.
target_residency
=
30
+
240
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
sh7372_enter_a4s
,
.
enter
=
sh7372_enter_a4s
,
.
disabled
=
true
,
.
disabled
=
true
,
},
},
...
...
arch/arm/mach-tegra/cpuidle-tegra114.c
View file @
0a924200
...
@@ -75,7 +75,6 @@ static struct cpuidle_driver tegra_idle_driver = {
...
@@ -75,7 +75,6 @@ static struct cpuidle_driver tegra_idle_driver = {
.
exit_latency
=
500
,
.
exit_latency
=
500
,
.
target_residency
=
1000
,
.
target_residency
=
1000
,
.
power_usage
=
0
,
.
power_usage
=
0
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"powered-down"
,
.
name
=
"powered-down"
,
.
desc
=
"CPU power gated"
,
.
desc
=
"CPU power gated"
,
},
},
...
...
arch/arm/mach-tegra/cpuidle-tegra20.c
View file @
0a924200
...
@@ -59,8 +59,7 @@ static struct cpuidle_driver tegra_idle_driver = {
...
@@ -59,8 +59,7 @@ static struct cpuidle_driver tegra_idle_driver = {
.
exit_latency
=
5000
,
.
exit_latency
=
5000
,
.
target_residency
=
10000
,
.
target_residency
=
10000
,
.
power_usage
=
0
,
.
power_usage
=
0
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_COUPLED
,
CPUIDLE_FLAG_COUPLED
,
.
name
=
"powered-down"
,
.
name
=
"powered-down"
,
.
desc
=
"CPU power gated"
,
.
desc
=
"CPU power gated"
,
},
},
...
...
arch/arm/mach-tegra/cpuidle-tegra30.c
View file @
0a924200
...
@@ -56,7 +56,6 @@ static struct cpuidle_driver tegra_idle_driver = {
...
@@ -56,7 +56,6 @@ static struct cpuidle_driver tegra_idle_driver = {
.
exit_latency
=
2000
,
.
exit_latency
=
2000
,
.
target_residency
=
2200
,
.
target_residency
=
2200
,
.
power_usage
=
0
,
.
power_usage
=
0
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"powered-down"
,
.
name
=
"powered-down"
,
.
desc
=
"CPU power gated"
,
.
desc
=
"CPU power gated"
,
},
},
...
...
arch/mips/include/asm/idle.h
View file @
0a924200
...
@@ -22,7 +22,6 @@ extern int mips_cpuidle_wait_enter(struct cpuidle_device *dev,
...
@@ -22,7 +22,6 @@ extern int mips_cpuidle_wait_enter(struct cpuidle_device *dev,
.exit_latency = 1,\
.exit_latency = 1,\
.target_residency = 1,\
.target_residency = 1,\
.power_usage = UINT_MAX,\
.power_usage = UINT_MAX,\
.flags = CPUIDLE_FLAG_TIME_VALID,\
.name = "wait",\
.name = "wait",\
.desc = "MIPS wait",\
.desc = "MIPS wait",\
}
}
...
...
arch/sh/kernel/cpu/shmobile/cpuidle.c
View file @
0a924200
...
@@ -59,7 +59,6 @@ static struct cpuidle_driver cpuidle_driver = {
...
@@ -59,7 +59,6 @@ static struct cpuidle_driver cpuidle_driver = {
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
*
2
,
.
target_residency
=
1
*
2
,
.
power_usage
=
3
,
.
power_usage
=
3
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
cpuidle_sleep_enter
,
.
enter
=
cpuidle_sleep_enter
,
.
name
=
"C1"
,
.
name
=
"C1"
,
.
desc
=
"SuperH Sleep Mode"
,
.
desc
=
"SuperH Sleep Mode"
,
...
@@ -68,7 +67,6 @@ static struct cpuidle_driver cpuidle_driver = {
...
@@ -68,7 +67,6 @@ static struct cpuidle_driver cpuidle_driver = {
.
exit_latency
=
100
,
.
exit_latency
=
100
,
.
target_residency
=
1
*
2
,
.
target_residency
=
1
*
2
,
.
power_usage
=
1
,
.
power_usage
=
1
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
cpuidle_sleep_enter
,
.
enter
=
cpuidle_sleep_enter
,
.
name
=
"C2"
,
.
name
=
"C2"
,
.
desc
=
"SuperH Sleep Mode [SF]"
,
.
desc
=
"SuperH Sleep Mode [SF]"
,
...
@@ -78,7 +76,6 @@ static struct cpuidle_driver cpuidle_driver = {
...
@@ -78,7 +76,6 @@ static struct cpuidle_driver cpuidle_driver = {
.
exit_latency
=
2300
,
.
exit_latency
=
2300
,
.
target_residency
=
1
*
2
,
.
target_residency
=
1
*
2
,
.
power_usage
=
1
,
.
power_usage
=
1
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
enter
=
cpuidle_sleep_enter
,
.
enter
=
cpuidle_sleep_enter
,
.
name
=
"C3"
,
.
name
=
"C3"
,
.
desc
=
"SuperH Mobile Standby Mode [SF]"
,
.
desc
=
"SuperH Mobile Standby Mode [SF]"
,
...
...
arch/x86/kernel/apm_32.c
View file @
0a924200
...
@@ -378,7 +378,6 @@ static struct cpuidle_driver apm_idle_driver = {
...
@@ -378,7 +378,6 @@ static struct cpuidle_driver apm_idle_driver = {
{
/* entry 1 is for APM idle */
{
/* entry 1 is for APM idle */
.
name
=
"APM"
,
.
name
=
"APM"
,
.
desc
=
"APM idle"
,
.
desc
=
"APM idle"
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
exit_latency
=
250
,
/* WAG */
.
exit_latency
=
250
,
/* WAG */
.
target_residency
=
500
,
/* WAG */
.
target_residency
=
500
,
/* WAG */
.
enter
=
&
apm_cpu_idle
.
enter
=
&
apm_cpu_idle
...
...
drivers/acpi/processor_idle.c
View file @
0a924200
...
@@ -985,8 +985,8 @@ static int acpi_processor_setup_cpuidle_states(struct acpi_processor *pr)
...
@@ -985,8 +985,8 @@ static int acpi_processor_setup_cpuidle_states(struct acpi_processor *pr)
state
->
flags
=
0
;
state
->
flags
=
0
;
switch
(
cx
->
type
)
{
switch
(
cx
->
type
)
{
case
ACPI_STATE_C1
:
case
ACPI_STATE_C1
:
if
(
cx
->
entry_method
=
=
ACPI_CSTATE_FFH
)
if
(
cx
->
entry_method
!
=
ACPI_CSTATE_FFH
)
state
->
flags
|=
CPUIDLE_FLAG_TIME_VALID
;
state
->
flags
|=
CPUIDLE_FLAG_TIME_
IN
VALID
;
state
->
enter
=
acpi_idle_enter_c1
;
state
->
enter
=
acpi_idle_enter_c1
;
state
->
enter_dead
=
acpi_idle_play_dead
;
state
->
enter_dead
=
acpi_idle_play_dead
;
...
@@ -994,14 +994,12 @@ static int acpi_processor_setup_cpuidle_states(struct acpi_processor *pr)
...
@@ -994,14 +994,12 @@ static int acpi_processor_setup_cpuidle_states(struct acpi_processor *pr)
break
;
break
;
case
ACPI_STATE_C2
:
case
ACPI_STATE_C2
:
state
->
flags
|=
CPUIDLE_FLAG_TIME_VALID
;
state
->
enter
=
acpi_idle_enter_simple
;
state
->
enter
=
acpi_idle_enter_simple
;
state
->
enter_dead
=
acpi_idle_play_dead
;
state
->
enter_dead
=
acpi_idle_play_dead
;
drv
->
safe_state_index
=
count
;
drv
->
safe_state_index
=
count
;
break
;
break
;
case
ACPI_STATE_C3
:
case
ACPI_STATE_C3
:
state
->
flags
|=
CPUIDLE_FLAG_TIME_VALID
;
state
->
enter
=
pr
->
flags
.
bm_check
?
state
->
enter
=
pr
->
flags
.
bm_check
?
acpi_idle_enter_bm
:
acpi_idle_enter_bm
:
acpi_idle_enter_simple
;
acpi_idle_enter_simple
;
...
...
drivers/cpuidle/cpuidle-arm64.c
View file @
0a924200
...
@@ -73,7 +73,6 @@ static struct cpuidle_driver arm64_idle_driver = {
...
@@ -73,7 +73,6 @@ static struct cpuidle_driver arm64_idle_driver = {
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
power_usage
=
UINT_MAX
,
.
power_usage
=
UINT_MAX
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"WFI"
,
.
name
=
"WFI"
,
.
desc
=
"ARM64 WFI"
,
.
desc
=
"ARM64 WFI"
,
}
}
...
...
drivers/cpuidle/cpuidle-at91.c
View file @
0a924200
...
@@ -43,7 +43,6 @@ static struct cpuidle_driver at91_idle_driver = {
...
@@ -43,7 +43,6 @@ static struct cpuidle_driver at91_idle_driver = {
.
enter
=
at91_enter_idle
,
.
enter
=
at91_enter_idle
,
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
10000
,
.
target_residency
=
10000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"RAM_SR"
,
.
name
=
"RAM_SR"
,
.
desc
=
"WFI and DDR Self Refresh"
,
.
desc
=
"WFI and DDR Self Refresh"
,
},
},
...
...
drivers/cpuidle/cpuidle-big_little.c
View file @
0a924200
...
@@ -67,8 +67,7 @@ static struct cpuidle_driver bl_idle_little_driver = {
...
@@ -67,8 +67,7 @@ static struct cpuidle_driver bl_idle_little_driver = {
.
enter
=
bl_enter_powerdown
,
.
enter
=
bl_enter_powerdown
,
.
exit_latency
=
700
,
.
exit_latency
=
700
,
.
target_residency
=
2500
,
.
target_residency
=
2500
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_TIMER_STOP
,
CPUIDLE_FLAG_TIMER_STOP
,
.
name
=
"C1"
,
.
name
=
"C1"
,
.
desc
=
"ARM little-cluster power down"
,
.
desc
=
"ARM little-cluster power down"
,
},
},
...
@@ -89,8 +88,7 @@ static struct cpuidle_driver bl_idle_big_driver = {
...
@@ -89,8 +88,7 @@ static struct cpuidle_driver bl_idle_big_driver = {
.
enter
=
bl_enter_powerdown
,
.
enter
=
bl_enter_powerdown
,
.
exit_latency
=
500
,
.
exit_latency
=
500
,
.
target_residency
=
2000
,
.
target_residency
=
2000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_TIMER_STOP
,
CPUIDLE_FLAG_TIMER_STOP
,
.
name
=
"C1"
,
.
name
=
"C1"
,
.
desc
=
"ARM big-cluster power down"
,
.
desc
=
"ARM big-cluster power down"
,
},
},
...
...
drivers/cpuidle/cpuidle-calxeda.c
View file @
0a924200
...
@@ -55,7 +55,6 @@ static struct cpuidle_driver calxeda_idle_driver = {
...
@@ -55,7 +55,6 @@ static struct cpuidle_driver calxeda_idle_driver = {
{
{
.
name
=
"PG"
,
.
name
=
"PG"
,
.
desc
=
"Power Gate"
,
.
desc
=
"Power Gate"
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
exit_latency
=
30
,
.
exit_latency
=
30
,
.
power_usage
=
50
,
.
power_usage
=
50
,
.
target_residency
=
200
,
.
target_residency
=
200
,
...
...
drivers/cpuidle/cpuidle-cps.c
View file @
0a924200
...
@@ -79,7 +79,6 @@ static struct cpuidle_driver cps_driver = {
...
@@ -79,7 +79,6 @@ static struct cpuidle_driver cps_driver = {
.
enter
=
cps_nc_enter
,
.
enter
=
cps_nc_enter
,
.
exit_latency
=
200
,
.
exit_latency
=
200
,
.
target_residency
=
450
,
.
target_residency
=
450
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"nc-wait"
,
.
name
=
"nc-wait"
,
.
desc
=
"non-coherent MIPS wait"
,
.
desc
=
"non-coherent MIPS wait"
,
},
},
...
@@ -87,8 +86,7 @@ static struct cpuidle_driver cps_driver = {
...
@@ -87,8 +86,7 @@ static struct cpuidle_driver cps_driver = {
.
enter
=
cps_nc_enter
,
.
enter
=
cps_nc_enter
,
.
exit_latency
=
300
,
.
exit_latency
=
300
,
.
target_residency
=
700
,
.
target_residency
=
700
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_TIMER_STOP
,
CPUIDLE_FLAG_TIMER_STOP
,
.
name
=
"clock-gated"
,
.
name
=
"clock-gated"
,
.
desc
=
"core clock gated"
,
.
desc
=
"core clock gated"
,
},
},
...
@@ -96,8 +94,7 @@ static struct cpuidle_driver cps_driver = {
...
@@ -96,8 +94,7 @@ static struct cpuidle_driver cps_driver = {
.
enter
=
cps_nc_enter
,
.
enter
=
cps_nc_enter
,
.
exit_latency
=
600
,
.
exit_latency
=
600
,
.
target_residency
=
1000
,
.
target_residency
=
1000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_TIMER_STOP
,
CPUIDLE_FLAG_TIMER_STOP
,
.
name
=
"power-gated"
,
.
name
=
"power-gated"
,
.
desc
=
"core power gated"
,
.
desc
=
"core power gated"
,
},
},
...
...
drivers/cpuidle/cpuidle-exynos.c
View file @
0a924200
...
@@ -47,7 +47,6 @@ static struct cpuidle_driver exynos_idle_driver = {
...
@@ -47,7 +47,6 @@ static struct cpuidle_driver exynos_idle_driver = {
.
enter
=
exynos_enter_lowpower
,
.
enter
=
exynos_enter_lowpower
,
.
exit_latency
=
300
,
.
exit_latency
=
300
,
.
target_residency
=
100000
,
.
target_residency
=
100000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"C1"
,
.
name
=
"C1"
,
.
desc
=
"ARM power down"
,
.
desc
=
"ARM power down"
,
},
},
...
...
drivers/cpuidle/cpuidle-kirkwood.c
View file @
0a924200
...
@@ -47,7 +47,6 @@ static struct cpuidle_driver kirkwood_idle_driver = {
...
@@ -47,7 +47,6 @@ static struct cpuidle_driver kirkwood_idle_driver = {
.
enter
=
kirkwood_enter_idle
,
.
enter
=
kirkwood_enter_idle
,
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
100000
,
.
target_residency
=
100000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"DDR SR"
,
.
name
=
"DDR SR"
,
.
desc
=
"WFI and DDR Self Refresh"
,
.
desc
=
"WFI and DDR Self Refresh"
,
},
},
...
...
drivers/cpuidle/cpuidle-mvebu-v7.c
View file @
0a924200
...
@@ -53,7 +53,6 @@ static struct cpuidle_driver armadaxp_idle_driver = {
...
@@ -53,7 +53,6 @@ static struct cpuidle_driver armadaxp_idle_driver = {
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
power_usage
=
50
,
.
power_usage
=
50
,
.
target_residency
=
100
,
.
target_residency
=
100
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"MV CPU IDLE"
,
.
name
=
"MV CPU IDLE"
,
.
desc
=
"CPU power down"
,
.
desc
=
"CPU power down"
,
},
},
...
@@ -62,8 +61,7 @@ static struct cpuidle_driver armadaxp_idle_driver = {
...
@@ -62,8 +61,7 @@ static struct cpuidle_driver armadaxp_idle_driver = {
.
exit_latency
=
100
,
.
exit_latency
=
100
,
.
power_usage
=
5
,
.
power_usage
=
5
,
.
target_residency
=
1000
,
.
target_residency
=
1000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
MVEBU_V7_FLAG_DEEP_IDLE
,
MVEBU_V7_FLAG_DEEP_IDLE
,
.
name
=
"MV CPU DEEP IDLE"
,
.
name
=
"MV CPU DEEP IDLE"
,
.
desc
=
"CPU and L2 Fabric power down"
,
.
desc
=
"CPU and L2 Fabric power down"
,
},
},
...
@@ -78,8 +76,7 @@ static struct cpuidle_driver armada370_idle_driver = {
...
@@ -78,8 +76,7 @@ static struct cpuidle_driver armada370_idle_driver = {
.
exit_latency
=
100
,
.
exit_latency
=
100
,
.
power_usage
=
5
,
.
power_usage
=
5
,
.
target_residency
=
1000
,
.
target_residency
=
1000
,
.
flags
=
(
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
MVEBU_V7_FLAG_DEEP_IDLE
,
MVEBU_V7_FLAG_DEEP_IDLE
),
.
name
=
"Deep Idle"
,
.
name
=
"Deep Idle"
,
.
desc
=
"CPU and L2 Fabric power down"
,
.
desc
=
"CPU and L2 Fabric power down"
,
},
},
...
@@ -94,7 +91,6 @@ static struct cpuidle_driver armada38x_idle_driver = {
...
@@ -94,7 +91,6 @@ static struct cpuidle_driver armada38x_idle_driver = {
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
power_usage
=
5
,
.
power_usage
=
5
,
.
target_residency
=
100
,
.
target_residency
=
100
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"Idle"
,
.
name
=
"Idle"
,
.
desc
=
"CPU and SCU power down"
,
.
desc
=
"CPU and SCU power down"
,
},
},
...
...
drivers/cpuidle/cpuidle-powernv.c
View file @
0a924200
...
@@ -93,7 +93,6 @@ static struct cpuidle_state powernv_states[MAX_POWERNV_IDLE_STATES] = {
...
@@ -93,7 +93,6 @@ static struct cpuidle_state powernv_states[MAX_POWERNV_IDLE_STATES] = {
{
/* Snooze */
{
/* Snooze */
.
name
=
"snooze"
,
.
name
=
"snooze"
,
.
desc
=
"snooze"
,
.
desc
=
"snooze"
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
exit_latency
=
0
,
.
exit_latency
=
0
,
.
target_residency
=
0
,
.
target_residency
=
0
,
.
enter
=
&
snooze_loop
},
.
enter
=
&
snooze_loop
},
...
@@ -202,7 +201,7 @@ static int powernv_add_idle_states(void)
...
@@ -202,7 +201,7 @@ static int powernv_add_idle_states(void)
/* Add NAP state */
/* Add NAP state */
strcpy
(
powernv_states
[
nr_idle_states
].
name
,
"Nap"
);
strcpy
(
powernv_states
[
nr_idle_states
].
name
,
"Nap"
);
strcpy
(
powernv_states
[
nr_idle_states
].
desc
,
"Nap"
);
strcpy
(
powernv_states
[
nr_idle_states
].
desc
,
"Nap"
);
powernv_states
[
nr_idle_states
].
flags
=
CPUIDLE_FLAG_TIME_VALID
;
powernv_states
[
nr_idle_states
].
flags
=
0
;
powernv_states
[
nr_idle_states
].
exit_latency
=
powernv_states
[
nr_idle_states
].
exit_latency
=
((
unsigned
int
)
latency_ns
)
/
1000
;
((
unsigned
int
)
latency_ns
)
/
1000
;
powernv_states
[
nr_idle_states
].
target_residency
=
powernv_states
[
nr_idle_states
].
target_residency
=
...
@@ -215,8 +214,7 @@ static int powernv_add_idle_states(void)
...
@@ -215,8 +214,7 @@ static int powernv_add_idle_states(void)
/* Add FASTSLEEP state */
/* Add FASTSLEEP state */
strcpy
(
powernv_states
[
nr_idle_states
].
name
,
"FastSleep"
);
strcpy
(
powernv_states
[
nr_idle_states
].
name
,
"FastSleep"
);
strcpy
(
powernv_states
[
nr_idle_states
].
desc
,
"FastSleep"
);
strcpy
(
powernv_states
[
nr_idle_states
].
desc
,
"FastSleep"
);
powernv_states
[
nr_idle_states
].
flags
=
powernv_states
[
nr_idle_states
].
flags
=
CPUIDLE_FLAG_TIMER_STOP
;
CPUIDLE_FLAG_TIME_VALID
|
CPUIDLE_FLAG_TIMER_STOP
;
powernv_states
[
nr_idle_states
].
exit_latency
=
powernv_states
[
nr_idle_states
].
exit_latency
=
((
unsigned
int
)
latency_ns
)
/
1000
;
((
unsigned
int
)
latency_ns
)
/
1000
;
powernv_states
[
nr_idle_states
].
target_residency
=
powernv_states
[
nr_idle_states
].
target_residency
=
...
...
drivers/cpuidle/cpuidle-pseries.c
View file @
0a924200
...
@@ -142,14 +142,12 @@ static struct cpuidle_state dedicated_states[] = {
...
@@ -142,14 +142,12 @@ static struct cpuidle_state dedicated_states[] = {
{
/* Snooze */
{
/* Snooze */
.
name
=
"snooze"
,
.
name
=
"snooze"
,
.
desc
=
"snooze"
,
.
desc
=
"snooze"
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
exit_latency
=
0
,
.
exit_latency
=
0
,
.
target_residency
=
0
,
.
target_residency
=
0
,
.
enter
=
&
snooze_loop
},
.
enter
=
&
snooze_loop
},
{
/* CEDE */
{
/* CEDE */
.
name
=
"CEDE"
,
.
name
=
"CEDE"
,
.
desc
=
"CEDE"
,
.
desc
=
"CEDE"
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
100
,
.
target_residency
=
100
,
.
enter
=
&
dedicated_cede_loop
},
.
enter
=
&
dedicated_cede_loop
},
...
@@ -162,7 +160,6 @@ static struct cpuidle_state shared_states[] = {
...
@@ -162,7 +160,6 @@ static struct cpuidle_state shared_states[] = {
{
/* Shared Cede */
{
/* Shared Cede */
.
name
=
"Shared Cede"
,
.
name
=
"Shared Cede"
,
.
desc
=
"Shared Cede"
,
.
desc
=
"Shared Cede"
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
exit_latency
=
0
,
.
exit_latency
=
0
,
.
target_residency
=
0
,
.
target_residency
=
0
,
.
enter
=
&
shared_cede_loop
},
.
enter
=
&
shared_cede_loop
},
...
...
drivers/cpuidle/cpuidle-ux500.c
View file @
0a924200
...
@@ -101,8 +101,7 @@ static struct cpuidle_driver ux500_idle_driver = {
...
@@ -101,8 +101,7 @@ static struct cpuidle_driver ux500_idle_driver = {
.
enter
=
ux500_enter_idle
,
.
enter
=
ux500_enter_idle
,
.
exit_latency
=
70
,
.
exit_latency
=
70
,
.
target_residency
=
260
,
.
target_residency
=
260
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
.
flags
=
CPUIDLE_FLAG_TIMER_STOP
,
CPUIDLE_FLAG_TIMER_STOP
,
.
name
=
"ApIdle"
,
.
name
=
"ApIdle"
,
.
desc
=
"ARM Retention"
,
.
desc
=
"ARM Retention"
,
},
},
...
...
drivers/cpuidle/cpuidle-zynq.c
View file @
0a924200
...
@@ -52,7 +52,6 @@ static struct cpuidle_driver zynq_idle_driver = {
...
@@ -52,7 +52,6 @@ static struct cpuidle_driver zynq_idle_driver = {
.
enter
=
zynq_enter_idle
,
.
enter
=
zynq_enter_idle
,
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
10000
,
.
target_residency
=
10000
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
name
=
"RAM_SR"
,
.
name
=
"RAM_SR"
,
.
desc
=
"WFI and RAM Self Refresh"
,
.
desc
=
"WFI and RAM Self Refresh"
,
},
},
...
...
drivers/cpuidle/driver.c
View file @
0a924200
...
@@ -201,7 +201,6 @@ static void poll_idle_init(struct cpuidle_driver *drv)
...
@@ -201,7 +201,6 @@ static void poll_idle_init(struct cpuidle_driver *drv)
state
->
exit_latency
=
0
;
state
->
exit_latency
=
0
;
state
->
target_residency
=
0
;
state
->
target_residency
=
0
;
state
->
power_usage
=
-
1
;
state
->
power_usage
=
-
1
;
state
->
flags
=
CPUIDLE_FLAG_TIME_VALID
;
state
->
enter
=
poll_idle
;
state
->
enter
=
poll_idle
;
state
->
disabled
=
false
;
state
->
disabled
=
false
;
}
}
...
...
drivers/cpuidle/dt_idle_states.c
View file @
0a924200
...
@@ -78,7 +78,7 @@ static int init_state_node(struct cpuidle_state *idle_state,
...
@@ -78,7 +78,7 @@ static int init_state_node(struct cpuidle_state *idle_state,
if
(
err
)
if
(
err
)
desc
=
state_node
->
name
;
desc
=
state_node
->
name
;
idle_state
->
flags
=
CPUIDLE_FLAG_TIME_VALID
;
idle_state
->
flags
=
0
;
if
(
of_property_read_bool
(
state_node
,
"local-timer-stop"
))
if
(
of_property_read_bool
(
state_node
,
"local-timer-stop"
))
idle_state
->
flags
|=
CPUIDLE_FLAG_TIMER_STOP
;
idle_state
->
flags
|=
CPUIDLE_FLAG_TIMER_STOP
;
/*
/*
...
...
drivers/cpuidle/governors/ladder.c
View file @
0a924200
...
@@ -79,7 +79,7 @@ static int ladder_select_state(struct cpuidle_driver *drv,
...
@@ -79,7 +79,7 @@ static int ladder_select_state(struct cpuidle_driver *drv,
last_state
=
&
ldev
->
states
[
last_idx
];
last_state
=
&
ldev
->
states
[
last_idx
];
if
(
drv
->
states
[
last_idx
].
flags
&
CPUIDLE_FLAG_TIME_VALID
)
{
if
(
!
(
drv
->
states
[
last_idx
].
flags
&
CPUIDLE_FLAG_TIME_INVALID
)
)
{
last_residency
=
cpuidle_get_last_residency
(
dev
)
-
\
last_residency
=
cpuidle_get_last_residency
(
dev
)
-
\
drv
->
states
[
last_idx
].
exit_latency
;
drv
->
states
[
last_idx
].
exit_latency
;
}
}
...
...
drivers/cpuidle/governors/menu.c
View file @
0a924200
...
@@ -405,7 +405,7 @@ static void menu_update(struct cpuidle_driver *drv, struct cpuidle_device *dev)
...
@@ -405,7 +405,7 @@ static void menu_update(struct cpuidle_driver *drv, struct cpuidle_device *dev)
* the measured amount of time is less than the exit latency,
* the measured amount of time is less than the exit latency,
* assume the state was never reached and the exit latency is 0.
* assume the state was never reached and the exit latency is 0.
*/
*/
if
(
unlikely
(
!
(
target
->
flags
&
CPUIDLE_FLAG_TIME_VALID
)
))
{
if
(
unlikely
(
target
->
flags
&
CPUIDLE_FLAG_TIME_INVALID
))
{
/* Use timer value as is */
/* Use timer value as is */
measured_us
=
data
->
next_timer_us
;
measured_us
=
data
->
next_timer_us
;
...
...
drivers/idle/intel_idle.c
View file @
0a924200
...
@@ -128,28 +128,28 @@ static struct cpuidle_state nehalem_cstates[] = {
...
@@ -128,28 +128,28 @@ static struct cpuidle_state nehalem_cstates[] = {
{
{
.
name
=
"C1-NHM"
,
.
name
=
"C1-NHM"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
3
,
.
exit_latency
=
3
,
.
target_residency
=
6
,
.
target_residency
=
6
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-NHM"
,
.
name
=
"C1E-NHM"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
20
,
.
target_residency
=
20
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-NHM"
,
.
name
=
"C3-NHM"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
20
,
.
exit_latency
=
20
,
.
target_residency
=
80
,
.
target_residency
=
80
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-NHM"
,
.
name
=
"C6-NHM"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
200
,
.
exit_latency
=
200
,
.
target_residency
=
800
,
.
target_residency
=
800
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -161,35 +161,35 @@ static struct cpuidle_state snb_cstates[] = {
...
@@ -161,35 +161,35 @@ static struct cpuidle_state snb_cstates[] = {
{
{
.
name
=
"C1-SNB"
,
.
name
=
"C1-SNB"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
2
,
.
exit_latency
=
2
,
.
target_residency
=
2
,
.
target_residency
=
2
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-SNB"
,
.
name
=
"C1E-SNB"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
20
,
.
target_residency
=
20
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-SNB"
,
.
name
=
"C3-SNB"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
80
,
.
exit_latency
=
80
,
.
target_residency
=
211
,
.
target_residency
=
211
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-SNB"
,
.
name
=
"C6-SNB"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
104
,
.
exit_latency
=
104
,
.
target_residency
=
345
,
.
target_residency
=
345
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C7-SNB"
,
.
name
=
"C7-SNB"
,
.
desc
=
"MWAIT 0x30"
,
.
desc
=
"MWAIT 0x30"
,
.
flags
=
MWAIT2flg
(
0x30
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x30
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
109
,
.
exit_latency
=
109
,
.
target_residency
=
345
,
.
target_residency
=
345
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -201,42 +201,42 @@ static struct cpuidle_state byt_cstates[] = {
...
@@ -201,42 +201,42 @@ static struct cpuidle_state byt_cstates[] = {
{
{
.
name
=
"C1-BYT"
,
.
name
=
"C1-BYT"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-BYT"
,
.
name
=
"C1E-BYT"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
15
,
.
exit_latency
=
15
,
.
target_residency
=
30
,
.
target_residency
=
30
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6N-BYT"
,
.
name
=
"C6N-BYT"
,
.
desc
=
"MWAIT 0x58"
,
.
desc
=
"MWAIT 0x58"
,
.
flags
=
MWAIT2flg
(
0x58
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x58
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
40
,
.
exit_latency
=
40
,
.
target_residency
=
275
,
.
target_residency
=
275
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6S-BYT"
,
.
name
=
"C6S-BYT"
,
.
desc
=
"MWAIT 0x52"
,
.
desc
=
"MWAIT 0x52"
,
.
flags
=
MWAIT2flg
(
0x52
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x52
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
140
,
.
exit_latency
=
140
,
.
target_residency
=
560
,
.
target_residency
=
560
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C7-BYT"
,
.
name
=
"C7-BYT"
,
.
desc
=
"MWAIT 0x60"
,
.
desc
=
"MWAIT 0x60"
,
.
flags
=
MWAIT2flg
(
0x60
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x60
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
1200
,
.
exit_latency
=
1200
,
.
target_residency
=
1500
,
.
target_residency
=
1500
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C7S-BYT"
,
.
name
=
"C7S-BYT"
,
.
desc
=
"MWAIT 0x64"
,
.
desc
=
"MWAIT 0x64"
,
.
flags
=
MWAIT2flg
(
0x64
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x64
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
10000
,
.
exit_latency
=
10000
,
.
target_residency
=
20000
,
.
target_residency
=
20000
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -248,35 +248,35 @@ static struct cpuidle_state ivb_cstates[] = {
...
@@ -248,35 +248,35 @@ static struct cpuidle_state ivb_cstates[] = {
{
{
.
name
=
"C1-IVB"
,
.
name
=
"C1-IVB"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-IVB"
,
.
name
=
"C1E-IVB"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
20
,
.
target_residency
=
20
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-IVB"
,
.
name
=
"C3-IVB"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
59
,
.
exit_latency
=
59
,
.
target_residency
=
156
,
.
target_residency
=
156
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-IVB"
,
.
name
=
"C6-IVB"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
80
,
.
exit_latency
=
80
,
.
target_residency
=
300
,
.
target_residency
=
300
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C7-IVB"
,
.
name
=
"C7-IVB"
,
.
desc
=
"MWAIT 0x30"
,
.
desc
=
"MWAIT 0x30"
,
.
flags
=
MWAIT2flg
(
0x30
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x30
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
87
,
.
exit_latency
=
87
,
.
target_residency
=
300
,
.
target_residency
=
300
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -288,28 +288,28 @@ static struct cpuidle_state ivt_cstates[] = {
...
@@ -288,28 +288,28 @@ static struct cpuidle_state ivt_cstates[] = {
{
{
.
name
=
"C1-IVT"
,
.
name
=
"C1-IVT"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-IVT"
,
.
name
=
"C1E-IVT"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
80
,
.
target_residency
=
80
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-IVT"
,
.
name
=
"C3-IVT"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
59
,
.
exit_latency
=
59
,
.
target_residency
=
156
,
.
target_residency
=
156
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-IVT"
,
.
name
=
"C6-IVT"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
82
,
.
exit_latency
=
82
,
.
target_residency
=
300
,
.
target_residency
=
300
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -321,28 +321,28 @@ static struct cpuidle_state ivt_cstates_4s[] = {
...
@@ -321,28 +321,28 @@ static struct cpuidle_state ivt_cstates_4s[] = {
{
{
.
name
=
"C1-IVT-4S"
,
.
name
=
"C1-IVT-4S"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-IVT-4S"
,
.
name
=
"C1E-IVT-4S"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
250
,
.
target_residency
=
250
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-IVT-4S"
,
.
name
=
"C3-IVT-4S"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
59
,
.
exit_latency
=
59
,
.
target_residency
=
300
,
.
target_residency
=
300
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-IVT-4S"
,
.
name
=
"C6-IVT-4S"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
84
,
.
exit_latency
=
84
,
.
target_residency
=
400
,
.
target_residency
=
400
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -354,28 +354,28 @@ static struct cpuidle_state ivt_cstates_8s[] = {
...
@@ -354,28 +354,28 @@ static struct cpuidle_state ivt_cstates_8s[] = {
{
{
.
name
=
"C1-IVT-8S"
,
.
name
=
"C1-IVT-8S"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
1
,
.
exit_latency
=
1
,
.
target_residency
=
1
,
.
target_residency
=
1
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-IVT-8S"
,
.
name
=
"C1E-IVT-8S"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
500
,
.
target_residency
=
500
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-IVT-8S"
,
.
name
=
"C3-IVT-8S"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
59
,
.
exit_latency
=
59
,
.
target_residency
=
600
,
.
target_residency
=
600
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-IVT-8S"
,
.
name
=
"C6-IVT-8S"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
88
,
.
exit_latency
=
88
,
.
target_residency
=
700
,
.
target_residency
=
700
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -387,56 +387,56 @@ static struct cpuidle_state hsw_cstates[] = {
...
@@ -387,56 +387,56 @@ static struct cpuidle_state hsw_cstates[] = {
{
{
.
name
=
"C1-HSW"
,
.
name
=
"C1-HSW"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
2
,
.
exit_latency
=
2
,
.
target_residency
=
2
,
.
target_residency
=
2
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-HSW"
,
.
name
=
"C1E-HSW"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
20
,
.
target_residency
=
20
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-HSW"
,
.
name
=
"C3-HSW"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
33
,
.
exit_latency
=
33
,
.
target_residency
=
100
,
.
target_residency
=
100
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-HSW"
,
.
name
=
"C6-HSW"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
133
,
.
exit_latency
=
133
,
.
target_residency
=
400
,
.
target_residency
=
400
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C7s-HSW"
,
.
name
=
"C7s-HSW"
,
.
desc
=
"MWAIT 0x32"
,
.
desc
=
"MWAIT 0x32"
,
.
flags
=
MWAIT2flg
(
0x32
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x32
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
166
,
.
exit_latency
=
166
,
.
target_residency
=
500
,
.
target_residency
=
500
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C8-HSW"
,
.
name
=
"C8-HSW"
,
.
desc
=
"MWAIT 0x40"
,
.
desc
=
"MWAIT 0x40"
,
.
flags
=
MWAIT2flg
(
0x40
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x40
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
300
,
.
exit_latency
=
300
,
.
target_residency
=
900
,
.
target_residency
=
900
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C9-HSW"
,
.
name
=
"C9-HSW"
,
.
desc
=
"MWAIT 0x50"
,
.
desc
=
"MWAIT 0x50"
,
.
flags
=
MWAIT2flg
(
0x50
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x50
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
600
,
.
exit_latency
=
600
,
.
target_residency
=
1800
,
.
target_residency
=
1800
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C10-HSW"
,
.
name
=
"C10-HSW"
,
.
desc
=
"MWAIT 0x60"
,
.
desc
=
"MWAIT 0x60"
,
.
flags
=
MWAIT2flg
(
0x60
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x60
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
2600
,
.
exit_latency
=
2600
,
.
target_residency
=
7700
,
.
target_residency
=
7700
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -447,56 +447,56 @@ static struct cpuidle_state bdw_cstates[] = {
...
@@ -447,56 +447,56 @@ static struct cpuidle_state bdw_cstates[] = {
{
{
.
name
=
"C1-BDW"
,
.
name
=
"C1-BDW"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
2
,
.
exit_latency
=
2
,
.
target_residency
=
2
,
.
target_residency
=
2
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C1E-BDW"
,
.
name
=
"C1E-BDW"
,
.
desc
=
"MWAIT 0x01"
,
.
desc
=
"MWAIT 0x01"
,
.
flags
=
MWAIT2flg
(
0x01
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x01
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
20
,
.
target_residency
=
20
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C3-BDW"
,
.
name
=
"C3-BDW"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
40
,
.
exit_latency
=
40
,
.
target_residency
=
100
,
.
target_residency
=
100
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-BDW"
,
.
name
=
"C6-BDW"
,
.
desc
=
"MWAIT 0x20"
,
.
desc
=
"MWAIT 0x20"
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x20
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
133
,
.
exit_latency
=
133
,
.
target_residency
=
400
,
.
target_residency
=
400
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C7s-BDW"
,
.
name
=
"C7s-BDW"
,
.
desc
=
"MWAIT 0x32"
,
.
desc
=
"MWAIT 0x32"
,
.
flags
=
MWAIT2flg
(
0x32
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x32
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
166
,
.
exit_latency
=
166
,
.
target_residency
=
500
,
.
target_residency
=
500
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C8-BDW"
,
.
name
=
"C8-BDW"
,
.
desc
=
"MWAIT 0x40"
,
.
desc
=
"MWAIT 0x40"
,
.
flags
=
MWAIT2flg
(
0x40
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x40
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
300
,
.
exit_latency
=
300
,
.
target_residency
=
900
,
.
target_residency
=
900
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C9-BDW"
,
.
name
=
"C9-BDW"
,
.
desc
=
"MWAIT 0x50"
,
.
desc
=
"MWAIT 0x50"
,
.
flags
=
MWAIT2flg
(
0x50
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x50
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
600
,
.
exit_latency
=
600
,
.
target_residency
=
1800
,
.
target_residency
=
1800
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C10-BDW"
,
.
name
=
"C10-BDW"
,
.
desc
=
"MWAIT 0x60"
,
.
desc
=
"MWAIT 0x60"
,
.
flags
=
MWAIT2flg
(
0x60
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x60
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
2600
,
.
exit_latency
=
2600
,
.
target_residency
=
7700
,
.
target_residency
=
7700
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -508,28 +508,28 @@ static struct cpuidle_state atom_cstates[] = {
...
@@ -508,28 +508,28 @@ static struct cpuidle_state atom_cstates[] = {
{
{
.
name
=
"C1E-ATM"
,
.
name
=
"C1E-ATM"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
10
,
.
exit_latency
=
10
,
.
target_residency
=
20
,
.
target_residency
=
20
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C2-ATM"
,
.
name
=
"C2-ATM"
,
.
desc
=
"MWAIT 0x10"
,
.
desc
=
"MWAIT 0x10"
,
.
flags
=
MWAIT2flg
(
0x10
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x10
),
.
exit_latency
=
20
,
.
exit_latency
=
20
,
.
target_residency
=
80
,
.
target_residency
=
80
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C4-ATM"
,
.
name
=
"C4-ATM"
,
.
desc
=
"MWAIT 0x30"
,
.
desc
=
"MWAIT 0x30"
,
.
flags
=
MWAIT2flg
(
0x30
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x30
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
100
,
.
exit_latency
=
100
,
.
target_residency
=
400
,
.
target_residency
=
400
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-ATM"
,
.
name
=
"C6-ATM"
,
.
desc
=
"MWAIT 0x52"
,
.
desc
=
"MWAIT 0x52"
,
.
flags
=
MWAIT2flg
(
0x52
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x52
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
140
,
.
exit_latency
=
140
,
.
target_residency
=
560
,
.
target_residency
=
560
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
@@ -540,14 +540,14 @@ static struct cpuidle_state avn_cstates[] = {
...
@@ -540,14 +540,14 @@ static struct cpuidle_state avn_cstates[] = {
{
{
.
name
=
"C1-AVN"
,
.
name
=
"C1-AVN"
,
.
desc
=
"MWAIT 0x00"
,
.
desc
=
"MWAIT 0x00"
,
.
flags
=
MWAIT2flg
(
0x00
)
|
CPUIDLE_FLAG_TIME_VALID
,
.
flags
=
MWAIT2flg
(
0x00
),
.
exit_latency
=
2
,
.
exit_latency
=
2
,
.
target_residency
=
2
,
.
target_residency
=
2
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
{
{
.
name
=
"C6-AVN"
,
.
name
=
"C6-AVN"
,
.
desc
=
"MWAIT 0x51"
,
.
desc
=
"MWAIT 0x51"
,
.
flags
=
MWAIT2flg
(
0x51
)
|
CPUIDLE_FLAG_T
IME_VALID
|
CPUIDLE_FLAG_T
LB_FLUSHED
,
.
flags
=
MWAIT2flg
(
0x51
)
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
15
,
.
exit_latency
=
15
,
.
target_residency
=
45
,
.
target_residency
=
45
,
.
enter
=
&
intel_idle
},
.
enter
=
&
intel_idle
},
...
...
include/linux/cpuidle.h
View file @
0a924200
...
@@ -53,7 +53,7 @@ struct cpuidle_state {
...
@@ -53,7 +53,7 @@ struct cpuidle_state {
};
};
/* Idle State Flags */
/* Idle State Flags */
#define CPUIDLE_FLAG_TIME_VALID (0x01)
/* is residency time measurable? */
#define CPUIDLE_FLAG_TIME_
IN
VALID (0x01)
/* is residency time measurable? */
#define CPUIDLE_FLAG_COUPLED (0x02)
/* state applies to multiple cpus */
#define CPUIDLE_FLAG_COUPLED (0x02)
/* state applies to multiple cpus */
#define CPUIDLE_FLAG_TIMER_STOP (0x04)
/* timer is stopped on this state */
#define CPUIDLE_FLAG_TIMER_STOP (0x04)
/* timer is stopped on this state */
...
@@ -90,7 +90,7 @@ DECLARE_PER_CPU(struct cpuidle_device, cpuidle_dev);
...
@@ -90,7 +90,7 @@ DECLARE_PER_CPU(struct cpuidle_device, cpuidle_dev);
* cpuidle_get_last_residency - retrieves the last state's residency time
* cpuidle_get_last_residency - retrieves the last state's residency time
* @dev: the target CPU
* @dev: the target CPU
*
*
* NOTE: this value is invalid if CPUIDLE_FLAG_TIME_
VALID isn't
set
* NOTE: this value is invalid if CPUIDLE_FLAG_TIME_
INVALID is
set
*/
*/
static
inline
int
cpuidle_get_last_residency
(
struct
cpuidle_device
*
dev
)
static
inline
int
cpuidle_get_last_residency
(
struct
cpuidle_device
*
dev
)
{
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment