Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
00527cc6
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看板
提交
00527cc6
编写于
10月 23, 2010
作者:
L
Len Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'intel_idle+snb' into idle-release
Signed-off-by:
N
Len Brown
<
len.brown@intel.com
>
上级
0f3f164d
d13780d4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
42 addition
and
1 deletion
+42
-1
drivers/idle/intel_idle.c
drivers/idle/intel_idle.c
+42
-1
未找到文件。
drivers/idle/intel_idle.c
浏览文件 @
00527cc6
...
...
@@ -81,7 +81,7 @@ static int max_cstate = MWAIT_MAX_NUM_CSTATES - 1;
static
unsigned
int
mwait_substates
;
/* Reliable LAPIC Timer States, bit 1 for C1 etc. */
static
unsigned
int
lapic_timer_reliable_states
;
static
unsigned
int
lapic_timer_reliable_states
=
(
1
<<
1
);
/* Default to only C1 */
static
struct
cpuidle_device
__percpu
*
intel_idle_cpuidle_devices
;
static
int
intel_idle
(
struct
cpuidle_device
*
dev
,
struct
cpuidle_state
*
state
);
...
...
@@ -121,6 +121,42 @@ static struct cpuidle_state nehalem_cstates[MWAIT_MAX_NUM_CSTATES] = {
.
enter
=
&
intel_idle
},
};
static
struct
cpuidle_state
snb_cstates
[
MWAIT_MAX_NUM_CSTATES
]
=
{
{
/* MWAIT C0 */
},
{
/* MWAIT C1 */
.
name
=
"SNB-C1"
,
.
desc
=
"MWAIT 0x00"
,
.
driver_data
=
(
void
*
)
0x00
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
,
.
exit_latency
=
1
,
.
target_residency
=
4
,
.
enter
=
&
intel_idle
},
{
/* MWAIT C2 */
.
name
=
"SNB-C3"
,
.
desc
=
"MWAIT 0x10"
,
.
driver_data
=
(
void
*
)
0x10
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
80
,
.
target_residency
=
160
,
.
enter
=
&
intel_idle
},
{
/* MWAIT C3 */
.
name
=
"SNB-C6"
,
.
desc
=
"MWAIT 0x20"
,
.
driver_data
=
(
void
*
)
0x20
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
104
,
.
target_residency
=
208
,
.
enter
=
&
intel_idle
},
{
/* MWAIT C4 */
.
name
=
"SNB-C7"
,
.
desc
=
"MWAIT 0x30"
,
.
driver_data
=
(
void
*
)
0x30
,
.
flags
=
CPUIDLE_FLAG_TIME_VALID
|
CPUIDLE_FLAG_TLB_FLUSHED
,
.
exit_latency
=
109
,
.
target_residency
=
300
,
.
enter
=
&
intel_idle
},
};
static
struct
cpuidle_state
atom_cstates
[
MWAIT_MAX_NUM_CSTATES
]
=
{
{
/* MWAIT C0 */
},
{
/* MWAIT C1 */
...
...
@@ -269,6 +305,11 @@ static int intel_idle_probe(void)
lapic_timer_reliable_states
=
(
1
<<
2
)
|
(
1
<<
1
);
/* C2, C1 */
cpuidle_state_table
=
atom_cstates
;
break
;
case
0x2A
:
/* SNB */
case
0x2D
:
/* SNB Xeon */
cpuidle_state_table
=
snb_cstates
;
break
;
#ifdef FUTURE_USE
case
0x17
:
/* 23 - Core 2 Duo */
lapic_timer_reliable_states
=
(
1
<<
2
)
|
(
1
<<
1
);
/* C2, C1 */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录