Re: [PATCH 3/3] usb: host: xhci-rcar: Add a condition check about PLL active

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Jul 3, 2018 at 12:46 PM, Yoshihiro Shimoda
<yoshihiro.shimoda.uh@xxxxxxxxxxx> wrote:
> This patch adds a condition check about the PLL acvice of this
> controller. Otherwise, the controller might cause hang when
> any USB clocks are not supplied yet and accesses the xHCI registers.
>
> Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@xxxxxxxxxxx>
> ---
>  drivers/usb/host/xhci-rcar.c | 26 ++++++++++++++++++++++++++
>  1 file changed, 26 insertions(+)
>
> diff --git a/drivers/usb/host/xhci-rcar.c b/drivers/usb/host/xhci-rcar.c
> index 4a22f25..a6e4637 100644
> --- a/drivers/usb/host/xhci-rcar.c
> +++ b/drivers/usb/host/xhci-rcar.c
> @@ -29,6 +29,7 @@
>  MODULE_FIRMWARE(XHCI_RCAR_FIRMWARE_NAME_V3);
>
>  /*** Register Offset ***/
> +#define RCAR_USB3_AXH_STA      0x104   /* AXI Host Control Status */
>  #define RCAR_USB3_INT_ENA      0x224   /* Interrupt Enable */
>  #define RCAR_USB3_DL_CTRL      0x250   /* FW Download Control & Status */
>  #define RCAR_USB3_FW_DATA0     0x258   /* FW Data0 */
> @@ -41,6 +42,12 @@
>  #define RCAR_USB3_TX_POL       0xab8   /* USB3.0 TX Polarity */
>
>  /*** Register Settings ***/
> +/* AXI Host Control Status */
> +#define RCAR_USB3_AXH_STA_B3_PLL_ACTIVE                0x00010000
> +#define RCAR_USB3_AXH_STA_B2_PLL_ACTIVE                0x00000001

Maybe use BIT() here?

> +#define RCAR_USB3_AXH_STA_PLL_ACTIVE_MASK (RCAR_USB3_AXH_STA_B3_PLL_ACTIVE | \
> +                                          RCAR_USB3_AXH_STA_B2_PLL_ACTIVE)
> +
>  /* Interrupt Enable */
>  #define RCAR_USB3_INT_XHC_ENA  0x00000001
>  #define RCAR_USB3_INT_PME_ENA  0x00000002
> @@ -200,6 +207,22 @@ static int xhci_rcar_download_firmware(struct usb_hcd *hcd)
>         return retval;
>  }
>
> +static bool xhci_rcar_wait_for_pll_active(struct usb_hcd *hcd)
> +{
> +       int timeout = 1000;
> +       u32 val, mask = RCAR_USB3_AXH_STA_PLL_ACTIVE_MASK;
> +
> +       while (timeout > 0) {
> +               val = readl(hcd->regs + RCAR_USB3_AXH_STA);
> +               if ((val & mask) == mask)
> +                       return true;
> +               udelay(1);
> +               timeout--;
> +       }
> +
> +       return false;
> +}
> +
>  /* This function needs to initialize a "phy" of usb before */
>  int xhci_rcar_init_quirk(struct usb_hcd *hcd)
>  {
> @@ -220,6 +243,9 @@ int xhci_rcar_init_quirk(struct usb_hcd *hcd)
>                         xhci_rcar_is_gen3(hcd->self.controller))
>                 xhci->quirks |= XHCI_NO_64BIT_SUPPORT;
>
> +       if (!xhci_rcar_wait_for_pll_active(hcd))
> +               return -ETIMEDOUT;
> +
>         return xhci_rcar_download_firmware(hcd);
>  }
>
> --
> 1.9.1
>

Reviewed-by: Ulrich Hecht <ulrich.hecht+renesas@xxxxxxxxx>

CU
Uli



[Index of Archives]     [Linux Samsung SOC]     [Linux Wireless]     [Linux Kernel]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]

  Powered by Linux