usb: dwc3: core: cache GHWPARAMS* registers
authorFelipe Balbi <balbi@ti.com>
Fri, 30 Sep 2011 07:58:49 +0000 (10:58 +0300)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 4 Oct 2011 17:25:55 +0000 (10:25 -0700)
cache the contents of GHWPARAMS* registers in
our device structure for easy access.

Signed-off-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/usb/dwc3/core.c

index cfb074548124d4ca27938e0d79bac72ab8f920b1..d35f90527c38d030fe37d72984352d900f4c4f1d 100644 (file)
@@ -229,6 +229,21 @@ static void dwc3_event_buffers_cleanup(struct dwc3 *dwc)
        }
 }
 
+static void __devinit dwc3_cache_hwparams(struct dwc3 *dwc)
+{
+       struct dwc3_hwparams    *parms = &dwc->hwparams;
+
+       parms->hwparams0 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS0);
+       parms->hwparams1 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS1);
+       parms->hwparams2 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS2);
+       parms->hwparams3 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS3);
+       parms->hwparams4 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS4);
+       parms->hwparams5 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS5);
+       parms->hwparams6 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS6);
+       parms->hwparams7 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS7);
+       parms->hwparams8 = dwc3_readl(dwc->regs, DWC3_GHWPARAMS8);
+}
+
 /**
  * dwc3_core_init - Low-level initialization of DWC3 Core
  * @dwc: Pointer to our controller context structure
@@ -283,6 +298,8 @@ static int __devinit dwc3_core_init(struct dwc3 *dwc)
                goto err1;
        }
 
+       dwc3_cache_hwparams(dwc);
+
        return 0;
 
 err1: