mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Add a convenience method to tell if two things are equal.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@140946 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3320f2a3bf
commit
405ca137a1
@ -69,9 +69,7 @@ int ARMConstantPoolValue::getExistingMachineCPValue(MachineConstantPool *CP,
|
|||||||
(Constants[i].getAlignment() & AlignMask) == 0) {
|
(Constants[i].getAlignment() & AlignMask) == 0) {
|
||||||
ARMConstantPoolValue *CPV =
|
ARMConstantPoolValue *CPV =
|
||||||
(ARMConstantPoolValue *)Constants[i].Val.MachineCPVal;
|
(ARMConstantPoolValue *)Constants[i].Val.MachineCPVal;
|
||||||
if (CPV->LabelId == LabelId &&
|
if (this->equals(CPV))
|
||||||
CPV->PCAdjust == PCAdjust &&
|
|
||||||
CPV->Modifier == Modifier)
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -186,11 +184,7 @@ int ARMConstantPoolConstant::getExistingMachineCPValue(MachineConstantPool *CP,
|
|||||||
(ARMConstantPoolValue *)Constants[i].Val.MachineCPVal;
|
(ARMConstantPoolValue *)Constants[i].Val.MachineCPVal;
|
||||||
ARMConstantPoolConstant *APC = dyn_cast<ARMConstantPoolConstant>(CPV);
|
ARMConstantPoolConstant *APC = dyn_cast<ARMConstantPoolConstant>(CPV);
|
||||||
if (!APC) continue;
|
if (!APC) continue;
|
||||||
|
if (APC->CVal == CVal && equals(APC))
|
||||||
if (APC->getGV() == this->CVal &&
|
|
||||||
APC->getLabelId() == this->getLabelId() &&
|
|
||||||
APC->getPCAdjustment() == this->getPCAdjustment() &&
|
|
||||||
APC->getModifier() == this->getModifier())
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -256,10 +250,7 @@ int ARMConstantPoolSymbol::getExistingMachineCPValue(MachineConstantPool *CP,
|
|||||||
ARMConstantPoolSymbol *APS = dyn_cast<ARMConstantPoolSymbol>(CPV);
|
ARMConstantPoolSymbol *APS = dyn_cast<ARMConstantPoolSymbol>(CPV);
|
||||||
if (!APS) continue;
|
if (!APS) continue;
|
||||||
|
|
||||||
if (APS->getLabelId() == this->getLabelId() &&
|
if (CPV_streq(APS->S, S) && equals(APS))
|
||||||
APS->getPCAdjustment() == this->getPCAdjustment() &&
|
|
||||||
CPV_streq(APS->getSymbol(), this->getSymbol()) &&
|
|
||||||
APS->getModifier() == this->getModifier())
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -315,10 +306,7 @@ int ARMConstantPoolMBB::getExistingMachineCPValue(MachineConstantPool *CP,
|
|||||||
ARMConstantPoolMBB *APMBB = dyn_cast<ARMConstantPoolMBB>(CPV);
|
ARMConstantPoolMBB *APMBB = dyn_cast<ARMConstantPoolMBB>(CPV);
|
||||||
if (!APMBB) continue;
|
if (!APMBB) continue;
|
||||||
|
|
||||||
if (APMBB->getLabelId() == this->getLabelId() &&
|
if (APMBB->MBB == MBB && equals(APMBB))
|
||||||
APMBB->getPCAdjustment() == this->getPCAdjustment() &&
|
|
||||||
APMBB->getMBB() == this->getMBB() &&
|
|
||||||
APMBB->getModifier() == this->getModifier())
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -93,6 +93,12 @@ public:
|
|||||||
/// constantpool entry as another ARM constpool value.
|
/// constantpool entry as another ARM constpool value.
|
||||||
virtual bool hasSameValue(ARMConstantPoolValue *ACPV);
|
virtual bool hasSameValue(ARMConstantPoolValue *ACPV);
|
||||||
|
|
||||||
|
bool equals(const ARMConstantPoolValue *A) const {
|
||||||
|
return this->LabelId == A->LabelId &&
|
||||||
|
this->PCAdjust == A->PCAdjust &&
|
||||||
|
this->Modifier == A->Modifier;
|
||||||
|
}
|
||||||
|
|
||||||
virtual void print(raw_ostream &O) const;
|
virtual void print(raw_ostream &O) const;
|
||||||
void print(raw_ostream *O) const { if (O) print(*O); }
|
void print(raw_ostream *O) const { if (O) print(*O); }
|
||||||
void dump() const;
|
void dump() const;
|
||||||
|
Loading…
Reference in New Issue
Block a user