sync.md (atomic_loaddi_1): Disable predication for arm_restrict_it.
2013-06-06 Kyrylo Tkachov <kyrylo.tkachov@arm.com> * config/arm/sync.md (atomic_loaddi_1): Disable predication for arm_restrict_it. (arm_load_exclusive<mode>): Likewise. (arm_load_exclusivesi): Likewise. (arm_load_exclusivedi): Likewise. (arm_load_acquire_exclusive<mode>): Likewise. (arm_load_acquire_exclusivesi): Likewise. (arm_load_acquire_exclusivedi): Likewise. (arm_store_exclusive<mode>): Likewise. (arm_store_exclusive<mode>): Likewise. (arm_store_release_exclusivedi): Likewise. (arm_store_release_exclusive<mode>): Likewise. From-SVN: r199733
This commit is contained in:
parent
15d16c8aeb
commit
12b4e7ef74
@ -1,3 +1,18 @@
|
||||
2013-06-06 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
|
||||
|
||||
* config/arm/sync.md (atomic_loaddi_1):
|
||||
Disable predication for arm_restrict_it.
|
||||
(arm_load_exclusive<mode>): Likewise.
|
||||
(arm_load_exclusivesi): Likewise.
|
||||
(arm_load_exclusivedi): Likewise.
|
||||
(arm_load_acquire_exclusive<mode>): Likewise.
|
||||
(arm_load_acquire_exclusivesi): Likewise.
|
||||
(arm_load_acquire_exclusivedi): Likewise.
|
||||
(arm_store_exclusive<mode>): Likewise.
|
||||
(arm_store_exclusive<mode>): Likewise.
|
||||
(arm_store_release_exclusivedi): Likewise.
|
||||
(arm_store_release_exclusive<mode>): Likewise.
|
||||
|
||||
2013-06-06 Richard Biener <rguenther@suse.de>
|
||||
|
||||
* lto-streamer.h (enum LTO_tags): Move LTO_tree_pickle_reference
|
||||
|
@ -124,7 +124,8 @@
|
||||
UNSPEC_LL))]
|
||||
"TARGET_HAVE_LDREXD && ARM_DOUBLEWORD_ALIGN"
|
||||
"ldrexd%?\t%0, %H0, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_expand "atomic_compare_and_swap<mode>"
|
||||
[(match_operand:SI 0 "s_register_operand" "") ;; bool out
|
||||
@ -361,7 +362,8 @@
|
||||
VUNSPEC_LL)))]
|
||||
"TARGET_HAVE_LDREXBH"
|
||||
"ldrex<sync_sfx>%?\t%0, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_load_acquire_exclusive<mode>"
|
||||
[(set (match_operand:SI 0 "s_register_operand" "=r")
|
||||
@ -371,7 +373,8 @@
|
||||
VUNSPEC_LAX)))]
|
||||
"TARGET_HAVE_LDACQ"
|
||||
"ldaex<sync_sfx>%?\\t%0, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_load_exclusivesi"
|
||||
[(set (match_operand:SI 0 "s_register_operand" "=r")
|
||||
@ -380,7 +383,8 @@
|
||||
VUNSPEC_LL))]
|
||||
"TARGET_HAVE_LDREX"
|
||||
"ldrex%?\t%0, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_load_acquire_exclusivesi"
|
||||
[(set (match_operand:SI 0 "s_register_operand" "=r")
|
||||
@ -389,7 +393,8 @@
|
||||
VUNSPEC_LAX))]
|
||||
"TARGET_HAVE_LDACQ"
|
||||
"ldaex%?\t%0, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_load_exclusivedi"
|
||||
[(set (match_operand:DI 0 "s_register_operand" "=r")
|
||||
@ -398,7 +403,8 @@
|
||||
VUNSPEC_LL))]
|
||||
"TARGET_HAVE_LDREXD"
|
||||
"ldrexd%?\t%0, %H0, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_load_acquire_exclusivedi"
|
||||
[(set (match_operand:DI 0 "s_register_operand" "=r")
|
||||
@ -407,7 +413,8 @@
|
||||
VUNSPEC_LAX))]
|
||||
"TARGET_HAVE_LDACQ && ARM_DOUBLEWORD_ALIGN"
|
||||
"ldaexd%?\t%0, %H0, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_store_exclusive<mode>"
|
||||
[(set (match_operand:SI 0 "s_register_operand" "=&r")
|
||||
@ -431,7 +438,8 @@
|
||||
}
|
||||
return "strex<sync_sfx>%?\t%0, %2, %C1";
|
||||
}
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_store_release_exclusivedi"
|
||||
[(set (match_operand:SI 0 "s_register_operand" "=&r")
|
||||
@ -448,7 +456,8 @@
|
||||
operands[3] = gen_rtx_REG (SImode, REGNO (value) + 1);
|
||||
return "stlexd%?\t%0, %2, %3, %C1";
|
||||
}
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
||||
(define_insn "arm_store_release_exclusive<mode>"
|
||||
[(set (match_operand:SI 0 "s_register_operand" "=&r")
|
||||
@ -459,4 +468,5 @@
|
||||
VUNSPEC_SLX))]
|
||||
"TARGET_HAVE_LDACQ"
|
||||
"stlex<sync_sfx>%?\t%0, %2, %C1"
|
||||
[(set_attr "predicable" "yes")])
|
||||
[(set_attr "predicable" "yes")
|
||||
(set_attr "predicable_short_it" "no")])
|
||||
|
Loading…
Reference in New Issue
Block a user