Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

97 lines
1.8 KiB

  1. //----------------------------------------------------------------------------
  2. //
  3. // float10.h
  4. //
  5. // Copyright (C) Microsoft Corporation, 1997.
  6. //
  7. //----------------------------------------------------------------------------
  8. #ifndef _FLOAT10_H_
  9. #define _FLOAT10_H_
  10. typedef struct {
  11. double x;
  12. } UDOUBLE;
  13. #pragma pack(4)
  14. typedef UCHAR u_char;
  15. typedef struct {
  16. u_char ld[10];
  17. } _ULDOUBLE;
  18. #pragma pack()
  19. #pragma pack(4)
  20. typedef struct {
  21. u_char ld12[12];
  22. } _ULDBL12;
  23. #pragma pack()
  24. #define MAX_MAN_DIGITS 21
  25. #define MAX_10_LEN 30 //max length of string including NULL
  26. // specifies '%f' format
  27. #define SO_FFORMAT 1
  28. typedef struct _FloatOutStruct {
  29. short exp;
  30. char sign;
  31. char ManLen;
  32. char man[MAX_MAN_DIGITS+1];
  33. } FOS;
  34. char * _uldtoa (_ULDOUBLE *px, int maxchars, char *ldtext);
  35. int $I10_OUTPUT(_ULDOUBLE ld, int ndigits,
  36. unsigned output_flags, FOS *fos);
  37. //
  38. // return values for strgtold12 routine
  39. //
  40. #define SLD_UNDERFLOW 1
  41. #define SLD_OVERFLOW 2
  42. #define SLD_NODIGITS 4
  43. //
  44. // return values for internal conversion routines
  45. // (12-byte to long double, double, or float)
  46. //
  47. typedef enum {
  48. INTRNCVT_OK,
  49. INTRNCVT_OVERFLOW,
  50. INTRNCVT_UNDERFLOW
  51. } INTRNCVT_STATUS;
  52. unsigned int
  53. __strgtold12(_ULDBL12 *pld12,
  54. char * *p_end_ptr,
  55. char *str,
  56. int mult12);
  57. INTRNCVT_STATUS _ld12tod(_ULDBL12 *pld12, UDOUBLE *d);
  58. void _ld12told(_ULDBL12 *pld12, _ULDOUBLE *pld);
  59. void _atodbl(UDOUBLE *d, char *str);
  60. void _atoldbl(_ULDOUBLE *ld, char *str);
  61. //
  62. // Simple FLOAT86 utilities
  63. //
  64. typedef struct {
  65. ULONG64 significand : 64;
  66. UINT exponent : 17;
  67. UINT sign : 1;
  68. } FLOAT82_FORMAT;
  69. double
  70. Float82ToDouble(const FLOAT128* FpReg82);
  71. void
  72. DoubleToFloat82(double f, FLOAT128* FpReg82);
  73. #endif // #ifndef _FLOAT10_H_