staging: unisys: remove typedef for PERIODIC_WORK
authorBenjamin Romer <benjamin.romer@unisys.com>
Tue, 30 Sep 2014 16:07:46 +0000 (12:07 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 2 Oct 2014 16:42:30 +0000 (09:42 -0700)
In periodic_work.h, remove the typedef PERIODIC_WORK and replace it with
struct periodic_work, and update functions used to manipulate the
structure to use the new name. The functions used to manipulate the
PERIODIC_WORK type are updated to use the fixed name, corrected for
clarity, and changed to not use periodic_work as the parameter's name.

Signed-off-by: Benjamin Romer <benjamin.romer@unisys.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/unisys/include/periodic_work.h
drivers/staging/unisys/visorutil/periodic_work.c

index 21553c8667f912d5389154cdac6f744fac8c0ec5..26ec10bdfe655a169a703c167e7ec184d3100035 100644 (file)
 /* PERIODIC_WORK an opaque structure to users.
  * Fields are declared only in the implementation .c files.
  */
-typedef struct PERIODIC_WORK_Tag PERIODIC_WORK;
+struct periodic_work;
 
-PERIODIC_WORK *visor_periodic_work_create(ulong jiffy_interval,
-                                         struct workqueue_struct *workqueue,
-                                         void (*workfunc)(void *),
-                                         void *workfuncarg,
-                                         const char *devnam);
-void            visor_periodic_work_destroy(PERIODIC_WORK *periodic_work);
-BOOL            visor_periodic_work_nextperiod(PERIODIC_WORK *periodic_work);
-BOOL            visor_periodic_work_start(PERIODIC_WORK *periodic_work);
-BOOL            visor_periodic_work_stop(PERIODIC_WORK *periodic_work);
+struct periodic_work *visor_periodic_work_create(ulong jiffy_interval,
+                                       struct workqueue_struct *workqueue,
+                                       void (*workfunc)(void *),
+                                       void *workfuncarg,
+                                       const char *devnam);
+void visor_periodic_work_destroy(struct periodic_work *pw);
+BOOL visor_periodic_work_nextperiod(struct periodic_work *pw);
+BOOL visor_periodic_work_start(struct periodic_work *pw);
+BOOL visor_periodic_work_stop(struct periodic_work *pw);
 
 #endif
index 38a60ce8c27c192e57988be1769d5432d0fba9fb..3dd1c04d0e14f214386bd7c014e340145f9dfe00 100644 (file)
@@ -27,7 +27,7 @@
 
 
 
-struct PERIODIC_WORK_Tag {
+struct periodic_work {
        rwlock_t lock;
        struct delayed_work work;
        void (*workfunc)(void *);
@@ -43,42 +43,41 @@ struct PERIODIC_WORK_Tag {
 
 static void periodic_work_func(struct work_struct *work)
 {
-       PERIODIC_WORK *periodic_work =
-               container_of(work, struct PERIODIC_WORK_Tag, work.work);
-       (*periodic_work->workfunc)(periodic_work->workfuncarg);
+       struct periodic_work *pw;
+
+       pw = container_of(work, struct periodic_work, work.work);
+       (*pw->workfunc)(pw->workfuncarg);
 }
 
 
 
-PERIODIC_WORK *visor_periodic_work_create(ulong jiffy_interval,
-                                         struct workqueue_struct *workqueue,
-                                         void (*workfunc)(void *),
-                                         void *workfuncarg,
-                                         const char *devnam)
+struct periodic_work *visor_periodic_work_create(ulong jiffy_interval,
+                                       struct workqueue_struct *workqueue,
+                                       void (*workfunc)(void *),
+                                       void *workfuncarg,
+                                       const char *devnam)
 {
-       PERIODIC_WORK *periodic_work = kzalloc(sizeof(PERIODIC_WORK),
-                                              GFP_KERNEL | __GFP_NORETRY);
-       if (periodic_work == NULL) {
-               ERRDRV("periodic_work allocation failed ");
+       struct periodic_work *pw;
+
+       pw = kzalloc(sizeof(*pw), GFP_KERNEL | __GFP_NORETRY);
+       if (!pw)
                return NULL;
-       }
-       rwlock_init(&periodic_work->lock);
-       periodic_work->jiffy_interval = jiffy_interval;
-       periodic_work->workqueue = workqueue;
-       periodic_work->workfunc = workfunc;
-       periodic_work->workfuncarg = workfuncarg;
-       periodic_work->devnam = devnam;
-       return periodic_work;
+
+       rwlock_init(&pw->lock);
+       pw->jiffy_interval = jiffy_interval;
+       pw->workqueue = workqueue;
+       pw->workfunc = workfunc;
+       pw->workfuncarg = workfuncarg;
+       pw->devnam = devnam;
+       return pw;
 }
 EXPORT_SYMBOL_GPL(visor_periodic_work_create);
 
 
 
-void visor_periodic_work_destroy(PERIODIC_WORK *periodic_work)
+void visor_periodic_work_destroy(struct periodic_work *pw)
 {
-       if (periodic_work == NULL)
-               return;
-       kfree(periodic_work);
+       kfree(pw);
 }
 EXPORT_SYMBOL_GPL(visor_periodic_work_destroy);
 
@@ -89,27 +88,26 @@ EXPORT_SYMBOL_GPL(visor_periodic_work_destroy);
  *  If this function returns FALSE, there was a failure and the
  *  periodic work is no longer scheduled
  */
-BOOL visor_periodic_work_nextperiod(PERIODIC_WORK *periodic_work)
+BOOL visor_periodic_work_nextperiod(struct periodic_work *pw)
 {
        BOOL rc = FALSE;
 
-       write_lock(&periodic_work->lock);
-       if (periodic_work->want_to_stop) {
-               periodic_work->is_scheduled = FALSE;
-               periodic_work->want_to_stop = FALSE;
+       write_lock(&pw->lock);
+       if (pw->want_to_stop) {
+               pw->is_scheduled = FALSE;
+               pw->want_to_stop = FALSE;
                rc = TRUE;  /* yes, TRUE; see visor_periodic_work_stop() */
-               goto Away;
-       } else if (queue_delayed_work(periodic_work->workqueue,
-                                     &periodic_work->work,
-                                     periodic_work->jiffy_interval) < 0) {
-               ERRDEV(periodic_work->devnam, "queue_delayed_work failed!");
-               periodic_work->is_scheduled = FALSE;
+               goto unlock;
+       } else if (queue_delayed_work(pw->workqueue, &pw->work,
+                                     pw->jiffy_interval) < 0) {
+               ERRDEV(pw->devnam, "queue_delayed_work failed!");
+               pw->is_scheduled = FALSE;
                rc = FALSE;
-               goto Away;
+               goto unlock;
        }
        rc = TRUE;
-Away:
-       write_unlock(&periodic_work->lock);
+unlock:
+       write_unlock(&pw->lock);
        return rc;
 }
 EXPORT_SYMBOL_GPL(visor_periodic_work_nextperiod);
@@ -120,34 +118,32 @@ EXPORT_SYMBOL_GPL(visor_periodic_work_nextperiod);
  *  If this function returns FALSE, then no work was started
  *  (either because it was already started, or because of a failure).
  */
-BOOL visor_periodic_work_start(PERIODIC_WORK *periodic_work)
+BOOL visor_periodic_work_start(struct periodic_work *pw)
 {
        BOOL rc = FALSE;
 
-       write_lock(&periodic_work->lock);
-       if (periodic_work->is_scheduled) {
+       write_lock(&pw->lock);
+       if (pw->is_scheduled) {
                rc = FALSE;
-               goto Away;
+               goto unlock;
        }
-       if (periodic_work->want_to_stop) {
-               ERRDEV(periodic_work->devnam,
+       if (pw->want_to_stop) {
+               ERRDEV(pw->devnam,
                       "dev_start_periodic_work failed!");
                rc = FALSE;
-               goto Away;
+               goto unlock;
        }
-       INIT_DELAYED_WORK(&periodic_work->work, &periodic_work_func);
-       if (queue_delayed_work(periodic_work->workqueue,
-                              &periodic_work->work,
-                              periodic_work->jiffy_interval) < 0) {
-               ERRDEV(periodic_work->devnam,
-                      "%s queue_delayed_work failed!", __func__);
+       INIT_DELAYED_WORK(&pw->work, &periodic_work_func);
+       if (queue_delayed_work(pw->workqueue, &pw->work,
+                              pw->jiffy_interval) < 0) {
+               ERRDEV(pw->devnam, "%s queue_delayed_work failed!", __func__);
                rc = FALSE;
-               goto Away;
+               goto unlock;
        }
-       periodic_work->is_scheduled = TRUE;
+       pw->is_scheduled = TRUE;
        rc = TRUE;
-Away:
-       write_unlock(&periodic_work->lock);
+unlock:
+       write_unlock(&pw->lock);
        return rc;
 
 }
@@ -190,21 +186,20 @@ EXPORT_SYMBOL_GPL(visor_periodic_work_start);
  *     this deadlock, you will get hung up in an infinite loop saying
  *     "waiting for delayed work...".
  */
-BOOL visor_periodic_work_stop(PERIODIC_WORK *periodic_work)
+BOOL visor_periodic_work_stop(struct periodic_work *pw)
 {
        BOOL stopped_something = FALSE;
 
-       write_lock(&periodic_work->lock);
-       stopped_something = periodic_work->is_scheduled &&
-               (!periodic_work->want_to_stop);
-       while (periodic_work->is_scheduled) {
-               periodic_work->want_to_stop = TRUE;
-               if (cancel_delayed_work(&periodic_work->work)) {
+       write_lock(&pw->lock);
+       stopped_something = pw->is_scheduled && (!pw->want_to_stop);
+       while (pw->is_scheduled) {
+               pw->want_to_stop = TRUE;
+               if (cancel_delayed_work(&pw->work)) {
                        /* We get here if the delayed work was pending as
                         * delayed work, but was NOT run.
                         */
-                       ASSERT(periodic_work->is_scheduled);
-                       periodic_work->is_scheduled = FALSE;
+                       ASSERT(pw->is_scheduled);
+                       pw->is_scheduled = FALSE;
                } else {
                        /* If we get here, either the delayed work:
                         * - was run, OR,
@@ -216,9 +211,9 @@ BOOL visor_periodic_work_stop(PERIODIC_WORK *periodic_work)
                         * explains the loop...
                         */
                }
-               if (periodic_work->is_scheduled) {
-                       write_unlock(&periodic_work->lock);
-                       WARNDEV(periodic_work->devnam,
+               if (pw->is_scheduled) {
+                       write_unlock(&pw->lock);
+                       WARNDEV(pw->devnam,
                                "waiting for delayed work...");
                        /* We rely on the delayed work function running here,
                         * and eventually calling
@@ -227,11 +222,11 @@ BOOL visor_periodic_work_stop(PERIODIC_WORK *periodic_work)
                         * subsequently clear is_scheduled.
                         */
                        SLEEPJIFFIES(10);
-                       write_lock(&periodic_work->lock);
+                       write_lock(&pw->lock);
                } else
-                       periodic_work->want_to_stop = FALSE;
+                       pw->want_to_stop = FALSE;
        }
-       write_unlock(&periodic_work->lock);
+       write_unlock(&pw->lock);
        return stopped_something;
 }
 EXPORT_SYMBOL_GPL(visor_periodic_work_stop);
This page took 0.058403 seconds and 5 git commands to generate.