mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
Continued support for field initializer
llvm-svn: 4854
This commit is contained in:
parent
b3385a75b7
commit
29f8466be1
@ -82,6 +82,10 @@ Init *BitsRecTy::convertValue(VarInit *VI) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Init *BitsRecTy::convertValue(FieldInit *VI) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Init *IntRecTy::convertValue(BitsInit *BI) {
|
Init *IntRecTy::convertValue(BitsInit *BI) {
|
||||||
int Result = 0;
|
int Result = 0;
|
||||||
@ -180,10 +184,10 @@ bool BitsInit::printAsVariable(std::ostream &OS) const {
|
|||||||
assert(getNumBits() != 0);
|
assert(getNumBits() != 0);
|
||||||
VarBitInit *FirstBit = dynamic_cast<VarBitInit*>(getBit(0));
|
VarBitInit *FirstBit = dynamic_cast<VarBitInit*>(getBit(0));
|
||||||
if (FirstBit == 0) return true;
|
if (FirstBit == 0) return true;
|
||||||
VarInit *Var = FirstBit->getVariable();
|
TypedInit *Var = FirstBit->getVariable();
|
||||||
|
|
||||||
// Check to make sure the types are compatible.
|
// Check to make sure the types are compatible.
|
||||||
BitsRecTy *Ty = dynamic_cast<BitsRecTy*>(Var->getType());
|
BitsRecTy *Ty = dynamic_cast<BitsRecTy*>(FirstBit->getVariable()->getType());
|
||||||
if (Ty == 0) return true;
|
if (Ty == 0) return true;
|
||||||
if (Ty->getNumBits() != getNumBits()) return true; // Incompatible types!
|
if (Ty->getNumBits() != getNumBits()) return true; // Incompatible types!
|
||||||
|
|
||||||
@ -194,7 +198,7 @@ bool BitsInit::printAsVariable(std::ostream &OS) const {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
OS << Var->getName();
|
Var->print(OS);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -249,7 +253,7 @@ void ListInit::print(std::ostream &OS) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Init *VarInit::convertInitializerBitRange(const std::vector<unsigned> &Bits) {
|
Init *VarInit::convertInitializerBitRange(const std::vector<unsigned> &Bits) {
|
||||||
BitsRecTy *T = dynamic_cast<BitsRecTy*>(Ty);
|
BitsRecTy *T = dynamic_cast<BitsRecTy*>(getType());
|
||||||
if (T == 0) return 0; // Cannot subscript a non-bits variable...
|
if (T == 0) return 0; // Cannot subscript a non-bits variable...
|
||||||
unsigned NumBits = T->getNumBits();
|
unsigned NumBits = T->getNumBits();
|
||||||
|
|
||||||
@ -265,34 +269,65 @@ Init *VarInit::convertInitializerBitRange(const std::vector<unsigned> &Bits) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
RecTy *VarInit::getFieldType(const std::string &FieldName) const {
|
RecTy *VarInit::getFieldType(const std::string &FieldName) const {
|
||||||
if (RecordRecTy *RTy = dynamic_cast<RecordRecTy*>(Ty))
|
if (RecordRecTy *RTy = dynamic_cast<RecordRecTy*>(getType()))
|
||||||
if (const RecordVal *RV = RTy->getRecord()->getValue(FieldName))
|
if (const RecordVal *RV = RTy->getRecord()->getValue(FieldName))
|
||||||
return RV->getType();
|
return RV->getType();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Init *VarInit::resolveBitReference(Record &R, unsigned Bit) {
|
||||||
Init *VarBitInit::resolveReferences(Record &R) {
|
if (R.isTemplateArg(getName()))
|
||||||
if (R.isTemplateArg(getVariable()->getName()))
|
|
||||||
return this;
|
return this;
|
||||||
|
|
||||||
RecordVal *RV = R.getValue(getVariable()->getName());
|
RecordVal *RV = R.getValue(getName());
|
||||||
assert(RV && "Reference to a non-existant variable?");
|
assert(RV && "Reference to a non-existant variable?");
|
||||||
assert(dynamic_cast<BitsInit*>(RV->getValue()));
|
assert(dynamic_cast<BitsInit*>(RV->getValue()));
|
||||||
BitsInit *BI = (BitsInit*)RV->getValue();
|
BitsInit *BI = (BitsInit*)RV->getValue();
|
||||||
|
|
||||||
assert(getBitNum() < BI->getNumBits() && "Bit reference out of range!");
|
assert(Bit < BI->getNumBits() && "Bit reference out of range!");
|
||||||
Init *B = BI->getBit(getBitNum());
|
Init *B = BI->getBit(Bit);
|
||||||
|
|
||||||
if (!dynamic_cast<UnsetInit*>(B)) // If the bit is not set...
|
if (!dynamic_cast<UnsetInit*>(B)) // If the bit is not set...
|
||||||
return B; // Replace the VarBitInit with it.
|
return B; // Replace the VarBitInit with it.
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Init *VarBitInit::resolveReferences(Record &R) {
|
||||||
|
Init *I = getVariable()->resolveBitReference(R, getBitNum());
|
||||||
|
|
||||||
|
if (I != getVariable())
|
||||||
|
return I;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
void DefInit::print(std::ostream &OS) const {
|
void DefInit::print(std::ostream &OS) const {
|
||||||
OS << Def->getName();
|
OS << Def->getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Init *FieldInit::convertInitializerBitRange(const std::vector<unsigned> &Bits) {
|
||||||
|
BitsRecTy *T = dynamic_cast<BitsRecTy*>(getType());
|
||||||
|
if (T == 0) return 0; // Cannot subscript a non-bits field...
|
||||||
|
unsigned NumBits = T->getNumBits();
|
||||||
|
|
||||||
|
BitsInit *BI = new BitsInit(Bits.size());
|
||||||
|
for (unsigned i = 0, e = Bits.size(); i != e; ++i) {
|
||||||
|
if (Bits[i] >= NumBits) {
|
||||||
|
delete BI;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
BI->setBit(i, new VarBitInit(this, Bits[i]));
|
||||||
|
}
|
||||||
|
return BI;
|
||||||
|
}
|
||||||
|
|
||||||
|
Init *FieldInit::resolveBitReference(Record &R, unsigned Bit) {
|
||||||
|
// Can never be resolved yet.
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Other implementations
|
// Other implementations
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
Loading…
Reference in New Issue
Block a user