1 //===-- AsmWriter.cpp - Printing LLVM as an assembly file -----------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This library implements the functionality defined in llvm/IR/Writer.h 11 // 12 // Note that these routines must be extremely tolerant of various errors in the 13 // LLVM code, because it can be used for debugging transformations. 14 // 15 //===----------------------------------------------------------------------===// 16 17 #include "AsmWriter.h" 18 #include "llvm/ADT/DenseMap.h" 19 #include "llvm/ADT/STLExtras.h" 20 #include "llvm/ADT/SmallString.h" 21 #include "llvm/ADT/StringExtras.h" 22 #include "llvm/IR/AssemblyAnnotationWriter.h" 23 #include "llvm/IR/CFG.h" 24 #include "llvm/IR/CallingConv.h" 25 #include "llvm/IR/Constants.h" 26 #include "llvm/IR/DebugInfo.h" 27 #include "llvm/IR/DerivedTypes.h" 28 #include "llvm/IR/IRPrintingPasses.h" 29 #include "llvm/IR/InlineAsm.h" 30 #include "llvm/IR/IntrinsicInst.h" 31 #include "llvm/IR/LLVMContext.h" 32 #include "llvm/IR/Module.h" 33 #include "llvm/IR/Operator.h" 34 #include "llvm/IR/TypeFinder.h" 35 #include "llvm/IR/ValueSymbolTable.h" 36 #include "llvm/Support/Debug.h" 37 #include "llvm/Support/Dwarf.h" 38 #include "llvm/Support/ErrorHandling.h" 39 #include "llvm/Support/FormattedStream.h" 40 #include "llvm/Support/MathExtras.h" 41 #include <algorithm> 42 #include <cctype> 43 using namespace llvm; 44 45 // Make virtual table appear in this compilation unit. 46 AssemblyAnnotationWriter::~AssemblyAnnotationWriter() {} 47 48 //===----------------------------------------------------------------------===// 49 // Helper Functions 50 //===----------------------------------------------------------------------===// 51 52 namespace { 53 struct OrderMap { 54 DenseMap<const Value *, std::pair<unsigned, bool>> IDs; 55 56 unsigned size() const { return IDs.size(); } 57 std::pair<unsigned, bool> &operator[](const Value *V) { return IDs[V]; } 58 std::pair<unsigned, bool> lookup(const Value *V) const { 59 return IDs.lookup(V); 60 } 61 void index(const Value *V) { 62 // Explicitly sequence get-size and insert-value operations to avoid UB. 63 unsigned ID = IDs.size() + 1; 64 IDs[V].first = ID; 65 } 66 }; 67 } 68 69 static void orderValue(const Value *V, OrderMap &OM) { 70 if (OM.lookup(V).first) 71 return; 72 73 if (const Constant *C = dyn_cast<Constant>(V)) 74 if (C->getNumOperands() && !isa<GlobalValue>(C)) 75 for (const Value *Op : C->operands()) 76 if (!isa<BasicBlock>(Op) && !isa<GlobalValue>(Op)) 77 orderValue(Op, OM); 78 79 // Note: we cannot cache this lookup above, since inserting into the map 80 // changes the map's size, and thus affects the other IDs. 81 OM.index(V); 82 } 83 84 static OrderMap orderModule(const Module *M) { 85 // This needs to match the order used by ValueEnumerator::ValueEnumerator() 86 // and ValueEnumerator::incorporateFunction(). 87 OrderMap OM; 88 89 for (const GlobalVariable &G : M->globals()) { 90 if (G.hasInitializer()) 91 if (!isa<GlobalValue>(G.getInitializer())) 92 orderValue(G.getInitializer(), OM); 93 orderValue(&G, OM); 94 } 95 for (const GlobalAlias &A : M->aliases()) { 96 if (!isa<GlobalValue>(A.getAliasee())) 97 orderValue(A.getAliasee(), OM); 98 orderValue(&A, OM); 99 } 100 for (const Function &F : *M) { 101 if (F.hasPrefixData()) 102 if (!isa<GlobalValue>(F.getPrefixData())) 103 orderValue(F.getPrefixData(), OM); 104 105 if (F.hasPrologueData()) 106 if (!isa<GlobalValue>(F.getPrologueData())) 107 orderValue(F.getPrologueData(), OM); 108 109 orderValue(&F, OM); 110 111 if (F.isDeclaration()) 112 continue; 113 114 for (const Argument &A : F.args()) 115 orderValue(&A, OM); 116 for (const BasicBlock &BB : F) { 117 orderValue(&BB, OM); 118 for (const Instruction &I : BB) { 119 for (const Value *Op : I.operands()) 120 if ((isa<Constant>(*Op) && !isa<GlobalValue>(*Op)) || 121 isa<InlineAsm>(*Op)) 122 orderValue(Op, OM); 123 orderValue(&I, OM); 124 } 125 } 126 } 127 return OM; 128 } 129 130 static void predictValueUseListOrderImpl(const Value *V, const Function *F, 131 unsigned ID, const OrderMap &OM, 132 UseListOrderStack &Stack) { 133 // Predict use-list order for this one. 134 typedef std::pair<const Use *, unsigned> Entry; 135 SmallVector<Entry, 64> List; 136 for (const Use &U : V->uses()) 137 // Check if this user will be serialized. 138 if (OM.lookup(U.getUser()).first) 139 List.push_back(std::make_pair(&U, List.size())); 140 141 if (List.size() < 2) 142 // We may have lost some users. 143 return; 144 145 bool GetsReversed = 146 !isa<GlobalVariable>(V) && !isa<Function>(V) && !isa<BasicBlock>(V); 147 if (auto *BA = dyn_cast<BlockAddress>(V)) 148 ID = OM.lookup(BA->getBasicBlock()).first; 149 std::sort(List.begin(), List.end(), [&](const Entry &L, const Entry &R) { 150 const Use *LU = L.first; 151 const Use *RU = R.first; 152 if (LU == RU) 153 return false; 154 155 auto LID = OM.lookup(LU->getUser()).first; 156 auto RID = OM.lookup(RU->getUser()).first; 157 158 // If ID is 4, then expect: 7 6 5 1 2 3. 159 if (LID < RID) { 160 if (GetsReversed) 161 if (RID <= ID) 162 return true; 163 return false; 164 } 165 if (RID < LID) { 166 if (GetsReversed) 167 if (LID <= ID) 168 return false; 169 return true; 170 } 171 172 // LID and RID are equal, so we have different operands of the same user. 173 // Assume operands are added in order for all instructions. 174 if (GetsReversed) 175 if (LID <= ID) 176 return LU->getOperandNo() < RU->getOperandNo(); 177 return LU->getOperandNo() > RU->getOperandNo(); 178 }); 179 180 if (std::is_sorted( 181 List.begin(), List.end(), 182 [](const Entry &L, const Entry &R) { return L.second < R.second; })) 183 // Order is already correct. 184 return; 185 186 // Store the shuffle. 187 Stack.emplace_back(V, F, List.size()); 188 assert(List.size() == Stack.back().Shuffle.size() && "Wrong size"); 189 for (size_t I = 0, E = List.size(); I != E; ++I) 190 Stack.back().Shuffle[I] = List[I].second; 191 } 192 193 static void predictValueUseListOrder(const Value *V, const Function *F, 194 OrderMap &OM, UseListOrderStack &Stack) { 195 auto &IDPair = OM[V]; 196 assert(IDPair.first && "Unmapped value"); 197 if (IDPair.second) 198 // Already predicted. 199 return; 200 201 // Do the actual prediction. 202 IDPair.second = true; 203 if (!V->use_empty() && std::next(V->use_begin()) != V->use_end()) 204 predictValueUseListOrderImpl(V, F, IDPair.first, OM, Stack); 205 206 // Recursive descent into constants. 207 if (const Constant *C = dyn_cast<Constant>(V)) 208 if (C->getNumOperands()) // Visit GlobalValues. 209 for (const Value *Op : C->operands()) 210 if (isa<Constant>(Op)) // Visit GlobalValues. 211 predictValueUseListOrder(Op, F, OM, Stack); 212 } 213 214 static UseListOrderStack predictUseListOrder(const Module *M) { 215 OrderMap OM = orderModule(M); 216 217 // Use-list orders need to be serialized after all the users have been added 218 // to a value, or else the shuffles will be incomplete. Store them per 219 // function in a stack. 220 // 221 // Aside from function order, the order of values doesn't matter much here. 222 UseListOrderStack Stack; 223 224 // We want to visit the functions backward now so we can list function-local 225 // constants in the last Function they're used in. Module-level constants 226 // have already been visited above. 227 for (auto I = M->rbegin(), E = M->rend(); I != E; ++I) { 228 const Function &F = *I; 229 if (F.isDeclaration()) 230 continue; 231 for (const BasicBlock &BB : F) 232 predictValueUseListOrder(&BB, &F, OM, Stack); 233 for (const Argument &A : F.args()) 234 predictValueUseListOrder(&A, &F, OM, Stack); 235 for (const BasicBlock &BB : F) 236 for (const Instruction &I : BB) 237 for (const Value *Op : I.operands()) 238 if (isa<Constant>(*Op) || isa<InlineAsm>(*Op)) // Visit GlobalValues. 239 predictValueUseListOrder(Op, &F, OM, Stack); 240 for (const BasicBlock &BB : F) 241 for (const Instruction &I : BB) 242 predictValueUseListOrder(&I, &F, OM, Stack); 243 } 244 245 // Visit globals last. 246 for (const GlobalVariable &G : M->globals()) 247 predictValueUseListOrder(&G, nullptr, OM, Stack); 248 for (const Function &F : *M) 249 predictValueUseListOrder(&F, nullptr, OM, Stack); 250 for (const GlobalAlias &A : M->aliases()) 251 predictValueUseListOrder(&A, nullptr, OM, Stack); 252 for (const GlobalVariable &G : M->globals()) 253 if (G.hasInitializer()) 254 predictValueUseListOrder(G.getInitializer(), nullptr, OM, Stack); 255 for (const GlobalAlias &A : M->aliases()) 256 predictValueUseListOrder(A.getAliasee(), nullptr, OM, Stack); 257 for (const Function &F : *M) 258 if (F.hasPrefixData()) 259 predictValueUseListOrder(F.getPrefixData(), nullptr, OM, Stack); 260 261 return Stack; 262 } 263 264 static const Module *getModuleFromVal(const Value *V) { 265 if (const Argument *MA = dyn_cast<Argument>(V)) 266 return MA->getParent() ? MA->getParent()->getParent() : nullptr; 267 268 if (const BasicBlock *BB = dyn_cast<BasicBlock>(V)) 269 return BB->getParent() ? BB->getParent()->getParent() : nullptr; 270 271 if (const Instruction *I = dyn_cast<Instruction>(V)) { 272 const Function *M = I->getParent() ? I->getParent()->getParent() : nullptr; 273 return M ? M->getParent() : nullptr; 274 } 275 276 if (const GlobalValue *GV = dyn_cast<GlobalValue>(V)) 277 return GV->getParent(); 278 return nullptr; 279 } 280 281 static void PrintCallingConv(unsigned cc, raw_ostream &Out) { 282 switch (cc) { 283 default: Out << "cc" << cc; break; 284 case CallingConv::Fast: Out << "fastcc"; break; 285 case CallingConv::Cold: Out << "coldcc"; break; 286 case CallingConv::WebKit_JS: Out << "webkit_jscc"; break; 287 case CallingConv::AnyReg: Out << "anyregcc"; break; 288 case CallingConv::PreserveMost: Out << "preserve_mostcc"; break; 289 case CallingConv::PreserveAll: Out << "preserve_allcc"; break; 290 case CallingConv::GHC: Out << "ghccc"; break; 291 case CallingConv::X86_StdCall: Out << "x86_stdcallcc"; break; 292 case CallingConv::X86_FastCall: Out << "x86_fastcallcc"; break; 293 case CallingConv::X86_ThisCall: Out << "x86_thiscallcc"; break; 294 case CallingConv::X86_VectorCall:Out << "x86_vectorcallcc"; break; 295 case CallingConv::Intel_OCL_BI: Out << "intel_ocl_bicc"; break; 296 case CallingConv::ARM_APCS: Out << "arm_apcscc"; break; 297 case CallingConv::ARM_AAPCS: Out << "arm_aapcscc"; break; 298 case CallingConv::ARM_AAPCS_VFP: Out << "arm_aapcs_vfpcc"; break; 299 case CallingConv::MSP430_INTR: Out << "msp430_intrcc"; break; 300 case CallingConv::PTX_Kernel: Out << "ptx_kernel"; break; 301 case CallingConv::PTX_Device: Out << "ptx_device"; break; 302 case CallingConv::X86_64_SysV: Out << "x86_64_sysvcc"; break; 303 case CallingConv::X86_64_Win64: Out << "x86_64_win64cc"; break; 304 case CallingConv::SPIR_FUNC: Out << "spir_func"; break; 305 case CallingConv::SPIR_KERNEL: Out << "spir_kernel"; break; 306 } 307 } 308 309 // PrintEscapedString - Print each character of the specified string, escaping 310 // it if it is not printable or if it is an escape char. 311 static void PrintEscapedString(StringRef Name, raw_ostream &Out) { 312 for (unsigned i = 0, e = Name.size(); i != e; ++i) { 313 unsigned char C = Name[i]; 314 if (isprint(C) && C != '\\' && C != '"') 315 Out << C; 316 else 317 Out << '\\' << hexdigit(C >> 4) << hexdigit(C & 0x0F); 318 } 319 } 320 321 enum PrefixType { 322 GlobalPrefix, 323 ComdatPrefix, 324 LabelPrefix, 325 LocalPrefix, 326 NoPrefix 327 }; 328 329 /// PrintLLVMName - Turn the specified name into an 'LLVM name', which is either 330 /// prefixed with % (if the string only contains simple characters) or is 331 /// surrounded with ""'s (if it has special chars in it). Print it out. 332 static void PrintLLVMName(raw_ostream &OS, StringRef Name, PrefixType Prefix) { 333 assert(!Name.empty() && "Cannot get empty name!"); 334 switch (Prefix) { 335 case NoPrefix: break; 336 case GlobalPrefix: OS << '@'; break; 337 case ComdatPrefix: OS << '$'; break; 338 case LabelPrefix: break; 339 case LocalPrefix: OS << '%'; break; 340 } 341 342 // Scan the name to see if it needs quotes first. 343 bool NeedsQuotes = isdigit(static_cast<unsigned char>(Name[0])); 344 if (!NeedsQuotes) { 345 for (unsigned i = 0, e = Name.size(); i != e; ++i) { 346 // By making this unsigned, the value passed in to isalnum will always be 347 // in the range 0-255. This is important when building with MSVC because 348 // its implementation will assert. This situation can arise when dealing 349 // with UTF-8 multibyte characters. 350 unsigned char C = Name[i]; 351 if (!isalnum(static_cast<unsigned char>(C)) && C != '-' && C != '.' && 352 C != '_') { 353 NeedsQuotes = true; 354 break; 355 } 356 } 357 } 358 359 // If we didn't need any quotes, just write out the name in one blast. 360 if (!NeedsQuotes) { 361 OS << Name; 362 return; 363 } 364 365 // Okay, we need quotes. Output the quotes and escape any scary characters as 366 // needed. 367 OS << '"'; 368 PrintEscapedString(Name, OS); 369 OS << '"'; 370 } 371 372 /// PrintLLVMName - Turn the specified name into an 'LLVM name', which is either 373 /// prefixed with % (if the string only contains simple characters) or is 374 /// surrounded with ""'s (if it has special chars in it). Print it out. 375 static void PrintLLVMName(raw_ostream &OS, const Value *V) { 376 PrintLLVMName(OS, V->getName(), 377 isa<GlobalValue>(V) ? GlobalPrefix : LocalPrefix); 378 } 379 380 381 namespace llvm { 382 383 void TypePrinting::incorporateTypes(const Module &M) { 384 NamedTypes.run(M, false); 385 386 // The list of struct types we got back includes all the struct types, split 387 // the unnamed ones out to a numbering and remove the anonymous structs. 388 unsigned NextNumber = 0; 389 390 std::vector<StructType*>::iterator NextToUse = NamedTypes.begin(), I, E; 391 for (I = NamedTypes.begin(), E = NamedTypes.end(); I != E; ++I) { 392 StructType *STy = *I; 393 394 // Ignore anonymous types. 395 if (STy->isLiteral()) 396 continue; 397 398 if (STy->getName().empty()) 399 NumberedTypes[STy] = NextNumber++; 400 else 401 *NextToUse++ = STy; 402 } 403 404 NamedTypes.erase(NextToUse, NamedTypes.end()); 405 } 406 407 408 /// CalcTypeName - Write the specified type to the specified raw_ostream, making 409 /// use of type names or up references to shorten the type name where possible. 410 void TypePrinting::print(Type *Ty, raw_ostream &OS) { 411 switch (Ty->getTypeID()) { 412 case Type::VoidTyID: OS << "void"; return; 413 case Type::HalfTyID: OS << "half"; return; 414 case Type::FloatTyID: OS << "float"; return; 415 case Type::DoubleTyID: OS << "double"; return; 416 case Type::X86_FP80TyID: OS << "x86_fp80"; return; 417 case Type::FP128TyID: OS << "fp128"; return; 418 case Type::PPC_FP128TyID: OS << "ppc_fp128"; return; 419 case Type::LabelTyID: OS << "label"; return; 420 case Type::MetadataTyID: OS << "metadata"; return; 421 case Type::X86_MMXTyID: OS << "x86_mmx"; return; 422 case Type::IntegerTyID: 423 OS << 'i' << cast<IntegerType>(Ty)->getBitWidth(); 424 return; 425 426 case Type::FunctionTyID: { 427 FunctionType *FTy = cast<FunctionType>(Ty); 428 print(FTy->getReturnType(), OS); 429 OS << " ("; 430 for (FunctionType::param_iterator I = FTy->param_begin(), 431 E = FTy->param_end(); I != E; ++I) { 432 if (I != FTy->param_begin()) 433 OS << ", "; 434 print(*I, OS); 435 } 436 if (FTy->isVarArg()) { 437 if (FTy->getNumParams()) OS << ", "; 438 OS << "..."; 439 } 440 OS << ')'; 441 return; 442 } 443 case Type::StructTyID: { 444 StructType *STy = cast<StructType>(Ty); 445 446 if (STy->isLiteral()) 447 return printStructBody(STy, OS); 448 449 if (!STy->getName().empty()) 450 return PrintLLVMName(OS, STy->getName(), LocalPrefix); 451 452 DenseMap<StructType*, unsigned>::iterator I = NumberedTypes.find(STy); 453 if (I != NumberedTypes.end()) 454 OS << '%' << I->second; 455 else // Not enumerated, print the hex address. 456 OS << "%\"type " << STy << '\"'; 457 return; 458 } 459 case Type::PointerTyID: { 460 PointerType *PTy = cast<PointerType>(Ty); 461 print(PTy->getElementType(), OS); 462 if (unsigned AddressSpace = PTy->getAddressSpace()) 463 OS << " addrspace(" << AddressSpace << ')'; 464 OS << '*'; 465 return; 466 } 467 case Type::ArrayTyID: { 468 ArrayType *ATy = cast<ArrayType>(Ty); 469 OS << '[' << ATy->getNumElements() << " x "; 470 print(ATy->getElementType(), OS); 471 OS << ']'; 472 return; 473 } 474 case Type::VectorTyID: { 475 VectorType *PTy = cast<VectorType>(Ty); 476 OS << "<" << PTy->getNumElements() << " x "; 477 print(PTy->getElementType(), OS); 478 OS << '>'; 479 return; 480 } 481 } 482 llvm_unreachable("Invalid TypeID"); 483 } 484 485 void TypePrinting::printStructBody(StructType *STy, raw_ostream &OS) { 486 if (STy->isOpaque()) { 487 OS << "opaque"; 488 return; 489 } 490 491 if (STy->isPacked()) 492 OS << '<'; 493 494 if (STy->getNumElements() == 0) { 495 OS << "{}"; 496 } else { 497 StructType::element_iterator I = STy->element_begin(); 498 OS << "{ "; 499 print(*I++, OS); 500 for (StructType::element_iterator E = STy->element_end(); I != E; ++I) { 501 OS << ", "; 502 print(*I, OS); 503 } 504 505 OS << " }"; 506 } 507 if (STy->isPacked()) 508 OS << '>'; 509 } 510 511 //===----------------------------------------------------------------------===// 512 // SlotTracker Class: Enumerate slot numbers for unnamed values 513 //===----------------------------------------------------------------------===// 514 /// This class provides computation of slot numbers for LLVM Assembly writing. 515 /// 516 class SlotTracker { 517 public: 518 /// ValueMap - A mapping of Values to slot numbers. 519 typedef DenseMap<const Value*, unsigned> ValueMap; 520 521 private: 522 /// TheModule - The module for which we are holding slot numbers. 523 const Module* TheModule; 524 525 /// TheFunction - The function for which we are holding slot numbers. 526 const Function* TheFunction; 527 bool FunctionProcessed; 528 529 /// mMap - The slot map for the module level data. 530 ValueMap mMap; 531 unsigned mNext; 532 533 /// fMap - The slot map for the function level data. 534 ValueMap fMap; 535 unsigned fNext; 536 537 /// mdnMap - Map for MDNodes. 538 DenseMap<const MDNode*, unsigned> mdnMap; 539 unsigned mdnNext; 540 541 /// asMap - The slot map for attribute sets. 542 DenseMap<AttributeSet, unsigned> asMap; 543 unsigned asNext; 544 public: 545 /// Construct from a module 546 explicit SlotTracker(const Module *M); 547 /// Construct from a function, starting out in incorp state. 548 explicit SlotTracker(const Function *F); 549 550 /// Return the slot number of the specified value in it's type 551 /// plane. If something is not in the SlotTracker, return -1. 552 int getLocalSlot(const Value *V); 553 int getGlobalSlot(const GlobalValue *V); 554 int getMetadataSlot(const MDNode *N); 555 int getAttributeGroupSlot(AttributeSet AS); 556 557 /// If you'd like to deal with a function instead of just a module, use 558 /// this method to get its data into the SlotTracker. 559 void incorporateFunction(const Function *F) { 560 TheFunction = F; 561 FunctionProcessed = false; 562 } 563 564 const Function *getFunction() const { return TheFunction; } 565 566 /// After calling incorporateFunction, use this method to remove the 567 /// most recently incorporated function from the SlotTracker. This 568 /// will reset the state of the machine back to just the module contents. 569 void purgeFunction(); 570 571 /// MDNode map iterators. 572 typedef DenseMap<const MDNode*, unsigned>::iterator mdn_iterator; 573 mdn_iterator mdn_begin() { return mdnMap.begin(); } 574 mdn_iterator mdn_end() { return mdnMap.end(); } 575 unsigned mdn_size() const { return mdnMap.size(); } 576 bool mdn_empty() const { return mdnMap.empty(); } 577 578 /// AttributeSet map iterators. 579 typedef DenseMap<AttributeSet, unsigned>::iterator as_iterator; 580 as_iterator as_begin() { return asMap.begin(); } 581 as_iterator as_end() { return asMap.end(); } 582 unsigned as_size() const { return asMap.size(); } 583 bool as_empty() const { return asMap.empty(); } 584 585 /// This function does the actual initialization. 586 inline void initialize(); 587 588 // Implementation Details 589 private: 590 /// CreateModuleSlot - Insert the specified GlobalValue* into the slot table. 591 void CreateModuleSlot(const GlobalValue *V); 592 593 /// CreateMetadataSlot - Insert the specified MDNode* into the slot table. 594 void CreateMetadataSlot(const MDNode *N); 595 596 /// CreateFunctionSlot - Insert the specified Value* into the slot table. 597 void CreateFunctionSlot(const Value *V); 598 599 /// \brief Insert the specified AttributeSet into the slot table. 600 void CreateAttributeSetSlot(AttributeSet AS); 601 602 /// Add all of the module level global variables (and their initializers) 603 /// and function declarations, but not the contents of those functions. 604 void processModule(); 605 606 /// Add all of the functions arguments, basic blocks, and instructions. 607 void processFunction(); 608 609 SlotTracker(const SlotTracker &) LLVM_DELETED_FUNCTION; 610 void operator=(const SlotTracker &) LLVM_DELETED_FUNCTION; 611 }; 612 613 SlotTracker *createSlotTracker(const Module *M) { 614 return new SlotTracker(M); 615 } 616 617 static SlotTracker *createSlotTracker(const Value *V) { 618 if (const Argument *FA = dyn_cast<Argument>(V)) 619 return new SlotTracker(FA->getParent()); 620 621 if (const Instruction *I = dyn_cast<Instruction>(V)) 622 if (I->getParent()) 623 return new SlotTracker(I->getParent()->getParent()); 624 625 if (const BasicBlock *BB = dyn_cast<BasicBlock>(V)) 626 return new SlotTracker(BB->getParent()); 627 628 if (const GlobalVariable *GV = dyn_cast<GlobalVariable>(V)) 629 return new SlotTracker(GV->getParent()); 630 631 if (const GlobalAlias *GA = dyn_cast<GlobalAlias>(V)) 632 return new SlotTracker(GA->getParent()); 633 634 if (const Function *Func = dyn_cast<Function>(V)) 635 return new SlotTracker(Func); 636 637 return nullptr; 638 } 639 640 #if 0 641 #define ST_DEBUG(X) dbgs() << X 642 #else 643 #define ST_DEBUG(X) 644 #endif 645 646 // Module level constructor. Causes the contents of the Module (sans functions) 647 // to be added to the slot table. 648 SlotTracker::SlotTracker(const Module *M) 649 : TheModule(M), TheFunction(nullptr), FunctionProcessed(false), mNext(0), 650 fNext(0), mdnNext(0), asNext(0) {} 651 652 // Function level constructor. Causes the contents of the Module and the one 653 // function provided to be added to the slot table. 654 SlotTracker::SlotTracker(const Function *F) 655 : TheModule(F ? F->getParent() : nullptr), TheFunction(F), 656 FunctionProcessed(false), mNext(0), fNext(0), mdnNext(0), asNext(0) {} 657 658 inline void SlotTracker::initialize() { 659 if (TheModule) { 660 processModule(); 661 TheModule = nullptr; ///< Prevent re-processing next time we're called. 662 } 663 664 if (TheFunction && !FunctionProcessed) 665 processFunction(); 666 } 667 668 // Iterate through all the global variables, functions, and global 669 // variable initializers and create slots for them. 670 void SlotTracker::processModule() { 671 ST_DEBUG("begin processModule!\n"); 672 673 // Add all of the unnamed global variables to the value table. 674 for (Module::const_global_iterator I = TheModule->global_begin(), 675 E = TheModule->global_end(); I != E; ++I) { 676 if (!I->hasName()) 677 CreateModuleSlot(I); 678 } 679 680 // Add metadata used by named metadata. 681 for (Module::const_named_metadata_iterator 682 I = TheModule->named_metadata_begin(), 683 E = TheModule->named_metadata_end(); I != E; ++I) { 684 const NamedMDNode *NMD = I; 685 for (unsigned i = 0, e = NMD->getNumOperands(); i != e; ++i) 686 CreateMetadataSlot(NMD->getOperand(i)); 687 } 688 689 for (Module::const_iterator I = TheModule->begin(), E = TheModule->end(); 690 I != E; ++I) { 691 if (!I->hasName()) 692 // Add all the unnamed functions to the table. 693 CreateModuleSlot(I); 694 695 // Add all the function attributes to the table. 696 // FIXME: Add attributes of other objects? 697 AttributeSet FnAttrs = I->getAttributes().getFnAttributes(); 698 if (FnAttrs.hasAttributes(AttributeSet::FunctionIndex)) 699 CreateAttributeSetSlot(FnAttrs); 700 } 701 702 ST_DEBUG("end processModule!\n"); 703 } 704 705 // Process the arguments, basic blocks, and instructions of a function. 706 void SlotTracker::processFunction() { 707 ST_DEBUG("begin processFunction!\n"); 708 fNext = 0; 709 710 // Add all the function arguments with no names. 711 for(Function::const_arg_iterator AI = TheFunction->arg_begin(), 712 AE = TheFunction->arg_end(); AI != AE; ++AI) 713 if (!AI->hasName()) 714 CreateFunctionSlot(AI); 715 716 ST_DEBUG("Inserting Instructions:\n"); 717 718 SmallVector<std::pair<unsigned, MDNode *>, 4> MDForInst; 719 720 // Add all of the basic blocks and instructions with no names. 721 for (Function::const_iterator BB = TheFunction->begin(), 722 E = TheFunction->end(); BB != E; ++BB) { 723 if (!BB->hasName()) 724 CreateFunctionSlot(BB); 725 726 for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I != E; 727 ++I) { 728 if (!I->getType()->isVoidTy() && !I->hasName()) 729 CreateFunctionSlot(I); 730 731 // Intrinsics can directly use metadata. We allow direct calls to any 732 // llvm.foo function here, because the target may not be linked into the 733 // optimizer. 734 if (const CallInst *CI = dyn_cast<CallInst>(I)) { 735 if (Function *F = CI->getCalledFunction()) 736 if (F->isIntrinsic()) 737 for (unsigned i = 0, e = I->getNumOperands(); i != e; ++i) 738 if (auto *V = dyn_cast_or_null<MetadataAsValue>(I->getOperand(i))) 739 if (MDNode *N = dyn_cast<MDNode>(V->getMetadata())) 740 CreateMetadataSlot(N); 741 742 // Add all the call attributes to the table. 743 AttributeSet Attrs = CI->getAttributes().getFnAttributes(); 744 if (Attrs.hasAttributes(AttributeSet::FunctionIndex)) 745 CreateAttributeSetSlot(Attrs); 746 } else if (const InvokeInst *II = dyn_cast<InvokeInst>(I)) { 747 // Add all the call attributes to the table. 748 AttributeSet Attrs = II->getAttributes().getFnAttributes(); 749 if (Attrs.hasAttributes(AttributeSet::FunctionIndex)) 750 CreateAttributeSetSlot(Attrs); 751 } 752 753 // Process metadata attached with this instruction. 754 I->getAllMetadata(MDForInst); 755 for (unsigned i = 0, e = MDForInst.size(); i != e; ++i) 756 CreateMetadataSlot(MDForInst[i].second); 757 MDForInst.clear(); 758 } 759 } 760 761 FunctionProcessed = true; 762 763 ST_DEBUG("end processFunction!\n"); 764 } 765 766 /// Clean up after incorporating a function. This is the only way to get out of 767 /// the function incorporation state that affects get*Slot/Create*Slot. Function 768 /// incorporation state is indicated by TheFunction != 0. 769 void SlotTracker::purgeFunction() { 770 ST_DEBUG("begin purgeFunction!\n"); 771 fMap.clear(); // Simply discard the function level map 772 TheFunction = nullptr; 773 FunctionProcessed = false; 774 ST_DEBUG("end purgeFunction!\n"); 775 } 776 777 /// getGlobalSlot - Get the slot number of a global value. 778 int SlotTracker::getGlobalSlot(const GlobalValue *V) { 779 // Check for uninitialized state and do lazy initialization. 780 initialize(); 781 782 // Find the value in the module map 783 ValueMap::iterator MI = mMap.find(V); 784 return MI == mMap.end() ? -1 : (int)MI->second; 785 } 786 787 /// getMetadataSlot - Get the slot number of a MDNode. 788 int SlotTracker::getMetadataSlot(const MDNode *N) { 789 // Check for uninitialized state and do lazy initialization. 790 initialize(); 791 792 // Find the MDNode in the module map 793 mdn_iterator MI = mdnMap.find(N); 794 return MI == mdnMap.end() ? -1 : (int)MI->second; 795 } 796 797 798 /// getLocalSlot - Get the slot number for a value that is local to a function. 799 int SlotTracker::getLocalSlot(const Value *V) { 800 assert(!isa<Constant>(V) && "Can't get a constant or global slot with this!"); 801 802 // Check for uninitialized state and do lazy initialization. 803 initialize(); 804 805 ValueMap::iterator FI = fMap.find(V); 806 return FI == fMap.end() ? -1 : (int)FI->second; 807 } 808 809 int SlotTracker::getAttributeGroupSlot(AttributeSet AS) { 810 // Check for uninitialized state and do lazy initialization. 811 initialize(); 812 813 // Find the AttributeSet in the module map. 814 as_iterator AI = asMap.find(AS); 815 return AI == asMap.end() ? -1 : (int)AI->second; 816 } 817 818 /// CreateModuleSlot - Insert the specified GlobalValue* into the slot table. 819 void SlotTracker::CreateModuleSlot(const GlobalValue *V) { 820 assert(V && "Can't insert a null Value into SlotTracker!"); 821 assert(!V->getType()->isVoidTy() && "Doesn't need a slot!"); 822 assert(!V->hasName() && "Doesn't need a slot!"); 823 824 unsigned DestSlot = mNext++; 825 mMap[V] = DestSlot; 826 827 ST_DEBUG(" Inserting value [" << V->getType() << "] = " << V << " slot=" << 828 DestSlot << " ["); 829 // G = Global, F = Function, A = Alias, o = other 830 ST_DEBUG((isa<GlobalVariable>(V) ? 'G' : 831 (isa<Function>(V) ? 'F' : 832 (isa<GlobalAlias>(V) ? 'A' : 'o'))) << "]\n"); 833 } 834 835 /// CreateSlot - Create a new slot for the specified value if it has no name. 836 void SlotTracker::CreateFunctionSlot(const Value *V) { 837 assert(!V->getType()->isVoidTy() && !V->hasName() && "Doesn't need a slot!"); 838 839 unsigned DestSlot = fNext++; 840 fMap[V] = DestSlot; 841 842 // G = Global, F = Function, o = other 843 ST_DEBUG(" Inserting value [" << V->getType() << "] = " << V << " slot=" << 844 DestSlot << " [o]\n"); 845 } 846 847 /// CreateModuleSlot - Insert the specified MDNode* into the slot table. 848 void SlotTracker::CreateMetadataSlot(const MDNode *N) { 849 assert(N && "Can't insert a null Value into SlotTracker!"); 850 851 unsigned DestSlot = mdnNext; 852 if (!mdnMap.insert(std::make_pair(N, DestSlot)).second) 853 return; 854 ++mdnNext; 855 856 // Recursively add any MDNodes referenced by operands. 857 for (unsigned i = 0, e = N->getNumOperands(); i != e; ++i) 858 if (const MDNode *Op = dyn_cast_or_null<MDNode>(N->getOperand(i))) 859 CreateMetadataSlot(Op); 860 } 861 862 void SlotTracker::CreateAttributeSetSlot(AttributeSet AS) { 863 assert(AS.hasAttributes(AttributeSet::FunctionIndex) && 864 "Doesn't need a slot!"); 865 866 as_iterator I = asMap.find(AS); 867 if (I != asMap.end()) 868 return; 869 870 unsigned DestSlot = asNext++; 871 asMap[AS] = DestSlot; 872 } 873 874 //===----------------------------------------------------------------------===// 875 // AsmWriter Implementation 876 //===----------------------------------------------------------------------===// 877 878 static void WriteAsOperandInternal(raw_ostream &Out, const Value *V, 879 TypePrinting *TypePrinter, 880 SlotTracker *Machine, 881 const Module *Context); 882 883 static void WriteAsOperandInternal(raw_ostream &Out, const Metadata *MD, 884 TypePrinting *TypePrinter, 885 SlotTracker *Machine, const Module *Context, 886 bool FromValue = false); 887 888 static const char *getPredicateText(unsigned predicate) { 889 const char * pred = "unknown"; 890 switch (predicate) { 891 case FCmpInst::FCMP_FALSE: pred = "false"; break; 892 case FCmpInst::FCMP_OEQ: pred = "oeq"; break; 893 case FCmpInst::FCMP_OGT: pred = "ogt"; break; 894 case FCmpInst::FCMP_OGE: pred = "oge"; break; 895 case FCmpInst::FCMP_OLT: pred = "olt"; break; 896 case FCmpInst::FCMP_OLE: pred = "ole"; break; 897 case FCmpInst::FCMP_ONE: pred = "one"; break; 898 case FCmpInst::FCMP_ORD: pred = "ord"; break; 899 case FCmpInst::FCMP_UNO: pred = "uno"; break; 900 case FCmpInst::FCMP_UEQ: pred = "ueq"; break; 901 case FCmpInst::FCMP_UGT: pred = "ugt"; break; 902 case FCmpInst::FCMP_UGE: pred = "uge"; break; 903 case FCmpInst::FCMP_ULT: pred = "ult"; break; 904 case FCmpInst::FCMP_ULE: pred = "ule"; break; 905 case FCmpInst::FCMP_UNE: pred = "une"; break; 906 case FCmpInst::FCMP_TRUE: pred = "true"; break; 907 case ICmpInst::ICMP_EQ: pred = "eq"; break; 908 case ICmpInst::ICMP_NE: pred = "ne"; break; 909 case ICmpInst::ICMP_SGT: pred = "sgt"; break; 910 case ICmpInst::ICMP_SGE: pred = "sge"; break; 911 case ICmpInst::ICMP_SLT: pred = "slt"; break; 912 case ICmpInst::ICMP_SLE: pred = "sle"; break; 913 case ICmpInst::ICMP_UGT: pred = "ugt"; break; 914 case ICmpInst::ICMP_UGE: pred = "uge"; break; 915 case ICmpInst::ICMP_ULT: pred = "ult"; break; 916 case ICmpInst::ICMP_ULE: pred = "ule"; break; 917 } 918 return pred; 919 } 920 921 static void writeAtomicRMWOperation(raw_ostream &Out, 922 AtomicRMWInst::BinOp Op) { 923 switch (Op) { 924 default: Out << " <unknown operation " << Op << ">"; break; 925 case AtomicRMWInst::Xchg: Out << " xchg"; break; 926 case AtomicRMWInst::Add: Out << " add"; break; 927 case AtomicRMWInst::Sub: Out << " sub"; break; 928 case AtomicRMWInst::And: Out << " and"; break; 929 case AtomicRMWInst::Nand: Out << " nand"; break; 930 case AtomicRMWInst::Or: Out << " or"; break; 931 case AtomicRMWInst::Xor: Out << " xor"; break; 932 case AtomicRMWInst::Max: Out << " max"; break; 933 case AtomicRMWInst::Min: Out << " min"; break; 934 case AtomicRMWInst::UMax: Out << " umax"; break; 935 case AtomicRMWInst::UMin: Out << " umin"; break; 936 } 937 } 938 939 static void WriteOptimizationInfo(raw_ostream &Out, const User *U) { 940 if (const FPMathOperator *FPO = dyn_cast<const FPMathOperator>(U)) { 941 // Unsafe algebra implies all the others, no need to write them all out 942 if (FPO->hasUnsafeAlgebra()) 943 Out << " fast"; 944 else { 945 if (FPO->hasNoNaNs()) 946 Out << " nnan"; 947 if (FPO->hasNoInfs()) 948 Out << " ninf"; 949 if (FPO->hasNoSignedZeros()) 950 Out << " nsz"; 951 if (FPO->hasAllowReciprocal()) 952 Out << " arcp"; 953 } 954 } 955 956 if (const OverflowingBinaryOperator *OBO = 957 dyn_cast<OverflowingBinaryOperator>(U)) { 958 if (OBO->hasNoUnsignedWrap()) 959 Out << " nuw"; 960 if (OBO->hasNoSignedWrap()) 961 Out << " nsw"; 962 } else if (const PossiblyExactOperator *Div = 963 dyn_cast<PossiblyExactOperator>(U)) { 964 if (Div->isExact()) 965 Out << " exact"; 966 } else if (const GEPOperator *GEP = dyn_cast<GEPOperator>(U)) { 967 if (GEP->isInBounds()) 968 Out << " inbounds"; 969 } 970 } 971 972 static void WriteConstantInternal(raw_ostream &Out, const Constant *CV, 973 TypePrinting &TypePrinter, 974 SlotTracker *Machine, 975 const Module *Context) { 976 if (const ConstantInt *CI = dyn_cast<ConstantInt>(CV)) { 977 if (CI->getType()->isIntegerTy(1)) { 978 Out << (CI->getZExtValue() ? "true" : "false"); 979 return; 980 } 981 Out << CI->getValue(); 982 return; 983 } 984 985 if (const ConstantFP *CFP = dyn_cast<ConstantFP>(CV)) { 986 if (&CFP->getValueAPF().getSemantics() == &APFloat::IEEEsingle || 987 &CFP->getValueAPF().getSemantics() == &APFloat::IEEEdouble) { 988 // We would like to output the FP constant value in exponential notation, 989 // but we cannot do this if doing so will lose precision. Check here to 990 // make sure that we only output it in exponential format if we can parse 991 // the value back and get the same value. 992 // 993 bool ignored; 994 bool isHalf = &CFP->getValueAPF().getSemantics()==&APFloat::IEEEhalf; 995 bool isDouble = &CFP->getValueAPF().getSemantics()==&APFloat::IEEEdouble; 996 bool isInf = CFP->getValueAPF().isInfinity(); 997 bool isNaN = CFP->getValueAPF().isNaN(); 998 if (!isHalf && !isInf && !isNaN) { 999 double Val = isDouble ? CFP->getValueAPF().convertToDouble() : 1000 CFP->getValueAPF().convertToFloat(); 1001 SmallString<128> StrVal; 1002 raw_svector_ostream(StrVal) << Val; 1003 1004 // Check to make sure that the stringized number is not some string like 1005 // "Inf" or NaN, that atof will accept, but the lexer will not. Check 1006 // that the string matches the "[-+]?[0-9]" regex. 1007 // 1008 if ((StrVal[0] >= '0' && StrVal[0] <= '9') || 1009 ((StrVal[0] == '-' || StrVal[0] == '+') && 1010 (StrVal[1] >= '0' && StrVal[1] <= '9'))) { 1011 // Reparse stringized version! 1012 if (APFloat(APFloat::IEEEdouble, StrVal).convertToDouble() == Val) { 1013 Out << StrVal.str(); 1014 return; 1015 } 1016 } 1017 } 1018 // Otherwise we could not reparse it to exactly the same value, so we must 1019 // output the string in hexadecimal format! Note that loading and storing 1020 // floating point types changes the bits of NaNs on some hosts, notably 1021 // x86, so we must not use these types. 1022 static_assert(sizeof(double) == sizeof(uint64_t), 1023 "assuming that double is 64 bits!"); 1024 char Buffer[40]; 1025 APFloat apf = CFP->getValueAPF(); 1026 // Halves and floats are represented in ASCII IR as double, convert. 1027 if (!isDouble) 1028 apf.convert(APFloat::IEEEdouble, APFloat::rmNearestTiesToEven, 1029 &ignored); 1030 Out << "0x" << 1031 utohex_buffer(uint64_t(apf.bitcastToAPInt().getZExtValue()), 1032 Buffer+40); 1033 return; 1034 } 1035 1036 // Either half, or some form of long double. 1037 // These appear as a magic letter identifying the type, then a 1038 // fixed number of hex digits. 1039 Out << "0x"; 1040 // Bit position, in the current word, of the next nibble to print. 1041 int shiftcount; 1042 1043 if (&CFP->getValueAPF().getSemantics() == &APFloat::x87DoubleExtended) { 1044 Out << 'K'; 1045 // api needed to prevent premature destruction 1046 APInt api = CFP->getValueAPF().bitcastToAPInt(); 1047 const uint64_t* p = api.getRawData(); 1048 uint64_t word = p[1]; 1049 shiftcount = 12; 1050 int width = api.getBitWidth(); 1051 for (int j=0; j<width; j+=4, shiftcount-=4) { 1052 unsigned int nibble = (word>>shiftcount) & 15; 1053 if (nibble < 10) 1054 Out << (unsigned char)(nibble + '0'); 1055 else 1056 Out << (unsigned char)(nibble - 10 + 'A'); 1057 if (shiftcount == 0 && j+4 < width) { 1058 word = *p; 1059 shiftcount = 64; 1060 if (width-j-4 < 64) 1061 shiftcount = width-j-4; 1062 } 1063 } 1064 return; 1065 } else if (&CFP->getValueAPF().getSemantics() == &APFloat::IEEEquad) { 1066 shiftcount = 60; 1067 Out << 'L'; 1068 } else if (&CFP->getValueAPF().getSemantics() == &APFloat::PPCDoubleDouble) { 1069 shiftcount = 60; 1070 Out << 'M'; 1071 } else if (&CFP->getValueAPF().getSemantics() == &APFloat::IEEEhalf) { 1072 shiftcount = 12; 1073 Out << 'H'; 1074 } else 1075 llvm_unreachable("Unsupported floating point type"); 1076 // api needed to prevent premature destruction 1077 APInt api = CFP->getValueAPF().bitcastToAPInt(); 1078 const uint64_t* p = api.getRawData(); 1079 uint64_t word = *p; 1080 int width = api.getBitWidth(); 1081 for (int j=0; j<width; j+=4, shiftcount-=4) { 1082 unsigned int nibble = (word>>shiftcount) & 15; 1083 if (nibble < 10) 1084 Out << (unsigned char)(nibble + '0'); 1085 else 1086 Out << (unsigned char)(nibble - 10 + 'A'); 1087 if (shiftcount == 0 && j+4 < width) { 1088 word = *(++p); 1089 shiftcount = 64; 1090 if (width-j-4 < 64) 1091 shiftcount = width-j-4; 1092 } 1093 } 1094 return; 1095 } 1096 1097 if (isa<ConstantAggregateZero>(CV)) { 1098 Out << "zeroinitializer"; 1099 return; 1100 } 1101 1102 if (const BlockAddress *BA = dyn_cast<BlockAddress>(CV)) { 1103 Out << "blockaddress("; 1104 WriteAsOperandInternal(Out, BA->getFunction(), &TypePrinter, Machine, 1105 Context); 1106 Out << ", "; 1107 WriteAsOperandInternal(Out, BA->getBasicBlock(), &TypePrinter, Machine, 1108 Context); 1109 Out << ")"; 1110 return; 1111 } 1112 1113 if (const ConstantArray *CA = dyn_cast<ConstantArray>(CV)) { 1114 Type *ETy = CA->getType()->getElementType(); 1115 Out << '['; 1116 TypePrinter.print(ETy, Out); 1117 Out << ' '; 1118 WriteAsOperandInternal(Out, CA->getOperand(0), 1119 &TypePrinter, Machine, 1120 Context); 1121 for (unsigned i = 1, e = CA->getNumOperands(); i != e; ++i) { 1122 Out << ", "; 1123 TypePrinter.print(ETy, Out); 1124 Out << ' '; 1125 WriteAsOperandInternal(Out, CA->getOperand(i), &TypePrinter, Machine, 1126 Context); 1127 } 1128 Out << ']'; 1129 return; 1130 } 1131 1132 if (const ConstantDataArray *CA = dyn_cast<ConstantDataArray>(CV)) { 1133 // As a special case, print the array as a string if it is an array of 1134 // i8 with ConstantInt values. 1135 if (CA->isString()) { 1136 Out << "c\""; 1137 PrintEscapedString(CA->getAsString(), Out); 1138 Out << '"'; 1139 return; 1140 } 1141 1142 Type *ETy = CA->getType()->getElementType(); 1143 Out << '['; 1144 TypePrinter.print(ETy, Out); 1145 Out << ' '; 1146 WriteAsOperandInternal(Out, CA->getElementAsConstant(0), 1147 &TypePrinter, Machine, 1148 Context); 1149 for (unsigned i = 1, e = CA->getNumElements(); i != e; ++i) { 1150 Out << ", "; 1151 TypePrinter.print(ETy, Out); 1152 Out << ' '; 1153 WriteAsOperandInternal(Out, CA->getElementAsConstant(i), &TypePrinter, 1154 Machine, Context); 1155 } 1156 Out << ']'; 1157 return; 1158 } 1159 1160 1161 if (const ConstantStruct *CS = dyn_cast<ConstantStruct>(CV)) { 1162 if (CS->getType()->isPacked()) 1163 Out << '<'; 1164 Out << '{'; 1165 unsigned N = CS->getNumOperands(); 1166 if (N) { 1167 Out << ' '; 1168 TypePrinter.print(CS->getOperand(0)->getType(), Out); 1169 Out << ' '; 1170 1171 WriteAsOperandInternal(Out, CS->getOperand(0), &TypePrinter, Machine, 1172 Context); 1173 1174 for (unsigned i = 1; i < N; i++) { 1175 Out << ", "; 1176 TypePrinter.print(CS->getOperand(i)->getType(), Out); 1177 Out << ' '; 1178 1179 WriteAsOperandInternal(Out, CS->getOperand(i), &TypePrinter, Machine, 1180 Context); 1181 } 1182 Out << ' '; 1183 } 1184 1185 Out << '}'; 1186 if (CS->getType()->isPacked()) 1187 Out << '>'; 1188 return; 1189 } 1190 1191 if (isa<ConstantVector>(CV) || isa<ConstantDataVector>(CV)) { 1192 Type *ETy = CV->getType()->getVectorElementType(); 1193 Out << '<'; 1194 TypePrinter.print(ETy, Out); 1195 Out << ' '; 1196 WriteAsOperandInternal(Out, CV->getAggregateElement(0U), &TypePrinter, 1197 Machine, Context); 1198 for (unsigned i = 1, e = CV->getType()->getVectorNumElements(); i != e;++i){ 1199 Out << ", "; 1200 TypePrinter.print(ETy, Out); 1201 Out << ' '; 1202 WriteAsOperandInternal(Out, CV->getAggregateElement(i), &TypePrinter, 1203 Machine, Context); 1204 } 1205 Out << '>'; 1206 return; 1207 } 1208 1209 if (isa<ConstantPointerNull>(CV)) { 1210 Out << "null"; 1211 return; 1212 } 1213 1214 if (isa<UndefValue>(CV)) { 1215 Out << "undef"; 1216 return; 1217 } 1218 1219 if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(CV)) { 1220 Out << CE->getOpcodeName(); 1221 WriteOptimizationInfo(Out, CE); 1222 if (CE->isCompare()) 1223 Out << ' ' << getPredicateText(CE->getPredicate()); 1224 Out << " ("; 1225 1226 for (User::const_op_iterator OI=CE->op_begin(); OI != CE->op_end(); ++OI) { 1227 TypePrinter.print((*OI)->getType(), Out); 1228 Out << ' '; 1229 WriteAsOperandInternal(Out, *OI, &TypePrinter, Machine, Context); 1230 if (OI+1 != CE->op_end()) 1231 Out << ", "; 1232 } 1233 1234 if (CE->hasIndices()) { 1235 ArrayRef<unsigned> Indices = CE->getIndices(); 1236 for (unsigned i = 0, e = Indices.size(); i != e; ++i) 1237 Out << ", " << Indices[i]; 1238 } 1239 1240 if (CE->isCast()) { 1241 Out << " to "; 1242 TypePrinter.print(CE->getType(), Out); 1243 } 1244 1245 Out << ')'; 1246 return; 1247 } 1248 1249 Out << "<placeholder or erroneous Constant>"; 1250 } 1251 1252 static void WriteMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node, 1253 TypePrinting *TypePrinter, 1254 SlotTracker *Machine, 1255 const Module *Context) { 1256 Out << "!{"; 1257 for (unsigned mi = 0, me = Node->getNumOperands(); mi != me; ++mi) { 1258 const Metadata *MD = Node->getOperand(mi); 1259 if (!MD) 1260 Out << "null"; 1261 else if (auto *MDV = dyn_cast<ValueAsMetadata>(MD)) { 1262 Value *V = MDV->getValue(); 1263 TypePrinter->print(V->getType(), Out); 1264 Out << ' '; 1265 WriteAsOperandInternal(Out, V, TypePrinter, Machine, Context); 1266 } else { 1267 Out << "metadata "; 1268 WriteAsOperandInternal(Out, MD, TypePrinter, Machine, Context); 1269 } 1270 if (mi + 1 != me) 1271 Out << ", "; 1272 } 1273 1274 Out << "}"; 1275 } 1276 1277 // Full implementation of printing a Value as an operand with support for 1278 // TypePrinting, etc. 1279 static void WriteAsOperandInternal(raw_ostream &Out, const Value *V, 1280 TypePrinting *TypePrinter, 1281 SlotTracker *Machine, 1282 const Module *Context) { 1283 if (V->hasName()) { 1284 PrintLLVMName(Out, V); 1285 return; 1286 } 1287 1288 const Constant *CV = dyn_cast<Constant>(V); 1289 if (CV && !isa<GlobalValue>(CV)) { 1290 assert(TypePrinter && "Constants require TypePrinting!"); 1291 WriteConstantInternal(Out, CV, *TypePrinter, Machine, Context); 1292 return; 1293 } 1294 1295 if (const InlineAsm *IA = dyn_cast<InlineAsm>(V)) { 1296 Out << "asm "; 1297 if (IA->hasSideEffects()) 1298 Out << "sideeffect "; 1299 if (IA->isAlignStack()) 1300 Out << "alignstack "; 1301 // We don't emit the AD_ATT dialect as it's the assumed default. 1302 if (IA->getDialect() == InlineAsm::AD_Intel) 1303 Out << "inteldialect "; 1304 Out << '"'; 1305 PrintEscapedString(IA->getAsmString(), Out); 1306 Out << "\", \""; 1307 PrintEscapedString(IA->getConstraintString(), Out); 1308 Out << '"'; 1309 return; 1310 } 1311 1312 if (auto *MD = dyn_cast<MetadataAsValue>(V)) { 1313 WriteAsOperandInternal(Out, MD->getMetadata(), TypePrinter, Machine, 1314 Context, /* FromValue */ true); 1315 return; 1316 } 1317 1318 char Prefix = '%'; 1319 int Slot; 1320 // If we have a SlotTracker, use it. 1321 if (Machine) { 1322 if (const GlobalValue *GV = dyn_cast<GlobalValue>(V)) { 1323 Slot = Machine->getGlobalSlot(GV); 1324 Prefix = '@'; 1325 } else { 1326 Slot = Machine->getLocalSlot(V); 1327 1328 // If the local value didn't succeed, then we may be referring to a value 1329 // from a different function. Translate it, as this can happen when using 1330 // address of blocks. 1331 if (Slot == -1) 1332 if ((Machine = createSlotTracker(V))) { 1333 Slot = Machine->getLocalSlot(V); 1334 delete Machine; 1335 } 1336 } 1337 } else if ((Machine = createSlotTracker(V))) { 1338 // Otherwise, create one to get the # and then destroy it. 1339 if (const GlobalValue *GV = dyn_cast<GlobalValue>(V)) { 1340 Slot = Machine->getGlobalSlot(GV); 1341 Prefix = '@'; 1342 } else { 1343 Slot = Machine->getLocalSlot(V); 1344 } 1345 delete Machine; 1346 Machine = nullptr; 1347 } else { 1348 Slot = -1; 1349 } 1350 1351 if (Slot != -1) 1352 Out << Prefix << Slot; 1353 else 1354 Out << "<badref>"; 1355 } 1356 1357 static void WriteAsOperandInternal(raw_ostream &Out, const Metadata *MD, 1358 TypePrinting *TypePrinter, 1359 SlotTracker *Machine, const Module *Context, 1360 bool FromValue) { 1361 if (const MDNode *N = dyn_cast<MDNode>(MD)) { 1362 if (!Machine) 1363 Machine = new SlotTracker(Context); 1364 int Slot = Machine->getMetadataSlot(N); 1365 if (Slot == -1) 1366 Out << "<badref>"; 1367 else 1368 Out << '!' << Slot; 1369 return; 1370 } 1371 1372 if (const MDString *MDS = dyn_cast<MDString>(MD)) { 1373 Out << "!\""; 1374 PrintEscapedString(MDS->getString(), Out); 1375 Out << '"'; 1376 return; 1377 } 1378 1379 auto *V = cast<ValueAsMetadata>(MD); 1380 assert(TypePrinter && "TypePrinter required for metadata values"); 1381 assert((FromValue || !isa<LocalAsMetadata>(V)) && 1382 "Unexpected function-local metadata outside of value argument"); 1383 1384 if (FromValue) 1385 Out << "!{"; 1386 TypePrinter->print(V->getValue()->getType(), Out); 1387 Out << ' '; 1388 WriteAsOperandInternal(Out, V->getValue(), TypePrinter, Machine, Context); 1389 if (FromValue) 1390 Out << "}"; 1391 } 1392 1393 void AssemblyWriter::init() { 1394 if (!TheModule) 1395 return; 1396 TypePrinter.incorporateTypes(*TheModule); 1397 for (const Function &F : *TheModule) 1398 if (const Comdat *C = F.getComdat()) 1399 Comdats.insert(C); 1400 for (const GlobalVariable &GV : TheModule->globals()) 1401 if (const Comdat *C = GV.getComdat()) 1402 Comdats.insert(C); 1403 } 1404 1405 1406 AssemblyWriter::AssemblyWriter(formatted_raw_ostream &o, SlotTracker &Mac, 1407 const Module *M, 1408 AssemblyAnnotationWriter *AAW) 1409 : Out(o), TheModule(M), Machine(Mac), AnnotationWriter(AAW) { 1410 init(); 1411 } 1412 1413 AssemblyWriter::AssemblyWriter(formatted_raw_ostream &o, const Module *M, 1414 AssemblyAnnotationWriter *AAW) 1415 : Out(o), TheModule(M), ModuleSlotTracker(createSlotTracker(M)), 1416 Machine(*ModuleSlotTracker), AnnotationWriter(AAW) { 1417 init(); 1418 } 1419 1420 AssemblyWriter::~AssemblyWriter() { } 1421 1422 void AssemblyWriter::writeOperand(const Value *Operand, bool PrintType) { 1423 if (!Operand) { 1424 Out << "<null operand!>"; 1425 return; 1426 } 1427 if (PrintType) { 1428 TypePrinter.print(Operand->getType(), Out); 1429 Out << ' '; 1430 } 1431 WriteAsOperandInternal(Out, Operand, &TypePrinter, &Machine, TheModule); 1432 } 1433 1434 void AssemblyWriter::writeAtomic(AtomicOrdering Ordering, 1435 SynchronizationScope SynchScope) { 1436 if (Ordering == NotAtomic) 1437 return; 1438 1439 switch (SynchScope) { 1440 case SingleThread: Out << " singlethread"; break; 1441 case CrossThread: break; 1442 } 1443 1444 switch (Ordering) { 1445 default: Out << " <bad ordering " << int(Ordering) << ">"; break; 1446 case Unordered: Out << " unordered"; break; 1447 case Monotonic: Out << " monotonic"; break; 1448 case Acquire: Out << " acquire"; break; 1449 case Release: Out << " release"; break; 1450 case AcquireRelease: Out << " acq_rel"; break; 1451 case SequentiallyConsistent: Out << " seq_cst"; break; 1452 } 1453 } 1454 1455 void AssemblyWriter::writeAtomicCmpXchg(AtomicOrdering SuccessOrdering, 1456 AtomicOrdering FailureOrdering, 1457 SynchronizationScope SynchScope) { 1458 assert(SuccessOrdering != NotAtomic && FailureOrdering != NotAtomic); 1459 1460 switch (SynchScope) { 1461 case SingleThread: Out << " singlethread"; break; 1462 case CrossThread: break; 1463 } 1464 1465 switch (SuccessOrdering) { 1466 default: Out << " <bad ordering " << int(SuccessOrdering) << ">"; break; 1467 case Unordered: Out << " unordered"; break; 1468 case Monotonic: Out << " monotonic"; break; 1469 case Acquire: Out << " acquire"; break; 1470 case Release: Out << " release"; break; 1471 case AcquireRelease: Out << " acq_rel"; break; 1472 case SequentiallyConsistent: Out << " seq_cst"; break; 1473 } 1474 1475 switch (FailureOrdering) { 1476 default: Out << " <bad ordering " << int(FailureOrdering) << ">"; break; 1477 case Unordered: Out << " unordered"; break; 1478 case Monotonic: Out << " monotonic"; break; 1479 case Acquire: Out << " acquire"; break; 1480 case Release: Out << " release"; break; 1481 case AcquireRelease: Out << " acq_rel"; break; 1482 case SequentiallyConsistent: Out << " seq_cst"; break; 1483 } 1484 } 1485 1486 void AssemblyWriter::writeParamOperand(const Value *Operand, 1487 AttributeSet Attrs, unsigned Idx) { 1488 if (!Operand) { 1489 Out << "<null operand!>"; 1490 return; 1491 } 1492 1493 // Print the type 1494 TypePrinter.print(Operand->getType(), Out); 1495 // Print parameter attributes list 1496 if (Attrs.hasAttributes(Idx)) 1497 Out << ' ' << Attrs.getAsString(Idx); 1498 Out << ' '; 1499 // Print the operand 1500 WriteAsOperandInternal(Out, Operand, &TypePrinter, &Machine, TheModule); 1501 } 1502 1503 void AssemblyWriter::printModule(const Module *M) { 1504 Machine.initialize(); 1505 1506 if (shouldPreserveAssemblyUseListOrder()) 1507 UseListOrders = predictUseListOrder(M); 1508 1509 if (!M->getModuleIdentifier().empty() && 1510 // Don't print the ID if it will start a new line (which would 1511 // require a comment char before it). 1512 M->getModuleIdentifier().find('\n') == std::string::npos) 1513 Out << "; ModuleID = '" << M->getModuleIdentifier() << "'\n"; 1514 1515 const std::string &DL = M->getDataLayoutStr(); 1516 if (!DL.empty()) 1517 Out << "target datalayout = \"" << DL << "\"\n"; 1518 if (!M->getTargetTriple().empty()) 1519 Out << "target triple = \"" << M->getTargetTriple() << "\"\n"; 1520 1521 if (!M->getModuleInlineAsm().empty()) { 1522 // Split the string into lines, to make it easier to read the .ll file. 1523 std::string Asm = M->getModuleInlineAsm(); 1524 size_t CurPos = 0; 1525 size_t NewLine = Asm.find_first_of('\n', CurPos); 1526 Out << '\n'; 1527 while (NewLine != std::string::npos) { 1528 // We found a newline, print the portion of the asm string from the 1529 // last newline up to this newline. 1530 Out << "module asm \""; 1531 PrintEscapedString(std::string(Asm.begin()+CurPos, Asm.begin()+NewLine), 1532 Out); 1533 Out << "\"\n"; 1534 CurPos = NewLine+1; 1535 NewLine = Asm.find_first_of('\n', CurPos); 1536 } 1537 std::string rest(Asm.begin()+CurPos, Asm.end()); 1538 if (!rest.empty()) { 1539 Out << "module asm \""; 1540 PrintEscapedString(rest, Out); 1541 Out << "\"\n"; 1542 } 1543 } 1544 1545 printTypeIdentities(); 1546 1547 // Output all comdats. 1548 if (!Comdats.empty()) 1549 Out << '\n'; 1550 for (const Comdat *C : Comdats) { 1551 printComdat(C); 1552 if (C != Comdats.back()) 1553 Out << '\n'; 1554 } 1555 1556 // Output all globals. 1557 if (!M->global_empty()) Out << '\n'; 1558 for (Module::const_global_iterator I = M->global_begin(), E = M->global_end(); 1559 I != E; ++I) { 1560 printGlobal(I); Out << '\n'; 1561 } 1562 1563 // Output all aliases. 1564 if (!M->alias_empty()) Out << "\n"; 1565 for (Module::const_alias_iterator I = M->alias_begin(), E = M->alias_end(); 1566 I != E; ++I) 1567 printAlias(I); 1568 1569 // Output global use-lists. 1570 printUseLists(nullptr); 1571 1572 // Output all of the functions. 1573 for (Module::const_iterator I = M->begin(), E = M->end(); I != E; ++I) 1574 printFunction(I); 1575 assert(UseListOrders.empty() && "All use-lists should have been consumed"); 1576 1577 // Output all attribute groups. 1578 if (!Machine.as_empty()) { 1579 Out << '\n'; 1580 writeAllAttributeGroups(); 1581 } 1582 1583 // Output named metadata. 1584 if (!M->named_metadata_empty()) Out << '\n'; 1585 1586 for (Module::const_named_metadata_iterator I = M->named_metadata_begin(), 1587 E = M->named_metadata_end(); I != E; ++I) 1588 printNamedMDNode(I); 1589 1590 // Output metadata. 1591 if (!Machine.mdn_empty()) { 1592 Out << '\n'; 1593 writeAllMDNodes(); 1594 } 1595 } 1596 1597 void AssemblyWriter::printNamedMDNode(const NamedMDNode *NMD) { 1598 Out << '!'; 1599 StringRef Name = NMD->getName(); 1600 if (Name.empty()) { 1601 Out << "<empty name> "; 1602 } else { 1603 if (isalpha(static_cast<unsigned char>(Name[0])) || 1604 Name[0] == '-' || Name[0] == '$' || 1605 Name[0] == '.' || Name[0] == '_') 1606 Out << Name[0]; 1607 else 1608 Out << '\\' << hexdigit(Name[0] >> 4) << hexdigit(Name[0] & 0x0F); 1609 for (unsigned i = 1, e = Name.size(); i != e; ++i) { 1610 unsigned char C = Name[i]; 1611 if (isalnum(static_cast<unsigned char>(C)) || C == '-' || C == '$' || 1612 C == '.' || C == '_') 1613 Out << C; 1614 else 1615 Out << '\\' << hexdigit(C >> 4) << hexdigit(C & 0x0F); 1616 } 1617 } 1618 Out << " = !{"; 1619 for (unsigned i = 0, e = NMD->getNumOperands(); i != e; ++i) { 1620 if (i) Out << ", "; 1621 int Slot = Machine.getMetadataSlot(NMD->getOperand(i)); 1622 if (Slot == -1) 1623 Out << "<badref>"; 1624 else 1625 Out << '!' << Slot; 1626 } 1627 Out << "}\n"; 1628 } 1629 1630 1631 static void PrintLinkage(GlobalValue::LinkageTypes LT, 1632 formatted_raw_ostream &Out) { 1633 switch (LT) { 1634 case GlobalValue::ExternalLinkage: break; 1635 case GlobalValue::PrivateLinkage: Out << "private "; break; 1636 case GlobalValue::InternalLinkage: Out << "internal "; break; 1637 case GlobalValue::LinkOnceAnyLinkage: Out << "linkonce "; break; 1638 case GlobalValue::LinkOnceODRLinkage: Out << "linkonce_odr "; break; 1639 case GlobalValue::WeakAnyLinkage: Out << "weak "; break; 1640 case GlobalValue::WeakODRLinkage: Out << "weak_odr "; break; 1641 case GlobalValue::CommonLinkage: Out << "common "; break; 1642 case GlobalValue::AppendingLinkage: Out << "appending "; break; 1643 case GlobalValue::ExternalWeakLinkage: Out << "extern_weak "; break; 1644 case GlobalValue::AvailableExternallyLinkage: 1645 Out << "available_externally "; 1646 break; 1647 } 1648 } 1649 1650 1651 static void PrintVisibility(GlobalValue::VisibilityTypes Vis, 1652 formatted_raw_ostream &Out) { 1653 switch (Vis) { 1654 case GlobalValue::DefaultVisibility: break; 1655 case GlobalValue::HiddenVisibility: Out << "hidden "; break; 1656 case GlobalValue::ProtectedVisibility: Out << "protected "; break; 1657 } 1658 } 1659 1660 static void PrintDLLStorageClass(GlobalValue::DLLStorageClassTypes SCT, 1661 formatted_raw_ostream &Out) { 1662 switch (SCT) { 1663 case GlobalValue::DefaultStorageClass: break; 1664 case GlobalValue::DLLImportStorageClass: Out << "dllimport "; break; 1665 case GlobalValue::DLLExportStorageClass: Out << "dllexport "; break; 1666 } 1667 } 1668 1669 static void PrintThreadLocalModel(GlobalVariable::ThreadLocalMode TLM, 1670 formatted_raw_ostream &Out) { 1671 switch (TLM) { 1672 case GlobalVariable::NotThreadLocal: 1673 break; 1674 case GlobalVariable::GeneralDynamicTLSModel: 1675 Out << "thread_local "; 1676 break; 1677 case GlobalVariable::LocalDynamicTLSModel: 1678 Out << "thread_local(localdynamic) "; 1679 break; 1680 case GlobalVariable::InitialExecTLSModel: 1681 Out << "thread_local(initialexec) "; 1682 break; 1683 case GlobalVariable::LocalExecTLSModel: 1684 Out << "thread_local(localexec) "; 1685 break; 1686 } 1687 } 1688 1689 void AssemblyWriter::printGlobal(const GlobalVariable *GV) { 1690 if (GV->isMaterializable()) 1691 Out << "; Materializable\n"; 1692 1693 WriteAsOperandInternal(Out, GV, &TypePrinter, &Machine, GV->getParent()); 1694 Out << " = "; 1695 1696 if (!GV->hasInitializer() && GV->hasExternalLinkage()) 1697 Out << "external "; 1698 1699 PrintLinkage(GV->getLinkage(), Out); 1700 PrintVisibility(GV->getVisibility(), Out); 1701 PrintDLLStorageClass(GV->getDLLStorageClass(), Out); 1702 PrintThreadLocalModel(GV->getThreadLocalMode(), Out); 1703 if (GV->hasUnnamedAddr()) 1704 Out << "unnamed_addr "; 1705 1706 if (unsigned AddressSpace = GV->getType()->getAddressSpace()) 1707 Out << "addrspace(" << AddressSpace << ") "; 1708 if (GV->isExternallyInitialized()) Out << "externally_initialized "; 1709 Out << (GV->isConstant() ? "constant " : "global "); 1710 TypePrinter.print(GV->getType()->getElementType(), Out); 1711 1712 if (GV->hasInitializer()) { 1713 Out << ' '; 1714 writeOperand(GV->getInitializer(), false); 1715 } 1716 1717 if (GV->hasSection()) { 1718 Out << ", section \""; 1719 PrintEscapedString(GV->getSection(), Out); 1720 Out << '"'; 1721 } 1722 if (GV->hasComdat()) { 1723 Out << ", comdat "; 1724 PrintLLVMName(Out, GV->getComdat()->getName(), ComdatPrefix); 1725 } 1726 if (GV->getAlignment()) 1727 Out << ", align " << GV->getAlignment(); 1728 1729 printInfoComment(*GV); 1730 } 1731 1732 void AssemblyWriter::printAlias(const GlobalAlias *GA) { 1733 if (GA->isMaterializable()) 1734 Out << "; Materializable\n"; 1735 1736 // Don't crash when dumping partially built GA 1737 if (!GA->hasName()) 1738 Out << "<<nameless>> = "; 1739 else { 1740 PrintLLVMName(Out, GA); 1741 Out << " = "; 1742 } 1743 PrintLinkage(GA->getLinkage(), Out); 1744 PrintVisibility(GA->getVisibility(), Out); 1745 PrintDLLStorageClass(GA->getDLLStorageClass(), Out); 1746 PrintThreadLocalModel(GA->getThreadLocalMode(), Out); 1747 if (GA->hasUnnamedAddr()) 1748 Out << "unnamed_addr "; 1749 1750 Out << "alias "; 1751 1752 const Constant *Aliasee = GA->getAliasee(); 1753 1754 if (!Aliasee) { 1755 TypePrinter.print(GA->getType(), Out); 1756 Out << " <<NULL ALIASEE>>"; 1757 } else { 1758 writeOperand(Aliasee, !isa<ConstantExpr>(Aliasee)); 1759 } 1760 1761 printInfoComment(*GA); 1762 Out << '\n'; 1763 } 1764 1765 void AssemblyWriter::printComdat(const Comdat *C) { 1766 C->print(Out); 1767 } 1768 1769 void AssemblyWriter::printTypeIdentities() { 1770 if (TypePrinter.NumberedTypes.empty() && 1771 TypePrinter.NamedTypes.empty()) 1772 return; 1773 1774 Out << '\n'; 1775 1776 // We know all the numbers that each type is used and we know that it is a 1777 // dense assignment. Convert the map to an index table. 1778 std::vector<StructType*> NumberedTypes(TypePrinter.NumberedTypes.size()); 1779 for (DenseMap<StructType*, unsigned>::iterator I = 1780 TypePrinter.NumberedTypes.begin(), E = TypePrinter.NumberedTypes.end(); 1781 I != E; ++I) { 1782 assert(I->second < NumberedTypes.size() && "Didn't get a dense numbering?"); 1783 NumberedTypes[I->second] = I->first; 1784 } 1785 1786 // Emit all numbered types. 1787 for (unsigned i = 0, e = NumberedTypes.size(); i != e; ++i) { 1788 Out << '%' << i << " = type "; 1789 1790 // Make sure we print out at least one level of the type structure, so 1791 // that we do not get %2 = type %2 1792 TypePrinter.printStructBody(NumberedTypes[i], Out); 1793 Out << '\n'; 1794 } 1795 1796 for (unsigned i = 0, e = TypePrinter.NamedTypes.size(); i != e; ++i) { 1797 PrintLLVMName(Out, TypePrinter.NamedTypes[i]->getName(), LocalPrefix); 1798 Out << " = type "; 1799 1800 // Make sure we print out at least one level of the type structure, so 1801 // that we do not get %FILE = type %FILE 1802 TypePrinter.printStructBody(TypePrinter.NamedTypes[i], Out); 1803 Out << '\n'; 1804 } 1805 } 1806 1807 /// printFunction - Print all aspects of a function. 1808 /// 1809 void AssemblyWriter::printFunction(const Function *F) { 1810 // Print out the return type and name. 1811 Out << '\n'; 1812 1813 if (AnnotationWriter) AnnotationWriter->emitFunctionAnnot(F, Out); 1814 1815 if (F->isMaterializable()) 1816 Out << "; Materializable\n"; 1817 1818 const AttributeSet &Attrs = F->getAttributes(); 1819 if (Attrs.hasAttributes(AttributeSet::FunctionIndex)) { 1820 AttributeSet AS = Attrs.getFnAttributes(); 1821 std::string AttrStr; 1822 1823 unsigned Idx = 0; 1824 for (unsigned E = AS.getNumSlots(); Idx != E; ++Idx) 1825 if (AS.getSlotIndex(Idx) == AttributeSet::FunctionIndex) 1826 break; 1827 1828 for (AttributeSet::iterator I = AS.begin(Idx), E = AS.end(Idx); 1829 I != E; ++I) { 1830 Attribute Attr = *I; 1831 if (!Attr.isStringAttribute()) { 1832 if (!AttrStr.empty()) AttrStr += ' '; 1833 AttrStr += Attr.getAsString(); 1834 } 1835 } 1836 1837 if (!AttrStr.empty()) 1838 Out << "; Function Attrs: " << AttrStr << '\n'; 1839 } 1840 1841 if (F->isDeclaration()) 1842 Out << "declare "; 1843 else 1844 Out << "define "; 1845 1846 PrintLinkage(F->getLinkage(), Out); 1847 PrintVisibility(F->getVisibility(), Out); 1848 PrintDLLStorageClass(F->getDLLStorageClass(), Out); 1849 1850 // Print the calling convention. 1851 if (F->getCallingConv() != CallingConv::C) { 1852 PrintCallingConv(F->getCallingConv(), Out); 1853 Out << " "; 1854 } 1855 1856 FunctionType *FT = F->getFunctionType(); 1857 if (Attrs.hasAttributes(AttributeSet::ReturnIndex)) 1858 Out << Attrs.getAsString(AttributeSet::ReturnIndex) << ' '; 1859 TypePrinter.print(F->getReturnType(), Out); 1860 Out << ' '; 1861 WriteAsOperandInternal(Out, F, &TypePrinter, &Machine, F->getParent()); 1862 Out << '('; 1863 Machine.incorporateFunction(F); 1864 1865 // Loop over the arguments, printing them... 1866 1867 unsigned Idx = 1; 1868 if (!F->isDeclaration()) { 1869 // If this isn't a declaration, print the argument names as well. 1870 for (Function::const_arg_iterator I = F->arg_begin(), E = F->arg_end(); 1871 I != E; ++I) { 1872 // Insert commas as we go... the first arg doesn't get a comma 1873 if (I != F->arg_begin()) Out << ", "; 1874 printArgument(I, Attrs, Idx); 1875 Idx++; 1876 } 1877 } else { 1878 // Otherwise, print the types from the function type. 1879 for (unsigned i = 0, e = FT->getNumParams(); i != e; ++i) { 1880 // Insert commas as we go... the first arg doesn't get a comma 1881 if (i) Out << ", "; 1882 1883 // Output type... 1884 TypePrinter.print(FT->getParamType(i), Out); 1885 1886 if (Attrs.hasAttributes(i+1)) 1887 Out << ' ' << Attrs.getAsString(i+1); 1888 } 1889 } 1890 1891 // Finish printing arguments... 1892 if (FT->isVarArg()) { 1893 if (FT->getNumParams()) Out << ", "; 1894 Out << "..."; // Output varargs portion of signature! 1895 } 1896 Out << ')'; 1897 if (F->hasUnnamedAddr()) 1898 Out << " unnamed_addr"; 1899 if (Attrs.hasAttributes(AttributeSet::FunctionIndex)) 1900 Out << " #" << Machine.getAttributeGroupSlot(Attrs.getFnAttributes()); 1901 if (F->hasSection()) { 1902 Out << " section \""; 1903 PrintEscapedString(F->getSection(), Out); 1904 Out << '"'; 1905 } 1906 if (F->hasComdat()) { 1907 Out << " comdat "; 1908 PrintLLVMName(Out, F->getComdat()->getName(), ComdatPrefix); 1909 } 1910 if (F->getAlignment()) 1911 Out << " align " << F->getAlignment(); 1912 if (F->hasGC()) 1913 Out << " gc \"" << F->getGC() << '"'; 1914 if (F->hasPrefixData()) { 1915 Out << " prefix "; 1916 writeOperand(F->getPrefixData(), true); 1917 } 1918 if (F->hasPrologueData()) { 1919 Out << " prologue "; 1920 writeOperand(F->getPrologueData(), true); 1921 } 1922 1923 if (F->isDeclaration()) { 1924 Out << '\n'; 1925 } else { 1926 Out << " {"; 1927 // Output all of the function's basic blocks. 1928 for (Function::const_iterator I = F->begin(), E = F->end(); I != E; ++I) 1929 printBasicBlock(I); 1930 1931 // Output the function's use-lists. 1932 printUseLists(F); 1933 1934 Out << "}\n"; 1935 } 1936 1937 Machine.purgeFunction(); 1938 } 1939 1940 /// printArgument - This member is called for every argument that is passed into 1941 /// the function. Simply print it out 1942 /// 1943 void AssemblyWriter::printArgument(const Argument *Arg, 1944 AttributeSet Attrs, unsigned Idx) { 1945 // Output type... 1946 TypePrinter.print(Arg->getType(), Out); 1947 1948 // Output parameter attributes list 1949 if (Attrs.hasAttributes(Idx)) 1950 Out << ' ' << Attrs.getAsString(Idx); 1951 1952 // Output name, if available... 1953 if (Arg->hasName()) { 1954 Out << ' '; 1955 PrintLLVMName(Out, Arg); 1956 } 1957 } 1958 1959 /// printBasicBlock - This member is called for each basic block in a method. 1960 /// 1961 void AssemblyWriter::printBasicBlock(const BasicBlock *BB) { 1962 if (BB->hasName()) { // Print out the label if it exists... 1963 Out << "\n"; 1964 PrintLLVMName(Out, BB->getName(), LabelPrefix); 1965 Out << ':'; 1966 } else if (!BB->use_empty()) { // Don't print block # of no uses... 1967 Out << "\n; <label>:"; 1968 int Slot = Machine.getLocalSlot(BB); 1969 if (Slot != -1) 1970 Out << Slot; 1971 else 1972 Out << "<badref>"; 1973 } 1974 1975 if (!BB->getParent()) { 1976 Out.PadToColumn(50); 1977 Out << "; Error: Block without parent!"; 1978 } else if (BB != &BB->getParent()->getEntryBlock()) { // Not the entry block? 1979 // Output predecessors for the block. 1980 Out.PadToColumn(50); 1981 Out << ";"; 1982 const_pred_iterator PI = pred_begin(BB), PE = pred_end(BB); 1983 1984 if (PI == PE) { 1985 Out << " No predecessors!"; 1986 } else { 1987 Out << " preds = "; 1988 writeOperand(*PI, false); 1989 for (++PI; PI != PE; ++PI) { 1990 Out << ", "; 1991 writeOperand(*PI, false); 1992 } 1993 } 1994 } 1995 1996 Out << "\n"; 1997 1998 if (AnnotationWriter) AnnotationWriter->emitBasicBlockStartAnnot(BB, Out); 1999 2000 // Output all of the instructions in the basic block... 2001 for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I != E; ++I) { 2002 printInstructionLine(*I); 2003 } 2004 2005 if (AnnotationWriter) AnnotationWriter->emitBasicBlockEndAnnot(BB, Out); 2006 } 2007 2008 /// printInstructionLine - Print an instruction and a newline character. 2009 void AssemblyWriter::printInstructionLine(const Instruction &I) { 2010 printInstruction(I); 2011 Out << '\n'; 2012 } 2013 2014 /// printInfoComment - Print a little comment after the instruction indicating 2015 /// which slot it occupies. 2016 /// 2017 void AssemblyWriter::printInfoComment(const Value &V) { 2018 if (AnnotationWriter) 2019 AnnotationWriter->printInfoComment(V, Out); 2020 } 2021 2022 // This member is called for each Instruction in a function.. 2023 void AssemblyWriter::printInstruction(const Instruction &I) { 2024 if (AnnotationWriter) AnnotationWriter->emitInstructionAnnot(&I, Out); 2025 2026 // Print out indentation for an instruction. 2027 Out << " "; 2028 2029 // Print out name if it exists... 2030 if (I.hasName()) { 2031 PrintLLVMName(Out, &I); 2032 Out << " = "; 2033 } else if (!I.getType()->isVoidTy()) { 2034 // Print out the def slot taken. 2035 int SlotNum = Machine.getLocalSlot(&I); 2036 if (SlotNum == -1) 2037 Out << "<badref> = "; 2038 else 2039 Out << '%' << SlotNum << " = "; 2040 } 2041 2042 if (const CallInst *CI = dyn_cast<CallInst>(&I)) { 2043 if (CI->isMustTailCall()) 2044 Out << "musttail "; 2045 else if (CI->isTailCall()) 2046 Out << "tail "; 2047 } 2048 2049 // Print out the opcode... 2050 Out << I.getOpcodeName(); 2051 2052 // If this is an atomic load or store, print out the atomic marker. 2053 if ((isa<LoadInst>(I) && cast<LoadInst>(I).isAtomic()) || 2054 (isa<StoreInst>(I) && cast<StoreInst>(I).isAtomic())) 2055 Out << " atomic"; 2056 2057 if (isa<AtomicCmpXchgInst>(I) && cast<AtomicCmpXchgInst>(I).isWeak()) 2058 Out << " weak"; 2059 2060 // If this is a volatile operation, print out the volatile marker. 2061 if ((isa<LoadInst>(I) && cast<LoadInst>(I).isVolatile()) || 2062 (isa<StoreInst>(I) && cast<StoreInst>(I).isVolatile()) || 2063 (isa<AtomicCmpXchgInst>(I) && cast<AtomicCmpXchgInst>(I).isVolatile()) || 2064 (isa<AtomicRMWInst>(I) && cast<AtomicRMWInst>(I).isVolatile())) 2065 Out << " volatile"; 2066 2067 // Print out optimization information. 2068 WriteOptimizationInfo(Out, &I); 2069 2070 // Print out the compare instruction predicates 2071 if (const CmpInst *CI = dyn_cast<CmpInst>(&I)) 2072 Out << ' ' << getPredicateText(CI->getPredicate()); 2073 2074 // Print out the atomicrmw operation 2075 if (const AtomicRMWInst *RMWI = dyn_cast<AtomicRMWInst>(&I)) 2076 writeAtomicRMWOperation(Out, RMWI->getOperation()); 2077 2078 // Print out the type of the operands... 2079 const Value *Operand = I.getNumOperands() ? I.getOperand(0) : nullptr; 2080 2081 // Special case conditional branches to swizzle the condition out to the front 2082 if (isa<BranchInst>(I) && cast<BranchInst>(I).isConditional()) { 2083 const BranchInst &BI(cast<BranchInst>(I)); 2084 Out << ' '; 2085 writeOperand(BI.getCondition(), true); 2086 Out << ", "; 2087 writeOperand(BI.getSuccessor(0), true); 2088 Out << ", "; 2089 writeOperand(BI.getSuccessor(1), true); 2090 2091 } else if (isa<SwitchInst>(I)) { 2092 const SwitchInst& SI(cast<SwitchInst>(I)); 2093 // Special case switch instruction to get formatting nice and correct. 2094 Out << ' '; 2095 writeOperand(SI.getCondition(), true); 2096 Out << ", "; 2097 writeOperand(SI.getDefaultDest(), true); 2098 Out << " ["; 2099 for (SwitchInst::ConstCaseIt i = SI.case_begin(), e = SI.case_end(); 2100 i != e; ++i) { 2101 Out << "\n "; 2102 writeOperand(i.getCaseValue(), true); 2103 Out << ", "; 2104 writeOperand(i.getCaseSuccessor(), true); 2105 } 2106 Out << "\n ]"; 2107 } else if (isa<IndirectBrInst>(I)) { 2108 // Special case indirectbr instruction to get formatting nice and correct. 2109 Out << ' '; 2110 writeOperand(Operand, true); 2111 Out << ", ["; 2112 2113 for (unsigned i = 1, e = I.getNumOperands(); i != e; ++i) { 2114 if (i != 1) 2115 Out << ", "; 2116 writeOperand(I.getOperand(i), true); 2117 } 2118 Out << ']'; 2119 } else if (const PHINode *PN = dyn_cast<PHINode>(&I)) { 2120 Out << ' '; 2121 TypePrinter.print(I.getType(), Out); 2122 Out << ' '; 2123 2124 for (unsigned op = 0, Eop = PN->getNumIncomingValues(); op < Eop; ++op) { 2125 if (op) Out << ", "; 2126 Out << "[ "; 2127 writeOperand(PN->getIncomingValue(op), false); Out << ", "; 2128 writeOperand(PN->getIncomingBlock(op), false); Out << " ]"; 2129 } 2130 } else if (const ExtractValueInst *EVI = dyn_cast<ExtractValueInst>(&I)) { 2131 Out << ' '; 2132 writeOperand(I.getOperand(0), true); 2133 for (const unsigned *i = EVI->idx_begin(), *e = EVI->idx_end(); i != e; ++i) 2134 Out << ", " << *i; 2135 } else if (const InsertValueInst *IVI = dyn_cast<InsertValueInst>(&I)) { 2136 Out << ' '; 2137 writeOperand(I.getOperand(0), true); Out << ", "; 2138 writeOperand(I.getOperand(1), true); 2139 for (const unsigned *i = IVI->idx_begin(), *e = IVI->idx_end(); i != e; ++i) 2140 Out << ", " << *i; 2141 } else if (const LandingPadInst *LPI = dyn_cast<LandingPadInst>(&I)) { 2142 Out << ' '; 2143 TypePrinter.print(I.getType(), Out); 2144 Out << " personality "; 2145 writeOperand(I.getOperand(0), true); Out << '\n'; 2146 2147 if (LPI->isCleanup()) 2148 Out << " cleanup"; 2149 2150 for (unsigned i = 0, e = LPI->getNumClauses(); i != e; ++i) { 2151 if (i != 0 || LPI->isCleanup()) Out << "\n"; 2152 if (LPI->isCatch(i)) 2153 Out << " catch "; 2154 else 2155 Out << " filter "; 2156 2157 writeOperand(LPI->getClause(i), true); 2158 } 2159 } else if (isa<ReturnInst>(I) && !Operand) { 2160 Out << " void"; 2161 } else if (const CallInst *CI = dyn_cast<CallInst>(&I)) { 2162 // Print the calling convention being used. 2163 if (CI->getCallingConv() != CallingConv::C) { 2164 Out << " "; 2165 PrintCallingConv(CI->getCallingConv(), Out); 2166 } 2167 2168 Operand = CI->getCalledValue(); 2169 PointerType *PTy = cast<PointerType>(Operand->getType()); 2170 FunctionType *FTy = cast<FunctionType>(PTy->getElementType()); 2171 Type *RetTy = FTy->getReturnType(); 2172 const AttributeSet &PAL = CI->getAttributes(); 2173 2174 if (PAL.hasAttributes(AttributeSet::ReturnIndex)) 2175 Out << ' ' << PAL.getAsString(AttributeSet::ReturnIndex); 2176 2177 // If possible, print out the short form of the call instruction. We can 2178 // only do this if the first argument is a pointer to a nonvararg function, 2179 // and if the return type is not a pointer to a function. 2180 // 2181 Out << ' '; 2182 if (!FTy->isVarArg() && 2183 (!RetTy->isPointerTy() || 2184 !cast<PointerType>(RetTy)->getElementType()->isFunctionTy())) { 2185 TypePrinter.print(RetTy, Out); 2186 Out << ' '; 2187 writeOperand(Operand, false); 2188 } else { 2189 writeOperand(Operand, true); 2190 } 2191 Out << '('; 2192 for (unsigned op = 0, Eop = CI->getNumArgOperands(); op < Eop; ++op) { 2193 if (op > 0) 2194 Out << ", "; 2195 writeParamOperand(CI->getArgOperand(op), PAL, op + 1); 2196 } 2197 2198 // Emit an ellipsis if this is a musttail call in a vararg function. This 2199 // is only to aid readability, musttail calls forward varargs by default. 2200 if (CI->isMustTailCall() && CI->getParent() && 2201 CI->getParent()->getParent() && 2202 CI->getParent()->getParent()->isVarArg()) 2203 Out << ", ..."; 2204 2205 Out << ')'; 2206 if (PAL.hasAttributes(AttributeSet::FunctionIndex)) 2207 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttributes()); 2208 } else if (const InvokeInst *II = dyn_cast<InvokeInst>(&I)) { 2209 Operand = II->getCalledValue(); 2210 PointerType *PTy = cast<PointerType>(Operand->getType()); 2211 FunctionType *FTy = cast<FunctionType>(PTy->getElementType()); 2212 Type *RetTy = FTy->getReturnType(); 2213 const AttributeSet &PAL = II->getAttributes(); 2214 2215 // Print the calling convention being used. 2216 if (II->getCallingConv() != CallingConv::C) { 2217 Out << " "; 2218 PrintCallingConv(II->getCallingConv(), Out); 2219 } 2220 2221 if (PAL.hasAttributes(AttributeSet::ReturnIndex)) 2222 Out << ' ' << PAL.getAsString(AttributeSet::ReturnIndex); 2223 2224 // If possible, print out the short form of the invoke instruction. We can 2225 // only do this if the first argument is a pointer to a nonvararg function, 2226 // and if the return type is not a pointer to a function. 2227 // 2228 Out << ' '; 2229 if (!FTy->isVarArg() && 2230 (!RetTy->isPointerTy() || 2231 !cast<PointerType>(RetTy)->getElementType()->isFunctionTy())) { 2232 TypePrinter.print(RetTy, Out); 2233 Out << ' '; 2234 writeOperand(Operand, false); 2235 } else { 2236 writeOperand(Operand, true); 2237 } 2238 Out << '('; 2239 for (unsigned op = 0, Eop = II->getNumArgOperands(); op < Eop; ++op) { 2240 if (op) 2241 Out << ", "; 2242 writeParamOperand(II->getArgOperand(op), PAL, op + 1); 2243 } 2244 2245 Out << ')'; 2246 if (PAL.hasAttributes(AttributeSet::FunctionIndex)) 2247 Out << " #" << Machine.getAttributeGroupSlot(PAL.getFnAttributes()); 2248 2249 Out << "\n to "; 2250 writeOperand(II->getNormalDest(), true); 2251 Out << " unwind "; 2252 writeOperand(II->getUnwindDest(), true); 2253 2254 } else if (const AllocaInst *AI = dyn_cast<AllocaInst>(&I)) { 2255 Out << ' '; 2256 if (AI->isUsedWithInAlloca()) 2257 Out << "inalloca "; 2258 TypePrinter.print(AI->getAllocatedType(), Out); 2259 if (!AI->getArraySize() || AI->isArrayAllocation()) { 2260 Out << ", "; 2261 writeOperand(AI->getArraySize(), true); 2262 } 2263 if (AI->getAlignment()) { 2264 Out << ", align " << AI->getAlignment(); 2265 } 2266 } else if (isa<CastInst>(I)) { 2267 if (Operand) { 2268 Out << ' '; 2269 writeOperand(Operand, true); // Work with broken code 2270 } 2271 Out << " to "; 2272 TypePrinter.print(I.getType(), Out); 2273 } else if (isa<VAArgInst>(I)) { 2274 if (Operand) { 2275 Out << ' '; 2276 writeOperand(Operand, true); // Work with broken code 2277 } 2278 Out << ", "; 2279 TypePrinter.print(I.getType(), Out); 2280 } else if (Operand) { // Print the normal way. 2281 2282 // PrintAllTypes - Instructions who have operands of all the same type 2283 // omit the type from all but the first operand. If the instruction has 2284 // different type operands (for example br), then they are all printed. 2285 bool PrintAllTypes = false; 2286 Type *TheType = Operand->getType(); 2287 2288 // Select, Store and ShuffleVector always print all types. 2289 if (isa<SelectInst>(I) || isa<StoreInst>(I) || isa<ShuffleVectorInst>(I) 2290 || isa<ReturnInst>(I)) { 2291 PrintAllTypes = true; 2292 } else { 2293 for (unsigned i = 1, E = I.getNumOperands(); i != E; ++i) { 2294 Operand = I.getOperand(i); 2295 // note that Operand shouldn't be null, but the test helps make dump() 2296 // more tolerant of malformed IR 2297 if (Operand && Operand->getType() != TheType) { 2298 PrintAllTypes = true; // We have differing types! Print them all! 2299 break; 2300 } 2301 } 2302 } 2303 2304 if (!PrintAllTypes) { 2305 Out << ' '; 2306 TypePrinter.print(TheType, Out); 2307 } 2308 2309 Out << ' '; 2310 for (unsigned i = 0, E = I.getNumOperands(); i != E; ++i) { 2311 if (i) Out << ", "; 2312 writeOperand(I.getOperand(i), PrintAllTypes); 2313 } 2314 } 2315 2316 // Print atomic ordering/alignment for memory operations 2317 if (const LoadInst *LI = dyn_cast<LoadInst>(&I)) { 2318 if (LI->isAtomic()) 2319 writeAtomic(LI->getOrdering(), LI->getSynchScope()); 2320 if (LI->getAlignment()) 2321 Out << ", align " << LI->getAlignment(); 2322 } else if (const StoreInst *SI = dyn_cast<StoreInst>(&I)) { 2323 if (SI->isAtomic()) 2324 writeAtomic(SI->getOrdering(), SI->getSynchScope()); 2325 if (SI->getAlignment()) 2326 Out << ", align " << SI->getAlignment(); 2327 } else if (const AtomicCmpXchgInst *CXI = dyn_cast<AtomicCmpXchgInst>(&I)) { 2328 writeAtomicCmpXchg(CXI->getSuccessOrdering(), CXI->getFailureOrdering(), 2329 CXI->getSynchScope()); 2330 } else if (const AtomicRMWInst *RMWI = dyn_cast<AtomicRMWInst>(&I)) { 2331 writeAtomic(RMWI->getOrdering(), RMWI->getSynchScope()); 2332 } else if (const FenceInst *FI = dyn_cast<FenceInst>(&I)) { 2333 writeAtomic(FI->getOrdering(), FI->getSynchScope()); 2334 } 2335 2336 // Print Metadata info. 2337 SmallVector<std::pair<unsigned, MDNode *>, 4> InstMD; 2338 I.getAllMetadata(InstMD); 2339 if (!InstMD.empty()) { 2340 SmallVector<StringRef, 8> MDNames; 2341 I.getType()->getContext().getMDKindNames(MDNames); 2342 for (unsigned i = 0, e = InstMD.size(); i != e; ++i) { 2343 unsigned Kind = InstMD[i].first; 2344 if (Kind < MDNames.size()) { 2345 Out << ", !" << MDNames[Kind]; 2346 } else { 2347 Out << ", !<unknown kind #" << Kind << ">"; 2348 } 2349 Out << ' '; 2350 WriteAsOperandInternal(Out, InstMD[i].second, &TypePrinter, &Machine, 2351 TheModule); 2352 } 2353 } 2354 printInfoComment(I); 2355 } 2356 2357 static void WriteMDNodeComment(const MDNode *Node, 2358 formatted_raw_ostream &Out) { 2359 if (Node->getNumOperands() < 1) 2360 return; 2361 2362 Metadata *Op = Node->getOperand(0); 2363 if (!Op || !isa<MDString>(Op)) 2364 return; 2365 2366 DIDescriptor Desc(Node); 2367 if (!Desc.Verify()) 2368 return; 2369 2370 unsigned Tag = Desc.getTag(); 2371 Out.PadToColumn(50); 2372 if (dwarf::TagString(Tag)) { 2373 Out << "; "; 2374 Desc.print(Out); 2375 } else if (Tag == dwarf::DW_TAG_user_base) { 2376 Out << "; [ DW_TAG_user_base ]"; 2377 } 2378 } 2379 2380 void AssemblyWriter::writeMDNode(unsigned Slot, const MDNode *Node) { 2381 Out << '!' << Slot << " = metadata "; 2382 printMDNodeBody(Node); 2383 } 2384 2385 void AssemblyWriter::writeAllMDNodes() { 2386 SmallVector<const MDNode *, 16> Nodes; 2387 Nodes.resize(Machine.mdn_size()); 2388 for (SlotTracker::mdn_iterator I = Machine.mdn_begin(), E = Machine.mdn_end(); 2389 I != E; ++I) 2390 Nodes[I->second] = cast<MDNode>(I->first); 2391 2392 for (unsigned i = 0, e = Nodes.size(); i != e; ++i) { 2393 writeMDNode(i, Nodes[i]); 2394 } 2395 } 2396 2397 void AssemblyWriter::printMDNodeBody(const MDNode *Node) { 2398 WriteMDNodeBodyInternal(Out, Node, &TypePrinter, &Machine, TheModule); 2399 WriteMDNodeComment(Node, Out); 2400 Out << "\n"; 2401 } 2402 2403 void AssemblyWriter::writeAllAttributeGroups() { 2404 std::vector<std::pair<AttributeSet, unsigned> > asVec; 2405 asVec.resize(Machine.as_size()); 2406 2407 for (SlotTracker::as_iterator I = Machine.as_begin(), E = Machine.as_end(); 2408 I != E; ++I) 2409 asVec[I->second] = *I; 2410 2411 for (std::vector<std::pair<AttributeSet, unsigned> >::iterator 2412 I = asVec.begin(), E = asVec.end(); I != E; ++I) 2413 Out << "attributes #" << I->second << " = { " 2414 << I->first.getAsString(AttributeSet::FunctionIndex, true) << " }\n"; 2415 } 2416 2417 } // namespace llvm 2418 2419 void AssemblyWriter::printUseListOrder(const UseListOrder &Order) { 2420 bool IsInFunction = Machine.getFunction(); 2421 if (IsInFunction) 2422 Out << " "; 2423 2424 Out << "uselistorder"; 2425 if (const BasicBlock *BB = 2426 IsInFunction ? nullptr : dyn_cast<BasicBlock>(Order.V)) { 2427 Out << "_bb "; 2428 writeOperand(BB->getParent(), false); 2429 Out << ", "; 2430 writeOperand(BB, false); 2431 } else { 2432 Out << " "; 2433 writeOperand(Order.V, true); 2434 } 2435 Out << ", { "; 2436 2437 assert(Order.Shuffle.size() >= 2 && "Shuffle too small"); 2438 Out << Order.Shuffle[0]; 2439 for (unsigned I = 1, E = Order.Shuffle.size(); I != E; ++I) 2440 Out << ", " << Order.Shuffle[I]; 2441 Out << " }\n"; 2442 } 2443 2444 void AssemblyWriter::printUseLists(const Function *F) { 2445 auto hasMore = 2446 [&]() { return !UseListOrders.empty() && UseListOrders.back().F == F; }; 2447 if (!hasMore()) 2448 // Nothing to do. 2449 return; 2450 2451 Out << "\n; uselistorder directives\n"; 2452 while (hasMore()) { 2453 printUseListOrder(UseListOrders.back()); 2454 UseListOrders.pop_back(); 2455 } 2456 } 2457 2458 //===----------------------------------------------------------------------===// 2459 // External Interface declarations 2460 //===----------------------------------------------------------------------===// 2461 2462 void Module::print(raw_ostream &ROS, AssemblyAnnotationWriter *AAW) const { 2463 SlotTracker SlotTable(this); 2464 formatted_raw_ostream OS(ROS); 2465 AssemblyWriter W(OS, SlotTable, this, AAW); 2466 W.printModule(this); 2467 } 2468 2469 void NamedMDNode::print(raw_ostream &ROS) const { 2470 SlotTracker SlotTable(getParent()); 2471 formatted_raw_ostream OS(ROS); 2472 AssemblyWriter W(OS, SlotTable, getParent(), nullptr); 2473 W.printNamedMDNode(this); 2474 } 2475 2476 void Comdat::print(raw_ostream &ROS) const { 2477 PrintLLVMName(ROS, getName(), ComdatPrefix); 2478 ROS << " = comdat "; 2479 2480 switch (getSelectionKind()) { 2481 case Comdat::Any: 2482 ROS << "any"; 2483 break; 2484 case Comdat::ExactMatch: 2485 ROS << "exactmatch"; 2486 break; 2487 case Comdat::Largest: 2488 ROS << "largest"; 2489 break; 2490 case Comdat::NoDuplicates: 2491 ROS << "noduplicates"; 2492 break; 2493 case Comdat::SameSize: 2494 ROS << "samesize"; 2495 break; 2496 } 2497 2498 ROS << '\n'; 2499 } 2500 2501 void Type::print(raw_ostream &OS) const { 2502 TypePrinting TP; 2503 TP.print(const_cast<Type*>(this), OS); 2504 2505 // If the type is a named struct type, print the body as well. 2506 if (StructType *STy = dyn_cast<StructType>(const_cast<Type*>(this))) 2507 if (!STy->isLiteral()) { 2508 OS << " = type "; 2509 TP.printStructBody(STy, OS); 2510 } 2511 } 2512 2513 void Value::print(raw_ostream &ROS) const { 2514 formatted_raw_ostream OS(ROS); 2515 if (const Instruction *I = dyn_cast<Instruction>(this)) { 2516 const Function *F = I->getParent() ? I->getParent()->getParent() : nullptr; 2517 SlotTracker SlotTable(F); 2518 AssemblyWriter W(OS, SlotTable, getModuleFromVal(I), nullptr); 2519 W.printInstruction(*I); 2520 } else if (const BasicBlock *BB = dyn_cast<BasicBlock>(this)) { 2521 SlotTracker SlotTable(BB->getParent()); 2522 AssemblyWriter W(OS, SlotTable, getModuleFromVal(BB), nullptr); 2523 W.printBasicBlock(BB); 2524 } else if (const GlobalValue *GV = dyn_cast<GlobalValue>(this)) { 2525 SlotTracker SlotTable(GV->getParent()); 2526 AssemblyWriter W(OS, SlotTable, GV->getParent(), nullptr); 2527 if (const GlobalVariable *V = dyn_cast<GlobalVariable>(GV)) 2528 W.printGlobal(V); 2529 else if (const Function *F = dyn_cast<Function>(GV)) 2530 W.printFunction(F); 2531 else 2532 W.printAlias(cast<GlobalAlias>(GV)); 2533 } else if (const MetadataAsValue *V = dyn_cast<MetadataAsValue>(this)) { 2534 V->getMetadata()->print(ROS); 2535 } else if (const Constant *C = dyn_cast<Constant>(this)) { 2536 TypePrinting TypePrinter; 2537 TypePrinter.print(C->getType(), OS); 2538 OS << ' '; 2539 WriteConstantInternal(OS, C, TypePrinter, nullptr, nullptr); 2540 } else if (isa<InlineAsm>(this) || isa<Argument>(this)) { 2541 this->printAsOperand(OS); 2542 } else { 2543 llvm_unreachable("Unknown value to print out!"); 2544 } 2545 } 2546 2547 void Value::printAsOperand(raw_ostream &O, bool PrintType, const Module *M) const { 2548 // Fast path: Don't construct and populate a TypePrinting object if we 2549 // won't be needing any types printed. 2550 if (!PrintType && ((!isa<Constant>(this) && !isa<MetadataAsValue>(this)) || 2551 hasName() || isa<GlobalValue>(this))) { 2552 WriteAsOperandInternal(O, this, nullptr, nullptr, M); 2553 return; 2554 } 2555 2556 if (!M) 2557 M = getModuleFromVal(this); 2558 2559 TypePrinting TypePrinter; 2560 if (M) 2561 TypePrinter.incorporateTypes(*M); 2562 if (PrintType) { 2563 TypePrinter.print(getType(), O); 2564 O << ' '; 2565 } 2566 2567 WriteAsOperandInternal(O, this, &TypePrinter, nullptr, M); 2568 } 2569 2570 void Metadata::print(raw_ostream &ROS) const { 2571 formatted_raw_ostream OS(ROS); 2572 if (auto *N = dyn_cast<MDNode>(this)) { 2573 OS << "metadata "; 2574 SlotTracker SlotTable(static_cast<Function *>(nullptr)); 2575 AssemblyWriter W(OS, SlotTable, nullptr, nullptr); 2576 W.printMDNodeBody(N); 2577 2578 return; 2579 } 2580 printAsOperand(OS); 2581 } 2582 2583 void Metadata::printAsOperand(raw_ostream &ROS, bool PrintType, 2584 const Module *M) const { 2585 formatted_raw_ostream OS(ROS); 2586 if (PrintType) 2587 OS << "metadata "; 2588 2589 std::unique_ptr<TypePrinting> TypePrinter; 2590 if (PrintType) { 2591 TypePrinter.reset(new TypePrinting); 2592 if (M) 2593 TypePrinter->incorporateTypes(*M); 2594 } 2595 WriteAsOperandInternal(OS, this, TypePrinter.get(), nullptr, M, 2596 /* FromValue */ true); 2597 } 2598 2599 // Value::dump - allow easy printing of Values from the debugger. 2600 void Value::dump() const { print(dbgs()); dbgs() << '\n'; } 2601 2602 // Type::dump - allow easy printing of Types from the debugger. 2603 void Type::dump() const { print(dbgs()); dbgs() << '\n'; } 2604 2605 // Module::dump() - Allow printing of Modules from the debugger. 2606 void Module::dump() const { print(dbgs(), nullptr); } 2607 2608 // \brief Allow printing of Comdats from the debugger. 2609 void Comdat::dump() const { print(dbgs()); } 2610 2611 // NamedMDNode::dump() - Allow printing of NamedMDNodes from the debugger. 2612 void NamedMDNode::dump() const { print(dbgs()); } 2613 2614 void Metadata::dump() const { 2615 print(dbgs()); 2616 dbgs() << '\n'; 2617 } 2618