On Tue, Aug 16, 2022 at 11:17 PM Iain Buclaw via Gcc-patches <gcc-patches@gcc.gnu.org> wrote: > > Hi, > > Because targetdm contains hooks pertaining to both the target platform > and cpu, it tries to pull in both platform and cpu headers via tm_d.h in > the source file where TARGETDM_INITIALIZER is used. > > Since 12.0, this has caused problems when there is no platform (*-elf), > resulting in default-d.cc failing to build due to triggering a > PREFERRED_DEBUGGING_TYPE #error. > > This patch removes the CPU-specific hooks from targetdm, documenting > them instead as target macros. Also removing the generation of tm_d.h > as its role is redundant. > > I also notice that Rust maintainers initially copied what I did in > devel/rust/master, but ended up reverting back to using macros to get at > target OS and CPU information as well, possibly because they ran into > the same problems as reported in PR105659. > > I'm not sure whether calling these hooks via function-like macros is > really desirable, I do recall early on during the review process of the > D front-end that putting target-specific language features behind a > targetdm hook was the preferred/encouraged way to expose these things. > > One alternative perhaps would be to break out CPU-specific hooks in > targetdm into a separate targetdm_cpu hook vector. This would mean > there would be no need to include tm_p.h anywhere in D-specific target > sources (only tm.h where needed), and all D-specific prototypes in > $cpu_type-protos.h can be removed. Though tm_d.h would still be > redundant, so either way it gets the chop. > > OK? Thoughts? I don't expect this to go in for 12.2, but backporting > some time before 12.3 would be nice.
I was hoping Joseph would chime in here - I recollect debugging this kind of thing and a thread about this a while back but unfortunately I do not remember the details here (IIRC some things get included where they better should not be). This is all D specific changes so I'd say OK for trunk unless Joseph has any comments. Please wait a while before backporting so we can see if it breaks any configuration. Thanks, Richard. > Bootstrapped and regression tested on x86_64-linux-gnu, and checked that > it indeed fixes the referenced PR by building an aarch64-rtems cross. > > Regards, > Iain. > > --- > PR d/105659 > > gcc/ChangeLog: > > * Makefile.in (tm_d_file_list): Remove. > (tm_d_include_list): Remove. > (TM_D_H): Remove. > (tm_d.h): Remove. > (cs-tm_d.h): Remove. > (generated_files): Remove TM_D_H. > * config.gcc (tm_d_file): Remove. > * config/darwin-d.cc: Include memmodel.h and tm_p.h instead of tm_d.h. > * config/default-d.cc: Remove includes of memmodel.h and tm_d.h. > * config/dragonfly-d.cc: Include tm_p.h instead of tm_d.h. > * configure: Regenerate. > * configure.ac (tm_d_file): Remove. > (tm_d_file_list): Remove substitution. > (tm_d_include_list): Remove substitution. > * doc/tm.texi: Regenerate. > * doc/tm.texi.in (TARGET_D_CPU_VERSIONS): Document hook as being a > function-like macro. > (TARGET_D_REGISTER_CPU_TARGET_INFO): Likewise. > > gcc/d/ChangeLog: > > * d-builtins.cc: Include memmodel.h and tm_p.h. > (d_init_versions): Call TARGET_D_CPU_VERSIONS via macro. > * d-target.cc (Target::_init): Call TARGET_D_REGISTER_CPU_TARGET_INFO > via macro. > * d-target.def (d_cpu_versions): Remove hook. > (d_register_cpu_target_info): Remove hook. > --- > gcc/Makefile.in | 11 +---------- > gcc/config.gcc | 7 ------- > gcc/config/darwin-d.cc | 3 ++- > gcc/config/default-d.cc | 9 +++++++-- > gcc/config/dragonfly-d.cc | 2 +- > gcc/configure | 32 ++++++++------------------------ > gcc/configure.ac | 18 ------------------ > gcc/d/d-builtins.cc | 6 +++++- > gcc/d/d-target.cc | 4 +++- > gcc/d/d-target.def | 22 ---------------------- > gcc/doc/tm.texi | 22 ++++++++++++---------- > gcc/doc/tm.texi.in | 18 ++++++++++++++++-- > 12 files changed, 55 insertions(+), 99 deletions(-) > > diff --git a/gcc/Makefile.in b/gcc/Makefile.in > index 203f0a15187..12d9b5a3be4 100644 > --- a/gcc/Makefile.in > +++ b/gcc/Makefile.in > @@ -571,8 +571,6 @@ tm_include_list=@tm_include_list@ > tm_defines=@tm_defines@ > tm_p_file_list=@tm_p_file_list@ > tm_p_include_list=@tm_p_include_list@ > -tm_d_file_list=@tm_d_file_list@ > -tm_d_include_list=@tm_d_include_list@ > build_xm_file_list=@build_xm_file_list@ > build_xm_include_list=@build_xm_include_list@ > build_xm_defines=@build_xm_defines@ > @@ -865,7 +863,6 @@ BCONFIG_H = bconfig.h $(build_xm_file_list) > CONFIG_H = config.h $(host_xm_file_list) > TCONFIG_H = tconfig.h $(xm_file_list) > TM_P_H = tm_p.h $(tm_p_file_list) > -TM_D_H = tm_d.h $(tm_d_file_list) > GTM_H = tm.h $(tm_file_list) insn-constants.h > TM_H = $(GTM_H) insn-flags.h $(OPTIONS_H) > > @@ -1937,7 +1934,6 @@ bconfig.h: cs-bconfig.h ; @true > tconfig.h: cs-tconfig.h ; @true > tm.h: cs-tm.h ; @true > tm_p.h: cs-tm_p.h ; @true > -tm_d.h: cs-tm_d.h ; @true > > cs-config.h: Makefile > TARGET_CPU_DEFAULT="" \ > @@ -1964,11 +1960,6 @@ cs-tm_p.h: Makefile > HEADERS="$(tm_p_include_list)" DEFINES="" \ > $(SHELL) $(srcdir)/mkconfig.sh tm_p.h > > -cs-tm_d.h: Makefile > - TARGET_CPU_DEFAULT="" \ > - HEADERS="$(tm_d_include_list)" DEFINES="" \ > - $(SHELL) $(srcdir)/mkconfig.sh tm_d.h > - > # Don't automatically run autoconf, since configure.ac might be accidentally > # newer than configure. Also, this writes into the source directory which > # might be on a read-only file system. If configured for maintainer mode > @@ -2783,7 +2774,7 @@ s-gtype: $(EXTRA_GTYPE_DEPS) > build/gengtype$(build_exeext) \ > -r gtype.state > $(STAMP) s-gtype > > -generated_files = config.h tm.h $(TM_P_H) $(TM_D_H) $(TM_H) multilib.h \ > +generated_files = config.h tm.h $(TM_P_H) $(TM_H) multilib.h \ > $(simple_generated_h) specs.h \ > tree-check.h genrtl.h insn-modes.h insn-modes-inline.h \ > tm-preds.h tm-constrs.h \ > diff --git a/gcc/config.gcc b/gcc/config.gcc > index 4e3b15bb5e9..927d50b4355 100644 > --- a/gcc/config.gcc > +++ b/gcc/config.gcc > @@ -87,9 +87,6 @@ > # tm_p_file Location of file with declarations for functions > # in $out_file. > # > -# tm_d_file A list of headers with definitions of target hook > -# macros for the D compiler. > -# > # out_file The name of the machine description C support > # file, if different from "$cpu_type/$cpu_type.c". > # > @@ -559,11 +556,9 @@ xtensa*-*-*) > esac > > tm_file=${cpu_type}/${cpu_type}.h > -tm_d_file=${cpu_type}/${cpu_type}.h > if test -f ${srcdir}/config/${cpu_type}/${cpu_type}-protos.h > then > tm_p_file=${cpu_type}/${cpu_type}-protos.h > - tm_d_file="${tm_d_file} ${cpu_type}/${cpu_type}-protos.h" > fi > > extra_modes= > @@ -669,7 +664,6 @@ case ${target} in > *-*-darwin*) > tmake_file="t-darwin " > tm_file="${tm_file} darwin.h" > - tm_d_file="${tm_d_file} tm-dwarf2.h" > darwin_os=`echo ${target} | sed 's/.*darwin\([0-9.]*\).*$/\1/'` > darwin_maj=`expr "$darwin_os" : '\([0-9]*\).*'` > macos_min=`expr "$darwin_os" : '[0-9]*\.\([0-9]*\).*'` > @@ -3524,7 +3518,6 @@ xstormy16-*-elf) > # For historical reasons, the target files omit the 'x'. > tm_file="dbxelf.h elfos.h newlib-stdint.h stormy16/stormy16.h" > tm_p_file=stormy16/stormy16-protos.h > - tm_d_file="elfos.h stormy16/stormy16.h" > md_file=stormy16/stormy16.md > out_file=stormy16/stormy16.cc > extra_options=stormy16/stormy16.opt > diff --git a/gcc/config/darwin-d.cc b/gcc/config/darwin-d.cc > index e983883dba6..e88ddc189c3 100644 > --- a/gcc/config/darwin-d.cc > +++ b/gcc/config/darwin-d.cc > @@ -18,9 +18,10 @@ along with GCC; see the file COPYING3. If not see > #include "config.h" > #include "system.h" > #include "coretypes.h" > -#include "tm_d.h" > #include "d/d-target.h" > #include "d/d-target-def.h" > +#include "memmodel.h" > +#include "tm_p.h" > > /* Implement TARGET_D_OS_VERSIONS for Darwin targets. */ > > diff --git a/gcc/config/default-d.cc b/gcc/config/default-d.cc > index 2d7abfcba96..6674373793c 100644 > --- a/gcc/config/default-d.cc > +++ b/gcc/config/default-d.cc > @@ -18,9 +18,14 @@ along with GCC; see the file COPYING3. If not see > #include "config.h" > #include "system.h" > #include "coretypes.h" > -#include "memmodel.h" > -#include "tm_d.h" > #include "d/d-target.h" > #include "d/d-target-def.h" > > +/* Do not include tm.h or tm_p.h here; if it is useful for a target to > + define some macros for the initializer in a header without defining > + targetcm itself (for example, because of interactions with some > + hooks depending on the target OS and others on the target > + architecture), create a separate tm_d.h for only the relevant > + definitions. */ > + > struct gcc_targetdm targetdm = TARGETDM_INITIALIZER; > diff --git a/gcc/config/dragonfly-d.cc b/gcc/config/dragonfly-d.cc > index d431638f7da..2ee35c42e99 100644 > --- a/gcc/config/dragonfly-d.cc > +++ b/gcc/config/dragonfly-d.cc > @@ -18,9 +18,9 @@ along with GCC; see the file COPYING3. If not see > #include "config.h" > #include "system.h" > #include "coretypes.h" > -#include "tm_d.h" > #include "d/d-target.h" > #include "d/d-target-def.h" > +#include "tm_p.h" > > /* Implement TARGET_D_OS_VERSIONS for DragonFly targets. */ > > diff --git a/gcc/configure b/gcc/configure > index 05efa5b01ef..7d0445178bb 100755 > --- a/gcc/configure > +++ b/gcc/configure > @@ -652,8 +652,6 @@ use_gcc_stdint > xm_defines > xm_include_list > xm_file_list > -tm_d_include_list > -tm_d_file_list > tm_p_include_list > tm_p_file_list > tm_defines > @@ -5226,12 +5224,16 @@ else > GNATMAKE="$ac_cv_prog_GNATMAKE" > fi > > -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether compiler driver > understands Ada" >&5 > -$as_echo_n "checking whether compiler driver understands Ada... " >&6; } > +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether compiler driver > understands Ada and is recent enough" >&5 > +$as_echo_n "checking whether compiler driver understands Ada and is recent > enough... " >&6; } > if ${acx_cv_cc_gcc_supports_ada+:} false; then : > $as_echo_n "(cached) " >&6 > else > cat >conftest.adb <<EOF > +pragma Warnings (Off); > +with System.CRTL; > +pragma Warnings (On); > +use type System.CRTL.int64; > procedure conftest is begin null; end conftest; > EOF > acx_cv_cc_gcc_supports_ada=no > @@ -13009,7 +13011,6 @@ fi > > tm_file="${tm_file} defaults.h" > tm_p_file="${tm_p_file} tm-preds.h" > -tm_d_file="${tm_d_file} defaults.h" > host_xm_file="auto-host.h ansidecl.h ${host_xm_file}" > build_xm_file="${build_auto} ansidecl.h ${build_xm_file}" > # We don't want ansidecl.h in target files, write code there in ISO/GNU C. > @@ -13403,21 +13404,6 @@ for f in $tm_p_file; do > esac > done > > -tm_d_file_list= > -tm_d_include_list="options.h insn-constants.h" > -for f in $tm_d_file; do > - case $f in > - defaults.h ) > - tm_d_file_list="${tm_d_file_list} \$(srcdir)/$f" > - tm_d_include_list="${tm_d_include_list} $f" > - ;; > - * ) > - tm_d_file_list="${tm_d_file_list} \$(srcdir)/config/$f" > - tm_d_include_list="${tm_d_include_list} config/$f" > - ;; > - esac > -done > - > xm_file_list= > xm_include_list= > for f in $xm_file; do > @@ -19674,7 +19660,7 @@ else > lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 > lt_status=$lt_dlunknown > cat > conftest.$ac_ext <<_LT_EOF > -#line 19677 "configure" > +#line 19663 "configure" > #include "confdefs.h" > > #if HAVE_DLFCN_H > @@ -19780,7 +19766,7 @@ else > lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 > lt_status=$lt_dlunknown > cat > conftest.$ac_ext <<_LT_EOF > -#line 19783 "configure" > +#line 19769 "configure" > #include "confdefs.h" > > #if HAVE_DLFCN_H > @@ -31731,8 +31717,6 @@ fi > > > > - > - > > > > diff --git a/gcc/configure.ac b/gcc/configure.ac > index f70b6c24fda..a9006885663 100644 > --- a/gcc/configure.ac > +++ b/gcc/configure.ac > @@ -2113,7 +2113,6 @@ AC_SUBST(HAVE_AUTO_BUILD) > > tm_file="${tm_file} defaults.h" > tm_p_file="${tm_p_file} tm-preds.h" > -tm_d_file="${tm_d_file} defaults.h" > host_xm_file="auto-host.h ansidecl.h ${host_xm_file}" > build_xm_file="${build_auto} ansidecl.h ${build_xm_file}" > # We don't want ansidecl.h in target files, write code there in ISO/GNU C. > @@ -2356,21 +2355,6 @@ for f in $tm_p_file; do > esac > done > > -tm_d_file_list= > -tm_d_include_list="options.h insn-constants.h" > -for f in $tm_d_file; do > - case $f in > - defaults.h ) > - tm_d_file_list="${tm_d_file_list} \$(srcdir)/$f" > - tm_d_include_list="${tm_d_include_list} $f" > - ;; > - * ) > - tm_d_file_list="${tm_d_file_list} \$(srcdir)/config/$f" > - tm_d_include_list="${tm_d_include_list} config/$f" > - ;; > - esac > -done > - > xm_file_list= > xm_include_list= > for f in $xm_file; do > @@ -7361,8 +7345,6 @@ AC_SUBST(tm_include_list) > AC_SUBST(tm_defines) > AC_SUBST(tm_p_file_list) > AC_SUBST(tm_p_include_list) > -AC_SUBST(tm_d_file_list) > -AC_SUBST(tm_d_include_list) > AC_SUBST(xm_file_list) > AC_SUBST(xm_include_list) > AC_SUBST(xm_defines) > diff --git a/gcc/d/d-builtins.cc b/gcc/d/d-builtins.cc > index c2ef0c836e1..a5491316599 100644 > --- a/gcc/d/d-builtins.cc > +++ b/gcc/d/d-builtins.cc > @@ -34,6 +34,8 @@ along with GCC; see the file COPYING3. If not see > #include "diagnostic.h" > #include "langhooks.h" > #include "target.h" > +#include "memmodel.h" > +#include "tm_p.h" > #include "common/common-target.h" > #include "stringpool.h" > #include "stor-layout.h" > @@ -508,7 +510,9 @@ d_init_versions (void) > VersionCondition::addPredefinedGlobalIdent ("all"); > > /* Emit all target-specific version identifiers. */ > - targetdm.d_cpu_versions (); > +#ifdef TARGET_D_CPU_VERSIONS > + TARGET_D_CPU_VERSIONS (); > +#endif > targetdm.d_os_versions (); > > VersionCondition::addPredefinedGlobalIdent ("CppRuntime_Gcc"); > diff --git a/gcc/d/d-target.cc b/gcc/d/d-target.cc > index d4350e593e4..7632a0af37b 100644 > --- a/gcc/d/d-target.cc > +++ b/gcc/d/d-target.cc > @@ -200,7 +200,9 @@ Target::_init (const Param &) > > /* Initialize target info tables, the keys required by the language are > added > last, so that the OS and CPU handlers can override. */ > - targetdm.d_register_cpu_target_info (); > +#ifdef TARGET_D_REGISTER_CPU_TARGET_INFO > + TARGET_D_REGISTER_CPU_TARGET_INFO (); > +#endif > targetdm.d_register_os_target_info (); > d_add_target_info_handlers (d_language_target_info); > } > diff --git a/gcc/d/d-target.def b/gcc/d/d-target.def > index 7805942b91e..10b0fe8171a 100644 > --- a/gcc/d/d-target.def > +++ b/gcc/d/d-target.def > @@ -28,16 +28,6 @@ HOOK_VECTOR (TARGETDM_INITIALIZER, gcc_targetdm) > #undef HOOK_PREFIX > #define HOOK_PREFIX "TARGET_" > > -/* Environmental version identifiers relating to the target CPU. */ > -DEFHOOK > -(d_cpu_versions, > - "Declare all environmental version identifiers relating to the target CPU\n\ > -using the function @code{builtin_version}, which takes a string > representing\n\ > -the name of the version. Version identifiers predefined by this hook > apply\n\ > -to all modules that are being compiled and imported.", > - void, (void), > - hook_void_void) > - > /* Environmental version identifiers relating to the target OS. */ > DEFHOOK > (d_os_versions, > @@ -46,18 +36,6 @@ relating to the target operating system.", > void, (void), > hook_void_void) > > -/* getTargetInfo keys relating to the target CPU. */ > -DEFHOOK > -(d_register_cpu_target_info, > - "Register all target information keys relating to the target CPU using > the\n\ > -function @code{d_add_target_info_handlers}, which takes a\n\ > -@samp{struct d_target_info_spec} (defined in @file{d/d-target.h}). The > keys\n\ > -added by this hook are made available at compile time by the\n\ > -@code{__traits(getTargetInfo)} extension, the result is an expression\n\ > -describing the requested target information.", > - void, (void), > - hook_void_void) > - > /* getTargetInfo keys relating to the target OS. */ > DEFHOOK > (d_register_os_target_info, > diff --git a/gcc/doc/tm.texi b/gcc/doc/tm.texi > index 92bda1a7e14..e2c4e98ed7c 100644 > --- a/gcc/doc/tm.texi > +++ b/gcc/doc/tm.texi > @@ -11005,26 +11005,28 @@ Return target-specific mangling context of > @var{decl} or @code{NULL_TREE}. > @section D ABI parameters > @cindex parameters, d abi > > -@deftypefn {D Target Hook} void TARGET_D_CPU_VERSIONS (void) > -Declare all environmental version identifiers relating to the target CPU > -using the function @code{builtin_version}, which takes a string representing > -the name of the version. Version identifiers predefined by this hook apply > -to all modules that are being compiled and imported. > -@end deftypefn > +@defmac TARGET_D_CPU_VERSIONS () > +This function-like macro expands to a block of code that declares all > +environmental version identifiers relating to the target CPU using the > function > +@code{builtin_version}, which takes a string representing the name of the > +version. Version identifiers predefined by this hook apply to all modules > that > +are being compiled and imported. > +@end defmac > > @deftypefn {D Target Hook} void TARGET_D_OS_VERSIONS (void) > Similarly to @code{TARGET_D_CPU_VERSIONS}, but is used for versions > relating to the target operating system. > @end deftypefn > > -@deftypefn {D Target Hook} void TARGET_D_REGISTER_CPU_TARGET_INFO (void) > -Register all target information keys relating to the target CPU using the > -function @code{d_add_target_info_handlers}, which takes a > +@defmac TARGET_D_REGISTER_CPU_TARGET_INFO () > +This function-like macro expands to a block of code that registers all target > +information keys relating to the target CPU using the function > +@code{d_add_target_info_handlers}, which takes a > @samp{struct d_target_info_spec} (defined in @file{d/d-target.h}). The keys > added by this hook are made available at compile time by the > @code{__traits(getTargetInfo)} extension, the result is an expression > describing the requested target information. > -@end deftypefn > +@end defmac > > @deftypefn {D Target Hook} void TARGET_D_REGISTER_OS_TARGET_INFO (void) > Same as @code{TARGET_D_CPU_TARGET_INFO}, but is used for keys relating to > diff --git a/gcc/doc/tm.texi.in b/gcc/doc/tm.texi.in > index 112462310b1..69a4188c4b2 100644 > --- a/gcc/doc/tm.texi.in > +++ b/gcc/doc/tm.texi.in > @@ -7309,11 +7309,25 @@ floating-point support; they are not included in this > mechanism. > @section D ABI parameters > @cindex parameters, d abi > > -@hook TARGET_D_CPU_VERSIONS > +@defmac TARGET_D_CPU_VERSIONS () > +This function-like macro expands to a block of code that declares all > +environmental version identifiers relating to the target CPU using the > function > +@code{builtin_version}, which takes a string representing the name of the > +version. Version identifiers predefined by this hook apply to all modules > that > +are being compiled and imported. > +@end defmac > > @hook TARGET_D_OS_VERSIONS > > -@hook TARGET_D_REGISTER_CPU_TARGET_INFO > +@defmac TARGET_D_REGISTER_CPU_TARGET_INFO () > +This function-like macro expands to a block of code that registers all target > +information keys relating to the target CPU using the function > +@code{d_add_target_info_handlers}, which takes a > +@samp{struct d_target_info_spec} (defined in @file{d/d-target.h}). The keys > +added by this hook are made available at compile time by the > +@code{__traits(getTargetInfo)} extension, the result is an expression > +describing the requested target information. > +@end defmac > > @hook TARGET_D_REGISTER_OS_TARGET_INFO > > -- > 2.34.1 >