mirror of
https://github.com/chromium/crashpad.git
synced 2025-01-21 15:11:37 +08:00
0567536f86
I haven't been able to reproduce this locally, but we see errors in crash dumps where the unloaded module list consists of a number of modules with invalid names and implausible addresses. My assumption is that RTL_UNLOAD_EVENT_TRACE isn't correct for some OS levels. Instead of trying to finesse and test that, use RtlGetUnloadEventTraceEx() instead of RtlGetUnloadEventTrace(), which returns an element size. (This function is Vista+ which is why it wasn't used the first time around.) R=mark@chromium.org BUG=chromium:620175 Change-Id: I4d7080a03623276f9c1c038d6e7329af70e4a64c Reviewed-on: https://chromium-review.googlesource.com/421564 Reviewed-by: Mark Mentovai <mark@chromium.org>
94 lines
3.3 KiB
C++
94 lines
3.3 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>
|
|
|
|
#include "util/win/process_structs.h"
|
|
|
|
namespace crashpad {
|
|
|
|
NTSTATUS NtClose(HANDLE handle);
|
|
|
|
// http://processhacker.sourceforge.net/doc/ntpsapi_8h_source.html
|
|
#define THREAD_CREATE_FLAGS_SKIP_THREAD_ATTACH 0x00000002
|
|
NTSTATUS
|
|
NtCreateThreadEx(PHANDLE thread_handle,
|
|
ACCESS_MASK desired_access,
|
|
POBJECT_ATTRIBUTES object_attributes,
|
|
HANDLE process_handle,
|
|
PVOID start_routine,
|
|
PVOID argument,
|
|
ULONG create_flags,
|
|
SIZE_T zero_bits,
|
|
SIZE_T stack_size,
|
|
SIZE_T maximum_stack_size,
|
|
PVOID /*PPS_ATTRIBUTE_LIST*/ attribute_list);
|
|
|
|
// Copied from ntstatus.h because um/winnt.h conflicts with general inclusion of
|
|
// ntstatus.h.
|
|
#define STATUS_BUFFER_TOO_SMALL ((NTSTATUS)0xC0000023L)
|
|
#define STATUS_INFO_LENGTH_MISMATCH ((NTSTATUS)0xC0000004L)
|
|
|
|
// winternal.h defines THREADINFOCLASS, but not all members.
|
|
enum { ThreadBasicInformation = 0 };
|
|
|
|
// winternal.h defines SYSTEM_INFORMATION_CLASS, but not all members.
|
|
enum { SystemExtendedHandleInformation = 64 };
|
|
|
|
NTSTATUS NtQuerySystemInformation(
|
|
SYSTEM_INFORMATION_CLASS system_information_class,
|
|
PVOID system_information,
|
|
ULONG system_information_length,
|
|
PULONG return_length);
|
|
|
|
NTSTATUS NtQueryInformationThread(HANDLE thread_handle,
|
|
THREADINFOCLASS thread_information_class,
|
|
PVOID thread_information,
|
|
ULONG thread_information_length,
|
|
PULONG return_length);
|
|
|
|
template <class Traits>
|
|
NTSTATUS NtOpenThread(PHANDLE thread_handle,
|
|
ACCESS_MASK desired_access,
|
|
POBJECT_ATTRIBUTES object_attributes,
|
|
const process_types::CLIENT_ID<Traits>* client_id);
|
|
|
|
NTSTATUS NtQueryObject(HANDLE handle,
|
|
OBJECT_INFORMATION_CLASS object_information_class,
|
|
void* object_information,
|
|
ULONG object_information_length,
|
|
ULONG* return_length);
|
|
|
|
NTSTATUS NtSuspendProcess(HANDLE handle);
|
|
|
|
NTSTATUS NtResumeProcess(HANDLE handle);
|
|
|
|
// From https://msdn.microsoft.com/en-us/library/cc678403(v=vs.85).aspx.
|
|
template <class Traits>
|
|
struct RTL_UNLOAD_EVENT_TRACE {
|
|
typename Traits::Pointer BaseAddress;
|
|
typename Traits::UnsignedIntegral SizeOfImage;
|
|
ULONG Sequence;
|
|
ULONG TimeDateStamp;
|
|
ULONG CheckSum;
|
|
WCHAR ImageName[32];
|
|
};
|
|
|
|
void RtlGetUnloadEventTraceEx(ULONG** element_size,
|
|
ULONG** element_count,
|
|
void** event_trace);
|
|
|
|
} // namespace crashpad
|