https://sourceware.org/git/gitweb.cgi?p=newlib-cygwin.git;h=f4a1b6ae182aaebd5b5a69f3f31ef633bc174464

commit f4a1b6ae182aaebd5b5a69f3f31ef633bc174464
Author: Jon Turney <[email protected]>
Date:   Mon Sep 7 16:24:39 2020 +0100

    Cygwin: ldd: Also look for not found DLLs when exit status is non-zero
    
    If the process exited with e.g. STATUS_DLL_NOT_FOUND, also process the
    file to look for not found DLLs.
    
    (We currently only do this when a STATUS_DLL_NOT_FOUND exception occurs,
    which I haven't managed to observe)
    
    This still isn't 100% correct, as it only examines the specified file
    for missing DLLs, not recursively on the DLLs it depends upon.

Diff:
---
 winsup/utils/ldd.cc | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/winsup/utils/ldd.cc b/winsup/utils/ldd.cc
index e1af99e12..1e1863c1c 100644
--- a/winsup/utils/ldd.cc
+++ b/winsup/utils/ldd.cc
@@ -407,6 +407,8 @@ report (const char *in_fn, bool multiple)
          }
          break;
        case EXIT_PROCESS_DEBUG_EVENT:
+         if (ev.u.ExitProcess.dwExitCode != 0)
+           process_fn = fn_win;
 print_and_exit:
          print_dlls (&dll_list, isdll ? fn_win : NULL, process_fn);
          exitnow = true;

Reply via email to