Source-Changes-HG archive

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

[src/trunk]: src/sys/external/bsd/common/linux Sprinkle dtrace probes all ove...



details:   https://anonhg.NetBSD.org/src/rev/ee568cef9c12
branches:  trunk
changeset: 993070:ee568cef9c12
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Mon Aug 27 15:06:37 2018 +0000

description:
Sprinkle dtrace probes all over the Linux workqueue stuff.

diffstat:

 sys/external/bsd/common/linux/linux_work.c |  106 ++++++++++++++++++++++++++++-
 1 files changed, 104 insertions(+), 2 deletions(-)

diffs (truncated from 379 to 300 lines):

diff -r b9bb6e203984 -r ee568cef9c12 sys/external/bsd/common/linux/linux_work.c
--- a/sys/external/bsd/common/linux/linux_work.c        Mon Aug 27 15:06:20 2018 +0000
+++ b/sys/external/bsd/common/linux/linux_work.c        Mon Aug 27 15:06:37 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: linux_work.c,v 1.40 2018/08/27 15:06:20 riastradh Exp $        */
+/*     $NetBSD: linux_work.c,v 1.41 2018/08/27 15:06:37 riastradh Exp $        */
 
 /*-
  * Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: linux_work.c,v 1.40 2018/08/27 15:06:20 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: linux_work.c,v 1.41 2018/08/27 15:06:37 riastradh Exp $");
 
 #include <sys/types.h>
 #include <sys/atomic.h>
@@ -42,6 +42,7 @@
 #include <sys/lwp.h>
 #include <sys/mutex.h>
 #include <sys/queue.h>
+#include <sys/sdt.h>
 
 #include <linux/workqueue.h>
 
@@ -80,6 +81,36 @@
 static void            cancel_delayed_work_done(struct workqueue_struct *,
                            struct delayed_work *);
 
+SDT_PROBE_DEFINE2(sdt, linux, work, acquire,
+    "struct work_struct *"/*work*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, release,
+    "struct work_struct *"/*work*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, queue,
+    "struct work_struct *"/*work*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, cancel,
+    "struct work_struct *"/*work*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE3(sdt, linux, work, schedule,
+    "struct delayed_work *"/*dw*/, "struct workqueue_struct *"/*wq*/,
+    "unsigned long"/*ticks*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, timer,
+    "struct delayed_work *"/*dw*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, wait__start,
+    "struct delayed_work *"/*dw*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, wait__done,
+    "struct delayed_work *"/*dw*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, run,
+    "struct work_struct *"/*work*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE2(sdt, linux, work, done,
+    "struct work_struct *"/*work*/, "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE1(sdt, linux, work, batch__start,
+    "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE1(sdt, linux, work, batch__done,
+    "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE1(sdt, linux, work, flush__start,
+    "struct workqueue_struct *"/*wq*/);
+SDT_PROBE_DEFINE1(sdt, linux, work, flush__done,
+    "struct workqueue_struct *"/*wq*/);
+
 static specificdata_key_t workqueue_key __read_mostly;
 
 struct workqueue_struct        *system_wq __read_mostly;
@@ -242,6 +273,7 @@
                 * however, then we can safely destroy the callout and
                 * dissociate it from the workqueue ourselves.
                 */
+               SDT_PROBE2(sdt, linux, work, cancel,  &dw->work, wq);
                dw->dw_state = DELAYED_WORK_CANCELLED;
                if (!callout_halt(&dw->dw_callout, &wq->wq_lock))
                        cancel_delayed_work_done(wq, dw);
@@ -312,6 +344,7 @@
                }
 
                /* Grab a batch of work off the queue.  */
+               SDT_PROBE1(sdt, linux, work, batch__start,  wq);
                TAILQ_INIT(&queue);
                TAILQ_INIT(&dqueue);
                TAILQ_CONCAT(&queue, &wq->wq_queue, work_entry);
@@ -340,7 +373,9 @@
                                /* Can't dereference work after this point.  */
 
                                mutex_exit(&wq->wq_lock);
+                               SDT_PROBE2(sdt, linux, work, run,  work, wq);
                                (*func)(work);
+                               SDT_PROBE2(sdt, linux, work, done,  work, wq);
                                mutex_enter(&wq->wq_lock);
 
                                KASSERT(wq->wq_current_work == work);
@@ -352,6 +387,7 @@
                /* Notify flush that we've completed a batch of work.  */
                wq->wq_gen++;
                cv_broadcast(&wq->wq_cv);
+               SDT_PROBE1(sdt, linux, work, batch__done,  wq);
        }
        mutex_exit(&wq->wq_lock);
 
@@ -378,6 +414,8 @@
            "delayed work %p state %d resched %d",
            dw, dw->dw_state, dw->dw_resched);
 
+       SDT_PROBE2(sdt, linux, work, timer,  dw, wq);
+
        mutex_enter(&wq->wq_lock);
        KASSERT(work_queue(&dw->work) == wq);
        switch (dw->dw_state) {
@@ -387,6 +425,7 @@
                dw_callout_destroy(wq, dw);
                TAILQ_INSERT_TAIL(&wq->wq_dqueue, &dw->work, work_entry);
                cv_broadcast(&wq->wq_cv);
+               SDT_PROBE2(sdt, linux, work, queue,  &dw->work, wq);
                break;
        case DELAYED_WORK_RESCHEDULED:
                KASSERT(dw->dw_resched >= 0);
@@ -508,6 +547,7 @@
 
        KASSERT(work_queue(work) == wq);
        membar_enter();
+       SDT_PROBE2(sdt, linux, work, acquire,  work, wq);
        return true;
 }
 
@@ -526,6 +566,7 @@
        KASSERT(work_queue(work) == wq);
        KASSERT(mutex_owned(&wq->wq_lock));
 
+       SDT_PROBE2(sdt, linux, work, release,  work, wq);
        membar_exit();
 
        /*
@@ -581,6 +622,7 @@
                 */
                TAILQ_INSERT_TAIL(&wq->wq_queue, work, work_entry);
                cv_broadcast(&wq->wq_cv);
+               SDT_PROBE2(sdt, linux, work, queue,  work, wq);
                newly_queued = true;
        } else {
                /*
@@ -627,6 +669,7 @@
                         * queue and report successful cancellation.
                         */
                        TAILQ_REMOVE(&wq->wq_queue, work, work_entry);
+                       SDT_PROBE2(sdt, linux, work, cancel,  work, wq);
                        release_work(work, wq);
                        /* Can't dereference work after this point.  */
                        cancelled_p = true;
@@ -675,6 +718,7 @@
                         * queue and report successful cancellation.
                         */
                        TAILQ_REMOVE(&wq->wq_queue, work, work_entry);
+                       SDT_PROBE2(sdt, linux, work, cancel,  work, wq);
                        release_work(work, wq);
                        /* Can't dereference work after this point.  */
                        cancelled_p = true;
@@ -707,10 +751,12 @@
        KASSERT(wq->wq_current_work == work);
 
        /* Wait only one generation in case it gets requeued quickly.  */
+       SDT_PROBE2(sdt, linux, work, wait__start,  work, wq);
        gen = wq->wq_gen;
        do {
                cv_wait(&wq->wq_cv, &wq->wq_lock);
        } while (wq->wq_current_work == work && wq->wq_gen == gen);
+       SDT_PROBE2(sdt, linux, work, wait__done,  work, wq);
 }
 
 /*
@@ -846,6 +892,7 @@
                        TAILQ_INSERT_TAIL(&wq->wq_dqueue, &dw->work,
                            work_entry);
                        cv_broadcast(&wq->wq_cv);
+                       SDT_PROBE2(sdt, linux, work, queue,  &dw->work, wq);
                } else {
                        /*
                         * Initialize a callout and schedule to run
@@ -853,6 +900,7 @@
                         */
                        dw_callout_init(wq, dw);
                        callout_schedule(&dw->dw_callout, MIN(INT_MAX, ticks));
+                       SDT_PROBE3(sdt, linux, work, schedule,  dw, wq, ticks);
                }
                newly_queued = true;
        } else {
@@ -871,9 +919,13 @@
                         */
                        if (ticks == 0) {
                                dw->dw_state = DELAYED_WORK_SCHEDULED;
+                               SDT_PROBE2(sdt, linux, work, queue,
+                                   &dw->work, wq);
                        } else {
                                dw->dw_state = DELAYED_WORK_RESCHEDULED;
                                dw->dw_resched = MIN(INT_MAX, ticks);
+                               SDT_PROBE3(sdt, linux, work, schedule,
+                                   dw, wq, ticks);
                        }
                        newly_queued = true;
                        break;
@@ -917,6 +969,7 @@
                        TAILQ_INSERT_TAIL(&wq->wq_dqueue, &dw->work,
                            work_entry);
                        cv_broadcast(&wq->wq_cv);
+                       SDT_PROBE2(sdt, linux, work, queue,  &dw->work, wq);
                } else {
                        /*
                         * Initialize a callout and schedule to run
@@ -924,6 +977,7 @@
                         */
                        dw_callout_init(wq, dw);
                        callout_schedule(&dw->dw_callout, MIN(INT_MAX, ticks));
+                       SDT_PROBE3(sdt, linux, work, schedule,  dw, wq, ticks);
                }
                timer_modified = false;
        } else {
@@ -933,6 +987,10 @@
                        /* On the queue.  */
                        if (ticks == 0) {
                                /* Leave it be.  */
+                               SDT_PROBE2(sdt, linux, work, cancel,
+                                   &dw->work, wq);
+                               SDT_PROBE2(sdt, linux, work, queue,
+                                   &dw->work, wq);
                        } else {
                                /* Remove from the queue and schedule.  */
                                TAILQ_REMOVE(&wq->wq_dqueue, &dw->work,
@@ -940,6 +998,10 @@
                                dw_callout_init(wq, dw);
                                callout_schedule(&dw->dw_callout,
                                    MIN(INT_MAX, ticks));
+                               SDT_PROBE2(sdt, linux, work, cancel,
+                                   &dw->work, wq);
+                               SDT_PROBE3(sdt, linux, work, schedule,
+                                   dw, wq, ticks);
                        }
                        timer_modified = true;
                        break;
@@ -959,10 +1021,18 @@
                                         * queue it as soon as it gets
                                         * the lock.
                                         */
+                                       SDT_PROBE2(sdt, linux, work, cancel,
+                                           &dw->work, wq);
+                                       SDT_PROBE2(sdt, linux, work, queue,
+                                           &dw->work, wq);
                                } else {
                                        /* Ask the callout to reschedule.  */
                                        dw->dw_state = DELAYED_WORK_RESCHEDULED;
                                        dw->dw_resched = MIN(INT_MAX, ticks);
+                                       SDT_PROBE2(sdt, linux, work, cancel,
+                                           &dw->work, wq);
+                                       SDT_PROBE3(sdt, linux, work, schedule,
+                                           dw, wq, ticks);
                                }
                        } else {
                                /* We stopped the callout before it began.  */
@@ -977,6 +1047,10 @@
                                        TAILQ_INSERT_TAIL(&wq->wq_dqueue,
                                            &dw->work, work_entry);
                                        cv_broadcast(&wq->wq_cv);
+                                       SDT_PROBE2(sdt, linux, work, cancel,
+                                           &dw->work, wq);
+                                       SDT_PROBE2(sdt, linux, work, queue,
+                                           &dw->work, wq);
                                } else {
                                        /*
                                         * Reschedule the callout.  No
@@ -984,6 +1058,10 @@
                                         */
                                        callout_schedule(&dw->dw_callout,
                                            MIN(INT_MAX, ticks));
+                                       SDT_PROBE2(sdt, linux, work, cancel,
+                                           &dw->work, wq);
+                                       SDT_PROBE3(sdt, linux, work, schedule,
+                                           dw, wq, ticks);
                                }
                        }
                        timer_modified = true;
@@ -1003,9 +1081,17 @@
                                 */
                                dw->dw_state = DELAYED_WORK_SCHEDULED;
                                dw->dw_resched = -1;
+                               SDT_PROBE2(sdt, linux, work, cancel,
+                                   &dw->work, wq);
+                               SDT_PROBE2(sdt, linux, work, queue,
+                                   &dw->work, wq);
                        } else {
                                /* Change the rescheduled time.  */
                                dw->dw_resched = ticks;
+                               SDT_PROBE2(sdt, linux, work, cancel,
+                                   &dw->work, wq);
+                               SDT_PROBE3(sdt, linux, work, schedule,
+                                   dw, wq, ticks);
                        }
                        timer_modified = true;
                        break;
@@ -1023,10 +1109,14 @@
                                 * as it gets the lock.
                                 */
                                dw->dw_state = DELAYED_WORK_SCHEDULED;
+                               SDT_PROBE2(sdt, linux, work, queue,
+                                   &dw->work, wq);



Home | Main Index | Thread Index | Old Index