On Sat, Jan 22, 2022 at 7:04 PM Jakub Jelinek via Gcc-patches <gcc-patches@gcc.gnu.org> wrote: > > On Sat, Jan 22, 2022 at 01:16:38PM +0100, Jakub Jelinek via Gcc-patches wrote: > > Actually, I suspect we either need something like following patch, > > or need to change gcc/config/{linux,rs6000/linux{,64},alpha/linux}.h > > so that next to those OPTION_GLIBC etc. macros it also defines versions > > of those macros with opts argument. > > And here is a larger but perhaps cleaner patch that matches how e.g. > options.h defines TARGET_WHATEVER_P(opts) options and then TARGET_WHATEVER > too. > > Only compile tested on x86_64-linux so far. > > 2022-01-22 Jakub Jelinek <ja...@redhat.com> > > * config/linux.h (OPTION_GLIBC_P, OPTION_UCLIBC_P, > OPTION_BIONIC_P, OPTION_MUSL_P): Define. > (OPTION_GLIBC, OPTION_UCLIBC, OPTION_BIONIC, OPTION_MUSL): Redefine > using OPTION_*_P macros. > * config/alpha/linux.h (OPTION_GLIBC_P, OPTION_UCLIBC_P, > OPTION_BIONIC_P, OPTION_MUSL_P): Define. > (OPTION_GLIBC, OPTION_UCLIBC, OPTION_BIONIC, OPTION_MUSL): Redefine > using OPTION_*_P macros. > * config/rs6000/linux.h (OPTION_GLIBC_P, OPTION_UCLIBC_P, > OPTION_BIONIC_P, OPTION_MUSL_P): Define. > (OPTION_GLIBC, OPTION_UCLIBC, OPTION_BIONIC, OPTION_MUSL): Redefine > using OPTION_*_P macros. > * config/rs6000/linux64.h (OPTION_GLIBC_P, OPTION_UCLIBC_P, > OPTION_BIONIC_P, OPTION_MUSL_P): Define. > (OPTION_GLIBC, OPTION_UCLIBC, OPTION_BIONIC, OPTION_MUSL): Redefine > using OPTION_*_P macros. > * config/fuchsia.h (OPTION_MUSL_P): Redefine. > * config/glibc-stdint.h (OPTION_MUSL_P): Define if not defined. > * common/config/s390/s390-common.cc (s390_supports_split_stack): > Re-add > ATTRIBUTE_UNUSED to opts parameter. If OPTION_GLIBC_P is defined, use > OPTION_GLIBC_P (opts) as condition, otherwise assume if (false). > * common/config/i386/i386-common.cc (ix86_supports_split_stack): If > OPTION_GLIBC_P is defined use !OPTION_GLIBC_P (opts) as condition, > otherwise assume if (true).
I wonder why every target defines its own set of #defines. I'd expect that they include toplevel gcc/config/linux.h and inherit these defines from it. Uros. > > --- gcc/config/linux.h.jj 2022-01-18 11:58:59.160988086 +0100 > +++ gcc/config/linux.h 2022-01-22 18:42:25.476235564 +0100 > @@ -29,18 +29,23 @@ see the files COPYING3 and COPYING.RUNTI > > /* C libraries supported on Linux. */ > #ifdef SINGLE_LIBC > -#define OPTION_GLIBC (DEFAULT_LIBC == LIBC_GLIBC) > -#define OPTION_UCLIBC (DEFAULT_LIBC == LIBC_UCLIBC) > -#define OPTION_BIONIC (DEFAULT_LIBC == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (DEFAULT_LIBC == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) (DEFAULT_LIBC == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) (DEFAULT_LIBC == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) (DEFAULT_LIBC == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) (DEFAULT_LIBC == LIBC_MUSL) > #else > -#define OPTION_GLIBC (linux_libc == LIBC_GLIBC) > -#define OPTION_UCLIBC (linux_libc == LIBC_UCLIBC) > -#define OPTION_BIONIC (linux_libc == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (linux_libc == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) ((opts)->x_linux_libc == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) ((opts)->x_linux_libc == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) ((opts)->x_linux_libc == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) ((opts)->x_linux_libc == LIBC_MUSL) > #endif > +#define OPTION_GLIBC OPTION_GLIBC_P (&global_options) > +#define OPTION_UCLIBC OPTION_UCLIBC_P (&global_options) > +#define OPTION_BIONIC OPTION_BIONIC_P (&global_options) > +#undef OPTION_MUSL > +#define OPTION_MUSL OPTION_MUSL_P (&global_options) > > #define GNU_USER_TARGET_OS_CPP_BUILTINS() \ > do { \ > --- gcc/config/alpha/linux.h.jj 2022-01-11 23:11:21.692299963 +0100 > +++ gcc/config/alpha/linux.h 2022-01-22 18:43:59.739923743 +0100 > @@ -58,18 +58,23 @@ along with GCC; see the file COPYING3. > #define WCHAR_TYPE "int" > > #ifdef SINGLE_LIBC > -#define OPTION_GLIBC (DEFAULT_LIBC == LIBC_GLIBC) > -#define OPTION_UCLIBC (DEFAULT_LIBC == LIBC_UCLIBC) > -#define OPTION_BIONIC (DEFAULT_LIBC == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (DEFAULT_LIBC == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) (DEFAULT_LIBC == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) (DEFAULT_LIBC == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) (DEFAULT_LIBC == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) (DEFAULT_LIBC == LIBC_MUSL) > #else > -#define OPTION_GLIBC (linux_libc == LIBC_GLIBC) > -#define OPTION_UCLIBC (linux_libc == LIBC_UCLIBC) > -#define OPTION_BIONIC (linux_libc == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (linux_libc == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) ((opts)->x_linux_libc == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) ((opts)->x_linux_libc == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) ((opts)->x_linux_libc == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) ((opts)->x_linux_libc == LIBC_MUSL) > #endif > +#define OPTION_GLIBC OPTION_GLIBC_P (&global_options) > +#define OPTION_UCLIBC OPTION_UCLIBC_P (&global_options) > +#define OPTION_BIONIC OPTION_BIONIC_P (&global_options) > +#undef OPTION_MUSL > +#define OPTION_MUSL OPTION_MUSL_P (&global_options) > > /* Determine what functions are present at the runtime; > this includes full c99 runtime and sincos. */ > --- gcc/config/rs6000/linux.h.jj 2022-01-11 23:11:21.939296492 +0100 > +++ gcc/config/rs6000/linux.h 2022-01-22 18:42:59.834757410 +0100 > @@ -27,18 +27,23 @@ > #define NO_PROFILE_COUNTERS 1 > > #ifdef SINGLE_LIBC > -#define OPTION_GLIBC (DEFAULT_LIBC == LIBC_GLIBC) > -#define OPTION_UCLIBC (DEFAULT_LIBC == LIBC_UCLIBC) > -#define OPTION_BIONIC (DEFAULT_LIBC == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (DEFAULT_LIBC == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) (DEFAULT_LIBC == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) (DEFAULT_LIBC == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) (DEFAULT_LIBC == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) (DEFAULT_LIBC == LIBC_MUSL) > #else > -#define OPTION_GLIBC (linux_libc == LIBC_GLIBC) > -#define OPTION_UCLIBC (linux_libc == LIBC_UCLIBC) > -#define OPTION_BIONIC (linux_libc == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (linux_libc == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) ((opts)->x_linux_libc == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) ((opts)->x_linux_libc == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) ((opts)->x_linux_libc == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) ((opts)->x_linux_libc == LIBC_MUSL) > #endif > +#define OPTION_GLIBC OPTION_GLIBC_P (&global_options) > +#define OPTION_UCLIBC OPTION_UCLIBC_P (&global_options) > +#define OPTION_BIONIC OPTION_BIONIC_P (&global_options) > +#undef OPTION_MUSL > +#define OPTION_MUSL OPTION_MUSL_P (&global_options) > > /* Determine what functions are present at the runtime; > this includes full c99 runtime and sincos. */ > --- gcc/config/rs6000/linux64.h.jj 2022-01-11 23:11:21.939296492 +0100 > +++ gcc/config/rs6000/linux64.h 2022-01-22 18:43:37.830228647 +0100 > @@ -265,18 +265,23 @@ extern int dot_symbols; > #define OS_MISSING_POWERPC64 !TARGET_64BIT > > #ifdef SINGLE_LIBC > -#define OPTION_GLIBC (DEFAULT_LIBC == LIBC_GLIBC) > -#define OPTION_UCLIBC (DEFAULT_LIBC == LIBC_UCLIBC) > -#define OPTION_BIONIC (DEFAULT_LIBC == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (DEFAULT_LIBC == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) (DEFAULT_LIBC == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) (DEFAULT_LIBC == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) (DEFAULT_LIBC == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) (DEFAULT_LIBC == LIBC_MUSL) > #else > -#define OPTION_GLIBC (linux_libc == LIBC_GLIBC) > -#define OPTION_UCLIBC (linux_libc == LIBC_UCLIBC) > -#define OPTION_BIONIC (linux_libc == LIBC_BIONIC) > -#undef OPTION_MUSL > -#define OPTION_MUSL (linux_libc == LIBC_MUSL) > +#define OPTION_GLIBC_P(opts) ((opts)->x_linux_libc == LIBC_GLIBC) > +#define OPTION_UCLIBC_P(opts) ((opts)->x_linux_libc == LIBC_UCLIBC) > +#define OPTION_BIONIC_P(opts) ((opts)->x_linux_libc == LIBC_BIONIC) > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) ((opts)->x_linux_libc == LIBC_MUSL) > #endif > +#define OPTION_GLIBC OPTION_GLIBC_P (&global_options) > +#define OPTION_UCLIBC OPTION_UCLIBC_P (&global_options) > +#define OPTION_BIONIC OPTION_BIONIC_P (&global_options) > +#undef OPTION_MUSL > +#define OPTION_MUSL OPTION_MUSL_P (&global_options) > > /* Determine what functions are present at the runtime; > this includes full c99 runtime and sincos. */ > --- gcc/config/fuchsia.h.jj 2022-01-11 23:11:21.750299147 +0100 > +++ gcc/config/fuchsia.h 2022-01-22 18:49:53.927996890 +0100 > @@ -52,6 +52,8 @@ along with GCC; see the file COPYING3. > /* We are using MUSL as our libc. */ > #undef OPTION_MUSL > #define OPTION_MUSL 1 > +#undef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) 1 > > #ifndef TARGET_SUB_OS_CPP_BUILTINS > #define TARGET_SUB_OS_CPP_BUILTINS() > --- gcc/config/glibc-stdint.h.jj 2022-01-11 23:11:21.753299105 +0100 > +++ gcc/config/glibc-stdint.h 2022-01-22 18:49:53.928996876 +0100 > @@ -27,6 +27,9 @@ see the files COPYING3 and COPYING.RUNTI > #ifndef OPTION_MUSL > #define OPTION_MUSL 0 > #endif > +#ifndef OPTION_MUSL_P > +#define OPTION_MUSL_P(opts) 0 > +#endif > > #define SIG_ATOMIC_TYPE "int" > > --- gcc/common/config/s390/s390-common.cc.jj 2022-01-22 18:37:18.701504795 > +0100 > +++ gcc/common/config/s390/s390-common.cc 2022-01-22 18:39:09.820958400 > +0100 > @@ -121,10 +121,12 @@ s390_handle_option (struct gcc_options * > > static bool > s390_supports_split_stack (bool report, > - struct gcc_options *opts) > + struct gcc_options *opts ATTRIBUTE_UNUSED) > { > - if (opts->x_linux_libc == LIBC_GLIBC) > +#ifdef OPTION_GLIBC_P > + if (OPTION_GLIBC_P (opts)) > return true; > +#endif > > if (report) > error ("%<-fsplit-stack%> currently only supported on GNU/Linux"); > --- gcc/common/config/i386/i386-common.cc.jj 2022-01-22 18:37:18.700504809 > +0100 > +++ gcc/common/config/i386/i386-common.cc 2022-01-22 18:39:09.821958386 > +0100 > @@ -1717,8 +1717,8 @@ static bool > ix86_supports_split_stack (bool report, > struct gcc_options *opts ATTRIBUTE_UNUSED) > { > -#ifdef TARGET_THREAD_SPLIT_STACK_OFFSET > - if (opts->x_linux_libc != LIBC_GLIBC) > +#if defined(TARGET_THREAD_SPLIT_STACK_OFFSET) && defined(OPTION_GLIBC_P) > + if (!OPTION_GLIBC_P (opts)) > #endif > { > if (report) > > > Jakub >