Owen Anderson
							
						 
						
							 
							
							
							
							
								
							
							
								66443c034d 
								
							 
						 
						
							
							
								
								Teach FastISel to support register-immediate-immediate instructions.  
							
							 
							
							... 
							
							
							
							llvm-svn: 127496 
							
						 
						
							2011-03-11 21:33:55 +00:00  
						
					 
				
					
						
							
							
								 
								Devang Patel
							
						 
						
							 
							
							
							
							
								
							
							
								c24048a718 
								
							 
						 
						
							
							
								
								If dbg_declare() or dbg_value() is not lowered by isel then emit DEBUG message instead of creating DBG_VALUE for undefined value in reg0.  
							
							 
							
							... 
							
							
							
							llvm-svn: 121059 
							
						 
						
							2010-12-06 22:39:26 +00:00  
						
					 
				
					
						
							
							
								 
								Wesley Peck
							
						 
						
							 
							
							
							
							
								
							
							
								527da1b6e2 
								
							 
						 
						
							
							
								
								Renaming ISD::BIT_CONVERT to ISD::BITCAST to better reflect the LLVM IR concept.  
							
							 
							
							... 
							
							
							
							llvm-svn: 119990 
							
						 
						
							2010-11-23 03:31:01 +00:00  
						
					 
				
					
						
							
							
								 
								Devang Patel
							
						 
						
							 
							
							
							
							
								
							
							
								e4682fa8e2 
								
							 
						 
						
							
							
								
								Use frame index, if available for byval argument while lowering dbg_declare. Otherwise let getRegForValue() find register for this argument.  
							
							 
							
							... 
							
							
							
							llvm-svn: 113843 
							
						 
						
							2010-09-14 20:29:31 +00:00  
						
					 
				
					
						
							
							
								 
								Devang Patel
							
						 
						
							 
							
							
							
							
								
							
							
								6095d818e5 
								
							 
						 
						
							
							
								
								Add DEBUG message.  
							
							 
							
							... 
							
							
							
							llvm-svn: 113614 
							
						 
						
							2010-09-10 20:32:09 +00:00  
						
					 
				
					
						
							
							
								 
								Eric Christopher
							
						 
						
							 
							
							
							
							
								
							
							
								541f8012d9 
								
							 
						 
						
							
							
								
								Fix typo.  
							
							 
							
							... 
							
							
							
							llvm-svn: 111223 
							
						 
						
							2010-08-17 01:30:33 +00:00  
						
					 
				
					
						
							
							
								 
								Gabor Greif
							
						 
						
							 
							
							
							
							
								
							
							
								dde79d8f1a 
								
							 
						 
						
							
							
								
								mass elimination of reliance on automatic iterator dereferencing  
							
							 
							
							... 
							
							
							
							llvm-svn: 109103 
							
						 
						
							2010-07-22 13:36:47 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								b5e918dc05 
								
							 
						 
						
							
							
								
								After a custom inserter, in a block which has constant instructions,  
							
							 
							
							... 
							
							
							
							update the current basic block in addition to the current insert
position, so that they remain consistent. This fixes rdar://8204072.
llvm-svn: 108765 
							
						 
						
							2010-07-19 22:48:56 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								1e936277c3 
								
							 
						 
						
							
							
								
								Revert r108369, sorting llvm.dbg.declare information by source position,  
							
							 
							
							... 
							
							
							
							since it doesn't work for front-ends which don't emit column information
(which includes llvm-gcc in its present configuration), and doesn't
work for clang for K&R style variables where the variables are declared
in a different order from the parameter list.
Instead, make a separate pass through the instructions to collect the
llvm.dbg.declare instructions in order. This ensures that the debug
information for variables is emitted in this order.
llvm-svn: 108538 
							
						 
						
							2010-07-16 17:54:27 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								c12a6731c5 
								
							 
						 
						
							
							
								
								Properly restore DebugLoc after leaving the local constant area.  
							
							 
							
							... 
							
							
							
							llvm-svn: 108364 
							
						 
						
							2010-07-14 22:01:31 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								042523340b 
								
							 
						 
						
							
							
								
								Delete fast-isel's trivial load optimization; it breaks debugging because  
							
							 
							
							... 
							
							
							
							it can look past points where a debugger might modify user variables.
llvm-svn: 108336 
							
						 
						
							2010-07-14 17:25:37 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								1f471435f8 
								
							 
						 
						
							
							
								
								Don't propagate debug locations to instructions for materializing  
							
							 
							
							... 
							
							
							
							constants, since they may not be emited near the other instructions
which get the same line, and this confuses debug info.
llvm-svn: 108302 
							
						 
						
							2010-07-14 01:07:44 +00:00  
						
					 
				
					
						
							
							
								 
								Jakob Stoklund Olesen
							
						 
						
							 
							
							
							
							
								
							
							
								51642aea77 
								
							 
						 
						
							
							
								
								Use COPY for fast-isel bitconvert, but don't create cross-class copies.  
							
							 
							
							... 
							
							
							
							This doesn't change the behavior of SelectBitcast for X86.
llvm-svn: 108073 
							
						 
						
							2010-07-11 05:16:54 +00:00  
						
					 
				
					
						
							
							
								 
								Jakob Stoklund Olesen
							
						 
						
							 
							
							
							
							
								
							
							
								7147ab9e78 
								
							 
						 
						
							
							
								
								Use COPY for extracting ImplicitDef'ed values from fast-isel instructions.  
							
							 
							
							... 
							
							
							
							This assumes that the registers can be copied which is probably a safe
assumption.
llvm-svn: 108070 
							
						 
						
							2010-07-11 03:31:05 +00:00  
						
					 
				
					
						
							
							
								 
								Jakob Stoklund Olesen
							
						 
						
							 
							
							
							
							
								
							
							
								3bb1267431 
								
							 
						 
						
							
							
								
								Use COPY in FastISel everywhere it is safe and trivial.  
							
							 
							
							... 
							
							
							
							The remaining copyRegToReg calls actually check the return value (shock!), so we
cannot trivially replace them with COPY instructions.
llvm-svn: 108069 
							
						 
						
							2010-07-11 03:31:00 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								d7b5ce3312 
								
							 
						 
						
							
							
								
								Reapply bottom-up fast-isel, with several fixes for x86-32:  
							
							 
							
							... 
							
							
							
							- Check getBytesToPopOnReturn().
 - Eschew ST0 and ST1 for return values.
 - Fix the PIC base register initialization so that it doesn't ever
   fail to end up the top of the entry block.
llvm-svn: 108039 
							
						 
						
							2010-07-10 09:00:22 +00:00  
						
					 
				
					
						
							
							
								 
								Bob Wilson
							
						 
						
							 
							
							
							
							
								
							
							
								6586e9b203 
								
							 
						 
						
							
							
								
								--- Reverse-merging r107947 into '.':  
							
							 
							
							... 
							
							
							
							U    utils/TableGen/FastISelEmitter.cpp
--- Reverse-merging r107943 into '.':
U    test/CodeGen/X86/fast-isel.ll
U    test/CodeGen/X86/fast-isel-loads.ll
U    include/llvm/Target/TargetLowering.h
U    include/llvm/Support/PassNameParser.h
U    include/llvm/CodeGen/FunctionLoweringInfo.h
U    include/llvm/CodeGen/CallingConvLower.h
U    include/llvm/CodeGen/FastISel.h
U    include/llvm/CodeGen/SelectionDAGISel.h
U    lib/CodeGen/LLVMTargetMachine.cpp
U    lib/CodeGen/CallingConvLower.cpp
U    lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
U    lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp
U    lib/CodeGen/SelectionDAG/FastISel.cpp
U    lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
U    lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
U    lib/CodeGen/SelectionDAG/InstrEmitter.cpp
U    lib/CodeGen/SelectionDAG/TargetLowering.cpp
U    lib/Target/XCore/XCoreISelLowering.cpp
U    lib/Target/XCore/XCoreISelLowering.h
U    lib/Target/X86/X86ISelLowering.cpp
U    lib/Target/X86/X86FastISel.cpp
U    lib/Target/X86/X86ISelLowering.h
llvm-svn: 107987 
							
						 
						
							2010-07-09 16:37:18 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								0b5aa1cdd3 
								
							 
						 
						
							
							
								
								Re-apply bottom-up fast-isel, with fixes. Be very careful to avoid emitting  
							
							 
							
							... 
							
							
							
							a DBG_VALUE after a terminator, or emitting any instructions before an EH_LABEL.
llvm-svn: 107943 
							
						 
						
							2010-07-09 00:39:23 +00:00  
						
					 
				
					
						
							
							
								 
								Jakob Stoklund Olesen
							
						 
						
							 
							
							
							
							
								
							
							
								00264624a9 
								
							 
						 
						
							
							
								
								Convert EXTRACT_SUBREG to COPY when emitting machine instrs.  
							
							 
							
							... 
							
							
							
							EXTRACT_SUBREG no longer appears as a machine instruction. Use COPY instead.
Add isCopy() checks in many places using isMoveInstr() and isExtractSubreg().
The isMoveInstr hook will be removed later.
llvm-svn: 107879 
							
						 
						
							2010-07-08 16:40:22 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								e75704369d 
								
							 
						 
						
							
							
								
								Revert 107840 107839 107813 107804 107800 107797 107791.  
							
							 
							
							... 
							
							
							
							Debug info intrinsics win for now.
llvm-svn: 107850 
							
						 
						
							2010-07-08 01:00:56 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								eb9164dc50 
								
							 
						 
						
							
							
								
								Don't forward-declare registers for static allocas, which we'll  
							
							 
							
							... 
							
							
							
							prefer to materialize as local constants. This fixes the clang
bootstrap abort.
llvm-svn: 107840 
							
						 
						
							2010-07-07 23:52:58 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								e7ccc51cc1 
								
							 
						 
						
							
							
								
								Implement bottom-up fast-isel. This has the advantage of not requiring  
							
							 
							
							... 
							
							
							
							a separate DCE pass over MachineInstrs.
llvm-svn: 107804 
							
						 
						
							2010-07-07 19:20:32 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								ffe64b1ee5 
								
							 
						 
						
							
							
								
								Give FunctionLoweringInfo an MBB member, avoiding the need to pass it  
							
							 
							
							... 
							
							
							
							around everywhere, and also give it an InsertPt member, to enable isel
to operate at an arbitrary position within a block, rather than just
appending to a block.
llvm-svn: 107791 
							
						 
						
							2010-07-07 16:47:08 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								87fb4e8fcd 
								
							 
						 
						
							
							
								
								Simplify FastISel's constructor by giving it a FunctionLoweringInfo  
							
							 
							
							... 
							
							
							
							instance, rather than pointers to all of FunctionLoweringInfo's
members.
This eliminates an NDEBUG ABI sensitivity.
llvm-svn: 107789 
							
						 
						
							2010-07-07 16:29:44 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								e784616fbb 
								
							 
						 
						
							
							
								
								Move FunctionLoweringInfo.h out into include/llvm/CodeGen. This will  
							
							 
							
							... 
							
							
							
							allow target-specific fast-isel code to make use of it directly.
llvm-svn: 107787 
							
						 
						
							2010-07-07 16:01:37 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								93f5920914 
								
							 
						 
						
							
							
								
								Rename CreateReg to CreateRegs, and MakeReg to CreateReg.  
							
							 
							
							... 
							
							
							
							llvm-svn: 107451 
							
						 
						
							2010-07-02 00:10:16 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								85e02e9340 
								
							 
						 
						
							
							
								
								Rename CreateRegForValue to CreateReg, and change its argument  
							
							 
							
							... 
							
							
							
							from a Value to a Type, because it doesn't actually care about
the Value.
llvm-svn: 107383 
							
						 
						
							2010-07-01 03:55:39 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								aef3d140b7 
								
							 
						 
						
							
							
								
								Teach fast-isel to avoid loading a value from memory when it's already  
							
							 
							
							... 
							
							
							
							available in a register. This is pretty primitive, but it reduces the
number of instructions in common testcases by 4%.
llvm-svn: 107380 
							
						 
						
							2010-07-01 03:49:38 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								722f5fc567 
								
							 
						 
						
							
							
								
								Enable on-demand fast-isel.  
							
							 
							
							... 
							
							
							
							llvm-svn: 107377 
							
						 
						
							2010-07-01 02:58:57 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								f91aff5f13 
								
							 
						 
						
							
							
								
								Do one lookup instead of two.  
							
							 
							
							... 
							
							
							
							llvm-svn: 106415 
							
						 
						
							2010-06-21 14:21:47 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								7c58cf75fa 
								
							 
						 
						
							
							
								
								Generalize this to look in the regular ValueMap in addition to  
							
							 
							
							... 
							
							
							
							the LocalValueMap, to make it more flexible when fast-isel isn't
proceding straight top-down.
llvm-svn: 106414 
							
						 
						
							2010-06-21 14:17:46 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								8693650422 
								
							 
						 
						
							
							
								
								Teach regular and fast isel to set dead flags on unused implicit defs  
							
							 
							
							... 
							
							
							
							on calls and similar instructions.
llvm-svn: 106353 
							
						 
						
							2010-06-18 23:28:01 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								f1d8304fe3 
								
							 
						 
						
							
							
								
								Eliminate unnecessary uses of getZExtValue().  
							
							 
							
							... 
							
							
							
							llvm-svn: 106279 
							
						 
						
							2010-06-18 14:22:04 +00:00  
						
					 
				
					
						
							
							
								 
								Stuart Hastings
							
						 
						
							 
							
							
							
							
								
							
							
								0125b6410a 
								
							 
						 
						
							
							
								
								Add a DebugLoc parameter to TargetInstrInfo::InsertBranch().  This  
							
							 
							
							... 
							
							
							
							addresses a longstanding deficiency noted in many FIXMEs scattered
across all the targets.
This effectively moves the problem up one level, replacing eleven
FIXMEs in the targets with eight FIXMEs in CodeGen, plus one path
through FastISel where we actually supply a DebugLoc, fixing Radar
7421831.
llvm-svn: 106243 
							
						 
						
							2010-06-17 22:43:56 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								ce3269b815 
								
							 
						 
						
							
							
								
								Do one map lookup instead of two.  
							
							 
							
							... 
							
							
							
							llvm-svn: 104645 
							
						 
						
							2010-05-25 21:59:42 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								88fb253562 
								
							 
						 
						
							
							
								
								Fast ISel trivially coalesces away no-op casts, so check for this when  
							
							 
							
							... 
							
							
							
							setting kill flags.
llvm-svn: 103832 
							
						 
						
							2010-05-14 22:53:18 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								5b510c1474 
								
							 
						 
						
							
							
								
								An Instruction has a trivial kill only if its use is in the same  
							
							 
							
							... 
							
							
							
							basic block.
llvm-svn: 103725 
							
						 
						
							2010-05-13 19:19:32 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								1a1b51ff59 
								
							 
						 
						
							
							
								
								Add initial kill flag support to FastISel.  
							
							 
							
							... 
							
							
							
							llvm-svn: 103529 
							
						 
						
							2010-05-11 23:54:07 +00:00  
						
					 
				
					
						
							
							
								 
								Devang Patel
							
						 
						
							 
							
							
							
							
								
							
							
								2ae3397536 
								
							 
						 
						
							
							
								
								Verify variable directly.  
							
							 
							
							... 
							
							
							
							llvm-svn: 103305 
							
						 
						
							2010-05-07 22:04:20 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								e6d40166a8 
								
							 
						 
						
							
							
								
								Transfer debug location information from PHI nodes to resulting  
							
							 
							
							... 
							
							
							
							lowered copies.
llvm-svn: 103228 
							
						 
						
							2010-05-07 01:10:20 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								779c69bbc5 
								
							 
						 
						
							
							
								
								Add a DebugLoc argument to TargetInstrInfo::copyRegToReg, so that it  
							
							 
							
							... 
							
							
							
							doesn't have to guess.
llvm-svn: 103194 
							
						 
						
							2010-05-06 20:33:48 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								a7c717d8d4 
								
							 
						 
						
							
							
								
								In bottom-up mode, defer the materialization of local constant values.  
							
							 
							
							... 
							
							
							
							llvm-svn: 103139 
							
						 
						
							2010-05-06 00:02:14 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								ffcb590b0f 
								
							 
						 
						
							
							
								
								Add an "IsBottomUp" member function to FastISel, which will be used to  
							
							 
							
							... 
							
							
							
							support a new bottom-up mode.
llvm-svn: 103138 
							
						 
						
							2010-05-05 23:58:35 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								626b5d8e0c 
								
							 
						 
						
							
							
								
								Factor out FastISel's code for materializing constants and other values  
							
							 
							
							... 
							
							
							
							in registers into a separate function to de-couple it from the
top-down-specific logic in getRegForValue.
llvm-svn: 102975 
							
						 
						
							2010-05-03 23:36:34 +00:00  
						
					 
				
					
						
							
							
								 
								Devang Patel
							
						 
						
							 
							
							
							
							
								
							
							
								888c17073a 
								
							 
						 
						
							
							
								
								While lowering dbg_declare, emit DBG_VALUE machine instruction if alloca matching llvm.dbg.declare intrinsic is missing.  
							
							 
							
							... 
							
							
							
							llvm-svn: 102513 
							
						 
						
							2010-04-28 19:27:33 +00:00  
						
					 
				
					
						
							
							
								 
								Dale Johannesen
							
						 
						
							 
							
							
							
							
								
							
							
								1fc01985a3 
								
							 
						 
						
							
							
								
								Add comment re byval args.  Doesn't actually work this way yet.  
							
							 
							
							... 
							
							
							
							xs
llvm-svn: 102316 
							
						 
						
							2010-04-25 21:03:54 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								6e9a8fcc28 
								
							 
						 
						
							
							
								
								Move FastISel's HandlePHINodesInSuccessorBlocks call down into FastISel  
							
							 
							
							... 
							
							
							
							itself too.
llvm-svn: 102176 
							
						 
						
							2010-04-23 15:29:50 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								c594eab10f 
								
							 
						 
						
							
							
								
								Move HandlePHINodesInSuccessorBlocks functions out of SelectionDAGISel  
							
							 
							
							... 
							
							
							
							and into SelectionDAGBuilder and FastISel.
llvm-svn: 102123 
							
						 
						
							2010-04-22 20:46:50 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								e149e9896c 
								
							 
						 
						
							
							
								
								Fix a comment.  
							
							 
							
							... 
							
							
							
							llvm-svn: 102110 
							
						 
						
							2010-04-22 20:06:42 +00:00  
						
					 
				
					
						
							
							
								 
								Dan Gohman
							
						 
						
							 
							
							
							
							
								
							
							
								f41ad478ca 
								
							 
						 
						
							
							
								
								Don't send PHI nodes down to SelectionDAGBuilder of FastISel, since  
							
							 
							
							... 
							
							
							
							they end up doing nothing.
llvm-svn: 101904 
							
						 
						
							2010-04-20 15:00:41 +00:00