Skip to content

Commit

Permalink
fix: mark PIDFDInfo and PIDRUsage unsafe
Browse files Browse the repository at this point in the history
This patch marks the PIDRUsage and PIDFDInfo traits
as unsafe, since incorrect implementations of
these traits could lead to unsound behavior.

Unfortunately, since these are public traits,
this will mean an incompatible version bump
for the next release, though hopefully no one
is really rolling their own implementation for
these guys.

https://doc.rust-lang.org/reference/unsafe-keyword.html#unsafe-traits-unsafe-trait
  • Loading branch information
ethanpailes committed Jul 29, 2024
1 parent cb8c2ab commit e2b7527
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 8 deletions.
8 changes: 7 additions & 1 deletion src/libproc/file_info.rs
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,13 @@ impl From<u32> for ProcFDType {

/// The `PIDFDInfo` trait is needed for polymorphism on pidfdinfo types, also abstracting flavor
/// in order to provide type-guaranteed flavor correctness
pub trait PIDFDInfo: Default {
///
/// # Safety
///
/// The type this trait is implemented on must be correctly sized such that
/// a pointer to that type can be passed to the libproc `proc_pidfdinfo` function
/// as the buffer parameter.
pub unsafe trait PIDFDInfo: Default {
/// Return the Pid File Descriptor Info flavor of the implementing struct
fn flavor() -> PIDFDInfoFlavor;
}
Expand Down
6 changes: 5 additions & 1 deletion src/libproc/net_info.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,11 @@ pub struct ProcFileInfo {
pub rfu_1: i32,
}

impl PIDFDInfo for SocketFDInfo {
/// # Saftey
///
/// The size of `SocketFDInfo` is correct for getting passed to
/// `proc_pidfdinfo`.
unsafe impl PIDFDInfo for SocketFDInfo {
fn flavor() -> PIDFDInfoFlavor {
PIDFDInfoFlavor::SocketInfo
}
Expand Down
33 changes: 27 additions & 6 deletions src/libproc/pid_rusage.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,13 @@ use crate::osx_libproc_bindings::proc_pid_rusage;

/// The `PIDRUsage` trait is needed for polymorphism on pidrusage types, also abstracting flavor in order to provide
/// type-guaranteed flavor correctness
pub trait PIDRUsage: Default {
///
/// # Safety
///
/// The type this trait is implemented on must be correctly sized such that
/// a pointer to that type can be passed to the libproc `proc_pid_rusage` function
/// as the buffer parameter.
pub unsafe trait PIDRUsage: Default {
/// Return the `PidRUsageFlavor` for the implementing struct
fn flavor() -> PidRUsageFlavor;
/// Memory used in bytes
Expand Down Expand Up @@ -62,7 +68,10 @@ pub struct RUsageInfoV0 {
pub ri_proc_exit_abstime: u64,
}

impl PIDRUsage for RUsageInfoV0 {
/// # Safety
///
/// The size is appropriate for getting passed to `proc_pid_pidrusage`.
unsafe impl PIDRUsage for RUsageInfoV0 {
fn flavor() -> PidRUsageFlavor {
PidRUsageFlavor::V0
}
Expand Down Expand Up @@ -116,7 +125,10 @@ pub struct RUsageInfoV1 {
pub ri_child_elapsed_abstime: u64,
}

impl PIDRUsage for RUsageInfoV1 {
/// # Safety
///
/// The size is appropriate for getting passed to `proc_pid_pidrusage`.
unsafe impl PIDRUsage for RUsageInfoV1 {
fn flavor() -> PidRUsageFlavor {
PidRUsageFlavor::V1
}
Expand Down Expand Up @@ -174,7 +186,10 @@ pub struct RUsageInfoV2 {
pub ri_diskio_byteswritten: u64,
}

impl PIDRUsage for RUsageInfoV2 {
/// # Safety
///
/// The size is appropriate for getting passed to `proc_pid_pidrusage`.
unsafe impl PIDRUsage for RUsageInfoV2 {
fn flavor() -> PidRUsageFlavor {
PidRUsageFlavor::V2
}
Expand Down Expand Up @@ -250,7 +265,10 @@ pub struct RUsageInfoV3 {
pub ri_serviced_system_time: u64,
}

impl PIDRUsage for RUsageInfoV3 {
/// # Safety
///
/// The size is appropriate for getting passed to `proc_pid_pidrusage`.
unsafe impl PIDRUsage for RUsageInfoV3 {
fn flavor() -> PidRUsageFlavor {
PidRUsageFlavor::V3
}
Expand Down Expand Up @@ -342,7 +360,10 @@ pub struct RUsageInfoV4 {
pub ri_unused: [u64; 1],
}

impl PIDRUsage for RUsageInfoV4 {
/// # Safety
///
/// The size is appropriate for getting passed to `proc_pid_pidrusage`.
unsafe impl PIDRUsage for RUsageInfoV4 {
fn flavor() -> PidRUsageFlavor {
PidRUsageFlavor::V4
}
Expand Down

0 comments on commit e2b7527

Please sign in to comment.