17dd7cddfSDavid du Colombier #include "os.h"
27dd7cddfSDavid du Colombier #include <mp.h>
37dd7cddfSDavid du Colombier #include "dat.h"
47dd7cddfSDavid du Colombier
57dd7cddfSDavid du Colombier // res = b << shift
67dd7cddfSDavid du Colombier void
mpleft(mpint * b,int shift,mpint * res)77dd7cddfSDavid du Colombier mpleft(mpint *b, int shift, mpint *res)
87dd7cddfSDavid du Colombier {
97dd7cddfSDavid du Colombier int d, l, r, i, otop;
107dd7cddfSDavid du Colombier mpdigit this, last;
117dd7cddfSDavid du Colombier
12*dc5a79c1SDavid du Colombier res->sign = b->sign;
13*dc5a79c1SDavid du Colombier if(b->top==0){
14*dc5a79c1SDavid du Colombier res->top = 0;
15*dc5a79c1SDavid du Colombier return;
16*dc5a79c1SDavid du Colombier }
17*dc5a79c1SDavid du Colombier
187dd7cddfSDavid du Colombier // a negative left shift is a right shift
197dd7cddfSDavid du Colombier if(shift < 0){
207dd7cddfSDavid du Colombier mpright(b, -shift, res);
217dd7cddfSDavid du Colombier return;
227dd7cddfSDavid du Colombier }
237dd7cddfSDavid du Colombier
247dd7cddfSDavid du Colombier // b and res may be the same so remember the old top
257dd7cddfSDavid du Colombier otop = b->top;
267dd7cddfSDavid du Colombier
277dd7cddfSDavid du Colombier // shift
287dd7cddfSDavid du Colombier mpbits(res, otop*Dbits + shift); // overkill
2959cc4ca5SDavid du Colombier res->top = DIGITS(otop*Dbits + shift);
307dd7cddfSDavid du Colombier d = shift/Dbits;
317dd7cddfSDavid du Colombier l = shift - d*Dbits;
327dd7cddfSDavid du Colombier r = Dbits - l;
337dd7cddfSDavid du Colombier
347dd7cddfSDavid du Colombier if(l == 0){
357dd7cddfSDavid du Colombier for(i = otop-1; i >= 0; i--)
367dd7cddfSDavid du Colombier res->p[i+d] = b->p[i];
377dd7cddfSDavid du Colombier } else {
387dd7cddfSDavid du Colombier last = 0;
397dd7cddfSDavid du Colombier for(i = otop-1; i >= 0; i--) {
407dd7cddfSDavid du Colombier this = b->p[i];
417dd7cddfSDavid du Colombier res->p[i+d+1] = (last<<l) | (this>>r);
427dd7cddfSDavid du Colombier last = this;
437dd7cddfSDavid du Colombier }
447dd7cddfSDavid du Colombier res->p[d] = last<<l;
457dd7cddfSDavid du Colombier }
467dd7cddfSDavid du Colombier for(i = 0; i < d; i++)
477dd7cddfSDavid du Colombier res->p[i] = 0;
487dd7cddfSDavid du Colombier
497dd7cddfSDavid du Colombier // normalize
507dd7cddfSDavid du Colombier while(res->top > 0 && res->p[res->top-1] == 0)
517dd7cddfSDavid du Colombier res->top--;
527dd7cddfSDavid du Colombier }
53