public inbox for gcc-help@gcc.gnu.org
 help / color / mirror / Atom feed
* RE: Sparc RELA incorrect addend
@ 2009-02-17 12:37 Neil Mayes
  2009-02-17 14:56 ` Neil Mayes
  0 siblings, 1 reply; 4+ messages in thread
From: Neil Mayes @ 2009-02-17 12:37 UTC (permalink / raw)
  To: gcc-help

Hi,

I am implementing a dynamic task loader for RTEMS using a Sparc ERC32.
I have been looking in what is invloved and what I need to do in order
to relocate the code however I have seen the relocations which use an
addend are incorrect, the addend is the absolute value not the offset
from the symbol value. I have had a look at the bugs but can't find
this one.

Has anyone any knowledge of this issue?

I am using GCC version 4.2.2

Thanks,
Neil

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: Sparc RELA incorrect addend
  2009-02-17 12:37 Sparc RELA incorrect addend Neil Mayes
@ 2009-02-17 14:56 ` Neil Mayes
  2009-02-17 20:36   ` Ian Lance Taylor
  0 siblings, 1 reply; 4+ messages in thread
From: Neil Mayes @ 2009-02-17 14:56 UTC (permalink / raw)
  To: gcc-help

Hi,

On closer inspection it's a little worse. I have a local global
variable which is located in .data @ 0x020005AC whereas the rela tells
me its within the .text section. Symbol value == 0x02000000 (.text
vitual address) with an addend == 0x020005AC, which is actually the
absolute address. Looking through binutils I can see for a global
symbol there is the following comment:

/* To avoid generating warning messages about truncated relocations,
set the relocation's address to be the same as the start of this
section.  */

It's strange that it's not got the correct section ID as well as an
incorrect addend. If I turn it into a global global everything is OK
with addend set to zero.

This is using GNU ld (GNU Binutils) 2.18
  Supported emulations:
   elf32_sparc

Thanks,
Neil



2009/2/17 Neil Mayes <neil.mayes@googlemail.com>:
> Hi,
>
> I am implementing a dynamic task loader for RTEMS using a Sparc ERC32.
> I have been looking in what is invloved and what I need to do in order
> to relocate the code however I have seen the relocations which use an
> addend are incorrect, the addend is the absolute value not the offset
> from the symbol value. I have had a look at the bugs but can't find
> this one.
>
> Has anyone any knowledge of this issue?
>
> I am using GCC version 4.2.2
>
> Thanks,
> Neil
>

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: Sparc RELA incorrect addend
  2009-02-17 14:56 ` Neil Mayes
@ 2009-02-17 20:36   ` Ian Lance Taylor
  2009-02-17 20:54     ` Neil Mayes
  0 siblings, 1 reply; 4+ messages in thread
From: Ian Lance Taylor @ 2009-02-17 20:36 UTC (permalink / raw)
  To: Neil Mayes; +Cc: gcc-help

Neil Mayes <neil.mayes@googlemail.com> writes:

> On closer inspection it's a little worse. I have a local global
> variable which is located in .data @ 0x020005AC whereas the rela tells
> me its within the .text section. Symbol value == 0x02000000 (.text
> vitual address) with an addend == 0x020005AC, which is actually the
> absolute address. Looking through binutils I can see for a global
> symbol there is the following comment:
>
> /* To avoid generating warning messages about truncated relocations,
> set the relocation's address to be the same as the start of this
> section.  */
>
> It's strange that it's not got the correct section ID as well as an
> incorrect addend. If I turn it into a global global everything is OK
> with addend set to zero.
>
> This is using GNU ld (GNU Binutils) 2.18
>   Supported emulations:
>    elf32_sparc

You are more likely to get help on GNU binutils issues at
binutils@sourceware.org.  See http://sourceware.org/binutils .  In order
to get help on this issue, I think you will need to provide a test case.

Ian

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: Sparc RELA incorrect addend
  2009-02-17 20:36   ` Ian Lance Taylor
@ 2009-02-17 20:54     ` Neil Mayes
  0 siblings, 0 replies; 4+ messages in thread
From: Neil Mayes @ 2009-02-17 20:54 UTC (permalink / raw)
  To: Ian Lance Taylor; +Cc: gcc-help

Hi Ian,

Thanks, I spotted the binutils help tonight! Appologies, newbie mistake.

Neil

2009/2/17 Ian Lance Taylor <iant@google.com>:
> Neil Mayes <neil.mayes@googlemail.com> writes:
>
>> On closer inspection it's a little worse. I have a local global
>> variable which is located in .data @ 0x020005AC whereas the rela tells
>> me its within the .text section. Symbol value == 0x02000000 (.text
>> vitual address) with an addend == 0x020005AC, which is actually the
>> absolute address. Looking through binutils I can see for a global
>> symbol there is the following comment:
>>
>> /* To avoid generating warning messages about truncated relocations,
>> set the relocation's address to be the same as the start of this
>> section.  */
>>
>> It's strange that it's not got the correct section ID as well as an
>> incorrect addend. If I turn it into a global global everything is OK
>> with addend set to zero.
>>
>> This is using GNU ld (GNU Binutils) 2.18
>>   Supported emulations:
>>    elf32_sparc
>
> You are more likely to get help on GNU binutils issues at
> binutils@sourceware.org.  See http://sourceware.org/binutils .  In order
> to get help on this issue, I think you will need to provide a test case.
>
> Ian
>

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2009-02-17 20:54 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-02-17 12:37 Sparc RELA incorrect addend Neil Mayes
2009-02-17 14:56 ` Neil Mayes
2009-02-17 20:36   ` Ian Lance Taylor
2009-02-17 20:54     ` Neil Mayes

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).