• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83.globl	.bn_sqr_comba4
84.globl	.bn_sqr_comba8
85.globl	.bn_mul_comba4
86.globl	.bn_mul_comba8
87.globl	.bn_sub_words
88.globl	.bn_add_words
89.globl	.bn_div_words
90.globl	.bn_sqr_words
91.globl	.bn_mul_words
92.globl	.bn_mul_add_words
93
94
95
96.machine	"any"
97.csect	.text[PR],7
98
99
100
101
102
103
104
105
106.align	4
107.bn_sqr_comba4:
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123	xor	0,0,0
124
125
126
127	ld	5,0(4)
128	mulld	9,5,5
129	mulhdu	10,5,5
130
131
132
133
134	std	9,0(3)
135
136	ld	6,8(4)
137	mulld	7,5,6
138	mulhdu	8,5,6
139
140	addc	7,7,7
141	adde	8,8,8
142	addze	9,0
143
144
145	addc	10,7,10
146	addze	11,8
147	addze	9,9
148
149	std	10,8(3)
150
151	mulld	7,6,6
152	mulhdu	8,6,6
153	addc	11,7,11
154	adde	9,8,9
155	addze	10,0
156
157	ld	6,16(4)
158	mulld	7,5,6
159	mulhdu	8,5,6
160
161	addc	7,7,7
162	adde	8,8,8
163	addze	10,10
164
165	addc	11,7,11
166	adde	9,8,9
167	addze	10,10
168	std	11,16(3)
169
170	ld	6,24(4)
171	mulld	7,5,6
172	mulhdu	8,5,6
173	addc	7,7,7
174	adde	8,8,8
175	addze	11,0
176
177	addc	9,7,9
178	adde	10,8,10
179	addze	11,11
180
181	ld	5,8(4)
182	ld	6,16(4)
183	mulld	7,5,6
184	mulhdu	8,5,6
185
186	addc	7,7,7
187	adde	8,8,8
188	addze	11,11
189	addc	9,7,9
190	adde	10,8,10
191	addze	11,11
192	std	9,24(3)
193
194	mulld	7,6,6
195	mulhdu	8,6,6
196	addc	10,7,10
197	adde	11,8,11
198	addze	9,0
199
200	ld	6,24(4)
201	mulld	7,5,6
202	mulhdu	8,5,6
203	addc	7,7,7
204	adde	8,8,8
205	addze	9,9
206
207	addc	10,7,10
208	adde	11,8,11
209	addze	9,9
210	std	10,32(3)
211
212	ld	5,16(4)
213	mulld	7,5,6
214	mulhdu	8,5,6
215	addc	7,7,7
216	adde	8,8,8
217	addze	10,0
218
219	addc	11,7,11
220	adde	9,8,9
221	addze	10,10
222	std	11,40(3)
223
224	mulld	7,6,6
225	mulhdu	8,6,6
226	addc	9,7,9
227	adde	10,8,10
228
229	std	9,48(3)
230	std	10,56(3)
231	blr
232.long	0
233.byte	0,12,0x14,0,0,0,2,0
234.long	0
235
236
237
238
239
240
241
242
243
244.align	4
245.bn_sqr_comba8:
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265	xor	0,0,0
266
267
268
269	ld	5,0(4)
270	mulld	9,5,5
271	mulhdu	10,5,5
272	std	9,0(3)
273
274	ld	6,8(4)
275	mulld	7,5,6
276	mulhdu	8,5,6
277
278	addc	10,7,10
279	adde	11,8,0
280	addze	9,0
281
282	addc	10,7,10
283	adde	11,8,11
284	addze	9,9
285
286	std	10,8(3)
287
288
289	mulld	7,6,6
290	mulhdu	8,6,6
291	addc	11,7,11
292	adde	9,8,9
293	addze	10,0
294
295	ld	6,16(4)
296	mulld	7,5,6
297	mulhdu	8,5,6
298
299	addc	11,7,11
300	adde	9,8,9
301	addze	10,10
302
303	addc	11,7,11
304	adde	9,8,9
305	addze	10,10
306
307	std	11,16(3)
308
309	ld	6,24(4)
310	mulld	7,5,6
311	mulhdu	8,5,6
312
313	addc	9,7,9
314	adde	10,8,10
315	addze	11,0
316
317	addc	9,7,9
318	adde	10,8,10
319	addze	11,11
320
321	ld	5,8(4)
322	ld	6,16(4)
323	mulld	7,5,6
324	mulhdu	8,5,6
325
326	addc	9,7,9
327	adde	10,8,10
328	addze	11,11
329
330	addc	9,7,9
331	adde	10,8,10
332	addze	11,11
333
334	std	9,24(3)
335
336	mulld	7,6,6
337	mulhdu	8,6,6
338
339	addc	10,7,10
340	adde	11,8,11
341	addze	9,0
342
343	ld	6,24(4)
344	mulld	7,5,6
345	mulhdu	8,5,6
346
347	addc	10,7,10
348	adde	11,8,11
349	addze	9,9
350
351	addc	10,7,10
352	adde	11,8,11
353	addze	9,9
354
355	ld	5,0(4)
356	ld	6,32(4)
357	mulld	7,5,6
358	mulhdu	8,5,6
359
360	addc	10,7,10
361	adde	11,8,11
362	addze	9,9
363
364	addc	10,7,10
365	adde	11,8,11
366	addze	9,9
367	std	10,32(3)
368
369	ld	6,40(4)
370	mulld	7,5,6
371	mulhdu	8,5,6
372
373	addc	11,7,11
374	adde	9,8,9
375	addze	10,0
376
377	addc	11,7,11
378	adde	9,8,9
379	addze	10,10
380
381	ld	5,8(4)
382	ld	6,32(4)
383	mulld	7,5,6
384	mulhdu	8,5,6
385
386	addc	11,7,11
387	adde	9,8,9
388	addze	10,10
389
390	addc	11,7,11
391	adde	9,8,9
392	addze	10,10
393
394	ld	5,16(4)
395	ld	6,24(4)
396	mulld	7,5,6
397	mulhdu	8,5,6
398
399	addc	11,7,11
400	adde	9,8,9
401	addze	10,10
402
403	addc	11,7,11
404	adde	9,8,9
405	addze	10,10
406	std	11,40(3)
407
408	mulld	7,6,6
409	mulhdu	8,6,6
410	addc	9,7,9
411	adde	10,8,10
412	addze	11,0
413
414	ld	6,32(4)
415	mulld	7,5,6
416	mulhdu	8,5,6
417
418	addc	9,7,9
419	adde	10,8,10
420	addze	11,11
421
422	addc	9,7,9
423	adde	10,8,10
424	addze	11,11
425
426	ld	5,8(4)
427	ld	6,40(4)
428	mulld	7,5,6
429	mulhdu	8,5,6
430
431	addc	9,7,9
432	adde	10,8,10
433	addze	11,11
434
435	addc	9,7,9
436	adde	10,8,10
437	addze	11,11
438
439	ld	5,0(4)
440	ld	6,48(4)
441	mulld	7,5,6
442	mulhdu	8,5,6
443	addc	9,7,9
444	adde	10,8,10
445	addze	11,11
446	addc	9,7,9
447	adde	10,8,10
448	addze	11,11
449	std	9,48(3)
450
451	ld	6,56(4)
452	mulld	7,5,6
453	mulhdu	8,5,6
454
455	addc	10,7,10
456	adde	11,8,11
457	addze	9,0
458	addc	10,7,10
459	adde	11,8,11
460	addze	9,9
461
462	ld	5,8(4)
463	ld	6,48(4)
464	mulld	7,5,6
465	mulhdu	8,5,6
466
467	addc	10,7,10
468	adde	11,8,11
469	addze	9,9
470	addc	10,7,10
471	adde	11,8,11
472	addze	9,9
473
474	ld	5,16(4)
475	ld	6,40(4)
476	mulld	7,5,6
477	mulhdu	8,5,6
478	addc	10,7,10
479	adde	11,8,11
480	addze	9,9
481	addc	10,7,10
482	adde	11,8,11
483	addze	9,9
484
485	ld	5,24(4)
486	ld	6,32(4)
487	mulld	7,5,6
488	mulhdu	8,5,6
489
490	addc	10,7,10
491	adde	11,8,11
492	addze	9,9
493	addc	10,7,10
494	adde	11,8,11
495	addze	9,9
496	std	10,56(3)
497
498	mulld	7,6,6
499	mulhdu	8,6,6
500	addc	11,7,11
501	adde	9,8,9
502	addze	10,0
503
504	ld	6,40(4)
505	mulld	7,5,6
506	mulhdu	8,5,6
507	addc	11,7,11
508	adde	9,8,9
509	addze	10,10
510	addc	11,7,11
511	adde	9,8,9
512	addze	10,10
513
514	ld	5,16(4)
515	ld	6,48(4)
516	mulld	7,5,6
517	mulhdu	8,5,6
518	addc	11,7,11
519	adde	9,8,9
520	addze	10,10
521
522	addc	11,7,11
523	adde	9,8,9
524	addze	10,10
525
526	ld	5,8(4)
527	ld	6,56(4)
528	mulld	7,5,6
529	mulhdu	8,5,6
530	addc	11,7,11
531	adde	9,8,9
532	addze	10,10
533	addc	11,7,11
534	adde	9,8,9
535	addze	10,10
536	std	11,64(3)
537
538	ld	5,16(4)
539	mulld	7,5,6
540	mulhdu	8,5,6
541
542	addc	9,7,9
543	adde	10,8,10
544	addze	11,0
545	addc	9,7,9
546	adde	10,8,10
547	addze	11,11
548
549	ld	5,24(4)
550	ld	6,48(4)
551	mulld	7,5,6
552	mulhdu	8,5,6
553	addc	9,7,9
554	adde	10,8,10
555	addze	11,11
556	addc	9,7,9
557	adde	10,8,10
558	addze	11,11
559
560	ld	5,32(4)
561	ld	6,40(4)
562	mulld	7,5,6
563	mulhdu	8,5,6
564	addc	9,7,9
565	adde	10,8,10
566	addze	11,11
567	addc	9,7,9
568	adde	10,8,10
569	addze	11,11
570	std	9,72(3)
571
572	mulld	7,6,6
573	mulhdu	8,6,6
574	addc	10,7,10
575	adde	11,8,11
576	addze	9,0
577
578	ld	6,48(4)
579	mulld	7,5,6
580	mulhdu	8,5,6
581	addc	10,7,10
582	adde	11,8,11
583	addze	9,9
584	addc	10,7,10
585	adde	11,8,11
586	addze	9,9
587
588	ld	5,24(4)
589	ld	6,56(4)
590	mulld	7,5,6
591	mulhdu	8,5,6
592	addc	10,7,10
593	adde	11,8,11
594	addze	9,9
595	addc	10,7,10
596	adde	11,8,11
597	addze	9,9
598	std	10,80(3)
599
600	ld	5,32(4)
601	mulld	7,5,6
602	mulhdu	8,5,6
603	addc	11,7,11
604	adde	9,8,9
605	addze	10,0
606	addc	11,7,11
607	adde	9,8,9
608	addze	10,10
609
610	ld	5,40(4)
611	ld	6,48(4)
612	mulld	7,5,6
613	mulhdu	8,5,6
614	addc	11,7,11
615	adde	9,8,9
616	addze	10,10
617	addc	11,7,11
618	adde	9,8,9
619	addze	10,10
620	std	11,88(3)
621
622	mulld	7,6,6
623	mulhdu	8,6,6
624	addc	9,7,9
625	adde	10,8,10
626	addze	11,0
627
628	ld	6,56(4)
629	mulld	7,5,6
630	mulhdu	8,5,6
631	addc	9,7,9
632	adde	10,8,10
633	addze	11,11
634	addc	9,7,9
635	adde	10,8,10
636	addze	11,11
637	std	9,96(3)
638
639
640	ld	5,48(4)
641	mulld	7,5,6
642	mulhdu	8,5,6
643	addc	10,7,10
644	adde	11,8,11
645	addze	9,0
646	addc	10,7,10
647	adde	11,8,11
648	addze	9,9
649	std	10,104(3)
650
651	mulld	7,6,6
652	mulhdu	8,6,6
653	addc	11,7,11
654	adde	9,8,9
655	std	11,112(3)
656	std	9, 120(3)
657
658
659	blr
660.long	0
661.byte	0,12,0x14,0,0,0,2,0
662.long	0
663
664
665
666
667
668
669
670
671
672.align	4
673.bn_mul_comba4:
674
675
676
677
678
679
680
681
682
683
684
685	xor	0,0,0
686
687	ld	6,0(4)
688	ld	7,0(5)
689	mulld	10,6,7
690	mulhdu	11,6,7
691	std	10,0(3)
692
693	ld	7,8(5)
694	mulld	8,6,7
695	mulhdu	9,6,7
696	addc	11,8,11
697	adde	12,9,0
698	addze	10,0
699
700	ld	6, 8(4)
701	ld	7, 0(5)
702	mulld	8,6,7
703	mulhdu	9,6,7
704	addc	11,8,11
705	adde	12,9,12
706	addze	10,10
707	std	11,8(3)
708
709	ld	6,16(4)
710	mulld	8,6,7
711	mulhdu	9,6,7
712	addc	12,8,12
713	adde	10,9,10
714	addze	11,0
715
716	ld	6,8(4)
717	ld	7,8(5)
718	mulld	8,6,7
719	mulhdu	9,6,7
720	addc	12,8,12
721	adde	10,9,10
722	addze	11,11
723
724	ld	6,0(4)
725	ld	7,16(5)
726	mulld	8,6,7
727	mulhdu	9,6,7
728	addc	12,8,12
729	adde	10,9,10
730	addze	11,11
731	std	12,16(3)
732
733	ld	7,24(5)
734	mulld	8,6,7
735	mulhdu	9,6,7
736	addc	10,8,10
737	adde	11,9,11
738	addze	12,0
739
740	ld	6,8(4)
741	ld	7,16(5)
742	mulld	8,6,7
743	mulhdu	9,6,7
744	addc	10,8,10
745	adde	11,9,11
746	addze	12,12
747
748	ld	6,16(4)
749	ld	7,8(5)
750	mulld	8,6,7
751	mulhdu	9,6,7
752	addc	10,8,10
753	adde	11,9,11
754	addze	12,12
755
756	ld	6,24(4)
757	ld	7,0(5)
758	mulld	8,6,7
759	mulhdu	9,6,7
760	addc	10,8,10
761	adde	11,9,11
762	addze	12,12
763	std	10,24(3)
764
765	ld	7,8(5)
766	mulld	8,6,7
767	mulhdu	9,6,7
768	addc	11,8,11
769	adde	12,9,12
770	addze	10,0
771
772	ld	6,16(4)
773	ld	7,16(5)
774	mulld	8,6,7
775	mulhdu	9,6,7
776	addc	11,8,11
777	adde	12,9,12
778	addze	10,10
779
780	ld	6,8(4)
781	ld	7,24(5)
782	mulld	8,6,7
783	mulhdu	9,6,7
784	addc	11,8,11
785	adde	12,9,12
786	addze	10,10
787	std	11,32(3)
788
789	ld	6,16(4)
790	mulld	8,6,7
791	mulhdu	9,6,7
792	addc	12,8,12
793	adde	10,9,10
794	addze	11,0
795
796	ld	6,24(4)
797	ld	7,16(5)
798	mulld	8,6,7
799	mulhdu	9,6,7
800	addc	12,8,12
801	adde	10,9,10
802	addze	11,11
803	std	12,40(3)
804
805	ld	7,24(5)
806	mulld	8,6,7
807	mulhdu	9,6,7
808	addc	10,8,10
809	adde	11,9,11
810
811	std	10,48(3)
812	std	11,56(3)
813	blr
814.long	0
815.byte	0,12,0x14,0,0,0,3,0
816.long	0
817
818
819
820
821
822
823
824
825
826.align	4
827.bn_mul_comba8:
828
829
830
831
832
833
834
835
836
837
838
839	xor	0,0,0
840
841
842	ld	6,0(4)
843	ld	7,0(5)
844	mulld	10,6,7
845	mulhdu	11,6,7
846	std	10,0(3)
847
848	ld	7,8(5)
849	mulld	8,6,7
850	mulhdu	9,6,7
851	addc	11,11,8
852	addze	12,9
853	addze	10,0
854
855	ld	6,8(4)
856	ld	7,0(5)
857	mulld	8,6,7
858	mulhdu	9,6,7
859	addc	11,11,8
860	adde	12,12,9
861	addze	10,10
862	std	11,8(3)
863
864	ld	6,16(4)
865	mulld	8,6,7
866	mulhdu	9,6,7
867	addc	12,12,8
868	adde	10,10,9
869	addze	11,0
870
871	ld	6,8(4)
872	ld	7,8(5)
873	mulld	8,6,7
874	mulhdu	9,6,7
875	addc	12,12,8
876	adde	10,10,9
877	addze	11,11
878
879	ld	6,0(4)
880	ld	7,16(5)
881	mulld	8,6,7
882	mulhdu	9,6,7
883	addc	12,12,8
884	adde	10,10,9
885	addze	11,11
886	std	12,16(3)
887
888	ld	7,24(5)
889	mulld	8,6,7
890	mulhdu	9,6,7
891	addc	10,10,8
892	adde	11,11,9
893	addze	12,0
894
895	ld	6,8(4)
896	ld	7,16(5)
897	mulld	8,6,7
898	mulhdu	9,6,7
899	addc	10,10,8
900	adde	11,11,9
901	addze	12,12
902
903
904	ld	6,16(4)
905	ld	7,8(5)
906	mulld	8,6,7
907	mulhdu	9,6,7
908	addc	10,10,8
909	adde	11,11,9
910	addze	12,12
911
912	ld	6,24(4)
913	ld	7,0(5)
914	mulld	8,6,7
915	mulhdu	9,6,7
916	addc	10,10,8
917	adde	11,11,9
918	addze	12,12
919	std	10,24(3)
920
921	ld	6,32(4)
922	mulld	8,6,7
923	mulhdu	9,6,7
924	addc	11,11,8
925	adde	12,12,9
926	addze	10,0
927
928	ld	6,24(4)
929	ld	7,8(5)
930	mulld	8,6,7
931	mulhdu	9,6,7
932	addc	11,11,8
933	adde	12,12,9
934	addze	10,10
935
936	ld	6,16(4)
937	ld	7,16(5)
938	mulld	8,6,7
939	mulhdu	9,6,7
940	addc	11,11,8
941	adde	12,12,9
942	addze	10,10
943
944	ld	6,8(4)
945	ld	7,24(5)
946	mulld	8,6,7
947	mulhdu	9,6,7
948	addc	11,11,8
949	adde	12,12,9
950	addze	10,10
951
952	ld	6,0(4)
953	ld	7,32(5)
954	mulld	8,6,7
955	mulhdu	9,6,7
956	addc	11,11,8
957	adde	12,12,9
958	addze	10,10
959	std	11,32(3)
960
961	ld	7,40(5)
962	mulld	8,6,7
963	mulhdu	9,6,7
964	addc	12,12,8
965	adde	10,10,9
966	addze	11,0
967
968	ld	6,8(4)
969	ld	7,32(5)
970	mulld	8,6,7
971	mulhdu	9,6,7
972	addc	12,12,8
973	adde	10,10,9
974	addze	11,11
975
976	ld	6,16(4)
977	ld	7,24(5)
978	mulld	8,6,7
979	mulhdu	9,6,7
980	addc	12,12,8
981	adde	10,10,9
982	addze	11,11
983
984	ld	6,24(4)
985	ld	7,16(5)
986	mulld	8,6,7
987	mulhdu	9,6,7
988	addc	12,12,8
989	adde	10,10,9
990	addze	11,11
991
992	ld	6,32(4)
993	ld	7,8(5)
994	mulld	8,6,7
995	mulhdu	9,6,7
996	addc	12,12,8
997	adde	10,10,9
998	addze	11,11
999
1000	ld	6,40(4)
1001	ld	7,0(5)
1002	mulld	8,6,7
1003	mulhdu	9,6,7
1004	addc	12,12,8
1005	adde	10,10,9
1006	addze	11,11
1007	std	12,40(3)
1008
1009	ld	6,48(4)
1010	mulld	8,6,7
1011	mulhdu	9,6,7
1012	addc	10,10,8
1013	adde	11,11,9
1014	addze	12,0
1015
1016	ld	6,40(4)
1017	ld	7,8(5)
1018	mulld	8,6,7
1019	mulhdu	9,6,7
1020	addc	10,10,8
1021	adde	11,11,9
1022	addze	12,12
1023
1024	ld	6,32(4)
1025	ld	7,16(5)
1026	mulld	8,6,7
1027	mulhdu	9,6,7
1028	addc	10,10,8
1029	adde	11,11,9
1030	addze	12,12
1031
1032	ld	6,24(4)
1033	ld	7,24(5)
1034	mulld	8,6,7
1035	mulhdu	9,6,7
1036	addc	10,10,8
1037	adde	11,11,9
1038	addze	12,12
1039
1040	ld	6,16(4)
1041	ld	7,32(5)
1042	mulld	8,6,7
1043	mulhdu	9,6,7
1044	addc	10,10,8
1045	adde	11,11,9
1046	addze	12,12
1047
1048	ld	6,8(4)
1049	ld	7,40(5)
1050	mulld	8,6,7
1051	mulhdu	9,6,7
1052	addc	10,10,8
1053	adde	11,11,9
1054	addze	12,12
1055
1056	ld	6,0(4)
1057	ld	7,48(5)
1058	mulld	8,6,7
1059	mulhdu	9,6,7
1060	addc	10,10,8
1061	adde	11,11,9
1062	addze	12,12
1063	std	10,48(3)
1064
1065	ld	7,56(5)
1066	mulld	8,6,7
1067	mulhdu	9,6,7
1068	addc	11,11,8
1069	adde	12,12,9
1070	addze	10,0
1071
1072	ld	6,8(4)
1073	ld	7,48(5)
1074	mulld	8,6,7
1075	mulhdu	9,6,7
1076	addc	11,11,8
1077	adde	12,12,9
1078	addze	10,10
1079
1080	ld	6,16(4)
1081	ld	7,40(5)
1082	mulld	8,6,7
1083	mulhdu	9,6,7
1084	addc	11,11,8
1085	adde	12,12,9
1086	addze	10,10
1087
1088	ld	6,24(4)
1089	ld	7,32(5)
1090	mulld	8,6,7
1091	mulhdu	9,6,7
1092	addc	11,11,8
1093	adde	12,12,9
1094	addze	10,10
1095
1096	ld	6,32(4)
1097	ld	7,24(5)
1098	mulld	8,6,7
1099	mulhdu	9,6,7
1100	addc	11,11,8
1101	adde	12,12,9
1102	addze	10,10
1103
1104	ld	6,40(4)
1105	ld	7,16(5)
1106	mulld	8,6,7
1107	mulhdu	9,6,7
1108	addc	11,11,8
1109	adde	12,12,9
1110	addze	10,10
1111
1112	ld	6,48(4)
1113	ld	7,8(5)
1114	mulld	8,6,7
1115	mulhdu	9,6,7
1116	addc	11,11,8
1117	adde	12,12,9
1118	addze	10,10
1119
1120	ld	6,56(4)
1121	ld	7,0(5)
1122	mulld	8,6,7
1123	mulhdu	9,6,7
1124	addc	11,11,8
1125	adde	12,12,9
1126	addze	10,10
1127	std	11,56(3)
1128
1129	ld	7,8(5)
1130	mulld	8,6,7
1131	mulhdu	9,6,7
1132	addc	12,12,8
1133	adde	10,10,9
1134	addze	11,0
1135
1136	ld	6,48(4)
1137	ld	7,16(5)
1138	mulld	8,6,7
1139	mulhdu	9,6,7
1140	addc	12,12,8
1141	adde	10,10,9
1142	addze	11,11
1143
1144	ld	6,40(4)
1145	ld	7,24(5)
1146	mulld	8,6,7
1147	mulhdu	9,6,7
1148	addc	12,12,8
1149	adde	10,10,9
1150	addze	11,11
1151
1152	ld	6,32(4)
1153	ld	7,32(5)
1154	mulld	8,6,7
1155	mulhdu	9,6,7
1156	addc	12,12,8
1157	adde	10,10,9
1158	addze	11,11
1159
1160	ld	6,24(4)
1161	ld	7,40(5)
1162	mulld	8,6,7
1163	mulhdu	9,6,7
1164	addc	12,12,8
1165	adde	10,10,9
1166	addze	11,11
1167
1168	ld	6,16(4)
1169	ld	7,48(5)
1170	mulld	8,6,7
1171	mulhdu	9,6,7
1172	addc	12,12,8
1173	adde	10,10,9
1174	addze	11,11
1175
1176	ld	6,8(4)
1177	ld	7,56(5)
1178	mulld	8,6,7
1179	mulhdu	9,6,7
1180	addc	12,12,8
1181	adde	10,10,9
1182	addze	11,11
1183	std	12,64(3)
1184
1185	ld	6,16(4)
1186	mulld	8,6,7
1187	mulhdu	9,6,7
1188	addc	10,10,8
1189	adde	11,11,9
1190	addze	12,0
1191
1192	ld	6,24(4)
1193	ld	7,48(5)
1194	mulld	8,6,7
1195	mulhdu	9,6,7
1196	addc	10,10,8
1197	adde	11,11,9
1198	addze	12,12
1199
1200	ld	6,32(4)
1201	ld	7,40(5)
1202	mulld	8,6,7
1203	mulhdu	9,6,7
1204	addc	10,10,8
1205	adde	11,11,9
1206	addze	12,12
1207
1208	ld	6,40(4)
1209	ld	7,32(5)
1210	mulld	8,6,7
1211	mulhdu	9,6,7
1212	addc	10,10,8
1213	adde	11,11,9
1214	addze	12,12
1215
1216	ld	6,48(4)
1217	ld	7,24(5)
1218	mulld	8,6,7
1219	mulhdu	9,6,7
1220	addc	10,10,8
1221	adde	11,11,9
1222	addze	12,12
1223
1224	ld	6,56(4)
1225	ld	7,16(5)
1226	mulld	8,6,7
1227	mulhdu	9,6,7
1228	addc	10,10,8
1229	adde	11,11,9
1230	addze	12,12
1231	std	10,72(3)
1232
1233	ld	7,24(5)
1234	mulld	8,6,7
1235	mulhdu	9,6,7
1236	addc	11,11,8
1237	adde	12,12,9
1238	addze	10,0
1239
1240	ld	6,48(4)
1241	ld	7,32(5)
1242	mulld	8,6,7
1243	mulhdu	9,6,7
1244	addc	11,11,8
1245	adde	12,12,9
1246	addze	10,10
1247
1248	ld	6,40(4)
1249	ld	7,40(5)
1250	mulld	8,6,7
1251	mulhdu	9,6,7
1252	addc	11,11,8
1253	adde	12,12,9
1254	addze	10,10
1255
1256	ld	6,32(4)
1257	ld	7,48(5)
1258	mulld	8,6,7
1259	mulhdu	9,6,7
1260	addc	11,11,8
1261	adde	12,12,9
1262	addze	10,10
1263
1264	ld	6,24(4)
1265	ld	7,56(5)
1266	mulld	8,6,7
1267	mulhdu	9,6,7
1268	addc	11,11,8
1269	adde	12,12,9
1270	addze	10,10
1271	std	11,80(3)
1272
1273	ld	6,32(4)
1274	mulld	8,6,7
1275	mulhdu	9,6,7
1276	addc	12,12,8
1277	adde	10,10,9
1278	addze	11,0
1279
1280	ld	6,40(4)
1281	ld	7,48(5)
1282	mulld	8,6,7
1283	mulhdu	9,6,7
1284	addc	12,12,8
1285	adde	10,10,9
1286	addze	11,11
1287
1288	ld	6,48(4)
1289	ld	7,40(5)
1290	mulld	8,6,7
1291	mulhdu	9,6,7
1292	addc	12,12,8
1293	adde	10,10,9
1294	addze	11,11
1295
1296	ld	6,56(4)
1297	ld	7,32(5)
1298	mulld	8,6,7
1299	mulhdu	9,6,7
1300	addc	12,12,8
1301	adde	10,10,9
1302	addze	11,11
1303	std	12,88(3)
1304
1305	ld	7,40(5)
1306	mulld	8,6,7
1307	mulhdu	9,6,7
1308	addc	10,10,8
1309	adde	11,11,9
1310	addze	12,0
1311
1312	ld	6,48(4)
1313	ld	7,48(5)
1314	mulld	8,6,7
1315	mulhdu	9,6,7
1316	addc	10,10,8
1317	adde	11,11,9
1318	addze	12,12
1319
1320	ld	6,40(4)
1321	ld	7,56(5)
1322	mulld	8,6,7
1323	mulhdu	9,6,7
1324	addc	10,10,8
1325	adde	11,11,9
1326	addze	12,12
1327	std	10,96(3)
1328
1329	ld	6,48(4)
1330	mulld	8,6,7
1331	mulhdu	9,6,7
1332	addc	11,11,8
1333	adde	12,12,9
1334	addze	10,0
1335
1336	ld	6,56(4)
1337	ld	7,48(5)
1338	mulld	8,6,7
1339	mulhdu	9,6,7
1340	addc	11,11,8
1341	adde	12,12,9
1342	addze	10,10
1343	std	11,104(3)
1344
1345	ld	7,56(5)
1346	mulld	8,6,7
1347	mulhdu	9,6,7
1348	addc	12,12,8
1349	adde	10,10,9
1350	std	12,112(3)
1351	std	10,120(3)
1352	blr
1353.long	0
1354.byte	0,12,0x14,0,0,0,3,0
1355.long	0
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365.align	4
1366.bn_sub_words:
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380	xor	0,0,0
1381
1382
1383
1384	subfc.	7,0,6
1385
1386
1387	beq	Lppcasm_sub_adios
1388	addi	4,4,-8
1389	addi	3,3,-8
1390	addi	5,5,-8
1391	mtctr	6
1392Lppcasm_sub_mainloop:
1393	ldu	7,8(4)
1394	ldu	8,8(5)
1395	subfe	6,8,7
1396
1397
1398	stdu	6,8(3)
1399	bc	16,0,Lppcasm_sub_mainloop
1400Lppcasm_sub_adios:
1401	subfze	3,0
1402	andi.	3,3,1
1403	blr
1404.long	0
1405.byte	0,12,0x14,0,0,0,4,0
1406.long	0
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416.align	4
1417.bn_add_words:
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431	xor	0,0,0
1432
1433
1434
1435	addic.	6,6,0
1436	beq	Lppcasm_add_adios
1437	addi	4,4,-8
1438	addi	3,3,-8
1439	addi	5,5,-8
1440	mtctr	6
1441Lppcasm_add_mainloop:
1442	ldu	7,8(4)
1443	ldu	8,8(5)
1444	adde	8,7,8
1445	stdu	8,8(3)
1446	bc	16,0,Lppcasm_add_mainloop
1447Lppcasm_add_adios:
1448	addze	3,0
1449	blr
1450.long	0
1451.byte	0,12,0x14,0,0,0,4,0
1452.long	0
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462.align	4
1463.bn_div_words:
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475	cmpldi	0,5,0
1476	bne	Lppcasm_div1
1477	li	3,-1
1478	blr
1479Lppcasm_div1:
1480	xor	0,0,0
1481	li	8,64
1482	cntlzd.	7,5
1483	beq	Lppcasm_div2
1484	subf	8,7,8
1485	srd.	9,3,8
1486	td	16,9,0
1487Lppcasm_div2:
1488	cmpld	0,3,5
1489	blt	Lppcasm_div3
1490	subf	3,5,3
1491Lppcasm_div3:
1492	cmpi	0,0,7,0
1493	beq	Lppcasm_div4
1494	sld	3,3,7
1495	srd	8,4,8
1496	sld	5,5,7
1497	or	3,3,8
1498	sld	4,4,7
1499Lppcasm_div4:
1500	srdi	9,5,32
1501
1502
1503	li	6,2
1504	mtctr	6
1505Lppcasm_divouterloop:
1506	srdi	8,3,32
1507	srdi	11,4,32
1508
1509	cmpld	0,8,9
1510	bne	Lppcasm_div5
1511
1512	li	8,-1
1513	clrldi	8,8,32
1514	b	Lppcasm_div6
1515Lppcasm_div5:
1516	divdu	8,3,9
1517Lppcasm_div6:
1518	mulld	12,9,8
1519	clrldi	10,5,32
1520	mulld	6,8,10
1521
1522Lppcasm_divinnerloop:
1523	subf	10,12,3
1524	srdi	7,10,32
1525	addic.	7,7,0
1526
1527
1528
1529	sldi	7,10,32
1530	or	7,7,11
1531	cmpld	1,6,7
1532	bne	Lppcasm_divinnerexit
1533	ble	1,Lppcasm_divinnerexit
1534	addi	8,8,-1
1535	subf	12,9,12
1536	clrldi	10,5,32
1537	subf	6,10,6
1538	b	Lppcasm_divinnerloop
1539Lppcasm_divinnerexit:
1540	srdi	10,6,32
1541	sldi	11,6,32
1542	cmpld	1,4,11
1543	add	12,12,10
1544	bge	1,Lppcasm_div7
1545	addi	12,12,1
1546Lppcasm_div7:
1547	subf	11,11,4
1548	cmpld	1,3,12
1549	bge	1,Lppcasm_div8
1550	addi	8,8,-1
1551	add	3,5,3
1552Lppcasm_div8:
1553	subf	12,12,3
1554	sldi	4,11,32
1555
1556
1557
1558	insrdi	11,12,32,32
1559	rotldi	3,11,32
1560	bdz	Lppcasm_div9
1561	sldi	0,8,32
1562	b	Lppcasm_divouterloop
1563Lppcasm_div9:
1564	or	3,8,0
1565	blr
1566.long	0
1567.byte	0,12,0x14,0,0,0,3,0
1568.long	0
1569
1570
1571
1572
1573
1574
1575
1576
1577.align	4
1578.bn_sqr_words:
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593	addic.	5,5,0
1594	beq	Lppcasm_sqr_adios
1595	addi	4,4,-8
1596	addi	3,3,-8
1597	mtctr	5
1598Lppcasm_sqr_mainloop:
1599
1600	ldu	6,8(4)
1601	mulld	7,6,6
1602	mulhdu	8,6,6
1603	stdu	7,8(3)
1604	stdu	8,8(3)
1605	bc	16,0,Lppcasm_sqr_mainloop
1606Lppcasm_sqr_adios:
1607	blr
1608.long	0
1609.byte	0,12,0x14,0,0,0,3,0
1610.long	0
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620.align	4
1621.bn_mul_words:
1622
1623
1624
1625
1626
1627
1628
1629	xor	0,0,0
1630	xor	12,12,12
1631	rlwinm.	7,5,30,2,31
1632	beq	Lppcasm_mw_REM
1633	mtctr	7
1634Lppcasm_mw_LOOP:
1635
1636	ld	8,0(4)
1637	mulld	9,6,8
1638	mulhdu	10,6,8
1639	addc	9,9,12
1640
1641
1642
1643
1644	std	9,0(3)
1645
1646	ld	8,8(4)
1647	mulld	11,6,8
1648	mulhdu	12,6,8
1649	adde	11,11,10
1650
1651	std	11,8(3)
1652
1653	ld	8,16(4)
1654	mulld	9,6,8
1655	mulhdu	10,6,8
1656	adde	9,9,12
1657
1658	std	9,16(3)
1659
1660	ld	8,24(4)
1661	mulld	11,6,8
1662	mulhdu	12,6,8
1663	adde	11,11,10
1664	addze	12,12
1665
1666	std	11,24(3)
1667
1668	addi	3,3,32
1669	addi	4,4,32
1670	bc	16,0,Lppcasm_mw_LOOP
1671
1672Lppcasm_mw_REM:
1673	andi.	5,5,0x3
1674	beq	Lppcasm_mw_OVER
1675
1676	ld	8,0(4)
1677	mulld	9,6,8
1678	mulhdu	10,6,8
1679	addc	9,9,12
1680	addze	10,10
1681	std	9,0(3)
1682	addi	12,10,0
1683
1684	addi	5,5,-1
1685	cmpli	0,0,5,0
1686	beq	Lppcasm_mw_OVER
1687
1688
1689
1690	ld	8,8(4)
1691	mulld	9,6,8
1692	mulhdu	10,6,8
1693	addc	9,9,12
1694	addze	10,10
1695	std	9,8(3)
1696	addi	12,10,0
1697
1698	addi	5,5,-1
1699	cmpli	0,0,5,0
1700	beq	Lppcasm_mw_OVER
1701
1702
1703	ld	8,16(4)
1704	mulld	9,6,8
1705	mulhdu	10,6,8
1706	addc	9,9,12
1707	addze	10,10
1708	std	9,16(3)
1709	addi	12,10,0
1710
1711Lppcasm_mw_OVER:
1712	addi	3,12,0
1713	blr
1714.long	0
1715.byte	0,12,0x14,0,0,0,4,0
1716.long	0
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726.align	4
1727.bn_mul_add_words:
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738	xor	0,0,0
1739	xor	12,12,12
1740	rlwinm.	7,5,30,2,31
1741	beq	Lppcasm_maw_leftover
1742	mtctr	7
1743Lppcasm_maw_mainloop:
1744
1745	ld	8,0(4)
1746	ld	11,0(3)
1747	mulld	9,6,8
1748	mulhdu	10,6,8
1749	addc	9,9,12
1750	addze	10,10
1751	addc	9,9,11
1752
1753
1754
1755
1756
1757
1758	std	9,0(3)
1759
1760
1761	ld	8,8(4)
1762	ld	9,8(3)
1763	mulld	11,6,8
1764	mulhdu	12,6,8
1765	adde	11,11,10
1766	addze	12,12
1767	addc	11,11,9
1768
1769	std	11,8(3)
1770
1771
1772	ld	8,16(4)
1773	mulld	9,6,8
1774	ld	11,16(3)
1775	mulhdu	10,6,8
1776	adde	9,9,12
1777	addze	10,10
1778	addc	9,9,11
1779
1780	std	9,16(3)
1781
1782
1783	ld	8,24(4)
1784	mulld	11,6,8
1785	ld	9,24(3)
1786	mulhdu	12,6,8
1787	adde	11,11,10
1788	addze	12,12
1789	addc	11,11,9
1790	addze	12,12
1791	std	11,24(3)
1792	addi	3,3,32
1793	addi	4,4,32
1794	bc	16,0,Lppcasm_maw_mainloop
1795
1796Lppcasm_maw_leftover:
1797	andi.	5,5,0x3
1798	beq	Lppcasm_maw_adios
1799	addi	3,3,-8
1800	addi	4,4,-8
1801
1802	mtctr	5
1803	ldu	8,8(4)
1804	mulld	9,6,8
1805	mulhdu	10,6,8
1806	ldu	11,8(3)
1807	addc	9,9,11
1808	addze	10,10
1809	addc	9,9,12
1810	addze	12,10
1811	std	9,0(3)
1812
1813	bdz	Lppcasm_maw_adios
1814
1815	ldu	8,8(4)
1816	mulld	9,6,8
1817	mulhdu	10,6,8
1818	ldu	11,8(3)
1819	addc	9,9,11
1820	addze	10,10
1821	addc	9,9,12
1822	addze	12,10
1823	std	9,0(3)
1824
1825	bdz	Lppcasm_maw_adios
1826
1827	ldu	8,8(4)
1828	mulld	9,6,8
1829	mulhdu	10,6,8
1830	ldu	11,8(3)
1831	addc	9,9,11
1832	addze	10,10
1833	addc	9,9,12
1834	addze	12,10
1835	std	9,0(3)
1836
1837Lppcasm_maw_adios:
1838	addi	3,12,0
1839	blr
1840.long	0
1841.byte	0,12,0x14,0,0,0,4,0
1842.long	0
1843
1844.align	4
1845