mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-24 18:30:34 -07:00 
			
		
		
		
	Implement VCNT instruction (#1963)
* Implement VCNT based on AArch64 CNT Add tests * Update PTC version * Address LDj's comments * Explicit size in encoding * Tighter tests * Replace SoftFallback with IR helper Co-authored-by: LDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com> * Reduce one BitwiseAnd from IR fallback Based on popcount64b from https://en.wikipedia.org/wiki/Hamming_weight#Efficient_implementation * Rename parameter and add assert Co-authored-by: LDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com> Co-authored-by: LDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com>
This commit is contained in:
		| @@ -234,6 +234,18 @@ namespace ARMeilleure.Instructions | ||||
|             throw new ArgumentException($"Invalid rounding mode \"{roundMode}\"."); | ||||
|         } | ||||
|  | ||||
|         public static Operand EmitCountSetBits8(ArmEmitterContext context, Operand op) // "size" is 8 (SIMD&FP Inst.). | ||||
|         { | ||||
|             Debug.Assert(op.Type == OperandType.I32 || op.Type == OperandType.I64); | ||||
|  | ||||
|             Operand op0 = context.Subtract(op, context.BitwiseAnd(context.ShiftRightUI(op, Const(1)), Const(op.Type, 0x55L))); | ||||
|  | ||||
|             Operand c1 = Const(op.Type, 0x33L); | ||||
|             Operand op1 = context.Add(context.BitwiseAnd(context.ShiftRightUI(op0, Const(2)), c1), context.BitwiseAnd(op0, c1)); | ||||
|  | ||||
|             return context.BitwiseAnd(context.Add(op1, context.ShiftRightUI(op1, Const(4))), Const(op.Type, 0x0fL)); | ||||
|         } | ||||
|  | ||||
|         public static void EmitScalarUnaryOpF(ArmEmitterContext context, Intrinsic inst32, Intrinsic inst64) | ||||
|         { | ||||
|             OpCodeSimd op = (OpCodeSimd)context.CurrOp; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user