[lldb-dev] [Bug 51433] New: crash for "x86_64-w64-windows-gnu" because of architecture triple mismatch - solution proposition

via lldb-dev lldb-dev at lists.llvm.org
Tue Aug 10 10:42:00 PDT 2021


https://bugs.llvm.org/show_bug.cgi?id=51433

            Bug ID: 51433
           Summary: crash for  "x86_64-w64-windows-gnu" because of
                    architecture triple mismatch - solution proposition
           Product: lldb
           Version: 12.0
          Hardware: PC
                OS: Windows NT
            Status: NEW
          Severity: enhancement
          Priority: P
         Component: All Bugs
          Assignee: lldb-dev at lists.llvm.org
          Reporter: rolchg at gmail.com
                CC: jdevlieghere at apple.com, llvm-bugs at lists.llvm.org

The problem concerns the 64bit lldb (12.0.01 and 14.0.0) debugger compiled for
"x86_64-w64-windows-gnu". 
The debugger crashes if a variable of type class method pointer is examined.
Debugging of the lldb shown the problem is a result of the architecture
"triple" mismatch, and a difference in the implementation of class method
pointers between "msvc" and "gnu".
The triplet lldb  for debugged exe file obtains the  by method
"ObjectFilePECOFF::GetModuleSpecifications"
and sets it to "x86_64-pc-windows". Finally the triplet is transformed to
""x86_64-pc-windows.msvc"  by Triple::normalize at the clang side.

It seems to be reasonable to resolve the problem at its origin, by replacing
the wrong hard coded triple value, in "ObjectFilePECOFF::
GetModuleSpecifications" to the proper one, by using some additional criteria.

Here is the patch:

diff --git a/lldb/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
b/lldb/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
index 9eb1c25d2403..61550682a019 100644
--- a/lldb/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
+++ b/lldb/source/Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.cpp
@@ -32,6 +32,7 @@
 #include "llvm/Object/COFFImportFile.h"
 #include "llvm/Support/Error.h"
 #include "llvm/Support/MemoryBuffer.h"
+#include "llvm/Support/Host.h"

 #define IMAGE_DOS_SIGNATURE 0x5A4D    // MZ
 #define IMAGE_NT_SIGNATURE 0x00004550 // PE00
@@ -163,7 +164,10 @@ size_t ObjectFilePECOFF::GetModuleSpecifications(

   switch (COFFObj->getMachine()) {
   case MachineAmd64:
-    spec.SetTriple("x86_64-pc-windows");
+       if(llvm::sys::getProcessTriple()=="x86_64-w64-windows-gnu")
+               spec.SetTriple("x86_64-w64-windows-gnu");
+       else
+               spec.SetTriple("x86_64-pc-windows");
     specs.Append(module_spec);
     break;
   case MachineX86:

-- 
You are receiving this mail because:
You are the assignee for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/lldb-dev/attachments/20210810/6c0f38e0/attachment.html>


More information about the lldb-dev mailing list