Commit d5337560 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Jens Axboe

block: remove the unused lock argument to rq_qos_throttle

Unused now that the legacy request path is gone.
Reviewed-by: default avatarHannes Reinecke <hare@suse.com>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 373e4af3
...@@ -276,10 +276,8 @@ static inline bool iolatency_may_queue(struct iolatency_grp *iolat, ...@@ -276,10 +276,8 @@ static inline bool iolatency_may_queue(struct iolatency_grp *iolat,
static void __blkcg_iolatency_throttle(struct rq_qos *rqos, static void __blkcg_iolatency_throttle(struct rq_qos *rqos,
struct iolatency_grp *iolat, struct iolatency_grp *iolat,
spinlock_t *lock, bool issue_as_root, bool issue_as_root,
bool use_memdelay) bool use_memdelay)
__releases(lock)
__acquires(lock)
{ {
struct rq_wait *rqw = &iolat->rq_wait; struct rq_wait *rqw = &iolat->rq_wait;
unsigned use_delay = atomic_read(&lat_to_blkg(iolat)->use_delay); unsigned use_delay = atomic_read(&lat_to_blkg(iolat)->use_delay);
...@@ -311,14 +309,7 @@ static void __blkcg_iolatency_throttle(struct rq_qos *rqos, ...@@ -311,14 +309,7 @@ static void __blkcg_iolatency_throttle(struct rq_qos *rqos,
if (iolatency_may_queue(iolat, &wait, first_block)) if (iolatency_may_queue(iolat, &wait, first_block))
break; break;
first_block = false; first_block = false;
if (lock) {
spin_unlock_irq(lock);
io_schedule();
spin_lock_irq(lock);
} else {
io_schedule(); io_schedule();
}
} while (1); } while (1);
finish_wait(&rqw->wait, &wait); finish_wait(&rqw->wait, &wait);
...@@ -478,8 +469,7 @@ static void check_scale_change(struct iolatency_grp *iolat) ...@@ -478,8 +469,7 @@ static void check_scale_change(struct iolatency_grp *iolat)
scale_change(iolat, direction > 0); scale_change(iolat, direction > 0);
} }
static void blkcg_iolatency_throttle(struct rq_qos *rqos, struct bio *bio, static void blkcg_iolatency_throttle(struct rq_qos *rqos, struct bio *bio)
spinlock_t *lock)
{ {
struct blk_iolatency *blkiolat = BLKIOLATENCY(rqos); struct blk_iolatency *blkiolat = BLKIOLATENCY(rqos);
struct blkcg *blkcg; struct blkcg *blkcg;
...@@ -495,12 +485,10 @@ static void blkcg_iolatency_throttle(struct rq_qos *rqos, struct bio *bio, ...@@ -495,12 +485,10 @@ static void blkcg_iolatency_throttle(struct rq_qos *rqos, struct bio *bio,
bio_associate_blkcg(bio, &blkcg->css); bio_associate_blkcg(bio, &blkcg->css);
blkg = blkg_lookup(blkcg, q); blkg = blkg_lookup(blkcg, q);
if (unlikely(!blkg)) { if (unlikely(!blkg)) {
if (!lock)
spin_lock_irq(q->queue_lock); spin_lock_irq(q->queue_lock);
blkg = blkg_lookup_create(blkcg, q); blkg = blkg_lookup_create(blkcg, q);
if (IS_ERR(blkg)) if (IS_ERR(blkg))
blkg = NULL; blkg = NULL;
if (!lock)
spin_unlock_irq(q->queue_lock); spin_unlock_irq(q->queue_lock);
} }
if (!blkg) if (!blkg)
...@@ -518,7 +506,7 @@ static void blkcg_iolatency_throttle(struct rq_qos *rqos, struct bio *bio, ...@@ -518,7 +506,7 @@ static void blkcg_iolatency_throttle(struct rq_qos *rqos, struct bio *bio,
} }
check_scale_change(iolat); check_scale_change(iolat);
__blkcg_iolatency_throttle(rqos, iolat, lock, issue_as_root, __blkcg_iolatency_throttle(rqos, iolat, issue_as_root,
(bio->bi_opf & REQ_SWAP) == REQ_SWAP); (bio->bi_opf & REQ_SWAP) == REQ_SWAP);
blkg = blkg->parent; blkg = blkg->parent;
} }
......
...@@ -1886,7 +1886,7 @@ static blk_qc_t blk_mq_make_request(struct request_queue *q, struct bio *bio) ...@@ -1886,7 +1886,7 @@ static blk_qc_t blk_mq_make_request(struct request_queue *q, struct bio *bio)
if (blk_mq_sched_bio_merge(q, bio)) if (blk_mq_sched_bio_merge(q, bio))
return BLK_QC_T_NONE; return BLK_QC_T_NONE;
rq_qos_throttle(q, bio, NULL); rq_qos_throttle(q, bio);
rq = blk_mq_get_request(q, bio, &data); rq = blk_mq_get_request(q, bio, &data);
if (unlikely(!rq)) { if (unlikely(!rq)) {
......
...@@ -67,14 +67,13 @@ void rq_qos_requeue(struct request_queue *q, struct request *rq) ...@@ -67,14 +67,13 @@ void rq_qos_requeue(struct request_queue *q, struct request *rq)
} }
} }
void rq_qos_throttle(struct request_queue *q, struct bio *bio, void rq_qos_throttle(struct request_queue *q, struct bio *bio)
spinlock_t *lock)
{ {
struct rq_qos *rqos; struct rq_qos *rqos;
for(rqos = q->rq_qos; rqos; rqos = rqos->next) { for(rqos = q->rq_qos; rqos; rqos = rqos->next) {
if (rqos->ops->throttle) if (rqos->ops->throttle)
rqos->ops->throttle(rqos, bio, lock); rqos->ops->throttle(rqos, bio);
} }
} }
......
...@@ -25,7 +25,7 @@ struct rq_qos { ...@@ -25,7 +25,7 @@ struct rq_qos {
}; };
struct rq_qos_ops { struct rq_qos_ops {
void (*throttle)(struct rq_qos *, struct bio *, spinlock_t *); void (*throttle)(struct rq_qos *, struct bio *);
void (*track)(struct rq_qos *, struct request *, struct bio *); void (*track)(struct rq_qos *, struct request *, struct bio *);
void (*issue)(struct rq_qos *, struct request *); void (*issue)(struct rq_qos *, struct request *);
void (*requeue)(struct rq_qos *, struct request *); void (*requeue)(struct rq_qos *, struct request *);
...@@ -103,7 +103,7 @@ void rq_qos_done(struct request_queue *, struct request *); ...@@ -103,7 +103,7 @@ void rq_qos_done(struct request_queue *, struct request *);
void rq_qos_issue(struct request_queue *, struct request *); void rq_qos_issue(struct request_queue *, struct request *);
void rq_qos_requeue(struct request_queue *, struct request *); void rq_qos_requeue(struct request_queue *, struct request *);
void rq_qos_done_bio(struct request_queue *q, struct bio *bio); void rq_qos_done_bio(struct request_queue *q, struct bio *bio);
void rq_qos_throttle(struct request_queue *, struct bio *, spinlock_t *); void rq_qos_throttle(struct request_queue *, struct bio *);
void rq_qos_track(struct request_queue *q, struct request *, struct bio *); void rq_qos_track(struct request_queue *q, struct request *, struct bio *);
void rq_qos_exit(struct request_queue *); void rq_qos_exit(struct request_queue *);
#endif #endif
...@@ -521,9 +521,7 @@ static int wbt_wake_function(struct wait_queue_entry *curr, unsigned int mode, ...@@ -521,9 +521,7 @@ static int wbt_wake_function(struct wait_queue_entry *curr, unsigned int mode,
* the timer to kick off queuing again. * the timer to kick off queuing again.
*/ */
static void __wbt_wait(struct rq_wb *rwb, enum wbt_flags wb_acct, static void __wbt_wait(struct rq_wb *rwb, enum wbt_flags wb_acct,
unsigned long rw, spinlock_t *lock) unsigned long rw)
__releases(lock)
__acquires(lock)
{ {
struct rq_wait *rqw = get_rq_wait(rwb, wb_acct); struct rq_wait *rqw = get_rq_wait(rwb, wb_acct);
struct wbt_wait_data data = { struct wbt_wait_data data = {
...@@ -561,13 +559,7 @@ static void __wbt_wait(struct rq_wb *rwb, enum wbt_flags wb_acct, ...@@ -561,13 +559,7 @@ static void __wbt_wait(struct rq_wb *rwb, enum wbt_flags wb_acct,
break; break;
} }
if (lock) {
spin_unlock_irq(lock);
io_schedule(); io_schedule();
spin_lock_irq(lock);
} else
io_schedule();
has_sleeper = false; has_sleeper = false;
} while (1); } while (1);
...@@ -624,7 +616,7 @@ static void wbt_cleanup(struct rq_qos *rqos, struct bio *bio) ...@@ -624,7 +616,7 @@ static void wbt_cleanup(struct rq_qos *rqos, struct bio *bio)
* in an irq held spinlock, if it holds one when calling this function. * in an irq held spinlock, if it holds one when calling this function.
* If we do sleep, we'll release and re-grab it. * If we do sleep, we'll release and re-grab it.
*/ */
static void wbt_wait(struct rq_qos *rqos, struct bio *bio, spinlock_t *lock) static void wbt_wait(struct rq_qos *rqos, struct bio *bio)
{ {
struct rq_wb *rwb = RQWB(rqos); struct rq_wb *rwb = RQWB(rqos);
enum wbt_flags flags; enum wbt_flags flags;
...@@ -636,7 +628,7 @@ static void wbt_wait(struct rq_qos *rqos, struct bio *bio, spinlock_t *lock) ...@@ -636,7 +628,7 @@ static void wbt_wait(struct rq_qos *rqos, struct bio *bio, spinlock_t *lock)
return; return;
} }
__wbt_wait(rwb, flags, bio->bi_opf, lock); __wbt_wait(rwb, flags, bio->bi_opf);
if (!blk_stat_is_active(rwb->cb)) if (!blk_stat_is_active(rwb->cb))
rwb_arm_timer(rwb); rwb_arm_timer(rwb);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment