Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Allow the f_touch() filter op to return an error, specif...
details: https://anonhg.NetBSD.org/src/rev/7f1722bd9eb2
branches: trunk
changeset: 1024377:7f1722bd9eb2
user: thorpej <thorpej%NetBSD.org@localhost>
date: Thu Oct 21 02:34:03 2021 +0000
description:
Allow the f_touch() filter op to return an error, specifically in
the EVENT_REGISTER case.
diffstat:
sys/kern/kern_event.c | 27 +++++++++++++++++----------
sys/sys/event.h | 4 ++--
2 files changed, 19 insertions(+), 12 deletions(-)
diffs (118 lines):
diff -r 5d1b2e82816c -r 7f1722bd9eb2 sys/kern/kern_event.c
--- a/sys/kern/kern_event.c Thu Oct 21 01:11:21 2021 +0000
+++ b/sys/kern/kern_event.c Thu Oct 21 02:34:03 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: kern_event.c,v 1.134 2021/10/21 01:11:21 thorpej Exp $ */
+/* $NetBSD: kern_event.c,v 1.135 2021/10/21 02:34:03 thorpej Exp $ */
/*-
* Copyright (c) 2008, 2009, 2021 The NetBSD Foundation, Inc.
@@ -63,7 +63,7 @@
#endif /* _KERNEL_OPT */
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_event.c,v 1.134 2021/10/21 01:11:21 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_event.c,v 1.135 2021/10/21 02:34:03 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -116,7 +116,7 @@
static int filt_userattach(struct knote *);
static void filt_userdetach(struct knote *);
static int filt_user(struct knote *, long hint);
-static void filt_usertouch(struct knote *, struct kevent *, long type);
+static int filt_usertouch(struct knote *, struct kevent *, long type);
static const struct fileops kqueueops = {
.fo_name = "kqueue",
@@ -476,10 +476,10 @@
return rv;
}
-static void
+static int
filter_touch(struct knote *kn, struct kevent *kev, long type)
{
- kn->kn_fop->f_touch(kn, kev, type);
+ return kn->kn_fop->f_touch(kn, kev, type);
}
static kauth_listener_t kqueue_listener;
@@ -1384,7 +1384,7 @@
return hookid;
}
-static void
+static int
filt_usertouch(struct knote *kn, struct kevent *kev, long type)
{
int ffctrl;
@@ -1441,6 +1441,8 @@
panic("filt_usertouch() - invalid type (%ld)", type);
break;
}
+
+ return 0;
}
/*
@@ -1874,8 +1876,13 @@
if (!(kn->kn_fop->f_flags & FILTEROP_ISFD) &&
kn->kn_fop->f_touch != NULL) {
mutex_spin_enter(&kq->kq_lock);
- filter_touch(kn, kev, EVENT_REGISTER);
+ error = filter_touch(kn, kev, EVENT_REGISTER);
mutex_spin_exit(&kq->kq_lock);
+ if (__predict_false(error != 0)) {
+ /* Never a new knote (which would consume newkn). */
+ KASSERT(newkn != NULL);
+ goto doneunlock;
+ }
} else {
kn->kn_sfflags = kev->fflags;
kn->kn_sdata = kev->data;
@@ -1887,7 +1894,7 @@
* support events, and the attach routine is
* broken and does not return an error.
*/
-done_ev_add:
+ done_ev_add:
rv = filter_event(kn, 0);
if (rv)
knote_activate(kn);
@@ -1904,7 +1911,7 @@
if ((kev->flags & EV_ENABLE)) {
knote_enqueue(kn);
}
-doneunlock:
+ doneunlock:
mutex_exit(&fdp->fd_lock);
done:
rw_exit(&kqueue_filter_lock);
@@ -2197,7 +2204,7 @@
kn->kn_fop->f_touch != NULL);
/* XXXAD should be got from f_event if !oneshot. */
if (touch) {
- filter_touch(kn, kevp, EVENT_PROCESS);
+ (void)filter_touch(kn, kevp, EVENT_PROCESS);
} else {
*kevp = kn->kn_kevent;
}
diff -r 5d1b2e82816c -r 7f1722bd9eb2 sys/sys/event.h
--- a/sys/sys/event.h Thu Oct 21 01:11:21 2021 +0000
+++ b/sys/sys/event.h Thu Oct 21 02:34:03 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: event.h,v 1.49 2021/10/20 03:08:18 thorpej Exp $ */
+/* $NetBSD: event.h,v 1.50 2021/10/21 02:34:04 thorpej Exp $ */
/*-
* Copyright (c) 1999,2000,2001 Jonathan Lemon <jlemon%FreeBSD.org@localhost>
@@ -230,7 +230,7 @@
/* called when knote is DELETEd */
int (*f_event) (struct knote *, long);
/* called when event is triggered */
- void (*f_touch) (struct knote *, struct kevent *, long);
+ int (*f_touch) (struct knote *, struct kevent *, long);
};
/* filterops flags */
Home |
Main Index |
Thread Index |
Old Index