From: rth Date: Thu, 24 Oct 2002 22:36:25 +0000 (+0000) Subject: * config/i386/i386.c (x86_output_mi_thunk): Fix x86_64 pic jump. X-Git-Tag: upstream/4.9.2~83724 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c9222242ab7d0dbad639e558ec51e69750ae23b9;p=platform%2Fupstream%2Flinaro-gcc.git * config/i386/i386.c (x86_output_mi_thunk): Fix x86_64 pic jump. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@58508 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 38c2287..72006a2 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2002-10-24 Richard Henderson + + * config/i386/i386.c (x86_output_mi_thunk): Fix x86_64 pic jump. + 2002-10-24 Kazu Hirata * config/h8300/h8300.c (initial_offset): Simplify by using diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c index 4b13c46..f950198 100644 --- a/gcc/config/i386/i386.c +++ b/gcc/config/i386/i386.c @@ -14233,7 +14233,14 @@ x86_output_mi_thunk (file, thunk, delta, vcall_offset, function) if (!flag_pic || (*targetm.binds_local_p) (function)) output_asm_insn ("jmp\t%P0", xops); else - output_asm_insn ("jmp\t*%P0@GOTPCREL(%%rip)", xops); + { + tmp = XEXP (xops[0], 0); + tmp = gen_rtx_UNSPEC (Pmode, gen_rtvec (1, tmp), UNSPEC_GOTPCREL); + tmp = gen_rtx_CONST (Pmode, tmp); + tmp = gen_rtx_MEM (QImode, tmp); + xops[0] = tmp; + output_asm_insn ("jmp\t%A0", xops); + } } else {