mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 09:02:31 -07:00 
			
		
		
		
	* Implement JIT Arm64 backend * PPTC version bump * Address some feedback from Arm64 JIT PR * Address even more PR feedback * Remove unused IsPageAligned function * Sync Qc flag before calls * Fix comment and remove unused enum * Address riperiperi PR feedback * Delete Breakpoint IR instruction that was only implemented for Arm64
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| 
 | |
| namespace ARMeilleure.CodeGen.Arm64
 | |
| {
 | |
|     static class CallingConvention
 | |
|     {
 | |
|         private const int RegistersMask = unchecked((int)0xffffffff);
 | |
| 
 | |
|         // Some of those register have specific roles and can't be used as general purpose registers.
 | |
|         // X18 - Reserved for platform specific usage.
 | |
|         // X29 - Frame pointer.
 | |
|         // X30 - Return address.
 | |
|         // X31 - Not an actual register, in some cases maps to SP, and in others to ZR.
 | |
|         private const int ReservedRegsMask = (1 << CodeGenCommon.ReservedRegister) | (1 << 18) | (1 << 29) | (1 << 30) | (1 << 31);
 | |
| 
 | |
|         public static int GetIntAvailableRegisters()
 | |
|         {
 | |
|             return RegistersMask & ~ReservedRegsMask;
 | |
|         }
 | |
| 
 | |
|         public static int GetVecAvailableRegisters()
 | |
|         {
 | |
|             return RegistersMask;
 | |
|         }
 | |
| 
 | |
|         public static int GetIntCallerSavedRegisters()
 | |
|         {
 | |
|             return (GetIntCalleeSavedRegisters() ^ RegistersMask) & ~ReservedRegsMask;
 | |
|         }
 | |
| 
 | |
|         public static int GetFpCallerSavedRegisters()
 | |
|         {
 | |
|             return GetFpCalleeSavedRegisters() ^ RegistersMask;
 | |
|         }
 | |
| 
 | |
|         public static int GetVecCallerSavedRegisters()
 | |
|         {
 | |
|             return GetVecCalleeSavedRegisters() ^ RegistersMask;
 | |
|         }
 | |
| 
 | |
|         public static int GetIntCalleeSavedRegisters()
 | |
|         {
 | |
|             return 0x1ff80000; // X19 to X28
 | |
|         }
 | |
| 
 | |
|         public static int GetFpCalleeSavedRegisters()
 | |
|         {
 | |
|             return 0xff00; // D8 to D15
 | |
|         }
 | |
| 
 | |
|         public static int GetVecCalleeSavedRegisters()
 | |
|         {
 | |
|             return 0;
 | |
|         }
 | |
| 
 | |
|         public static int GetArgumentsOnRegsCount()
 | |
|         {
 | |
|             return 8;
 | |
|         }
 | |
| 
 | |
|         public static int GetIntArgumentRegister(int index)
 | |
|         {
 | |
|             if ((uint)index < (uint)GetArgumentsOnRegsCount())
 | |
|             {
 | |
|                 return index;
 | |
|             }
 | |
| 
 | |
|             throw new ArgumentOutOfRangeException(nameof(index));
 | |
|         }
 | |
| 
 | |
|         public static int GetVecArgumentRegister(int index)
 | |
|         {
 | |
|             if ((uint)index < (uint)GetArgumentsOnRegsCount())
 | |
|             {
 | |
|                 return index;
 | |
|             }
 | |
| 
 | |
|             throw new ArgumentOutOfRangeException(nameof(index));
 | |
|         }
 | |
| 
 | |
|         public static int GetIntReturnRegister()
 | |
|         {
 | |
|             return 0;
 | |
|         }
 | |
| 
 | |
|         public static int GetIntReturnRegisterHigh()
 | |
|         {
 | |
|             return 1;
 | |
|         }
 | |
| 
 | |
|         public static int GetVecReturnRegister()
 | |
|         {
 | |
|             return 0;
 | |
|         }
 | |
|     }
 | |
| } |