]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
w1: fix redundant counter decrement in w1_attach_slave_device()
authorHaoxiang Li <lihaoxiang@isrc.iscas.ac.cn>
Thu, 18 Dec 2025 11:14:14 +0000 (19:14 +0800)
committerKrzysztof Kozlowski <krzk@kernel.org>
Sun, 28 Dec 2025 10:52:10 +0000 (11:52 +0100)
In w1_attach_slave_device(), if __w1_attach_slave_device() fails,
put_device() -> w1_slave_release() is called to do the cleanup job.
In w1_slave_release(), sl->family->refcnt and sl->master->slave_count
have already been decremented. There is no need to decrement twice
in w1_attach_slave_device().

Fixes: 2c927c0c73fd ("w1: Fix slave count on 1-Wire bus (resend)")
Cc: stable@vger.kernel.org
Signed-off-by: Haoxiang Li <lihaoxiang@isrc.iscas.ac.cn>
Link: https://patch.msgid.link/20251218111414.564403-1-lihaoxiang@isrc.iscas.ac.cn
Signed-off-by: Krzysztof Kozlowski <krzk@kernel.org>
drivers/w1/w1.c

index 002d2639aa12cc7b4d51db5dd85e6a9dd3c9cca3..5f78b0a0b76670403df8278af42d70a44211fae9 100644 (file)
@@ -758,8 +758,6 @@ int w1_attach_slave_device(struct w1_master *dev, struct w1_reg_num *rn)
        if (err < 0) {
                dev_err(&dev->dev, "%s: Attaching %s failed.\n", __func__,
                         sl->name);
-               dev->slave_count--;
-               w1_family_put(sl->family);
                atomic_dec(&sl->master->refcnt);
                kfree(sl);
                return err;