283207a71c 
								
							 
						 
						
							
							
								
								Eliminate the remaining uses of getTypeSize.  This  
							
							... 
							
							
							
							should only effect x86 when using long double.  Now
12/16 bytes are output for long double globals (the
exact amount depends on the alignment).  This brings
globals in line with the rest of LLVM: the space
reserved for an object is now always the ABI size.
One tricky point is that only 10 bytes should be
output for long double if it is a field in a packed
struct, which is the reason for the additional
argument to EmitGlobalConstant.
llvm-svn: 43688 
							
						 
						
							2007-11-05 00:04:43 +00:00  
				
					
						
							
							
								 
						
							
								463e2ab0ac 
								
							 
						 
						
							
							
								
								- Added getOpcodeAfterMemoryUnfold(). It doesn't unfold an instruction, but only returns the opcode of the instruction post unfolding.  
							
							... 
							
							
							
							- Fix some copy+paste bugs.
llvm-svn: 43153 
							
						 
						
							2007-10-18 22:40:57 +00:00  
				
					
						
							
							
								 
						
							
								aa9a225699 
								
							 
						 
						
							
							
								
								Use SmallVectorImpl instead of SmallVector with hardcoded size in MRegister public interface.  
							
							... 
							
							
							
							llvm-svn: 43150 
							
						 
						
							2007-10-18 21:29:24 +00:00  
				
					
						
							
							
								 
						
							
								cdf3609130 
								
							 
						 
						
							
							
								
								Revert 42908 for now.  
							
							... 
							
							
							
							llvm-svn: 42960 
							
						 
						
							2007-10-14 05:57:21 +00:00  
				
					
						
							
							
								 
						
							
								dc35bd79ca 
								
							 
						 
						
							
							
								
								Change the names used for internal labels to use the current  
							
							... 
							
							
							
							function symbol name instead of a codegen-assigned function
number.
Thanks Evan! :-)
llvm-svn: 42908 
							
						 
						
							2007-10-12 14:53:36 +00:00  
				
					
						
							
							
								 
						
							
								482732af9d 
								
							 
						 
						
							
							
								
								Set ISD::FPOW to Expand.  
							
							... 
							
							
							
							llvm-svn: 42881 
							
						 
						
							2007-10-11 23:21:31 +00:00  
				
					
						
							
							
								 
						
							
								f4cf5dcdd2 
								
							 
						 
						
							
							
								
								- Added a few target hooks to generate load / store instructions from / to any  
							
							... 
							
							
							
							address (not just from / to frameindexes).
- Added target hooks to unfold load / store instructions / SDNodes into separate
load, data processing, store instructions / SDNodes.
llvm-svn: 42621 
							
						 
						
							2007-10-05 01:32:41 +00:00  
				
					
						
							
							
								 
						
							
								c1e4e3743b 
								
							 
						 
						
							
							
								
								Allow copyRegToReg to emit cross register classes copies.  
							
							... 
							
							
							
							Tested with "make check"!
llvm-svn: 42346 
							
						 
						
							2007-09-26 06:25:56 +00:00  
				
					
						
							
							
								 
						
							
								57211c5550 
								
							 
						 
						
							
							
								
								More explicit keywords.  
							
							... 
							
							
							
							llvm-svn: 42316 
							
						 
						
							2007-09-25 20:27:06 +00:00  
				
					
						
							
							
								 
						
							
								e36c400255 
								
							 
						 
						
							
							
								
								Fix PR 1681.  When X86 target uses +sse -sse2,  
							
							... 
							
							
							
							keep f32 in SSE registers and f64 in x87.  This
is effectively a new codegen mode.
Change addLegalFPImmediate to permit float and
double variants to do different things.
Adjust callers.
llvm-svn: 42246 
							
						 
						
							2007-09-23 14:52:20 +00:00  
				
					
						
							
							
								 
						
							
								3e18e504ae 
								
							 
						 
						
							
							
								
								Remove (somewhat confusing) Imp<> helper, use let Defs = [], Uses = [] instead.  
							
							... 
							
							
							
							llvm-svn: 41863 
							
						 
						
							2007-09-11 19:55:27 +00:00  
				
					
						
							
							
								 
						
							
								86e0119822 
								
							 
						 
						
							
							
								
								Fold the adjust_trampoline intrinsic into  
							
							... 
							
							
							
							init_trampoline.  There is now only one
trampoline intrinsic.
llvm-svn: 41841 
							
						 
						
							2007-09-11 14:10:23 +00:00  
				
					
						
							
							
								 
						
							
								e2f23a3abf 
								
							 
						 
						
							
							
								
								Add lengthof and endof templates that hide a lot of sizeof computations.  
							
							... 
							
							
							
							Patch by Sterling Stein!
llvm-svn: 41758 
							
						 
						
							2007-09-07 04:06:50 +00:00  
				
					
						
							
							
								 
						
							
								3cf889f75e 
								
							 
						 
						
							
							
								
								Enhance APFloat to retain bits of NaNs (fixes oggenc).  
							
							... 
							
							
							
							Use APFloat interfaces for more references, mostly
of ConstantFPSDNode.
llvm-svn: 41632 
							
						 
						
							2007-08-31 04:03:46 +00:00  
				
					
						
							
							
								 
						
							
								9a25d98c86 
								
							 
						 
						
							
							
								
								Add a variant of foldMemoryOperand to fold any load / store, not just load / store from / to stack slots.  
							
							... 
							
							
							
							llvm-svn: 41597 
							
						 
						
							2007-08-30 05:52:20 +00:00  
				
					
						
							
							
								 
						
							
								d246b2ca5c 
								
							 
						 
						
							
							
								
								Change LegalFPImmediates to use APFloat.  
							
							... 
							
							
							
							Add APFloat interfaces to ConstantFP, SelectionDAG.
Fix integer bit in double->APFloat conversion.
Convert LegalizeDAG to use APFloat interface in
ConstantFPSDNode uses.
llvm-svn: 41587 
							
						 
						
							2007-08-30 00:23:21 +00:00  
				
					
						
							
							
								 
						
							
								c5283ecd6f 
								
							 
						 
						
							
							
								
								long double patch 2 of N.  Handle it in TargetData.  
							
							... 
							
							
							
							(I've tried to get the info right for all targets,
but I'm not expert on all of them - check yours.)
llvm-svn: 40792 
							
						 
						
							2007-08-03 20:20:50 +00:00  
				
					
						
							
							
								 
						
							
								5f6a9da530 
								
							 
						 
						
							
							
								
								More explicit keywords.  
							
							... 
							
							
							
							llvm-svn: 40757 
							
						 
						
							2007-08-02 21:21:54 +00:00  
				
					
						
							
							
								 
						
							
								644f917358 
								
							 
						 
						
							
							
								
								Support for trampolines, except for X86 codegen which is  
							
							... 
							
							
							
							still under discussion.
llvm-svn: 40549 
							
						 
						
							2007-07-27 12:58:54 +00:00  
				
					
						
							
							
								 
						
							
								cf0a5349de 
								
							 
						 
						
							
							
								
								Don't ignore the return value of AsmPrinter::doInitialization and  
							
							... 
							
							
							
							AsmPrinter::doFinalization.
llvm-svn: 40487 
							
						 
						
							2007-07-25 19:33:14 +00:00  
				
					
						
							
							
								 
						
							
								ac1591be42 
								
							 
						 
						
							
							
								
								No more noResults.  
							
							... 
							
							
							
							llvm-svn: 40132 
							
						 
						
							2007-07-21 00:34:19 +00:00  
				
					
						
							
							
								 
						
							
								9d5df0a5f6 
								
							 
						 
						
							
							
								
								Added -print-emitted-asm to print out JIT generated asm to cerr.  
							
							... 
							
							
							
							llvm-svn: 40123 
							
						 
						
							2007-07-20 21:56:13 +00:00  
				
					
						
							
							
								 
						
							
								94b5a80b93 
								
							 
						 
						
							
							
								
								Change instruction description to split OperandList into OutOperandList and  
							
							... 
							
							
							
							InOperandList. This gives one piece of important information: # of results
produced by an instruction.
An example of the change:
def ADD32rr  : I<0x01, MRMDestReg, (ops GR32:$dst, GR32:$src1, GR32:$src2),
                 "add{l} {$src2, $dst|$dst, $src2}",
                 [(set GR32:$dst, (add GR32:$src1, GR32:$src2))]>;
=>
def ADD32rr  : I<0x01, MRMDestReg, (outs GR32:$dst), (ins GR32:$src1, GR32:$src2),
                 "add{l} {$src2, $dst|$dst, $src2}",
                 [(set GR32:$dst, (add GR32:$src1, GR32:$src2))]>;
llvm-svn: 40033 
							
						 
						
							2007-07-19 01:14:50 +00:00  
				
					
						
							
							
								 
						
							
								383a324735 
								
							 
						 
						
							
							
								
								Long live the exception handling!  
							
							... 
							
							
							
							This patch fills the last necessary bits to enable exceptions
handling in LLVM. Currently only on x86-32/linux.
In fact, this patch adds necessary intrinsics (and their lowering) which
represent really weird target-specific gcc builtins used inside unwinder.
After corresponding llvm-gcc patch will land (easy) exceptions should be
more or less workable. However, exceptions handling support should not be 
thought as 'finished': I expect many small and not so small glitches
everywhere.
llvm-svn: 39855 
							
						 
						
							2007-07-14 14:06:15 +00:00  
				
					
						
							
							
								 
						
							
								09d73c0305 
								
							 
						 
						
							
							
								
								Assert when TLS is not implemented.  
							
							... 
							
							
							
							llvm-svn: 39737 
							
						 
						
							2007-07-11 17:19:51 +00:00  
				
					
						
							
							
								 
						
							
								517290ae52 
								
							 
						 
						
							
							
								
								The various "getModuleMatchQuality" implementations should return  
							
							... 
							
							
							
							zero if they see a target triple they don't understand.
llvm-svn: 38463 
							
						 
						
							2007-07-09 17:25:29 +00:00  
				
					
						
							
							
								 
						
							
								2660cef6d7 
								
							 
						 
						
							
							
								
								Convert .cvsignore files  
							
							... 
							
							
							
							llvm-svn: 37801 
							
						 
						
							2007-06-29 16:35:07 +00:00  
				
					
						
							
							
								 
						
							
								309d3d51b3 
								
							 
						 
						
							
							
								
								Move ComputeMaskedBits, MaskedValueIsZero, and ComputeNumSignBits from  
							
							... 
							
							
							
							TargetLowering to SelectionDAG so that they have more convenient
access to the current DAG, in preparation for the ValueType routines
being changed from standalone functions to members of SelectionDAG for
the pre-legalize vector type changes.
llvm-svn: 37704 
							
						 
						
							2007-06-22 14:59:07 +00:00  
				
					
						
							
							
								 
						
							
								a7644dd9b9 
								
							 
						 
						
							
							
								
								Pass a SelectionDAG into SDNode::dump everywhere it's used, in prepration  
							
							... 
							
							
							
							for needing the DAG node to print pre-legalize extended value types, and
to get better debug messages with target-specific nodes.
llvm-svn: 37656 
							
						 
						
							2007-06-19 14:13:56 +00:00  
				
					
						
							
							
								 
						
							
								c68554683d 
								
							 
						 
						
							
							
								
								Handle blocks with 2 unconditional branches in AnalyzeBranch.  
							
							... 
							
							
							
							llvm-svn: 37571 
							
						 
						
							2007-06-13 17:59:52 +00:00  
				
					
						
							
							
								 
						
							
								5514bbef46 
								
							 
						 
						
							
							
								
								Add a utility routine to check for unpredicated terminator instruction.  
							
							... 
							
							
							
							llvm-svn: 37528 
							
						 
						
							2007-06-08 21:59:56 +00:00  
				
					
						
							
							
								 
						
							
								fc94eb66d2 
								
							 
						 
						
							
							
								
								BlockHasNoFallThrough() now returns true if block ends with a return instruction.  
							
							... 
							
							
							
							llvm-svn: 37266 
							
						 
						
							2007-05-21 18:44:17 +00:00  
				
					
						
							
							
								 
						
							
								99be49dd9b 
								
							 
						 
						
							
							
								
								RemoveBranch() and InsertBranch() now returns number of instructions deleted / inserted.  
							
							... 
							
							
							
							llvm-svn: 37192 
							
						 
						
							2007-05-18 00:05:48 +00:00  
				
					
						
							
							
								 
						
							
								8c78a0bff0 
								
							 
						 
						
							
							
								
								Drop 'const'  
							
							... 
							
							
							
							llvm-svn: 36662 
							
						 
						
							2007-05-03 01:11:54 +00:00  
				
					
						
							
							
								 
						
							
								e95c6ad802 
								
							 
						 
						
							
							
								
								Use 'static const char' instead of 'static const int'.  
							
							... 
							
							
							
							Due to darwin gcc bug, one version of darwin linker coalesces
static const int, which defauts PassID based pass identification.
llvm-svn: 36652 
							
						 
						
							2007-05-02 21:39:20 +00:00  
				
					
						
							
							
								 
						
							
								09f162ca6a 
								
							 
						 
						
							
							
								
								Do not use typeinfo to identify pass in pass manager.  
							
							... 
							
							
							
							llvm-svn: 36632 
							
						 
						
							2007-05-01 21:15:47 +00:00  
				
					
						
							
							
								 
						
							
								5662b21db1 
								
							 
						 
						
							
							
								
								eliminateFrameIndex() change.  
							
							... 
							
							
							
							llvm-svn: 36626 
							
						 
						
							2007-05-01 09:13:03 +00:00  
				
					
						
							
							
								 
						
							
								8cd224e81c 
								
							 
						 
						
							
							
								
								Relex assertions to account for additional implicit def / use operands.  
							
							... 
							
							
							
							llvm-svn: 36430 
							
						 
						
							2007-04-25 07:12:14 +00:00  
				
					
						
							
							
								 
						
							
								2077814c91 
								
							 
						 
						
							
							
								
								Use this nifty Constraints thing and fix the inverted conditional moves  
							
							... 
							
							
							
							llvm-svn: 36191 
							
						 
						
							2007-04-17 04:07:59 +00:00  
				
					
						
							
							
								 
						
							
								fb80151c42 
								
							 
						 
						
							
							
								
								Removed tabs everywhere except autogenerated & external files. Add make  
							
							... 
							
							
							
							target for tabs checking.
llvm-svn: 36146 
							
						 
						
							2007-04-16 18:10:23 +00:00  
				
					
						
							
							
								 
						
							
								19c0217d99 
								
							 
						 
						
							
							
								
								For PR1336:  
							
							... 
							
							
							
							Subtarget option names must be given in lower case in order to be
recognized. Fixes test/CodeGen/Alpha/ctlz.ll
llvm-svn: 36125 
							
						 
						
							2007-04-16 14:06:19 +00:00  
				
					
						
							
							
								 
						
							
								427ec7fa51 
								
							 
						 
						
							
							
								
								Readme  
							
							... 
							
							
							
							llvm-svn: 35533 
							
						 
						
							2007-03-31 15:05:44 +00:00  
				
					
						
							
							
								 
						
							
								d685514e2e 
								
							 
						 
						
							
							
								
								switch TargetLowering::getConstraintType to take the entire constraint,  
							
							... 
							
							
							
							not just the first letter.  No functionality change.
llvm-svn: 35322 
							
						 
						
							2007-03-25 02:14:49 +00:00  
				
					
						
							
							
								 
						
							
								61f39d186c 
								
							 
						 
						
							
							
								
								Added MRegisterInfo hook to re-materialize an instruction.  
							
							... 
							
							
							
							llvm-svn: 35205 
							
						 
						
							2007-03-20 08:09:38 +00:00  
				
					
						
							
							
								 
						
							
								ed4b303c10 
								
							 
						 
						
							
							
								
								Refactoring of formal parameter flags. Enable properly use of  
							
							... 
							
							
							
							zext/sext/aext stuff.
llvm-svn: 35008 
							
						 
						
							2007-03-07 16:25:09 +00:00  
				
					
						
							
							
								 
						
							
								95ae95a6a6 
								
							 
						 
						
							
							
								
								PEI now passes a RegScavenger ptr to eliminateFrameIndex.  
							
							... 
							
							
							
							llvm-svn: 34707 
							
						 
						
							2007-02-28 00:21:17 +00:00  
				
					
						
							
							
								 
						
							
								df5899258c 
								
							 
						 
						
							
							
								
								By default, spills kills the register being stored.  
							
							... 
							
							
							
							llvm-svn: 34515 
							
						 
						
							2007-02-23 01:10:04 +00:00  
				
					
						
							
							
								 
						
							
								e0008e23cf 
								
							 
						 
						
							
							
								
								Simplify lowering and selection of exception ops.  
							
							... 
							
							
							
							llvm-svn: 34488 
							
						 
						
							2007-02-22 14:56:36 +00:00  
				
					
						
							
							
								 
						
							
								3796abea0f 
								
							 
						 
						
							
							
								
								Support to provide exception and selector registers.  
							
							... 
							
							
							
							llvm-svn: 34482 
							
						 
						
							2007-02-21 22:54:50 +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  
				
					
						
							
							
								 
						
							
								9865be6d40 
								
							 
						 
						
							
							
								
								Added getReservedRegs().  
							
							... 
							
							
							
							llvm-svn: 34376 
							
						 
						
							2007-02-17 11:06:00 +00:00  
				
					
						
							
							
								 
						
							
								b8d6fa20bb 
								
							 
						 
						
							
							
								
								This was done recently  
							
							... 
							
							
							
							llvm-svn: 34338 
							
						 
						
							2007-02-16 02:11:59 +00:00  
				
					
						
							
							
								 
						
							
								6719d3d0a2 
								
							 
						 
						
							
							
								
								Well this isn't as ugly and it works better. At least gcc bootstraps again  
							
							... 
							
							
							
							llvm-svn: 34254 
							
						 
						
							2007-02-13 23:41:16 +00:00  
				
					
						
							
							
								 
						
							
								9a4a1515ee 
								
							 
						 
						
							
							
								
								return addresses, those I already have  
							
							... 
							
							
							
							llvm-svn: 34056 
							
						 
						
							2007-02-08 17:37:41 +00:00  
				
					
						
							
							
								 
						
							
								59889ae93f 
								
							 
						 
						
							
							
								
								Added new method to add a "simple" code emitter. That is, to only add  
							
							... 
							
							
							
							the code emitter and not set variables.
llvm-svn: 34033 
							
						 
						
							2007-02-08 01:38:33 +00:00  
				
					
						
							
							
								 
						
							
								5301e7c605 
								
							 
						 
						
							
							
								
								For PR1136: Rename GlobalVariable::isExternal as isDeclaration to avoid  
							
							... 
							
							
							
							confusion with external linkage types.
llvm-svn: 33663 
							
						 
						
							2007-01-30 20:08:39 +00:00  
				
					
						
							
							
								 
						
							
								eda5997cc8 
								
							 
						 
						
							
							
								
								Finish off bug 680, allowing targets to custom lower frame and return  
							
							... 
							
							
							
							address nodes.
llvm-svn: 33636 
							
						 
						
							2007-01-29 22:58:52 +00:00  
				
					
						
							
							
								 
						
							
								f9e5445ed4 
								
							 
						 
						
							
							
								
								Make LABEL a builtin opcode.  
							
							... 
							
							
							
							llvm-svn: 33537 
							
						 
						
							2007-01-26 14:34:52 +00:00  
				
					
						
							
							
								 
						
							
								c4bdea012b 
								
							 
						 
						
							
							
								
								FTOIT and ITOFT are bit converts, and if we drop 21264s, are always available  
							
							... 
							
							
							
							llvm-svn: 33492 
							
						 
						
							2007-01-24 21:09:16 +00:00  
				
					
						
							
							
								 
						
							
								8a75518f0b 
								
							 
						 
						
							
							
								
								Fix unordered fp on alpha  
							
							... 
							
							
							
							llvm-svn: 33487 
							
						 
						
							2007-01-24 18:43:14 +00:00  
				
					
						
							
							
								 
						
							
								f5c96fabf9 
								
							 
						 
						
							
							
								
								Renamed getTypeAlignmentShift() to getPreferredTypeAlignmentShift().  
							
							... 
							
							
							
							llvm-svn: 33482 
							
						 
						
							2007-01-24 07:03:39 +00:00  
				
					
						
							
							
								 
						
							
								6730e12ae4 
								
							 
						 
						
							
							
								
								PEI is now responsible for adding MaxCallFrameSize to frame size and align the stack. Each target can further adjust the frame size if necessary.  
							
							... 
							
							
							
							llvm-svn: 33460 
							
						 
						
							2007-01-23 09:38:11 +00:00  
				
					
						
							
							
								 
						
							
								16e58be1bc 
								
							 
						 
						
							
							
								
								hasFP() is now a virtual method of MRegisterInfo.  
							
							... 
							
							
							
							llvm-svn: 33455 
							
						 
						
							2007-01-23 00:57:47 +00:00  
				
					
						
							
							
								 
						
							
								a94d394ad2 
								
							 
						 
						
							
							
								
								For PR1043:  
							
							... 
							
							
							
							This is the final patch for this PR. It implements some minor cleanup
in the use of IntegerType, to wit:
1. Type::getIntegerTypeMask -> IntegerType::getBitMask
2. Type::Int*Ty changed to IntegerType* from Type*
3. ConstantInt::getType() returns IntegerType* now, not Type*
This also fixes PR1120.
Patch by Sheng Zhou.
llvm-svn: 33370 
							
						 
						
							2007-01-19 21:13:56 +00:00  
				
					
						
							
							
								 
						
							
								74b46e8c05 
								
							 
						 
						
							
							
								
								Fix naming inconsistency.  
							
							... 
							
							
							
							llvm-svn: 32823 
							
						 
						
							2007-01-02 21:33:40 +00:00  
				
					
						
							
							
								 
						
							
								e63b6518fa 
								
							 
						 
						
							
							
								
								For PR950:  
							
							... 
							
							
							
							Three changes:
1. Convert signed integer types to signless versions.
2. Implement the @sext and @zext parameter attributes. Previously the
   type of an function parameter was used to determine whether it should
   be sign extended or zero extended before the call. This information is
   now communicated via the function type's parameter attributes.
3. The interface to LowerCallTo had to be changed in order to accommodate
   the parameter attribute information. Although it would have been
   convenient to pass in the FunctionType itself, there isn't always one
   present in the caller. Consequently, a signedness indication for the
   result type and for each parameter was provided for in the interface
   to this method. All implementations were changed to make the adjustment
   necessary.
llvm-svn: 32788 
							
						 
						
							2006-12-31 05:55:36 +00:00  
				
					
						
							
							
								 
						
							
								1ef9cd400d 
								
							 
						 
						
							
							
								
								eliminate static ctors for Statistic objects.  
							
							... 
							
							
							
							llvm-svn: 32703 
							
						 
						
							2006-12-19 22:59:26 +00:00  
				
					
						
							
							
								 
						
							
								085cfdbfdc 
								
							 
						 
						
							
							
								
								Simplify a bit  
							
							... 
							
							
							
							llvm-svn: 32343 
							
						 
						
							2006-12-07 23:55:55 +00:00  
				
					
						
							
							
								 
						
							
								9bfb1e1f29 
								
							 
						 
						
							
							
								
								What should be the last unnecessary <iostream>s in the library.  
							
							... 
							
							
							
							llvm-svn: 32333 
							
						 
						
							2006-12-07 22:21:48 +00:00  
				
					
						
							
							
								 
						
							
								76a61eb054 
								
							 
						 
						
							
							
								
								Be sure to grab weak functions too, and make implicit defs comments  
							
							... 
							
							
							
							llvm-svn: 32308 
							
						 
						
							2006-12-07 17:39:14 +00:00  
				
					
						
							
							
								 
						
							
								7c779fcad4 
								
							 
						 
						
							
							
								
								add #include  
							
							... 
							
							
							
							llvm-svn: 32281 
							
						 
						
							2006-12-06 18:19:53 +00:00  
				
					
						
							
							
								 
						
							
								700b873130 
								
							 
						 
						
							
							
								
								Detemplatize the Statistic class.  The only type it is instantiated with  
							
							... 
							
							
							
							is 'unsigned'.
llvm-svn: 32279 
							
						 
						
							2006-12-06 17:46:33 +00:00  
				
					
						
							
							
								 
						
							
								aafeaef8c8 
								
							 
						 
						
							
							
								
								MachineInstr::setOpcode -> MachineInstr::setInstrDescriptor  
							
							... 
							
							
							
							llvm-svn: 32034 
							
						 
						
							2006-11-30 07:12:03 +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  
				
					
						
							
							
								 
						
							
								dc2c8748a7 
								
							 
						 
						
							
							
								
								Properly transfer kill / dead info.  
							
							... 
							
							
							
							llvm-svn: 31765 
							
						 
						
							2006-11-15 20:58:11 +00:00  
				
					
						
							
							
								 
						
							
								dbd3d294e6 
								
							 
						 
						
							
							
								
								Matches MachineInstr changes.  
							
							... 
							
							
							
							llvm-svn: 31712 
							
						 
						
							2006-11-13 23:36:35 +00:00  
				
					
						
							
							
								 
						
							
								b974b0a3e1 
								
							 
						 
						
							
							
								
								silence warnings.  
							
							... 
							
							
							
							llvm-svn: 31394 
							
						 
						
							2006-11-03 01:18:29 +00:00  
				
					
						
							
							
								 
						
							
								de46e48420 
								
							 
						 
						
							
							
								
								For PR786:  
							
							... 
							
							
							
							Turn on -Wunused and -Wno-unused-parameter. Clean up most of the resulting
fall out by removing unused variables. Remaining warnings have to do with
unused functions (I didn't want to delete code without review) and unused
variables in generated code. Maintainers should clean up the remaining
issues when they see them. All changes pass DejaGnu tests and Olden.
llvm-svn: 31380 
							
						 
						
							2006-11-02 20:25:50 +00:00  
				
					
						
							
							
								 
						
							
								d8b59f67f6 
								
							 
						 
						
							
							
								
								fix 2006-11-01-vastart.ll  
							
							... 
							
							
							
							llvm-svn: 31371 
							
						 
						
							2006-11-02 03:05:26 +00:00  
				
					
						
							
							
								 
						
							
								dfbf91e59d 
								
							 
						 
						
							
							
								
								more shotenning  
							
							... 
							
							
							
							llvm-svn: 31331 
							
						 
						
							2006-10-31 23:46:56 +00:00  
				
					
						
							
							
								 
						
							
								8b20fa42da 
								
							 
						 
						
							
							
								
								Let us play simplify the td file (and fix a few missed sub and mul patterns).  
							
							... 
							
							
							
							llvm-svn: 31322 
							
						 
						
							2006-10-31 19:52:12 +00:00  
				
					
						
							
							
								 
						
							
								692e4155aa 
								
							 
						 
						
							
							
								
								Add all that branch mangling niftiness  
							
							... 
							
							
							
							llvm-svn: 31313 
							
						 
						
							2006-10-31 16:49:55 +00:00  
				
					
						
							
							
								 
						
							
								0d41d19427 
								
							 
						 
						
							
							
								
								All targets expand BR_JT for now.  
							
							... 
							
							
							
							llvm-svn: 31294 
							
						 
						
							2006-10-30 08:02:39 +00:00  
				
					
						
							
							
								 
						
							
								71b99297aa 
								
							 
						 
						
							
							
								
								Move getPreferredAlignmentLog from AsmPrinter to TargetData  
							
							... 
							
							
							
							llvm-svn: 31171 
							
						 
						
							2006-10-24 20:32:14 +00:00  
				
					
						
							
							
								 
						
							
								ed32883b27 
								
							 
						 
						
							
							
								
								fix warning about missing newline at end of file  
							
							... 
							
							
							
							llvm-svn: 31162 
							
						 
						
							2006-10-24 17:07:11 +00:00  
				
					
						
							
							
								 
						
							
								042d56230e 
								
							 
						 
						
							
							
								
								implement uncond branch insertion so alpha works work branchfolding.  
							
							... 
							
							
							
							llvm-svn: 31158 
							
						 
						
							2006-10-24 16:41:36 +00:00  
				
					
						
							
							
								 
						
							
								e0fc4dfc22 
								
							 
						 
						
							
							
								
								For PR950:  
							
							... 
							
							
							
							This patch implements the first increment for the Signless Types feature.
All changes pertain to removing the ConstantSInt and ConstantUInt classes
in favor of just using ConstantInt.
llvm-svn: 31063 
							
						 
						
							2006-10-20 07:07:24 +00:00  
				
					
						
							
							
								 
						
							
								ab51cf2e78 
								
							 
						 
						
							
							
								
								Merge ISD::TRUNCSTORE to ISD::STORE. Switch to using StoreSDNode.  
							
							... 
							
							
							
							llvm-svn: 30945 
							
						 
						
							2006-10-13 21:14:26 +00:00  
				
					
						
							
							
								 
						
							
								0e0ee36f45 
								
							 
						 
						
							
							
								
								adjcallstack up/down clobbers the sp  
							
							... 
							
							
							
							llvm-svn: 30910 
							
						 
						
							2006-10-12 18:00:14 +00:00  
				
					
						
							
							
								 
						
							
								fa8cbfd8e8 
								
							 
						 
						
							
							
								
								Reduce the amount of state in the lowering code and drop old pattern ISel functions  
							
							... 
							
							
							
							llvm-svn: 30881 
							
						 
						
							2006-10-11 16:24:51 +00:00  
				
					
						
							
							
								 
						
							
								6487854b3f 
								
							 
						 
						
							
							
								
								Use cute tblgen tricks to make zap handling more powerful.  Specifically,  
							
							... 
							
							
							
							when the dag combiner simplifies an and mask, notice this and allow those bits
to be missing from the zap mask.
This compiles Alpha/zapnot4.ll into:
        sll $16,3,$0
        zapnot $0,3,$0
        ret $31,($26),1
instead of:
        ldah $0,1($31)
        lda $0,-8($0)
        sll $16,3,$1
        and $1,$0,$0
        ret $31,($26),1
It would be *really* nice to replace the hunk of code in the
AlphaISelDAGToDAG.cpp file that matches (and (srl (x, C), c2) into
(SRL (ZAPNOTi)) with a similar pattern, but I've spent enough time poking
at alpha.  Make andrew will do this.
llvm-svn: 30875 
							
						 
						
							2006-10-11 05:13:56 +00:00  
				
					
						
							
							
								 
						
							
								a6bbf33cbf 
								
							 
						 
						
							
							
								
								Jimptables working again on alpha.  
							
							... 
							
							
							
							As a bonus, use the GOT node instead of the AlphaISD::GOT for internal stuff.
llvm-svn: 30873 
							
						 
						
							2006-10-11 04:29:42 +00:00  
				
					
						
							
							
								 
						
							
								9f86f7c2ab 
								
							 
						 
						
							
							
								
								Remove dead/redundant instructions.  These are handled by ZAPNOTi  
							
							... 
							
							
							
							llvm-svn: 30872 
							
						 
						
							2006-10-11 04:12:39 +00:00  
				
					
						
							
							
								 
						
							
								4a57e2a6ed 
								
							 
						 
						
							
							
								
								This entry is done.  switched to the gcc way of doing things.  
							
							... 
							
							
							
							llvm-svn: 30867 
							
						 
						
							2006-10-11 01:48:03 +00:00  
				
					
						
							
							
								 
						
							
								3d74556d74 
								
							 
						 
						
							
							
								
								This has apparently been fixed  
							
							... 
							
							
							
							llvm-svn: 30864 
							
						 
						
							2006-10-11 01:44:46 +00:00  
				
					
						
							
							
								 
						
							
								e71fe34d75 
								
							 
						 
						
							
							
								
								Reflects ISD::LOAD / ISD::LOADX / LoadSDNode changes.  
							
							... 
							
							
							
							llvm-svn: 30844 
							
						 
						
							2006-10-09 20:57:25 +00:00  
				
					
						
							
							
								 
						
							
								dc3064e223 
								
							 
						 
						
							
							
								
								Set the jt section  
							
							... 
							
							
							
							llvm-svn: 30781 
							
						 
						
							2006-10-06 22:52:33 +00:00  
				
					
						
							
							
								 
						
							
								21fa769867 
								
							 
						 
						
							
							
								
								Alpha uses a got  
							
							... 
							
							
							
							llvm-svn: 30778 
							
						 
						
							2006-10-06 22:46:51 +00:00  
				
					
						
							
							
								 
						
							
								df9ac47e5e 
								
							 
						 
						
							
							
								
								Make use of getStore().  
							
							... 
							
							
							
							llvm-svn: 30759 
							
						 
						
							2006-10-05 23:01:46 +00:00  
				
					
						
							
							
								 
						
							
								8cfd10eff3 
								
							 
						 
						
							
							
								
								Don't bother setting JumpTableTextSection, it is about to disappear  
							
							... 
							
							
							
							llvm-svn: 30745 
							
						 
						
							2006-10-05 03:13:59 +00:00  
				
					
						
							
							
								 
						
							
								a6a570e02f 
								
							 
						 
						
							
							
								
								Pass the MachineFunction into EmitJumpTableInfo.  
							
							... 
							
							
							
							llvm-svn: 30742 
							
						 
						
							2006-10-05 03:01:21 +00:00  
				
					
						
							
							
								 
						
							
								c8c78982d4 
								
							 
						 
						
							
							
								
								use getSectionForFunction to decide which section to emit code into  
							
							... 
							
							
							
							llvm-svn: 30738 
							
						 
						
							2006-10-05 02:47:13 +00:00  
				
					
						
							
							
								 
						
							
								5d9fd977d3 
								
							 
						 
						
							
							
								
								Combine ISD::EXTLOAD, ISD::SEXTLOAD, ISD::ZEXTLOAD into ISD::LOADX. Add an  
							
							... 
							
							
							
							extra operand to LOADX to specify the exact value extension type.
llvm-svn: 30714 
							
						 
						
							2006-10-04 00:56:09 +00:00  
				
					
						
							
							
								 
						
							
								5e2bacd6be 
								
							 
						 
						
							
							
								
								Fix jump tables to match gcc (and the ABI and whatnot)  
							
							... 
							
							
							
							llvm-svn: 30594 
							
						 
						
							2006-09-24 19:46:56 +00:00  
				
					
						
							
							
								 
						
							
								68324f8f85 
								
							 
						 
						
							
							
								
								jump table note  
							
							... 
							
							
							
							llvm-svn: 30591 
							
						 
						
							2006-09-24 13:13:10 +00:00  
				
					
						
							
							
								 
						
							
								ccdaecc448 
								
							 
						 
						
							
							
								
								Account for pseudo-ops correctly  
							
							... 
							
							
							
							llvm-svn: 30548 
							
						 
						
							2006-09-20 20:08:52 +00:00  
				
					
						
							
							
								 
						
							
								f007f21c8a 
								
							 
						 
						
							
							
								
								catch constants more often  
							
							... 
							
							
							
							llvm-svn: 30534 
							
						 
						
							2006-09-20 15:05:49 +00:00  
				
					
						
							
							
								 
						
							
								97a4e99aff 
								
							 
						 
						
							
							
								
								clarify with test case  
							
							... 
							
							
							
							llvm-svn: 30531 
							
						 
						
							2006-09-20 14:48:00 +00:00  
				
					
						
							
							
								 
						
							
								e2d138a462 
								
							 
						 
						
							
							
								
								Add Note  
							
							... 
							
							
							
							llvm-svn: 30530 
							
						 
						
							2006-09-20 14:40:01 +00:00  
				
					
						
							
							
								 
						
							
								f23e3bfcb2 
								
							 
						 
						
							
							
								
								A pass to remove the worst of the replay trap offenders, and as a bonus, align basic blocks when it is free to do so  
							
							... 
							
							
							
							llvm-svn: 30467 
							
						 
						
							2006-09-18 19:44:29 +00:00  
				
					
						
							
							
								 
						
							
								3aa3ad780e 
								
							 
						 
						
							
							
								
								Jump tables on Alpha  
							
							... 
							
							
							
							llvm-svn: 30463 
							
						 
						
							2006-09-18 18:01:03 +00:00  
				
					
						
							
							
								 
						
							
								d61d39ec53 
								
							 
						 
						
							
							
								
								Adding dllimport, dllexport and external weak linkage types.  
							
							... 
							
							
							
							DLL* linkages got full (I hope) codegeneration support in C & both x86
assembler backends.
External weak linkage added for future use, we don't provide any
codegeneration, etc. support for it.
llvm-svn: 30374 
							
						 
						
							2006-09-14 18:23:27 +00:00  
				
					
						
							
							
								 
						
							
								9a083a4121 
								
							 
						 
						
							
							
								
								Reflects MachineConstantPoolEntry changes.  
							
							... 
							
							
							
							llvm-svn: 30279 
							
						 
						
							2006-09-12 21:04:05 +00:00  
				
					
						
							
							
								 
						
							
								ae92ce8798 
								
							 
						 
						
							
							
								
								1. Remove condition on delete.  
							
							... 
							
							
							
							2. Protect and outline createTargetAsmInfo.
3. Misc. kruft.
llvm-svn: 30169 
							
						 
						
							2006-09-07 23:39:26 +00:00  
				
					
						
							
							
								 
						
							
								261779bb45 
								
							 
						 
						
							
							
								
								Make target asm info a property of the target machine.  
							
							... 
							
							
							
							llvm-svn: 30162 
							
						 
						
							2006-09-07 22:06:40 +00:00  
				
					
						
							
							
								 
						
							
								0e83541f8b 
								
							 
						 
						
							
							
								
								Break out target asm info into separate files.  
							
							... 
							
							
							
							llvm-svn: 30161 
							
						 
						
							2006-09-07 22:05:02 +00:00  
				
					
						
							
							
								 
						
							
								a6211dcdad 
								
							 
						 
						
							
							
								
								Separate target specific asm properties from the asm printers.  
							
							... 
							
							
							
							llvm-svn: 30126 
							
						 
						
							2006-09-06 18:34:40 +00:00  
				
					
						
							
							
								 
						
							
								af23f9b5f6 
								
							 
						 
						
							
							
								
								Completely eliminate def&use operands.  Now a register operand is EITHER a  
							
							... 
							
							
							
							def operand or a use operand.
llvm-svn: 30109 
							
						 
						
							2006-09-05 02:31:13 +00:00  
				
					
						
							
							
								 
						
							
								3852b2ce7e 
								
							 
						 
						
							
							
								
								jmp_bufs are this big on alpha.  
							
							... 
							
							
							
							llvm-svn: 30107 
							
						 
						
							2006-09-05 00:22:25 +00:00  
				
					
						
							
							
								 
						
							
								12e97307a1 
								
							 
						 
						
							
							
								
								Completely rearchitect the interface between targets and the pass manager.  
							
							... 
							
							
							
							This pass:
1. Splits TargetMachine into TargetMachine (generic targets, can be implemented
any way, like the CBE) and LLVMTargetMachine (subclass of TM that is used by
things using libcodegen and other support).
2. Instead of having each target fully populate the passmgr for file or JIT
   output, move all this to common code, and give targets hooks they can
   implement.
3. Commonalize the target population stuff between file emission and JIT
   emission.
4. All (native code) codegen stuff now happens in a FunctionPassManager, which
   paves the way for "fast -O0" stuff in the CFE later, and now LLC could
   lazily stream .bc files from disk to use less memory.
5. There are now many fewer #includes and the targets don't depend on the
   scalar xforms or libanalysis anymore (but codegen does).
6. Changing common code generator pass ordering stuff no longer requires
   touching all targets.
7. The JIT now has the option of "-fast" codegen or normal optimized codegen,
   which is now orthogonal to the fact that JIT'ing is being done.
llvm-svn: 30081 
							
						 
						
							2006-09-04 04:14:57 +00:00  
				
					
						
							
							
								 
						
							
								0fc4541c67 
								
							 
						 
						
							
							
								
								Simplify target construction.  
							
							... 
							
							
							
							llvm-svn: 30070 
							
						 
						
							2006-09-03 18:44:02 +00:00  
				
					
						
							
							
								 
						
							
								c3acfc0b10 
								
							 
						 
						
							
							
								
								Do not use getTargetNode() and SelectNodeTo() which takes more than 3  
							
							... 
							
							
							
							SDOperand arguments. Use the variants which take an array and number instead.
llvm-svn: 29907 
							
						 
						
							2006-08-27 08:14:06 +00:00  
				
					
						
							
							
								 
						
							
								34b70eea5c 
								
							 
						 
						
							
							
								
								SelectNodeTo now returns a SDNode*.  
							
							... 
							
							
							
							llvm-svn: 29901 
							
						 
						
							2006-08-26 08:00:10 +00:00  
				
					
						
							
							
								 
						
							
								61413a3d72 
								
							 
						 
						
							
							
								
								Select() no longer require Result operand by reference.  
							
							... 
							
							
							
							llvm-svn: 29898 
							
						 
						
							2006-08-26 05:34:46 +00:00  
				
					
						
							
							
								 
						
							
								ab8297f92d 
								
							 
						 
						
							
							
								
								Match tblgen changes.  
							
							... 
							
							
							
							llvm-svn: 29895 
							
						 
						
							2006-08-26 01:07:58 +00:00  
				
					
						
							
							
								 
						
							
								60f1eecd3a 
								
							 
						 
						
							
							
								
								Constify some methods.  Patch provided by Anton Vayvod, thanks!  
							
							... 
							
							
							
							llvm-svn: 29756 
							
						 
						
							2006-08-17 22:00:08 +00:00  
				
					
						
							
							
								 
						
							
								63d178f473 
								
							 
						 
						
							
							
								
								SelectNodeTo() may return a SDOperand that is different from the input.  
							
							... 
							
							
							
							llvm-svn: 29726 
							
						 
						
							2006-08-16 07:30:09 +00:00  
				
					
						
							
							
								 
						
							
								ed728e8dc9 
								
							 
						 
						
							
							
								
								Eliminate use of getNode that takes a vector.  
							
							... 
							
							
							
							llvm-svn: 29614 
							
						 
						
							2006-08-11 17:38:39 +00:00  
				
					
						
							
							
								 
						
							
								2aa76cf371 
								
							 
						 
						
							
							
								
								eliminate use of getNode that takes vector<SDOperand>.  Wrap a really long line.  
							
							... 
							
							
							
							llvm-svn: 29610 
							
						 
						
							2006-08-11 17:19:54 +00:00  
				
					
						
							
							
								 
						
							
								bd1c5a8fb8 
								
							 
						 
						
							
							
								
								Match tablegen changes.  
							
							... 
							
							
							
							llvm-svn: 29604 
							
						 
						
							2006-08-11 09:08:15 +00:00  
				
					
						
							
							
								 
						
							
								81b645a76b 
								
							 
						 
						
							
							
								
								CALLSEQ_* produces chain even if that's not needed.  
							
							... 
							
							
							
							llvm-svn: 29603 
							
						 
						
							2006-08-11 09:03:33 +00:00  
				
					
						
							
							
								 
						
							
								b9d34bd098 
								
							 
						 
						
							
							
								
								Match tablegen isel changes.  
							
							... 
							
							
							
							llvm-svn: 29549 
							
						 
						
							2006-08-07 22:28:20 +00:00  
				
					
						
							
							
								 
						
							
								2af3a67902 
								
							 
						 
						
							
							
								
								Remove a duplicate pattern/  
							
							... 
							
							
							
							llvm-svn: 29413 
							
						 
						
							2006-07-31 18:42:49 +00:00  
				
					
						
							
							
								 
						
							
								b572401bea 
								
							 
						 
						
							
							
								
								Remove InFlightSet hack. No longer needed.  
							
							... 
							
							
							
							llvm-svn: 29373 
							
						 
						
							2006-07-28 00:47:19 +00:00  
				
					
						
							
							
								 
						
							
								78bf1074fc 
								
							 
						 
						
							
							
								
								Resolve BB references with relocation.  
							
							... 
							
							
							
							llvm-svn: 29351 
							
						 
						
							2006-07-27 18:21:10 +00:00  
				
					
						
							
							
								 
						
							
								f6acb34d23 
								
							 
						 
						
							
							
								
								- Refactor the code that resolve basic block references to a TargetJITInfo  
							
							... 
							
							
							
							method.
- Added synchronizeICache() to TargetJITInfo. It is called after each block
  of code is emitted to flush the icache. This ensures correct execution
  on targets that have separate dcache and icache.
- Added PPC / Mac OS X specific code to do icache flushing.
llvm-svn: 29276 
							
						 
						
							2006-07-25 20:40:54 +00:00  
				
					
						
							
							
								 
						
							
								c3d341ea98 
								
							 
						 
						
							
							
								
								Ensure that dump calls that are associated with asserts are removed from  
							
							... 
							
							
							
							non-debug build.
llvm-svn: 29105 
							
						 
						
							2006-07-11 17:58:07 +00:00  
				
					
						
							
							
								 
						
							
								01078dc60b 
								
							 
						 
						
							
							
								
								These are already implemented  
							
							... 
							
							
							
							llvm-svn: 28990 
							
						 
						
							2006-07-03 18:00:29 +00:00  
				
					
						
							
							
								 
						
							
								042f5076ed 
								
							 
						 
						
							
							
								
								0 offsets for memory operands  
							
							... 
							
							
							
							llvm-svn: 28989 
							
						 
						
							2006-07-03 17:57:34 +00:00  
				
					
						
							
							
								 
						
							
								a53a22e5fe 
								
							 
						 
						
							
							
								
								this case isn't handled  
							
							... 
							
							
							
							llvm-svn: 28948 
							
						 
						
							2006-06-27 23:19:14 +00:00  
				
					
						
							
							
								 
						
							
								680ac12e53 
								
							 
						 
						
							
							
								
								Add memory operand and int regs  
							
							... 
							
							
							
							llvm-svn: 28896 
							
						 
						
							2006-06-21 15:42:36 +00:00  
				
					
						
							
							
								 
						
							
								b0316eada6 
								
							 
						 
						
							
							
								
								inline asm, at least for floats  
							
							... 
							
							
							
							llvm-svn: 28895 
							
						 
						
							2006-06-21 13:37:27 +00:00  
				
					
						
							
							
								 
						
							
								336313ce3d 
								
							 
						 
						
							
							
								
								fix argument problem  
							
							... 
							
							
							
							llvm-svn: 28893 
							
						 
						
							2006-06-21 01:00:43 +00:00  
				
					
						
							
							
								 
						
							
								f3b5b92e58 
								
							 
						 
						
							
							
								
								Don't pass target name into TargetData anymore, it is never used or needed.  
							
							... 
							
							
							
							Remove explicit casts to std::string now that there is no overload resolution
issues in the TargetData ctors.
llvm-svn: 28830 
							
						 
						
							2006-06-16 18:22:52 +00:00  
				
					
						
							
							
								 
						
							
								7c69df968c 
								
							 
						 
						
							
							
								
								I am sure I had commited this workaround before.  Perhaps soon I should sort it all out  
							
							... 
							
							
							
							llvm-svn: 28772 
							
						 
						
							2006-06-13 20:34:47 +00:00  
				
					
						
							
							
								 
						
							
								f570feeae3 
								
							 
						 
						
							
							
								
								It really helps to be returning to the correct place  
							
							... 
							
							
							
							llvm-svn: 28769 
							
						 
						
							2006-06-13 18:27:39 +00:00  
				
					
						
							
							
								 
						
							
								80528499cf 
								
							 
						 
						
							
							
								
								Let the alpha breakage begin.  First Formals and RET.  next Calls  
							
							... 
							
							
							
							llvm-svn: 28753 
							
						 
						
							2006-06-12 18:09:24 +00:00  
				
					
						
							
							
								 
						
							
								b47461350c 
								
							 
						 
						
							
							
								
								ignore ordered/unordered for now  
							
							... 
							
							
							
							llvm-svn: 28679 
							
						 
						
							2006-06-04 00:25:51 +00:00  
				
					
						
							
							
								 
						
							
								a3add0fea8 
								
							 
						 
						
							
							
								
								Change RET node to include signness information of the return values. i.e.  
							
							... 
							
							
							
							RET chain, value1, sign1, value2, sign2, ...
llvm-svn: 28510 
							
						 
						
							2006-05-26 23:10:12 +00:00  
				
					
						
							
							
								 
						
							
								4af59dac0b 
								
							 
						 
						
							
							
								
								Assert if InflightSet is not cleared after instruction selecting a BB.  
							
							... 
							
							
							
							llvm-svn: 28459 
							
						 
						
							2006-05-25 00:24:28 +00:00  
				
					
						
							
							
								 
						
							
								1a8e74d113 
								
							 
						 
						
							
							
								
								Clear HandleMap and ReplaceMap after instruction selection. Or it may cause  
							
							... 
							
							
							
							non-deterministic behavior.
llvm-svn: 28454 
							
						 
						
							2006-05-24 20:46:25 +00:00  
				
					
						
							
							
								 
						
							
								aa2372562e 
								
							 
						 
						
							
							
								
								Patches to make the LLVM sources more -pedantic clean.  Patch provided  
							
							... 
							
							
							
							by Anton Korobeynikov!  This is a step towards closing PR786.
llvm-svn: 28447 
							
						 
						
							2006-05-24 17:04:05 +00:00  
				
					
						
							
							
								 
						
							
								88812b5c0a 
								
							 
						 
						
							
							
								
								Make all of the TargetMachine subclasses use the new string TargetData methods.  
							
							... 
							
							
							
							This is part of the on-going work on PR 761.
llvm-svn: 28414 
							
						 
						
							2006-05-20 00:24:56 +00:00  
				
					
						
							
							
								 
						
							
								b90055ef24 
								
							 
						 
						
							
							
								
								Fix a bogus gcc warning  
							
							... 
							
							
							
							llvm-svn: 28382 
							
						 
						
							2006-05-18 17:29:34 +00:00  
				
					
						
							
							
								 
						
							
								305c49579c 
								
							 
						 
						
							
							
								
								getCalleeSaveRegs and getCalleeSaveRegClasses are no long TableGen'd.  
							
							... 
							
							
							
							llvm-svn: 28378 
							
						 
						
							2006-05-18 00:12:58 +00:00  
				
					
						
							
							
								 
						
							
								dcec882286 
								
							 
						 
						
							
							
								
								Remove PointerType from class Target  
							
							... 
							
							
							
							llvm-svn: 28368 
							
						 
						
							2006-05-17 21:20:27 +00:00  
				
					
						
							
							
								 
						
							
								0f524f2050 
								
							 
						 
						
							
							
								
								Fix call_adj.ll  
							
							... 
							
							
							
							llvm-svn: 28360 
							
						 
						
							2006-05-17 19:24:49 +00:00  
				
					
						
							
							
								 
						
							
								446dbcb5e4 
								
							 
						 
						
							
							
								
								Added sanity check for obviously bogus immediates  
							
							... 
							
							
							
							llvm-svn: 28359 
							
						 
						
							2006-05-17 19:24:31 +00:00  
				
					
						
							
							
								 
						
							
								1dc9ec5874 
								
							 
						 
						
							
							
								
								Move this code to a common place  
							
							... 
							
							
							
							llvm-svn: 28329 
							
						 
						
							2006-05-16 17:42:15 +00:00  
				
					
						
							
							
								 
						
							
								132322b96e 
								
							 
						 
						
							
							
								
								remove dead variable.  
							
							... 
							
							
							
							llvm-svn: 28258 
							
						 
						
							2006-05-12 18:17:25 +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  
				
					
						
							
							
								 
						
							
								8488ba2e41 
								
							 
						 
						
							
							
								
								Split SwitchSection into SwitchTo{Text|Data}Section methods.  
							
							... 
							
							
							
							llvm-svn: 28184 
							
						 
						
							2006-05-09 04:59:56 +00:00  
				
					
						
							
							
								 
						
							
								10b71c0d08 
								
							 
						 
						
							
							
								
								Rename MO_VirtualRegister -> MO_Register.  Clean up immediate handling.  
							
							... 
							
							
							
							llvm-svn: 28104 
							
						 
						
							2006-05-04 18:05:43 +00:00  
				
					
						
							
							
								 
						
							
								10d6341618 
								
							 
						 
						
							
							
								
								Move some methods out of MachineInstr into MachineOperand  
							
							... 
							
							
							
							llvm-svn: 28102 
							
						 
						
							2006-05-04 17:52:23 +00:00  
				
					
						
							
							
								 
						
							
								fef7a2d0f5 
								
							 
						 
						
							
							
								
								There shalt be only one "immediate" operand type!  
							
							... 
							
							
							
							llvm-svn: 28099 
							
						 
						
							2006-05-04 17:21:20 +00:00  
				
					
						
							
							
								 
						
							
								940cc978ef 
								
							 
						 
						
							
							
								
								Remove a bunch more SparcV9 specific stuff  
							
							... 
							
							
							
							llvm-svn: 28093 
							
						 
						
							2006-05-04 01:15:02 +00:00  
				
					
						
							
							
								 
						
							
								6e663f1c1e 
								
							 
						 
						
							
							
								
								Remove some more V9-specific stuff.  
							
							... 
							
							
							
							llvm-svn: 28092 
							
						 
						
							2006-05-04 00:49:59 +00:00  
				
					
						
							
							
								 
						
							
								9f6639b64d 
								
							 
						 
						
							
							
								
								Remove some more unused stuff from MachineInstr that was leftover from V9.  
							
							... 
							
							
							
							llvm-svn: 28091 
							
						 
						
							2006-05-04 00:44:25 +00:00  
				
					
						
							
							
								 
						
							
								e3a9c70ba0 
								
							 
						 
						
							
							
								
								Change from using MachineRelocation ctors to using static methods  
							
							... 
							
							
							
							in MachineRelocation to create Relocations.
llvm-svn: 28088 
							
						 
						
							2006-05-03 20:30:20 +00:00  
				
					
						
							
							
								 
						
							
								1d8ee1fc80 
								
							 
						 
						
							
							
								
								Suck block address tracking out of targets into the JIT Emitter.  This  
							
							... 
							
							
							
							simplifies the MachineCodeEmitter interface just a little bit and makes
BasicBlocks work like constant pools and jump tables.
llvm-svn: 28082 
							
						 
						
							2006-05-03 17:10:41 +00:00  
				
					
						
							
							
								 
						
							
								20a631fde7 
								
							 
						 
						
							
							
								
								Refactor TargetMachine, pushing handling of TargetData into the target-specific subclasses.  This has one caller-visible change: getTargetData() now returns a pointer instead of a reference.  
							
							... 
							
							
							
							This fixes PR 759.
llvm-svn: 28074 
							
						 
						
							2006-05-03 01:29:57 +00:00  
				
					
						
							
							
								 
						
							
								0267807ddc 
								
							 
						 
						
							
							
								
								Keep the alpha JIT similar to the PPC/X86 jits  
							
							... 
							
							
							
							llvm-svn: 28068 
							
						 
						
							2006-05-03 00:31:21 +00:00  
				
					
						
							
							
								 
						
							
								b8065a9a3a 
								
							 
						 
						
							
							
								
								Several related changes:  
							
							... 
							
							
							
							1. Change several methods in the MachineCodeEmitter class to be pure virtual.
2. Suck emitConstantPool/initJumpTableInfo into startFunction, removing them
   from the MachineCodeEmitter interface, and reducing the amount of target-
   specific code.
3. Change the JITEmitter so that it allocates constantpools and jump tables
   *right* next to the functions that they belong to, instead of in a separate
   pool of memory.  This makes all memory for a function be contiguous, and
   means the JITEmitter only tracks one block of memory now.
llvm-svn: 28065 
							
						 
						
							2006-05-02 23:22:24 +00:00  
				
					
						
							
							
								 
						
							
								e1c96369e2 
								
							 
						 
						
							
							
								
								Fix a purely hypothetical problem (for now): emitWord emits in the host  
							
							... 
							
							
							
							byte format.  This doesn't work when using the code emitter in a cross target
environment.  Since the code emitter is only really used by the JIT, this
isn't a current problem, but if we ever start emitting .o files, it would be.
llvm-svn: 28060 
							
						 
						
							2006-05-02 19:14:47 +00:00  
				
					
						
							
							
								 
						
							
								c9aa3715e8 
								
							 
						 
						
							
							
								
								Refactor the machine code emitter interface to pull the pointers for the current  
							
							... 
							
							
							
							code emission location into the base class, instead of being in the derived classes.
This change means that low-level methods like emitByte/emitWord now are no longer
virtual (yaay for speed), and we now have a framework to support growable code
segments.  This implements feature request #1  of PR469.
llvm-svn: 28059 
							
						 
						
							2006-05-02 18:27:26 +00:00  
				
					
						
							
							
								 
						
							
								b9d4f8324d 
								
							 
						 
						
							
							
								
								Extend printBasicBlockLabel a bit so that it can be used to print all  
							
							... 
							
							
							
							basic block labels, consolidating the code to do so in one place for each
target.
llvm-svn: 28050 
							
						 
						
							2006-05-02 05:37:32 +00:00  
				
					
						
							
							
								 
						
							
								4ca2ea5b43 
								
							 
						 
						
							
							
								
								JumpTable support!  What this represents is working asm and jit support for  
							
							... 
							
							
							
							x86 and ppc for 100% dense switch statements when relocations are non-PIC.
This support will be extended and enhanced in the coming days to support
PIC, and less dense forms of jump tables.
llvm-svn: 27947 
							
						 
						
							2006-04-22 18:53:45 +00:00  
				
					
						
							
							
								 
						
							
								3f9c17906f 
								
							 
						 
						
							
							
								
								Disable switch lowering for targets based on the selection dag isel,  
							
							... 
							
							
							
							letting the code generator handle them directly.
llvm-svn: 27539 
							
						 
						
							2006-04-08 19:46:55 +00:00  
				
					
						
							
							
								 
						
							
								cf905223c5 
								
							 
						 
						
							
							
								
								Initialize SDOperand values because the gcc 4.0.2 compiler complains about  
							
							... 
							
							
							
							them.
llvm-svn: 27534 
							
						 
						
							2006-04-08 05:38:03 +00:00  
				
					
						
							
							
								 
						
							
								2d7298c362 
								
							 
						 
						
							
							
								
								Foundation for call frame information.  
							
							... 
							
							
							
							llvm-svn: 27491 
							
						 
						
							2006-04-07 16:34:46 +00:00  
				
					
						
							
							
								 
						
							
								1596a1b276 
								
							 
						 
						
							
							
								
								This may be overconservative, but it lets the new cfe compile  
							
							... 
							
							
							
							llvm-svn: 27471 
							
						 
						
							2006-04-06 23:18:45 +00:00  
				
					
						
							
							
								 
						
							
								cee782d514 
								
							 
						 
						
							
							
								
								fix some linking problems with the new gcc  
							
							... 
							
							
							
							llvm-svn: 27460 
							
						 
						
							2006-04-06 21:26:32 +00:00  
				
					
						
							
							
								 
						
							
								df7abf8b74 
								
							 
						 
						
							
							
								
								support x * (c1 + c2) where c1 and c2 are pow2s.  special case for c2 == 4  
							
							... 
							
							
							
							llvm-svn: 27370 
							
						 
						
							2006-04-03 04:19:17 +00:00  
				
					
						
							
							
								 
						
							
								4e2c073a33 
								
							 
						 
						
							
							
								
								mul by const conversion sequences.  more coming soon  
							
							... 
							
							
							
							llvm-svn: 27368 
							
						 
						
							2006-04-03 03:18:59 +00:00  
				
					
						
							
							
								 
						
							
								444bdb069a 
								
							 
						 
						
							
							
								
								This makes McCat/12-IOtest go 8x faster or so  
							
							... 
							
							
							
							llvm-svn: 27363 
							
						 
						
							2006-04-02 21:08:39 +00:00  
				
					
						
							
							
								 
						
							
								01bd5523a3 
								
							 
						 
						
							
							
								
								This will be needed soon  
							
							... 
							
							
							
							llvm-svn: 27362 
							
						 
						
							2006-04-02 20:13:57 +00:00  
				
					
						
							
							
								 
						
							
								d1aa1638c6 
								
							 
						 
						
							
							
								
								Expose base register for DwarfWriter.  Refactor code accordingly.  
							
							... 
							
							
							
							llvm-svn: 27225 
							
						 
						
							2006-03-28 13:48:33 +00:00  
				
					
						
							
							
								 
						
							
								fa53b276d0 
								
							 
						 
						
							
							
								
								Translate llvm target registers to dwarf register numbers properly.  
							
							... 
							
							
							
							llvm-svn: 27180 
							
						 
						
							2006-03-27 20:18:45 +00:00  
				
					
						
							
							
								 
						
							
								5d70a7c4a5 
								
							 
						 
						
							
							
								
								#include Intrinsics.h into all dag isels  
							
							... 
							
							
							
							llvm-svn: 27109 
							
						 
						
							2006-03-25 06:47:10 +00:00  
				
					
						
							
							
								 
						
							
								f0729b4067 
								
							 
						 
						
							
							
								
								Add dwarf register numbering to register data.  
							
							... 
							
							
							
							llvm-svn: 27081 
							
						 
						
							2006-03-24 21:15:58 +00:00  
				
					
						
							
							
								 
						
							
								3c43609f1f 
								
							 
						 
						
							
							
								
								Add support to locate local variables in frames (early version.)  
							
							... 
							
							
							
							llvm-svn: 26994 
							
						 
						
							2006-03-23 18:12:57 +00:00  
				
					
						
							
							
								 
						
							
								6f95ab7abb 
								
							 
						 
						
							
							
								
								Eliminate IntrinsicLowering from TargetMachine.  
							
							... 
							
							
							
							Make the CBE and V9 backends create their own, since they're the only ones that use it.
llvm-svn: 26974 
							
						 
						
							2006-03-23 05:43:16 +00:00  
				
					
						
							
							
								 
						
							
								bb01d4f272 
								
							 
						 
						
							
							
								
								Remove BRTWOWAY*  
							
							... 
							
							
							
							Make the PPC backend not dependent on BRTWOWAY_CC and make the branch
selector smarter about the code it generates, fixing a case in the
readme.
llvm-svn: 26814 
							
						 
						
							2006-03-17 01:40:33 +00:00  
				
					
						
							
							
								 
						
							
								43e569c95f 
								
							 
						 
						
							
							
								
								these are copies too  
							
							... 
							
							
							
							llvm-svn: 26653 
							
						 
						
							2006-03-09 18:18:51 +00:00  
				
					
						
							
							
								 
						
							
								7e7dccd3ab 
								
							 
						 
						
							
							
								
								remove some now-dead code  
							
							... 
							
							
							
							llvm-svn: 26652 
							
						 
						
							2006-03-09 18:07:49 +00:00  
				
					
						
							
							
								 
						
							
								70236fc12f 
								
							 
						 
						
							
							
								
								fcopysign for mixed mode  
							
							... 
							
							
							
							llvm-svn: 26651 
							
						 
						
							2006-03-09 17:56:33 +00:00  
				
					
						
							
							
								 
						
							
								4a87e7d9a3 
								
							 
						 
						
							
							
								
								alpha and llvm have different oppinions on which arg is the sign bit  
							
							... 
							
							
							
							llvm-svn: 26647 
							
						 
						
							2006-03-09 17:41:50 +00:00  
				
					
						
							
							
								 
						
							
								16b96d2cb4 
								
							 
						 
						
							
							
								
								Alpha Scheduling classes  
							
							... 
							
							
							
							llvm-svn: 26643 
							
						 
						
							2006-03-09 17:16:45 +00:00  
				
					
						
							
							
								 
						
							
								ed7a293b44 
								
							 
						 
						
							
							
								
								fcopysign and get rid of dsnode cruft.  custom PA runtimes make this better in some senses  
							
							... 
							
							
							
							llvm-svn: 26641 
							
						 
						
							2006-03-09 14:58:25 +00:00  
				
					
						
							
							
								 
						
							
								e363fdf318 
								
							 
						 
						
							
							
								
								Add support for 'special' llvm globals like debug info and static ctors/dtors.  
							
							... 
							
							
							
							llvm-svn: 26628 
							
						 
						
							2006-03-09 06:14:35 +00:00  
				
					
						
							
							
								 
						
							
								9c7f50376a 
								
							 
						 
						
							
							
								
								Copysign needs to be expanded everywhere.  Note that Alpha and IA64 should  
							
							... 
							
							
							
							implement copysign as a native op if they have it.
llvm-svn: 26541 
							
						 
						
							2006-03-05 05:08:37 +00:00  
				
					
						
							
							
								 
						
							
								8f2c1021b4 
								
							 
						 
						
							
							
								
								Removed dependency on how operands are printed (want multi-line.)  
							
							... 
							
							
							
							llvm-svn: 26399 
							
						 
						
							2006-02-27 10:29:04 +00:00  
				
					
						
							
							
								 
						
							
								a438ef0ee7 
								
							 
						 
						
							
							
								
								improved zap discovery  
							
							... 
							
							
							
							llvm-svn: 26148 
							
						 
						
							2006-02-13 18:52:29 +00:00  
				
					
						
							
							
								 
						
							
								62c3484e43 
								
							 
						 
						
							
							
								
								Switch targets over to using SelectionDAG::getCALLSEQ_START to create  
							
							... 
							
							
							
							CALLSEQ_START nodes.
llvm-svn: 26143 
							
						 
						
							2006-02-13 09:00:43 +00:00  
				
					
						
							
							
								 
						
							
								d1b82d8db0 
								
							 
						 
						
							
							
								
								Match getTargetNode() changes (now return SDNode* instead of SDOperand).  
							
							... 
							
							
							
							llvm-svn: 26085 
							
						 
						
							2006-02-09 07:17:49 +00:00  
				
					
						
							
							
								 
						
							
								6dc90ca172 
								
							 
						 
						
							
							
								
								Change Select() from  
							
							... 
							
							
							
							SDOperand Select(SDOperand N);
to
void Select(SDOperand &Result, SDOperand N);
llvm-svn: 26067 
							
						 
						
							2006-02-09 00:37:58 +00:00  
				
					
						
							
							
								 
						
							
								f5b7f16259 
								
							 
						 
						
							
							
								
								see what this allignment thing will do  
							
							... 
							
							
							
							llvm-svn: 26017 
							
						 
						
							2006-02-06 17:15:17 +00:00  
				
					
						
							
							
								 
						
							
								54cb1833a4 
								
							 
						 
						
							
							
								
								Use SelectRoot() as entry of any tblgen based isel.  
							
							... 
							
							
							
							llvm-svn: 25997 
							
						 
						
							2006-02-05 06:46:41 +00:00  
				
					
						
							
							
								 
						
							
								1fcff15f86 
								
							 
						 
						
							
							
								
								linkage fix for weak functions  
							
							... 
							
							
							
							llvm-svn: 25976 
							
						 
						
							2006-02-04 19:13:09 +00:00  
				
					
						
							
							
								 
						
							
								1318240fd0 
								
							 
						 
						
							
							
								
								isStoreToStackSlot  
							
							... 
							
							
							
							llvm-svn: 25925 
							
						 
						
							2006-02-03 03:07:37 +00:00  
				
					
						
							
							
								 
						
							
								bb53acd03c 
								
							 
						 
						
							
							
								
								Move isLoadFrom/StoreToStackSlot from MRegisterInfo to TargetInstrInfo,a far more logical place.  Other methods should also be moved if anyoneis interested. :)  
							
							... 
							
							
							
							llvm-svn: 25913 
							
						 
						
							2006-02-02 20:12:32 +00:00  
				
					
						
							
							
								 
						
							
								4b1c726fbb 
								
							 
						 
						
							
							
								
								Add immediate forms of cmov and remove some cruft  
							
							... 
							
							
							
							llvm-svn: 25882 
							
						 
						
							2006-02-01 19:37:33 +00:00  
				
					
						
							
							
								 
						
							
								7e7f439f85 
								
							 
						 
						
							
							
								
								Fix some of the stuff in the PPC README file, and clean up legalization  
							
							... 
							
							
							
							of the SELECT_CC, BR_CC, and BRTWOWAY_CC nodes.
llvm-svn: 25875 
							
						 
						
							2006-02-01 07:19:44 +00:00  
				
					
						
							
							
								 
						
							
								32be2dc0af 
								
							 
						 
						
							
							
								
								Allow the specification of explicit alignments for constant pool entries.  
							
							... 
							
							
							
							llvm-svn: 25855 
							
						 
						
							2006-01-31 22:23:14 +00:00  
				
					
						
							
							
								 
						
							
								b5f0ba6051 
								
							 
						 
						
							
							
								
								Update alpha to reflect recent constantfp legalize changes.  It's not clear  
							
							... 
							
							
							
							why all this code isn't autogenerated. :(
llvm-svn: 25770 
							
						 
						
							2006-01-29 06:25:22 +00:00  
				
					
						
							
							
								 
						
							
								1b09c6ba87 
								
							 
						 
						
							
							
								
								cmovle != cmovlt  
							
							... 
							
							
							
							llvm-svn: 25761 
							
						 
						
							2006-01-29 03:47:30 +00:00  
				
					
						
							
							
								 
						
							
								595ec734fc 
								
							 
						 
						
							
							
								
								Implement Promote for VAARG, and allow it to be custom promoted for people  
							
							... 
							
							
							
							who don't want the default behavior (Alpha).
llvm-svn: 25726 
							
						 
						
							2006-01-28 03:14:31 +00:00  
				
					
						
							
							
								 
						
							
								2c00db82bd 
								
							 
						 
						
							
							
								
								Switch to AlphaISD::CALL instead of ISD::CALL  
							
							... 
							
							
							
							llvm-svn: 25718 
							
						 
						
							2006-01-27 23:39:00 +00:00  
				
					
						
							
							
								 
						
							
								d98701c639 
								
							 
						 
						
							
							
								
								Subtarget feature can now set any variable to any value  
							
							... 
							
							
							
							llvm-svn: 25678 
							
						 
						
							2006-01-27 08:09:42 +00:00  
				
					
						
							
							
								 
						
							
								1240574609 
								
							 
						 
						
							
							
								
								PHI and INLINEASM are now built-in instructions provided by Target.td  
							
							... 
							
							
							
							llvm-svn: 25674 
							
						 
						
							2006-01-27 01:46:15 +00:00  
				
					
						
							
							
								 
						
							
								0a01374299 
								
							 
						 
						
							
							
								
								minor renaming  
							
							... 
							
							
							
							llvm-svn: 25640 
							
						 
						
							2006-01-26 03:24:15 +00:00  
				
					
						
							
							
								 
						
							
								153f808f53 
								
							 
						 
						
							
							
								
								allow R28 to be used for frame calculations without entirely removing it from circulation  
							
							... 
							
							
							
							llvm-svn: 25639 
							
						 
						
							2006-01-26 03:22:07 +00:00  
				
					
						
							
							
								 
						
							
								5c3dd5fafd 
								
							 
						 
						
							
							
								
								oops  
							
							... 
							
							
							
							llvm-svn: 25623 
							
						 
						
							2006-01-25 23:33:32 +00:00  
				
					
						
							
							
								 
						
							
								a852660e74 
								
							 
						 
						
							
							
								
								forgot one  
							
							... 
							
							
							
							llvm-svn: 25620 
							
						 
						
							2006-01-25 22:28:07 +00:00  
				
					
						
							
							
								 
						
							
								93fd315292 
								
							 
						 
						
							
							
								
								make things compile again  
							
							... 
							
							
							
							llvm-svn: 25614 
							
						 
						
							2006-01-25 21:54:38 +00:00  
				
					
						
							
							
								 
						
							
								e74795cd70 
								
							 
						 
						
							
							
								
								First part of bug 680:  
							
							... 
							
							
							
							Remove TLI.LowerVA* and replace it with SDNodes that are lowered the same
way as everything else.
llvm-svn: 25606 
							
						 
						
							2006-01-25 18:21:52 +00:00  
				
					
						
							
							
								 
						
							
								94150f0666 
								
							 
						 
						
							
							
								
								maintaining stackpointer alignment.  Perhaps it doesn't matter  
							
							... 
							
							
							
							llvm-svn: 25592 
							
						 
						
							2006-01-25 01:51:08 +00:00  
				
					
						
							
							
								 
						
							
								c0bf377f98 
								
							 
						 
						
							
							
								
								bye bye Pattern ISEL  
							
							... 
							
							
							
							llvm-svn: 25553 
							
						 
						
							2006-01-23 21:56:07 +00:00  
				
					
						
							
							
								 
						
							
								fef7dec9cc 
								
							 
						 
						
							
							
								
								added stores to lsmark  
							
							... 
							
							
							
							llvm-svn: 25552 
							
						 
						
							2006-01-23 21:51:33 +00:00  
				
					
						
							
							
								 
						
							
								208bbe9ca9 
								
							 
						 
						
							
							
								
								fix up more lsmark stuff  
							
							... 
							
							
							
							llvm-svn: 25550 
							
						 
						
							2006-01-23 21:23:26 +00:00  
				
					
						
							
							
								 
						
							
								ba97ea52d4 
								
							 
						 
						
							
							
								
								yea, lowering this stuff will basically work  
							
							... 
							
							
							
							llvm-svn: 25549 
							
						 
						
							2006-01-23 20:59:50 +00:00  
				
					
						
							
							
								 
						
							
								de02d7727f 
								
							 
						 
						
							
							
								
								Add explicit #includes of <iostream>  
							
							... 
							
							
							
							llvm-svn: 25515 
							
						 
						
							2006-01-22 23:41:00 +00:00  
				
					
						
							
							
								 
						
							
								5df67bcd50 
								
							 
						 
						
							
							
								
								typo  
							
							... 
							
							
							
							llvm-svn: 25464 
							
						 
						
							2006-01-19 21:10:38 +00:00  
				
					
						
							
							
								 
						
							
								688ea707d8 
								
							 
						 
						
							
							
								
								nasty nasty patterns  
							
							... 
							
							
							
							llvm-svn: 25463 
							
						 
						
							2006-01-19 20:49:37 +00:00  
				
					
						
							
							
								 
						
							
								cfd9c6e526 
								
							 
						 
						
							
							
								
								fix short immediate loads  
							
							... 
							
							
							
							llvm-svn: 25371 
							
						 
						
							2006-01-16 21:41:39 +00:00  
				
					
						
							
							
								 
						
							
								34380b7675 
								
							 
						 
						
							
							
								
								stack and rpcc  
							
							... 
							
							
							
							llvm-svn: 25369 
							
						 
						
							2006-01-16 21:22:38 +00:00  
				
					
						
							
							
								 
						
							
								81b108c54d 
								
							 
						 
						
							
							
								
								Friendly names  
							
							... 
							
							
							
							llvm-svn: 25364 
							
						 
						
							2006-01-16 19:53:25 +00:00  
				
					
						
							
							
								 
						
							
								2fba8a3aaa 
								
							 
						 
						
							
							
								
								bswap implementation  
							
							... 
							
							
							
							llvm-svn: 25312 
							
						 
						
							2006-01-14 03:14:10 +00:00  
				
					
						
							
							
								 
						
							
								045371a744 
								
							 
						 
						
							
							
								
								make DAG isel the default  
							
							... 
							
							
							
							llvm-svn: 25282 
							
						 
						
							2006-01-13 18:49:47 +00:00  
				
					
						
							
							
								 
						
							
								8e2f52e645 
								
							 
						 
						
							
							
								
								expand unsupported stacksave/stackrestore nodes  
							
							... 
							
							
							
							llvm-svn: 25272 
							
						 
						
							2006-01-13 02:42:53 +00:00  
				
					
						
							
							
								 
						
							
								1b8121b227 
								
							 
						 
						
							
							
								
								Add bswap, rotl, and rotr nodes  
							
							... 
							
							
							
							Add dag combiner code to recognize rotl, rotr
Add ppc code to match rotl
Targets should add rotl/rotr patterns if they have them
llvm-svn: 25222 
							
						 
						
							2006-01-11 21:21:00 +00:00  
				
					
						
							
							
								 
						
							
								91eda00a7a 
								
							 
						 
						
							
							
								
								this pattern was bogus  
							
							... 
							
							
							
							llvm-svn: 25197 
							
						 
						
							2006-01-11 03:33:06 +00:00  
				
					
						
							
							
								 
						
							
								599e73f21c 
								
							 
						 
						
							
							
								
								Int immediate loading fix  
							
							... 
							
							
							
							llvm-svn: 25182 
							
						 
						
							2006-01-10 19:12:47 +00:00  
				
					
						
							
							
								 
						
							
								32e7d1ed4a 
								
							 
						 
						
							
							
								
								proper branch not equal sequence  
							
							... 
							
							
							
							llvm-svn: 25159 
							
						 
						
							2006-01-09 19:49:58 +00:00  
				
					
						
							
							
								 
						
							
								346b4120af 
								
							 
						 
						
							
							
								
								make 0 codegen much better  
							
							... 
							
							
							
							llvm-svn: 25131 
							
						 
						
							2006-01-06 19:41:51 +00:00  
				
					
						
							
							
								 
						
							
								da56ae98a9 
								
							 
						 
						
							
							
								
								unbreak the build, these are now in TargetSelectionDAG.td  
							
							... 
							
							
							
							llvm-svn: 25109 
							
						 
						
							2006-01-05 04:48:15 +00:00  
				
					
						
							
							
								 
						
							
								deeafa0f00 
								
							 
						 
						
							
							
								
								Had expand logic backward.  
							
							... 
							
							
							
							llvm-svn: 25105 
							
						 
						
							2006-01-05 01:47:43 +00:00  
				
					
						
							
							
								 
						
							
								762e9ec06c 
								
							 
						 
						
							
							
								
								Added initial support for DEBUG_LABEL allowing debug specific labels to be  
							
							... 
							
							
							
							inserted in the code.
llvm-svn: 25104 
							
						 
						
							2006-01-05 01:25:28 +00:00  
				
					
						
							
							
								 
						
							
								eaf5ed1438 
								
							 
						 
						
							
							
								
								typeo  
							
							... 
							
							
							
							llvm-svn: 25060 
							
						 
						
							2006-01-02 21:15:53 +00:00  
				
					
						
							
							
								 
						
							
								38e0b281da 
								
							 
						 
						
							
							
								
								Remove a 'using namespace std'.  
							
							... 
							
							
							
							llvm-svn: 25059 
							
						 
						
							2006-01-01 22:20:31 +00:00  
				
					
						
							
							
								 
						
							
								6bec63aac9 
								
							 
						 
						
							
							
								
								Move brcond over and fix some imm patterns.  This may be the last change before changing the default alpha isel.  
							
							... 
							
							
							
							llvm-svn: 25057 
							
						 
						
							2006-01-01 22:16:14 +00:00  
				
					
						
							
							
								 
						
							
								f0545f7c48 
								
							 
						 
						
							
							
								
								clean this function up some  
							
							... 
							
							
							
							llvm-svn: 25055 
							
						 
						
							2006-01-01 22:13:54 +00:00  
				
					
						
							
							
								 
						
							
								60ab61fcfc 
								
							 
						 
						
							
							
								
								improve constant loading.  Still sucks, but oh well  
							
							... 
							
							
							
							llvm-svn: 25047 
							
						 
						
							2005-12-30 02:30:02 +00:00  
				
					
						
							
							
								 
						
							
								50d9caf6a4 
								
							 
						 
						
							
							
								
								let us get some do what I meant not what I said stuff checked in.  You would think the alpha backend would be 64bit clean  
							
							... 
							
							
							
							llvm-svn: 25040 
							
						 
						
							2005-12-29 01:06:12 +00:00  
				
					
						
							
							
								 
						
							
								34e4782c95 
								
							 
						 
						
							
							
								
								Fix up immediate handling  
							
							... 
							
							
							
							llvm-svn: 25039 
							
						 
						
							2005-12-29 00:50:08 +00:00  
				
					
						
							
							
								 
						
							
								5bd1c2783b 
								
							 
						 
						
							
							
								
								Restore some happiness to the JIT  
							
							... 
							
							
							
							llvm-svn: 25026 
							
						 
						
							2005-12-27 06:25:50 +00:00  
				
					
						
							
							
								 
						
							
								962dcbd572 
								
							 
						 
						
							
							
								
								Fix alpha regressions.  
							
							... 
							
							
							
							llvm-svn: 25025 
							
						 
						
							2005-12-27 03:53:58 +00:00  
				
					
						
							
							
								 
						
							
								14c53b45f5 
								
							 
						 
						
							
							
								
								Added field noResults to Instruction.  
							
							... 
							
							
							
							Currently tblgen cannot tell which operands in the operand list are results so
it assumes the first one is a result. This is bad. Ideally we would fix this
by separating results from inputs, e.g. (res R32:$dst),
(ops R32:$src1, R32:$src2). But that's a more distruptive change. Adding
'let noResults = 1' is the workaround to tell tblgen that the instruction does
not produces a result. It works for now since tblgen does not support
instructions which produce multiple results.
llvm-svn: 25017 
							
						 
						
							2005-12-26 09:11:45 +00:00  
				
					
						
							
							
								 
						
							
								f520093eb3 
								
							 
						 
						
							
							
								
								add br pattern, unify JSR and BSR ISel instrs, and add BSR support for DAG  
							
							... 
							
							
							
							llvm-svn: 25011 
							
						 
						
							2005-12-25 17:36:48 +00:00  
				
					
						
							
							
								 
						
							
								0fce613eff 
								
							 
						 
						
							
							
								
								All that just to lower div and rem  
							
							... 
							
							
							
							llvm-svn: 25008 
							
						 
						
							2005-12-25 01:34:27 +00:00  
				
					
						
							
							
								 
						
							
								5b18ed9e60 
								
							 
						 
						
							
							
								
								All addressing modes are now exposed.  The only remaining relocated forms  
							
							... 
							
							
							
							are for function prologue.
TODO: move external symbols over to using RelLit.
    : have a pattern that matches constpool|globaladdr
    : have a pattern that matches (add x imm) -> x, imm or (...) -> ..., 0
llvm-svn: 25003 
							
						 
						
							2005-12-24 08:29:32 +00:00  
				
					
						
							
							
								 
						
							
								b9aaea3564 
								
							 
						 
						
							
							
								
								Unify the patterns for loads and stores.  Now offset addressing should be  
							
							... 
							
							
							
							supported.  This almost completes memory operations.
llvm-svn: 25002 
							
						 
						
							2005-12-24 07:34:33 +00:00  
				
					
						
							
							
								 
						
							
								4621488965 
								
							 
						 
						
							
							
								
								Let's see if we can break things.  
							
							... 
							
							
							
							Lower GOT relative addresses to Lo and HI.
Update both ISels to select them when they can.
Saves instructions here and there.
llvm-svn: 25001 
							
						 
						
							2005-12-24 05:36:33 +00:00  
				
					
						
							
							
								 
						
							
								636e1aed43 
								
							 
						 
						
							
							
								
								move loads and stores over.  Smart addr selection comming  
							
							... 
							
							
							
							llvm-svn: 25000 
							
						 
						
							2005-12-24 03:41:56 +00:00  
				
					
						
							
							
								 
						
							
								177d7af5d5 
								
							 
						 
						
							
							
								
								remove dead code  
							
							... 
							
							
							
							llvm-svn: 24965 
							
						 
						
							2005-12-22 21:16:08 +00:00  
				
					
						
							
							
								 
						
							
								9e296bee9a 
								
							 
						 
						
							
							
								
								Disengage DEBUG_LOC from non-PPC targets.  
							
							... 
							
							
							
							llvm-svn: 24919 
							
						 
						
							2005-12-21 20:51:37 +00:00  
				
					
						
							
							
								 
						
							
								cd54254af3 
								
							 
						 
						
							
							
								
								fix FP selects  
							
							... 
							
							
							
							llvm-svn: 24672 
							
						 
						
							2005-12-12 20:30:09 +00:00  
				
					
						
							
							
								 
						
							
								b8296181e0 
								
							 
						 
						
							
							
								
								restore a more restricted select  
							
							... 
							
							
							
							llvm-svn: 24668 
							
						 
						
							2005-12-12 17:43:52 +00:00  
				
					
						
							
							
								 
						
							
								20d0b81c04 
								
							 
						 
						
							
							
								
								FP select improvements (and likely breakage), oh and crazy people might want to *return* floating point values.  Don't see why myself  
							
							... 
							
							
							
							llvm-svn: 24658 
							
						 
						
							2005-12-11 03:54:31 +00:00  
				
					
						
							
							
								 
						
							
								87bf2234b5 
								
							 
						 
						
							
							
								
								it helps if your conditionals are not reversed  
							
							... 
							
							
							
							llvm-svn: 24641 
							
						 
						
							2005-12-09 00:45:42 +00:00  
				
					
						
							
							
								 
						
							
								26473b6b58 
								
							 
						 
						
							
							
								
								fix divide and remainder  
							
							... 
							
							
							
							llvm-svn: 24628 
							
						 
						
							2005-12-06 23:27:39 +00:00  
				
					
						
							
							
								 
						
							
								973cd1c845 
								
							 
						 
						
							
							
								
								more decent branches for FP.  I might have to make some intermediate nodes to actually be able to use the DAG for FPcmp  
							
							... 
							
							
							
							llvm-svn: 24625 
							
						 
						
							2005-12-06 20:43:30 +00:00  
				
					
						
							
							
								 
						
							
								29b7ef0065 
								
							 
						 
						
							
							
								
								OK, this does wonders for broken stuff  
							
							... 
							
							
							
							llvm-svn: 24624 
							
						 
						
							2005-12-06 20:40:34 +00:00  
				
					
						
							
							
								 
						
							
								e788bbf6ef 
								
							 
						 
						
							
							
								
								added instructions with inverted immediates  
							
							... 
							
							
							
							llvm-svn: 24614 
							
						 
						
							2005-12-06 00:33:53 +00:00  
				
					
						
							
							
								 
						
							
								08c4a775e6 
								
							 
						 
						
							
							
								
								yea, it helps to have your path set right when testing  
							
							... 
							
							
							
							llvm-svn: 24613 
							
						 
						
							2005-12-05 23:41:45 +00:00  
				
					
						
							
							
								 
						
							
								3c7c4d7508 
								
							 
						 
						
							
							
								
								These never trigger, but whatever  
							
							... 
							
							
							
							llvm-svn: 24612 
							
						 
						
							2005-12-05 23:19:44 +00:00  
				
					
						
							
							
								 
						
							
								5bfcd1e63a 
								
							 
						 
						
							
							
								
								move this over to the dag  
							
							... 
							
							
							
							llvm-svn: 24609 
							
						 
						
							2005-12-05 20:50:53 +00:00  
				
					
						
							
							
								 
						
							
								9410433966 
								
							 
						 
						
							
							
								
								fix constant pool loads  
							
							... 
							
							
							
							llvm-svn: 24607 
							
						 
						
							2005-12-05 17:51:02 +00:00  
				
					
						
							
							
								 
						
							
								7bb09912c8 
								
							 
						 
						
							
							
								
								major think-o  
							
							... 
							
							
							
							llvm-svn: 24564 
							
						 
						
							2005-12-01 17:48:51 +00:00  
				
					
						
							
							
								 
						
							
								006bb04f3a 
								
							 
						 
						
							
							
								
								Support multiple ValueTypes per RegisterClass, needed for upcoming vector  
							
							... 
							
							
							
							work.  This change has no effect on generated code.
llvm-svn: 24563 
							
						 
						
							2005-12-01 04:51:06 +00:00  
				
					
						
							
							
								 
						
							
								ce68ef8073 
								
							 
						 
						
							
							
								
								Flags where I think I need them, quick, before the nightly tester starts  
							
							... 
							
							
							
							llvm-svn: 24560 
							
						 
						
							2005-12-01 01:53:10 +00:00  
				
					
						
							
							
								 
						
							
								4b25924d2a 
								
							 
						 
						
							
							
								
								SelectNodeTo now returns its result, we must pay attention to it.  
							
							... 
							
							
							
							llvm-svn: 24552 
							
						 
						
							2005-11-30 23:04:38 +00:00  
				
					
						
							
							
								 
						
							
								6f8c1ace6e 
								
							 
						 
						
							
							
								
								No longer track value types for asm printer operands, and remove them as  
							
							... 
							
							
							
							an argument to every operand printing function.  Requires some slight
tweaks to x86, the only user.
llvm-svn: 24541 
							
						 
						
							2005-11-30 18:54:35 +00:00  
				
					
						
							
							
								 
						
							
								7ffe3affda 
								
							 
						 
						
							
							
								
								remove redundant code  
							
							... 
							
							
							
							llvm-svn: 24538 
							
						 
						
							2005-11-30 17:14:11 +00:00  
				
					
						
							
							
								 
						
							
								ede966e8ee 
								
							 
						 
						
							
							
								
								Make typesafe that which isn't: FCMOVxx  
							
							... 
							
							
							
							llvm-svn: 24536 
							
						 
						
							2005-11-30 17:11:20 +00:00  
				
					
						
							
							
								 
						
							
								873ed82a36 
								
							 
						 
						
							
							
								
								FPSelect and more custom lowering  
							
							... 
							
							
							
							llvm-svn: 24535 
							
						 
						
							2005-11-30 16:10:29 +00:00  
				
					
						
							
							
								 
						
							
								6db615df14 
								
							 
						 
						
							
							
								
								All sorts of stuff.  
							
							... 
							
							
							
							Getting in on the custom lowering thing, yay
evilness with fp setcc, yuck
trivial int select, hmmm
in memory args for functions, yay
DIV and REM, always handy.  They should be custom lowered though.
Lots more stuff compiles now (go go single source!).  Of course, none of it
probably works, but that is what the nightly tester can find out :)
llvm-svn: 24533 
							
						 
						
							2005-11-30 07:19:56 +00:00  
				
					
						
							
							
								 
						
							
								9c415364cf 
								
							 
						 
						
							
							
								
								No targets support line number info yet.  
							
							... 
							
							
							
							llvm-svn: 24513 
							
						 
						
							2005-11-29 06:16:21 +00:00  
				
					
						
							
							
								 
						
							
								d6a0308470 
								
							 
						 
						
							
							
								
								Fix warning, the better way.  Really, this is what this instruction is for, so use it  
							
							... 
							
							
							
							llvm-svn: 24486 
							
						 
						
							2005-11-22 20:59:00 +00:00  
				
					
						
							
							
								 
						
							
								03390557fa 
								
							 
						 
						
							
							
								
								Fix warning  
							
							... 
							
							
							
							llvm-svn: 24485 
							
						 
						
							2005-11-22 20:56:05 +00:00  
				
					
						
							
							
								 
						
							
								0294e33ea4 
								
							 
						 
						
							
							
								
								massive DAGISel patch.  lots and lots more stuff compiles now  
							
							... 
							
							
							
							llvm-svn: 24483 
							
						 
						
							2005-11-22 04:20:06 +00:00  
				
					
						
							
							
								 
						
							
								882b9fa977 
								
							 
						 
						
							
							
								
								Switch to using the generic constant pool emitter impl, use shorter  
							
							... 
							
							
							
							CPI names
llvm-svn: 24466 
							
						 
						
							2005-11-21 08:29:17 +00:00  
				
					
						
							
							
								 
						
							
								99946fb63f 
								
							 
						 
						
							
							
								
								Adjust to capitalized AsmPrinter method names  
							
							... 
							
							
							
							llvm-svn: 24456 
							
						 
						
							2005-11-21 07:51:23 +00:00  
				
					
						
							
							
								 
						
							
								9885c97088 
								
							 
						 
						
							
							
								
								Use PrivateGlobalPrefix for basic blocks  
							
							... 
							
							
							
							llvm-svn: 24451 
							
						 
						
							2005-11-21 07:38:08 +00:00  
				
					
						
							
							
								 
						
							
								a43b832f7f 
								
							 
						 
						
							
							
								
								Switch to the new shared SwitchSection  
							
							... 
							
							
							
							llvm-svn: 24450 
							
						 
						
							2005-11-21 07:30:28 +00:00  
				
					
						
							
							
								 
						
							
								2c0b435ba6 
								
							 
						 
						
							
							
								
								Rename SwitchSection -> switchSection to avoid conflicting with a future  
							
							... 
							
							
							
							change.
llvm-svn: 24443 
							
						 
						
							2005-11-21 06:55:27 +00:00  
				
					
						
							
							
								 
						
							
								8a4995e42a 
								
							 
						 
						
							
							
								
								Start using PrivateGlobalPrefix correctly  
							
							... 
							
							
							
							llvm-svn: 24442 
							
						 
						
							2005-11-21 06:51:52 +00:00  
				
					
						
							
							
								 
						
							
								6bc51c6f34 
								
							 
						 
						
							
							
								
								prevent latent switch creation  
							
							... 
							
							
							
							llvm-svn: 24413 
							
						 
						
							2005-11-18 13:57:03 +00:00  
				
					
						
							
							
								 
						
							
								59eefd4787 
								
							 
						 
						
							
							
								
								who would have thought you would want to write into globals too  
							
							... 
							
							
							
							llvm-svn: 24381 
							
						 
						
							2005-11-16 21:15:53 +00:00  
				
					
						
							
							
								 
						
							
								54c8fcf303 
								
							 
						 
						
							
							
								
								unbreak the build  
							
							... 
							
							
							
							llvm-svn: 24339 
							
						 
						
							2005-11-13 01:45:23 +00:00  
				
					
						
							
							
								 
						
							
								ab72424488 
								
							 
						 
						
							
							
								
								enable LSR by default on alpha  
							
							... 
							
							
							
							llvm-svn: 24337 
							
						 
						
							2005-11-12 19:21:08 +00:00  
				
					
						
							
							
								 
						
							
								2ba45d1ee9 
								
							 
						 
						
							
							
								
								fix more regressions  
							
							... 
							
							
							
							llvm-svn: 24335 
							
						 
						
							2005-11-12 19:06:28 +00:00  
				
					
						
							
							
								 
						
							
								56526ec1a9 
								
							 
						 
						
							
							
								
								fix READCYCLECOUNTER  
							
							... 
							
							
							
							llvm-svn: 24334 
							
						 
						
							2005-11-12 19:04:09 +00:00  
				
					
						
							
							
								 
						
							
								97e8207a05 
								
							 
						 
						
							
							
								
								fix yet more regressions  
							
							... 
							
							
							
							llvm-svn: 24308 
							
						 
						
							2005-11-11 23:08:46 +00:00  
				
					
						
							
							
								 
						
							
								fab772045e 
								
							 
						 
						
							
							
								
								generate chain result  
							
							... 
							
							
							
							llvm-svn: 24307 
							
						 
						
							2005-11-11 23:02:55 +00:00  
				
					
						
							
							
								 
						
							
								5b3b9d7052 
								
							 
						 
						
							
							
								
								Fix a bunch more alpha regressions  
							
							... 
							
							
							
							llvm-svn: 24304 
							
						 
						
							2005-11-11 19:52:25 +00:00  
				
					
						
							
							
								 
						
							
								01aa56397d 
								
							 
						 
						
							
							
								
								continued readcyclecounter support  
							
							... 
							
							
							
							llvm-svn: 24300 
							
						 
						
							2005-11-11 16:47:30 +00:00  
				
					
						
							
							
								 
						
							
								e373163e95 
								
							 
						 
						
							
							
								
								fix a bunch of regressions  
							
							... 
							
							
							
							llvm-svn: 24269 
							
						 
						
							2005-11-10 16:59:55 +00:00  
				
					
						
							
							
								 
						
							
								97a7fcfd2b 
								
							 
						 
						
							
							
								
								whatever.  Intermediate patch to see what breaks.  Seems ok.  
							
							... 
							
							
							
							llvm-svn: 24260 
							
						 
						
							2005-11-09 19:17:08 +00:00  
				
					
						
							
							
								 
						
							
								b28f214033 
								
							 
						 
						
							
							
								
								Add a new option to indicate we want the code generator to emit code quickly,not spending tons of time microoptimizing it.  This is useful for an -O0style of build.  
							
							... 
							
							
							
							llvm-svn: 24233 
							
						 
						
							2005-11-08 02:11:51 +00:00  
				
					
						
							
							
								 
						
							
								5c7d731832 
								
							 
						 
						
							
							
								
								If the module has no t-t and the host is an alpha, default to using the Alpha BE  
							
							... 
							
							
							
							llvm-svn: 24110 
							
						 
						
							2005-10-30 16:44:01 +00:00  
				
					
						
							
							
								 
						
							
								85b184b292 
								
							 
						 
						
							
							
								
								Make -time-passes output prettier  
							
							... 
							
							
							
							llvm-svn: 24096 
							
						 
						
							2005-10-29 16:45:02 +00:00  
				
					
						
							
							
								 
						
							
								381cab36ed 
								
							 
						 
						
							
							
								
								int comparison patterns  
							
							... 
							
							
							
							llvm-svn: 24020 
							
						 
						
							2005-10-26 18:44:45 +00:00  
				
					
						
							
							
								 
						
							
								75eab3ca63 
								
							 
						 
						
							
							
								
								Typo made worse x 2 - take 2.  
							
							... 
							
							
							
							llvm-svn: 24018 
							
						 
						
							2005-10-26 18:07:50 +00:00  
				
					
						
							
							
								 
						
							
								b1f2cedbaa 
								
							 
						 
						
							
							
								
								Typo x 2  
							
							... 
							
							
							
							llvm-svn: 24016 
							
						 
						
							2005-10-26 17:50:22 +00:00  
				
					
						
							
							
								 
						
							
								7ac194560e 
								
							 
						 
						
							
							
								
								Simplify instinfo, set random bits on more fp insts, and fix 1 opcode  
							
							... 
							
							
							
							llvm-svn: 24014 
							
						 
						
							2005-10-26 17:41:46 +00:00  
				
					
						
							
							
								 
						
							
								a2b5235fac 
								
							 
						 
						
							
							
								
								Give full control of subtarget features over to table generated code.  
							
							... 
							
							
							
							llvm-svn: 24013 
							
						 
						
							2005-10-26 17:30:34 +00:00  
				
					
						
							
							
								 
						
							
								53ad110490 
								
							 
						 
						
							
							
								
								Add attribute name and type to SubtargetFeatures.  
							
							... 
							
							
							
							llvm-svn: 24012 
							
						 
						
							2005-10-26 17:28:23 +00:00  
				
					
						
							
							
								 
						
							
								26ee5953f7 
								
							 
						 
						
							
							
								
								The dag isel generator generates this now  
							
							... 
							
							
							
							llvm-svn: 23984 
							
						 
						
							2005-10-25 20:36:10 +00:00  
				
					
						
							
							
								 
						
							
								db4621a5f5 
								
							 
						 
						
							
							
								
								Preparation of supporting scheduling info.  Need to find info based on selected  
							
							... 
							
							
							
							CPU.
llvm-svn: 23974 
							
						 
						
							2005-10-25 15:15:28 +00:00  
				
					
						
							
							
								 
						
							
								03bf3a1763 
								
							 
						 
						
							
							
								
								Simplify this due to changes in the tblgen side  
							
							... 
							
							
							
							llvm-svn: 23908 
							
						 
						
							2005-10-23 22:33:22 +00:00  
				
					
						
							
							
								 
						
							
								766361e8f4 
								
							 
						 
						
							
							
								
								Autogen subtarget information from .td files.  
							
							... 
							
							
							
							llvm-svn: 23904 
							
						 
						
							2005-10-23 22:15:34 +00:00  
				
					
						
							
							
								 
						
							
								4b5921d4d8 
								
							 
						 
						
							
							
								
								Add subtarget feature/processor defns to the .td file  
							
							... 
							
							
							
							llvm-svn: 23903 
							
						 
						
							2005-10-23 22:08:45 +00:00  
				
					
						
							
							
								 
						
							
								c6072af580 
								
							 
						 
						
							
							
								
								Add several things.  
							
							... 
							
							
							
							loads
branches
setcc
working calls
Global address
External addresses
now I can manage malloc calls.
llvm-svn: 23887 
							
						 
						
							2005-10-23 03:43:48 +00:00  
				
					
						
							
							
								 
						
							
								5a990417f8 
								
							 
						 
						
							
							
								
								Well, the Constant matching pattern works.  Can't say much about calls or globals yet.  
							
							... 
							
							
							
							llvm-svn: 23884 
							
						 
						
							2005-10-22 22:06:58 +00:00  
				
					
						
							
							
								 
						
							
								229878b7bc 
								
							 
						 
						
							
							
								
								silence a release mode warning  
							
							... 
							
							
							
							llvm-svn: 23868 
							
						 
						
							2005-10-21 16:01:26 +00:00  
				
					
						
							
							
								 
						
							
								62e9e5462c 
								
							 
						 
						
							
							
								
								Kill some now-dead code.  
							
							... 
							
							
							
							llvm-svn: 23857 
							
						 
						
							2005-10-21 01:52:20 +00:00  
				
					
						
							
							
								 
						
							
								a099c0131e 
								
							 
						 
						
							
							
								
								byte zap not immediate goodness  
							
							... 
							
							
							
							llvm-svn: 23855 
							
						 
						
							2005-10-21 01:24:05 +00:00  
				
					
						
							
							
								 
						
							
								a6a23b5874 
								
							 
						 
						
							
							
								
								Inst cleanup.  As a bonus, operands are in the correct order for cmovs.  Expect new stuff to pass in the JIT tonight  
							
							... 
							
							
							
							llvm-svn: 23852 
							
						 
						
							2005-10-20 23:58:36 +00:00  
				
					
						
							
							
								 
						
							
								d4c0ed74e4 
								
							 
						 
						
							
							
								
								added a few 1 operand form stuff.  Seems to break regalloc on alpha.  sigh  
							
							... 
							
							
							
							llvm-svn: 23849 
							
						 
						
							2005-10-20 19:39:24 +00:00  
				
					
						
							
							
								 
						
							
								eb0ad1863b 
								
							 
						 
						
							
							
								
								Sounds good, finish the intop conversion.  
							
							... 
							
							
							
							llvm-svn: 23843 
							
						 
						
							2005-10-20 14:42:48 +00:00  
				
					
						
							
							
								 
						
							
								fd07fcda67 
								
							 
						 
						
							
							
								
								Add some pattern fragments to simplify the repetitive parts of the patterns  
							
							... 
							
							
							
							for some common ops and use them for a few examples.  Andrew, if you like
this, feel free to convert the rest over, if you hate it, feel free to
revert.
llvm-svn: 23837 
							
						 
						
							2005-10-20 04:21:06 +00:00  
				
					
						
							
							
								 
						
							
								cd4be8798f 
								
							 
						 
						
							
							
								
								simplify this a bit by using immediates  
							
							... 
							
							
							
							llvm-svn: 23836 
							
						 
						
							2005-10-20 03:57:03 +00:00  
				
					
						
							
							
								 
						
							
								794f15868a 
								
							 
						 
						
							
							
								
								forgot this one  
							
							... 
							
							
							
							llvm-svn: 23833 
							
						 
						
							2005-10-20 00:29:02 +00:00  
				
					
						
							
							
								 
						
							
								7b69867052 
								
							 
						 
						
							
							
								
								ret 0; works, not much else  
							
							... 
							
							
							
							still lots of uglyness.
Maybe calls will come soon.
Fixing the return value of things will be necessary to make alpha work.
llvm-svn: 23832 
							
						 
						
							2005-10-20 00:28:31 +00:00  
				
					
						
							
							
								 
						
							
								1dfb85c7af 
								
							 
						 
						
							
							
								
								This seems useful from the original patch that added the function.  If there is a reason it is not useful on a RISC type target, let me know and I will pull it out  
							
							... 
							
							
							
							llvm-svn: 23676 
							
						 
						
							2005-10-09 20:11:35 +00:00  
				
					
						
							
							
								 
						
							
								e4c91fc9e8 
								
							 
						 
						
							
							
								
								This is suppose to work now  
							
							... 
							
							
							
							llvm-svn: 23644 
							
						 
						
							2005-10-06 16:54:29 +00:00  
				
					
						
							
							
								 
						
							
								332df13b9e 
								
							 
						 
						
							
							
								
								remove VAX compatibility instruction, we will never use this  
							
							... 
							
							
							
							llvm-svn: 23643 
							
						 
						
							2005-10-06 16:53:32 +00:00  
				
					
						
							
							
								 
						
							
								98da1d9910 
								
							 
						 
						
							
							
								
								Sort the cpu and features table, so that the alpha backend doesn't fail EVERY  
							
							... 
							
							
							
							compile with an assertion that the tables are not sorted!
llvm-svn: 23591 
							
						 
						
							2005-10-02 07:13:52 +00:00  
				
					
						
							
							
								 
						
							
								49e48f6234 
								
							 
						 
						
							
							
								
								subtarget support for CIX and FIX extentions (the only 2 I care about right now)  
							
							... 
							
							
							
							llvm-svn: 23569 
							
						 
						
							2005-09-30 20:24:38 +00:00  
				
					
						
							
							
								 
						
							
								a654525c1c 
								
							 
						 
						
							
							
								
								Pass extra regclasses into spilling code  
							
							... 
							
							
							
							llvm-svn: 23537 
							
						 
						
							2005-09-30 01:29:42 +00:00  
				
					
						
							
							
								 
						
							
								a7a83b9255 
								
							 
						 
						
							
							
								
								begining alpha subtarget support  
							
							... 
							
							
							
							llvm-svn: 23531 
							
						 
						
							2005-09-29 22:54:56 +00:00  
				
					
						
							
							
								 
						
							
								0815dcae3f 
								
							 
						 
						
							
							
								
								Add FP versions of the binary operators, keeping the int and fp worlds seperate.  
							
							... 
							
							
							
							Though I have done extensive testing, it is possible that this will break
things in configs I can't test.  Please let me know if this causes a problem
and I'll fix it ASAP.
llvm-svn: 23505 
							
						 
						
							2005-09-28 22:29:17 +00:00  
				
					
						
							
							
								 
						
							
								fb96e50b8c 
								
							 
						 
						
							
							
								
								This code is no longer needed, it is moved to the target-indep code  
							
							... 
							
							
							
							llvm-svn: 23332 
							
						 
						
							2005-09-13 19:31:44 +00:00  
				
					
						
							
							
								 
						
							
								64685b4ca2 
								
							 
						 
						
							
							
								
								Majik numbers are bad  
							
							... 
							
							
							
							llvm-svn: 23330 
							
						 
						
							2005-09-13 19:03:13 +00:00  
				
					
						
							
							
								 
						
							
								7c8dba750c 
								
							 
						 
						
							
							
								
								ignore generated files  
							
							... 
							
							
							
							llvm-svn: 23263 
							
						 
						
							2005-09-07 23:47:44 +00:00  
				
					
						
							
							
								 
						
							
								a63a066205 
								
							 
						 
						
							
							
								
								Fix up the AssertXext problem, as well as adding it at calls  
							
							... 
							
							
							
							llvm-svn: 23246 
							
						 
						
							2005-09-06 17:00:23 +00:00  
				
					
						
							
							
								 
						
							
								c8bd5bda59 
								
							 
						 
						
							
							
								
								revert part of the last change, should fix regressions  
							
							... 
							
							
							
							llvm-svn: 23241 
							
						 
						
							2005-09-04 06:12:19 +00:00  
				
					
						
							
							
								 
						
							
								9690a4f321 
								
							 
						 
						
							
							
								
								Pull out Lowering in preperation for multiple ISels.  Oh, and get rid of some stuff  
							
							... 
							
							
							
							llvm-svn: 23220 
							
						 
						
							2005-09-02 18:46:02 +00:00  
				
					
						
							
							
								 
						
							
								19058c3989 
								
							 
						 
						
							
							
								
								1. Use SubtargetFeatures in llc/lli.  
							
							... 
							
							
							
							2. Propagate feature "string" to all targets.
3. Implement use of SubtargetFeatures in PowerPCTargetSubtarget.
llvm-svn: 23192 
							
						 
						
							2005-09-01 21:38:21 +00:00  
				
					
						
							
							
								 
						
							
								c30405e0ee 
								
							 
						 
						
							
							
								
								Change ConstantPoolSDNode to actually hold the Constant itself instead of  
							
							... 
							
							
							
							putting it into the constant pool.  This allows the isel machinery to
create constants that it will end up deciding are not needed, without them
ending up in the resultant function constant pool.
llvm-svn: 23081 
							
						 
						
							2005-08-26 17:15:30 +00:00  
				
					
						
							
							
								 
						
							
								8975de187f 
								
							 
						 
						
							
							
								
								Put register classes in namespaces  
							
							... 
							
							
							
							llvm-svn: 22924 
							
						 
						
							2005-08-19 18:50:46 +00:00  
				
					
						
							
							
								 
						
							
								0faf0b7313 
								
							 
						 
						
							
							
								
								This code has always been dead for alpha  
							
							... 
							
							
							
							llvm-svn: 22915 
							
						 
						
							2005-08-19 18:33:26 +00:00  
				
					
						
							
							
								 
						
							
								8cbddfc8c5 
								
							 
						 
						
							
							
								
								mark variable arity instructions as such.  Alpha wins the battle for  
							
							... 
							
							
							
							cleanest backend in this metric :)
llvm-svn: 22893 
							
						 
						
							2005-08-19 00:51:37 +00:00  
				
					
						
							
							
								 
						
							
								33900811ee 
								
							 
						 
						
							
							
								
								Fix some bugs in the alpha backend, some of which I introduced yesterday,  
							
							... 
							
							
							
							and some that were preexisting.  All alpha regtests pass now.
llvm-svn: 22829 
							
						 
						
							2005-08-17 17:08:24 +00:00  
				
					
						
							
							
								 
						
							
								73370ba5fd 
								
							 
						 
						
							
							
								
								thinko.  Should fix s4addl.ll regression  
							
							... 
							
							
							
							llvm-svn: 22817 
							
						 
						
							2005-08-17 00:47:24 +00:00  
				
					
						
							
							
								 
						
							
								7c76278242 
								
							 
						 
						
							
							
								
								update the backends to work with the new CopyFromReg/CopyToReg/ImplicitDef nodes  
							
							... 
							
							
							
							llvm-svn: 22807 
							
						 
						
							2005-08-16 21:56:37 +00:00  
				
					
						
							
							
								 
						
							
								371e49515d 
								
							 
						 
						
							
							
								
								Implement BR_CC and BRTWOWAY_CC.  This allows the removal of a rather nasty  
							
							... 
							
							
							
							fixme from the PowerPC backend.  Emit slightly better code for legalizing
select_cc.
llvm-svn: 22805 
							
						 
						
							2005-08-16 19:49:35 +00:00  
				
					
						
							
							
								 
						
							
								b65b1568ae 
								
							 
						 
						
							
							
								
								isIntImmediate is a good Idea.  Add a flavor that checks bounds while it is at it  
							
							... 
							
							
							
							llvm-svn: 22790 
							
						 
						
							2005-08-15 14:31:37 +00:00  
				
					
						
							
							
								 
						
							
								8c6701be6e 
								
							 
						 
						
							
							
								
								match gcc's use of tabs, makes diffs easier  
							
							... 
							
							
							
							llvm-svn: 22764 
							
						 
						
							2005-08-12 16:14:08 +00:00  
				
					
						
							
							
								 
						
							
								ca94102d3e 
								
							 
						 
						
							
							
								
								.section cleanup, patch from Nicholas Riley  
							
							... 
							
							
							
							llvm-svn: 22763 
							
						 
						
							2005-08-12 16:13:43 +00:00  
				
					
						
							
							
								 
						
							
								6ec7745e80 
								
							 
						 
						
							
							
								
								Update the targets to the new SETCC/CondCodeSDNode interfaces.  
							
							... 
							
							
							
							llvm-svn: 22729 
							
						 
						
							2005-08-09 20:21:10 +00:00  
				
					
						
							
							
								 
						
							
								5adb830b30 
								
							 
						 
						
							
							
								
								No, IDEFs shouldn't be JITed  
							
							... 
							
							
							
							llvm-svn: 22648 
							
						 
						
							2005-08-04 15:32:36 +00:00  
				
					
						
							
							
								 
						
							
								3a18a39587 
								
							 
						 
						
							
							
								
								Alpha ABI specifies stack is always 16 byte alligned, and gcc does it, so I will too  
							
							... 
							
							
							
							llvm-svn: 22634 
							
						 
						
							2005-08-03 22:33:21 +00:00  
				
					
						
							
							
								 
						
							
								80e038c148 
								
							 
						 
						
							
							
								
								one more hunk that got dropped  
							
							... 
							
							
							
							llvm-svn: 22596 
							
						 
						
							2005-08-02 19:35:29 +00:00  
				
					
						
							
							
								 
						
							
								6667bdbaca 
								
							 
						 
						
							
							
								
								Update to use the new MathExtras.h support for log2 computation.  
							
							... 
							
							
							
							Patch contributed by Jim Laskey!
llvm-svn: 22594 
							
						 
						
							2005-08-02 19:26:06 +00:00  
				
					
						
							
							
								 
						
							
								ae97fff758 
								
							 
						 
						
							
							
								
								update function codes to reflect /su flags that have been added since this was written  
							
							... 
							
							
							
							llvm-svn: 22571 
							
						 
						
							2005-08-01 20:06:01 +00:00  
				
					
						
							
							
								 
						
							
								33bbf15147 
								
							 
						 
						
							
							
								
								use llabs not abs  
							
							... 
							
							
							
							llvm-svn: 22569 
							
						 
						
							2005-08-01 17:47:28 +00:00  
				
					
						
							
							
								 
						
							
								546fd5944e 
								
							 
						 
						
							
							
								
								Keep tabs and trailing spaces out.  
							
							... 
							
							
							
							llvm-svn: 22565 
							
						 
						
							2005-07-30 18:33:25 +00:00  
				
					
						
							
							
								 
						
							
								1ec48e8683 
								
							 
						 
						
							
							
								
								support bsr, and more .td simplification  
							
							... 
							
							
							
							llvm-svn: 22543 
							
						 
						
							2005-07-28 18:14:47 +00:00  
				
					
						
							
							
								 
						
							
								b57b0baac0 
								
							 
						 
						
							
							
								
								get lazy JITing working.  Some of shootout runs now  
							
							... 
							
							
							
							llvm-svn: 22538 
							
						 
						
							2005-07-28 12:45:20 +00:00  
				
					
						
							
							
								 
						
							
								5f4ef3c5a8 
								
							 
						 
						
							
							
								
								Eliminate all remaining tabs and trailing spaces.  
							
							... 
							
							
							
							llvm-svn: 22523 
							
						 
						
							2005-07-27 06:12:32 +00:00  
				
					
						
							
							
								 
						
							
								a5ec193118 
								
							 
						 
						
							
							
								
								fix some warnings when compiled with 32-bit hosts  
							
							... 
							
							
							
							llvm-svn: 22521 
							
						 
						
							2005-07-27 05:58:01 +00:00  
				
					
						
							
							
								 
						
							
								54b0b62ff0 
								
							 
						 
						
							
							
								
								fix compile error  
							
							... 
							
							
							
							llvm-svn: 22508 
							
						 
						
							2005-07-23 07:46:48 +00:00  
				
					
						
							
							
								 
						
							
								7dec1f3aa6 
								
							 
						 
						
							
							
								
								Handle more imm forms, and load small negative i32 constants without hitting memory (should do the same for arbitrary zero extended small negative constants)  
							
							... 
							
							
							
							llvm-svn: 22505 
							
						 
						
							2005-07-22 22:24:01 +00:00  
				
					
						
							
							
								 
						
							
								c32843ed2b 
								
							 
						 
						
							
							
								
								finally found the gcc defined constants  
							
							... 
							
							
							
							llvm-svn: 22502 
							
						 
						
							2005-07-22 21:00:30 +00:00  
				
					
						
							
							
								 
						
							
								55d045190e 
								
							 
						 
						
							
							
								
								Alpha JIT (beta)  
							
							... 
							
							
							
							llvm-svn: 22500 
							
						 
						
							2005-07-22 20:52:16 +00:00  
				
					
						
							
							
								 
						
							
								02daecc7c6 
								
							 
						 
						
							
							
								
								simpilfy instruction encoding (and make the lines way shorter, aka Misha happification)  
							
							... 
							
							
							
							llvm-svn: 22499 
							
						 
						
							2005-07-22 20:50:29 +00:00  
				
					
						
							
							
								 
						
							
								20b534a4fd 
								
							 
						 
						
							
							
								
								Fix povray and minor cleanups  
							
							... 
							
							
							
							llvm-svn: 22397 
							
						 
						
							2005-07-12 04:20:52 +00:00  
				
					
						
							
							
								 
						
							
								53676dfd33 
								
							 
						 
						
							
							
								
								Change *EXTLOAD to use an VTSDNode operand instead of being an MVTSDNode.  
							
							... 
							
							
							
							This is the last MVTSDNode.
This allows us to eliminate a bunch of special case code for handling
MVTSDNodes.
Also, remove some uses of dyn_cast that should really be cast (which is
cheaper in a release build).
llvm-svn: 22368 
							
						 
						
							2005-07-10 01:56:13 +00:00  
				
					
						
							
							
								 
						
							
								36db1ed06f 
								
							 
						 
						
							
							
								
								Change TRUNCSTORE to use a VTSDNode operand instead of being an MVTSTDNode  
							
							... 
							
							
							
							llvm-svn: 22366 
							
						 
						
							2005-07-10 00:29:18 +00:00  
				
					
						
							
							
								 
						
							
								8d40dcbd18 
								
							 
						 
						
							
							
								
								clean up prolouge and epilouge  
							
							... 
							
							
							
							llvm-svn: 22346 
							
						 
						
							2005-07-07 19:52:58 +00:00  
				
					
						
							
							
								 
						
							
								a7220851c0 
								
							 
						 
						
							
							
								
								Make several cleanups to Andrews varargs change:  
							
							... 
							
							
							
							1. Pass Value*'s into lowering methods so that the proper pointers can be
   added to load/stores from the valist
2. Intrinsics that return void should only return a token chain, not a token
   chain/retval pair.
3. Rename LowerVAArgNext -> LowerVAArg, because VANext is long gone.
4. Now that we have Value*'s available in the lowering methods, pass them
   into any load/stores from the valist that are emitted
llvm-svn: 22339 
							
						 
						
							2005-07-05 19:58:54 +00:00  
				
					
						
							
							
								 
						
							
								26fa89e0a7 
								
							 
						 
						
							
							
								
								check the correct VT  
							
							... 
							
							
							
							llvm-svn: 22332 
							
						 
						
							2005-07-04 20:07:21 +00:00  
				
					
						
							
							
								 
						
							
								da852d51df 
								
							 
						 
						
							
							
								
								fix loading address of fp symbols  
							
							... 
							
							
							
							llvm-svn: 22331 
							
						 
						
							2005-07-03 20:06:13 +00:00  
				
					
						
							
							
								 
						
							
								21da9b669e 
								
							 
						 
						
							
							
								
								simplify call code, remove pseudo ops for div and rem, track more loads and stores  
							
							... 
							
							
							
							llvm-svn: 22323 
							
						 
						
							2005-07-01 19:14:02 +00:00  
				
					
						
							
							
								 
						
							
								dd55b1566b 
								
							 
						 
						
							
							
								
								simplify call code, remove pseudo ops for div and rem, track more loads and stores  
							
							... 
							
							
							
							llvm-svn: 22322 
							
						 
						
							2005-07-01 19:12:13 +00:00  
				
					
						
							
							
								 
						
							
								2edc1881ac 
								
							 
						 
						
							
							
								
								restore old srcValueNode behavior and try to to work around it  
							
							... 
							
							
							
							llvm-svn: 22315 
							
						 
						
							2005-06-29 18:54:02 +00:00  
				
					
						
							
							
								 
						
							
								8192568fbc 
								
							 
						 
						
							
							
								
								tracking the instructions causing loads and stores provides more information than just the pointer being loaded or stored  
							
							... 
							
							
							
							llvm-svn: 22311 
							
						 
						
							2005-06-29 15:57:19 +00:00  
				
					
						
							
							
								 
						
							
								4401049f05 
								
							 
						 
						
							
							
								
								thinko  
							
							... 
							
							
							
							llvm-svn: 22309 
							
						 
						
							2005-06-29 13:35:05 +00:00  
				
					
						
							
							
								 
						
							
								d0a2f0f95a 
								
							 
						 
						
							
							
								
								unify SelectExpr and SelectFP  
							
							... 
							
							
							
							llvm-svn: 22308 
							
						 
						
							2005-06-29 12:49:51 +00:00  
				
					
						
							
							
								 
						
							
								d0f59dedf8 
								
							 
						 
						
							
							
								
								fix most regressions  
							
							... 
							
							
							
							llvm-svn: 22307 
							
						 
						
							2005-06-29 12:23:34 +00:00  
				
					
						
							
							
								 
						
							
								47a9c4715a 
								
							 
						 
						
							
							
								
								support more relocations for stores also  
							
							... 
							
							
							
							llvm-svn: 22306 
							
						 
						
							2005-06-29 00:39:17 +00:00  
				
					
						
							
							
								 
						
							
								1ef3c0c798 
								
							 
						 
						
							
							
								
								Get rid of all symbolic loads.  I now do gernate all relocations sequences  
							
							... 
							
							
							
							rather than relying on the assembler.  Only a few more pseudo instructions
left.  Also merge load code paths.
llvm-svn: 22305 
							
						 
						
							2005-06-29 00:31:08 +00:00  
				
					
						
							
							
								 
						
							
								a50adcf57d 
								
							 
						 
						
							
							
								
								So, it turns out I forgot that one valid way of restoring GP after a call  
							
							... 
							
							
							
							is to use RA, which assumes the called function uses RA for the register
holding the return address when it issues a ret.
llvm-svn: 22301 
							
						 
						
							2005-06-27 23:24:11 +00:00  
				
					
						
							
							
								 
						
							
								595646f934 
								
							 
						 
						
							
							
								
								get rid of another pseudo op  
							
							... 
							
							
							
							llvm-svn: 22299 
							
						 
						
							2005-06-27 21:11:40 +00:00  
				
					
						
							
							
								 
						
							
								1291a85883 
								
							 
						 
						
							
							
								
								generate address of constant pool entries  
							
							... 
							
							
							
							llvm-svn: 22298 
							
						 
						
							2005-06-27 21:02:56 +00:00  
				
					
						
							
							
								 
						
							
								02ffa5a7ed 
								
							 
						 
						
							
							
								
								Misha happification patch  
							
							... 
							
							
							
							llvm-svn: 22297 
							
						 
						
							2005-06-27 17:39:17 +00:00  
				
					
						
							
							
								 
						
							
								7aba58ab89 
								
							 
						 
						
							
							
								
								Reduce use of pseudo ops  
							
							... 
							
							
							
							Namely, output the rellocation flags explicitly when loading constants.
Added benifit: save a load when loading from the constant pool.
llvm-svn: 22296 
							
						 
						
							2005-06-27 17:15:36 +00:00  
				
					
						
							
							
								 
						
							
								fcb112eb7a 
								
							 
						 
						
							
							
								
								missed a load  
							
							... 
							
							
							
							llvm-svn: 22295 
							
						 
						
							2005-06-27 16:40:26 +00:00  
				
					
						
							
							
								 
						
							
								96db51a3b6 
								
							 
						 
						
							
							
								
								make constant pool labels local  
							
							... 
							
							
							
							llvm-svn: 22294 
							
						 
						
							2005-06-27 16:29:54 +00:00  
				
					
						
							
							
								 
						
							
								53bb83bc43 
								
							 
						 
						
							
							
								
								who said we had to use the return address in the return address register.  Might save a move in many cases  
							
							... 
							
							
							
							llvm-svn: 22293 
							
						 
						
							2005-06-27 15:36:48 +00:00  
				
					
						
							
							
								 
						
							
								dac0b3cb8a 
								
							 
						 
						
							
							
								
								depend more on legalize putting constants on the RHS  
							
							... 
							
							
							
							llvm-svn: 22289 
							
						 
						
							2005-06-26 23:01:11 +00:00  
				
					
						
							
							
								 
						
							
								331380b2e2 
								
							 
						 
						
							
							
								
								With setOperationAction(ISD::UINT_TO_FP, MVT::i64, Expand), Legalize  
							
							... 
							
							
							
							should be able to handle this case.  The code is there, so let's see
if it works.
llvm-svn: 22288 
							
						 
						
							2005-06-26 22:23:06 +00:00  
				
					
						
							
							
								 
						
							
								f11f48ba61 
								
							 
						 
						
							
							
								
								Refactor the addPassesToEmitAssembly interface into a addPassesToEmitFile  
							
							... 
							
							
							
							interface.
llvm-svn: 22282 
							
						 
						
							2005-06-25 02:48:37 +00:00  
				
					
						
							
							
								 
						
							
								af1e825112 
								
							 
						 
						
							
							
								
								remove a pseudo instruction, make ret always right, and fix vararg chains  
							
							... 
							
							
							
							llvm-svn: 22276 
							
						 
						
							2005-06-23 23:42:05 +00:00  
				
					
						
							
							
								 
						
							
								01cebcc131 
								
							 
						 
						
							
							
								
								finally, Working varargs  
							
							... 
							
							
							
							llvm-svn: 22275 
							
						 
						
							2005-06-23 16:48:51 +00:00  
				
					
						
							
							
								 
						
							
								a4a12983cc 
								
							 
						 
						
							
							
								
								more complete Lowering for vacopy and vaarg  
							
							... 
							
							
							
							llvm-svn: 22274 
							
						 
						
							2005-06-22 23:04:28 +00:00  
				
					
						
							
							
								 
						
							
								cf9008afea 
								
							 
						 
						
							
							
								
								Make it easier to find alpha stuff in doxygen, and fixup labeling  
							
							... 
							
							
							
							of memory instructions in the assembly, to allow later linking
of traces with LLVM Value*s.
llvm-svn: 22271 
							
						 
						
							2005-06-22 17:19:45 +00:00  
				
					
						
							
							
								 
						
							
								9144ec4764 
								
							 
						 
						
							
							
								
								core changes for varargs  
							
							... 
							
							
							
							llvm-svn: 22254 
							
						 
						
							2005-06-18 18:34:52 +00:00  
				
					
						
							
							
								 
						
							
								c504a3db60 
								
							 
						 
						
							
							
								
								fix BranchCC with a setCC with an arg of 0  
							
							... 
							
							
							
							llvm-svn: 22203 
							
						 
						
							2005-06-08 18:02:21 +00:00  
				
					
						
							
							
								 
						
							
								ddb94f4169 
								
							 
						 
						
							
							
								
								Fix spelling of `correlate'  
							
							... 
							
							
							
							llvm-svn: 22196 
							
						 
						
							2005-06-06 19:08:04 +00:00  
				
					
						
							
							
								 
						
							
								c74fe84456 
								
							 
						 
						
							
							
								
								allow marking of loads and stores in the instruction stream with enough information to reconstruct the Value* if it existed  
							
							... 
							
							
							
							llvm-svn: 22195 
							
						 
						
							2005-06-06 19:03:55 +00:00  
				
					
						
							
							
								 
						
							
								b07a3d7138 
								
							 
						 
						
							
							
								
								hide basic block labels.  The utility of these for debuging is long since passed  
							
							... 
							
							
							
							llvm-svn: 22194 
							
						 
						
							2005-06-06 19:03:09 +00:00  
				
					
						
							
							
								 
						
							
								175df27466 
								
							 
						 
						
							
							
								
								* Replace block of commented-out lines with #if 0  
							
							... 
							
							
							
							* Remove warning "control reaches end of non-void function"
llvm-svn: 22193 
							
						 
						
							2005-06-06 17:39:46 +00:00  
				
					
						
							
							
								 
						
							
								7c0e9285ce 
								
							 
						 
						
							
							
								
								try custom expanders, doesn't seem to expand yet, so disabled  
							
							... 
							
							
							
							llvm-svn: 22188 
							
						 
						
							2005-05-31 19:49:34 +00:00  
				
					
						
							
							
								 
						
							
								41e2981e0a 
								
							 
						 
						
							
							
								
								switch to the new live in thing.  Really, this time it works  
							
							... 
							
							
							
							llvm-svn: 22187 
							
						 
						
							2005-05-31 18:42:18 +00:00  
				
					
						
							
							
								 
						
							
								676e4db6dc 
								
							 
						 
						
							
							
								
								switch to the new live in thing  
							
							... 
							
							
							
							llvm-svn: 22186 
							
						 
						
							2005-05-31 18:37:16 +00:00  
				
					
						
							
							
								 
						
							
								973d85e660 
								
							 
						 
						
							
							
								
								switch to the new live in thing  
							
							... 
							
							
							
							llvm-svn: 22185 
							
						 
						
							2005-05-31 18:35:43 +00:00  
				
					
						
							
							
								 
						
							
								86f856f19c 
								
							 
						 
						
							
							
								
								match gcc, makes diff easier  
							
							... 
							
							
							
							llvm-svn: 22179 
							
						 
						
							2005-05-27 03:39:30 +00:00  
				
					
						
							
							
								 
						
							
								39edea8306 
								
							 
						 
						
							
							
								
								Fix 2005-05-12-Int64ToFP  
							
							... 
							
							
							
							The issue is there is no unsigned -> double conversion, only signed.  So I
need to test the sign and do a different thing depending on it.  Ideally
this should be in a different BB, but in the mean time, I use a branch
free method.
llvm-svn: 22177 
							
						 
						
							2005-05-26 18:18:34 +00:00  
				
					
						
							
							
								 
						
							
								8abab9b0c7 
								
							 
						 
						
							
							
								
								treat TAILCALL nodes identically to CALL nodes  
							
							... 
							
							
							
							llvm-svn: 21977 
							
						 
						
							2005-05-13 20:29:26 +00:00  
				
					
						
							
							
								 
						
							
								2e77db6af6 
								
							 
						 
						
							
							
								
								Add an isTailCall flag to LowerCallTo  
							
							... 
							
							
							
							llvm-svn: 21958 
							
						 
						
							2005-05-13 18:50:42 +00:00  
				
					
						
							
							
								 
						
							
								2dce703710 
								
							 
						 
						
							
							
								
								rename the ADJCALLSTACKDOWN/ADJCALLSTACKUP nodes to be CALLSEQ_START/BEGIN.  
							
							... 
							
							
							
							llvm-svn: 21915 
							
						 
						
							2005-05-12 23:24:06 +00:00  
				
					
						
							
							
								 
						
							
								36674a123e 
								
							 
						 
						
							
							
								
								Pass in Calling Convention to use into LowerCallTo  
							
							... 
							
							
							
							llvm-svn: 21899 
							
						 
						
							2005-05-12 19:56:45 +00:00  
				
					
						
							
							
								 
						
							
								b8e94c3499 
								
							 
						 
						
							
							
								
								fix typo  
							
							... 
							
							
							
							llvm-svn: 21693 
							
						 
						
							2005-05-04 19:25:37 +00:00  
				
					
						
							
							
								 
						
							
								aed06a0e92 
								
							 
						 
						
							
							
								
								Well, add support for ct* for 21264 only.  
							
							... 
							
							
							
							21164 is broken until expand works.
llvm-svn: 21692 
							
						 
						
							2005-05-04 19:12:09 +00:00  
				
					
						
							
							
								 
						
							
								5e177826fd 
								
							 
						 
						
							
							
								
								Implement count leading zeros (ctlz), count trailing zeros (cttz), and count  
							
							... 
							
							
							
							population (ctpop).  Generic lowering is implemented, however only promotion
is implemented for SelectionDAG at the moment.
More coming soon.
llvm-svn: 21676 
							
						 
						
							2005-05-03 17:19:30 +00:00  
				
					
						
							
							
								 
						
							
								537332eba8 
								
							 
						 
						
							
							
								
								I was sure I had thought about this and there was a reason it should work.  
							
							... 
							
							
							
							But it is entirely possible I am just crazy.
llvm-svn: 21640 
							
						 
						
							2005-04-30 14:19:13 +00:00  
				
					
						
							
							
								 
						
							
								c8a6633dea 
								
							 
						 
						
							
							
								
								Eliminate some random whitespace  
							
							... 
							
							
							
							llvm-svn: 21637 
							
						 
						
							2005-04-30 04:44:07 +00:00  
				
					
						
							
							
								 
						
							
								9c6bbafc15 
								
							 
						 
						
							
							
								
								This target doesn't support the FSIN/FCOS/FSQRT nodes yet  
							
							... 
							
							
							
							llvm-svn: 21633 
							
						 
						
							2005-04-30 04:26:06 +00:00  
				
					
						
							
							
								 
						
							
								4a73c2cfdc 
								
							 
						 
						
							
							
								
								Implement Value* tracking for loads and stores in the selection DAG.  This enables one to use alias analysis in the backends.  
							
							... 
							
							
							
							(TRUNK)Stores and (EXT|ZEXT|SEXT)Loads have an extra SDOperand which is a SrcValueSDNode which contains the Value*.  Note that if the operation is introduced by the backend, it will still have the operand, but the value* will be null.
llvm-svn: 21599 
							
						 
						
							2005-04-27 20:10:01 +00:00  
				
					
						
							
							
								 
						
							
								e73e76dc42 
								
							 
						 
						
							
							
								
								Convert tabs to spaces  
							
							... 
							
							
							
							llvm-svn: 21452 
							
						 
						
							2005-04-22 17:54:37 +00:00  
				
					
						
							
							
								 
						
							
								8f4081a8c9 
								
							 
						 
						
							
							
								
								keep track of max depth stats  
							
							... 
							
							
							
							llvm-svn: 21446 
							
						 
						
							2005-04-22 13:35:18 +00:00  
				
					
						
							
							
								 
						
							
								89b8c8d215 
								
							 
						 
						
							
							
								
								Remove trailing whitespace  
							
							... 
							
							
							
							llvm-svn: 21424 
							
						 
						
							2005-04-21 23:13:11 +00:00  
				
					
						
							
							
								 
						
							
								00ce283b3f 
								
							 
						 
						
							
							
								
								fix calls  
							
							... 
							
							
							
							llvm-svn: 21303 
							
						 
						
							2005-04-14 17:34:20 +00:00  
				
					
						
							
							
								 
						
							
								7ae3aba5aa 
								
							 
						 
						
							
							
								
								a 21264 fix, and fix the operator precidence on an and -> zap check (should fix hundreds of test cases  
							
							... 
							
							
							
							llvm-svn: 21302 
							
						 
						
							2005-04-14 16:24:00 +00:00  
				
					
						
							
							
								 
						
							
								93341a0f82 
								
							 
						 
						
							
							
								
								WOW, function calls still seem to work after this.  
							
							... 
							
							
							
							llvm-svn: 21286 
							
						 
						
							2005-04-13 17:17:28 +00:00  
				
					
						
							
							
								 
						
							
								c3621316ee 
								
							 
						 
						
							
							
								
								prepare for func call optimization  
							
							... 
							
							
							
							llvm-svn: 21285 
							
						 
						
							2005-04-13 16:19:50 +00:00  
				
					
						
							
							
								 
						
							
								c7287c8eda 
								
							 
						 
						
							
							
								
								add matches for SxADDL and company, as well as simplify the SxADDQ code  
							
							... 
							
							
							
							llvm-svn: 21281 
							
						 
						
							2005-04-13 05:19:55 +00:00  
				
					
						
							
							
								 
						
							
								8eb82fb524 
								
							 
						 
						
							
							
								
								added all flavors of zap for anding  
							
							... 
							
							
							
							llvm-svn: 21276 
							
						 
						
							2005-04-13 03:47:03 +00:00  
				
					
						
							
							
								 
						
							
								857624f47a 
								
							 
						 
						
							
							
								
								Remove support for ZERO_EXTEND_INREG.  This pessimizes code, genering stuff  
							
							... 
							
							
							
							like this:
        ldah $1,1($31)
        lda $1,-1($1)
        and $0,$1,$24
instead of this:
        zap $0,252,$24
To get this back, the selector should recognize the ISD::AND case where this
happens and emit the appropriate ZAP instruction.
llvm-svn: 21270 
							
						 
						
							2005-04-13 02:43:40 +00:00  
				
					
						
							
							
								 
						
							
								740f93ca10 
								
							 
						 
						
							
							
								
								Get rid of idefs for arguments (oops)  
							
							... 
							
							
							
							llvm-svn: 21251 
							
						 
						
							2005-04-12 17:47:57 +00:00  
				
					
						
							
							
								 
						
							
								10c6eb4be2 
								
							 
						 
						
							
							
								
								Get rid of idefs for arguments  
							
							... 
							
							
							
							llvm-svn: 21250 
							
						 
						
							2005-04-12 17:35:16 +00:00  
				
					
						
							
							
								 
						
							
								a3a135a9f7 
								
							 
						 
						
							
							
								
								This target does not support/want ISD::BRCONDTWOWAY  
							
							... 
							
							
							
							llvm-svn: 21164 
							
						 
						
							2005-04-09 03:22:37 +00:00  
				
					
						
							
							
								 
						
							
								de5aed3f12 
								
							 
						 
						
							
							
								
								collect a few statistics, factor constants (constant loading and mult), fix logic operation pattern matchs, supress FP div when int dividing by a constant  
							
							... 
							
							
							
							llvm-svn: 21156 
							
						 
						
							2005-04-08 17:28:49 +00:00  
				
					
						
							
							
								 
						
							
								534eebb317 
								
							 
						 
						
							
							
								
								Alpha zero extends setcc results  
							
							... 
							
							
							
							llvm-svn: 21149 
							
						 
						
							2005-04-07 20:11:32 +00:00  
				
					
						
							
							
								 
						
							
								9807ac5d3c 
								
							 
						 
						
							
							
								
								fix a small optimization opertunity and make gcc happy  
							
							... 
							
							
							
							llvm-svn: 21143 
							
						 
						
							2005-04-07 18:15:28 +00:00  
				
					
						
							
							
								 
						
							
								6b492bec30 
								
							 
						 
						
							
							
								
								fixup magic constant making code.  tested by thousands of random divisions.... by 10000.  ok, so random divisors would be good too, but this at least fixes some things  
							
							... 
							
							
							
							llvm-svn: 21140 
							
						 
						
							2005-04-07 17:19:16 +00:00