21 {
29
30#define a0 numa
31#define a1 (numa + n)
32#define asm1 dst
33
34 if (s == n) {
37 else
39 } else {
43 } else
45 }
46
48
49#undef asm1
50#define v0 dst
51#define vinf (dst + 2 * n)
52
54
56
59 cy +=
lmmp_add_(dst + 2 * n, dst + 2 * n, n,
vinf + n, s + s - n);
60
62
63
65
66 if (cy < 0)
68 else
71}
#define lmmp_param_assert(x)
static mp_limb_t lmmp_add_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_srcptr numb, mp_size_t nb)
大数加法静态内联函数 [dst,na]=[numa,na]+[numb,nb]
static int lmmp_cmp_(mp_srcptr numa, mp_srcptr numb, mp_size_t n)
大数比较函数(内联)
#define lmmp_dec(p)
大数减1宏(预期无借位)
void lmmp_sqr_(mp_ptr dst, mp_srcptr numa, mp_size_t na)
大数平方操作 [dst,2*na] = [numa,na]^2
mp_limb_t lmmp_sub_n_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
无借位的n位减法 [dst,n] = [numa,n] - [numb,n]
#define lmmp_inc_1(p, inc)
大数加指定值宏(预期无进位)
mp_limb_t lmmp_add_n_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
无进位的n位加法 [dst,n] = [numa,n] + [numb,n]
#define SALLOC_TYPE(n, type)