Source-Changes-D archive

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

Re: CVS commit: src/sys



On Tue, Jul 07, 2009 at 06:34:49PM -0500, David Young wrote:
> On Tue, Jul 07, 2009 at 10:47:51PM +0200, Joerg Sonnenberger wrote:
> > On Tue, Jul 07, 2009 at 01:26:13PM -0500, David Young wrote:
> > > How is this for a fix?  I haven't run-tested this, yet.
> > 
> > Wouldn't a pool serve the same purpose with less code?
> 
> I don't see why not.  See attachment.

The previous patch didn't work, try this.

Dave

-- 
David Young             OJC Technologies
dyoung%ojctech.com@localhost      Urbana, IL * (217) 278-3933
Index: sys/kern/kern_pmf.c
===================================================================
RCS file: /cvsroot/src/sys/kern/kern_pmf.c,v
retrieving revision 1.27
diff -p -u -u -p -r1.27 kern_pmf.c
--- sys/kern/kern_pmf.c 26 Jun 2009 19:30:45 -0000      1.27
+++ sys/kern/kern_pmf.c 8 Jul 2009 15:44:00 -0000
@@ -94,6 +94,11 @@ typedef struct pmf_event_workitem {
        device_t                pew_device;
 } pmf_event_workitem_t;
 
+static pool_cache_t pew_pc;
+
+static pmf_event_workitem_t *pmf_event_workitem_get(void);
+static void pmf_event_workitem_put(pmf_event_workitem_t *);
+
 
 
 static bool pmf_device_resume_locked(device_t PMF_FN_PROTO);
@@ -116,7 +121,7 @@ pmf_event_worker(struct work *wk, void *
                        (*event->pmf_handler)(event->pmf_device);
        }
 
-       kmem_free(pew, sizeof(*pew));
+       pmf_event_workitem_put(pew);
 }
 
 static bool
@@ -555,7 +560,7 @@ pmf_event_inject(device_t dv, pmf_generi
 {
        pmf_event_workitem_t *pew;
 
-       pew = kmem_alloc(sizeof(pmf_event_workitem_t), KM_NOSLEEP);
+       pew = pmf_event_workitem_get();
        if (pew == NULL) {
                PMF_EVENT_PRINTF(("%s: PMF event %d dropped (no memory)\n",
                    dv ? device_xname(dv) : "<anonymous>", ev));
@@ -686,11 +691,36 @@ pmf_class_display_register(device_t dv)
        return true;
 }
 
+static void
+pmf_event_workitem_put(pmf_event_workitem_t *pew)
+{
+       KASSERT(pew != NULL);
+       pool_cache_put(pew_pc, pew);
+}
+
+static pmf_event_workitem_t *
+pmf_event_workitem_get(void)
+{
+       return pool_cache_get(pew_pc, PR_NOWAIT);
+}
+
+static int
+pew_constructor(void *arg, void *obj, int flags)
+{
+       memset(obj, 0, sizeof(pmf_event_workitem_t));
+       return 0;
+}
+
 void
 pmf_init(void)
 {
        int err;
 
+       pew_pc = pool_cache_init(sizeof(pmf_event_workitem_t), 0, 0, 0,
+           "pew pool", NULL, IPL_HIGH, pew_constructor, NULL, NULL);
+       pool_cache_setlowat(pew_pc, 16);
+       pool_cache_sethiwat(pew_pc, 256);
+
        KASSERT(pmf_event_workqueue == NULL);
        err = workqueue_create(&pmf_event_workqueue, "pmfevent",
            pmf_event_worker, NULL, PRI_NONE, IPL_VM, 0);


Home | Main Index | Thread Index | Old Index