3 * Copyright (C) 2006-2014 wolfSSL Inc.
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
24 void fp_mul_comba3(fp_int *A, fp_int *B, fp_int *C)
26 fp_digit c0, c1, c2, at[6];
28 memcpy(at, A->dp, 3 * sizeof(fp_digit));
29 memcpy(at+3, B->dp, 3 * sizeof(fp_digit));
35 COMBA_STORE(C->dp[0]);
38 MULADD(at[0], at[4]); MULADD(at[1], at[3]);
39 COMBA_STORE(C->dp[1]);
42 MULADD(at[0], at[5]); MULADD(at[1], at[4]); MULADD(at[2], at[3]);
43 COMBA_STORE(C->dp[2]);
46 MULADD(at[1], at[5]); MULADD(at[2], at[4]);
47 COMBA_STORE(C->dp[3]);
51 COMBA_STORE(C->dp[4]);
52 COMBA_STORE2(C->dp[5]);
54 C->sign = A->sign ^ B->sign;