usb: dwc3: omap: Adds dwc3_omap_readl/writel wrappers
authorGeorge Cherian <george.cherian@ti.com>
Wed, 12 Jun 2013 09:23:47 +0000 (14:53 +0530)
committerFelipe Balbi <balbi@ti.com>
Wed, 12 Jun 2013 20:57:13 +0000 (23:57 +0300)
This patch adds wrappers to dwc3_omap_readl/writel calls to accomodate
both OMAP5 and AM437x reg maps (It uses the cached register offsets).
Also renames OMAP5 IRQ1 as IRQMISC and IRQ1 bits as IRQMISC bits.

Signed-off-by: George Cherian <george.cherian@ti.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
drivers/usb/dwc3/dwc3-omap.c

index 54dd6fe886e2784cdd01dd2647c8e39cd600b93d..077f110bd746073931e75fc6c9321cd0b1003aff 100644 (file)
 #define USBOTGSS_IRQENABLE_SET_0               0x002c
 #define USBOTGSS_IRQENABLE_CLR_0               0x0030
 #define USBOTGSS_IRQ0_OFFSET                   0x0004
-#define USBOTGSS_IRQSTATUS_RAW_1               0x0034
-#define USBOTGSS_IRQSTATUS_1                   0x0038
-#define USBOTGSS_IRQENABLE_SET_1               0x003c
-#define USBOTGSS_IRQENABLE_CLR_1               0x0040
+#define USBOTGSS_IRQSTATUS_RAW_1               0x0030
+#define USBOTGSS_IRQSTATUS_1                   0x0034
+#define USBOTGSS_IRQENABLE_SET_1               0x0038
+#define USBOTGSS_IRQENABLE_CLR_1               0x003c
+#define USBOTGSS_IRQSTATUS_RAW_2               0x0040
+#define USBOTGSS_IRQSTATUS_2                   0x0044
+#define USBOTGSS_IRQENABLE_SET_2               0x0048
+#define USBOTGSS_IRQENABLE_CLR_2               0x004c
+#define USBOTGSS_IRQSTATUS_RAW_3               0x0050
+#define USBOTGSS_IRQSTATUS_3                   0x0054
+#define USBOTGSS_IRQENABLE_SET_3               0x0058
+#define USBOTGSS_IRQENABLE_CLR_3               0x005c
 #define USBOTGSS_IRQSTATUS_EOI_MISC            0x0030
 #define USBOTGSS_IRQSTATUS_RAW_MISC            0x0034
 #define USBOTGSS_IRQSTATUS_MISC                        0x0038
 /* IRQS0 BITS */
 #define USBOTGSS_IRQO_COREIRQ_ST               (1 << 0)
 
-/* IRQ1 BITS */
-#define USBOTGSS_IRQ1_DMADISABLECLR            (1 << 17)
-#define USBOTGSS_IRQ1_OEVT                     (1 << 16)
-#define USBOTGSS_IRQ1_DRVVBUS_RISE             (1 << 13)
-#define USBOTGSS_IRQ1_CHRGVBUS_RISE            (1 << 12)
-#define USBOTGSS_IRQ1_DISCHRGVBUS_RISE         (1 << 11)
-#define USBOTGSS_IRQ1_IDPULLUP_RISE            (1 << 8)
-#define USBOTGSS_IRQ1_DRVVBUS_FALL             (1 << 5)
-#define USBOTGSS_IRQ1_CHRGVBUS_FALL            (1 << 4)
-#define USBOTGSS_IRQ1_DISCHRGVBUS_FALL         (1 << 3)
-#define USBOTGSS_IRQ1_IDPULLUP_FALL            (1 << 0)
+/* IRQMISC BITS */
+#define USBOTGSS_IRQMISC_DMADISABLECLR         (1 << 17)
+#define USBOTGSS_IRQMISC_OEVT                  (1 << 16)
+#define USBOTGSS_IRQMISC_DRVVBUS_RISE          (1 << 13)
+#define USBOTGSS_IRQMISC_CHRGVBUS_RISE         (1 << 12)
+#define USBOTGSS_IRQMISC_DISCHRGVBUS_RISE      (1 << 11)
+#define USBOTGSS_IRQMISC_IDPULLUP_RISE         (1 << 8)
+#define USBOTGSS_IRQMISC_DRVVBUS_FALL          (1 << 5)
+#define USBOTGSS_IRQMISC_CHRGVBUS_FALL         (1 << 4)
+#define USBOTGSS_IRQMISC_DISCHRGVBUS_FALL              (1 << 3)
+#define USBOTGSS_IRQMISC_IDPULLUP_FALL         (1 << 0)
 
 /* UTMI_OTG_CTRL REGISTER */
 #define USBOTGSS_UTMI_OTG_CTRL_DRVVBUS         (1 << 5)
@@ -161,6 +169,58 @@ static inline void dwc3_omap_writel(void __iomem *base, u32 offset, u32 value)
        writel(value, base + offset);
 }
 
+static u32 dwc3_omap_read_utmi_status(struct dwc3_omap *omap)
+{
+       return dwc3_omap_readl(omap->base, USBOTGSS_UTMI_OTG_STATUS +
+                                                       omap->utmi_otg_offset);
+}
+
+static void dwc3_omap_write_utmi_status(struct dwc3_omap *omap, u32 value)
+{
+       dwc3_omap_writel(omap->base, USBOTGSS_UTMI_OTG_STATUS +
+                                       omap->utmi_otg_offset, value);
+
+}
+
+static u32 dwc3_omap_read_irq0_status(struct dwc3_omap *omap)
+{
+       return dwc3_omap_readl(omap->base, USBOTGSS_IRQSTATUS_0 -
+                                               omap->irq0_offset);
+}
+
+static void dwc3_omap_write_irq0_status(struct dwc3_omap *omap, u32 value)
+{
+       dwc3_omap_writel(omap->base, USBOTGSS_IRQSTATUS_0 -
+                                               omap->irq0_offset, value);
+
+}
+
+static u32 dwc3_omap_read_irqmisc_status(struct dwc3_omap *omap)
+{
+       return dwc3_omap_readl(omap->base, USBOTGSS_IRQSTATUS_MISC +
+                                               omap->irqmisc_offset);
+}
+
+static void dwc3_omap_write_irqmisc_status(struct dwc3_omap *omap, u32 value)
+{
+       dwc3_omap_writel(omap->base, USBOTGSS_IRQSTATUS_MISC +
+                                       omap->irqmisc_offset, value);
+
+}
+
+static void dwc3_omap_write_irqmisc_set(struct dwc3_omap *omap, u32 value)
+{
+       dwc3_omap_writel(omap->base, USBOTGSS_IRQENABLE_SET_MISC +
+                                               omap->irqmisc_offset, value);
+
+}
+
+static void dwc3_omap_write_irq0_set(struct dwc3_omap *omap, u32 value)
+{
+       dwc3_omap_writel(omap->base, USBOTGSS_IRQENABLE_SET_0 -
+                                               omap->irq0_offset, value);
+}
+
 int dwc3_omap_mailbox(enum omap_dwc3_vbus_id_status status)
 {
        u32                     val;
@@ -173,38 +233,38 @@ int dwc3_omap_mailbox(enum omap_dwc3_vbus_id_status status)
        case OMAP_DWC3_ID_GROUND:
                dev_dbg(omap->dev, "ID GND\n");
 
-               val = dwc3_omap_readl(omap->base, USBOTGSS_UTMI_OTG_STATUS);
+               val = dwc3_omap_read_utmi_status(omap);
                val &= ~(USBOTGSS_UTMI_OTG_STATUS_IDDIG
                                | USBOTGSS_UTMI_OTG_STATUS_VBUSVALID
                                | USBOTGSS_UTMI_OTG_STATUS_SESSEND);
                val |= USBOTGSS_UTMI_OTG_STATUS_SESSVALID
                                | USBOTGSS_UTMI_OTG_STATUS_POWERPRESENT;
-               dwc3_omap_writel(omap->base, USBOTGSS_UTMI_OTG_STATUS, val);
+               dwc3_omap_write_utmi_status(omap, val);
                break;
 
        case OMAP_DWC3_VBUS_VALID:
                dev_dbg(omap->dev, "VBUS Connect\n");
 
-               val = dwc3_omap_readl(omap->base, USBOTGSS_UTMI_OTG_STATUS);
+               val = dwc3_omap_read_utmi_status(omap);
                val &= ~USBOTGSS_UTMI_OTG_STATUS_SESSEND;
                val |= USBOTGSS_UTMI_OTG_STATUS_IDDIG
                                | USBOTGSS_UTMI_OTG_STATUS_VBUSVALID
                                | USBOTGSS_UTMI_OTG_STATUS_SESSVALID
                                | USBOTGSS_UTMI_OTG_STATUS_POWERPRESENT;
-               dwc3_omap_writel(omap->base, USBOTGSS_UTMI_OTG_STATUS, val);
+               dwc3_omap_write_utmi_status(omap, val);
                break;
 
        case OMAP_DWC3_ID_FLOAT:
        case OMAP_DWC3_VBUS_OFF:
                dev_dbg(omap->dev, "VBUS Disconnect\n");
 
-               val = dwc3_omap_readl(omap->base, USBOTGSS_UTMI_OTG_STATUS);
+               val = dwc3_omap_read_utmi_status(omap);
                val &= ~(USBOTGSS_UTMI_OTG_STATUS_SESSVALID
                                | USBOTGSS_UTMI_OTG_STATUS_VBUSVALID
                                | USBOTGSS_UTMI_OTG_STATUS_POWERPRESENT);
                val |= USBOTGSS_UTMI_OTG_STATUS_SESSEND
                                | USBOTGSS_UTMI_OTG_STATUS_IDDIG;
-               dwc3_omap_writel(omap->base, USBOTGSS_UTMI_OTG_STATUS, val);
+               dwc3_omap_write_utmi_status(omap, val);
                break;
 
        default:
@@ -222,44 +282,45 @@ static irqreturn_t dwc3_omap_interrupt(int irq, void *_omap)
 
        spin_lock(&omap->lock);
 
-       reg = dwc3_omap_readl(omap->base, USBOTGSS_IRQSTATUS_1);
+       reg = dwc3_omap_read_irqmisc_status(omap);
 
-       if (reg & USBOTGSS_IRQ1_DMADISABLECLR) {
+       if (reg & USBOTGSS_IRQMISC_DMADISABLECLR) {
                dev_dbg(omap->dev, "DMA Disable was Cleared\n");
                omap->dma_status = false;
        }
 
-       if (reg & USBOTGSS_IRQ1_OEVT)
+       if (reg & USBOTGSS_IRQMISC_OEVT)
                dev_dbg(omap->dev, "OTG Event\n");
 
-       if (reg & USBOTGSS_IRQ1_DRVVBUS_RISE)
+       if (reg & USBOTGSS_IRQMISC_DRVVBUS_RISE)
                dev_dbg(omap->dev, "DRVVBUS Rise\n");
 
-       if (reg & USBOTGSS_IRQ1_CHRGVBUS_RISE)
+       if (reg & USBOTGSS_IRQMISC_CHRGVBUS_RISE)
                dev_dbg(omap->dev, "CHRGVBUS Rise\n");
 
-       if (reg & USBOTGSS_IRQ1_DISCHRGVBUS_RISE)
+       if (reg & USBOTGSS_IRQMISC_DISCHRGVBUS_RISE)
                dev_dbg(omap->dev, "DISCHRGVBUS Rise\n");
 
-       if (reg & USBOTGSS_IRQ1_IDPULLUP_RISE)
+       if (reg & USBOTGSS_IRQMISC_IDPULLUP_RISE)
                dev_dbg(omap->dev, "IDPULLUP Rise\n");
 
-       if (reg & USBOTGSS_IRQ1_DRVVBUS_FALL)
+       if (reg & USBOTGSS_IRQMISC_DRVVBUS_FALL)
                dev_dbg(omap->dev, "DRVVBUS Fall\n");
 
-       if (reg & USBOTGSS_IRQ1_CHRGVBUS_FALL)
+       if (reg & USBOTGSS_IRQMISC_CHRGVBUS_FALL)
                dev_dbg(omap->dev, "CHRGVBUS Fall\n");
 
-       if (reg & USBOTGSS_IRQ1_DISCHRGVBUS_FALL)
+       if (reg & USBOTGSS_IRQMISC_DISCHRGVBUS_FALL)
                dev_dbg(omap->dev, "DISCHRGVBUS Fall\n");
 
-       if (reg & USBOTGSS_IRQ1_IDPULLUP_FALL)
+       if (reg & USBOTGSS_IRQMISC_IDPULLUP_FALL)
                dev_dbg(omap->dev, "IDPULLUP Fall\n");
 
-       dwc3_omap_writel(omap->base, USBOTGSS_IRQSTATUS_1, reg);
+       dwc3_omap_write_irqmisc_status(omap, reg);
+
+       reg = dwc3_omap_read_irq0_status(omap);
 
-       reg = dwc3_omap_readl(omap->base, USBOTGSS_IRQSTATUS_0);
-       dwc3_omap_writel(omap->base, USBOTGSS_IRQSTATUS_0, reg);
+       dwc3_omap_write_irq0_status(omap, reg);
 
        spin_unlock(&omap->lock);
 
@@ -281,26 +342,26 @@ static void dwc3_omap_enable_irqs(struct dwc3_omap *omap)
 
        /* enable all IRQs */
        reg = USBOTGSS_IRQO_COREIRQ_ST;
-       dwc3_omap_writel(omap->base, USBOTGSS_IRQENABLE_SET_0, reg);
-
-       reg = (USBOTGSS_IRQ1_OEVT |
-                       USBOTGSS_IRQ1_DRVVBUS_RISE |
-                       USBOTGSS_IRQ1_CHRGVBUS_RISE |
-                       USBOTGSS_IRQ1_DISCHRGVBUS_RISE |
-                       USBOTGSS_IRQ1_IDPULLUP_RISE |
-                       USBOTGSS_IRQ1_DRVVBUS_FALL |
-                       USBOTGSS_IRQ1_CHRGVBUS_FALL |
-                       USBOTGSS_IRQ1_DISCHRGVBUS_FALL |
-                       USBOTGSS_IRQ1_IDPULLUP_FALL);
-
-       dwc3_omap_writel(omap->base, USBOTGSS_IRQENABLE_SET_1, reg);
+       dwc3_omap_write_irq0_set(omap, reg);
+
+       reg = (USBOTGSS_IRQMISC_OEVT |
+                       USBOTGSS_IRQMISC_DRVVBUS_RISE |
+                       USBOTGSS_IRQMISC_CHRGVBUS_RISE |
+                       USBOTGSS_IRQMISC_DISCHRGVBUS_RISE |
+                       USBOTGSS_IRQMISC_IDPULLUP_RISE |
+                       USBOTGSS_IRQMISC_DRVVBUS_FALL |
+                       USBOTGSS_IRQMISC_CHRGVBUS_FALL |
+                       USBOTGSS_IRQMISC_DISCHRGVBUS_FALL |
+                       USBOTGSS_IRQMISC_IDPULLUP_FALL);
+
+       dwc3_omap_write_irqmisc_set(omap, reg);
 }
 
 static void dwc3_omap_disable_irqs(struct dwc3_omap *omap)
 {
        /* disable all IRQs */
-       dwc3_omap_writel(omap->base, USBOTGSS_IRQENABLE_SET_1, 0x00);
-       dwc3_omap_writel(omap->base, USBOTGSS_IRQENABLE_SET_0, 0x00);
+       dwc3_omap_write_irqmisc_set(omap, 0x00);
+       dwc3_omap_write_irq0_set(omap, 0x00);
 }
 
 static u64 dwc3_omap_dma_mask = DMA_BIT_MASK(32);
@@ -378,7 +439,7 @@ static int dwc3_omap_probe(struct platform_device *pdev)
        omap->revision = reg;
        x_major = USBOTGSS_REVISION_XMAJOR(reg);
 
-       /* Differentiate between OMAP5,AM437x and others*/
+       /* Differentiate between OMAP5 and AM437x */
        switch (x_major) {
        case USBOTGSS_REVISION_XMAJOR1:
        case USBOTGSS_REVISION_XMAJOR2:
@@ -410,7 +471,7 @@ static int dwc3_omap_probe(struct platform_device *pdev)
                omap->debug_offset = USBOTGSS_DEBUG_OFFSET;
        }
 
-       reg = dwc3_omap_readl(omap->base, USBOTGSS_UTMI_OTG_STATUS);
+       reg = dwc3_omap_read_utmi_status(omap);
 
        of_property_read_u32(node, "utmi-mode", &utmi_mode);
 
@@ -425,7 +486,7 @@ static int dwc3_omap_probe(struct platform_device *pdev)
                dev_dbg(dev, "UNKNOWN utmi mode %d\n", utmi_mode);
        }
 
-       dwc3_omap_writel(omap->base, USBOTGSS_UTMI_OTG_STATUS, reg);
+       dwc3_omap_write_utmi_status(omap, reg);
 
        /* check the DMA Status */
        reg = dwc3_omap_readl(omap->base, USBOTGSS_SYSCONFIG);
@@ -505,8 +566,7 @@ static int dwc3_omap_suspend(struct device *dev)
 {
        struct dwc3_omap        *omap = dev_get_drvdata(dev);
 
-       omap->utmi_otg_status = dwc3_omap_readl(omap->base,
-                       USBOTGSS_UTMI_OTG_STATUS);
+       omap->utmi_otg_status = dwc3_omap_read_utmi_status(omap);
 
        return 0;
 }
@@ -515,8 +575,7 @@ static int dwc3_omap_resume(struct device *dev)
 {
        struct dwc3_omap        *omap = dev_get_drvdata(dev);
 
-       dwc3_omap_writel(omap->base, USBOTGSS_UTMI_OTG_STATUS,
-                       omap->utmi_otg_status);
+       dwc3_omap_write_utmi_status(omap, omap->utmi_otg_status);
 
        pm_runtime_disable(dev);
        pm_runtime_set_active(dev);