Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp5376346ybv; Tue, 11 Feb 2020 14:37:27 -0800 (PST) X-Google-Smtp-Source: APXvYqzXMrIO/JrLZKkRat9bAx4hBAsHkLhBK9mutdjPlxjbx+J8o2y0qwvfgN0cjUIOMhLDSqJt X-Received: by 2002:a05:6830:18ce:: with SMTP id v14mr6780716ote.36.1581460647024; Tue, 11 Feb 2020 14:37:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581460647; cv=none; d=google.com; s=arc-20160816; b=yrt/rkTdbR7M9IjhFCgizSr7emDPrDLBALRP0xP7wNyOa2HhlhF9E/mgP/lD7V8c4Y iyPjuWfRh+mvqPf4sw6UzkZqiBk4INwTYlaL5ZKFZuSnWAWqqAQ7TwmJPkzsfBkIwvwM 1D2Y2R+avA7B7SRbKepjBQLY/2EAOzUPbdu7zUdjGfvcUdaqmmDOrU0bsBu1Hxi+4Jdt 4acnI4xONIPOugp/KJBSuyAxRWTF3OAMQ65pp0GDggZJHL9qK/hrONj22awaNhnLIZdf rwLRBlrOKRstQ1wXxRiV38ahseOvoEx6ekiZC5LqNZUIJPm6odTrzUIAkrA6ngXGowTG PTnA== 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=tn5KLhV2UflAg8SWktUj0z7+eGphwmGyKjf8wzfFF6c=; b=TtPaUG2b4JNfeiTAI5triQDsvS6XoDB78L/RQz+HE1/iJzCDE5JTOKm+6vw7LLTSVM y7q7rIGlk+VzGY+JLGlxIKm1hF7JGAWBqWJ672yU7q3xxRTLDd+2RDhVQK26oiFi+sLB YPj6uiTsoTsJFBJWXpaEbUbBt5f5LAUrUxJ/nOuOz+0q0pvsMn/gOGRDmv7JkAp3TSwh 0Jxq+ocosIhpHLtAWQQN6iuZujXfbz5ten+aKogy1eE8iLz9l2g1dF7rQ/v7SdVGbHZS JbRQRRMwwWpmDg7n/TqFjCm5fjmzXyKdt362Wopb2jzfbg+1dE19CNbQ+8nlTH1GFLbZ Jf0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=urSRtZif; 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 z20si2091149oib.26.2020.02.11.14.37.14; Tue, 11 Feb 2020 14:37:27 -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=urSRtZif; 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 S1727429AbgBKWhG (ORCPT + 99 others); Tue, 11 Feb 2020 17:37:06 -0500 Received: from mail-ua1-f74.google.com ([209.85.222.74]:42011 "EHLO mail-ua1-f74.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727041AbgBKWhF (ORCPT ); Tue, 11 Feb 2020 17:37:05 -0500 Received: by mail-ua1-f74.google.com with SMTP id p15so38303uao.9 for ; Tue, 11 Feb 2020 14:37:05 -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=tn5KLhV2UflAg8SWktUj0z7+eGphwmGyKjf8wzfFF6c=; b=urSRtZifT/QzvZKFDFC7/ZnQJbkvRzX80g/fbmNyhIMIZj/8ubezc0r7GhuCo3gyv2 5ww+otf5kKowLgPCCt/07eDrHteSifb/OmAcx9VEH+SCpMf4mazjoPz8mIyQDDp9xC2W OmllTh9rDMxYl40+vl9RFvRlxrztbrK27yD4zEun0wkFGcnBmxp34adEaVDFaA0SvSTD rPgT9lIp3j/H/DOH9dz+6/gxhd0q2AaqM5u3r1s1UOK3E9YzIz3y+p+At9GTNI+X7PUl DJSJfY+VIAAsd6sDTaA3U2UpygMsRQuGNH81kkq4Lkp/Eu+SK+PtWsex4eRPzgJztDyp PxxA== 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=tn5KLhV2UflAg8SWktUj0z7+eGphwmGyKjf8wzfFF6c=; b=hfQXeYp3UFTVOYj3ZmQwfx+kRfK2fe51enWYzY26ffDSql/bYlg6ND3pmzKxMqCpHw 5ghsZdQ6pgRNsWJ5omLjvObkvRxC+1Kn8ptLCVNuTNfqUZwbXMRw11uYL+YFI4/HyXOJ c4gLPGV/Dh8fKMT21xddcnxDIWd8SWLJPJ/1AQw5pSjHc9XtWiT55itOE/RRc/md2BpW 1kyj4LcPmhZh7pagEjSCu/wAy09pGFJLmzcCjwOgtLgkVqg2zLAeN8qEIWJ/uSYf+edx R5WABeYGMUrxuLhP1emzTNr03rNDnSD/QjUJ/nabyy3PuoOzgU642HVtEDA8D0LfRWRP 36WQ== X-Gm-Message-State: APjAAAUD0xwTCAG0BPtLclYwC6Xfu5fvLSEgjsRNF7BtPZcN9+pyS3aF enm4dRTeWze9s5Na0aT8hHnrh0wvn1ZN X-Received: by 2002:ab0:6902:: with SMTP id b2mr5251519uas.32.1581460624477; Tue, 11 Feb 2020 14:37:04 -0800 (PST) Date: Tue, 11 Feb 2020 14:37:00 -0800 Message-Id: <20200211223700.110252-1-rajatja@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.25.0.225.g125e21ebc7-goog Subject: [PATCH] spi: pxa2xx: Add CS control clock quirk 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 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