5 #define VLDIGITS (sizeof(vlong)/sizeof(mpdigit))
8 * this code assumes that a vlong is an integral number of
12 uvtomp(uvlong v, mpint *b)
17 b = mpnew(VLDIGITS*sizeof(mpdigit));
19 mpbits(b, VLDIGITS*sizeof(mpdigit));
23 for(s = 0; s < VLDIGITS && v != 0; s++){
25 /* !@*$&!@$ gcc gives warnings about the >> here
26 * when running on 64-bit machines, even though
27 * it's in dead code. fake it out with two shifts.
28 if(sizeof(mpdigit) == sizeof(uvlong))
31 v >>= sizeof(mpdigit)*8;
33 v >>= sizeof(mpdigit)*4;
34 v >>= sizeof(mpdigit)*4;
54 for(s = 0; s < b->top; s++)
55 v |= (uvlong)b->p[s]<<(s*sizeof(mpdigit)*8);