<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/57799>57799</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Regression in LLDB reading i386/mingw PDB debug info since "[LLDB][NativePDB] Switch to use DWARFLocationList."
</td>
</tr>
<tr>
<th>Labels</th>
<td>
lldb,
regression,
platform:windows
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
mstorsjo
</td>
</tr>
</table>
<pre>
With the attached testcase [hello-exception-pdb-i686.zip](https://github.com/llvm/llvm-project/files/9591745/hello-exception-pdb-i686.zip), an i386 executable with PDB info, it no longer prints variable locations/contents correctly since this commit (https://reviews.llvm.org/D130796, 71d778f33e8615f525f118db351c6541b40199ab). It still works correctly for x86_64 and aarch64 like it did before.
To reproduce, with the attached executable:
```
> $ lldb.exe -- hello-exception-pdb.exe -crash
(lldb) target create "c:\\code\\pdb-repro\\hello-exception-pdb.exe"
Current executable set to 'c:\code\pdb-repro\hello-exception-pdb.exe' (i386).
(lldb) settings set -- target.run-args "-crash"..
(lldb) run
(lldb) Process 1424 launched: 'c:\code\pdb-repro\hello-exception-pdb.exe' (i386)
Process 1424 stopped
* thread #1, stop reason = Exception 0xc0000005 encountered at address 0x261453: Access violation writing location 0x00000000
frame #0: 0x00261453 hello-exception-pdb.exe`recurse(val=0) at hello-exception.cpp:51
(lldb) bt
* thread #1, stop reason = Exception 0xc0000005 encountered at address 0x261453: Access violation writing location 0x00000000
* frame #0: 0x00261453 hello-exception-pdb.exe`recurse(val=0) at hello-exception.cpp:51
frame #1: 0x002615b1 hello-exception-pdb.exe`recurse(val=1) at hello-exception.cpp:68
frame #2: 0x002615b1 hello-exception-pdb.exe`recurse(val=2) at hello-exception.cpp:68
frame #3: 0x002615b1 hello-exception-pdb.exe`recurse(val=3) at hello-exception.cpp:68
frame #4: 0x002615b1 hello-exception-pdb.exe`recurse(val=4) at hello-exception.cpp:68
frame #5: 0x002614ef hello-exception-pdb.exe`recurse(val=5) at hello-exception.cpp:62
frame #6: 0x002615b1 hello-exception-pdb.exe`recurse(val=6) at hello-exception.cpp:68
frame #7: 0x002615b1 hello-exception-pdb.exe`recurse(val=7) at hello-exception.cpp:68
frame #8: 0x002615b1 hello-exception-pdb.exe`recurse(val=8) at hello-exception.cpp:68
frame #9: 0x002615b1 hello-exception-pdb.exe`recurse(val=9) at hello-exception.cpp:68
frame #10: 0x002615b1 hello-exception-pdb.exe`recurse(val=10) at hello-exception.cpp:68
frame #11: 0x002617ec hello-exception-pdb.exe`main(argc=2, argv=0x00284f50) at hello-exception.cpp:95
frame #12: 0x00261393 hello-exception-pdb.exe
frame #13: 0x74c20419 kernel32.dll`BaseThreadInitThunk + 25
frame #14: 0x771c662d ntdll.dll`RtlGetAppContainerNamedObjectPath + 237
frame #15: 0x771c65fd ntdll.dll`RtlGetAppContainerNamedObjectPath + 189
```
(To get proper debugging of an i386 executable, you also need to have LLDB built in i386 mode.)
Since this commit, I get this printout:
```
(lldb) target create "c:\\code\\pdb-repro\\hello-exception-pdb.exe"
(rrent executable set to 'c:\code\pdb-repro\hello-exception-pdb.exe' (i386).
(ldb) settings set -- target.run-args "-crash".
(lldb) run
(lldb) Process 4068 launched: 'c:\code\pdb-repro\hello-exception-pdb.exe' (i386)
Process 4068 stopped
* thread #1, stop reason = Exception 0xc0000005 encountered at address 0x261453: Access violation writing location 0x00000000
frame #0: 0x00261453 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:51
(lldb) bt
* thread #1, stop reason = Exception 0xc0000005 encountered at address 0x261453: Access violation writing location 0x00000000
* frame #0: 0x00261453 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:51
frame #1: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #2: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #3: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #4: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #5: 0x002614ef hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:62
frame #6: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #7: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #8: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #9: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #10: 0x002615b1 hello-exception-pdb.exe`recurse(val=<unavailable>) at hello-exception.cpp:68
frame #11: 0x002617ec hello-exception-pdb.exe`main(argc=<unavailable>, argv=<unavailable>) at hello-exception.cpp:95
frame #12: 0x00261393 hello-exception-pdb.exe
frame #13: 0x74c20419 kernel32.dll`BaseThreadInitThunk + 25
frame #14: 0x771c662d ntdll.dll`RtlGetAppContainerNamedObjectPath + 237
frame #15: 0x771c65fd ntdll.dll`RtlGetAppContainerNamedObjectPath + 189
```
Note, the `recurse(val=<unavailable>)` everywhere.
The strange thing is that this only regressed if LLDB was built in mingw mode; an MSVC built LLDB still correctly handles this case. (`settings set plugin.object-file.pe-coff.abi gnu` in the MSVC built case doesn't make any difference, nor does `settings set plugin.object-file.pe-coff.abi msvc` in the mingw built case either.)
CC @ZequanWu
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJztmVtv2zYUxz-N_UJY0I26PPghcdqhQNYVbbECexkoirLY0KRGUnayT79DSk3cxAkm1S2GoYZg3cjzP-eQon4UK1XfrT9x2yLbMkSsJbRlNbLMWEoMQwt82TIh1IrdUtZZruSqq6sVz4os-Jt3C3y1iIvW2s4skotF_Bq2LVjrq4CqHZwIsf-yW3VafWbUwmnDBTOwL3EZ5SmGoxdF4nIRbxCRiCdFhtgto70llWDo4Bx_d3WJuGyUK8MtkgoJJbdMo05zaQ3aE819aaEoccadMlXSMneXKq3BKXGHDJeUQRq4u7jbgaknoWm25-xgAhdOoPQWLl1FSZiXmRPPozrPiyZJWJFFuMExbqKoqKsERzTDaVSlYVSWpIJ4AvTGImO5EOig9M2xG43S6LbI_sxSiLhGhGjawrHgN8yFV_MaVQwKsWARXi3Ci-H_o0KaQYLrnjLny-FJkz6kzYVzVHWRheM2nCavIHAQFHUVQCW0WqETrTPcopqYdqwXF64KBIcs0VtmEdWMWOhCcUydJN7ARlXNhiPXwt7l4fQZCag8mN_0kCBpj1vfgIZVYD8f7Y_Gjy0_azZ3rev6k2uNJxGAacvl1ngNSMAQUaB7uYIjg1xQY_BxHDytDwWfXHunFWXGoCh12SW9dM0Cjp8hgEHrKwFjVdeB_dGLC-gM0Bw1VEoi10HcfegyxCiJFskVevVFAYW3NPQ_jJikqocHRUP_IRaRutZOILyNsyjFiXP-gnrNPVfCP1zooLlL3f3TBqXD8Tc4g-DXaLJzPSMJnQ1XYrD4XE-D3gmPR68NBF7siQCPQ5dTcOpRjYB2HdjE0ZP8V_Y_mQznzg9Lx1e5j47EcBVNEIteFMuKE2LxbLF4ulgyWyyZLpbOFkuni-HjDsKaCWL4ZbH4hFg2O7JsemT5bLF8ulgxW6yYLlbOFiuni0Xh_Kf65THktNzxIJIz-oLcjnAJWvD-pMNTDUint3s3drnqRdrglx0o8SkHjgeWpHx-yDxRdRwm8pTGYRqV6IZpyUQSB7UQ4PAlAPBH_6J4I7n92PbyBqpdovikH-MwkOcAe1lcI2nBymjpvRW_MHvRdRvATkgD02-hWv1b5Xj4HQFU83bhGThhGB8Zxs0cw1FRnka9L69IoEcHbEAcHXBzzap-u3WvLdWcoG7XcHeqR0QYhSRzswWFWrJn6PoaULzqubAA5EO1HRBNcE8ow_-Hx6DtLL7xHviLnttVbx849ZHb35c0wfwPQc05pDkJNNMwK74raHqB_z1oLpJNL8mecDFMnl79BM9vT8-ZQHSa-JnB9Azi80H1DOLzwfUM4vNBdqL4ecH2DJHPB90ziM8H3zOIzwfhM4h_AxifQ30uJ5_QvufmaX79xOcz4_NbZT0Mu8-s_7LXQDHE9kzfHVr2-AsuWDFWE7n1bAzvbkBh25IRipUUd0AKW_fqBw7gzUDbB2IeiHsHtQ4euRfJpSP3Xz_8vhlv-9LDF-eHb80tkbVgZmRxaK_AsR44-RWVdqKH2UCgfFZW7tt90LEVVU0TkIqjrexdWKDvEnEk6RcQasUMdOfcoh25YeDUHap500D0cvhSLZX2hdBE2Z3Z0yPdIfYjYcbhsn4899hs0CIN_2B_9UR-6tGSraMsS9IYx2myrNdJXSYlWVpuBVu_H7Lt6AlEfAJdb_ZN43H49SDqFiD8nMkvQ4zrCG46gS9dJbdGgi_fAobt2Tt_ij4cuKWtm1H04OnVp4v3r69HULvmxoLT8bLXYj15YYUb0_uVFZznZbls1xnJYwKvetwkZRxSXNVZUrOySDDBUYbTJXROJswaPATRgVj91Bx2-j7-h2sd8GWj9A6cOnBZq4PxgV4t-ToO4zgsozxKkzSMA9hHcVHFTZ5TTCiBtDMY2sT94slSr733kDgDNwUE_rCysiQgvIXZpfcM7JPetkqvd0DM2nxWSx_p2of5D1DGUEw">