]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
md: Remove extra mddev_get() in md_seq_start()
authorLogan Gunthorpe <logang@deltatee.com>
Thu, 8 Sep 2022 16:15:15 +0000 (10:15 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 21 Oct 2022 10:38:48 +0000 (12:38 +0200)
[ Upstream commit 3bfc3bcd787c48aa31e4fde4a6dfcef4cd7ee2c2 ]

A regression is seen where mddev devices stay permanently after they
are stopped due to an elevated reference count.

This was tracked down to an extra mddev_get() in md_seq_start().

It only happened rarely because most of the time the md_seq_start()
is called with a zero offset. The path with an extra mddev_get() only
happens when it starts with a non-zero offset.

The commit noted below changed an mddev_get() to check its success
but inadvertently left the original call in. Remove the extra call.

Fixes: 12a6caf27324 ("md: only delete entries from all_mddevs when the disk is freed")
Signed-off-by: Logan Gunthorpe <logang@deltatee.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Acked-by: Guoqing Jiang <Guoqing.jiang@linux.dev>
Signed-off-by: Song Liu <song@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/md/md.c

index 729be2c5296c6c3544abaa7701e3d7b8fa7f9f43..470a975e4be9b32ae997c8e52b7e005b45d8e015 100644 (file)
@@ -8156,7 +8156,6 @@ static void *md_seq_start(struct seq_file *seq, loff_t *pos)
        list_for_each(tmp,&all_mddevs)
                if (!l--) {
                        mddev = list_entry(tmp, struct mddev, all_mddevs);
-                       mddev_get(mddev);
                        if (!mddev_get(mddev))
                                continue;
                        spin_unlock(&all_mddevs_lock);