Blame SOURCES/gdb-6.5-sharedlibrary-path.patch

93189d
From FEDORA_PATCHES Mon Sep 17 00:00:00 2001
93189d
From: Jan Kratochvil <jan.kratochvil@redhat.com>
93189d
Date: Fri, 27 Oct 2017 21:07:50 +0200
93189d
Subject: gdb-6.5-sharedlibrary-path.patch
93189d
93189d
;; Fix TLS symbols resolving for shared libraries with a relative pathname.
93189d
;; The testsuite needs `gdb-6.5-tls-of-separate-debuginfo.patch'.
93189d
;;=fedoratest: One should recheck if it is really fixed upstream.
93189d
93189d
If you provided some relative path to the shared library, such as with
93189d
	export LD_LIBRARY_PATH=.
93189d
then gdb would fail to match the shared library name during the TLS lookup.
93189d
93189d
Dropped the workaround/fix for gdb-6.8.50.20081128 - is it still needed?
93189d
93189d
The testsuite needs `gdb-6.3-bz146810-solib_absolute_prefix_is_empty.patch'.
93189d
The testsuite needs `gdb-6.5-tls-of-separate-debuginfo.patch'.
93189d
93189d
2006-09-01  Jan Kratochvil  <jan.kratochvil@redhat.com>
93189d
93189d
	* solib-svr4.c (svr4_fetch_objfile_link_map): Match even absolute
93189d
	requested pathnames to the internal loaded relative pathnames.
93189d
93189d
2007-10-16  Jan Kratochvil  <jan.kratochvil@redhat.com>
93189d
93189d
	Port to GDB-6.7.
93189d
93189d
2008-02-27  Jan Kratochvil  <jan.kratochvil@redhat.com>
93189d
93189d
	Port to gdb-6.7.50.20080227.
93189d
93189d
diff --git a/gdb/testsuite/gdb.threads/tls-sepdebug-main.c b/gdb/testsuite/gdb.threads/tls-sepdebug-main.c
93189d
new file mode 100644
93189d
--- /dev/null
93189d
+++ b/gdb/testsuite/gdb.threads/tls-sepdebug-main.c
93189d
@@ -0,0 +1,31 @@
93189d
+/* This testcase is part of GDB, the GNU debugger.
93189d
+
93189d
+   Copyright 2006 Free Software Foundation, Inc.
93189d
+
93189d
+   This program is free software; you can redistribute it and/or modify
93189d
+   it under the terms of the GNU General Public License as published by
93189d
+   the Free Software Foundation; either version 2 of the License, or
93189d
+   (at your option) any later version.
93189d
+
93189d
+   This program is distributed in the hope that it will be useful,
93189d
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
93189d
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
93189d
+   GNU General Public License for more details.
93189d
+
93189d
+   You should have received a copy of the GNU General Public License
93189d
+   along with this program; if not, write to the Free Software
93189d
+   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
93189d
+
93189d
+   Please email any bugs, comments, and/or additions to this file to:
93189d
+   bug-gdb@prep.ai.mit.edu  */
93189d
+
93189d
+#include <pthread.h>
93189d
+
93189d
+extern __thread int var;
93189d
+
93189d
+int main()
93189d
+{
93189d
+  /* Ensure we link against pthreads even with --as-needed.  */
93189d
+  pthread_testcancel();
93189d
+  return var;
93189d
+}
93189d
diff --git a/gdb/testsuite/gdb.threads/tls-sepdebug-shared.c b/gdb/testsuite/gdb.threads/tls-sepdebug-shared.c
93189d
new file mode 100644
93189d
--- /dev/null
93189d
+++ b/gdb/testsuite/gdb.threads/tls-sepdebug-shared.c
93189d
@@ -0,0 +1,22 @@
93189d
+/* This testcase is part of GDB, the GNU debugger.
93189d
+
93189d
+   Copyright 2006 Free Software Foundation, Inc.
93189d
+
93189d
+   This program is free software; you can redistribute it and/or modify
93189d
+   it under the terms of the GNU General Public License as published by
93189d
+   the Free Software Foundation; either version 2 of the License, or
93189d
+   (at your option) any later version.
93189d
+
93189d
+   This program is distributed in the hope that it will be useful,
93189d
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
93189d
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
93189d
+   GNU General Public License for more details.
93189d
+
93189d
+   You should have received a copy of the GNU General Public License
93189d
+   along with this program; if not, write to the Free Software
93189d
+   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
93189d
+
93189d
+   Please email any bugs, comments, and/or additions to this file to:
93189d
+   bug-gdb@prep.ai.mit.edu  */
93189d
+
93189d
+__thread int var = 42;
93189d
diff --git a/gdb/testsuite/gdb.threads/tls-sepdebug.exp b/gdb/testsuite/gdb.threads/tls-sepdebug.exp
93189d
new file mode 100644
93189d
--- /dev/null
93189d
+++ b/gdb/testsuite/gdb.threads/tls-sepdebug.exp
93189d
@@ -0,0 +1,94 @@
93189d
+# Copyright 2006 Free Software Foundation, Inc.
93189d
+
93189d
+# This program is free software; you can redistribute it and/or modify
93189d
+# it under the terms of the GNU General Public License as published by
93189d
+# the Free Software Foundation; either version 2 of the License, or
93189d
+# (at your option) any later version.
93189d
+#
93189d
+# This program is distributed in the hope that it will be useful,
93189d
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
93189d
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
93189d
+# GNU General Public License for more details.
93189d
+#
93189d
+# You should have received a copy of the GNU General Public License
93189d
+# along with this program; if not, write to the Free Software
93189d
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
93189d
+
93189d
+# This test uses gdb_exit and gdb_start, which are not supported
93189d
+# on non-extended-remote sessions.
93189d
+if {[use_gdb_stub]} {
93189d
+    untested "skipping test because of stub"
93189d
+    return 0
93189d
+}
93189d
+
93189d
+if $tracelevel then {
93189d
+    strace $tracelevel
93189d
+}
93189d
+
93189d
+set testfile tls-sepdebug
93189d
+set srcmainfile   ${testfile}-main.c
93189d
+set srcsharedfile ${testfile}-shared.c
93189d
+
93189d
+set binmainfile        [standard_output_file ${testfile}-main]
93189d
+set binsharedbase      ${testfile}-shared.so
93189d
+set binsharedfile      [standard_output_file ${binsharedbase}]
93189d
+set binshareddebugfile [standard_output_file ${binsharedbase}.debug]
93189d
+
93189d
+# Use explicit -soname as otherwise the full path to the library would get
93189d
+# encoded into ${binmainfile} making LD_LIBRARY_PATH tests useless.
93189d
+
93189d
+# FIXME: gcc dependency (-Wl,-soname).
93189d
+
93189d
+if  { [gdb_compile_shlib "${srcdir}/${subdir}/${srcsharedfile}" "${binsharedfile}" [list debug additional_flags=-Wl,-soname=${binsharedbase}]] != "" } {
93189d
+    untested "Couldn't compile test library"
93189d
+    return -1
93189d
+}
93189d
+
93189d
+# eu-strip(1) works fine but it is a part of `elfutils', not `binutils'.
93189d
+if 0 then {
93189d
+    remote_exec build "eu-strip -f ${binshareddebugfile} ${binsharedfile}"
93189d
+} else {
93189d
+    remote_exec build "objcopy --only-keep-debug ${binsharedfile} ${binshareddebugfile}"
93189d
+    remote_exec build "objcopy --strip-debug ${binsharedfile}"
93189d
+    remote_exec build "objcopy --add-gnu-debuglink=${binshareddebugfile} ${binsharedfile}"
93189d
+}
93189d
+
93189d
+# Do not use `shlib=' as it will automatically add also -rpath for gcc.
93189d
+
93189d
+if  { [gdb_compile_pthreads "${srcdir}/${subdir}/${srcmainfile} ${binsharedfile}" "${binmainfile}" executable {debug}] != "" } {
93189d
+    untested "Couldn't compile test program"
93189d
+    return -1
93189d
+}
93189d
+
93189d
+# Get things started.
93189d
+
93189d
+# Test also the proper resolving of relative library names to absolute ones.
93189d
+# \$PWD is easy - it is the absolute way
93189d
+# ${subdir} would fail on "print var"
93189d
+
93189d
+set absdir [file dirname [standard_output_file ${binsharedbase}]]
93189d
+foreach ld_library_path [list $absdir [relative_filename [pwd] $absdir]] name { absolute relative }  {
93189d
+
93189d
+    gdb_exit
93189d
+    gdb_start
93189d
+    ###gdb_reinitialize_dir $srcdir/$subdir
93189d
+
93189d
+    gdb_test "set env LD_LIBRARY_PATH=$ld_library_path" \
93189d
+             "" \
93189d
+             "set env LD_LIBRARY_PATH is $name"
93189d
+
93189d
+    gdb_load ${binmainfile}
93189d
+
93189d
+    # For C programs, "start" should stop in main().
93189d
+
93189d
+    gdb_test "start" \
93189d
+             "main \\(\\) at .*${srcmainfile}.*" \
93189d
+             "start"
93189d
+
93189d
+    # Check for: Cannot find shared library `/usr/lib/debug/lib/libc-2.4.90.so.debug' in dynamic linker's load module list
93189d
+    # as happens with TLS variables and `separate_debug_objfile_backlink'.
93189d
+
93189d
+    gdb_test "print var" \
93189d
+             "\\\$1 = \[0-9\].*" \
93189d
+             "print TLS variable from a shared library with $name-directory separate debug info file"
93189d
+}