Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp6270594yba; Thu, 11 Apr 2019 16:04:46 -0700 (PDT) X-Google-Smtp-Source: APXvYqxVTXjVF1yJZSj6jaoWJFOgpB4ykeEm+DZQFSxZyTe/sPoAbeWZcgXSqYl9Hb5OQEmovzHw X-Received: by 2002:a62:e50a:: with SMTP id n10mr52807417pff.55.1555023886540; Thu, 11 Apr 2019 16:04:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555023886; cv=none; d=google.com; s=arc-20160816; b=0tCKXG/6wSy3HNbilIDSoEsk9PhRu4Q8PCgQsDQGJHim7/TyOzKT2W1pEqjz26ktyu lcHTQR24jDWrnY8HCCCu/TuMFVX0rEhtcXilrpV29zoTMFi5L/+5aXGAsCNkD+i+Mu+j 7Nh/olZ+S74beRW6u9XfNH6na2UqtwiY0EKgUzxJ69eROmdXElFCkokwAnrvcA45HTFI ysxL0Y+1ya369gZtzMuzjzcXUfUWkg8qFv+DpIVMiM3UjuSiQZo6gw7E7c17Z8+DR8eN rd4UJ4QsZzsxKkVkd1BTNfGw+bNnIMFT56WxO173rtYAVkDj2p/rBrqFSU2z51/XzqI1 pUPg== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=4m105n5JXJH4GNf9WN+soWtXGry/vpyc5a/iSxRDFzw=; b=j5BSSwpwa1ReqBFM3TpGxQU4ajGGSN4OskioRTMynFl4jZtwJcAC1FeHC71n3U84dK 7epaQBzTW388IbXM2SiUkckVcXYVbcxY0zC1ikjp8zgvALCnn9BAD0klsmGrDwCsZWCW zybn6/MY41HlBFU+Ml2xdhAN34esQWXfV8/XT6stZs1EN/VYjJdLUWqOob70Jwkm6qVU o6mGOufo5bd2H+6J5yF6QcojOtfDPsrb4tEeu+jbRGgrFTux1h9rMHkP46a1s05dDEwA b4ntcFFqylpXGnFUzRkMD9+/O+P0KazRO+6LtL7x0kR8WRnIA7ehcCd4rRzmpTWPsSnB U1DA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@googlemail.com header.s=20161025 header.b=NzNFKjHb; 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=QUARANTINE dis=NONE) header.from=googlemail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f38si34997722pgf.90.2019.04.11.16.04.16; Thu, 11 Apr 2019 16:04:46 -0700 (PDT) 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=@googlemail.com header.s=20161025 header.b=NzNFKjHb; 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=QUARANTINE dis=NONE) header.from=googlemail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726936AbfDKWBa (ORCPT + 99 others); Thu, 11 Apr 2019 18:01:30 -0400 Received: from mail-wm1-f66.google.com ([209.85.128.66]:35849 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726890AbfDKWB1 (ORCPT ); Thu, 11 Apr 2019 18:01:27 -0400 Received: by mail-wm1-f66.google.com with SMTP id h18so8495154wml.1 for ; Thu, 11 Apr 2019 15:01:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=googlemail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=4m105n5JXJH4GNf9WN+soWtXGry/vpyc5a/iSxRDFzw=; b=NzNFKjHb09kbOIHFC41lGJd95srXDx+k6jOgARNJ6GIQ36ROXxomwgG1t5ZZmtnDcq 9x0D4BW/E1st5N+fdpO4q/KshtnUPtQJjHjutgQdFrpX/HAI1lc5Ni4VWJC9Jhnak+9a WLTkCFzeaPFj4djeAlX7H65RWyYR3vJnvlRvlCcEvZ6vxC6XH5Mo7QYJ4PKFAQdOrrZl BH44N+OpoVxPWmBdIAwy0qsgN2oarmGgx7+jb8cJfmn2RlvtqijKBA420rFOYuQ2us0E shLtv0GWTTcOa/xcgDqYvMJ0mH2xgXcuRLkpajKWtvCRPnSPjSLKY+s4lAdDjEeGD7+3 +R2g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=4m105n5JXJH4GNf9WN+soWtXGry/vpyc5a/iSxRDFzw=; b=tGKh7bvGHSCpxHdmyruxCNEdM/fYKe/HWL35Af9hQIbbQj53y9ODz/31i5WUj/UKIK e3/Nf/k81bq75qbfSGf32amNcZJ573eWMEpU4k7ZO5Bd6ldGABMJNI3W7fBJWi5p5Wzt 8aIbDohaahUJzZOWykJZQuZ5oxzoSU8kGD+nE9PP+tOhD0BSOtBLbt3LwHXQevufONbD 67a8FMdZB0ePIHLQuI6q9B1mZEI9nnbbEzMd1nACQBN3tX/kRfwA/Mn+nvC/XhXD90wW MNx6QT1QJimCKsBzJP27zwU9NPEzG8qbf/yQFJycG+SMRDZri6ezicGMa5ffPt+mw4DN VVMA== X-Gm-Message-State: APjAAAV+8iqKww7DZxujuCfrfPdtk31Q7eKQjmXm5YEvaglsBJMIDSdd wWFgyf2Mo1OtpBQdiVy8oR0= X-Received: by 2002:a1c:6783:: with SMTP id b125mr8256171wmc.41.1555020085029; Thu, 11 Apr 2019 15:01:25 -0700 (PDT) Received: from blackbox.darklights.net (p200300F133C8AD0009F15067C8D22C31.dip0.t-ipconnect.de. [2003:f1:33c8:ad00:9f1:5067:c8d2:2c31]) by smtp.googlemail.com with ESMTPSA id s189sm13266186wmf.45.2019.04.11.15.01.23 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 11 Apr 2019 15:01:24 -0700 (PDT) From: Martin Blumenstingl To: liang.yang@amlogic.com, linux-amlogic@lists.infradead.org, linux-mtd@lists.infradead.org, richard@nod.at, miquel.raynal@bootlin.com Cc: linux-arm-kernel@lists.infradead.org, marek.vasut@gmail.com, linux-kernel@vger.kernel.org, computersforpeace@gmail.com, dwmw2@infradead.org, bbrezillon@kernel.org, jianxin.pan@amlogic.com, Martin Blumenstingl Subject: [PATCH 4/4] mtd: rawnand: meson: only initialize the RB completion once Date: Fri, 12 Apr 2019 00:00:56 +0200 Message-Id: <20190411220056.19109-5-martin.blumenstingl@googlemail.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190411220056.19109-1-martin.blumenstingl@googlemail.com> References: <20190411220056.19109-1-martin.blumenstingl@googlemail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Documentation/scheduler/completion.txt states: Calling init_completion() on the same completion object twice is most likely a bug as it re-initializes the queue to an empty queue and enqueued tasks could get "lost" - use reinit_completion() in that case, but be aware of other races. Initialize nfc->completion in meson_nfc_probe using init_completion and change the call in meson_nfc_queue_rb to reinit_completion so the logic matches what the documentation suggests. Signed-off-by: Martin Blumenstingl --- drivers/mtd/nand/raw/meson_nand.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/drivers/mtd/nand/raw/meson_nand.c b/drivers/mtd/nand/raw/meson_nand.c index 57cc4bd3f665..ea57ddcec41e 100644 --- a/drivers/mtd/nand/raw/meson_nand.c +++ b/drivers/mtd/nand/raw/meson_nand.c @@ -400,7 +400,7 @@ static int meson_nfc_queue_rb(struct meson_nfc *nfc, int timeout_ms) cfg |= NFC_RB_IRQ_EN; writel(cfg, nfc->reg_base + NFC_REG_CFG); - init_completion(&nfc->completion); + reinit_completion(&nfc->completion); /* use the max erase time as the maximum clock for waiting R/B */ cmd = NFC_CMD_RB | NFC_CMD_RB_INT @@ -1380,6 +1380,7 @@ static int meson_nfc_probe(struct platform_device *pdev) nand_controller_init(&nfc->controller); INIT_LIST_HEAD(&nfc->chips); + init_completion(&nfc->completion); nfc->dev = dev; -- 2.21.0