[gdb] Don't return non-existing path in debuginfod_source_query
authorTom de Vries <tdevries@suse.de>
Mon, 23 Nov 2020 19:09:50 +0000 (20:09 +0100)
committerTom de Vries <tdevries@suse.de>
Mon, 23 Nov 2020 19:09:50 +0000 (20:09 +0100)
When setting env var DEBUGINFOD_URLS to " " and running the testsuite, we run
into these regressions:
...
FAIL: gdb.base/list-missing-source.exp: info source
FAIL: gdb.base/source-dir.exp: info source before setting directory search list
...

Setting var DEBUGINFOD_URLS to " " allows the debuginfod query function
debuginfod_source_query to get past its early exit.

The function debuginfod_source_query is documented as: "If the file is
successfully retrieved, its path on the local machine is stored in DESTNAME".

However, in case we get back -ENOENT from libdebuginfod, we still set
DESTNAME:
....
  if (fd.get () < 0 && fd.get () != -ENOENT)
    printf_filtered (_("Download failed: %s.  Continuing without source file %ps.\n"),
                     safe_strerror (-fd.get ()),
                     styled_string (file_name_style.style (),  srcpath));
  else
    *destname = make_unique_xstrdup (srcpath);

  return fd;
...

Fix this by making debuginfod_source_query fit it's documentation and only
setting DESTNAME when successfully retrieving a file.  Likewise in
debuginfod_debuginfo_query.

gdb/ChangeLog:

2020-11-23  Tom de Vries  <tdevries@suse.de>

* debuginfod-support.c (debuginfod_source_query)
(debuginfod_debuginfo_query): Only set DESTNAME if successful.

gdb/ChangeLog
gdb/debuginfod-support.c

index 3d516df084b81e138badb067bdabc9d0060926d2..47c68cbde03d489c17386fb231336c57f13dc769 100644 (file)
@@ -1,3 +1,8 @@
+2020-11-23  Tom de Vries  <tdevries@suse.de>
+
+       * debuginfod-support.c (debuginfod_source_query)
+       (debuginfod_debuginfo_query): Only set DESTNAME if successful.
+
 2020-11-21  Tom Tromey  <tom@tromey.com>
 
        * breakpoint.c (watchpoint_exp_is_const): Return bool.
index a7c76ab6134c22129945b4d88b076b1896ea4700..e21b2f40caee107c802b997d10da749d1d9be431 100644 (file)
@@ -134,7 +134,8 @@ debuginfod_source_query (const unsigned char *build_id,
     printf_filtered (_("Download failed: %s.  Continuing without source file %ps.\n"),
                     safe_strerror (-fd.get ()),
                     styled_string (file_name_style.style (),  srcpath));
-  else
+
+  if (fd.get () >= 0)
     *destname = make_unique_xstrdup (srcpath);
 
   return fd;
@@ -169,7 +170,8 @@ debuginfod_debuginfo_query (const unsigned char *build_id,
                     safe_strerror (-fd.get ()),
                     styled_string (file_name_style.style (),  filename));
 
-  destname->reset (dname);
+  if (fd.get () >= 0)
+    destname->reset (dname);
 
   return fd;
 }