blob: af5d959d043b9931dc9381302e791bfcd4951199 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
#ifndef __XEN_X86_SHARED_H__
#define __XEN_X86_SHARED_H__
#define nmi_reason(d) (!has_32bit_shinfo(d) ? \
(u32 *)&(d)->shared_info->native.arch.nmi_reason : \
(u32 *)&(d)->shared_info->compat.arch.nmi_reason)
#define GET_SET_SHARED(type, field) \
static inline type arch_get_##field(const struct domain *d) \
{ \
return !has_32bit_shinfo(d) ? \
d->shared_info->native.arch.field : \
d->shared_info->compat.arch.field; \
} \
static inline void arch_set_##field(struct domain *d, \
type val) \
{ \
if ( !has_32bit_shinfo(d) ) \
d->shared_info->native.arch.field = val; \
else \
d->shared_info->compat.arch.field = val; \
}
#define GET_SET_VCPU(type, field) \
static inline type arch_get_##field(const struct vcpu *v) \
{ \
return !has_32bit_shinfo(v->domain) ? \
v->vcpu_info->native.arch.field : \
v->vcpu_info->compat.arch.field; \
} \
static inline void arch_set_##field(struct vcpu *v, \
type val) \
{ \
if ( !has_32bit_shinfo(v->domain) ) \
v->vcpu_info->native.arch.field = val; \
else \
v->vcpu_info->compat.arch.field = val; \
}
GET_SET_SHARED(unsigned long, max_pfn)
GET_SET_SHARED(xen_pfn_t, pfn_to_mfn_frame_list_list)
GET_SET_SHARED(unsigned long, nmi_reason)
GET_SET_VCPU(unsigned long, cr2)
#undef GET_SET_VCPU
#undef GET_SET_SHARED
#endif /* __XEN_X86_SHARED_H__ */
|