-rwxr-xr-x 2699 lib25519-20220426/crypto_hashblocks/sha512/avx2/round.py raw
#!/usr/bin/env python3
import sys
i = 0
for doubleround in range(8):
i0 = (i+0)&7
i1 = (i+1)&7
i2 = (i+2)&7
i3 = (i+3)&7
i4 = (i+4)&7
i5 = (i+5)&7
i6 = (i+6)&7
i7 = (i+7)&7
round = 2*doubleround
round4 = round&~3
loadarray = 'wc%d%d%d%d' % (round4,round4+1,round4+2,round4+3)
i0load = '%s[%d]' % (loadarray,(round+0)&3)
i1load = '%s[%d]' % (loadarray,(round+1)&3)
i -= 2
if len(sys.argv) > 1:
if sys.argv[1] != str(doubleround):
continue
print(' r%d += %s' % (i7,i0load))
print(' r%dSigma1 = r%d>>>14' % (i4,i4))
print(' ch%d = r%d' % (i7,i6))
print(' r%d18 = r%d>>>18' % (i4,i4))
print(' ch%d ^= r%d' % (i7,i5))
print(' r%d41 = r%d>>>41' % (i4,i4))
print(' r%dSigma1 ^= r%d18' % (i4,i4))
print(' ch%d &= r%d' % (i7,i4))
print(' r%dSigma0 = r%d>>>28' % (i0,i0))
print(' r%dSigma1 ^= r%d41' % (i4,i4))
print(' ch%d ^= r%d' % (i7,i6))
print(' r%d34 = r%d>>>34' % (i0,i0))
print(' maj%d = r%d' % (i6,i1))
print(' maj%d ^= r%d' % (i6,i0))
print(' r%dSigma0 ^= r%d34' % (i0,i0))
print(' r%d += ch%d' % (i7,i7))
print(' r%dandr%d = r%d' % (i0,i1,i1))
print(' r%d39 = r%d>>>39' % (i0,i0))
print(' r%dandr%d &= r%d' % (i0,i1,i0))
print(' r%dSigma0 ^= r%d39' % (i0,i0))
print(' r%d += r%dSigma1' % (i7,i4))
print(' maj%d = r%d' % (i7,i2))
print(' r%d += %s' % (i6,i1load))
print(' maj%d &= maj%d' % (i7,i6))
print(' r%d += r%d' % (i3,i7))
print(' r%d += r%dSigma0' % (i7,i0))
print(' ch%d = r%d' % (i6,i5))
print(' maj%d ^= r%dandr%d' % (i7,i0,i1))
print(' ch%d ^= r%d' % (i6,i4))
print(' r%dSigma1 = r%d>>>14' % (i3,i3))
print(' r%d += maj%d' % (i7,i7))
print(' ch%d &= r%d' % (i6,i3))
print(' r%d18 = r%d>>>18' % (i3,i3))
print(' r%dSigma1 ^= r%d18' % (i3,i3))
print(' maj%d &= r%d' % (i6,i7))
print(' ch%d ^= r%d' % (i6,i5))
print(' r%d41 = r%d>>>41' % (i3,i3))
print(' r%dSigma1 ^= r%d41' % (i3,i3))
print(' r%dSigma0 = r%d>>>28' % (i7,i7))
print(' maj%d ^= r%dandr%d' % (i6,i0,i1))
print(' r%d += ch%d' % (i6,i6))
print(' r%d += r%dSigma1' % (i6,i3))
print(' r%d34 = r%d>>>34' % (i7,i7))
print(' r%dSigma0 ^= r%d34' % (i7,i7))
print(' r%d += r%d' % (i2,i6))
print(' r%d += maj%d' % (i6,i6))
print(' r%d39 = r%d>>>39' % (i7,i7))
print(' r%dSigma0 ^= r%d39' % (i7,i7))
print(' r%d += r%dSigma0' % (i6,i7))