taskq style, remove #define wrappers

When the taskq implementation was originally written I wrapped all
the API functions in #define's.  This was done as a preventative
measure to ensure that a taskq symbol never conflicted with an
existing kernel symbol.

However, in practice the taskq symbols never conflicted.  The only
major conflicts occured with the kmem cache API.  Since this added
layer of obfuscation never bought us anything for the taskq's I'm
removing it.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
This commit is contained in:
Brian Behlendorf 2012-12-06 13:04:27 -08:00
parent 472a34caff
commit aed8671cb0
2 changed files with 36 additions and 46 deletions

View File

@ -103,33 +103,23 @@ typedef struct taskq_thread {
/* Global system-wide dynamic task queue available for all consumers */ /* Global system-wide dynamic task queue available for all consumers */
extern taskq_t *system_taskq; extern taskq_t *system_taskq;
extern taskqid_t __taskq_dispatch(taskq_t *, task_func_t, void *, uint_t); extern taskqid_t taskq_dispatch(taskq_t *, task_func_t, void *, uint_t);
extern void __taskq_dispatch_ent(taskq_t *, task_func_t, void *, uint_t, taskq_ent_t *); extern void taskq_dispatch_ent(taskq_t *, task_func_t, void *, uint_t,
extern int __taskq_empty_ent(taskq_ent_t *); taskq_ent_t *);
extern void __taskq_init_ent(taskq_ent_t *); extern int taskq_empty_ent(taskq_ent_t *);
extern taskq_t *__taskq_create(const char *, int, pri_t, int, int, uint_t); extern void taskq_init_ent(taskq_ent_t *);
extern void __taskq_destroy(taskq_t *); extern taskq_t *taskq_create(const char *, int, pri_t, int, int, uint_t);
extern void __taskq_wait_id(taskq_t *, taskqid_t); extern void taskq_destroy(taskq_t *);
extern void __taskq_wait(taskq_t *); extern void taskq_wait_id(taskq_t *, taskqid_t);
extern int __taskq_member(taskq_t *, void *); extern void taskq_wait(taskq_t *);
extern int taskq_member(taskq_t *, void *);
#define taskq_create_proc(name, nthreads, pri, min, max, proc, flags) \
taskq_create(name, nthreads, pri, min, max, flags)
#define taskq_create_sysdc(name, nthreads, min, max, proc, dc, flags) \
taskq_create(name, nthreads, maxclsyspri, min, max, flags)
int spl_taskq_init(void); int spl_taskq_init(void);
void spl_taskq_fini(void); void spl_taskq_fini(void);
#define taskq_member(tq, t) __taskq_member(tq, t)
#define taskq_wait_id(tq, id) __taskq_wait_id(tq, id)
#define taskq_wait(tq) __taskq_wait(tq)
#define taskq_dispatch(tq, f, p, fl) __taskq_dispatch(tq, f, p, fl)
#define taskq_dispatch_ent(tq, f, p, fl, t) \
__taskq_dispatch_ent(tq, f, p, fl, t)
#define taskq_empty_ent(t) __taskq_empty_ent(t)
#define taskq_init_ent(t) __taskq_init_ent(t)
#define taskq_create(n, th, p, mi, ma, fl) \
__taskq_create(n, th, p, mi, ma, fl)
#define taskq_create_proc(n, th, p, mi, ma, pr, fl) \
__taskq_create(n, th, p, mi, ma, fl)
#define taskq_create_sysdc(n, th, mi, ma, pr, dc, fl) \
__taskq_create(n, th, maxclsyspri, mi, ma, fl)
#define taskq_destroy(tq) __taskq_destroy(tq)
#endif /* _SPL_TASKQ_H */ #endif /* _SPL_TASKQ_H */

View File

@ -201,7 +201,7 @@ taskq_wait_check(taskq_t *tq, taskqid_t id)
} }
void void
__taskq_wait_id(taskq_t *tq, taskqid_t id) taskq_wait_id(taskq_t *tq, taskqid_t id)
{ {
SENTRY; SENTRY;
ASSERT(tq); ASSERT(tq);
@ -210,10 +210,10 @@ __taskq_wait_id(taskq_t *tq, taskqid_t id)
SEXIT; SEXIT;
} }
EXPORT_SYMBOL(__taskq_wait_id); EXPORT_SYMBOL(taskq_wait_id);
void void
__taskq_wait(taskq_t *tq) taskq_wait(taskq_t *tq)
{ {
taskqid_t id; taskqid_t id;
SENTRY; SENTRY;
@ -224,15 +224,15 @@ __taskq_wait(taskq_t *tq)
id = tq->tq_next_id - 1; id = tq->tq_next_id - 1;
spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags); spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags);
__taskq_wait_id(tq, id); taskq_wait_id(tq, id);
SEXIT; SEXIT;
} }
EXPORT_SYMBOL(__taskq_wait); EXPORT_SYMBOL(taskq_wait);
int int
__taskq_member(taskq_t *tq, void *t) taskq_member(taskq_t *tq, void *t)
{ {
struct list_head *l; struct list_head *l;
taskq_thread_t *tqt; taskq_thread_t *tqt;
@ -249,10 +249,10 @@ __taskq_member(taskq_t *tq, void *t)
SRETURN(0); SRETURN(0);
} }
EXPORT_SYMBOL(__taskq_member); EXPORT_SYMBOL(taskq_member);
taskqid_t taskqid_t
__taskq_dispatch(taskq_t *tq, task_func_t func, void *arg, uint_t flags) taskq_dispatch(taskq_t *tq, task_func_t func, void *arg, uint_t flags)
{ {
taskq_ent_t *t; taskq_ent_t *t;
taskqid_t rc = 0; taskqid_t rc = 0;
@ -297,10 +297,10 @@ out:
spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags); spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags);
SRETURN(rc); SRETURN(rc);
} }
EXPORT_SYMBOL(__taskq_dispatch); EXPORT_SYMBOL(taskq_dispatch);
void void
__taskq_dispatch_ent(taskq_t *tq, task_func_t func, void *arg, uint_t flags, taskq_dispatch_ent(taskq_t *tq, task_func_t func, void *arg, uint_t flags,
taskq_ent_t *t) taskq_ent_t *t)
{ {
SENTRY; SENTRY;
@ -343,17 +343,17 @@ out:
spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags); spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags);
SEXIT; SEXIT;
} }
EXPORT_SYMBOL(__taskq_dispatch_ent); EXPORT_SYMBOL(taskq_dispatch_ent);
int int
__taskq_empty_ent(taskq_ent_t *t) taskq_empty_ent(taskq_ent_t *t)
{ {
return list_empty(&t->tqent_list); return list_empty(&t->tqent_list);
} }
EXPORT_SYMBOL(__taskq_empty_ent); EXPORT_SYMBOL(taskq_empty_ent);
void void
__taskq_init_ent(taskq_ent_t *t) taskq_init_ent(taskq_ent_t *t)
{ {
spin_lock_init(&t->tqent_lock); spin_lock_init(&t->tqent_lock);
INIT_LIST_HEAD(&t->tqent_list); INIT_LIST_HEAD(&t->tqent_list);
@ -362,7 +362,7 @@ __taskq_init_ent(taskq_ent_t *t)
t->tqent_arg = NULL; t->tqent_arg = NULL;
t->tqent_flags = 0; t->tqent_flags = 0;
} }
EXPORT_SYMBOL(__taskq_init_ent); EXPORT_SYMBOL(taskq_init_ent);
/* /*
* Returns the lowest incomplete taskqid_t. The taskqid_t may * Returns the lowest incomplete taskqid_t. The taskqid_t may
@ -532,7 +532,7 @@ taskq_thread(void *args)
} }
taskq_t * taskq_t *
__taskq_create(const char *name, int nthreads, pri_t pri, taskq_create(const char *name, int nthreads, pri_t pri,
int minalloc, int maxalloc, uint_t flags) int minalloc, int maxalloc, uint_t flags)
{ {
taskq_t *tq; taskq_t *tq;
@ -610,16 +610,16 @@ __taskq_create(const char *name, int nthreads, pri_t pri,
wait_event(tq->tq_wait_waitq, tq->tq_nthreads == j); wait_event(tq->tq_wait_waitq, tq->tq_nthreads == j);
if (rc) { if (rc) {
__taskq_destroy(tq); taskq_destroy(tq);
tq = NULL; tq = NULL;
} }
SRETURN(tq); SRETURN(tq);
} }
EXPORT_SYMBOL(__taskq_create); EXPORT_SYMBOL(taskq_create);
void void
__taskq_destroy(taskq_t *tq) taskq_destroy(taskq_t *tq)
{ {
struct task_struct *thread; struct task_struct *thread;
taskq_thread_t *tqt; taskq_thread_t *tqt;
@ -632,7 +632,7 @@ __taskq_destroy(taskq_t *tq)
spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags); spin_unlock_irqrestore(&tq->tq_lock, tq->tq_lock_flags);
/* TQ_ACTIVE cleared prevents new tasks being added to pending */ /* TQ_ACTIVE cleared prevents new tasks being added to pending */
__taskq_wait(tq); taskq_wait(tq);
spin_lock_irqsave(&tq->tq_lock, tq->tq_lock_flags); spin_lock_irqsave(&tq->tq_lock, tq->tq_lock_flags);
@ -676,7 +676,7 @@ __taskq_destroy(taskq_t *tq)
SEXIT; SEXIT;
} }
EXPORT_SYMBOL(__taskq_destroy); EXPORT_SYMBOL(taskq_destroy);
int int
spl_taskq_init(void) spl_taskq_init(void)