On Wed, 2009-11-25 at 21:24 +0000, Jeremy Fitzhardinge wrote:
> On 11/25/09 02:22, Jan Beulich wrote:
> > Okay, I think I spotted the relevant difference: 2.6.18 and forward ports
> > set VGCF_in_syscall only when returning from 64-bit system calls (through
> > ret_from_sys_call) - 32-bit syscalls (regardless of the entry path taken)
> > return through int_ret_from_sys_call. 32-bit guest kernels shouldn't be
> > affected by this, as compat mode returns from the hypervisor
> > (compat_restore_all_guest) always use iret.
> >   
> 
> I think dropping the VCGF_in_syscall flag is the simplest possible fix
> then.  There doesn't seem to be a huge benefit to using sysret in this
> case.  Does this look OK?

Looks OK and works for me in practice too.

Ian.

> 
>     J
> 
> Subject: [PATCH] xen: use iret for return from 64b kernel to 32b usermode
> 
> If Xen wants to return to a 32b usermode with sysret it must use the
> right form.  When using VCGF_in_syscall to trigger this, it looks at
> the code segment and does a 32b sysret if it is FLAT_USER_CS32.
> However, this is different from __USER32_CS, so it fails to return
> properly if we use the normal Linux segment.
> 
> So avoid the whole mess by dropping VCGF_in_syscall and simply use
> plain iret to return to usermode.
> 
> Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardi...@citrix.com>

Tested-by: Ian Campbell <ian.campb...@citrix.com>

> 
> diff --git a/arch/x86/xen/xen-asm_64.S b/arch/x86/xen/xen-asm_64.S
> index 02f496a..f681d55 100644
> --- a/arch/x86/xen/xen-asm_64.S
> +++ b/arch/x86/xen/xen-asm_64.S
> @@ -96,7 +96,7 @@ ENTRY(xen_sysret32)
>       pushq $__USER32_CS
>       pushq %rcx
>  
> -     pushq $VGCF_in_syscall
> +     pushq $0
>  1:   jmp hypercall_iret
>  ENDPATCH(xen_sysret32)
>  RELOC(xen_sysret32, 1b+1)
> 
> 





-- 
To UNSUBSCRIBE, email to debian-bugs-dist-requ...@lists.debian.org
with a subject of "unsubscribe". Trouble? Contact listmas...@lists.debian.org

Reply via email to