gcc: add patch for aarch64 to not ICE on mysql.
This commit is contained in:
parent
2205b64714
commit
c5680ed072
71
srcpkgs/gcc/patches/gcc-4.9-aarch64-local-atomic.patch
Normal file
71
srcpkgs/gcc/patches/gcc-4.9-aarch64-local-atomic.patch
Normal file
@ -0,0 +1,71 @@
|
||||
https://gcc.gnu.org/ml/gcc-patches/2014-09/msg02209.html
|
||||
via https://gcc.gnu.org/ml/gcc-patches/2014-12/msg01844.html
|
||||
|
||||
--- gcc/config/aarch64/iterators.md 2014-09-22 10:10:04.520258964 -0700
|
||||
+++ gcc/config/aarch64/iterators.md 2014-09-16 14:27:10.459050672 -0700
|
||||
@@ -349,6 +349,9 @@
|
||||
;; Attribute to describe constants acceptable in logical operations
|
||||
(define_mode_attr lconst [(SI "K") (DI "L")])
|
||||
|
||||
+;; Attribute to describe constants acceptable in atomic logical operations
|
||||
+(define_mode_attr lconst_atomic [(QI "K") (HI "K") (SI "K") (DI "L")])
|
||||
+
|
||||
;; Map a mode to a specific constraint character.
|
||||
(define_mode_attr cmode [(QI "q") (HI "h") (SI "s") (DI "d")])
|
||||
|
||||
--- gcc/config/aarch64/atomics.md 2014-07-03 21:55:36.083476668 -0700
|
||||
+++ gcc/config/aarch64/atomics.md 2014-09-16 14:27:10.459050672 -0700
|
||||
@@ -119,7 +119,7 @@
|
||||
[(set (match_operand:ALLI 0 "aarch64_sync_memory_operand" "+Q")
|
||||
(unspec_volatile:ALLI
|
||||
[(atomic_op:ALLI (match_dup 0)
|
||||
- (match_operand:ALLI 1 "<atomic_op_operand>" "rn"))
|
||||
+ (match_operand:ALLI 1 "<atomic_op_operand>" "r<lconst_atomic>"))
|
||||
(match_operand:SI 2 "const_int_operand")] ;; model
|
||||
UNSPECV_ATOMIC_OP))
|
||||
(clobber (reg:CC CC_REGNUM))
|
||||
@@ -141,7 +141,7 @@
|
||||
(unspec_volatile:ALLI
|
||||
[(not:ALLI
|
||||
(and:ALLI (match_dup 0)
|
||||
- (match_operand:ALLI 1 "aarch64_logical_operand" "rn")))
|
||||
+ (match_operand:ALLI 1 "aarch64_logical_operand" "r<lconst_atomic>")))
|
||||
(match_operand:SI 2 "const_int_operand")] ;; model
|
||||
UNSPECV_ATOMIC_OP))
|
||||
(clobber (reg:CC CC_REGNUM))
|
||||
@@ -164,7 +164,7 @@
|
||||
(set (match_dup 1)
|
||||
(unspec_volatile:ALLI
|
||||
[(atomic_op:ALLI (match_dup 1)
|
||||
- (match_operand:ALLI 2 "<atomic_op_operand>" "rn"))
|
||||
+ (match_operand:ALLI 2 "<atomic_op_operand>" "r<lconst_atomic>"))
|
||||
(match_operand:SI 3 "const_int_operand")] ;; model
|
||||
UNSPECV_ATOMIC_OP))
|
||||
(clobber (reg:CC CC_REGNUM))
|
||||
@@ -188,7 +188,7 @@
|
||||
(unspec_volatile:ALLI
|
||||
[(not:ALLI
|
||||
(and:ALLI (match_dup 1)
|
||||
- (match_operand:ALLI 2 "aarch64_logical_operand" "rn")))
|
||||
+ (match_operand:ALLI 2 "aarch64_logical_operand" "r<lconst_atomic>")))
|
||||
(match_operand:SI 3 "const_int_operand")] ;; model
|
||||
UNSPECV_ATOMIC_OP))
|
||||
(clobber (reg:CC CC_REGNUM))
|
||||
@@ -209,7 +209,7 @@
|
||||
[(set (match_operand:ALLI 0 "register_operand" "=&r")
|
||||
(atomic_op:ALLI
|
||||
(match_operand:ALLI 1 "aarch64_sync_memory_operand" "+Q")
|
||||
- (match_operand:ALLI 2 "<atomic_op_operand>" "rn")))
|
||||
+ (match_operand:ALLI 2 "<atomic_op_operand>" "r<lconst_atomic>")))
|
||||
(set (match_dup 1)
|
||||
(unspec_volatile:ALLI
|
||||
[(match_dup 1) (match_dup 2)
|
||||
@@ -233,7 +233,7 @@
|
||||
(not:ALLI
|
||||
(and:ALLI
|
||||
(match_operand:ALLI 1 "aarch64_sync_memory_operand" "+Q")
|
||||
- (match_operand:ALLI 2 "aarch64_logical_operand" "rn"))))
|
||||
+ (match_operand:ALLI 2 "aarch64_logical_operand" "r<lconst_atomic>"))))
|
||||
(set (match_dup 1)
|
||||
(unspec_volatile:ALLI
|
||||
[(match_dup 1) (match_dup 2)
|
Loading…
Reference in New Issue
Block a user