Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: MiniTLS-HTTPS-Example
fp_mul_comba_9.c
00001 #define TFM_DEFINES 00002 #include "fp_mul_comba.c" 00003 00004 #ifdef TFM_MUL9 00005 void fp_mul_comba9(fp_int *A, fp_int *B, fp_int *C) 00006 { 00007 fp_digit c0, c1, c2, at[18]; 00008 00009 memcpy(at, A->dp, 9 * sizeof(fp_digit)); 00010 memcpy(at+9, B->dp, 9 * sizeof(fp_digit)); 00011 COMBA_START; 00012 00013 COMBA_CLEAR; 00014 /* 0 */ 00015 MULADD(at[0], at[9]); 00016 COMBA_STORE(C->dp[0]); 00017 /* 1 */ 00018 COMBA_FORWARD; 00019 MULADD(at[0], at[10]); MULADD(at[1], at[9]); 00020 COMBA_STORE(C->dp[1]); 00021 /* 2 */ 00022 COMBA_FORWARD; 00023 MULADD(at[0], at[11]); MULADD(at[1], at[10]); MULADD(at[2], at[9]); 00024 COMBA_STORE(C->dp[2]); 00025 /* 3 */ 00026 COMBA_FORWARD; 00027 MULADD(at[0], at[12]); MULADD(at[1], at[11]); MULADD(at[2], at[10]); MULADD(at[3], at[9]); 00028 COMBA_STORE(C->dp[3]); 00029 /* 4 */ 00030 COMBA_FORWARD; 00031 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]); 00032 COMBA_STORE(C->dp[4]); 00033 /* 5 */ 00034 COMBA_FORWARD; 00035 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]); 00036 COMBA_STORE(C->dp[5]); 00037 /* 6 */ 00038 COMBA_FORWARD; 00039 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]); 00040 COMBA_STORE(C->dp[6]); 00041 /* 7 */ 00042 COMBA_FORWARD; 00043 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]); 00044 COMBA_STORE(C->dp[7]); 00045 /* 8 */ 00046 COMBA_FORWARD; 00047 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]); 00048 COMBA_STORE(C->dp[8]); 00049 /* 9 */ 00050 COMBA_FORWARD; 00051 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]); 00052 COMBA_STORE(C->dp[9]); 00053 /* 10 */ 00054 COMBA_FORWARD; 00055 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]); 00056 COMBA_STORE(C->dp[10]); 00057 /* 11 */ 00058 COMBA_FORWARD; 00059 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]); 00060 COMBA_STORE(C->dp[11]); 00061 /* 12 */ 00062 COMBA_FORWARD; 00063 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]); 00064 COMBA_STORE(C->dp[12]); 00065 /* 13 */ 00066 COMBA_FORWARD; 00067 MULADD(at[5], at[17]); MULADD(at[6], at[16]); MULADD(at[7], at[15]); MULADD(at[8], at[14]); 00068 COMBA_STORE(C->dp[13]); 00069 /* 14 */ 00070 COMBA_FORWARD; 00071 MULADD(at[6], at[17]); MULADD(at[7], at[16]); MULADD(at[8], at[15]); 00072 COMBA_STORE(C->dp[14]); 00073 /* 15 */ 00074 COMBA_FORWARD; 00075 MULADD(at[7], at[17]); MULADD(at[8], at[16]); 00076 COMBA_STORE(C->dp[15]); 00077 /* 16 */ 00078 COMBA_FORWARD; 00079 MULADD(at[8], at[17]); 00080 COMBA_STORE(C->dp[16]); 00081 COMBA_STORE2(C->dp[17]); 00082 C->used = 18; 00083 C->sign = A->sign ^ B->sign; 00084 fp_clamp(C); 00085 COMBA_FINI; 00086 } 00087 #endif
Generated on Wed Jul 13 2022 00:22:54 by
1.7.2