https://gcc.gnu.org/bugzilla/show_bug.cgi?id=89222
--- Comment #11 from Wilco <wilco at gcc dot gnu.org> --- Author: wilco Date: Tue Jul 16 13:13:26 2019 New Revision: 273527 URL: https://gcc.gnu.org/viewcvs?rev=273527&root=gcc&view=rev Log: [ARM] Fix PR89222 The GCC optimizer can generate symbols with non-zero offset from simple if-statements. Bit zero is used for the Arm/Thumb state bit, so relocations with offsets fail if it changes bit zero and the relocation forces bit zero to true. The fix is to disable offsets on function pointer symbols. gcc/ PR target/89222 * config/arm/arm.md (movsi): Use targetm.cannot_force_const_mem to decide when to split off a non-zero offset from a symbol. * config/arm/arm.c (arm_cannot_force_const_mem): Disallow offsets in function symbols. testsuite/ PR target/89222 * gcc.target/arm/pr89222.c: Add new test. Added: branches/gcc-7-branch/gcc/testsuite/gcc.target/arm/pr89222.c Modified: branches/gcc-7-branch/gcc/ChangeLog branches/gcc-7-branch/gcc/config/arm/arm.c branches/gcc-7-branch/gcc/config/arm/arm.md branches/gcc-7-branch/gcc/testsuite/ChangeLog