Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
715a4318
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看板
提交
715a4318
编写于
12月 15, 2011
作者:
I
Ingo Molnar
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'early-mce-decode' of
git://git.kernel.org/pub/scm/linux/kernel/git/bp/bp
into x86/mce
上级
29e9bf18
09371957
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
65 addition
and
16 deletion
+65
-16
arch/x86/include/asm/mce.h
arch/x86/include/asm/mce.h
+2
-1
arch/x86/kernel/cpu/mcheck/mce.c
arch/x86/kernel/cpu/mcheck/mce.c
+57
-7
drivers/edac/i7core_edac.c
drivers/edac/i7core_edac.c
+2
-2
drivers/edac/mce_amd.c
drivers/edac/mce_amd.c
+2
-2
drivers/edac/sb_edac.c
drivers/edac/sb_edac.c
+2
-4
未找到文件。
arch/x86/include/asm/mce.h
浏览文件 @
715a4318
...
...
@@ -120,7 +120,8 @@ struct mce_log {
#ifdef __KERNEL__
extern
struct
atomic_notifier_head
x86_mce_decoder_chain
;
extern
void
mce_register_decode_chain
(
struct
notifier_block
*
nb
);
extern
void
mce_unregister_decode_chain
(
struct
notifier_block
*
nb
);
#include <linux/percpu.h>
#include <linux/init.h>
...
...
arch/x86/kernel/cpu/mcheck/mce.c
浏览文件 @
715a4318
...
...
@@ -95,13 +95,6 @@ static DECLARE_WAIT_QUEUE_HEAD(mce_chrdev_wait);
static
DEFINE_PER_CPU
(
struct
mce
,
mces_seen
);
static
int
cpu_missing
;
/*
* CPU/chipset specific EDAC code can register a notifier call here to print
* MCE errors in a human-readable form.
*/
ATOMIC_NOTIFIER_HEAD
(
x86_mce_decoder_chain
);
EXPORT_SYMBOL_GPL
(
x86_mce_decoder_chain
);
/* MCA banks polled by the period polling timer for corrected events */
DEFINE_PER_CPU
(
mce_banks_t
,
mce_poll_banks
)
=
{
[
0
...
BITS_TO_LONGS
(
MAX_NR_BANKS
)
-
1
]
=
~
0UL
...
...
@@ -109,6 +102,12 @@ DEFINE_PER_CPU(mce_banks_t, mce_poll_banks) = {
static
DEFINE_PER_CPU
(
struct
work_struct
,
mce_work
);
/*
* CPU/chipset specific EDAC code can register a notifier call here to print
* MCE errors in a human-readable form.
*/
ATOMIC_NOTIFIER_HEAD
(
x86_mce_decoder_chain
);
/* Do initial initialization of a struct mce */
void
mce_setup
(
struct
mce
*
m
)
{
...
...
@@ -190,6 +189,57 @@ void mce_log(struct mce *mce)
set_bit
(
0
,
&
mce_need_notify
);
}
static
void
drain_mcelog_buffer
(
void
)
{
unsigned
int
next
,
i
,
prev
=
0
;
next
=
rcu_dereference_check_mce
(
mcelog
.
next
);
do
{
struct
mce
*
m
;
/* drain what was logged during boot */
for
(
i
=
prev
;
i
<
next
;
i
++
)
{
unsigned
long
start
=
jiffies
;
unsigned
retries
=
1
;
m
=
&
mcelog
.
entry
[
i
];
while
(
!
m
->
finished
)
{
if
(
time_after_eq
(
jiffies
,
start
+
2
*
retries
))
retries
++
;
cpu_relax
();
if
(
!
m
->
finished
&&
retries
>=
4
)
{
pr_err
(
"MCE: skipping error being logged currently!
\n
"
);
break
;
}
}
smp_rmb
();
atomic_notifier_call_chain
(
&
x86_mce_decoder_chain
,
0
,
m
);
}
memset
(
mcelog
.
entry
+
prev
,
0
,
(
next
-
prev
)
*
sizeof
(
*
m
));
prev
=
next
;
next
=
cmpxchg
(
&
mcelog
.
next
,
prev
,
0
);
}
while
(
next
!=
prev
);
}
void
mce_register_decode_chain
(
struct
notifier_block
*
nb
)
{
atomic_notifier_chain_register
(
&
x86_mce_decoder_chain
,
nb
);
drain_mcelog_buffer
();
}
EXPORT_SYMBOL_GPL
(
mce_register_decode_chain
);
void
mce_unregister_decode_chain
(
struct
notifier_block
*
nb
)
{
atomic_notifier_chain_unregister
(
&
x86_mce_decoder_chain
,
nb
);
}
EXPORT_SYMBOL_GPL
(
mce_unregister_decode_chain
);
static
void
print_mce
(
struct
mce
*
m
)
{
int
ret
=
0
;
...
...
drivers/edac/i7core_edac.c
浏览文件 @
715a4318
...
...
@@ -2234,7 +2234,7 @@ static void i7core_unregister_mci(struct i7core_dev *i7core_dev)
if
(
pvt
->
enable_scrub
)
disable_sdram_scrub_setting
(
mci
);
atomic_notifier_chain_unregister
(
&
x86_mce_decoder_chain
,
&
i7_mce_dec
);
mce_unregister_decode_chain
(
&
i7_mce_dec
);
/* Disable EDAC polling */
i7core_pci_ctl_release
(
pvt
);
...
...
@@ -2336,7 +2336,7 @@ static int i7core_register_mci(struct i7core_dev *i7core_dev)
/* DCLK for scrub rate setting */
pvt
->
dclk_freq
=
get_dclk_freq
();
atomic_notifier_chain_register
(
&
x86_mce_decoder_chain
,
&
i7_mce_dec
);
mce_register_decode_chain
(
&
i7_mce_dec
);
return
0
;
...
...
drivers/edac/mce_amd.c
浏览文件 @
715a4318
...
...
@@ -884,7 +884,7 @@ static int __init mce_amd_init(void)
pr_info
(
"MCE: In-kernel MCE decoding enabled.
\n
"
);
atomic_notifier_chain_register
(
&
x86_mce_decoder_chain
,
&
amd_mce_dec_nb
);
mce_register_decode_chain
(
&
amd_mce_dec_nb
);
return
0
;
}
...
...
@@ -893,7 +893,7 @@ early_initcall(mce_amd_init);
#ifdef MODULE
static
void
__exit
mce_amd_exit
(
void
)
{
atomic_notifier_chain_unregister
(
&
x86_mce_decoder_chain
,
&
amd_mce_dec_nb
);
mce_unregister_decode_chain
(
&
amd_mce_dec_nb
);
kfree
(
fam_ops
);
}
...
...
drivers/edac/sb_edac.c
浏览文件 @
715a4318
...
...
@@ -1661,8 +1661,7 @@ static void sbridge_unregister_mci(struct sbridge_dev *sbridge_dev)
debugf0
(
"MC: "
__FILE__
": %s(): mci = %p, dev = %p
\n
"
,
__func__
,
mci
,
&
sbridge_dev
->
pdev
[
0
]
->
dev
);
atomic_notifier_chain_unregister
(
&
x86_mce_decoder_chain
,
&
sbridge_mce_dec
);
mce_unregister_decode_chain
(
&
sbridge_mce_dec
);
/* Remove MC sysfs nodes */
edac_mc_del_mc
(
mci
->
dev
);
...
...
@@ -1731,8 +1730,7 @@ static int sbridge_register_mci(struct sbridge_dev *sbridge_dev)
goto
fail0
;
}
atomic_notifier_chain_register
(
&
x86_mce_decoder_chain
,
&
sbridge_mce_dec
);
mce_register_decode_chain
(
&
sbridge_mce_dec
);
return
0
;
fail0:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录