2021-12-30 00:14:23 +00:00
|
|
|
/*
|
2022-06-02 18:51:06 +00:00
|
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
2021-12-30 00:14:23 +00:00
|
|
|
*
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
|
|
|
*/
|
|
|
|
|
2022-01-05 02:13:19 +00:00
|
|
|
//! This instrumentation tool does nothing except acting as a gdbserver.
|
2021-12-30 00:14:23 +00:00
|
|
|
|
2022-06-30 21:56:20 +00:00
|
|
|
use reverie::Error;
|
|
|
|
use reverie::Subscription;
|
|
|
|
use reverie::Tool;
|
2021-12-30 00:14:23 +00:00
|
|
|
use reverie_util::CommonToolArguments;
|
2022-06-30 21:56:20 +00:00
|
|
|
use serde::Deserialize;
|
|
|
|
use serde::Serialize;
|
2021-12-30 00:14:23 +00:00
|
|
|
use structopt::StructOpt;
|
|
|
|
|
|
|
|
#[derive(Debug, Default, Serialize, Deserialize)]
|
|
|
|
struct DebugTool;
|
|
|
|
impl Tool for DebugTool {
|
|
|
|
fn subscriptions(_cfg: &()) -> Subscription {
|
|
|
|
Subscription::none()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-05 02:13:19 +00:00
|
|
|
/// A tool that acts as a GDB server. The process will start in a stopped state,
|
|
|
|
/// waiting for a GDB client to connect. Once the connection is complete,
|
|
|
|
/// execution of the guest process will continue.
|
2021-12-30 00:14:23 +00:00
|
|
|
#[derive(Debug, StructOpt)]
|
|
|
|
struct Args {
|
|
|
|
#[structopt(flatten)]
|
|
|
|
common_opts: CommonToolArguments,
|
|
|
|
|
|
|
|
#[structopt(long, default_value = "1234", help = "launch gdbserver on given port")]
|
|
|
|
port: u16,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::main]
|
|
|
|
async fn main() -> Result<(), Error> {
|
|
|
|
let args = Args::from_args();
|
|
|
|
let port = args.port;
|
|
|
|
let log_guard = args.common_opts.init_tracing();
|
|
|
|
eprintln!("Listening on port {}", port);
|
|
|
|
let tracer = reverie_ptrace::TracerBuilder::<DebugTool>::new(args.common_opts.into())
|
|
|
|
.gdbserver(port)
|
|
|
|
.spawn()
|
|
|
|
.await?;
|
|
|
|
let (status, _global_state) = tracer.wait().await?;
|
|
|
|
drop(log_guard); // Flush logs before exiting.
|
|
|
|
status.raise_or_exit()
|
|
|
|
}
|