From patchwork Tue Jul 17 08:19:15 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Amit Pundir X-Patchwork-Id: 142119 Delivered-To: patch@linaro.org Received: by 2002:a2e:9754:0:0:0:0:0 with SMTP id f20-v6csp3369046ljj; Tue, 17 Jul 2018 01:19:34 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcZJh0gevPTs2T785M3buTr1CI5dsDwETPgOnJeJvItwQi1tF6bKLYiJfjU3N46eZ/JmW5m X-Received: by 2002:a63:5964:: with SMTP id j36-v6mr663659pgm.222.1531815574093; Tue, 17 Jul 2018 01:19:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531815574; cv=none; d=google.com; s=arc-20160816; b=zrVJ/TB1ECGno3JLAJNVsWvdiLCMOYu4QGMYKDRrhH3I0TMABjzp7JCxQIJMTtA9gT x2M6qJw1sf0oQlRY9x5KEKFfGDBRjwQFH1QLW7pFkYIu3MjNCb0MpfJOzT66CvReR/R4 IdVamRFURgV7xCixsVIOiQEZzES2txE9ERkFAEGXMWmxhs36MY50dbq15QnM2vvaX6FS 7kPVQHzs4SLZj2cKuwGm01hiKdLSHChRsBlWBHU1gyPxc4ppNwi+QBCUV4ObAdP/NpZF eJhHRiL5vI5TWtXLAiRnEVlWoTrtJM3c+h7tGgoz6g3lidDmqNvGRKK21LAMgGK08Z8m QJ6A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=8b+3EqX2oZIHwT/cEWUkKEK+RbYqm2NrXD+1TzXyh5M=; b=xmPdtipAtfV+FdyBuRryI/761gQac9VUSiLMczTRa0wPIBDY0bkPwH0oxbYHUF2l3b /9qqRoC8JNL1BeoVtKgQesbgWpBgu4SIZ8qzAxWGHv6e8QKx+pSyD6Eq84XM6OlINx6M EI8+DaTTs0uuwcXfkBztBL7sYjlKYozRcQiWxviP5Mj/HcnlXH8E1pmw2sxBYl3ifhKt aAd4i28pQ9Hp1h0sY1/oLHMnnZn2aDHOmDlECu9YXiEvlSw2jb0r553RUwO3Ad3BtBaK 6V8whqx+X0xiVo9wApHmpoPeNOFkzs1O4+5528RproZI5IyWkBYHGFXHD3E6s18/Z7KI 6haQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=diDEAlh6; spf=pass (google.com: best guess record for domain of stable-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=stable-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r65-v6si381493pfe.298.2018.07.17.01.19.33; Tue, 17 Jul 2018 01:19:34 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of stable-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=@linaro.org header.s=google header.b=diDEAlh6; spf=pass (google.com: best guess record for domain of stable-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=stable-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729720AbeGQIu5 (ORCPT + 13 others); Tue, 17 Jul 2018 04:50:57 -0400 Received: from mail-pf0-f196.google.com ([209.85.192.196]:46005 "EHLO mail-pf0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728843AbeGQIu5 (ORCPT ); Tue, 17 Jul 2018 04:50:57 -0400 Received: by mail-pf0-f196.google.com with SMTP id i26-v6so137584pfo.12 for ; Tue, 17 Jul 2018 01:19:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=8b+3EqX2oZIHwT/cEWUkKEK+RbYqm2NrXD+1TzXyh5M=; b=diDEAlh6sY5+LuSJD60Q/GkvflFxUwcIv72gU3/YxmGTg9SCDc8xH4Ir2fq2WfFGKs 8wFsVfP2DOWerR6igL4q5KSZueAvvYTLN0LZWnplPtGqq9/ggsIvniDBcyoP7zEdF8Do N28zGAkND51tSWYO23GwYqWamMjDXQc1/CAAg= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=8b+3EqX2oZIHwT/cEWUkKEK+RbYqm2NrXD+1TzXyh5M=; b=TUceNM/Hmq4oel2EScmK0Tdcis6Yxur+doqvrVBIrIaqbJJ45OCxSrdUIGkvMkMIy2 mfjs8zTzxnM5Ms4m4O057wFQOi/NHfLb+xOeRdBGCpDa2/HYfeDdmLoHKsH9d46D9kj2 DuZj+ncrnOzLnhiGvTkhR8aHNfjlWOpruEMlOM29e4H+V4rxH96+nqdz6IKM4aLfctuM N4RlXLaUJlQSz7wLTIzEMrZa2XKfyCqLEt5opNuJlU0BjxR2g61XuGWqiKQ8KfxXM0bN CNoJwgsLniz/AMi93HsayF0dir8+9DJu/JPxqbmiw/F0Pae6vz7etwtAhq3fRYf4miFB RN5g== X-Gm-Message-State: AOUpUlH90vfrXM0myu2Wy5FUFeqkOXGIENOBFPC+1+JwBx2i6vVywHY9 yxotsLFMkkNlqdKi+uBRO4NDrA== X-Received: by 2002:a62:5cc1:: with SMTP id q184-v6mr661910pfb.241.1531815571848; Tue, 17 Jul 2018 01:19:31 -0700 (PDT) Received: from localhost.localdomain ([106.51.22.240]) by smtp.gmail.com with ESMTPSA id z2-v6sm740263pgv.12.2018.07.17.01.19.28 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Tue, 17 Jul 2018 01:19:30 -0700 (PDT) From: Amit Pundir To: Greg KH , Stable Cc: Jonas Gorski , Mark Brown Subject: [PATCH for-4.9.y 2/5] spi/bcm63xx: make spi subsystem aware of message size limits Date: Tue, 17 Jul 2018 13:49:15 +0530 Message-Id: <1531815558-20002-3-git-send-email-amit.pundir@linaro.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1531815558-20002-1-git-send-email-amit.pundir@linaro.org> References: <1531815558-20002-1-git-send-email-amit.pundir@linaro.org> Sender: stable-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: stable@vger.kernel.org From: Jonas Gorski commit 0135c03df914f0481c61f097c78d37cece84f330 upstream. The bcm63xx SPI controller does not allow manual control of the CS lines and will toggle it automatically before and after sending data, so we are limited to messages that fit in the FIFO buffer. Since the CS lines aren't available as GPIOs either, we will need to make slave drivers aware of this limitation so they can handle them accordingly. Signed-off-by: Jonas Gorski Signed-off-by: Mark Brown Signed-off-by: Amit Pundir --- Cherry-picked from lede tree https://git.lede-project.org/?p=source.git drivers/spi/spi-bcm63xx.c | 9 +++++++++ 1 file changed, 9 insertions(+) -- 2.7.4 diff --git a/drivers/spi/spi-bcm63xx.c b/drivers/spi/spi-bcm63xx.c index fee747030ee6..caa733ec405c 100644 --- a/drivers/spi/spi-bcm63xx.c +++ b/drivers/spi/spi-bcm63xx.c @@ -428,6 +428,13 @@ static irqreturn_t bcm63xx_spi_interrupt(int irq, void *dev_id) return IRQ_HANDLED; } +static size_t bcm63xx_spi_max_length(struct spi_device *dev) +{ + struct bcm63xx_spi *bs = spi_master_get_devdata(spi->master); + + return bs->fifo_size; +} + static const unsigned long bcm6348_spi_reg_offsets[] = { [SPI_CMD] = SPI_6348_CMD, [SPI_INT_STATUS] = SPI_6348_INT_STATUS, @@ -541,6 +548,8 @@ static int bcm63xx_spi_probe(struct platform_device *pdev) master->transfer_one_message = bcm63xx_spi_transfer_one; master->mode_bits = MODEBITS; master->bits_per_word_mask = SPI_BPW_MASK(8); + master->max_transfer_size = bcm63xx_spi_max_length; + master->max_message_size = bcm63xx_spi_max_length; master->auto_runtime_pm = true; bs->msg_type_shift = bs->reg_offsets[SPI_MSG_TYPE_SHIFT]; bs->msg_ctl_width = bs->reg_offsets[SPI_MSG_CTL_WIDTH];