On Wed, Sep 21, 2022 at 12:37 AM Richard Biener
<richard.guent...@gmail.com> wrote:
>
> On Tue, Sep 20, 2022 at 2:55 PM Martin Liška <mli...@suse.cz> wrote:
> >
> > On 7/1/22 09:20, Fangrui Song via Gcc-patches wrote:
> > > On 2022-07-01, Andrew Pinski wrote:
> > >> On Thu, Jun 30, 2022 at 11:58 PM Fangrui Song via Gcc-patches
> > >> <gcc-patches@gcc.gnu.org> wrote:
> > >>>
> > >>> From: Fangrui Song <i...@maskray.me>
> > >>>
> > >>> SHF_COMPRESSED style zlib has been supported since binutils 2.26
> > >>> and the legacy zlib-gnu option hasn't gain adoption.
> > >>> According to Debian Code Search (`gz=zlib-gnu`), no project uses
> > >>> -gz=zlib-gnu (valgrind has a configure to use -gz=zlib).
> > >>> Remove support for the legacy zlib-gnu and simplify configure.ac by
> > >>> removing zlib-gnu ld/as check.
> > >>
> > >> A couple of things, you are missing a changelog.
> > >
> > > Sorry.
> > >
> > >> Second, why remove something which is still working?
> >
> > Hi.
> >
> > I do support the option removal, while I would replace the removal with a 
> > warning
> > saying no compression will be used.
> >
> > >
> > > It's unused and its existence causes confusion: the paradox of choice.
> > > People may assume the support may be good but newer DWARF consumers may
> > > not support the legacy format.
> >
> > Agree, the compression format is legacy. I verified all openSUSE packages 
> > (15k)
> > and there's no project actively using it.
> >
> > >
> > > The other motivation is to clean up it a bit.  I foresee that someone
> > > will add --compress-debug-sections=zstd to binutils and configure.ac and
> > > gcc/gcc.cc would become more messy.
> >
> > The argument makes sense, it will be even bigger mess.
> >
> > @Richi: Is it something we can deprecate for GCC 13?
>
> What's the practical difference between zlib and zlib-gnu?  Can we just
> map zlib-gnu to zlib?  If it's all configure time what's the point in
> "deprecating" it?

zlib-gnu uses the legacy .zdebug section name with a "ZLIB" magic:
http://www.linker-aliens.org/blogs/ali/entry/elf_section_compression/
https://maskray.me/blog/2022-01-23-compressed-debug-sections has some
history about how the zlib-gabi replacement: ELFCOMPRESS_ZLIB .

FWIW I removed -gz=zlib-gnu from clang and .zdebug support from
various llvm-project tools.

I cannot really find uses of -gz=zlib-gnu in the wild. Users can
always fallback to -Wa, and -Wl, if their tools are so old that
ELFCOMPRESS_ZLIB is unsupported.

> Richard.
>
> >
> > Martin
> >
> > >
> > >> Third, why not just make gz=zlib-gnu as an alias to gz=zlib instead so
> > >> if someone used it before it will still work. we try not to remove
> > >> options; have them emit a warning and be ignored (or moved over to the
> > >> closed option).
> > >
> > > Changing the semantics of -gz=zlib-gnu would be even more confusing.
> > >
> > >> Thanks,
> > >> Andrew
> > >>
> > >>> ---
> > >>>  gcc/common.opt      |  3 ---
> > >>>  gcc/configure       | 33 ++++++---------------------------
> > >>>  gcc/configure.ac    | 29 ++++-------------------------
> > >>>  gcc/doc/invoke.texi | 11 +++++------
> > >>>  gcc/gcc.cc          | 22 ++--------------------
> > >>>  5 files changed, 17 insertions(+), 81 deletions(-)
> > >>>
> > >>> diff --git a/gcc/common.opt b/gcc/common.opt
> > >>> index e7a51e882ba..8754d93d545 100644
> > >>> --- a/gcc/common.opt
> > >>> +++ b/gcc/common.opt
> > >>> @@ -3424,9 +3424,6 @@ Enum(compressed_debug_sections) String(none) 
> > >>> Value(0)
> > >>>  EnumValue
> > >>>  Enum(compressed_debug_sections) String(zlib) Value(1)
> > >>>
> > >>> -EnumValue
> > >>> -Enum(compressed_debug_sections) String(zlib-gnu) Value(2)
> > >>> -
> > >>>  gz
> > >>>  Common Driver
> > >>>  Generate compressed debug sections.
> > >>> diff --git a/gcc/configure b/gcc/configure
> > >>> index 62872d132ea..ca87e875e9d 100755
> > >>> --- a/gcc/configure
> > >>> +++ b/gcc/configure
> > >>> @@ -19674,7 +19674,7 @@ else
> > >>>    lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
> > >>>    lt_status=$lt_dlunknown
> > >>>    cat > conftest.$ac_ext <<_LT_EOF
> > >>> -#line 19679 "configure"
> > >>> +#line 19677 "configure"
> > >>>  #include "confdefs.h"
> > >>>
> > >>>  #if HAVE_DLFCN_H
> > >>> @@ -19780,7 +19780,7 @@ else
> > >>>    lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
> > >>>    lt_status=$lt_dlunknown
> > >>>    cat > conftest.$ac_ext <<_LT_EOF
> > >>> -#line 19785 "configure"
> > >>> +#line 19783 "configure"
> > >>>  #include "confdefs.h"
> > >>>
> > >>>  #if HAVE_DLFCN_H
> > >>> @@ -29711,20 +29711,13 @@ else
> > >>>     if $gcc_cv_as --compress-debug-sections -o conftest.o conftest.s 
> > >>> 2>&1 | grep -i warning > /dev/null
> > >>>     then
> > >>>       gcc_cv_as_compress_debug=0
> > >>> -   # Since binutils 2.26, gas supports --compress-debug-sections=type,
> > >>> +   # Since binutils 2.26, gas supports --compress-debug-sections=zlib,
> > >>>     # defaulting to the ELF gABI format.
> > >>> -   elif $gcc_cv_as --compress-debug-sections=zlib-gnu -o conftest.o 
> > >>> conftest.s > /dev/null 2>&1
> > >>> +   elif $gcc_cv_as --compress-debug-sections=zlib -o conftest.o 
> > >>> conftest.s > /dev/null 2>&1
> > >>>     then
> > >>>       gcc_cv_as_compress_debug=2
> > >>>       gcc_cv_as_compress_debug_option="--compress-debug-sections"
> > >>>       gcc_cv_as_no_compress_debug_option="--nocompress-debug-sections"
> > >>> -   # Before binutils 2.26, gas only supported --compress-debug-options 
> > >>> and
> > >>> -   # emitted the traditional GNU format.
> > >>> -   elif $gcc_cv_as --compress-debug-sections -o conftest.o conftest.s 
> > >>> > /dev/null 2>&1
> > >>> -   then
> > >>> -     gcc_cv_as_compress_debug=1
> > >>> -     gcc_cv_as_compress_debug_option="--compress-debug-sections"
> > >>> -     gcc_cv_as_no_compress_debug_option="--nocompress-debug-sections"
> > >>>     else
> > >>>       gcc_cv_as_compress_debug=0
> > >>>     fi
> > >>> @@ -30238,42 +30231,28 @@ $as_echo "$gcc_cv_ld_eh_gc_sections_bug" >&6; 
> > >>> }
> > >>>
> > >>>  { $as_echo "$as_me:${as_lineno-$LINENO}: checking linker for 
> > >>> compressed debug sections" >&5
> > >>>  $as_echo_n "checking linker for compressed debug sections... " >&6; }
> > >>> -# gold/gld support compressed debug sections since binutils 2.19/2.21
> > >>> -# In binutils 2.26, gld gained support for the ELF gABI format.
> > >>> +# GNU ld/gold support --compressed-debug-sections=zlib since binutils 
> > >>> 2.26.
> > >>>  if test $in_tree_ld = yes ; then
> > >>>    gcc_cv_ld_compress_debug=0
> > >>>    if test $ld_is_mold = yes; then
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>> -  elif test "$gcc_cv_gld_major_version" -eq 2 -a 
> > >>> "$gcc_cv_gld_minor_version" -ge 19 -o "$gcc_cv_gld_major_version" -gt 2 
> > >>> \
> > >>> -     && test $in_tree_ld_is_elf = yes && test $ld_is_gold = yes; then
> > >>> -    gcc_cv_ld_compress_debug=2
> > >>> -    gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>>    elif test "$gcc_cv_gld_major_version" -eq 2 -a 
> > >>> "$gcc_cv_gld_minor_version" -ge 26 -o "$gcc_cv_gld_major_version" -gt 2 
> > >>> \
> > >>>       && test $in_tree_ld_is_elf = yes && test $ld_is_gold = no; then
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>> -  elif test "$gcc_cv_gld_major_version" -eq 2 -a 
> > >>> "$gcc_cv_gld_minor_version" -ge 21 -o "$gcc_cv_gld_major_version" -gt 2 
> > >>> \
> > >>> -     && test $in_tree_ld_is_elf = yes; then
> > >>> -    gcc_cv_ld_compress_debug=1
> > >>>    fi
> > >>>  elif echo "$ld_ver" | grep GNU > /dev/null; then
> > >>>    if test $ld_is_mold = yes; then
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>>    elif test "$ld_vers_major" -lt 2 \
> > >>> -     || test "$ld_vers_major" -eq 2 -a "$ld_vers_minor" -lt 21; then
> > >>> +     || test "$ld_vers_major" -eq 2 -a "$ld_vers_minor" -lt 26; then
> > >>>      gcc_cv_ld_compress_debug=0
> > >>> -  elif test "$ld_vers_major" -eq 2 -a "$ld_vers_minor" -lt 26; then
> > >>> -    gcc_cv_ld_compress_debug=1
> > >>>    else
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>>    fi
> > >>> -  if test $ld_is_gold = yes; then
> > >>> -    gcc_cv_ld_compress_debug=2
> > >>> -    gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>> -  fi
> > >>>  else
> > >>>    case "${target}" in
> > >>>      *-*-solaris2*)
> > >>> diff --git a/gcc/configure.ac b/gcc/configure.ac
> > >>> index 446747311a6..f40f75271c2 100644
> > >>> --- a/gcc/configure.ac
> > >>> +++ b/gcc/configure.ac
> > >>> @@ -5733,20 +5733,13 @@ gcc_GAS_CHECK_FEATURE([compressed debug 
> > >>> sections],
> > >>>     if $gcc_cv_as --compress-debug-sections -o conftest.o conftest.s 
> > >>> 2>&1 | grep -i warning > /dev/null
> > >>>     then
> > >>>       gcc_cv_as_compress_debug=0
> > >>> -   # Since binutils 2.26, gas supports --compress-debug-sections=type,
> > >>> +   # Since binutils 2.26, gas supports --compress-debug-sections=zlib,
> > >>>     # defaulting to the ELF gABI format.
> > >>> -   elif $gcc_cv_as --compress-debug-sections=zlib-gnu -o conftest.o 
> > >>> conftest.s > /dev/null 2>&1
> > >>> +   elif $gcc_cv_as --compress-debug-sections=zlib -o conftest.o 
> > >>> conftest.s > /dev/null 2>&1
> > >>>     then
> > >>>       gcc_cv_as_compress_debug=2
> > >>>       gcc_cv_as_compress_debug_option="--compress-debug-sections"
> > >>>       gcc_cv_as_no_compress_debug_option="--nocompress-debug-sections"
> > >>> -   # Before binutils 2.26, gas only supported --compress-debug-options 
> > >>> and
> > >>> -   # emitted the traditional GNU format.
> > >>> -   elif $gcc_cv_as --compress-debug-sections -o conftest.o conftest.s 
> > >>> > /dev/null 2>&1
> > >>> -   then
> > >>> -     gcc_cv_as_compress_debug=1
> > >>> -     gcc_cv_as_compress_debug_option="--compress-debug-sections"
> > >>> -     gcc_cv_as_no_compress_debug_option="--nocompress-debug-sections"
> > >>>     else
> > >>>       gcc_cv_as_compress_debug=0
> > >>>     fi])
> > >>> @@ -6131,42 +6124,28 @@ fi
> > >>>  AC_MSG_RESULT($gcc_cv_ld_eh_gc_sections_bug)
> > >>>
> > >>>  AC_MSG_CHECKING(linker for compressed debug sections)
> > >>> -# gold/gld support compressed debug sections since binutils 2.19/2.21
> > >>> -# In binutils 2.26, gld gained support for the ELF gABI format.
> > >>> +# GNU ld/gold support --compressed-debug-sections=zlib since binutils 
> > >>> 2.26.
> > >>>  if test $in_tree_ld = yes ; then
> > >>>    gcc_cv_ld_compress_debug=0
> > >>>    if test $ld_is_mold = yes; then
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>> -  elif test "$gcc_cv_gld_major_version" -eq 2 -a 
> > >>> "$gcc_cv_gld_minor_version" -ge 19 -o "$gcc_cv_gld_major_version" -gt 2 
> > >>> \
> > >>> -     && test $in_tree_ld_is_elf = yes && test $ld_is_gold = yes; then
> > >>> -    gcc_cv_ld_compress_debug=2
> > >>> -    gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>>    elif test "$gcc_cv_gld_major_version" -eq 2 -a 
> > >>> "$gcc_cv_gld_minor_version" -ge 26 -o "$gcc_cv_gld_major_version" -gt 2 
> > >>> \
> > >>>       && test $in_tree_ld_is_elf = yes && test $ld_is_gold = no; then
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>> -  elif test "$gcc_cv_gld_major_version" -eq 2 -a 
> > >>> "$gcc_cv_gld_minor_version" -ge 21 -o "$gcc_cv_gld_major_version" -gt 2 
> > >>> \
> > >>> -     && test $in_tree_ld_is_elf = yes; then
> > >>> -    gcc_cv_ld_compress_debug=1
> > >>>    fi
> > >>>  elif echo "$ld_ver" | grep GNU > /dev/null; then
> > >>>    if test $ld_is_mold = yes; then
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>>    elif test "$ld_vers_major" -lt 2 \
> > >>> -     || test "$ld_vers_major" -eq 2 -a "$ld_vers_minor" -lt 21; then
> > >>> +     || test "$ld_vers_major" -eq 2 -a "$ld_vers_minor" -lt 26; then
> > >>>      gcc_cv_ld_compress_debug=0
> > >>> -  elif test "$ld_vers_major" -eq 2 -a "$ld_vers_minor" -lt 26; then
> > >>> -    gcc_cv_ld_compress_debug=1
> > >>>    else
> > >>>      gcc_cv_ld_compress_debug=3
> > >>>      gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>>    fi
> > >>> -  if test $ld_is_gold = yes; then
> > >>> -    gcc_cv_ld_compress_debug=2
> > >>> -    gcc_cv_ld_compress_debug_option="--compress-debug-sections"
> > >>> -  fi
> > >>>  else
> > >>>  changequote(,)dnl
> > >>>    case "${target}" in
> > >>> diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi
> > >>> index 757775ea576..467659cb094 100644
> > >>> --- a/gcc/doc/invoke.texi
> > >>> +++ b/gcc/doc/invoke.texi
> > >>> @@ -10775,12 +10775,11 @@ location views are enabled.
> > >>>  Produce compressed debug sections in DWARF format, if that is 
> > >>> supported.
> > >>>  If @var{type} is not given, the default type depends on the 
> > >>> capabilities
> > >>>  of the assembler and linker used.  @var{type} may be one of
> > >>> -@samp{none} (don't compress debug sections), @samp{zlib} (use zlib
> > >>> -compression in ELF gABI format), or @samp{zlib-gnu} (use zlib
> > >>> -compression in traditional GNU format).  If the linker doesn't support
> > >>> -writing compressed debug sections, the option is rejected.  Otherwise,
> > >>> -if the assembler does not support them, @option{-gz} is silently 
> > >>> ignored
> > >>> -when producing object files.
> > >>> +@samp{none} (don't compress debug sections), or @samp{zlib} (use zlib
> > >>> +compression in ELF gABI format).  If the linker doesn't support writing
> > >>> +compressed debug sections, the option is rejected.  Otherwise, if the
> > >>> +assembler does not support them, @option{-gz} is silently ignored when
> > >>> +producing object files.
> > >>>
> > >>>  @item -femit-struct-debug-baseonly
> > >>>  @opindex femit-struct-debug-baseonly
> > >>> diff --git a/gcc/gcc.cc b/gcc/gcc.cc
> > >>> index 5cbb38560b2..660cd6f4ef4 100644
> > >>> --- a/gcc/gcc.cc
> > >>> +++ b/gcc/gcc.cc
> > >>> @@ -827,22 +827,11 @@ proper position among the other output files.  */
> > >>>  /* No linker support.  */
> > >>>  #define LINK_COMPRESS_DEBUG_SPEC \
> > >>>         " %{gz*:%e-gz is not supported in this configuration} "
> > >>> -#elif HAVE_LD_COMPRESS_DEBUG == 1
> > >>> -/* GNU style on input, GNU ld options.  Reject, not useful.  */
> > >>> -#define LINK_COMPRESS_DEBUG_SPEC \
> > >>> -       " %{gz*:%e-gz is not supported in this configuration} "
> > >>> -#elif HAVE_LD_COMPRESS_DEBUG == 2
> > >>> -/* GNU style, GNU gold options.  */
> > >>> -#define LINK_COMPRESS_DEBUG_SPEC \
> > >>> -       " %{gz|gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib}" \
> > >>> -       " %{gz=none:"        LD_COMPRESS_DEBUG_OPTION "=none}" \
> > >>> -       " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
> > >>>  #elif HAVE_LD_COMPRESS_DEBUG == 3
> > >>>  /* ELF gABI style.  */
> > >>>  #define LINK_COMPRESS_DEBUG_SPEC \
> > >>>         " %{gz|gz=zlib:"  LD_COMPRESS_DEBUG_OPTION "=zlib}" \
> > >>> -       " %{gz=none:"     LD_COMPRESS_DEBUG_OPTION "=none}" \
> > >>> -       " %{gz=zlib-gnu:" LD_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
> > >>> +       " %{gz=none:"     LD_COMPRESS_DEBUG_OPTION "=none}"
> > >>>  #else
> > >>>  #error Unknown value for HAVE_LD_COMPRESS_DEBUG.
> > >>>  #endif
> > >>> @@ -891,18 +880,11 @@ proper position among the other output files.  */
> > >>>  /* No assembler support.  Ignore silently.  */
> > >>>  #define ASM_COMPRESS_DEBUG_SPEC \
> > >>>         " %{gz*:} "
> > >>> -#elif HAVE_AS_COMPRESS_DEBUG == 1
> > >>> -/* GNU style, GNU as options.  */
> > >>> -#define ASM_COMPRESS_DEBUG_SPEC \
> > >>> -       " %{gz|gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "}" \
> > >>> -       " %{gz=none:"        AS_NO_COMPRESS_DEBUG_OPTION "}" \
> > >>> -       " %{gz=zlib:%e-gz=zlib is not supported in this configuration} "
> > >>>  #elif HAVE_AS_COMPRESS_DEBUG == 2
> > >>>  /* ELF gABI style.  */
> > >>>  #define ASM_COMPRESS_DEBUG_SPEC \
> > >>>         " %{gz|gz=zlib:"  AS_COMPRESS_DEBUG_OPTION "=zlib}" \
> > >>> -       " %{gz=none:"     AS_COMPRESS_DEBUG_OPTION "=none}" \
> > >>> -       " %{gz=zlib-gnu:" AS_COMPRESS_DEBUG_OPTION "=zlib-gnu} "
> > >>> +       " %{gz=none:"     AS_COMPRESS_DEBUG_OPTION "=none}"
> > >>>  #else
> > >>>  #error Unknown value for HAVE_AS_COMPRESS_DEBUG.
> > >>>  #endif
> > >>> --
> > >>> 2.37.0.rc0.161.g10f37bed90-goog
> > >>>
> >



-- 
宋方睿

Reply via email to