All of lore.kernel.org
 help / color / mirror / Atom feed
From: Leo Liang <ycliang@andestech.com>
To: u-boot@lists.denx.de
Subject: [PATCH 1/1] riscv: Fix efi header size for RV32
Date: Tue, 17 Nov 2020 15:51:07 +0800	[thread overview]
Message-ID: <20201117075107.GA32531@andestech.com> (raw)
In-Reply-To: <0f0791db-29fc-c727-13ec-8679bff50a0a@gmx.de>

On Thu, Nov 12, 2020 at 03:05:23PM +0100, Heinrich Schuchardt wrote:
> On 12.11.20 14:43, Leo Liang wrote:
> > Date: Thu, 12 Nov 2020 10:09:52 +0800
> > From: Leo Yu-Chi Liang <ycliang@andestech.com>
> > Subject: [PATCH 1/1] riscv: Fix efi header size for RV32
> >
> > This patch depends on Atish's patch.
> > (https://patchwork.ozlabs.org/project/uboot/patch/20201013192331.3236458-1-atish.patra at wdc.com/)
> >
> > Modify the size of the Optional Header "Windows-Specific Fields" to fit with the specification.
> > (https://docs.microsoft.com/en-us/windows/win32/debug/pe-format)
> 
> With both patches applied on RISCV-64 I get SizeOfOptionalHeader = 0xa0
> instead of expected 0xf0.
> 
> Best regards
> 
> Heinrich
Hi Heinrich,

I will drop this patch and send a new patchset later.

Best regards,
Leo
> 
> >
> > Signed-off-by: Leo Yu-Chi Liang <ycliang@andestech.com>
> > Cc: rick at andestech.com
> > Cc: alankao at andestech.com
> > Cc: atish.patra at wdc.com
> > Cc: xypron.glpk at gmx.de
> > Cc: bmeng.cn at gmail.com
> > ---
> >  arch/riscv/lib/crt0_riscv_efi.S | 17 ++++++++++++++---
> >  1 file changed, 14 insertions(+), 3 deletions(-)
> >
> > diff --git a/arch/riscv/lib/crt0_riscv_efi.S b/arch/riscv/lib/crt0_riscv_efi.S
> > index 4aaa49ad07..48ff89553b 100644
> > --- a/arch/riscv/lib/crt0_riscv_efi.S
> > +++ b/arch/riscv/lib/crt0_riscv_efi.S
> > @@ -15,13 +15,13 @@
> >  #define SAVE_LONG(reg, idx)	sd	reg, (idx*SIZE_LONG)(sp)
> >  #define LOAD_LONG(reg, idx)	ld	reg, (idx*SIZE_LONG)(sp)
> >  #define PE_MACHINE	IMAGE_FILE_MACHINE_RISCV64
> > -#define PE_MAGIC        IMAGE_NT_OPTIONAL_HDR64_MAGIC
> > +#define PE_MAGIC    IMAGE_NT_OPTIONAL_HDR64_MAGIC
> >  #else
> >  #define SIZE_LONG	4
> >  #define SAVE_LONG(reg, idx)	sw	reg, (idx*SIZE_LONG)(sp)
> >  #define LOAD_LONG(reg, idx)	lw	reg, (idx*SIZE_LONG)(sp)
> >  #define PE_MACHINE	IMAGE_FILE_MACHINE_RISCV32
> > -#define PE_MAGIC        IMAGE_NT_OPTIONAL_HDR32_MAGIC
> > +#define PE_MAGIC    IMAGE_NT_OPTIONAL_HDR32_MAGIC
> >  #endif
> >
> >
> > @@ -50,7 +50,7 @@ coff_header:
> >  		 IMAGE_FILE_LOCAL_SYMS_STRIPPED | \
> >  		 IMAGE_FILE_DEBUG_STRIPPED)
> >  optional_header:
> > -	.short	PE_MAGIC			/* PE32+ format */
> > +	.short	PE_MAGIC			/* PE32(+) format */
> >  	.byte	0x02				/* MajorLinkerVersion */
> >  	.byte	0x14				/* MinorLinkerVersion */
> >  	.long	_edata - _start			/* SizeOfCode */
> > @@ -63,7 +63,11 @@ optional_header:
> >  #endif
> >
> >  extra_header_fields:
> > +#if __riscv_xlen == 32
> > +	.long	0				/* ImageBase */
> > +#else
> >  	.quad	0				/* ImageBase */
> > +#endif
> >  	.long	0x20				/* SectionAlignment */
> >  	.long	0x8				/* FileAlignment */
> >  	.short	0				/* MajorOperatingSystemVersion */
> > @@ -83,10 +87,17 @@ extra_header_fields:
> >  	.long	0				/* CheckSum */
> >  	.short	IMAGE_SUBSYSTEM_EFI_APPLICATION /* Subsystem */
> >  	.short	0				/* DllCharacteristics */
> > +#if __riscv_xlen == 32
> > +	.long	0				/* SizeOfStackReserve */
> > +	.long	0				/* SizeOfStackCommit */
> > +	.long	0				/* SizeOfHeapReserve */
> > +	.long	0				/* SizeOfHeapCommit */
> > +#else
> >  	.quad	0				/* SizeOfStackReserve */
> >  	.quad	0				/* SizeOfStackCommit */
> >  	.quad	0				/* SizeOfHeapReserve */
> >  	.quad	0				/* SizeOfHeapCommit */
> > +#endif
> >  	.long	0				/* LoaderFlags */
> >  	.long	0x6				/* NumberOfRvaAndSizes */
> >
> >
> 

      reply	other threads:[~2020-11-17  7:51 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-11-12 13:43 [PATCH 1/1] riscv: Fix efi header size for RV32 Leo Liang
2020-11-12 14:05 ` Heinrich Schuchardt
2020-11-17  7:51   ` Leo Liang [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20201117075107.GA32531@andestech.com \
    --to=ycliang@andestech.com \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.