| /* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */ |
| /* |
| * Copyright (c) 2016 Mellanox Technologies Ltd. All rights reserved. |
| * Copyright (c) 2015 System Fabric Works, Inc. All rights reserved. |
| */ |
| |
| #ifndef RXE_TASK_H |
| #define RXE_TASK_H |
| |
| enum { |
| TASK_STATE_START = 0, |
| TASK_STATE_BUSY = 1, |
| TASK_STATE_ARMED = 2, |
| }; |
| |
| /* |
| * data structure to describe a 'task' which is a short |
| * function that returns 0 as long as it needs to be |
| * called again. |
| */ |
| struct rxe_task { |
| void *obj; |
| struct tasklet_struct tasklet; |
| int state; |
| spinlock_t state_lock; /* spinlock for task state */ |
| void *arg; |
| int (*func)(void *arg); |
| int ret; |
| char name[16]; |
| bool destroyed; |
| }; |
| |
| /* |
| * init rxe_task structure |
| * arg => parameter to pass to fcn |
| * func => function to call until it returns != 0 |
| */ |
| int rxe_init_task(void *obj, struct rxe_task *task, |
| void *arg, int (*func)(void *), char *name); |
| |
| /* cleanup task */ |
| void rxe_cleanup_task(struct rxe_task *task); |
| |
| /* |
| * raw call to func in loop without any checking |
| * can call when tasklets are disabled |
| */ |
| int __rxe_do_task(struct rxe_task *task); |
| |
| /* |
| * common function called by any of the main tasklets |
| * If there is any chance that there is additional |
| * work to do someone must reschedule the task before |
| * leaving |
| */ |
| void rxe_do_task(struct tasklet_struct *t); |
| |
| /* run a task, else schedule it to run as a tasklet, The decision |
| * to run or schedule tasklet is based on the parameter sched. |
| */ |
| void rxe_run_task(struct rxe_task *task, int sched); |
| |
| /* keep a task from scheduling */ |
| void rxe_disable_task(struct rxe_task *task); |
| |
| /* allow task to run */ |
| void rxe_enable_task(struct rxe_task *task); |
| |
| #endif /* RXE_TASK_H */ |