image/svg+xmlAESDECWIDE128KL—Perform Ten Rounds of AES Decryption Flow with Key Locker on 8 Blocks Using 128-Bit KeyInstruction Operand EncodingDescriptionThe AESDECWIDE128KL1 instruction performs ten rounds of AES to decrypt each of the eight blocks in XMM0-7 using the 128-bit key indicated by the handle from the second operand. It replaces each input block in XMM0-7 with its corresponding decrypted block if the operation succeeds (e.g., does not run into a handle violation failure).OperationAESDECWIDE128KLHandle := UnalignedLoad of 384 bit (SRC);// Load is not guaranteed to be atomic.Illegal Handle = (HandleReservedBitSet (Handle) ||(Handle[0] AND (CPL > 0)) ||Handle [2] ||HandleKeyType (Handle) != HANDLE_KEY_TYPE_AES128);IF (Illegal Handle) THEN RFLAGS.ZF := 1;ELSE (UnwrappedKey, Authentic) := UnwrapKeyAndAuthenticate384 (Handle[383:0], IWKey);IF Authentic == 0 {THEN RFLAGS.ZF := 1;ELSE XMM0 := AES128Decrypt (XMM0, UnwrappedKey) ;XMM1 := AES128Decrypt (XMM1, UnwrappedKey) ;XMM2 := AES128Decrypt (XMM2, UnwrappedKey) ;XMM3 := AES128Decrypt (XMM3, UnwrappedKey) ;XMM4 := AES128Decrypt (XMM4, UnwrappedKey) ;XMM5 := AES128Decrypt (XMM5, UnwrappedKey) ;XMM6 := AES128Decrypt (XMM6, UnwrappedKey) ;XMM7 := AES128Decrypt (XMM7, UnwrappedKey) ;RFLAGS.ZF := 0;FI;FI;RFLAGS.OF, SF, AF, PF, CF := 0;Flags AffectedZF is set to 0 if the operation succeeded and set to 1 if the operation failed due to a handle violation. The other arithmetic flags (OF, SF, AF, PF, CF) are cleared to 0.Opcode/InstructionOp/ En64/32-bit ModeCPUID Feature FlagDescriptionF3 0F 38 D8 !(11):001:bbb AESDECWIDE128KL m384, <XMM0-7>AV/VAESKLEWIDE_KLDecrypt XMM0-7 using 128-bit AES key indicated by handle at m384 and store each resultant block back to its corresponding register.Op/EnTupleOperand 1Operands 2 - 9ANAModRM:r/m (r)Implicit XMM0-7 (r, w)1.Further details on Key Locker and usage of this instruction can be found here:https://software.intel.com/content/www/us/en/develop/download/intel-key-locker-specification.html.

image/svg+xmlIntel C/C++ Compiler Intrinsic EquivalentAESDECWIDE128KLunsigned char _mm_aesdecwide128kl_u8(__m128i odata[8], const __m128i idata[8], const void* h);Exceptions (All Operating Modes)#UD If the LOCK prefix is used.If CPUID.07H:ECX.KL [bit 23] = 0.If CR4.KL = 0.If CPUID.19H:EBX.AESKLE [bit 0] = 0.If CR0.EM = 1.If CR4.OSFXSR = 0.If CPUID.19H:EBX.WIDE_KL [bit 2] = 0.#NM If CR0.TS = 1.#PF If a page fault occurs.#GP(0) If a memory operand effective address is outside the CS, DS, ES, FS, or GS segment limit.If the DS, ES, FS, or GS register is used to access memory and it contains a NULL segment selector.If the memory address is in a non-canonical form.#SS(0) If a memory operand effective address is outside the SS segment limit.If a memory address referencing the SS segment is in a non-canonical form.

This UNOFFICIAL reference was generated from the official Intel® 64 and IA-32 Architectures Software Developer’s Manual by a dumb script. There is no guarantee that some parts aren't mangled or broken and is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.