Evan Cheng 
							
						 
					 
					
						
						
							
						
						491f54f1fd 
					 
					
						
						
							
							Distinquish stack slots from other stack objects. They (and fixed objects) get FixedStack PseudoSourceValues.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@84326  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-10-17 09:20:14 +00:00 
						 
				 
			
				
					
						
							
							
								Chris Lattner 
							
						 
					 
					
						
						
							
						
						d9ea85ab01 
					 
					
						
						
							
							remove some uses of llvm/Support/Streams.h  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79842  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-08-23 08:43:55 +00:00 
						 
				 
			
				
					
						
							
							
								Daniel Dunbar 
							
						 
					 
					
						
						
							
						
						1cd1d98232 
					 
					
						
						
							
							Move more to raw_ostream, provide support for writing MachineBasicBlock,  
						
						... 
						
						
						
						LiveInterval, etc to raw_ostream.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@76965  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-07-24 10:36:58 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						358dec5180 
					 
					
						
						
							
							Part 1.  
						
						... 
						
						
						
						- Change register allocation hint to a pair of unsigned integers. The hint type is zero (which means prefer the register specified as second part of the pair) or entirely target dependent.
- Allow targets to specify alternative register allocation orders based on allocation hint.
Part 2.
- Use the register allocation hint system to implement more aggressive load / store multiple formation.
- Aggressively form LDRD / STRD. These are formed *before* register allocation. It has to be done this way to shorten live interval of base and offset registers. e.g.
v1025 = LDR v1024, 0
v1026 = LDR v1024, 0
=>
v1025,v1026 = LDRD v1024, 0
If this transformation isn't done before allocation, v1024 will overlap v1025 which means it more difficult to allocate a register pair.
- Even with the register allocation hint, it may not be possible to get the desired allocation. In that case, the post-allocation load / store multiple pass must fix the ldrd / strd instructions. They can either become ldm / stm instructions or back to a pair of ldr / str instructions.
This is work in progress, not yet enabled.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@73381  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-06-15 08:28:29 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						90f95f88c6 
					 
					
						
						
							
							Move register allocation preference (or hint) from LiveInterval to MachineRegisterInfo. This allows more passes to set them.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@73346  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-06-14 20:22:55 +00:00 
						 
				 
			
				
					
						
							
							
								Mike Stump 
							
						 
					 
					
						
						
							
						
						fe095f39e7 
					 
					
						
						
							
							Restore minor deletion.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@70892  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-05-04 18:40:41 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						c781a243a3 
					 
					
						
						
							
							In some rare cases, the register allocator can spill registers but end up not utilizing registers at all. The fundamental problem is linearscan's backtracking can end up freeing more than one allocated registers. However,  reloads and restores might be folded into uses / defs and freed registers might not be used at all.  
						
						... 
						
						
						
						VirtRegMap keeps track of allocations so it knows what's not used. As a horrible hack, the stack coloring can color spill slots with *free* registers. That is, it replace reload and spills with copies from and to the free register. It unfold instructions that load and store the spill slot and replace them with register using variants.
Not yet enabled. This is part 1. More coming.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@70787  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-05-03 18:32:42 +00:00 
						 
				 
			
				
					
						
							
							
								Bill Wendling 
							
						 
					 
					
						
						
							
						
						e67f5e4273 
					 
					
						
						
							
							Oy! When reverting r68073, I added in experimental code. Sorry...  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@68099  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-03-31 08:41:31 +00:00 
						 
				 
			
				
					
						
							
							
								Bill Wendling 
							
						 
					 
					
						
						
							
						
						8fe00540fc 
					 
					
						
						
							
							Revert r68073. It's causing a failure in the Apple-style builds.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@68092  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-03-31 08:26:26 +00:00 
						 
				 
			
				
					
						
							
							
								Daniel Dunbar 
							
						 
					 
					
						
						
							
						
						cfbf05ef03 
					 
					
						
						
							
							Add newlines at end of file (this can annoy gcov)  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67000  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-03-14 01:53:05 +00:00 
						 
				 
			
				
					
						
							
							
								Owen Anderson 
							
						 
					 
					
						
						
							
						
						49c8aa0d8b 
					 
					
						
						
							
							Convert VirtRegMap to a MachineFunctionPass.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66870  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-03-13 05:55:11 +00:00 
						 
				 
			
				
					
						
							
							
								Owen Anderson 
							
						 
					 
					
						
						
							
						
						1ed5b714f1 
					 
					
						
						
							
							Reorganization: Move the Spiller out of VirtRegMap.cpp into its own files.  No (intended) functionality change.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66720  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-03-11 22:31:21 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						0d8fc52ed3 
					 
					
						
						
							
							Yet another case where the spiller marked two uses of the same register on the same instruction as kill. This fixes PR3706.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66428  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-03-09 19:00:05 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						821b8560e7 
					 
					
						
						
							
							If a MI uses the same register more than once, only mark one of them as 'kill'.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66363  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-03-08 03:58:35 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						c8bb37a50a 
					 
					
						
						
							
							Last commit accidentially deleted this code.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65679  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-28 06:02:14 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						04cf3e39f3 
					 
					
						
						
							
							The last commit was overly conservative. It's ok to reuse value that's already marked livein.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65498  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-26 03:02:21 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						f792352c25 
					 
					
						
						
							
							If an available register falls through to a succ block, unset the last kill. Sorry, it's impossible to reduce a sensible test case. It basically requires the moon and stars to align in order to cause a failure.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65497  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-26 02:30:42 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						bf18939180 
					 
					
						
						
							
							A couple of places where reused use operands should be marked kill. This is exposed by recent availability fallthrough changes.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64745  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-17 06:41:03 +00:00 
						 
				 
			
				
					
						
							
							
								Bill Wendling 
							
						 
					 
					
						
						
							
						
						92c1e12647 
					 
					
						
						
							
							Revert this. It was breaking stuff.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64428  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-13 02:16:35 +00:00 
						 
				 
			
				
					
						
							
							
								Bill Wendling 
							
						 
					 
					
						
						
							
						
						54fc7d6714 
					 
					
						
						
							
							Turn off the old way of handling debug information in the code generator. Use  
						
						... 
						
						
						
						the new way, where all of the information is passed on SDNodes and machine
instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64427  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-13 02:01:04 +00:00 
						 
				 
			
				
					
						
							
							
								Dan Gohman 
							
						 
					 
					
						
						
							
						
						4ed76e76bb 
					 
					
						
						
							
							Adjust the sizes for a few SmallVectors to reflect their usage.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64381  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-12 17:29:01 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						8679119f4b 
					 
					
						
						
							
							It's (currently) not safe to keep certain physical registers live across basic blocks, e.g. x86 fp stack registers.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64374  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-12 10:32:17 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						6d209c413e 
					 
					
						
						
							
							If availability info is kept when fallthrough into a bb, add the available registers to live-in set.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64372  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-12 09:43:23 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						ce7f5a1e50 
					 
					
						
						
							
							Remove a bogus assertion. It's possible a live-in available value is used by a previous instruction.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64339  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-11 23:41:57 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						752272a5e5 
					 
					
						
						
							
							Implement PR3495: local spiller optimization. The local spiller can now keep availability information over BB boundaries. It visits BB's in depth first order. After visiting a BB if it find a successor which has a single predecessor it visits the successor next without clearing the availability information. This allows the successor to omit reloads or change them into copies.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@64298  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-11 08:24:21 +00:00 
						 
				 
			
				
					
						
							
							
								Bill Wendling 
							
						 
					 
					
						
						
							
						
						d62e06c53b 
					 
					
						
						
							
							Explicitly pass in debug location information to BuildMI.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@63599  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-02-03 02:29:34 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						04ee5a1d92 
					 
					
						
						
							
							Change TargetInstrInfo::isMoveInstr to return source and destination sub-register indices as well.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@62600  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2009-01-20 19:12:24 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						bbe4105cd7 
					 
					
						
						
							
							Fix PR3124: overly strict assert.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@60392  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-12-02 02:15:36 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						af42fe36ac 
					 
					
						
						
							
							Fix PR2898. Spiller delete a store for reuse before it knows for sure the reuse happened.  
						
						... 
						
						
						
						Patch by Lang Hames!
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57720  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-10-17 20:56:41 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						6784598895 
					 
					
						
						
							
							Fix a very subtle spiller bug: UpdateKills should not forget to track defs of aliases.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57673  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-10-17 06:16:07 +00:00 
						 
				 
			
				
					
						
							
							
								Dan Gohman 
							
						 
					 
					
						
						
							
						
						b8cab9227a 
					 
					
						
						
							
							Fix command-line option printing to print two spaces where needed,  
						
						... 
						
						
						
						instead of requiring all "short description" strings to begin with
two spaces. This makes these strings less mysterious, and it fixes
some cases where short description strings mistakenly did not
begin with two spaces.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57521  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-10-14 20:25:08 +00:00 
						 
				 
			
				
					
						
							
							
								Dan Gohman 
							
						 
					 
					
						
						
							
						
						4daa9071ed 
					 
					
						
						
							
							Don't dereference the end() iterator. Thanks to  
						
						... 
						
						
						
						ENABLE_EXPENSIVE_CHECKS for finding this.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57181  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-10-06 18:00:07 +00:00 
						 
				 
			
				
					
						
							
							
								Dan Gohman 
							
						 
					 
					
						
						
							
						
						d735b8019b 
					 
					
						
						
							
							Switch the MachineOperand accessors back to the short names like  
						
						... 
						
						
						
						isReg, etc., from isRegister, etc.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57006  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-10-03 15:45:36 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						d9c553f262 
					 
					
						
						
							
							Propagate subreg index when promoting a load to a copy.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56085  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-09-11 01:02:12 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						014264b70f 
					 
					
						
						
							
							Fix PR2664 - spiller GetRegForReload wasn't respecting sub-register indices on machine operands.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56065  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-09-10 20:08:45 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						90960280ee 
					 
					
						
						
							
							Fix an overly strict assertion. Source register of a copy may not be killed, it may be killed by an implicit super-register use.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55762  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-09-04 05:43:55 +00:00 
						 
				 
			
				
					
						
							
							
								Owen Anderson 
							
						 
					 
					
						
						
							
						
						724651ab6e 
					 
					
						
						
							
							Make SimpleSpiller respect subregister indices.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54968  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-08-19 01:05:33 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						e3b8a48d32 
					 
					
						
						
							
							Fix PR2596: out of bound reference.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@54375  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-08-05 21:51:46 +00:00 
						 
				 
			
				
					
						
							
							
								Dan Gohman 
							
						 
					 
					
						
						
							
						
						fa82857e41 
					 
					
						
						
							
							Fix a LocalSpiller leak. This fixes tramp3d-v4.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@53766  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-07-18 18:28:56 +00:00 
						 
				 
			
				
					
						
							
							
								Dan Gohman 
							
						 
					 
					
						
						
							
						
						8e5f2c6f65 
					 
					
						
						
							
							Pool-allocation for MachineInstrs, MachineBasicBlocks, and  
						
						... 
						
						
						
						MachineMemOperands. The pools are owned by MachineFunctions.
This drastically reduces the number of calls to malloc/free made
during the "Emit" phase of scheduling, as well as later phases
in CodeGen. Combined with other changes, this speeds up the
"instruction selection" phase of CodeGen by 10% in some cases.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@53212  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-07-07 23:14:23 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						625986afea 
					 
					
						
						
							
							Cosmetic.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52450  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-06-18 07:47:28 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						7a15391c8d 
					 
					
						
						
							
							Fix read after free found by valgrind.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52309  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-06-16 07:34:17 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						87bb991aa8 
					 
					
						
						
							
							Teach the spiller to commute instructions in order to fold a reload. This hits 410 times on 444.namd and 122 times on 252.eon.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52266  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-06-13 23:58:02 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						cb74266cdb 
					 
					
						
						
							
							Move #include to right place.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51932  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-06-04 09:16:33 +00:00 
						 
				 
			
				
					
						
							
							
								Bill Wendling 
							
						 
					 
					
						
						
							
						
						f3061f8210 
					 
					
						
						
							
							Remove warnings about comparison between signed and unsigned expressions.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51465  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-05-23 01:29:08 +00:00 
						 
				 
			
				
					
						
							
							
								David Greene 
							
						 
					 
					
						
						
							
						
						cff860801e 
					 
					
						
						
							
							Don't attempt to update SpillSlotToUsesMap for stack slots that aren't  
						
						... 
						
						
						
						generated by the spiller.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51439  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-05-22 21:12:21 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						7a0f1851ec 
					 
					
						
						
							
							More local spiller complexity!  
						
						... 
						
						
						
						If local spiller optimization turns some instruction into an identity copy, it will be removed. If the output register happens to be dead (and source is obviously killed), transfer the kill / dead information to last use / def in the same MBB.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51306  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-05-20 08:13:21 +00:00 
						 
				 
			
				
					
						
							
							
								Dan Gohman 
							
						 
					 
					
						
						
							
						
						844731a7f1 
					 
					
						
						
							
							Clean up the use of static and anonymous namespaces. This turned up  
						
						... 
						
						
						
						several things that were neither in an anonymous namespace nor static
but not intended to be global.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51017  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-05-13 00:00:25 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						7ebc06bfd8 
					 
					
						
						
							
							Yet another nasty spiller bug.  
						
						... 
						
						
						
						%ecx = op
store %cl<kill>, (addr)
(addr) = op %al
It's not safe to unfold the last operand and eliminate store even though %cl is marked kill. It's a sub-register use which means one of its super-register(s) may be used below.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@50794  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-05-07 00:49:28 +00:00 
						 
				 
			
				
					
						
							
							
								Evan Cheng 
							
						 
					 
					
						
						
							
						
						4cce6b4c78 
					 
					
						
						
							
							Use of implicit_def is not part of live interval. Create empty intervals for the uses when the live interval is being spilled.  
						
						... 
						
						
						
						git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49542  91177308-0d34-0410-b5e6-96231b3b80d8 
						
						
					 
					
						2008-04-11 17:53:36 +00:00