Received: by 2002:ac0:8845:0:0:0:0:0 with SMTP id g63csp622742img; Tue, 26 Feb 2019 06:02:38 -0800 (PST) X-Google-Smtp-Source: AHgI3IZEhrQ30pJ+ecCn9PyrudIBPup7Rj78kB2jpVez7QV6qF0EfeUGoc4FrAoSrReUwH5mXIp4 X-Received: by 2002:a65:47ca:: with SMTP id f10mr24403283pgs.124.1551189758226; Tue, 26 Feb 2019 06:02:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551189758; cv=none; d=google.com; s=arc-20160816; b=kOuxUYZYwGpEvlo8ne2WnacW/IPFdGJ+mO+RHXjt14BUkxFSzk8X8vaHLswu5LEFeK zGS9IPtSajVXu8v8Y99JAWmimLqqcprkyVh0QeDE2bprfQ0J2/HiH+UzobHTawcuvqb8 xSXLfvyhJ949hq9RWcblFysxbk8CI1lvXrl5Hg31x4w2cO2hRtULyZzxez7IPGc5yaSv eq7YEEFmaVeYtzqup41xr0edNQnxpzvtjMGntIRdTcCKvCWy3+fp36ws2Ue0HhCfRNs7 5jDPMSV5o208uiYQ6dfOFGQHeVS/IX5xCyM6T7IAIgiAvdpqwzaVP7hK09hQBuQawI3X h9Hg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=nJHEbpcKs44e7gyBkJNs503owjlL8fPhmcTdVH2NP7M=; b=xULik3SiPTo4wh2RVuAEcdzqlVEgluuwyXiAIYqbJfB6Og4ZemUBsoXHKVPPfsiNIB Lnl1qUPFt1BqoRcLfsRYdgY5uF+dvqykpNtMcCFVNdEdYOaNMw5AVBt5hs5wyqO4G+Ur 4JQzVe5jA7Oe0UvuKk+K5xTnnIUDiJMHIfDlC+lGC/W7txRmGYgtAOEWijrcAWiGnvCj wICkuQ67ZHHJCIg+2V14/Vq/fCIOIRHjvq3YHJPHjpDEjQNj/b86b+E4uAO4+e4fRNZd 5FfB+/D/Gha0dXXdIiO7hMObzqLgBE0Po0zUcwXdMGTG6gwEd6O72XKuqjZ440xw3dQC sURw== ARC-Authentication-Results: i=1; mx.google.com; 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 k29si6096676pgb.267.2019.02.26.06.02.14; Tue, 26 Feb 2019 06:02:38 -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; 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 S1726539AbfBZOBp (ORCPT + 99 others); Tue, 26 Feb 2019 09:01:45 -0500 Received: from szxga06-in.huawei.com ([45.249.212.32]:35768 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726245AbfBZOBp (ORCPT ); Tue, 26 Feb 2019 09:01:45 -0500 Received: from DGGEMS413-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id E6E8532FD90917FD5AFA; Tue, 26 Feb 2019 22:01:41 +0800 (CST) Received: from huawei.com (10.175.104.208) by DGGEMS413-HUB.china.huawei.com (10.3.19.213) with Microsoft SMTP Server id 14.3.408.0; Tue, 26 Feb 2019 22:01:31 +0800 From: Liu Jian To: , , , , , , , , CC: , , Subject: [PATCH v3] cfi: fix deadloop in cfi_cmdset_0002.c do_write_buffer Date: Tue, 26 Feb 2019 22:00:48 +0800 Message-ID: <1551189648-58073-1-git-send-email-liujian56@huawei.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.104.208] X-CFilter-Loop: Reflected 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)) break; if (chip_good(map, adr, datum)) { -- 2.7.4