Blame view

block/blk-mq-sched.h 2.54 KB
b24413180   Greg Kroah-Hartman   License cleanup: ...
1
  /* SPDX-License-Identifier: GPL-2.0 */
bd166ef18   Jens Axboe   blk-mq-sched: add...
2
3
4
5
6
  #ifndef BLK_MQ_SCHED_H
  #define BLK_MQ_SCHED_H
  
  #include "blk-mq.h"
  #include "blk-mq-tag.h"
bd166ef18   Jens Axboe   blk-mq-sched: add...
7
8
  void blk_mq_sched_free_hctx_data(struct request_queue *q,
  				 void (*exit)(struct blk_mq_hw_ctx *));
e2b3fa5af   Damien Le Moal   block: Remove bio...
9
  void blk_mq_sched_assign_ioc(struct request *rq);
bd166ef18   Jens Axboe   blk-mq-sched: add...
10
11
  
  void blk_mq_sched_request_inserted(struct request *rq);
e4d750c97   Jens Axboe   block: free merge...
12
  bool blk_mq_sched_try_merge(struct request_queue *q, struct bio *bio,
14ccb66b3   Christoph Hellwig   block: remove the...
13
14
15
  		unsigned int nr_segs, struct request **merged_request);
  bool __blk_mq_sched_bio_merge(struct request_queue *q, struct bio *bio,
  		unsigned int nr_segs);
bd166ef18   Jens Axboe   blk-mq-sched: add...
16
  bool blk_mq_sched_try_insert_merge(struct request_queue *q, struct request *rq);
7211aef86   Damien Le Moal   block: mq-deadlin...
17
  void blk_mq_sched_mark_restart_hctx(struct blk_mq_hw_ctx *hctx);
6d8c6c0f9   Bart Van Assche   blk-mq: Restart a...
18
  void blk_mq_sched_restart(struct blk_mq_hw_ctx *hctx);
bd166ef18   Jens Axboe   blk-mq-sched: add...
19

bd6737f1a   Jens Axboe   blk-mq-sched: add...
20
  void blk_mq_sched_insert_request(struct request *rq, bool at_head,
9e97d2951   Mike Snitzer   blk-mq-sched: rem...
21
  				 bool run_queue, bool async);
67cae4c94   Jens Axboe   blk-mq: cleanup a...
22
  void blk_mq_sched_insert_requests(struct blk_mq_hw_ctx *hctx,
bd6737f1a   Jens Axboe   blk-mq-sched: add...
23
24
  				  struct blk_mq_ctx *ctx,
  				  struct list_head *list, bool run_queue_async);
bd166ef18   Jens Axboe   blk-mq-sched: add...
25
  void blk_mq_sched_dispatch_requests(struct blk_mq_hw_ctx *hctx);
bd166ef18   Jens Axboe   blk-mq-sched: add...
26

6917ff0b5   Omar Sandoval   blk-mq-sched: ref...
27
  int blk_mq_init_sched(struct request_queue *q, struct elevator_type *e);
54d5329d4   Omar Sandoval   blk-mq-sched: fix...
28
  void blk_mq_exit_sched(struct request_queue *q, struct elevator_queue *e);
c3e221921   Ming Lei   block: free sched...
29
  void blk_mq_sched_free_requests(struct request_queue *q);
bd166ef18   Jens Axboe   blk-mq-sched: add...
30
31
  
  static inline bool
14ccb66b3   Christoph Hellwig   block: remove the...
32
33
  blk_mq_sched_bio_merge(struct request_queue *q, struct bio *bio,
  		unsigned int nr_segs)
bd166ef18   Jens Axboe   blk-mq-sched: add...
34
  {
9bddeb2a5   Ming Lei   blk-mq: make per-...
35
  	if (blk_queue_nomerges(q) || !bio_mergeable(bio))
bd166ef18   Jens Axboe   blk-mq-sched: add...
36
  		return false;
14ccb66b3   Christoph Hellwig   block: remove the...
37
  	return __blk_mq_sched_bio_merge(q, bio, nr_segs);
bd166ef18   Jens Axboe   blk-mq-sched: add...
38
  }
bd166ef18   Jens Axboe   blk-mq-sched: add...
39
40
41
42
43
  static inline bool
  blk_mq_sched_allow_merge(struct request_queue *q, struct request *rq,
  			 struct bio *bio)
  {
  	struct elevator_queue *e = q->elevator;
f9cd4bfe9   Jens Axboe   block: get rid of...
44
45
  	if (e && e->type->ops.allow_merge)
  		return e->type->ops.allow_merge(q, rq, bio);
bd166ef18   Jens Axboe   blk-mq-sched: add...
46
47
48
  
  	return true;
  }
ed88660a5   Omar Sandoval   block: move call ...
49
  static inline void blk_mq_sched_completed_request(struct request *rq, u64 now)
bd166ef18   Jens Axboe   blk-mq-sched: add...
50
  {
c05f8525f   Omar Sandoval   blk-mq-sched: mak...
51
  	struct elevator_queue *e = rq->q->elevator;
bd166ef18   Jens Axboe   blk-mq-sched: add...
52

f9cd4bfe9   Jens Axboe   block: get rid of...
53
54
  	if (e && e->type->ops.completed_request)
  		e->type->ops.completed_request(rq, now);
bd166ef18   Jens Axboe   blk-mq-sched: add...
55
  }
bd166ef18   Jens Axboe   blk-mq-sched: add...
56
57
58
59
  static inline void blk_mq_sched_requeue_request(struct request *rq)
  {
  	struct request_queue *q = rq->q;
  	struct elevator_queue *e = q->elevator;
7f07bbf9b   Omar Sandoval   block: only call ...
60
  	if ((rq->rq_flags & RQF_ELVPRIV) && e && e->type->ops.requeue_request)
f9cd4bfe9   Jens Axboe   block: get rid of...
61
  		e->type->ops.requeue_request(rq);
bd166ef18   Jens Axboe   blk-mq-sched: add...
62
63
64
65
66
  }
  
  static inline bool blk_mq_sched_has_work(struct blk_mq_hw_ctx *hctx)
  {
  	struct elevator_queue *e = hctx->queue->elevator;
f9cd4bfe9   Jens Axboe   block: get rid of...
67
68
  	if (e && e->type->ops.has_work)
  		return e->type->ops.has_work(hctx);
bd166ef18   Jens Axboe   blk-mq-sched: add...
69
70
71
  
  	return false;
  }
bd166ef18   Jens Axboe   blk-mq-sched: add...
72
73
74
75
76
77
  static inline bool blk_mq_sched_needs_restart(struct blk_mq_hw_ctx *hctx)
  {
  	return test_bit(BLK_MQ_S_SCHED_RESTART, &hctx->state);
  }
  
  #endif