From: Nelson Chu <nelson@rivosinc.com>
To: Luis Machado <luis.machado@arm.com>
Cc: binutils@sourceware.org, "Patrick O'Neill" <patrick@rivosinc.com>
Subject: Re: [committed 1/2] RISC-V: Improve link time complexity.
Date: Wed, 26 Oct 2022 10:06:32 +0800 [thread overview]
Message-ID: <CAPpQWtD80RvbrcsN-UupskTpw9sf2CNNp6__BOGT6gc=ziJJwg@mail.gmail.com> (raw)
In-Reply-To: <84a75951-f5a7-fc53-a11a-9a1b964200b7@arm.com>
Hi Luis,
Although I cannot reproduce the case from my side, does the following
fix work for you?
diff --git a/bfd/elfnn-riscv.c b/bfd/elfnn-riscv.c
index cf852636c9c..73e422dd57a 100644
--- a/bfd/elfnn-riscv.c
+++ b/bfd/elfnn-riscv.c
@@ -4253,7 +4253,8 @@ riscv_relax_resolve_delete_relocs (bfd *abfd,
rel->r_info = ELFNN_R_INFO (0, R_RISCV_NONE);
/* Skip ahead to the next delete reloc. */
- i = rel_next != NULL ? rel_next - relocs - 1 : sec->reloc_count;
+ i = rel_next != NULL ? (unsigned int) (rel_next - relocs - 1)
+ : sec->reloc_count;
}
return true;
Thanks
Nelson
On Tue, Oct 25, 2022 at 6:11 PM Luis Machado <luis.machado@arm.com> wrote:
>
> Hi Nelson,
>
> On 10/25/22 02:33, Nelson Chu wrote:
> > From: Patrick O'Neill <patrick@rivosinc.com>
> >
> > The riscv port does deletion and symbol table update for each relocation
> > while relaxing, so we are moving section bytes and scanning symbol table once
> > for each relocation. Compared to microblaze port, they record the relaxation
> > changes into a table, then do the deletion and symbol table update once per
> > section, rather than per relocation. Therefore, they should have better link
> > time complexity than us.
> >
> > To improve the link time complexity, this patch try to make the deletion in
> > linear time. Compared to record the relaxation changes into a table, we
> > replace the unused relocation with R_RISCV_DELETE for the deleted bytes, and
> > then resolve them at the end of the section. Assuming the number of
> > R_RISCV_DELETE is m, and the number of symbols is n, the total link complexity
> > should be O(m) for moving section bytes, and O(m*n^2) for symbol table update.
> > If we record the relaxation changes into the table, and then sort the symbol
> > table by values, then probably can reduce the time complexity to O(m*n*log(n))
> > for updating symbol table, but it doesn't seem worth it for now.
> >
> > bfd/
> > * elfnn-riscv.c (_riscv_relax_delete_bytes): Renamed from
> > riscv_relax_delete_bytes, updated to reduce the tiem complexity to O(m)
> > for memmove.
> > (typedef relax_delete_t): Function pointer declaration of delete functions.
> > (riscv_relax_delete_bytes): Can choose to use _riscv_relax_delete_piecewise
> > or _riscv_relax_delete_immediate for deletion.
> > (_riscv_relax_delete_piecewise): Just mark the deleted bytes as R_RISCV_DELETE.
> > (_riscv_relax_delete_immediate): Delete some bytes from a section while
> > relaxing.
> > (riscv_relax_resolve_delete_relocs): Delete the bytes for R_RISCV_DELETE
> > relocations from a section, at the end of _bfd_riscv_relax_section.
> > (_bfd_riscv_relax_call): Mark deleted bytes as R_RISCV_DELETE by reusing
> > R_RISCV_RELAX.
> > (_bfd_riscv_relax_lui): Likewise, but reuse R_RISCV_HI20 for lui, and reuse
> > R_RISCV_RELAX for c.lui.
> > (_bfd_riscv_relax_tls_le): Likewise, but resue R_RISCV_TPREL_HI20 and
> > R_RISCV_TPREL_ADD.
> > (_bfd_riscv_relax_pc): Likewise, but resue R_RISCV_PCREL_HI20 for auipc.
> > (_bfd_riscv_relax_align): Updated, don't need to resue relocation since
> > calling _riscv_relax_delete_immediate.
> > (_bfd_riscv_relax_delete): Removed.
> > (_bfd_riscv_relax_section): Set riscv_relax_delete_bytes for each relax_func,
> > to delete bytes immediately or later. Call riscv_relax_resolve_delete_relocs
> > to delete bytes for DELETE relocations from a section.
> > ---
> > bfd/elfnn-riscv.c | 180 +++++++++++++++++++++++++++++++++-------------
> > 1 file changed, 131 insertions(+), 49 deletions(-)
> >
>
> This seems to cause build failures due to a couple warnings (Werror). I can reproduce it on
> armhf Ubuntu 22.04, with the following configure line:
>
> configure --enable-targets=all --enable-64-bit-bfd
>
> The following warnings show up:
>
> elfnn-riscv.c: In function ‘riscv_relax_resolve_delete_relocs’:
> elfnn-riscv.c:4256:30: error: operand of ‘?:’ changes signedness from ‘int’ to ‘unsigned int’ due to unsignedness of other operand [-Werror=sign-compare]
>
> elfnn-riscv.c: In function ‘riscv_relax_resolve_delete_relocs’:
> elfnn-riscv.c:4256:30: error: operand of ‘?:’ changes signedness from ‘int’ to ‘unsigned int’ due to unsignedness of other operand [-Werror=sign-compare]
next prev parent reply other threads:[~2022-10-26 2:06 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-10-25 1:33 Nelson Chu
2022-10-25 1:33 ` [committed 2/2] RISC-V: Should reset `again' flag for _bfd_riscv_relax_pc Nelson Chu
2022-10-25 4:36 ` [committed 1/2] RISC-V: Improve link time complexity Nelson Chu
2022-10-25 10:10 ` Luis Machado
2022-10-26 2:06 ` Nelson Chu [this message]
2022-10-26 8:30 ` Luis Machado
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='CAPpQWtD80RvbrcsN-UupskTpw9sf2CNNp6__BOGT6gc=ziJJwg@mail.gmail.com' \
--to=nelson@rivosinc.com \
--cc=binutils@sourceware.org \
--cc=luis.machado@arm.com \
--cc=patrick@rivosinc.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).