* Re: [Re: [Linux-ia64] IA64 Link Relocation operators ]
@ 2002-02-06 15:03 Harish Babu
2002-02-06 15:07 ` Harish Babu
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: Harish Babu @ 2002-02-06 15:03 UTC (permalink / raw)
To: linux-ia64
Hi,
Yes that is about the only documentation that i have been able to find about
link relocations. I needed some more details like how they are
implemented etc.
Harish
Cary Coutant <cary@cup.hp.com> wrote:
>The only formal documention I know about is in the Assembly Language
>Reference Guide available from the Intel web site. It has a chapter on
>Link-relocation Operators. The explanations are very short, and probably
>not understandable unless you have a good understanding of how IA-64
>compilers work.
The Itanium psABI document also has a discussion of this; see the end of
Chapter 4.
http://www.intel.com/design/Itanium/Downloads/245370.htm
-cary
____________________________________________________________________
Get free e-mail and a permanent address at http://www.amexmail.com/?A=1
^ permalink raw reply [flat|nested] 4+ messages in thread* Re: [Re: [Linux-ia64] IA64 Link Relocation operators ]
2002-02-06 15:03 [Re: [Linux-ia64] IA64 Link Relocation operators ] Harish Babu
@ 2002-02-06 15:07 ` Harish Babu
2002-02-06 15:49 ` Saxena, Sunil
2002-02-06 18:45 ` Cary Coutant
2 siblings, 0 replies; 4+ messages in thread
From: Harish Babu @ 2002-02-06 15:07 UTC (permalink / raw)
To: linux-ia64
Hi,
Yes that is about the only documentation that i have been able to find about
link relocations. I needed some more details like how they are
implemented etc.
Harish
Cary Coutant <cary@cup.hp.com> wrote:
>The only formal documention I know about is in the Assembly Language
>Reference Guide available from the Intel web site. It has a chapter on
>Link-relocation Operators. The explanations are very short, and probably
>not understandable unless you have a good understanding of how IA-64
>compilers work.
The Itanium psABI document also has a discussion of this; see the end of
Chapter 4.
http://www.intel.com/design/Itanium/Downloads/245370.htm
-cary
____________________________________________________________________
Get free e-mail and a permanent address at http://www.amexmail.com/?A=1
^ permalink raw reply [flat|nested] 4+ messages in thread
* RE: [Re: [Linux-ia64] IA64 Link Relocation operators ]
2002-02-06 15:03 [Re: [Linux-ia64] IA64 Link Relocation operators ] Harish Babu
2002-02-06 15:07 ` Harish Babu
@ 2002-02-06 15:49 ` Saxena, Sunil
2002-02-06 18:45 ` Cary Coutant
2 siblings, 0 replies; 4+ messages in thread
From: Saxena, Sunil @ 2002-02-06 15:49 UTC (permalink / raw)
To: linux-ia64
Were you able to find sources to Intel assembler at the Intel web site?
Here is a url for your reference. Hope that helps you out in the
implementation details.
http://developer.intel.com/software/products/opensource/tools1/ia64_download
.htm
Thanks
Sunil
-----Original Message-----
From: Harish Babu [mailto:babu.harish@usa.net]
Sent: Wednesday, February 06, 2002 7:08 AM
To: Cary Coutant; Cary Coutant
Cc: linux-ia64@linuxia64.org
Subject: Re: [Re: [Linux-ia64] IA64 Link Relocation operators ]
Hi,
Yes that is about the only documentation that i have been able to find
about
link relocations. I needed some more details like how they are
implemented etc.
Harish
Cary Coutant <cary@cup.hp.com> wrote:
>The only formal documention I know about is in the Assembly Language
>Reference Guide available from the Intel web site. It has a chapter on
>Link-relocation Operators. The explanations are very short, and probably
>not understandable unless you have a good understanding of how IA-64
>compilers work.
The Itanium psABI document also has a discussion of this; see the end of
Chapter 4.
http://www.intel.com/design/Itanium/Downloads/245370.htm
-cary
____________________________________________________________________
Get free e-mail and a permanent address at http://www.amexmail.com/?A=1
_______________________________________________
Linux-IA64 mailing list
Linux-IA64@linuxia64.org
http://lists.linuxia64.org/lists/listinfo/linux-ia64
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [Re: [Linux-ia64] IA64 Link Relocation operators ]
2002-02-06 15:03 [Re: [Linux-ia64] IA64 Link Relocation operators ] Harish Babu
2002-02-06 15:07 ` Harish Babu
2002-02-06 15:49 ` Saxena, Sunil
@ 2002-02-06 18:45 ` Cary Coutant
2 siblings, 0 replies; 4+ messages in thread
From: Cary Coutant @ 2002-02-06 18:45 UTC (permalink / raw)
To: linux-ia64
> Yes that is about the only documentation that i have been able to find about
>link relocations. I needed some more details like how they are
>implemented etc.
This might help -- it's the original text of the proposal I submitted to
the psABI group. This proposal didn't include the assembler pseudo-ops;
they came about later.
-cary
Subject: Link-time optimization of indirect addressing (Issue #66?)
Date: 5/21/99 8:24 PM
To: IA-64 ABI Group, ia64-abi@unix-os.sc.intel.com
One useful and simple optimization that can be done at link time is the
in situ conversion of an indirect load or store sequence into a direct
load or store sequence, when the linker can determine that a particular
variable is "protected" and within addl addressing range of gp. While
this doesn't remove any instructions (I don't want to get into the
business of rewriting IA-64 code in the linker), it does replace a load
with an effective no-op.
What we want to change is the sequence on the left to that on the right,
without regard to any intervening instructions:
addl t1=@ltoff(var),gp => addl t1=@gprel(var),gp
ld8 t2=[t1] => mov t2=[t1]
ld8 loc0=[t2] => ld8 loc0=[t2]
Notice that we don't have to worry about whether the temporaries t1 and
t2 are live beyond their original ranges.
This transformation can be particularly easy with two new relocations:
LTOFF22X 0x86
LDXMOV 0x87
The LTOFF22X relocation is used on the addl instruction in place of the
normal LTOFF22 relocation. It has exactly the same semantics as LTOFF22
unless the linker determines that the symbol can be addressed directly.
If the symbol can be addressed directly, the linker transforms this into
a GPREL22 relocation.
The LDXMOV relocation is used on the first ld8 instruction, where no
relocation would ordinarily be seen. Its symbol and addend fields must
match exactly those of the corresponding LTOFF22X relocation. If the
linker determines that the symbol can be addressed directly, it rewrites
the ld8 as a mov. This can be done easily by masking out all but the qp,
r1, and r3 fields of the instruction, then or'ing in the bit pattern
0x8000000000.
Of course, any implementation may treat LTOFF22X as a synonym of LTOFF22,
and ignore LDXMOV completely.
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2002-02-06 18:45 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2002-02-06 15:03 [Re: [Linux-ia64] IA64 Link Relocation operators ] Harish Babu
2002-02-06 15:07 ` Harish Babu
2002-02-06 15:49 ` Saxena, Sunil
2002-02-06 18:45 ` Cary Coutant
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox