mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-24 16:00:37 -07:00 
			
		
		
		
	Implements some 32-bit instructions (VBIC, VTST, VSRA) (#1192)
* Added some 32 bits instructions: * VBIC * VTST * VSRA * Incremented the PTC * Add tests and fix implementation * Fixed VBIC immediate opcode mapping * Hey hey! * Nit. Co-authored-by: gdkchan <gab.dark.100@gmail.com> Co-authored-by: LDj3SNuD <dvitiello@gmail.com> Co-authored-by: LDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com>
This commit is contained in:
		| @@ -1,4 +1,4 @@ | ||||
| using ARMeilleure.Decoders; | ||||
| using ARMeilleure.Decoders; | ||||
| using ARMeilleure.IntermediateRepresentation; | ||||
| using ARMeilleure.Translation; | ||||
| using System; | ||||
| @@ -305,6 +305,35 @@ namespace ARMeilleure.Instructions | ||||
|             context.Copy(GetVecA32(op.Qd), res); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorImmBinaryQdQmOpZx32(ArmEmitterContext context, Func2I emit) | ||||
|         { | ||||
|             EmitVectorImmBinaryQdQmOpI32(context, emit, false); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorImmBinaryQdQmOpSx32(ArmEmitterContext context, Func2I emit) | ||||
|         { | ||||
|             EmitVectorImmBinaryQdQmOpI32(context, emit, true); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorImmBinaryQdQmOpI32(ArmEmitterContext context, Func2I emit, bool signed) | ||||
|         { | ||||
|             OpCode32SimdShImm op = (OpCode32SimdShImm)context.CurrOp; | ||||
|  | ||||
|             Operand res = GetVecA32(op.Qd); | ||||
|  | ||||
|             int elems = op.GetBytesCount() >> op.Size; | ||||
|  | ||||
|             for (int index = 0; index < elems; index++) | ||||
|             { | ||||
|                 Operand de = EmitVectorExtract32(context, op.Qd, op.Id + index, op.Size, signed); | ||||
|                 Operand me = EmitVectorExtract32(context, op.Qm, op.Im + index, op.Size, signed); | ||||
|  | ||||
|                 res = EmitVectorInsert(context, res, emit(de, me), op.Id + index, op.Size); | ||||
|             } | ||||
|  | ||||
|             context.Copy(GetVecA32(op.Qd), res); | ||||
|         } | ||||
|  | ||||
|         public static void EmitVectorTernaryLongOpI32(ArmEmitterContext context, Func3I emit, bool signed) | ||||
|         { | ||||
|             OpCode32SimdReg op = (OpCode32SimdReg)context.CurrOp; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user