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

📄 mpaux.c

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 C
字号:
#include "os.h"#include <mp.h>#include "dat.h"static mpdigit _mptwodata[1] = { 2 };static mpint _mptwo ={	1,	1,	1,	_mptwodata,	MPstatic};mpint *mptwo = &_mptwo;static mpdigit _mponedata[1] = { 1 };static mpint _mpone ={	1,	1,	1,	_mponedata,	MPstatic};mpint *mpone = &_mpone;static mpdigit _mpzerodata[1] = { 0 };static mpint _mpzero ={	1,	1,	0,	_mpzerodata,	MPstatic};mpint *mpzero = &_mpzero;static int mpmindigits = 33;// set minimum digit allocationvoidmpsetminbits(int n){	if(n < 0)		sysfatal("mpsetminbits: n < 0");	if(n == 0)		n = 1;	mpmindigits = DIGITS(n);}// allocate an n bit 0'd number mpint*mpnew(int n){	mpint *b;	if(n < 0)		sysfatal("mpsetminbits: n < 0");	b = mallocz(sizeof(mpint), 1);	setmalloctag(b, getcallerpc(&n));	if(b == nil)		sysfatal("mpnew: %r");	n = DIGITS(n);	if(n < mpmindigits)		n = mpmindigits;	b->p = (mpdigit*)mallocz(n*Dbytes, 1);	if(b->p == nil)		sysfatal("mpnew: %r");	b->size = n;	b->sign = 1;	return b;}// guarantee at least n significant bitsvoidmpbits(mpint *b, int m){	int n;	n = DIGITS(m);	if(b->size >= n){		if(b->top >= n)			return;		memset(&b->p[b->top], 0, Dbytes*(n - b->top));		b->top = n;		return;	}	b->p = (mpdigit*)realloc(b->p, n*Dbytes);	if(b->p == nil)		sysfatal("mpbits: %r");	memset(&b->p[b->top], 0, Dbytes*(n - b->top));	b->size = n;	b->top = n;}voidmpfree(mpint *b){	if(b == nil)		return;	if(b->flags & MPstatic)		sysfatal("freeing mp constant");	memset(b->p, 0, b->size*Dbytes);	// information hiding	free(b->p);	free(b);}voidmpnorm(mpint *b){	int i;	for(i = b->top-1; i >= 0; i--)		if(b->p[i] != 0)			break;	b->top = i+1;	if(b->top == 0)		b->sign = 1;}mpint*mpcopy(mpint *old){	mpint *new;	new = mpnew(Dbits*old->size);	new->top = old->top;	new->sign = old->sign;	memmove(new->p, old->p, Dbytes*old->top);	return new;}voidmpassign(mpint *old, mpint *new){	mpbits(new, Dbits*old->top);	new->sign = old->sign;	new->top = old->top;	memmove(new->p, old->p, Dbytes*old->top);}// number of significant bits in mantissaintmpsignif(mpint *n){	int i, j;	mpdigit d;	if(n->top == 0)		return 0;	for(i = n->top-1; i >= 0; i--){		d = n->p[i];		for(j = Dbits-1; j >= 0; j--){			if(d & (((mpdigit)1)<<j))				return i*Dbits + j + 1;		}	}	return 0;}// k, where n = 2**k * q for odd qintmplowbits0(mpint *n){	int k, bit, digit;	mpdigit d;	if(n->top==0)		return 0;	k = 0;	bit = 0;	digit = 0;	d = n->p[0];	for(;;){		if(d & (1<<bit))			break;		k++;		bit++;		if(bit==Dbits){			if(++digit >= n->top)				return 0;			d = n->p[digit];			bit = 0;		}	}	return k;}

⌨️ 快捷键说明

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