summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-05-09 04:30:20 +0000
committerChris Lattner <sabre@nondot.org>2004-05-09 04:30:20 +0000
commit14d328e2a5d70dc4c7db033ce0e3de195a7d624d (patch)
tree3da7078d91468edc98aa9eb5038872116ee31e21 /llvm/lib/Target
parent254677fe0aa3c40945239b44bcd012009a27b4de (diff)
downloadbcm5719-llvm-14d328e2a5d70dc4c7db033ce0e3de195a7d624d.tar.gz
bcm5719-llvm-14d328e2a5d70dc4c7db033ce0e3de195a7d624d.zip
Get this looking more like a function pass.
llvm-svn: 13433
Diffstat (limited to 'llvm/lib/Target')
-rw-r--r--llvm/lib/Target/CBackend/Writer.cpp65
1 files changed, 33 insertions, 32 deletions
diff --git a/llvm/lib/Target/CBackend/Writer.cpp b/llvm/lib/Target/CBackend/Writer.cpp
index 41e8fdde432..41e51620480 100644
--- a/llvm/lib/Target/CBackend/Writer.cpp
+++ b/llvm/lib/Target/CBackend/Writer.cpp
@@ -59,14 +59,14 @@ namespace {
bool doInitialization(Module &M);
bool run(Module &M) {
- // First pass, lower all unhandled intrinsics.
- lowerIntrinsics(M);
-
doInitialization(M);
for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I)
- if (!I->isExternal())
+ if (!I->isExternal()) {
+ // First pass, lower all unhandled intrinsics.
+ lowerIntrinsics(*I);
printFunction(*I);
+ }
// Free memory...
delete Mang;
@@ -82,7 +82,7 @@ namespace {
void writeOperandInternal(Value *Operand);
private :
- void lowerIntrinsics(Module &M);
+ void lowerIntrinsics(Function &F);
bool nameAllUsedStructureTypes(Module &M);
void printModule(Module *M);
@@ -655,6 +655,8 @@ bool CWriter::doInitialization(Module &M) {
// Initialize
TheModule = &M;
FUT = &getAnalysis<FindUsedTypes>();
+
+ IL.AddPrototypes(M);
// Ensure that all structure types have names...
bool Changed = nameAllUsedStructureTypes(M);
@@ -776,7 +778,7 @@ bool CWriter::doInitialization(Module &M) {
void CWriter::printFloatingPointConstants(Module &M) {
union {
double D;
- unsigned long long U;
+ uint64_t U;
} DBLUnion;
union {
@@ -1219,33 +1221,32 @@ void CWriter::visitSelectInst(SelectInst &I) {
}
-void CWriter::lowerIntrinsics(Module &M) {
- for (Module::iterator F = M.begin(), E = M.end(); F != E; ++F)
- for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB)
- for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; )
- if (CallInst *CI = dyn_cast<CallInst>(I++))
- if (Function *F = CI->getCalledFunction())
- switch (F->getIntrinsicID()) {
- case Intrinsic::not_intrinsic:
- case Intrinsic::vastart:
- case Intrinsic::vacopy:
- case Intrinsic::vaend:
- case Intrinsic::returnaddress:
- case Intrinsic::frameaddress:
- case Intrinsic::setjmp:
- case Intrinsic::longjmp:
- // We directly implement these intrinsics
- break;
- default:
- // All other intrinsic calls we must lower.
- Instruction *Before = CI->getPrev();
- IL.LowerIntrinsicCall(CI);
- if (Before) { // Move iterator to instruction after call
- I = Before; ++I;
- } else {
- I = BB->begin();
- }
+void CWriter::lowerIntrinsics(Function &F) {
+ for (Function::iterator BB = F.begin(), E = F.end(); BB != E; ++BB)
+ for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; )
+ if (CallInst *CI = dyn_cast<CallInst>(I++))
+ if (Function *F = CI->getCalledFunction())
+ switch (F->getIntrinsicID()) {
+ case Intrinsic::not_intrinsic:
+ case Intrinsic::vastart:
+ case Intrinsic::vacopy:
+ case Intrinsic::vaend:
+ case Intrinsic::returnaddress:
+ case Intrinsic::frameaddress:
+ case Intrinsic::setjmp:
+ case Intrinsic::longjmp:
+ // We directly implement these intrinsics
+ break;
+ default:
+ // All other intrinsic calls we must lower.
+ Instruction *Before = CI->getPrev();
+ IL.LowerIntrinsicCall(CI);
+ if (Before) { // Move iterator to instruction after call
+ I = Before; ++I;
+ } else {
+ I = BB->begin();
}
+ }
}
OpenPOWER on IntegriCloud