0001
0002 #include <linux/linkage.h>
0003 #include <asm/visasm.h>
0004
0005 #include "opcodes.h"
0006
0007 ENTRY(sha1_sparc64_transform)
0008
0009 VISEntryHalf
0010 ld [%o0 + 0x00], %f0
0011 ld [%o0 + 0x04], %f1
0012 ld [%o0 + 0x08], %f2
0013 andcc %o1, 0x7, %g0
0014 ld [%o0 + 0x0c], %f3
0015 bne,pn %xcc, 10f
0016 ld [%o0 + 0x10], %f4
0017
0018 1:
0019 ldd [%o1 + 0x00], %f8
0020 ldd [%o1 + 0x08], %f10
0021 ldd [%o1 + 0x10], %f12
0022 ldd [%o1 + 0x18], %f14
0023 ldd [%o1 + 0x20], %f16
0024 ldd [%o1 + 0x28], %f18
0025 ldd [%o1 + 0x30], %f20
0026 ldd [%o1 + 0x38], %f22
0027
0028 SHA1
0029
0030 subcc %o2, 1, %o2
0031 bne,pt %xcc, 1b
0032 add %o1, 0x40, %o1
0033
0034 5:
0035 st %f0, [%o0 + 0x00]
0036 st %f1, [%o0 + 0x04]
0037 st %f2, [%o0 + 0x08]
0038 st %f3, [%o0 + 0x0c]
0039 st %f4, [%o0 + 0x10]
0040 retl
0041 VISExitHalf
0042 10:
0043 alignaddr %o1, %g0, %o1
0044
0045 ldd [%o1 + 0x00], %f10
0046 1:
0047 ldd [%o1 + 0x08], %f12
0048 ldd [%o1 + 0x10], %f14
0049 ldd [%o1 + 0x18], %f16
0050 ldd [%o1 + 0x20], %f18
0051 ldd [%o1 + 0x28], %f20
0052 ldd [%o1 + 0x30], %f22
0053 ldd [%o1 + 0x38], %f24
0054 ldd [%o1 + 0x40], %f26
0055
0056 faligndata %f10, %f12, %f8
0057 faligndata %f12, %f14, %f10
0058 faligndata %f14, %f16, %f12
0059 faligndata %f16, %f18, %f14
0060 faligndata %f18, %f20, %f16
0061 faligndata %f20, %f22, %f18
0062 faligndata %f22, %f24, %f20
0063 faligndata %f24, %f26, %f22
0064
0065 SHA1
0066
0067 subcc %o2, 1, %o2
0068 fsrc2 %f26, %f10
0069 bne,pt %xcc, 1b
0070 add %o1, 0x40, %o1
0071
0072 ba,a,pt %xcc, 5b
0073 ENDPROC(sha1_sparc64_transform)