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