convert.h
来自「用于进行gcc测试」· C头文件 代码 · 共 462 行
H
462 行
extern void abort (void);static int failcnt = 0;/* Macros are set up to skip using long double, which doesn't necessarily map to TF mode. If there's a reason to skip those for a test, the test itself can define USE_TF to be zero. */#ifndef USE_TF#define USE_TF 1#endif/* Support compiling the test to report individual failures; default is to abort as soon as a check fails. */#if defined(DBG) || defined(DBG2)#include <stdio.h>#define FAILURE(NUM) \ { printf ("failed for test %s\n", NUM); failcnt++; }#else#define FAILURE(N) abort ();#endif/* This is useful when modifying the test to make sure that tests are actually run. */#if defined(DBG2)#define REPORT(NUM) \ { printf ("%s\n", NUM); }#else#define REPORT(N) ;#endif#define CONVERT_VALID(NUM,FROM,TO,FROMVAL,TOVAL,DIFF) \void \convert_##NUM (void) \{ \ REPORT(#NUM " " #FROMVAL) \ FROM = FROMVAL; \ TO = FROM; \ if (TO < (TOVAL - DIFF) || TO > (TOVAL + DIFF)) \ FAILURE (#NUM); \}#define CONVERT_TO_PINF(NUM,FROM,TO,FROMVAL,TOSUFFIX) \void \convert_##NUM (void) \{ \ REPORT(#NUM " " #FROMVAL) \ FROM = FROMVAL; \ TO = FROM; \ if (__builtin_isinf##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " pinf: isinf"); \ if (__builtin_signbit##TOSUFFIX (TO) != 0) \ FAILURE (#NUM " pinf: sign"); \}#define CONVERT_TO_MINF(NUM,FROM,TO,FROMVAL,TOSUFFIX) \void \convert_##NUM (void) \{ \ REPORT(#NUM " " #FROMVAL) \ FROM = FROMVAL; \ TO = FROM; \ if (__builtin_isinf##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " pinf: isinf"); \ if (__builtin_signbit##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " pinf: sign"); \}#define CONVERT_TO_PZERO(NUM,FROM,TO,FROMVAL,TOVAL,TOSUFFIX) \void \convert_##NUM (void) \{ \ REPORT(#NUM " " #FROMVAL) \ FROM = FROMVAL; \ TO = FROM; \ if (TO != TOVAL) \ FAILURE (#NUM "_pzero: zero") \ if (__builtin_signbit##TOSUFFIX (TO) != 0) \ FAILURE (#NUM " _pzero: sign"); \}#define CONVERT_TO_MZERO(NUM,FROM,TO,FROMVAL,TOVAL,TOSUFFIX) \void \convert_##NUM (void) \{ \ REPORT(#NUM " " #FROMVAL) \ FROM = FROMVAL; \ TO = FROM; \ if (TO != TOVAL) \ FAILURE (#NUM "_mzero: zero") \ if (__builtin_signbit##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " _mzero: sign"); \}#define CONVERT_NAN(NUM,FROM,TO,FROMSUFFIX,TOSUFFIX) \void \convert_##NUM##_nan (void) \{ \ REPORT(#NUM "_nan") \ FROM = __builtin_nan##FROMSUFFIX (""); \ TO = FROM; \ if (__builtin_isnan##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " nan"); \}#define CONVERT_PINF(NUM,FROM,TO,FROMSUFFIX,TOSUFFIX) \void \convert_##NUM##_pinf (void) \{ \ REPORT (#NUM "_pinf") \ FROM = __builtin_inf##FROMSUFFIX (); \ TO = FROM; \ if (__builtin_isinf##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " pinf: isinf"); \ if (__builtin_signbit##TOSUFFIX (TO) != 0) \ FAILURE (#NUM " pinf: sign"); \}#define CONVERT_MINF(NUM,FROM,TO,FROMSUFFIX,TOSUFFIX) \void \convert_##NUM##_minf (void) \{ \ REPORT (#NUM "_minf") \ FROM = -__builtin_inf##FROMSUFFIX (); \ TO = FROM; \ if (__builtin_isinf##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " minf: isinf"); \ if (__builtin_signbit##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " minf: sign"); \}#define CONVERT_PZERO(NUM,FROM,TO,FROMVALUE,TOVALUE,TOSUFFIX) \void \convert_##NUM##_pzero (void) \{ \ REPORT (#NUM "_pzero") \ FROM = FROMVALUE; \ TO = FROM; \ if (TO != TOVALUE) \ FAILURE (#NUM "pzero: zero") \ if (__builtin_signbit##TOSUFFIX (TO) != 0) \ FAILURE (#NUM " pzero: sign"); \}#define CONVERT_MZERO(NUM,FROM,TO,FROMVALUE,TOVALUE,TOSUFFIX) \void \convert_##NUM##_mzero (void) \{ \ REPORT (#NUM "_mzero") \ FROM = FROMVALUE; \ TO = FROM; \ if (TO != TOVALUE) \ FAILURE (#NUM "mzero: zero") \ if (__builtin_signbit##TOSUFFIX (TO) == 0) \ FAILURE (#NUM " mzero: sign"); \}#define CONVERT_VALID_NOTF(NUM,VAL,DIFF) \CONVERT_VALID (NUM##_sdsf, sd, sf, VAL##df, VAL##f, DIFF##f) \CONVERT_VALID (NUM##_sddf, sd, df, VAL##df, VAL, DIFF) \CONVERT_VALID (NUM##_ddsf, dd, sf, VAL##dd, VAL##f, DIFF##f) \CONVERT_VALID (NUM##_dddf, dd, df, VAL##dd, VAL, DIFF) \CONVERT_VALID (NUM##_tdsf, td, sf, VAL##dl, VAL##f, DIFF##f) \CONVERT_VALID (NUM##_tddf, td, df, VAL##dl, VAL, DIFF) \CONVERT_VALID (NUM##_sfsd, sf, sd, VAL##f, VAL##df, DIFF##df) \CONVERT_VALID (NUM##_sfdd, sf, dd, VAL##f, VAL##dd, DIFF##dd) \CONVERT_VALID (NUM##_sftd, sf, td, VAL##f, VAL##dl, DIFF##dl) \CONVERT_VALID (NUM##_dfsd, df, sd, VAL, VAL##df, DIFF##df) \CONVERT_VALID (NUM##_dfdd, df, dd, VAL, VAL##dd, DIFF##dd) \CONVERT_VALID (NUM##_dftd, df, td, VAL, VAL##dl, DIFF##dl) \CONVERT_VALID (NUM##_sddd, sd, dd, VAL##df, VAL##dd, DIFF##dd) \CONVERT_VALID (NUM##_sdtd, sd, dd, VAL##df, VAL##dd, DIFF##dd) \CONVERT_VALID (NUM##_ddsd, dd, sd, VAL##dd, VAL##df, DIFF##dd) \CONVERT_VALID (NUM##_ddtd, dd, td, VAL##dd, VAL##dl, DIFF##dl) \CONVERT_VALID (NUM##_tdsd, td, sd, VAL##dl, VAL##df, DIFF##df) \CONVERT_VALID (NUM##_tddd, td, dd, VAL##dl, VAL##dd, DIFF##dd)#if USE_TF == 0#define CONVERT_VALID_TF(NUM,VAL,DIFF)#else#define CONVERT_VALID_TF(NUM,VAL,DIFF) \CONVERT_VALID (NUM##_sdtf, sd, tf, VAL##df, VAL##l, DIFF##l) \CONVERT_VALID (NUM##_tdtf, td, tf, VAL##dl, VAL##l, DIFF##l) \CONVERT_VALID (NUM##_ddtf, dd, tf, VAL##dd, VAL##l, DIFF##l) \CONVERT_VALID (NUM##_tfsd, tf, sd, VAL##l, VAL##df, DIFF##df) \CONVERT_VALID (NUM##_tfdd, tf, dd, VAL##l, VAL##dd, DIFF##dd) \CONVERT_VALID (NUM##_tftd, tf, td, VAL##l, VAL##dl, DIFF##dl)#endif#define CONVERT_VALID_ALL(NUM,VAL,DIFF) \ CONVERT_VALID_NOTF(NUM,VAL,DIFF) \ CONVERT_VALID_TF(NUM,VAL,DIFF)#define CALL_VALID_NOTF(NUM) \ convert_##NUM##_sdsf (); \ convert_##NUM##_sddf (); \ convert_##NUM##_ddsf (); \ convert_##NUM##_dddf (); \ convert_##NUM##_tdsf (); \ convert_##NUM##_tddf (); \ convert_##NUM##_sfsd (); \ convert_##NUM##_sfdd (); \ convert_##NUM##_sftd (); \ convert_##NUM##_dfsd (); \ convert_##NUM##_dfdd (); \ convert_##NUM##_dftd (); \ convert_##NUM##_sddd (); \ convert_##NUM##_sdtd (); \ convert_##NUM##_ddsd (); \ convert_##NUM##_ddtd (); \ convert_##NUM##_tdsd (); \ convert_##NUM##_tddd ();#if USE_TF == 0#define CALL_VALID_TF(NUM)#else#define CALL_VALID_TF(NUM) \ convert_##NUM##_sdtf (); \ convert_##NUM##_ddtf (); \ convert_##NUM##_tdtf (); \ convert_##NUM##_tfsd (); \ convert_##NUM##_tfdd (); \ convert_##NUM##_tftd ();#endif#define CALL_VALID_ALL(NUM) \ CALL_VALID_NOTF(NUM) \ CALL_VALID_TF(NUM)#define CONVERT_ZEROES(NUM,FROM,TO,FROMVALUE,TOVALUE,TOSUFFIX) \CONVERT_PZERO(NUM, FROM, TO, FROMVALUE, TOVALUE, TOSUFFIX) \CONVERT_MZERO(NUM, FROM, TO, -FROMVALUE, -TOVALUE, TOSUFFIX)#define CONVERT_ZEROES_NOTF(NUM) \CONVERT_ZEROES (NUM##_sdsf, sd, sf, 0.0df, 0.0f, f) \CONVERT_ZEROES (NUM##_sddf, sd, df, 0.0df, 0.0, ) \CONVERT_ZEROES (NUM##_ddsf, dd, sf, 0.0dd, 0.0f, f) \CONVERT_ZEROES (NUM##_dddf, dd, df, 0.0dd, 0.0, ) \CONVERT_ZEROES (NUM##_tdsf, td, sf, 0.0dl, 0.0f, f) \CONVERT_ZEROES (NUM##_tddf, td, df, 0.0dl, 0.0, ) \CONVERT_ZEROES (NUM##_sfsd, sf, sd, 0.0f, 0.0df, d32) \CONVERT_ZEROES (NUM##_sfdd, sf, dd, 0.0f, 0.0dd, d64) \CONVERT_ZEROES (NUM##_sftd, sf, td, 0.0f, 0.0dl, d128) \CONVERT_ZEROES (NUM##_dfsd, df, sd, 0.0, 0.0df, d32) \CONVERT_ZEROES (NUM##_dfdd, df, dd, 0.0, 0.0dd, d64) \CONVERT_ZEROES (NUM##_dftd, df, td, 0.0, 0.0dl, d128) \CONVERT_ZEROES (NUM##_sddd, sd, dd, 0.0df, 0.0dd, d64) \CONVERT_ZEROES (NUM##_sdtd, sd, td, 0.0dl, 0.0dl, d128) \CONVERT_ZEROES (NUM##_ddsd, dd, sd, 0.0dd, 0.0df, d32) \CONVERT_ZEROES (NUM##_ddtd, dd, td, 0.0dd, 0.0dl, d128) \CONVERT_ZEROES (NUM##_tdsd, td, sd, 0.0dl, 0.0df, d32) \CONVERT_ZEROES (NUM##_tddd, td, dd, 0.0dl, 0.0dd, d64)#if USE_TF == 0#define CONVERT_ZEROES_TF(NUM)#else#define CONVERT_ZEROES_TF(NUM) \CONVERT_ZEROES (NUM##_sdtf, sd, tf, 0.0df, 0.0l, l) \CONVERT_ZEROES (NUM##_ddtf, dd, tf, 0.0dd, 0.0l, l) \CONVERT_ZEROES (NUM##_tdtf, td, tf, 0.0dl, 0.0l, l) \CONVERT_ZEROES (NUM##_tfsd, tf, sd, 0.0l, 0.0df, d32) \CONVERT_ZEROES (NUM##_tfdd, tf, dd, 0.0l, 0.0dd, d64) \CONVERT_ZEROES (NUM##_tftd, tf, td, 0.0l, 0.0dl, d128)#endif#define CONVERT_ZEROES_ALL(NUM) \ CONVERT_ZEROES_NOTF(NUM) \ CONVERT_ZEROES_TF(NUM)#define CALL_ZEROES(NUM) \ convert_##NUM##_pzero (); \ convert_##NUM##_mzero ();#define CALL_ZEROES_NOTF(NUM) \ CALL_ZEROES (NUM##_sdsf) \ CALL_ZEROES (NUM##_sddf) \ CALL_ZEROES (NUM##_ddsf) \ CALL_ZEROES (NUM##_dddf) \ CALL_ZEROES (NUM##_tdsf) \ CALL_ZEROES (NUM##_tddf) \ CALL_ZEROES (NUM##_sfsd) \ CALL_ZEROES (NUM##_sfdd) \ CALL_ZEROES (NUM##_sftd) \ CALL_ZEROES (NUM##_dfsd) \ CALL_ZEROES (NUM##_dfdd) \ CALL_ZEROES (NUM##_dftd) \ CALL_ZEROES (NUM##_sddd) \ CALL_ZEROES (NUM##_sdtd) \ CALL_ZEROES (NUM##_ddsd) \ CALL_ZEROES (NUM##_ddtd) \ CALL_ZEROES (NUM##_tdsd) \ CALL_ZEROES (NUM##_tddd)#if USE_TF == 0#define CALL_ZEROES_TF(NUM)#else#define CALL_ZEROES_TF(NUM) \ CALL_ZEROES (NUM##_sdtf) \ CALL_ZEROES (NUM##_ddtf) \ CALL_ZEROES (NUM##_tdtf) \ CALL_ZEROES (NUM##_tfsd) \ CALL_ZEROES (NUM##_tfdd) \ CALL_ZEROES (NUM##_tftd)#endif#define CALL_ZEROES_ALL(NUM) \ CALL_ZEROES_NOTF(NUM) \ CALL_ZEROES_TF(NUM)#define CONVERT_INF(NUM,FROM,TO,FROMSUFFIX,TOSUFFIX) \CONVERT_PINF (NUM, FROM, TO, FROMSUFFIX, TOSUFFIX) \CONVERT_MINF (NUM, FROM, TO, FROMSUFFIX, TOSUFFIX)#define CONVERT_INF_NOTF(NUM) \CONVERT_INF (NUM##_sdsf, sd, sf, d32, f) \CONVERT_INF (NUM##_sddf, sd, df, d32, ) \CONVERT_INF (NUM##_ddsf, dd, sf, d64, f) \CONVERT_INF (NUM##_dddf, dd, df, d64, ) \CONVERT_INF (NUM##_tdsf, td, sf, d128, f) \CONVERT_INF (NUM##_tddf, td, df, d128, ) \CONVERT_INF (NUM##_sfsd, sf, sd, f, d32) \CONVERT_INF (NUM##_sfdd, sf, dd, f, d64) \CONVERT_INF (NUM##_sftd, sf, td, f, d128) \CONVERT_INF (NUM##_dfsd, df, sd, , d32) \CONVERT_INF (NUM##_dfdd, df, dd, , d64) \CONVERT_INF (NUM##_dftd, df, td, , d128) \CONVERT_INF (NUM##_sddd, sd, dd, d32, d64) \CONVERT_INF (NUM##_sdtd, sd, td, d32, d128) \CONVERT_INF (NUM##_ddsd, dd, sd, d64, d32) \CONVERT_INF (NUM##_ddtd, dd, td, d64, d128) \CONVERT_INF (NUM##_tdsd, td, sd, d128, d32) \CONVERT_INF (NUM##_tddd, td, dd, d128, d64)#if USE_TF == 0#define CONVERT_INF_TF(NUM)#else#define CONVERT_INF_TF(NUM) \CONVERT_INF (NUM##_sdtf, sd, tf, d32, l) \CONVERT_INF (NUM##_ddtf, dd, tf, d64, l) \CONVERT_INF (NUM##_tdtf, td, tf, d128, l) \CONVERT_INF (NUM##_tfsd, tf, sd, l, d32) \CONVERT_INF (NUM##_tfdd, tf, dd, l, d64) \CONVERT_INF (NUM##_tftd, tf, td, l, d128)#endif#define CONVERT_INF_ALL(NUM) \ CONVERT_INF_NOTF(NUM) \ CONVERT_INF_TF(NUM)#define CALL_INF(NUM) \ convert_##NUM##_pinf (); \ convert_##NUM##_minf ();#define CALL_INF_NOTF(NUM) \ CALL_INF (NUM##_sdsf) \ CALL_INF (NUM##_sddf) \ CALL_INF (NUM##_ddsf) \ CALL_INF (NUM##_dddf) \ CALL_INF (NUM##_tdsf) \ CALL_INF (NUM##_tddf) \ CALL_INF (NUM##_sfsd) \ CALL_INF (NUM##_sfdd) \ CALL_INF (NUM##_sftd) \ CALL_INF (NUM##_dfsd) \ CALL_INF (NUM##_dfdd) \ CALL_INF (NUM##_dftd) \ CALL_INF (NUM##_sddd) \ CALL_INF (NUM##_sdtd) \ CALL_INF (NUM##_ddsd) \ CALL_INF (NUM##_ddtd) \ CALL_INF (NUM##_tdsd) \ CALL_INF (NUM##_tddd)#if USE_TF == 0#define CALL_INF_TF(NUM)#else#define CALL_INF_TF(NUM) \ CALL_INF (NUM##_sdtf) \ CALL_INF (NUM##_ddtf) \ CALL_INF (NUM##_tdtf) \ CALL_INF (NUM##_tfsd) \ CALL_INF (NUM##_tfdd) \ CALL_INF (NUM##_tftd)#endif#define CALL_INF_ALL(NUM) \ CALL_INF_NOTF(NUM) \ CALL_INF_TF(NUM)#define CONVERT_NAN_NOTF(NUM) \CONVERT_NAN (NUM##_sdsf, sd, sf, d32, f) \CONVERT_NAN (NUM##_sddf, sd, df, d32, ) \CONVERT_NAN (NUM##_ddsf, dd, sf, d64, f) \CONVERT_NAN (NUM##_dddf, dd, df, d64, ) \CONVERT_NAN (NUM##_tdsf, td, sf, d128, f) \CONVERT_NAN (NUM##_tddf, td, df, d128, ) \CONVERT_NAN (NUM##_sfsd, sf, sd, f, d32) \CONVERT_NAN (NUM##_sfdd, sf, dd, f, d64) \CONVERT_NAN (NUM##_sftd, sf, td, f, d128) \CONVERT_NAN (NUM##_dfsd, df, sd, , d32) \CONVERT_NAN (NUM##_dfdd, df, dd, , d64) \CONVERT_NAN (NUM##_dftd, df, td, , d128) \CONVERT_NAN (NUM##_sddd, sd, dd, d32, d64) \CONVERT_NAN (NUM##_sdtd, sd, td, d32, d128) \CONVERT_NAN (NUM##_ddsd, dd, sd, d64, d32) \CONVERT_NAN (NUM##_ddtd, dd, td, d64, d128) \CONVERT_NAN (NUM##_tdsd, td, sd, d128, d32) \CONVERT_NAN (NUM##_tddd, td, dd, d128, d64)#if USE_TF == 0#define CONVERT_NAN_TF(NUM)#else#define CONVERT_NAN_TF(NUM) \CONVERT_NAN (NUM##_sdtf, sd, tf, d32, l) \CONVERT_NAN (NUM##_ddtf, dd, tf, d64, l) \CONVERT_NAN (NUM##_tdtf, td, tf, d128, l) \CONVERT_NAN (NUM##_tfsd, tf, sd, l, d32) \CONVERT_NAN (NUM##_tfdd, tf, dd, l, d64) \CONVERT_NAN (NUM##_tftd, tf, td, l, d128)#endif#define CONVERT_NAN_ALL(NUM) \ CONVERT_NAN_NOTF(NUM) \ CONVERT_NAN_TF(NUM)#define CALL_NAN(NUM) \ convert_##NUM##_nan ();#define CALL_NAN_NOTF(NUM) \ CALL_NAN (NUM##_sdsf) \ CALL_NAN (NUM##_sddf) \ CALL_NAN (NUM##_ddsf) \ CALL_NAN (NUM##_dddf) \ CALL_NAN (NUM##_tdsf) \ CALL_NAN (NUM##_tddf) \ CALL_NAN (NUM##_sfsd) \ CALL_NAN (NUM##_sfdd) \ CALL_NAN (NUM##_sftd) \ CALL_NAN (NUM##_dfsd) \ CALL_NAN (NUM##_dfdd) \ CALL_NAN (NUM##_dftd) \ CALL_NAN (NUM##_sddd) \ CALL_NAN (NUM##_sdtd) \ CALL_NAN (NUM##_ddsd) \ CALL_NAN (NUM##_ddtd) \ CALL_NAN (NUM##_tdsd) \ CALL_NAN (NUM##_tddd)#if USE_TF == 0#define CALL_NAN_TF(NUM)#else#define CALL_NAN_TF(NUM) \ CALL_NAN (NUM##_sdtf) \ CALL_NAN (NUM##_ddtf) \ CALL_NAN (NUM##_tdtf) \ CALL_NAN (NUM##_tfsd) \ CALL_NAN (NUM##_tfdd) \ CALL_NAN (NUM##_tftd)#endif#define CALL_NAN_ALL(NUM) \ CALL_NAN_NOTF(NUM) \ CALL_NAN_TF(NUM)
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?