Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
6af7faf6
K
Kernel
项目概览
openeuler
/
Kernel
接近 2 年 前同步成功
通知
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看板
提交
6af7faf6
编写于
5月 15, 2015
作者:
T
Thomas Gleixner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
x86: Use entering[_ack]_irq() instead of open coding it
Signed-off-by:
N
Thomas Gleixner
<
tglx@linutronix.de
>
上级
486ca539
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
8 addition
and
20 deletion
+8
-20
arch/x86/kernel/apic/vector.c
arch/x86/kernel/apic/vector.c
+2
-4
arch/x86/kernel/cpu/mshyperv.c
arch/x86/kernel/cpu/mshyperv.c
+2
-4
arch/x86/kernel/irq.c
arch/x86/kernel/irq.c
+4
-12
未找到文件。
arch/x86/kernel/apic/vector.c
浏览文件 @
6af7faf6
...
@@ -542,9 +542,7 @@ asmlinkage __visible void smp_irq_move_cleanup_interrupt(void)
...
@@ -542,9 +542,7 @@ asmlinkage __visible void smp_irq_move_cleanup_interrupt(void)
{
{
unsigned
vector
,
me
;
unsigned
vector
,
me
;
ack_APIC_irq
();
entering_ack_irq
();
irq_enter
();
exit_idle
();
me
=
smp_processor_id
();
me
=
smp_processor_id
();
for
(
vector
=
FIRST_EXTERNAL_VECTOR
;
vector
<
NR_VECTORS
;
vector
++
)
{
for
(
vector
=
FIRST_EXTERNAL_VECTOR
;
vector
<
NR_VECTORS
;
vector
++
)
{
...
@@ -596,7 +594,7 @@ asmlinkage __visible void smp_irq_move_cleanup_interrupt(void)
...
@@ -596,7 +594,7 @@ asmlinkage __visible void smp_irq_move_cleanup_interrupt(void)
raw_spin_unlock
(
&
desc
->
lock
);
raw_spin_unlock
(
&
desc
->
lock
);
}
}
irq_exit
();
exiting_irq
();
}
}
static
void
__irq_complete_move
(
struct
irq_cfg
*
cfg
,
unsigned
vector
)
static
void
__irq_complete_move
(
struct
irq_cfg
*
cfg
,
unsigned
vector
)
...
...
arch/x86/kernel/cpu/mshyperv.c
浏览文件 @
6af7faf6
...
@@ -39,14 +39,12 @@ void hyperv_vector_handler(struct pt_regs *regs)
...
@@ -39,14 +39,12 @@ void hyperv_vector_handler(struct pt_regs *regs)
{
{
struct
pt_regs
*
old_regs
=
set_irq_regs
(
regs
);
struct
pt_regs
*
old_regs
=
set_irq_regs
(
regs
);
irq_enter
();
entering_irq
();
exit_idle
();
inc_irq_stat
(
irq_hv_callback_count
);
inc_irq_stat
(
irq_hv_callback_count
);
if
(
vmbus_handler
)
if
(
vmbus_handler
)
vmbus_handler
();
vmbus_handler
();
irq_exit
();
exiting_irq
();
set_irq_regs
(
old_regs
);
set_irq_regs
(
old_regs
);
}
}
...
...
arch/x86/kernel/irq.c
浏览文件 @
6af7faf6
...
@@ -198,8 +198,7 @@ __visible unsigned int __irq_entry do_IRQ(struct pt_regs *regs)
...
@@ -198,8 +198,7 @@ __visible unsigned int __irq_entry do_IRQ(struct pt_regs *regs)
unsigned
vector
=
~
regs
->
orig_ax
;
unsigned
vector
=
~
regs
->
orig_ax
;
unsigned
irq
;
unsigned
irq
;
irq_enter
();
entering_irq
();
exit_idle
();
irq
=
__this_cpu_read
(
vector_irq
[
vector
]);
irq
=
__this_cpu_read
(
vector_irq
[
vector
]);
...
@@ -215,7 +214,7 @@ __visible unsigned int __irq_entry do_IRQ(struct pt_regs *regs)
...
@@ -215,7 +214,7 @@ __visible unsigned int __irq_entry do_IRQ(struct pt_regs *regs)
}
}
}
}
irq_exit
();
exiting_irq
();
set_irq_regs
(
old_regs
);
set_irq_regs
(
old_regs
);
return
1
;
return
1
;
...
@@ -250,16 +249,9 @@ __visible void smp_kvm_posted_intr_ipi(struct pt_regs *regs)
...
@@ -250,16 +249,9 @@ __visible void smp_kvm_posted_intr_ipi(struct pt_regs *regs)
{
{
struct
pt_regs
*
old_regs
=
set_irq_regs
(
regs
);
struct
pt_regs
*
old_regs
=
set_irq_regs
(
regs
);
ack_APIC_irq
();
entering_ack_irq
();
irq_enter
();
exit_idle
();
inc_irq_stat
(
kvm_posted_intr_ipis
);
inc_irq_stat
(
kvm_posted_intr_ipis
);
exiting_irq
();
irq_exit
();
set_irq_regs
(
old_regs
);
set_irq_regs
(
old_regs
);
}
}
#endif
#endif
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录