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
10AES_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
628AES_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
6391:	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
6991:	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
742AES_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
1360AES_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
13711:	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
14311:	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