1 /* fp_mul_comba_small_set.i
3 * Copyright (C) 2006-2011 Sawtooth Consulting Ltd.
5 * This file is part of CyaSSL.
7 * CyaSSL is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * CyaSSL is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
23 #if defined(TFM_SMALL_SET)
24 void fp_mul_comba_small(fp_int *A, fp_int *B, fp_int *C)
26 fp_digit c0, c1, c2, at[32];
27 switch (MAX(A->used, B->used)) {
30 memcpy(at, A->dp, 1 * sizeof(fp_digit));
31 memcpy(at+1, B->dp, 1 * sizeof(fp_digit));
37 COMBA_STORE(C->dp[0]);
38 COMBA_STORE2(C->dp[1]);
40 C->sign = A->sign ^ B->sign;
46 memcpy(at, A->dp, 2 * sizeof(fp_digit));
47 memcpy(at+2, B->dp, 2 * sizeof(fp_digit));
53 COMBA_STORE(C->dp[0]);
56 MULADD(at[0], at[3]); MULADD(at[1], at[2]);
57 COMBA_STORE(C->dp[1]);
61 COMBA_STORE(C->dp[2]);
62 COMBA_STORE2(C->dp[3]);
64 C->sign = A->sign ^ B->sign;
70 memcpy(at, A->dp, 3 * sizeof(fp_digit));
71 memcpy(at+3, B->dp, 3 * sizeof(fp_digit));
77 COMBA_STORE(C->dp[0]);
80 MULADD(at[0], at[4]); MULADD(at[1], at[3]);
81 COMBA_STORE(C->dp[1]);
84 MULADD(at[0], at[5]); MULADD(at[1], at[4]); MULADD(at[2], at[3]);
85 COMBA_STORE(C->dp[2]);
88 MULADD(at[1], at[5]); MULADD(at[2], at[4]);
89 COMBA_STORE(C->dp[3]);
93 COMBA_STORE(C->dp[4]);
94 COMBA_STORE2(C->dp[5]);
96 C->sign = A->sign ^ B->sign;
102 memcpy(at, A->dp, 4 * sizeof(fp_digit));
103 memcpy(at+4, B->dp, 4 * sizeof(fp_digit));
108 MULADD(at[0], at[4]);
109 COMBA_STORE(C->dp[0]);
112 MULADD(at[0], at[5]); MULADD(at[1], at[4]);
113 COMBA_STORE(C->dp[1]);
116 MULADD(at[0], at[6]); MULADD(at[1], at[5]); MULADD(at[2], at[4]);
117 COMBA_STORE(C->dp[2]);
120 MULADD(at[0], at[7]); MULADD(at[1], at[6]); MULADD(at[2], at[5]); MULADD(at[3], at[4]);
121 COMBA_STORE(C->dp[3]);
124 MULADD(at[1], at[7]); MULADD(at[2], at[6]); MULADD(at[3], at[5]);
125 COMBA_STORE(C->dp[4]);
128 MULADD(at[2], at[7]); MULADD(at[3], at[6]);
129 COMBA_STORE(C->dp[5]);
132 MULADD(at[3], at[7]);
133 COMBA_STORE(C->dp[6]);
134 COMBA_STORE2(C->dp[7]);
136 C->sign = A->sign ^ B->sign;
142 memcpy(at, A->dp, 5 * sizeof(fp_digit));
143 memcpy(at+5, B->dp, 5 * sizeof(fp_digit));
148 MULADD(at[0], at[5]);
149 COMBA_STORE(C->dp[0]);
152 MULADD(at[0], at[6]); MULADD(at[1], at[5]);
153 COMBA_STORE(C->dp[1]);
156 MULADD(at[0], at[7]); MULADD(at[1], at[6]); MULADD(at[2], at[5]);
157 COMBA_STORE(C->dp[2]);
160 MULADD(at[0], at[8]); MULADD(at[1], at[7]); MULADD(at[2], at[6]); MULADD(at[3], at[5]);
161 COMBA_STORE(C->dp[3]);
164 MULADD(at[0], at[9]); MULADD(at[1], at[8]); MULADD(at[2], at[7]); MULADD(at[3], at[6]); MULADD(at[4], at[5]);
165 COMBA_STORE(C->dp[4]);
168 MULADD(at[1], at[9]); MULADD(at[2], at[8]); MULADD(at[3], at[7]); MULADD(at[4], at[6]);
169 COMBA_STORE(C->dp[5]);
172 MULADD(at[2], at[9]); MULADD(at[3], at[8]); MULADD(at[4], at[7]);
173 COMBA_STORE(C->dp[6]);
176 MULADD(at[3], at[9]); MULADD(at[4], at[8]);
177 COMBA_STORE(C->dp[7]);
180 MULADD(at[4], at[9]);
181 COMBA_STORE(C->dp[8]);
182 COMBA_STORE2(C->dp[9]);
184 C->sign = A->sign ^ B->sign;
190 memcpy(at, A->dp, 6 * sizeof(fp_digit));
191 memcpy(at+6, B->dp, 6 * sizeof(fp_digit));
196 MULADD(at[0], at[6]);
197 COMBA_STORE(C->dp[0]);
200 MULADD(at[0], at[7]); MULADD(at[1], at[6]);
201 COMBA_STORE(C->dp[1]);
204 MULADD(at[0], at[8]); MULADD(at[1], at[7]); MULADD(at[2], at[6]);
205 COMBA_STORE(C->dp[2]);
208 MULADD(at[0], at[9]); MULADD(at[1], at[8]); MULADD(at[2], at[7]); MULADD(at[3], at[6]);
209 COMBA_STORE(C->dp[3]);
212 MULADD(at[0], at[10]); MULADD(at[1], at[9]); MULADD(at[2], at[8]); MULADD(at[3], at[7]); MULADD(at[4], at[6]);
213 COMBA_STORE(C->dp[4]);
216 MULADD(at[0], at[11]); MULADD(at[1], at[10]); MULADD(at[2], at[9]); MULADD(at[3], at[8]); MULADD(at[4], at[7]); MULADD(at[5], at[6]);
217 COMBA_STORE(C->dp[5]);
220 MULADD(at[1], at[11]); MULADD(at[2], at[10]); MULADD(at[3], at[9]); MULADD(at[4], at[8]); MULADD(at[5], at[7]);
221 COMBA_STORE(C->dp[6]);
224 MULADD(at[2], at[11]); MULADD(at[3], at[10]); MULADD(at[4], at[9]); MULADD(at[5], at[8]);
225 COMBA_STORE(C->dp[7]);
228 MULADD(at[3], at[11]); MULADD(at[4], at[10]); MULADD(at[5], at[9]);
229 COMBA_STORE(C->dp[8]);
232 MULADD(at[4], at[11]); MULADD(at[5], at[10]);
233 COMBA_STORE(C->dp[9]);
236 MULADD(at[5], at[11]);
237 COMBA_STORE(C->dp[10]);
238 COMBA_STORE2(C->dp[11]);
240 C->sign = A->sign ^ B->sign;
246 memcpy(at, A->dp, 7 * sizeof(fp_digit));
247 memcpy(at+7, B->dp, 7 * sizeof(fp_digit));
252 MULADD(at[0], at[7]);
253 COMBA_STORE(C->dp[0]);
256 MULADD(at[0], at[8]); MULADD(at[1], at[7]);
257 COMBA_STORE(C->dp[1]);
260 MULADD(at[0], at[9]); MULADD(at[1], at[8]); MULADD(at[2], at[7]);
261 COMBA_STORE(C->dp[2]);
264 MULADD(at[0], at[10]); MULADD(at[1], at[9]); MULADD(at[2], at[8]); MULADD(at[3], at[7]);
265 COMBA_STORE(C->dp[3]);
268 MULADD(at[0], at[11]); MULADD(at[1], at[10]); MULADD(at[2], at[9]); MULADD(at[3], at[8]); MULADD(at[4], at[7]);
269 COMBA_STORE(C->dp[4]);
272 MULADD(at[0], at[12]); MULADD(at[1], at[11]); MULADD(at[2], at[10]); MULADD(at[3], at[9]); MULADD(at[4], at[8]); MULADD(at[5], at[7]);
273 COMBA_STORE(C->dp[5]);
276 MULADD(at[0], at[13]); MULADD(at[1], at[12]); MULADD(at[2], at[11]); MULADD(at[3], at[10]); MULADD(at[4], at[9]); MULADD(at[5], at[8]); MULADD(at[6], at[7]);
277 COMBA_STORE(C->dp[6]);
280 MULADD(at[1], at[13]); MULADD(at[2], at[12]); MULADD(at[3], at[11]); MULADD(at[4], at[10]); MULADD(at[5], at[9]); MULADD(at[6], at[8]);
281 COMBA_STORE(C->dp[7]);
284 MULADD(at[2], at[13]); MULADD(at[3], at[12]); MULADD(at[4], at[11]); MULADD(at[5], at[10]); MULADD(at[6], at[9]);
285 COMBA_STORE(C->dp[8]);
288 MULADD(at[3], at[13]); MULADD(at[4], at[12]); MULADD(at[5], at[11]); MULADD(at[6], at[10]);
289 COMBA_STORE(C->dp[9]);
292 MULADD(at[4], at[13]); MULADD(at[5], at[12]); MULADD(at[6], at[11]);
293 COMBA_STORE(C->dp[10]);
296 MULADD(at[5], at[13]); MULADD(at[6], at[12]);
297 COMBA_STORE(C->dp[11]);
300 MULADD(at[6], at[13]);
301 COMBA_STORE(C->dp[12]);
302 COMBA_STORE2(C->dp[13]);
304 C->sign = A->sign ^ B->sign;
310 memcpy(at, A->dp, 8 * sizeof(fp_digit));
311 memcpy(at+8, B->dp, 8 * sizeof(fp_digit));
316 MULADD(at[0], at[8]);
317 COMBA_STORE(C->dp[0]);
320 MULADD(at[0], at[9]); MULADD(at[1], at[8]);
321 COMBA_STORE(C->dp[1]);
324 MULADD(at[0], at[10]); MULADD(at[1], at[9]); MULADD(at[2], at[8]);
325 COMBA_STORE(C->dp[2]);
328 MULADD(at[0], at[11]); MULADD(at[1], at[10]); MULADD(at[2], at[9]); MULADD(at[3], at[8]);
329 COMBA_STORE(C->dp[3]);
332 MULADD(at[0], at[12]); MULADD(at[1], at[11]); MULADD(at[2], at[10]); MULADD(at[3], at[9]); MULADD(at[4], at[8]);
333 COMBA_STORE(C->dp[4]);
336 MULADD(at[0], at[13]); MULADD(at[1], at[12]); MULADD(at[2], at[11]); MULADD(at[3], at[10]); MULADD(at[4], at[9]); MULADD(at[5], at[8]);
337 COMBA_STORE(C->dp[5]);
340 MULADD(at[0], at[14]); MULADD(at[1], at[13]); MULADD(at[2], at[12]); MULADD(at[3], at[11]); MULADD(at[4], at[10]); MULADD(at[5], at[9]); MULADD(at[6], at[8]);
341 COMBA_STORE(C->dp[6]);
344 MULADD(at[0], at[15]); MULADD(at[1], at[14]); MULADD(at[2], at[13]); MULADD(at[3], at[12]); MULADD(at[4], at[11]); MULADD(at[5], at[10]); MULADD(at[6], at[9]); MULADD(at[7], at[8]);
345 COMBA_STORE(C->dp[7]);
348 MULADD(at[1], at[15]); MULADD(at[2], at[14]); MULADD(at[3], at[13]); MULADD(at[4], at[12]); MULADD(at[5], at[11]); MULADD(at[6], at[10]); MULADD(at[7], at[9]);
349 COMBA_STORE(C->dp[8]);
352 MULADD(at[2], at[15]); MULADD(at[3], at[14]); MULADD(at[4], at[13]); MULADD(at[5], at[12]); MULADD(at[6], at[11]); MULADD(at[7], at[10]);
353 COMBA_STORE(C->dp[9]);
356 MULADD(at[3], at[15]); MULADD(at[4], at[14]); MULADD(at[5], at[13]); MULADD(at[6], at[12]); MULADD(at[7], at[11]);
357 COMBA_STORE(C->dp[10]);
360 MULADD(at[4], at[15]); MULADD(at[5], at[14]); MULADD(at[6], at[13]); MULADD(at[7], at[12]);
361 COMBA_STORE(C->dp[11]);
364 MULADD(at[5], at[15]); MULADD(at[6], at[14]); MULADD(at[7], at[13]);
365 COMBA_STORE(C->dp[12]);
368 MULADD(at[6], at[15]); MULADD(at[7], at[14]);
369 COMBA_STORE(C->dp[13]);
372 MULADD(at[7], at[15]);
373 COMBA_STORE(C->dp[14]);
374 COMBA_STORE2(C->dp[15]);
376 C->sign = A->sign ^ B->sign;
382 memcpy(at, A->dp, 9 * sizeof(fp_digit));
383 memcpy(at+9, B->dp, 9 * sizeof(fp_digit));
388 MULADD(at[0], at[9]);
389 COMBA_STORE(C->dp[0]);
392 MULADD(at[0], at[10]); MULADD(at[1], at[9]);
393 COMBA_STORE(C->dp[1]);
396 MULADD(at[0], at[11]); MULADD(at[1], at[10]); MULADD(at[2], at[9]);
397 COMBA_STORE(C->dp[2]);
400 MULADD(at[0], at[12]); MULADD(at[1], at[11]); MULADD(at[2], at[10]); MULADD(at[3], at[9]);
401 COMBA_STORE(C->dp[3]);
404 MULADD(at[0], at[13]); MULADD(at[1], at[12]); MULADD(at[2], at[11]); MULADD(at[3], at[10]); MULADD(at[4], at[9]);
405 COMBA_STORE(C->dp[4]);
408 MULADD(at[0], at[14]); MULADD(at[1], at[13]); MULADD(at[2], at[12]); MULADD(at[3], at[11]); MULADD(at[4], at[10]); MULADD(at[5], at[9]);
409 COMBA_STORE(C->dp[5]);
412 MULADD(at[0], at[15]); MULADD(at[1], at[14]); MULADD(at[2], at[13]); MULADD(at[3], at[12]); MULADD(at[4], at[11]); MULADD(at[5], at[10]); MULADD(at[6], at[9]);
413 COMBA_STORE(C->dp[6]);
416 MULADD(at[0], at[16]); MULADD(at[1], at[15]); MULADD(at[2], at[14]); MULADD(at[3], at[13]); MULADD(at[4], at[12]); MULADD(at[5], at[11]); MULADD(at[6], at[10]); MULADD(at[7], at[9]);
417 COMBA_STORE(C->dp[7]);
420 MULADD(at[0], at[17]); MULADD(at[1], at[16]); MULADD(at[2], at[15]); MULADD(at[3], at[14]); MULADD(at[4], at[13]); MULADD(at[5], at[12]); MULADD(at[6], at[11]); MULADD(at[7], at[10]); MULADD(at[8], at[9]);
421 COMBA_STORE(C->dp[8]);
424 MULADD(at[1], at[17]); MULADD(at[2], at[16]); MULADD(at[3], at[15]); MULADD(at[4], at[14]); MULADD(at[5], at[13]); MULADD(at[6], at[12]); MULADD(at[7], at[11]); MULADD(at[8], at[10]);
425 COMBA_STORE(C->dp[9]);
428 MULADD(at[2], at[17]); MULADD(at[3], at[16]); MULADD(at[4], at[15]); MULADD(at[5], at[14]); MULADD(at[6], at[13]); MULADD(at[7], at[12]); MULADD(at[8], at[11]);
429 COMBA_STORE(C->dp[10]);
432 MULADD(at[3], at[17]); MULADD(at[4], at[16]); MULADD(at[5], at[15]); MULADD(at[6], at[14]); MULADD(at[7], at[13]); MULADD(at[8], at[12]);
433 COMBA_STORE(C->dp[11]);
436 MULADD(at[4], at[17]); MULADD(at[5], at[16]); MULADD(at[6], at[15]); MULADD(at[7], at[14]); MULADD(at[8], at[13]);
437 COMBA_STORE(C->dp[12]);
440 MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]); MULADD(at[8], at[14]);
441 COMBA_STORE(C->dp[13]);
444 MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]);
445 COMBA_STORE(C->dp[14]);
448 MULADD(at[7], at[17]); MULADD(at[8], at[16]);
449 COMBA_STORE(C->dp[15]);
452 MULADD(at[8], at[17]);
453 COMBA_STORE(C->dp[16]);
454 COMBA_STORE2(C->dp[17]);
456 C->sign = A->sign ^ B->sign;
462 memcpy(at, A->dp, 10 * sizeof(fp_digit));
463 memcpy(at+10, B->dp, 10 * sizeof(fp_digit));
468 MULADD(at[0], at[10]);
469 COMBA_STORE(C->dp[0]);
472 MULADD(at[0], at[11]); MULADD(at[1], at[10]);
473 COMBA_STORE(C->dp[1]);
476 MULADD(at[0], at[12]); MULADD(at[1], at[11]); MULADD(at[2], at[10]);
477 COMBA_STORE(C->dp[2]);
480 MULADD(at[0], at[13]); MULADD(at[1], at[12]); MULADD(at[2], at[11]); MULADD(at[3], at[10]);
481 COMBA_STORE(C->dp[3]);
484 MULADD(at[0], at[14]); MULADD(at[1], at[13]); MULADD(at[2], at[12]); MULADD(at[3], at[11]); MULADD(at[4], at[10]);
485 COMBA_STORE(C->dp[4]);
488 MULADD(at[0], at[15]); MULADD(at[1], at[14]); MULADD(at[2], at[13]); MULADD(at[3], at[12]); MULADD(at[4], at[11]); MULADD(at[5], at[10]);
489 COMBA_STORE(C->dp[5]);
492 MULADD(at[0], at[16]); MULADD(at[1], at[15]); MULADD(at[2], at[14]); MULADD(at[3], at[13]); MULADD(at[4], at[12]); MULADD(at[5], at[11]); MULADD(at[6], at[10]);
493 COMBA_STORE(C->dp[6]);
496 MULADD(at[0], at[17]); MULADD(at[1], at[16]); MULADD(at[2], at[15]); MULADD(at[3], at[14]); MULADD(at[4], at[13]); MULADD(at[5], at[12]); MULADD(at[6], at[11]); MULADD(at[7], at[10]);
497 COMBA_STORE(C->dp[7]);
500 MULADD(at[0], at[18]); MULADD(at[1], at[17]); MULADD(at[2], at[16]); MULADD(at[3], at[15]); MULADD(at[4], at[14]); MULADD(at[5], at[13]); MULADD(at[6], at[12]); MULADD(at[7], at[11]); MULADD(at[8], at[10]);
501 COMBA_STORE(C->dp[8]);
504 MULADD(at[0], at[19]); MULADD(at[1], at[18]); MULADD(at[2], at[17]); MULADD(at[3], at[16]); MULADD(at[4], at[15]); MULADD(at[5], at[14]); MULADD(at[6], at[13]); MULADD(at[7], at[12]); MULADD(at[8], at[11]); MULADD(at[9], at[10]);
505 COMBA_STORE(C->dp[9]);
508 MULADD(at[1], at[19]); MULADD(at[2], at[18]); MULADD(at[3], at[17]); MULADD(at[4], at[16]); MULADD(at[5], at[15]); MULADD(at[6], at[14]); MULADD(at[7], at[13]); MULADD(at[8], at[12]); MULADD(at[9], at[11]);
509 COMBA_STORE(C->dp[10]);
512 MULADD(at[2], at[19]); MULADD(at[3], at[18]); MULADD(at[4], at[17]); MULADD(at[5], at[16]); MULADD(at[6], at[15]); MULADD(at[7], at[14]); MULADD(at[8], at[13]); MULADD(at[9], at[12]);
513 COMBA_STORE(C->dp[11]);
516 MULADD(at[3], at[19]); MULADD(at[4], at[18]); MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]); MULADD(at[8], at[14]); MULADD(at[9], at[13]);
517 COMBA_STORE(C->dp[12]);
520 MULADD(at[4], at[19]); MULADD(at[5], at[18]); MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]); MULADD(at[9], at[14]);
521 COMBA_STORE(C->dp[13]);
524 MULADD(at[5], at[19]); MULADD(at[6], at[18]); MULADD(at[7], at[17]); MULADD(at[8], at[16]); MULADD(at[9], at[15]);
525 COMBA_STORE(C->dp[14]);
528 MULADD(at[6], at[19]); MULADD(at[7], at[18]); MULADD(at[8], at[17]); MULADD(at[9], at[16]);
529 COMBA_STORE(C->dp[15]);
532 MULADD(at[7], at[19]); MULADD(at[8], at[18]); MULADD(at[9], at[17]);
533 COMBA_STORE(C->dp[16]);
536 MULADD(at[8], at[19]); MULADD(at[9], at[18]);
537 COMBA_STORE(C->dp[17]);
540 MULADD(at[9], at[19]);
541 COMBA_STORE(C->dp[18]);
542 COMBA_STORE2(C->dp[19]);
544 C->sign = A->sign ^ B->sign;
550 memcpy(at, A->dp, 11 * sizeof(fp_digit));
551 memcpy(at+11, B->dp, 11 * sizeof(fp_digit));
556 MULADD(at[0], at[11]);
557 COMBA_STORE(C->dp[0]);
560 MULADD(at[0], at[12]); MULADD(at[1], at[11]);
561 COMBA_STORE(C->dp[1]);
564 MULADD(at[0], at[13]); MULADD(at[1], at[12]); MULADD(at[2], at[11]);
565 COMBA_STORE(C->dp[2]);
568 MULADD(at[0], at[14]); MULADD(at[1], at[13]); MULADD(at[2], at[12]); MULADD(at[3], at[11]);
569 COMBA_STORE(C->dp[3]);
572 MULADD(at[0], at[15]); MULADD(at[1], at[14]); MULADD(at[2], at[13]); MULADD(at[3], at[12]); MULADD(at[4], at[11]);
573 COMBA_STORE(C->dp[4]);
576 MULADD(at[0], at[16]); MULADD(at[1], at[15]); MULADD(at[2], at[14]); MULADD(at[3], at[13]); MULADD(at[4], at[12]); MULADD(at[5], at[11]);
577 COMBA_STORE(C->dp[5]);
580 MULADD(at[0], at[17]); MULADD(at[1], at[16]); MULADD(at[2], at[15]); MULADD(at[3], at[14]); MULADD(at[4], at[13]); MULADD(at[5], at[12]); MULADD(at[6], at[11]);
581 COMBA_STORE(C->dp[6]);
584 MULADD(at[0], at[18]); MULADD(at[1], at[17]); MULADD(at[2], at[16]); MULADD(at[3], at[15]); MULADD(at[4], at[14]); MULADD(at[5], at[13]); MULADD(at[6], at[12]); MULADD(at[7], at[11]);
585 COMBA_STORE(C->dp[7]);
588 MULADD(at[0], at[19]); MULADD(at[1], at[18]); MULADD(at[2], at[17]); MULADD(at[3], at[16]); MULADD(at[4], at[15]); MULADD(at[5], at[14]); MULADD(at[6], at[13]); MULADD(at[7], at[12]); MULADD(at[8], at[11]);
589 COMBA_STORE(C->dp[8]);
592 MULADD(at[0], at[20]); MULADD(at[1], at[19]); MULADD(at[2], at[18]); MULADD(at[3], at[17]); MULADD(at[4], at[16]); MULADD(at[5], at[15]); MULADD(at[6], at[14]); MULADD(at[7], at[13]); MULADD(at[8], at[12]); MULADD(at[9], at[11]);
593 COMBA_STORE(C->dp[9]);
596 MULADD(at[0], at[21]); MULADD(at[1], at[20]); MULADD(at[2], at[19]); MULADD(at[3], at[18]); MULADD(at[4], at[17]); MULADD(at[5], at[16]); MULADD(at[6], at[15]); MULADD(at[7], at[14]); MULADD(at[8], at[13]); MULADD(at[9], at[12]); MULADD(at[10], at[11]);
597 COMBA_STORE(C->dp[10]);
600 MULADD(at[1], at[21]); MULADD(at[2], at[20]); MULADD(at[3], at[19]); MULADD(at[4], at[18]); MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]); MULADD(at[8], at[14]); MULADD(at[9], at[13]); MULADD(at[10], at[12]);
601 COMBA_STORE(C->dp[11]);
604 MULADD(at[2], at[21]); MULADD(at[3], at[20]); MULADD(at[4], at[19]); MULADD(at[5], at[18]); MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]); MULADD(at[9], at[14]); MULADD(at[10], at[13]);
605 COMBA_STORE(C->dp[12]);
608 MULADD(at[3], at[21]); MULADD(at[4], at[20]); MULADD(at[5], at[19]); MULADD(at[6], at[18]); MULADD(at[7], at[17]); MULADD(at[8], at[16]); MULADD(at[9], at[15]); MULADD(at[10], at[14]);
609 COMBA_STORE(C->dp[13]);
612 MULADD(at[4], at[21]); MULADD(at[5], at[20]); MULADD(at[6], at[19]); MULADD(at[7], at[18]); MULADD(at[8], at[17]); MULADD(at[9], at[16]); MULADD(at[10], at[15]);
613 COMBA_STORE(C->dp[14]);
616 MULADD(at[5], at[21]); MULADD(at[6], at[20]); MULADD(at[7], at[19]); MULADD(at[8], at[18]); MULADD(at[9], at[17]); MULADD(at[10], at[16]);
617 COMBA_STORE(C->dp[15]);
620 MULADD(at[6], at[21]); MULADD(at[7], at[20]); MULADD(at[8], at[19]); MULADD(at[9], at[18]); MULADD(at[10], at[17]);
621 COMBA_STORE(C->dp[16]);
624 MULADD(at[7], at[21]); MULADD(at[8], at[20]); MULADD(at[9], at[19]); MULADD(at[10], at[18]);
625 COMBA_STORE(C->dp[17]);
628 MULADD(at[8], at[21]); MULADD(at[9], at[20]); MULADD(at[10], at[19]);
629 COMBA_STORE(C->dp[18]);
632 MULADD(at[9], at[21]); MULADD(at[10], at[20]);
633 COMBA_STORE(C->dp[19]);
636 MULADD(at[10], at[21]);
637 COMBA_STORE(C->dp[20]);
638 COMBA_STORE2(C->dp[21]);
640 C->sign = A->sign ^ B->sign;
646 memcpy(at, A->dp, 12 * sizeof(fp_digit));
647 memcpy(at+12, B->dp, 12 * sizeof(fp_digit));
652 MULADD(at[0], at[12]);
653 COMBA_STORE(C->dp[0]);
656 MULADD(at[0], at[13]); MULADD(at[1], at[12]);
657 COMBA_STORE(C->dp[1]);
660 MULADD(at[0], at[14]); MULADD(at[1], at[13]); MULADD(at[2], at[12]);
661 COMBA_STORE(C->dp[2]);
664 MULADD(at[0], at[15]); MULADD(at[1], at[14]); MULADD(at[2], at[13]); MULADD(at[3], at[12]);
665 COMBA_STORE(C->dp[3]);
668 MULADD(at[0], at[16]); MULADD(at[1], at[15]); MULADD(at[2], at[14]); MULADD(at[3], at[13]); MULADD(at[4], at[12]);
669 COMBA_STORE(C->dp[4]);
672 MULADD(at[0], at[17]); MULADD(at[1], at[16]); MULADD(at[2], at[15]); MULADD(at[3], at[14]); MULADD(at[4], at[13]); MULADD(at[5], at[12]);
673 COMBA_STORE(C->dp[5]);
676 MULADD(at[0], at[18]); MULADD(at[1], at[17]); MULADD(at[2], at[16]); MULADD(at[3], at[15]); MULADD(at[4], at[14]); MULADD(at[5], at[13]); MULADD(at[6], at[12]);
677 COMBA_STORE(C->dp[6]);
680 MULADD(at[0], at[19]); MULADD(at[1], at[18]); MULADD(at[2], at[17]); MULADD(at[3], at[16]); MULADD(at[4], at[15]); MULADD(at[5], at[14]); MULADD(at[6], at[13]); MULADD(at[7], at[12]);
681 COMBA_STORE(C->dp[7]);
684 MULADD(at[0], at[20]); MULADD(at[1], at[19]); MULADD(at[2], at[18]); MULADD(at[3], at[17]); MULADD(at[4], at[16]); MULADD(at[5], at[15]); MULADD(at[6], at[14]); MULADD(at[7], at[13]); MULADD(at[8], at[12]);
685 COMBA_STORE(C->dp[8]);
688 MULADD(at[0], at[21]); MULADD(at[1], at[20]); MULADD(at[2], at[19]); MULADD(at[3], at[18]); MULADD(at[4], at[17]); MULADD(at[5], at[16]); MULADD(at[6], at[15]); MULADD(at[7], at[14]); MULADD(at[8], at[13]); MULADD(at[9], at[12]);
689 COMBA_STORE(C->dp[9]);
692 MULADD(at[0], at[22]); MULADD(at[1], at[21]); MULADD(at[2], at[20]); MULADD(at[3], at[19]); MULADD(at[4], at[18]); MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]); MULADD(at[8], at[14]); MULADD(at[9], at[13]); MULADD(at[10], at[12]);
693 COMBA_STORE(C->dp[10]);
696 MULADD(at[0], at[23]); MULADD(at[1], at[22]); MULADD(at[2], at[21]); MULADD(at[3], at[20]); MULADD(at[4], at[19]); MULADD(at[5], at[18]); MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]); MULADD(at[9], at[14]); MULADD(at[10], at[13]); MULADD(at[11], at[12]);
697 COMBA_STORE(C->dp[11]);
700 MULADD(at[1], at[23]); MULADD(at[2], at[22]); MULADD(at[3], at[21]); MULADD(at[4], at[20]); MULADD(at[5], at[19]); MULADD(at[6], at[18]); MULADD(at[7], at[17]); MULADD(at[8], at[16]); MULADD(at[9], at[15]); MULADD(at[10], at[14]); MULADD(at[11], at[13]);
701 COMBA_STORE(C->dp[12]);
704 MULADD(at[2], at[23]); MULADD(at[3], at[22]); MULADD(at[4], at[21]); MULADD(at[5], at[20]); MULADD(at[6], at[19]); MULADD(at[7], at[18]); MULADD(at[8], at[17]); MULADD(at[9], at[16]); MULADD(at[10], at[15]); MULADD(at[11], at[14]);
705 COMBA_STORE(C->dp[13]);
708 MULADD(at[3], at[23]); MULADD(at[4], at[22]); MULADD(at[5], at[21]); MULADD(at[6], at[20]); MULADD(at[7], at[19]); MULADD(at[8], at[18]); MULADD(at[9], at[17]); MULADD(at[10], at[16]); MULADD(at[11], at[15]);
709 COMBA_STORE(C->dp[14]);
712 MULADD(at[4], at[23]); MULADD(at[5], at[22]); MULADD(at[6], at[21]); MULADD(at[7], at[20]); MULADD(at[8], at[19]); MULADD(at[9], at[18]); MULADD(at[10], at[17]); MULADD(at[11], at[16]);
713 COMBA_STORE(C->dp[15]);
716 MULADD(at[5], at[23]); MULADD(at[6], at[22]); MULADD(at[7], at[21]); MULADD(at[8], at[20]); MULADD(at[9], at[19]); MULADD(at[10], at[18]); MULADD(at[11], at[17]);
717 COMBA_STORE(C->dp[16]);
720 MULADD(at[6], at[23]); MULADD(at[7], at[22]); MULADD(at[8], at[21]); MULADD(at[9], at[20]); MULADD(at[10], at[19]); MULADD(at[11], at[18]);
721 COMBA_STORE(C->dp[17]);
724 MULADD(at[7], at[23]); MULADD(at[8], at[22]); MULADD(at[9], at[21]); MULADD(at[10], at[20]); MULADD(at[11], at[19]);
725 COMBA_STORE(C->dp[18]);
728 MULADD(at[8], at[23]); MULADD(at[9], at[22]); MULADD(at[10], at[21]); MULADD(at[11], at[20]);
729 COMBA_STORE(C->dp[19]);
732 MULADD(at[9], at[23]); MULADD(at[10], at[22]); MULADD(at[11], at[21]);
733 COMBA_STORE(C->dp[20]);
736 MULADD(at[10], at[23]); MULADD(at[11], at[22]);
737 COMBA_STORE(C->dp[21]);
740 MULADD(at[11], at[23]);
741 COMBA_STORE(C->dp[22]);
742 COMBA_STORE2(C->dp[23]);
744 C->sign = A->sign ^ B->sign;
750 memcpy(at, A->dp, 13 * sizeof(fp_digit));
751 memcpy(at+13, B->dp, 13 * sizeof(fp_digit));
756 MULADD(at[0], at[13]);
757 COMBA_STORE(C->dp[0]);
760 MULADD(at[0], at[14]); MULADD(at[1], at[13]);
761 COMBA_STORE(C->dp[1]);
764 MULADD(at[0], at[15]); MULADD(at[1], at[14]); MULADD(at[2], at[13]);
765 COMBA_STORE(C->dp[2]);
768 MULADD(at[0], at[16]); MULADD(at[1], at[15]); MULADD(at[2], at[14]); MULADD(at[3], at[13]);
769 COMBA_STORE(C->dp[3]);
772 MULADD(at[0], at[17]); MULADD(at[1], at[16]); MULADD(at[2], at[15]); MULADD(at[3], at[14]); MULADD(at[4], at[13]);
773 COMBA_STORE(C->dp[4]);
776 MULADD(at[0], at[18]); MULADD(at[1], at[17]); MULADD(at[2], at[16]); MULADD(at[3], at[15]); MULADD(at[4], at[14]); MULADD(at[5], at[13]);
777 COMBA_STORE(C->dp[5]);
780 MULADD(at[0], at[19]); MULADD(at[1], at[18]); MULADD(at[2], at[17]); MULADD(at[3], at[16]); MULADD(at[4], at[15]); MULADD(at[5], at[14]); MULADD(at[6], at[13]);
781 COMBA_STORE(C->dp[6]);
784 MULADD(at[0], at[20]); MULADD(at[1], at[19]); MULADD(at[2], at[18]); MULADD(at[3], at[17]); MULADD(at[4], at[16]); MULADD(at[5], at[15]); MULADD(at[6], at[14]); MULADD(at[7], at[13]);
785 COMBA_STORE(C->dp[7]);
788 MULADD(at[0], at[21]); MULADD(at[1], at[20]); MULADD(at[2], at[19]); MULADD(at[3], at[18]); MULADD(at[4], at[17]); MULADD(at[5], at[16]); MULADD(at[6], at[15]); MULADD(at[7], at[14]); MULADD(at[8], at[13]);
789 COMBA_STORE(C->dp[8]);
792 MULADD(at[0], at[22]); MULADD(at[1], at[21]); MULADD(at[2], at[20]); MULADD(at[3], at[19]); MULADD(at[4], at[18]); MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]); MULADD(at[8], at[14]); MULADD(at[9], at[13]);
793 COMBA_STORE(C->dp[9]);
796 MULADD(at[0], at[23]); MULADD(at[1], at[22]); MULADD(at[2], at[21]); MULADD(at[3], at[20]); MULADD(at[4], at[19]); MULADD(at[5], at[18]); MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]); MULADD(at[9], at[14]); MULADD(at[10], at[13]);
797 COMBA_STORE(C->dp[10]);
800 MULADD(at[0], at[24]); MULADD(at[1], at[23]); MULADD(at[2], at[22]); MULADD(at[3], at[21]); MULADD(at[4], at[20]); MULADD(at[5], at[19]); MULADD(at[6], at[18]); MULADD(at[7], at[17]); MULADD(at[8], at[16]); MULADD(at[9], at[15]); MULADD(at[10], at[14]); MULADD(at[11], at[13]);
801 COMBA_STORE(C->dp[11]);
804 MULADD(at[0], at[25]); MULADD(at[1], at[24]); MULADD(at[2], at[23]); MULADD(at[3], at[22]); MULADD(at[4], at[21]); MULADD(at[5], at[20]); MULADD(at[6], at[19]); MULADD(at[7], at[18]); MULADD(at[8], at[17]); MULADD(at[9], at[16]); MULADD(at[10], at[15]); MULADD(at[11], at[14]); MULADD(at[12], at[13]);
805 COMBA_STORE(C->dp[12]);
808 MULADD(at[1], at[25]); MULADD(at[2], at[24]); MULADD(at[3], at[23]); MULADD(at[4], at[22]); MULADD(at[5], at[21]); MULADD(at[6], at[20]); MULADD(at[7], at[19]); MULADD(at[8], at[18]); MULADD(at[9], at[17]); MULADD(at[10], at[16]); MULADD(at[11], at[15]); MULADD(at[12], at[14]);
809 COMBA_STORE(C->dp[13]);
812 MULADD(at[2], at[25]); MULADD(at[3], at[24]); MULADD(at[4], at[23]); MULADD(at[5], at[22]); MULADD(at[6], at[21]); MULADD(at[7], at[20]); MULADD(at[8], at[19]); MULADD(at[9], at[18]); MULADD(at[10], at[17]); MULADD(at[11], at[16]); MULADD(at[12], at[15]);
813 COMBA_STORE(C->dp[14]);
816 MULADD(at[3], at[25]); MULADD(at[4], at[24]); MULADD(at[5], at[23]); MULADD(at[6], at[22]); MULADD(at[7], at[21]); MULADD(at[8], at[20]); MULADD(at[9], at[19]); MULADD(at[10], at[18]); MULADD(at[11], at[17]); MULADD(at[12], at[16]);
817 COMBA_STORE(C->dp[15]);
820 MULADD(at[4], at[25]); MULADD(at[5], at[24]); MULADD(at[6], at[23]); MULADD(at[7], at[22]); MULADD(at[8], at[21]); MULADD(at[9], at[20]); MULADD(at[10], at[19]); MULADD(at[11], at[18]); MULADD(at[12], at[17]);
821 COMBA_STORE(C->dp[16]);
824 MULADD(at[5], at[25]); MULADD(at[6], at[24]); MULADD(at[7], at[23]); MULADD(at[8], at[22]); MULADD(at[9], at[21]); MULADD(at[10], at[20]); MULADD(at[11], at[19]); MULADD(at[12], at[18]);
825 COMBA_STORE(C->dp[17]);
828 MULADD(at[6], at[25]); MULADD(at[7], at[24]); MULADD(at[8], at[23]); MULADD(at[9], at[22]); MULADD(at[10], at[21]); MULADD(at[11], at[20]); MULADD(at[12], at[19]);
829 COMBA_STORE(C->dp[18]);
832 MULADD(at[7], at[25]); MULADD(at[8], at[24]); MULADD(at[9], at[23]); MULADD(at[10], at[22]); MULADD(at[11], at[21]); MULADD(at[12], at[20]);
833 COMBA_STORE(C->dp[19]);
836 MULADD(at[8], at[25]); MULADD(at[9], at[24]); MULADD(at[10], at[23]); MULADD(at[11], at[22]); MULADD(at[12], at[21]);
837 COMBA_STORE(C->dp[20]);
840 MULADD(at[9], at[25]); MULADD(at[10], at[24]); MULADD(at[11], at[23]); MULADD(at[12], at[22]);
841 COMBA_STORE(C->dp[21]);
844 MULADD(at[10], at[25]); MULADD(at[11], at[24]); MULADD(at[12], at[23]);
845 COMBA_STORE(C->dp[22]);
848 MULADD(at[11], at[25]); MULADD(at[12], at[24]);
849 COMBA_STORE(C->dp[23]);
852 MULADD(at[12], at[25]);
853 COMBA_STORE(C->dp[24]);
854 COMBA_STORE2(C->dp[25]);
856 C->sign = A->sign ^ B->sign;
862 memcpy(at, A->dp, 14 * sizeof(fp_digit));
863 memcpy(at+14, B->dp, 14 * sizeof(fp_digit));
868 MULADD(at[0], at[14]);
869 COMBA_STORE(C->dp[0]);
872 MULADD(at[0], at[15]); MULADD(at[1], at[14]);
873 COMBA_STORE(C->dp[1]);
876 MULADD(at[0], at[16]); MULADD(at[1], at[15]); MULADD(at[2], at[14]);
877 COMBA_STORE(C->dp[2]);
880 MULADD(at[0], at[17]); MULADD(at[1], at[16]); MULADD(at[2], at[15]); MULADD(at[3], at[14]);
881 COMBA_STORE(C->dp[3]);
884 MULADD(at[0], at[18]); MULADD(at[1], at[17]); MULADD(at[2], at[16]); MULADD(at[3], at[15]); MULADD(at[4], at[14]);
885 COMBA_STORE(C->dp[4]);
888 MULADD(at[0], at[19]); MULADD(at[1], at[18]); MULADD(at[2], at[17]); MULADD(at[3], at[16]); MULADD(at[4], at[15]); MULADD(at[5], at[14]);
889 COMBA_STORE(C->dp[5]);
892 MULADD(at[0], at[20]); MULADD(at[1], at[19]); MULADD(at[2], at[18]); MULADD(at[3], at[17]); MULADD(at[4], at[16]); MULADD(at[5], at[15]); MULADD(at[6], at[14]);
893 COMBA_STORE(C->dp[6]);
896 MULADD(at[0], at[21]); MULADD(at[1], at[20]); MULADD(at[2], at[19]); MULADD(at[3], at[18]); MULADD(at[4], at[17]); MULADD(at[5], at[16]); MULADD(at[6], at[15]); MULADD(at[7], at[14]);
897 COMBA_STORE(C->dp[7]);
900 MULADD(at[0], at[22]); MULADD(at[1], at[21]); MULADD(at[2], at[20]); MULADD(at[3], at[19]); MULADD(at[4], at[18]); MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]); MULADD(at[8], at[14]);
901 COMBA_STORE(C->dp[8]);
904 MULADD(at[0], at[23]); MULADD(at[1], at[22]); MULADD(at[2], at[21]); MULADD(at[3], at[20]); MULADD(at[4], at[19]); MULADD(at[5], at[18]); MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]); MULADD(at[9], at[14]);
905 COMBA_STORE(C->dp[9]);
908 MULADD(at[0], at[24]); MULADD(at[1], at[23]); MULADD(at[2], at[22]); MULADD(at[3], at[21]); MULADD(at[4], at[20]); MULADD(at[5], at[19]); MULADD(at[6], at[18]); MULADD(at[7], at[17]); MULADD(at[8], at[16]); MULADD(at[9], at[15]); MULADD(at[10], at[14]);
909 COMBA_STORE(C->dp[10]);
912 MULADD(at[0], at[25]); MULADD(at[1], at[24]); MULADD(at[2], at[23]); MULADD(at[3], at[22]); MULADD(at[4], at[21]); MULADD(at[5], at[20]); MULADD(at[6], at[19]); MULADD(at[7], at[18]); MULADD(at[8], at[17]); MULADD(at[9], at[16]); MULADD(at[10], at[15]); MULADD(at[11], at[14]);
913 COMBA_STORE(C->dp[11]);
916 MULADD(at[0], at[26]); MULADD(at[1], at[25]); MULADD(at[2], at[24]); MULADD(at[3], at[23]); MULADD(at[4], at[22]); MULADD(at[5], at[21]); MULADD(at[6], at[20]); MULADD(at[7], at[19]); MULADD(at[8], at[18]); MULADD(at[9], at[17]); MULADD(at[10], at[16]); MULADD(at[11], at[15]); MULADD(at[12], at[14]);
917 COMBA_STORE(C->dp[12]);
920 MULADD(at[0], at[27]); MULADD(at[1], at[26]); MULADD(at[2], at[25]); MULADD(at[3], at[24]); MULADD(at[4], at[23]); MULADD(at[5], at[22]); MULADD(at[6], at[21]); MULADD(at[7], at[20]); MULADD(at[8], at[19]); MULADD(at[9], at[18]); MULADD(at[10], at[17]); MULADD(at[11], at[16]); MULADD(at[12], at[15]); MULADD(at[13], at[14]);
921 COMBA_STORE(C->dp[13]);
924 MULADD(at[1], at[27]); MULADD(at[2], at[26]); MULADD(at[3], at[25]); MULADD(at[4], at[24]); MULADD(at[5], at[23]); MULADD(at[6], at[22]); MULADD(at[7], at[21]); MULADD(at[8], at[20]); MULADD(at[9], at[19]); MULADD(at[10], at[18]); MULADD(at[11], at[17]); MULADD(at[12], at[16]); MULADD(at[13], at[15]);
925 COMBA_STORE(C->dp[14]);
928 MULADD(at[2], at[27]); MULADD(at[3], at[26]); MULADD(at[4], at[25]); MULADD(at[5], at[24]); MULADD(at[6], at[23]); MULADD(at[7], at[22]); MULADD(at[8], at[21]); MULADD(at[9], at[20]); MULADD(at[10], at[19]); MULADD(at[11], at[18]); MULADD(at[12], at[17]); MULADD(at[13], at[16]);
929 COMBA_STORE(C->dp[15]);
932 MULADD(at[3], at[27]); MULADD(at[4], at[26]); MULADD(at[5], at[25]); MULADD(at[6], at[24]); MULADD(at[7], at[23]); MULADD(at[8], at[22]); MULADD(at[9], at[21]); MULADD(at[10], at[20]); MULADD(at[11], at[19]); MULADD(at[12], at[18]); MULADD(at[13], at[17]);
933 COMBA_STORE(C->dp[16]);
936 MULADD(at[4], at[27]); MULADD(at[5], at[26]); MULADD(at[6], at[25]); MULADD(at[7], at[24]); MULADD(at[8], at[23]); MULADD(at[9], at[22]); MULADD(at[10], at[21]); MULADD(at[11], at[20]); MULADD(at[12], at[19]); MULADD(at[13], at[18]);
937 COMBA_STORE(C->dp[17]);
940 MULADD(at[5], at[27]); MULADD(at[6], at[26]); MULADD(at[7], at[25]); MULADD(at[8], at[24]); MULADD(at[9], at[23]); MULADD(at[10], at[22]); MULADD(at[11], at[21]); MULADD(at[12], at[20]); MULADD(at[13], at[19]);
941 COMBA_STORE(C->dp[18]);
944 MULADD(at[6], at[27]); MULADD(at[7], at[26]); MULADD(at[8], at[25]); MULADD(at[9], at[24]); MULADD(at[10], at[23]); MULADD(at[11], at[22]); MULADD(at[12], at[21]); MULADD(at[13], at[20]);
945 COMBA_STORE(C->dp[19]);
948 MULADD(at[7], at[27]); MULADD(at[8], at[26]); MULADD(at[9], at[25]); MULADD(at[10], at[24]); MULADD(at[11], at[23]); MULADD(at[12], at[22]); MULADD(at[13], at[21]);
949 COMBA_STORE(C->dp[20]);
952 MULADD(at[8], at[27]); MULADD(at[9], at[26]); MULADD(at[10], at[25]); MULADD(at[11], at[24]); MULADD(at[12], at[23]); MULADD(at[13], at[22]);
953 COMBA_STORE(C->dp[21]);
956 MULADD(at[9], at[27]); MULADD(at[10], at[26]); MULADD(at[11], at[25]); MULADD(at[12], at[24]); MULADD(at[13], at[23]);
957 COMBA_STORE(C->dp[22]);
960 MULADD(at[10], at[27]); MULADD(at[11], at[26]); MULADD(at[12], at[25]); MULADD(at[13], at[24]);
961 COMBA_STORE(C->dp[23]);
964 MULADD(at[11], at[27]); MULADD(at[12], at[26]); MULADD(at[13], at[25]);
965 COMBA_STORE(C->dp[24]);
968 MULADD(at[12], at[27]); MULADD(at[13], at[26]);
969 COMBA_STORE(C->dp[25]);
972 MULADD(at[13], at[27]);
973 COMBA_STORE(C->dp[26]);
974 COMBA_STORE2(C->dp[27]);
976 C->sign = A->sign ^ B->sign;
982 memcpy(at, A->dp, 15 * sizeof(fp_digit));
983 memcpy(at+15, B->dp, 15 * sizeof(fp_digit));
988 MULADD(at[0], at[15]);
989 COMBA_STORE(C->dp[0]);
992 MULADD(at[0], at[16]); MULADD(at[1], at[15]);
993 COMBA_STORE(C->dp[1]);
996 MULADD(at[0], at[17]); MULADD(at[1], at[16]); MULADD(at[2], at[15]);
997 COMBA_STORE(C->dp[2]);
1000 MULADD(at[0], at[18]); MULADD(at[1], at[17]); MULADD(at[2], at[16]); MULADD(at[3], at[15]);
1001 COMBA_STORE(C->dp[3]);
1004 MULADD(at[0], at[19]); MULADD(at[1], at[18]); MULADD(at[2], at[17]); MULADD(at[3], at[16]); MULADD(at[4], at[15]);
1005 COMBA_STORE(C->dp[4]);
1008 MULADD(at[0], at[20]); MULADD(at[1], at[19]); MULADD(at[2], at[18]); MULADD(at[3], at[17]); MULADD(at[4], at[16]); MULADD(at[5], at[15]);
1009 COMBA_STORE(C->dp[5]);
1012 MULADD(at[0], at[21]); MULADD(at[1], at[20]); MULADD(at[2], at[19]); MULADD(at[3], at[18]); MULADD(at[4], at[17]); MULADD(at[5], at[16]); MULADD(at[6], at[15]);
1013 COMBA_STORE(C->dp[6]);
1016 MULADD(at[0], at[22]); MULADD(at[1], at[21]); MULADD(at[2], at[20]); MULADD(at[3], at[19]); MULADD(at[4], at[18]); MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]);
1017 COMBA_STORE(C->dp[7]);
1020 MULADD(at[0], at[23]); MULADD(at[1], at[22]); MULADD(at[2], at[21]); MULADD(at[3], at[20]); MULADD(at[4], at[19]); MULADD(at[5], at[18]); MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]);
1021 COMBA_STORE(C->dp[8]);
1024 MULADD(at[0], at[24]); MULADD(at[1], at[23]); MULADD(at[2], at[22]); MULADD(at[3], at[21]); MULADD(at[4], at[20]); MULADD(at[5], at[19]); MULADD(at[6], at[18]); MULADD(at[7], at[17]); MULADD(at[8], at[16]); MULADD(at[9], at[15]);
1025 COMBA_STORE(C->dp[9]);
1028 MULADD(at[0], at[25]); MULADD(at[1], at[24]); MULADD(at[2], at[23]); MULADD(at[3], at[22]); MULADD(at[4], at[21]); MULADD(at[5], at[20]); MULADD(at[6], at[19]); MULADD(at[7], at[18]); MULADD(at[8], at[17]); MULADD(at[9], at[16]); MULADD(at[10], at[15]);
1029 COMBA_STORE(C->dp[10]);
1032 MULADD(at[0], at[26]); MULADD(at[1], at[25]); MULADD(at[2], at[24]); MULADD(at[3], at[23]); MULADD(at[4], at[22]); MULADD(at[5], at[21]); MULADD(at[6], at[20]); MULADD(at[7], at[19]); MULADD(at[8], at[18]); MULADD(at[9], at[17]); MULADD(at[10], at[16]); MULADD(at[11], at[15]);
1033 COMBA_STORE(C->dp[11]);
1036 MULADD(at[0], at[27]); MULADD(at[1], at[26]); MULADD(at[2], at[25]); MULADD(at[3], at[24]); MULADD(at[4], at[23]); MULADD(at[5], at[22]); MULADD(at[6], at[21]); MULADD(at[7], at[20]); MULADD(at[8], at[19]); MULADD(at[9], at[18]); MULADD(at[10], at[17]); MULADD(at[11], at[16]); MULADD(at[12], at[15]);
1037 COMBA_STORE(C->dp[12]);
1040 MULADD(at[0], at[28]); MULADD(at[1], at[27]); MULADD(at[2], at[26]); MULADD(at[3], at[25]); MULADD(at[4], at[24]); MULADD(at[5], at[23]); MULADD(at[6], at[22]); MULADD(at[7], at[21]); MULADD(at[8], at[20]); MULADD(at[9], at[19]); MULADD(at[10], at[18]); MULADD(at[11], at[17]); MULADD(at[12], at[16]); MULADD(at[13], at[15]);
1041 COMBA_STORE(C->dp[13]);
1044 MULADD(at[0], at[29]); MULADD(at[1], at[28]); MULADD(at[2], at[27]); MULADD(at[3], at[26]); MULADD(at[4], at[25]); MULADD(at[5], at[24]); MULADD(at[6], at[23]); MULADD(at[7], at[22]); MULADD(at[8], at[21]); MULADD(at[9], at[20]); MULADD(at[10], at[19]); MULADD(at[11], at[18]); MULADD(at[12], at[17]); MULADD(at[13], at[16]); MULADD(at[14], at[15]);
1045 COMBA_STORE(C->dp[14]);
1048 MULADD(at[1], at[29]); MULADD(at[2], at[28]); MULADD(at[3], at[27]); MULADD(at[4], at[26]); MULADD(at[5], at[25]); MULADD(at[6], at[24]); MULADD(at[7], at[23]); MULADD(at[8], at[22]); MULADD(at[9], at[21]); MULADD(at[10], at[20]); MULADD(at[11], at[19]); MULADD(at[12], at[18]); MULADD(at[13], at[17]); MULADD(at[14], at[16]);
1049 COMBA_STORE(C->dp[15]);
1052 MULADD(at[2], at[29]); MULADD(at[3], at[28]); MULADD(at[4], at[27]); MULADD(at[5], at[26]); MULADD(at[6], at[25]); MULADD(at[7], at[24]); MULADD(at[8], at[23]); MULADD(at[9], at[22]); MULADD(at[10], at[21]); MULADD(at[11], at[20]); MULADD(at[12], at[19]); MULADD(at[13], at[18]); MULADD(at[14], at[17]);
1053 COMBA_STORE(C->dp[16]);
1056 MULADD(at[3], at[29]); MULADD(at[4], at[28]); MULADD(at[5], at[27]); MULADD(at[6], at[26]); MULADD(at[7], at[25]); MULADD(at[8], at[24]); MULADD(at[9], at[23]); MULADD(at[10], at[22]); MULADD(at[11], at[21]); MULADD(at[12], at[20]); MULADD(at[13], at[19]); MULADD(at[14], at[18]);
1057 COMBA_STORE(C->dp[17]);
1060 MULADD(at[4], at[29]); MULADD(at[5], at[28]); MULADD(at[6], at[27]); MULADD(at[7], at[26]); MULADD(at[8], at[25]); MULADD(at[9], at[24]); MULADD(at[10], at[23]); MULADD(at[11], at[22]); MULADD(at[12], at[21]); MULADD(at[13], at[20]); MULADD(at[14], at[19]);
1061 COMBA_STORE(C->dp[18]);
1064 MULADD(at[5], at[29]); MULADD(at[6], at[28]); MULADD(at[7], at[27]); MULADD(at[8], at[26]); MULADD(at[9], at[25]); MULADD(at[10], at[24]); MULADD(at[11], at[23]); MULADD(at[12], at[22]); MULADD(at[13], at[21]); MULADD(at[14], at[20]);
1065 COMBA_STORE(C->dp[19]);
1068 MULADD(at[6], at[29]); MULADD(at[7], at[28]); MULADD(at[8], at[27]); MULADD(at[9], at[26]); MULADD(at[10], at[25]); MULADD(at[11], at[24]); MULADD(at[12], at[23]); MULADD(at[13], at[22]); MULADD(at[14], at[21]);
1069 COMBA_STORE(C->dp[20]);
1072 MULADD(at[7], at[29]); MULADD(at[8], at[28]); MULADD(at[9], at[27]); MULADD(at[10], at[26]); MULADD(at[11], at[25]); MULADD(at[12], at[24]); MULADD(at[13], at[23]); MULADD(at[14], at[22]);
1073 COMBA_STORE(C->dp[21]);
1076 MULADD(at[8], at[29]); MULADD(at[9], at[28]); MULADD(at[10], at[27]); MULADD(at[11], at[26]); MULADD(at[12], at[25]); MULADD(at[13], at[24]); MULADD(at[14], at[23]);
1077 COMBA_STORE(C->dp[22]);
1080 MULADD(at[9], at[29]); MULADD(at[10], at[28]); MULADD(at[11], at[27]); MULADD(at[12], at[26]); MULADD(at[13], at[25]); MULADD(at[14], at[24]);
1081 COMBA_STORE(C->dp[23]);
1084 MULADD(at[10], at[29]); MULADD(at[11], at[28]); MULADD(at[12], at[27]); MULADD(at[13], at[26]); MULADD(at[14], at[25]);
1085 COMBA_STORE(C->dp[24]);
1088 MULADD(at[11], at[29]); MULADD(at[12], at[28]); MULADD(at[13], at[27]); MULADD(at[14], at[26]);
1089 COMBA_STORE(C->dp[25]);
1092 MULADD(at[12], at[29]); MULADD(at[13], at[28]); MULADD(at[14], at[27]);
1093 COMBA_STORE(C->dp[26]);
1096 MULADD(at[13], at[29]); MULADD(at[14], at[28]);
1097 COMBA_STORE(C->dp[27]);
1100 MULADD(at[14], at[29]);
1101 COMBA_STORE(C->dp[28]);
1102 COMBA_STORE2(C->dp[29]);
1104 C->sign = A->sign ^ B->sign;
1110 memcpy(at, A->dp, 16 * sizeof(fp_digit));
1111 memcpy(at+16, B->dp, 16 * sizeof(fp_digit));
1116 MULADD(at[0], at[16]);
1117 COMBA_STORE(C->dp[0]);
1120 MULADD(at[0], at[17]); MULADD(at[1], at[16]);
1121 COMBA_STORE(C->dp[1]);
1124 MULADD(at[0], at[18]); MULADD(at[1], at[17]); MULADD(at[2], at[16]);
1125 COMBA_STORE(C->dp[2]);
1128 MULADD(at[0], at[19]); MULADD(at[1], at[18]); MULADD(at[2], at[17]); MULADD(at[3], at[16]);
1129 COMBA_STORE(C->dp[3]);
1132 MULADD(at[0], at[20]); MULADD(at[1], at[19]); MULADD(at[2], at[18]); MULADD(at[3], at[17]); MULADD(at[4], at[16]);
1133 COMBA_STORE(C->dp[4]);
1136 MULADD(at[0], at[21]); MULADD(at[1], at[20]); MULADD(at[2], at[19]); MULADD(at[3], at[18]); MULADD(at[4], at[17]); MULADD(at[5], at[16]);
1137 COMBA_STORE(C->dp[5]);
1140 MULADD(at[0], at[22]); MULADD(at[1], at[21]); MULADD(at[2], at[20]); MULADD(at[3], at[19]); MULADD(at[4], at[18]); MULADD(at[5], at[17]); MULADD(at[6], at[16]);
1141 COMBA_STORE(C->dp[6]);
1144 MULADD(at[0], at[23]); MULADD(at[1], at[22]); MULADD(at[2], at[21]); MULADD(at[3], at[20]); MULADD(at[4], at[19]); MULADD(at[5], at[18]); MULADD(at[6], at[17]); MULADD(at[7], at[16]);
1145 COMBA_STORE(C->dp[7]);
1148 MULADD(at[0], at[24]); MULADD(at[1], at[23]); MULADD(at[2], at[22]); MULADD(at[3], at[21]); MULADD(at[4], at[20]); MULADD(at[5], at[19]); MULADD(at[6], at[18]); MULADD(at[7], at[17]); MULADD(at[8], at[16]);
1149 COMBA_STORE(C->dp[8]);
1152 MULADD(at[0], at[25]); MULADD(at[1], at[24]); MULADD(at[2], at[23]); MULADD(at[3], at[22]); MULADD(at[4], at[21]); MULADD(at[5], at[20]); MULADD(at[6], at[19]); MULADD(at[7], at[18]); MULADD(at[8], at[17]); MULADD(at[9], at[16]);
1153 COMBA_STORE(C->dp[9]);
1156 MULADD(at[0], at[26]); MULADD(at[1], at[25]); MULADD(at[2], at[24]); MULADD(at[3], at[23]); MULADD(at[4], at[22]); MULADD(at[5], at[21]); MULADD(at[6], at[20]); MULADD(at[7], at[19]); MULADD(at[8], at[18]); MULADD(at[9], at[17]); MULADD(at[10], at[16]);
1157 COMBA_STORE(C->dp[10]);
1160 MULADD(at[0], at[27]); MULADD(at[1], at[26]); MULADD(at[2], at[25]); MULADD(at[3], at[24]); MULADD(at[4], at[23]); MULADD(at[5], at[22]); MULADD(at[6], at[21]); MULADD(at[7], at[20]); MULADD(at[8], at[19]); MULADD(at[9], at[18]); MULADD(at[10], at[17]); MULADD(at[11], at[16]);
1161 COMBA_STORE(C->dp[11]);
1164 MULADD(at[0], at[28]); MULADD(at[1], at[27]); MULADD(at[2], at[26]); MULADD(at[3], at[25]); MULADD(at[4], at[24]); MULADD(at[5], at[23]); MULADD(at[6], at[22]); MULADD(at[7], at[21]); MULADD(at[8], at[20]); MULADD(at[9], at[19]); MULADD(at[10], at[18]); MULADD(at[11], at[17]); MULADD(at[12], at[16]);
1165 COMBA_STORE(C->dp[12]);
1168 MULADD(at[0], at[29]); MULADD(at[1], at[28]); MULADD(at[2], at[27]); MULADD(at[3], at[26]); MULADD(at[4], at[25]); MULADD(at[5], at[24]); MULADD(at[6], at[23]); MULADD(at[7], at[22]); MULADD(at[8], at[21]); MULADD(at[9], at[20]); MULADD(at[10], at[19]); MULADD(at[11], at[18]); MULADD(at[12], at[17]); MULADD(at[13], at[16]);
1169 COMBA_STORE(C->dp[13]);
1172 MULADD(at[0], at[30]); MULADD(at[1], at[29]); MULADD(at[2], at[28]); MULADD(at[3], at[27]); MULADD(at[4], at[26]); MULADD(at[5], at[25]); MULADD(at[6], at[24]); MULADD(at[7], at[23]); MULADD(at[8], at[22]); MULADD(at[9], at[21]); MULADD(at[10], at[20]); MULADD(at[11], at[19]); MULADD(at[12], at[18]); MULADD(at[13], at[17]); MULADD(at[14], at[16]);
1173 COMBA_STORE(C->dp[14]);
1176 MULADD(at[0], at[31]); MULADD(at[1], at[30]); MULADD(at[2], at[29]); MULADD(at[3], at[28]); MULADD(at[4], at[27]); MULADD(at[5], at[26]); MULADD(at[6], at[25]); MULADD(at[7], at[24]); MULADD(at[8], at[23]); MULADD(at[9], at[22]); MULADD(at[10], at[21]); MULADD(at[11], at[20]); MULADD(at[12], at[19]); MULADD(at[13], at[18]); MULADD(at[14], at[17]); MULADD(at[15], at[16]);
1177 COMBA_STORE(C->dp[15]);
1180 MULADD(at[1], at[31]); MULADD(at[2], at[30]); MULADD(at[3], at[29]); MULADD(at[4], at[28]); MULADD(at[5], at[27]); MULADD(at[6], at[26]); MULADD(at[7], at[25]); MULADD(at[8], at[24]); MULADD(at[9], at[23]); MULADD(at[10], at[22]); MULADD(at[11], at[21]); MULADD(at[12], at[20]); MULADD(at[13], at[19]); MULADD(at[14], at[18]); MULADD(at[15], at[17]);
1181 COMBA_STORE(C->dp[16]);
1184 MULADD(at[2], at[31]); MULADD(at[3], at[30]); MULADD(at[4], at[29]); MULADD(at[5], at[28]); MULADD(at[6], at[27]); MULADD(at[7], at[26]); MULADD(at[8], at[25]); MULADD(at[9], at[24]); MULADD(at[10], at[23]); MULADD(at[11], at[22]); MULADD(at[12], at[21]); MULADD(at[13], at[20]); MULADD(at[14], at[19]); MULADD(at[15], at[18]);
1185 COMBA_STORE(C->dp[17]);
1188 MULADD(at[3], at[31]); MULADD(at[4], at[30]); MULADD(at[5], at[29]); MULADD(at[6], at[28]); MULADD(at[7], at[27]); MULADD(at[8], at[26]); MULADD(at[9], at[25]); MULADD(at[10], at[24]); MULADD(at[11], at[23]); MULADD(at[12], at[22]); MULADD(at[13], at[21]); MULADD(at[14], at[20]); MULADD(at[15], at[19]);
1189 COMBA_STORE(C->dp[18]);
1192 MULADD(at[4], at[31]); MULADD(at[5], at[30]); MULADD(at[6], at[29]); MULADD(at[7], at[28]); MULADD(at[8], at[27]); MULADD(at[9], at[26]); MULADD(at[10], at[25]); MULADD(at[11], at[24]); MULADD(at[12], at[23]); MULADD(at[13], at[22]); MULADD(at[14], at[21]); MULADD(at[15], at[20]);
1193 COMBA_STORE(C->dp[19]);
1196 MULADD(at[5], at[31]); MULADD(at[6], at[30]); MULADD(at[7], at[29]); MULADD(at[8], at[28]); MULADD(at[9], at[27]); MULADD(at[10], at[26]); MULADD(at[11], at[25]); MULADD(at[12], at[24]); MULADD(at[13], at[23]); MULADD(at[14], at[22]); MULADD(at[15], at[21]);
1197 COMBA_STORE(C->dp[20]);
1200 MULADD(at[6], at[31]); MULADD(at[7], at[30]); MULADD(at[8], at[29]); MULADD(at[9], at[28]); MULADD(at[10], at[27]); MULADD(at[11], at[26]); MULADD(at[12], at[25]); MULADD(at[13], at[24]); MULADD(at[14], at[23]); MULADD(at[15], at[22]);
1201 COMBA_STORE(C->dp[21]);
1204 MULADD(at[7], at[31]); MULADD(at[8], at[30]); MULADD(at[9], at[29]); MULADD(at[10], at[28]); MULADD(at[11], at[27]); MULADD(at[12], at[26]); MULADD(at[13], at[25]); MULADD(at[14], at[24]); MULADD(at[15], at[23]);
1205 COMBA_STORE(C->dp[22]);
1208 MULADD(at[8], at[31]); MULADD(at[9], at[30]); MULADD(at[10], at[29]); MULADD(at[11], at[28]); MULADD(at[12], at[27]); MULADD(at[13], at[26]); MULADD(at[14], at[25]); MULADD(at[15], at[24]);
1209 COMBA_STORE(C->dp[23]);
1212 MULADD(at[9], at[31]); MULADD(at[10], at[30]); MULADD(at[11], at[29]); MULADD(at[12], at[28]); MULADD(at[13], at[27]); MULADD(at[14], at[26]); MULADD(at[15], at[25]);
1213 COMBA_STORE(C->dp[24]);
1216 MULADD(at[10], at[31]); MULADD(at[11], at[30]); MULADD(at[12], at[29]); MULADD(at[13], at[28]); MULADD(at[14], at[27]); MULADD(at[15], at[26]);
1217 COMBA_STORE(C->dp[25]);
1220 MULADD(at[11], at[31]); MULADD(at[12], at[30]); MULADD(at[13], at[29]); MULADD(at[14], at[28]); MULADD(at[15], at[27]);
1221 COMBA_STORE(C->dp[26]);
1224 MULADD(at[12], at[31]); MULADD(at[13], at[30]); MULADD(at[14], at[29]); MULADD(at[15], at[28]);
1225 COMBA_STORE(C->dp[27]);
1228 MULADD(at[13], at[31]); MULADD(at[14], at[30]); MULADD(at[15], at[29]);
1229 COMBA_STORE(C->dp[28]);
1232 MULADD(at[14], at[31]); MULADD(at[15], at[30]);
1233 COMBA_STORE(C->dp[29]);
1236 MULADD(at[15], at[31]);
1237 COMBA_STORE(C->dp[30]);
1238 COMBA_STORE2(C->dp[31]);
1240 C->sign = A->sign ^ B->sign;