summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordim <dim@FreeBSD.org>2012-01-20 19:18:11 +0000
committerdim <dim@FreeBSD.org>2012-01-20 19:18:11 +0000
commitd337cd8b79286df5494262294a0d9559f789b64e (patch)
tree1b0685cf17992cd077accdef28092dab5fc50ff2
parent6aecdb4cd57cadd8365b973c0a3d819d09f66da4 (diff)
downloadFreeBSD-src-d337cd8b79286df5494262294a0d9559f789b64e.zip
FreeBSD-src-d337cd8b79286df5494262294a0d9559f789b64e.tar.gz
Pull in r148240 from upstream llvm trunk:
Make sure the non-SSE lowering for fences correctly clobbers EFLAGS. PR11768. In particular, this fixes segfaults during the build of devel/icu on i386. The __sync_synchronize() builtin used for implementing icu's internal barrier could lead to incorrect behaviour. MFC after: 3 days
-rw-r--r--contrib/llvm/lib/Target/X86/X86InstrCompiler.td2
1 files changed, 1 insertions, 1 deletions
diff --git a/contrib/llvm/lib/Target/X86/X86InstrCompiler.td b/contrib/llvm/lib/Target/X86/X86InstrCompiler.td
index da28690..612b2fa 100644
--- a/contrib/llvm/lib/Target/X86/X86InstrCompiler.td
+++ b/contrib/llvm/lib/Target/X86/X86InstrCompiler.td
@@ -533,7 +533,7 @@ def ATOMSWAP6432 : I<0, Pseudo, (outs GR32:$dst1, GR32:$dst2),
// Memory barriers
// TODO: Get this to fold the constant into the instruction.
-let isCodeGenOnly = 1 in
+let isCodeGenOnly = 1, Defs = [EFLAGS] in
def OR32mrLocked : I<0x09, MRMDestMem, (outs), (ins i32mem:$dst, GR32:$zero),
"lock\n\t"
"or{l}\t{$zero, $dst|$dst, $zero}",
OpenPOWER on IntegriCloud