Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3534550imu; Mon, 7 Jan 2019 05:14:07 -0800 (PST) X-Google-Smtp-Source: ALg8bN42NOsssY6/H4KxXLSoaGUMzdkYDqpp1oboQd2QS+Smoko4Kv7SovEqdYfxZIDDPl2zNhgh X-Received: by 2002:a17:902:7588:: with SMTP id j8mr61884622pll.215.1546866847127; Mon, 07 Jan 2019 05:14:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546866847; cv=none; d=google.com; s=arc-20160816; b=HieZFm4z5DWqMy7Uc6GTw478jJqXfxth7TLXq7kB6CIKEaiTRMVJIPICAXSiNm0ilc TTXD1KrRsXM1pZXAIU/BIDKUIzeuSe+gUkmJq/tzGtzDMkPFWXZmryR+TA3N/6sDSgnx D/NPsCwFpK0Y0PWtzNbHrm5XPy1tYOt/8nH/dslEPC2NuqzcjxPqSkR4EnWrsMpgQZSQ yrNlwlU9loKrIzt431HbZ68D1N9yl43xCxiTNHHRFOME4BMJwUuUrjV6Gb4SkHJWFf8x HkR/gb0dLM6Dolb0Tb1lJllVEVYJIre12UxBo0arjir/3/X8dr6Dx1+rSsXt3ddCCXdK ktQA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=XrxnAyCpOVji3+cF/s4z1+lNScJA8z4b6O7hvZEH+v4=; b=vGsk99If08fkDvLEfBV87CTqIVpUVTMbxnSbdy9WXbQYrTYDX72AYEinNH0/grFdZr 7vWW08YWt50lRXlMSu+7KudN0uHVWVRS8045xpFHRLfQ922MyY/khv3060PagZYC32OV CxRPmPc5EVyKUzD0Ky33Pl/nsnsfc+evFzy9UolmVegOzx8PPTHjXDaE6ubG37FlgYD5 p3F0UXKY2QGPSj0h/77LsHOMLuuWYUvclH04cMqG5r12ickyVP25NqxqLBYJyvJwYyIy v9zxsLTbu4C9CVP53Y5lq109SU0QVryAMha7VjO5/TLAGVm1xMreJDho7jX4UlNsxfid jBdw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=AtbjvUPK; 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 128si41660062pfe.4.2019.01.07.05.13.52; Mon, 07 Jan 2019 05:14:07 -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=@kernel.org header.s=default header.b=AtbjvUPK; 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 S1731674AbfAGNIc (ORCPT + 99 others); Mon, 7 Jan 2019 08:08:32 -0500 Received: from mail.kernel.org ([198.145.29.99]:55598 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731653AbfAGNIb (ORCPT ); Mon, 7 Jan 2019 08:08:31 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id F24022089F; Mon, 7 Jan 2019 13:08:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1546866510; bh=AfMYJoITpWioCihJBpIQ8MpgL7fSMrdm/I+waEBAW1s=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=AtbjvUPKb8nYbypOhjPsgPzwk+7Xf8U6F8XyDalh4i6k0cQ8flVAT8kRpoZkgQT+D Knbkmre4lsQeXCchkM2BCQ6cgyIj1u6ifl5vbiQukazk9a5RFujH7u7CPPi6lSgRxI N9qUdKYJ6pTb1wqK3l2oYuY9DszC4JkioXZSM3wU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lukas Wunner , Mathias Duckeck , Frank Pavlic , Martin Sperl , =?UTF-8?q?Noralf=20Tr=C3=B8nnes?= , Mark Brown Subject: [PATCH 4.9 54/71] spi: bcm2835: Avoid finishing transfer prematurely in IRQ mode Date: Mon, 7 Jan 2019 13:33:23 +0100 Message-Id: <20190107105335.821695797@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190107105330.280153213@linuxfoundation.org> References: <20190107105330.280153213@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.9-stable review patch. If anyone has any objections, please let me know. ------------------ From: Lukas Wunner commit 56c1723426d3cfd4723bfbfce531d7b38bae6266 upstream. The IRQ handler bcm2835_spi_interrupt() first reads as much as possible from the RX FIFO, then writes as much as possible to the TX FIFO. Afterwards it decides whether the transfer is finished by checking if the TX FIFO is empty. If very few bytes were written to the TX FIFO, they may already have been transmitted by the time the FIFO's emptiness is checked. As a result, the transfer will be declared finished and the chip will be reset without reading the corresponding received bytes from the RX FIFO. The odds of this happening increase with a high clock frequency (such that the TX FIFO drains quickly) and either passing "threadirqs" on the command line or enabling CONFIG_PREEMPT_RT_BASE (such that the IRQ handler may be preempted between filling the TX FIFO and checking its emptiness). Fix by instead checking whether rx_len has reached zero, which means that the transfer has been received in full. This is also more efficient as it avoids one bus read access per interrupt. Note that bcm2835_spi_transfer_one_poll() likewise uses rx_len to determine whether the transfer has finished. Signed-off-by: Lukas Wunner Fixes: e34ff011c70e ("spi: bcm2835: move to the transfer_one driver model") Cc: stable@vger.kernel.org # v4.1+ Cc: Mathias Duckeck Cc: Frank Pavlic Cc: Martin Sperl Cc: Noralf Trønnes Signed-off-by: Mark Brown Signed-off-by: Greg Kroah-Hartman --- drivers/spi/spi-bcm2835.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) --- a/drivers/spi/spi-bcm2835.c +++ b/drivers/spi/spi-bcm2835.c @@ -155,8 +155,7 @@ static irqreturn_t bcm2835_spi_interrupt /* Write as many bytes as possible to FIFO */ bcm2835_wr_fifo(bs); - /* based on flags decide if we can finish the transfer */ - if (bcm2835_rd(bs, BCM2835_SPI_CS) & BCM2835_SPI_CS_DONE) { + if (!bs->rx_len) { /* Transfer complete - reset SPI HW */ bcm2835_spi_reset_hw(master); /* wake up the framework */