Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp5374494ybv; Tue, 11 Feb 2020 14:34:48 -0800 (PST) X-Google-Smtp-Source: APXvYqwNjWlbHGi5yHwJpXHF2YwvEWtFkfha4A7/9dWj6Hga4i136UrnfpA/Epvyg2do8qxI/cws X-Received: by 2002:a9d:6c9a:: with SMTP id c26mr6684893otr.279.1581460488700; Tue, 11 Feb 2020 14:34:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581460488; cv=none; d=google.com; s=arc-20160816; b=f1aDwtEvfpesUZgMy+iARbZFUgJEzeatrS0of0d8BfvCFXhu/VoybiexZkPUNTZ2g9 Nv+XJyjVjxAcHGenOJvGLIlrQOieNsevc7mZGPYrR/qRxIyoHKBnDs/OOdSdPX3z/0bK Py01yPAIeJfHsukQZMzKPbA7NbvDJwRbfnC+viQ++aKSF5zAD221Hkw4bGLOYgCGhAt6 nul5eH4VRo87S9eY+T89NZkMSHXFMYkR6z0J4WrdYHBToxRsZEq8bahIePY7AInen7Ps 6gmSyD3NfDHwgGnVPV6jwqPMMraYZCOyZsojJPa68N8Pkea+BTpZQDfTcUN7Y2iiIBBp Tb2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:mime-version :message-id:date:dkim-signature; bh=tCp39nGmh6jfHffZt6h0GnEI2p4k3vAcc1eu6SXs2AA=; b=vBs40IlSKXDjZPcbr1JXdEl+aiw+chFDlLYiN/tB2H67EWR8MFRY/X+XJUmSQvwamg DJMQ1c30WAfq2Qe3LVoNsZL0LCducnFv3AxAcD445Cx39/H83DC2FE71X3Vpcp0D3qCf gqfEOuzYZJEXCc7YmNGuuPmA4FP8teRsOYeZmaURKu2uJkUK9n74uIXrYUzcdIHlyLLI ey6dlCRO20+Y5h0k52uZ0c6rbEJVId7ghihQELxxrQHl6htBP2wzCeL2YsRvsMsxWUXL hOgb4PnEGRCBk97s6iQdUTjdnz2ty1m22ID9rkqvu0rsR2wElsRAJFAchDSlWnanuB8j e5nw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=EZ9WVyoW; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a7si2624746otp.11.2020.02.11.14.34.35; Tue, 11 Feb 2020 14:34:48 -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=@google.com header.s=20161025 header.b=EZ9WVyoW; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727347AbgBKWe0 (ORCPT + 99 others); Tue, 11 Feb 2020 17:34:26 -0500 Received: from mail-pl1-f202.google.com ([209.85.214.202]:35806 "EHLO mail-pl1-f202.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727041AbgBKWe0 (ORCPT ); Tue, 11 Feb 2020 17:34:26 -0500 Received: by mail-pl1-f202.google.com with SMTP id v24so5363113plo.2 for ; Tue, 11 Feb 2020 14:34:25 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:message-id:mime-version:subject:from:to:cc; bh=tCp39nGmh6jfHffZt6h0GnEI2p4k3vAcc1eu6SXs2AA=; b=EZ9WVyoWLXE02i7Y/3ZJ4Tadn7u6Jh16ATWGwkj4iIcfHwD6Q5PrJgiyF1fLolo1kf G8+VB/3TXt0o6s5jORy1pmkNdIgEo2rudsmW28fXSpBvk2bDJXn5wor3+PopK+lhGOpT fGINzh3d/4wTeGBHoleb+loZ5Zvh1hNd5icRXHQJAlq3JL2gqYaiiK1gHegOUUBdr2H4 /M7q3pkkn3WrdTSSc51R32H1A0VnyC+yTWtXSOyHl3gB3BmUwN7q5a0Ta4lLoEMHgYDT ODjfkXMYEV9NwI0CJ/++R2ZzKrhzUtAMmPyX62TafJ0zLyLAjT5y37KT6uzcF1zN8T6+ EHKA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=tCp39nGmh6jfHffZt6h0GnEI2p4k3vAcc1eu6SXs2AA=; b=gWQckjET7fnFU9TT2muB36Hbm5qhD2Mnyiwmlo+8Tfvcgsb4PK6jT09NDdOnfF5Tmj WMm8wpKGLabz+FRbATq37Td9EbAp0RcUt2FDYipB/twF5slXCIOxdfEnCcbBMTb+JUAW O+5f4Ij49kUAar129Qd29NPDb5bZcSn+KxDB/GxKzW4djozu14RlmQchiUq90jIN2YY/ 5g8IJv0kTohQbnITMvjlwJ1W0eJekRlNFHeuCzP/48pbrX+u13Wd15JTfsFtXelp1eUK llx0GD2cTuijHpCjCcjhgzlyoWNgOp1tHUzx8R2WNY6Hud/DqBW9kp3IMrLxt/PZ1pTk 7rVQ== X-Gm-Message-State: APjAAAUIl++3i19EcpfozgMCGaB8tCBF/a7X4MCOnpI55UAOFlYFPR0P q0JrOrEgr00McK0cKFWat87iUcF9WwFb X-Received: by 2002:a63:2266:: with SMTP id t38mr9426357pgm.145.1581460465371; Tue, 11 Feb 2020 14:34:25 -0800 (PST) Date: Tue, 11 Feb 2020 14:34:00 -0800 Message-Id: <20200211223400.107604-1-rajatja@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.25.0.225.g125e21ebc7-goog Subject: From: Rajat Jain To: Daniel Mack , Haojian Zhuang , Robert Jarzmik , Mark Brown , linux-arm-kernel@lists.infradead.org, linux-spi@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Evan Green , rajatja@google.com, rajatxjain@gmail.com, evgreen@google.com, shobhit.srivastava@intel.com, porselvan.muthukrishnan@intel.com Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Evan Green Date: Wed, 29 Jan 2020 13:54:16 -0800 Subject: [PATCH] spi: pxa2xx: Add CS control clock quirk In some circumstances on Intel LPSS controllers, toggling the LPSS CS control register doesn't actually cause the CS line to toggle. This seems to be failure of dynamic clock gating that occurs after going through a suspend/resume transition, where the controller is sent through a reset transition. This ruins SPI transactions that either rely on delay_usecs, or toggle the CS line without sending data. Whenever CS is toggled, momentarily set the clock gating register to "Force On" to poke the controller into acting on CS. Signed-off-by: Evan Green Signed-off-by: Rajat Jain --- drivers/spi/spi-pxa2xx.c | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/drivers/spi/spi-pxa2xx.c b/drivers/spi/spi-pxa2xx.c index 4c7a71f0fb3e..2e318158fca9 100644 --- a/drivers/spi/spi-pxa2xx.c +++ b/drivers/spi/spi-pxa2xx.c @@ -70,6 +70,10 @@ MODULE_ALIAS("platform:pxa2xx-spi"); #define LPSS_CAPS_CS_EN_SHIFT 9 #define LPSS_CAPS_CS_EN_MASK (0xf << LPSS_CAPS_CS_EN_SHIFT) +#define LPSS_PRIV_CLOCK_GATE 0x38 +#define LPSS_PRIV_CLOCK_GATE_CLK_CTL_MASK 0x3 +#define LPSS_PRIV_CLOCK_GATE_CLK_CTL_FORCE_ON 0x3 + struct lpss_config { /* LPSS offset from drv_data->ioaddr */ unsigned offset; @@ -86,6 +90,8 @@ struct lpss_config { unsigned cs_sel_shift; unsigned cs_sel_mask; unsigned cs_num; + /* Quirks */ + unsigned cs_clk_stays_gated : 1; }; /* Keep these sorted with enum pxa_ssp_type */ @@ -156,6 +162,7 @@ static const struct lpss_config lpss_platforms[] = { .tx_threshold_hi = 56, .cs_sel_shift = 8, .cs_sel_mask = 3 << 8, + .cs_clk_stays_gated = true, }, }; @@ -383,6 +390,22 @@ static void lpss_ssp_cs_control(struct spi_device *spi, bool enable) else value |= LPSS_CS_CONTROL_CS_HIGH; __lpss_ssp_write_priv(drv_data, config->reg_cs_ctrl, value); + if (config->cs_clk_stays_gated) { + u32 clkgate; + + /* + * Changing CS alone when dynamic clock gating is on won't + * actually flip CS at that time. This ruins SPI transfers + * that specify delays, or have no data. Toggle the clock mode + * to force on briefly to poke the CS pin to move. + */ + clkgate = __lpss_ssp_read_priv(drv_data, LPSS_PRIV_CLOCK_GATE); + value = (clkgate & ~LPSS_PRIV_CLOCK_GATE_CLK_CTL_MASK) | + LPSS_PRIV_CLOCK_GATE_CLK_CTL_FORCE_ON; + + __lpss_ssp_write_priv(drv_data, LPSS_PRIV_CLOCK_GATE, value); + __lpss_ssp_write_priv(drv_data, LPSS_PRIV_CLOCK_GATE, clkgate); + } } static void cs_assert(struct spi_device *spi) -- 2.25.0.225.g125e21ebc7-goog