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