From d0a3e38006fe800c1286638031fbdd7d6281d6ac Mon Sep 17 00:00:00 2001 From: Wolfgang Bumiller Date: Thu, 20 Jan 2022 10:05:07 +0100 Subject: [PATCH] drop RawWaker usage this was also leaking a refcount before, this is fixed now Signed-off-by: Wolfgang Bumiller --- proxmox-async/src/runtime.rs | 49 +++++++++++------------------------- 1 file changed, 14 insertions(+), 35 deletions(-) diff --git a/proxmox-async/src/runtime.rs b/proxmox-async/src/runtime.rs index baa7ded0..a99a9b3d 100644 --- a/proxmox-async/src/runtime.rs +++ b/proxmox-async/src/runtime.rs @@ -3,7 +3,7 @@ use std::cell::RefCell; use std::future::Future; use std::sync::{Arc, Weak, Mutex}; -use std::task::{Context, Poll, RawWaker, Waker}; +use std::task::{Context, Poll, Waker}; use std::thread::{self, Thread}; use lazy_static::lazy_static; @@ -156,12 +156,22 @@ pub fn main(fut: F) -> F::Output { block_on(fut) } +struct ThreadWaker(Thread); + +impl std::task::Wake for ThreadWaker { + fn wake(self: Arc) { + self.0.unpark(); + } + + fn wake_by_ref(self: &Arc) { + self.0.unpark(); + } +} + fn block_on_local_future(fut: F) -> F::Output { pin_mut!(fut); - let waker = Arc::new(thread::current()); - let waker = thread_waker_clone(Arc::into_raw(waker) as *const ()); - let waker = unsafe { Waker::from_raw(waker) }; + let waker = Waker::from(Arc::new(ThreadWaker(thread::current()))); let mut context = Context::from_waker(&waker); loop { match fut.as_mut().poll(&mut context) { @@ -170,34 +180,3 @@ fn block_on_local_future(fut: F) -> F::Output { } } } - -const THREAD_WAKER_VTABLE: std::task::RawWakerVTable = std::task::RawWakerVTable::new( - thread_waker_clone, - thread_waker_wake, - thread_waker_wake_by_ref, - thread_waker_drop, -); - -fn thread_waker_clone(this: *const ()) -> RawWaker { - let this = unsafe { Arc::from_raw(this as *const Thread) }; - let cloned = Arc::clone(&this); - let _ = Arc::into_raw(this); - - RawWaker::new(Arc::into_raw(cloned) as *const (), &THREAD_WAKER_VTABLE) -} - -fn thread_waker_wake(this: *const ()) { - let this = unsafe { Arc::from_raw(this as *const Thread) }; - this.unpark(); -} - -fn thread_waker_wake_by_ref(this: *const ()) { - let this = unsafe { Arc::from_raw(this as *const Thread) }; - this.unpark(); - let _ = Arc::into_raw(this); -} - -fn thread_waker_drop(this: *const ()) { - let this = unsafe { Arc::from_raw(this as *const Thread) }; - drop(this); -}