Chris Lattner 
							
						 
					 
					
						
						
							
						
						f2c5bca165 
					 
					
						
						
							
							add some logical ops  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28887  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-20 23:11:59 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						3ae5eef027 
					 
					
						
						
							
							Add some more immediate patterns.  This allows us to compile:  
						
						... 
						
						
						
						void test6() {
  Y = 0xABCD0123BCDE4567;
}
into:
_test6:
        lis r2, -21555
        lis r3, ha16(_Y)
        ori r2, r2, 291
        rldicr r2, r2, 32, 31
        oris r2, r2, 48350
        ori r2, r2, 17767
        std r2, lo16(_Y)(r3)
        blr
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28885  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-20 23:03:01 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						eded521a17 
					 
					
						
						
							
							Instead of li/xoris use li/oris.  Note that this doesn't work if bit 15 is  
						
						... 
						
						
						
						set, so disable the pattern in that case.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28884  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-20 22:38:59 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						0ea70b219a 
					 
					
						
						
							
							Add some 64-bit logical ops.  
						
						... 
						
						
						
						Split imm16Shifted into a sext/zext form for 64-bit support.
Add some patterns for immediate formation.  For example, we now compile this:
static unsigned long long Y;
void test3() {
  Y = 0xF0F00F00;
}
into:
_test3:
        li r2, 3840
        lis r3, ha16(_Y)
        xoris r2, r2, 61680
        std r2, lo16(_Y)(r3)
        blr
GCC produces:
_test3:
        li r0,0
        lis r2,ha16(_Y)
        ori r0,r0,61680
        sldi r0,r0,16
        ori r0,r0,3840
        std r0,lo16(_Y)(r2)
        blr
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28883  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-20 22:34:10 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						f27bb6de10 
					 
					
						
						
							
							Add some patterns for globals, so we can now compile this:  
						
						... 
						
						
						
						static unsigned long long X, Y;
void test1() {
  X = Y;
}
into:
_test1:
        lis r2, ha16(_Y)
        lis r3, ha16(_X)
        ld r2, lo16(_Y)(r2)
        std r2, lo16(_X)(r3)
        blr
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28879  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-20 21:23:06 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						047854f2b7 
					 
					
						
						
							
							Add some patterns for ppc64  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28866  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-20 00:38:36 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						a24b7618f8 
					 
					
						
						
							
							Upgrade some load/store instructions to use the proper addressing mode stuff.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28841  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-16 21:29:41 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						059ca0f5b7 
					 
					
						
						
							
							fix some assumptions that pointers can only be 32-bits.  With this, we can  
						
						... 
						
						
						
						now compile:
static unsigned long X;
void test1() {
  X = 0;
}
into:
_test1:
        lis r2, ha16(_X)
        li r3, 0
        stw r3, lo16(_X)(r2)
        blr
Totally amazing :)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28839  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-16 21:01:35 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						956f43c310 
					 
					
						
						
							
							Split 64-bit instructions out into a separate .td file  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28838  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2006-06-16 20:22:01 +00:00