Skip to content

Commit

Permalink
Add mc-sgx-sync::sys::locks::Condvar
Browse files Browse the repository at this point in the history
Add the backend end `Condvar` implementation for use in SGX enclaves
  • Loading branch information
nick-mobilecoin committed Jan 30, 2023
1 parent ee48383 commit 2d4e076
Show file tree
Hide file tree
Showing 3 changed files with 73 additions and 0 deletions.
2 changes: 2 additions & 0 deletions sync/src/sys/locks.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,7 @@

//! Platform specific concurrency locking primitives.
mod condvar;
mod mutex;

pub(crate) use mutex::Mutex;
67 changes: 67 additions & 0 deletions sync/src/sys/locks/condvar.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
// Copyright (c) 2023 The MobileCoin Foundation

//! Rust condition variable implementation used in SGX environments
#![allow(dead_code)]
use crate::sys::locks::Mutex;
use mc_sgx_tstdc::Condvar as SgxCondvar;

/// The condition variable backend to use with the common Rust std lib Condvar
/// interface
pub(crate) struct Condvar {
inner: SgxCondvar,
}

unsafe impl Send for Condvar {}
unsafe impl Sync for Condvar {}

impl Condvar {
pub const fn new() -> Self {
Self {
inner: SgxCondvar::new(),
}
}

/// Wait on the condition variable
///
/// # Arguments
/// * `mutex` - The mutex to paired with the current [`Condvar`]
///
/// # Panics
/// If:
/// - the condition variable got into an invalid state
/// - the [`Mutex`] is not locked by the current thread
pub fn wait(&self, mutex: &Mutex) {
self.inner
.wait(mutex.raw())
.expect("Condition variable is invalid or mutex is not locked by current thread");
}

/// Notify the next waiting thread (if any) of the condition variable event
///
/// Returns when there are no waiting threads.
///
/// # Panics
/// If the condition variable got into an invalid state
pub fn notify_one(&self) {
self.inner
.notify_one()
.expect("Condition variable is in an invalid state");
}

/// Notify *all* waiting threads of the condition variable event
///
/// Returns when there are no waiting threads.
///
/// # Panics
/// If:
/// - the condition variable got into an invalid state
/// - ran out of memory while notifying other threads.
pub fn notify_all(&self) {
// For the `expect()` message, out of memory could be a reason for
// failing, but it is unlikely given that the memory allocation is a
// `void *` per waiting thread.
self.inner
.notify_all()
.expect("Condition variable is in an invalid state");
}
}
4 changes: 4 additions & 0 deletions sync/src/sys/locks/mutex.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,4 +54,8 @@ impl Mutex {
.try_lock()
.expect("Mutex got into an invalid state.")
}

pub(crate) fn raw(&self) -> &SgxMutex {
&self.inner
}
}

0 comments on commit 2d4e076

Please sign in to comment.