Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4672551pxj; Wed, 12 May 2021 10:33:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw8mJkavZBsg3DVfbyE1Kmi8MgTG5jS6w6susR9Kp1BhNS2ZuBQx1wSINd7s4HUBVvxAVc4 X-Received: by 2002:a05:6830:40a4:: with SMTP id x36mr28346511ott.342.1620840803287; Wed, 12 May 2021 10:33:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620840803; cv=none; d=google.com; s=arc-20160816; b=QNhVlmt2EimPKQCpaCZo8ucFt1i8PFYkCBIM31MPP95/LOh3tzfn9+JRZjzlzJzuua cGwjYGycQvKs/R9I15rL7fE2CQGnwlXO04APLOmOnev8Co9l1suN6KXSiWbEEccdK34H jFNCbAhUHj9TXwziNAskLf7hd3IvoRcL0WPxxUnOAmCS8OmeHFvY1avkli3iq435JcXb BL+PZGuU1Xmw68YdVIPVo6CXmdFuYTG6wP6IJzVL5S3h1bN2VcnkiX/c4aOgsvvkTnaR g1lgD4ps+3GdeKMm/fcEakOt6bCral1hF+a+Uhv0Co6l2kWJWAGVbjM2AEw4CEaTG1DD g6pQ== 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=QP28rQxTZvNHaChye4xyeeRLSlkf+IhYva4AzVn7xdUqRdQCNeTHNdT/XNSdToiGp3 kRWOee6/8dLRAGaJaVX0XloR918feIPzCPSB8yU5WBJ0TfcmZWJILttFWdE5hFIWn9II XmL8U4CqEmKu7AYJEviYdABR8ZLngKc60050ELURc7bcooezy/qZzVxTIVcPUa8AXRyo SJHR1FcJOytoZsXjh3xBX+JcsCtWJFKJwlqj/8QMjeX6TIecm3BcaJqyHnL2VEjor65p wY98Vt2LL9x08TAg6Xpyviks+Q271Okro+o/7oAT51pqvDTRuK3pp3sgv6XfioK15ll2 ZBVw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=pbY+XoQX; 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 l10si289892otn.155.2021.05.12.10.33.09; Wed, 12 May 2021 10:33:23 -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=pbY+XoQX; 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 S1346835AbhELRVq (ORCPT + 99 others); Wed, 12 May 2021 13:21:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:34346 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239004AbhELQHB (ORCPT ); Wed, 12 May 2021 12:07:01 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 6311361D05; Wed, 12 May 2021 15:35:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620833734; bh=3ko12gNx5sd+b+RuP/0bkyRe5JZE8HzT8Tp0etjgp3Q=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=pbY+XoQXvPeKAzTjZtF+F7c+41MjlAMt5D/I3w/woOlXy/oKBIqA3oAV18sfI9nOB +zdh52FPgURR+ZNuWdpP5s4Vc02+Ic8n3vRKHIlW1neKaRkjjuGnUvd1y5ZI+4RwbX jbWlUSX68aBfZRYX32qmGROvrl7aTLdoRsc/KNaA= 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.11 268/601] spi: spi-zynqmp-gqspi: use wait_for_completion_timeout to make zynqmp_qspi_exec_op not interruptible Date: Wed, 12 May 2021 16:45:45 +0200 Message-Id: <20210512144836.639370174@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144827.811958675@linuxfoundation.org> References: <20210512144827.811958675@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