[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-unstable] Enable compatibility mode operation for HYPERVISOR_set_trap_table and
# HG changeset patch # User Emmanuel Ackaouy <ack@xxxxxxxxxxxxx> # Date 1168018474 0 # Node ID e5f24d5f71acbe0fe52ffbbab3817a189dc57ed6 # Parent ac55ec633422320a92b5cbec17f695a29ee9e220 Enable compatibility mode operation for HYPERVISOR_set_trap_table and HYPERVISOR_set_gdt. Signed-off-by: Jan Beulich <jbeulich@xxxxxxxxxx> --- xen/arch/x86/x86_64/compat/entry.S | 2 - xen/arch/x86/x86_64/compat/mm.c | 33 +++++++++++++++++++++++++++ xen/arch/x86/x86_64/compat/traps.c | 45 +++++++++++++++++++++++++++++++++++++ 3 files changed, 78 insertions(+), 2 deletions(-) diff -r ac55ec633422 -r e5f24d5f71ac xen/arch/x86/x86_64/compat/entry.S --- a/xen/arch/x86/x86_64/compat/entry.S Fri Jan 05 17:34:33 2007 +0000 +++ b/xen/arch/x86/x86_64/compat/entry.S Fri Jan 05 17:34:34 2007 +0000 @@ -278,8 +278,6 @@ CFIX14: .section .rodata, "a", @progbits -#define compat_set_trap_table domain_crash_synchronous -#define compat_set_gdt domain_crash_synchronous #define compat_platform_op domain_crash_synchronous #define compat_multicall domain_crash_synchronous #define compat_set_timer_op domain_crash_synchronous diff -r ac55ec633422 -r e5f24d5f71ac xen/arch/x86/x86_64/compat/mm.c --- a/xen/arch/x86/x86_64/compat/mm.c Fri Jan 05 17:34:33 2007 +0000 +++ b/xen/arch/x86/x86_64/compat/mm.c Fri Jan 05 17:34:34 2007 +0000 @@ -3,6 +3,39 @@ #include <xen/event.h> #include <compat/memory.h> #include <compat/xen.h> + +int compat_set_gdt(XEN_GUEST_HANDLE(uint) frame_list, unsigned int entries) +{ + unsigned int i, nr_pages = (entries + 511) / 512; + unsigned long frames[16]; + long ret; + + /* Rechecked in set_gdt, but ensures a sane limit for copy_from_user(). */ + if ( entries > FIRST_RESERVED_GDT_ENTRY ) + return -EINVAL; + + if ( !guest_handle_okay(frame_list, nr_pages) ) + return -EFAULT; + + for ( i = 0; i < nr_pages; ++i ) + { + unsigned int frame; + + if ( __copy_from_guest(&frame, frame_list, 1) ) + return -EFAULT; + frames[i] = frame; + guest_handle_add_offset(frame_list, 1); + } + + LOCK_BIGLOCK(current->domain); + + if ( (ret = set_gdt(current, frames, entries)) == 0 ) + local_flush_tlb(); + + UNLOCK_BIGLOCK(current->domain); + + return ret; +} int compat_update_descriptor(u32 pa_lo, u32 pa_hi, u32 desc_lo, u32 desc_hi) { diff -r ac55ec633422 -r e5f24d5f71ac xen/arch/x86/x86_64/compat/traps.c --- a/xen/arch/x86/x86_64/compat/traps.c Fri Jan 05 17:34:33 2007 +0000 +++ b/xen/arch/x86/x86_64/compat/traps.c Fri Jan 05 17:34:34 2007 +0000 @@ -1,6 +1,8 @@ #ifdef CONFIG_COMPAT +#include <xen/event.h> #include <compat/callback.h> +#include <compat/arch-x86_32.h> void compat_show_guest_stack(struct cpu_user_regs *regs, int debug_stack_lines) { @@ -252,6 +254,49 @@ long compat_set_callbacks(unsigned long return 0; } +DEFINE_XEN_GUEST_HANDLE(trap_info_compat_t); + +int compat_set_trap_table(XEN_GUEST_HANDLE(trap_info_compat_t) traps) +{ + struct compat_trap_info cur; + struct trap_info *dst = current->arch.guest_context.trap_ctxt; + long rc = 0; + + /* If no table is presented then clear the entire virtual IDT. */ + if ( guest_handle_is_null(traps) ) + { + memset(dst, 0, 256 * sizeof(*dst)); + return 0; + } + + for ( ; ; ) + { + if ( hypercall_preempt_check() ) + { + rc = hypercall_create_continuation( + __HYPERVISOR_set_trap_table, "h", traps); + break; + } + + if ( copy_from_guest(&cur, traps, 1) ) + { + rc = -EFAULT; + break; + } + + if ( cur.address == 0 ) + break; + + fixup_guest_code_selector(current->domain, cur.cs); + + XLAT_trap_info(dst + cur.vector, &cur); + + guest_handle_add_offset(traps, 1); + } + + return rc; +} + #endif /* CONFIG_COMPAT */ static void hypercall_page_initialise_ring1_kernel(void *hypercall_page) _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |