use ax_errno::{AxError, AxResult};
use bitflags::bitflags;
use linux_raw_sys::general::{EFD_CLOEXEC, EFD_NONBLOCK, EFD_SEMAPHORE};
use crate::file::{FileLike, add_file_like, event::EventFd};
bitflags! {
#[derive(Debug, Clone, Copy, Default)]
pub struct EventFdFlags: u32 {
const CLOEXEC = EFD_CLOEXEC;
const NONBLOCK = EFD_NONBLOCK;
const SEMAPHORE = EFD_SEMAPHORE;
}
}
pub fn sys_eventfd2(initval: u32, flags: u32) -> AxResult<isize> {
debug!("sys_eventfd2 <= initval: {initval}, flags: {flags}");
let flags = EventFdFlags::from_bits(flags).ok_or(AxError::InvalidInput)?;
let event_fd = EventFd::new(initval as _, flags.contains(EventFdFlags::SEMAPHORE));
event_fd.set_nonblocking(flags.contains(EventFdFlags::NONBLOCK))?;
add_file_like(event_fd as _, flags.contains(EventFdFlags::CLOEXEC)).map(|fd| fd as _)
}