Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp806979imu; Tue, 27 Nov 2018 06:35:56 -0800 (PST) X-Google-Smtp-Source: AFSGD/UH2r0akBc2iW19LIcacmRtrZQDTVs1VvWSYnzePtNmRqTSz2hCsMP1OIqJcEGq5ZdYm+si X-Received: by 2002:a17:902:4681:: with SMTP id p1mr32533371pld.184.1543329356844; Tue, 27 Nov 2018 06:35:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543329356; cv=none; d=google.com; s=arc-20160816; b=jvHLzWtzrIAO4P7AKNu/p9UX+XF66r0dLyREGKcuIYWrYSdf9COrkANu/vkaZ8scQw VFM2G/FLz9ZD4v4Q5SR4Knorrg9Y2HPi6pX9S78fMsB8H7IMbiEZZDRGvdTMWu2ClZ6l dUwZUAyLwXAhpMzv94La/zUTEpj3GnL3tGi2i36oKzqMgOX4tihQCES44tCAPxJENfXW neDWIEcHRzp7dxhOQKEQISNGXmKzP6mE3T8K1EfooavbjQ8YPCQAUoosYVPe2jtu4UUh PMV5pcNY9kcbzbXIDp12hOw8Mq+oSm5XVsBben35kCvkuy7Y/dMZLmQcayiYkI5rx6KY 4gnQ== 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=IVCP6KjXw4SdUwbraedFu0XHwLpTkR+LBKdggOrcVKs=; b=gArDm4jtv0zm+KEbZ27uFZoQY84HIK8eMlKbVgWdw5PetF/YZdufJRS9WxNg8+3W39 Enxn/FNDWqROiZoQI1fZ6Aa3fQ0Tyl1i6ptGf3O+Vi9AIg9ZA7RHeOeRQkkPl+gUylsU inVAxoJkOeKwkOEzGkq7Sw1ACnZ2ZeRZdozY39s1vXIYWkxhKGpDx8hJOC9B04e1OHsg TpHRcMI8AFnCUfCd7f2NPxRCdwgtNlJ048WZY5NeXayLEa8P/ELCf+0FRRJEe0B3ogqX DxknRpxTu8nvn2uxaX2ZCODrPsWdszOtHNUB+59t1TcbHFsl9XtbivIuHnZZLEJ/BgKO YKHw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=Bg2SaTrs; 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 p127si806335pfp.119.2018.11.27.06.34.44; Tue, 27 Nov 2018 06:35:56 -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=Bg2SaTrs; 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 S1727512AbeK1BYX (ORCPT + 99 others); Tue, 27 Nov 2018 20:24:23 -0500 Received: from mail-lf1-f65.google.com ([209.85.167.65]:41265 "EHLO mail-lf1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727089AbeK1BYX (ORCPT ); Tue, 27 Nov 2018 20:24:23 -0500 Received: by mail-lf1-f65.google.com with SMTP id c16so16580278lfj.8 for ; Tue, 27 Nov 2018 06:26:17 -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=IVCP6KjXw4SdUwbraedFu0XHwLpTkR+LBKdggOrcVKs=; b=Bg2SaTrsDEw+KHgOQyc850or4mspu7N2ECj7kE4F0P4XJgX67Cf/kkHts9jFtQckIO duh0lFE+pJ4ng2o53589zA+aPfGz8lIZR7Fj9mA3bfAO8Ibj6Puu4U775RVBAFsgFU7E 0ObOtfqyAjyg2Nqaf5u40n1FpJtodm6ar8c756peSV0bUSXQN3GlNewel9TCKn3AA8oN yjbN0Wu2IrR7X3k5BdUrQH8FFOSN8knRqk/dAiT3xBancd6z2kcXUBvV5OjbntxWKMtj rFII2mUuL5JRFzJ+wnBVSZHyzW03HKznjsFDoz3JuPiI1w1MHHVGrZqrTfArK4lZb769 Z8ng== 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=IVCP6KjXw4SdUwbraedFu0XHwLpTkR+LBKdggOrcVKs=; b=F7YcBe/HsipNXM9RI2mOSlcqHw0IS+xBXWkYICO5pJmS0qe9u5JbLjBeTiDQ+/puzj lcIE2YzUpwRJiJlRTVUan+XIoRNaFBh/iRoE0sVYwX8cvPOpCKv7T558m2vdJSRZ6gIY l8CUg6b/J/uKHRV2QvGiGAjd5LCdAMwjacmze0Dgp4yaO0QPev8yKjvSuYLVdIfOwKWj yqpylbK5UXmHpSUYvAgOnTdQ0VaC1ae3uydg2DTPXVY2/s1wYS2uC92pRMMQ76HLQFua ed6LsaoNDIWlXwaIK7Lrcq/VX1gQP6Ci2gLl6HbhlcNMA/ZR8bQeFDMPK43Tyr8O/e1L yTIg== X-Gm-Message-State: AGRZ1gIwSBYtlupddzfaRlKFgFBQmBSy6Wq+XW7bl/YuH7X9TAtZr2AM vXL0oj5KwtTYMruFl018keXh1tmFMYM= X-Received: by 2002:a19:a86:: with SMTP id 128mr18014259lfk.139.1543328776402; Tue, 27 Nov 2018 06:26:16 -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 f29sm614699lfa.46.2018.11.27.06.26.15 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 27 Nov 2018 06:26:15 -0800 (PST) Subject: Re: [PATCH] lightnvm: pblk: adjust the position of the lock To: javier@cnexlabs.com Cc: suhua.tanke@gmail.com, axboe@kernel.dk, linux-block@vger.kernel.org, linux-kernel@vger.kernel.org References: <20181127015309.2374-1-suhua.tanke@gmail.com> From: =?UTF-8?Q?Matias_Bj=c3=b8rling?= Message-ID: <55a08621-53cd-66b0-5b31-ca2bd6b26861@lightnvm.io> Date: Tue, 27 Nov 2018 15:26:15 +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: 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/27/2018 03:24 PM, Javier Gonzalez wrote: > >> On 27 Nov 2018, at 15.22, Matias Bjørling wrote: >> >> On 11/27/2018 01:57 PM, Javier Gonzalez wrote: >>>> On 27 Nov 2018, at 02.53, Hua Su wrote: >>>> >>>> Add lock protection for list operations. >>>> Signed-off-by: Hua Su >>>> --- >>>> drivers/lightnvm/pblk-core.c | 17 ++++++++++------- >>>> 1 file changed, 10 insertions(+), 7 deletions(-) >>>> >>>> diff --git a/drivers/lightnvm/pblk-core.c b/drivers/lightnvm/pblk-core.c >>>> index 6944aac43b01..e490df217dac 100644 >>>> --- a/drivers/lightnvm/pblk-core.c >>>> +++ b/drivers/lightnvm/pblk-core.c >>>> @@ -1286,24 +1286,27 @@ int pblk_line_recov_alloc(struct pblk *pblk, struct pblk_line *line) >>>> list_del(&line->list); >>>> >>>> ret = pblk_line_prepare(pblk, line); >>>> - if (ret) { >>>> - list_add(&line->list, &l_mg->free_list); >>>> - spin_unlock(&l_mg->free_lock); >>>> - return ret; >>>> - } >>>> - spin_unlock(&l_mg->free_lock); >>>> + if (ret) >>>> + goto out; >>>> >>>> ret = pblk_line_alloc_bitmaps(pblk, line); >>>> if (ret) >>>> - return ret; >>>> + goto out; >>>> >>>> if (!pblk_line_init_bb(pblk, line, 0)) { >>>> list_add(&line->list, &l_mg->free_list); >>>> + spin_unlock(&l_mg->free_lock); >>>> return -EINTR; >>>> } >>>> + spin_unlock(&l_mg->free_lock); >>>> >>>> pblk_rl_free_lines_dec(&pblk->rl, line, true); >>>> return 0; >>>> + >>>> +out: >>>> + 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 >>> This path is only touched by the recovery path, which is single >>> threaded, so there is no race condition as is. Also, if recovery fails, >>> pblk will not create the instance at all. This said, it would be >>> good to 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. >> >> I like your explanation here. Another option is that we could add a comment to notify the developer that it safe in this context? > > Sure. Do you want to add it? Or should I send it? > > Javier > Please send it. Thanks!