mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 00:42:27 -07:00 
			
		
		
		
	Faster crc32 implementation (#1294)
* Add Pclmulqdq intrinsic * Implement crc32 in terms of pclmulqdq * Address PR comments
This commit is contained in:
		| @@ -165,6 +165,7 @@ namespace ARMeilleure.CodeGen.X86 | ||||
|             Add(X86Instruction.Pavgb,      new InstructionInfo(BadOp,      BadOp,      BadOp,      BadOp,      0x00000fe0, InstructionFlags.Vex | InstructionFlags.Prefix66)); | ||||
|             Add(X86Instruction.Pavgw,      new InstructionInfo(BadOp,      BadOp,      BadOp,      BadOp,      0x00000fe3, InstructionFlags.Vex | InstructionFlags.Prefix66)); | ||||
|             Add(X86Instruction.Pblendvb,   new InstructionInfo(BadOp,      BadOp,      BadOp,      BadOp,      0x000f3810, InstructionFlags.Prefix66)); | ||||
|             Add(X86Instruction.Pclmulqdq,  new InstructionInfo(BadOp,      BadOp,      BadOp,      BadOp,      0x000f3a44, InstructionFlags.Vex | InstructionFlags.Prefix66)); | ||||
|             Add(X86Instruction.Pcmpeqb,    new InstructionInfo(BadOp,      BadOp,      BadOp,      BadOp,      0x00000f74, InstructionFlags.Vex | InstructionFlags.Prefix66)); | ||||
|             Add(X86Instruction.Pcmpeqd,    new InstructionInfo(BadOp,      BadOp,      BadOp,      BadOp,      0x00000f76, InstructionFlags.Vex | InstructionFlags.Prefix66)); | ||||
|             Add(X86Instruction.Pcmpeqq,    new InstructionInfo(BadOp,      BadOp,      BadOp,      BadOp,      0x000f3829, InstructionFlags.Vex | InstructionFlags.Prefix66)); | ||||
| @@ -633,6 +634,13 @@ namespace ARMeilleure.CodeGen.X86 | ||||
|             WriteInstruction(dest, source, type, X86Instruction.Or); | ||||
|         } | ||||
|  | ||||
|         public void Pclmulqdq(Operand dest, Operand source, byte imm) | ||||
|         { | ||||
|             WriteInstruction(dest, null, source, X86Instruction.Pclmulqdq); | ||||
|  | ||||
|             WriteByte(imm); | ||||
|         } | ||||
|  | ||||
|         public void Pcmpeqw(Operand dest, Operand src1, Operand src2) | ||||
|         { | ||||
|             WriteInstruction(dest, src1, src2, X86Instruction.Pcmpeqw); | ||||
|   | ||||
| @@ -82,6 +82,7 @@ namespace ARMeilleure.CodeGen.X86 | ||||
|             Add(Intrinsic.X86Pavgb,      new IntrinsicInfo(X86Instruction.Pavgb,      IntrinsicType.Binary)); | ||||
|             Add(Intrinsic.X86Pavgw,      new IntrinsicInfo(X86Instruction.Pavgw,      IntrinsicType.Binary)); | ||||
|             Add(Intrinsic.X86Pblendvb,   new IntrinsicInfo(X86Instruction.Pblendvb,   IntrinsicType.Ternary)); | ||||
|             Add(Intrinsic.X86Pclmulqdq,  new IntrinsicInfo(X86Instruction.Pclmulqdq,  IntrinsicType.TernaryImm)); | ||||
|             Add(Intrinsic.X86Pcmpeqb,    new IntrinsicInfo(X86Instruction.Pcmpeqb,    IntrinsicType.Binary)); | ||||
|             Add(Intrinsic.X86Pcmpeqd,    new IntrinsicInfo(X86Instruction.Pcmpeqd,    IntrinsicType.Binary)); | ||||
|             Add(Intrinsic.X86Pcmpeqq,    new IntrinsicInfo(X86Instruction.Pcmpeqq,    IntrinsicType.Binary)); | ||||
|   | ||||
| @@ -98,6 +98,7 @@ namespace ARMeilleure.CodeGen.X86 | ||||
|         Pavgb, | ||||
|         Pavgw, | ||||
|         Pblendvb, | ||||
|         Pclmulqdq, | ||||
|         Pcmpeqb, | ||||
|         Pcmpeqd, | ||||
|         Pcmpeqq, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user