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

📄 cif8.c

📁 操作系统源代码
💻 C
字号:
/*  (c) copyright 1988 by the Vrije Universiteit, Amsterdam, The Netherlands.  See the copyright notice in the ACK home directory, in the file "Copyright".*//* $Header: cif8.c,v 1.5 93/01/05 12:04:07 ceriel Exp $ *//*	CONVERT INTEGER TO FLOAT (CIF n 8)	THIS ROUTINE WORKS BY FILLING AN EXTENDED	WITH THE INTEGER VALUE IN EXTENDED FORMAT	AND USES COMPACT() TO PUT IT INTO THE PROPER	FLOATING POINT PRECISION.*/#include "FP_types.h"voidcif8(ss,src)int	ss;	/* source size */long	src;	/* largest possible integer to convert */{	EXTEND	buf;	DOUBLE	*result;	/* for return value */	short	*ipt;	long	i_src;	result = (DOUBLE *) ((void *) &ss);	/* always */	zrf_ext(&buf);	if (ss == sizeof(long))	{		buf.exp = 31;		i_src = src;	}	else	{		ipt = (short *) &src;		i_src = (long) *ipt;		buf.exp = 15;	}	if (i_src == 0)	{		zrf8(result);		return;	}			/* ESTABLISHED THAT src != 0	*/			/* adjust exponent field	*/	buf.sign = (i_src < 0) ? 0x8000 : 0;			/* clear sign bit of integer	*/			/* move to mantissa field	*/	buf.m1 = (i_src < 0) ? -i_src : i_src;			/* adjust mantissa field	*/	if (ss != sizeof(long))		buf.m1 <<= 16;	nrm_ext(&buf);	compact(&buf,&result->d[0],8);}

⌨️ 快捷键说明

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