Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp111540rdh; Sat, 23 Sep 2023 03:49:24 -0700 (PDT) X-Google-Smtp-Source: AGHT+IF7mLAIY44FelAfjaIZV1wbtJu05ZLVLSMg7ZHA/gFkOThUr9lsmqX0Sjc8qoNZvqTrovqW X-Received: by 2002:a05:6830:1683:b0:6b9:41e1:713f with SMTP id k3-20020a056830168300b006b941e1713fmr2118811otr.18.1695466164235; Sat, 23 Sep 2023 03:49:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695466164; cv=none; d=google.com; s=arc-20160816; b=hqtdYKk0aZL6uLxmm/Kp+2ocT7RVw3Ww0ImiyA29iryTzgkrGVNFO7H+OMAbzJ/grH uAXsT455W6pJ7lHYK6J+PQi87Si6/gMCobiaEgoAlQxZuIDzq9gXJgcIw73aL23f+svo KZy7eeVgXwP8sPv7sjBPZY9f8kzVpvS7C8iyWnSr9AzJ/23QnD1SsG5C5IyUAeMRKQI3 D99E/2QLM8DxgTQHXjd9TS8vfz16kZzWyCwJTDTs+21nrqo2yud5ya9M2EU3cK8/wRw2 EHxeOyePXSdG7bx9TSAyh+Esft8ZvykO+K+9DLwN7T1wd9MpHizqZ4vyjzqE06gj4L21 200A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=QLlXb9G1nMsqavn+6sHoJV3c/TNGqJrWyAowLF/rbiw=; fh=kOwkCO7i74xNZcCpfWThDUuxIb1BUuQkCesFqRSfziQ=; b=noz4SkuBU+9uOQlH0RR/wr5gh3m2v62VW7WPEGNd/KNdNtRa3RbcPmnB0hkcl/TXNS 0l3AJhQT/j5/pNXQkOwE+XPbPTt6qZaUV2jFIx1SM4WxquhP44fvRReIwgkHjoh97VAx /ZrkgUgG7PJfkxZiKb65uqdo7FNw14O5fQU3gDlluNOb3RfJIJ709xmC/fDEFMTEttax 4ClWMbxogTEncCDXjseeE1B/9j7VnnJPg81xglnjHcY8eD5jpzf4inhk+rHsSB06sv0t OsciRhGZttvIwc+vn19/Ydca7FNCg5MN8bm8dj2LkOX58Pk6G90dT0U6JhnNqfdR4Dis +WFw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id i190-20020a6387c7000000b0057ab7f46381si5444052pge.76.2023.09.23.03.49.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 23 Sep 2023 03:49:24 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id EFBBE82F44E6; Sat, 23 Sep 2023 03:38:12 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230264AbjIWKiG (ORCPT + 99 others); Sat, 23 Sep 2023 06:38:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59292 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229538AbjIWKiF (ORCPT ); Sat, 23 Sep 2023 06:38:05 -0400 Received: from zju.edu.cn (mail.zju.edu.cn [61.164.42.155]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id C885319C; Sat, 23 Sep 2023 03:37:55 -0700 (PDT) Received: from localhost.localdomain (unknown [10.181.229.131]) by mail-app4 (Coremail) with SMTP id cS_KCgCHjBTjvw5lHNuxAA--.64194S4; Sat, 23 Sep 2023 18:37:42 +0800 (CST) From: Dinghao Liu To: dinghao.liu@zju.edu.cn Cc: linux-scsi@vger.kernel.org, Steffen Maier , Benjamin Block , Heiko Carstens , Vasily Gorbik , Alexander Gordeev , Christian Borntraeger , Sven Schnelle , Christof Schmitt , James Bottomley , Swen Schillig , linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] [v3] scsi: zfcp: Fix a double put in zfcp_port_enqueue Date: Sat, 23 Sep 2023 18:37:23 +0800 Message-Id: <20230923103723.10320-1-dinghao.liu@zju.edu.cn> X-Mailer: git-send-email 2.17.1 X-CM-TRANSID: cS_KCgCHjBTjvw5lHNuxAA--.64194S4 X-Coremail-Antispam: 1UD129KBjvJXoW7WF1rCF4UAry3Kw43WrW7Jwb_yoW8Cr4fpF s2g3WkJrW0vw4v9r4UJryUXFZ8ua1rKrW5Ca1jk34FkF9YgFnrtrWUtFySyr4UJrn7Wa9r AFWDKan8AFWDAw7anT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUUvl1xkIjI8I6I8E6xAIw20EY4v20xvaj40_Wr0E3s1l1IIY67AE w4v_Jr0_Jr4l8cAvFVAK0II2c7xJM28CjxkF64kEwVA0rcxSw2x7M28EF7xvwVC0I7IYx2 IY67AKxVWDJVCq3wA2z4x0Y4vE2Ix0cI8IcVCY1x0267AKxVW8Jr0_Cr1UM28EF7xvwVC2 z280aVAFwI0_GcCE3s1l84ACjcxK6I8E87Iv6xkF7I0E14v26rxl6s0DM2AIxVAIcxkEcV Aq07x20xvEncxIr21l5I8CrVACY4xI64kE6c02F40Ex7xfMcIj6xIIjxv20xvE14v26r1j 6r18McIj6I8E87Iv67AKxVWUJVW8JwAm72CE4IkC6x0Yz7v_Jr0_Gr1lF7xvr2IYc2Ij64 vIr41lF7I21c0EjII2zVCS5cI20VAGYxC7M4IIrI8v6xkF7I0E8cxan2IY04v7MxAIw28I cxkI7VAKI48JMxAIw28IcVCjz48v1sIEY20_GFWkJr1UJwCFx2IqxVCFs4IE7xkEbVWUJV W8JwC20s026c02F40E14v26r1j6r18MI8I3I0E7480Y4vE14v26r106r1rMI8E67AF67kF 1VAFwI0_Jw0_GFylIxkGc2Ij64vIr41lIxAIcVC0I7IYx2IY67AKxVWUJVWUCwCI42IY6x IIjxv20xvEc7CjxVAFwI0_Gr0_Cr1lIxAIcVCF04k26cxKx2IYs7xG6r1j6r1xMIIF0xvE x4A2jsIE14v26r1j6r4UMIIF0xvEx4A2jsIEc7CjxVAFwI0_Gr0_Gr1UYxBIdaVFxhVjvj DU0xZFpf9x0JUdHUDUUUUU= X-CM-SenderInfo: qrrzjiaqtzq6lmxovvfxof0/1tbiAgoHBmUNoyAhBgAAsF X-Spam-Status: No, score=2.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RCVD_IN_SBL_CSS,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Sat, 23 Sep 2023 03:38:13 -0700 (PDT) X-Spam-Level: ** When device_register() fails, zfcp_port_release() will be called after put_device(). As a result, zfcp_ccw_adapter_put() will be called twice: one in zfcp_port_release() and one in the error path after device_register(). So the reference on the adapter object is doubly put, which may lead to a premature free. Fix this by adjusting the error tag after device_register(). Fixes: f3450c7b9172 ("[SCSI] zfcp: Replace local reference counting with common kref") Signed-off-by: Dinghao Liu --- Changelog: v2: -Improve the patch description. -Add a new label 'err_register' to unify code style. v3: -Improve the names of goto labels. --- drivers/s390/scsi/zfcp_aux.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/drivers/s390/scsi/zfcp_aux.c b/drivers/s390/scsi/zfcp_aux.c index df782646e856..ab2f35bc294d 100644 --- a/drivers/s390/scsi/zfcp_aux.c +++ b/drivers/s390/scsi/zfcp_aux.c @@ -518,12 +518,12 @@ struct zfcp_port *zfcp_port_enqueue(struct zfcp_adapter *adapter, u64 wwpn, if (port) { put_device(&port->dev); retval = -EEXIST; - goto err_out; + goto err_put; } port = kzalloc(sizeof(struct zfcp_port), GFP_KERNEL); if (!port) - goto err_out; + goto err_put; rwlock_init(&port->unit_list_lock); INIT_LIST_HEAD(&port->unit_list); @@ -546,7 +546,7 @@ struct zfcp_port *zfcp_port_enqueue(struct zfcp_adapter *adapter, u64 wwpn, if (dev_set_name(&port->dev, "0x%016llx", (unsigned long long)wwpn)) { kfree(port); - goto err_out; + goto err_put; } retval = -EINVAL; @@ -563,7 +563,8 @@ struct zfcp_port *zfcp_port_enqueue(struct zfcp_adapter *adapter, u64 wwpn, return port; -err_out: +err_put: zfcp_ccw_adapter_put(adapter); +err_out: return ERR_PTR(retval); } -- 2.17.1