drm/control/
syncobj.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
//! # SyncObj
//!
//! A SyncObj is a binding point for the DRM subsystem to attach single-use fences which are
//! signalled when a device task completes. They are typically provided as optional arguments to
//! device-specific command submission IOCTLs. In practice, they are used to implement Vulkan
//! fence objects.
//!
//! After a submission IOCTL sets a fence into a SyncObj, it may be exported as a sync file
//! descriptor. This sync file may be epoll()'d for EPOLLIN to implement asynchronous waiting on
//! multiple events. This file descriptor is also compatible with [`tokio::io::unix::AsyncFd`] for
//! Rust async/await integration.
//!
//! [`tokio::io::unix::AsyncFd`]: <https://docs.rs/tokio/latest/tokio/io/unix/struct.AsyncFd.html>

use crate::control;

/// A handle to a specific syncobj
#[repr(transparent)]
#[derive(Copy, Clone, Hash, PartialEq, Eq)]
pub struct Handle(control::RawResourceHandle);

// Safety: Handle is repr(transparent) over NonZeroU32
unsafe impl bytemuck::ZeroableInOption for Handle {}
unsafe impl bytemuck::PodInOption for Handle {}
unsafe impl bytemuck::NoUninit for Handle {}

impl From<Handle> for control::RawResourceHandle {
    fn from(handle: Handle) -> Self {
        handle.0
    }
}

impl From<Handle> for u32 {
    fn from(handle: Handle) -> Self {
        handle.0.into()
    }
}

impl From<control::RawResourceHandle> for Handle {
    fn from(handle: control::RawResourceHandle) -> Self {
        Handle(handle)
    }
}

impl std::fmt::Debug for Handle {
    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
        f.debug_tuple("syncobj::Handle").field(&self.0).finish()
    }
}