Blame view

block/blk-mq.h 4.17 KB
b24413180   Greg Kroah-Hartman   License cleanup: ...
1
  /* SPDX-License-Identifier: GPL-2.0 */
320ae51fe   Jens Axboe   blk-mq: new multi...
2
3
  #ifndef INT_BLK_MQ_H
  #define INT_BLK_MQ_H
cf43e6be8   Jens Axboe   block: add scalab...
4
  #include "blk-stat.h"
24d2f9030   Christoph Hellwig   blk-mq: split out...
5
  struct blk_mq_tag_set;
320ae51fe   Jens Axboe   blk-mq: new multi...
6
7
8
9
10
11
12
13
  struct blk_mq_ctx {
  	struct {
  		spinlock_t		lock;
  		struct list_head	rq_list;
  	}  ____cacheline_aligned_in_smp;
  
  	unsigned int		cpu;
  	unsigned int		index_hw;
320ae51fe   Jens Axboe   blk-mq: new multi...
14
15
16
17
18
19
20
21
22
23
  
  	/* incremented at dispatch time */
  	unsigned long		rq_dispatched[2];
  	unsigned long		rq_merged;
  
  	/* incremented at completion time */
  	unsigned long		____cacheline_aligned_in_smp rq_completed[2];
  
  	struct request_queue	*queue;
  	struct kobject		kobj;
4bb659b15   Jens Axboe   blk-mq: implement...
24
  } ____cacheline_aligned_in_smp;
320ae51fe   Jens Axboe   blk-mq: new multi...
25

320ae51fe   Jens Axboe   blk-mq: new multi...
26
  void blk_mq_run_hw_queue(struct blk_mq_hw_ctx *hctx, bool async);
780db2071   Tejun Heo   blk-mq: decouble ...
27
  void blk_mq_freeze_queue(struct request_queue *q);
3edcc0ce8   Ming Lei   block: blk-mq: do...
28
  void blk_mq_free_queue(struct request_queue *q);
e3a2b3f93   Jens Axboe   blk-mq: allow cha...
29
  int blk_mq_update_nr_requests(struct request_queue *q, unsigned int nr);
aed3ea94b   Jens Axboe   block: wake up wa...
30
  void blk_mq_wake_waiters(struct request_queue *q);
81380ca10   Omar Sandoval   blk-mq: use the r...
31
  bool blk_mq_dispatch_rq_list(struct request_queue *, struct list_head *);
2c3ad6679   Jens Axboe   blk-mq: export so...
32
  void blk_mq_flush_busy_ctxs(struct blk_mq_hw_ctx *hctx, struct list_head *list);
50e1dab86   Jens Axboe   blk-mq-sched: fix...
33
  bool blk_mq_hctx_has_pending(struct blk_mq_hw_ctx *hctx);
bd6737f1a   Jens Axboe   blk-mq-sched: add...
34
35
  bool blk_mq_get_driver_tag(struct request *rq, struct blk_mq_hw_ctx **hctx,
  				bool wait);
2c3ad6679   Jens Axboe   blk-mq: export so...
36
37
38
39
  
  /*
   * Internal helpers for allocating/freeing the request map
   */
cc71a6f43   Jens Axboe   blk-mq: abstract ...
40
41
42
43
44
45
46
47
48
  void blk_mq_free_rqs(struct blk_mq_tag_set *set, struct blk_mq_tags *tags,
  		     unsigned int hctx_idx);
  void blk_mq_free_rq_map(struct blk_mq_tags *tags);
  struct blk_mq_tags *blk_mq_alloc_rq_map(struct blk_mq_tag_set *set,
  					unsigned int hctx_idx,
  					unsigned int nr_tags,
  					unsigned int reserved_tags);
  int blk_mq_alloc_rqs(struct blk_mq_tag_set *set, struct blk_mq_tags *tags,
  		     unsigned int hctx_idx, unsigned int depth);
2c3ad6679   Jens Axboe   blk-mq: export so...
49
50
51
52
53
54
  
  /*
   * Internal helpers for request insertion into sw queues
   */
  void __blk_mq_insert_request(struct blk_mq_hw_ctx *hctx, struct request *rq,
  				bool at_head);
157f377be   Jens Axboe   block: directly i...
55
  void blk_mq_request_bypass_insert(struct request *rq);
bd166ef18   Jens Axboe   blk-mq-sched: add...
56
57
  void blk_mq_insert_requests(struct blk_mq_hw_ctx *hctx, struct blk_mq_ctx *ctx,
  				struct list_head *list);
320ae51fe   Jens Axboe   blk-mq: new multi...
58
59
60
61
  
  /*
   * CPU -> queue mappings
   */
f14bbe77a   Jens Axboe   blk-mq: pass in s...
62
  extern int blk_mq_hw_queue_to_node(unsigned int *map, unsigned int);
320ae51fe   Jens Axboe   blk-mq: new multi...
63

7d7e0f90b   Christoph Hellwig   blk-mq: remove ->...
64
65
66
67
68
  static inline struct blk_mq_hw_ctx *blk_mq_map_queue(struct request_queue *q,
  		int cpu)
  {
  	return q->queue_hw_ctx[q->mq_map[cpu]];
  }
e93ecf602   Jens Axboe   blk-mq: move the ...
69
  /*
67aec14ce   Jens Axboe   blk-mq: make the ...
70
71
   * sysfs helpers
   */
737f98cfe   Ming Lei   blk-mq: initializ...
72
  extern void blk_mq_sysfs_init(struct request_queue *q);
7ea5fe31c   Ming Lei   blk-mq: make life...
73
  extern void blk_mq_sysfs_deinit(struct request_queue *q);
2d0364c8c   Bart Van Assche   blk-mq: Register ...
74
  extern int __blk_mq_register_dev(struct device *dev, struct request_queue *q);
67aec14ce   Jens Axboe   blk-mq: make the ...
75
76
  extern int blk_mq_sysfs_register(struct request_queue *q);
  extern void blk_mq_sysfs_unregister(struct request_queue *q);
868f2f0b7   Keith Busch   blk-mq: dynamic h...
77
  extern void blk_mq_hctx_kobj_init(struct blk_mq_hw_ctx *hctx);
67aec14ce   Jens Axboe   blk-mq: make the ...
78

904158376   Christoph Hellwig   block: fix blk_ab...
79
  extern void blk_mq_rq_timed_out(struct request *req, bool reserved);
e09aae7ed   Ming Lei   blk-mq: release m...
80
  void blk_mq_release(struct request_queue *q);
1aecfe488   Ming Lei   blk-mq: move blk_...
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
  static inline struct blk_mq_ctx *__blk_mq_get_ctx(struct request_queue *q,
  					   unsigned int cpu)
  {
  	return per_cpu_ptr(q->queue_ctx, cpu);
  }
  
  /*
   * This assumes per-cpu software queueing queues. They could be per-node
   * as well, for instance. For now this is hardcoded as-is. Note that we don't
   * care about preemption, since we know the ctx's are persistent. This does
   * mean that we can't rely on ctx always matching the currently running CPU.
   */
  static inline struct blk_mq_ctx *blk_mq_get_ctx(struct request_queue *q)
  {
  	return __blk_mq_get_ctx(q, get_cpu());
  }
  
  static inline void blk_mq_put_ctx(struct blk_mq_ctx *ctx)
  {
  	put_cpu();
  }
cb96a42cc   Ming Lei   blk-mq: fix sched...
102
103
104
  struct blk_mq_alloc_data {
  	/* input parameter */
  	struct request_queue *q;
6f3b0e8bc   Christoph Hellwig   blk-mq: add a fla...
105
  	unsigned int flags;
229a92873   Omar Sandoval   blk-mq: add shall...
106
  	unsigned int shallow_depth;
cb96a42cc   Ming Lei   blk-mq: fix sched...
107
108
109
110
111
  
  	/* input & output parameter */
  	struct blk_mq_ctx *ctx;
  	struct blk_mq_hw_ctx *hctx;
  };
4941115be   Jens Axboe   blk-mq-tag: clean...
112
113
  static inline struct blk_mq_tags *blk_mq_tags_from_data(struct blk_mq_alloc_data *data)
  {
bd166ef18   Jens Axboe   blk-mq-sched: add...
114
115
  	if (data->flags & BLK_MQ_REQ_INTERNAL)
  		return data->hctx->sched_tags;
4941115be   Jens Axboe   blk-mq-tag: clean...
116
117
  	return data->hctx->tags;
  }
5d1b25c1e   Bart Van Assche   blk-mq: Introduce...
118
119
120
121
  static inline bool blk_mq_hctx_stopped(struct blk_mq_hw_ctx *hctx)
  {
  	return test_bit(BLK_MQ_S_STOPPED, &hctx->state);
  }
19c66e59c   Ming Lei   blk-mq: prevent u...
122
123
124
125
  static inline bool blk_mq_hw_queue_mapped(struct blk_mq_hw_ctx *hctx)
  {
  	return hctx->nr_ctx && hctx->tags;
  }
f299b7c7a   Jens Axboe   blk-mq: provide i...
126
  void blk_mq_in_flight(struct request_queue *q, struct hd_struct *part,
06beec871   Omar Sandoval   blk-mq: fix sysfs...
127
128
129
  		      unsigned int inflight[2]);
  void blk_mq_in_flight_rw(struct request_queue *q, struct hd_struct *part,
  			 unsigned int inflight[2]);
f299b7c7a   Jens Axboe   blk-mq: provide i...
130

320ae51fe   Jens Axboe   blk-mq: new multi...
131
  #endif