Add section switching to common code generator code. Add a couple of

asserts.

llvm-svn: 24445
This commit is contained in:
Chris Lattner 2005-11-21 07:06:27 +00:00
parent 279f96c55e
commit 2ea5c99eca
3 changed files with 23 additions and 2 deletions

View File

@ -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;
}

View File

@ -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.
}
}
}

View File

@ -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");