60#define HANDLE_MDNODE_LEAF(CLASS) CLASS##AbbrevID,
61#include "llvm/IR/Metadata.def"
79 CONSTANTS_INTEGER_ABBREV,
80 CONSTANTS_CE_CAST_Abbrev,
81 CONSTANTS_NULL_Abbrev,
85 FUNCTION_INST_BINOP_ABBREV,
86 FUNCTION_INST_BINOP_FLAGS_ABBREV,
87 FUNCTION_INST_CAST_ABBREV,
88 FUNCTION_INST_RET_VOID_ABBREV,
89 FUNCTION_INST_RET_VAL_ABBREV,
90 FUNCTION_INST_UNREACHABLE_ABBREV,
91 FUNCTION_INST_GEP_ABBREV,
112 std::map<GlobalValue::GUID, unsigned> GUIDToValueIdMap;
115 unsigned GlobalValueId;
135 : I8Ty(
Type::getInt8Ty(M.getContext())),
137 StrtabBuilder(StrtabBuilder), M(M), VE(M, I8PtrTy), Buffer(Buffer),
138 BitcodeStartBit(Stream.GetCurrentBitNo()),
140 GlobalValueId = VE.getValues().
size();
142 for (
auto El : PointerMap)
143 VE.EnumerateType(El.second);
170 void writeModuleVersion();
171 void writePerModuleGlobalValueSummary();
176 unsigned FSCallsAbbrev,
177 unsigned FSCallsProfileAbbrev,
181 unsigned FSModRefsAbbrev,
182 unsigned FSModVTableRefsAbbrev);
185 GUIDToValueIdMap[ValGUID] = ++GlobalValueId;
189 const auto &VMI = GUIDToValueIdMap.find(ValGUID);
192 assert(VMI != GUIDToValueIdMap.end() &&
193 "GUID does not have assigned value Id");
199 if (!VI.haveGVs() || !VI.getValue())
200 return getValueId(VI.getGUID());
201 return VE.getValueID(VI.getValue());
204 std::map<GlobalValue::GUID, unsigned> &valueIds() {
return GUIDToValueIdMap; }
206 uint64_t bitcodeStartBit() {
return BitcodeStartBit; }
208 size_t addToStrtab(StringRef Str);
210 unsigned createDILocationAbbrev();
211 unsigned createGenericDINodeAbbrev();
213 void writeAttributeGroupTable();
214 void writeAttributeTable();
215 void writeTypeTable();
217 void writeValueSymbolTableForwardDecl();
218 void writeModuleInfo();
219 void writeValueAsMetadata(
const ValueAsMetadata *MD,
220 SmallVectorImpl<uint64_t> &Record);
221 void writeMDTuple(
const MDTuple *
N, SmallVectorImpl<uint64_t> &Record,
223 void writeDILocation(
const DILocation *
N, SmallVectorImpl<uint64_t> &Record,
225 void writeGenericDINode(
const GenericDINode *
N,
226 SmallVectorImpl<uint64_t> &Record,
unsigned &Abbrev) {
229 void writeDISubrange(
const DISubrange *
N, SmallVectorImpl<uint64_t> &Record,
231 void writeDIGenericSubrange(
const DIGenericSubrange *
N,
232 SmallVectorImpl<uint64_t> &Record,
236 void writeDIEnumerator(
const DIEnumerator *
N,
237 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
238 void writeDIBasicType(
const DIBasicType *
N, SmallVectorImpl<uint64_t> &Record,
240 void writeDIFixedPointType(
const DIFixedPointType *
N,
241 SmallVectorImpl<uint64_t> &Record,
245 void writeDIStringType(
const DIStringType *
N,
246 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev) {
249 void writeDIDerivedType(
const DIDerivedType *
N,
250 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
251 void writeDISubrangeType(
const DISubrangeType *
N,
252 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev) {
255 void writeDICompositeType(
const DICompositeType *
N,
256 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
257 void writeDISubroutineType(
const DISubroutineType *
N,
258 SmallVectorImpl<uint64_t> &Record,
260 void writeDIFile(
const DIFile *
N, SmallVectorImpl<uint64_t> &Record,
262 void writeDICompileUnit(
const DICompileUnit *
N,
263 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
264 void writeDISubprogram(
const DISubprogram *
N,
265 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
266 void writeDILexicalBlock(
const DILexicalBlock *
N,
267 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
268 void writeDILexicalBlockFile(
const DILexicalBlockFile *
N,
269 SmallVectorImpl<uint64_t> &Record,
271 void writeDICommonBlock(
const DICommonBlock *
N,
272 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev) {
275 void writeDINamespace(
const DINamespace *
N, SmallVectorImpl<uint64_t> &Record,
277 void writeDIMacro(
const DIMacro *
N, SmallVectorImpl<uint64_t> &Record,
281 void writeDIMacroFile(
const DIMacroFile *
N, SmallVectorImpl<uint64_t> &Record,
285 void writeDIArgList(
const DIArgList *
N, SmallVectorImpl<uint64_t> &Record,
289 void writeDIAssignID(
const DIAssignID *
N, SmallVectorImpl<uint64_t> &Record,
296 void writeDIModule(
const DIModule *
N, SmallVectorImpl<uint64_t> &Record,
298 void writeDITemplateTypeParameter(
const DITemplateTypeParameter *
N,
299 SmallVectorImpl<uint64_t> &Record,
301 void writeDITemplateValueParameter(
const DITemplateValueParameter *
N,
302 SmallVectorImpl<uint64_t> &Record,
304 void writeDIGlobalVariable(
const DIGlobalVariable *
N,
305 SmallVectorImpl<uint64_t> &Record,
307 void writeDILocalVariable(
const DILocalVariable *
N,
308 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
309 void writeDILabel(
const DILabel *
N, SmallVectorImpl<uint64_t> &Record,
313 void writeDIExpression(
const DIExpression *
N,
314 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
315 void writeDIGlobalVariableExpression(
const DIGlobalVariableExpression *
N,
316 SmallVectorImpl<uint64_t> &Record,
320 void writeDIObjCProperty(
const DIObjCProperty *
N,
321 SmallVectorImpl<uint64_t> &Record,
unsigned Abbrev);
322 void writeDIImportedEntity(
const DIImportedEntity *
N,
323 SmallVectorImpl<uint64_t> &Record,
325 unsigned createNamedMetadataAbbrev();
326 void writeNamedMetadata(SmallVectorImpl<uint64_t> &Record);
327 unsigned createMetadataStringsAbbrev();
329 SmallVectorImpl<uint64_t> &Record);
331 SmallVectorImpl<uint64_t> &Record,
332 std::vector<unsigned> *MDAbbrevs =
nullptr,
333 std::vector<uint64_t> *IndexPos =
nullptr);
334 void writeModuleMetadata();
335 void writeFunctionMetadata(
const Function &
F);
336 void writeFunctionMetadataAttachment(
const Function &
F);
337 void pushGlobalMetadataAttachment(SmallVectorImpl<uint64_t> &Record,
338 const GlobalObject &GO);
339 void writeModuleMetadataKinds();
340 void writeOperandBundleTags();
341 void writeSyncScopeNames();
342 void writeConstants(
unsigned FirstVal,
unsigned LastVal,
bool isGlobal);
343 void writeModuleConstants();
344 bool pushValueAndType(
const Value *V,
unsigned InstID,
345 SmallVectorImpl<unsigned> &Vals);
346 void writeOperandBundles(
const CallBase &CB,
unsigned InstID);
347 void pushValue(
const Value *V,
unsigned InstID,
348 SmallVectorImpl<unsigned> &Vals);
349 void pushValueSigned(
const Value *V,
unsigned InstID,
350 SmallVectorImpl<uint64_t> &Vals);
351 void writeInstruction(
const Instruction &
I,
unsigned InstID,
352 SmallVectorImpl<unsigned> &Vals);
353 void writeFunctionLevelValueSymbolTable(
const ValueSymbolTable &VST);
354 void writeGlobalValueSymbolTable(
355 DenseMap<const Function *, uint64_t> &FunctionToBitcodeIndex);
356 void writeFunction(
const Function &
F);
357 void writeBlockInfo();
359 unsigned getEncodedSyncScopeID(
SyncScope::ID SSID) {
return unsigned(SSID); }
361 unsigned getEncodedAlign(MaybeAlign Alignment) {
return encode(Alignment); }
363 unsigned getTypeID(
Type *
T,
const Value *V =
nullptr);
368 unsigned getGlobalObjectValueTypeID(
Type *
T,
const GlobalObject *
G);
384 Stream->Emit((
unsigned)
'B', 8);
385 Stream->Emit((
unsigned)
'C', 8);
386 Stream->Emit(0x0, 4);
387 Stream->Emit(0xC, 4);
388 Stream->Emit(0xE, 4);
389 Stream->Emit(0xD, 4);
401 Triple TT(M.getTargetTriple());
402 if (TT.isOSDarwin() || TT.isOSBinFormatMachO())
416 auto Abbv = std::make_shared<BitCodeAbbrev>();
419 auto AbbrevNo = Stream->
EmitAbbrev(std::move(Abbv));
432 assert(M.isMaterialized());
433 Mods.push_back(
const_cast<Module *
>(&M));
436 ModuleWriter.
write();
447 case Instruction::Trunc:
449 case Instruction::ZExt:
451 case Instruction::SExt:
453 case Instruction::FPToUI:
455 case Instruction::FPToSI:
457 case Instruction::UIToFP:
459 case Instruction::SIToFP:
461 case Instruction::FPTrunc:
463 case Instruction::FPExt:
465 case Instruction::PtrToInt:
467 case Instruction::IntToPtr:
469 case Instruction::BitCast:
471 case Instruction::AddrSpaceCast:
480 case Instruction::FNeg:
489 case Instruction::Add:
490 case Instruction::FAdd:
492 case Instruction::Sub:
493 case Instruction::FSub:
495 case Instruction::Mul:
496 case Instruction::FMul:
498 case Instruction::UDiv:
500 case Instruction::FDiv:
501 case Instruction::SDiv:
503 case Instruction::URem:
505 case Instruction::FRem:
506 case Instruction::SRem:
508 case Instruction::Shl:
510 case Instruction::LShr:
512 case Instruction::AShr:
514 case Instruction::And:
516 case Instruction::Or:
518 case Instruction::Xor:
523unsigned DXILBitcodeWriter::getTypeID(
Type *
T,
const Value *V) {
524 if (!
T->isPointerTy() &&
528 return VE.getTypeID(
T);
529 auto It = PointerMap.
find(V);
530 if (It != PointerMap.
end())
531 return VE.getTypeID(It->second);
537 return VE.getTypeID(
T);
538 return VE.getTypeID(I8PtrTy);
541unsigned DXILBitcodeWriter::getGlobalObjectValueTypeID(
Type *
T,
543 auto It = PointerMap.
find(
G);
544 if (It != PointerMap.
end()) {
548 return VE.getTypeID(
T);
610 unsigned AbbrevToUse) {
621 Stream.EmitRecord(Code, Vals, AbbrevToUse);
626 case Attribute::Alignment:
628 case Attribute::AlwaysInline:
630 case Attribute::Builtin:
632 case Attribute::ByVal:
634 case Attribute::Convergent:
636 case Attribute::InAlloca:
638 case Attribute::Cold:
640 case Attribute::InlineHint:
642 case Attribute::InReg:
644 case Attribute::JumpTable:
646 case Attribute::MinSize:
648 case Attribute::Naked:
650 case Attribute::Nest:
652 case Attribute::NoAlias:
654 case Attribute::NoBuiltin:
656 case Attribute::NoDuplicate:
658 case Attribute::NoImplicitFloat:
660 case Attribute::NoInline:
662 case Attribute::NonLazyBind:
664 case Attribute::NonNull:
666 case Attribute::Dereferenceable:
668 case Attribute::DereferenceableOrNull:
670 case Attribute::NoRedZone:
672 case Attribute::NoReturn:
674 case Attribute::NoUnwind:
676 case Attribute::OptimizeForSize:
678 case Attribute::OptimizeNone:
680 case Attribute::ReadNone:
682 case Attribute::ReadOnly:
684 case Attribute::Returned:
686 case Attribute::ReturnsTwice:
688 case Attribute::SExt:
690 case Attribute::StackAlignment:
692 case Attribute::StackProtect:
694 case Attribute::StackProtectReq:
696 case Attribute::StackProtectStrong:
698 case Attribute::SafeStack:
700 case Attribute::StructRet:
702 case Attribute::SanitizeAddress:
704 case Attribute::SanitizeThread:
706 case Attribute::SanitizeMemory:
708 case Attribute::UWTable:
710 case Attribute::ZExt:
721 "should be stripped in DXILPrepare");
741 unsigned NumWords =
A.getActiveWords();
742 const uint64_t *RawData =
A.getRawData();
743 for (
unsigned i = 0; i < NumWords; i++)
751 if (OBO->hasNoSignedWrap())
753 if (OBO->hasNoUnsignedWrap())
759 if (FPMO->hasAllowReassoc() || FPMO->hasAllowContract())
761 if (FPMO->hasNoNaNs())
763 if (FPMO->hasNoInfs())
765 if (FPMO->hasNoSignedZeros())
767 if (FPMO->hasAllowReciprocal())
848 switch (
C.getSelectionKind()) {
867void DXILBitcodeWriter::writeAttributeGroupTable() {
868 const std::vector<ValueEnumerator::IndexAndAttrSet> &AttrGrps =
869 VE.getAttributeGroups();
870 if (AttrGrps.empty())
877 unsigned AttrListIndex = Pair.first;
879 Record.push_back(
VE.getAttributeGroupID(Pair));
880 Record.push_back(AttrListIndex);
883 if (Attr.isEnumAttribute()) {
886 "DXIL does not support attributes above ATTR_KIND_ARGMEMONLY");
889 }
else if (Attr.isIntAttribute()) {
890 if (Attr.getKindAsEnum() == Attribute::AttrKind::Memory) {
908 "DXIL does not support attributes above ATTR_KIND_ARGMEMONLY");
914 StringRef
Kind = Attr.getKindAsString();
915 StringRef Val = Attr.getValueAsString();
934void DXILBitcodeWriter::writeAttributeTable() {
935 const std::vector<AttributeList> &
Attrs = VE.getAttributeLists();
941 SmallVector<uint64_t, 64> Record;
942 for (AttributeList AL : Attrs) {
943 for (
unsigned i :
AL.indexes()) {
944 AttributeSet AS =
AL.getAttributes(i);
946 Record.
push_back(VE.getAttributeGroupID({i, AS}));
957void DXILBitcodeWriter::writeTypeTable() {
961 SmallVector<uint64_t, 64> TypeVals;
963 uint64_t NumBits = VE.computeBitsRequiredForTypeIndices();
966 auto Abbv = std::make_shared<BitCodeAbbrev>();
969 Abbv->Add(BitCodeAbbrevOp(0));
970 unsigned PtrAbbrev = Stream.EmitAbbrev(std::move(Abbv));
973 Abbv = std::make_shared<BitCodeAbbrev>();
978 unsigned FunctionAbbrev = Stream.EmitAbbrev(std::move(Abbv));
981 Abbv = std::make_shared<BitCodeAbbrev>();
986 unsigned StructAnonAbbrev = Stream.EmitAbbrev(std::move(Abbv));
989 Abbv = std::make_shared<BitCodeAbbrev>();
993 unsigned StructNameAbbrev = Stream.EmitAbbrev(std::move(Abbv));
996 Abbv = std::make_shared<BitCodeAbbrev>();
1001 unsigned StructNamedAbbrev = Stream.EmitAbbrev(std::move(Abbv));
1004 Abbv = std::make_shared<BitCodeAbbrev>();
1008 unsigned ArrayAbbrev = Stream.EmitAbbrev(std::move(Abbv));
1016 for (
Type *
T : TypeList) {
1017 int AbbrevToUse = 0;
1020 switch (
T->getTypeID()) {
1067 AbbrevToUse = PtrAbbrev;
1078 "dxilOpaquePtrReservedName", StructNameAbbrev);
1086 TypeVals.
push_back(getTypeID(FT->getReturnType()));
1087 for (
Type *PTy : FT->params())
1089 AbbrevToUse = FunctionAbbrev;
1097 for (
Type *ElTy :
ST->elements())
1100 if (
ST->isLiteral()) {
1102 AbbrevToUse = StructAnonAbbrev;
1104 if (
ST->isOpaque()) {
1108 AbbrevToUse = StructNamedAbbrev;
1112 if (!
ST->getName().empty())
1122 TypeVals.
push_back(AT->getNumElements());
1123 TypeVals.
push_back(getTypeID(AT->getElementType()));
1124 AbbrevToUse = ArrayAbbrev;
1132 TypeVals.
push_back(VT->getElementCount().getKnownMinValue());
1133 TypeVals.
push_back(getTypeID(VT->getElementType()));
1139 Stream.EmitRecord(Code, TypeVals, AbbrevToUse);
1146void DXILBitcodeWriter::writeComdats() {
1148 for (
const Comdat *
C : VE.getComdats()) {
1151 size_t Size =
C->getName().size();
1154 for (
char Chr :
C->getName())
1161void DXILBitcodeWriter::writeValueSymbolTableForwardDecl() {}
1166void DXILBitcodeWriter::writeModuleInfo() {
1168 if (!M.getTargetTriple().empty())
1170 M.getTargetTriple().str(), 0 );
1171 const std::string &
DL = M.getDataLayoutStr();
1174 if (!M.getModuleInlineAsm().empty())
1180 std::map<std::string, unsigned> SectionMap;
1181 std::map<std::string, unsigned> GCMap;
1182 MaybeAlign MaxAlignment;
1183 unsigned MaxGlobalType = 0;
1184 const auto UpdateMaxAlignment = [&MaxAlignment](
const MaybeAlign
A) {
1186 MaxAlignment = !MaxAlignment ? *
A : std::max(*MaxAlignment, *
A);
1188 for (
const GlobalVariable &GV : M.globals()) {
1189 UpdateMaxAlignment(GV.getAlign());
1192 MaxGlobalType = std::max(
1193 MaxGlobalType, getGlobalObjectValueTypeID(GV.getValueType(), &GV));
1194 if (GV.hasSection()) {
1196 unsigned &
Entry = SectionMap[std::string(GV.getSection())];
1199 GV.getSection(), 0 );
1200 Entry = SectionMap.size();
1204 for (
const Function &
F : M) {
1205 UpdateMaxAlignment(
F.getAlign());
1206 if (
F.hasSection()) {
1208 unsigned &
Entry = SectionMap[std::string(
F.getSection())];
1212 Entry = SectionMap.size();
1217 unsigned &
Entry = GCMap[
F.getGC()];
1221 Entry = GCMap.size();
1227 unsigned SimpleGVarAbbrev = 0;
1228 if (!M.global_empty()) {
1231 auto Abbv = std::make_shared<BitCodeAbbrev>();
1241 Abbv->Add(BitCodeAbbrevOp(0));
1243 unsigned MaxEncAlignment = getEncodedAlign(MaxAlignment);
1247 if (SectionMap.empty())
1248 Abbv->Add(BitCodeAbbrevOp(0));
1253 SimpleGVarAbbrev = Stream.EmitAbbrev(std::move(Abbv));
1258 for (
const GlobalVariable &GV : M.globals()) {
1259 unsigned AbbrevToUse = 0;
1265 Vals.
push_back(getGlobalObjectValueTypeID(GV.getValueType(), &GV));
1267 GV.getType()->getAddressSpace() << 2 | 2 |
1268 (GV.isConstant() ? 1 : 0));
1271 GV.isDeclaration() ? 0 : (VE.getValueID(GV.getInitializer()) + 1));
1273 Vals.
push_back(getEncodedAlign(GV.getAlign()));
1274 Vals.
push_back(GV.hasSection() ? SectionMap[std::string(GV.getSection())]
1276 if (GV.isThreadLocal() ||
1279 GV.isExternallyInitialized() ||
1285 Vals.
push_back(GV.isExternallyInitialized());
1287 Vals.
push_back(GV.hasComdat() ? VE.getComdatID(GV.getComdat()) : 0);
1289 AbbrevToUse = SimpleGVarAbbrev;
1297 for (
const Function &
F : M) {
1301 Vals.
push_back(getGlobalObjectValueTypeID(
F.getFunctionType(), &
F));
1305 Vals.
push_back(VE.getAttributeListID(
F.getAttributes()));
1306 Vals.
push_back(getEncodedAlign(
F.getAlign()));
1307 Vals.
push_back(
F.hasSection() ? SectionMap[std::string(
F.getSection())]
1313 F.hasPrologueData() ? (VE.getValueID(
F.getPrologueData()) + 1) : 0);
1315 Vals.
push_back(
F.hasComdat() ? VE.getComdatID(
F.getComdat()) : 0);
1316 Vals.
push_back(
F.hasPrefixData() ? (VE.getValueID(
F.getPrefixData()) + 1)
1319 F.hasPersonalityFn() ? (VE.getValueID(
F.getPersonalityFn()) + 1) : 0);
1321 unsigned AbbrevToUse = 0;
1327 for (
const GlobalAlias &
A : M.aliases()) {
1330 Vals.
push_back(VE.getValueID(
A.getAliasee()));
1336 unsigned AbbrevToUse = 0;
1342void DXILBitcodeWriter::writeValueAsMetadata(
1343 const ValueAsMetadata *MD, SmallVectorImpl<uint64_t> &Record) {
1346 Type *Ty =
V->getType();
1357void DXILBitcodeWriter::writeMDTuple(
const MDTuple *
N,
1358 SmallVectorImpl<uint64_t> &Record,
1360 for (
unsigned i = 0, e =
N->getNumOperands(); i != e; ++i) {
1363 "Unexpected function-local metadata");
1364 Record.
push_back(VE.getMetadataOrNullID(MD));
1372void DXILBitcodeWriter::writeDILocation(
const DILocation *
N,
1373 SmallVectorImpl<uint64_t> &Record,
1376 Abbrev = createDILocationAbbrev();
1380 Record.
push_back(VE.getMetadataID(
N->getScope()));
1381 Record.
push_back(VE.getMetadataOrNullID(
N->getInlinedAt()));
1390 return I < 0 ? ~(U << 1) : U << 1;
1393void DXILBitcodeWriter::writeDISubrange(
const DISubrange *
N,
1394 SmallVectorImpl<uint64_t> &Record,
1401 assert(
Count &&
"Count is missing or not ConstantInt");
1405 DISubrange::BoundType LowerBound =
N->getLowerBound();
1407 "Lower bound provided but not ConstantInt");
1415void DXILBitcodeWriter::writeDIEnumerator(
const DIEnumerator *
N,
1416 SmallVectorImpl<uint64_t> &Record,
1420 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1426void DXILBitcodeWriter::writeDIBasicType(
const DIBasicType *
N,
1427 SmallVectorImpl<uint64_t> &Record,
1431 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1440void DXILBitcodeWriter::writeDIDerivedType(
const DIDerivedType *
N,
1441 SmallVectorImpl<uint64_t> &Record,
1445 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1446 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1448 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1449 Record.
push_back(VE.getMetadataOrNullID(
N->getBaseType()));
1454 Record.
push_back(VE.getMetadataOrNullID(
N->getExtraData()));
1460void DXILBitcodeWriter::writeDICompositeType(
const DICompositeType *
N,
1461 SmallVectorImpl<uint64_t> &Record,
1465 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1466 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1468 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1469 Record.
push_back(VE.getMetadataOrNullID(
N->getBaseType()));
1474 Record.
push_back(VE.getMetadataOrNullID(
N->getElements().get()));
1476 Record.
push_back(VE.getMetadataOrNullID(
N->getVTableHolder()));
1477 Record.
push_back(VE.getMetadataOrNullID(
N->getTemplateParams().get()));
1478 Record.
push_back(VE.getMetadataOrNullID(
N->getRawIdentifier()));
1484void DXILBitcodeWriter::writeDISubroutineType(
const DISubroutineType *
N,
1485 SmallVectorImpl<uint64_t> &Record,
1489 Record.
push_back(VE.getMetadataOrNullID(
N->getTypeArray().get()));
1495void DXILBitcodeWriter::writeDIFile(
const DIFile *
N,
1496 SmallVectorImpl<uint64_t> &Record,
1499 Record.
push_back(VE.getMetadataOrNullID(
N->getRawFilename()));
1500 Record.
push_back(VE.getMetadataOrNullID(
N->getRawDirectory()));
1506void DXILBitcodeWriter::writeDICompileUnit(
const DICompileUnit *
N,
1507 SmallVectorImpl<uint64_t> &Record,
1511 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1512 Record.
push_back(VE.getMetadataOrNullID(
N->getRawProducer()));
1514 Record.
push_back(VE.getMetadataOrNullID(
N->getRawFlags()));
1516 Record.
push_back(VE.getMetadataOrNullID(
N->getRawSplitDebugFilename()));
1518 Record.
push_back(VE.getMetadataOrNullID(
N->getEnumTypes().get()));
1519 Record.
push_back(VE.getMetadataOrNullID(
N->getRetainedTypes().get()));
1521 Record.
push_back(VE.getMetadataOrNullID(
N->getGlobalVariables().get()));
1522 Record.
push_back(VE.getMetadataOrNullID(
N->getImportedEntities().get()));
1529void DXILBitcodeWriter::writeDISubprogram(
const DISubprogram *
N,
1530 SmallVectorImpl<uint64_t> &Record,
1533 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1534 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1535 Record.
push_back(VE.getMetadataOrNullID(
N->getRawLinkageName()));
1536 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1538 Record.
push_back(VE.getMetadataOrNullID(
N->getType()));
1542 Record.
push_back(VE.getMetadataOrNullID(
N->getContainingType()));
1547 Record.
push_back(VE.getMetadataOrNullID(
N->getRawUnit()));
1548 Record.
push_back(VE.getMetadataOrNullID(
N->getTemplateParams().get()));
1549 Record.
push_back(VE.getMetadataOrNullID(
N->getDeclaration()));
1550 Record.
push_back(VE.getMetadataOrNullID(
N->getRetainedNodes().get()));
1556void DXILBitcodeWriter::writeDILexicalBlock(
const DILexicalBlock *
N,
1557 SmallVectorImpl<uint64_t> &Record,
1560 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1561 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1569void DXILBitcodeWriter::writeDILexicalBlockFile(
1570 const DILexicalBlockFile *
N, SmallVectorImpl<uint64_t> &Record,
1573 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1574 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1581void DXILBitcodeWriter::writeDINamespace(
const DINamespace *
N,
1582 SmallVectorImpl<uint64_t> &Record,
1585 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1586 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1587 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1594void DXILBitcodeWriter::writeDIModule(
const DIModule *
N,
1595 SmallVectorImpl<uint64_t> &Record,
1598 for (
auto &
I :
N->operands())
1605void DXILBitcodeWriter::writeDITemplateTypeParameter(
1606 const DITemplateTypeParameter *
N, SmallVectorImpl<uint64_t> &Record,
1609 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1610 Record.
push_back(VE.getMetadataOrNullID(
N->getType()));
1616void DXILBitcodeWriter::writeDITemplateValueParameter(
1617 const DITemplateValueParameter *
N, SmallVectorImpl<uint64_t> &Record,
1621 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1622 Record.
push_back(VE.getMetadataOrNullID(
N->getType()));
1623 Record.
push_back(VE.getMetadataOrNullID(
N->getValue()));
1629void DXILBitcodeWriter::writeDIGlobalVariable(
const DIGlobalVariable *
N,
1630 SmallVectorImpl<uint64_t> &Record,
1633 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1634 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1635 Record.
push_back(VE.getMetadataOrNullID(
N->getRawLinkageName()));
1636 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1638 Record.
push_back(VE.getMetadataOrNullID(
N->getType()));
1642 Record.
push_back(VE.getMetadataOrNullID(
N->getStaticDataMemberDeclaration()));
1648void DXILBitcodeWriter::writeDILocalVariable(
const DILocalVariable *
N,
1649 SmallVectorImpl<uint64_t> &Record,
1653 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1654 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1655 Record.
push_back(VE.getMetadataOrNullID(
N->getFile()));
1657 Record.
push_back(VE.getMetadataOrNullID(
N->getType()));
1665void DXILBitcodeWriter::writeDIExpression(
const DIExpression *
N,
1666 SmallVectorImpl<uint64_t> &Record,
1668 Record.
reserve(
N->getElements().size() + 1);
1671 Record.
append(
N->elements_begin(),
N->elements_end());
1677void DXILBitcodeWriter::writeDIObjCProperty(
const DIObjCProperty *
N,
1678 SmallVectorImpl<uint64_t> &Record,
1683void DXILBitcodeWriter::writeDIImportedEntity(
const DIImportedEntity *
N,
1684 SmallVectorImpl<uint64_t> &Record,
1688 Record.
push_back(VE.getMetadataOrNullID(
N->getScope()));
1689 Record.
push_back(VE.getMetadataOrNullID(
N->getEntity()));
1691 Record.
push_back(VE.getMetadataOrNullID(
N->getRawName()));
1697unsigned DXILBitcodeWriter::createDILocationAbbrev() {
1702 std::shared_ptr<BitCodeAbbrev> Abbv = std::make_shared<BitCodeAbbrev>();
1709 return Stream.EmitAbbrev(std::move(Abbv));
1712unsigned DXILBitcodeWriter::createGenericDINodeAbbrev() {
1717 std::shared_ptr<BitCodeAbbrev> Abbv = std::make_shared<BitCodeAbbrev>();
1725 return Stream.EmitAbbrev(std::move(Abbv));
1729 SmallVectorImpl<uint64_t> &Record,
1730 std::vector<unsigned> *MDAbbrevs,
1731 std::vector<uint64_t> *IndexPos) {
1736#define HANDLE_MDNODE_LEAF(CLASS) unsigned CLASS##Abbrev = 0;
1737#include "llvm/IR/Metadata.def"
1741 IndexPos->push_back(Stream.GetCurrentBitNo());
1743 assert(
N->isResolved() &&
"Expected forward references to be resolved");
1745 switch (
N->getMetadataID()) {
1748#define HANDLE_MDNODE_LEAF(CLASS) \
1749 case Metadata::CLASS##Kind: \
1751 write##CLASS(cast<CLASS>(N), Record, \
1752 (*MDAbbrevs)[MetadataAbbrev::CLASS##AbbrevID]); \
1754 write##CLASS(cast<CLASS>(N), Record, CLASS##Abbrev); \
1756#include "llvm/IR/Metadata.def"
1763unsigned DXILBitcodeWriter::createMetadataStringsAbbrev() {
1764 auto Abbv = std::make_shared<BitCodeAbbrev>();
1768 return Stream.EmitAbbrev(std::move(Abbv));
1771void DXILBitcodeWriter::writeMetadataStrings(
1773 if (Strings.
empty())
1776 unsigned MDSAbbrev = createMetadataStringsAbbrev();
1778 for (
const Metadata *MD : Strings) {
1789void DXILBitcodeWriter::writeModuleMetadata() {
1790 if (!VE.hasMDs() && M.named_metadata_empty())
1797 std::vector<unsigned> MDAbbrevs;
1800 MDAbbrevs[MetadataAbbrev::DILocationAbbrevID] = createDILocationAbbrev();
1801 MDAbbrevs[MetadataAbbrev::GenericDINodeAbbrevID] =
1802 createGenericDINodeAbbrev();
1804 unsigned NameAbbrev = 0;
1805 if (!M.named_metadata_empty()) {
1807 std::shared_ptr<BitCodeAbbrev> Abbv = std::make_shared<BitCodeAbbrev>();
1811 NameAbbrev = Stream.EmitAbbrev(std::move(Abbv));
1814 SmallVector<uint64_t, 64> Record;
1815 writeMetadataStrings(VE.getMDStrings(), Record);
1817 std::vector<uint64_t> IndexPos;
1818 IndexPos.reserve(VE.getNonMDStrings().size());
1819 writeMetadataRecords(VE.getNonMDStrings(), Record, &MDAbbrevs, &IndexPos);
1822 for (
const NamedMDNode &NMD : M.named_metadata()) {
1824 StringRef Str = NMD.getName();
1825 Record.
append(Str.bytes_begin(), Str.bytes_end());
1830 for (
const MDNode *
N : NMD.operands())
1839void DXILBitcodeWriter::writeFunctionMetadata(
const Function &
F) {
1844 SmallVector<uint64_t, 64> Record;
1845 writeMetadataStrings(VE.getMDStrings(), Record);
1846 writeMetadataRecords(VE.getNonMDStrings(), Record);
1850void DXILBitcodeWriter::writeFunctionMetadataAttachment(
const Function &
F) {
1853 SmallVector<uint64_t, 64> Record;
1858 F.getAllMetadata(MDs);
1860 for (
const auto &
I : MDs) {
1862 Record.
push_back(VE.getMetadataID(
I.second));
1868 for (
const BasicBlock &BB :
F)
1869 for (
const Instruction &
I : BB) {
1871 I.getAllMetadataOtherThanDebugLoc(MDs);
1879 for (
unsigned i = 0, e = MDs.size(); i != e; ++i) {
1881 Record.
push_back(VE.getMetadataID(MDs[i].second));
1890void DXILBitcodeWriter::writeModuleMetadataKinds() {
1891 SmallVector<uint64_t, 64> Record;
1896 M.getMDKindNames(Names);
1903 for (
unsigned MDKindID = 0, e = Names.
size(); MDKindID != e; ++MDKindID) {
1905 StringRef KName = Names[MDKindID];
1915void DXILBitcodeWriter::writeConstants(
unsigned FirstVal,
unsigned LastVal,
1917 if (FirstVal == LastVal)
1922 unsigned AggregateAbbrev = 0;
1923 unsigned String8Abbrev = 0;
1924 unsigned CString7Abbrev = 0;
1925 unsigned CString6Abbrev = 0;
1929 auto Abbv = std::make_shared<BitCodeAbbrev>();
1934 AggregateAbbrev = Stream.EmitAbbrev(std::move(Abbv));
1937 Abbv = std::make_shared<BitCodeAbbrev>();
1941 String8Abbrev = Stream.EmitAbbrev(std::move(Abbv));
1943 Abbv = std::make_shared<BitCodeAbbrev>();
1947 CString7Abbrev = Stream.EmitAbbrev(std::move(Abbv));
1949 Abbv = std::make_shared<BitCodeAbbrev>();
1953 CString6Abbrev = Stream.EmitAbbrev(std::move(Abbv));
1956 SmallVector<uint64_t, 64> Record;
1959 Type *LastTy =
nullptr;
1960 for (
unsigned i = FirstVal; i != LastVal; ++i) {
1961 const Value *
V = Vals[i].first;
1963 if (
V->getType() != LastTy) {
1964 LastTy =
V->getType();
1967 CONSTANTS_SETTYPE_ABBREV);
1973 unsigned(
IA->isAlignStack()) << 1 |
1974 unsigned(
IA->getDialect() & 1) << 2);
1977 StringRef AsmStr =
IA->getAsmString();
1982 StringRef ConstraintStr =
IA->getConstraintString();
1990 unsigned Code = -1U;
1991 unsigned AbbrevToUse = 0;
1992 if (
C->isNullValue()) {
1997 if (
IV->getBitWidth() <= 64) {
1998 uint64_t
V =
IV->getSExtValue();
2001 AbbrevToUse = CONSTANTS_INTEGER_ABBREV;
2007 unsigned NWords =
IV->getValue().getActiveWords();
2008 const uint64_t *RawWords =
IV->getValue().getRawData();
2009 for (
unsigned i = 0; i != NWords; ++i) {
2016 Type *Ty = CFP->getType();
2018 Record.
push_back(CFP->getValueAPF().bitcastToAPInt().getZExtValue());
2022 APInt api = CFP->getValueAPF().bitcastToAPInt();
2024 Record.
push_back((p[1] << 48) | (p[0] >> 16));
2027 APInt api = CFP->getValueAPF().bitcastToAPInt();
2032 assert(0 &&
"Unknown FP type!");
2038 unsigned NumElts = Str->getNumElements();
2040 if (Str->isCString()) {
2045 AbbrevToUse = String8Abbrev;
2049 for (
unsigned i = 0; i != NumElts; ++i) {
2050 unsigned char V = Str->getElementAsInteger(i);
2052 isCStr7 &= (
V & 128) == 0;
2058 AbbrevToUse = CString6Abbrev;
2060 AbbrevToUse = CString7Abbrev;
2061 }
else if (
const ConstantDataSequential *CDS =
2064 Type *EltTy = CDS->getElementType();
2066 for (
unsigned i = 0, e = CDS->getNumElements(); i != e; ++i)
2067 Record.
push_back(CDS->getElementAsInteger(i));
2069 for (
unsigned i = 0, e = CDS->getNumElements(); i != e; ++i) {
2074 F = CDS->getElementAsFloat(i);
2079 for (
unsigned i = 0, e = CDS->getNumElements(); i != e; ++i) {
2084 F = CDS->getElementAsDouble(i);
2091 for (
const Value *
Op :
C->operands())
2093 AbbrevToUse = AggregateAbbrev;
2095 switch (
CE->getOpcode()) {
2101 getTypeID(
C->getOperand(0)->getType(),
C->getOperand(0)));
2102 Record.
push_back(VE.getValueID(
C->getOperand(0)));
2103 AbbrevToUse = CONSTANTS_CE_CAST_Abbrev;
2105 assert(
CE->getNumOperands() == 2 &&
"Unknown constant expr!");
2108 Record.
push_back(VE.getValueID(
C->getOperand(0)));
2109 Record.
push_back(VE.getValueID(
C->getOperand(1)));
2115 case Instruction::GetElementPtr: {
2118 if (GO->isInBounds())
2120 Record.
push_back(getTypeID(GO->getSourceElementType()));
2121 for (
unsigned i = 0, e =
CE->getNumOperands(); i != e; ++i) {
2123 getTypeID(
C->getOperand(i)->getType(),
C->getOperand(i)));
2124 Record.
push_back(VE.getValueID(
C->getOperand(i)));
2128 case Instruction::Select:
2130 Record.
push_back(VE.getValueID(
C->getOperand(0)));
2131 Record.
push_back(VE.getValueID(
C->getOperand(1)));
2132 Record.
push_back(VE.getValueID(
C->getOperand(2)));
2134 case Instruction::ExtractElement:
2136 Record.
push_back(getTypeID(
C->getOperand(0)->getType()));
2137 Record.
push_back(VE.getValueID(
C->getOperand(0)));
2138 Record.
push_back(getTypeID(
C->getOperand(1)->getType()));
2139 Record.
push_back(VE.getValueID(
C->getOperand(1)));
2141 case Instruction::InsertElement:
2143 Record.
push_back(VE.getValueID(
C->getOperand(0)));
2144 Record.
push_back(VE.getValueID(
C->getOperand(1)));
2145 Record.
push_back(getTypeID(
C->getOperand(2)->getType()));
2146 Record.
push_back(VE.getValueID(
C->getOperand(2)));
2148 case Instruction::ShuffleVector:
2153 if (
C->getType() ==
C->getOperand(0)->getType()) {
2157 Record.
push_back(getTypeID(
C->getOperand(0)->getType()));
2159 Record.
push_back(VE.getValueID(
C->getOperand(0)));
2160 Record.
push_back(VE.getValueID(
C->getOperand(1)));
2161 Record.
push_back(VE.getValueID(
C->getOperand(2)));
2166 Record.
push_back(getTypeID(BA->getFunction()->getType()));
2167 Record.
push_back(VE.getValueID(BA->getFunction()));
2168 Record.
push_back(VE.getGlobalBasicBlockID(BA->getBasicBlock()));
2175 Stream.EmitRecord(Code, Record, AbbrevToUse);
2182void DXILBitcodeWriter::writeModuleConstants() {
2187 for (
unsigned i = 0, e = Vals.size(); i != e; ++i) {
2189 writeConstants(i, Vals.size(),
true);
2203bool DXILBitcodeWriter::pushValueAndType(
const Value *V,
unsigned InstID,
2204 SmallVectorImpl<unsigned> &Vals) {
2205 unsigned ValID = VE.getValueID(V);
2208 if (ValID >= InstID) {
2217void DXILBitcodeWriter::pushValue(
const Value *V,
unsigned InstID,
2218 SmallVectorImpl<unsigned> &Vals) {
2219 unsigned ValID = VE.getValueID(V);
2223void DXILBitcodeWriter::pushValueSigned(
const Value *V,
unsigned InstID,
2224 SmallVectorImpl<uint64_t> &Vals) {
2225 unsigned ValID = VE.getValueID(V);
2226 int64_t diff = ((int32_t)InstID - (int32_t)ValID);
2231void DXILBitcodeWriter::writeInstruction(
const Instruction &
I,
unsigned InstID,
2232 SmallVectorImpl<unsigned> &Vals) {
2234 unsigned AbbrevToUse = 0;
2235 VE.setInstructionID(&
I);
2236 switch (
I.getOpcode()) {
2240 if (!pushValueAndType(
I.getOperand(0), InstID, Vals))
2241 AbbrevToUse = (unsigned)FUNCTION_INST_CAST_ABBREV;
2247 if (!pushValueAndType(
I.getOperand(0), InstID, Vals))
2248 AbbrevToUse = (unsigned)FUNCTION_INST_BINOP_ABBREV;
2249 pushValue(
I.getOperand(1), InstID, Vals);
2253 if (AbbrevToUse == (
unsigned)FUNCTION_INST_BINOP_ABBREV)
2254 AbbrevToUse = (unsigned)FUNCTION_INST_BINOP_FLAGS_ABBREV;
2260 case Instruction::GetElementPtr: {
2262 AbbrevToUse = (unsigned)FUNCTION_INST_GEP_ABBREV;
2265 Vals.
push_back(getTypeID(GEPInst.getSourceElementType()));
2266 for (
unsigned i = 0, e =
I.getNumOperands(); i != e; ++i)
2267 pushValueAndType(
I.getOperand(i), InstID, Vals);
2270 case Instruction::ExtractValue: {
2272 pushValueAndType(
I.getOperand(0), InstID, Vals);
2277 case Instruction::InsertValue: {
2279 pushValueAndType(
I.getOperand(0), InstID, Vals);
2280 pushValueAndType(
I.getOperand(1), InstID, Vals);
2285 case Instruction::Select:
2287 pushValueAndType(
I.getOperand(1), InstID, Vals);
2288 pushValue(
I.getOperand(2), InstID, Vals);
2289 pushValueAndType(
I.getOperand(0), InstID, Vals);
2291 case Instruction::ExtractElement:
2293 pushValueAndType(
I.getOperand(0), InstID, Vals);
2294 pushValueAndType(
I.getOperand(1), InstID, Vals);
2296 case Instruction::InsertElement:
2298 pushValueAndType(
I.getOperand(0), InstID, Vals);
2299 pushValue(
I.getOperand(1), InstID, Vals);
2300 pushValueAndType(
I.getOperand(2), InstID, Vals);
2302 case Instruction::ShuffleVector:
2304 pushValueAndType(
I.getOperand(0), InstID, Vals);
2305 pushValue(
I.getOperand(1), InstID, Vals);
2309 case Instruction::ICmp:
2310 case Instruction::FCmp: {
2313 pushValueAndType(
I.getOperand(0), InstID, Vals);
2314 pushValue(
I.getOperand(1), InstID, Vals);
2322 case Instruction::Ret: {
2324 unsigned NumOperands =
I.getNumOperands();
2325 if (NumOperands == 0)
2326 AbbrevToUse = (unsigned)FUNCTION_INST_RET_VOID_ABBREV;
2327 else if (NumOperands == 1) {
2328 if (!pushValueAndType(
I.getOperand(0), InstID, Vals))
2329 AbbrevToUse = (unsigned)FUNCTION_INST_RET_VAL_ABBREV;
2331 for (
unsigned i = 0, e = NumOperands; i !=
e; ++i)
2332 pushValueAndType(
I.getOperand(i), InstID, Vals);
2335 case Instruction::Br: {
2338 Vals.
push_back(VE.getValueID(
II.getSuccessor(0)));
2339 if (
II.isConditional()) {
2340 Vals.
push_back(VE.getValueID(
II.getSuccessor(1)));
2341 pushValue(
II.getCondition(), InstID, Vals);
2344 case Instruction::Switch: {
2347 Vals.
push_back(getTypeID(
SI.getCondition()->getType()));
2348 pushValue(
SI.getCondition(), InstID, Vals);
2349 Vals.
push_back(VE.getValueID(
SI.getDefaultDest()));
2350 for (
auto Case :
SI.cases()) {
2351 Vals.
push_back(VE.getValueID(Case.getCaseValue()));
2352 Vals.
push_back(VE.getValueID(Case.getCaseSuccessor()));
2355 case Instruction::IndirectBr:
2357 Vals.
push_back(getTypeID(
I.getOperand(0)->getType()));
2359 pushValue(
I.getOperand(0), InstID, Vals);
2360 for (
unsigned i = 1, e =
I.getNumOperands(); i != e; ++i)
2361 Vals.
push_back(VE.getValueID(
I.getOperand(i)));
2364 case Instruction::Invoke: {
2367 FunctionType *FTy =
II->getFunctionType();
2370 Vals.
push_back(VE.getAttributeListID(
II->getAttributes()));
2372 Vals.
push_back(VE.getValueID(
II->getNormalDest()));
2373 Vals.
push_back(VE.getValueID(
II->getUnwindDest()));
2375 pushValueAndType(Callee, InstID, Vals);
2378 for (
unsigned i = 0, e = FTy->getNumParams(); i != e; ++i)
2379 pushValue(
I.getOperand(i), InstID, Vals);
2382 if (FTy->isVarArg()) {
2383 for (
unsigned i = FTy->getNumParams(), e =
I.getNumOperands() - 3; i != e;
2385 pushValueAndType(
I.getOperand(i), InstID, Vals);
2389 case Instruction::Resume:
2391 pushValueAndType(
I.getOperand(0), InstID, Vals);
2393 case Instruction::Unreachable:
2395 AbbrevToUse = (unsigned)FUNCTION_INST_UNREACHABLE_ABBREV;
2398 case Instruction::PHI: {
2411 Stream.EmitRecord(Code, Vals64, AbbrevToUse);
2416 case Instruction::LandingPad: {
2427 pushValueAndType(LP.
getClause(
I), InstID, Vals);
2432 case Instruction::Alloca: {
2436 Vals.
push_back(getTypeID(
I.getOperand(0)->getType()));
2437 Vals.
push_back(VE.getValueID(
I.getOperand(0)));
2439 assert(AlignRecord < 1 << 5 &&
"alignment greater than 1 << 64");
2441 AlignRecord |= 1 << 6;
2446 case Instruction::Load:
2449 pushValueAndType(
I.getOperand(0), InstID, Vals);
2452 if (!pushValueAndType(
I.getOperand(0), InstID, Vals))
2453 AbbrevToUse = (unsigned)FUNCTION_INST_LOAD_ABBREV;
2463 case Instruction::Store:
2468 pushValueAndType(
I.getOperand(1), InstID, Vals);
2469 pushValueAndType(
I.getOperand(0), InstID, Vals);
2478 case Instruction::AtomicCmpXchg:
2480 pushValueAndType(
I.getOperand(0), InstID, Vals);
2481 pushValueAndType(
I.getOperand(1), InstID, Vals);
2482 pushValue(
I.getOperand(2), InstID, Vals);
2492 case Instruction::AtomicRMW:
2494 pushValueAndType(
I.getOperand(0), InstID, Vals);
2495 pushValue(
I.getOperand(1), InstID, Vals);
2503 case Instruction::Fence:
2508 case Instruction::Call: {
2521 for (
unsigned i = 0, e = FTy->getNumParams(); i != e; ++i) {
2523 if (FTy->getParamType(i)->isLabelTy())
2530 if (FTy->isVarArg()) {
2531 for (
unsigned i = FTy->getNumParams(), e = CI.
arg_size(); i != e; ++i)
2536 case Instruction::VAArg:
2538 Vals.
push_back(getTypeID(
I.getOperand(0)->getType()));
2539 pushValue(
I.getOperand(0), InstID, Vals);
2544 Stream.EmitRecord(Code, Vals, AbbrevToUse);
2549void DXILBitcodeWriter::writeFunctionLevelValueSymbolTable(
2550 const ValueSymbolTable &VST) {
2562 for (
auto &VI : VST) {
2567 return A->first() <
B->first();
2570 for (
const ValueName *SI : SortedTable) {
2575 bool isChar6 =
true;
2576 for (
const char *
C =
Name.getKeyData(), *
E =
C +
Name.getKeyLength();
2580 if ((
unsigned char)*
C & 128) {
2586 unsigned AbbrevToUse = VST_ENTRY_8_ABBREV;
2594 AbbrevToUse = VST_BBENTRY_6_ABBREV;
2598 AbbrevToUse = VST_ENTRY_6_ABBREV;
2600 AbbrevToUse = VST_ENTRY_7_ABBREV;
2603 NameVals.
push_back(VE.getValueID(
SI->getValue()));
2604 for (
const char *
P =
Name.getKeyData(),
2605 *
E =
Name.getKeyData() +
Name.getKeyLength();
2610 Stream.EmitRecord(Code, NameVals, AbbrevToUse);
2617void DXILBitcodeWriter::writeFunction(
const Function &
F) {
2619 VE.incorporateFunction(
F);
2625 Vals.
push_back(VE.getBasicBlocks().size());
2630 unsigned CstStart, CstEnd;
2631 VE.getFunctionConstantRange(CstStart, CstEnd);
2632 writeConstants(CstStart, CstEnd,
false);
2635 writeFunctionMetadata(
F);
2638 unsigned InstID = CstEnd;
2640 bool NeedsMetadataAttachment =
F.hasMetadata();
2642 DILocation *LastDL =
nullptr;
2648 writeInstruction(*
I, InstID, Vals);
2650 if (!
I->getType()->isVoidTy())
2654 NeedsMetadataAttachment |=
I->hasMetadataOtherThanDebugLoc();
2657 DILocation *
DL =
I->getDebugLoc();
2669 Vals.
push_back(VE.getMetadataOrNullID(
DL->getScope()));
2670 Vals.
push_back(VE.getMetadataOrNullID(
DL->getInlinedAt()));
2678 if (
auto *Symtab =
F.getValueSymbolTable())
2679 writeFunctionLevelValueSymbolTable(*Symtab);
2681 if (NeedsMetadataAttachment)
2682 writeFunctionMetadataAttachment(
F);
2689void DXILBitcodeWriter::writeBlockInfo() {
2693 Stream.EnterBlockInfoBlock();
2696 auto Abbv = std::make_shared<BitCodeAbbrev>();
2702 std::move(Abbv)) != VST_ENTRY_8_ABBREV)
2703 assert(
false &&
"Unexpected abbrev ordering!");
2707 auto Abbv = std::make_shared<BitCodeAbbrev>();
2713 std::move(Abbv)) != VST_ENTRY_7_ABBREV)
2714 assert(
false &&
"Unexpected abbrev ordering!");
2717 auto Abbv = std::make_shared<BitCodeAbbrev>();
2723 std::move(Abbv)) != VST_ENTRY_6_ABBREV)
2724 assert(
false &&
"Unexpected abbrev ordering!");
2727 auto Abbv = std::make_shared<BitCodeAbbrev>();
2733 std::move(Abbv)) != VST_BBENTRY_6_ABBREV)
2734 assert(
false &&
"Unexpected abbrev ordering!");
2738 auto Abbv = std::make_shared<BitCodeAbbrev>();
2741 VE.computeBitsRequiredForTypeIndices()));
2743 CONSTANTS_SETTYPE_ABBREV)
2744 assert(
false &&
"Unexpected abbrev ordering!");
2748 auto Abbv = std::make_shared<BitCodeAbbrev>();
2752 CONSTANTS_INTEGER_ABBREV)
2753 assert(
false &&
"Unexpected abbrev ordering!");
2757 auto Abbv = std::make_shared<BitCodeAbbrev>();
2761 VE.computeBitsRequiredForTypeIndices()));
2765 CONSTANTS_CE_CAST_Abbrev)
2766 assert(
false &&
"Unexpected abbrev ordering!");
2769 auto Abbv = std::make_shared<BitCodeAbbrev>();
2772 CONSTANTS_NULL_Abbrev)
2773 assert(
false &&
"Unexpected abbrev ordering!");
2779 auto Abbv = std::make_shared<BitCodeAbbrev>();
2783 VE.computeBitsRequiredForTypeIndices()));
2787 (
unsigned)FUNCTION_INST_LOAD_ABBREV)
2788 assert(
false &&
"Unexpected abbrev ordering!");
2791 auto Abbv = std::make_shared<BitCodeAbbrev>();
2797 (
unsigned)FUNCTION_INST_BINOP_ABBREV)
2798 assert(
false &&
"Unexpected abbrev ordering!");
2801 auto Abbv = std::make_shared<BitCodeAbbrev>();
2808 (
unsigned)FUNCTION_INST_BINOP_FLAGS_ABBREV)
2809 assert(
false &&
"Unexpected abbrev ordering!");
2812 auto Abbv = std::make_shared<BitCodeAbbrev>();
2816 VE.computeBitsRequiredForTypeIndices()));
2819 (
unsigned)FUNCTION_INST_CAST_ABBREV)
2820 assert(
false &&
"Unexpected abbrev ordering!");
2824 auto Abbv = std::make_shared<BitCodeAbbrev>();
2827 (
unsigned)FUNCTION_INST_RET_VOID_ABBREV)
2828 assert(
false &&
"Unexpected abbrev ordering!");
2831 auto Abbv = std::make_shared<BitCodeAbbrev>();
2835 (
unsigned)FUNCTION_INST_RET_VAL_ABBREV)
2836 assert(
false &&
"Unexpected abbrev ordering!");
2839 auto Abbv = std::make_shared<BitCodeAbbrev>();
2842 (
unsigned)FUNCTION_INST_UNREACHABLE_ABBREV)
2843 assert(
false &&
"Unexpected abbrev ordering!");
2846 auto Abbv = std::make_shared<BitCodeAbbrev>();
2854 (
unsigned)FUNCTION_INST_GEP_ABBREV)
2855 assert(
false &&
"Unexpected abbrev ordering!");
2861void DXILBitcodeWriter::writeModuleVersion() {
2876 DXILBitcodeWriter::writeModuleVersion();
2882 writeAttributeGroupTable();
2885 writeAttributeTable();
2897 writeModuleConstants();
2900 writeModuleMetadataKinds();
2903 writeModuleMetadata();
2908 writeFunctionLevelValueSymbolTable(M.getValueSymbolTable());
2912 if (!
F.isDeclaration())
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
This file contains the simple types necessary to represent the attributes associated with functions a...
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
This file contains the declarations for the subclasses of Constant, which represent the different fla...
static uint64_t rotateSign(APInt Val)
This file contains the declaration of the GlobalIFunc class, which represents a single indirect funct...
Module.h This file contains the declarations for the Module class.
ModuleSummaryIndex.h This file contains the declarations the classes that hold the module index and s...
uint64_t IntrinsicInst * II
static unsigned getBitWidth(Type *Ty, const DataLayout &DL)
Returns the bitwidth of the given scalar or pointer type.
static const uint32_t IV[8]
Class for arbitrary precision integers.
const uint64_t * getRawData() const
This function returns a pointer to the internal storage of the APInt.
int64_t getSExtValue() const
Get sign extended value.
Align getAlign() const
Return the alignment of the memory that is being allocated by the instruction.
Type * getAllocatedType() const
Return the type that is being allocated by the instruction.
bool isUsedWithInAlloca() const
Return true if this alloca is used as an inalloca argument to a call.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
bool empty() const
empty - Check if the array is empty.
BinOp
This enumeration lists the possible modifications atomicrmw can make.
@ Min
*p = old <signed v ? old : v
@ Max
*p = old >signed v ? old : v
@ UMin
*p = old <unsigned v ? old : v
@ FMin
*p = minnum(old, v) minnum matches the behavior of llvm.minnum.
@ UMax
*p = old >unsigned v ? old : v
@ FMax
*p = maxnum(old, v) maxnum matches the behavior of llvm.maxnum.
This class holds the attributes for a particular argument, parameter, function, or return value.
bool hasAttributes() const
Return true if attributes exists in this set.
Functions, function parameters, and return types can have attributes to indicate how they should be t...
AttrKind
This enumeration lists the attributes that can be associated with parameters, function results,...
@ TombstoneKey
Use as Tombstone key for DenseMap of AttrKind.
@ None
No attributes have been set.
@ EmptyKey
Use as Empty key for DenseMap of AttrKind.
@ EndAttrKinds
Sentinel value useful for loops.
InstListType::const_iterator const_iterator
BitCodeAbbrevOp - This describes one or more operands in an abbreviation.
static bool isChar6(char C)
isChar6 - Return true if this character is legal in the Char6 encoding.
unsigned EmitAbbrev(std::shared_ptr< BitCodeAbbrev > Abbv)
Emits the abbreviation Abbv to the stream.
void EmitRecordWithBlob(unsigned Abbrev, const Container &Vals, StringRef Blob)
EmitRecordWithBlob - Emit the specified record to the stream, using an abbrev that includes a blob at...
void EnterSubblock(unsigned BlockID, unsigned CodeLen)
Function * getCalledFunction() const
Returns the function called, or null if this is an indirect function invocation or the function signa...
CallingConv::ID getCallingConv() const
Value * getCalledOperand() const
Value * getArgOperand(unsigned i) const
FunctionType * getFunctionType() const
unsigned arg_size() const
AttributeList getAttributes() const
Return the attributes for this call.
bool isMustTailCall() const
@ Largest
The linker will choose the largest COMDAT.
@ SameSize
The data referenced by the COMDAT must be the same size.
@ Any
The linker may choose any COMDAT.
@ NoDeduplicate
No deduplication is performed.
@ ExactMatch
The data referenced by the COMDAT must be the same.
iterator find(const_arg_type_t< KeyT > Val)
BasicBlockListType::const_iterator const_iterator
Function and variable summary information to aid decisions and implementation of importing.
VisibilityTypes getVisibility() const
LinkageTypes getLinkage() const
uint64_t GUID
Declare a type to represent a global unique identifier for a global value.
ThreadLocalMode getThreadLocalMode() const
@ DLLExportStorageClass
Function to be accessible from DLL.
@ DLLImportStorageClass
Function to be imported from DLL.
@ DefaultVisibility
The GV is visible.
@ HiddenVisibility
The GV is hidden.
@ ProtectedVisibility
The GV is protected.
LinkageTypes
An enumeration for the kinds of linkage for global values.
@ PrivateLinkage
Like Internal, but omit from symbol table.
@ CommonLinkage
Tentative definitions.
@ InternalLinkage
Rename collisions when linking (static functions).
@ LinkOnceAnyLinkage
Keep one copy of function when linking (inline)
@ WeakODRLinkage
Same, but only replaced by something equivalent.
@ ExternalLinkage
Externally visible function.
@ WeakAnyLinkage
Keep one copy of named function when linking (weak)
@ AppendingLinkage
Special purpose, only applies to global arrays.
@ AvailableExternallyLinkage
Available for inspection, not emission.
@ ExternalWeakLinkage
ExternalWeak linkage description.
@ LinkOnceODRLinkage
Same, but only replaced by something equivalent.
DLLStorageClassTypes getDLLStorageClass() const
idx_iterator idx_end() const
idx_iterator idx_begin() const
bool isCleanup() const
Return 'true' if this landingpad instruction is a cleanup.
unsigned getNumClauses() const
Get the number of clauses for this landing pad.
bool isCatch(unsigned Idx) const
Return 'true' if the clause and index Idx is a catch clause.
Constant * getClause(unsigned Idx) const
Get the value of the clause at index Idx.
const unsigned char * bytes_begin() const
const unsigned char * bytes_end() const
bool doesNotAccessMemory() const
Whether this function accesses no memory.
bool onlyAccessesArgPointees() const
Whether this function only (at most) accesses argument memory.
bool onlyReadsMemory() const
Whether this function only (at most) reads memory.
A Module instance is used to store all the information related to an LLVM module.
BasicBlock * getIncomingBlock(unsigned i) const
Return incoming basic block number i.
Value * getIncomingValue(unsigned i) const
Return incoming value number x.
unsigned getNumIncomingValues() const
Return the number of incoming edges.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void reserve(size_type N)
void append(ItTy in_start, ItTy in_end)
Add the specified range to the end of the SmallVector.
iterator insert(iterator I, T &&Elt)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
constexpr bool empty() const
empty - Check if the string is empty.
constexpr size_t size() const
size - Get the string size.
Utility for building string tables with deduplicated suffixes.
Triple - Helper class for working with autoconf configuration names.
The instances of the Type class are immutable: once they are created, they are never changed.
bool isX86_FP80Ty() const
Return true if this is x86 long double.
bool isFloatTy() const
Return true if this is 'float', a 32-bit IEEE fp type.
@ X86_AMXTyID
AMX vectors (8192 bits, X86 specific)
@ TypedPointerTyID
Typed pointer used by some GPU targets.
@ HalfTyID
16-bit floating point type
@ TargetExtTyID
Target extension type.
@ VoidTyID
type with no size
@ ScalableVectorTyID
Scalable SIMD vector type.
@ FloatTyID
32-bit floating point type
@ IntegerTyID
Arbitrary bit width integers.
@ FixedVectorTyID
Fixed width SIMD vector type.
@ BFloatTyID
16-bit floating point type (7-bit significand)
@ DoubleTyID
64-bit floating point type
@ X86_FP80TyID
80-bit floating point type (X87)
@ PPC_FP128TyID
128-bit floating point type (two 64-bits, PowerPC)
@ FP128TyID
128-bit floating point type (112-bit significand)
bool isPPC_FP128Ty() const
Return true if this is powerpc long double.
bool isFP128Ty() const
Return true if this is 'fp128'.
bool isHalfTy() const
Return true if this is 'half', a 16-bit IEEE fp type.
bool isDoubleTy() const
Return true if this is 'double', a 64-bit IEEE fp type.
A few GPU targets, such as DXIL and SPIR-V, have typed pointers.
Type * getElementType() const
static LLVM_ABI TypedPointerType * get(Type *ElementType, unsigned AddressSpace)
This constructs a pointer to an object of the specified type in a numbered address space.
unsigned getAddressSpace() const
Return the address space of the Pointer type.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
void writeModule(const Module &M)
Write the specified module to the buffer specified at construction time.
BitcodeWriter(SmallVectorImpl< char > &Buffer)
Create a BitcodeWriter that writes to Buffer.
static void emitWideAPInt(SmallVectorImpl< uint64_t > &Vals, const APInt &A)
static unsigned getEncodedThreadLocalMode(const GlobalValue &GV)
static unsigned getEncodedCastOpcode(unsigned Opcode)
Begin dxil::BitcodeWriterBase Implementation.
static void writeStringRecord(BitstreamWriter &Stream, unsigned Code, StringRef Str, unsigned AbbrevToUse)
static uint64_t getAttrKindEncoding(Attribute::AttrKind Kind)
static unsigned getEncodedDLLStorageClass(const GlobalValue &GV)
static unsigned getEncodedOrdering(AtomicOrdering Ordering)
static unsigned getEncodedLinkage(const GlobalValue::LinkageTypes Linkage)
static unsigned getEncodedVisibility(const GlobalValue &GV)
void write()
Emit the current module to the bitstream.
static void writeIdentificationBlock(BitstreamWriter &Stream)
static unsigned getEncodedBinaryOpcode(unsigned Opcode)
static void emitSignedInt64(SmallVectorImpl< uint64_t > &Vals, uint64_t V)
static unsigned getEncodedUnaryOpcode(unsigned Opcode)
static unsigned getEncodedRMWOperation(AtomicRMWInst::BinOp Op)
DXILBitcodeWriter(const Module &M, SmallVectorImpl< char > &Buffer, StringTableBuilder &StrtabBuilder, BitstreamWriter &Stream)
Constructs a ModuleBitcodeWriter object for the given Module, writing to the provided Buffer.
static unsigned getEncodedComdatSelectionKind(const Comdat &C)
static uint64_t getOptimizationFlags(const Value *V)
std::pair< unsigned, AttributeSet > IndexAndAttrSet
Attribute groups as encoded in bitcode are almost AttributeSets, but they include the AttributeList i...
std::vector< std::pair< const Value *, unsigned > > ValueList
std::vector< Type * > TypeList
This class implements an extremely fast bulk output stream that can only output to a stream.
raw_ostream & write(unsigned char C)
This file contains the declaration of the Comdat class, which represents a single COMDAT in LLVM.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
@ C
The default llvm calling convention, compatible with C.
Predicate getPredicate(unsigned Condition, unsigned Hint)
Return predicate consisting of specified condition and hint bits.
@ CE
Windows NT (Windows on ARM)
@ METADATA_TEMPLATE_VALUE
@ METADATA_LEXICAL_BLOCK_FILE
@ METADATA_SUBROUTINE_TYPE
@ METADATA_IMPORTED_ENTITY
@ METADATA_COMPOSITE_TYPE
@ CST_CODE_CE_INBOUNDS_GEP
@ COMDAT_SELECTION_KIND_LARGEST
@ COMDAT_SELECTION_KIND_ANY
@ COMDAT_SELECTION_KIND_SAME_SIZE
@ COMDAT_SELECTION_KIND_EXACT_MATCH
@ COMDAT_SELECTION_KIND_NO_DUPLICATES
@ ATTR_KIND_STACK_PROTECT
@ ATTR_KIND_STACK_PROTECT_STRONG
@ ATTR_KIND_SANITIZE_MEMORY
@ ATTR_KIND_OPTIMIZE_FOR_SIZE
@ ATTR_KIND_SANITIZE_ADDRESS
@ ATTR_KIND_NO_IMPLICIT_FLOAT
@ ATTR_KIND_STACK_ALIGNMENT
@ ATTR_KIND_STACK_PROTECT_REQ
@ ATTR_KIND_RETURNS_TWICE
@ ATTR_KIND_NON_LAZY_BIND
@ ATTR_KIND_DEREFERENCEABLE
@ ATTR_KIND_OPTIMIZE_NONE
@ ATTR_KIND_DEREFERENCEABLE_OR_NULL
@ ATTR_KIND_ALWAYS_INLINE
@ ATTR_KIND_SANITIZE_THREAD
@ PARAMATTR_GROUP_BLOCK_ID
@ MODULE_CODE_SECTIONNAME
@ FUNC_CODE_INST_LANDINGPAD
@ FUNC_CODE_INST_EXTRACTVAL
@ FUNC_CODE_INST_LOADATOMIC
@ FUNC_CODE_INST_STOREATOMIC
@ FUNC_CODE_INST_ATOMICRMW
@ FUNC_CODE_DEBUG_LOC_AGAIN
@ FUNC_CODE_INST_EXTRACTELT
@ FUNC_CODE_INST_INDIRECTBR
@ FUNC_CODE_INST_INSERTVAL
@ FUNC_CODE_DECLAREBLOCKS
@ FUNC_CODE_INST_INSERTELT
@ FUNC_CODE_INST_SHUFFLEVEC
@ FUNC_CODE_INST_UNREACHABLE
@ FIRST_APPLICATION_ABBREV
@ PARAMATTR_GRP_CODE_ENTRY
An analysis to compute the PointerTypes for pointers in a Module.
void WriteDXILToFile(const Module &M, raw_ostream &Out)
Write the specified module to the specified raw output stream.
DenseMap< const Value *, Type * > PointerTypeMap
NodeAddr< CodeNode * > Code
This is an optimization pass for GlobalISel generic memory operations.
unsigned Log2_32_Ceil(uint32_t Value)
Return the ceil log base 2 of the specified value, 32 if the value is zero.
FunctionAddr VTableAddr Value
StringMapEntry< Value * > ValueName
MaybeAlign getAlign(const CallInst &I, unsigned Index)
auto size(R &&Range, std::enable_if_t< std::is_base_of< std::random_access_iterator_tag, typename std::iterator_traits< decltype(Range.begin())>::iterator_category >::value, void > *=nullptr)
Get the size of a range.
unsigned encode(MaybeAlign A)
Returns a representation of the alignment that encodes undefined as 0.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
MemoryEffectsBase< IRMemLocation > MemoryEffects
Summary of how a function affects memory in the program.
unsigned Log2_32(uint32_t Value)
Return the floor log base 2 of the specified value, -1 if the value is zero.
decltype(auto) get(const PointerIntPair< PointerTy, IntBits, IntType, PtrTraits, Info > &Pair)
void sort(IteratorTy Start, IteratorTy End)
FunctionAddr VTableAddr Count
constexpr bool isUInt(uint64_t x)
Checks if an unsigned integer fits into the given bit width.
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
AtomicOrdering
Atomic ordering for LLVM's memory model.
DWARFExpression::Operation Op
ArrayRef(const T &OneElt) -> ArrayRef< T >
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
unsigned Log2(Align A)
Returns the log2 of the alignment.
uint64_t value() const
This is a hole in the type system and should not be abused.
Struct that holds a reference to a particular GUID in a global value summary.