mirror of
https://github.com/chromium/crashpad.git
synced 2025-03-10 06:36:02 +00:00
crashy_program's log looks something like this now: 0:000> .ecxr eax=00000007 ebx=7f24e000 ecx=7f24d000 edx=00000000 esi=00497ec8 edi=00d39ca0 eip=00cf5d12 esp=001ffcd8 ebp=001ffcdc iopl=0 nv up ei ng nz ac po cy cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00010293 crashy_program+0x5d12: 00cf5d12 ?? ??? 0:000> !teb TEB at 7f24d000 ExceptionList: 001ff548 StackBase: 00200000 StackLimit: 001fd000 SubSystemTib: 00000000 FiberData: 00001e00 ArbitraryUserPointer: 00000000 Self: 7f24d000 EnvironmentPointer: 00000000 ClientId: 00003658 . 00004630 RpcHandle: 00000000 Tls Storage: 7f24d02c PEB Address: 7f24e000 LastErrorValue: 2 LastStatusValue: c000000f Count Owned Locks: 0 HardErrorMode: 0 0:000> !gle LastErrorValue: (Win32) 0x2 (2) - The system cannot find the file specified. LastStatusValue: (NTSTATUS) 0xc000000f - {File Not Found} The file %hs does not exist. R=mark@chromium.org BUG=crashpad:46 Review URL: https://codereview.chromium.org/1364803004 .
75 lines
2.2 KiB
C++
75 lines
2.2 KiB
C++
// Copyright 2015 The Crashpad Authors. All rights reserved.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#include <windows.h>
|
|
#include <winternl.h>
|
|
|
|
// ntstatus.h conflicts with windows.h so define this locally.
|
|
#ifndef STATUS_NO_SUCH_FILE
|
|
#define STATUS_NO_SUCH_FILE static_cast<NTSTATUS>(0xC000000F)
|
|
#endif
|
|
|
|
#include "base/logging.h"
|
|
#include "client/crashpad_client.h"
|
|
#include "tools/tool_support.h"
|
|
|
|
namespace crashpad {
|
|
namespace {
|
|
|
|
ULONG RtlNtStatusToDosError(NTSTATUS status) {
|
|
static decltype(::RtlNtStatusToDosError)* rtl_nt_status_to_dos_error =
|
|
reinterpret_cast<decltype(::RtlNtStatusToDosError)*>(
|
|
GetProcAddress(LoadLibrary(L"ntdll.dll"), "RtlNtStatusToDosError"));
|
|
DCHECK(rtl_nt_status_to_dos_error);
|
|
return rtl_nt_status_to_dos_error(status);
|
|
}
|
|
|
|
void SomeCrashyFunction() {
|
|
// SetLastError and NTSTATUS so that we have something to view in !gle in
|
|
// windbg. RtlNtStatusToDosError() stores STATUS_NO_SUCH_FILE into the
|
|
// LastStatusError of the TEB as a side-effect, and we'll be setting
|
|
// ERROR_FILE_NOT_FOUND for GetLastError().
|
|
SetLastError(RtlNtStatusToDosError(STATUS_NO_SUCH_FILE));
|
|
volatile int* foo = reinterpret_cast<volatile int*>(7);
|
|
*foo = 42;
|
|
}
|
|
|
|
int CrashyMain(int argc, char* argv[]) {
|
|
if (argc != 2) {
|
|
fprintf(stderr, "Usage: %s <server_pipe_name>\n", argv[0]);
|
|
return 1;
|
|
}
|
|
|
|
CrashpadClient client;
|
|
if (!client.SetHandler(argv[1])) {
|
|
LOG(ERROR) << "SetHandler";
|
|
return 1;
|
|
}
|
|
if (!client.UseHandler()) {
|
|
LOG(ERROR) << "UseHandler";
|
|
return 1;
|
|
}
|
|
|
|
SomeCrashyFunction();
|
|
|
|
return 0;
|
|
}
|
|
|
|
} // namespace
|
|
} // namespace crashpad
|
|
|
|
int wmain(int argc, wchar_t* argv[]) {
|
|
return crashpad::ToolSupport::Wmain(argc, argv, crashpad::CrashyMain);
|
|
}
|