Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/sysmon - Call selnotify() with sysmon_power_event_qu...



details:   https://anonhg.NetBSD.org/src/rev/651d03f927a1
branches:  trunk
changeset: 987440:651d03f927a1
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Sun Sep 26 16:24:21 2021 +0000

description:
- Call selnotify() with sysmon_power_event_queue_mtx held, passing the
  correct hints.  Adjust filt_sysmon_power_read() accordingly (assert
  that the mutex is held iff NOTE_SUBMIT).
- Mark sysmon_power_read_filtops as MPSAFE.
- Use seltrue_filtops rather than rolling our own with filt_seltrue.

diffstat:

 sys/dev/sysmon/sysmon_power.c |  37 +++++++++++++++++++------------------
 1 files changed, 19 insertions(+), 18 deletions(-)

diffs (93 lines):

diff -r c937e6af2b9f -r 651d03f927a1 sys/dev/sysmon/sysmon_power.c
--- a/sys/dev/sysmon/sysmon_power.c     Sun Sep 26 15:58:33 2021 +0000
+++ b/sys/dev/sysmon/sysmon_power.c     Sun Sep 26 16:24:21 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: sysmon_power.c,v 1.67 2021/09/26 01:16:09 thorpej Exp $        */
+/*     $NetBSD: sysmon_power.c,v 1.68 2021/09/26 16:24:21 thorpej Exp $        */
 
 /*-
  * Copyright (c) 2007 Juan Romero Pardines.
@@ -69,7 +69,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sysmon_power.c,v 1.67 2021/09/26 01:16:09 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sysmon_power.c,v 1.68 2021/09/26 16:24:21 thorpej Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_compat_netbsd.h"
@@ -419,8 +419,9 @@
                ped->flags |= SYSMON_POWER_DICTIONARY_READY;
                SIMPLEQ_INSERT_TAIL(&pev_dict_list, ped, pev_dict_head);
                cv_broadcast(&sysmon_power_event_queue_cv);
+               selnotify(&sysmon_power_event_queue_selinfo,
+                   POLLIN | POLLRDNORM, NOTE_SUBMIT);
                mutex_exit(&sysmon_power_event_queue_mtx);
-               selnotify(&sysmon_power_event_queue_selinfo, 0, 0);
        }
 
 out:
@@ -546,27 +547,28 @@
 filt_sysmon_power_read(struct knote *kn, long hint)
 {
 
-       mutex_enter(&sysmon_power_event_queue_mtx);
+       if (hint & NOTE_SUBMIT) {
+               KASSERT(mutex_owned(&sysmon_power_event_queue_mtx));
+       } else {
+               mutex_enter(&sysmon_power_event_queue_mtx);
+       }
+
        kn->kn_data = sysmon_power_event_queue_count;
-       mutex_exit(&sysmon_power_event_queue_mtx);
+
+       if ((hint & NOTE_SUBMIT) == 0) {
+               mutex_exit(&sysmon_power_event_queue_mtx);
+       }
 
        return kn->kn_data > 0;
 }
 
 static const struct filterops sysmon_power_read_filtops = {
-       .f_flags = FILTEROP_ISFD,
+       .f_flags = FILTEROP_ISFD | FILTEROP_MPSAFE,
        .f_attach = NULL,
        .f_detach = filt_sysmon_power_rdetach,
        .f_event = filt_sysmon_power_read,
 };
 
-static const struct filterops sysmon_power_write_filtops = {
-       .f_flags = FILTEROP_ISFD,
-       .f_attach = NULL,
-       .f_detach = filt_sysmon_power_rdetach,
-       .f_event = filt_seltrue,
-};
-
 /*
  * sysmonkqfilter_power:
  *
@@ -579,20 +581,19 @@
        switch (kn->kn_filter) {
        case EVFILT_READ:
                kn->kn_fop = &sysmon_power_read_filtops;
+               mutex_enter(&sysmon_power_event_queue_mtx);
+               selrecord_knote(&sysmon_power_event_queue_selinfo, kn);
+               mutex_exit(&sysmon_power_event_queue_mtx);
                break;
 
        case EVFILT_WRITE:
-               kn->kn_fop = &sysmon_power_write_filtops;
+               kn->kn_fop = &seltrue_filtops;
                break;
 
        default:
                return EINVAL;
        }
 
-       mutex_enter(&sysmon_power_event_queue_mtx);
-       selrecord_knote(&sysmon_power_event_queue_selinfo, kn);
-       mutex_exit(&sysmon_power_event_queue_mtx);
-
        return 0;
 }
 



Home | Main Index | Thread Index | Old Index