Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4722814pxj; Wed, 12 May 2021 11:44:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy4UkL3jAc7fdNwGaNqO+Wg0+j5Ow2hSpfQ+AEjTnC75UhqY9wH7BXXr0c9xhq9mFo+1wMK X-Received: by 2002:aca:490d:: with SMTP id w13mr8497941oia.140.1620845043624; Wed, 12 May 2021 11:44:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620845043; cv=none; d=google.com; s=arc-20160816; b=UxTKmQkpNoYrKLdqSgTLMKS0wPRlDuSCoQ8u1+ta/1wJFp+0mzFcV3Pby7pN6xJY0B i6a0AJJWpgQlPradRjn6paSZnqC1QL/OnyT0XjafNVwLjQdF0HTflK4+SrNl4TumuQyi iFtAc0/BD4Lr+EIIm6OK43NESZ8Dq/4sKLFJ1lYXBiBf+lWQTvNTugHSjUiaLGKSRdab AoP+/ZU3KmAxRPGnC0YvdD0HaM0tZIvLeFmq7rFAwbLmwYPn3AU1fRNAwW+GqgWvB/d9 UsiyzbIN1JHLZTZo4+1MxueQSmNrnloms1aYBj8TdsLXb58XUY4YnRl0JBzzU7PNmckH UYsA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ic7bvfGIldOPMo4dusdO9ArZftOFpl9pR6KjcKuAwXA=; b=Zroce/jFf2fds+mAMWITS5koBFilKUiaaISz3cuAUiVTTvMOtcnkKDVnxM/nXOh8BA PlBhoUxh3cah07FBfTF26lf4jU27UCl9/h0/hBkYFnXrrgfVhacQZzZDRG5rwiJRnB3k 7gRN8iu0LEx5z3RzcubOiMa+RHaenJw86Ex2f4075GKCukR6eqQwtMLs7j3tklRCZ0r7 +sN4uQZTxfAHizE154ntoqzZdfB+So3WfmgrauVB3prxHN/DsMf41TJA1rWROCRDWyci uRQbfa7fZC5lbxDxjHgmQagLHuX22MNBJR3dmM93QpQL/mZCSXvs/DJ2R/S5hHh6OZPy M8/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=EQIqpsnd; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e20si431322otj.11.2021.05.12.11.43.47; Wed, 12 May 2021 11:44:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=EQIqpsnd; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242278AbhELSdD (ORCPT + 99 others); Wed, 12 May 2021 14:33:03 -0400 Received: from mail.kernel.org ([198.145.29.99]:57124 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243264AbhELQhB (ORCPT ); Wed, 12 May 2021 12:37:01 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 7692F61E23; Wed, 12 May 2021 16:01:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620835314; bh=3ko12gNx5sd+b+RuP/0bkyRe5JZE8HzT8Tp0etjgp3Q=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=EQIqpsndDa+zcY4JMU/L+oPivcXtRWdF2v05NUzyvLe8ruarLg+GGMEXJezQvQtFJ 2XZVEuCRCAEWYEXLHf3ITU6hBn3sA+R2H/poDExzoltt998ZSuH5C6si7Ohb4PACLF /pmwjs3xDy6es6ebBiIaqqHrLc0ZCcjhjfUu/JyY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Quanyang Wang , Amit Kumar Mahapatra , Mark Brown , Sasha Levin Subject: [PATCH 5.12 293/677] spi: spi-zynqmp-gqspi: use wait_for_completion_timeout to make zynqmp_qspi_exec_op not interruptible Date: Wed, 12 May 2021 16:45:39 +0200 Message-Id: <20210512144846.948559409@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144837.204217980@linuxfoundation.org> References: <20210512144837.204217980@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Quanyang Wang [ Upstream commit a16bff68b75fd082d36aa0b14b540bd7a3ebebbd ] When Ctrl+C occurs during the process of zynqmp_qspi_exec_op, the function wait_for_completion_interruptible_timeout will return a non-zero value -ERESTARTSYS immediately. This will disrupt the SPI memory operation because the data transmitting may begin before the command or address transmitting completes. Use wait_for_completion_timeout to prevent the process from being interruptible. This patch fixes the error as below: root@xilinx-zynqmp:~# flash_erase /dev/mtd3 0 0 Erasing 4 Kibyte @ 3d000 -- 4 % complete (Press Ctrl+C) [ 169.581911] zynqmp-qspi ff0f0000.spi: Chip select timed out [ 170.585907] zynqmp-qspi ff0f0000.spi: Chip select timed out [ 171.589910] zynqmp-qspi ff0f0000.spi: Chip select timed out [ 172.593910] zynqmp-qspi ff0f0000.spi: Chip select timed out [ 173.597907] zynqmp-qspi ff0f0000.spi: Chip select timed out [ 173.603480] spi-nor spi0.0: Erase operation failed. [ 173.608368] spi-nor spi0.0: Attempted to modify a protected sector. Fixes: 1c26372e5aa9 ("spi: spi-zynqmp-gqspi: Update driver to use spi-mem framework") Signed-off-by: Quanyang Wang Reviewed-by: Amit Kumar Mahapatra Link: https://lore.kernel.org/r/20210408040223.23134-2-quanyang.wang@windriver.com Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- drivers/spi/spi-zynqmp-gqspi.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/spi/spi-zynqmp-gqspi.c b/drivers/spi/spi-zynqmp-gqspi.c index c8fa6ee18ae7..d49ab6575553 100644 --- a/drivers/spi/spi-zynqmp-gqspi.c +++ b/drivers/spi/spi-zynqmp-gqspi.c @@ -973,7 +973,7 @@ static int zynqmp_qspi_exec_op(struct spi_mem *mem, zynqmp_gqspi_write(xqspi, GQSPI_IER_OFST, GQSPI_IER_GENFIFOEMPTY_MASK | GQSPI_IER_TXNOT_FULL_MASK); - if (!wait_for_completion_interruptible_timeout + if (!wait_for_completion_timeout (&xqspi->data_completion, msecs_to_jiffies(1000))) { err = -ETIMEDOUT; kfree(tmpbuf); @@ -1001,7 +1001,7 @@ static int zynqmp_qspi_exec_op(struct spi_mem *mem, GQSPI_IER_TXEMPTY_MASK | GQSPI_IER_GENFIFOEMPTY_MASK | GQSPI_IER_TXNOT_FULL_MASK); - if (!wait_for_completion_interruptible_timeout + if (!wait_for_completion_timeout (&xqspi->data_completion, msecs_to_jiffies(1000))) { err = -ETIMEDOUT; goto return_err; @@ -1076,7 +1076,7 @@ static int zynqmp_qspi_exec_op(struct spi_mem *mem, GQSPI_IER_RXEMPTY_MASK); } } - if (!wait_for_completion_interruptible_timeout + if (!wait_for_completion_timeout (&xqspi->data_completion, msecs_to_jiffies(1000))) err = -ETIMEDOUT; } -- 2.30.2