Hi All, The previous fix for this problem was wrong due to a subtle difference between where NEON expects the RMW values and where intrinsics expects them.
The insn pattern is modeled after the intrinsics and so needs an expand for the vectorizer optab to switch the RTL. However operand[3] is not expected to be written to so the current pattern is bogus. Instead we use the expand to shuffle around the RTL. The vectorizer expects operands[3] and operands[0] to be the same but the aarch64 intrinsics expanders expect operands[0] and operands[1] to be the same. arm-none-linux-gnueabihf build is currently broken, the best I could do is verify on arm-none-eabi but the tests are all marked UNSUPPORTED, but the ICE is gone for the backend test. Ok for master? and active branches after some stew? Thanks, Tamar gcc/ChangeLog: * config/arm/neon.md (<sup>dot_prod<vsi2qi>): Correct RTL. --- inline copy of patch -- diff --git a/gcc/config/arm/neon.md b/gcc/config/arm/neon.md index 8b0a396947cc8e7345f178b926128d7224fb218a..876577fc20daee30ecdf03942c0d81c15bf8fe9a 100644 --- a/gcc/config/arm/neon.md +++ b/gcc/config/arm/neon.md @@ -2954,20 +2954,14 @@ (define_insn "neon_<sup>dot_lane<vsi2qi>" ;; and so the vectorizer provides r, in which the result has to be accumulated. (define_expand "<sup>dot_prod<vsi2qi>" [(set (match_operand:VCVTI 0 "register_operand") - (plus:VCVTI (unspec:VCVTI [(match_operand:<VSI2QI> 1 + (plus:VCVTI (match_operand:VCVTI 3 "register_operand") + (unspec:VCVTI [(match_operand:<VSI2QI> 1 "register_operand") (match_operand:<VSI2QI> 2 "register_operand")] - DOTPROD) - (match_operand:VCVTI 3 "register_operand")))] + DOTPROD)))] "TARGET_DOTPROD" -{ - emit_insn ( - gen_neon_<sup>dot<vsi2qi> (operands[3], operands[3], operands[1], - operands[2])); - emit_insn (gen_rtx_SET (operands[0], operands[3])); - DONE; -}) +) ;; Auto-vectorizer pattern for usdot (define_expand "usdot_prod<vsi2qi>" --
diff --git a/gcc/config/arm/neon.md b/gcc/config/arm/neon.md index 8b0a396947cc8e7345f178b926128d7224fb218a..876577fc20daee30ecdf03942c0d81c15bf8fe9a 100644 --- a/gcc/config/arm/neon.md +++ b/gcc/config/arm/neon.md @@ -2954,20 +2954,14 @@ (define_insn "neon_<sup>dot_lane<vsi2qi>" ;; and so the vectorizer provides r, in which the result has to be accumulated. (define_expand "<sup>dot_prod<vsi2qi>" [(set (match_operand:VCVTI 0 "register_operand") - (plus:VCVTI (unspec:VCVTI [(match_operand:<VSI2QI> 1 + (plus:VCVTI (match_operand:VCVTI 3 "register_operand") + (unspec:VCVTI [(match_operand:<VSI2QI> 1 "register_operand") (match_operand:<VSI2QI> 2 "register_operand")] - DOTPROD) - (match_operand:VCVTI 3 "register_operand")))] + DOTPROD)))] "TARGET_DOTPROD" -{ - emit_insn ( - gen_neon_<sup>dot<vsi2qi> (operands[3], operands[3], operands[1], - operands[2])); - emit_insn (gen_rtx_SET (operands[0], operands[3])); - DONE; -}) +) ;; Auto-vectorizer pattern for usdot (define_expand "usdot_prod<vsi2qi>"