mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-29 11:41:21 +03:00
Create and use first-versions.h with macros for function symbol versions.
This patch arranges for the glibc build to generate a header first-versions.h that defines macros for the earliest symbol version in which each public symbol (GLIBC_[0-9]* symbol version, name only uses C identifier characters) is available. This is used in sysdeps/ieee754/ldbl-opt/math-type-macros-double.h to replace the manually defined LDOUBLE_*_libm_version macros for various functions defined using type-generic templates, the purpose of which is to use in LONG_DOUBLE_COMPAT tests "was this function originally added before glibc supported long double != double on this platform?". As discussed in <https://sourceware.org/ml/libc-alpha/2016-12/msg00246.html>, I expect this to be useful more generally in reducing the amount of special-case code needed in ldbl-opt and ldbl-64-128. Tested with build-many-glibcs.py that installed stripped shared libraries are unchanged by this patch. * scripts/versions.awk: Generate first-versions.h. * sysdeps/ieee754/ldbl-opt/math-type-macros-double.h: Include <first-versions.h>. (LDOUBLE_cabsl_libm_version): Remove macro. (LDOUBLE_cargl_libm_version): Likewise. (LDOUBLE_cimagl_libm_version): Likewise. (LDOUBLE_conjl_libm_version): Likewise. (LDOUBLE_creall_libm_version): Likewise. (LDOUBLE_cacosl_libm_version): Likewise. (LDOUBLE_cacoshl_libm_version): Likewise. (LDOUBLE_ccosl_libm_version): Likewise. (LDOUBLE_ccoshl_libm_version): Likewise. (LDOUBLE_casinl_libm_version): Likewise. (LDOUBLE_csinl_libm_version): Likewise. (LDOUBLE_casinhl_libm_version): Likewise. (LDOUBLE_csinhl_libm_version): Likewise. (LDOUBLE_catanl_libm_version): Likewise. (LDOUBLE_catanhl_libm_version): Likewise. (LDOUBLE_ctanl_libm_version): Likewise. (LDOUBLE_ctanhl_libm_version): Likewise. (LDOUBLE_cexpl_libm_version): Likewise. (LDOUBLE_clogl_libm_version): Likewise. (LDOUBLE_cprojl_libm_version): Likewise. (LDOUBLE_csqrtl_libm_version): Likewise. (LDOUBLE_cpowl_libm_version): Likewise. (LDOUBLE_clog10l_libm_version): Likewise. (LDOUBLE___clog10l_libm_version): Likewise. (LDOUBLE_fdiml_libm_version): Likewise. (LDOUBLE_fmaxl_libm_version): Likewise. (LDOUBLE_fminl_libm_version): Likewise. (LDOUBLE_ilogbl_libm_version): Likewise. (LDOUBLE_nanl_libm_version): Likewise. [!M_LIBM_NEED_COMPAT] (M_LIBM_NEED_COMPAT): Use FIRST_VERSION_libm_* macros. [!declare_mgen_libm_compat] (declare_mgen_libm_compat): Likewise. * Makerules [$(build-shared) = yes && !avoid-generated] (before-compile): Add $(common-objpfx)first-versions.h. [$(build-shared) = yes && !avoid-generated] ($(common-objpfx)first-versions.h): New target. ($(common-objpfx)sysd-versions): Depend on and change to rule for building $(common-objpfx)versions.stmp.
This commit is contained in:
44
ChangeLog
44
ChangeLog
@ -1,3 +1,47 @@
|
|||||||
|
2017-05-19 Joseph Myers <joseph@codesourcery.com>
|
||||||
|
|
||||||
|
* scripts/versions.awk: Generate first-versions.h.
|
||||||
|
* sysdeps/ieee754/ldbl-opt/math-type-macros-double.h: Include
|
||||||
|
<first-versions.h>.
|
||||||
|
(LDOUBLE_cabsl_libm_version): Remove macro.
|
||||||
|
(LDOUBLE_cargl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_cimagl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_conjl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_creall_libm_version): Likewise.
|
||||||
|
(LDOUBLE_cacosl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_cacoshl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_ccosl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_ccoshl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_casinl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_csinl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_casinhl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_csinhl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_catanl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_catanhl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_ctanl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_ctanhl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_cexpl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_clogl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_cprojl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_csqrtl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_cpowl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_clog10l_libm_version): Likewise.
|
||||||
|
(LDOUBLE___clog10l_libm_version): Likewise.
|
||||||
|
(LDOUBLE_fdiml_libm_version): Likewise.
|
||||||
|
(LDOUBLE_fmaxl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_fminl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_ilogbl_libm_version): Likewise.
|
||||||
|
(LDOUBLE_nanl_libm_version): Likewise.
|
||||||
|
[!M_LIBM_NEED_COMPAT] (M_LIBM_NEED_COMPAT): Use
|
||||||
|
FIRST_VERSION_libm_* macros.
|
||||||
|
[!declare_mgen_libm_compat] (declare_mgen_libm_compat): Likewise.
|
||||||
|
* Makerules [$(build-shared) = yes && !avoid-generated]
|
||||||
|
(before-compile): Add $(common-objpfx)first-versions.h.
|
||||||
|
[$(build-shared) = yes && !avoid-generated]
|
||||||
|
($(common-objpfx)first-versions.h): New target.
|
||||||
|
($(common-objpfx)sysd-versions): Depend on and change to rule for
|
||||||
|
building $(common-objpfx)versions.stmp.
|
||||||
|
|
||||||
2017-05-18 Adhemerval Zanella <adhemerval.zanella@linaro.org>
|
2017-05-18 Adhemerval Zanella <adhemerval.zanella@linaro.org>
|
||||||
|
|
||||||
* rt/Makefile (CFLAGS-mq_timedsend.c): New flag.
|
* rt/Makefile (CFLAGS-mq_timedsend.c): New flag.
|
||||||
|
13
Makerules
13
Makerules
@ -105,6 +105,11 @@ $(common-objpfx)%.latest: $(common-objpfx)abi-versions.h
|
|||||||
sed -n '/ VERSION_$*_/{s/^.*_\([A-Z0-9_]*\).*$$/\1/;h;};$${g;p;}' \
|
sed -n '/ VERSION_$*_/{s/^.*_\([A-Z0-9_]*\).*$$/\1/;h;};$${g;p;}' \
|
||||||
$(common-objpfx)abi-versions.h > $@T
|
$(common-objpfx)abi-versions.h > $@T
|
||||||
mv -f $@T $@
|
mv -f $@T $@
|
||||||
|
|
||||||
|
# first-versions.h provides macros used in various symbol versioning
|
||||||
|
# macro calls.
|
||||||
|
before-compile := $(common-objpfx)first-versions.h $(before-compile)
|
||||||
|
$(common-objpfx)first-versions.h: $(common-objpfx)versions.stmp
|
||||||
endif # avoid-generated
|
endif # avoid-generated
|
||||||
endif # $(build-shared) = yes
|
endif # $(build-shared) = yes
|
||||||
|
|
||||||
@ -458,7 +463,8 @@ $(common-objpfx)Versions.all: $(..)scripts/firstversions.awk \
|
|||||||
$(common-objpfx)Versions.v.i: $(wildcard $(subdirs:%=$(..)%/Versions)) \
|
$(common-objpfx)Versions.v.i: $(wildcard $(subdirs:%=$(..)%/Versions)) \
|
||||||
$(wildcard $(sysdirs:%=%/Versions)) \
|
$(wildcard $(sysdirs:%=%/Versions)) \
|
||||||
$(sysd-versions-force)
|
$(sysd-versions-force)
|
||||||
$(common-objpfx)sysd-versions: $(common-objpfx)Versions.all \
|
$(common-objpfx)sysd-versions: $(common-objpfx)versions.stmp
|
||||||
|
$(common-objpfx)versions.stmp: $(common-objpfx)Versions.all \
|
||||||
$(common-objpfx)Versions.v \
|
$(common-objpfx)Versions.v \
|
||||||
$(..)scripts/versions.awk
|
$(..)scripts/versions.awk
|
||||||
( echo 'sysd-versions-subdirs = $(subdirs) $(config-sysdirs)' ; \
|
( echo 'sysd-versions-subdirs = $(subdirs) $(config-sysdirs)' ; \
|
||||||
@ -466,8 +472,9 @@ $(common-objpfx)sysd-versions: $(common-objpfx)Versions.all \
|
|||||||
| LC_ALL=C $(AWK) -v buildroot=$(common-objpfx) -v defsfile=$< \
|
| LC_ALL=C $(AWK) -v buildroot=$(common-objpfx) -v defsfile=$< \
|
||||||
-v move_if_change='$(move-if-change)' \
|
-v move_if_change='$(move-if-change)' \
|
||||||
-f $(word 3,$^); \
|
-f $(word 3,$^); \
|
||||||
) > $@T
|
) > $(common-objpfx)sysd-versionsT
|
||||||
mv -f $@T $@
|
mv -f $(common-objpfx)sysd-versionsT $(common-objpfx)sysd-versions
|
||||||
|
touch $@
|
||||||
endif # avoid-generated
|
endif # avoid-generated
|
||||||
endif # $(build-shared) = yes
|
endif # $(build-shared) = yes
|
||||||
endif # sysd-sorted-done
|
endif # sysd-sorted-done
|
||||||
|
@ -101,6 +101,10 @@ END {
|
|||||||
|
|
||||||
oldlib = "";
|
oldlib = "";
|
||||||
oldver = "";
|
oldver = "";
|
||||||
|
real_first_ver_header = buildroot "first-versions.h"
|
||||||
|
first_ver_header = real_first_ver_header "T"
|
||||||
|
printf("#ifndef _FIRST_VERSIONS_H\n") > first_ver_header;
|
||||||
|
printf("#define _FIRST_VERSIONS_H\n") > first_ver_header;
|
||||||
printf("version-maps =");
|
printf("version-maps =");
|
||||||
while (getline < tmpfile) {
|
while (getline < tmpfile) {
|
||||||
if ($1 != oldlib) {
|
if ($1 != oldlib) {
|
||||||
@ -127,11 +131,24 @@ END {
|
|||||||
printf(" ") > outfile;
|
printf(" ") > outfile;
|
||||||
for (n = 3; n <= NF; ++n) {
|
for (n = 3; n <= NF; ++n) {
|
||||||
printf(" %s", $n) > outfile;
|
printf(" %s", $n) > outfile;
|
||||||
|
sym = $n;
|
||||||
|
sub(";", "", sym);
|
||||||
|
first_ver_macro = "FIRST_VERSION_" oldlib "_" sym;
|
||||||
|
if (!(first_ver_macro in first_ver_seen) \
|
||||||
|
&& oldver ~ "^GLIBC_[0-9]" \
|
||||||
|
&& sym ~ "^[A-Za-z0-9_]*$") {
|
||||||
|
ver_val = oldver;
|
||||||
|
gsub("\\.", "_", ver_val);
|
||||||
|
printf("#define %s %s\n", first_ver_macro, ver_val) > first_ver_header;
|
||||||
|
first_ver_seen[first_ver_macro] = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
printf("\n") > outfile;
|
printf("\n") > outfile;
|
||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n");
|
||||||
|
printf("#endif /* first-versions.h */\n") > first_ver_header;
|
||||||
closeversion(oldver, veryoldver);
|
closeversion(oldver, veryoldver);
|
||||||
close_and_move(outfile, real_outfile);
|
close_and_move(outfile, real_outfile);
|
||||||
|
close_and_move(first_ver_header, real_first_ver_header);
|
||||||
#system("rm -f " tmpfile);
|
#system("rm -f " tmpfile);
|
||||||
}
|
}
|
||||||
|
@ -19,48 +19,19 @@
|
|||||||
#ifndef _MATH_TYPE_MACROS_DOUBLE
|
#ifndef _MATH_TYPE_MACROS_DOUBLE
|
||||||
|
|
||||||
#include <math_ldbl_opt.h>
|
#include <math_ldbl_opt.h>
|
||||||
|
#include <first-versions.h>
|
||||||
#define LDOUBLE_cabsl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_cargl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_cimagl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_conjl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_creall_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_cacosl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_cacoshl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_ccosl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_ccoshl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_casinl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_csinl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_casinhl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_csinhl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_catanl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_catanhl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_ctanl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_ctanhl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_cexpl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_clogl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_cprojl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_csqrtl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_cpowl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_clog10l_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE___clog10l_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_fdiml_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_fmaxl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_fminl_libm_version GLIBC_2_1
|
|
||||||
#define LDOUBLE_ilogbl_libm_version GLIBC_2_0
|
|
||||||
#define LDOUBLE_nanl_libm_version GLIBC_2_1
|
|
||||||
|
|
||||||
/* Define compat symbols for long double on platforms
|
/* Define compat symbols for long double on platforms
|
||||||
where it was not always a distinct type. */
|
where it was not always a distinct type. */
|
||||||
#if !defined M_LIBM_NEED_COMPAT
|
#if !defined M_LIBM_NEED_COMPAT
|
||||||
# define M_LIBM_NEED_COMPAT(f) \
|
# define M_LIBM_NEED_COMPAT(f) \
|
||||||
LONG_DOUBLE_COMPAT (libm, LDOUBLE_ ## f ## l_libm_version)
|
LONG_DOUBLE_COMPAT (libm, FIRST_VERSION_libm_ ## f ## l)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined declare_mgen_libm_compat
|
#if !defined declare_mgen_libm_compat
|
||||||
# define declare_mgen_libm_compat(from, to) \
|
# define declare_mgen_libm_compat(from, to) \
|
||||||
compat_symbol (libm, from, to ## l, \
|
compat_symbol (libm, from, to ## l, \
|
||||||
LDOUBLE_ ## to ## l_libm_version);
|
FIRST_VERSION_libm_ ## to ## l);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include_next <math-type-macros-double.h>
|
#include_next <math-type-macros-double.h>
|
||||||
|
Reference in New Issue
Block a user