diff options
author | Tim Northover <tnorthover@apple.com> | 2013-08-28 14:39:19 +0000 |
---|---|---|
committer | Tim Northover <tnorthover@apple.com> | 2013-08-28 14:39:19 +0000 |
commit | 22266c1d4817fc30355a90bb264ede08482bba3a (patch) | |
tree | a45dbfb4e64a237b8382aef5f2872d7c4ed4e882 /lib/Target/ARM | |
parent | bafb5f8d9f415340d9035ee9430f9480da9a50fb (diff) | |
download | external_llvm-22266c1d4817fc30355a90bb264ede08482bba3a.zip external_llvm-22266c1d4817fc30355a90bb264ede08482bba3a.tar.gz external_llvm-22266c1d4817fc30355a90bb264ede08482bba3a.tar.bz2 |
ARM: Use "dmb sy" for barriers on M-class CPUs
The usual default of "dmb ish" (inner-shareable) isn't even a valid instruction
on v6M or v7M (well, it does the same thing but software is strongly
discouraged from using it) so we should emit a full-system barrier there.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@189483 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM')
-rw-r--r-- | lib/Target/ARM/ARMISelLowering.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/lib/Target/ARM/ARMISelLowering.cpp b/lib/Target/ARM/ARMISelLowering.cpp index 74353c1..063f1d4 100644 --- a/lib/Target/ARM/ARMISelLowering.cpp +++ b/lib/Target/ARM/ARMISelLowering.cpp @@ -2600,7 +2600,10 @@ static SDValue LowerATOMIC_FENCE(SDValue Op, SelectionDAG &DAG, ConstantSDNode *OrdN = cast<ConstantSDNode>(Op.getOperand(1)); AtomicOrdering Ord = static_cast<AtomicOrdering>(OrdN->getZExtValue()); unsigned Domain = ARM_MB::ISH; - if (Subtarget->isSwift() && Ord == Release) { + if (Subtarget->isMClass()) { + // Only a full system barrier exists in the M-class architectures. + Domain = ARM_MB::SY; + } else if (Subtarget->isSwift() && Ord == Release) { // Swift happens to implement ISHST barriers in a way that's compatible with // Release semantics but weaker than ISH so we'd be fools not to use // it. Beware: other processors probably don't! |