Skip to content

SHA1RNDS4

Henk-Jan Lebbink edited this page Jun 5, 2018 · 12 revisions

SHA1RNDS4 — Perform Four Rounds of SHA1 Operation

Opcode/ Instruction Op/En 64/32 bit Mode Support CPUID Feature Flag Description
NP 0F 3A CC /r ib SHA1RNDS4 xmm1, xmm2/m128, imm8 RMI V/V SHA Performs four rounds of SHA1 operation operating on SHA1 state (A,B,C,D) from xmm1, with a pre-computed sum of the next 4 round message dwords and state variable E from xmm2/m128. The immediate byte controls logic functions and round constants.

Instruction Operand Encoding

Op/En Operand 1 Operand 2 Operand 3
RMI ModRM:reg (r, w) ModRM:r/m (r) Imm8

Description

The SHA1RNDS4 instruction performs four rounds of SHA1 operation using an initial SHA1 state (A,B,C,D) from the first operand (which is a source operand and the destination operand) and some pre-computed sum of the next 4 round message dwords, and state variable E from the second operand (a source operand). The updated SHA1 state (A,B,C,D) after four rounds of processing is stored in the destination operand.

Operation

SHA1RNDS4

The function f() and Constant K are dependent on the value of the immediate.
IF ( imm8[1:0] = 0 )
    THEN f() ← f0(), KK0; 
ELSE IF ( imm8[1:0] = 1 ) 
    THEN f() ← f1(), KK1; 
ELSE IF ( imm8[1:0] = 2 ) 
    THEN f() ← f2(), KK2; 
ELSE IF ( imm8[1:0] = 3 ) 
    THEN f() ← f3(), KK3; 
FI;
ASRC1[127:96]; 
BSRC1[95:64]; 
CSRC1[63:32]; 
DSRC1[31:0]; 
W0ESRC2[127:96]; 
W1SRC2[95:64]; 
W2SRC2[63:32]; 
W3SRC2[31:0]; 
Round i = 0 operation:
A_1f (B, C, D) + (A ROL 5) +W0E +K; 
B_1A; 
C_1B ROL 30; 
D_1C; 
E_1D; 
FOR i = 1 to 3
    A_(i +1) ← f (B_i, C_i, D_i) + (A_i ROL 5) +Wi+ E_i +K; 
    B_(i +1) ← A_i; 
    C_(i +1) ← B_i ROL 30; 
    D_(i +1) ← C_i; 
    E_(i +1) ← D_i; 
ENDFOR
DEST[127:96] ← A_4; 
DEST[95:64] ← B_4; 
DEST[63:32] ← C_4; 
DEST[31:0] ← D_4; 

Intel C/C++ Compiler Intrinsic Equivalent

SHA1RNDS4: __m128i _mm_sha1rnds4_epu32(__m128i, __m128i, const int);

Flags Affected

None

SIMD Floating-Point Exceptions

None

Other Exceptions

See Exceptions Type 4.


Source: Intel® Architecture Software Developer's Manual (May 2018)
Generated: 5-6-2018

Clone this wiki locally