12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- #include <gmp.h>
- #include "gmp-impl.h"
- #include "longlong.h"
- mp_limb_t
- mpn_mul_1 (register mp_ptr res_ptr, register mp_srcptr s1_ptr,
- mp_size_t s1_size, register mp_limb_t s2_limb)
- {
- register mp_limb_t cy_limb;
- register mp_size_t j;
- register mp_limb_t prod_high, prod_low;
-
- j = -s1_size;
-
- s1_ptr -= j;
- res_ptr -= j;
- cy_limb = 0;
- do
- {
- umul_ppmm (prod_high, prod_low, s1_ptr[j], s2_limb);
- prod_low += cy_limb;
- cy_limb = (prod_low < cy_limb) + prod_high;
- res_ptr[j] = prod_low;
- }
- while (++j != 0);
- return cy_limb;
- }
|