| 
									
										
										
										
											2009-08-05 09:07:21 +02:00
										 |  |  | #ifndef BLK_IOPOLL_H
 | 
					
						
							|  |  |  | #define BLK_IOPOLL_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct blk_iopoll; | 
					
						
							|  |  |  | typedef int (blk_iopoll_fn)(struct blk_iopoll *, int); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct blk_iopoll { | 
					
						
							|  |  |  | 	struct list_head list; | 
					
						
							|  |  |  | 	unsigned long state; | 
					
						
							|  |  |  | 	unsigned long data; | 
					
						
							|  |  |  | 	int weight; | 
					
						
							|  |  |  | 	int max; | 
					
						
							|  |  |  | 	blk_iopoll_fn *poll; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum { | 
					
						
							|  |  |  | 	IOPOLL_F_SCHED		= 0, | 
					
						
							|  |  |  | 	IOPOLL_F_DISABLE	= 1, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-11 08:31:14 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Returns 0 if we successfully set the IOPOLL_F_SCHED bit, indicating | 
					
						
							|  |  |  |  * that we were the first to acquire this iop for scheduling. If this iop | 
					
						
							|  |  |  |  * is currently disabled, return "failure". | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-08-05 09:07:21 +02:00
										 |  |  | static inline int blk_iopoll_sched_prep(struct blk_iopoll *iop) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-08-11 08:31:14 +02:00
										 |  |  | 	if (!test_bit(IOPOLL_F_DISABLE, &iop->state)) | 
					
						
							|  |  |  | 		return test_and_set_bit(IOPOLL_F_SCHED, &iop->state); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 1; | 
					
						
							| 
									
										
										
										
											2009-08-05 09:07:21 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline int blk_iopoll_disable_pending(struct blk_iopoll *iop) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return test_bit(IOPOLL_F_DISABLE, &iop->state); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern void blk_iopoll_sched(struct blk_iopoll *); | 
					
						
							|  |  |  | extern void blk_iopoll_init(struct blk_iopoll *, int, blk_iopoll_fn *); | 
					
						
							|  |  |  | extern void blk_iopoll_complete(struct blk_iopoll *); | 
					
						
							|  |  |  | extern void __blk_iopoll_complete(struct blk_iopoll *); | 
					
						
							|  |  |  | extern void blk_iopoll_enable(struct blk_iopoll *); | 
					
						
							|  |  |  | extern void blk_iopoll_disable(struct blk_iopoll *); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |