mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-01 07:30:31 +00:00
Add bitcode reader and writer support for ConstantDataAggregate, which
should be feature complete now. Lets see if it works. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@149215 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f95b2dafc9
commit
d408f06048
@ -164,7 +164,8 @@ namespace bitc {
|
|||||||
CST_CODE_INLINEASM = 18, // INLINEASM: [sideeffect,asmstr,conststr]
|
CST_CODE_INLINEASM = 18, // INLINEASM: [sideeffect,asmstr,conststr]
|
||||||
CST_CODE_CE_SHUFVEC_EX = 19, // SHUFVEC_EX: [opty, opval, opval, opval]
|
CST_CODE_CE_SHUFVEC_EX = 19, // SHUFVEC_EX: [opty, opval, opval, opval]
|
||||||
CST_CODE_CE_INBOUNDS_GEP = 20,// INBOUNDS_GEP: [n x operands]
|
CST_CODE_CE_INBOUNDS_GEP = 20,// INBOUNDS_GEP: [n x operands]
|
||||||
CST_CODE_BLOCKADDRESS = 21 // CST_CODE_BLOCKADDRESS [fnty, fnval, bb#]
|
CST_CODE_BLOCKADDRESS = 21, // CST_CODE_BLOCKADDRESS [fnty, fnval, bb#]
|
||||||
|
CST_CODE_DATA = 22 // DATA: [n x elements]
|
||||||
};
|
};
|
||||||
|
|
||||||
/// CastOpcodes - These are values used in the bitcode files to encode which
|
/// CastOpcodes - These are values used in the bitcode files to encode which
|
||||||
|
@ -1121,6 +1121,65 @@ bool BitcodeReader::ParseConstants() {
|
|||||||
V = ConstantArray::get(ATy, Elts);
|
V = ConstantArray::get(ATy, Elts);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case bitc::CST_CODE_DATA: {// DATA: [n x value]
|
||||||
|
if (Record.empty())
|
||||||
|
return Error("Invalid CST_DATA record");
|
||||||
|
|
||||||
|
Type *EltTy = cast<SequentialType>(CurTy)->getElementType();
|
||||||
|
unsigned Size = Record.size();
|
||||||
|
|
||||||
|
if (EltTy->isIntegerTy(8)) {
|
||||||
|
SmallVector<uint8_t, 16> Elts(Record.begin(), Record.end());
|
||||||
|
if (isa<VectorType>(CurTy))
|
||||||
|
V = ConstantDataVector::get(Context, Elts);
|
||||||
|
else
|
||||||
|
V = ConstantDataArray::get(Context, Elts);
|
||||||
|
} else if (EltTy->isIntegerTy(16)) {
|
||||||
|
SmallVector<uint16_t, 16> Elts(Record.begin(), Record.end());
|
||||||
|
if (isa<VectorType>(CurTy))
|
||||||
|
V = ConstantDataVector::get(Context, Elts);
|
||||||
|
else
|
||||||
|
V = ConstantDataArray::get(Context, Elts);
|
||||||
|
} else if (EltTy->isIntegerTy(32)) {
|
||||||
|
SmallVector<uint32_t, 16> Elts(Record.begin(), Record.end());
|
||||||
|
if (isa<VectorType>(CurTy))
|
||||||
|
V = ConstantDataVector::get(Context, Elts);
|
||||||
|
else
|
||||||
|
V = ConstantDataArray::get(Context, Elts);
|
||||||
|
} else if (EltTy->isIntegerTy(64)) {
|
||||||
|
SmallVector<uint64_t, 16> Elts(Record.begin(), Record.end());
|
||||||
|
if (isa<VectorType>(CurTy))
|
||||||
|
V = ConstantDataVector::get(Context, Elts);
|
||||||
|
else
|
||||||
|
V = ConstantDataArray::get(Context, Elts);
|
||||||
|
} else if (EltTy->isFloatTy()) {
|
||||||
|
SmallVector<float, 16> Elts;
|
||||||
|
for (unsigned i = 0; i != Size; ++i) {
|
||||||
|
union { uint32_t I; float F; };
|
||||||
|
I = Record[i];
|
||||||
|
Elts.push_back(F);
|
||||||
|
}
|
||||||
|
if (isa<VectorType>(CurTy))
|
||||||
|
V = ConstantDataVector::get(Context, Elts);
|
||||||
|
else
|
||||||
|
V = ConstantDataArray::get(Context, Elts);
|
||||||
|
} else if (EltTy->isDoubleTy()) {
|
||||||
|
SmallVector<double, 16> Elts;
|
||||||
|
for (unsigned i = 0; i != Size; ++i) {
|
||||||
|
union { uint64_t I; double F; };
|
||||||
|
I = Record[i];
|
||||||
|
Elts.push_back(F);
|
||||||
|
}
|
||||||
|
if (isa<VectorType>(CurTy))
|
||||||
|
V = ConstantDataVector::get(Context, Elts);
|
||||||
|
else
|
||||||
|
V = ConstantDataArray::get(Context, Elts);
|
||||||
|
} else {
|
||||||
|
return Error("Unknown element type in CE_DATA");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case bitc::CST_CODE_CE_BINOP: { // CE_BINOP: [opcode, opval, opval]
|
case bitc::CST_CODE_CE_BINOP: { // CE_BINOP: [opcode, opval, opval]
|
||||||
if (Record.size() < 3) return Error("Invalid CE_BINOP record");
|
if (Record.size() < 3) return Error("Invalid CE_BINOP record");
|
||||||
int Opc = GetDecodedBinaryOpcode(Record[0], CurTy);
|
int Opc = GetDecodedBinaryOpcode(Record[0], CurTy);
|
||||||
|
@ -871,8 +871,55 @@ static void WriteConstants(unsigned FirstVal, unsigned LastVal,
|
|||||||
AbbrevToUse = CString6Abbrev;
|
AbbrevToUse = CString6Abbrev;
|
||||||
else if (isCStr7)
|
else if (isCStr7)
|
||||||
AbbrevToUse = CString7Abbrev;
|
AbbrevToUse = CString7Abbrev;
|
||||||
} else if (isa<ConstantArray>(C) || isa<ConstantStruct>(V) ||
|
} else if (isa<ConstantDataSequential>(C) &&
|
||||||
isa<ConstantVector>(V)) {
|
cast<ConstantDataSequential>(C)->isString()) {
|
||||||
|
const ConstantDataSequential *Str = cast<ConstantDataSequential>(C);
|
||||||
|
// Emit constant strings specially.
|
||||||
|
unsigned NumElts = Str->getNumElements();
|
||||||
|
// If this is a null-terminated string, use the denser CSTRING encoding.
|
||||||
|
if (Str->isCString()) {
|
||||||
|
Code = bitc::CST_CODE_CSTRING;
|
||||||
|
--NumElts; // Don't encode the null, which isn't allowed by char6.
|
||||||
|
} else {
|
||||||
|
Code = bitc::CST_CODE_STRING;
|
||||||
|
AbbrevToUse = String8Abbrev;
|
||||||
|
}
|
||||||
|
bool isCStr7 = Code == bitc::CST_CODE_CSTRING;
|
||||||
|
bool isCStrChar6 = Code == bitc::CST_CODE_CSTRING;
|
||||||
|
for (unsigned i = 0; i != NumElts; ++i) {
|
||||||
|
unsigned char V = Str->getElementAsInteger(i);
|
||||||
|
Record.push_back(V);
|
||||||
|
isCStr7 &= (V & 128) == 0;
|
||||||
|
if (isCStrChar6)
|
||||||
|
isCStrChar6 = BitCodeAbbrevOp::isChar6(V);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isCStrChar6)
|
||||||
|
AbbrevToUse = CString6Abbrev;
|
||||||
|
else if (isCStr7)
|
||||||
|
AbbrevToUse = CString7Abbrev;
|
||||||
|
} else if (const ConstantDataSequential *CDS =
|
||||||
|
dyn_cast<ConstantDataSequential>(C)) {
|
||||||
|
Type *EltTy = CDS->getType()->getElementType();
|
||||||
|
if (isa<IntegerType>(EltTy)) {
|
||||||
|
for (unsigned i = 0, e = CDS->getNumElements(); i != e; ++i)
|
||||||
|
Record.push_back(CDS->getElementAsInteger(i));
|
||||||
|
} else if (EltTy->isFloatTy()) {
|
||||||
|
for (unsigned i = 0, e = CDS->getNumElements(); i != e; ++i) {
|
||||||
|
union { float F; uint32_t I; };
|
||||||
|
F = CDS->getElementAsFloat(i);
|
||||||
|
Record.push_back(I);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
assert(EltTy->isDoubleTy() && "Unknown ConstantData element type");
|
||||||
|
for (unsigned i = 0, e = CDS->getNumElements(); i != e; ++i) {
|
||||||
|
union { double F; uint64_t I; };
|
||||||
|
F = CDS->getElementAsDouble(i);
|
||||||
|
Record.push_back(I);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (isa<ConstantArray>(C) || isa<ConstantStruct>(C) ||
|
||||||
|
isa<ConstantVector>(C)) {
|
||||||
Code = bitc::CST_CODE_AGGREGATE;
|
Code = bitc::CST_CODE_AGGREGATE;
|
||||||
for (unsigned i = 0, e = C->getNumOperands(); i != e; ++i)
|
for (unsigned i = 0, e = C->getNumOperands(); i != e; ++i)
|
||||||
Record.push_back(VE.getValueID(C->getOperand(i)));
|
Record.push_back(VE.getValueID(C->getOperand(i)));
|
||||||
|
@ -208,6 +208,8 @@ static const char *GetCodeName(unsigned CodeID, unsigned BlockID,
|
|||||||
case bitc::CST_CODE_CE_CMP: return "CE_CMP";
|
case bitc::CST_CODE_CE_CMP: return "CE_CMP";
|
||||||
case bitc::CST_CODE_INLINEASM: return "INLINEASM";
|
case bitc::CST_CODE_INLINEASM: return "INLINEASM";
|
||||||
case bitc::CST_CODE_CE_SHUFVEC_EX: return "CE_SHUFVEC_EX";
|
case bitc::CST_CODE_CE_SHUFVEC_EX: return "CE_SHUFVEC_EX";
|
||||||
|
case bitc::CST_CODE_BLOCKADDRESS: return "CST_CODE_BLOCKADDRESS";
|
||||||
|
case bitc::CST_CODE_DATA: return "DATA";
|
||||||
}
|
}
|
||||||
case bitc::FUNCTION_BLOCK_ID:
|
case bitc::FUNCTION_BLOCK_ID:
|
||||||
switch (CodeID) {
|
switch (CodeID) {
|
||||||
|
Loading…
Reference in New Issue
Block a user