From: "H.J. Lu" <hjl.tools@gmail.com>
To: "徐持恒 Xu Chiheng" <chiheng.xu@gmail.com>
Cc: "binutils@sourceware.org" <binutils@sourceware.org>
Subject: Re: [PATCH] binutils: partially revert 17c6c3b99156fe82c1e637e1a5fd9f163ac788c8
Date: Thu, 17 Nov 2022 10:50:49 -0800 [thread overview]
Message-ID: <CAMe9rOoRBQVM8teugtWJ7CiwHVa4D3NxSfnDTkgqtc9uMchLBw@mail.gmail.com> (raw)
In-Reply-To: <SY4P282MB40478D0B56A396B9DF249BBE8A069@SY4P282MB4047.AUSP282.PROD.OUTLOOK.COM>
On Thu, Nov 17, 2022 at 10:28 AM 徐持恒 Xu Chiheng <chiheng.xu@gmail.com> wrote:
>
> No. not using NASM.
>
> using x86_64-elf-g++ -m32 to generate 32 bit code(elf32).
> using x86_64-elf-objcopy to convert it to elf64.
> then link the 32 bit code(elf64) with 64 bit code.
>
This is an unsupported operation.
H.J.
>
>
> ________________________________
> From: H.J. Lu <hjl.tools@gmail.com>
> Sent: Friday, November 18, 2022 02:06
> To: 徐持恒 Xu Chiheng <chiheng.xu@gmail.com>
> Cc: binutils@sourceware.org <binutils@sourceware.org>
> Subject: Re: [PATCH] binutils: partially revert 17c6c3b99156fe82c1e637e1a5fd9f163ac788c8
>
> On Thu, Nov 17, 2022 at 9:44 AM 徐持恒 Xu Chiheng via Binutils
> <binutils@sourceware.org> wrote:
> >
> > Phenomenal: In 32 bit and 64 bit mixed code, ld can't do relocation
> > for 32 bit code.
> > It is caused by commit 17c6c3b99156fe82c1e637e1a5fd9f163ac788c8.
> >
> >
> >
> >
> > /* src_mask selects the part of the instruction (or data) to be used
> > in the relocation sum. If the target relocations don't have an
> > addend in the reloc, eg. ELF USE_REL, src_mask will normally equal
> > dst_mask to extract the addend from the section contents. If
> > relocations do have an addend in the reloc, eg. ELF USE_RELA, this
> > field should normally be zero. Non-zero values for ELF USE_RELA
> > targets should be viewed with suspicion as normally the value in
> > the dst_mask part of the section contents should be ignored. */
> > bfd_vma src_mask;
> >
> >
> >
> > Author: Jan Beulich <jbeulich@suse.com> 2021-05-07 18:05:12
> > Committer: Jan Beulich <jbeulich@suse.com> 2021-05-07 18:05:12
> > Parent: 98da05bf2698b55b73453480a3fbb92f163d2c7b (x86: don't mix disp
> > and imm processing)
> > Child: 4cf88725da1cb503be04d3237354105ec170bc86 ([gdb/symtab] Fix
> > infinite recursion in dwarf2_cu::get_builder())
> > Branches: master, test0558-01 and many more (41)
> > Follows: gdb-10-branchpoint
> > Precedes: binutils-2_37, gdb-11-branchpoint
> >
> > x86-64/ELF: clear src_mask for all reloc types
> >
> > x86-64 uses rela relocations. The comment next to the field's declaration
> > says "Non-zero values for ELF USE_RELA targets should be viewed with
> > suspicion ..." And indeed the fields being non-zero causes section
> > contents to be accumulated into the final relocated values in addition to
> > the relocations' addends, which is contrary to the ELF spec.
>
> Are you using NASM?
>
> --
> H.J.
--
H.J.
next prev parent reply other threads:[~2022-11-17 18:51 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-11-17 17:44 徐持恒 Xu Chiheng
2022-11-17 18:06 ` H.J. Lu
[not found] ` <SY4P282MB40478D0B56A396B9DF249BBE8A069@SY4P282MB4047.AUSP282.PROD.OUTLOOK.COM>
2022-11-17 18:50 ` H.J. Lu [this message]
[not found] ` <SY4P282MB40470E7AC17968C86A8731488A069@SY4P282MB4047.AUSP282.PROD.OUTLOOK.COM>
2022-11-17 19:11 ` H.J. Lu
[not found] ` <SY4P282MB40478BD7C68830B7DC5705358A069@SY4P282MB4047.AUSP282.PROD.OUTLOOK.COM>
2022-11-17 19:51 ` H.J. Lu
[not found] ` <SY4P282MB404738CCE8DD452A63DA4B0B8A069@SY4P282MB4047.AUSP282.PROD.OUTLOOK.COM>
2022-11-18 9:37 ` 徐持恒 Xu Chiheng
2022-11-18 10:01 ` Jan Beulich
2022-11-18 10:24 ` 徐持恒 Xu Chiheng
2022-11-18 10:34 ` Jan Beulich
2022-11-18 10:45 ` 徐持恒 Xu Chiheng
2022-11-18 13:31 ` Jan Beulich
[not found] ` <CAPOVtOuQ3Xto+uoRVqfyWDuvqO=8XrL64+ujZHY+OsN81Q4E=A@mail.gmail.com>
2022-11-18 14:03 ` Jan Beulich
[not found] ` <da40ede4-5f91-a35e-dcae-ab222f0d0cdf@suse.com>
[not found] ` <CAPOVtOsHOzBxx=1bCMgRP-DfWzJu_eS-5UaEj-q_F8p86R-q9g@mail.gmail.com>
2022-11-18 14:09 ` Jan Beulich
2022-11-18 14:14 ` 徐持恒 Xu Chiheng
2022-11-18 14:35 ` 徐持恒 Xu Chiheng
2022-11-21 7:53 ` Jan Beulich
2022-11-21 8:30 ` 徐持恒 Xu Chiheng
2022-11-21 8:50 ` 徐持恒 Xu Chiheng
2022-11-21 9:02 ` Jan Beulich
2022-11-21 9:06 ` Jan Beulich
2022-11-21 9:21 ` 徐持恒 Xu Chiheng
2022-11-21 9:52 ` Jan Beulich
2022-11-21 10:59 ` 徐持恒 Xu Chiheng
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=CAMe9rOoRBQVM8teugtWJ7CiwHVa4D3NxSfnDTkgqtc9uMchLBw@mail.gmail.com \
--to=hjl.tools@gmail.com \
--cc=binutils@sourceware.org \
--cc=chiheng.xu@gmail.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).