Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
52d1dba9
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看板
提交
52d1dba9
编写于
10月 15, 2012
作者:
M
Marc Zyngier
提交者:
Christoffer Dall
3月 06, 2013
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ARM: KVM: abstract HSR_EC_IABT away
Signed-off-by:
N
Marc Zyngier
<
marc.zyngier@arm.com
>
上级
1cc287dd
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
8 addition
and
5 deletion
+8
-5
arch/arm/include/asm/kvm_emulate.h
arch/arm/include/asm/kvm_emulate.h
+5
-0
arch/arm/kvm/mmu.c
arch/arm/kvm/mmu.c
+3
-5
未找到文件。
arch/arm/include/asm/kvm_emulate.h
浏览文件 @
52d1dba9
...
@@ -147,6 +147,11 @@ static inline u8 kvm_vcpu_trap_get_class(struct kvm_vcpu *vcpu)
...
@@ -147,6 +147,11 @@ static inline u8 kvm_vcpu_trap_get_class(struct kvm_vcpu *vcpu)
return
kvm_vcpu_get_hsr
(
vcpu
)
>>
HSR_EC_SHIFT
;
return
kvm_vcpu_get_hsr
(
vcpu
)
>>
HSR_EC_SHIFT
;
}
}
static
inline
bool
kvm_vcpu_trap_is_iabt
(
struct
kvm_vcpu
*
vcpu
)
{
return
kvm_vcpu_trap_get_class
(
vcpu
)
==
HSR_EC_IABT
;
}
static
inline
u8
kvm_vcpu_trap_get_fault
(
struct
kvm_vcpu
*
vcpu
)
static
inline
u8
kvm_vcpu_trap_get_fault
(
struct
kvm_vcpu
*
vcpu
)
{
{
return
kvm_vcpu_get_hsr
(
vcpu
)
&
HSR_FSC_TYPE
;
return
kvm_vcpu_get_hsr
(
vcpu
)
&
HSR_FSC_TYPE
;
...
...
arch/arm/kvm/mmu.c
浏览文件 @
52d1dba9
...
@@ -585,7 +585,6 @@ static int user_mem_abort(struct kvm_vcpu *vcpu, phys_addr_t fault_ipa,
...
@@ -585,7 +585,6 @@ static int user_mem_abort(struct kvm_vcpu *vcpu, phys_addr_t fault_ipa,
*/
*/
int
kvm_handle_guest_abort
(
struct
kvm_vcpu
*
vcpu
,
struct
kvm_run
*
run
)
int
kvm_handle_guest_abort
(
struct
kvm_vcpu
*
vcpu
,
struct
kvm_run
*
run
)
{
{
unsigned
long
hsr_ec
;
unsigned
long
fault_status
;
unsigned
long
fault_status
;
phys_addr_t
fault_ipa
;
phys_addr_t
fault_ipa
;
struct
kvm_memory_slot
*
memslot
;
struct
kvm_memory_slot
*
memslot
;
...
@@ -593,8 +592,7 @@ int kvm_handle_guest_abort(struct kvm_vcpu *vcpu, struct kvm_run *run)
...
@@ -593,8 +592,7 @@ int kvm_handle_guest_abort(struct kvm_vcpu *vcpu, struct kvm_run *run)
gfn_t
gfn
;
gfn_t
gfn
;
int
ret
,
idx
;
int
ret
,
idx
;
hsr_ec
=
kvm_vcpu_trap_get_class
(
vcpu
);
is_iabt
=
kvm_vcpu_trap_is_iabt
(
vcpu
);
is_iabt
=
(
hsr_ec
==
HSR_EC_IABT
);
fault_ipa
=
kvm_vcpu_get_fault_ipa
(
vcpu
);
fault_ipa
=
kvm_vcpu_get_fault_ipa
(
vcpu
);
trace_kvm_guest_fault
(
*
vcpu_pc
(
vcpu
),
kvm_vcpu_get_hsr
(
vcpu
),
trace_kvm_guest_fault
(
*
vcpu_pc
(
vcpu
),
kvm_vcpu_get_hsr
(
vcpu
),
...
@@ -603,8 +601,8 @@ int kvm_handle_guest_abort(struct kvm_vcpu *vcpu, struct kvm_run *run)
...
@@ -603,8 +601,8 @@ int kvm_handle_guest_abort(struct kvm_vcpu *vcpu, struct kvm_run *run)
/* Check the stage-2 fault is trans. fault or write fault */
/* Check the stage-2 fault is trans. fault or write fault */
fault_status
=
kvm_vcpu_trap_get_fault
(
vcpu
);
fault_status
=
kvm_vcpu_trap_get_fault
(
vcpu
);
if
(
fault_status
!=
FSC_FAULT
&&
fault_status
!=
FSC_PERM
)
{
if
(
fault_status
!=
FSC_FAULT
&&
fault_status
!=
FSC_PERM
)
{
kvm_err
(
"Unsupported fault status: EC=%#
l
x DFCS=%#lx
\n
"
,
kvm_err
(
"Unsupported fault status: EC=%#x DFCS=%#lx
\n
"
,
hsr_ec
,
fault_status
);
kvm_vcpu_trap_get_class
(
vcpu
)
,
fault_status
);
return
-
EFAULT
;
return
-
EFAULT
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录