ARM assembly parsing for 'msr' plain 'cpsr' operand.
[oota-llvm.git] / lib / Target / ARM / AsmParser / ARMAsmParser.cpp
index 0729da1a8ea20c27768225ac4f035d740aedc3c8..a558a61592f5b3e43c474ede6653e56c5347d9f4 100644 (file)
@@ -3328,7 +3328,8 @@ parseMSRMaskOperand(SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
         FlagsVal = 8; // No flag
     }
   } else if (SpecReg == "cpsr" || SpecReg == "spsr") {
-    if (Flags == "all") // cpsr_all is an alias for cpsr_fc
+    // cpsr_all is an alias for cpsr_fc, as is plain cpsr.
+    if (Flags == "all" || Flags == "")
       Flags = "fc";
     for (int i = 0, e = Flags.size(); i != e; ++i) {
       unsigned Flag = StringSwitch<unsigned>(Flags.substr(i, 1))