mirror of
https://github.com/chromium/crashpad.git
synced 2025-01-21 23:23:05 +08:00
dea8fa51d0
The integration into the Fuchsia tree is still being negotiated, but I've added crashsvc on that side https://fuchsia.googlesource.com/zircon/+/HEAD/system/core/crashsvc/crashsvc.cpp, which handles exceptions and spawns something to actually deal with the crashed process. This means that there's no resident thing, so it seems simplest to use handler/crash_report_exception_handler directly, rather than add another wrapper binary. At some point it may make sense to roll this functionality back into Crashpad upstream, we'll see how it evolves. Additionally, the "normal" crashpad_handler model may still be necessary if Chrome wants to use a copy locally (rather than the system handler). To accomplish this: - Split crashpad_handler and crashpad_database_util packages so crashpad_database_util can still be included into the system image for debugging. - Add handle-based version of HandleException() to CrashReportExceptionHandler (and also remove the "type" argument because I've come around to realizing there's no point to it, finally. :) Bug: crashpad:196 Change-Id: I38872183ee3691c0938c5b761e6b73c80019f355 Reviewed-on: https://chromium-review.googlesource.com/1057833 Reviewed-by: Joshua Peraza <jperaza@chromium.org> Commit-Queue: Scott Graham <scottmg@chromium.org>
61 lines
1.9 KiB
C++
61 lines
1.9 KiB
C++
// Copyright 2017 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 "handler/fuchsia/exception_handler_server.h"
|
|
|
|
#include <zircon/syscalls/exception.h>
|
|
#include <zircon/syscalls/port.h>
|
|
|
|
#include <utility>
|
|
|
|
#include "base/fuchsia/fuchsia_logging.h"
|
|
#include "base/logging.h"
|
|
#include "handler/fuchsia/crash_report_exception_handler.h"
|
|
#include "util/fuchsia/system_exception_port_key.h"
|
|
|
|
namespace crashpad {
|
|
|
|
ExceptionHandlerServer::ExceptionHandlerServer(
|
|
base::ScopedZxHandle root_job,
|
|
base::ScopedZxHandle exception_port)
|
|
: root_job_(std::move(root_job)),
|
|
exception_port_(std::move(exception_port)) {}
|
|
|
|
ExceptionHandlerServer::~ExceptionHandlerServer() = default;
|
|
|
|
void ExceptionHandlerServer::Run(CrashReportExceptionHandler* handler) {
|
|
while (true) {
|
|
zx_port_packet_t packet;
|
|
zx_status_t status =
|
|
zx_port_wait(exception_port_.get(), ZX_TIME_INFINITE, &packet, 1);
|
|
if (status != ZX_OK) {
|
|
ZX_LOG(ERROR, status) << "zx_port_wait, aborting";
|
|
return;
|
|
}
|
|
|
|
if (packet.key != kSystemExceptionPortKey) {
|
|
LOG(ERROR) << "unexpected packet key, ignoring";
|
|
continue;
|
|
}
|
|
|
|
bool result =
|
|
handler->HandleException(packet.exception.pid, packet.exception.tid);
|
|
if (!result) {
|
|
LOG(ERROR) << "HandleException failed";
|
|
}
|
|
}
|
|
}
|
|
|
|
} // namespace crashpad
|