On Mon, Nov 19, 2018 at 11:06:06AM +0100, Greg Kroah-Hartman wrote:
On Sat, Nov 17, 2018 at 10:26:38AM +0800, Ming Lei wrote:
On Fri, Nov 16, 2018 at 06:05:21AM -0800, Greg Kroah-Hartman wrote:
On Fri, Nov 16, 2018 at 07:23:10PM +0800, Ming Lei wrote:
@@ -456,7 +456,7 @@ struct request_queue { /* * mq queue kobject */
- struct kobject mq_kobj;
- struct kobject *mq_kobj;
What is this kobject even used for? It wasn't obvious at all from this patch, why is it needed if you are not using it to reference count the larger structure here?
All attributes and kobjects under /sys/block/$DEV/mq are covered by this kobject actually, and all are for exposing blk-mq specific information, but now there is only blk-mq, and legacy io path is removed.
I am sorry, but I really can not parse this sentance at all.
What Documentation/ABI/ entries are covered by this kobject, that should help me out more. And what do you mean by "legacy io"?
After blk-mq is introduced, there are two main IO request paths:
1) blk-mq, IO is queued via blk_mq_make_request()
2) legacy IO path, IO is queued via blk_queue_bio()
The legacy IO path will be removed in 4.21, and patches have been queued in for-4.21/block.
That is why I mentioned we may remove this kobject last time and move all under /sys/block/$DEV/queue, however you thought that may break some userspace.
Who relies on these sysfs files today?
I don't know, actually the question is from you, :-(
https://marc.info/?l=linux-kernel&m=154205455332755&w=2
Even we remove q->mq_kobj, the same kobject lifetime issue is still here in kobjects embedded in 'struct blk_mq_ctx'.
If we want to backport them to stable, this patch may be a bit easier to go.
Why do you want to backport any of this to stable?
For this report from Guenter, it should be enough to backport the 1st patch, and it shouldn't be very hard to backport both.
I can help to backport them if patches can't be applied cleanly.
Thanks, Ming