Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp654885ybz; Wed, 15 Apr 2020 16:03:00 -0700 (PDT) X-Google-Smtp-Source: APiQypLz0U5ObZlMR3PyPSKIRHjdaw6Zwg0q32cwDiR7tNmAKvsucf9noDXB9ZVs/q/MmfaKh+oI X-Received: by 2002:a05:6402:1802:: with SMTP id g2mr22374666edy.364.1586991780540; Wed, 15 Apr 2020 16:03:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586991780; cv=none; d=google.com; s=arc-20160816; b=ofpAdBOiFzGKkN//2hBLHtzHy36KRlKUM97Qz9LdgPHmLeVdkpzBoaPBTB+4BylHxw nf8O5rsVyR4oKoVxa5dgvnOB74105RnYJr9+3nrp48zM9XUJ/rDRiKVtcYVW18s4xj99 sLewPtVMWUWVfZ/PlM6ukvEeCXnplgaoPKr6aQZaDEhBAmEE13nxSJtoGOMdho/B+h8d t+UjFutdQn0G10AFGXhcJBSfZIARgDddV/yI2pQG9l7AOZylGPdVQRWOFr9zkKLoXHaS gtIlM+UyN/ecJr5/ehUZOtvP7w9cDx3Gkh4msansVVY3M8pMu0s/YxzntTTR+TOPTPeK cXpA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:mime-version:user-agent:date:message-id:subject :from:cc:to; bh=yNz3NcxLuoc35wRCbUetkD6qX/TAP+5hSUiowv0CdDg=; b=mgMcKySaSALvA18E58MujKhYwuu2XTcmmk20Ib5127Mqw24lM4SMPkpsbsTZPM/3GK iu7asMaaF/zOWo74k1GBZ9rCrBVz5ChZ2p+I6O2WdnLD9K+c7ZKvmHz/ehiW2c4noFe8 DgeSGYFzdNnVnPg5/tMlmLh8G3Gts7aVRAJ8VNV23+i4vBa8farHynn1G4Xui3BRquki jbs3EZDESwkZfnohalH0FBrHZnqMCbxtv8ReE5jLOHLWq/hNGzszau/suMzyqlfnrV5t rr9WuPduGRPYgS3Ahn0GVPFN4V50vyy7DTjpSvgC9dPkZI1YFBwPOl5VjazWiwD//rZM s7DQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i18si11901635ejz.35.2020.04.15.16.02.37; Wed, 15 Apr 2020 16:03:00 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2406128AbgDOLpY (ORCPT + 99 others); Wed, 15 Apr 2020 07:45:24 -0400 Received: from szxga07-in.huawei.com ([45.249.212.35]:58510 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2897446AbgDOLmP (ORCPT ); Wed, 15 Apr 2020 07:42:15 -0400 Received: from DGGEMS409-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id AF1C788E720CD8B1895E; Wed, 15 Apr 2020 19:42:10 +0800 (CST) Received: from [127.0.0.1] (10.173.220.183) by DGGEMS409-HUB.china.huawei.com (10.3.19.209) with Microsoft SMTP Server id 14.3.487.0; Wed, 15 Apr 2020 19:42:04 +0800 To: , , , CC: "wubo (T)" , Mingfangsen , Yanxiaodan , linfeilong From: Zhiqiang Liu Subject: bcache: unlock new_nodes[i]->write_lock in btree_gc_coalesce Message-ID: Date: Wed, 15 Apr 2020 19:42:03 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.173.220.183] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Zhiqiang Liu coccicheck reports: drivers/md//bcache/btree.c:1538:1-7: preceding lock on line 1417 After obtaining new_nodes[i]->write_lock, we may go to out_nocoalesce tag without releasing lock. Here, we add a new tag 'out_unlock_nocoalesce' before out_nocoalesce tag to release new_nodes[i]->write_lock. Fixes: 2a285686c1 ("bcache: btree locking rework") Signed-off-by: Zhiqiang Liu --- drivers/md/bcache/btree.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/drivers/md/bcache/btree.c b/drivers/md/bcache/btree.c index fa872df4e770..cad8b0b97e33 100644 --- a/drivers/md/bcache/btree.c +++ b/drivers/md/bcache/btree.c @@ -1447,7 +1447,7 @@ static int btree_gc_coalesce(struct btree *b, struct btree_op *op, if (__set_blocks(n1, n1->keys + n2->keys, block_bytes(b->c)) > btree_blocks(new_nodes[i])) - goto out_nocoalesce; + goto out_unlock_nocoalesce; keys = n2->keys; /* Take the key of the node we're getting rid of */ @@ -1476,7 +1476,7 @@ static int btree_gc_coalesce(struct btree *b, struct btree_op *op, if (__bch_keylist_realloc(&keylist, bkey_u64s(&new_nodes[i]->key))) - goto out_nocoalesce; + goto out_unlock_nocoalesce; bch_btree_node_write(new_nodes[i], &cl); bch_keylist_add(&keylist, &new_nodes[i]->key); @@ -1522,6 +1522,10 @@ static int btree_gc_coalesce(struct btree *b, struct btree_op *op, /* Invalidated our iterator */ return -EINTR; +out_unlock_nocoalesce: + for (i = 0; i < nodes; i++) + mutex_unlock(&new_nodes[i]->write_lock); + out_nocoalesce: closure_sync(&cl); -- 2.19.1