From: Jakub Jelinek Date: Thu, 20 Mar 2014 16:10:33 +0000 (+0100) Subject: re PR target/60568 (lto1: internal compiler error: in insn_min_length, at config... X-Git-Tag: releases/gcc-4.8.3~244 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=faa2c177f2209d24246b887e21fd61c12340a971;p=thirdparty%2Fgcc.git re PR target/60568 (lto1: internal compiler error: in insn_min_length, at config/i386/i386.md:1599) PR target/60568 * config/i386/i386.c (x86_output_mi_thunk): Surround UNSPEC_GOT into CONST, put pic register as first operand of PLUS. Use gen_const_mem for both 32-bit and 64-bit PIC got loads. From-SVN: r208707 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ff4c501e4099..5026d0c16f09 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2014-03-20 Jakub Jelinek + + PR target/60568 + * config/i386/i386.c (x86_output_mi_thunk): Surround UNSPEC_GOT + into CONST, put pic register as first operand of PLUS. Use + gen_const_mem for both 32-bit and 64-bit PIC got loads. + 2014-03-20 Eric Botcazou * config/sparc/sparc.c (sparc_do_work_around_errata): Implement work diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c index a6414c45d85b..402dec8d9d6a 100644 --- a/gcc/config/i386/i386.c +++ b/gcc/config/i386/i386.c @@ -35053,7 +35053,7 @@ x86_output_mi_thunk (FILE *file, { tmp = gen_rtx_UNSPEC (Pmode, gen_rtvec (1, fnaddr), UNSPEC_GOTPCREL); tmp = gen_rtx_CONST (Pmode, tmp); - fnaddr = gen_rtx_MEM (Pmode, tmp); + fnaddr = gen_const_mem (Pmode, tmp); } } else @@ -35073,8 +35073,9 @@ x86_output_mi_thunk (FILE *file, output_set_got (tmp, NULL_RTX); fnaddr = gen_rtx_UNSPEC (Pmode, gen_rtvec (1, fnaddr), UNSPEC_GOT); - fnaddr = gen_rtx_PLUS (Pmode, fnaddr, tmp); - fnaddr = gen_rtx_MEM (Pmode, fnaddr); + fnaddr = gen_rtx_CONST (Pmode, fnaddr); + fnaddr = gen_rtx_PLUS (Pmode, tmp, fnaddr); + fnaddr = gen_const_mem (Pmode, fnaddr); } }