Bug#946606: marked as done (libc-bin: catchsegv does not handle backtraces with parentheses)
Your message dated Sun, 07 Aug 2022 21:06:46 +0000
with message-id <E1oKnTy-004xFS-S0@fasolo.debian.org>
and subject line Bug#946606: fixed in glibc 2.35-0experimental0
has caused the Debian Bug report #946606,
regarding libc-bin: catchsegv does not handle backtraces with parentheses
to be marked as done.
This means that you claim that the problem has been dealt with.
If this is not the case it is now your responsibility to reopen the
Bug report if necessary, and/or fix the problem forthwith.
(NB: If you are a system administrator and have no idea what this
message is talking about, this may indicate a serious mail system
misconfiguration somewhere. Please contact owner@bugs.debian.org
immediately.)
-- 
946606: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=946606
Debian Bug Tracking System
Contact owner@bugs.debian.org with problems
--- Begin Message ---
- To: Debian Bug Tracking System <submit@bugs.debian.org>
- Subject: libc-bin: catchsegv does not handle backtraces with parentheses
- From: Bernhard Übelacker <bernhardu@mailbox.org>
- Date: Wed, 11 Dec 2019 20:05:38 +0100
- Message-id: <cf55c5bb-6bbf-df27-2054-fb698ca62590@mailbox.org>
Package: libc-bin
Version: 2.29-3
Severity: wishlist
Tags: upstream patch
Dear Maintainer,
since upstream commit in 2012 [1] the function __backtrace_symbols_fd
seems to outputs in one of this formats:
    program(+<offset>)[<address>]
    program(function+<offset>)[<address>]
Therefore the /usr/bin/catchsegv cannot find the backtrace lines
and produces less useful outputs (see below)
There exists an upstream bug about the issue [2].
Attached patch is an attempt to parse the offset instead of the
address, which seems now less important due to ASLR.
Known symbols are currently written by __backtrace_symbols_fd
as such with the offset in relation to the function instead
of the library section.
To get for these also sourcefile and line information
either __backtrace_symbols_fd needs to be changed to
output the library section offset to the backtrace too,
or addr2line (binutils) needs a change to lookup the symbol and
calculate from there, but both would be different issues.
What do you think?
Kind regards,
Bernhard
Current:
Backtrace:
/tmp/tmp.sSrfzsTKpn/3-options-input-fn(+0x175b)[0x557275eb775b]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xeb)[0x7f4f8194ebbb]
/tmp/tmp.sSrfzsTKpn/3-options-input-fn(+0x11ba)[0x557275eb71ba]
With proposed changes:
Backtrace:
 [0x5578ceb0575b] main at /usr/share/doc/libsoxr-dev/examples/3-options-input-fn.c:79 (discriminator 4) /tmp/tmp.sSrfzsTKpn/3-options-input-fn(+0x175b)
 /lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xeb)[0x7fcf5f243bbb]
 [0x5578ceb051ba] _start at ??:? /tmp/tmp.sSrfzsTKpn/3-options-input-fn(+0x11ba)
[1] https://sourceware.org/git/?p=glibc.git;a=commit;h=1d6c3d237d10606121c959b9bd2ae722f79ea899
[2] https://sourceware.org/bugzilla/show_bug.cgi?id=21830
-- System Information:
Debian Release: bullseye/sid
  APT prefers testing-debug
  APT policy: (500, 'testing-debug'), (500, 'proposed-updates-debug'), (500, 'testing')
Architecture: amd64 (x86_64)
Kernel: Linux 5.3.0-2-amd64 (SMP w/12 CPU cores)
Locale: LANG=de_DE.UTF-8, LC_CTYPE=de_DE.UTF-8 (charmap=UTF-8), LANGUAGE=de_DE.UTF-8 (charmap=UTF-8)
Shell: /bin/sh linked to /usr/bin/dash
Init: systemd (via /run/systemd/system)
LSM: AppArmor: enabled
Versions of packages libc-bin depends on:
ii  libc6  2.29-3
Versions of packages libc-bin recommends:
ii  manpages  5.04-1
libc-bin suggests no packages.
-- no debconf information
>From fca03cd9af5ffaea1e4968fa27a7b28ee80903ef Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bernhard=20=C3=9Cbelacker?= <bernhardu@mailbox.org>
Date: Wed, 11 Dec 2019 19:56:39 +0100
Subject: Make catchsegv work again after format changed.
https://sourceware.org/bugzilla/show_bug.cgi?id=21830
---
 debug/catchsegv.sh | 34 +++++++++++++++++++++++-----------
 1 file changed, 23 insertions(+), 11 deletions(-)
diff --git a/debug/catchsegv.sh b/debug/catchsegv.sh
index 245c100f..da87122c 100755
--- a/debug/catchsegv.sh
+++ b/debug/catchsegv.sh
@@ -87,18 +87,30 @@ if test -s "$segv_output"; then
   sed '/Backtrace/q' "$segv_output"
   sed '1,/Backtrace/d' "$segv_output" |
   (while read line; do
-     line=`echo $line | sed "s@^$prog\\(\\[.*\\)@\1@"`
      case "$line" in
-       \[*) addr=`echo "$line" | sed 's/^\[\(.*\)\]$/\1/'`
-	    complete=`addr2line -f -e "$prog" $addr 2>/dev/null`
-	    if test $? -eq 0; then
-	      echo "`echo "$complete"|sed 'N;s/\(.*\)\n\(.*\)/\2(\1)/;'`$line"
-	    else
-	      echo "$line"
-	    fi
-	    ;;
-	 *) echo "$line"
-	    ;;
+       *\(*\)\[*\])
+         lib=`echo $line  | sed "s@^\(.*\)(\(.*\))\[\(.*\)\]\\$@\1@"`
+         offs=`echo $line | sed "s@^\(.*\)(\(.*\))\[\(.*\)\]\\$@\2@"`
+         addr=`echo $line | sed "s@^\(.*\)(\(.*\))\[\(.*\)\]\\$@\3@"`
+         case "$offs" in
+           +*) case "$prog" in
+                 */$lib)
+                   lib="$prog"
+                   ;;
+               esac
+               complete=`addr2line -p -i -f -e "$lib" $offs 2>/dev/null`
+               if test $? -eq 0; then
+                 echo " [$addr] $complete $lib($offs)"
+               else
+                 echo " $line"
+               fi
+               ;;
+             *) echo " $line"
+                ;;
+         esac
+         ;;
+        *) echo "$line"
+           ;;
      esac
    done)
 fi
-- 
2.24.0
--- End Message ---
--- Begin Message ---
Source: glibc
Source-Version: 2.35-0experimental0
Done: Aurelien Jarno <aurel32@debian.org>
We believe that the bug you reported is fixed in the latest version of
glibc, which is due to be installed in the Debian FTP archive.
A summary of the changes between this version and the previous one is
attached.
Thank you for reporting the bug, which will now be closed.  If you
have further comments please address them to 946606@bugs.debian.org,
and the maintainer will reopen the bug report if appropriate.
Debian distribution maintenance software
pp.
Aurelien Jarno <aurel32@debian.org> (supplier of updated glibc package)
(This message was generated automatically at their request; if you
believe that there is a problem with it please contact the archive
administrators by mailing ftpmaster@ftp-master.debian.org)
-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA512
Format: 1.8
Date: Sun, 07 Aug 2022 22:25:02 +0200
Source: glibc
Architecture: source
Version: 2.35-0experimental0
Distribution: experimental
Urgency: medium
Maintainer: GNU Libc Maintainers <debian-glibc@lists.debian.org>
Changed-By: Aurelien Jarno <aurel32@debian.org>
Closes: 775716 896008 946606
Changes:
 glibc (2.35-0experimental0) experimental; urgency=medium
 .
   [ Aurelien Jarno ]
   * New upstream release:
     - Fixes performance issues in dynamic loader.  Closes: #896008.
     - debian/symbols.wildcard: add 2.35.
     - debian/patches/localedata/locale-C.diff: upstreamed.
     - debian/patches/alpha/local-string-functions.diff: rebased.
     - debian/patches/hurd-i386/git-drop-rmh.diff: upstreamed.
     - debian/patches/hurd-i386/git-AT_NO_AUTOMOUNT.diff: upstreamed.
     - debian/patches/hurd-i386/git-get_errlist.diff: upstreamed.
     - debian/patches/hurd-i386/git-msync.diff: upstreamed.
     - debian/patches/hurd-i386/git-htl-init_sigset.diff: upstreamed.
     - debian/patches/hurd-i386/git-machrules-chk_fail.diff: upstreamed.
     - debian/patches/hurd-i386/git-random-getrandom.diff: upstreamed.
     - debian/patches/hurd-i386/git-lib-map.diff: upstreamed.
     - debian/patches/hurd-i386/git-large-text.diff: upstreamed.
     - debian/patches/hurd-i386/git-get_dtable.diff: upstreamed.
     - debian/patches/hurd-i386/git-auth-leak.diff: upstreamed.
     - debian/patches/hurd-i386/git-nuke_ports_on_exec.diff: upstreamed.
     - debian/patches/hurd-i386/git-ttydefaults.diff: upstreamed.
     - debian/patches/hurd-i386/git-const.diff: upstreamed.
     - debian/patches/hurd-i386/git-pthread_kill_exited.diff: upstreamed.
     - debian/patches/hurd-i386/git-reply_bogus.diff: upstreamed.
     - debian/patches/hurd-i386/tg-EIEIO-fr.diff: upstreamed.
     - debian/patches/hurd-i386/tg-EGREGIOUS-fr.diff: upstreamed.
     - debian/patches/hurd-i386/local-tls-ie-align.diff: dropped, obsolete.
     - debian/patches/kfreebsd/submitted-auxv.diff: rebased.
     - debian/patches/mips/submitted-rld_map.diff: rebased.
     - debian/patches/all/submitted-po-fr-fixes.diff: upstreamed.
     - debian/patches/any/local-ldconfig-ignore-ld.so.diff: rebased.
     - debian/patches/any/git-localedef-check-magic.patch: upstreamed.
     - debian/debhelper.in/libc-bin.{install,manpages}: stop installing
       catchsegv, removed upstream.  Closes: #775716, #946606.
   * debian/sysdeps/{amd64,arm64,i386,x32}.mk: stop passing --enable-static-pie
     to configure as it is now the default.
   * debian/debhelper.in/libc-bin.install: install /usr/bin/ld.so in libc-bin.
   * debian/rules.d/build.mk: remove the C.utf8 locale from locales-all to
     avoid conflicts with the one in libc-bin. Unfortunately we can't use the
     one build in locales-all for libc-bin, as locales-all currently can't be
     cross-compiled.
   * debian/rules.d/debhelper.mk: do not offer C.UTF-8 in the list of locales
     that can be generated through the debconf template, as it is already
     provided by libc-bin.
   * debian/testsuite-xfail-debian.mk: add new math tests that are also
     affected by the Octeon 3 and XBurst tininess detection.
 .
   [ Samuel Thibault ]
   * debian/patches/hurd-i386/local-fix-nss.diff: Refresh.
   * debian/patches/hurd-i386/submitted-net.diff: Refresh.
   * debian/patches/hurd-i386/tg-bits_atomic.h_multiple_threads.diff: Refresh.
Checksums-Sha1:
 a53ec56a4f84a635bafe9431561d409b8e0fd20d 9725 glibc_2.35-0experimental0.dsc
 14acd5dd674eacdac8989c5e4020555de65eef47 18943876 glibc_2.35.orig.tar.xz
 ea797ce0b8d8cc94e9a68d7c060724f6e498ee29 887548 glibc_2.35-0experimental0.debian.tar.xz
 942e922a57edcb4d7d921df3f954c58f1829b664 9516 glibc_2.35-0experimental0_source.buildinfo
Checksums-Sha256:
 765a25e45905fc182a0e156ddb0737647784a493ffb0202592783b8902c193f2 9725 glibc_2.35-0experimental0.dsc
 bacb01a162ccf9a683c26684dbf8f077fe9b445db5be439db4e69bbcbc3adb49 18943876 glibc_2.35.orig.tar.xz
 651a4fa2db105d9ce5f086750d8d657353707eb146b52c2d3f1c576f800be317 887548 glibc_2.35-0experimental0.debian.tar.xz
 030f932633ed5c20b67e81e1cdaf1c2802a66e4562ecc7e778ac7bba41bf10ee 9516 glibc_2.35-0experimental0_source.buildinfo
Files:
 a3c933668c65d2e14fc85f3ca9d2e932 9725 libs required glibc_2.35-0experimental0.dsc
 9ca98a4f77c72ef646dede484f103070 18943876 libs required glibc_2.35.orig.tar.xz
 4d2dd4832360f43ce545de384fdb08fa 887548 libs required glibc_2.35-0experimental0.debian.tar.xz
 953eba36f6b990344cc243f606afbe57 9516 libs required glibc_2.35-0experimental0_source.buildinfo
-----BEGIN PGP SIGNATURE-----
iQIzBAEBCgAdFiEEUryGlb40+QrX1Ay4E4jA+JnoM2sFAmLwIXgACgkQE4jA+Jno
M2v7FA/+KNIYw0ZtaQtHWOEMmhCbaOhNz5nRyn/nmNsL5+DvQ0Vm2E4V2jKuzGRm
e407k4eJ5mooHlC4etOLj7PcqkcGN3z2DQ5rUefiITFD34TwkZdrT9Nk+ZpvMUPL
8ygd3W6uGr73SeO21wzgf4e2Bzi7ME6GH3Km2G0X3aKc6yIyIzOjGkh/nAWppbuz
B0yyt34t97/m8BYKeO3Ci0GNS7fXE5GVBygWOOY1mBuiqS/ptFY2P84dbqPOuFSU
3kXyI8ngwUVelhue6Nl7bTwxzpafrGur49BXio0XWoMqnf1V7kBUXQaecnxrma9f
ztMTM+DRp07N7DeMLIndrspXaZcdRA0VjYdfcMDtaAK/V90vUdT2agIQsuCcGKf9
psIxJCq2g4TxAOo9FYcy/rD+gF9k4YyYDbMSkuNsWQ7XlNOZjEZQmFYRSurdkqg6
i3iMHq5ItrxTB81Uc9S3nKhvIfvxCFHCF93yNOb1nuIlPykJs84gZQSLI2k++amc
L8yalXsCE50qSxR6A6oMvL+O60l0/R46MfHhX0rT6WZmqBp4+befGEEJQ2zXF5bm
znzYz2wEagsPL///FeB6XkO3shdWt/YQu1Qo03/Eu63m5Pc+T24tdZXea8oLACS8
bRpcvpfm25uAO0OUQRrsJZ/YGm/Nv45uHp+lUVH7n//BtpanfR8=
=f+3c
-----END PGP SIGNATURE-----
--- End Message ---
Reply to: