Received: by 2002:a25:2c96:0:0:0:0:0 with SMTP id s144csp1103743ybs; Mon, 25 May 2020 07:17:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw7UoOlPoGKjUVNZ/yY3QFMhLFRstqS7gjQrmwKCwtddZss56CLJoOc3taKhbLXKjGPdE67 X-Received: by 2002:aa7:cb8d:: with SMTP id r13mr15315812edt.12.1590416236990; Mon, 25 May 2020 07:17:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590416236; cv=none; d=google.com; s=arc-20160816; b=lRUKEUzdu6thSlxztySdyGMdvi960lpGJNuoCejnbUGnByUnrm0Ki4xt5r2HrVVLl4 N1MtxTmPodNYm1pY82TW1EjXhg5apRUzD8cHlYefS5EnO25Cfv2JTs97JhFBQ1jhqyst /VbZZikqYU6fDhzGp9H6PP2MqBU/wlgUioXcidGmbHd8LXb7hLBIQxcvpv8yyaLtekzi J2DoqTwlLSIetSXLdzJOu/4Lr/Z8Ql8b5eAFTsW1tbSuxC/78wu2oH0pIigYvZ1/Svo6 iOXjrpJtUksxjhEUR30CLxt/rW4cCNVtRXtWL4RXWW8ATjEnn2hCBu3zeoIWU1scdiYc /8vA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=e35Z1aZcBpO4FjT4/OfXhJlClEKE3GlteSXg77ztYqc=; b=RXisKoHcYgj2tWbHWzaZypBOi1z5nQiACd4xM+qXB/5ubhqEG30fKt4JuumuBWcq1+ hH8h7/cRQbsM2X769PXYfdCp8S9qnWpOpKulyxzjT8JDiu6VP0n+kWm16ttnyDn9Ngrh 7M267mRxg+2zEtnbLR1H8dMlo2O1Gd8rj9dySBlzlWSagcGgaH+hz08x5oxPs1jGLpbm FBruGyhEo3Uzke5wvG2Rfg/r4FfSewUEdGUCmmnEf/YIcTVAP4UE3H6LyXSkaHhjQ8d1 xE75VSqMyDlgiI6lvwkO+FmD1XrOQOad+qk6ErZHEZ1930j+SirM1h+bwVQefyiwYg3y sGGg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fudan.edu.cn header.s=dkim header.b=jPH55+5T; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=fudan.edu.cn Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id du9si11521100ejc.154.2020.05.25.07.16.53; Mon, 25 May 2020 07:17:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@fudan.edu.cn header.s=dkim header.b=jPH55+5T; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=fudan.edu.cn Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388909AbgEYOMg (ORCPT + 99 others); Mon, 25 May 2020 10:12:36 -0400 Received: from mail.fudan.edu.cn ([202.120.224.73]:37808 "EHLO fudan.edu.cn" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2388855AbgEYOMg (ORCPT ); Mon, 25 May 2020 10:12:36 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fudan.edu.cn; s=dkim; h=Received:From:To:Cc:Subject:Date: Message-Id; bh=e35Z1aZcBpO4FjT4/OfXhJlClEKE3GlteSXg77ztYqc=; b=j PH55+5TSZQKrRnRs/Q6BFmo4bAVedI3XsuUqmNPn+LSJw31h84UiM5/J8FEVXMqf 6LgFoXk15SpIWDz00Fw8zirS4DN5oG6nUFUFAEPeCFsjcl2omNwKkGfSnLFs6Mnk ZrijSSneX648u0Oq5LuS57tHUXaFHZkTkUu9heakeo= Received: from localhost.localdomain (unknown [223.73.184.21]) by app2 (Coremail) with SMTP id XQUFCgC3v+M90stetAqpAg--.14499S3; Mon, 25 May 2020 22:12:15 +0800 (CST) From: Xiyu Yang To: David Howells , linux-afs@lists.infradead.org, linux-kernel@vger.kernel.org Cc: yuanxzhang@fudan.edu.cn, kjlu@umn.edu, Xiyu Yang , Xin Tan Subject: [PATCH] afs: Fix afs_cb_interest refcnt leak in afs_select_fileserver() Date: Mon, 25 May 2020 22:11:26 +0800 Message-Id: <1590415886-52353-1-git-send-email-xiyuyang19@fudan.edu.cn> X-Mailer: git-send-email 2.7.4 X-CM-TRANSID: XQUFCgC3v+M90stetAqpAg--.14499S3 X-Coremail-Antispam: 1UD129KBjvJXoW7WF1xuF17tF47XrWrZFy3CFg_yoW8Jw1Dpr 4rCw1DKr98X348GwsxJa1rXa4rX393Xw42kFZxWw1rZws8CF4avr1vqryvgFW7u395Aw4U XF18K34Y9FZ8CFJanT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUUkC14x267AKxVW8JVW5JwAFc2x0x2IEx4CE42xK8VAvwI8IcIk0 rVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2AK02 1l84ACjcxK6xIIjxv20xvE14v26w1j6s0DM28EF7xvwVC0I7IYx2IY6xkF7I0E14v26F4U JVW0owA2z4x0Y4vEx4A2jsIE14v26rxl6s0DM28EF7xvwVC2z280aVCY1x0267AKxVW0oV Cq3wAac4AC62xK8xCEY4vEwIxC4wAS0I0E0xvYzxvE52x082IY62kv0487Mc02F40EFcxC 0VAKzVAqx4xG6I80ewAv7VC0I7IYx2IY67AKxVWUJVWUGwAv7VC2z280aVAFwI0_Jr0_Gr 1lOx8S6xCaFVCjc4AY6r1j6r4UM4x0Y48IcxkI7VAKI48JM4x0x7Aq67IIx4CEVc8vx2IE rcIFxwCF04k20xvY0x0EwIxGrwCFx2IqxVCFs4IE7xkEbVWUJVW8JwC20s026c02F40E14 v26r1j6r18MI8I3I0E7480Y4vE14v26r106r1rMI8E67AF67kF1VAFwI0_JF0_Jw1lIxkG c2Ij64vIr41lIxAIcVC0I7IYx2IY67AKxVWUJVWUCwCI42IY6xIIjxv20xvEc7CjxVAFwI 0_Jr0_Gr1lIxAIcVCF04k26cxKx2IYs7xG6rW3Jr0E3s1lIxAIcVC2z280aVAFwI0_Jr0_ Gr1lIxAIcVC2z280aVCY1x0267AKxVWUJVW8JbIYCTnIWIevJa73UjIFyTuYvjfUOlksUU UUU X-CM-SenderInfo: irzsiiysuqikmy6i3vldqovvfxof0/ Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org afs_select_fileserver() invokes afs_get_cb_interest(), which returns a reference of the specified afs_cb_interest object to "fc->cbi" with increased refcnt. The reference counting issue happens in one exception handling path of afs_select_fileserver(). When error occurred in afs_wait_for_fs_probes(), the function forgets to decrease the refcnt increased by afs_get_cb_interest(), causing a refcnt leak. Fix this issue by calling afs_put_cb_interest() when error occurred in afs_wait_for_fs_probes(). Signed-off-by: Xiyu Yang Signed-off-by: Xin Tan --- fs/afs/rotate.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/fs/afs/rotate.c b/fs/afs/rotate.c index 2a3305e42b14..f73af16cdb92 100644 --- a/fs/afs/rotate.c +++ b/fs/afs/rotate.c @@ -357,8 +357,10 @@ bool afs_select_fileserver(struct afs_fs_cursor *fc) _debug("pick [%lx]", fc->untried); error = afs_wait_for_fs_probes(fc->server_list, fc->untried); - if (error < 0) + if (error < 0) { + afs_put_cb_interest(afs_v2net(vnode), fc->cbi); goto failed_set_error; + } /* Pick the untried server with the lowest RTT. If we have outstanding * callbacks, we stick with the server we're already using if we can. -- 2.7.4