blob: 6490e6fa70a2d1fa74026eefadf9ed47441a6963 [file] [log] [blame]
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_CRASH_CONTENT_BROWSER_CRASH_MICRO_DUMP_MANAGER_ANDROID_H_
#define COMPONENTS_CRASH_CONTENT_BROWSER_CRASH_MICRO_DUMP_MANAGER_ANDROID_H_
#include <map>
#include "base/files/scoped_file.h"
#include "base/memory/scoped_ptr.h"
#include "base/memory/singleton.h"
#include "base/memory/weak_ptr.h"
#include "base/process/kill.h"
#include "base/sync_socket.h"
#include "base/synchronization/lock.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
namespace breakpad {
// This class manages behavior of the browser on renderer crashes when
// microdumps are used for capturing the crash stack. Normally, in this case
// the browser doesn't need to do much, because a microdump is written into
// Android log by the renderer process itself. However, the browser may need to
// crash itself on a renderer crash. Since on Android renderers are not child
// processes of the browser, it can't access the exit code. Instead, the browser
// uses a dedicated pipe in order to receive the information about the renderer
// crash status.
class CrashMicroDumpManager : public content::NotificationObserver {
public:
// There is only a single instance of CrashMicroDumpManager per browser
// process. It needs to be created on the UI thread.
static CrashMicroDumpManager* GetInstance();
// Returns a pipe that should be used to transfer termination cause of
// |child_process_id|.
base::ScopedFD CreateCrashInfoChannel(int child_process_id);
private:
friend struct base::DefaultSingletonTraits<CrashMicroDumpManager>;
CrashMicroDumpManager();
~CrashMicroDumpManager() override;
// NotificationObserver implementation:
void Observe(int type,
const content::NotificationSource& source,
const content::NotificationDetails& details) override;
// Called on child process exit (including crash).
void HandleChildTerminationOnFileThread(
int child_process_id,
base::TerminationStatus termination_status);
content::NotificationRegistrar notification_registrar_;
// This map should only be accessed with its lock aquired as it is accessed
// from the PROCESS_LAUNCHER, FILE, and UI threads.
base::Lock child_process_id_to_pipe_lock_;
std::map<int, scoped_ptr<base::SyncSocket>> child_process_id_to_pipe_;
base::WeakPtrFactory<CrashMicroDumpManager> weak_factory_;
DISALLOW_COPY_AND_ASSIGN(CrashMicroDumpManager);
};
} // namespace breakpad
#endif // COMPONENTS_CRASH_CONTENT_BROWSER_CRASH_MICRO_DUMP_MANAGER_ANDROID_H_