mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 17:14:00 -07:00 
			
		
		
		
	* Fix typos * Remove unneeded using statements * Enforce var style more * Remove redundant qualifiers * Fix some indentation * Disable naming warnings on files with external enum names * Fix build * Mass find & replace for comments with no spacing * Standardize todo capitalization and for/if spacing
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using ChocolArm64.Instructions;
 | |
| 
 | |
| namespace ChocolArm64.Decoders
 | |
| {
 | |
|     class OpCodeMemImm64 : OpCodeMem64
 | |
|     {
 | |
|         public    long Imm      { get; protected set; }
 | |
|         public    bool WBack    { get; protected set; }
 | |
|         public    bool PostIdx  { get; protected set; }
 | |
|         protected bool Unscaled { get; private   set; }
 | |
| 
 | |
|         private enum MemOp
 | |
|         {
 | |
|             Unscaled     = 0,
 | |
|             PostIndexed  = 1,
 | |
|             Unprivileged = 2,
 | |
|             PreIndexed   = 3,
 | |
|             Unsigned
 | |
|         }
 | |
| 
 | |
|         public OpCodeMemImm64(Inst inst, long position, int opCode) : base(inst, position, opCode)
 | |
|         {
 | |
|             Extend64 = ((opCode >> 22) & 3) == 2;
 | |
|             WBack    = ((opCode >> 24) & 1) == 0;
 | |
| 
 | |
|             // The type is not valid for the Unsigned Immediate 12-bits encoding,
 | |
|             // because the bits 11:10 are used for the larger Immediate offset.
 | |
|             MemOp type = WBack ? (MemOp)((opCode >> 10) & 3) : MemOp.Unsigned;
 | |
| 
 | |
|             PostIdx  = type == MemOp.PostIndexed;
 | |
|             Unscaled = type == MemOp.Unscaled ||
 | |
|                        type == MemOp.Unprivileged;
 | |
| 
 | |
|             // Unscaled and Unprivileged doesn't write back,
 | |
|             // but they do use the 9-bits Signed Immediate.
 | |
|             if (Unscaled)
 | |
|             {
 | |
|                 WBack = false;
 | |
|             }
 | |
| 
 | |
|             if (WBack || Unscaled)
 | |
|             {
 | |
|                 // 9-bits Signed Immediate.
 | |
|                 Imm = (opCode << 11) >> 23;
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 // 12-bits Unsigned Immediate.
 | |
|                 Imm = ((opCode >> 10) & 0xfff) << Size;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| } |