Commit 98f04499 authored by Jan Kara's avatar Jan Kara Committed by Jens Axboe

bfq: Track number of allocated requests in bfq_entity

When we want to limit number of requests used by each bfqq and also
cgroup, we need to track also number of requests used by each cgroup.
So track number of allocated requests for each bfq_entity.
Acked-by: default avatarPaolo Valente <paolo.valente@linaro.org>
Signed-off-by: default avatarJan Kara <jack@suse.cz>
Link: https://lore.kernel.org/r/20211125133645.27483-2-jack@suse.czSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 790cf9c8
...@@ -1113,7 +1113,8 @@ bfq_bfqq_resume_state(struct bfq_queue *bfqq, struct bfq_data *bfqd, ...@@ -1113,7 +1113,8 @@ bfq_bfqq_resume_state(struct bfq_queue *bfqq, struct bfq_data *bfqd,
static int bfqq_process_refs(struct bfq_queue *bfqq) static int bfqq_process_refs(struct bfq_queue *bfqq)
{ {
return bfqq->ref - bfqq->allocated - bfqq->entity.on_st_or_in_serv - return bfqq->ref - bfqq->entity.allocated -
bfqq->entity.on_st_or_in_serv -
(bfqq->weight_counter != NULL) - bfqq->stable_ref; (bfqq->weight_counter != NULL) - bfqq->stable_ref;
} }
...@@ -5878,6 +5879,22 @@ static void bfq_rq_enqueued(struct bfq_data *bfqd, struct bfq_queue *bfqq, ...@@ -5878,6 +5879,22 @@ static void bfq_rq_enqueued(struct bfq_data *bfqd, struct bfq_queue *bfqq,
} }
} }
static void bfqq_request_allocated(struct bfq_queue *bfqq)
{
struct bfq_entity *entity = &bfqq->entity;
for_each_entity(entity)
entity->allocated++;
}
static void bfqq_request_freed(struct bfq_queue *bfqq)
{
struct bfq_entity *entity = &bfqq->entity;
for_each_entity(entity)
entity->allocated--;
}
/* returns true if it causes the idle timer to be disabled */ /* returns true if it causes the idle timer to be disabled */
static bool __bfq_insert_request(struct bfq_data *bfqd, struct request *rq) static bool __bfq_insert_request(struct bfq_data *bfqd, struct request *rq)
{ {
...@@ -5891,8 +5908,8 @@ static bool __bfq_insert_request(struct bfq_data *bfqd, struct request *rq) ...@@ -5891,8 +5908,8 @@ static bool __bfq_insert_request(struct bfq_data *bfqd, struct request *rq)
* Release the request's reference to the old bfqq * Release the request's reference to the old bfqq
* and make sure one is taken to the shared queue. * and make sure one is taken to the shared queue.
*/ */
new_bfqq->allocated++; bfqq_request_allocated(new_bfqq);
bfqq->allocated--; bfqq_request_freed(bfqq);
new_bfqq->ref++; new_bfqq->ref++;
/* /*
* If the bic associated with the process * If the bic associated with the process
...@@ -6251,8 +6268,7 @@ static void bfq_completed_request(struct bfq_queue *bfqq, struct bfq_data *bfqd) ...@@ -6251,8 +6268,7 @@ static void bfq_completed_request(struct bfq_queue *bfqq, struct bfq_data *bfqd)
static void bfq_finish_requeue_request_body(struct bfq_queue *bfqq) static void bfq_finish_requeue_request_body(struct bfq_queue *bfqq)
{ {
bfqq->allocated--; bfqq_request_freed(bfqq);
bfq_put_queue(bfqq); bfq_put_queue(bfqq);
} }
...@@ -6674,7 +6690,7 @@ static struct bfq_queue *bfq_init_rq(struct request *rq) ...@@ -6674,7 +6690,7 @@ static struct bfq_queue *bfq_init_rq(struct request *rq)
} }
} }
bfqq->allocated++; bfqq_request_allocated(bfqq);
bfqq->ref++; bfqq->ref++;
bfq_log_bfqq(bfqd, bfqq, "get_request %p: bfqq %p, %d", bfq_log_bfqq(bfqd, bfqq, "get_request %p: bfqq %p, %d",
rq, bfqq, bfqq->ref); rq, bfqq, bfqq->ref);
......
...@@ -170,6 +170,9 @@ struct bfq_entity { ...@@ -170,6 +170,9 @@ struct bfq_entity {
/* budget, used also to calculate F_i: F_i = S_i + @budget / @weight */ /* budget, used also to calculate F_i: F_i = S_i + @budget / @weight */
int budget; int budget;
/* Number of requests allocated in the subtree of this entity */
int allocated;
/* device weight, if non-zero, it overrides the default weight of /* device weight, if non-zero, it overrides the default weight of
* bfq_group_data */ * bfq_group_data */
int dev_weight; int dev_weight;
...@@ -266,8 +269,6 @@ struct bfq_queue { ...@@ -266,8 +269,6 @@ struct bfq_queue {
struct request *next_rq; struct request *next_rq;
/* number of sync and async requests queued */ /* number of sync and async requests queued */
int queued[2]; int queued[2];
/* number of requests currently allocated */
int allocated;
/* number of pending metadata requests */ /* number of pending metadata requests */
int meta_pending; int meta_pending;
/* fifo list of requests in sort_list */ /* fifo list of requests in sort_list */
......
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