2022-10-22 18:41:00 +08:00
|
|
|
#define TFM_DEFINES
|
|
|
|
#include "fp_mul_comba.c"
|
|
|
|
|
2023-01-14 18:28:39 +08:00
|
|
|
#if defined(TFM_MUL24) && FP_SIZE >= 48
|
2022-10-22 18:41:00 +08:00
|
|
|
void fp_mul_comba24(fp_int *A, fp_int *B, fp_int *C)
|
|
|
|
{
|
|
|
|
fp_digit c0, c1, c2, at[48];
|
|
|
|
|
|
|
|
memcpy(at, A->dp, 24 * sizeof(fp_digit));
|
|
|
|
memcpy(at+24, B->dp, 24 * sizeof(fp_digit));
|
|
|
|
COMBA_START;
|
|
|
|
|
|
|
|
COMBA_CLEAR;
|
|
|
|
/* 0 */
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[0]);
|
|
|
|
/* 1 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[25]); MULADD(at[1], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[1]);
|
|
|
|
/* 2 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[26]); MULADD(at[1], at[25]); MULADD(at[2], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[2]);
|
|
|
|
/* 3 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[27]); MULADD(at[1], at[26]); MULADD(at[2], at[25]); MULADD(at[3], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[3]);
|
|
|
|
/* 4 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[4]);
|
|
|
|
/* 5 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[5]);
|
|
|
|
/* 6 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[6]);
|
|
|
|
/* 7 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[7]);
|
|
|
|
/* 8 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[8]);
|
|
|
|
/* 9 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[33]); MULADD(at[1], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[9]);
|
|
|
|
/* 10 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[34]); MULADD(at[1], at[33]); MULADD(at[2], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[10]);
|
|
|
|
/* 11 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[35]); MULADD(at[1], at[34]); MULADD(at[2], at[33]); MULADD(at[3], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[11]);
|
|
|
|
/* 12 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[36]); MULADD(at[1], at[35]); MULADD(at[2], at[34]); MULADD(at[3], at[33]); MULADD(at[4], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[12]);
|
|
|
|
/* 13 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[37]); MULADD(at[1], at[36]); MULADD(at[2], at[35]); MULADD(at[3], at[34]); MULADD(at[4], at[33]); MULADD(at[5], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[13]);
|
|
|
|
/* 14 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[38]); MULADD(at[1], at[37]); MULADD(at[2], at[36]); MULADD(at[3], at[35]); MULADD(at[4], at[34]); MULADD(at[5], at[33]); MULADD(at[6], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[14]);
|
|
|
|
/* 15 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[39]); MULADD(at[1], at[38]); MULADD(at[2], at[37]); MULADD(at[3], at[36]); MULADD(at[4], at[35]); MULADD(at[5], at[34]); MULADD(at[6], at[33]); MULADD(at[7], at[32]); 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]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[15]);
|
|
|
|
/* 16 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[40]); MULADD(at[1], at[39]); MULADD(at[2], at[38]); MULADD(at[3], at[37]); MULADD(at[4], at[36]); MULADD(at[5], at[35]); MULADD(at[6], at[34]); MULADD(at[7], at[33]); MULADD(at[8], at[32]); 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]); MULADD(at[16], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[16]);
|
|
|
|
/* 17 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[41]); MULADD(at[1], at[40]); MULADD(at[2], at[39]); MULADD(at[3], at[38]); MULADD(at[4], at[37]); MULADD(at[5], at[36]); MULADD(at[6], at[35]); MULADD(at[7], at[34]); MULADD(at[8], at[33]); MULADD(at[9], at[32]); 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]); MULADD(at[16], at[25]); MULADD(at[17], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[17]);
|
|
|
|
/* 18 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[42]); MULADD(at[1], at[41]); MULADD(at[2], at[40]); MULADD(at[3], at[39]); MULADD(at[4], at[38]); MULADD(at[5], at[37]); MULADD(at[6], at[36]); MULADD(at[7], at[35]); MULADD(at[8], at[34]); MULADD(at[9], at[33]); MULADD(at[10], at[32]); 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]); MULADD(at[16], at[26]); MULADD(at[17], at[25]); MULADD(at[18], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[18]);
|
|
|
|
/* 19 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[43]); MULADD(at[1], at[42]); MULADD(at[2], at[41]); MULADD(at[3], at[40]); MULADD(at[4], at[39]); MULADD(at[5], at[38]); MULADD(at[6], at[37]); MULADD(at[7], at[36]); MULADD(at[8], at[35]); MULADD(at[9], at[34]); MULADD(at[10], at[33]); MULADD(at[11], at[32]); MULADD(at[12], at[31]); MULADD(at[13], at[30]); MULADD(at[14], at[29]); MULADD(at[15], at[28]); MULADD(at[16], at[27]); MULADD(at[17], at[26]); MULADD(at[18], at[25]); MULADD(at[19], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[19]);
|
|
|
|
/* 20 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[44]); MULADD(at[1], at[43]); MULADD(at[2], at[42]); MULADD(at[3], at[41]); MULADD(at[4], at[40]); MULADD(at[5], at[39]); MULADD(at[6], at[38]); MULADD(at[7], at[37]); MULADD(at[8], at[36]); MULADD(at[9], at[35]); MULADD(at[10], at[34]); MULADD(at[11], at[33]); MULADD(at[12], at[32]); MULADD(at[13], at[31]); MULADD(at[14], at[30]); MULADD(at[15], at[29]); MULADD(at[16], at[28]); MULADD(at[17], at[27]); MULADD(at[18], at[26]); MULADD(at[19], at[25]); MULADD(at[20], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[20]);
|
|
|
|
/* 21 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[45]); MULADD(at[1], at[44]); MULADD(at[2], at[43]); MULADD(at[3], at[42]); MULADD(at[4], at[41]); MULADD(at[5], at[40]); MULADD(at[6], at[39]); MULADD(at[7], at[38]); MULADD(at[8], at[37]); MULADD(at[9], at[36]); MULADD(at[10], at[35]); MULADD(at[11], at[34]); MULADD(at[12], at[33]); MULADD(at[13], at[32]); MULADD(at[14], at[31]); MULADD(at[15], at[30]); MULADD(at[16], at[29]); MULADD(at[17], at[28]); MULADD(at[18], at[27]); MULADD(at[19], at[26]); MULADD(at[20], at[25]); MULADD(at[21], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[21]);
|
|
|
|
/* 22 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[46]); MULADD(at[1], at[45]); MULADD(at[2], at[44]); MULADD(at[3], at[43]); MULADD(at[4], at[42]); MULADD(at[5], at[41]); MULADD(at[6], at[40]); MULADD(at[7], at[39]); MULADD(at[8], at[38]); MULADD(at[9], at[37]); MULADD(at[10], at[36]); MULADD(at[11], at[35]); MULADD(at[12], at[34]); MULADD(at[13], at[33]); MULADD(at[14], at[32]); MULADD(at[15], at[31]); MULADD(at[16], at[30]); MULADD(at[17], at[29]); MULADD(at[18], at[28]); MULADD(at[19], at[27]); MULADD(at[20], at[26]); MULADD(at[21], at[25]); MULADD(at[22], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[22]);
|
|
|
|
/* 23 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[0], at[47]); MULADD(at[1], at[46]); MULADD(at[2], at[45]); MULADD(at[3], at[44]); MULADD(at[4], at[43]); MULADD(at[5], at[42]); MULADD(at[6], at[41]); MULADD(at[7], at[40]); MULADD(at[8], at[39]); MULADD(at[9], at[38]); MULADD(at[10], at[37]); MULADD(at[11], at[36]); MULADD(at[12], at[35]); MULADD(at[13], at[34]); MULADD(at[14], at[33]); MULADD(at[15], at[32]); MULADD(at[16], at[31]); MULADD(at[17], at[30]); MULADD(at[18], at[29]); MULADD(at[19], at[28]); MULADD(at[20], at[27]); MULADD(at[21], at[26]); MULADD(at[22], at[25]); MULADD(at[23], at[24]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[23]);
|
|
|
|
/* 24 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[1], at[47]); MULADD(at[2], at[46]); MULADD(at[3], at[45]); MULADD(at[4], at[44]); MULADD(at[5], at[43]); MULADD(at[6], at[42]); MULADD(at[7], at[41]); MULADD(at[8], at[40]); MULADD(at[9], at[39]); MULADD(at[10], at[38]); MULADD(at[11], at[37]); MULADD(at[12], at[36]); MULADD(at[13], at[35]); MULADD(at[14], at[34]); MULADD(at[15], at[33]); MULADD(at[16], at[32]); MULADD(at[17], at[31]); MULADD(at[18], at[30]); MULADD(at[19], at[29]); MULADD(at[20], at[28]); MULADD(at[21], at[27]); MULADD(at[22], at[26]); MULADD(at[23], at[25]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[24]);
|
|
|
|
/* 25 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[2], at[47]); MULADD(at[3], at[46]); MULADD(at[4], at[45]); MULADD(at[5], at[44]); MULADD(at[6], at[43]); MULADD(at[7], at[42]); MULADD(at[8], at[41]); MULADD(at[9], at[40]); MULADD(at[10], at[39]); MULADD(at[11], at[38]); MULADD(at[12], at[37]); MULADD(at[13], at[36]); MULADD(at[14], at[35]); MULADD(at[15], at[34]); MULADD(at[16], at[33]); MULADD(at[17], at[32]); MULADD(at[18], at[31]); MULADD(at[19], at[30]); MULADD(at[20], at[29]); MULADD(at[21], at[28]); MULADD(at[22], at[27]); MULADD(at[23], at[26]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[25]);
|
|
|
|
/* 26 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[3], at[47]); MULADD(at[4], at[46]); MULADD(at[5], at[45]); MULADD(at[6], at[44]); MULADD(at[7], at[43]); MULADD(at[8], at[42]); MULADD(at[9], at[41]); MULADD(at[10], at[40]); MULADD(at[11], at[39]); MULADD(at[12], at[38]); MULADD(at[13], at[37]); MULADD(at[14], at[36]); MULADD(at[15], at[35]); MULADD(at[16], at[34]); MULADD(at[17], at[33]); MULADD(at[18], at[32]); MULADD(at[19], at[31]); MULADD(at[20], at[30]); MULADD(at[21], at[29]); MULADD(at[22], at[28]); MULADD(at[23], at[27]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[26]);
|
|
|
|
/* 27 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[4], at[47]); MULADD(at[5], at[46]); MULADD(at[6], at[45]); MULADD(at[7], at[44]); MULADD(at[8], at[43]); MULADD(at[9], at[42]); MULADD(at[10], at[41]); MULADD(at[11], at[40]); MULADD(at[12], at[39]); MULADD(at[13], at[38]); MULADD(at[14], at[37]); MULADD(at[15], at[36]); MULADD(at[16], at[35]); MULADD(at[17], at[34]); MULADD(at[18], at[33]); MULADD(at[19], at[32]); MULADD(at[20], at[31]); MULADD(at[21], at[30]); MULADD(at[22], at[29]); MULADD(at[23], at[28]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[27]);
|
|
|
|
/* 28 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[5], at[47]); MULADD(at[6], at[46]); MULADD(at[7], at[45]); MULADD(at[8], at[44]); MULADD(at[9], at[43]); MULADD(at[10], at[42]); MULADD(at[11], at[41]); MULADD(at[12], at[40]); MULADD(at[13], at[39]); MULADD(at[14], at[38]); MULADD(at[15], at[37]); MULADD(at[16], at[36]); MULADD(at[17], at[35]); MULADD(at[18], at[34]); MULADD(at[19], at[33]); MULADD(at[20], at[32]); MULADD(at[21], at[31]); MULADD(at[22], at[30]); MULADD(at[23], at[29]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[28]);
|
|
|
|
/* 29 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[6], at[47]); MULADD(at[7], at[46]); MULADD(at[8], at[45]); MULADD(at[9], at[44]); MULADD(at[10], at[43]); MULADD(at[11], at[42]); MULADD(at[12], at[41]); MULADD(at[13], at[40]); MULADD(at[14], at[39]); MULADD(at[15], at[38]); MULADD(at[16], at[37]); MULADD(at[17], at[36]); MULADD(at[18], at[35]); MULADD(at[19], at[34]); MULADD(at[20], at[33]); MULADD(at[21], at[32]); MULADD(at[22], at[31]); MULADD(at[23], at[30]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[29]);
|
|
|
|
/* 30 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[7], at[47]); MULADD(at[8], at[46]); MULADD(at[9], at[45]); MULADD(at[10], at[44]); MULADD(at[11], at[43]); MULADD(at[12], at[42]); MULADD(at[13], at[41]); MULADD(at[14], at[40]); MULADD(at[15], at[39]); MULADD(at[16], at[38]); MULADD(at[17], at[37]); MULADD(at[18], at[36]); MULADD(at[19], at[35]); MULADD(at[20], at[34]); MULADD(at[21], at[33]); MULADD(at[22], at[32]); MULADD(at[23], at[31]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[30]);
|
|
|
|
/* 31 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[8], at[47]); MULADD(at[9], at[46]); MULADD(at[10], at[45]); MULADD(at[11], at[44]); MULADD(at[12], at[43]); MULADD(at[13], at[42]); MULADD(at[14], at[41]); MULADD(at[15], at[40]); MULADD(at[16], at[39]); MULADD(at[17], at[38]); MULADD(at[18], at[37]); MULADD(at[19], at[36]); MULADD(at[20], at[35]); MULADD(at[21], at[34]); MULADD(at[22], at[33]); MULADD(at[23], at[32]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[31]);
|
|
|
|
/* 32 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[9], at[47]); MULADD(at[10], at[46]); MULADD(at[11], at[45]); MULADD(at[12], at[44]); MULADD(at[13], at[43]); MULADD(at[14], at[42]); MULADD(at[15], at[41]); MULADD(at[16], at[40]); MULADD(at[17], at[39]); MULADD(at[18], at[38]); MULADD(at[19], at[37]); MULADD(at[20], at[36]); MULADD(at[21], at[35]); MULADD(at[22], at[34]); MULADD(at[23], at[33]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[32]);
|
|
|
|
/* 33 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[10], at[47]); MULADD(at[11], at[46]); MULADD(at[12], at[45]); MULADD(at[13], at[44]); MULADD(at[14], at[43]); MULADD(at[15], at[42]); MULADD(at[16], at[41]); MULADD(at[17], at[40]); MULADD(at[18], at[39]); MULADD(at[19], at[38]); MULADD(at[20], at[37]); MULADD(at[21], at[36]); MULADD(at[22], at[35]); MULADD(at[23], at[34]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[33]);
|
|
|
|
/* 34 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[11], at[47]); MULADD(at[12], at[46]); MULADD(at[13], at[45]); MULADD(at[14], at[44]); MULADD(at[15], at[43]); MULADD(at[16], at[42]); MULADD(at[17], at[41]); MULADD(at[18], at[40]); MULADD(at[19], at[39]); MULADD(at[20], at[38]); MULADD(at[21], at[37]); MULADD(at[22], at[36]); MULADD(at[23], at[35]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[34]);
|
|
|
|
/* 35 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[12], at[47]); MULADD(at[13], at[46]); MULADD(at[14], at[45]); MULADD(at[15], at[44]); MULADD(at[16], at[43]); MULADD(at[17], at[42]); MULADD(at[18], at[41]); MULADD(at[19], at[40]); MULADD(at[20], at[39]); MULADD(at[21], at[38]); MULADD(at[22], at[37]); MULADD(at[23], at[36]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[35]);
|
|
|
|
/* 36 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[13], at[47]); MULADD(at[14], at[46]); MULADD(at[15], at[45]); MULADD(at[16], at[44]); MULADD(at[17], at[43]); MULADD(at[18], at[42]); MULADD(at[19], at[41]); MULADD(at[20], at[40]); MULADD(at[21], at[39]); MULADD(at[22], at[38]); MULADD(at[23], at[37]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[36]);
|
|
|
|
/* 37 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[14], at[47]); MULADD(at[15], at[46]); MULADD(at[16], at[45]); MULADD(at[17], at[44]); MULADD(at[18], at[43]); MULADD(at[19], at[42]); MULADD(at[20], at[41]); MULADD(at[21], at[40]); MULADD(at[22], at[39]); MULADD(at[23], at[38]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[37]);
|
|
|
|
/* 38 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[15], at[47]); MULADD(at[16], at[46]); MULADD(at[17], at[45]); MULADD(at[18], at[44]); MULADD(at[19], at[43]); MULADD(at[20], at[42]); MULADD(at[21], at[41]); MULADD(at[22], at[40]); MULADD(at[23], at[39]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[38]);
|
|
|
|
/* 39 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[16], at[47]); MULADD(at[17], at[46]); MULADD(at[18], at[45]); MULADD(at[19], at[44]); MULADD(at[20], at[43]); MULADD(at[21], at[42]); MULADD(at[22], at[41]); MULADD(at[23], at[40]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[39]);
|
|
|
|
/* 40 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[17], at[47]); MULADD(at[18], at[46]); MULADD(at[19], at[45]); MULADD(at[20], at[44]); MULADD(at[21], at[43]); MULADD(at[22], at[42]); MULADD(at[23], at[41]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[40]);
|
|
|
|
/* 41 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[18], at[47]); MULADD(at[19], at[46]); MULADD(at[20], at[45]); MULADD(at[21], at[44]); MULADD(at[22], at[43]); MULADD(at[23], at[42]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[41]);
|
|
|
|
/* 42 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[19], at[47]); MULADD(at[20], at[46]); MULADD(at[21], at[45]); MULADD(at[22], at[44]); MULADD(at[23], at[43]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[42]);
|
|
|
|
/* 43 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[20], at[47]); MULADD(at[21], at[46]); MULADD(at[22], at[45]); MULADD(at[23], at[44]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[43]);
|
|
|
|
/* 44 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[21], at[47]); MULADD(at[22], at[46]); MULADD(at[23], at[45]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[44]);
|
|
|
|
/* 45 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[22], at[47]); MULADD(at[23], at[46]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[45]);
|
|
|
|
/* 46 */
|
|
|
|
COMBA_FORWARD;
|
2023-01-14 18:28:39 +08:00
|
|
|
MULADD(at[23], at[47]);
|
2022-10-22 18:41:00 +08:00
|
|
|
COMBA_STORE(C->dp[46]);
|
|
|
|
COMBA_STORE2(C->dp[47]);
|
|
|
|
C->used = 48;
|
|
|
|
C->sign = A->sign ^ B->sign;
|
|
|
|
fp_clamp(C);
|
|
|
|
COMBA_FINI;
|
|
|
|
}
|
|
|
|
#endif
|
2023-01-14 18:28:39 +08:00
|
|
|
|
|
|
|
|
|
|
|
/* $Source$ */
|
|
|
|
/* $Revision$ */
|
|
|
|
/* $Date$ */
|