Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3724277imu; Mon, 7 Jan 2019 08:19:58 -0800 (PST) X-Google-Smtp-Source: ALg8bN4bHVQbY0y9xGAz6mOwucqb7yw2vZqsq3i4TwxhipOIPpS9O5/Fqp5mDTdb1g/CMSpZ7wSi X-Received: by 2002:a63:5026:: with SMTP id e38mr11538283pgb.123.1546877998407; Mon, 07 Jan 2019 08:19:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546877998; cv=none; d=google.com; s=arc-20160816; b=jK0nVmvktATRaOwN8NwM2DS08CUrWVXowgfFX9bmjmUPWCdNNINvjLHPkW7h0H975v LF7lU9iQaGDFDHcihG7bbLLKd74fYpcLuADl8fw5WUrzr9afDwWWUK7Lmue3vjX0h4hW DQWZ3qTuwnnMqXAUC2c/ijzRdvoxurA1ccV1+B5SCizOVugbyAGKzqPKRoslXjTEO7XL wYMKNbYGNbiLvf7+MAW1TDo+6081g15i3xOLPXG9y0H6JV0DL548lUAYbYMtG95BYv3t TiqxZDn3quxnAs1BEa5Vl1XsoLbz5XDSIQMKXqZ+d/EWleDij/qrYrLnDICOH1x++DhS 1HYQ== 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=Q+NUL6q4KIRNGfQ3G2aNN0169bl/FBCH+rM6/ViFx1M=; b=dt9PFluskHldw9IiSiATkWeX5vbp9bKiR1q8pixesYjuYtdOgz0O/gkoRB2yM5i7qj k9lAmhwEBKL7XpGCw9r8YGXhWWxbKVFVgBsykq+BlSlnf2YAW3UlS3uhPbrTnDW9EsSz Sm8Uyn1ZWU7PDtjFBuSE0/iy27oghXqPq8VW34co77IiuFgvq9kjgOMFCjiH63Jue4vV fft5mDj0Jsq/Pd+Q+Nvtulqh3KoHEh/53mtE15/08BRFwJiaf+LaPln6xL4NaOL53zZF u40L7Oe2r7VoAJMErTxv4XB0g/UAg/WXfY+fz6wRsUvla4q6e0avyZ/FSeD3T4Q70vH7 RQFQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=DhF7rpBO; 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 g31si46752141pld.358.2019.01.07.08.19.42; Mon, 07 Jan 2019 08:19:58 -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=DhF7rpBO; 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 S1730924AbfAGNDC (ORCPT + 99 others); Mon, 7 Jan 2019 08:03:02 -0500 Received: from mail.kernel.org ([198.145.29.99]:50516 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730907AbfAGNDB (ORCPT ); Mon, 7 Jan 2019 08:03:01 -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 EA6EA217D4; Mon, 7 Jan 2019 13:02:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1546866180; bh=ldRUUl9d/Gf3DHkuSQEmlQIgIqfemy+Glo2o4zzylTo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DhF7rpBO75qPYdkAtVreRpF3oRdx12BbyqX9Xe/D3lxVed/h7IbTWc5umHOHGyBDJ XlA5GUuPkuePQuAzaqFT8sIEhkMO1sc+9BqjiQFn9SlHmRo0F8sSa5aQf3ZGiDBcBC Jv/84bx0TrgqmjacTTum+HUntbCgpD/Wk68Z9rPA= 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.14 071/101] spi: bcm2835: Avoid finishing transfer prematurely in IRQ mode Date: Mon, 7 Jan 2019 13:32:59 +0100 Message-Id: <20190107105336.872263253@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190107105330.372621917@linuxfoundation.org> References: <20190107105330.372621917@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.14-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 */