shithub: femtolisp

ref: 0d5459f1f08ef367cd8849fc733b64bbdd9fd552
dir: /ieee754.h/

View raw version
#pragma once

union ieee754_float {
	float f;

	struct {
#if BYTE_ORDER == BIG_ENDIAN
	unsigned int negative:1;
	unsigned int exponent:8;
	unsigned int mantissa:23;
#elif BYTE_ORDER == LITTLE_ENDIAN
	unsigned int mantissa:23;
	unsigned int exponent:8;
	unsigned int negative:1;
#else
#error which endian?
#endif
	}ieee;
};

#define IEEE754_FLOAT_BIAS 0x7f

union ieee754_double {
	double d;

	struct {
#if BYTE_ORDER == BIG_ENDIAN
	unsigned int negative:1;
	unsigned int exponent:11;
	unsigned int mantissa0:20;
	unsigned int mantissa1:32;
#else
	unsigned int mantissa1:32;
	unsigned int mantissa0:20;
	unsigned int exponent:11;
	unsigned int negative:1;
#endif
	}ieee;
};

#define IEEE754_DOUBLE_BIAS 0x3ff