We can use armxx as an infix for names that are for both arm and aarch64

On Thu, Aug 3, 2017, 18:44 Vladimir 'phcoder' Serbinenko <phco...@gmail.com>
wrote:

>
>
> On Thu, Aug 3, 2017, 12:14 Leif Lindholm <leif.lindh...@linaro.org> wrote:
>
>> In preparation for using the linux loader for 32-bit and 64-bit
>> platforms, rename
>> grub_arm64*/GRUB_ARM64* to grub_efi*/GRUB_EFI*.
>>
>> Move prototypes for now-common functions to efi/efi.h.
>>
>> Signed-off-by: Leif Lindholm <leif.lindh...@linaro.org>
>> ---
>>  grub-core/loader/arm64/linux.c    | 14 +++++++-------
>>  grub-core/loader/arm64/xen_boot.c | 12 ++++++------
>>  include/grub/arm64/linux.h        | 11 ++---------
>>  include/grub/efi/efi.h            |  4 ++++
>>  4 files changed, 19 insertions(+), 22 deletions(-)
>>
>> diff --git a/grub-core/loader/arm64/linux.c
>> b/grub-core/loader/arm64/linux.c
>> index c60469e53..8cd44230d 100644
>> --- a/grub-core/loader/arm64/linux.c
>> +++ b/grub-core/loader/arm64/linux.c
>> @@ -48,9 +48,9 @@ static grub_addr_t initrd_start;
>>  static grub_addr_t initrd_end;
>>
>>  grub_err_t
>> -grub_arm64_uefi_check_image (struct grub_arm64_linux_kernel_header * lh)
>> +grub_efi_linux_check_image (struct grub_linux_kernel_header * lh)
>>  {
>> -  if (lh->magic != GRUB_ARM64_LINUX_MAGIC)
>> +  if (lh->magic != GRUB_LINUX_MAGIC_SIGNATURE)
>>      return grub_error(GRUB_ERR_BAD_OS, "invalid magic number");
>>
>>    if ((lh->code0 & 0xffff) != GRUB_PE32_MAGIC)
>> @@ -109,7 +109,7 @@ failure:
>>  }
>>
>>  grub_err_t
>> -grub_arm64_uefi_boot_image (grub_addr_t addr, grub_size_t size, char
>> *args)
>> +grub_efi_linux_boot_image (grub_addr_t addr, grub_size_t size, char
>> *args)
>>  {
>>    grub_efi_memory_mapped_device_path_t *mempath;
>>    grub_efi_handle_t image_handle;
>> @@ -173,8 +173,8 @@ grub_linux_boot (void)
>>    if (finalize_params_linux () != GRUB_ERR_NONE)
>>      return grub_errno;
>>
>> -  return (grub_arm64_uefi_boot_image((grub_addr_t)kernel_addr,
>> -                                     kernel_size, linux_args));
>> +  return (grub_efi_linux_boot_image((grub_addr_t)kernel_addr,
>> +                                    kernel_size, linux_args));
>>  }
>>
>>  static grub_err_t
>> @@ -250,7 +250,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__
>> ((unused)),
>>                 int argc, char *argv[])
>>  {
>>    grub_file_t file = 0;
>> -  struct grub_arm64_linux_kernel_header lh;
>> +  struct grub_linux_kernel_header lh;
>>
>>    grub_dl_ref (my_mod);
>>
>> @@ -269,7 +269,7 @@ grub_cmd_linux (grub_command_t cmd __attribute__
>> ((unused)),
>>    if (grub_file_read (file, &lh, sizeof (lh)) < (long) sizeof (lh))
>>      return grub_errno;
>>
>> -  if (grub_arm64_uefi_check_image (&lh) != GRUB_ERR_NONE)
>> +  if (grub_efi_linux_check_image (&lh) != GRUB_ERR_NONE)
>>      goto fail;
>>
>>    grub_loader_unset();
>> diff --git a/grub-core/loader/arm64/xen_boot.c
>> b/grub-core/loader/arm64/xen_boot.c
>> index d092a53ed..e8720584b 100644
>> --- a/grub-core/loader/arm64/xen_boot.c
>> +++ b/grub-core/loader/arm64/xen_boot.c
>> @@ -67,7 +67,7 @@ typedef enum module_type module_type_t;
>>
>>  struct xen_hypervisor_header
>>  {
>> -  struct grub_arm64_linux_kernel_header efi_head;
>> +  struct grub_linux_kernel_header efi_head;
>>
>>    /* This is always PE\0\0.  */
>>    grub_uint8_t signature[GRUB_PE32_SIGNATURE_SIZE];
>> @@ -254,9 +254,9 @@ xen_boot (void)
>>    if (err)
>>      return err;
>>
>> -  return grub_arm64_uefi_boot_image (xen_hypervisor->start,
>> -                                    xen_hypervisor->size,
>> -                                    xen_hypervisor->cmdline);
>> +  return grub_efi_linux_boot_image (xen_hypervisor->start,
>> +                                   xen_hypervisor->size,
>> +                                   xen_hypervisor->cmdline);
>>  }
>>
>>  static void
>> @@ -458,8 +458,8 @@ grub_cmd_xen_hypervisor (grub_command_t cmd
>> __attribute__ ((unused)),
>>
>>    if (grub_file_read (file, &sh, sizeof (sh)) != (long) sizeof (sh))
>>      goto fail;
>> -  if (grub_arm64_uefi_check_image
>> -      ((struct grub_arm64_linux_kernel_header *) &sh) != GRUB_ERR_NONE)
>> +  if (grub_efi_linux_check_image
>> +      ((struct grub_linux_kernel_header *) &sh) != GRUB_ERR_NONE)
>>      goto fail;
>>    grub_file_seek (file, 0);
>>
>> diff --git a/include/grub/arm64/linux.h b/include/grub/arm64/linux.h
>> index a981df5d1..e53be83b1 100644
>> --- a/include/grub/arm64/linux.h
>> +++ b/include/grub/arm64/linux.h
>> @@ -19,12 +19,10 @@
>>  #ifndef GRUB_LINUX_CPU_HEADER
>>  #define GRUB_LINUX_CPU_HEADER 1
>>
>> -#include <grub/efi/efi.h>
>> -
>> -#define GRUB_ARM64_LINUX_MAGIC 0x644d5241 /* 'ARM\x64' */
>> +#define GRUB_LINUX_MAGIC_SIGNATURE 0x644d5241 /* 'ARM\x64' */
>>
> This doesn't sound arm64-independent.
>
>>
>>  /* From linux/Documentation/arm64/booting.txt */
>> -struct grub_arm64_linux_kernel_header
>> +struct grub_linux_kernel_header
>>  {
>>
> This makes it confusing with x86 counterpart.
>
   grub_uint32_t code0;         /* Executable code */
>>    grub_uint32_t code1;         /* Executable code */
>> @@ -38,9 +36,4 @@ struct grub_arm64_linux_kernel_header
>>    grub_uint32_t hdr_offset;    /* Offset of PE/COFF header */
>>  };
>>
>> -grub_err_t grub_arm64_uefi_check_image (struct
>> grub_arm64_linux_kernel_header
>> -                                        *lh);
>> -grub_err_t grub_arm64_uefi_boot_image (grub_addr_t addr, grub_size_t
>> size,
>> -                                       char *args);
>> -
>>  #endif /* ! GRUB_LINUX_CPU_HEADER */
>> diff --git a/include/grub/efi/efi.h b/include/grub/efi/efi.h
>> index a58774efc..149969941 100644
>> --- a/include/grub/efi/efi.h
>> +++ b/include/grub/efi/efi.h
>> @@ -92,6 +92,10 @@ void *EXPORT_FUNC(grub_efi_get_firmware_fdt)(void);
>>  #endif
>>  #if defined(__aarch64__)
>>  grub_err_t EXPORT_FUNC(grub_efi_get_ram_base)(grub_addr_t *);
>> +#include <grub/cpu/linux.h>
>> +grub_err_t grub_efi_linux_check_image(struct grub_linux_kernel_header
>> *lh);
>> +grub_err_t grub_efi_linux_boot_image(grub_addr_t addr, grub_size_t size,
>> +                                    char *args);
>>  #endif
>>
>>  grub_addr_t grub_efi_modules_addr (void);
>> --
>> 2.11.0
>>
>>
>> _______________________________________________
>> Grub-devel mailing list
>> Grub-devel@gnu.org
>> https://lists.gnu.org/mailman/listinfo/grub-devel
>>
>
_______________________________________________
Grub-devel mailing list
Grub-devel@gnu.org
https://lists.gnu.org/mailman/listinfo/grub-devel

Reply via email to