libs/libc/stdio: replace double_t to double
Modify reason: When build Nuttx SIM, in x86_64 system: Compile with gcc option '-m64' (default): sizeof(double_t) = 8 sizeof(double) = 8 Compile with gcc option '-mx32': sizeof(double_t) = 8 sizeof(double) = 8 Compile with gcc option '-m32': sizeof(double_t) = 12 // long double sizeof(double) = 8 When use '-m32', and print sth. like this: printf("%f\n", (double)3.0); SIM will print out: nan This is because sizeof(double_t) is not equal with double. Resolve: replace all double_t to double in libs/libc/stdio. As a user of '-m32', you should know double_t is one type long double, and len is 12. And you use use '%lf' to print. like: printf("%lf\n", (double_t)3.0); Currently we don't support '%lf'. Change-Id: I9b9d11853140d5296dd80416c8ed6a260a9d2d9c Signed-off-by: ligd <liguiding1@xiaomi.com>
This commit is contained in:
parent
d47131d8ae
commit
c11c1dc8fd
@ -144,14 +144,14 @@ static FAR bigint_t *g_freelist[KMAX + 1];
|
|||||||
static FAR bigint_t *g_p5s;
|
static FAR bigint_t *g_p5s;
|
||||||
|
|
||||||
#ifdef IEEE_ARITH
|
#ifdef IEEE_ARITH
|
||||||
static const double_t g_bigtens[] =
|
static const double g_bigtens[] =
|
||||||
{
|
{
|
||||||
1e16, 1e32, 1e64, 1e128, 1e256
|
1e16, 1e32, 1e64, 1e128, 1e256
|
||||||
};
|
};
|
||||||
|
|
||||||
# define n_bigtens 5
|
# define n_bigtens 5
|
||||||
#else
|
#else
|
||||||
static const double_t g_bigtens[] =
|
static const double g_bigtens[] =
|
||||||
{
|
{
|
||||||
1e16, 1e32
|
1e16, 1e32
|
||||||
};
|
};
|
||||||
@ -770,7 +770,7 @@ static FAR bigint_t *diff(FAR bigint_t *a, FAR bigint_t *b)
|
|||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAR bigint_t *d2b(double_t d, int *e, int *bits)
|
static FAR bigint_t *d2b(double d, int *e, int *bits)
|
||||||
{
|
{
|
||||||
FAR bigint_t *b;
|
FAR bigint_t *b;
|
||||||
FAR unsigned long *x;
|
FAR unsigned long *x;
|
||||||
@ -906,7 +906,7 @@ static FAR bigint_t *d2b(double_t d, int *e, int *bits)
|
|||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const double_t tens[] =
|
static const double tens[] =
|
||||||
{
|
{
|
||||||
1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9,
|
1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e9,
|
||||||
1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19,
|
1e10, 1e11, 1e12, 1e13, 1e14, 1e15, 1e16, 1e17, 1e18, 1e19,
|
||||||
@ -1088,7 +1088,7 @@ static int quorem(FAR bigint_t *b, FAR bigint_t *s)
|
|||||||
* calculation.
|
* calculation.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
FAR char *__dtoa(double_t d, int mode, int ndigits, FAR int *decpt,
|
FAR char *__dtoa(double d, int mode, int ndigits, FAR int *decpt,
|
||||||
FAR int *sign, FAR char **rve)
|
FAR int *sign, FAR char **rve)
|
||||||
{
|
{
|
||||||
/* Arguments ndigits, decpt, sign are similar to those of ecvt and fcvt;
|
/* Arguments ndigits, decpt, sign are similar to those of ecvt and fcvt;
|
||||||
@ -1126,9 +1126,9 @@ FAR char *__dtoa(double_t d, int mode, int ndigits, FAR int *decpt,
|
|||||||
FAR bigint_t *s;
|
FAR bigint_t *s;
|
||||||
FAR char *st;
|
FAR char *st;
|
||||||
FAR char *st0;
|
FAR char *st0;
|
||||||
double_t d2;
|
double d2;
|
||||||
double_t ds;
|
double ds;
|
||||||
double_t eps;
|
double eps;
|
||||||
long l;
|
long l;
|
||||||
unsigned long x;
|
unsigned long x;
|
||||||
int denorm;
|
int denorm;
|
||||||
|
@ -508,7 +508,7 @@ static int getusize(uint8_t fmt, uint16_t flags, unsigned int n)
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_LIBC_FLOATINGPOINT
|
#ifdef CONFIG_LIBC_FLOATINGPOINT
|
||||||
static int getdblsize(uint8_t fmt, int trunc, uint16_t flags, double_t n)
|
static int getdblsize(uint8_t fmt, int trunc, uint16_t flags, double n)
|
||||||
{
|
{
|
||||||
struct lib_outstream_s nulloutstream;
|
struct lib_outstream_s nulloutstream;
|
||||||
lib_nulloutstream(&nulloutstream);
|
lib_nulloutstream(&nulloutstream);
|
||||||
@ -1565,7 +1565,7 @@ int lib_vsprintf(FAR struct lib_outstream_s *obj, FAR const IPTR char *src,
|
|||||||
#ifdef CONFIG_LIBC_FLOATINGPOINT
|
#ifdef CONFIG_LIBC_FLOATINGPOINT
|
||||||
else if (strchr("eEfgG", FMT_CHAR))
|
else if (strchr("eEfgG", FMT_CHAR))
|
||||||
{
|
{
|
||||||
double_t dblval = va_arg(ap, double_t);
|
double dblval = va_arg(ap, double);
|
||||||
int dblsize;
|
int dblsize;
|
||||||
|
|
||||||
if (FMT_CHAR == 'g' || FMT_CHAR == 'G')
|
if (FMT_CHAR == 'g' || FMT_CHAR == 'G')
|
||||||
|
@ -68,7 +68,7 @@
|
|||||||
* Public Data
|
* Public Data
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
const double_t g_dtoa_scale_up[] =
|
const double g_dtoa_scale_up[] =
|
||||||
{
|
{
|
||||||
#if DBL_MAX_10_EXP >= 1
|
#if DBL_MAX_10_EXP >= 1
|
||||||
1e1,
|
1e1,
|
||||||
@ -123,7 +123,7 @@ const double_t g_dtoa_scale_up[] =
|
|||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
const double_t g_dtoa_scale_down[] =
|
const double g_dtoa_scale_down[] =
|
||||||
{
|
{
|
||||||
#if DBL_MIN_10_EXP <= -1
|
#if DBL_MIN_10_EXP <= -1
|
||||||
1e-1,
|
1e-1,
|
||||||
@ -178,7 +178,7 @@ const double_t g_dtoa_scale_down[] =
|
|||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
const double_t g_dtoa_round[] =
|
const double g_dtoa_round[] =
|
||||||
{
|
{
|
||||||
#if DBL_DIG >= 30
|
#if DBL_DIG >= 30
|
||||||
5e30,
|
5e30,
|
||||||
|
@ -61,7 +61,7 @@
|
|||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
int __dtoa_engine(double_t x, FAR struct dtoa_s *dtoa, int max_digits,
|
int __dtoa_engine(double x, FAR struct dtoa_s *dtoa, int max_digits,
|
||||||
int max_decimals)
|
int max_decimals)
|
||||||
{
|
{
|
||||||
int32_t exp = 0;
|
int32_t exp = 0;
|
||||||
@ -90,7 +90,7 @@ int __dtoa_engine(double_t x, FAR struct dtoa_s *dtoa, int max_digits,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
double_t y;
|
double y;
|
||||||
|
|
||||||
exp = MIN_MANT_EXP;
|
exp = MIN_MANT_EXP;
|
||||||
|
|
||||||
|
@ -176,15 +176,15 @@ struct dtoa_s
|
|||||||
* Public Data
|
* Public Data
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
extern const double_t g_dtoa_scale_up[];
|
extern const double g_dtoa_scale_up[];
|
||||||
extern const double_t g_dtoa_scale_down[];
|
extern const double g_dtoa_scale_down[];
|
||||||
extern const double_t g_dtoa_round[];
|
extern const double g_dtoa_round[];
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Function Prototypes
|
* Public Function Prototypes
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
int __dtoa_engine(double_t x, FAR struct dtoa_s *dtoa, int max_digits,
|
int __dtoa_engine(double x, FAR struct dtoa_s *dtoa, int max_digits,
|
||||||
int max_decimals);
|
int max_decimals);
|
||||||
|
|
||||||
#endif /* __LIBS_LIBC_STDIO_LIB_DTOA_ENGINE_H */
|
#endif /* __LIBS_LIBC_STDIO_LIB_DTOA_ENGINE_H */
|
||||||
|
@ -158,7 +158,7 @@ static void lib_dtoa_string(FAR struct lib_outstream_s *obj, const char *str)
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static void lib_dtoa(FAR struct lib_outstream_s *obj, int fmt, int prec,
|
static void lib_dtoa(FAR struct lib_outstream_s *obj, int fmt, int prec,
|
||||||
uint16_t flags, double_t value)
|
uint16_t flags, double value)
|
||||||
{
|
{
|
||||||
FAR char *digits; /* String returned by __dtoa */
|
FAR char *digits; /* String returned by __dtoa */
|
||||||
FAR char *rve; /* Points to the end of the return value */
|
FAR char *rve; /* Points to the end of the return value */
|
||||||
|
@ -918,7 +918,7 @@ int lib_vscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
|
|||||||
else if (strchr("aAfFeEgG", fmt_char(fmt)) != NULL)
|
else if (strchr("aAfFeEgG", fmt_char(fmt)) != NULL)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_HAVE_DOUBLE
|
#ifdef CONFIG_HAVE_DOUBLE
|
||||||
FAR double_t *pd = NULL;
|
FAR double *pd = NULL;
|
||||||
#endif
|
#endif
|
||||||
FAR float *pf = NULL;
|
FAR float *pf = NULL;
|
||||||
|
|
||||||
@ -938,7 +938,7 @@ int lib_vscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
|
|||||||
#ifdef CONFIG_HAVE_DOUBLE
|
#ifdef CONFIG_HAVE_DOUBLE
|
||||||
if (modifier >= L_MOD)
|
if (modifier >= L_MOD)
|
||||||
{
|
{
|
||||||
pd = va_arg(ap, FAR double_t *);
|
pd = va_arg(ap, FAR double *);
|
||||||
*pd = 0.0;
|
*pd = 0.0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -971,7 +971,7 @@ int lib_vscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
|
|||||||
bool stopconv;
|
bool stopconv;
|
||||||
int errsave;
|
int errsave;
|
||||||
# ifdef CONFIG_HAVE_DOUBLE
|
# ifdef CONFIG_HAVE_DOUBLE
|
||||||
double_t dvalue;
|
double dvalue;
|
||||||
# endif
|
# endif
|
||||||
float fvalue;
|
float fvalue;
|
||||||
|
|
||||||
@ -1057,7 +1057,7 @@ int lib_vscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
|
|||||||
# ifdef CONFIG_HAVE_DOUBLE
|
# ifdef CONFIG_HAVE_DOUBLE
|
||||||
if (modifier >= L_MOD)
|
if (modifier >= L_MOD)
|
||||||
{
|
{
|
||||||
/* Get the converted double_t value */
|
/* Get the converted double value */
|
||||||
|
|
||||||
dvalue = strtod(tmp, &endptr);
|
dvalue = strtod(tmp, &endptr);
|
||||||
}
|
}
|
||||||
@ -1080,13 +1080,13 @@ int lib_vscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
|
|||||||
if (!noassign)
|
if (!noassign)
|
||||||
{
|
{
|
||||||
/* We have to check whether we need to return a float
|
/* We have to check whether we need to return a float
|
||||||
* or a double_t.
|
* or a double.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
# ifdef CONFIG_HAVE_DOUBLE
|
# ifdef CONFIG_HAVE_DOUBLE
|
||||||
if (modifier >= L_MOD)
|
if (modifier >= L_MOD)
|
||||||
{
|
{
|
||||||
/* Return the double_t value */
|
/* Return the double value */
|
||||||
|
|
||||||
linfo("Return %f to %p\n", dvalue, pd);
|
linfo("Return %f to %p\n", dvalue, pd);
|
||||||
*pd = dvalue;
|
*pd = dvalue;
|
||||||
@ -1096,7 +1096,7 @@ int lib_vscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
|
|||||||
{
|
{
|
||||||
/* Return the float value */
|
/* Return the float value */
|
||||||
|
|
||||||
linfo("Return %f to %p\n", (double_t)fvalue, pf);
|
linfo("Return %f to %p\n", (double)fvalue, pf);
|
||||||
*pf = fvalue;
|
*pf = fvalue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,7 +131,7 @@ struct arg
|
|||||||
#ifdef CONFIG_LIBC_LONG_LONG
|
#ifdef CONFIG_LIBC_LONG_LONG
|
||||||
unsigned long long ull;
|
unsigned long long ull;
|
||||||
#endif
|
#endif
|
||||||
double_t d;
|
double d;
|
||||||
FAR char *cp;
|
FAR char *cp;
|
||||||
} value;
|
} value;
|
||||||
};
|
};
|
||||||
@ -540,7 +540,7 @@ static int vsprintf_internal(FAR struct lib_outstream_s *stream,
|
|||||||
}
|
}
|
||||||
else if (c >= 'e' && c <= 'g')
|
else if (c >= 'e' && c <= 'g')
|
||||||
{
|
{
|
||||||
double_t value;
|
double value;
|
||||||
int exp; /* Exponent of master decimal digit */
|
int exp; /* Exponent of master decimal digit */
|
||||||
int n;
|
int n;
|
||||||
uint8_t sign; /* Sign character (or 0) */
|
uint8_t sign; /* Sign character (or 0) */
|
||||||
@ -589,10 +589,10 @@ static int vsprintf_internal(FAR struct lib_outstream_s *stream,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
value = va_arg(ap, double_t);
|
value = va_arg(ap, double);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
value = va_arg(ap, double_t);
|
value = va_arg(ap, double);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
ndigs = __dtoa_engine(value, &_dtoa, ndigs,
|
ndigs = __dtoa_engine(value, &_dtoa, ndigs,
|
||||||
@ -858,7 +858,7 @@ static int vsprintf_internal(FAR struct lib_outstream_s *stream,
|
|||||||
#else /* !CONFIG_LIBC_FLOATINGPOINT */
|
#else /* !CONFIG_LIBC_FLOATINGPOINT */
|
||||||
if ((c >= 'E' && c <= 'G') || (c >= 'e' && c <= 'g'))
|
if ((c >= 'E' && c <= 'G') || (c >= 'e' && c <= 'g'))
|
||||||
{
|
{
|
||||||
va_arg(ap, double_t);
|
va_arg(ap, double);
|
||||||
pnt = "*float*";
|
pnt = "*float*";
|
||||||
size = sizeof("*float*") - 1;
|
size = sizeof("*float*") - 1;
|
||||||
goto str_lpad;
|
goto str_lpad;
|
||||||
@ -1273,7 +1273,7 @@ int lib_vsprintf(FAR struct lib_outstream_s *stream,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case TYPE_DOUBLE:
|
case TYPE_DOUBLE:
|
||||||
arglist[i].value.d = va_arg(ap, double_t);
|
arglist[i].value.d = va_arg(ap, double);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TYPE_CHAR_POINTER:
|
case TYPE_CHAR_POINTER:
|
||||||
|
Loading…
Reference in New Issue
Block a user