@@ -2694,6 +2694,7 @@ static inline void trace_shadow_emulate_
}
}
+#ifdef CONFIG_HVM
#if GUEST_PAGING_LEVELS == 3
static DEFINE_PER_CPU(guest_va_t,trace_emulate_initial_va);
static DEFINE_PER_CPU(int,trace_extra_emulation_count);
@@ -2745,6 +2746,7 @@ static inline void trace_shadow_emulate(
__trace_var(event, 0/*!tsc*/, sizeof(d), &d);
}
}
+#endif /* CONFIG_HVM */
/**************************************************************************/
/* Entry points into the shadow code */
@@ -4887,8 +4889,8 @@ const struct paging_mode sh_paging_mode
.shadow.guess_wrmap = sh_guess_wrmap,
#endif
.shadow.pagetable_dying = sh_pagetable_dying,
-#endif /* CONFIG_HVM */
.shadow.trace_emul_write_val = trace_emulate_write_val,
+#endif /* CONFIG_HVM */
.shadow.shadow_levels = SHADOW_PAGING_LEVELS,
};
@@ -108,10 +108,10 @@ struct shadow_paging_mode {
int (*guess_wrmap )(struct vcpu *v,
unsigned long vaddr, mfn_t gmfn);
void (*pagetable_dying )(paddr_t gpa);
-#endif
void (*trace_emul_write_val )(const void *ptr, unsigned long vaddr,
const void *src, unsigned int bytes);
#endif
+#endif
/* For outsiders to tell what mode we're in */
unsigned int shadow_levels;
};
Its only caller lives in HVM-only code, and the only caller of trace_shadow_emulate() also already site in a HVM-only code section. Signed-off-by: Jan Beulich <jbeulich@suse.com>