Bob Wilson 
							
						 
					 
					
						
						
							
						
						1ce588c970 
					 
					
						
						
							
							Revert "Stop using struct wrappers for Neon vector types in <arm_neon.h>."  
						
						... 
						
						
						
						It's breaking buildbots.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@119363  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-11-16 18:43:07 +00:00 
						 
				 
			
				
					
						
							
							
								Bob Wilson 
							
						 
					 
					
						
						
							
						
						f93cbbd72e 
					 
					
						
						
							
							Stop using struct wrappers for Neon vector types in <arm_neon.h>.  
						
						... 
						
						
						
						Thanks to Nate Begeman for an earlier version of this patch.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@119358  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-11-16 18:17:03 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						8a6e7e1214 
					 
					
						
						
							
							Revert r114596, it's breaking a few tests.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114659  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-09-23 16:49:17 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						e5cb26fab9 
					 
					
						
						
							
							<rdar://problem/8228022> Wvector-conversions warnings in arm_neon.h  
						
						... 
						
						
						
						Explicitly cast arguments to the type the builtin expects, which is <vN x i8>
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114596  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-09-22 22:28:42 +00:00 
						 
				 
			
				
					
						
							
							
								Bob Wilson 
							
						 
					 
					
						
						
							
						
						ee9ca07e7f 
					 
					
						
						
							
							Use float64 instead of int64 vector elements for NEON vget_low and vget_high  
						
						... 
						
						
						
						functions, since int64 is not a legal type and using it leads to inefficient
code.  PR8036.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@113919  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-09-15 01:52:33 +00:00 
						 
				 
			
				
					
						
							
							
								Bob Wilson 
							
						 
					 
					
						
						
							
						
						72774c9a83 
					 
					
						
						
							
							Tidy whitespace in generated arm_neon.h.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@113865  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-09-14 21:52:34 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						59d70cbc29 
					 
					
						
						
							
							Add tablegen support for vdup_lane  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110419  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-08-06 01:24:11 +00:00 
						 
				 
			
				
					
						
							
							
								Bob Wilson 
							
						 
					 
					
						
						
							
						
						fdb530d406 
					 
					
						
						
							
							Fix a warning from gcc-4.0 (from the ppc buildbot).  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@109605  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-07-28 18:21:10 +00:00 
						 
				 
			
				
					
						
							
							
								Bob Wilson 
							
						 
					 
					
						
						
							
						
						e9c2615b76 
					 
					
						
						
							
							Change array references to match my previous change to use the public type  
						
						... 
						
						
						
						names for the array fields.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106803  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-24 22:21:19 +00:00 
						 
				 
			
				
					
						
							
							
								Bob Wilson 
							
						 
					 
					
						
						
							
						
						1ac27cf5ae 
					 
					
						
						
							
							Fix up some comments.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106795  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-24 22:04:30 +00:00 
						 
				 
			
				
					
						
							
							
								Bob Wilson 
							
						 
					 
					
						
						
							
						
						9969bc3d19 
					 
					
						
						
							
							Use the struct tags mandated by ARM's ABI.  Also use the public type names for  
						
						... 
						
						
						
						the array fields in these structs.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106794  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-24 22:03:41 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						c4a1b652b2 
					 
					
						
						
							
							Add support for returning multiple vectors via sret, which is how the ARM target expects the intrinsics to work.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106406  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-20 21:09:52 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						f8c4c27d84 
					 
					
						
						
							
							Modify tablegen to support generating all NEON code used by clang at once.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106207  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-17 04:15:13 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						4da883a56f 
					 
					
						
						
							
							Make VC++ happy  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106054  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-15 22:10:31 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						918f8e4ab0 
					 
					
						
						
							
							Add the last of the SemaChecking-gen code.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105929  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-14 05:17:23 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						d72c900152 
					 
					
						
						
							
							Add a helping of comments  
						
						... 
						
						
						
						Add code for generating bits of semachecking
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105907  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-13 04:47:03 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						5ca96988b0 
					 
					
						
						
							
							declare a class with 'class' instead of struct to avoid tag mismatch  
						
						... 
						
						
						
						warnings, and don't shift by a bool.  Patch by Rizky Herucakra!
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105886  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-12 15:46:56 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						cc3c41a9c3 
					 
					
						
						
							
							Add generic vector support for bitselect & element byteswap  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105874  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-12 03:09:49 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						d6645dd4fe 
					 
					
						
						
							
							Add support for polynomial type, for polynomial multiply  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105792  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-10 18:06:07 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						4b425a8caa 
					 
					
						
						
							
							NEON support for _lane ops, and multiplies by scalar.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105769  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-10 00:16:56 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						f50551eb08 
					 
					
						
						
							
							Further refine types for operations which take scalars.  
						
						... 
						
						
						
						This will be used primarily by NEON shift intrinsics.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105733  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-09 18:02:26 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						007afe4b4b 
					 
					
						
						
							
							Specialize I-Class instructions better so that we have less work to do in codegen.  
						
						... 
						
						
						
						Parenthesize macro args
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105682  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-09 05:11:55 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						6c060dbf84 
					 
					
						
						
							
							Handle instructions which need to be #defines for the purpose of capturing constant arguments  
						
						... 
						
						
						
						Handle extract hi/lo with common code
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105666  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-09 01:09:00 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						96ec22d683 
					 
					
						
						
							
							Fix a valgrind error.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105600  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-08 07:11:17 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						5638783276 
					 
					
						
						
							
							Refine BuiltinsARM.def types a bit, we should do a better job of this to save some c++ code in CGBuiltins.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105598  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-08 06:01:16 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						900f4674c1 
					 
					
						
						
							
							ARM NEON:  
						
						... 
						
						
						
						fix vcvt naming
handle vdup, vcombine with generic vector code
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105588  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-08 00:14:42 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						b0a4e4554e 
					 
					
						
						
							
							clang codegen support  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105531  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-07 16:00:37 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						9e584b37b0 
					 
					
						
						
							
							Handle multi-vector returns and args.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105496  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-04 22:53:30 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						7c21f747c7 
					 
					
						
						
							
							Additional fixes to BuiltinsARM.def generator, on to clang codegen.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105488  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-04 21:36:00 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						92f98af9fb 
					 
					
						
						
							
							Progress on generating BuiltinsARM.def, still some duplicates to work out.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105461  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-04 07:11:25 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						73cef3e9b1 
					 
					
						
						
							
							BuiltinsARM.def emitter, still needs a substantial bit of tweaking to lighten the load on clang.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105456  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-04 01:26:15 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						a8979a0e7b 
					 
					
						
						
							
							Mangle __builtin_neon_* names appropriately.  
						
						... 
						
						
						
						Add skeleton of support for emitting the list of prototypes for BuiltinsARM.def
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105443  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-04 00:21:41 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						3861e74490 
					 
					
						
						
							
							Add some additional capabilities to the neon emitter  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105416  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-03 21:35:22 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						162d3ba464 
					 
					
						
						
							
							arm_neon.h now makes it through clang and generates appropriate code for those functions which can use  
						
						... 
						
						
						
						generic vector operators rather than __builtin_neon_*
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105380  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-03 04:04:09 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						7c8c8830a9 
					 
					
						
						
							
							arm_neon.h emitter now mostly complete for the purposes of initial testing.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105349  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-02 21:53:00 +00:00 
						 
				 
			
				
					
						
							
							
								Duncan Sands 
							
						 
					 
					
						
						
							
						
						8dbbacedcd 
					 
					
						
						
							
							Pacify recent gcc: remove a pointless const qualifier.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105318  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-02 08:37:30 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						e66aab553c 
					 
					
						
						
							
							Checkpoint; handle 'int' and 'void' correctly  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105316  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-02 07:14:28 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						af905efc61 
					 
					
						
						
							
							Emit full function prototypes.  Definitions & typedefs to come.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105315  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-02 06:17:19 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						22237771d8 
					 
					
						
						
							
							Checkpoint arm_neon.h generation with tablegen  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105307  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-06-02 00:34:55 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						e8f0349439 
					 
					
						
						
							
							Comment out some code in prep for actual .td file checkpoint.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104927  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-05-28 02:19:08 +00:00 
						 
				 
			
				
					
						
							
							
								Nate Begeman 
							
						 
					 
					
						
						
							
						
						5ddb087f7f 
					 
					
						
						
							
							Add support to tablegen for auto-generating arm_neon.h from a tablegen description  
						
						... 
						
						
						
						of the intrinsics.  The goal is to auto-generate both support for GCC-style (vector)
and ARM-style (struct of vector) intrinsics.
This is work in progress, but will be completed soon.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104910  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2010-05-28 01:08:32 +00:00