Konstantin Demin
8cbaf1dea2
3rd patchs (in alphabetical order): - bbr3 - ntsync5 - openwrt - pf-kernel - xanmod - zen no configuration changes for now
68 lines
1.9 KiB
Diff
68 lines
1.9 KiB
Diff
From a6f107f17a976008b85c3e269bf4196e595d3f52 Mon Sep 17 00:00:00 2001
|
|
From: Elizabeth Figura <zfigura@codeweavers.com>
|
|
Date: Sun, 19 May 2024 15:24:33 -0500
|
|
Subject: ntsync: Introduce NTSYNC_IOC_EVENT_SET.
|
|
|
|
This corresponds to the NT syscall NtSetEvent().
|
|
|
|
This sets the event to the signaled state, and returns its previous state.
|
|
|
|
Signed-off-by: Elizabeth Figura <zfigura@codeweavers.com>
|
|
---
|
|
drivers/misc/ntsync.c | 27 +++++++++++++++++++++++++++
|
|
include/uapi/linux/ntsync.h | 1 +
|
|
2 files changed, 28 insertions(+)
|
|
|
|
--- a/drivers/misc/ntsync.c
|
|
+++ b/drivers/misc/ntsync.c
|
|
@@ -534,6 +534,31 @@ static int ntsync_mutex_kill(struct ntsy
|
|
return ret;
|
|
}
|
|
|
|
+static int ntsync_event_set(struct ntsync_obj *event, void __user *argp)
|
|
+{
|
|
+ struct ntsync_device *dev = event->dev;
|
|
+ __u32 prev_state;
|
|
+ bool all;
|
|
+
|
|
+ if (event->type != NTSYNC_TYPE_EVENT)
|
|
+ return -EINVAL;
|
|
+
|
|
+ all = ntsync_lock_obj(dev, event);
|
|
+
|
|
+ prev_state = event->u.event.signaled;
|
|
+ event->u.event.signaled = true;
|
|
+ if (all)
|
|
+ try_wake_all_obj(dev, event);
|
|
+ try_wake_any_event(event);
|
|
+
|
|
+ ntsync_unlock_obj(dev, event, all);
|
|
+
|
|
+ if (put_user(prev_state, (__u32 __user *)argp))
|
|
+ return -EFAULT;
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
static int ntsync_obj_release(struct inode *inode, struct file *file)
|
|
{
|
|
struct ntsync_obj *obj = file->private_data;
|
|
@@ -557,6 +582,8 @@ static long ntsync_obj_ioctl(struct file
|
|
return ntsync_mutex_unlock(obj, argp);
|
|
case NTSYNC_IOC_MUTEX_KILL:
|
|
return ntsync_mutex_kill(obj, argp);
|
|
+ case NTSYNC_IOC_EVENT_SET:
|
|
+ return ntsync_event_set(obj, argp);
|
|
default:
|
|
return -ENOIOCTLCMD;
|
|
}
|
|
--- a/include/uapi/linux/ntsync.h
|
|
+++ b/include/uapi/linux/ntsync.h
|
|
@@ -51,5 +51,6 @@ struct ntsync_wait_args {
|
|
#define NTSYNC_IOC_SEM_POST _IOWR('N', 0x81, __u32)
|
|
#define NTSYNC_IOC_MUTEX_UNLOCK _IOWR('N', 0x85, struct ntsync_mutex_args)
|
|
#define NTSYNC_IOC_MUTEX_KILL _IOW ('N', 0x86, __u32)
|
|
+#define NTSYNC_IOC_EVENT_SET _IOR ('N', 0x88, __u32)
|
|
|
|
#endif
|