From: Jakub Jelinek Date: Wed, 7 May 2014 15:54:34 +0000 (+0200) Subject: backport: re PR target/57623 (BEXTR intrinsic has memory operands switched around... X-Git-Tag: releases/gcc-4.7.4~109 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=bc5874827e3fc7ae863a6172737d4e288b005eec;p=thirdparty%2Fgcc.git backport: re PR target/57623 (BEXTR intrinsic has memory operands switched around (fails to compile code)) Backported from mainline 2013-06-27 Jakub Jelinek PR target/57623 * config/i386/i386.md (bmi2_bzhi_3): Swap AND arguments to match RTL canonicalization. Swap predicates and constraints of operand 1 and 2. * gcc.target/i386/bmi2-bzhi-1.c: New test. From-SVN: r210166 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8e1bbfc8083d..90a411b8969c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,13 @@ +2014-05-07 Jakub Jelinek + + Backported from mainline + 2013-06-27 Jakub Jelinek + + PR target/57623 + * config/i386/i386.md (bmi2_bzhi_3): Swap AND arguments + to match RTL canonicalization. Swap predicates and + constraints of operand 1 and 2. + 2014-05-07 Richard Biener Backport from mainline diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md index f85f17af1a1b..781e671036d4 100644 --- a/gcc/config/i386/i386.md +++ b/gcc/config/i386/i386.md @@ -12127,9 +12127,9 @@ ;; BMI2 instructions. (define_insn "bmi2_bzhi_3" [(set (match_operand:SWI48 0 "register_operand" "=r") - (and:SWI48 (match_operand:SWI48 1 "register_operand" "r") - (lshiftrt:SWI48 (const_int -1) - (match_operand:SWI48 2 "nonimmediate_operand" "rm")))) + (and:SWI48 (lshiftrt:SWI48 (const_int -1) + (match_operand:SWI48 2 "register_operand" "r")) + (match_operand:SWI48 1 "nonimmediate_operand" "rm"))) (clobber (reg:CC FLAGS_REG))] "TARGET_BMI2" "bzhi\t{%2, %1, %0|%0, %1, %2}" diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9ae3e94ca1f6..897dfbcc0866 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2014-05-07 Jakub Jelinek + + Backported from mainline + 2013-06-27 Jakub Jelinek + + PR target/57623 + * gcc.target/i386/bmi2-bzhi-1.c: New test. + 2014-05-07 Richard Biener Backport from mainline diff --git a/gcc/testsuite/gcc.target/i386/bmi2-bzhi-1.c b/gcc/testsuite/gcc.target/i386/bmi2-bzhi-1.c new file mode 100644 index 000000000000..42e002d06304 --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/bmi2-bzhi-1.c @@ -0,0 +1,31 @@ +/* PR target/57623 */ +/* { dg-do assemble { target bmi2 } } */ +/* { dg-options "-O2 -mbmi2" } */ + +#include + +unsigned int +f1 (unsigned int x, unsigned int *y) +{ + return _bzhi_u32 (x, *y); +} + +unsigned int +f2 (unsigned int *x, unsigned int y) +{ + return _bzhi_u32 (*x, y); +} + +#ifdef __x86_64__ +unsigned long long +f3 (unsigned long long x, unsigned long long *y) +{ + return _bzhi_u64 (x, *y); +} + +unsigned long long +f4 (unsigned long long *x, unsigned long long y) +{ + return _bzhi_u64 (*x, y); +} +#endif