]> git.ipfire.org Git - thirdparty/glibc.git/commit
ldbl-128ibm-compat: Add printf_size
authorGabriel F. T. Gomes <gabriel@inconstante.eti.br>
Fri, 29 Jun 2018 01:38:55 +0000 (22:38 -0300)
committerGabriel F. T. Gomes <gabriel@inconstante.eti.br>
Mon, 2 Jul 2018 13:51:01 +0000 (10:51 -0300)
commitb7b88cea4151d85eafd7ababc2e4b7ae1daeedf5
tree9e39b1e246cf3201522aafdbe073d29281684334
parent2b445206a1a450af0e6e66d78652e1ffd80685e2
ldbl-128ibm-compat: Add printf_size

Since the addition of the _Float128 API, strfromf128 and printf_size use
__printf_fp to print _Float128 values.  This is achieved by setting the
'is_binary128' member of the 'printf_info' structure to one.  Now that
the format of long double on powerpc64le is getting a third option, this
mechanism is reused for long double values that have binary128 format
(i.e.: when -mabi=ieeelongdouble).

This patch adds __printf_sizeieee128 as an exported symbol, but doesn't
provide redirections from printf_size, yet.  All redirections will be
installed in a future commit, once all other functions that print or
read long double values with binary128 format are ready.  In
__printf_fp, when 'is_binary128' is one, the floating-point argument is
treated as if it was of _Float128 type, regardless of the value of
'is_long_double', thus __printf_sizeieee128 sets 'is_binary128' to the
same value of 'is_long_double'.  Otherwise, double values would not be
printed correctly.

Tested for powerpc64le.
ChangeLog
stdio-common/Makefile
stdio-common/tst-printfsz-islongdouble.c [new file with mode: 0644]
stdio-common/tst-printfsz-islongdouble.sh [new file with mode: 0644]
sysdeps/ieee754/ldbl-128ibm-compat/Makefile [new file with mode: 0644]
sysdeps/ieee754/ldbl-128ibm-compat/Versions
sysdeps/ieee754/ldbl-128ibm-compat/ieee128-printf_size.c [new file with mode: 0644]
sysdeps/ieee754/ldbl-128ibm-compat/test-printf-size-ibm128.c [new file with mode: 0644]
sysdeps/ieee754/ldbl-128ibm-compat/test-printf-size-ieee128.c [new file with mode: 0644]