From: Vardan Mikayelyan <mvar...@synopsys.com>

Move hptxfsiz to host register's backup/restore functions, not
needed to have it in global register's backup/restore functions.

Add backup for glpmcfg, and read/write for gi2cctl and pcgcctl.
As requires programming guide.

Affected functions:
dwc2_backup_host_registers()
dwc2_restore_host_registers()
dwc2_backup_global_registers()
dwc2_restore_global_registers()

Signed-off-by: Vardan Mikayelyan <mvar...@synopsys.com>
Signed-off-by: John Youn <johny...@synopsys.com>
Signed-off-by: Grigor Tovmasyan <tovma...@synopsys.com>
---
 drivers/usb/dwc2/core.c | 8 ++++++--
 drivers/usb/dwc2/core.h | 6 ++++--
 drivers/usb/dwc2/hcd.c  | 2 ++
 3 files changed, 12 insertions(+), 4 deletions(-)

diff --git a/drivers/usb/dwc2/core.c b/drivers/usb/dwc2/core.c
index 53f0eb61d3b2..8647e2a26eee 100644
--- a/drivers/usb/dwc2/core.c
+++ b/drivers/usb/dwc2/core.c
@@ -79,9 +79,11 @@ static int dwc2_backup_global_registers(struct dwc2_hsotg 
*hsotg)
        gr->gusbcfg = dwc2_readl(hsotg->regs + GUSBCFG);
        gr->grxfsiz = dwc2_readl(hsotg->regs + GRXFSIZ);
        gr->gnptxfsiz = dwc2_readl(hsotg->regs + GNPTXFSIZ);
-       gr->hptxfsiz = dwc2_readl(hsotg->regs + HPTXFSIZ);
        gr->gdfifocfg = dwc2_readl(hsotg->regs + GDFIFOCFG);
        gr->pcgcctl1 = dwc2_readl(hsotg->regs + PCGCCTL1);
+       gr->glpmcfg = dwc2_readl(hsotg->regs + GLPMCFG);
+       gr->gi2cctl = dwc2_readl(hsotg->regs + GI2CCTL);
+       gr->pcgcctl = dwc2_readl(hsotg->regs + PCGCTL);
 
        gr->valid = true;
        return 0;
@@ -116,9 +118,11 @@ static int dwc2_restore_global_registers(struct dwc2_hsotg 
*hsotg)
        dwc2_writel(gr->gahbcfg, hsotg->regs + GAHBCFG);
        dwc2_writel(gr->grxfsiz, hsotg->regs + GRXFSIZ);
        dwc2_writel(gr->gnptxfsiz, hsotg->regs + GNPTXFSIZ);
-       dwc2_writel(gr->hptxfsiz, hsotg->regs + HPTXFSIZ);
        dwc2_writel(gr->gdfifocfg, hsotg->regs + GDFIFOCFG);
        dwc2_writel(gr->pcgcctl1, hsotg->regs + PCGCCTL1);
+       dwc2_writel(gr->glpmcfg, hsotg->regs + GLPMCFG);
+       dwc2_writel(gr->pcgcctl, hsotg->regs + PCGCTL);
+       dwc2_writel(gr->gi2cctl, hsotg->regs + GI2CCTL);
 
        return 0;
 }
diff --git a/drivers/usb/dwc2/core.h b/drivers/usb/dwc2/core.h
index 49834a7be78a..d83fafcee95c 100644
--- a/drivers/usb/dwc2/core.h
+++ b/drivers/usb/dwc2/core.h
@@ -636,7 +636,7 @@ struct dwc2_hw_params {
  * @grxfsiz:           Backup of GRXFSIZ register
  * @gnptxfsiz:         Backup of GNPTXFSIZ register
  * @gi2cctl:           Backup of GI2CCTL register
- * @hptxfsiz:          Backup of HPTXFSIZ register
+ * @glpmcfg:           Backup of GLPMCFG register
  * @gdfifocfg:         Backup of GDFIFOCFG register
  * @gpwrdn:            Backup of GPWRDN register
  */
@@ -648,7 +648,7 @@ struct dwc2_gregs_backup {
        u32 grxfsiz;
        u32 gnptxfsiz;
        u32 gi2cctl;
-       u32 hptxfsiz;
+       u32 glpmcfg;
        u32 pcgcctl;
        u32 pcgcctl1;
        u32 gdfifocfg;
@@ -696,6 +696,7 @@ struct dwc2_dregs_backup {
  * @hcintmsk:          Backup of HCINTMSK register
  * @hptr0:             Backup of HPTR0 register
  * @hfir:              Backup of HFIR register
+ * @hptxfsiz:          Backup of HPTXFSIZ register
  */
 struct dwc2_hregs_backup {
        u32 hcfg;
@@ -703,6 +704,7 @@ struct dwc2_hregs_backup {
        u32 hcintmsk[MAX_EPS_CHANNELS];
        u32 hprt0;
        u32 hfir;
+       u32 hptxfsiz;
        bool valid;
 };
 
diff --git a/drivers/usb/dwc2/hcd.c b/drivers/usb/dwc2/hcd.c
index 050e01e193c8..badd3a571977 100644
--- a/drivers/usb/dwc2/hcd.c
+++ b/drivers/usb/dwc2/hcd.c
@@ -5311,6 +5311,7 @@ int dwc2_backup_host_registers(struct dwc2_hsotg *hsotg)
 
        hr->hprt0 = dwc2_read_hprt0(hsotg);
        hr->hfir = dwc2_readl(hsotg->regs + HFIR);
+       hr->hptxfsiz = dwc2_readl(hsotg->regs + HPTXFSIZ);
        hr->valid = true;
 
        return 0;
@@ -5347,6 +5348,7 @@ int dwc2_restore_host_registers(struct dwc2_hsotg *hsotg)
 
        dwc2_writel(hr->hprt0, hsotg->regs + HPRT0);
        dwc2_writel(hr->hfir, hsotg->regs + HFIR);
+       dwc2_writel(hr->hptxfsiz, hsotg->regs + HPTXFSIZ);
        hsotg->frame_number = 0;
 
        return 0;
-- 
2.11.0

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to