ec3b8f6cc1
Summary: In particular this fixes `FlattenUnordered` having a nasty deadlock, but also some other bugs: ``` # 0.3.28 - 2023-03-30 * Update to syn 2. This raises MSRV of utility crates to 1.56. (#2730, #2733) * Fix bug in `FlattenUnordered` (#2726, #2728) # 0.3.27 - 2023-03-11 * Add `TryFlattenUnordered` (#2577, #2590, #2606, #2607) * Add `AbortHandle::is_aborted` (#2710) * Add `AbortRegistration::handle` (#2712) * Make `BiLock` strict-provenance compatible (#2716) # 0.3.26 - 2023-01-30 * Add `Either::as_pin_mut` and `Either::as_pin_ref` (#2691) * Add `Shared::ptr_eq` and `Shared::ptr_hash` (#2691) * Implement `FusedStream` for `Buffered` (#2676) * Implement `FusedStream` for all streams in `ReadyChunks` (#2693) * Fix bug in `FuturesOrdered::push_front` (#2664) * Remove `Fut::Output: Clone` bounds from some `Shared` methods (#2662) * Remove `T: Debug` bounds from `Debug` implementations of `mpsc` and `oneshot` types (#2666, #2667) # 0.3.25 - 2022-10-20 * Fix soundness issue in `join!` and `try_join!` macros (#2649) * Implement `Clone` for `sink::Drain` (#2650) # 0.3.24 - 2022-08-29 * Fix incorrect termination of `select_with_strategy` streams (#2635) # 0.3.23 - 2022-08-14 * Work around MSRV increase due to a cargo bug. ``` Reviewed By: zertosh Differential Revision: D44623815 fbshipit-source-id: 343ddb9277e1703104e516d07fe0610b5020930a |
||
---|---|---|
.. | ||
src | ||
Cargo.toml | ||
README.md |
A safe ptrace interface
This crate provides a safe and Rustic alternative to the infamous ptrace
API.
There are many extremely subtle aspects of the raw ptrace API and this crate
helps avoid common pitfalls.
Note that this library is still rather low-level and does not claim to solve all your ptrace problems. You have been warned!
Features
- Ergonomic interface that provides a state machine for ptrace states. This
avoids the infamous
ESRCH
errors that can happen when you use the ptrace API incorrectly. - Provides an interface to read/write guest's memory (see "memory" feature flag).
- Provides an optional and semi-experimental async interface, which can be used
with
tokio
(see "notifier" feature).
Usage
Add this to your Cargo.toml
file:
safeptrace = "0.1"
Feature Flags
"memory"
(off by default)
Provides access to the guest's memory. Memory can only be safely accessed when
the guest is in a stopped state, thus the MemoryAccess
trait is only
implemented for the Stopped
type.
"notifier"
(off by default)
Provides an async interface for ptrace using notifier threads. This is semi-experimental, but testing shows that it has very good performance. It works by spawning a separate thread for each thread being traced, waiting for ptrace events in a loop. Thus, there will be 1 thread per guest thread.
Use with:
safeptrace = { version = "0.1", features = ["async"] }