| Index: components/breakpad/app/breakpad_win.cc
|
| diff --git a/components/breakpad/app/breakpad_win.cc b/components/breakpad/app/breakpad_win.cc
|
| index a493d2687dc8816259de9024cb9016af239d5d47..1f6a3c49a93b5f4fc3ab90331d8bba0c800c7832 100644
|
| --- a/components/breakpad/app/breakpad_win.cc
|
| +++ b/components/breakpad/app/breakpad_win.cc
|
| @@ -33,6 +33,7 @@
|
| #include "base/win/win_util.h"
|
| #include "breakpad/src/client/windows/handler/exception_handler.h"
|
| #include "components/breakpad/app/breakpad_client.h"
|
| +#include "components/breakpad/app/crash_keys_win.h"
|
| #include "components/breakpad/app/hard_error_handler_win.h"
|
| #include "content/public/common/result_codes.h"
|
| #include "sandbox/win/src/nt_internals.h"
|
| @@ -46,55 +47,6 @@
|
|
|
| namespace breakpad {
|
|
|
| -// Manages the breakpad key/value pair stash, there may only be one instance
|
| -// of this class per process at one time.
|
| -class CrashKeysWin {
|
| - public:
|
| - CrashKeysWin();
|
| - ~CrashKeysWin();
|
| -
|
| - // May only be called once.
|
| - google_breakpad::CustomClientInfo*
|
| - GetCustomInfo(const std::wstring& exe_path, const std::wstring& type);
|
| -
|
| - void SetCrashKeyValue(const std::wstring& key, const std::wstring& value);
|
| - void ClearCrashKeyValue(const std::wstring& key);
|
| -
|
| - static CrashKeysWin* keeper() { return keeper_; }
|
| -
|
| - private:
|
| - // One-time initialization of private key/value pairs.
|
| - void SetPluginPath(const std::wstring& path);
|
| - void SetBreakpadDumpPath();
|
| -
|
| - // Must not be resized after GetCustomInfo is invoked.
|
| - std::vector<google_breakpad::CustomInfoEntry> custom_entries_;
|
| -
|
| - typedef std::map<std::wstring, google_breakpad::CustomInfoEntry*>
|
| - DynamicEntriesMap;
|
| - base::Lock lock_;
|
| - // Keeps track of the next index for a new dynamic entry.
|
| - size_t dynamic_keys_offset_; // Under lock_.
|
| - // Maintains key->entry information for dynamic key/value entries
|
| - // in custom_entries_.
|
| - DynamicEntriesMap dynamic_entries_; // Under lock_.
|
| -
|
| - // Stores the sole instance of this class allowed per process.
|
| - static CrashKeysWin* keeper_;
|
| -};
|
| -
|
| -CrashKeysWin* CrashKeysWin::keeper_;
|
| -
|
| -CrashKeysWin::CrashKeysWin() : dynamic_keys_offset_(0) {
|
| - DCHECK_EQ(static_cast<CrashKeysWin*>(NULL), keeper_);
|
| - keeper_ = this;
|
| -}
|
| -
|
| -CrashKeysWin::~CrashKeysWin() {
|
| - DCHECK_EQ(this, keeper_);
|
| - keeper_ = NULL;
|
| -}
|
| -
|
| namespace {
|
|
|
| // Minidump with stacks, PEB, TEB, and unloaded module list.
|
| @@ -134,14 +86,6 @@ typedef NTSTATUS (WINAPI* NtTerminateProcessPtr)(HANDLE ProcessHandle,
|
| NTSTATUS ExitStatus);
|
| char* g_real_terminate_process_stub = NULL;
|
|
|
| -
|
| -// Allow for 256 dynamic entries in addition to the fixed set of entries
|
| -// set up in this file.
|
| -const size_t kMaxDynamicEntries = 256;
|
| -
|
| -// Maximum length for plugin path to include in plugin crash reports.
|
| -const size_t kMaxPluginPathLength = 256;
|
| -
|
| } // namespace
|
|
|
| // Dumps the current process memory.
|
| @@ -201,43 +145,6 @@ InjectDumpForHangDebugging(HANDLE process) {
|
| 0, 0, NULL);
|
| }
|
|
|
| -// Appends the plugin path to |g_custom_entries|.
|
| -void CrashKeysWin::SetPluginPath(const std::wstring& path) {
|
| - if (path.size() > kMaxPluginPathLength) {
|
| - // If the path is too long, truncate from the start rather than the end,
|
| - // since we want to be able to recover the DLL name.
|
| - SetPluginPath(path.substr(path.size() - kMaxPluginPathLength));
|
| - return;
|
| - }
|
| -
|
| - // The chunk size without terminator.
|
| - const size_t kChunkSize = static_cast<size_t>(
|
| - google_breakpad::CustomInfoEntry::kValueMaxLength - 1);
|
| -
|
| - int chunk_index = 0;
|
| - size_t chunk_start = 0; // Current position inside |path|
|
| -
|
| - for (chunk_start = 0; chunk_start < path.size(); chunk_index++) {
|
| - size_t chunk_length = std::min(kChunkSize, path.size() - chunk_start);
|
| -
|
| - custom_entries_.push_back(google_breakpad::CustomInfoEntry(
|
| - base::StringPrintf(L"plugin-path-chunk-%i", chunk_index + 1).c_str(),
|
| - path.substr(chunk_start, chunk_length).c_str()));
|
| -
|
| - chunk_start += chunk_length;
|
| - }
|
| -}
|
| -
|
| -// Appends the breakpad dump path to |g_custom_entries|.
|
| -void CrashKeysWin::SetBreakpadDumpPath() {
|
| - base::FilePath crash_dumps_dir_path;
|
| - if (GetBreakpadClient()->GetAlternativeCrashDumpLocation(
|
| - &crash_dumps_dir_path)) {
|
| - custom_entries_.push_back(google_breakpad::CustomInfoEntry(
|
| - L"breakpad-dump-location", crash_dumps_dir_path.value().c_str()));
|
| - }
|
| -}
|
| -
|
| // Returns a string containing a list of all modifiers for the loaded profile.
|
| std::wstring GetProfileType() {
|
| std::wstring profile_type;
|
| @@ -267,79 +174,6 @@ std::wstring GetProfileType() {
|
| return profile_type;
|
| }
|
|
|
| -// Returns the custom info structure based on the dll in parameter and the
|
| -// process type.
|
| -google_breakpad::CustomClientInfo*
|
| -CrashKeysWin::GetCustomInfo(const std::wstring& exe_path,
|
| - const std::wstring& type) {
|
| - base::string16 version, product;
|
| - base::string16 special_build;
|
| - base::string16 channel_name;
|
| - GetBreakpadClient()->GetProductNameAndVersion(
|
| - base::FilePath(exe_path),
|
| - &product,
|
| - &version,
|
| - &special_build,
|
| - &channel_name);
|
| -
|
| - // We only expect this method to be called once per process.
|
| - // Common enties
|
| - custom_entries_.push_back(
|
| - google_breakpad::CustomInfoEntry(L"ver", version.c_str()));
|
| - custom_entries_.push_back(
|
| - google_breakpad::CustomInfoEntry(L"prod", product.c_str()));
|
| - custom_entries_.push_back(
|
| - google_breakpad::CustomInfoEntry(L"plat", L"Win32"));
|
| - custom_entries_.push_back(
|
| - google_breakpad::CustomInfoEntry(L"ptype", type.c_str()));
|
| - custom_entries_.push_back(google_breakpad::CustomInfoEntry(
|
| - L"pid", base::StringPrintf(L"%d", ::GetCurrentProcessId()).c_str()));
|
| - custom_entries_.push_back(google_breakpad::CustomInfoEntry(
|
| - L"channel", channel_name.c_str()));
|
| - custom_entries_.push_back(google_breakpad::CustomInfoEntry(
|
| - L"profile-type", GetProfileType().c_str()));
|
| -
|
| - if (!special_build.empty()) {
|
| - custom_entries_.push_back(google_breakpad::CustomInfoEntry(
|
| - L"special", special_build.c_str()));
|
| - }
|
| -
|
| - if (type == L"plugin" || type == L"ppapi") {
|
| - std::wstring plugin_path =
|
| - CommandLine::ForCurrentProcess()->GetSwitchValueNative("plugin-path");
|
| - if (!plugin_path.empty())
|
| - SetPluginPath(plugin_path);
|
| - }
|
| -
|
| - // Check whether configuration management controls crash reporting.
|
| - bool crash_reporting_enabled = true;
|
| - bool controlled_by_policy = GetBreakpadClient()->ReportingIsEnforcedByPolicy(
|
| - &crash_reporting_enabled);
|
| - const CommandLine& command = *CommandLine::ForCurrentProcess();
|
| - bool use_crash_service =
|
| - !controlled_by_policy && (command.HasSwitch(switches::kNoErrorDialogs) ||
|
| - GetBreakpadClient()->IsRunningUnattended());
|
| - if (use_crash_service)
|
| - SetBreakpadDumpPath();
|
| -
|
| - // Create space for dynamic ad-hoc keys. The names and values are set using
|
| - // the API defined in base/debug/crash_logging.h.
|
| - dynamic_keys_offset_ = custom_entries_.size();
|
| - for (size_t i = 0; i < kMaxDynamicEntries; ++i) {
|
| - // The names will be mutated as they are set. Un-numbered since these are
|
| - // merely placeholders. The name cannot be empty because Breakpad's
|
| - // HTTPUpload will interpret that as an invalid parameter.
|
| - custom_entries_.push_back(
|
| - google_breakpad::CustomInfoEntry(L"unspecified-crash-key", L""));
|
| - }
|
| -
|
| - static google_breakpad::CustomClientInfo custom_client_info;
|
| - custom_client_info.entries = &custom_entries_.front();
|
| - custom_client_info.count = custom_entries_.size();
|
| -
|
| - return &custom_client_info;
|
| -}
|
| -
|
| namespace {
|
|
|
| // This callback is used when we want to get a dump without crashing the
|
| @@ -433,35 +267,6 @@ long WINAPI ServiceExceptionFilter(EXCEPTION_POINTERS* info) {
|
|
|
| } // namespace
|
|
|
| -void CrashKeysWin::SetCrashKeyValue(
|
| - const std::wstring& key, const std::wstring& value) {
|
| - // CustomInfoEntry limits the length of key and value. If they exceed
|
| - // their maximum length the underlying string handling functions raise
|
| - // an exception and prematurely trigger a crash. Truncate here.
|
| - std::wstring safe_key(std::wstring(key).substr(
|
| - 0, google_breakpad::CustomInfoEntry::kNameMaxLength - 1));
|
| - std::wstring safe_value(std::wstring(value).substr(
|
| - 0, google_breakpad::CustomInfoEntry::kValueMaxLength - 1));
|
| -
|
| - // If we already have a value for this key, update it; otherwise, insert
|
| - // the new value if we have not exhausted the pre-allocated slots for dynamic
|
| - // entries.
|
| - base::AutoLock lock(lock_);
|
| -
|
| - DynamicEntriesMap::iterator it = dynamic_entries_.find(safe_key);
|
| - google_breakpad::CustomInfoEntry* entry = NULL;
|
| - if (it == dynamic_entries_.end()) {
|
| - if (dynamic_entries_.size() >= kMaxDynamicEntries)
|
| - return;
|
| - entry = &custom_entries_[dynamic_keys_offset_++];
|
| - dynamic_entries_.insert(std::make_pair(safe_key, entry));
|
| - } else {
|
| - entry = it->second;
|
| - }
|
| -
|
| - entry->set(safe_key.data(), safe_value.data());
|
| -}
|
| -
|
| // NOTE: This function is used by SyzyASAN to annotate crash reports. If you
|
| // change the name or signature of this function you will break SyzyASAN
|
| // instrumented releases of Chrome. Please contact syzygy-team@chromium.org
|
| @@ -477,17 +282,6 @@ extern "C" void __declspec(dllexport) __cdecl SetCrashKeyValueImpl(
|
| keeper->SetCrashKeyValue(key, value);
|
| }
|
|
|
| -void CrashKeysWin::ClearCrashKeyValue(const std::wstring& key) {
|
| - base::AutoLock lock(lock_);
|
| -
|
| - std::wstring key_string(key);
|
| - DynamicEntriesMap::iterator it = dynamic_entries_.find(key_string);
|
| - if (it == dynamic_entries_.end())
|
| - return;
|
| -
|
| - it->second->set_value(NULL);
|
| -}
|
| -
|
| extern "C" void __declspec(dllexport) __cdecl ClearCrashKeyValueImpl(
|
| const wchar_t* key) {
|
| CrashKeysWin* keeper = CrashKeysWin::keeper();
|
| @@ -709,7 +503,9 @@ void InitCrashReporter(const std::string& process_type_switch) {
|
| CrashKeysWin* keeper = new CrashKeysWin();
|
|
|
| google_breakpad::CustomClientInfo* custom_info =
|
| - keeper->GetCustomInfo(exe_path, process_type);
|
| + keeper->GetCustomInfo(exe_path, process_type,
|
| + GetProfileType(), CommandLine::ForCurrentProcess(),
|
| + GetBreakpadClient());
|
|
|
| google_breakpad::ExceptionHandler::MinidumpCallback callback = NULL;
|
| LPTOP_LEVEL_EXCEPTION_FILTER default_filter = NULL;
|
|
|