diff --git a/lldb/source/Plugins/Process/minidump/ProcessMinidump.cpp b/lldb/source/Plugins/Process/minidump/ProcessMinidump.cpp --- a/lldb/source/Plugins/Process/minidump/ProcessMinidump.cpp +++ b/lldb/source/Plugins/Process/minidump/ProcessMinidump.cpp @@ -226,10 +226,10 @@ llvm::Optional pid = m_minidump_parser->GetPid(); if (!pid) { - error.SetErrorString("failed to parse PID"); - return error; - } - SetID(pid.getValue()); + GetTarget().GetDebugger().GetAsyncErrorStream()->PutCString( + "Unable to retrieve process ID from minidump file.\n"); + } else + SetID(pid.getValue()); return error; } diff --git a/lldb/source/Target/Process.cpp b/lldb/source/Target/Process.cpp --- a/lldb/source/Target/Process.cpp +++ b/lldb/source/Target/Process.cpp @@ -5428,23 +5428,30 @@ } void Process::GetStatus(Stream &strm) { + llvm::raw_ostream &OS = strm.AsRawOstream(); const StateType state = GetState(); + if (state == eStateConnected) { + OS << "Connected to remote target.\n"; + return; + } + + OS << "Process "; + if (GetID() != LLDB_INVALID_PROCESS_ID) + OS << GetID() << ' '; + if (StateIsStoppedState(state, false)) { if (state == eStateExited) { int exit_status = GetExitStatus(); const char *exit_description = GetExitDescription(); - strm.Printf("Process %" PRIu64 " exited with status = %i (0x%8.8x) %s\n", - GetID(), exit_status, exit_status, - exit_description ? exit_description : ""); + OS << llvm::format("exited with status = %i (0x%8.8x) %s", exit_status, + exit_status, exit_description ? exit_description : ""); } else { - if (state == eStateConnected) - strm.Printf("Connected to remote target.\n"); - else - strm.Printf("Process %" PRIu64 " %s\n", GetID(), StateAsCString(state)); + OS << llvm::formatv("{0}", state); } } else { - strm.Printf("Process %" PRIu64 " is running.\n", GetID()); + OS << "is running."; } + OS << "\n"; } size_t Process::GetThreadStatus(Stream &strm, diff --git a/lldb/test/Shell/Minidump/no-process-id.yaml b/lldb/test/Shell/Minidump/no-process-id.yaml new file mode 100644 --- /dev/null +++ b/lldb/test/Shell/Minidump/no-process-id.yaml @@ -0,0 +1,38 @@ +# RUN: yaml2obj %s > %t +# RUN: %lldb -c %t -o "thread list" -o "register read" -b 2>&1 | FileCheck %s + +# CHECK: (lldb) target create --core +# CHECK: Unable to retrieve process ID from minidump file. +# CHECK: Core file {{.*}} was loaded. + +# CHECK: (lldb) thread list +# CHECK: Process stopped +# CHECK: * thread #1: tid = 16001, 0x0000000000401dc6 a.out + +# CHECK: (lldb) register read +# CHECK: rsp = 0x00007ffceb34a210 + +--- !minidump +Streams: + - Type: ThreadList + Threads: + - Thread Id: 0x00003E81 + Context: 0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000B0010000000000033000000000000000000000006020100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000010A234EBFC7F000010A234EBFC7F00000000000000000000F09C34EBFC7F0000C0A91ABCE97F00000000000000000000A0163FBCE97F00004602000000000000921C40000000000030A434EBFC7F000000000000000000000000000000000000C61D4000000000007F0300000000000000000000000000000000000000000000801F0000FFFF0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000FFFF00FFFFFFFFFFFFFF00FFFFFFFF25252525252525252525252525252525000000000000000000000000000000000000000000000000000000000000000000FFFF00FFFFFFFFFFFFFF00FFFFFFFF0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000FF00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + Stack: + Start of Memory Range: 0x00007FFCEB34A000 + Content: '' + - Type: ModuleList + Modules: + - Base of Image: 0x0000000000400000 + Size of Image: 0x00017000 + Module Name: 'a.out' + CodeView Record: '' + - Type: SystemInfo + Processor Arch: AMD64 + Platform ID: Linux + CSD Version: 'Linux 3.13' + CPU: + Vendor ID: GenuineIntel + Version Info: 0x00000000 + Feature Info: 0x00000000 +...