On 10/28/18 10:07 AM, Christoph Hellwig wrote:
>> +static enum blk_eh_timer_return bsg_timeout(struct request *rq, bool
>> reserved)
>> +{
>> + enum blk_eh_timer_return ret = BLK_EH_DONE;
>> + struct request_queue *q = rq->q;
>> +
>> + if (q->rq_timed_out_fn)
>> + ret = q->rq_timed_out_fn(rq);
>> +
>> + return ret;
>
> This is pretty awkward. I guess it is ok as an intermediate step,
> but I really don't want to keep rq_timed_out_fn to just for bsg.
Me neither.
> I think we should do something like this ontop of your series to move
> all the bsg-lib bits outside struct request_queue:
Looks good to me, I'll queue this up after this patch to clean things
up nicely.
I added this incremental on top, you missed some error handling and
cleanup bits. Care to send as a proper patch?
diff --git a/block/bsg-lib.c b/block/bsg-lib.c
index 21dccaf8399e..f01f11048d5e 100644
--- a/block/bsg-lib.c
+++ b/block/bsg-lib.c
@@ -299,12 +299,13 @@ static void bsg_exit_rq(struct blk_mq_tag_set *set,
struct request *req,
void bsg_remove_queue(struct request_queue *q)
{
- struct blk_mq_tag_set *set = q->tag_set;
+ struct bsg_set *bset =
+ container_of(q->tag_set, struct bsg_set, tag_set);
bsg_unregister_queue(q);
blk_cleanup_queue(q);
- blk_mq_free_tag_set(set);
- kfree(set);
+ blk_mq_free_tag_set(&bset->tag_set);
+ kfree(bset);
}
EXPORT_SYMBOL_GPL(bsg_remove_queue);
@@ -382,7 +383,7 @@ struct request_queue *bsg_setup_queue(struct device *dev,
const char *name,
out_queue:
blk_mq_free_tag_set(set);
out_tag_set:
- kfree(set);
+ kfree(bset);
return ERR_PTR(ret);
}
EXPORT_SYMBOL_GPL(bsg_setup_queue);
--
Jens Axboe