diff options
| author | Martin Storsjö <martin@martin.st> | 2019-10-28 10:28:26 +0200 |
|---|---|---|
| committer | Martin Storsjö <martin@martin.st> | 2019-10-31 11:26:20 +0200 |
| commit | 403cd574b6d9fbdae1b39fe9d2576b02c7139486 (patch) | |
| tree | 483a5a1092f0179136dbc6476999428621d034ca /lldb/test/Shell/Process/Windows | |
| parent | 3db1d138b1172b5855f35ab74dbf3bf327f517d2 (diff) | |
| download | bcm5719-llvm-403cd574b6d9fbdae1b39fe9d2576b02c7139486.tar.gz bcm5719-llvm-403cd574b6d9fbdae1b39fe9d2576b02c7139486.zip | |
[LLDB] [Windows] Fix Windows-specific race condition in LLDB for session lifetime
This can e.g. happen if the debugged executable exits before the initial
stop, e.g. if it fails to load dependent DLLs.
Add a virtual destructor to ProcessDebugger and let it clean up the
session, and make ProcessWindows::OnExitProcess call
ProcessDebugger::OnExitProcess for shared parts.
Fix suggestion by Adrian McCarthy.
Differential Revision: https://reviews.llvm.org/D69503
Diffstat (limited to 'lldb/test/Shell/Process/Windows')
| -rw-r--r-- | lldb/test/Shell/Process/Windows/launch_failure.yaml | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/lldb/test/Shell/Process/Windows/launch_failure.yaml b/lldb/test/Shell/Process/Windows/launch_failure.yaml new file mode 100644 index 00000000000..be723ef7621 --- /dev/null +++ b/lldb/test/Shell/Process/Windows/launch_failure.yaml @@ -0,0 +1,90 @@ +## Test that we don't crash when the process fails to launch before reaching +## the initial stop. This test exe has a dependency on NonExistent.dll. + +# REQUIRES: system-windows +# REQUIRES: native && target-x86_64 + +# RUN: yaml2obj %s > %t.exe +# RUN: %lldb %t.exe -o run 2>&1 | FileCheck %s + +# CHECK: error: process launch failed: unknown error + +--- !COFF +OptionalHeader: + AddressOfEntryPoint: 4096 + ImageBase: 1073741824 + SectionAlignment: 4096 + FileAlignment: 512 + MajorOperatingSystemVersion: 6 + MinorOperatingSystemVersion: 0 + MajorImageVersion: 0 + MinorImageVersion: 0 + MajorSubsystemVersion: 6 + MinorSubsystemVersion: 0 + Subsystem: IMAGE_SUBSYSTEM_WINDOWS_CUI + DLLCharacteristics: [ IMAGE_DLL_CHARACTERISTICS_HIGH_ENTROPY_VA, IMAGE_DLL_CHARACTERISTICS_DYNAMIC_BASE, IMAGE_DLL_CHARACTERISTICS_NX_COMPAT, IMAGE_DLL_CHARACTERISTICS_TERMINAL_SERVER_AWARE ] + SizeOfStackReserve: 1048576 + SizeOfStackCommit: 4096 + SizeOfHeapReserve: 1048576 + SizeOfHeapCommit: 4096 + ExportTable: + RelativeVirtualAddress: 0 + Size: 0 + ImportTable: + RelativeVirtualAddress: 8192 + Size: 40 + ResourceTable: + RelativeVirtualAddress: 0 + Size: 0 + ExceptionTable: + RelativeVirtualAddress: 0 + Size: 0 + CertificateTable: + RelativeVirtualAddress: 0 + Size: 0 + BaseRelocationTable: + RelativeVirtualAddress: 0 + Size: 0 + Debug: + RelativeVirtualAddress: 0 + Size: 0 + Architecture: + RelativeVirtualAddress: 0 + Size: 0 + GlobalPtr: + RelativeVirtualAddress: 0 + Size: 0 + TlsTable: + RelativeVirtualAddress: 0 + Size: 0 + LoadConfigTable: + RelativeVirtualAddress: 0 + Size: 0 + BoundImport: + RelativeVirtualAddress: 0 + Size: 0 + IAT: + RelativeVirtualAddress: 8248 + Size: 16 + DelayImportDescriptor: + RelativeVirtualAddress: 0 + Size: 0 + ClrRuntimeHeader: + RelativeVirtualAddress: 0 + Size: 0 +header: + Machine: IMAGE_FILE_MACHINE_AMD64 + Characteristics: [ IMAGE_FILE_EXECUTABLE_IMAGE, IMAGE_FILE_LARGE_ADDRESS_AWARE ] +sections: + - Name: .text + Characteristics: [ IMAGE_SCN_CNT_CODE, IMAGE_SCN_MEM_EXECUTE, IMAGE_SCN_MEM_READ ] + VirtualAddress: 4096 + VirtualSize: 7 + SectionData: 48FF2531100000 + - Name: .rdata + Characteristics: [ IMAGE_SCN_CNT_INITIALIZED_DATA, IMAGE_SCN_MEM_READ ] + VirtualAddress: 8192 + VirtualSize: 96 + SectionData: 282000000000000000000000502000003820000000000000000000000000000000000000000000004820000000000000000000000000000048200000000000000000000000000000000066756E6300004E6F6E4578697374656E742E646C6C00 +symbols: [] +... |

