Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3478825imu; Fri, 30 Nov 2018 00:38:40 -0800 (PST) X-Google-Smtp-Source: AFSGD/VNEdJYVDghX/vBkT3xca7fO2KTzQt5pAYatFofU7FCoMu4eZyozNp3wUIPnDPjyBz1BXXK X-Received: by 2002:aa7:83c6:: with SMTP id j6mr4722462pfn.91.1543567120325; Fri, 30 Nov 2018 00:38:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543567120; cv=none; d=google.com; s=arc-20160816; b=KvDgNQr7mmc5ak9LRfOgav9HLGeHx+Gf6UBFfnqep23AxjlGRALj0n4HsOLWC6SRad fk3x94BJr+a6uoUnNAtRuKS06Z01AcX2Zv+D1cas3xnJl7EZLCpJdPxAqqE6n3Lg6I8K ce4bedof0co4GL1SGbYqjUYW56Irwz7viwrgDxyHiKBjBPG1nYvuUP1NJ3vojTVD7XHY 7fIPSUGsHE8DAvKrQcq3GBGbmXiNBd55swyJ2s5e5XsQgHvYR0Ir2IxNeySg9SHHfRsq RyfBUIq4YgjIkvGxtNqocdOLt+Ra10B9tkjcvpb86xwAcUal3F/NSTyVaAfKNRTcJCIU FMzg== 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:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=mrwc12kGFUvTe4G8O2yVusGKb78ANicaV+8Tfof25bQ=; b=abrUpkW7N4RWhpbdKDmIdiaPLZobSTpMgAsIJnkGmHiFlu1iuNQY3oxQNKMnOCMuO3 TfZkfRZCKU/TGNUk/jEHOZtDxBwo5aSApKzEzTG3PzRz2jeW120tQV93wHNOlle7+mMG K5nNApFgyKR9CIgfQSGNFzpLDTYSBLyFOjOjpt5yyzUMf9up5FVTE9IFlQtM5h4qrj4v 8Q45iapigjayy+XIYdtB5wBYdNcP4+TCCIorhWICfHLAbbMyVeFEweVfjEXt1gYT+OSP ujw/H6G8dIA9B0gChqQAZn2OkIxk8BJ8UUBjzZa8733g3br16tMBP+X4sohbzZCU2hXt dlwg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=TOITIWu2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h191si4374085pgc.302.2018.11.30.00.38.26; Fri, 30 Nov 2018 00:38:40 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=TOITIWu2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727138AbeK3Tor (ORCPT + 99 others); Fri, 30 Nov 2018 14:44:47 -0500 Received: from mail-lf1-f66.google.com ([209.85.167.66]:43341 "EHLO mail-lf1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727086AbeK3Tor (ORCPT ); Fri, 30 Nov 2018 14:44:47 -0500 Received: by mail-lf1-f66.google.com with SMTP id u18so3474748lff.10 for ; Fri, 30 Nov 2018 00:36:13 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lightnvm-io.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=mrwc12kGFUvTe4G8O2yVusGKb78ANicaV+8Tfof25bQ=; b=TOITIWu20w+TZzp9jiY2fK2vjMZvd83jQatrBCtKkujphNDnnVWVNTAGQ0VU/zKcAV G+6wA3zFS9Pu1NKX6suxFFvxrNxBkWUzY3SZOzmoBqClkdTrdNASnO3QWodWM+IUHAi/ jVh4MxqNsJOVsLhh/bF7r/Ml6VIoV1JlwfWr/LqajnllsBMt4+wKH4Lx+VccUg9AhLEe 36dP/9ECY2fxwKBUNdz5ExGr8G1Zy7Tp8bFpvqEedT+qbgMdyM7Ipd3L46XcGsqbNKU0 p/w7uRwVEXVOZdz4+BIThD0a/M5uWCzDsxr00+CLHZWYjxplpC0I+9Z1pmyuweBXh6t8 8V3w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=mrwc12kGFUvTe4G8O2yVusGKb78ANicaV+8Tfof25bQ=; b=qTtmbNIW2gKyeYIGf35puK4T37N8rCx9RrvtqMEFdJvq2pTSH2BzrQs1nia+lRITGS D1CT7kYiRUBbz73ZuCsWAkLkHTNIjCReqvn4abOqAhcxzWaNg4gHvwYZl+D+QuQh2BG3 b6lFsLg7TH1AC8EBP250wGFtyA8ImqrtHWR0MoUdHUYJFEodlYS+6XBfC33bvuv8ERgW HqQvUZosQ0wJXEyuyru/T39Yuif993xOWTDioz1EhFUNIY2sc5RR62l+LXSzXYIAFz4P 2B3wGoc2tP8IFEnRJ446VzbdvTwpLt5OZofkndFJ6ie+yfGlNJ9Niw2C2NdVWrfjfg+E 047A== X-Gm-Message-State: AA+aEWYq3ES0MEu7dlfE0OzyWpjvyFWeG5Pu18n079y3TCAMwcLA2de7 Z8g2Z51aMIanV0aPmVB3ZXKBzdLsvbw= X-Received: by 2002:a19:2106:: with SMTP id h6mr2943704lfh.29.1543566972748; Fri, 30 Nov 2018 00:36:12 -0800 (PST) Received: from [192.168.0.36] (95-166-82-66-cable.dk.customer.tdc.net. [95.166.82.66]) by smtp.googlemail.com with ESMTPSA id b81-v6sm680627ljb.7.2018.11.30.00.36.11 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 30 Nov 2018 00:36:12 -0800 (PST) Subject: Re: [PATCH] lightnvm: pblk: add lock protection to list operations To: Javier Gonzalez , Hua Su Cc: Jens Axboe , "linux-block@vger.kernel.org" , "linux-kernel@vger.kernel.org" References: <20181128091352.5088-1-suhua.tanke@gmail.com> <930717BD-D32A-4BE2-AEE6-579594E70842@cnexlabs.com> From: =?UTF-8?Q?Matias_Bj=c3=b8rling?= Message-ID: Date: Fri, 30 Nov 2018 09:36:11 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <930717BD-D32A-4BE2-AEE6-579594E70842@cnexlabs.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/28/2018 10:16 AM, Javier Gonzalez wrote: >> On 28 Nov 2018, at 10.13, Hua Su wrote: >> >> Protect the list_add on the pblk_line_init_bb() error >> path in case this code is used for some other purpose >> in the future. >> >> Signed-off-by: Hua Su >> --- >> drivers/lightnvm/pblk-core.c | 13 ++++++++++--- >> 1 file changed, 10 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/lightnvm/pblk-core.c b/drivers/lightnvm/pblk-core.c >> index 6944aac43b01..247112e1db94 100644 >> --- a/drivers/lightnvm/pblk-core.c >> +++ b/drivers/lightnvm/pblk-core.c >> @@ -1295,15 +1295,22 @@ int pblk_line_recov_alloc(struct pblk *pblk, struct pblk_line *line) >> >> ret = pblk_line_alloc_bitmaps(pblk, line); >> if (ret) >> - return ret; >> + goto fail; >> >> if (!pblk_line_init_bb(pblk, line, 0)) { >> - list_add(&line->list, &l_mg->free_list); >> - return -EINTR; >> + ret = -EINTR; >> + goto fail; >> } >> >> pblk_rl_free_lines_dec(&pblk->rl, line, true); >> return 0; >> + >> +fail: >> + spin_lock(&l_mg->free_lock); >> + list_add(&line->list, &l_mg->free_list); >> + spin_unlock(&l_mg->free_lock); >> + >> + return ret; >> } >> >> void pblk_line_recov_close(struct pblk *pblk, struct pblk_line *line) >> -- >> 2.19.1 > > Looks good to me. > > Reviewed-by: Javier González > Picked up for 4.21.