From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 67381 invoked by alias); 21 May 2015 21:59:34 -0000 Mailing-List: contact gcc-bugs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-bugs-owner@gcc.gnu.org Received: (qmail 67338 invoked by uid 55); 21 May 2015 21:59:29 -0000 From: "hjl at gcc dot gnu.org" To: gcc-bugs@gcc.gnu.org Subject: [Bug target/66232] -fPIC -fno-plt -mx32 fails to generate indirect branch via GOT Date: Thu, 21 May 2015 21:59:00 -0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: changed X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gcc X-Bugzilla-Component: target X-Bugzilla-Version: 6.0 X-Bugzilla-Keywords: X-Bugzilla-Severity: normal X-Bugzilla-Who: hjl at gcc dot gnu.org X-Bugzilla-Status: UNCONFIRMED X-Bugzilla-Resolution: X-Bugzilla-Priority: P3 X-Bugzilla-Assigned-To: unassigned at gcc dot gnu.org X-Bugzilla-Target-Milestone: --- X-Bugzilla-Flags: X-Bugzilla-Changed-Fields: Message-ID: In-Reply-To: References: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Bugzilla-URL: http://gcc.gnu.org/bugzilla/ Auto-Submitted: auto-generated MIME-Version: 1.0 X-SW-Source: 2015-05/txt/msg01851.txt.bz2 https://gcc.gnu.org/bugzilla/show_bug.cgi?id=66232 --- Comment #4 from hjl at gcc dot gnu.org --- Author: hjl Date: Thu May 21 21:58:57 2015 New Revision: 223505 URL: https://gcc.gnu.org/viewcvs?rev=223505&root=gcc&view=rev Log: Allow indirect branch via GOT slot for x32 X32 doesn't support indirect branch via 32-bit memory slot since indirect branch will load 64-bit address from 64-bit memory slot. Since x32 GOT slot is 64-bit, we should allow indirect branch via GOT slot for x32. gcc/ PR target/66232 * config/i386/constraints.md (Bg): New constraint for GOT memory operand. * config/i386/i386.md (*call_got_x32): New pattern. (*call_value_got_x32): Likewise. * config/i386/predicates.md (GOT_memory_operand): New predicate. gcc/testsuite/ PR target/66232 * gcc.target/i386/pr66232-1.c: New test. * gcc.target/i386/pr66232-2.c: Likewise. * gcc.target/i386/pr66232-3.c: Likewise. * gcc.target/i386/pr66232-4.c: Likewise. * gcc.target/i386/pr66232-5.c: Likewise. Added: trunk/gcc/testsuite/gcc.target/i386/pr66232-1.c trunk/gcc/testsuite/gcc.target/i386/pr66232-2.c trunk/gcc/testsuite/gcc.target/i386/pr66232-3.c trunk/gcc/testsuite/gcc.target/i386/pr66232-4.c trunk/gcc/testsuite/gcc.target/i386/pr66232-5.c Modified: trunk/gcc/ChangeLog trunk/gcc/config/i386/constraints.md trunk/gcc/config/i386/i386.md trunk/gcc/config/i386/predicates.md trunk/gcc/testsuite/ChangeLog