Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp4741225ybv; Wed, 26 Feb 2020 02:19:57 -0800 (PST) X-Google-Smtp-Source: APXvYqxA6YHj7v9n4k3NESvtS/OMs+MuPXA9IqSbwKuRXrQcid0oJ2OHJ56P2TORwBQIGI9kQafa X-Received: by 2002:a05:6830:2157:: with SMTP id r23mr2241368otd.57.1582712397788; Wed, 26 Feb 2020 02:19:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582712397; cv=none; d=google.com; s=arc-20160816; b=RmdVG518Url5Rrest6h1zALLWe0Ndrs03REyXnK0viwcU0T3lq40NE61TJL6Nx02bY a63FynHqaqvpQn+yWY0X+FoMruQ54kODv7NfYE9iyq8O024jQFWu6dOfOZbYWB6W9XFO gLzeXZlS1707/QOZIYpygYic9CYjWHscxmHLmpkHEC0QgJqrJBeq0p7H+5EQCI1TCLKA HNvpSF4I97rtbuP6BNRcclyeg7q83esr2BUY/b1ZfNsw94Ssz/hO+FRkBTGDNes/NGt0 7AW7ir1MWmS0MEPhdbddUm/iRqC9AuDdBfF/7E4Zal7o/VLiid2Vr3v7mWFZ6Tp/Q7lg nSjA== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:autocrypt:openpgp:references:cc:to:from:subject; bh=XxwxnyouEmtM5cB71N5azachKjjg4suexS0RlCNds1k=; b=hNqPk/W9Wlt9GSid24I2tswpNWRCNB16yT+fG0E8KdT4XiSCx/PykwqpefKs7768NK XFlosS6NhJYxPRqOGgymdcmIFppSBgk4cUX7ImkD+mWydq2YsUOYmuBBr58L9ejzYnMS F5OqNgDcJ5AML2Jl+djjJMjVvmm6qfdDMqyq2tpMuO38/BJ2yMe8+k9qll9d4mp4Oalb ikjxp1PnpFaSRIzHC5EjcjJgWV1V9FELp0Y9dShLp7YGMLN2QwfiWW+9quFDdea1dNtb XfEWKNW1hKS4kW/rP0zu403DGGKXrS9GKS9QSzb1/u7JdKpzxU7NVdjxfWbfk7BSby/3 0jHg== 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 m5si872134oie.240.2020.02.26.02.19.43; Wed, 26 Feb 2020 02:19:57 -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 S1727359AbgBZKTf (ORCPT + 99 others); Wed, 26 Feb 2020 05:19:35 -0500 Received: from metis.ext.pengutronix.de ([85.220.165.71]:39443 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726057AbgBZKTf (ORCPT ); Wed, 26 Feb 2020 05:19:35 -0500 Received: from gallifrey.ext.pengutronix.de ([2001:67c:670:201:5054:ff:fe8d:eefb] helo=bjornoya.blackshift.org) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1j6tmt-0005IF-5H; Wed, 26 Feb 2020 11:19:31 +0100 Received: from [IPv6:2a03:f580:87bc:d400:6ccf:3365:1a9c:55ad] (unknown [IPv6:2a03:f580:87bc:d400:6ccf:3365:1a9c:55ad]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-384) server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mkl@blackshift.org", Issuer "StartCom Class 1 Client CA" (not verified)) (Authenticated sender: mkl@blackshift.org) by smtp.blackshift.org (Postfix) with ESMTPSA id A34594C10C3; Wed, 26 Feb 2020 10:19:29 +0000 (UTC) Subject: Re: [PATCH] can: mcp251x: convert to half-duplex SPI From: Marc Kleine-Budde To: Tim Harvey Cc: open list , linux-can@vger.kernel.org, Wolfgang Grandegger , =?UTF-8?Q?Timo_Schl=c3=bc=c3=9fler?= , Andy Shevchenko References: <1582655734-20890-1-git-send-email-tharvey@gateworks.com> <0ac77abd-0df5-e437-ea46-f6c77f59b81c@pengutronix.de> <0b351fe3-8fe9-572f-fd85-e2aed22873e3@pengutronix.de> Openpgp: preference=signencrypt Autocrypt: addr=mkl@pengutronix.de; prefer-encrypt=mutual; keydata= mQINBFFVq30BEACtnSvtXHoeHJxG6nRULcvlkW6RuNwHKmrqoksispp43X8+nwqIFYgb8UaX zu8T6kZP2wEIpM9RjEL3jdBjZNCsjSS6x1qzpc2+2ivjdiJsqeaagIgvy2JWy7vUa4/PyGfx QyUeXOxdj59DvLwAx8I6hOgeHx2X/ntKAMUxwawYfPZpP3gwTNKc27dJWSomOLgp+gbmOmgc 6U5KwhAxPTEb3CsT5RicsC+uQQFumdl5I6XS+pbeXZndXwnj5t84M+HEj7RN6bUfV2WZO/AB Xt5+qFkC/AVUcj/dcHvZwQJlGeZxoi4veCoOT2MYqfR0ax1MmN+LVRvKm29oSyD4Ts/97cbs XsZDRxnEG3z/7Winiv0ZanclA7v7CQwrzsbpCv+oj+zokGuKasofzKdpywkjAfSE1zTyF+8K nxBAmzwEqeQ3iKqBc3AcCseqSPX53mPqmwvNVS2GqBpnOfY7Mxr1AEmxdEcRYbhG6Xdn+ACq Dq0Db3A++3PhMSaOu125uIAIwMXRJIzCXYSqXo8NIeo9tobk0C/9w3fUfMTrBDtSviLHqlp8 eQEP8+TDSmRP/CwmFHv36jd+XGmBHzW5I7qw0OORRwNFYBeEuiOIgxAfjjbLGHh9SRwEqXAL kw+WVTwh0MN1k7I9/CDVlGvc3yIKS0sA+wudYiselXzgLuP5cQARAQABtCZNYXJjIEtsZWlu ZS1CdWRkZSA8bWtsQHBlbmd1dHJvbml4LmRlPokCVAQTAQoAPgIbAwIeAQIXgAULCQgHAwUV CgkICwUWAgMBABYhBMFAC6CzmJ5vvH1bXCte4hHFiupUBQJcUsSbBQkM366zAAoJECte4hHF iupUgkAP/2RdxKPZ3GMqag33jKwKAbn/fRqAFWqUH9TCsRH3h6+/uEPnZdzhkL4a9p/6OeJn Z6NXqgsyRAOTZsSFcwlfxLNHVxBWm8pMwrBecdt4lzrjSt/3ws2GqxPsmza1Gs61lEdYvLST Ix2vPbB4FAfE0kizKAjRZzlwOyuHOr2ilujDsKTpFtd8lV1nBNNn6HBIBR5ShvJnwyUdzuby tOsSt7qJEvF1x3y49bHCy3uy+MmYuoEyG6zo9udUzhVsKe3hHYC2kfB16ZOBjFC3lH2U5An+ yQYIIPZrSWXUeKjeMaKGvbg6W9Oi4XEtrwpzUGhbewxCZZCIrzAH2hz0dUhacxB201Y/faY6 BdTS75SPs+zjTYo8yE9Y9eG7x/lB60nQjJiZVNvZ88QDfVuLl/heuIq+fyNajBbqbtBT5CWf mOP4Dh4xjm3Vwlz8imWW/drEVJZJrPYqv0HdPbY8jVMpqoe5jDloyVn3prfLdXSbKPexlJaW 5tnPd4lj8rqOFShRnLFCibpeHWIumqrIqIkiRA9kFW3XMgtU6JkIrQzhJb6Tc6mZg2wuYW0d Wo2qvdziMgPkMFiWJpsxM9xPk9BBVwR+uojNq5LzdCsXQ2seG0dhaOTaaIDWVS8U/V8Nqjrl 6bGG2quo5YzJuXKjtKjZ4R6k762pHJ3tnzI/jnlc1sXz Message-ID: <7b85e098-b9a9-dd14-203f-100cdf2e703e@pengutronix.de> Date: Wed, 26 Feb 2020 11:19:26 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: <0b351fe3-8fe9-572f-fd85-e2aed22873e3@pengutronix.de> Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2001:67c:670:201:5054:ff:fe8d:eefb X-SA-Exim-Mail-From: mkl@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2/26/20 8:37 AM, Marc Kleine-Budde wrote: >> Your right... there is the mcp251x_hw_rx_frame() call that also uses >> spi_rx_buf after a synchronous transfer (I didn't see any others). >> I'll look at this again. > > Have you hardware to test your changes? I think the SPI framework would > return an -EINVAL in that case....though the return value is sometimes > not checked by the driver :/ See https://elixir.bootlin.com/linux/v5.5.6/source/drivers/spi/spi.c#L3413 If you have really have HW with SPI_CONTROLLER_HALF_DUPLEX (a.k.a SPI_MASTER_HALF_DUPLEX) restrictions, you need to convert _every_ mcp251x_spi_trans() call in the driver, as _always_ both rx_buf _and_ tx_buf are used. Marc -- Pengutronix e.K. | Marc Kleine-Budde | Embedded Linux | https://www.pengutronix.de | Vertretung West/Dortmund | Phone: +49-231-2826-924 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |