mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			614 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			614 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| diff --git chrome/common/crash_keys.cc chrome/common/crash_keys.cc
 | |
| index e0a839813a07..5c0d05bcc78c 100644
 | |
| --- chrome/common/crash_keys.cc
 | |
| +++ chrome/common/crash_keys.cc
 | |
| @@ -4,6 +4,8 @@
 | |
|  
 | |
|  #include "chrome/common/crash_keys.h"
 | |
|  
 | |
| +#include <iterator>
 | |
| +
 | |
|  #include "base/base_switches.h"
 | |
|  #include "base/command_line.h"
 | |
|  #include "base/logging.h"
 | |
| @@ -26,7 +28,7 @@
 | |
|  
 | |
|  namespace crash_keys {
 | |
|  
 | |
| -static bool IsBoringSwitch(const std::string& flag) {
 | |
| +bool IsBoringChromeSwitch(const std::string& flag) {
 | |
|    static const char* const kIgnoreSwitches[] = {
 | |
|      switches::kEnableLogging,
 | |
|      switches::kFlagSwitchesBegin,
 | |
| @@ -77,7 +79,7 @@ static bool IsBoringSwitch(const std::string& flag) {
 | |
|  }
 | |
|  
 | |
|  void SetCrashKeysFromCommandLine(const base::CommandLine& command_line) {
 | |
| -  return SetSwitchesFromCommandLine(command_line, &IsBoringSwitch);
 | |
| +  return SetSwitchesFromCommandLine(command_line, &IsBoringChromeSwitch);
 | |
|  }
 | |
|  
 | |
|  void SetActiveExtensions(const std::set<std::string>& extensions) {
 | |
| diff --git chrome/common/crash_keys.h chrome/common/crash_keys.h
 | |
| index bcf172e645a2..f879aa745adf 100644
 | |
| --- chrome/common/crash_keys.h
 | |
| +++ chrome/common/crash_keys.h
 | |
| @@ -17,6 +17,10 @@ class CommandLine;
 | |
|  
 | |
|  namespace crash_keys {
 | |
|  
 | |
| +// Returns true if the specified command-line flag should be excluded from
 | |
| +// crash reporting.
 | |
| +bool IsBoringChromeSwitch(const std::string& flag);
 | |
| +
 | |
|  // Sets the kNumSwitches key and the set of keys named using kSwitchFormat based
 | |
|  // on the given |command_line|.
 | |
|  void SetCrashKeysFromCommandLine(const base::CommandLine& command_line);
 | |
| diff --git chrome_elf/BUILD.gn chrome_elf/BUILD.gn
 | |
| index 61efc526eed9..b8d101eda7fd 100644
 | |
| --- chrome_elf/BUILD.gn
 | |
| +++ chrome_elf/BUILD.gn
 | |
| @@ -7,6 +7,7 @@
 | |
|  
 | |
|  import("//build/config/compiler/compiler.gni")
 | |
|  import("//build/config/win/manifest.gni")
 | |
| +import("//cef/libcef/features/features.gni")
 | |
|  import("//chrome/process_version_rc_template.gni")
 | |
|  import("//testing/test.gni")
 | |
|  
 | |
| @@ -126,9 +127,6 @@ source_set("constants") {
 | |
|  
 | |
|  static_library("crash") {
 | |
|    sources = [
 | |
| -    "../chrome/app/chrome_crash_reporter_client_win.cc",
 | |
| -    "../chrome/app/chrome_crash_reporter_client_win.h",
 | |
| -    "../chrome/common/chrome_result_codes.h",
 | |
|      "crash/crash_helper.cc",
 | |
|      "crash/crash_helper.h",
 | |
|    ]
 | |
| @@ -136,6 +134,7 @@ static_library("crash") {
 | |
|      ":hook_util",
 | |
|      "//base",  # This needs to go.  DEP of app, crash_keys, client.
 | |
|      "//base:base_static",  # pe_image
 | |
| +    "//cef/libcef/features",
 | |
|      "//chrome/install_static:install_static_util",
 | |
|      "//components/crash/content/app",
 | |
|      "//components/crash/core/common",  # crash_keys
 | |
| @@ -143,6 +142,17 @@ static_library("crash") {
 | |
|      "//content/public/common:result_codes",
 | |
|      "//third_party/crashpad/crashpad/client",  # DumpWithoutCrash
 | |
|    ]
 | |
| +
 | |
| +  if (enable_cef) {
 | |
| +    deps += [ "//cef:chrome_elf_set" ]
 | |
| +    include_dirs = [ "//cef" ]
 | |
| +  } else {
 | |
| +    sources += [
 | |
| +      "//chrome/app/chrome_crash_reporter_client_win.cc",
 | |
| +      "//chrome/app/chrome_crash_reporter_client_win.h",
 | |
| +      "//chrome/common/chrome_result_codes.h",
 | |
| +    ]
 | |
| +  }
 | |
|  }
 | |
|  
 | |
|  source_set("dll_hash") {
 | |
| diff --git chrome_elf/crash/crash_helper.cc chrome_elf/crash/crash_helper.cc
 | |
| index fdc51ab22807..cb0a99dd190c 100644
 | |
| --- chrome_elf/crash/crash_helper.cc
 | |
| +++ chrome_elf/crash/crash_helper.cc
 | |
| @@ -11,12 +11,17 @@
 | |
|  #include <string>
 | |
|  #include <vector>
 | |
|  
 | |
| +#include "cef/libcef/features/features.h"
 | |
|  #include "chrome/app/chrome_crash_reporter_client_win.h"
 | |
|  #include "chrome_elf/hook_util/hook_util.h"
 | |
|  #include "components/crash/content/app/crashpad.h"
 | |
|  #include "components/crash/core/common/crash_keys.h"
 | |
|  #include "third_party/crashpad/crashpad/client/crashpad_client.h"
 | |
|  
 | |
| +#if BUILDFLAG(ENABLE_CEF)
 | |
| +#include "cef/libcef/common/crash_reporter_client.h"
 | |
| +#endif
 | |
| +
 | |
|  namespace {
 | |
|  
 | |
|  // Crash handling from elf is only enabled for the chrome.exe process.
 | |
| @@ -74,7 +79,11 @@ bool InitializeCrashReporting() {
 | |
|    g_crash_reports = new std::vector<crash_reporter::Report>;
 | |
|    g_set_unhandled_exception_filter = new elf_hook::IATHook();
 | |
|  
 | |
| +#if BUILDFLAG(ENABLE_CEF)
 | |
| +  CefCrashReporterClient::InitializeCrashReportingForProcess();
 | |
| +#else
 | |
|    ChromeCrashReporterClient::InitializeCrashReportingForProcess();
 | |
| +#endif
 | |
|  
 | |
|    g_crash_helper_enabled = true;
 | |
|    return true;
 | |
| diff --git components/crash/content/app/breakpad_linux.cc components/crash/content/app/breakpad_linux.cc
 | |
| index a7378204ffaa..7efc255eb1b4 100644
 | |
| --- components/crash/content/app/breakpad_linux.cc
 | |
| +++ components/crash/content/app/breakpad_linux.cc
 | |
| @@ -28,6 +28,7 @@
 | |
|  #include "base/base_switches.h"
 | |
|  #include "base/command_line.h"
 | |
|  #include "base/debug/dump_without_crashing.h"
 | |
| +#include "base/debug/leak_annotations.h"
 | |
|  #include "base/files/file_path.h"
 | |
|  #include "base/lazy_instance.h"
 | |
|  #include "base/linux_util.h"
 | |
| @@ -89,6 +90,7 @@ namespace {
 | |
|  
 | |
|  #if !defined(OS_CHROMEOS)
 | |
|  const char kUploadURL[] = "https://clients2.google.com/cr/report";
 | |
| +const char* g_crash_server_url = kUploadURL;
 | |
|  #endif
 | |
|  
 | |
|  bool g_is_crash_reporter_enabled = false;
 | |
| @@ -702,7 +704,7 @@ bool CrashDone(const MinidumpDescriptor& minidump,
 | |
|    info.process_type_length = 7;
 | |
|    info.distro = base::g_linux_distro;
 | |
|    info.distro_length = my_strlen(base::g_linux_distro);
 | |
| -  info.upload = upload;
 | |
| +  info.upload = upload && g_crash_server_url;
 | |
|    info.process_start_time = g_process_start_time;
 | |
|    info.oom_size = base::g_oom_size;
 | |
|    info.pid = g_pid;
 | |
| @@ -1357,7 +1359,7 @@ void ExecUploadProcessOrTerminate(const BreakpadInfo& info,
 | |
|      header_content_encoding,
 | |
|      header_content_type,
 | |
|      post_file,
 | |
| -    kUploadURL,
 | |
| +    g_crash_server_url,
 | |
|      "--timeout=10",  // Set a timeout so we don't hang forever.
 | |
|      "--tries=1",     // Don't retry if the upload fails.
 | |
|      "-O",  // Output reply to the file descriptor path.
 | |
| @@ -1697,10 +1699,19 @@ void HandleCrashDump(const BreakpadInfo& info) {
 | |
|      GetCrashReporterClient()->GetProductNameAndVersion(&product_name, &version);
 | |
|  
 | |
|      writer.AddBoundary();
 | |
| -    writer.AddPairString("prod", product_name);
 | |
| +    writer.AddPairString("product", product_name);
 | |
| +    writer.AddBoundary();
 | |
| +    writer.AddPairString("version", version);
 | |
|      writer.AddBoundary();
 | |
| -    writer.AddPairString("ver", version);
 | |
| +
 | |
| +#if defined(ARCH_CPU_32_BITS)
 | |
| +    const char* platform = "linux32";
 | |
| +#elif defined(ARCH_CPU_64_BITS)
 | |
| +    const char* platform = "linux64";
 | |
| +#endif
 | |
| +    writer.AddPairString("platform", platform);
 | |
|      writer.AddBoundary();
 | |
| +
 | |
|      if (info.pid > 0) {
 | |
|        char pid_value_buf[kUint64StringSize];
 | |
|        uint64_t pid_value_len = my_uint64_len(info.pid);
 | |
| @@ -1817,10 +1828,20 @@ void HandleCrashDump(const BreakpadInfo& info) {
 | |
|          crash_reporter::internal::TransitionalCrashKeyStorage;
 | |
|      CrashKeyStorage::Iterator crash_key_iterator(*info.crash_keys);
 | |
|      const CrashKeyStorage::Entry* entry;
 | |
| +
 | |
| +    crash_reporter::CrashReporterClient::ParameterMap parameters;
 | |
| +
 | |
|      while ((entry = crash_key_iterator.Next())) {
 | |
|        if (g_use_crash_key_white_list && !IsInWhiteList(entry->key))
 | |
|          continue;
 | |
| -      writer.AddPairString(entry->key, entry->value);
 | |
| +      parameters.insert(std::make_pair(entry->key, entry->value));
 | |
| +    }
 | |
| +
 | |
| +    if (!parameters.empty())
 | |
| +      parameters = GetCrashReporterClient()->FilterParameters(parameters);
 | |
| +
 | |
| +    for (const auto& param : parameters) {
 | |
| +      writer.AddPairString(param.first.c_str(), param.second.c_str());
 | |
|        writer.AddBoundary();
 | |
|        writer.Flush();
 | |
|      }
 | |
| @@ -2032,6 +2053,17 @@ void SetChannelCrashKey(const std::string& channel) {
 | |
|    channel_key.Set(channel);
 | |
|  }
 | |
|  
 | |
| +void SetCrashServerURL(const std::string& url) {
 | |
| +  if (url.empty()) {
 | |
| +    g_crash_server_url = nullptr;
 | |
| +  } else {
 | |
| +    char* new_url = new char[url.size() + 1];
 | |
| +    ANNOTATE_LEAKING_OBJECT_PTR(new_url);
 | |
| +    strcpy(new_url, url.c_str());
 | |
| +    g_crash_server_url = new_url;
 | |
| +  }
 | |
| +}
 | |
| +
 | |
|  #if defined(OS_ANDROID)
 | |
|  void InitNonBrowserCrashReporterForAndroid(const std::string& process_type) {
 | |
|    SanitizationInfo sanitization_info;
 | |
| diff --git components/crash/content/app/breakpad_linux.h components/crash/content/app/breakpad_linux.h
 | |
| index 9ee85554812c..7af55ddda8fe 100644
 | |
| --- components/crash/content/app/breakpad_linux.h
 | |
| +++ components/crash/content/app/breakpad_linux.h
 | |
| @@ -19,6 +19,9 @@ extern void InitCrashReporter(const std::string& process_type);
 | |
|  // Sets the product/distribution channel crash key.
 | |
|  void SetChannelCrashKey(const std::string& channel);
 | |
|  
 | |
| +// Set the crash server URL.
 | |
| +void SetCrashServerURL(const std::string& url);
 | |
| +
 | |
|  #if defined(OS_ANDROID)
 | |
|  extern void InitCrashKeysForTesting();
 | |
|  
 | |
| diff --git components/crash/content/app/crash_reporter_client.cc components/crash/content/app/crash_reporter_client.cc
 | |
| index b3b09cee8d6f..4bc2afc7bd6e 100644
 | |
| --- components/crash/content/app/crash_reporter_client.cc
 | |
| +++ components/crash/content/app/crash_reporter_client.cc
 | |
| @@ -88,7 +88,7 @@ int CrashReporterClient::GetResultCodeRespawnFailed() {
 | |
|  }
 | |
|  #endif
 | |
|  
 | |
| -#if defined(OS_POSIX) && !defined(OS_MACOSX) && !defined(OS_IOS)
 | |
| +#if defined(OS_POSIX) && !defined(OS_IOS)
 | |
|  void CrashReporterClient::GetProductNameAndVersion(const char** product_name,
 | |
|                                                     const char** version) {
 | |
|  }
 | |
| @@ -97,6 +97,7 @@ void CrashReporterClient::GetProductNameAndVersion(std::string* product_name,
 | |
|                                                     std::string* version,
 | |
|                                                     std::string* channel) {}
 | |
|  
 | |
| +#if !defined(OS_MACOSX)
 | |
|  base::FilePath CrashReporterClient::GetReporterLogFilename() {
 | |
|    return base::FilePath();
 | |
|  }
 | |
| @@ -105,6 +106,7 @@ bool CrashReporterClient::HandleCrashDump(const char* crashdump_filename) {
 | |
|    return false;
 | |
|  }
 | |
|  #endif
 | |
| +#endif
 | |
|  
 | |
|  #if defined(OS_WIN)
 | |
|  bool CrashReporterClient::GetCrashDumpLocation(base::string16* crash_dir) {
 | |
| @@ -147,6 +149,32 @@ bool CrashReporterClient::ReportingIsEnforcedByPolicy(bool* breakpad_enabled) {
 | |
|    return false;
 | |
|  }
 | |
|  
 | |
| +bool CrashReporterClient::EnableBreakpadForProcess(
 | |
| +    const std::string& process_type) {
 | |
| +  return false;
 | |
| +}
 | |
| +
 | |
| +std::string CrashReporterClient::GetCrashServerURL() {
 | |
| +  return std::string();
 | |
| +}
 | |
| +
 | |
| +void CrashReporterClient::GetCrashOptionalArguments(
 | |
| +    std::vector<std::string>* arguments) {
 | |
| +}
 | |
| +
 | |
| +#if defined(OS_WIN)
 | |
| +base::string16 CrashReporterClient::GetCrashExternalHandler(
 | |
| +    const base::string16& exe_dir) {
 | |
| +  return exe_dir + L"\\crashpad_handler.exe";
 | |
| +}
 | |
| +#endif
 | |
| +
 | |
| +#if defined(OS_MACOSX)
 | |
| +bool CrashReporterClient::EnableBrowserCrashForwarding() {
 | |
| +  return true;
 | |
| +}
 | |
| +#endif
 | |
| +
 | |
|  #if defined(OS_ANDROID)
 | |
|  unsigned int CrashReporterClient::GetCrashDumpPercentageForWebView() {
 | |
|    return 100;
 | |
| @@ -194,9 +222,11 @@ bool CrashReporterClient::ShouldMonitorCrashHandlerExpensively() {
 | |
|    return false;
 | |
|  }
 | |
|  
 | |
| -bool CrashReporterClient::EnableBreakpadForProcess(
 | |
| -    const std::string& process_type) {
 | |
| -  return false;
 | |
| +#if defined(OS_POSIX) && !defined(OS_MACOSX)
 | |
| +CrashReporterClient::ParameterMap
 | |
| +CrashReporterClient::FilterParameters(const ParameterMap& parameters) {
 | |
| +  return parameters;
 | |
|  }
 | |
| +#endif
 | |
|  
 | |
|  }  // namespace crash_reporter
 | |
| diff --git components/crash/content/app/crash_reporter_client.h components/crash/content/app/crash_reporter_client.h
 | |
| index caebf67a7e0f..5e7cf3d8c1a6 100644
 | |
| --- components/crash/content/app/crash_reporter_client.h
 | |
| +++ components/crash/content/app/crash_reporter_client.h
 | |
| @@ -5,7 +5,9 @@
 | |
|  #ifndef COMPONENTS_CRASH_CONTENT_APP_CRASH_REPORTER_CLIENT_H_
 | |
|  #define COMPONENTS_CRASH_CONTENT_APP_CRASH_REPORTER_CLIENT_H_
 | |
|  
 | |
| +#include <map>
 | |
|  #include <string>
 | |
| +#include <vector>
 | |
|  
 | |
|  #include "base/strings/string16.h"
 | |
|  #include "build/build_config.h"
 | |
| @@ -91,7 +93,7 @@ class CrashReporterClient {
 | |
|    virtual int GetResultCodeRespawnFailed();
 | |
|  #endif
 | |
|  
 | |
| -#if defined(OS_POSIX) && !defined(OS_MACOSX) && !defined(OS_IOS)
 | |
| +#if defined(OS_POSIX) && !defined(OS_IOS)
 | |
|    // Returns a textual description of the product type and version to include
 | |
|    // in the crash report. Neither out parameter should be set to NULL.
 | |
|    // TODO(jperaza): Remove the 2-parameter overload of this method once all
 | |
| @@ -102,6 +104,7 @@ class CrashReporterClient {
 | |
|                                          std::string* version,
 | |
|                                          std::string* channel);
 | |
|  
 | |
| +#if !defined(OS_MACOSX)
 | |
|    virtual base::FilePath GetReporterLogFilename();
 | |
|  
 | |
|    // Custom crash minidump handler after the minidump is generated.
 | |
| @@ -110,6 +113,7 @@ class CrashReporterClient {
 | |
|    // WARNING: this handler runs in a compromised context. It may not call into
 | |
|    // libc nor allocate memory normally.
 | |
|    virtual bool HandleCrashDump(const char* crashdump_filename);
 | |
| +#endif
 | |
|  #endif
 | |
|  
 | |
|    // The location where minidump files should be written. Returns true if
 | |
| @@ -206,6 +210,30 @@ class CrashReporterClient {
 | |
|  
 | |
|    // Returns true if breakpad should run in the given process type.
 | |
|    virtual bool EnableBreakpadForProcess(const std::string& process_type);
 | |
| +
 | |
| +  // Returns the URL for submitting crash reports.
 | |
| +  virtual std::string GetCrashServerURL();
 | |
| +
 | |
| +  // Populate |arguments| with additional optional arguments.
 | |
| +  virtual void GetCrashOptionalArguments(std::vector<std::string>* arguments);
 | |
| +
 | |
| +#if defined(OS_WIN)
 | |
| +  // Returns the absolute path to the external crash handler exe.
 | |
| +  virtual base::string16 GetCrashExternalHandler(const base::string16& exe_dir);
 | |
| +#endif
 | |
| +
 | |
| +#if defined(OS_MACOSX)
 | |
| +  // Returns true if forwarding of crashes to the system crash reporter is
 | |
| +  // enabled for the browser process.
 | |
| +  virtual bool EnableBrowserCrashForwarding();
 | |
| +#endif
 | |
| +
 | |
| +#if defined(OS_POSIX) && !defined(OS_MACOSX)
 | |
| +  // Provides an oportunity to modify the parameters that will be sent with a
 | |
| +  // crash upload.
 | |
| +  using ParameterMap = std::map<std::string, std::string>;
 | |
| +  virtual ParameterMap FilterParameters(const ParameterMap& parameters);
 | |
| +#endif
 | |
|  };
 | |
|  
 | |
|  }  // namespace crash_reporter
 | |
| diff --git components/crash/content/app/crashpad.cc components/crash/content/app/crashpad.cc
 | |
| index a04a4d843004..366a687c352d 100644
 | |
| --- components/crash/content/app/crashpad.cc
 | |
| +++ components/crash/content/app/crashpad.cc
 | |
| @@ -150,7 +150,8 @@ void InitializeCrashpadImpl(bool initial_client,
 | |
|    // fallback. Forwarding is turned off for debug-mode builds even for the
 | |
|    // browser process, because the system's crash reporter can take a very long
 | |
|    // time to chew on symbols.
 | |
| -  if (!browser_process || is_debug_build) {
 | |
| +  if (!browser_process || is_debug_build ||
 | |
| +      !crash_reporter_client->EnableBrowserCrashForwarding()) {
 | |
|      crashpad::CrashpadInfo::GetCrashpadInfo()
 | |
|          ->set_system_crash_reporter_forwarding(crashpad::TriState::kDisabled);
 | |
|    }
 | |
| diff --git components/crash/content/app/crashpad_mac.mm components/crash/content/app/crashpad_mac.mm
 | |
| index f079174b3586..ff9a19e259fb 100644
 | |
| --- components/crash/content/app/crashpad_mac.mm
 | |
| +++ components/crash/content/app/crashpad_mac.mm
 | |
| @@ -16,11 +16,14 @@
 | |
|  #include "base/logging.h"
 | |
|  #include "base/mac/bundle_locations.h"
 | |
|  #include "base/mac/foundation_util.h"
 | |
| +#include "base/path_service.h"
 | |
|  #include "base/strings/string_number_conversions.h"
 | |
|  #include "base/strings/string_piece.h"
 | |
|  #include "base/strings/stringprintf.h"
 | |
|  #include "base/strings/sys_string_conversions.h"
 | |
|  #include "components/crash/content/app/crash_reporter_client.h"
 | |
| +#include "components/crash/content/app/crash_switches.h"
 | |
| +#include "content/public/common/content_paths.h"
 | |
|  #include "third_party/crashpad/crashpad/client/crash_report_database.h"
 | |
|  #include "third_party/crashpad/crashpad/client/crashpad_client.h"
 | |
|  #include "third_party/crashpad/crashpad/client/crashpad_info.h"
 | |
| @@ -36,12 +39,25 @@ namespace {
 | |
|  std::map<std::string, std::string> GetProcessSimpleAnnotations() {
 | |
|    static std::map<std::string, std::string> annotations = []() -> auto {
 | |
|      std::map<std::string, std::string> process_annotations;
 | |
| +
 | |
|      @autoreleasepool {
 | |
|        NSBundle* outer_bundle = base::mac::OuterBundle();
 | |
| -      NSString* product = base::mac::ObjCCast<NSString>([outer_bundle
 | |
| -          objectForInfoDictionaryKey:base::mac::CFToNSCast(kCFBundleNameKey)]);
 | |
| -      process_annotations["prod"] =
 | |
| -          base::SysNSStringToUTF8(product).append("_Mac");
 | |
| +
 | |
| +      CrashReporterClient* crash_reporter_client = GetCrashReporterClient();
 | |
| +      const char* product_name = "";
 | |
| +      const char* product_version = "";
 | |
| +      crash_reporter_client->GetProductNameAndVersion(&product_name,
 | |
| +                                                      &product_version);
 | |
| +
 | |
| +      if (strlen(product_name) == 0) {
 | |
| +        NSString* product = base::mac::ObjCCast<NSString>([outer_bundle
 | |
| +            objectForInfoDictionaryKey:base::mac::CFToNSCast(
 | |
| +                kCFBundleNameKey)]);
 | |
| +        process_annotations["product"] =
 | |
| +            base::SysNSStringToUTF8(product).append("_Mac");
 | |
| +      } else {
 | |
| +        process_annotations["product"] = product_name;
 | |
| +      }
 | |
|  
 | |
|  #if defined(GOOGLE_CHROME_BUILD)
 | |
|        // Empty means stable.
 | |
| @@ -57,12 +73,16 @@ std::map<std::string, std::string> GetProcessSimpleAnnotations() {
 | |
|          process_annotations["channel"] = "";
 | |
|        }
 | |
|  
 | |
| -      NSString* version =
 | |
| -          base::mac::ObjCCast<NSString>([base::mac::FrameworkBundle()
 | |
| -              objectForInfoDictionaryKey:@"CFBundleShortVersionString"]);
 | |
| -      process_annotations["ver"] = base::SysNSStringToUTF8(version);
 | |
| +      if (strlen(product_version) == 0) {
 | |
| +        NSString* version =
 | |
| +            base::mac::ObjCCast<NSString>([base::mac::FrameworkBundle()
 | |
| +                objectForInfoDictionaryKey:@"CFBundleShortVersionString"]);
 | |
| +        process_annotations["version"] = base::SysNSStringToUTF8(version);
 | |
| +      } else {
 | |
| +        process_annotations["version"] = product_version;
 | |
| +      }
 | |
|  
 | |
| -      process_annotations["plat"] = std::string("OS X");
 | |
| +      process_annotations["platform"] = std::string("macos");
 | |
|      }  // @autoreleasepool
 | |
|      return process_annotations;
 | |
|    }();
 | |
| @@ -122,9 +142,10 @@ base::FilePath PlatformCrashpadInitialization(
 | |
|  
 | |
|    if (initial_client) {
 | |
|      @autoreleasepool {
 | |
| -      base::FilePath framework_bundle_path = base::mac::FrameworkBundlePath();
 | |
| -      base::FilePath handler_path =
 | |
| -          framework_bundle_path.Append("Helpers").Append("crashpad_handler");
 | |
| +      // Use the same subprocess helper exe.
 | |
| +      base::FilePath handler_path;
 | |
| +      base::PathService::Get(content::CHILD_PROCESS_EXE, &handler_path);
 | |
| +      DCHECK(!handler_path.empty());
 | |
|  
 | |
|        // Is there a way to recover if this fails?
 | |
|        CrashReporterClient* crash_reporter_client = GetCrashReporterClient();
 | |
| @@ -136,7 +157,7 @@ base::FilePath PlatformCrashpadInitialization(
 | |
|        // crash server won't have symbols for any other build types.
 | |
|        std::string url = "https://clients2.google.com/cr/report";
 | |
|  #else
 | |
| -      std::string url;
 | |
| +      std::string url = crash_reporter_client->GetCrashServerURL();
 | |
|  #endif
 | |
|  
 | |
|        std::vector<std::string> arguments;
 | |
| @@ -159,6 +180,12 @@ base::FilePath PlatformCrashpadInitialization(
 | |
|              "--reset-own-crash-exception-port-to-system-default");
 | |
|        }
 | |
|  
 | |
| +      // Since we're using the same subprocess helper exe we must specify the
 | |
| +      // process type.
 | |
| +      arguments.push_back(std::string("--type=") + switches::kCrashpadHandler);
 | |
| +
 | |
| +      crash_reporter_client->GetCrashOptionalArguments(&arguments);
 | |
| +
 | |
|        bool result = GetCrashpadClient().StartHandler(
 | |
|            handler_path, database_path, metrics_path, url,
 | |
|            GetProcessSimpleAnnotations(), arguments, true, false);
 | |
| diff --git components/crash/content/app/crashpad_win.cc components/crash/content/app/crashpad_win.cc
 | |
| index cc16c40ea320..3bb03459adf4 100644
 | |
| --- components/crash/content/app/crashpad_win.cc
 | |
| +++ components/crash/content/app/crashpad_win.cc
 | |
| @@ -35,8 +35,8 @@ void GetPlatformCrashpadAnnotations(
 | |
|    base::string16 product_name, version, special_build, channel_name;
 | |
|    crash_reporter_client->GetProductNameAndVersion(
 | |
|        exe_file, &product_name, &version, &special_build, &channel_name);
 | |
| -  (*annotations)["prod"] = base::UTF16ToUTF8(product_name);
 | |
| -  (*annotations)["ver"] = base::UTF16ToUTF8(version);
 | |
| +  (*annotations)["product"] = base::UTF16ToUTF8(product_name);
 | |
| +  (*annotations)["version"] = base::UTF16ToUTF8(version);
 | |
|  #if defined(GOOGLE_CHROME_BUILD)
 | |
|    // Empty means stable.
 | |
|    const bool allow_empty_channel = true;
 | |
| @@ -48,9 +48,9 @@ void GetPlatformCrashpadAnnotations(
 | |
|    if (!special_build.empty())
 | |
|      (*annotations)["special"] = base::UTF16ToUTF8(special_build);
 | |
|  #if defined(ARCH_CPU_X86)
 | |
| -  (*annotations)["plat"] = std::string("Win32");
 | |
| +  (*annotations)["platform"] = std::string("win32");
 | |
|  #elif defined(ARCH_CPU_X86_64)
 | |
| -  (*annotations)["plat"] = std::string("Win64");
 | |
| +  (*annotations)["platform"] = std::string("win64");
 | |
|  #endif
 | |
|  }
 | |
|  
 | |
| @@ -65,7 +65,9 @@ base::FilePath PlatformCrashpadInitialization(
 | |
|    base::FilePath metrics_path;  // Only valid in the browser process.
 | |
|  
 | |
|    const char kPipeNameVar[] = "CHROME_CRASHPAD_PIPE_NAME";
 | |
| +#if defined(GOOGLE_CHROME_BUILD)
 | |
|    const char kServerUrlVar[] = "CHROME_CRASHPAD_SERVER_URL";
 | |
| +#endif
 | |
|    std::unique_ptr<base::Environment> env(base::Environment::Create());
 | |
|    if (initial_client) {
 | |
|      CrashReporterClient* crash_reporter_client = GetCrashReporterClient();
 | |
| @@ -85,13 +87,13 @@ base::FilePath PlatformCrashpadInitialization(
 | |
|  
 | |
|  #if defined(GOOGLE_CHROME_BUILD)
 | |
|      std::string url = "https://clients2.google.com/cr/report";
 | |
| -#else
 | |
| -    std::string url;
 | |
| -#endif
 | |
|  
 | |
|      // Allow the crash server to be overridden for testing. If the variable
 | |
|      // isn't present in the environment then the default URL will remain.
 | |
|      env->GetVar(kServerUrlVar, &url);
 | |
| +#else
 | |
| +    std::string url = crash_reporter_client->GetCrashServerURL();
 | |
| +#endif
 | |
|  
 | |
|      base::FilePath exe_file(exe_path);
 | |
|      if (exe_file.empty()) {
 | |
| @@ -109,13 +111,14 @@ base::FilePath PlatformCrashpadInitialization(
 | |
|                crashpad::TriState::kEnabled, kIndirectMemoryLimit);
 | |
|      }
 | |
|  
 | |
| -    // If the handler is embedded in the binary (e.g. chrome, setup), we
 | |
| -    // reinvoke it with --type=crashpad-handler. Otherwise, we use the
 | |
| -    // standalone crashpad_handler.exe (for tests, etc.).
 | |
|      std::vector<std::string> start_arguments(initial_arguments);
 | |
| +
 | |
| +    // Always add --type=crashpad-handler because the value is expected by
 | |
| +    // CefExecuteProcess.
 | |
| +    start_arguments.push_back(
 | |
| +        std::string("--type=") + switches::kCrashpadHandler);
 | |
| +
 | |
|      if (embedded_handler) {
 | |
| -      start_arguments.push_back(std::string("--type=") +
 | |
| -                                switches::kCrashpadHandler);
 | |
|        if (!user_data_dir.empty()) {
 | |
|          start_arguments.push_back(std::string("--user-data-dir=") +
 | |
|                                    user_data_dir);
 | |
| @@ -126,9 +129,12 @@ base::FilePath PlatformCrashpadInitialization(
 | |
|        start_arguments.push_back("/prefetch:7");
 | |
|      } else {
 | |
|        base::FilePath exe_dir = exe_file.DirName();
 | |
| -      exe_file = exe_dir.Append(FILE_PATH_LITERAL("crashpad_handler.exe"));
 | |
| +      exe_file = base::FilePath(
 | |
| +          crash_reporter_client->GetCrashExternalHandler(exe_dir.value()));
 | |
|      }
 | |
|  
 | |
| +    crash_reporter_client->GetCrashOptionalArguments(&start_arguments);
 | |
| +
 | |
|      std::vector<std::string> arguments(start_arguments);
 | |
|  
 | |
|      if (crash_reporter_client->ShouldMonitorCrashHandlerExpensively()) {
 | |
| diff --git content/browser/frame_host/debug_urls.cc content/browser/frame_host/debug_urls.cc
 | |
| index d396b2fc0309..e1451174d705 100644
 | |
| --- content/browser/frame_host/debug_urls.cc
 | |
| +++ content/browser/frame_host/debug_urls.cc
 | |
| @@ -134,7 +134,9 @@ bool HandleDebugURL(const GURL& url, ui::PageTransition transition) {
 | |
|            cc::switches::kEnableGpuBenchmarking) &&
 | |
|        (PageTransitionCoreTypeIs(transition, ui::PAGE_TRANSITION_TYPED));
 | |
|  
 | |
| -  if (!(transition & ui::PAGE_TRANSITION_FROM_ADDRESS_BAR) &&
 | |
| +  // CEF does not use PAGE_TRANSITION_FROM_ADDRESS_BAR.
 | |
| +  if (!(transition & (ui::PAGE_TRANSITION_TYPED |
 | |
| +                      ui::PAGE_TRANSITION_FROM_ADDRESS_BAR)) &&
 | |
|        !is_telemetry_navigation)
 | |
|      return false;
 | |
|  
 |