On Wed, Nov 9, 2022 at 12:14 AM Ard Biesheuvel <a...@kernel.org> wrote:

> On Wed, 9 Nov 2022 at 09:13, Atish Kumar Patra <ati...@rivosinc.com>
> wrote:
> >
> >
> >
> > On Tue, Nov 8, 2022 at 8:37 AM Ard Biesheuvel <a...@kernel.org> wrote:
> >>
> >> On Tue, 8 Nov 2022 at 16:59, Daniel Kiper <dki...@net-space.pl> wrote:
> >> >
> >> > On Fri, Nov 04, 2022 at 04:26:06PM -0700, Atish Patra wrote:
> >> > > Update the RISC-V Linux kernel image headers as per the current
> header.
> >> > >
> >> > > Reference:
> >> > > <Linux kernel source>/Documentation/riscv/boot-image-header.rst
> >> > >
> >> > > 474efecb65dc: ("riscv: modify the Image header to improve
> compatibility with the ARM64 header")
> >> >
> >> > The latest commit which updates
> Documentation/riscv/boot-image-header.rst is
> >> > 1d5c17e47028 (RISC-V: Typo fixes in image header and documentation).
> >> >
> >> > > Acked-by: Heinrich Schuchardt <heinrich.schucha...@canonical.com>
> >> > > Signed-off-by: Atish Patra <ati...@rivosinc.com>
> >> >
> >> > The order of these lines should be reversed...
> >> >
> >> > > ---
> >> > >  include/grub/riscv32/linux.h | 19 ++++++++++---------
> >> > >  include/grub/riscv64/linux.h | 19 +++++++++++--------
> >> > >  2 files changed, 21 insertions(+), 17 deletions(-)
> >> > >
> >> > > diff --git a/include/grub/riscv32/linux.h
> b/include/grub/riscv32/linux.h
> >> > > index 512b777c8a41..a884d4f4760c 100644
> >> > > --- a/include/grub/riscv32/linux.h
> >> > > +++ b/include/grub/riscv32/linux.h
> >> > > @@ -19,21 +19,22 @@
> >> > >  #ifndef GRUB_RISCV32_LINUX_HEADER
> >> > >  #define GRUB_RISCV32_LINUX_HEADER 1
> >> > >
> >> > > -#define GRUB_LINUX_RISCV_MAGIC_SIGNATURE 0x52534356 /* 'RSCV' */
> >> > > -
> >> > > -/* From linux/Documentation/riscv/booting.txt */
> >> > > +/* From linux/Documentation/riscv/boot-image-header.rst */
> >> > >  struct linux_riscv_kernel_header
> >> > >  {
> >> > >    grub_uint32_t code0;               /* Executable code */
> >> > >    grub_uint32_t code1;               /* Executable code */
> >> > > -  grub_uint64_t text_offset; /* Image load offset */
> >> > > -  grub_uint64_t res0;                /* reserved */
> >> > > -  grub_uint64_t res1;                /* reserved */
> >> > > +  grub_uint64_t text_offset; /* Image load offset, little endian */
> >> > > +  grub_uint64_t image_size;  /* Effective Image size, little
> endian */
> >> > > +  grub_uint64_t flags;               /* kernel flags, little
> endian */
> >> > > +  grub_uint32_t version;     /* Version of this header */
> >> > > +  grub_uint32_t res1;                /* reserved */
> >> > >    grub_uint64_t res2;                /* reserved */
> >> > > -  grub_uint64_t res3;                /* reserved */
> >> > > -  grub_uint64_t res4;                /* reserved */
> >> > > -  grub_uint32_t magic;               /* Magic number, little
> endian, "RSCV" */
> >> > > +  grub_uint64_t magic;               /* magic (RISC-V specifc,
> deprecated)*/
> >> > > +  grub_uint32_t magic2;              /* Magic number 2 (to match
> the ARM64 'magic' field pos) */
> >> > >    grub_uint32_t hdr_offset;  /* Offset of PE/COFF header */
> >> >
> >> > I can agree that hdr_offset makes more sense but
> >> > Documentation/riscv/boot-image-header.rst names this member as res3.
> >> > So, I would rename hdr_offset to res3 too. Or fix
> >> > Documentation/riscv/boot-image-header.rst in the kernel. Or, least
> >> > preferred, explain in the commit message why you do not rename this
> >> > member and add to the comment that this member is named res3 in the
> >> > documentation.
> >> >
> >>
> >> Can we get rid of these header definitions entirely?
> >>
> >> The only GRUB code that seems to care about the fields that are not
> >> defined in the PE/COFF spec is grub_cmd_file(), which currently parses
> >> the magic field, but given that we only support EFI boot anyway, that
> >> code should just parse the PE machine type instead.
> >
> >
> > If I understand you correctly, you are suggesting to remove the
> linux_arm64_kernel_header/linux_riscv_kernel_header
> > and just define a generic linux_arch_kernel_header which has
> pe_image_header at the correct offset.
> > grub_cmd_file() can just compare the machine type instead of the magic
> number for the IS_ARM64_LINUX case.
> > The other places using linux_arm64_kernel_header will just use the
> generic structure to compute the section_alignment field from the PE header.
> >
>
> Exactly.
>

Thanks for the prompt response. I will take a stab at it and revise the
series.
_______________________________________________
Grub-devel mailing list
Grub-devel@gnu.org
https://lists.gnu.org/mailman/listinfo/grub-devel

Reply via email to