aes-sparcv9.S revision 1.1.1.2 1 #include "sparc_arch.h"
2
3 #ifdef __arch64__
4 .register %g2,#scratch
5 .register %g3,#scratch
6 #endif
7 .section ".text",#alloc,#execinstr
8
9 .align 256
10 AES_Te:
11 .long 0xc66363a5,0xc66363a5
12 .long 0xf87c7c84,0xf87c7c84
13 .long 0xee777799,0xee777799
14 .long 0xf67b7b8d,0xf67b7b8d
15 .long 0xfff2f20d,0xfff2f20d
16 .long 0xd66b6bbd,0xd66b6bbd
17 .long 0xde6f6fb1,0xde6f6fb1
18 .long 0x91c5c554,0x91c5c554
19 .long 0x60303050,0x60303050
20 .long 0x02010103,0x02010103
21 .long 0xce6767a9,0xce6767a9
22 .long 0x562b2b7d,0x562b2b7d
23 .long 0xe7fefe19,0xe7fefe19
24 .long 0xb5d7d762,0xb5d7d762
25 .long 0x4dababe6,0x4dababe6
26 .long 0xec76769a,0xec76769a
27 .long 0x8fcaca45,0x8fcaca45
28 .long 0x1f82829d,0x1f82829d
29 .long 0x89c9c940,0x89c9c940
30 .long 0xfa7d7d87,0xfa7d7d87
31 .long 0xeffafa15,0xeffafa15
32 .long 0xb25959eb,0xb25959eb
33 .long 0x8e4747c9,0x8e4747c9
34 .long 0xfbf0f00b,0xfbf0f00b
35 .long 0x41adadec,0x41adadec
36 .long 0xb3d4d467,0xb3d4d467
37 .long 0x5fa2a2fd,0x5fa2a2fd
38 .long 0x45afafea,0x45afafea
39 .long 0x239c9cbf,0x239c9cbf
40 .long 0x53a4a4f7,0x53a4a4f7
41 .long 0xe4727296,0xe4727296
42 .long 0x9bc0c05b,0x9bc0c05b
43 .long 0x75b7b7c2,0x75b7b7c2
44 .long 0xe1fdfd1c,0xe1fdfd1c
45 .long 0x3d9393ae,0x3d9393ae
46 .long 0x4c26266a,0x4c26266a
47 .long 0x6c36365a,0x6c36365a
48 .long 0x7e3f3f41,0x7e3f3f41
49 .long 0xf5f7f702,0xf5f7f702
50 .long 0x83cccc4f,0x83cccc4f
51 .long 0x6834345c,0x6834345c
52 .long 0x51a5a5f4,0x51a5a5f4
53 .long 0xd1e5e534,0xd1e5e534
54 .long 0xf9f1f108,0xf9f1f108
55 .long 0xe2717193,0xe2717193
56 .long 0xabd8d873,0xabd8d873
57 .long 0x62313153,0x62313153
58 .long 0x2a15153f,0x2a15153f
59 .long 0x0804040c,0x0804040c
60 .long 0x95c7c752,0x95c7c752
61 .long 0x46232365,0x46232365
62 .long 0x9dc3c35e,0x9dc3c35e
63 .long 0x30181828,0x30181828
64 .long 0x379696a1,0x379696a1
65 .long 0x0a05050f,0x0a05050f
66 .long 0x2f9a9ab5,0x2f9a9ab5
67 .long 0x0e070709,0x0e070709
68 .long 0x24121236,0x24121236
69 .long 0x1b80809b,0x1b80809b
70 .long 0xdfe2e23d,0xdfe2e23d
71 .long 0xcdebeb26,0xcdebeb26
72 .long 0x4e272769,0x4e272769
73 .long 0x7fb2b2cd,0x7fb2b2cd
74 .long 0xea75759f,0xea75759f
75 .long 0x1209091b,0x1209091b
76 .long 0x1d83839e,0x1d83839e
77 .long 0x582c2c74,0x582c2c74
78 .long 0x341a1a2e,0x341a1a2e
79 .long 0x361b1b2d,0x361b1b2d
80 .long 0xdc6e6eb2,0xdc6e6eb2
81 .long 0xb45a5aee,0xb45a5aee
82 .long 0x5ba0a0fb,0x5ba0a0fb
83 .long 0xa45252f6,0xa45252f6
84 .long 0x763b3b4d,0x763b3b4d
85 .long 0xb7d6d661,0xb7d6d661
86 .long 0x7db3b3ce,0x7db3b3ce
87 .long 0x5229297b,0x5229297b
88 .long 0xdde3e33e,0xdde3e33e
89 .long 0x5e2f2f71,0x5e2f2f71
90 .long 0x13848497,0x13848497
91 .long 0xa65353f5,0xa65353f5
92 .long 0xb9d1d168,0xb9d1d168
93 .long 0x00000000,0x00000000
94 .long 0xc1eded2c,0xc1eded2c
95 .long 0x40202060,0x40202060
96 .long 0xe3fcfc1f,0xe3fcfc1f
97 .long 0x79b1b1c8,0x79b1b1c8
98 .long 0xb65b5bed,0xb65b5bed
99 .long 0xd46a6abe,0xd46a6abe
100 .long 0x8dcbcb46,0x8dcbcb46
101 .long 0x67bebed9,0x67bebed9
102 .long 0x7239394b,0x7239394b
103 .long 0x944a4ade,0x944a4ade
104 .long 0x984c4cd4,0x984c4cd4
105 .long 0xb05858e8,0xb05858e8
106 .long 0x85cfcf4a,0x85cfcf4a
107 .long 0xbbd0d06b,0xbbd0d06b
108 .long 0xc5efef2a,0xc5efef2a
109 .long 0x4faaaae5,0x4faaaae5
110 .long 0xedfbfb16,0xedfbfb16
111 .long 0x864343c5,0x864343c5
112 .long 0x9a4d4dd7,0x9a4d4dd7
113 .long 0x66333355,0x66333355
114 .long 0x11858594,0x11858594
115 .long 0x8a4545cf,0x8a4545cf
116 .long 0xe9f9f910,0xe9f9f910
117 .long 0x04020206,0x04020206
118 .long 0xfe7f7f81,0xfe7f7f81
119 .long 0xa05050f0,0xa05050f0
120 .long 0x783c3c44,0x783c3c44
121 .long 0x259f9fba,0x259f9fba
122 .long 0x4ba8a8e3,0x4ba8a8e3
123 .long 0xa25151f3,0xa25151f3
124 .long 0x5da3a3fe,0x5da3a3fe
125 .long 0x804040c0,0x804040c0
126 .long 0x058f8f8a,0x058f8f8a
127 .long 0x3f9292ad,0x3f9292ad
128 .long 0x219d9dbc,0x219d9dbc
129 .long 0x70383848,0x70383848
130 .long 0xf1f5f504,0xf1f5f504
131 .long 0x63bcbcdf,0x63bcbcdf
132 .long 0x77b6b6c1,0x77b6b6c1
133 .long 0xafdada75,0xafdada75
134 .long 0x42212163,0x42212163
135 .long 0x20101030,0x20101030
136 .long 0xe5ffff1a,0xe5ffff1a
137 .long 0xfdf3f30e,0xfdf3f30e
138 .long 0xbfd2d26d,0xbfd2d26d
139 .long 0x81cdcd4c,0x81cdcd4c
140 .long 0x180c0c14,0x180c0c14
141 .long 0x26131335,0x26131335
142 .long 0xc3ecec2f,0xc3ecec2f
143 .long 0xbe5f5fe1,0xbe5f5fe1
144 .long 0x359797a2,0x359797a2
145 .long 0x884444cc,0x884444cc
146 .long 0x2e171739,0x2e171739
147 .long 0x93c4c457,0x93c4c457
148 .long 0x55a7a7f2,0x55a7a7f2
149 .long 0xfc7e7e82,0xfc7e7e82
150 .long 0x7a3d3d47,0x7a3d3d47
151 .long 0xc86464ac,0xc86464ac
152 .long 0xba5d5de7,0xba5d5de7
153 .long 0x3219192b,0x3219192b
154 .long 0xe6737395,0xe6737395
155 .long 0xc06060a0,0xc06060a0
156 .long 0x19818198,0x19818198
157 .long 0x9e4f4fd1,0x9e4f4fd1
158 .long 0xa3dcdc7f,0xa3dcdc7f
159 .long 0x44222266,0x44222266
160 .long 0x542a2a7e,0x542a2a7e
161 .long 0x3b9090ab,0x3b9090ab
162 .long 0x0b888883,0x0b888883
163 .long 0x8c4646ca,0x8c4646ca
164 .long 0xc7eeee29,0xc7eeee29
165 .long 0x6bb8b8d3,0x6bb8b8d3
166 .long 0x2814143c,0x2814143c
167 .long 0xa7dede79,0xa7dede79
168 .long 0xbc5e5ee2,0xbc5e5ee2
169 .long 0x160b0b1d,0x160b0b1d
170 .long 0xaddbdb76,0xaddbdb76
171 .long 0xdbe0e03b,0xdbe0e03b
172 .long 0x64323256,0x64323256
173 .long 0x743a3a4e,0x743a3a4e
174 .long 0x140a0a1e,0x140a0a1e
175 .long 0x924949db,0x924949db
176 .long 0x0c06060a,0x0c06060a
177 .long 0x4824246c,0x4824246c
178 .long 0xb85c5ce4,0xb85c5ce4
179 .long 0x9fc2c25d,0x9fc2c25d
180 .long 0xbdd3d36e,0xbdd3d36e
181 .long 0x43acacef,0x43acacef
182 .long 0xc46262a6,0xc46262a6
183 .long 0x399191a8,0x399191a8
184 .long 0x319595a4,0x319595a4
185 .long 0xd3e4e437,0xd3e4e437
186 .long 0xf279798b,0xf279798b
187 .long 0xd5e7e732,0xd5e7e732
188 .long 0x8bc8c843,0x8bc8c843
189 .long 0x6e373759,0x6e373759
190 .long 0xda6d6db7,0xda6d6db7
191 .long 0x018d8d8c,0x018d8d8c
192 .long 0xb1d5d564,0xb1d5d564
193 .long 0x9c4e4ed2,0x9c4e4ed2
194 .long 0x49a9a9e0,0x49a9a9e0
195 .long 0xd86c6cb4,0xd86c6cb4
196 .long 0xac5656fa,0xac5656fa
197 .long 0xf3f4f407,0xf3f4f407
198 .long 0xcfeaea25,0xcfeaea25
199 .long 0xca6565af,0xca6565af
200 .long 0xf47a7a8e,0xf47a7a8e
201 .long 0x47aeaee9,0x47aeaee9
202 .long 0x10080818,0x10080818
203 .long 0x6fbabad5,0x6fbabad5
204 .long 0xf0787888,0xf0787888
205 .long 0x4a25256f,0x4a25256f
206 .long 0x5c2e2e72,0x5c2e2e72
207 .long 0x381c1c24,0x381c1c24
208 .long 0x57a6a6f1,0x57a6a6f1
209 .long 0x73b4b4c7,0x73b4b4c7
210 .long 0x97c6c651,0x97c6c651
211 .long 0xcbe8e823,0xcbe8e823
212 .long 0xa1dddd7c,0xa1dddd7c
213 .long 0xe874749c,0xe874749c
214 .long 0x3e1f1f21,0x3e1f1f21
215 .long 0x964b4bdd,0x964b4bdd
216 .long 0x61bdbddc,0x61bdbddc
217 .long 0x0d8b8b86,0x0d8b8b86
218 .long 0x0f8a8a85,0x0f8a8a85
219 .long 0xe0707090,0xe0707090
220 .long 0x7c3e3e42,0x7c3e3e42
221 .long 0x71b5b5c4,0x71b5b5c4
222 .long 0xcc6666aa,0xcc6666aa
223 .long 0x904848d8,0x904848d8
224 .long 0x06030305,0x06030305
225 .long 0xf7f6f601,0xf7f6f601
226 .long 0x1c0e0e12,0x1c0e0e12
227 .long 0xc26161a3,0xc26161a3
228 .long 0x6a35355f,0x6a35355f
229 .long 0xae5757f9,0xae5757f9
230 .long 0x69b9b9d0,0x69b9b9d0
231 .long 0x17868691,0x17868691
232 .long 0x99c1c158,0x99c1c158
233 .long 0x3a1d1d27,0x3a1d1d27
234 .long 0x279e9eb9,0x279e9eb9
235 .long 0xd9e1e138,0xd9e1e138
236 .long 0xebf8f813,0xebf8f813
237 .long 0x2b9898b3,0x2b9898b3
238 .long 0x22111133,0x22111133
239 .long 0xd26969bb,0xd26969bb
240 .long 0xa9d9d970,0xa9d9d970
241 .long 0x078e8e89,0x078e8e89
242 .long 0x339494a7,0x339494a7
243 .long 0x2d9b9bb6,0x2d9b9bb6
244 .long 0x3c1e1e22,0x3c1e1e22
245 .long 0x15878792,0x15878792
246 .long 0xc9e9e920,0xc9e9e920
247 .long 0x87cece49,0x87cece49
248 .long 0xaa5555ff,0xaa5555ff
249 .long 0x50282878,0x50282878
250 .long 0xa5dfdf7a,0xa5dfdf7a
251 .long 0x038c8c8f,0x038c8c8f
252 .long 0x59a1a1f8,0x59a1a1f8
253 .long 0x09898980,0x09898980
254 .long 0x1a0d0d17,0x1a0d0d17
255 .long 0x65bfbfda,0x65bfbfda
256 .long 0xd7e6e631,0xd7e6e631
257 .long 0x844242c6,0x844242c6
258 .long 0xd06868b8,0xd06868b8
259 .long 0x824141c3,0x824141c3
260 .long 0x299999b0,0x299999b0
261 .long 0x5a2d2d77,0x5a2d2d77
262 .long 0x1e0f0f11,0x1e0f0f11
263 .long 0x7bb0b0cb,0x7bb0b0cb
264 .long 0xa85454fc,0xa85454fc
265 .long 0x6dbbbbd6,0x6dbbbbd6
266 .long 0x2c16163a,0x2c16163a
267 .byte 0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5
268 .byte 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76
269 .byte 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0
270 .byte 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0
271 .byte 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc
272 .byte 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15
273 .byte 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a
274 .byte 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75
275 .byte 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0
276 .byte 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84
277 .byte 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b
278 .byte 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf
279 .byte 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85
280 .byte 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8
281 .byte 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5
282 .byte 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2
283 .byte 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17
284 .byte 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73
285 .byte 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88
286 .byte 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb
287 .byte 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c
288 .byte 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79
289 .byte 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9
290 .byte 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08
291 .byte 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6
292 .byte 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a
293 .byte 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e
294 .byte 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e
295 .byte 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94
296 .byte 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf
297 .byte 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68
298 .byte 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16
299 .type AES_Te,#object
300 .size AES_Te,(.-AES_Te)
301
302 .align 64
303 .skip 16
304 _sparcv9_AES_encrypt:
305 save %sp,-STACK_FRAME-16,%sp
306 stx %i7,[%sp+STACK_BIAS+STACK_FRAME+0] ! off-load return address
307 ld [%i5+240],%i7
308 ld [%i5+0],%l4
309 ld [%i5+4],%l5 !
310 ld [%i5+8],%l6
311 srl %i7,1,%i7
312 xor %l4,%i0,%i0
313 ld [%i5+12],%l7
314 srl %i0,21,%l0
315 xor %l5,%i1,%i1
316 ld [%i5+16],%l4
317 srl %i1,13,%o0 !
318 xor %l6,%i2,%i2
319 ld [%i5+20],%l5
320 xor %l7,%i3,%i3
321 ld [%i5+24],%l6
322 and %l0,2040,%l0
323 ld [%i5+28],%l7
324 nop
325 .Lenc_loop:
326 srl %i2,5,%o1 !
327 and %o0,2040,%o0
328 ldx [%i4+%l0],%l0
329 sll %i3,3,%o2
330 and %o1,2040,%o1
331 ldx [%i4+%o0],%o0
332 srl %i1,21,%l1
333 and %o2,2040,%o2
334 ldx [%i4+%o1],%o1 !
335 srl %i2,13,%o3
336 and %l1,2040,%l1
337 ldx [%i4+%o2],%o2
338 srl %i3,5,%o4
339 and %o3,2040,%o3
340 ldx [%i4+%l1],%l1
341
342 sll %i0,3,%o5 !
343 and %o4,2040,%o4
344 ldx [%i4+%o3],%o3
345 srl %i2,21,%l2
346 and %o5,2040,%o5
347 ldx [%i4+%o4],%o4
348 srl %i3,13,%o7
349 and %l2,2040,%l2
350 ldx [%i4+%o5],%o5 !
351 srl %i0,5,%g1
352 and %o7,2040,%o7
353 ldx [%i4+%l2],%l2
354 sll %i1,3,%g2
355 and %g1,2040,%g1
356 ldx [%i4+%o7],%o7
357
358 srl %i3,21,%l3 !
359 and %g2,2040,%g2
360 ldx [%i4+%g1],%g1
361 srl %i0,13,%g3
362 and %l3,2040,%l3
363 ldx [%i4+%g2],%g2
364 srl %i1,5,%g4
365 and %g3,2040,%g3
366 ldx [%i4+%l3],%l3 !
367 sll %i2,3,%g5
368 and %g4,2040,%g4
369 ldx [%i4+%g3],%g3
370 and %g5,2040,%g5
371 add %i5,32,%i5
372 ldx [%i4+%g4],%g4
373
374 subcc %i7,1,%i7 !
375 ldx [%i4+%g5],%g5
376 bz,a,pn %icc,.Lenc_last
377 add %i4,2048,%i7
378
379 srlx %o0,8,%o0
380 xor %l0,%l4,%l4
381 ld [%i5+0],%i0
382
383 srlx %o1,16,%o1 !
384 xor %o0,%l4,%l4
385 ld [%i5+4],%i1
386 srlx %o2,24,%o2
387 xor %o1,%l4,%l4
388 ld [%i5+8],%i2
389 srlx %o3,8,%o3
390 xor %o2,%l4,%l4
391 ld [%i5+12],%i3 !
392 srlx %o4,16,%o4
393 xor %l1,%l5,%l5
394
395 srlx %o5,24,%o5
396 xor %o3,%l5,%l5
397 srlx %o7,8,%o7
398 xor %o4,%l5,%l5
399 srlx %g1,16,%g1 !
400 xor %o5,%l5,%l5
401 srlx %g2,24,%g2
402 xor %l2,%l6,%l6
403 srlx %g3,8,%g3
404 xor %o7,%l6,%l6
405 srlx %g4,16,%g4
406 xor %g1,%l6,%l6
407 srlx %g5,24,%g5 !
408 xor %g2,%l6,%l6
409 xor %l3,%g4,%g4
410 xor %g3,%l7,%l7
411 srl %l4,21,%l0
412 xor %g4,%l7,%l7
413 srl %l5,13,%o0
414 xor %g5,%l7,%l7
415
416 and %l0,2040,%l0 !
417 srl %l6,5,%o1
418 and %o0,2040,%o0
419 ldx [%i4+%l0],%l0
420 sll %l7,3,%o2
421 and %o1,2040,%o1
422 ldx [%i4+%o0],%o0
423
424 srl %l5,21,%l1 !
425 and %o2,2040,%o2
426 ldx [%i4+%o1],%o1
427 srl %l6,13,%o3
428 and %l1,2040,%l1
429 ldx [%i4+%o2],%o2
430 srl %l7,5,%o4
431 and %o3,2040,%o3
432 ldx [%i4+%l1],%l1 !
433 sll %l4,3,%o5
434 and %o4,2040,%o4
435 ldx [%i4+%o3],%o3
436 srl %l6,21,%l2
437 and %o5,2040,%o5
438 ldx [%i4+%o4],%o4
439
440 srl %l7,13,%o7 !
441 and %l2,2040,%l2
442 ldx [%i4+%o5],%o5
443 srl %l4,5,%g1
444 and %o7,2040,%o7
445 ldx [%i4+%l2],%l2
446 sll %l5,3,%g2
447 and %g1,2040,%g1
448 ldx [%i4+%o7],%o7 !
449 srl %l7,21,%l3
450 and %g2,2040,%g2
451 ldx [%i4+%g1],%g1
452 srl %l4,13,%g3
453 and %l3,2040,%l3
454 ldx [%i4+%g2],%g2
455
456 srl %l5,5,%g4 !
457 and %g3,2040,%g3
458 ldx [%i4+%l3],%l3
459 sll %l6,3,%g5
460 and %g4,2040,%g4
461 ldx [%i4+%g3],%g3
462 srlx %o0,8,%o0
463 and %g5,2040,%g5
464 ldx [%i4+%g4],%g4 !
465
466 srlx %o1,16,%o1
467 xor %l0,%i0,%i0
468 ldx [%i4+%g5],%g5
469 srlx %o2,24,%o2
470 xor %o0,%i0,%i0
471 ld [%i5+16],%l4
472
473 srlx %o3,8,%o3 !
474 xor %o1,%i0,%i0
475 ld [%i5+20],%l5
476 srlx %o4,16,%o4
477 xor %o2,%i0,%i0
478 ld [%i5+24],%l6
479 srlx %o5,24,%o5
480 xor %l1,%i1,%i1
481 ld [%i5+28],%l7 !
482 srlx %o7,8,%o7
483 xor %o3,%i1,%i1
484 ldx [%i4+2048+0],%g0 ! prefetch te4
485 srlx %g1,16,%g1
486 xor %o4,%i1,%i1
487 ldx [%i4+2048+32],%g0 ! prefetch te4
488 srlx %g2,24,%g2
489 xor %o5,%i1,%i1
490 ldx [%i4+2048+64],%g0 ! prefetch te4
491 srlx %g3,8,%g3
492 xor %l2,%i2,%i2
493 ldx [%i4+2048+96],%g0 ! prefetch te4
494 srlx %g4,16,%g4 !
495 xor %o7,%i2,%i2
496 ldx [%i4+2048+128],%g0 ! prefetch te4
497 srlx %g5,24,%g5
498 xor %g1,%i2,%i2
499 ldx [%i4+2048+160],%g0 ! prefetch te4
500 srl %i0,21,%l0
501 xor %g2,%i2,%i2
502 ldx [%i4+2048+192],%g0 ! prefetch te4
503 xor %l3,%g4,%g4
504 xor %g3,%i3,%i3
505 ldx [%i4+2048+224],%g0 ! prefetch te4
506 srl %i1,13,%o0 !
507 xor %g4,%i3,%i3
508 xor %g5,%i3,%i3
509 ba .Lenc_loop
510 and %l0,2040,%l0
511
512 .align 32
513 .Lenc_last:
514 srlx %o0,8,%o0 !
515 xor %l0,%l4,%l4
516 ld [%i5+0],%i0
517 srlx %o1,16,%o1
518 xor %o0,%l4,%l4
519 ld [%i5+4],%i1
520 srlx %o2,24,%o2
521 xor %o1,%l4,%l4
522 ld [%i5+8],%i2 !
523 srlx %o3,8,%o3
524 xor %o2,%l4,%l4
525 ld [%i5+12],%i3
526 srlx %o4,16,%o4
527 xor %l1,%l5,%l5
528 srlx %o5,24,%o5
529 xor %o3,%l5,%l5
530 srlx %o7,8,%o7 !
531 xor %o4,%l5,%l5
532 srlx %g1,16,%g1
533 xor %o5,%l5,%l5
534 srlx %g2,24,%g2
535 xor %l2,%l6,%l6
536 srlx %g3,8,%g3
537 xor %o7,%l6,%l6
538 srlx %g4,16,%g4 !
539 xor %g1,%l6,%l6
540 srlx %g5,24,%g5
541 xor %g2,%l6,%l6
542 xor %l3,%g4,%g4
543 xor %g3,%l7,%l7
544 srl %l4,24,%l0
545 xor %g4,%l7,%l7
546 srl %l5,16,%o0 !
547 xor %g5,%l7,%l7
548
549 srl %l6,8,%o1
550 and %o0,255,%o0
551 ldub [%i7+%l0],%l0
552 srl %l5,24,%l1
553 and %o1,255,%o1
554 ldub [%i7+%o0],%o0
555 srl %l6,16,%o3 !
556 and %l7,255,%o2
557 ldub [%i7+%o1],%o1
558 ldub [%i7+%o2],%o2
559 srl %l7,8,%o4
560 and %o3,255,%o3
561 ldub [%i7+%l1],%l1
562
563 srl %l6,24,%l2 !
564 and %o4,255,%o4
565 ldub [%i7+%o3],%o3
566 srl %l7,16,%o7
567 and %l4,255,%o5
568 ldub [%i7+%o4],%o4
569 ldub [%i7+%o5],%o5
570
571 srl %l4,8,%g1 !
572 and %o7,255,%o7
573 ldub [%i7+%l2],%l2
574 srl %l7,24,%l3
575 and %g1,255,%g1
576 ldub [%i7+%o7],%o7
577 srl %l4,16,%g3
578 and %l5,255,%g2
579 ldub [%i7+%g1],%g1 !
580 srl %l5,8,%g4
581 and %g3,255,%g3
582 ldub [%i7+%g2],%g2
583 ldub [%i7+%l3],%l3
584 and %g4,255,%g4
585 ldub [%i7+%g3],%g3
586 and %l6,255,%g5
587 ldub [%i7+%g4],%g4 !
588
589 sll %l0,24,%l0
590 xor %o2,%i0,%i0
591 ldub [%i7+%g5],%g5
592 sll %o0,16,%o0
593 xor %l0,%i0,%i0
594 ldx [%sp+STACK_BIAS+STACK_FRAME+0],%i7 ! restore return address
595
596 sll %o1,8,%o1 !
597 xor %o0,%i0,%i0
598 sll %l1,24,%l1
599 xor %o1,%i0,%i0
600 sll %o3,16,%o3
601 xor %o5,%i1,%i1
602 sll %o4,8,%o4
603 xor %l1,%i1,%i1
604 sll %l2,24,%l2 !
605 xor %o3,%i1,%i1
606 sll %o7,16,%o7
607 xor %g2,%i2,%i2
608 sll %g1,8,%g1
609 xor %o4,%i1,%i1
610 sll %l3,24,%l3
611 xor %l2,%i2,%i2
612 sll %g3,16,%g3 !
613 xor %o7,%i2,%i2
614 sll %g4,8,%g4
615 xor %g1,%i2,%i2
616 xor %l3,%g4,%g4
617 xor %g3,%i3,%i3
618 xor %g4,%i3,%i3
619 xor %g5,%i3,%i3
620
621 ret
622 restore
623 .type _sparcv9_AES_encrypt,#function
624 .size _sparcv9_AES_encrypt,(.-_sparcv9_AES_encrypt)
625
626 .align 32
627 .globl AES_encrypt
628 AES_encrypt:
629 or %o0,%o1,%g1
630 andcc %g1,3,%g0
631 bnz,pn %xcc,.Lunaligned_enc
632 save %sp,-STACK_FRAME,%sp
633
634 ld [%i0+0],%o0
635 ld [%i0+4],%o1
636 ld [%i0+8],%o2
637 ld [%i0+12],%o3
638
639 1: call .+8
640 add %o7,AES_Te-1b,%o4
641 call _sparcv9_AES_encrypt
642 mov %i2,%o5
643
644 st %o0,[%i1+0]
645 st %o1,[%i1+4]
646 st %o2,[%i1+8]
647 st %o3,[%i1+12]
648
649 ret
650 restore
651
652 .align 32
653 .Lunaligned_enc:
654 ldub [%i0+0],%l0
655 ldub [%i0+1],%l1
656 ldub [%i0+2],%l2
657
658 sll %l0,24,%l0
659 ldub [%i0+3],%l3
660 sll %l1,16,%l1
661 ldub [%i0+4],%l4
662 sll %l2,8,%l2
663 or %l1,%l0,%l0
664 ldub [%i0+5],%l5
665 sll %l4,24,%l4
666 or %l3,%l2,%l2
667 ldub [%i0+6],%l6
668 sll %l5,16,%l5
669 or %l0,%l2,%o0
670 ldub [%i0+7],%l7
671
672 sll %l6,8,%l6
673 or %l5,%l4,%l4
674 ldub [%i0+8],%l0
675 or %l7,%l6,%l6
676 ldub [%i0+9],%l1
677 or %l4,%l6,%o1
678 ldub [%i0+10],%l2
679
680 sll %l0,24,%l0
681 ldub [%i0+11],%l3
682 sll %l1,16,%l1
683 ldub [%i0+12],%l4
684 sll %l2,8,%l2
685 or %l1,%l0,%l0
686 ldub [%i0+13],%l5
687 sll %l4,24,%l4
688 or %l3,%l2,%l2
689 ldub [%i0+14],%l6
690 sll %l5,16,%l5
691 or %l0,%l2,%o2
692 ldub [%i0+15],%l7
693
694 sll %l6,8,%l6
695 or %l5,%l4,%l4
696 or %l7,%l6,%l6
697 or %l4,%l6,%o3
698
699 1: call .+8
700 add %o7,AES_Te-1b,%o4
701 call _sparcv9_AES_encrypt
702 mov %i2,%o5
703
704 srl %o0,24,%l0
705 srl %o0,16,%l1
706 stb %l0,[%i1+0]
707 srl %o0,8,%l2
708 stb %l1,[%i1+1]
709 stb %l2,[%i1+2]
710 srl %o1,24,%l4
711 stb %o0,[%i1+3]
712
713 srl %o1,16,%l5
714 stb %l4,[%i1+4]
715 srl %o1,8,%l6
716 stb %l5,[%i1+5]
717 stb %l6,[%i1+6]
718 srl %o2,24,%l0
719 stb %o1,[%i1+7]
720
721 srl %o2,16,%l1
722 stb %l0,[%i1+8]
723 srl %o2,8,%l2
724 stb %l1,[%i1+9]
725 stb %l2,[%i1+10]
726 srl %o3,24,%l4
727 stb %o2,[%i1+11]
728
729 srl %o3,16,%l5
730 stb %l4,[%i1+12]
731 srl %o3,8,%l6
732 stb %l5,[%i1+13]
733 stb %l6,[%i1+14]
734 stb %o3,[%i1+15]
735
736 ret
737 restore
738 .type AES_encrypt,#function
739 .size AES_encrypt,(.-AES_encrypt)
740
741 .align 256
742 AES_Td:
743 .long 0x51f4a750,0x51f4a750
744 .long 0x7e416553,0x7e416553
745 .long 0x1a17a4c3,0x1a17a4c3
746 .long 0x3a275e96,0x3a275e96
747 .long 0x3bab6bcb,0x3bab6bcb
748 .long 0x1f9d45f1,0x1f9d45f1
749 .long 0xacfa58ab,0xacfa58ab
750 .long 0x4be30393,0x4be30393
751 .long 0x2030fa55,0x2030fa55
752 .long 0xad766df6,0xad766df6
753 .long 0x88cc7691,0x88cc7691
754 .long 0xf5024c25,0xf5024c25
755 .long 0x4fe5d7fc,0x4fe5d7fc
756 .long 0xc52acbd7,0xc52acbd7
757 .long 0x26354480,0x26354480
758 .long 0xb562a38f,0xb562a38f
759 .long 0xdeb15a49,0xdeb15a49
760 .long 0x25ba1b67,0x25ba1b67
761 .long 0x45ea0e98,0x45ea0e98
762 .long 0x5dfec0e1,0x5dfec0e1
763 .long 0xc32f7502,0xc32f7502
764 .long 0x814cf012,0x814cf012
765 .long 0x8d4697a3,0x8d4697a3
766 .long 0x6bd3f9c6,0x6bd3f9c6
767 .long 0x038f5fe7,0x038f5fe7
768 .long 0x15929c95,0x15929c95
769 .long 0xbf6d7aeb,0xbf6d7aeb
770 .long 0x955259da,0x955259da
771 .long 0xd4be832d,0xd4be832d
772 .long 0x587421d3,0x587421d3
773 .long 0x49e06929,0x49e06929
774 .long 0x8ec9c844,0x8ec9c844
775 .long 0x75c2896a,0x75c2896a
776 .long 0xf48e7978,0xf48e7978
777 .long 0x99583e6b,0x99583e6b
778 .long 0x27b971dd,0x27b971dd
779 .long 0xbee14fb6,0xbee14fb6
780 .long 0xf088ad17,0xf088ad17
781 .long 0xc920ac66,0xc920ac66
782 .long 0x7dce3ab4,0x7dce3ab4
783 .long 0x63df4a18,0x63df4a18
784 .long 0xe51a3182,0xe51a3182
785 .long 0x97513360,0x97513360
786 .long 0x62537f45,0x62537f45
787 .long 0xb16477e0,0xb16477e0
788 .long 0xbb6bae84,0xbb6bae84
789 .long 0xfe81a01c,0xfe81a01c
790 .long 0xf9082b94,0xf9082b94
791 .long 0x70486858,0x70486858
792 .long 0x8f45fd19,0x8f45fd19
793 .long 0x94de6c87,0x94de6c87
794 .long 0x527bf8b7,0x527bf8b7
795 .long 0xab73d323,0xab73d323
796 .long 0x724b02e2,0x724b02e2
797 .long 0xe31f8f57,0xe31f8f57
798 .long 0x6655ab2a,0x6655ab2a
799 .long 0xb2eb2807,0xb2eb2807
800 .long 0x2fb5c203,0x2fb5c203
801 .long 0x86c57b9a,0x86c57b9a
802 .long 0xd33708a5,0xd33708a5
803 .long 0x302887f2,0x302887f2
804 .long 0x23bfa5b2,0x23bfa5b2
805 .long 0x02036aba,0x02036aba
806 .long 0xed16825c,0xed16825c
807 .long 0x8acf1c2b,0x8acf1c2b
808 .long 0xa779b492,0xa779b492
809 .long 0xf307f2f0,0xf307f2f0
810 .long 0x4e69e2a1,0x4e69e2a1
811 .long 0x65daf4cd,0x65daf4cd
812 .long 0x0605bed5,0x0605bed5
813 .long 0xd134621f,0xd134621f
814 .long 0xc4a6fe8a,0xc4a6fe8a
815 .long 0x342e539d,0x342e539d
816 .long 0xa2f355a0,0xa2f355a0
817 .long 0x058ae132,0x058ae132
818 .long 0xa4f6eb75,0xa4f6eb75
819 .long 0x0b83ec39,0x0b83ec39
820 .long 0x4060efaa,0x4060efaa
821 .long 0x5e719f06,0x5e719f06
822 .long 0xbd6e1051,0xbd6e1051
823 .long 0x3e218af9,0x3e218af9
824 .long 0x96dd063d,0x96dd063d
825 .long 0xdd3e05ae,0xdd3e05ae
826 .long 0x4de6bd46,0x4de6bd46
827 .long 0x91548db5,0x91548db5
828 .long 0x71c45d05,0x71c45d05
829 .long 0x0406d46f,0x0406d46f
830 .long 0x605015ff,0x605015ff
831 .long 0x1998fb24,0x1998fb24
832 .long 0xd6bde997,0xd6bde997
833 .long 0x894043cc,0x894043cc
834 .long 0x67d99e77,0x67d99e77
835 .long 0xb0e842bd,0xb0e842bd
836 .long 0x07898b88,0x07898b88
837 .long 0xe7195b38,0xe7195b38
838 .long 0x79c8eedb,0x79c8eedb
839 .long 0xa17c0a47,0xa17c0a47
840 .long 0x7c420fe9,0x7c420fe9
841 .long 0xf8841ec9,0xf8841ec9
842 .long 0x00000000,0x00000000
843 .long 0x09808683,0x09808683
844 .long 0x322bed48,0x322bed48
845 .long 0x1e1170ac,0x1e1170ac
846 .long 0x6c5a724e,0x6c5a724e
847 .long 0xfd0efffb,0xfd0efffb
848 .long 0x0f853856,0x0f853856
849 .long 0x3daed51e,0x3daed51e
850 .long 0x362d3927,0x362d3927
851 .long 0x0a0fd964,0x0a0fd964
852 .long 0x685ca621,0x685ca621
853 .long 0x9b5b54d1,0x9b5b54d1
854 .long 0x24362e3a,0x24362e3a
855 .long 0x0c0a67b1,0x0c0a67b1
856 .long 0x9357e70f,0x9357e70f
857 .long 0xb4ee96d2,0xb4ee96d2
858 .long 0x1b9b919e,0x1b9b919e
859 .long 0x80c0c54f,0x80c0c54f
860 .long 0x61dc20a2,0x61dc20a2
861 .long 0x5a774b69,0x5a774b69
862 .long 0x1c121a16,0x1c121a16
863 .long 0xe293ba0a,0xe293ba0a
864 .long 0xc0a02ae5,0xc0a02ae5
865 .long 0x3c22e043,0x3c22e043
866 .long 0x121b171d,0x121b171d
867 .long 0x0e090d0b,0x0e090d0b
868 .long 0xf28bc7ad,0xf28bc7ad
869 .long 0x2db6a8b9,0x2db6a8b9
870 .long 0x141ea9c8,0x141ea9c8
871 .long 0x57f11985,0x57f11985
872 .long 0xaf75074c,0xaf75074c
873 .long 0xee99ddbb,0xee99ddbb
874 .long 0xa37f60fd,0xa37f60fd
875 .long 0xf701269f,0xf701269f
876 .long 0x5c72f5bc,0x5c72f5bc
877 .long 0x44663bc5,0x44663bc5
878 .long 0x5bfb7e34,0x5bfb7e34
879 .long 0x8b432976,0x8b432976
880 .long 0xcb23c6dc,0xcb23c6dc
881 .long 0xb6edfc68,0xb6edfc68
882 .long 0xb8e4f163,0xb8e4f163
883 .long 0xd731dcca,0xd731dcca
884 .long 0x42638510,0x42638510
885 .long 0x13972240,0x13972240
886 .long 0x84c61120,0x84c61120
887 .long 0x854a247d,0x854a247d
888 .long 0xd2bb3df8,0xd2bb3df8
889 .long 0xaef93211,0xaef93211
890 .long 0xc729a16d,0xc729a16d
891 .long 0x1d9e2f4b,0x1d9e2f4b
892 .long 0xdcb230f3,0xdcb230f3
893 .long 0x0d8652ec,0x0d8652ec
894 .long 0x77c1e3d0,0x77c1e3d0
895 .long 0x2bb3166c,0x2bb3166c
896 .long 0xa970b999,0xa970b999
897 .long 0x119448fa,0x119448fa
898 .long 0x47e96422,0x47e96422
899 .long 0xa8fc8cc4,0xa8fc8cc4
900 .long 0xa0f03f1a,0xa0f03f1a
901 .long 0x567d2cd8,0x567d2cd8
902 .long 0x223390ef,0x223390ef
903 .long 0x87494ec7,0x87494ec7
904 .long 0xd938d1c1,0xd938d1c1
905 .long 0x8ccaa2fe,0x8ccaa2fe
906 .long 0x98d40b36,0x98d40b36
907 .long 0xa6f581cf,0xa6f581cf
908 .long 0xa57ade28,0xa57ade28
909 .long 0xdab78e26,0xdab78e26
910 .long 0x3fadbfa4,0x3fadbfa4
911 .long 0x2c3a9de4,0x2c3a9de4
912 .long 0x5078920d,0x5078920d
913 .long 0x6a5fcc9b,0x6a5fcc9b
914 .long 0x547e4662,0x547e4662
915 .long 0xf68d13c2,0xf68d13c2
916 .long 0x90d8b8e8,0x90d8b8e8
917 .long 0x2e39f75e,0x2e39f75e
918 .long 0x82c3aff5,0x82c3aff5
919 .long 0x9f5d80be,0x9f5d80be
920 .long 0x69d0937c,0x69d0937c
921 .long 0x6fd52da9,0x6fd52da9
922 .long 0xcf2512b3,0xcf2512b3
923 .long 0xc8ac993b,0xc8ac993b
924 .long 0x10187da7,0x10187da7
925 .long 0xe89c636e,0xe89c636e
926 .long 0xdb3bbb7b,0xdb3bbb7b
927 .long 0xcd267809,0xcd267809
928 .long 0x6e5918f4,0x6e5918f4
929 .long 0xec9ab701,0xec9ab701
930 .long 0x834f9aa8,0x834f9aa8
931 .long 0xe6956e65,0xe6956e65
932 .long 0xaaffe67e,0xaaffe67e
933 .long 0x21bccf08,0x21bccf08
934 .long 0xef15e8e6,0xef15e8e6
935 .long 0xbae79bd9,0xbae79bd9
936 .long 0x4a6f36ce,0x4a6f36ce
937 .long 0xea9f09d4,0xea9f09d4
938 .long 0x29b07cd6,0x29b07cd6
939 .long 0x31a4b2af,0x31a4b2af
940 .long 0x2a3f2331,0x2a3f2331
941 .long 0xc6a59430,0xc6a59430
942 .long 0x35a266c0,0x35a266c0
943 .long 0x744ebc37,0x744ebc37
944 .long 0xfc82caa6,0xfc82caa6
945 .long 0xe090d0b0,0xe090d0b0
946 .long 0x33a7d815,0x33a7d815
947 .long 0xf104984a,0xf104984a
948 .long 0x41ecdaf7,0x41ecdaf7
949 .long 0x7fcd500e,0x7fcd500e
950 .long 0x1791f62f,0x1791f62f
951 .long 0x764dd68d,0x764dd68d
952 .long 0x43efb04d,0x43efb04d
953 .long 0xccaa4d54,0xccaa4d54
954 .long 0xe49604df,0xe49604df
955 .long 0x9ed1b5e3,0x9ed1b5e3
956 .long 0x4c6a881b,0x4c6a881b
957 .long 0xc12c1fb8,0xc12c1fb8
958 .long 0x4665517f,0x4665517f
959 .long 0x9d5eea04,0x9d5eea04
960 .long 0x018c355d,0x018c355d
961 .long 0xfa877473,0xfa877473
962 .long 0xfb0b412e,0xfb0b412e
963 .long 0xb3671d5a,0xb3671d5a
964 .long 0x92dbd252,0x92dbd252
965 .long 0xe9105633,0xe9105633
966 .long 0x6dd64713,0x6dd64713
967 .long 0x9ad7618c,0x9ad7618c
968 .long 0x37a10c7a,0x37a10c7a
969 .long 0x59f8148e,0x59f8148e
970 .long 0xeb133c89,0xeb133c89
971 .long 0xcea927ee,0xcea927ee
972 .long 0xb761c935,0xb761c935
973 .long 0xe11ce5ed,0xe11ce5ed
974 .long 0x7a47b13c,0x7a47b13c
975 .long 0x9cd2df59,0x9cd2df59
976 .long 0x55f2733f,0x55f2733f
977 .long 0x1814ce79,0x1814ce79
978 .long 0x73c737bf,0x73c737bf
979 .long 0x53f7cdea,0x53f7cdea
980 .long 0x5ffdaa5b,0x5ffdaa5b
981 .long 0xdf3d6f14,0xdf3d6f14
982 .long 0x7844db86,0x7844db86
983 .long 0xcaaff381,0xcaaff381
984 .long 0xb968c43e,0xb968c43e
985 .long 0x3824342c,0x3824342c
986 .long 0xc2a3405f,0xc2a3405f
987 .long 0x161dc372,0x161dc372
988 .long 0xbce2250c,0xbce2250c
989 .long 0x283c498b,0x283c498b
990 .long 0xff0d9541,0xff0d9541
991 .long 0x39a80171,0x39a80171
992 .long 0x080cb3de,0x080cb3de
993 .long 0xd8b4e49c,0xd8b4e49c
994 .long 0x6456c190,0x6456c190
995 .long 0x7bcb8461,0x7bcb8461
996 .long 0xd532b670,0xd532b670
997 .long 0x486c5c74,0x486c5c74
998 .long 0xd0b85742,0xd0b85742
999 .byte 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38
1000 .byte 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb
1001 .byte 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87
1002 .byte 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb
1003 .byte 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d
1004 .byte 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e
1005 .byte 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2
1006 .byte 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25
1007 .byte 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16
1008 .byte 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92
1009 .byte 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda
1010 .byte 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84
1011 .byte 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a
1012 .byte 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06
1013 .byte 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02
1014 .byte 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b
1015 .byte 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea
1016 .byte 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73
1017 .byte 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85
1018 .byte 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e
1019 .byte 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89
1020 .byte 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b
1021 .byte 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20
1022 .byte 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4
1023 .byte 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31
1024 .byte 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f
1025 .byte 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d
1026 .byte 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef
1027 .byte 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0
1028 .byte 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61
1029 .byte 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26
1030 .byte 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d
1031 .type AES_Td,#object
1032 .size AES_Td,(.-AES_Td)
1033
1034 .align 64
1035 .skip 16
1036 _sparcv9_AES_decrypt:
1037 save %sp,-STACK_FRAME-16,%sp
1038 stx %i7,[%sp+STACK_BIAS+STACK_FRAME+0] ! off-load return address
1039 ld [%i5+240],%i7
1040 ld [%i5+0],%l4
1041 ld [%i5+4],%l5 !
1042 ld [%i5+8],%l6
1043 ld [%i5+12],%l7
1044 srl %i7,1,%i7
1045 xor %l4,%i0,%i0
1046 ld [%i5+16],%l4
1047 xor %l5,%i1,%i1
1048 ld [%i5+20],%l5
1049 srl %i0,21,%l0 !
1050 xor %l6,%i2,%i2
1051 ld [%i5+24],%l6
1052 xor %l7,%i3,%i3
1053 and %l0,2040,%l0
1054 ld [%i5+28],%l7
1055 srl %i3,13,%o0
1056 nop
1057 .Ldec_loop:
1058 srl %i2,5,%o1 !
1059 and %o0,2040,%o0
1060 ldx [%i4+%l0],%l0
1061 sll %i1,3,%o2
1062 and %o1,2040,%o1
1063 ldx [%i4+%o0],%o0
1064 srl %i1,21,%l1
1065 and %o2,2040,%o2
1066 ldx [%i4+%o1],%o1 !
1067 srl %i0,13,%o3
1068 and %l1,2040,%l1
1069 ldx [%i4+%o2],%o2
1070 srl %i3,5,%o4
1071 and %o3,2040,%o3
1072 ldx [%i4+%l1],%l1
1073
1074 sll %i2,3,%o5 !
1075 and %o4,2040,%o4
1076 ldx [%i4+%o3],%o3
1077 srl %i2,21,%l2
1078 and %o5,2040,%o5
1079 ldx [%i4+%o4],%o4
1080 srl %i1,13,%o7
1081 and %l2,2040,%l2
1082 ldx [%i4+%o5],%o5 !
1083 srl %i0,5,%g1
1084 and %o7,2040,%o7
1085 ldx [%i4+%l2],%l2
1086 sll %i3,3,%g2
1087 and %g1,2040,%g1
1088 ldx [%i4+%o7],%o7
1089
1090 srl %i3,21,%l3 !
1091 and %g2,2040,%g2
1092 ldx [%i4+%g1],%g1
1093 srl %i2,13,%g3
1094 and %l3,2040,%l3
1095 ldx [%i4+%g2],%g2
1096 srl %i1,5,%g4
1097 and %g3,2040,%g3
1098 ldx [%i4+%l3],%l3 !
1099 sll %i0,3,%g5
1100 and %g4,2040,%g4
1101 ldx [%i4+%g3],%g3
1102 and %g5,2040,%g5
1103 add %i5,32,%i5
1104 ldx [%i4+%g4],%g4
1105
1106 subcc %i7,1,%i7 !
1107 ldx [%i4+%g5],%g5
1108 bz,a,pn %icc,.Ldec_last
1109 add %i4,2048,%i7
1110
1111 srlx %o0,8,%o0
1112 xor %l0,%l4,%l4
1113 ld [%i5+0],%i0
1114
1115 srlx %o1,16,%o1 !
1116 xor %o0,%l4,%l4
1117 ld [%i5+4],%i1
1118 srlx %o2,24,%o2
1119 xor %o1,%l4,%l4
1120 ld [%i5+8],%i2
1121 srlx %o3,8,%o3
1122 xor %o2,%l4,%l4
1123 ld [%i5+12],%i3 !
1124 srlx %o4,16,%o4
1125 xor %l1,%l5,%l5
1126
1127 srlx %o5,24,%o5
1128 xor %o3,%l5,%l5
1129 srlx %o7,8,%o7
1130 xor %o4,%l5,%l5
1131 srlx %g1,16,%g1 !
1132 xor %o5,%l5,%l5
1133 srlx %g2,24,%g2
1134 xor %l2,%l6,%l6
1135 srlx %g3,8,%g3
1136 xor %o7,%l6,%l6
1137 srlx %g4,16,%g4
1138 xor %g1,%l6,%l6
1139 srlx %g5,24,%g5 !
1140 xor %g2,%l6,%l6
1141 xor %l3,%g4,%g4
1142 xor %g3,%l7,%l7
1143 srl %l4,21,%l0
1144 xor %g4,%l7,%l7
1145 xor %g5,%l7,%l7
1146 srl %l7,13,%o0
1147
1148 and %l0,2040,%l0 !
1149 srl %l6,5,%o1
1150 and %o0,2040,%o0
1151 ldx [%i4+%l0],%l0
1152 sll %l5,3,%o2
1153 and %o1,2040,%o1
1154 ldx [%i4+%o0],%o0
1155
1156 srl %l5,21,%l1 !
1157 and %o2,2040,%o2
1158 ldx [%i4+%o1],%o1
1159 srl %l4,13,%o3
1160 and %l1,2040,%l1
1161 ldx [%i4+%o2],%o2
1162 srl %l7,5,%o4
1163 and %o3,2040,%o3
1164 ldx [%i4+%l1],%l1 !
1165 sll %l6,3,%o5
1166 and %o4,2040,%o4
1167 ldx [%i4+%o3],%o3
1168 srl %l6,21,%l2
1169 and %o5,2040,%o5
1170 ldx [%i4+%o4],%o4
1171
1172 srl %l5,13,%o7 !
1173 and %l2,2040,%l2
1174 ldx [%i4+%o5],%o5
1175 srl %l4,5,%g1
1176 and %o7,2040,%o7
1177 ldx [%i4+%l2],%l2
1178 sll %l7,3,%g2
1179 and %g1,2040,%g1
1180 ldx [%i4+%o7],%o7 !
1181 srl %l7,21,%l3
1182 and %g2,2040,%g2
1183 ldx [%i4+%g1],%g1
1184 srl %l6,13,%g3
1185 and %l3,2040,%l3
1186 ldx [%i4+%g2],%g2
1187
1188 srl %l5,5,%g4 !
1189 and %g3,2040,%g3
1190 ldx [%i4+%l3],%l3
1191 sll %l4,3,%g5
1192 and %g4,2040,%g4
1193 ldx [%i4+%g3],%g3
1194 srlx %o0,8,%o0
1195 and %g5,2040,%g5
1196 ldx [%i4+%g4],%g4 !
1197
1198 srlx %o1,16,%o1
1199 xor %l0,%i0,%i0
1200 ldx [%i4+%g5],%g5
1201 srlx %o2,24,%o2
1202 xor %o0,%i0,%i0
1203 ld [%i5+16],%l4
1204
1205 srlx %o3,8,%o3 !
1206 xor %o1,%i0,%i0
1207 ld [%i5+20],%l5
1208 srlx %o4,16,%o4
1209 xor %o2,%i0,%i0
1210 ld [%i5+24],%l6
1211 srlx %o5,24,%o5
1212 xor %l1,%i1,%i1
1213 ld [%i5+28],%l7 !
1214 srlx %o7,8,%o7
1215 xor %o3,%i1,%i1
1216 ldx [%i4+2048+0],%g0 ! prefetch td4
1217 srlx %g1,16,%g1
1218 xor %o4,%i1,%i1
1219 ldx [%i4+2048+32],%g0 ! prefetch td4
1220 srlx %g2,24,%g2
1221 xor %o5,%i1,%i1
1222 ldx [%i4+2048+64],%g0 ! prefetch td4
1223 srlx %g3,8,%g3
1224 xor %l2,%i2,%i2
1225 ldx [%i4+2048+96],%g0 ! prefetch td4
1226 srlx %g4,16,%g4 !
1227 xor %o7,%i2,%i2
1228 ldx [%i4+2048+128],%g0 ! prefetch td4
1229 srlx %g5,24,%g5
1230 xor %g1,%i2,%i2
1231 ldx [%i4+2048+160],%g0 ! prefetch td4
1232 srl %i0,21,%l0
1233 xor %g2,%i2,%i2
1234 ldx [%i4+2048+192],%g0 ! prefetch td4
1235 xor %l3,%g4,%g4
1236 xor %g3,%i3,%i3
1237 ldx [%i4+2048+224],%g0 ! prefetch td4
1238 and %l0,2040,%l0 !
1239 xor %g4,%i3,%i3
1240 xor %g5,%i3,%i3
1241 ba .Ldec_loop
1242 srl %i3,13,%o0
1243
1244 .align 32
1245 .Ldec_last:
1246 srlx %o0,8,%o0 !
1247 xor %l0,%l4,%l4
1248 ld [%i5+0],%i0
1249 srlx %o1,16,%o1
1250 xor %o0,%l4,%l4
1251 ld [%i5+4],%i1
1252 srlx %o2,24,%o2
1253 xor %o1,%l4,%l4
1254 ld [%i5+8],%i2 !
1255 srlx %o3,8,%o3
1256 xor %o2,%l4,%l4
1257 ld [%i5+12],%i3
1258 srlx %o4,16,%o4
1259 xor %l1,%l5,%l5
1260 srlx %o5,24,%o5
1261 xor %o3,%l5,%l5
1262 srlx %o7,8,%o7 !
1263 xor %o4,%l5,%l5
1264 srlx %g1,16,%g1
1265 xor %o5,%l5,%l5
1266 srlx %g2,24,%g2
1267 xor %l2,%l6,%l6
1268 srlx %g3,8,%g3
1269 xor %o7,%l6,%l6
1270 srlx %g4,16,%g4 !
1271 xor %g1,%l6,%l6
1272 srlx %g5,24,%g5
1273 xor %g2,%l6,%l6
1274 xor %l3,%g4,%g4
1275 xor %g3,%l7,%l7
1276 srl %l4,24,%l0
1277 xor %g4,%l7,%l7
1278 xor %g5,%l7,%l7 !
1279 srl %l7,16,%o0
1280
1281 srl %l6,8,%o1
1282 and %o0,255,%o0
1283 ldub [%i7+%l0],%l0
1284 srl %l5,24,%l1
1285 and %o1,255,%o1
1286 ldub [%i7+%o0],%o0
1287 srl %l4,16,%o3 !
1288 and %l5,255,%o2
1289 ldub [%i7+%o1],%o1
1290 ldub [%i7+%o2],%o2
1291 srl %l7,8,%o4
1292 and %o3,255,%o3
1293 ldub [%i7+%l1],%l1
1294
1295 srl %l6,24,%l2 !
1296 and %o4,255,%o4
1297 ldub [%i7+%o3],%o3
1298 srl %l5,16,%o7
1299 and %l6,255,%o5
1300 ldub [%i7+%o4],%o4
1301 ldub [%i7+%o5],%o5
1302
1303 srl %l4,8,%g1 !
1304 and %o7,255,%o7
1305 ldub [%i7+%l2],%l2
1306 srl %l7,24,%l3
1307 and %g1,255,%g1
1308 ldub [%i7+%o7],%o7
1309 srl %l6,16,%g3
1310 and %l7,255,%g2
1311 ldub [%i7+%g1],%g1 !
1312 srl %l5,8,%g4
1313 and %g3,255,%g3
1314 ldub [%i7+%g2],%g2
1315 ldub [%i7+%l3],%l3
1316 and %g4,255,%g4
1317 ldub [%i7+%g3],%g3
1318 and %l4,255,%g5
1319 ldub [%i7+%g4],%g4 !
1320
1321 sll %l0,24,%l0
1322 xor %o2,%i0,%i0
1323 ldub [%i7+%g5],%g5
1324 sll %o0,16,%o0
1325 xor %l0,%i0,%i0
1326 ldx [%sp+STACK_BIAS+STACK_FRAME+0],%i7 ! restore return address
1327
1328 sll %o1,8,%o1 !
1329 xor %o0,%i0,%i0
1330 sll %l1,24,%l1
1331 xor %o1,%i0,%i0
1332 sll %o3,16,%o3
1333 xor %o5,%i1,%i1
1334 sll %o4,8,%o4
1335 xor %l1,%i1,%i1
1336 sll %l2,24,%l2 !
1337 xor %o3,%i1,%i1
1338 sll %o7,16,%o7
1339 xor %g2,%i2,%i2
1340 sll %g1,8,%g1
1341 xor %o4,%i1,%i1
1342 sll %l3,24,%l3
1343 xor %l2,%i2,%i2
1344 sll %g3,16,%g3 !
1345 xor %o7,%i2,%i2
1346 sll %g4,8,%g4
1347 xor %g1,%i2,%i2
1348 xor %l3,%g4,%g4
1349 xor %g3,%i3,%i3
1350 xor %g4,%i3,%i3
1351 xor %g5,%i3,%i3
1352
1353 ret
1354 restore
1355 .type _sparcv9_AES_decrypt,#function
1356 .size _sparcv9_AES_decrypt,(.-_sparcv9_AES_decrypt)
1357
1358 .align 32
1359 .globl AES_decrypt
1360 AES_decrypt:
1361 or %o0,%o1,%g1
1362 andcc %g1,3,%g0
1363 bnz,pn %xcc,.Lunaligned_dec
1364 save %sp,-STACK_FRAME,%sp
1365
1366 ld [%i0+0],%o0
1367 ld [%i0+4],%o1
1368 ld [%i0+8],%o2
1369 ld [%i0+12],%o3
1370
1371 1: call .+8
1372 add %o7,AES_Td-1b,%o4
1373 call _sparcv9_AES_decrypt
1374 mov %i2,%o5
1375
1376 st %o0,[%i1+0]
1377 st %o1,[%i1+4]
1378 st %o2,[%i1+8]
1379 st %o3,[%i1+12]
1380
1381 ret
1382 restore
1383
1384 .align 32
1385 .Lunaligned_dec:
1386 ldub [%i0+0],%l0
1387 ldub [%i0+1],%l1
1388 ldub [%i0+2],%l2
1389
1390 sll %l0,24,%l0
1391 ldub [%i0+3],%l3
1392 sll %l1,16,%l1
1393 ldub [%i0+4],%l4
1394 sll %l2,8,%l2
1395 or %l1,%l0,%l0
1396 ldub [%i0+5],%l5
1397 sll %l4,24,%l4
1398 or %l3,%l2,%l2
1399 ldub [%i0+6],%l6
1400 sll %l5,16,%l5
1401 or %l0,%l2,%o0
1402 ldub [%i0+7],%l7
1403
1404 sll %l6,8,%l6
1405 or %l5,%l4,%l4
1406 ldub [%i0+8],%l0
1407 or %l7,%l6,%l6
1408 ldub [%i0+9],%l1
1409 or %l4,%l6,%o1
1410 ldub [%i0+10],%l2
1411
1412 sll %l0,24,%l0
1413 ldub [%i0+11],%l3
1414 sll %l1,16,%l1
1415 ldub [%i0+12],%l4
1416 sll %l2,8,%l2
1417 or %l1,%l0,%l0
1418 ldub [%i0+13],%l5
1419 sll %l4,24,%l4
1420 or %l3,%l2,%l2
1421 ldub [%i0+14],%l6
1422 sll %l5,16,%l5
1423 or %l0,%l2,%o2
1424 ldub [%i0+15],%l7
1425
1426 sll %l6,8,%l6
1427 or %l5,%l4,%l4
1428 or %l7,%l6,%l6
1429 or %l4,%l6,%o3
1430
1431 1: call .+8
1432 add %o7,AES_Td-1b,%o4
1433 call _sparcv9_AES_decrypt
1434 mov %i2,%o5
1435
1436 srl %o0,24,%l0
1437 srl %o0,16,%l1
1438 stb %l0,[%i1+0]
1439 srl %o0,8,%l2
1440 stb %l1,[%i1+1]
1441 stb %l2,[%i1+2]
1442 srl %o1,24,%l4
1443 stb %o0,[%i1+3]
1444
1445 srl %o1,16,%l5
1446 stb %l4,[%i1+4]
1447 srl %o1,8,%l6
1448 stb %l5,[%i1+5]
1449 stb %l6,[%i1+6]
1450 srl %o2,24,%l0
1451 stb %o1,[%i1+7]
1452
1453 srl %o2,16,%l1
1454 stb %l0,[%i1+8]
1455 srl %o2,8,%l2
1456 stb %l1,[%i1+9]
1457 stb %l2,[%i1+10]
1458 srl %o3,24,%l4
1459 stb %o2,[%i1+11]
1460
1461 srl %o3,16,%l5
1462 stb %l4,[%i1+12]
1463 srl %o3,8,%l6
1464 stb %l5,[%i1+13]
1465 stb %l6,[%i1+14]
1466 stb %o3,[%i1+15]
1467
1468 ret
1469 restore
1470 .type AES_decrypt,#function
1471 .size AES_decrypt,(.-AES_decrypt)
1472