[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH 0/5] ARM hypercall ABI: 64 bit ready



On 06/08/12 15:11, Stefano Stabellini wrote:
> Hi all,
> this patch series makes the necessary changes to make sure that the
> current ARM hypercall ABI can be used as-is on 64 bit ARM platforms:
> 
> - it defines xen_ulong_t as uint64_t on ARM;
> - it introduces a new macro to handle guest pointers, called
> XEN_GUEST_HANDLE_PARAM (that has size 4 bytes on aarch and is going to
> have size 8 bytes on aarch64);
> - it replaces all the occurrences of XEN_GUEST_HANDLE in hypercall
> parameters with XEN_GUEST_HANDLE_PARAM.

This is a subtle (and undocumented!) distinction. I can see people
adding/modifying hypercall etc. getting this wrong and no one noticing
for a while (since it doesn't affect x86).

The xen_ulong_t parameters (when used for pointers) from an aarch guest
point of view are a uint32_t guest pointer and uint32_t of padding.  So
the guest handles will be the same size in hypercall parameters and
structure members.

David

> On x86 and ia64 things should stay exactly the same.
> 
> On ARM all the unsigned long and the guest pointers that are members of
> a struct become size 8 byte (both aarch and aarch64).
> However guest pointers that are passed as hypercall arguments in
> registers are going to be 4 bytes on aarch and 8 bytes on aarch64.
> 
> It is based on Ian's arm-for-4.3 branch. 
> 
> 
> Stefano Stabellini (5):
>       xen: improve changes to xen_add_to_physmap
>       xen/arm: introduce __lshrdi3 and __aeabi_llsr
>       xen: few more xen_ulong_t substitutions
>       xen: introduce XEN_GUEST_HANDLE_PARAM
>       xen: replace XEN_GUEST_HANDLE with XEN_GUEST_HANDLE_PARAM when 
> appropriate
> 
> 
>  xen/arch/arm/domain.c              |    2 +-
>  xen/arch/arm/domctl.c              |    2 +-
>  xen/arch/arm/hvm.c                 |    2 +-
>  xen/arch/arm/lib/Makefile          |    2 +-
>  xen/arch/arm/lib/lshrdi3.S         |   54 
> ++++++++++++++++++++++++++++++++++++
>  xen/arch/arm/mm.c                  |    2 +-
>  xen/arch/arm/physdev.c             |    2 +-
>  xen/arch/arm/sysctl.c              |    2 +-
>  xen/arch/x86/cpu/mcheck/mce.c      |    2 +-
>  xen/arch/x86/domain.c              |    2 +-
>  xen/arch/x86/domctl.c              |    2 +-
>  xen/arch/x86/efi/runtime.c         |    2 +-
>  xen/arch/x86/hvm/hvm.c             |   26 ++++++++--------
>  xen/arch/x86/microcode.c           |    2 +-
>  xen/arch/x86/mm.c                  |   14 ++++----
>  xen/arch/x86/mm/hap/hap.c          |    2 +-
>  xen/arch/x86/mm/mem_event.c        |    2 +-
>  xen/arch/x86/mm/paging.c           |    2 +-
>  xen/arch/x86/mm/shadow/common.c    |    2 +-
>  xen/arch/x86/physdev.c             |    2 +-
>  xen/arch/x86/platform_hypercall.c  |    2 +-
>  xen/arch/x86/sysctl.c              |    2 +-
>  xen/arch/x86/traps.c               |    2 +-
>  xen/arch/x86/x86_32/mm.c           |    2 +-
>  xen/arch/x86/x86_32/traps.c        |    2 +-
>  xen/arch/x86/x86_64/compat/mm.c    |    8 ++--
>  xen/arch/x86/x86_64/domain.c       |    2 +-
>  xen/arch/x86/x86_64/mm.c           |    2 +-
>  xen/arch/x86/x86_64/traps.c        |    2 +-
>  xen/common/compat/domain.c         |    2 +-
>  xen/common/compat/grant_table.c    |    2 +-
>  xen/common/compat/memory.c         |    2 +-
>  xen/common/domain.c                |    2 +-
>  xen/common/domctl.c                |    2 +-
>  xen/common/event_channel.c         |    2 +-
>  xen/common/grant_table.c           |   36 ++++++++++++------------
>  xen/common/kernel.c                |    4 +-
>  xen/common/kexec.c                 |   16 +++++-----
>  xen/common/memory.c                |    4 +-
>  xen/common/multicall.c             |    2 +-
>  xen/common/schedule.c              |    2 +-
>  xen/common/sysctl.c                |    2 +-
>  xen/common/xenoprof.c              |    8 ++--
>  xen/drivers/acpi/pmstat.c          |    2 +-
>  xen/drivers/char/console.c         |    6 ++--
>  xen/drivers/passthrough/iommu.c    |    2 +-
>  xen/include/asm-arm/guest_access.h |    2 +-
>  xen/include/asm-arm/hypercall.h    |    2 +-
>  xen/include/asm-arm/mm.h           |    2 +-
>  xen/include/asm-x86/hap.h          |    2 +-
>  xen/include/asm-x86/hypercall.h    |   24 ++++++++--------
>  xen/include/asm-x86/mem_event.h    |    2 +-
>  xen/include/asm-x86/mm.h           |    8 ++--
>  xen/include/asm-x86/paging.h       |    2 +-
>  xen/include/asm-x86/processor.h    |    2 +-
>  xen/include/asm-x86/shadow.h       |    2 +-
>  xen/include/asm-x86/xenoprof.h     |    6 ++--
>  xen/include/public/arch-arm.h      |   21 ++++++++++----
>  xen/include/public/arch-ia64.h     |    1 +
>  xen/include/public/arch-x86/xen.h  |    1 +
>  xen/include/public/memory.h        |   11 ++++--
>  xen/include/public/physdev.h       |    2 +-
>  xen/include/public/version.h       |    2 +-
>  xen/include/public/xen.h           |    4 +-
>  xen/include/xen/acpi.h             |    4 +-
>  xen/include/xen/hypercall.h        |   52 +++++++++++++++++-----------------
>  xen/include/xen/iommu.h            |    2 +-
>  xen/include/xen/tmem_xen.h         |    2 +-
>  xen/include/xsm/xsm.h              |    4 +-
>  xen/xsm/dummy.c                    |    2 +-
>  xen/xsm/flask/flask_op.c           |    4 +-
>  xen/xsm/flask/hooks.c              |    2 +-
>  xen/xsm/xsm_core.c                 |    2 +-
>  73 files changed, 243 insertions(+), 175 deletions(-)
> 
> 
> Cheers,
> 
> Stefano
> 
> _______________________________________________
> Xen-devel mailing list
> Xen-devel@xxxxxxxxxxxxx
> http://lists.xen.org/xen-devel


_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.