forked from OSchip/llvm-project
[hexagon] Distinguish the 'o', 'v', and 'm' inline assembly memory constraints.
Summary: But still handle them the same way since I don't know how they differ on this target. No functional change intended. Reviewers: kparzysz, adasgupt Reviewed By: kparzysz, adasgupt Subscribers: colinl, llvm-commits Differential Revision: http://reviews.llvm.org/D8204 llvm-svn: 232374
This commit is contained in:
parent
bf5b80f5f9
commit
b2d0c02451
|
@ -240,8 +240,8 @@ public:
|
|||
// constraint codes for all targets.
|
||||
Constraint_Unknown = 0,
|
||||
Constraint_m,
|
||||
Constraint_o, // Unused at the moment since Constraint_m is always used.
|
||||
Constraint_v, // Unused at the moment since Constraint_m is always used.
|
||||
Constraint_o,
|
||||
Constraint_v,
|
||||
Constraints_Max = Constraint_v,
|
||||
Constraints_ShiftAmount = 16,
|
||||
|
||||
|
|
|
@ -1108,11 +1108,11 @@ SelectInlineAsmMemoryOperand(const SDValue &Op, unsigned ConstraintID,
|
|||
SDValue Inp = Op, Res;
|
||||
|
||||
switch (ConstraintID) {
|
||||
case InlineAsm::Constraint_o: // Offsetable.
|
||||
case InlineAsm::Constraint_v: // Not offsetable.
|
||||
default:
|
||||
return true;
|
||||
case InlineAsm::Constraint_m: // Memory.
|
||||
case InlineAsm::Constraint_o: // Offsetable.
|
||||
case InlineAsm::Constraint_v: // Not offsetable.
|
||||
case InlineAsm::Constraint_m: // Memory.
|
||||
if (SelectAddrFI(Inp, Res))
|
||||
OutOps.push_back(Res);
|
||||
else
|
||||
|
|
|
@ -185,8 +185,11 @@ bool isPositiveHalfWord(SDNode *N);
|
|||
|
||||
unsigned getInlineAsmMemConstraint(
|
||||
const std::string &ConstraintCode) const override {
|
||||
// FIXME: Map different constraints differently.
|
||||
return InlineAsm::Constraint_m;
|
||||
if (ConstraintCode == "o")
|
||||
return InlineAsm::Constraint_o;
|
||||
else if (ConstraintCode == "v")
|
||||
return InlineAsm::Constraint_v;
|
||||
return TargetLowering::getInlineAsmMemConstraint(ConstraintCode);
|
||||
}
|
||||
|
||||
// Intrinsics
|
||||
|
|
Loading…
Reference in New Issue