arm questions
Scott Bambrough
scottb@corelcomputer.com
Thu Apr 15 11:31:00 GMT 1999
Ian Lance Taylor wrote:
>
> Date: Thu, 15 Apr 1999 10:38:25 -0700
> From: Doug Evans <devans@cygnus.com>
>
> Two random questions.
>
> 1)
> elfarm-oabi.c uses USE_RELA
> elfarm-nabi.c uses USE_REL
> That seems rather backwards, doesn't it?
> I'd expect a new version of an abi to switch from USE_REL to USE_RELA,
> but not the other way around.
> [not that it can be changed, but rather ... why the switch?]
>
> This is my understanding of the situation. If anybody knows that I am
> wrong, please correct me.
>
> The ARM ELF situation is a mess because there were two separate
> implementations.
>
> Some folks in England put together ARM GNU/Linux, but they took a very
> long time to get the copyright stuff done. For some reason that I do
> not know, that implementation used REL rather than RELA relocs.
Actually Phil is in England, Pat Beirne and I are in Canada. And that very long
copyright time was due entirely to Corel's legal department. They were a pain
in the ass. We chose REL because we did not need the addend. In hindsight I
would choose RELA. We did this work over a period of about 6 months when we
brought up gcc, binutils, gdb and glibc on the NetWinder.
> In the meantime, Cygnus implemented ARM ELF, using RELA relocs.
Something of which we were entirely unaware of at the time, otherwise we would
have attempted to collaborate in a closer fashion.
> It's obviously desirable to have a single ARM ELF ABI, and the best
> choice is probably the one currently being used for GNU/Linux.
> Therefore, when we straightened out the copyright situation, we dumped
> the Cygnus RELA implementation in favour of the GNU/Linux REL
> implementation.
I don't know about better. Cygnus does pretty good work. It probably has a
larger installed base ATM, as the GNU/Linux implementation is used by HJ Lu's
2.9.1.0.xx releases of binutils. I think most of the ARM community uses this
rather than the GAS2 snapshots.
> Whats the R_ARM_THM_XPC22 reloc for?
The docs say it is a Thumb BLX pair. It is a two byte Thumb instruction. It is
a relocateable branch instruction, where bits 0-10 encode the 11 most
significant bits of the branch offset, and bits 0-10 of the next instruction
word encode the least significant bits of the branch offset. There is also a
note about it being provisional. The least significant bit of the branch offset
must be zero.
Scott Bambrough
More information about the Bfd
mailing list