⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bn16.c

📁 著名的加密软件的应用于电子邮件中
💻 C
📖 第 1 页 / 共 2 页
字号:
			if (src == dest) {
					BNIALLOC(srcbuf, BNWORD16, s);
					if (!srcbuf)
						return -1;
					bniCopy_16(srcbuf, (BNWORD16 *)src->ptr, s);
					bniSquare_16((BNWORD16 *)dest->ptr, (BNWORD16 *)srcbuf, s);
					BNIFREE(srcbuf, s);
			} else {
				 bniSquare_16((BNWORD16 *)dest->ptr, (BNWORD16 *)src->ptr, s);
			}

			dest->size = bniNorm_16((BNWORD16 *)dest->ptr, 2*s);
			MALLOCDB;
return 0;
}

int
bnMul_16(struct BigNum *dest, struct BigNum const *a, struct BigNum const *b)
{
unsigned s, t;
BNWORD16 *srcbuf;

s = bniNorm_16((BNWORD16 *)a->ptr, a->size);
t = bniNorm_16((BNWORD16 *)b->ptr, b->size);

if (!s || !t) {
	dest->size = 0;
	return 0;
}

if (a == b)
	return bnSquare_16(dest, a);

bnSizeCheck(dest, s+t);

if (dest == a) {
			BNIALLOC(srcbuf, BNWORD16, s);
			if (!srcbuf)
				 return -1;
			bniCopy_16(srcbuf, (BNWORD16 *)a->ptr, s);
			bniMul_16((BNWORD16 *)dest->ptr, srcbuf, s,
			(BNWORD16 *)b->ptr, t);
			BNIFREE(srcbuf, s);
} else if (dest == b) {
			BNIALLOC(srcbuf, BNWORD16, t);
			if (!srcbuf)
				 return -1;
			bniCopy_16(srcbuf, (BNWORD16 *)b->ptr, t);
			bniMul_16((BNWORD16 *)dest->ptr, (BNWORD16 *)a->ptr, s,
			srcbuf, t);
			BNIFREE(srcbuf, t);
	} else {
	bniMul_16((BNWORD16 *)dest->ptr, (BNWORD16 *)a->ptr, s,
			(BNWORD16 *)b->ptr, t);
	}
dest->size = bniNorm_16((BNWORD16 *)dest->ptr, s+t);
MALLOCDB;
return 0;
}

int
bnMulQ_16(struct BigNum *dest, struct BigNum const *a, unsigned b)
	{
			unsigned s;

			s = bniNorm_16((BNWORD16 *)a->ptr, a->size);
			if (!s || !b) {
				 dest->size = 0;
				 return 0;
			}
			if (b == 1)
				 return bnCopy_16(dest, a);
			bnSizeCheck(dest, s+1);
			bniMulN1_16((BNWORD16 *)dest->ptr, (BNWORD16 *)a->ptr, s, b);
			dest->size = bniNorm_16((BNWORD16 *)dest->ptr, s+1);
			MALLOCDB;
			return 0;
	}

	int
bnDivMod_16(struct BigNum *q, struct BigNum *r, struct BigNum const *n,
		struct BigNum const *d)
	{
			unsigned dsize, nsize;
			BNWORD16 qhigh;

			dsize = bniNorm_16((BNWORD16 *)d->ptr, d->size);
			nsize = bniNorm_16((BNWORD16 *)n->ptr, n->size);

			if (nsize < dsize) {
				 q->size = 0;	/* No quotient */
				 r->size = nsize;
				 return 0;	/* Success */
			}

			bnSizeCheck(q, nsize-dsize);

			if (r != n) {	/* You are allowed to reduce in place */
				 bnSizeCheck(r, nsize);
				 bniCopy_16((BNWORD16 *)r->ptr, (BNWORD16 *)n->ptr, nsize);
			}
				
			qhigh = bniDiv_16((BNWORD16 *)q->ptr, (BNWORD16 *)r->ptr, nsize,
			(BNWORD16 *)d->ptr, dsize);
			nsize -= dsize;
			if (qhigh) {
				 bnSizeCheck(q, nsize+1);
				 *((BNWORD16 *)q->ptr BIGLITTLE(-nsize-1,+nsize)) = qhigh;
				 q->size = nsize+1;
			} else {
				 q->size = bniNorm_16((BNWORD16 *)q->ptr, nsize);
			}
			r->size = bniNorm_16((BNWORD16 *)r->ptr, dsize);
			MALLOCDB;
			return 0;
	}

	int
bnMod_16(struct BigNum *dest, struct BigNum const *src, struct BigNum const *d)
{
unsigned dsize, nsize;

nsize = bniNorm_16((BNWORD16 *)src->ptr, src->size);
dsize = bniNorm_16((BNWORD16 *)d->ptr, d->size);


			if (dest != src) {
				 bnSizeCheck(dest, nsize);
				 bniCopy_16((BNWORD16 *)dest->ptr, (BNWORD16 *)src->ptr, nsize);
}

if (nsize < dsize) {
	dest->size = nsize;	/* No quotient */
			return 0;
		}

		(void)bniDiv_16((BNWORD16 *)dest->ptr BIGLITTLE(-dsize,+dsize),
			(BNWORD16 *)dest->ptr, nsize,
			(BNWORD16 *)d->ptr, dsize);
			dest->size = bniNorm_16((BNWORD16 *)dest->ptr, dsize);
			MALLOCDB;
			return 0;
	}

	unsigned
bnModQ_16(struct BigNum const *src, unsigned d)
	{
			unsigned s;

			s = bniNorm_16((BNWORD16 *)src->ptr, src->size);
			if (!s)
				 return 0;
		
			if (d & (d-1))	/* Not a power of 2 */
				 d = bniModQ_16((BNWORD16 *)src->ptr, s, d);
			else
				 d = (unsigned)((BNWORD16 *)src->ptr)[BIGLITTLE(-1,0)] & (d-1);
			return d;
	}

int
bnExpMod_16(struct BigNum *dest, struct BigNum const *n,
			struct BigNum const *exp, struct BigNum const *mod)
	{
			unsigned nsize, esize, msize;

			nsize = bniNorm_16((BNWORD16 *)n->ptr, n->size);
			esize = bniNorm_16((BNWORD16 *)exp->ptr, exp->size);
			msize = bniNorm_16((BNWORD16 *)mod->ptr, mod->size);

			if (!msize || (((BNWORD16 *)mod->ptr)[BIGLITTLE(-1,0)] & 1) == 0)
				 return -1;	 /* Illegal modulus! */

		bnSizeCheck(dest, msize);

		/* Special-case base of 2 */
		if (nsize == 1 && ((BNWORD16 *)n->ptr)[BIGLITTLE(-1,0)] == 2) {
			if (bniTwoExpMod_16((BNWORD16 *)dest->ptr,
					(BNWORD16 *)exp->ptr, esize,
					(BNWORD16 *)mod->ptr, msize) < 0)
				return -1;
		} else {
		if (bniExpMod_16((BNWORD16 *)dest->ptr,
		(BNWORD16 *)n->ptr, nsize,
			 (BNWORD16 *)exp->ptr, esize,
			 (BNWORD16 *)mod->ptr, msize) < 0)
	return -1;
}

dest->size = bniNorm_16((BNWORD16 *)dest->ptr, msize);
MALLOCDB;
return 0;
}

int
bnDoubleExpMod_16(struct BigNum *dest,
			struct BigNum const *n1, struct BigNum const *e1,
			struct BigNum const *n2, struct BigNum const *e2,
			struct BigNum const *mod)
	{
			unsigned n1size, e1size, n2size, e2size, msize;

			n1size = bniNorm_16((BNWORD16 *)n1->ptr, n1->size);
			e1size = bniNorm_16((BNWORD16 *)e1->ptr, e1->size);
			n2size = bniNorm_16((BNWORD16 *)n2->ptr, n2->size);
			e2size = bniNorm_16((BNWORD16 *)e2->ptr, e2->size);
			msize = bniNorm_16((BNWORD16 *)mod->ptr, mod->size);

			if (!msize || (((BNWORD16 *)mod->ptr)[BIGLITTLE(-1,0)] & 1) == 0)
				 return -1;	 /* Illegal modulus! */

			bnSizeCheck(dest, msize);

			if (bniDoubleExpMod_16((BNWORD16 *)dest->ptr,
				 (BNWORD16 *)n1->ptr, n1size, (BNWORD16 *)e1->ptr, e1size,
				 (BNWORD16 *)n2->ptr, n2size, (BNWORD16 *)e2->ptr, e2size,
				 (BNWORD16 *)mod->ptr, msize) < 0)
				 return -1;

			dest->size = bniNorm_16((BNWORD16 *)dest->ptr, msize);
			MALLOCDB;
			return 0;
}

int
bnTwoExpMod_16(struct BigNum *n, struct BigNum const *exp,
			struct BigNum const *mod)
{
			unsigned esize, msize;

			esize = bniNorm_16((BNWORD16 *)exp->ptr, exp->size);
			msize = bniNorm_16((BNWORD16 *)mod->ptr, mod->size);

			if (!msize || (((BNWORD16 *)mod->ptr)[BIGLITTLE(-1,0)] & 1) == 0)
				 return -1;	 /* Illegal modulus! */

			bnSizeCheck(n, msize);

			if (bniTwoExpMod_16((BNWORD16 *)n->ptr, (BNWORD16 *)exp->ptr, esize,
			(BNWORD16 *)mod->ptr, msize) < 0)
				 return -1;

			n->size = bniNorm_16((BNWORD16 *)n->ptr, msize);
			MALLOCDB;
			return 0;
}

int
bnGcd_16(struct BigNum *dest, struct BigNum const *a, struct BigNum const *b)
	{
			BNWORD16 *tmp;
			unsigned asize, bsize;
			int i;

			/* Kind of silly, but we might as well permit it... */
			if (a == b)
				 return dest == a ? 0 : bnCopy(dest, a);

			/* Ensure a is not the same as "dest" */
			if (a == dest) {
				 a = b;
				 b = dest;
			}

			asize = bniNorm_16((BNWORD16 *)a->ptr, a->size);
			bsize = bniNorm_16((BNWORD16 *)b->ptr, b->size);
			bnSizeCheck(dest, bsize+1);


			/* Copy a to tmp */
			BNIALLOC(tmp, BNWORD16, asize+1);
			if (!tmp)
				 return -1;
			bniCopy_16(tmp, (BNWORD16 *)a->ptr, asize);

			/* Copy b to dest, if necessary */
			if (dest != b)
				 bniCopy_16((BNWORD16 *)dest->ptr,
				 	(BNWORD16 *)b->ptr, bsize);
			if (bsize > asize || (bsize == asize &&
			bniCmp_16((BNWORD16 *)b->ptr, (BNWORD16 *)a->ptr, asize) > 0))
			{
					i = bniGcd_16((BNWORD16 *)dest->ptr, bsize, tmp, asize,
						&dest->size);
					if (i > 0)	 /* Result in tmp, not dest */
						bniCopy_16((BNWORD16 *)dest->ptr, tmp, dest->size);
			} else {
					i = bniGcd_16(tmp, asize, (BNWORD16 *)dest->ptr, bsize,
						&dest->size);
					if (i == 0)	/* Result in tmp, not dest */
						bniCopy_16((BNWORD16 *)dest->ptr, tmp, dest->size);
			}
			BNIFREE(tmp, asize+1);
			MALLOCDB;
			return (i < 0) ? i : 0;
	}

	int
bnInv_16(struct BigNum *dest, struct BigNum const *src,
struct BigNum const *mod)
{
	unsigned s, m;
	int i;

			s = bniNorm_16((BNWORD16 *)src->ptr, src->size);
			m = bniNorm_16((BNWORD16 *)mod->ptr, mod->size);

			/* bniInv_16 requires that the input be less than the modulus */
			if (m < s ||
			(m==s && bniCmp_16((BNWORD16 *)src->ptr, (BNWORD16 *)mod->ptr, s)))
		{
					bnSizeCheck(dest, s + (m==s));
					if (dest != src)
						bniCopy_16((BNWORD16 *)dest->ptr,
						(BNWORD16 *)src->ptr, s);
					/* Pre-reduce modulo the modulus */
					(void)bniDiv_16((BNWORD16 *)dest->ptr BIGLITTLE(-m,+m),
						(BNWORD16 *)dest->ptr, s,
					(BNWORD16 *)mod->ptr, m);
					s = bniNorm_16((BNWORD16 *)dest->ptr, m);
					MALLOCDB;
			} else {
					bnSizeCheck(dest, m+1);
					if (dest != src)
						bniCopy_16((BNWORD16 *)dest->ptr,
						(BNWORD16 *)src->ptr, s);
			}

			i = bniInv_16((BNWORD16 *)dest->ptr, s, (BNWORD16 *)mod->ptr, m);
			if (i == 0)
				 dest->size = bniNorm_16((BNWORD16 *)dest->ptr, m);

			MALLOCDB;
			return i;
}

/*
 * Shift a bignum left the appropriate number of bits,
 * multiplying by 2^amt.
 */
int
bnLShift_16(struct BigNum *dest, unsigned amt)
{
			unsigned s = dest->size;
			BNWORD16 carry;

 			if (amt % 16) {
					carry = bniLshift_16((BNWORD16 *)dest->ptr, s, amt % 16);
					if (carry) {
							s++;
							bnSizeCheck(dest, s);
							((BNWORD16 *)dest->ptr)[BIGLITTLE(-s,s-1)] = carry;
					}
			}

			amt /= 16;
			if (amt) {
				 bnSizeCheck(dest, s+amt);
				 memmove((BNWORD16 *)dest->ptr BIGLITTLE(-s-amt, +amt),
						(BNWORD16 *)dest->ptr BIG(-s),
				 	s * sizeof(BNWORD16));
	bniZero_16((BNWORD16 *)dest->ptr, amt);
	s += amt;
}
dest->size = s;
MALLOCDB;
return 0;
}

/*
 * Shift a bignum right the appropriate number of bits,
 * dividing by 2^amt.
 */
void bnRShift_16(struct BigNum *dest, unsigned amt)
	{
			unsigned s = dest->size;

			if (amt >= 16) {
					memmove(
						(BNWORD16 *)dest->ptr BIG(-s+amt/16),
						(BNWORD16 *)dest->ptr BIGLITTLE(-s, +amt/16),
						s-amt/16 * sizeof(BNWORD16));
					s -= amt/16;
					amt %= 16;
			}

			if (amt)
				 (void)bniRshift_16((BNWORD16 *)dest->ptr, s, amt);

			dest->size = bniNorm_16((BNWORD16 *)dest->ptr, s);
			MALLOCDB;
}

/*
 * Shift a bignum right until it is odd, and return the number of
 * bits shifted. n = d * 2^s. Replaces n with d and returns s.
 * Returns 0 when given 0. (Another valid answer is infinity.)
 */
unsigned
bnMakeOdd_16(struct BigNum *n)
	{
			unsigned size;
			unsigned s;		/* shift amount */
			BNWORD16 *p;
			BNWORD16 t;

p = (BNWORD16 *)n->ptr;
size = bniNorm_16(p, n->size);
if (!size)
	return 0;

t = BIGLITTLE(p[-1],p[0]);
s = 0;

/* See how many words we have to shift */
if (!t) {
	/* Shift by words */
	do {
		
						s++;
	BIGLITTLE(--p,p++);
} while ((t = BIGLITTLE(p[-1],p[0])) == 0);
size -= s;
s *= 16;
memmove((BNWORD16 *)n->ptr BIG(-size), p BIG(-size),
	size * sizeof(BNWORD16));
p = (BNWORD16 *)n->ptr;
MALLOCDB;
}

pgpAssert(t);

/* Now count the bits */
while ((t & 1) == 0) {
	t >>= 1;
	s++;
}

/* Shift the bits */
if (s & (16-1)) {
				bniRshift_16(p, size, s & (16-1));
				/* Renormalize */
				if (BIGLITTLE(*(p-size),*(p+(size-1))) == 0)
					  --size;
		}
n->size = size;

MALLOCDB;
return s;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -