-rw-r--r-- 9386 lib25519-20221222/crypto_hashblocks/sha512/m3/inner.q raw
spill64 r0_spill
spill64 r1_spill
spill64 r2_spill
spill64 r3_spill
spill64 r4_spill
spill64 r5_spill
spill64 r6_spill
spill64 r7_spill
spill64 w0_spill
spill64 w1_spill
spill64 w2_spill
spill64 w3_spill
spill64 w4_spill
spill64 w5_spill
spill64 w6_spill
spill64 w7_spill
stack64 w8_stack
stack64 state0
stack64 state1
stack64 state2
stack64 state3
stack64 state4
stack64 state5
stack64 state6
stack64 state7
int64 r0
int64 r1
int64 r2
int64 r3
int64 r4
int64 r5
int64 r6
int64 r7
int64 w0
int64 w1
int64 w2
int64 w3
int64 w4
int64 w5
int64 w6
int64 w7
stack64 w0_next
stack64 w1_next
stack64 w2_next
stack64 w3_next
stack64 w4_next
stack64 w5_next
stack64 w6_next
stack64 w7_next
int64 w8
int64 w9
int64 w10
int64 w11
int64 w12
int64 w13
int64 w14
int64 w15
int32 i
ptr statebytes
ptr in
int32 inlen
ptr constants
stackptr in_stack
stackptr statebytes_stack
stack32 inlen_stack
stack32 i_stack
pushenter inner
statebytes_stack = input_0
in_stack = input_1
inlen = input_2 - 128
inlen_stack = inlen
r0 = flip mem64[input_0]
r1 = flip mem64[input_0+8]
r2 = flip mem64[input_0+16]
r3 = flip mem64[input_0+24]
r0 = reverse flip r0
r1 = reverse flip r1
r2 = reverse flip r2
r3 = reverse flip r3
state0 = r0
state1 = r1
state2 = r2
state3 = r3
r0_spill = r0
r1_spill = r1
r2_spill = r2
r3_spill = r3
r4 = flip mem64[input_0+32]
r5 = flip mem64[input_0+40]
r6 = flip mem64[input_0+48]
r7 = flip mem64[input_0+56]
r4 = reverse flip r4
r5 = reverse flip r5
r6 = reverse flip r6
r7 = reverse flip r7
state4 = r4
state5 = r5
state6 = r6
state7 = r7
r4_spill = r4
r5_spill = r5
r6_spill = r6
r7_spill = r7
constants = input_3
mainloop:
in = in_stack
w0 = flip mem64[in]; in += 8
w1 = flip mem64[in]; in += 8
w2 = flip mem64[in]; in += 8
w3 = flip mem64[in]; in += 8
w0 = reverse flip w0
w1 = reverse flip w1
w2 = reverse flip w2
w3 = reverse flip w3
w0_spill = w0
w1_spill = w1
w2_spill = w2
w3_spill = w3
w4 = flip mem64[in]; in += 8
w5 = flip mem64[in]; in += 8
w6 = flip mem64[in]; in += 8
w7 = flip mem64[in]; in += 8
w4 = reverse flip w4
w5 = reverse flip w5
w6 = reverse flip w6
w7 = reverse flip w7
w4_spill = w4
w5_spill = w5
w6_spill = w6
w7_spill = w7
w8 = flip mem64[in]; in += 8
w9 = flip mem64[in]; in += 8
w10 = flip mem64[in]; in += 8
w11 = flip mem64[in]; in += 8
w8 = reverse flip w8
w9 = reverse flip w9
w10 = reverse flip w10
w11 = reverse flip w11
w0_next = w8
w1_next = w9
w2_next = w10
w3_next = w11
w12 = flip mem64[in]; in += 8
w13 = flip mem64[in]; in += 8
w14 = flip mem64[in]; in += 8
w15 = flip mem64[in]; in += 8
w12 = reverse flip w12
w13 = reverse flip w13
w14 = reverse flip w14
w15 = reverse flip w15
w4_next = w12
w5_next = w13
w6_next = w14
w7_next = w15
in_stack = in
i = 80 simple
i_stack = i
innerloop:
assign 0 to r0_spill
assign 1 to r1_spill
assign 2 to r2_spill
assign 3 to r3_spill
assign 4 to r4_spill
assign 5 to r5_spill
assign 6 to r6_spill
assign 7 to r7_spill
r3 = r3_spill
r4 = r4_spill
r5 = r5_spill
r6 = r6_spill
r7 = r7_spill
w0 = w0_spill
r7 += w0 + mem64[constants] + Sigma1(r4) + Ch(r4,r5,r6); constants += 8
r3 += r7
r3_spill = r3
r0 = r0_spill
r1 = r1_spill
r2 = r2_spill
r7 += Sigma0(r0) + Maj(r0,r1,r2)
r7_spill = r7
r4 = r4_spill
r5 = r5_spill
r6 = r6_spill
w1 = w1_spill
r6 += w1 + mem64[constants] + Sigma1(r3) + Ch(r3,r4,r5); constants += 8
r2 += r6
r2_spill = r2
r7 = r7_spill
r0 = r0_spill
r1 = r1_spill
r6 += Sigma0(r7) + Maj(r7,r0,r1)
r6_spill = r6
assign 0 to r0_spill
assign 1 to r1_spill
assign 2 to r2_spill
assign 3 to r3_spill
assign 4 to r4_spill
assign 5 to r5_spill
assign 6 to r6_spill
assign 7 to r7_spill
r3 = r3_spill
r4 = r4_spill
r5 = r5_spill
w2 = w2_spill
r5 += w2 + mem64[constants] + Sigma1(r2) + Ch(r2,r3,r4); constants += 8
r1 += r5
r1_spill = r1
r6 = r6_spill
r7 = r7_spill
r0 = r0_spill
r5 += Sigma0(r6) + Maj(r6,r7,r0)
r5_spill = r5
r2 = r2_spill
r3 = r3_spill
r4 = r4_spill
w3 = w3_spill
r4 += w3 + mem64[constants] + Sigma1(r1) + Ch(r1,r2,r3); constants += 8
r0 += r4
r0_spill = r0
r5 = r5_spill
r6 = r6_spill
r7 = r7_spill
r4 += Sigma0(r5) + Maj(r5,r6,r7)
r4_spill = r4
assign 0 to r0_spill
assign 1 to r1_spill
assign 2 to r2_spill
assign 3 to r3_spill
assign 4 to r4_spill
assign 5 to r5_spill
assign 6 to r6_spill
assign 7 to r7_spill
r1 = r1_spill
r2 = r2_spill
r3 = r3_spill
w4 = w4_spill
r3 += w4 + mem64[constants] + Sigma1(r0) + Ch(r0,r1,r2); constants += 8
r7 += r3
r7_spill = r7
r4 = r4_spill
r5 = r5_spill
r6 = r6_spill
r3 += Sigma0(r4) + Maj(r4,r5,r6)
r3_spill = r3
r0 = r0_spill
r1 = r1_spill
r2 = r2_spill
w5 = w5_spill
r2 += w5 + mem64[constants] + Sigma1(r7) + Ch(r7,r0,r1); constants += 8
r6 += r2
r6_spill = r6
r3 = r3_spill
r4 = r4_spill
r5 = r5_spill
r2 += Sigma0(r3) + Maj(r3,r4,r5)
r2_spill = r2
assign 0 to r0_spill
assign 1 to r1_spill
assign 2 to r2_spill
assign 3 to r3_spill
assign 4 to r4_spill
assign 5 to r5_spill
assign 6 to r6_spill
assign 7 to r7_spill
r7 = r7_spill
r0 = r0_spill
r1 = r1_spill
w6 = w6_spill
r1 += w6 + mem64[constants] + Sigma1(r6) + Ch(r6,r7,r0); constants += 8
r5 += r1
r5_spill = r5
r2 = r2_spill
r3 = r3_spill
r4 = r4_spill
r1 += Sigma0(r2) + Maj(r2,r3,r4)
r1_spill = r1
r6 = r6_spill
r7 = r7_spill
r0 = r0_spill
w7 = w7_spill
r0 += w7 + mem64[constants] + Sigma1(r5) + Ch(r5,r6,r7); constants += 8
r4 += r0
r4_spill = r4
r1 = r1_spill
r2 = r2_spill
r3 = r3_spill
r0 += Sigma0(r1) + Maj(r1,r2,r3)
r0_spill = r0
assign 8 to w0_spill
assign 9 to w1_spill
assign 10 to w2_spill
assign 11 to w3_spill
assign 12 to w4_spill
assign 13 to w5_spill
assign 14 to w6_spill
assign 15 to w7_spill
i = i_stack
=? i -= 8
goto endinnerloop if =
i_stack = i
=? i - 8
goto nearend if =
w8 = w0_spill
w9 = w1_spill
w6 = w6_next
w1 = w1_next
w8 += sigma1(w6)
w8 += sigma0(w9)
w8 += w1
w1_spill = w1
w7 = w7_next
w8_stack = w8
w9 += sigma1(w7)
w10 = w2_spill
w9 += sigma0(w10)
w2 = w2_next
w9 += w2
w2_spill = w2
w1_next = w9
w10 += sigma1(w8)
w11 = w3_spill
w10 += sigma0(w11)
w3 = w3_next
w10 += w3
w3_spill = w3
w2_next = w10
w11 += sigma1(w9)
w12 = w4_spill
w11 += sigma0(w12)
w4 = w4_next
w11 += w4
w4_spill = w4
w3_next = w11
w12 += sigma1(w10)
w13 = w5_spill
w12 += sigma0(w13)
w5 = w5_next
w12 += w5
w5_spill = w5
w4_next = w12
w13 += sigma1(w11)
w14 = w6_spill
w6_spill = w6
w13 += sigma0(w14)
w13 += w6
w5_next = w13
w14 += sigma1(w12)
w15 = w7_spill
w7_spill = w7
w14 += sigma0(w15)
w14 += w7
w6_next = w14
w15 += sigma1(w13)
w0 = w0_next
w8 = w8_stack
w0_next = w8
w15 += sigma0(w0)
w15 += w8
w7_next = w15
w0_spill = w0
goto innerloop
nearend:
w0 = w0_next
w1 = w1_next
w2 = w2_next
w3 = w3_next
w0_spill = w0
w1_spill = w1
w2_spill = w2
w3_spill = w3
w4 = w4_next
w5 = w5_next
w6 = w6_next
w7 = w7_next
w4_spill = w4
w5_spill = w5
w6_spill = w6
w7_spill = w7
goto innerloop
endinnerloop:
constants -= 640
r0 = r0_spill
r1 = r1_spill
r2 = r2_spill
r3 = r3_spill
r0 += state0
r1 += state1
r2 += state2
r3 += state3
state0 = r0
state1 = r1
state2 = r2
state3 = r3
r0_spill = r0
r1_spill = r1
r2_spill = r2
r3_spill = r3
r4 = r4_spill
r5 = r5_spill
r6 = r6_spill
r7 = r7_spill
r4 += state4
r5 += state5
r6 += state6
r7 += state7
state4 = r4
state5 = r5
state6 = r6
state7 = r7
r4_spill = r4
r5_spill = r5
r6_spill = r6
r7_spill = r7
inlen = inlen_stack
unsigned>=? inlen -= 128
inlen_stack = inlen
goto mainloop if unsigned>=
endmainloop:
statebytes = statebytes_stack
r0 = state0
r1 = state1
r2 = state2
r3 = state3
r0 = reverse flip r0
r1 = reverse flip r1
r2 = reverse flip r2
r3 = reverse flip r3
mem64[statebytes] = flip r0
mem64[statebytes+8] = flip r1
mem64[statebytes+16] = flip r2
mem64[statebytes+24] = flip r3
r4 = state4
r5 = state5
r6 = state6
r7 = state7
r4 = reverse flip r4
r5 = reverse flip r5
r6 = reverse flip r6
r7 = reverse flip r7
mem64[statebytes+32] = flip r4
mem64[statebytes+40] = flip r5
mem64[statebytes+48] = flip r6
mem64[statebytes+56] = flip r7
inlen += 128
popreturn inlen