From a2ffb96ee28a5698d48613ff4acb920420fa653a Mon Sep 17 00:00:00 2001 From: Mara Bos Date: Sat, 3 Oct 2020 13:46:16 +0200 Subject: [PATCH 1/3] Don't leak a forever-blocked thread in test_rwlock_recursive. --- src/rwlock.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/rwlock.rs b/src/rwlock.rs index 89987c64..70e1b1a7 100644 --- a/src/rwlock.rs +++ b/src/rwlock.rs @@ -539,8 +539,8 @@ mod tests { fn test_rwlock_recursive() { let arc = Arc::new(RwLock::new(1)); let arc2 = arc.clone(); - let _lock1 = arc.read(); - thread::spawn(move || { + let lock1 = arc.read(); + let t = thread::spawn(move || { let _lock = arc2.write(); }); @@ -554,7 +554,12 @@ mod tests { } // A normal read would block here since there is a pending writer - let _lock2 = arc.read_recursive(); + let lock2 = arc.read_recursive(); + + // Unblock the thread and join it. + drop(lock1); + drop(lock2); + t.join().unwrap(); } #[test] From 420bc3e82f94a582a49314962c0776c4bd3df6a1 Mon Sep 17 00:00:00 2001 From: Mara Bos Date: Sat, 3 Oct 2020 13:46:47 +0200 Subject: [PATCH 2/3] Explicitly yield in test_condvar_requeue, to make it work on Miri. --- src/condvar.rs | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/condvar.rs b/src/condvar.rs index 54511686..534b8aff 100644 --- a/src/condvar.rs +++ b/src/condvar.rs @@ -663,6 +663,9 @@ mod tests { while !c.notify_one() { // Wait for the thread to get into wait() MutexGuard::bump(&mut g); + // Yield, so the other thread gets a chance to do something. + // (At least Miri needs this, because it doesn't preempt threads.) + thread::yield_now(); } // The thread should have been requeued to the mutex, which we wake up now. drop(g); From 1f8df370bf47f522963cbdbd49184e0d298ad56e Mon Sep 17 00:00:00 2001 From: Mara Bos Date: Sat, 3 Oct 2020 16:39:40 +0200 Subject: [PATCH 3/3] Remove cloudabi from CI. Cloudabi is no longer available from rustup, as it has been moved to tier 3. --- .github/workflows/rust.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/rust.yml b/.github/workflows/rust.yml index daf2895f..d613089a 100644 --- a/.github/workflows/rust.yml +++ b/.github/workflows/rust.yml @@ -42,7 +42,6 @@ jobs: - wasm32-unknown-unknown - x86_64-fortanix-unknown-sgx #- x86_64-unknown-redox - - x86_64-unknown-cloudabi #- x86_64-linux-android steps: - uses: actions/checkout@v2