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

Re: [Xen-ia64-devel] [PATCH]minios: remove big endian stuff



On Tue, Nov 18, 2008 at 10:49:01AM +0100, Dietmar Hahn wrote:
> Hi,
> 
> this patch removes all the useless big endian stuff from the minios.
> Thanks.

Hi. IIRC, you are the one who wanted big endian support for PV-guest.
What is the point to remove it from the minios?


> # HG changeset patch
> # User dietmar.hahn@xxxxxxxxxxxxxxxxxxx
> # Date 1227002151 -3600
> # Node ID 56ecdf7c49e7d86caf476da7119a8b19c5496910
> # Parent  cf3b9afb8568a18250faf08a0dd7c2b57bc7d3ac
> 
> Remove the useless big endian stuff.
> 
> Signed-off-by: Dietmar Hahn <dietmar.hahn@xxxxxxxxxxxxxxxxxxx>
> 
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/arch.mk
> --- a/extras/mini-os/arch/ia64/arch.mk        Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/arch.mk        Tue Nov 18 10:55:51 2008 +0100
> @@ -1,5 +1,3 @@
> -# Build for Big Endian?
> -BIGENDIAN ?= n
>  
>  ARCH_CFLAGS := -mfixed-range=f2-f5,f12-f15,f32-f127 -mconstant-gp
>  ARCH_CFLAGS += -O2
> @@ -9,12 +7,3 @@ ARCH_ASFLAGS += -fno-builtin -fno-common
>  
>  ARCH_LDFLAGS = -warn-common
>  
> -# Next lines are for big endian code !
> -ifeq ($(BIGENDIAN),y)
> -ARCH_CFLAGS += -mbig-endian -Wa,-mbe -Wa,-mlp64
> -ARCH_CFLAGS += -DBIG_ENDIAN
> -ARCH_ASFLAGS += -Wa,-mbe
> -ARCH_ASFLAGS += -DBIG_ENDIAN
> -ARCH_LDFLAGS = -EB -d
> -endif
> -
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/common.c
> --- a/extras/mini-os/arch/ia64/common.c       Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/common.c       Tue Nov 18 10:55:51 2008 +0100
> @@ -116,8 +116,8 @@ registerCallback(void)
>  {
>       struct callback_register event =
>       {
> -             .type = SWAP(CALLBACKTYPE_event),
> -             .address = SWAP((unsigned long)&hypervisor_callback),
> +             .type = CALLBACKTYPE_event,
> +             .address = (unsigned long)&hypervisor_callback,
>       };
>       HYPERVISOR_callback_op(CALLBACKOP_register, &event);
>  }
> @@ -126,46 +126,44 @@ init_start_info(start_info_t* xen_start_
>  init_start_info(start_info_t* xen_start_info)
>  {
>       /* Make a copy of the start_info structure */
> -     start_info.nr_pages = SWAP(xen_start_info->nr_pages);
> -     start_info.shared_info = SWAP(xen_start_info->shared_info);
> -     start_info.flags = SWAP(xen_start_info->flags);
> -     start_info.store_mfn = SWAP(xen_start_info->store_mfn);
> -     start_info.store_evtchn = SWAP(xen_start_info->store_evtchn);
> -     start_info.console.domU.mfn = SWAP(xen_start_info->console.domU.mfn);
> +     start_info.nr_pages = xen_start_info->nr_pages;
> +     start_info.shared_info = xen_start_info->shared_info;
> +     start_info.flags = xen_start_info->flags;
> +     start_info.store_mfn = xen_start_info->store_mfn;
> +     start_info.store_evtchn = xen_start_info->store_evtchn;
> +     start_info.console.domU.mfn = xen_start_info->console.domU.mfn;
>       start_info.console.domU.evtchn =
> -                             SWAP(xen_start_info->console.domU.evtchn);
> -     start_info.pt_base = SWAP(xen_start_info->pt_base);
> -     start_info.nr_pt_frames = SWAP(xen_start_info->nr_pt_frames);
> -     start_info.mfn_list = SWAP(xen_start_info->mfn_list);
> -     start_info.mod_start = SWAP(xen_start_info->mod_start);
> -     start_info.mod_len = SWAP(xen_start_info->mod_len);
> +                             xen_start_info->console.domU.evtchn;
> +     start_info.pt_base = xen_start_info->pt_base;
> +     start_info.nr_pt_frames = xen_start_info->nr_pt_frames;
> +     start_info.mfn_list = xen_start_info->mfn_list;
> +     start_info.mod_start = xen_start_info->mod_start;
> +     start_info.mod_len = xen_start_info->mod_len;
>  }
>  
>  static void
>  init_boot_params(void)
>  {
> -     ia64BootParamG.command_line = SWAP(ia64_boot_paramP->command_line);
> -     ia64BootParamG.efi_systab = SWAP(ia64_boot_paramP->efi_systab);
> -     ia64BootParamG.efi_memmap = SWAP(ia64_boot_paramP->efi_memmap);
> -     ia64BootParamG.efi_memmap_size =
> -                             SWAP(ia64_boot_paramP->efi_memmap_size);
> -     ia64BootParamG.efi_memdesc_size =
> -                             SWAP(ia64_boot_paramP->efi_memdesc_size);
> +     ia64BootParamG.command_line = ia64_boot_paramP->command_line;
> +     ia64BootParamG.efi_systab = ia64_boot_paramP->efi_systab;
> +     ia64BootParamG.efi_memmap = ia64_boot_paramP->efi_memmap;
> +     ia64BootParamG.efi_memmap_size = ia64_boot_paramP->efi_memmap_size;
> +     ia64BootParamG.efi_memdesc_size = ia64_boot_paramP->efi_memdesc_size;
>       ia64BootParamG.efi_memdesc_version =
> -                             SWAP(ia64_boot_paramP->efi_memdesc_version);
> +                             ia64_boot_paramP->efi_memdesc_version;
>       ia64BootParamG.console_info.num_cols =
> -                             SWAP(ia64_boot_paramP->console_info.num_cols);
> +                             ia64_boot_paramP->console_info.num_cols;
>       ia64BootParamG.console_info.num_rows =
> -                             SWAP(ia64_boot_paramP->console_info.num_rows);
> +                             ia64_boot_paramP->console_info.num_rows;
>       ia64BootParamG.console_info.orig_x =
> -                             SWAP(ia64_boot_paramP->console_info.orig_x);
> +                             ia64_boot_paramP->console_info.orig_x;
>       ia64BootParamG.console_info.orig_y =
> -                             SWAP(ia64_boot_paramP->console_info.orig_y);
> -     ia64BootParamG.fpswa = SWAP(ia64_boot_paramP->fpswa);
> -     ia64BootParamG.initrd_start = SWAP(ia64_boot_paramP->initrd_start);
> -     ia64BootParamG.initrd_size = SWAP(ia64_boot_paramP->initrd_size);
> -     ia64BootParamG.domain_start = SWAP(ia64_boot_paramP->domain_start);
> -     ia64BootParamG.domain_size = SWAP(ia64_boot_paramP->domain_size);
> +                             ia64_boot_paramP->console_info.orig_y;
> +     ia64BootParamG.fpswa = ia64_boot_paramP->fpswa;
> +     ia64BootParamG.initrd_start = ia64_boot_paramP->initrd_start;
> +     ia64BootParamG.initrd_size = ia64_boot_paramP->initrd_size;
> +     ia64BootParamG.domain_start = ia64_boot_paramP->domain_start;
> +     ia64BootParamG.domain_size = ia64_boot_paramP->domain_size;
>  
>       /*
>        * Copy and parse the boot command line.
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/debug.c
> --- a/extras/mini-os/arch/ia64/debug.c        Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/debug.c        Tue Nov 18 10:55:51 2008 +0100
> @@ -102,7 +102,6 @@ static const char *ia64_vector_names[] =
>  
>  typedef struct
>  {
> -#if !defined(BIG_ENDIAN)
>       uint64_t sof    :7;     /* 0-6 size of frame */
>       uint64_t sol    :7;     /* 7-13 size of locals (in + loc) */
>       uint64_t sor    :4;
> @@ -111,16 +110,6 @@ typedef struct
>       uint64_t rrb_pr :6;
>       uint64_t res    :25;    /* reserved */
>       uint64_t v      :1;     /* The v bit */
> -#else /* !BIG_ENDIAN */
> -     uint64_t v      :1;     /* The v bit */
> -     uint64_t res    :25;    /* reserved */
> -     uint64_t rrb_pr :6;
> -     uint64_t rrb_fr :7;
> -     uint64_t rrb_gr :7;
> -     uint64_t sor    :4;
> -     uint64_t sol    :7;     /* 7-13 size of locals (in + loc) */
> -     uint64_t sof    :7;     /* 0-6 size of frame */
> -#endif /* BIG_ENDIAN */
>  } ifs_t;
>  
>  void
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/efi.c
> --- a/extras/mini-os/arch/ia64/efi.c  Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/efi.c  Tue Nov 18 10:55:51 2008 +0100
> @@ -49,13 +49,6 @@ efi_get_time(efi_time_t* tmP)
>               printk("efi.getTime() failed\n");
>               return 0;
>       }
> -
> -#if defined(BIG_ENDIAN)
> -     tmP->Year = SWAP(tmP->Year);
> -     tmP->TimeZone = SWAP(tmP->TimeZone);
> -     tmP->Nanosecond = SWAP(tmP->Nanosecond);
> -#endif
> -
>       return 1;
>  }
>  
> @@ -65,17 +58,7 @@ static int
>  static int
>  efi_guid_cmp(efi_guid_t* a_le, efi_guid_t* b)
>  {
> -#if defined(BIG_ENDIAN)
> -     if(SWAP(a_le->Data1) != b->Data1)
> -             return 1;
> -     if(SWAP(a_le->Data2) != b->Data2)
> -             return 1;
> -     if(SWAP(a_le->Data3) != b->Data3)
> -             return 1;
> -     return memcmp(a_le->Data4, b->Data4, sizeof(uint8_t)*8);
> -#else
>       return memcmp(a_le, b, sizeof(efi_guid_t));
> -#endif
>  }
>  
>  void
> @@ -99,20 +82,20 @@ init_efi(void)
>       efiSysTableP = (efi_system_table_t*)__va(ia64BootParamG.efi_systab);
>       machineFwG.efi.efiSysTableP = efiSysTableP;
>       PRINT_BV("EfiSystemTable at: %p\n", efiSysTableP);
> -     fwP = (uint16_t*) __va(SWAP(efiSysTableP->FirmwareVendor));
> +     fwP = (uint16_t*) __va(efiSysTableP->FirmwareVendor);
>       if (fwP) {
>               for (i = 0; i < (int)sizeof(fwVendor) - 1 && *fwP; ++i)
> -                     fwVendor[i] = SWAP(*fwP++);
> +                     fwVendor[i] = *fwP++;
>               fwVendor[i] = '\0';
>       }
>       PRINT_BV("  EFI-FirmwareVendor        : %s\n", fwVendor);
>       PRINT_BV("  EFI-FirmwareRevision      : %d\n",
> -              SWAP(efiSysTableP->FirmwareRevision));
> +              efiSysTableP->FirmwareRevision);
>       PRINT_BV("  EFI-SystemTable-Revision  : %d.%d\n",
> -              SWAP(efiSysTableP->Hdr.Revision)>>16,
> -              SWAP(efiSysTableP->Hdr.Revision)&0xffff);
> +              efiSysTableP->Hdr.Revision >> 16,
> +              efiSysTableP->Hdr.Revision & 0xffff);
>       rsP = (efi_runtime_services_t*)
> -             __va(SWAP(efiSysTableP->RuntimeServices));
> +             __va(efiSysTableP->RuntimeServices);
>       mdcnt = ia64BootParamG.efi_memmap_size /
>               ia64BootParamG.efi_memdesc_size;
>       memdP = (efi_memory_descriptor_t*) __va(ia64BootParamG.efi_memmap);
> @@ -123,10 +106,10 @@ init_efi(void)
>            mdP = NextMemoryDescriptor(mdP, ia64BootParamG.efi_memdesc_size)) {
>               /* Relocate runtime memory segments for firmware. */
>               PRINT_BV("  %d. Type: %x  Attributes: 0x%lx\n",
> -                      i, SWAP(mdP->Type), SWAP(mdP->Attribute));
> +                      i, mdP->Type, mdP->Attribute);
>               PRINT_BV("     PhysStart: 0x%lx  NumPages: 0x%lx\n",
> -                      SWAP(mdP->PhysicalStart), SWAP(mdP->NumberOfPages));
> -             switch (SWAP(mdP->Type)) {
> +                      mdP->PhysicalStart, mdP->NumberOfPages);
> +             switch (mdP->Type) {
>                       case EfiRuntimeServicesData:
>                               PRINT_BV("     -> EfiRuntimeServicesData\n");
>                               break;
> @@ -139,18 +122,17 @@ init_efi(void)
>                       case EfiConventionalMemory:
>                               PRINT_BV("     -> EfiConventionalMemory\n");
>                               PRINT_BV("        start: 0x%lx end: 0x%lx\n",
> -                                     SWAP(mdP->PhysicalStart),
> -                                     SWAP(mdP->PhysicalStart)+
> -                                     SWAP(mdP->NumberOfPages)*EFI_PAGE_SIZE);
> +                                     mdP->PhysicalStart,
> +                                     mdP->PhysicalStart +
> +                                     mdP->NumberOfPages * EFI_PAGE_SIZE);
>                               if (numConvMem) {
>                                       printk("     Currently only one efi "
>                                               "memory chunk supported !!!\n");
>                                       break;
>                               }
> -                             machineFwG.mach_mem_start =
> -                                     SWAP(mdP->PhysicalStart);
> +                             machineFwG.mach_mem_start = mdP->PhysicalStart;
>                               machineFwG.mach_mem_size =
> -                                     SWAP(mdP->NumberOfPages)*EFI_PAGE_SIZE;
> +                                     mdP->NumberOfPages * EFI_PAGE_SIZE;
>                               numConvMem++;
>                               break;
>                       case EfiMemoryMappedIOPortSpace:
> @@ -158,7 +140,7 @@ init_efi(void)
>                               break;
>                       case EfiPalCode:
>                                       machineFwG.ia64_pal_base =
> -                                     __va(SWAP(mdP->PhysicalStart));
> +                                     __va(mdP->PhysicalStart);
>                               PRINT_BV("     -> EfiPalCode\n"
>                                        "        start : %p\n",
>                                        machineFwG.ia64_pal_base);
> @@ -170,12 +152,11 @@ init_efi(void)
>                * virtual addressing and the efi runtime functions
>                * may be called directly.
>                */
> -             if (SWAP(mdP->Attribute) & EFI_MEMORY_RUNTIME) {
> -                     if (SWAP(mdP->Attribute) & EFI_MEMORY_WB)
> -                             mdP->VirtualStart =
> -                                     SWAP(__va(mdP->PhysicalStart));
> +             if (mdP->Attribute & EFI_MEMORY_RUNTIME) {
> +                     if (mdP->Attribute & EFI_MEMORY_WB)
> +                             mdP->VirtualStart = __va(mdP->PhysicalStart);
>                       else {
> -                             if (SWAP(mdP->Attribute) & EFI_MEMORY_UC)
> +                             if (mdP->Attribute & EFI_MEMORY_UC)
>                                       printk("efi_init: RuntimeMemory with "
>                                               "UC attribute !!!!!!\n");
>                                       /*
> @@ -187,7 +168,7 @@ init_efi(void)
>       }
>       /* Now switch efi runtime stuff to virtual addressing. */
>       status = ia64_call_efi_physical(
> -                     (void*)__va(SWAP((uint64_t)rsP->SetVirtualAddressMap)),
> +                     (void*)__va((uint64_t)rsP->SetVirtualAddressMap),
>                       ia64BootParamG.efi_memmap_size,
>                       ia64BootParamG.efi_memdesc_size,
>                       ia64BootParamG.efi_memdesc_version,
> @@ -200,35 +181,35 @@ init_efi(void)
>       }
>       /* Getting efi function pointer for getEfiTime. */
>       machineFwG.efi.getTimeF =
> -             (efi_get_time_t)__va(SWAP((uint64_t)rsP->GetTime));
> +             (efi_get_time_t)__va((uint64_t)rsP->GetTime);
>       /* Getting efi function pointer for resetSystem. */
>       machineFwG.efi.resetSystemF =
> -             (efi_reset_system_t)__va(SWAP((uint64_t)rsP->ResetSystem));
> +             (efi_reset_system_t)__va((uint64_t)rsP->ResetSystem);
>  
>       /* Scanning the Configuration table of the EfiSystemTable. */
>       PRINT_BV("NumberOfConfigTableEntries: %ld\n",
> -              SWAP(efiSysTableP->NumberOfTableEntries));
> +              efiSysTableP->NumberOfTableEntries);
>  
>       confP = (efi_configuration_table_t*)
> -                     __va(SWAP(efiSysTableP->ConfigurationTable));
> -     for (i = 0; i < SWAP(efiSysTableP->NumberOfTableEntries); i++) {
> +                     __va(efiSysTableP->ConfigurationTable);
> +     for (i = 0; i < efiSysTableP->NumberOfTableEntries; i++) {
>               if (!efi_guid_cmp(&confP[i].VendorGuid, &sal)) {
>                       machineFwG.ia64_sal_tableP = (sal_system_table_t*)
> -                             __va(SWAP((uint64_t) confP[i].VendorTable));
> +                             __va((uint64_t) confP[i].VendorTable);
>                       PRINT_BV("  Found SalSystemTable at: 0x%lx\n",
>                                (uint64_t) machineFwG.ia64_sal_tableP);
>                       continue;
>               }
>               if (!efi_guid_cmp(&confP[i].VendorGuid, &acpi)) {
>                       machineFwG.ia64_efi_acpi_table =
> -                             __va(SWAP((uint64_t) confP[i].VendorTable));
> +                             __va((uint64_t) confP[i].VendorTable);
>                       PRINT_BV("  Found AcpiTable at:      0x%lx\n",
>                                (uint64_t) machineFwG.ia64_efi_acpi_table);
>                       continue;
>               }
>               if (!efi_guid_cmp(&confP[i].VendorGuid, &acpi20)) {
>                       machineFwG.ia64_efi_acpi20_table =
> -                             __va(SWAP((uint64_t) confP[i].VendorTable));
> +                             __va((uint64_t) confP[i].VendorTable);
>                       PRINT_BV("  Found Acpi20Table at:    0x%lx\n",
>                                (uint64_t) machineFwG.ia64_efi_acpi20_table);
>                       continue;
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/fw.S
> --- a/extras/mini-os/arch/ia64/fw.S   Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/fw.S   Tue Nov 18 10:55:51 2008 +0100
> @@ -155,11 +155,6 @@ ENTRY(ia64_call_efi_physical)
>       ld8     r14=[in0],8             // function address
>       ;;
>       ld8     gp=[in0]                // function gp value
> -#if defined(BIG_ENDIAN)
> -     mux1    r14=r14,@rev            // swap because mini-os is in BE
> -     mov     ar.rsc=3
> -     ;;
> -#endif
>       mov     out0=in1
>       mov     out1=in2
>       mov     out2=in3
> @@ -167,19 +162,7 @@ ENTRY(ia64_call_efi_physical)
>       mov     out4=in5
>       mov     b6=r14
>       ;;
> -#if defined(BIG_ENDIAN)
> -     mux1    gp=gp,@rev              // swap because mini-os is in BE
> -     rum IA64_PSR_BE
> -     ;;
> -#endif
> -
>       br.call.sptk.many rp=b6         // call EFI procedure
> -
> -#if defined(BIG_ENDIAN)
> -     ;;
> -     sum IA64_PSR_BE
> -     mov     ar.rsc=IA64_RSE_EAGER
> -#endif
>       mov     gp=loc3                 // restore kernel gp
>       mov     r14=loc2                // psr to restore mode
>       ;;
> @@ -227,16 +210,8 @@ 1:       mov     palret=ip               // for return 
> address
>       mov     b0=palret
>       rsm     psr.i                   // disable interrupts
>       ;;
> -#if defined(BIG_ENDIAN)
> -     rum     IA64_PSR_BE             // set psr.be==0
> -     ;;
> -#endif
>       br.cond.sptk b6                 // call into firmware
>       ;;
> -#if defined(BIG_ENDIAN)
> -     sum     IA64_PSR_BE             // set psr.be==1
> -     ;;
> -#endif
>       ssm     psr.i                   // enable interrupts
>       ;;
>  2:   mov     psr.l=psrsave
> @@ -271,24 +246,8 @@ ENTRY(ia64_call_efi_func)
>       ;;
>       ld8     gp=[in0]                // function gp value
>       ;;
> -#if defined(BIG_ENDIAN)
> -     mux1    r14=r14,@rev            // swap if mini-os is in BE
> -     mux1    gp=gp,@rev              // swap if mini-os is in BE
> -#endif
> -     ;;
>       mov     b6=r14
> -
> -#if defined(BIG_ENDIAN)
> -     rum     IA64_PSR_BE
> -     ;;
> -#endif
> -
>       br.call.sptk.many rp=b6         // call EFI procedure
> -     
> -#if defined(BIG_ENDIAN)
> -     sum     IA64_PSR_BE
> -     ;;
> -#endif
>       
>       mov     ar.pfs=loc0
>       mov     gp=loc1
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/ia64.S
> --- a/extras/mini-os/arch/ia64/ia64.S Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/ia64.S Tue Nov 18 10:55:51 2008 +0100
> @@ -205,10 +205,6 @@ 1:       /* now we are in virtual mode */
>       START_INFO_PFN_ld       r14=[r15]       // load the start_info_pfn
>       add     r16=7, r0
>       ;;
> -#if defined(BIG_ENDIAN)
> -     mux1    r14=r14,@rev            // swap because mini-os is in BE
> -#endif
> -     ;;
>       shl     r15=r14,PAGE_SHIFT_XEN_16K      // pfn << PAGE_SHIFT_XEN_16K
>       shl     r16=r16,IA64_RR_IDX_POS         // (7<<IA64_RR_IDX_POS)
>       ;;
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/ivt.S
> --- a/extras/mini-os/arch/ia64/ivt.S  Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/ivt.S  Tue Nov 18 10:55:51 2008 +0100
> @@ -87,11 +87,6 @@ ENTRY(save_tf_rse_switch)
>       ;;
>       ld8     r21=[r21]               // XEN.ipsr
>       ld8     r22=[r22];;             // XEN.iip
> -#if defined(BIG_ENDIAN)
> -     mux1    r21=r21,@rev            // swap because mini-os is in BE
> -     mux1    r22=r22,@rev            // swap because mini-os is in BE
> -     ;;
> -#endif
>       add     r19=TF_IPSR,r18
>       add     r20=TF_IIP,r18
>       ;;
> @@ -129,10 +124,6 @@ ENTRY(save_tf_rse_switch)
>       //bsw.1         // switch to bank 1 for saving these registers.
>       movl r30=XSI_BANKNUM            // Switch to bank 1.
>       mov r31=1;;
> -#if defined(BIG_ENDIAN)
> -     mux1    r31=r31,@rev            // swap because mini-os is in BE
> -     ;;
> -#endif
>       st4 [r30]=r31
>       ;;
>       /*
> @@ -143,38 +134,13 @@ ENTRY(save_tf_rse_switch)
>       movl r30=XSI_BANK1_R16;
>       movl r31=XSI_BANK1_R16+8;; 
>       ld8 r16=[r30],16; ld8 r17=[r31],16;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r16=r16,@rev; mux1 r17=r17,@rev;;
> -#endif
>       ld8 r18=[r30],16; ld8 r19=[r31],16;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r18=r18,@rev; mux1 r19=r19,@rev;;
> -#endif
>       ld8 r20=[r30],16; ld8 r21=[r31],16;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r20=r20,@rev; mux1 r21=r21,@rev;;
> -#endif
>       ld8 r22=[r30],16; ld8 r23=[r31],16;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r22=r22,@rev; mux1 r23=r23,@rev;;
> -#endif
>       ld8 r24=[r30],16; ld8 r25=[r31],16;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r24=r24,@rev; mux1 r25=r25,@rev;;
> -#endif
>       ld8 r26=[r30],16; ld8 r27=[r31],16;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r26=r26,@rev; mux1 r27=r27,@rev;;
> -#endif
>       ld8 r28=[r30],16; ld8 r29=[r31],16;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r28=r28,@rev; mux1 r29=r29,@rev;;
> -#endif
>       ld8 r30=[r30]; ld8 r31=[r31];;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r30=r30,@rev; mux1 r31=r31,@rev;;
> -#endif
> -
>       add     r2=TF_GREG16,r14
>       add     r3=TF_GREG17,r14
>       ;;
> @@ -251,10 +217,6 @@ ENTRY(save_tf_rse_switch)
>       ;;
>       ld8     r21=[r8]
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r21=r21,@rev
> -     ;;
> -#endif
>       st8     [r19]=r21               // store cr.ifs
>       dep.z   r22=r21,0,38            // copy ifm part from ifs.ifm
>       ;;
> @@ -330,12 +292,6 @@ ENTRY(restore_tf_rse_switch)
>       ;;
>       ld8     r21=[r19]               // load cr.ipsr
>       ld8     r22=[r20]               // load cr.iip
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     ;;
> -     mux1    r21=r21,@rev
> -     mux1    r22=r22,@rev
> -     ;;
> -#endif
>       movl    r16=XSI_IPSR            // XEN !!
>       ;;
>       st8     [r16]=r21,XSI_IIP_OFS-XSI_IPSR_OFS      // XEN.ipsr
> @@ -353,9 +309,6 @@ ENTRY(restore_tf_rse_switch)
>       ld8     r22=[r19]               // ndirty
>       ;;
>       shl     r21=r22,16              // value for ar.rsc
> -     //mov   r19=(MOS_IA64_RSC_BE << IA64_RSC_BE)
> -     ;;
> -     or      r21=(MOS_IA64_RSC_BE << IA64_RSC_BE),r21
>       ;;
>       mov     ar.rsc=r21              // setup for loadrs
>       ;;
> @@ -386,10 +339,6 @@ ENTRY(restore_tf_rse_switch)
>       ld8     r21=[r19]               // load ar.pfs
>       ld8     r22=[r20]               // load cr.ifs
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r22=r22,@rev
> -     ;;
> -#endif
>       add     r19=TF_RSC,r18
>       mov     ar.pfs=r21
>       st8     [r16]=r22               // XEN.ifs
> @@ -429,10 +378,6 @@ ENTRY(restore_tf_rse_switch)
>       // bsw.1
>       movl r30=XSI_BANKNUM            // Switch to bank 1.
>       mov r31=1;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r31=r31,@rev
> -     ;;
> -#endif
>       st4 [r30]=r31
>       ;;
>       add     r2=TF_GREG16,r14
> @@ -455,51 +400,27 @@ ENTRY(restore_tf_rse_switch)
>       movl r2=XSI_BANK1_R16
>       movl r3=XSI_BANK1_R16+8
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r16=r16,@rev; mux1 r17=r17,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r16,16
>       .mem.offset 8,0; st8.spill [r3]=r17,16
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r18=r18,@rev; mux1 r19=r19,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r18,16
>       .mem.offset 8,0; st8.spill [r3]=r19,16
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r20=r20,@rev; mux1 r21=r21,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r20,16
>       .mem.offset 8,0; st8.spill [r3]=r21,16
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r22=r22,@rev; mux1 r23=r23,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r22,16
>       .mem.offset 8,0; st8.spill [r3]=r23,16
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r24=r24,@rev; mux1 r25=r25,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r24,16
>       .mem.offset 8,0; st8.spill [r3]=r25,16
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r26=r26,@rev; mux1 r27=r27,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r26,16
>       .mem.offset 8,0; st8.spill [r3]=r27,16
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r28=r28,@rev; mux1 r29=r29,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r28,16
>       .mem.offset 8,0; st8.spill [r3]=r29,16
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r30=r30,@rev; mux1 r31=r31,@rev;;
> -#endif
>       .mem.offset 0,0; st8.spill [r2]=r30,16
>       .mem.offset 8,0; st8.spill [r3]=r31,16
>       ;;
> @@ -567,17 +488,11 @@ ENTRY(save_special_regs)
>       add     loc5=TF_IFA,in0
>       add     loc6=TF_ISR,in0
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    loc3=loc3,@rev; mux1 loc4=loc4,@rev;;
> -#endif
>       st8     [loc5]=loc3,TF_IIM-TF_IFA       // store cr.ifa
>       st8     [loc6]=loc4                     // store cr.isr
>       ;;
>       ld8     loc3=[loc1]                     // load XEN.iim
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    loc3=loc3,@rev;;
> -#endif
>       st8     [loc5]=loc3                     // store cr.iim
>       ;;
>       mov     ar.pfs=loc0
> @@ -605,9 +520,6 @@ ENTRY(hypervisor_callback)
>       mov     out0=r18                // the trap frame
>       movl    r22=XSI_PSR_IC
>       mov     r23=1;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r23=r23,@rev;;
> -#endif
>       st8     [r22]=r23               // ssm psr.ic
>       ;;
>       br.call.sptk.few rp = do_hypervisor_callback
> @@ -649,9 +561,6 @@ ENTRY(trap_error)
>       ;;
>       movl r30=XSI_BANKNUM            // bsw.1
>       mov r31=1;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r31=r31,@rev;;
> -#endif
>       st4 [r30]=r31;;
>  
>               /* Save extra interrupt registers to the trap frame. */
> @@ -664,9 +573,6 @@ ENTRY(trap_error)
>       ld8     r23=[r23]
>       mov     r25=1
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r25=r25,@rev; mux1 r23=r23,@rev;;
> -#endif
>       st4     [r22]=r25               // ssm psr.ic
>       st1     [r23]=r0                // ssm psr.i
>       ;;
> @@ -680,10 +586,6 @@ ENTRY(trap_error)
>       ld8 r23=[r23]
>       mov r25=1
>       ;;
> -#if defined(BIG_ENDIAN)                      // swap because mini-os is in BE
> -     mux1    r25=r25,@rev;;
> -     mux1    r25=r25,@rev; mux1 r23=r23,@rev;;
> -#endif
>       st1 [r23]=r25
>       st4 [r22]=r0            // note: clears both vpsr.i and vpsr.ic!
>       ;;
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/mm.c
> --- a/extras/mini-os/arch/ia64/mm.c   Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/mm.c   Tue Nov 18 10:55:51 2008 +0100
> @@ -153,7 +153,7 @@ map_frames_ex(unsigned long* frames, uns
>          ASSERT(n == 1 || (stride == 0 && increment == 1));
>          ASSERT(id == DOMID_SELF);
>          ASSERT(prot == 0);
> -     return (void*) __va(SWAP(frames[0]) << PAGE_SHIFT);
> +     return (void*) __va(frames[0] << PAGE_SHIFT);
>  }
>  
>  void arch_init_p2m(unsigned long max_pfn)
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/sal.c
> --- a/extras/mini-os/arch/ia64/sal.c  Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/sal.c  Tue Nov 18 10:55:51 2008 +0100
> @@ -76,19 +76,19 @@ ia64_sal_init(struct sal_system_table *s
>               return;
>       }
>       p = (uint8_t *) (saltab + 1);
> -     for (i = 0; i < SWAP(saltab->sal_entry_count); i++) {
> -             switch (SWAP(*p)) {
> +     for (i = 0; i < saltab->sal_entry_count; i++) {
> +             switch (*p) {
>               case SAL_DESC_ENTRYPOINT:               // 0
>               {
>                       struct sal_entrypoint_descriptor *dp;
>  
>                       dp = (struct sal_entrypoint_descriptor*)p;
>                       ia64_pal_entry =
> -                             IA64_PHYS_TO_RR7(SWAP(dp->sale_pal_proc));
> +                             IA64_PHYS_TO_RR7(dp->sale_pal_proc);
>                       PRINT_BV("  PAL Proc at 0x%lx\n", ia64_pal_entry);
>                       sal_fdesc.func =
> -                             IA64_PHYS_TO_RR7(SWAP(dp->sale_sal_proc));
> -                     sal_fdesc.gp = IA64_PHYS_TO_RR7(SWAP(dp->sale_sal_gp));
> +                             IA64_PHYS_TO_RR7(dp->sale_sal_proc);
> +                     sal_fdesc.gp = IA64_PHYS_TO_RR7(dp->sale_sal_gp);
>                       PRINT_BV("  SAL Proc at 0x%lx, GP at 0x%lx\n",
>                                sal_fdesc.func, sal_fdesc.gp);
>                       ia64_sal_entry = (sal_entry_t *) &sal_fdesc;
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/time.c
> --- a/extras/mini-os/arch/ia64/time.c Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/time.c Tue Nov 18 10:55:51 2008 +0100
> @@ -197,15 +197,6 @@ calculate_frequencies(void)
>       struct ia64_pal_result pal_res;
>  
>       pal_res = ia64_call_pal_static(PAL_FREQ_RATIOS, 0, 0, 0);
> -     //sal_res = ia64_sal_call(SAL_FREQ_BASE, 0, 0, 0, 0, 0, 0, 0);
> -#if defined(BIG_ENDIAN)
> -//#warning calculate_frequencies TODO
> -     /*
> -      * I have to do an own function with switching psr.be!
> -      * Currently it's running because it's a break into the hypervisor
> -      * behind the call.!
> -      */
> -#endif
>       sal_res = ia64_sal_entry(SAL_FREQ_BASE, 0, 0, 0, 0, 0, 0, 0);
>  
>       if (sal_res.sal_status == 0 && pal_res.pal_status == 0) {
> @@ -260,9 +251,8 @@ init_time(void)
>       if (efi_get_time(&tm)) {
>               printk("  EFI-Time: %d.%d.%d   %d:%d:%d\n", tm.Day,
>                      tm.Month, tm.Year, tm.Hour, tm.Minute, tm.Second);
> -             os_time.tv_sec = _mktime(SWAP(tm.Year), SWAP(tm.Month),
> -                                     SWAP(tm.Day), SWAP(tm.Hour),
> -                                     SWAP(tm.Minute), SWAP(tm.Second));
> +             os_time.tv_sec = _mktime(tm.Year, tm.Month,
> +                                     tm.Day, tm.Hour, tm.Minute, tm.Second);
>               os_time.tv_nsec = tm.Nanosecond;
>       } else
>               printk("efi_get_time() failed\n");
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/arch/ia64/xencomm.c
> --- a/extras/mini-os/arch/ia64/xencomm.c      Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/arch/ia64/xencomm.c      Tue Nov 18 10:55:51 2008 +0100
> @@ -95,7 +95,7 @@ xencomm_init_desc(struct xencomm_desc *d
>                       return -EINVAL;
>               }
>  
> -             desc->address[i++] = SWAP(paddr);
> +             desc->address[i++] = paddr;
>               recorded += chunksz;
>       }
>       if (recorded < bytes) {
> @@ -106,8 +106,8 @@ xencomm_init_desc(struct xencomm_desc *d
>  
>       /* mark remaining addresses invalid (just for safety) */
>       while (i < desc->nr_addrs)
> -             desc->address[i++] = SWAP(XENCOMM_INVALID);
> -     desc->magic = SWAP(XENCOMM_MAGIC);
> +             desc->address[i++] = XENCOMM_INVALID;
> +     desc->magic = XENCOMM_MAGIC;
>       return 0;
>  }
>  
> @@ -184,15 +184,14 @@ xencommize_mini_grant_table_op(struct xe
>                       return -EINVAL;
>               rc = xencomm_create_mini
>                       (xc_area, nbr_area,
> -                      (void*)SWAP((uint64_t)
> -                                  xen_guest_handle(setup->frame_list)),
> -                      SWAP(setup->nr_frames)
> +                      (void*)(uint64_t) xen_guest_handle(setup->frame_list),
> +                      setup->nr_frames
>                        * sizeof(*xen_guest_handle(setup->frame_list)),
>                        &desc1);
>               if (rc)
>                       return rc;
>               set_xen_guest_handle(setup->frame_list,
> -                                  (void *)SWAP((uint64_t)desc1));
> +                                  (void *)(uint64_t)desc1);
>               break;
>       }
>       case GNTTABOP_dump_table:
> @@ -284,7 +283,7 @@ HYPERVISOR_suspend(unsigned long srec)
>  {
>          struct sched_shutdown arg;
>  
> -        arg.reason = (uint32_t)SWAP((uint32_t)SHUTDOWN_suspend);
> +        arg.reason = (uint32_t)SHUTDOWN_suspend;
>  
>          return xencomm_arch_hypercall_suspend(xencomm_create_inline(&arg));
>  }
> @@ -300,7 +299,7 @@ HYPERVISOR_event_channel_op(int cmd, voi
>       if (unlikely(rc == -ENOSYS)) {
>               struct evtchn_op op;
>  
> -             op.cmd = SWAP(cmd);
> +             op.cmd = cmd;
>               memcpy(&op.u, arg, sizeof(op.u));
>               rc = _hypercall1(int, event_channel_op_compat, &op);
>       }
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/include/ia64/atomic.h
> --- a/extras/mini-os/include/ia64/atomic.h    Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/include/ia64/atomic.h    Tue Nov 18 10:55:51 2008 +0100
> @@ -427,11 +427,10 @@ static inline void
>  static inline void
>  set_bit(int num, volatile void *addr)
>  {
> -     uint32_t bit, b, old, new;
> +     uint32_t bit, old, new;
>       volatile uint32_t *p;
>       p = (volatile uint32_t *) addr + (num >> 5);
> -     b = 1 << (num & 31);
> -     bit = SWAP(b);
> +     bit = 1 << (num & 31);
>       do
>       {
>               old = *p;
> @@ -442,11 +441,10 @@ static __inline__ void
>  static __inline__ void
>  clear_bit(int num, volatile void *addr)
>  {
> -     uint32_t mask, m,  old, new;
> +     uint32_t mask, old, new;
>       volatile uint32_t *p;
>       p = (volatile uint32_t *) addr + (num >> 5);
> -     m = ~(1 << (num & 31));
> -     mask = SWAP(m);
> +     mask = ~(1 << (num & 31));
>       do {
>               old = *p;
>               new = old & mask;
> @@ -456,7 +454,7 @@ static __inline__ int
>  static __inline__ int
>  test_bit(int num, const volatile void *addr)
>  {
> -     uint32_t val = SWAP(1);
> +     uint32_t val = 1;
>          return val & (((const volatile uint32_t *) addr)[num >> 5] >> (num & 
> 31));
>  }
>  
> @@ -468,12 +466,11 @@ static inline int
>  static inline int
>  test_and_set_bit (int num, volatile void *addr)
>  {
> -        uint32_t bit, b, old, new;
> +        uint32_t bit, old, new;
>          volatile uint32_t *m;
>  
>          m = (volatile uint32_t *) addr + (num >> 5);
> -        b = 1 << (num & 31);
> -        bit = SWAP(b);
> +        bit = 1 << (num & 31);
>          do {
>                  old = *m;
>                  new = old | bit;
> @@ -489,12 +486,11 @@ static
>  static
>  inline int test_and_clear_bit(int num, volatile unsigned long * addr)
>  {
> -        uint32_t bit, b, old, new;
> +        uint32_t bit, old, new;
>          volatile uint32_t* a;
>  
>          a = (volatile uint32_t *) addr + (num >> 5);
> -        b = ~(1 << (num & 31));
> -        bit = SWAP(b);
> +        bit = ~(1 << (num & 31));
>          do {
>                  old = *a;
>                  new = old & bit;
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/include/ia64/ia64_cpu.h
> --- a/extras/mini-os/include/ia64/ia64_cpu.h  Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/include/ia64/ia64_cpu.h  Tue Nov 18 10:55:51 2008 +0100
> @@ -134,23 +134,16 @@
>  #define IA64_PSR_IA          0x0000200000000000
>  
>  
> -/* Endianess of mini-os. */
> -#if defined(BIG_ENDIAN)
> -#define MOS_IA64_PSR_BE      IA64_PSR_BE
> -#else
> -#define MOS_IA64_PSR_BE      0
> -#endif
> -
>  #define STARTUP_PSR (IA64_PSR_IT | IA64_PSR_PK | \
> -                  IA64_PSR_DT | IA64_PSR_RT | MOS_IA64_PSR_BE | \
> +                  IA64_PSR_DT | IA64_PSR_RT | \
>                    IA64_PSR_BN | IA64_PSR_CPL_KERN | IA64_PSR_AC)
>  
>  #define MOS_SYS_PSR (IA64_PSR_IC | IA64_PSR_I | IA64_PSR_IT | \
> -                  IA64_PSR_DT | IA64_PSR_RT | MOS_IA64_PSR_BE | \
> +                  IA64_PSR_DT | IA64_PSR_RT | \
>                    IA64_PSR_BN | IA64_PSR_CPL_KERN | IA64_PSR_AC)
>  
>  #define MOS_USR_PSR (IA64_PSR_IC | IA64_PSR_I | IA64_PSR_IT | \
> -                  IA64_PSR_DT | IA64_PSR_RT | MOS_IA64_PSR_BE | \
> +                  IA64_PSR_DT | IA64_PSR_RT | \
>                    IA64_PSR_BN | IA64_PSR_CPL_USER | IA64_PSR_AC)
>  
>  /*
> @@ -193,14 +186,7 @@
>  #define IA64_DCR_MBZ1_V              0xffffffffffffULL
>  
>  
> -     /* Endianess of DCR register. */
> -#if defined(BIG_ENDIAN)
> -#define MOS_IA64_DCR_BE      (1 << IA64_DCR_BE)
> -#else
> -#define MOS_IA64_DCR_BE      (0 << IA64_DCR_BE)
> -#endif
> -
> -#define IA64_DCR_DEFAULT (MOS_IA64_DCR_BE)
> +#define IA64_DCR_DEFAULT (IA64_DCR_BE)
>  
>  /*
>   * Vector numbers for various ia64 interrupts.
> @@ -262,18 +248,8 @@
>  #define IA64_RSC_MODE_LI (0x2)               /* Load intensive */
>  #define IA64_RSC_MODE_EA (0x3)               /* Eager */
>  
> -/* RSE endian mode. */
> -#if defined(BIG_ENDIAN)
> -#define MOS_IA64_RSC_BE      1               /* Big endian rse. */
> -#else
> -#define MOS_IA64_RSC_BE      0               /* Little endian rse. */
> -#endif
> -
> -#define IA64_RSE_EAGER ((IA64_RSC_MODE_EA<<IA64_RSC_MODE) |  \
> -                        (MOS_IA64_RSC_BE << IA64_RSC_BE)     )
> -
> -#define IA64_RSE_LAZY ((IA64_RSC_MODE_LY<<IA64_RSC_MODE) |   \
> -                        (MOS_IA64_RSC_BE << IA64_RSC_BE)     )
> +#define IA64_RSE_EAGER (IA64_RSC_MODE_EA<<IA64_RSC_MODE)
> +#define IA64_RSE_LAZY (IA64_RSC_MODE_LY<<IA64_RSC_MODE)
>  
>  
>  
> @@ -719,19 +695,6 @@ typedef struct trap_frame trap_frame_t;
>   */
>  typedef struct
>  {
> -#if defined(BIG_ENDIAN)
> -     uint64_t pte_ig :11;    /* bits 53..63 */
> -     uint64_t pte_ed :1;     /* bits 52..52 */
> -     uint64_t pte_rv2:2;     /* bits 50..51 */
> -     uint64_t pte_ppn:38;    /* bits 12..49 */
> -     uint64_t pte_ar :3;     /* bits 9..11 */
> -     uint64_t pte_pl :2;     /* bits 7..8 */
> -     uint64_t pte_d  :1;     /* bits 6..6 */
> -     uint64_t pte_a  :1;     /* bits 5..5 */
> -     uint64_t pte_ma :3;     /* bits 2..4 */
> -     uint64_t pte_rv1:1;     /* bits 1..1 */
> -     uint64_t pte_p  :1;     /* bits 0..0 */
> -#else
>       uint64_t pte_p  :1;     /* bits 0..0 */
>       uint64_t pte_rv1:1;     /* bits 1..1 */
>       uint64_t pte_ma :3;     /* bits 2..4 */
> @@ -743,7 +706,6 @@ typedef struct
>       uint64_t pte_rv2:2;     /* bits 50..51 */
>       uint64_t pte_ed :1;     /* bits 52..52 */
>       uint64_t pte_ig :11;    /* bits 53..63 */
> -#endif
>  } ia64_pte_t;
>  
>  
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/include/ia64/os.h
> --- a/extras/mini-os/include/ia64/os.h        Mon Nov 17 09:27:02 2008 +0100
> +++ b/extras/mini-os/include/ia64/os.h        Tue Nov 18 10:55:51 2008 +0100
> @@ -28,7 +28,6 @@
>  #if !defined(__ASSEMBLY__)
>  
>  #include <mini-os/types.h>
> -#include "endian.h"
>  #include "ia64_cpu.h"
>  #include "atomic.h"
>  #include "efi.h"
> @@ -210,7 +209,7 @@ do {                                                      
>                 \
>  do {                                                                 \
>       vcpu_info_t *_vcpu;                                             \
>       _vcpu = &HYPERVISOR_shared_info->vcpu_info[smp_processor_id()]; \
> -     _vcpu->evtchn_upcall_mask = SWAP(1);                            \
> +     _vcpu->evtchn_upcall_mask = 1;                                  \
>       barrier();                                                      \
>  } while (0)
>  
> @@ -221,7 +220,7 @@ do {                                                      
>                 \
>       _vcpu = &HYPERVISOR_shared_info->vcpu_info[smp_processor_id()]; \
>       _vcpu->evtchn_upcall_mask = 0;                                  \
>       barrier(); /* unmask then check (avoid races) */                \
> -     if (unlikely(SWAP(_vcpu->evtchn_upcall_pending)))               \
> +     if (unlikely(_vcpu->evtchn_upcall_pending))                     \
>               force_evtchn_callback();                                \
>  } while (0)
>  
> @@ -229,7 +228,7 @@ do {                                                      
>                 \
>  do {                                                                 \
>       vcpu_info_t *_vcpu;                                             \
>       _vcpu = &HYPERVISOR_shared_info->vcpu_info[smp_processor_id()]; \
> -     (x) = SWAP(_vcpu->evtchn_upcall_mask);                          \
> +     (x) = _vcpu->evtchn_upcall_mask;                                \
>  } while (0)
>  
>  #define __restore_flags(x)                                           \
> @@ -239,7 +238,7 @@ do {                                                      
>                 \
>       _vcpu = &HYPERVISOR_shared_info->vcpu_info[smp_processor_id()]; \
>       if ((_vcpu->evtchn_upcall_mask = (x)) == 0) {                   \
>               barrier(); /* unmask then check (avoid races) */        \
> -             if ( unlikely(SWAP(_vcpu->evtchn_upcall_pending)) )     \
> +             if ( unlikely(_vcpu->evtchn_upcall_pending) )           \
>                       force_evtchn_callback();                        \
>       }\
>  } while (0)
> @@ -250,8 +249,8 @@ do {                                                      
>                 \
>  do {                                                                 \
>       vcpu_info_t *_vcpu;                                             \
>       _vcpu = &HYPERVISOR_shared_info->vcpu_info[smp_processor_id()]; \
> -     (x) = SWAP(_vcpu->evtchn_upcall_mask);                          \
> -     _vcpu->evtchn_upcall_mask = SWAP(1);                            \
> +     (x) = _vcpu->evtchn_upcall_mask;                                \
> +     _vcpu->evtchn_upcall_mask = 1;                                  \
>       barrier();                                                      \
>  } while (0)
>  
> @@ -262,7 +261,7 @@ do {                                                      
>                 \
>  #define local_irq_enable()   __sti()
>  
>  #define irqs_disabled()                      \
> -     
> SWAP(HYPERVISOR_shared_info->vcpu_info[smp_processor_id()].evtchn_upcall_mask)
> +     
> (HYPERVISOR_shared_info->vcpu_info[smp_processor_id()].evtchn_upcall_mask)
>  
>  /* This is a barrier for the compiler only, NOT the processor! */
>  #define barrier() __asm__ __volatile__("": : :"memory")
> diff -r cf3b9afb8568 -r 56ecdf7c49e7 extras/mini-os/include/ia64/endian.h
> --- a/extras/mini-os/include/ia64/endian.h    Mon Nov 17 09:27:02 2008 +0100
> +++ /dev/null Thu Jan 01 00:00:00 1970 +0000
> @@ -1,75 +0,0 @@
> -/*
> - * Done by Dietmar Hahn <dietmar.hahn@xxxxxxxxxxxxxxxxxxx>
> - * Parts are taken from FreeBSD.
> - *
> - ****************************************************************************
> - * Permission is hereby granted, free of charge, to any person obtaining a 
> copy
> - * of this software and associated documentation files (the "Software"), to
> - * deal in the Software without restriction, including without limitation the
> - * rights to use, copy, modify, merge, publish, distribute, sublicense, 
> and/or
> - * sell copies of the Software, and to permit persons to whom the Software is
> - * furnished to do so, subject to the following conditions:
> - * 
> - * The above copyright notice and this permission notice shall be included in
> - * all copies or substantial portions of the Software.
> - * 
> - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 
> OR 
> - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 
> - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 
> THE 
> - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 
> - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 
> - * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 
> - * DEALINGS IN THE SOFTWARE.
> - */
> -
> -
> -#if !defined(_ENDIAN_H_)
> -#define _ENDIAN_H_
> -
> -#include <mini-os/types.h>
> -
> -
> -#if !defined(__ASSEMBLY__)
> -
> -#if defined(BIG_ENDIAN)
> -
> -static __inline uint64_t
> -__bswap64(uint64_t __x)
> -{
> -     uint64_t __r;
> -     asm __volatile("mux1 %0=%1,@rev" : "=r" (__r) : "r"(__x));
> -     return __r;
> -}
> -
> -static __inline uint32_t
> -__bswap32(uint32_t __x)
> -{
> -     return (__bswap64(__x) >> 32);
> -}
> -
> -static __inline uint16_t
> -__bswap16(uint16_t __x)
> -{
> -     return (__bswap64(__x) >> 48);
> -}
> -
> -#define doswap(x,sz)  ( \
> -     ((sz)==1)? (uint8_t)(x): \
> -     ((sz)==2)? __bswap16(x): \
> -     ((sz)==4)? __bswap32(x): \
> -     ((sz)==8)? __bswap64(x): \
> -     ~0l )
> -
> -#define SWAP(x)      doswap((x), sizeof((x)))
> -
> -
> -#else /* defined(BIG_ENDIAN) */
> -
> -#define SWAP(x) (x)
> -
> -#endif /* defined(BIG_ENDIAN) */
> -
> -#endif /* !defined(__ASSEMBLY__) */
> -
> -
> -#endif /* !defined(_ENDIAN_H_) */

> _______________________________________________
> Xen-ia64-devel mailing list
> Xen-ia64-devel@xxxxxxxxxxxxxxxxxxx
> http://lists.xensource.com/xen-ia64-devel

-- 
yamahata

_______________________________________________
Xen-ia64-devel mailing list
Xen-ia64-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-ia64-devel


 


Rackspace

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