always be disambiguated as sldtw. sldtw and sldtq with
a mem operands have the same effect, but sldtw is more
compact. Force it to sldtw, resolving rdar://
8017530
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@113186
91177308-0d34-0410-b5e6-
96231b3b80d8
Operands.push_back(X86Operand::CreateReg(Op->getReg(), Op->getStartLoc(),
Op->getEndLoc()));
}
+
+ // 'sldt <mem>' can be encoded with either sldtw or sldtq with the same
+ // effect (both store to a 16-bit mem). Force to sldtw to avoid ambiguity
+ // errors, since its encoding is the most compact.
+ if (Name == "sldt" && Operands.size() == 2 &&
+ static_cast<X86Operand*>(Operands[1])->isMem())
+ Operands[0] = X86Operand::CreateToken("sldtw", NameLoc);
return false;
}
// CHECK: pushq $1
push $1
+// rdar://8017530
+// CHECK: sldtw 4
+sldt 4