diff options
author | Chris Lattner <sabre@nondot.org> | 2004-05-23 21:23:12 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-05-23 21:23:12 +0000 |
commit | df04097f87485ef2c0036d1f42208aa6c4d7575c (patch) | |
tree | 7439f6b07f5066f0d908734a72b8d8194c5524ac /lib | |
parent | bbdbf302385742cab4f712d5a2ff35bfb68963d9 (diff) | |
download | external_llvm-df04097f87485ef2c0036d1f42208aa6c4d7575c.zip external_llvm-df04097f87485ef2c0036d1f42208aa6c4d7575c.tar.gz external_llvm-df04097f87485ef2c0036d1f42208aa6c4d7575c.tar.bz2 |
Add some notes to myself, no functional changes
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@13695 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Target/X86/InstSelectSimple.cpp | 26 | ||||
-rw-r--r-- | lib/Target/X86/X86ISelSimple.cpp | 26 |
2 files changed, 38 insertions, 14 deletions
diff --git a/lib/Target/X86/InstSelectSimple.cpp b/lib/Target/X86/InstSelectSimple.cpp index f9d5387..494feb9 100644 --- a/lib/Target/X86/InstSelectSimple.cpp +++ b/lib/Target/X86/InstSelectSimple.cpp @@ -3567,12 +3567,24 @@ void ISel::getGEPIndex(MachineBasicBlock *MBB, MachineBasicBlock::iterator IP, } } - // GEPTypes is empty, which means we have a single operand left. See if we - // can set it as the base register. + // GEPTypes is empty, which means we have a single operand left. Set it as + // the base register. // - // FIXME: When addressing modes are more powerful/correct, we could load - // global addresses directly as 32-bit immediates. assert(BaseReg == 0); + +#if 0 // FIXME: TODO! + if (AllocaInst *AI = dyn_castFixedAlloca(V)) { + // FIXME: When we can add FrameIndex values as the first operand, we can + // make GEP's of allocas MUCH more efficient! + unsigned FI = getFixedSizedAllocaFI(AI); + GEPOps.pop_back(); + return; + } else if (GlobalValue *GV = dyn_cast<GlobalValue>(V)) { + // FIXME: When addressing modes are more powerful/correct, we could load + // global addresses directly as 32-bit immediates. + } +#endif + BaseReg = MBB ? getReg(GEPOps[0], MBB, IP) : 1; GEPOps.pop_back(); // Consume the last GEP operand } @@ -3592,9 +3604,9 @@ bool ISel::isGEPFoldable(MachineBasicBlock *MBB, GEPOps[0] = Src; std::copy(IdxBegin, IdxEnd, GEPOps.begin()+1); - std::vector<const Type*> GEPTypes; - GEPTypes.assign(gep_type_begin(Src->getType(), IdxBegin, IdxEnd), - gep_type_end(Src->getType(), IdxBegin, IdxEnd)); + std::vector<const Type*> + GEPTypes(gep_type_begin(Src->getType(), IdxBegin, IdxEnd), + gep_type_end(Src->getType(), IdxBegin, IdxEnd)); MachineBasicBlock::iterator IP; if (MBB) IP = MBB->end(); diff --git a/lib/Target/X86/X86ISelSimple.cpp b/lib/Target/X86/X86ISelSimple.cpp index f9d5387..494feb9 100644 --- a/lib/Target/X86/X86ISelSimple.cpp +++ b/lib/Target/X86/X86ISelSimple.cpp @@ -3567,12 +3567,24 @@ void ISel::getGEPIndex(MachineBasicBlock *MBB, MachineBasicBlock::iterator IP, } } - // GEPTypes is empty, which means we have a single operand left. See if we - // can set it as the base register. + // GEPTypes is empty, which means we have a single operand left. Set it as + // the base register. // - // FIXME: When addressing modes are more powerful/correct, we could load - // global addresses directly as 32-bit immediates. assert(BaseReg == 0); + +#if 0 // FIXME: TODO! + if (AllocaInst *AI = dyn_castFixedAlloca(V)) { + // FIXME: When we can add FrameIndex values as the first operand, we can + // make GEP's of allocas MUCH more efficient! + unsigned FI = getFixedSizedAllocaFI(AI); + GEPOps.pop_back(); + return; + } else if (GlobalValue *GV = dyn_cast<GlobalValue>(V)) { + // FIXME: When addressing modes are more powerful/correct, we could load + // global addresses directly as 32-bit immediates. + } +#endif + BaseReg = MBB ? getReg(GEPOps[0], MBB, IP) : 1; GEPOps.pop_back(); // Consume the last GEP operand } @@ -3592,9 +3604,9 @@ bool ISel::isGEPFoldable(MachineBasicBlock *MBB, GEPOps[0] = Src; std::copy(IdxBegin, IdxEnd, GEPOps.begin()+1); - std::vector<const Type*> GEPTypes; - GEPTypes.assign(gep_type_begin(Src->getType(), IdxBegin, IdxEnd), - gep_type_end(Src->getType(), IdxBegin, IdxEnd)); + std::vector<const Type*> + GEPTypes(gep_type_begin(Src->getType(), IdxBegin, IdxEnd), + gep_type_end(Src->getType(), IdxBegin, IdxEnd)); MachineBasicBlock::iterator IP; if (MBB) IP = MBB->end(); |