mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 00b3c11879
			
		
	
	
		00b3c11879
		
	
	
	
	
		
			
			In preparation for unconditionally passing the struct tasklet_struct pointer to all tasklet callbacks, switch to using the new tasklet_setup() and from_tasklet() to pass the tasklet pointer explicitly. Link: https://lore.kernel.org/r/20200903060637.424458-6-allen.lkml@gmail.com Signed-off-by: Romain Perier <romain.perier@gmail.com> Signed-off-by: Allen Pais <allen.lkml@gmail.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
		
			
				
	
	
		
			70 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 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 */
 |