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 */
> >
> >
>
prev parent 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.