|  nickysn | 1f8a9c708e
							
							* use RegistersInterfere instead of SuperRegistersEqual in TAoptBase.RegInOp and TAoptBase.RegInRef | 5 lat temu | 
				
					
						|  nickysn | 531cc0ab0d
							
							+ introduced TAOptBase.RegistersInterfere (which might not always be equivalent to SuperRegistersEqual) | 5 lat temu | 
				
					
						|  nickysn | 5947adcd7b
							
							+ added a correct implementation of TAOptBase.SuperRegistersEqual for the Z80 | 5 lat temu | 
				
					
						|  florian | 872c22842e
							
							* do prefetching correctly | 5 lat temu | 
				
					
						|  Jonas Maebe | ebd674d40e
							
							* fixed TAOptBase.SkipEntryExitMarker() not initialising out parameter in | 5 lat temu | 
				
					
						|  florian | 7e6eeebdf0
							
							o patch by J. Gareth Moreton, seeks to improve maintainability, safety and efficiency | 6 lat temu | 
				
					
						|  florian | 59d300fc6e
							
							* optimize TAOptBase.SuperRegistersEqual | 6 lat temu | 
				
					
						|  florian | 9230ae5aab
							
							o overhaul-base.patch by J. Gareth Moreton, base for further patches | 6 lat temu | 
				
					
						|  florian | 7f286eb54e
							
							+ define cpudelayslot: set during compiler compilation for CPUs having branch instructions with delay slot (MIPS, SPARC) | 8 lat temu | 
				
					
						|  florian | f4718c0969
							
							* made nop handling generic for sparc, so it is used by sparc64 as well | 8 lat temu | 
				
					
						|  florian | b1dff29cbf
							
							* removed unused units | 8 lat temu | 
				
					
						|  nickysn | 9b7a8f0da5
							
							+ take into account the x86 segment register in TAOptBase.RegInRef | 8 lat temu | 
				
					
						|  florian | bc73d0914e
							
							* TAOptBase.RegInRef compares using SuperRegistersEqual as TAOptBase.RegInOp does for top_reg already | 9 lat temu | 
				
					
						|  florian | e6cea6622e
							
							* when checking if a register is used by an operand, compare the super registers | 9 lat temu | 
				
					
						|  florian | b274599a47
							
							* made some assembler optimizer methods class methods | 9 lat temu | 
				
					
						|  florian | cfd49ec708
							
							+ TAOptBase.SuperRegistersEqual | 9 lat temu | 
				
					
						|  florian | 8b4a392863
							
							* compilation fixed | 9 lat temu | 
				
					
						|  florian | 5aabe71aee
							
							* better throw an internalerror in TAoptBase.RegLoadedWithNewValue instead of trying to make a safe approximation | 9 lat temu | 
				
					
						|  florian | 1266491085
							
							o refactored some peephole optimizer code: | 9 lat temu | 
				
					
						|  Jonas Maebe | 3c7ad95f7d
							
							* simplified RegInInstruction() and fixed range errors | 12 lat temu | 
				
					
						|  sergei | a5ae26da7e
							
							* Moved SkipEntryExitMarker method from ARM optimizer to the base one, since it is not target-dependent. Now it can be reused by other targets. | 12 lat temu | 
				
					
						|  sergei | 1c84c3edbf
							
							* Fixed label optimizer to work with MIPS, and enabled level 1 optimization for MIPS targets. | 12 lat temu | 
				
					
						|  florian | ca5078f9cf
							
							+ RegModifiedBetween | 13 lat temu | 
				
					
						|  florian | 0c08ae8553
							
							+ RegUsedBetween | 13 lat temu | 
				
					
						|  masta | 9825fbf554
							
							Support top_shifterop and top_regset for arm in RegInOp | 13 lat temu | 
				
					
						|  florian | d4c120cb34
							
							* fix comment so it does not confuse lazarus | 13 lat temu | 
				
					
						|  florian | 748694a325
							
							* fixes some issues with reg. allocation information | 13 lat temu | 
				
					
						|  florian | 2a6a4831ea
							
							* basics for generic register usage information | 13 lat temu | 
				
					
						|  florian | 2f5ce095ce
							
							* RefsHaveIndexReg -> cpurefshaveindexreg | 13 lat temu | 
				
					
						|  florian | 8278271b4e
							
							* fix RegInInstruction | 13 lat temu |