[TableGen][GlobalISel] Make the arguments of the Instruction and Operand Matchers consistent

Move InsnVarID and OpIdx at the beginning of the list of arguments
for all the constructors of the OperandMatcher subclasses.
This matches what we do for the InstructionMatcher.

NFC.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@321031 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Quentin Colombet 2017-12-18 22:12:13 +00:00
parent b43be724f7
commit df42abc90b

View File

@ -931,7 +931,7 @@ class SameOperandMatcher : public OperandPredicateMatcher {
std::string MatchingName; std::string MatchingName;
public: public:
SameOperandMatcher(StringRef MatchingName, unsigned InsnVarID, unsigned OpIdx) SameOperandMatcher(unsigned InsnVarID, unsigned OpIdx, StringRef MatchingName)
: OperandPredicateMatcher(OPM_SameOperand, InsnVarID, OpIdx), : OperandPredicateMatcher(OPM_SameOperand, InsnVarID, OpIdx),
MatchingName(MatchingName) {} MatchingName(MatchingName) {}
@ -951,7 +951,7 @@ protected:
public: public:
static std::set<LLTCodeGen> KnownTypes; static std::set<LLTCodeGen> KnownTypes;
LLTOperandMatcher(const LLTCodeGen &Ty, unsigned InsnVarID, unsigned OpIdx) LLTOperandMatcher(unsigned InsnVarID, unsigned OpIdx, const LLTCodeGen &Ty)
: OperandPredicateMatcher(OPM_LLT, InsnVarID, OpIdx), Ty(Ty) { : OperandPredicateMatcher(OPM_LLT, InsnVarID, OpIdx), Ty(Ty) {
KnownTypes.insert(Ty); KnownTypes.insert(Ty);
} }
@ -991,8 +991,8 @@ protected:
unsigned SizeInBits; unsigned SizeInBits;
public: public:
PointerToAnyOperandMatcher(unsigned SizeInBits, unsigned InsnVarID, PointerToAnyOperandMatcher(unsigned InsnVarID, unsigned OpIdx,
unsigned OpIdx) unsigned SizeInBits)
: OperandPredicateMatcher(OPM_PointerToAny, InsnVarID, OpIdx), : OperandPredicateMatcher(OPM_PointerToAny, InsnVarID, OpIdx),
SizeInBits(SizeInBits) {} SizeInBits(SizeInBits) {}
@ -1021,9 +1021,9 @@ protected:
public: public:
bool isIdentical(const PredicateMatcher &B) const override { return false; } bool isIdentical(const PredicateMatcher &B) const override { return false; }
ComplexPatternOperandMatcher(const OperandMatcher &Operand, ComplexPatternOperandMatcher(unsigned InsnVarID, unsigned OpIdx,
const Record &TheDef, unsigned InsnVarID, const OperandMatcher &Operand,
unsigned OpIdx) const Record &TheDef)
: OperandPredicateMatcher(OPM_ComplexPattern, InsnVarID, OpIdx), : OperandPredicateMatcher(OPM_ComplexPattern, InsnVarID, OpIdx),
Operand(Operand), TheDef(TheDef) {} Operand(Operand), TheDef(TheDef) {}
@ -1053,8 +1053,8 @@ protected:
const CodeGenRegisterClass &RC; const CodeGenRegisterClass &RC;
public: public:
RegisterBankOperandMatcher(const CodeGenRegisterClass &RC, unsigned InsnVarID, RegisterBankOperandMatcher(unsigned InsnVarID, unsigned OpIdx,
unsigned OpIdx) const CodeGenRegisterClass &RC)
: OperandPredicateMatcher(OPM_RegBank, InsnVarID, OpIdx), RC(RC) {} : OperandPredicateMatcher(OPM_RegBank, InsnVarID, OpIdx), RC(RC) {}
bool isIdentical(const PredicateMatcher &B) const override { bool isIdentical(const PredicateMatcher &B) const override {
@ -1102,7 +1102,7 @@ protected:
int64_t Value; int64_t Value;
public: public:
ConstantIntOperandMatcher(int64_t Value, unsigned InsnVarID, unsigned OpIdx) ConstantIntOperandMatcher(unsigned InsnVarID, unsigned OpIdx, int64_t Value)
: OperandPredicateMatcher(OPM_Int, InsnVarID, OpIdx), Value(Value) {} : OperandPredicateMatcher(OPM_Int, InsnVarID, OpIdx), Value(Value) {}
bool isIdentical(const PredicateMatcher &B) const override { bool isIdentical(const PredicateMatcher &B) const override {
@ -1130,7 +1130,7 @@ protected:
int64_t Value; int64_t Value;
public: public:
LiteralIntOperandMatcher(int64_t Value, unsigned InsnVarID, unsigned OpIdx) LiteralIntOperandMatcher(unsigned InsnVarID, unsigned OpIdx, int64_t Value)
: OperandPredicateMatcher(OPM_LiteralInt, InsnVarID, OpIdx), : OperandPredicateMatcher(OPM_LiteralInt, InsnVarID, OpIdx),
Value(Value) {} Value(Value) {}
@ -1158,8 +1158,8 @@ protected:
const CodeGenIntrinsic *II; const CodeGenIntrinsic *II;
public: public:
IntrinsicIDOperandMatcher(const CodeGenIntrinsic *II, unsigned InsnVarID, IntrinsicIDOperandMatcher(unsigned InsnVarID, unsigned OpIdx,
unsigned OpIdx) const CodeGenIntrinsic *II)
: OperandPredicateMatcher(OPM_IntrinsicID, InsnVarID, OpIdx), II(II) {} : OperandPredicateMatcher(OPM_IntrinsicID, InsnVarID, OpIdx), II(II) {}
bool isIdentical(const PredicateMatcher &B) const override { bool isIdentical(const PredicateMatcher &B) const override {
@ -1294,9 +1294,9 @@ PredicateListMatcher<OperandPredicateMatcher>::addPredicate(Args &&... args) {
auto *OpMatcher = static_cast<OperandMatcher *>(this); auto *OpMatcher = static_cast<OperandMatcher *>(this);
if (static_cast<OperandMatcher *>(this)->isSameAsAnotherOperand()) if (static_cast<OperandMatcher *>(this)->isSameAsAnotherOperand())
return None; return None;
Predicates.emplace_back(llvm::make_unique<Kind>( Predicates.emplace_back(llvm::make_unique<Kind>(OpMatcher->getInsnVarID(),
std::forward<Args>(args)..., OpMatcher->getInsnVarID(), OpMatcher->getOperandIndex(),
OpMatcher->getOperandIndex())); std::forward<Args>(args)...));
return static_cast<Kind *>(Predicates.back().get()); return static_cast<Kind *>(Predicates.back().get());
} }
@ -1668,8 +1668,8 @@ protected:
std::unique_ptr<InstructionMatcher> InsnMatcher; std::unique_ptr<InstructionMatcher> InsnMatcher;
public: public:
InstructionOperandMatcher(RuleMatcher &Rule, StringRef SymbolicName, InstructionOperandMatcher(unsigned InsnVarID, unsigned OpIdx,
unsigned InsnVarID, unsigned OpIdx) RuleMatcher &Rule, StringRef SymbolicName)
: OperandPredicateMatcher(OPM_Instruction, InsnVarID, OpIdx), : OperandPredicateMatcher(OPM_Instruction, InsnVarID, OpIdx),
InsnMatcher(new InstructionMatcher(Rule, SymbolicName)) {} InsnMatcher(new InstructionMatcher(Rule, SymbolicName)) {}