fa0df55bdd 
								
							 
						 
						
							
							
								
								Move the LowerMEMCPY and LowerMEMCPYCall to a common place.  
							
							... 
							
							
							
							Thanks for the suggestions Bill :-)
llvm-svn: 43742 
							
						 
						
							2007-11-05 23:12:20 +00:00  
				
					
						
							
							
								 
						
							
								4646aa3e33 
								
							 
						 
						
							
							
								
								Make labels work in asm blocks; allow labels as  
							
							... 
							
							
							
							parameters.  Rename ValueRefList to ParamList
in AsmParser, since its only use is for parameters.
llvm-svn: 43734 
							
						 
						
							2007-11-05 21:20:28 +00:00  
				
					
						
							
							
								 
						
							
								fd66486950 
								
							 
						 
						
							
							
								
								Add runtime library names for pow.  
							
							... 
							
							
							
							llvm-svn: 42880 
							
						 
						
							2007-10-11 23:09:10 +00:00  
				
					
						
							
							
								 
						
							
								a160361c85 
								
							 
						 
						
							
							
								
								Migrate X86 and ARM from using X86ISD::{,I}DIV and ARMISD::MULHILO{U,S} to  
							
							... 
							
							
							
							use ISD::{S,U}DIVREM and ISD::{S,U}MUL_HIO. Move the lowering code
associated with these operators into target-independent in LegalizeDAG.cpp
and TargetLowering.cpp.
llvm-svn: 42762 
							
						 
						
							2007-10-08 18:33:35 +00:00  
				
					
						
							
							
								 
						
							
								c0154c06d6 
								
							 
						 
						
							
							
								
								First round of ppc long double.  call/return and  
							
							... 
							
							
							
							basic arithmetic works.
Rename RTLIB long double functions to distinguish
different flavors of long double; the lib functions
have different names, alas.
llvm-svn: 42644 
							
						 
						
							2007-10-05 20:04:43 +00:00  
				
					
						
							
							
								 
						
							
								25a00a63eb 
								
							 
						 
						
							
							
								
								Add sqrt and powi intrinsics for long double.  
							
							... 
							
							
							
							llvm-svn: 42423 
							
						 
						
							2007-09-28 01:08:20 +00:00  
				
					
						
							
							
								 
						
							
								5e1a428344 
								
							 
						 
						
							
							
								
								Move the setOperationAction(ISD::DEBUG_LOC, MVT::Other, Expand) and  
							
							... 
							
							
							
							the check to see if the assembler supports .loc from X86TargetLowering
into the superclass TargetLowering.
llvm-svn: 42297 
							
						 
						
							2007-09-25 15:10:49 +00:00  
				
					
						
							
							
								 
						
							
								b3d01d2f56 
								
							 
						 
						
							
							
								
								initialize SetCCResultContents, fixing PR1693  
							
							... 
							
							
							
							llvm-svn: 42193 
							
						 
						
							2007-09-21 17:06:39 +00:00  
				
					
						
							
							
								 
						
							
								7d67e547b5 
								
							 
						 
						
							
							
								
								More long double fixes.  x86_64 should build now.  
							
							... 
							
							
							
							llvm-svn: 42155 
							
						 
						
							2007-09-19 23:55:34 +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  
				
					
						
							
							
								 
						
							
								d8c9cb9182 
								
							 
						 
						
							
							
								
								rename isOperandValidForConstraint to LowerAsmOperandForConstraint,  
							
							... 
							
							
							
							changing the interface to allow for future changes.
llvm-svn: 41384 
							
						 
						
							2007-08-25 00:47:38 +00:00  
				
					
						
							
							
								 
						
							
								ba1a98a4e0 
								
							 
						 
						
							
							
								
								long double 9 of N.  This finishes up the X86-32 bits  
							
							... 
							
							
							
							(constants are still not handled).  Adds ConvertActions
to control fp-to-fp conversions (these are currently
defaulted for all other targets, so no changes there).
llvm-svn: 40958 
							
						 
						
							2007-08-09 01:04:01 +00:00  
				
					
						
							
							
								 
						
							
								6decfbf133 
								
							 
						 
						
							
							
								
								Initialize the IndexedModeActions array with memset before  
							
							... 
							
							
							
							updating it with calls to setIndexedLoadAction/setIndexedStoreAction,
which only update a few bits at a time. This avoids ostensible
undefined behavior of operationg on values which may be
trap-representations, and as a practical matter fixes errors from
valgrind, which doesn't track uninitialized memory with bit
granularity.
llvm-svn: 38468 
							
						 
						
							2007-07-09 20:49:44 +00:00  
				
					
						
							
							
								 
						
							
								7867793aff 
								
							 
						 
						
							
							
								
								Add new TargetLowering code to provide the final register type that an  
							
							... 
							
							
							
							illegal value type will be transformed to, for code that needs the
register type after all transformations instead of just after the first
transformation.
Factor out the code that uses this information to do copy-from-regs and
copy-to-regs for various purposes into separate functions so that they
are done consistently.
llvm-svn: 37781 
							
						 
						
							2007-06-28 23:29:44 +00:00  
				
					
						
							
							
								 
						
							
								a866514528 
								
							 
						 
						
							
							
								
								Generalize MVT::ValueType and associated functions to be able to represent  
							
							... 
							
							
							
							extended vector types. Remove the special SDNode opcodes used for pre-legalize
vector operations, and the special MVT::Vector type used with them. Adjust
lowering and legalize to work with the normal SDNode kinds instead, and to
use the normal MVT functions to work with vector types instead of using the
two special operands that the pre-legalize nodes held.
This allows pre-legalize and post-legalize DAGs, and the code that operates
on them, to be more consistent. Pre-legalize vector operators can be handled
more consistently with scalar operators. And, -view-dag-combine1-dags and
-view-legalize-dags now look prettier for vector code.
llvm-svn: 37719 
							
						 
						
							2007-06-25 16:23:39 +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  
				
					
						
							
							
								 
						
							
								8e8d34b220 
								
							 
						 
						
							
							
								
								Tidy up ValueType names in comments.  
							
							... 
							
							
							
							llvm-svn: 37688 
							
						 
						
							2007-06-21 14:48:26 +00:00  
				
					
						
							
							
								 
						
							
								04deef3a49 
								
							 
						 
						
							
							
								
								Rename TargetLowering::getNumElements and friends to  
							
							... 
							
							
							
							TargetLowering::getNumRegisters and similar, to avoid confusion with
the actual number of elements for vector types.
llvm-svn: 37687 
							
						 
						
							2007-06-21 14:42:22 +00:00  
				
					
						
							
							
								 
						
							
								397c4d9ef6 
								
							 
						 
						
							
							
								
								Fix CodeGen/PowerPC/2007-05-30-dagcombine-miscomp.ll, and PR1473.  
							
							... 
							
							
							
							llvm-svn: 37362 
							
						 
						
							2007-05-30 16:30:06 +00:00  
				
					
						
							
							
								 
						
							
								1fa8276e70 
								
							 
						 
						
							
							
								
								same patch as the previous one, but the symmetric case  
							
							... 
							
							
							
							llvm-svn: 37249 
							
						 
						
							2007-05-19 00:46:51 +00:00  
				
					
						
							
							
								 
						
							
								b08cbbd737 
								
							 
						 
						
							
							
								
								Disable the (A == (B-A)) -> 2*A == B xform when the sub has multiple uses (in  
							
							... 
							
							
							
							this case, the xform introduces an extra operation).  This compiles
PowerPC/compare-duplicate.ll into:
_test:
        subf r2, r3, r4
        cmplw cr0, r2, r3
        bne cr0, LBB1_2 ;F
instead of:
_test:
        slwi r2, r3, 1
        subf r3, r3, r4
        cmplw cr0, r4, r2
        bne cr0, LBB1_2 ;F
This is target independent of course.
llvm-svn: 37246 
							
						 
						
							2007-05-19 00:43:44 +00:00  
				
					
						
							
							
								 
						
							
								1796f1f8e9 
								
							 
						 
						
							
							
								
								Qualify several calls to functions in the MVT namespace, for consistency.  
							
							... 
							
							
							
							llvm-svn: 37230 
							
						 
						
							2007-05-18 17:52:13 +00:00  
				
					
						
							
							
								 
						
							
								0184f88deb 
								
							 
						 
						
							
							
								
								disable MaskedValueIsZero, ComputeMaskedBits, and SimplifyDemandedBits for  
							
							... 
							
							
							
							i128 integers.  The 64-bit masks are not wide enough to represent the results.
These should be converted to APInt someday.
llvm-svn: 37169 
							
						 
						
							2007-05-17 18:19:23 +00:00  
				
					
						
							
							
								 
						
							
								429178d727 
								
							 
						 
						
							
							
								
								Add target hook to specify block size limit for if-conversion.  
							
							... 
							
							
							
							llvm-svn: 37134 
							
						 
						
							2007-05-16 23:45:53 +00:00  
				
					
						
							
							
								 
						
							
								44a2ed66b1 
								
							 
						 
						
							
							
								
								Allow i/s to match (gv+c).  This fixes CodeGen/PowerPC/2007-05-03-InlineAsm-S-Constraint.ll  
							
							... 
							
							
							
							and PR1382
llvm-svn: 36672 
							
						 
						
							2007-05-03 16:54:34 +00:00  
				
					
						
							
							
								 
						
							
								15c1b820cc 
								
							 
						 
						
							
							
								
								fix a pasto  
							
							... 
							
							
							
							llvm-svn: 36242 
							
						 
						
							2007-04-18 03:01:40 +00:00  
				
					
						
							
							
								 
						
							
								4aff52bf3d 
								
							 
						 
						
							
							
								
								Fix a bug in my previous patch, grabbing the shift amount width from the  
							
							... 
							
							
							
							wrong operand.
llvm-svn: 36223 
							
						 
						
							2007-04-17 22:53:02 +00:00  
				
					
						
							
							
								 
						
							
								9a861a8550 
								
							 
						 
						
							
							
								
								Fold (x << c1)>> c2 into a single shift if the bits shifted out aren't used.  
							
							... 
							
							
							
							This compiles:
int baz(long long a) { return (short)(((int)(a >>24)) >> 9); }
into:
_baz:
        srwi r2, r3, 1
        extsh r3, r2
        blr
on PPC, instead of:
_baz:
        slwi r2, r3, 8
        srwi r2, r2, 9
        extsh r3, r2
        blr
GCC produces:
_baz:
        srwi r10,r4,24
        insrwi r10,r3,24,0
        srawi r9,r3,24
        srawi r3,r10,9
        extsh r3,r3
        blr
This implements CodeGen/PowerPC/shl_elim.ll
llvm-svn: 36221 
							
						 
						
							2007-04-17 21:14:16 +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  
				
					
						
							
							
								 
						
							
								784a68a702 
								
							 
						 
						
							
							
								
								Fix weirdness handling single element vectors.  
							
							... 
							
							
							
							llvm-svn: 35941 
							
						 
						
							2007-04-12 04:44:28 +00:00  
				
					
						
							
							
								 
						
							
								35f0417ec1 
								
							 
						 
						
							
							
								
								remove dead target hooks.  
							
							... 
							
							
							
							llvm-svn: 35847 
							
						 
						
							2007-04-09 23:34:08 +00:00  
				
					
						
							
							
								 
						
							
								39f65335d5 
								
							 
						 
						
							
							
								
								remove some dead target hooks, subsumed by isLegalAddressingMode  
							
							... 
							
							
							
							llvm-svn: 35840 
							
						 
						
							2007-04-09 22:27:04 +00:00  
				
					
						
							
							
								 
						
							
								f2d71d49e2 
								
							 
						 
						
							
							
								
								switch TL::getValueType to use MVT::getValueType.  
							
							... 
							
							
							
							llvm-svn: 35527 
							
						 
						
							2007-03-31 04:05:24 +00:00  
				
					
						
							
							
								 
						
							
								ac3f81508c 
								
							 
						 
						
							
							
								
								add one addressing mode description hook to rule them all.  
							
							... 
							
							
							
							llvm-svn: 35520 
							
						 
						
							2007-03-30 23:14:50 +00:00  
				
					
						
							
							
								 
						
							
								c2cba18f2b 
								
							 
						 
						
							
							
								
								Remove isLegalAddressImmediate.  
							
							... 
							
							
							
							llvm-svn: 35406 
							
						 
						
							2007-03-28 01:53:55 +00:00  
				
					
						
							
							
								 
						
							
								3d7efa2586 
								
							 
						 
						
							
							
								
								implement initial support for the silly X constraint.  Testcase here: CodeGen/X86/2007-03-24-InlineAsmXConstraint.ll  
							
							... 
							
							
							
							llvm-svn: 35327 
							
						 
						
							2007-03-25 04:35:41 +00:00  
				
					
						
							
							
								 
						
							
								843e44503c 
								
							 
						 
						
							
							
								
								Implement CodeGen/X86/2007-03-24-InlineAsmMultiRegConstraint.ll  
							
							... 
							
							
							
							llvm-svn: 35324 
							
						 
						
							2007-03-25 02:18:14 +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  
				
					
						
							
							
								 
						
							
								0c6bb5eab7 
								
							 
						 
						
							
							
								
								repair x86 performance, dejagnu problems from previous change  
							
							... 
							
							
							
							llvm-svn: 35245 
							
						 
						
							2007-03-21 21:51:52 +00:00  
				
					
						
							
							
								 
						
							
								bacf4acf65 
								
							 
						 
						
							
							
								
								do not share old induction variables when this would result in invalid  
							
							... 
							
							
							
							instructions (that would have to be split later)
llvm-svn: 35227 
							
						 
						
							2007-03-20 21:54:54 +00:00  
				
					
						
							
							
								 
						
							
								a2a2fd1e55 
								
							 
						 
						
							
							
								
								Added isLegalAddressExpression hook to test if the given expression can be  
							
							... 
							
							
							
							folded into target addressing mode for the given type.
llvm-svn: 35121 
							
						 
						
							2007-03-16 08:42:32 +00:00  
				
					
						
							
							
								 
						
							
								b7004fd889 
								
							 
						 
						
							
							
								
								More flexible TargetLowering LSR hooks for testing whether an immediate is a legal target address immediate or scale.  
							
							... 
							
							
							
							llvm-svn: 35076 
							
						 
						
							2007-03-12 23:37:10 +00:00  
				
					
						
							
							
								 
						
							
								168c5856bf 
								
							 
						 
						
							
							
								
								initialize a instance variable  
							
							... 
							
							
							
							llvm-svn: 34567 
							
						 
						
							2007-02-25 01:28:05 +00:00  
				
					
						
							
							
								 
						
							
								d7ef3f804d 
								
							 
						 
						
							
							
								
								Fix CodeGen/Generic/2007-02-23-DAGCombine-Miscompile.ll and PR1219  
							
							... 
							
							
							
							llvm-svn: 34551 
							
						 
						
							2007-02-24 02:09:29 +00:00  
				
					
						
							
							
								 
						
							
								3e3a65b764 
								
							 
						 
						
							
							
								
								Need to init.  
							
							... 
							
							
							
							llvm-svn: 34499 
							
						 
						
							2007-02-22 18:04:49 +00:00  
				
					
						
							
							
								 
						
							
								a9f917af59 
								
							 
						 
						
							
							
								
								Implement i/n/s constraints correctly.  This fixes  
							
							... 
							
							
							
							test/CodeGen/PowerPC/2007-02-16-InlineAsmNConstraint.ll
llvm-svn: 34368 
							
						 
						
							2007-02-17 06:00:35 +00:00  
				
					
						
							
							
								 
						
							
								d84d35ba70 
								
							 
						 
						
							
							
								
								For PR1195:  
							
							... 
							
							
							
							Rename PackedType -> VectorType, ConstantPacked -> ConstantVector, and
PackedTyID -> VectorTyID. No functional changes.
llvm-svn: 34293 
							
						 
						
							2007-02-15 02:26:10 +00:00  
				
					
						
							
							
								 
						
							
								d08d31f68a 
								
							 
						 
						
							
							
								
								Fix PR1198, by adding initial i128 support.  Patch by Dan Gohman.  
							
							... 
							
							
							
							llvm-svn: 34256 
							
						 
						
							2007-02-13 23:41:38 +00:00  
				
					
						
							
							
								 
						
							
								92658d5648 
								
							 
						 
						
							
							
								
								Move SimplifySetCC to TargetLowering and allow it to be shared with legalizer.  
							
							... 
							
							
							
							llvm-svn: 34065 
							
						 
						
							2007-02-08 22:13:59 +00:00  
				
					
						
							
							
								 
						
							
								296a83cefb 
								
							 
						 
						
							
							
								
								Fit in 80 columns  
							
							... 
							
							
							
							llvm-svn: 33745 
							
						 
						
							2007-02-01 04:55:59 +00:00  
				
					
						
							
							
								 
						
							
								53026f1d5a 
								
							 
						 
						
							
							
								
								Allow the target to override the ISD::CondCode that's to be used to test the  
							
							... 
							
							
							
							result of the comparison libcall against zero.
llvm-svn: 33701 
							
						 
						
							2007-01-31 09:29:11 +00:00  
				
					
						
							
							
								 
						
							
								ddf1421b8e 
								
							 
						 
						
							
							
								
								Move a function out of line.  
							
							... 
							
							
							
							llvm-svn: 33158 
							
						 
						
							2007-01-12 23:30:31 +00:00  
				
					
						
							
							
								 
						
							
								61a4be88b4 
								
							 
						 
						
							
							
								
								Minor fix.  
							
							... 
							
							
							
							llvm-svn: 33149 
							
						 
						
							2007-01-12 22:51:10 +00:00  
				
					
						
							
							
								 
						
							
								31cbddf28a 
								
							 
						 
						
							
							
								
								Store default libgcc routine names and allow them to be redefined by target.  
							
							... 
							
							
							
							llvm-svn: 33105 
							
						 
						
							2007-01-12 02:11:51 +00:00  
				
					
						
							
							
								 
						
							
								3b7c257cae 
								
							 
						 
						
							
							
								
								Cleaned setjmp/longjmp lowering interfaces. Now we're producing right  
							
							... 
							
							
							
							code (both asm & cbe) for Mingw32 target.
Removed autoconf checks for underscored versions of setjmp/longjmp.
llvm-svn: 32415 
							
						 
						
							2006-12-10 23:12:42 +00:00  
				
					
						
							
							
								 
						
							
								4eee72471c 
								
							 
						 
						
							
							
								
								Preliminary soft float support.  
							
							... 
							
							
							
							llvm-svn: 32394 
							
						 
						
							2006-12-09 02:42:38 +00:00  
				
					
						
							
							
								 
						
							
								5d5916b4d1 
								
							 
						 
						
							
							
								
								Fix the dag combiner bug corresponding to PR1014.  
							
							... 
							
							
							
							llvm-svn: 31943 
							
						 
						
							2006-11-27 21:50:02 +00:00  
				
					
						
							
							
								 
						
							
								d550248f2c 
								
							 
						 
						
							
							
								
								Add a mechanism to specify whether a target supports a particular indexed load / store.  
							
							... 
							
							
							
							llvm-svn: 31597 
							
						 
						
							2006-11-09 18:56:43 +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  
				
					
						
							
							
								 
						
							
								8c6949e5b2 
								
							 
						 
						
							
							
								
								Change the prototype for TargetLowering::isOperandValidForConstraint  
							
							... 
							
							
							
							llvm-svn: 31318 
							
						 
						
							2006-10-31 19:40:43 +00:00  
				
					
						
							
							
								 
						
							
								ab51cf2e78 
								
							 
						 
						
							
							
								
								Merge ISD::TRUNCSTORE to ISD::STORE. Switch to using StoreSDNode.  
							
							... 
							
							
							
							llvm-svn: 30945 
							
						 
						
							2006-10-13 21:14:26 +00:00  
				
					
						
							
							
								 
						
							
								d35734bd1f 
								
							 
						 
						
							
							
								
								Naming consistency.  
							
							... 
							
							
							
							llvm-svn: 30878 
							
						 
						
							2006-10-11 07:10:22 +00:00  
				
					
						
							
							
								 
						
							
								e71fe34d75 
								
							 
						 
						
							
							
								
								Reflects ISD::LOAD / ISD::LOADX / LoadSDNode changes.  
							
							... 
							
							
							
							llvm-svn: 30844 
							
						 
						
							2006-10-09 20:57:25 +00:00  
				
					
						
							
							
								 
						
							
								a389a612bb 
								
							 
						 
						
							
							
								
								initialize ivar  
							
							... 
							
							
							
							llvm-svn: 30780 
							
						 
						
							2006-10-06 22:52:08 +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  
				
					
						
							
							
								 
						
							
								0dce3311c4 
								
							 
						 
						
							
							
								
								Change the default to 0, which means 'default'.  
							
							... 
							
							
							
							llvm-svn: 30114 
							
						 
						
							2006-09-05 17:39:15 +00:00  
				
					
						
							
							
								 
						
							
								373be1d1a2 
								
							 
						 
						
							
							
								
								forgot this  
							
							... 
							
							
							
							llvm-svn: 30097 
							
						 
						
							2006-09-04 07:44:11 +00:00  
				
					
						
							
							
								 
						
							
								85ea83e821 
								
							 
						 
						
							
							
								
								Add some advice  
							
							... 
							
							
							
							llvm-svn: 29324 
							
						 
						
							2006-07-27 04:24:14 +00:00