Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
4a973f24
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
4a973f24
编写于
7月 22, 2010
作者:
L
Len Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'bugzilla-15886' into release
上级
be48b115
d3e7e99f
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
17 addition
and
2 deletion
+17
-2
arch/x86/kernel/acpi/cstate.c
arch/x86/kernel/acpi/cstate.c
+9
-0
drivers/acpi/processor_idle.c
drivers/acpi/processor_idle.c
+6
-1
include/acpi/processor.h
include/acpi/processor.h
+2
-1
未找到文件。
arch/x86/kernel/acpi/cstate.c
浏览文件 @
4a973f24
...
...
@@ -145,6 +145,15 @@ int acpi_processor_ffh_cstate_probe(unsigned int cpu,
percpu_entry
->
states
[
cx
->
index
].
eax
=
cx
->
address
;
percpu_entry
->
states
[
cx
->
index
].
ecx
=
MWAIT_ECX_INTERRUPT_BREAK
;
}
/*
* For _CST FFH on Intel, if GAS.access_size bit 1 is cleared,
* then we should skip checking BM_STS for this C-state.
* ref: "Intel Processor Vendor-Specific ACPI Interface Specification"
*/
if
((
c
->
x86_vendor
==
X86_VENDOR_INTEL
)
&&
!
(
reg
->
access_size
&
0x2
))
cx
->
bm_sts_skip
=
1
;
return
retval
;
}
EXPORT_SYMBOL_GPL
(
acpi_processor_ffh_cstate_probe
);
...
...
drivers/acpi/processor_idle.c
浏览文件 @
4a973f24
...
...
@@ -76,6 +76,8 @@ static unsigned int max_cstate __read_mostly = ACPI_PROCESSOR_MAX_POWER;
module_param
(
max_cstate
,
uint
,
0000
);
static
unsigned
int
nocst
__read_mostly
;
module_param
(
nocst
,
uint
,
0000
);
static
int
bm_check_disable
__read_mostly
;
module_param
(
bm_check_disable
,
uint
,
0000
);
static
unsigned
int
latency_factor
__read_mostly
=
2
;
module_param
(
latency_factor
,
uint
,
0644
);
...
...
@@ -763,6 +765,9 @@ static int acpi_idle_bm_check(void)
{
u32
bm_status
=
0
;
if
(
bm_check_disable
)
return
0
;
acpi_read_bit_register
(
ACPI_BITREG_BUS_MASTER_STATUS
,
&
bm_status
);
if
(
bm_status
)
acpi_write_bit_register
(
ACPI_BITREG_BUS_MASTER_STATUS
,
1
);
...
...
@@ -947,7 +952,7 @@ static int acpi_idle_enter_bm(struct cpuidle_device *dev,
if
(
acpi_idle_suspend
)
return
(
acpi_idle_enter_c1
(
dev
,
state
));
if
(
acpi_idle_bm_check
())
{
if
(
!
cx
->
bm_sts_skip
&&
acpi_idle_bm_check
())
{
if
(
dev
->
safe_state
)
{
dev
->
last_state
=
dev
->
safe_state
;
return
dev
->
safe_state
->
enter
(
dev
,
dev
->
safe_state
);
...
...
include/acpi/processor.h
浏览文件 @
4a973f24
...
...
@@ -48,7 +48,7 @@ struct acpi_power_register {
u8
space_id
;
u8
bit_width
;
u8
bit_offset
;
u8
reserved
;
u8
access_size
;
u64
address
;
}
__attribute__
((
packed
));
...
...
@@ -63,6 +63,7 @@ struct acpi_processor_cx {
u32
power
;
u32
usage
;
u64
time
;
u8
bm_sts_skip
;
char
desc
[
ACPI_CX_DESC_LEN
];
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录