bb2f10759e 
								
							 
						 
						
							
							
								
								If a MachineBasicBlock has multiple ways of reaching another block,  
							
							... 
							
							
							
							allow it to have multiple CFG edges to that block. This is needed
to allow MachineBasicBlock::isOnlyReachableByFallthrough to work
correctly. This fixes PR4126.
llvm-svn: 71018 
							
						 
						
							2009-05-05 21:10:19 +00:00  
				
					
						
							
							
								 
						
							
								6b42dfddf4 
								
							 
						 
						
							
							
								
								Reapply 68073, with fixes. EH Landing-pad basic blocks are not  
							
							... 
							
							
							
							entered via fall-through. Don't miss fallthroughs from blocks
terminated by conditional branches. Also, move
isOnlyReachableByFallthrough out of line.
llvm-svn: 68129 
							
						 
						
							2009-03-31 18:39:13 +00:00  
				
					
						
							
							
								 
						
							
								ff62c62b7c 
								
							 
						 
						
							
							
								
								Constify arguments in isSuccessor and isLayoutSuccessor.  
							
							... 
							
							
							
							llvm-svn: 68054 
							
						 
						
							2009-03-30 20:06:29 +00:00  
				
					
						
							
							
								 
						
							
								f87dc9264a 
								
							 
						 
						
							
							
								
								Delete unnecessary parens around return values.  
							
							... 
							
							
							
							llvm-svn: 61950 
							
						 
						
							2009-01-08 22:19:34 +00:00  
				
					
						
							
							
								 
						
							
								0d1e9a8e04 
								
							 
						 
						
							
							
								
								Switch the MachineOperand accessors back to the short names like  
							
							... 
							
							
							
							isReg, etc., from isRegister, etc.
llvm-svn: 57006 
							
						 
						
							2008-10-03 15:45:36 +00:00  
				
					
						
							
							
								 
						
							
								a78bae34a5 
								
							 
						 
						
							
							
								
								Add a new MachineBasicBlock utility function, isLayoutSuccessor, that  
							
							... 
							
							
							
							can be used when deciding if a block can transfer control to another
via a fall-through instead of a branch.
llvm-svn: 56968 
							
						 
						
							2008-10-02 22:09:09 +00:00  
				
					
						
							
							
								 
						
							
								38453eebdc 
								
							 
						 
						
							
							
								
								Remove isImm(), isReg(), and friends, in favor of  
							
							... 
							
							
							
							isImmediate(), isRegister(), and friends, to avoid confusion
about having two different names with the same meaning. I'm
not attached to the longer names, and would be ok with
changing to the shorter names if others prefer it.
llvm-svn: 56189 
							
						 
						
							2008-09-13 17:58:21 +00:00  
				
					
						
							
							
								 
						
							
								804c95df52 
								
							 
						 
						
							
							
								
								Fold the useful features of alist and alist_node into ilist, and  
							
							... 
							
							
							
							a new ilist_node class, and remove them. Unlike alist_node,
ilist_node doesn't attempt to manage storage itself, so it avoids
the associated problems, including being opaque in gdb.
Adjust the Recycler class so that it doesn't depend on alist_node.
Also, change it to use explicit Size and Align parameters, allowing
it to work when the largest-sized node doesn't have the greatest
alignment requirement.
Change MachineInstr's MachineMemOperand list from a pool-backed
alist to a std::list for now.
llvm-svn: 54146 
							
						 
						
							2008-07-28 21:51:04 +00:00  
				
					
						
							
							
								 
						
							
								0ece943845 
								
							 
						 
						
							
							
								
								Re-introduce LeakDetector support for MachineInstrs and MachineBasicBlocks.  
							
							... 
							
							
							
							Fix a leak that this turned up in LowerSubregs.cpp.
And, comment a leak in LiveIntervalAnalysis.cpp.
llvm-svn: 53746 
							
						 
						
							2008-07-17 23:49:46 +00:00  
				
					
						
							
							
								 
						
							
								3b46030375 
								
							 
						 
						
							
							
								
								Pool-allocation for MachineInstrs, MachineBasicBlocks, and  
							
							... 
							
							
							
							MachineMemOperands. The pools are owned by MachineFunctions.
This drastically reduces the number of calls to malloc/free made
during the "Emit" phase of scheduling, as well as later phases
in CodeGen. Combined with other changes, this speeds up the
"instruction selection" phase of CodeGen by 10% in some cases.
llvm-svn: 53212 
							
						 
						
							2008-07-07 23:14:23 +00:00  
				
					
						
							
							
								 
						
							
								3e58393c3d 
								
							 
						 
						
							
							
								
								Added addition atomic instrinsics and, or, xor, min, and max.  
							
							... 
							
							
							
							llvm-svn: 50663 
							
						 
						
							2008-05-05 19:05:59 +00:00  
				
					
						
							
							
								 
						
							
								3980a7911a 
								
							 
						 
						
							
							
								
								- Check if a register is livein before removing it. It may have already been removed.  
							
							... 
							
							
							
							- Do not iterate over SmallPtrSet, the order of iteration is not deterministic.
llvm-svn: 50209 
							
						 
						
							2008-04-24 09:06:33 +00:00  
				
					
						
							
							
								 
						
							
								c799065cc3 
								
							 
						 
						
							
							
								
								Add a quick and dirty "loop aligner pass". x86 uses it to align its loops to 16-byte boundaries.  
							
							... 
							
							
							
							llvm-svn: 47703 
							
						 
						
							2008-02-28 00:43:03 +00:00  
				
					
						
							
							
								 
						
							
								d7a258d325 
								
							 
						 
						
							
							
								
								Rename PrintableName to Name.  
							
							... 
							
							
							
							llvm-svn: 47629 
							
						 
						
							2008-02-26 21:47:57 +00:00  
				
					
						
							
							
								 
						
							
								c24ea4fb41 
								
							 
						 
						
							
							
								
								Change "Name" to "AsmName" in the target register info. Gee, a refactoring tool  
							
							... 
							
							
							
							would have been a Godsend here!
llvm-svn: 47625 
							
						 
						
							2008-02-26 21:11:01 +00:00  
				
					
						
							
							
								 
						
							
								3a4be0fdef 
								
							 
						 
						
							
							
								
								Rename MRegisterInfo to TargetRegisterInfo.  
							
							... 
							
							
							
							llvm-svn: 46930 
							
						 
						
							2008-02-10 18:45:23 +00:00  
				
					
						
							
							
								 
						
							
								f3efadcb5b 
								
							 
						 
						
							
							
								
								remove #includage  
							
							... 
							
							
							
							llvm-svn: 45697 
							
						 
						
							2008-01-07 07:42:25 +00:00  
				
					
						
							
							
								 
						
							
								03ad885039 
								
							 
						 
						
							
							
								
								rename TargetInstrDescriptor -> TargetInstrDesc.  
							
							... 
							
							
							
							Make MachineInstr::getDesc return a reference instead
of a pointer, since it can never be null.
llvm-svn: 45695 
							
						 
						
							2008-01-07 07:27:27 +00:00  
				
					
						
							
							
								 
						
							
								a98c679de0 
								
							 
						 
						
							
							
								
								Rename MachineInstr::getInstrDescriptor -> getDesc(), which reflects  
							
							... 
							
							
							
							that it is cheap and efficient to get.
Move a variety of predicates from TargetInstrInfo into 
TargetInstrDescriptor, which makes it much easier to query a predicate
when you don't have TII around.  Now you can use MI->getDesc()->isBranch()
instead of going through TII, and this is much more efficient anyway. Not
all of the predicates have been moved over yet.
Update old code that used MI->getInstrDescriptor()->Flags to use the
new predicates in many places.
llvm-svn: 45674 
							
						 
						
							2008-01-07 01:56:04 +00:00  
				
					
						
							
							
								 
						
							
								961e7427ea 
								
							 
						 
						
							
							
								
								Implement automatically updated def/use lists for all MachineInstr register  
							
							... 
							
							
							
							operands.  The lists are currently kept in MachineRegisterInfo, but it does
not yet provide an iterator interface to them.
llvm-svn: 45477 
							
						 
						
							2008-01-01 01:12:31 +00:00  
				
					
						
							
							
								 
						
							
								574e7166e0 
								
							 
						 
						
							
							
								
								properly encapsulate the parent field of MBB and MI with get/set accessors.  
							
							... 
							
							
							
							llvm-svn: 45469 
							
						 
						
							2007-12-31 04:56:33 +00:00  
				
					
						
							
							
								 
						
							
								a5bb370aa4 
								
							 
						 
						
							
							
								
								Add new shorter predicates for testing machine operands for various types:  
							
							... 
							
							
							
							e.g. MO.isMBB() instead of MO.isMachineBasicBlock().  I don't plan on 
switching everything over, so new clients should just start using the 
shorter names.
Remove old long accessors, switching everything over to use the short
accessor: getMachineBasicBlock() -> getMBB(), 
getConstantPoolIndex() -> getIndex(), setMachineBasicBlock -> setMBB(), etc.
llvm-svn: 45464 
							
						 
						
							2007-12-30 23:10:15 +00:00  
				
					
						
							
							
								 
						
							
								f3ebc3f3d2 
								
							 
						 
						
							
							
								
								Remove attribution from file headers, per discussion on llvmdev.  
							
							... 
							
							
							
							llvm-svn: 45418 
							
						 
						
							2007-12-29 20:36:04 +00:00  
				
					
						
							
							
								 
						
							
								c731c97fac 
								
							 
						 
						
							
							
								
								Use empty() member functions when that's what's being tested for instead  
							
							... 
							
							
							
							of comparing begin() and end().
llvm-svn: 42585 
							
						 
						
							2007-10-03 19:26:29 +00:00  
				
					
						
							
							
								 
						
							
								35322d745c 
								
							 
						 
						
							
							
								
								Silence warning while compiling with gcc 4.2  
							
							... 
							
							
							
							llvm-svn: 41676 
							
						 
						
							2007-09-02 22:11:14 +00:00  
				
					
						
							
							
								 
						
							
								451d1a6ecd 
								
							 
						 
						
							
							
								
								Fix misue of iterator pointing to erased object.  Uncovered by  
							
							... 
							
							
							
							_GLIBCXX_DEBUG.
llvm-svn: 37793 
							
						 
						
							2007-06-29 02:45:24 +00:00  
				
					
						
							
							
								 
						
							
								2afd702c20 
								
							 
						 
						
							
							
								
								Move CorrectExtraCFGEdges() from BranchFolding.cpp to a MachineBasicBlock method.  
							
							... 
							
							
							
							llvm-svn: 37633 
							
						 
						
							2007-06-18 22:43:58 +00:00  
				
					
						
							
							
								 
						
							
								df75785594 
								
							 
						 
						
							
							
								
								Move ReplaceUsesOfBlockWith() out of BranchFolding into a MachineBasicBlock general facility.  
							
							... 
							
							
							
							llvm-svn: 37408 
							
						 
						
							2007-06-04 06:44:01 +00:00  
				
					
						
							
							
								 
						
							
								a92b2b38ff 
								
							 
						 
						
							
							
								
								Move isSuccessor() offline, change it to use std::find.  
							
							... 
							
							
							
							llvm-svn: 37190 
							
						 
						
							2007-05-17 23:58:53 +00:00  
				
					
						
							
							
								 
						
							
								f90c8fbd2b 
								
							 
						 
						
							
							
								
								print isLandingPad() for MBBs  
							
							... 
							
							
							
							llvm-svn: 36600 
							
						 
						
							2007-04-30 23:12:53 +00:00  
				
					
						
							
							
								 
						
							
								9bc8d4b6f2 
								
							 
						 
						
							
							
								
								Print preds / succs BB numbers.  
							
							... 
							
							
							
							llvm-svn: 35040 
							
						 
						
							2007-03-09 08:29:08 +00:00  
				
					
						
							
							
								 
						
							
								f7ed82da10 
								
							 
						 
						
							
							
								
								Re-apply my liveintervalanalysis changes. Now with PR1207 fixes.  
							
							... 
							
							
							
							llvm-svn: 34428 
							
						 
						
							2007-02-19 21:49:54 +00:00  
				
					
						
							
							
								 
						
							
								da81bf4d3e 
								
							 
						 
						
							
							
								
								For PR1207:  
							
							... 
							
							
							
							Revert patches that caused the problem. Evan, please investigate and reapply
when you've discovered the problem.
llvm-svn: 34399 
							
						 
						
							2007-02-19 03:20:00 +00:00  
				
					
						
							
							
								 
						
							
								41d2a1d8bf 
								
							 
						 
						
							
							
								
								Added removeLiveIn.  
							
							... 
							
							
							
							llvm-svn: 34381 
							
						 
						
							2007-02-17 11:10:48 +00:00  
				
					
						
							
							
								 
						
							
								bcf1d7faef 
								
							 
						 
						
							
							
								
								Add live-ins to MachineBasicBlock.  
							
							... 
							
							
							
							llvm-svn: 34111 
							
						 
						
							2007-02-10 02:38:19 +00:00  
				
					
						
							
							
								 
						
							
								29192e6274 
								
							 
						 
						
							
							
								
								The best unbreakage yet, addressing Bill's concerns.  
							
							... 
							
							
							
							llvm-svn: 32622 
							
						 
						
							2006-12-16 02:15:42 +00:00  
				
					
						
							
							
								 
						
							
								b82309f1ab 
								
							 
						 
						
							
							
								
								An even better unbreakage...  
							
							... 
							
							
							
							llvm-svn: 32617 
							
						 
						
							2006-12-15 22:57:14 +00:00  
				
					
						
							
							
								 
						
							
								355fc5ad50 
								
							 
						 
						
							
							
								
								Removed more <iostream> includes  
							
							... 
							
							
							
							llvm-svn: 32321 
							
						 
						
							2006-12-07 20:28:15 +00:00  
				
					
						
							
							
								 
						
							
								20350c4025 
								
							 
						 
						
							
							
								
								Change MachineInstr ctor's to take a TargetInstrDescriptor reference instead  
							
							... 
							
							
							
							of opcode and number of operands.
llvm-svn: 31947 
							
						 
						
							2006-11-27 23:37:22 +00:00  
				
					
						
							
							
								 
						
							
								ace542fa6c 
								
							 
						 
						
							
							
								
								Implement operator<< for machine basic blocks to make it easier to dump them.  
							
							... 
							
							
							
							llvm-svn: 31857 
							
						 
						
							2006-11-18 21:47:36 +00:00  
				
					
						
							
							
								 
						
							
								94866bef35 
								
							 
						 
						
							
							
								
								add moveBefore/moveAfter helper methods  
							
							... 
							
							
							
							llvm-svn: 31145 
							
						 
						
							2006-10-24 00:02:26 +00:00  
				
					
						
							
							
								 
						
							
								4e107aa0b6 
								
							 
						 
						
							
							
								
								print labels even if a MBB doesn't have a corresponding LLVM BB, just don't  
							
							... 
							
							
							
							print the LLVM BB label.
llvm-svn: 30775 
							
						 
						
							2006-10-06 21:28:17 +00:00  
				
					
						
							
							
								 
						
							
								16ae43e901 
								
							 
						 
						
							
							
								
								MachineBasicBlock::splice was incorrectly updating parent pointers on  
							
							... 
							
							
							
							instructions.
llvm-svn: 30760 
							
						 
						
							2006-10-06 01:12:44 +00:00  
				
					
						
							
							
								 
						
							
								de154b1737 
								
							 
						 
						
							
							
								
								Print the MBB ID # along with the bb tag in the -print-machine-instrs output.  
							
							... 
							
							
							
							llvm-svn: 30708 
							
						 
						
							2006-10-03 20:17:24 +00:00  
				
					
						
							
							
								 
						
							
								9a1e91b107 
								
							 
						 
						
							
							
								
								print the preds of each MBB  
							
							... 
							
							
							
							llvm-svn: 30606 
							
						 
						
							2006-09-26 03:41:59 +00:00  
				
					
						
							
							
								 
						
							
								8c2c1e90c4 
								
							 
						 
						
							
							
								
								Refactor a bunch of includes so that TargetMachine.h doesn't have to include  
							
							... 
							
							
							
							TargetData.h.  This should make recompiles a bit faster with my current
TargetData tinkering.
llvm-svn: 28238 
							
						 
						
							2006-05-12 06:33:49 +00:00  
				
					
						
							
							
								 
						
							
								469647bf38 
								
							 
						 
						
							
							
								
								Remove and simplify some more machineinstr/machineoperand stuff.  
							
							... 
							
							
							
							llvm-svn: 28105 
							
						 
						
							2006-05-04 18:16:01 +00:00  
				
					
						
							
							
								 
						
							
								ee64b6b40f 
								
							 
						 
						
							
							
								
								Remove a bunch more dead V9 specific stuff  
							
							... 
							
							
							
							llvm-svn: 28094 
							
						 
						
							2006-05-04 01:26:39 +00:00  
				
					
						
							
							
								 
						
							
								835702a094 
								
							 
						 
						
							
							
								
								Remove trailing whitespace  
							
							... 
							
							
							
							llvm-svn: 21420 
							
						 
						
							2005-04-21 22:36:52 +00:00  
				
					
						
							
							
								 
						
							
								329c14a8bc 
								
							 
						 
						
							
							
								
								print the machine CFG in the -print-machineinstrs dump  
							
							... 
							
							
							
							llvm-svn: 20976 
							
						 
						
							2005-04-01 06:48:38 +00:00