Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp598483imb; Fri, 1 Mar 2019 08:50:43 -0800 (PST) X-Google-Smtp-Source: APXvYqxU9i+4meukafdB1ufUEiMT09cuA+XkPirCT4DJUvTVER+v6ddGqvxzlTxWuUuRSPj1+sqw X-Received: by 2002:a17:902:9341:: with SMTP id g1mr6494429plp.80.1551459043206; Fri, 01 Mar 2019 08:50:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551459043; cv=none; d=google.com; s=arc-20160816; b=uu4fyiMT/nb/H+aKdUdc76/nMVFAjJ1F5BObCx+UG+wfCWtyMytUtMNpqwqKwdJVU4 S1RTLXEJOmExPDdPaq44YoinckzZn0R3j7D29+9zYwofXHyP/OwN4DzBv+c3H2gP2RgY LGcd0y8aWOFB6NZ1/0eqvvMWbmjnpc7pN0KoZMHnISKN6RR+wVKPNRSSXYuzX4ABzpKi hdoRo0DD6hWuAjp5f9MwonmE9v8IX9iLBEwOtNOulJzAWI2GQSlCRAaX9IQUk8SYwY4Q Ptfydb4ZxE5ZLjcRUQudQAiWTcyGQIeolRSLo1vGfszqP8jIuS/Y8HI7wdbZH1Rp6K6K 5jVg== 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=+Yz0uiTf07O3FtCAB7jVc9+niTq+LKff5BwRnHvkvdw=; b=OFOu/9zNxD5iMn9uLunOjSMzqC14Rh6BbaPny3hKD2DCyych/2130qc/hZWx/64Qmh mo2JF36Kwi98uNleSEeXFYt6Fhq2qb/Z4fcHs+r9Mpr3bMCpO4qwGlmhPb6w+9dGYpMF 1d1GZ5eQ1l3TSbzxa/g0PerA89Gnj11QcF+/l7tS22EJtuCRO+fK9j54d5H2S6ZKLnfh D8TIKZ8je/Vz8vBtWdwjxkbY4rcnKRqUKBvH+eIm4tCCX7DPzeqcbx5lKu6XkiMPmSIm uu+jNbziRMQULOeABxaKhiw795jcIzm6bAflxtyTdAOGurYfJxp/NE5O0G+OmU4tE+OZ 6/lA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=QfosMyAG; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e71si633322pgc.593.2019.03.01.08.50.27; Fri, 01 Mar 2019 08:50:43 -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=@ti.com header.s=ti-com-17Q1 header.b=QfosMyAG; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389158AbfCAQsn (ORCPT + 99 others); Fri, 1 Mar 2019 11:48:43 -0500 Received: from lelv0142.ext.ti.com ([198.47.23.249]:47820 "EHLO lelv0142.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728285AbfCAQsm (ORCPT ); Fri, 1 Mar 2019 11:48:42 -0500 Received: from fllv0034.itg.ti.com ([10.64.40.246]) by lelv0142.ext.ti.com (8.15.2/8.15.2) with ESMTP id x21Gm2dA087945; Fri, 1 Mar 2019 10:48:02 -0600 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1551458882; bh=+Yz0uiTf07O3FtCAB7jVc9+niTq+LKff5BwRnHvkvdw=; h=Subject:To:CC:References:From:Date:In-Reply-To; b=QfosMyAG9oj0+25rtvwPdPXW+EH277e79rHnQuRwkTiX/8dNRhlyYex4x/molZpyg xEQS2ZQZOlA0lnLmHgQInsi/wO+nuSQ0ShNruZLZx3sQf7XTS9jKuA9hmLkA3pz7QQ gqhAlDKHYSj7wAn9ypABuUJuSeQCyEGcQoaJkJpM= Received: from DLEE108.ent.ti.com (dlee108.ent.ti.com [157.170.170.38]) by fllv0034.itg.ti.com (8.15.2/8.15.2) with ESMTPS id x21Gm2S7052275 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Fri, 1 Mar 2019 10:48:02 -0600 Received: from DLEE103.ent.ti.com (157.170.170.33) by DLEE108.ent.ti.com (157.170.170.38) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1591.10; Fri, 1 Mar 2019 10:48:01 -0600 Received: from dlep33.itg.ti.com (157.170.170.75) by DLEE103.ent.ti.com (157.170.170.33) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1591.10 via Frontend Transport; Fri, 1 Mar 2019 10:48:01 -0600 Received: from [172.22.218.108] (ileax41-snat.itg.ti.com [10.172.224.153]) by dlep33.itg.ti.com (8.14.3/8.13.8) with ESMTP id x21Glt8a007743; Fri, 1 Mar 2019 10:47:56 -0600 Subject: Re: [PATCH v3] cfi: fix deadloop in cfi_cmdset_0002.c do_write_buffer To: Tokunori Ikegami , "'Boris Brezillon'" , "'liujian (CE)'" CC: "'Tokunori Ikegami'" , "keescook@chromium.org" , "bbrezillon@kernel.org" , "ikegami@allied-telesis.co.jp" , "richard@nod.at" , "linux-kernel@vger.kernel.org" , "marek.vasut@gmail.com" , "linux-mtd@lists.infradead.org" , "computersforpeace@gmail.com" , "dwmw2@infradead.org" References: <1551189648-58073-1-git-send-email-liujian56@huawei.com> <016001d4cf71$865e7b60$931b7220$@gmail.com> <4F88C5DDA1E80143B232E89585ACE27D0264F137@DGGEMM528-MBX.china.huawei.com> <20190228164228.734ede80@collabora.com> <005a01d4d03e$39b0e0f0$ad12a2d0$@yahoo.co.jp> From: Vignesh Raghavendra Message-ID: <4b3bc01a-3632-5dde-f683-94744ee7179d@ti.com> Date: Fri, 1 Mar 2019 22:17:55 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.5.1 MIME-Version: 1.0 In-Reply-To: <005a01d4d03e$39b0e0f0$ad12a2d0$@yahoo.co.jp> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [...] >>>>> In function do_write_buffer(), in the for loop, there is a case >>>>> chip_ready() returns 1 while chip_good() returns 0, so it never break >>>>> the loop. >>>>> To fix this, chip_good() is enough and it should timeout if it stay >>>>> bad for a while. >>>>> >>>>> Fixes: dfeae1073583("mtd: cfi_cmdset_0002: Change write buffer to >>>>> check correct value") >>>>> Signed-off-by: Yi Huaijie >>>>> Signed-off-by: Liu Jian >>>>> Reviewed-by: Tokunori Ikegami >>>>> --- >>>>> v2->v3: >>>>> Follow Vignesh's advice: >>>>> add one more check for check_good() even when time_after() returns >> true. >>>>> >>>>> drivers/mtd/chips/cfi_cmdset_0002.c | 2 +- >>>>> 1 file changed, 1 insertion(+), 1 deletion(-) >>>>> >>>>> diff --git a/drivers/mtd/chips/cfi_cmdset_0002.c >>>>> b/drivers/mtd/chips/cfi_cmdset_0002.c >>>>> index 72428b6..3da2376 100644 >>>>> --- a/drivers/mtd/chips/cfi_cmdset_0002.c >>>>> +++ b/drivers/mtd/chips/cfi_cmdset_0002.c >>>>> @@ -1876,7 +1876,7 @@ static int __xipram do_write_buffer(struct >>>>> map_info *map, struct flchip *chip, >>>>> continue; >>>>> } >>>>> >>>>> - if (time_after(jiffies, timeo) && !chip_ready(map, adr)) >>>>> + if (time_after(jiffies, timeo) && !chip_good(map, adr, >>>>> datum)) >>>> >>>> Just another idea to understand easily. >>>> >>>> unsigned long now = jiffies; >>>> >>>> if (chip_good(map, adr, datum)) { >>>> xip_enable(map, chip, adr); >>>> goto op_done; >>>> } >>>> >>>> if (time_after(now, timeo) { >>>> break; >>>> } >>>> >>> >>> Thank you~. It is more easier to understand! >>> If there are no other comments, I will send new patch again ): >> >> Except this version no longer does what Vignesh suggested. See how you >> no longer test if chip_good() is true if time_after() returns true. So, >> imagine the thread entering this function is preempted just after the >> first chip_good() test, and resumed a few ms later. time_after() will >> return true, but chip_good() might also return true, and you ignore it. > > I think that the following 3 versions will be worked for time_after() as a same result and follow the Vignesh-san suggestion. > As Boris explained above version 3 does not really follow my suggestion... Please see below > 1. Original Vignesh-san suggestion > > if (chip_good(map, adr, datum)) { > xip_enable(map, chip, adr); > goto op_done; > } > > if (time_after(jiffies, timeo)) { > /* Test chip_good() if TRUE incorrectly again so write failure by time_after() can be avoided. */ > if (chip_good(map, adr, datum)) { > xip_enable(map, chip, adr); > goto op_done; > } > break; > } > Right, here we check chip_good() once _even when time_after() is true_ to avoid _spurious_ timeout > 2. Liujian-san v3 patch > > /* Test chip_good() if FALSE correctly so write failure by time_after() can be avoided. */ > if (time_after(jiffies, timeo) && !chip_good(map, adr)) > break; > > if (chip_good(map, adr, datum)) { > xip_enable(map, chip, adr); > goto op_done; > } > This is a better version of 1 > 3. My idea > > /* Save current jiffies value before chip_good() to avoid write failure by time_after() without testing chip_good() again. */ > unsigned long now = jiffies; > > if (chip_good(map, adr, datum)) { > xip_enable(map, chip, adr); > goto op_done; > } > What if thread gets pre-empted at this point and is re-scheduled exactly after timeo jiffies have elapsed? Below check would be true and exit loop > if (time_after(now, timeo)) > break; > So, code does not check for check chip_good() after timeoout has elapsed. But chip_good() might be true at this point. Therefore leading to spurious timeout. So this version is still not right. > Note: Some brackets have been fixed from the previous mail. >