Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp3969232ybv; Tue, 25 Feb 2020 10:36:13 -0800 (PST) X-Google-Smtp-Source: APXvYqzLIL5YDnzclYryg18eE1R2UaY0lCS6C6WxK2XCt3qe7xGKFKRSk/CIfC/VzH4VDEaQ7zGy X-Received: by 2002:aca:2114:: with SMTP id 20mr229565oiz.9.1582655773626; Tue, 25 Feb 2020 10:36:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582655773; cv=none; d=google.com; s=arc-20160816; b=u2Gry7zSP1wyaOaBHGU7I9T+CIFN6ro6vUGq8SyweMkR1cphy8DY0WXhM0SlOBfikd WpJI5/2wDyZImM1mUWk1TBORrgV8l98epJpRVTnqY/sNGThr+jXnuZP/0GJWFYwjaBhy ZCu8xkQ/LwRNEspgOhFV+esm3DN+RpVtfDIPkm3E878q/5Aft6ArQpSyO2zc+HXVTjoq +GvFp52d/6SwmMrd9fOK6ni5gILEwWn21WPWw9yVu2JUOh+UEwLXtlu+d75T7ajYJxVN ieZ+SGmb43ULL1q2sgg1BfaF21UlDPZ7wmMe1dofakP46YPdTQTic3malMJLgk7nGVHA Rjxg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=awGXHjJ6lx/JMyhLODfcHSCIeeZ1sLXsOBCrCw9XT5M=; b=GOy3DGs4Rh/H4RVEbJvEjvpWIzHIZE2NJtxwbQMrB70aqyMuU7WJW1qjdJsStBeX6E VggpOY/G22XkyrgG3ckI+prv9wSXYffvFXdrTk8vO3kSG+BD6U2g9Y/Jb/ODaOeUm0QJ az5Bc7DPfTVQVmZpf9hx2gCcd8PkVj2HW5GgAj4FsBOfvgwULgcm3mmvLUqjyMtbCnbo uDCQHm+Aa58k2wZhRgfvwN4pLwkHA96Y1dCZ2Vg30XMt+i5AK0spSSjH7U/Ik+sdxRd9 IGUfPcIzWTb3Cnb7Acv+C2hGD+OTTH4KdolWfZRuLbEpm5/CFHyLSt53eGwQG27Hz/Iu 7ULg== ARC-Authentication-Results: i=1; mx.google.com; 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 i13si18294otc.228.2020.02.25.10.36.00; Tue, 25 Feb 2020 10:36:13 -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; 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 S1731569AbgBYSfo (ORCPT + 99 others); Tue, 25 Feb 2020 13:35:44 -0500 Received: from lists.gateworks.com ([108.161.130.12]:33873 "EHLO lists.gateworks.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727983AbgBYSfo (ORCPT ); Tue, 25 Feb 2020 13:35:44 -0500 Received: from 68-189-91-139.static.snlo.ca.charter.com ([68.189.91.139] helo=tharvey.pdc.gateworks.com) by lists.gateworks.com with esmtp (Exim 4.82) (envelope-from ) id 1j6f4T-0007kM-P9; Tue, 25 Feb 2020 18:36:41 +0000 From: Tim Harvey To: linux-kernel@vger.kernel.org, linux-can@vger.kernel.org, Wolfgang Grandegger , Marc Kleine-Budde Cc: =?UTF-8?q?Timo=20Schl=C3=BC=C3=9Fler?= , Andy Shevchenko , Tim Harvey Subject: [PATCH] can: mcp251x: convert to half-duplex SPI Date: Tue, 25 Feb 2020 10:35:34 -0800 Message-Id: <1582655734-20890-1-git-send-email-tharvey@gateworks.com> X-Mailer: git-send-email 2.7.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some SPI host controllers such as the Cavium Thunder do not support full-duplex SPI. Using half-duplex transfers allows the driver to work with those host controllers. Signed-off-by: Tim Harvey --- drivers/net/can/spi/mcp251x.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/drivers/net/can/spi/mcp251x.c b/drivers/net/can/spi/mcp251x.c index 5009ff2..840c31c 100644 --- a/drivers/net/can/spi/mcp251x.c +++ b/drivers/net/can/spi/mcp251x.c @@ -290,23 +290,23 @@ static u8 mcp251x_read_reg(struct spi_device *spi, u8 reg) priv->spi_tx_buf[0] = INSTRUCTION_READ; priv->spi_tx_buf[1] = reg; - mcp251x_spi_trans(spi, 3); - val = priv->spi_rx_buf[2]; + spi_write_then_read(spi, priv->spi_tx_buf, 2, &val, 1); return val; } static void mcp251x_read_2regs(struct spi_device *spi, u8 reg, u8 *v1, u8 *v2) { + u8 val[4] = {0}; struct mcp251x_priv *priv = spi_get_drvdata(spi); priv->spi_tx_buf[0] = INSTRUCTION_READ; priv->spi_tx_buf[1] = reg; - mcp251x_spi_trans(spi, 4); + spi_write_then_read(spi, priv->spi_tx_buf, 2, val, 2); - *v1 = priv->spi_rx_buf[2]; - *v2 = priv->spi_rx_buf[3]; + *v1 = val[0]; + *v2 = val[1]; } static void mcp251x_write_reg(struct spi_device *spi, u8 reg, u8 val) -- 2.7.4