Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp946714ybz; Wed, 29 Apr 2020 12:13:04 -0700 (PDT) X-Google-Smtp-Source: APiQypI2TJ0/WbLsMXdTi2mrwztn2S7R+hwaPoiOmcapgcKA07IxuNsTxmHvNcWUmaEfAlb1n6J+ X-Received: by 2002:a50:d0d5:: with SMTP id g21mr4073178edf.92.1588187584526; Wed, 29 Apr 2020 12:13:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588187584; cv=none; d=google.com; s=arc-20160816; b=M3MeJg7EBkC6xIvMKwLa0P7soUPiRi7ywfT/F+qVIxoPLFAaq/9BPXJMBZRJSFRGke IkjzyVGTUSX2Sl9si75idPiODVsx+2mvstYV/1bl4zKO4z2f8hLTXTYFkaf3HuSgQxK8 3yZmggNDjTnoVgQI6B9AdcwP9rFUbNA2oVFBORJXuPHks39Vpt11TH52A3tpAP1+MQbM pkftrGt5A/kP4XJIR3cHH6wj8eMnfEc29I1BvponWv+0nHPYYZQJd0M5YxsgeTH6H3j7 LgnzOCQavNL2/rlfsuuBt2FjC45IfPsDpFRcSd00Oo6JFhPtI+Yz6TxoUQk/qkp31V2c PV6g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:in-reply-to :subject:cc:to:from:date; bh=KYMnSHFUkJpZh6MYmraMYTtzbuQGvurRiWb/eSUgN/I=; b=o2XABkXGFCcY4oGk7GpqzqKD1Js/iYIIAjGBC0MX8k5BvH2KEcQ4ZS7Fk0yls6IXtm ZkQemR06xzDWoEz45UMMiN+/x5PCA5vrnsj/ne8Rt8D6iAaMtXt8ycoLJk38dSbegc2C 1DLv5VWTqceu/3B45l9cwqQJ/dEkwg+yEvsTD4aJnJmaBDlX9iMPtMp8K2s7PCaLDDhJ xWjVSbJsGSQGSazbjG3yZHyAGb5+LrrsqXW7+V8cJe1jPNsiDQhkN9RlGkHqNnsvz8bi Oz2BSX7q4wByveGhtNQm+jyLnHE5wwDKQ+Zg9mSsHHmWCG2sVeOEYaPReXH2V3n3XXHl 3Ccg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i14si4307835edt.120.2020.04.29.12.12.39; Wed, 29 Apr 2020 12:13:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727103AbgD2TIt (ORCPT + 99 others); Wed, 29 Apr 2020 15:08:49 -0400 Received: from netrider.rowland.org ([192.131.102.5]:55585 "HELO netrider.rowland.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1726456AbgD2TIs (ORCPT ); Wed, 29 Apr 2020 15:08:48 -0400 Received: (qmail 19996 invoked by uid 500); 29 Apr 2020 15:08:47 -0400 Received: from localhost (sendmail-bs@127.0.0.1) by localhost with SMTP; 29 Apr 2020 15:08:47 -0400 Date: Wed, 29 Apr 2020 15:08:47 -0400 (EDT) From: Alan Stern X-X-Sender: stern@netrider.rowland.org To: Al Cooper cc: linux-kernel@vger.kernel.org, , , Greg Kroah-Hartman , Krzysztof Kozlowski , , Mathias Nyman , Rob Herring , Yoshihiro Shimoda , Andy Shevchenko Subject: Re: [PATCH v4 3/4] usb: ehci: Add new EHCI driver for Broadcom STB SoC's In-Reply-To: <20200429173112.38366-4-alcooperx@gmail.com> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 29 Apr 2020, Al Cooper wrote: > Add a new EHCI driver for Broadcom STB SoC's. A new EHCI driver > was created instead of adding support to the existing ehci platform > driver because of the code required to workaround bugs in the EHCI > controller. > > Signed-off-by: Al Cooper > --- ... > +static int __maybe_unused ehci_brcm_resume(struct device *dev) > +{ > + struct usb_hcd *hcd = dev_get_drvdata(dev); > + struct ehci_hcd *ehci = hcd_to_ehci(hcd); > + struct brcm_priv *priv = hcd_to_ehci_priv(hcd); > + int err; > + > + err = clk_prepare_enable(priv->clk); > + if (err) > + return err; > + /* > + * SWLINUX-1705: Avoid OUT packet underflows during high memory > + * bus usage > + * port_status[0x0f] = Broadcom-proprietary USB_EHCI_INSNREG00 > + * @ 0x90 > + */ > + ehci_writel(ehci, 0x00800040, &ehci->regs->port_status[0x10]); > + ehci_writel(ehci, 0x00000001, &ehci->regs->port_status[0x12]); > + > + ehci_resume(hcd, false); > + return 0; > +} One extra thing that came to my attention recently... Like all other platform drivers, this has to set the runtime PM status of the controller at the end of a system resume. See https://marc.info/?l=linux-usb&m=158773611612885&w=2 for an example. Alan Stern