Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Minimal rubicon 3.x changes
Browse files Browse the repository at this point in the history
fasterthanlime committed Aug 6, 2024
1 parent ab53bf0 commit 4bde7b0
Showing 11 changed files with 80 additions and 25 deletions.
1 change: 1 addition & 0 deletions tokio/Cargo.toml
Original file line number Diff line number Diff line change
@@ -94,6 +94,7 @@ pin-project-lite = "0.2.11"
bytes = { version = "1.0.0", optional = true }
mio = { version = "1.0.1", optional = true, default-features = false }
parking_lot = { version = "0.12.0", optional = true }
rubicon = "3.4.0"

[target.'cfg(not(target_family = "wasm"))'.dependencies]
socket2 = { version = "0.5.5", optional = true, features = [ "all" ] }
34 changes: 34 additions & 0 deletions tokio/src/lib.rs
Original file line number Diff line number Diff line change
@@ -694,3 +694,37 @@ fn is_unpin<T: Unpin>() {}
/// fuzz test (`fuzz_linked_list`)
#[cfg(fuzzing)]
pub mod fuzz;

rubicon::compatibility_check! {
("version", env!("CARGO_PKG_VERSION")),

#[cfg(feature = "fs")]
("fs", "enabled"),

#[cfg(feature = "io-util")]
("io-util", "enabled"),

#[cfg(feature = "io-std")]
("io-std", "enabled"),

#[cfg(feature = "net")]
("net", "enabled"),

#[cfg(feature = "process")]
("process", "enabled"),

#[cfg(feature = "rt")]
("rt", "enabled"),

#[cfg(feature = "rt-multi-thread")]
("rt-multi-thread", "enabled"),

#[cfg(feature = "signal")]
("signal", "enabled"),

#[cfg(feature = "sync")]
("sync", "enabled"),

#[cfg(feature = "time")]
("time", "enabled"),
}
2 changes: 1 addition & 1 deletion tokio/src/macros/thread_local.rs
Original file line number Diff line number Diff line change
@@ -13,6 +13,6 @@ macro_rules! tokio_thread_local {
#[cfg(not(all(loom, test)))]
macro_rules! tokio_thread_local {
($($tts:tt)+) => {
::std::thread_local!{ $($tts)+ }
::rubicon::thread_local!{ $($tts)+ }
}
}
12 changes: 8 additions & 4 deletions tokio/src/process/unix/mod.rs
Original file line number Diff line number Diff line change
@@ -68,17 +68,21 @@ cfg_not_has_const_mutex_new! {
fn get_orphan_queue() -> &'static OrphanQueueImpl<StdChild> {
use crate::util::once_cell::OnceCell;

static ORPHAN_QUEUE: OnceCell<OrphanQueueImpl<StdChild>> = OnceCell::new();
rubicon::process_local! {
static TOKIO_PROCESS_UNIX_ORPHAN_QUEUE: OnceCell<OrphanQueueImpl<StdChild>> = OnceCell::new();
}

ORPHAN_QUEUE.get(OrphanQueueImpl::new)
TOKIO_PROCESS_UNIX_ORPHAN_QUEUE.get(OrphanQueueImpl::new)
}
}

cfg_has_const_mutex_new! {
fn get_orphan_queue() -> &'static OrphanQueueImpl<StdChild> {
static ORPHAN_QUEUE: OrphanQueueImpl<StdChild> = OrphanQueueImpl::new();
rubicon::process_local! {
static TOKIO_PROCESS_UNIX_ORPHAN_QUEUE: OrphanQueueImpl<StdChild> = OrphanQueueImpl::new();
}

&ORPHAN_QUEUE
&TOKIO_PROCESS_UNIX_ORPHAN_QUEUE
}
}

8 changes: 5 additions & 3 deletions tokio/src/runtime/task/id.rs
Original file line number Diff line number Diff line change
@@ -79,14 +79,16 @@ impl Id {

#[cfg(all(test, loom))]
crate::loom::lazy_static! {
static ref NEXT_ID: StaticAtomicU64 = StaticAtomicU64::new(1);
static ref TOKIO_TASK_NEXT_ID: StaticAtomicU64 = StaticAtomicU64::new(1);
}

#[cfg(not(all(test, loom)))]
static NEXT_ID: StaticAtomicU64 = StaticAtomicU64::new(1);
rubicon::process_local! {
static TOKIO_TASK_NEXT_ID: StaticAtomicU64 = StaticAtomicU64::new(1);
}

loop {
let id = NEXT_ID.fetch_add(1, Relaxed);
let id = TOKIO_TASK_NEXT_ID.fetch_add(1, Relaxed);
if let Some(id) = NonZeroU64::new(id) {
return Self(id);
}
12 changes: 8 additions & 4 deletions tokio/src/runtime/task/list.rs
Original file line number Diff line number Diff line change
@@ -28,11 +28,13 @@ use std::num::NonZeroU64;
cfg_has_atomic_u64! {
use std::sync::atomic::AtomicU64;

static NEXT_OWNED_TASKS_ID: AtomicU64 = AtomicU64::new(1);
rubicon::process_local! {
static TOKIO_NEXT_OWNED_TASKS_ID: AtomicU64 = AtomicU64::new(1);
}

fn get_next_id() -> NonZeroU64 {
loop {
let id = NEXT_OWNED_TASKS_ID.fetch_add(1, Ordering::Relaxed);
let id = TOKIO_NEXT_OWNED_TASKS_ID.fetch_add(1, Ordering::Relaxed);
if let Some(id) = NonZeroU64::new(id) {
return id;
}
@@ -43,11 +45,13 @@ cfg_has_atomic_u64! {
cfg_not_has_atomic_u64! {
use std::sync::atomic::AtomicU32;

static NEXT_OWNED_TASKS_ID: AtomicU32 = AtomicU32::new(1);
rubicon::process_local! {
static TOKIO_NEXT_OWNED_TASKS_ID: AtomicU32 = AtomicU32::new(1);
}

fn get_next_id() -> NonZeroU64 {
loop {
let id = NEXT_OWNED_TASKS_ID.fetch_add(1, Ordering::Relaxed);
let id = TOKIO_NEXT_OWNED_TASKS_ID.fetch_add(1, Ordering::Relaxed);
if let Some(id) = NonZeroU64::new(u64::from(id)) {
return id;
}
8 changes: 5 additions & 3 deletions tokio/src/runtime/task/waker.rs
Original file line number Diff line number Diff line change
@@ -93,10 +93,12 @@ unsafe fn wake_by_ref(ptr: *const ()) {
raw.wake_by_ref();
}

static WAKER_VTABLE: RawWakerVTable =
RawWakerVTable::new(clone_waker, wake_by_val, wake_by_ref, drop_waker);
rubicon::process_local! {
static TOKIO_RUNTIME_TASK_WAKER_VTABLE: RawWakerVTable =
RawWakerVTable::new(clone_waker, wake_by_val, wake_by_ref, drop_waker);
}

fn raw_waker(header: NonNull<Header>) -> RawWaker {
let ptr = header.as_ptr() as *const ();
RawWaker::new(ptr, &WAKER_VTABLE)
RawWaker::new(ptr, &TOKIO_RUNTIME_TASK_WAKER_VTABLE)
}
8 changes: 5 additions & 3 deletions tokio/src/runtime/thread_id.rs
Original file line number Diff line number Diff line change
@@ -7,16 +7,18 @@ impl ThreadId {
pub(crate) fn next() -> Self {
use crate::loom::sync::atomic::{Ordering::Relaxed, StaticAtomicU64};

static NEXT_ID: StaticAtomicU64 = StaticAtomicU64::new(0);
rubicon::process_local! {
static TOKIO_RUNTIME_THREAD_NEXT_ID: StaticAtomicU64 = StaticAtomicU64::new(0);
}

let mut last = NEXT_ID.load(Relaxed);
let mut last = TOKIO_RUNTIME_THREAD_NEXT_ID.load(Relaxed);
loop {
let id = match last.checked_add(1) {
Some(id) => id,
None => exhausted(),
};

match NEXT_ID.compare_exchange_weak(last, id, Relaxed, Relaxed) {
match TOKIO_RUNTIME_THREAD_NEXT_ID.compare_exchange_weak(last, id, Relaxed, Relaxed) {
Ok(_) => return ThreadId(NonZeroU64::new(id).unwrap()),
Err(id) => last = id,
}
6 changes: 4 additions & 2 deletions tokio/src/signal/registry.rs
Original file line number Diff line number Diff line change
@@ -164,9 +164,11 @@ where
OsExtraData: 'static + Send + Sync + Init,
OsStorage: 'static + Send + Sync + Init,
{
static GLOBALS: OnceCell<Globals> = OnceCell::new();
rubicon::process_local! {
static TOKIO_SIGNAL_REGISTRY_GLOBALS: OnceCell<Globals> = OnceCell::new();
}

GLOBALS.get(globals_init)
TOKIO_SIGNAL_REGISTRY_GLOBALS.get(globals_init)
}

#[cfg(all(test, not(loom)))]
6 changes: 4 additions & 2 deletions tokio/src/signal/windows/sys.rs
Original file line number Diff line number Diff line change
@@ -88,11 +88,13 @@ impl Init for OsExtraData {
}

fn global_init() -> io::Result<()> {
static INIT: Once = Once::new();
rubicon::process_local! {
static TOKIO_SIGNAL_WINDOWS_INIT: Once = Once::new();
}

let mut init = None;

INIT.call_once(|| unsafe {
TOKIO_SIGNAL_WINDOWS_INIT.call_once(|| unsafe {
let rc = console::SetConsoleCtrlHandler(Some(handler), 1);
let ret = if rc == 0 {
Err(io::Error::last_os_error())
8 changes: 5 additions & 3 deletions tokio/src/time/clock.rs
Original file line number Diff line number Diff line change
@@ -74,7 +74,9 @@ cfg_test_util! {
// A static is used so we can avoid accessing the thread-local as well. The
// `std` AtomicBool is used directly because loom does not support static
// atomics.
static DID_PAUSE_CLOCK: StdAtomicBool = StdAtomicBool::new(false);
rubicon::process_local! {
static TOKIO_TIME_DID_PAUSE_CLOCK: StdAtomicBool = StdAtomicBool::new(false);
}

#[derive(Debug)]
struct Inner {
@@ -210,7 +212,7 @@ cfg_test_util! {

/// Returns the current instant, factoring in frozen time.
pub(crate) fn now() -> Instant {
if !DID_PAUSE_CLOCK.load(Ordering::Acquire) {
if !TOKIO_TIME_DID_PAUSE_CLOCK.load(Ordering::Acquire) {
return Instant::from_std(std::time::Instant::now());
}

@@ -257,7 +259,7 @@ cfg_test_util! {
}

// Track that we paused the clock
DID_PAUSE_CLOCK.store(true, Ordering::Release);
TOKIO_TIME_DID_PAUSE_CLOCK.store(true, Ordering::Release);

let elapsed = match inner.unfrozen.as_ref() {
Some(v) => v.elapsed(),

0 comments on commit 4bde7b0

Please sign in to comment.