[PR gdb/27614] gdb-add-index fails on symlinks.
authorLancelot SIX <lsix@lancelotsix.com>
Wed, 24 Mar 2021 23:55:25 +0000 (23:55 +0000)
committerLancelot SIX <lsix@lancelotsix.com>
Mon, 10 May 2021 22:14:41 +0000 (23:14 +0100)
PR 27614 shows that gdb-add-index fails to generate the index when its
argument is a symlink.

The following one liner illustrates the reported problem:

        $ echo 'int main(){}'|gcc -g -x c -;ln -s a.out symlink;gdb-add-index symlink
        gdb-add-index: No index was created for symlink
        gdb-add-index: [Was there no debuginfo? Was there already an index?]
        $ ls -l
        -rwxr-xr-x 1 25712 Mar 19 23:05 a.out*
        -rw------- 1  8277 Mar 19 23:05 a.out.gdb-index
        lrwxrwxrwx 1     5 Mar 19 23:05 symlink -> a.out*

GDB generates the .gdb-index file with a name that matches the name of
the actual program (a.out.gdb-index here), not the symlink that
references it.  The remaining of the script is looking for a file named
after the provided argument (would be 'symlink.gdb-index' in our
example).

gdb/ChangeLog:

PR gdb/27614
* contrib/gdb-add-index.sh: Fix when called with a symlink as an
argument.

gdb/testsuite/ChangeLog:

PR gdb/27614
* gdb.dwarf2/gdb-add-index-symlink.exp: New test.

gdb/ChangeLog
gdb/contrib/gdb-add-index.sh
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.dwarf2/gdb-add-index-symlink.exp [new file with mode: 0644]

index 52d5faac8a9db8fe66cd64cf533a32260a7a4b48..624d5793a158219f4d4ebfda6510609ad4df7979 100644 (file)
@@ -1,3 +1,9 @@
+2021-05-10  Lancelot Six  <lsix@lancelotsix.com>
+
+       PR gdb/27614
+       * contrib/gdb-add-index.sh: Fix when called with a symlink as an
+       argument.
+
 2021-05-10  Simon Marchi  <simon.marchi@polymtl.ca>
 
        * nat/linux-waitpid.c (status_to_str): Show signal name.
index 2ac3fddbf26a82717c15b03f27859f88467b18ad..734110caa3b522d3455cf9876feef1c478b0ddbe 100755 (executable)
@@ -37,6 +37,34 @@ fi
 
 file="$1"
 
+if test -L "$file"; then
+    if ! command -v readlink >/dev/null 2>&1; then
+       echo "$myname: 'readlink' missing.  Failed to follow symlink $1." 1>&2
+       exit 1
+    fi
+
+    # Count number of links followed in order to detect loops.
+    count=0
+    while test -L "$file"; do
+       target=$(readlink "$file")
+
+       case "$target" in
+           /*)
+               file="$target"
+               ;;
+           *)
+               file="$(dirname "$file")/$target"
+               ;;
+       esac
+
+       count="$((count + 1))"
+       if test "$count" -gt 10; then
+           echo "$myname: Detected loop while following link $file"
+           exit 1
+       fi
+    done
+fi
+
 if test ! -r "$file"; then
     echo "$myname: unable to access: $file" 1>&2
     exit 1
index b3a41bd5481893672056750aac4a21ac2fdf2d24..c188719cd575a48665d7a370d240038986944476 100644 (file)
@@ -1,3 +1,8 @@
+2021-05-10  Lancelot Six  <lsix@lancelotsix.com>
+
+       PR gdb/27614
+       * gdb.dwarf2/gdb-add-index-symlink.exp: New test.
+
 2021-05-10  Andrew Burgess  <andrew.burgess@embecosm.com>
 
        * gdb.guile/guile.exp: Don't use the source directory as a
diff --git a/gdb/testsuite/gdb.dwarf2/gdb-add-index-symlink.exp b/gdb/testsuite/gdb.dwarf2/gdb-add-index-symlink.exp
new file mode 100644 (file)
index 0000000..eaeddec
--- /dev/null
@@ -0,0 +1,47 @@
+# Copyright 2021 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+load_lib dwarf.exp
+
+# This test can only be run on targets which support DWARF-2.
+if {![dwarf2_support]} {
+    return 0
+}
+
+standard_testfile main.c
+
+if { [prepare_for_testing "failed to prepare" "${testfile}" \
+         [list ${srcfile}]] } {
+    return -1
+}
+
+set symlink [file dirname $binfile]/symlink
+
+if { ![file exists $symlink] } {
+    file link -symbolic $symlink $binfile
+}
+
+if { [ensure_gdb_index $symlink] == -1 } {
+    fail "Unable to call gdb-add-index with a symlink to a symfile"
+    return -1
+}
+
+# Ok, we have a copy of $binfile with an index.
+# Restart gdb and verify the index was used.
+
+clean_restart $symlink
+gdb_test "mt print objfiles ${testfile}" \
+    "(gdb_index|debug_names).*" \
+    "index used"