On Mon, Mar 16, 2026 at 4:19 PM Jonathan Wakely <[email protected]> wrote:

> This ensures that the module init functions are present in libstdc++.so
> and libstdc++.a, so that users of the std and std.compat modules don't
> need to manually link to std.o and/or std.compat.o in addition to
> compiling the CMIs.
>
> This also adds a clean-local target to remove the generated interface
> units and manifest, and the gcm.cache directory for the CMIs.
>
> libstdc++-v3/ChangeLog:
>
>         PR libstdc++/124268
>         * config/abi/pre/gnu.ver: Export symbols.
>         * src/Makefile.am: Add libmodulesconvenience.la to libstdc++
>         link.
>         * src/Makefile.in: Regenerate.
>         * src/c++23/Makefile.am: Create libmodulesconvenience.la
>         and populate it with std.o and std.compat.o interface units.
>         Add clean-local target.
>         * src/c++23/Makefile.in: Regenerate.
> ---
>
> v2: renamed the new convenience library containing std.o and
> std.compat.o
>
LGTM.

>
>  libstdc++-v3/config/abi/pre/gnu.ver |  4 +++
>  libstdc++-v3/src/Makefile.am        |  6 ++--
>  libstdc++-v3/src/Makefile.in        |  6 ++--
>  libstdc++-v3/src/c++23/Makefile.am  | 25 +++++++++++--
>  libstdc++-v3/src/c++23/Makefile.in  | 56 +++++++++++++++++++++--------
>  5 files changed, 77 insertions(+), 20 deletions(-)
>
> diff --git a/libstdc++-v3/config/abi/pre/gnu.ver
> b/libstdc++-v3/config/abi/pre/gnu.ver
> index fb968e122d8a..323fff28c255 100644
> --- a/libstdc++-v3/config/abi/pre/gnu.ver
> +++ b/libstdc++-v3/config/abi/pre/gnu.ver
> @@ -2592,6 +2592,10 @@ GLIBCXX_3.4.35 {
>      _ZSt15__get_once_callv;
>  #endif
>
> +    # Module inititialization symbols for std and std.compat modules.
> +    _ZGIW3std;
> +    _ZGIW3stdW6compat;
> +
>  } GLIBCXX_3.4.34;
>
>  # Symbols in the support library (libsupc++) have their own tag.
> diff --git a/libstdc++-v3/src/Makefile.am b/libstdc++-v3/src/Makefile.am
> index 55a8c88a0e12..35a497a15886 100644
> --- a/libstdc++-v3/src/Makefile.am
> +++ b/libstdc++-v3/src/Makefile.am
> @@ -145,7 +145,8 @@ libstdc___la_LIBADD = \
>         $(top_builddir)/src/c++98/libc++98convenience.la \
>         $(top_builddir)/src/c++11/libc++11convenience.la \
>         $(top_builddir)/src/c++17/libc++17convenience.la \
> -       $(top_builddir)/src/c++20/libc++20convenience.la
> +       $(top_builddir)/src/c++20/libc++20convenience.la \
> +       $(top_builddir)/src/c++23/libmodulesconvenience.la
>
>  libstdc___la_DEPENDENCIES = \
>         ${version_dep} \
> @@ -153,7 +154,8 @@ libstdc___la_DEPENDENCIES = \
>         $(top_builddir)/src/c++98/libc++98convenience.la \
>         $(top_builddir)/src/c++11/libc++11convenience.la \
>         $(top_builddir)/src/c++17/libc++17convenience.la \
> -       $(top_builddir)/src/c++20/libc++20convenience.la
> +       $(top_builddir)/src/c++20/libc++20convenience.la \
> +       $(top_builddir)/src/c++23/libmodulesconvenience.la
>
>  if ENABLE_DARWIN_AT_RPATH
>  libstdc___darwin_rpath = -Wc,-nodefaultrpaths
> diff --git a/libstdc++-v3/src/Makefile.in b/libstdc++-v3/src/Makefile.in
> index f0ad019a71fd..811d0a5ce4a8 100644
> --- a/libstdc++-v3/src/Makefile.in
> +++ b/libstdc++-v3/src/Makefile.in
> @@ -555,7 +555,8 @@ libstdc___la_LIBADD = \
>         $(top_builddir)/src/c++98/libc++98convenience.la \
>         $(top_builddir)/src/c++11/libc++11convenience.la \
>         $(top_builddir)/src/c++17/libc++17convenience.la \
> -       $(top_builddir)/src/c++20/libc++20convenience.la
> +       $(top_builddir)/src/c++20/libc++20convenience.la \
> +       $(top_builddir)/src/c++23/libmodulesconvenience.la
>
>  libstdc___la_DEPENDENCIES = \
>         ${version_dep} \
> @@ -563,7 +564,8 @@ libstdc___la_DEPENDENCIES = \
>         $(top_builddir)/src/c++98/libc++98convenience.la \
>         $(top_builddir)/src/c++11/libc++11convenience.la \
>         $(top_builddir)/src/c++17/libc++17convenience.la \
> -       $(top_builddir)/src/c++20/libc++20convenience.la
> +       $(top_builddir)/src/c++20/libc++20convenience.la \
> +       $(top_builddir)/src/c++23/libmodulesconvenience.la
>
>  @ENABLE_DARWIN_AT_RPATH_TRUE@libstdc___darwin_rpath =  \
>  @ENABLE_DARWIN_AT_RPATH_TRUE@  -Wc,-nodefaultrpaths \
> diff --git a/libstdc++-v3/src/c++23/Makefile.am
> b/libstdc++-v3/src/c++23/Makefile.am
> index b031ec69576c..019241b884dd 100644
> --- a/libstdc++-v3/src/c++23/Makefile.am
> +++ b/libstdc++-v3/src/c++23/Makefile.am
> @@ -23,10 +23,13 @@
>  include $(top_srcdir)/fragment.am
>
>  # Convenience library for C++23 runtime.
> -noinst_LTLIBRARIES = libc++23convenience.la
> +# This libc++23convenience.la one isn't linked into libstdc++.la yet,
> +# so build an additional libmodulesconvenience.la which is linked in.
> +noinst_LTLIBRARIES = libc++23convenience.la libmodulesconvenience.la
>
> -# Module std support.  Not compiled for now, only installed.
> +# Module std support.
>  # Let's install the interface units in the bits subdirectory.
> +# We also compile them and include them in libmodulesconvenience.la
>  toolexeclib_DATA = libstdc++.modules.json
>  includebitsdir = $(gxx_include_dir)/bits
>  includebits_DATA = std.cc std.compat.cc
> @@ -59,6 +62,9 @@ stamp-modules-bits: $(includebits_DATA)
>
>  all-local: stamp-module-manifest stamp-modules-bits
>
> +clean-local:
> +       rm -rf stamp* libstdc++.modules.json std.cc std.compat.cc
> gcm.cache
> +
>  headers =
>
>  if ENABLE_EXTERN_TEMPLATE
> @@ -80,12 +86,27 @@ else
>  libc__23convenience_la_SOURCES =
>  endif
>
> +libmodulesconvenience_la_SOURCES = std.cc std.compat.cc
> +
>  # Use C++26 so that std::filebuf::native_handle() is available.
>  print.lo: print.cc
>         $(LTCXXCOMPILE) -std=gnu++26 -c $<
>  print.o: print.cc
>         $(CXXCOMPILE) -std=gnu++26 -c $<
>
> +MODULES_FLAGS = -isystem ${glibcxx_srcdir}/include/backward -fmodules \
> +       -Wno-unknown-pragmas
> +
> +# These go into libmodulesconvenience.la and are linked into libstdc++
> +std.lo: std.cc
> +       $(LTCXXCOMPILE) $(MODULES_FLAGS) -c $<
> +std.o: std.cc
> +       $(CXXCOMPILE) $(MODULES_FLAGS) -c $<
> +std.compat.lo: std.compat.cc std.lo
> +       $(LTCXXCOMPILE) $(MODULES_FLAGS) -c $<
> +std.compat.o: std.compat.cc std.o
> +       $(CXXCOMPILE) $(MODULES_FLAGS) -c $<
> +
>  # AM_CXXFLAGS needs to be in each subdirectory so that it can be
>  # modified in a per-library or per-sub-library way.  Need to manually
>  # set this option because CONFIG_CXXFLAGS has to be after
> diff --git a/libstdc++-v3/src/c++23/Makefile.in
> b/libstdc++-v3/src/c++23/Makefile.in
> index fd9110ab8ad2..ac3830f569f4 100644
> --- a/libstdc++-v3/src/c++23/Makefile.in
> +++ b/libstdc++-v3/src/c++23/Makefile.in
> @@ -133,6 +133,10 @@ AM_V_lt = $(am__v_lt_@AM_V@)
>  am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
>  am__v_lt_0 = --silent
>  am__v_lt_1 =
> +libmodulesconvenience_la_LIBADD =
> +am_libmodulesconvenience_la_OBJECTS = std.lo std.compat.lo
> +libmodulesconvenience_la_OBJECTS =  \
> +       $(am_libmodulesconvenience_la_OBJECTS)
>  AM_V_P = $(am__v_P_@AM_V@)
>  am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
>  am__v_P_0 = false
> @@ -159,7 +163,8 @@ AM_V_CXXLD = $(am__v_CXXLD_@AM_V@)
>  am__v_CXXLD_ = $(am__v_CXXLD_@AM_DEFAULT_V@)
>  am__v_CXXLD_0 = @echo "  CXXLD   " $@;
>  am__v_CXXLD_1 =
> -SOURCES = $(libc__23convenience_la_SOURCES)
> +SOURCES = $(libc__23convenience_la_SOURCES) \
> +       $(libmodulesconvenience_la_SOURCES)
>  am__can_run_installinfo = \
>    case $$AM_UPDATE_INFO_DIR in \
>      n|no|NO) false;; \
> @@ -457,10 +462,13 @@ WARN_CXXFLAGS = \
>  AM_CPPFLAGS = $(GLIBCXX_INCLUDES) $(CPPFLAGS)
>
>  # Convenience library for C++23 runtime.
> -noinst_LTLIBRARIES = libc++23convenience.la
> +# This libc++23convenience.la one isn't linked into libstdc++.la yet,
> +# so build an additional libmodulesconvenience.la which is linked in.
> +noinst_LTLIBRARIES = libc++23convenience.la libmodulesconvenience.la
>
> -# Module std support.  Not compiled for now, only installed.
> +# Module std support.
>  # Let's install the interface units in the bits subdirectory.
> +# We also compile them and include them in libmodulesconvenience.la
>  toolexeclib_DATA = libstdc++.modules.json
>  includebitsdir = $(gxx_include_dir)/bits
>  includebits_DATA = std.cc std.compat.cc
> @@ -473,6 +481,10 @@ headers =
>  sources = stacktrace.cc print.cc
>  @GLIBCXX_HOSTED_FALSE@libc__23convenience_la_SOURCES =
>  @GLIBCXX_HOSTED_TRUE@libc__23convenience_la_SOURCES = $(sources)
> $(inst_sources)
> +libmodulesconvenience_la_SOURCES = std.cc std.compat.cc
> +MODULES_FLAGS = -isystem ${glibcxx_srcdir}/include/backward -fmodules \
> +       -Wno-unknown-pragmas
> +
>
>  # AM_CXXFLAGS needs to be in each subdirectory so that it can be
>  # modified in a per-library or per-sub-library way.  Need to manually
> @@ -586,6 +598,9 @@ clean-noinstLTLIBRARIES:
>  libc++23convenience.la: $(libc__23convenience_la_OBJECTS)
> $(libc__23convenience_la_DEPENDENCIES)
> $(EXTRA_libc__23convenience_la_DEPENDENCIES)
>         $(AM_V_CXXLD)$(CXXLINK)  $(libc__23convenience_la_OBJECTS)
> $(libc__23convenience_la_LIBADD) $(LIBS)
>
> +libmodulesconvenience.la: $(libmodulesconvenience_la_OBJECTS)
> $(libmodulesconvenience_la_DEPENDENCIES)
> $(EXTRA_libmodulesconvenience_la_DEPENDENCIES)
> +       $(AM_V_CXXLD)$(CXXLINK)  $(libmodulesconvenience_la_OBJECTS)
> $(libmodulesconvenience_la_LIBADD) $(LIBS)
> +
>  mostlyclean-compile:
>         -rm -f *.$(OBJEXT)
>
> @@ -739,8 +754,8 @@ maintainer-clean-generic:
>         @echo "it deletes files that may require special tools to rebuild."
>  clean: clean-am
>
> -clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \
> -       mostlyclean-am
> +clean-am: clean-generic clean-libtool clean-local \
> +       clean-noinstLTLIBRARIES mostlyclean-am
>
>  distclean: distclean-am
>         -rm -f Makefile
> @@ -809,15 +824,15 @@ uninstall-am: uninstall-includebitsDATA
> uninstall-toolexeclibDATA
>  .MAKE: install-am install-strip
>
>  .PHONY: CTAGS GTAGS TAGS all all-am all-local check check-am clean \
> -       clean-generic clean-libtool clean-noinstLTLIBRARIES \
> -       cscopelist-am ctags ctags-am distclean distclean-compile \
> -       distclean-generic distclean-libtool distclean-tags dvi dvi-am \
> -       html html-am info info-am install install-am install-data \
> -       install-data-am install-dvi install-dvi-am install-exec \
> -       install-exec-am install-html install-html-am \
> -       install-includebitsDATA install-info install-info-am \
> -       install-man install-pdf install-pdf-am install-ps \
> -       install-ps-am install-strip install-toolexeclibDATA \
> +       clean-generic clean-libtool clean-local \
> +       clean-noinstLTLIBRARIES cscopelist-am ctags ctags-am distclean \
> +       distclean-compile distclean-generic distclean-libtool \
> +       distclean-tags dvi dvi-am html html-am info info-am install \
> +       install-am install-data install-data-am install-dvi \
> +       install-dvi-am install-exec install-exec-am install-html \
> +       install-html-am install-includebitsDATA install-info \
> +       install-info-am install-man install-pdf install-pdf-am \
> +       install-ps install-ps-am install-strip install-toolexeclibDATA \
>         installcheck installcheck-am installdirs maintainer-clean \
>         maintainer-clean-generic mostlyclean mostlyclean-compile \
>         mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
> @@ -855,6 +870,9 @@ stamp-modules-bits: $(includebits_DATA)
>
>  all-local: stamp-module-manifest stamp-modules-bits
>
> +clean-local:
> +       rm -rf stamp* libstdc++.modules.json std.cc std.compat.cc
> gcm.cache
> +
>  vpath % $(top_srcdir)/src/c++23
>
>  # Use C++26 so that std::filebuf::native_handle() is available.
> @@ -863,6 +881,16 @@ print.lo: print.cc
>  print.o: print.cc
>         $(CXXCOMPILE) -std=gnu++26 -c $<
>
> +# These go into libmodulesconvenience.la and are linked into libstdc++
> +std.lo: std.cc
> +       $(LTCXXCOMPILE) $(MODULES_FLAGS) -c $<
> +std.o: std.cc
> +       $(CXXCOMPILE) $(MODULES_FLAGS) -c $<
> +std.compat.lo: std.compat.cc std.lo
> +       $(LTCXXCOMPILE) $(MODULES_FLAGS) -c $<
> +std.compat.o: std.compat.cc std.o
> +       $(CXXCOMPILE) $(MODULES_FLAGS) -c $<
> +
>  # Tell versions [3.59,3.63) of GNU make to not export all variables.
>  # Otherwise a system limit (for SysV at least) may be exceeded.
>  .NOEXPORT:
> --
> 2.53.0
>
>

Reply via email to