diff options
author | Chris Lattner <sabre@nondot.org> | 2005-11-21 07:06:27 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-11-21 07:06:27 +0000 |
commit | 2ea5c99eca017fb740f49b44eb9338018e8374d4 (patch) | |
tree | 48456b9e706a60b157cde756e6dccf52fcea2198 /llvm/lib | |
parent | 279f96c55e86a264fdbe6500f2f1362fac2514cf (diff) | |
download | bcm5719-llvm-2ea5c99eca017fb740f49b44eb9338018e8374d4.tar.gz bcm5719-llvm-2ea5c99eca017fb740f49b44eb9338018e8374d4.zip |
Add section switching to common code generator code. Add a couple of
asserts.
llvm-svn: 24445
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/CodeGen/AsmPrinter.cpp | 19 | ||||
-rw-r--r-- | llvm/lib/CodeGen/LiveVariables.cpp | 5 | ||||
-rw-r--r-- | llvm/lib/CodeGen/RegAllocLinearScan.cpp | 1 |
3 files changed, 23 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter.cpp index d81846bd7a8..9faea7085a7 100644 --- a/llvm/lib/CodeGen/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter.cpp @@ -19,8 +19,27 @@ #include "llvm/Target/TargetMachine.h" using namespace llvm; +/// SwitchSection - Switch to the specified section of the executable if we +/// are not already in it! +/// +void AsmPrinter::SwitchSection(const char *NewSection, const GlobalValue *GV) { + std::string NS; + + if (GV && GV->hasSection()) + NS = ".section " + GV->getSection(); + else + NS = NewSection; + + if (CurrentSection != NS) { + CurrentSection = NS; + if (!CurrentSection.empty()) + O << "\t" << CurrentSection << "\n"; + } +} + bool AsmPrinter::doInitialization(Module &M) { Mang = new Mangler(M, GlobalPrefix); + SwitchSection("", 0); // Reset back to no section. return false; } diff --git a/llvm/lib/CodeGen/LiveVariables.cpp b/llvm/lib/CodeGen/LiveVariables.cpp index cb034c017a8..a1bda195ff6 100644 --- a/llvm/lib/CodeGen/LiveVariables.cpp +++ b/llvm/lib/CodeGen/LiveVariables.cpp @@ -278,10 +278,11 @@ bool LiveVariables::runOnMachineFunction(MachineFunction &MF) { MachineOperand &MO = MI->getOperand(i); if (!MO.getVRegValueOrNull()) { VarInfo &VRInfo = getVarInfo(MO.getReg()); + assert(VRInfo.DefInst && "Register use before def (or no def)!"); - // Only mark it alive only in the block we are representing... + // Only mark it alive only in the block we are representing. MarkVirtRegAliveInBlock(VRInfo, MBB); - break; // Found the PHI entry for this block... + break; // Found the PHI entry for this block. } } } diff --git a/llvm/lib/CodeGen/RegAllocLinearScan.cpp b/llvm/lib/CodeGen/RegAllocLinearScan.cpp index a42a366ef36..9bad0d376f8 100644 --- a/llvm/lib/CodeGen/RegAllocLinearScan.cpp +++ b/llvm/lib/CodeGen/RegAllocLinearScan.cpp @@ -547,6 +547,7 @@ void RA::assignRegOrStackSlotAtInterval(LiveInterval* cur) minReg = reg; } } + assert(minReg && "Didn't find any reg!"); DEBUG(std::cerr << "\t\tregister with min weight: " << mri_->getName(minReg) << " (" << minWeight << ")\n"); |