usb: chipidea: usbmisc: Add support for i.MX27/i.MX31 CPUs
This adds i.MX27 and i.MX31 as the next user of the usbmisc driver. Tested-by: Chris Ruehl <chris.ruehl@gtsys.com.hk> Signed-off-by: Alexander Shiyan <shc_work@mail.ru> Signed-off-by: Peter Chen <peter.chen@freescale.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
73de934401
commit
9f90e111a6
@ -21,6 +21,10 @@
|
|||||||
#define MX25_USB_PHY_CTRL_OFFSET 0x08
|
#define MX25_USB_PHY_CTRL_OFFSET 0x08
|
||||||
#define MX25_BM_EXTERNAL_VBUS_DIVIDER BIT(23)
|
#define MX25_BM_EXTERNAL_VBUS_DIVIDER BIT(23)
|
||||||
|
|
||||||
|
#define MX27_H1_PM_BIT BIT(8)
|
||||||
|
#define MX27_H2_PM_BIT BIT(16)
|
||||||
|
#define MX27_OTG_PM_BIT BIT(24)
|
||||||
|
|
||||||
#define MX53_USB_OTG_PHY_CTRL_0_OFFSET 0x08
|
#define MX53_USB_OTG_PHY_CTRL_0_OFFSET 0x08
|
||||||
#define MX53_USB_UH2_CTRL_OFFSET 0x14
|
#define MX53_USB_UH2_CTRL_OFFSET 0x14
|
||||||
#define MX53_USB_UH3_CTRL_OFFSET 0x18
|
#define MX53_USB_UH3_CTRL_OFFSET 0x18
|
||||||
@ -68,6 +72,36 @@ static int usbmisc_imx25_post(struct imx_usbmisc_data *data)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int usbmisc_imx27_init(struct imx_usbmisc_data *data)
|
||||||
|
{
|
||||||
|
unsigned long flags;
|
||||||
|
u32 val;
|
||||||
|
|
||||||
|
switch (data->index) {
|
||||||
|
case 0:
|
||||||
|
val = MX27_OTG_PM_BIT;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
val = MX27_H1_PM_BIT;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
val = MX27_H2_PM_BIT;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return -EINVAL;
|
||||||
|
};
|
||||||
|
|
||||||
|
spin_lock_irqsave(&usbmisc->lock, flags);
|
||||||
|
if (data->disable_oc)
|
||||||
|
val = readl(usbmisc->base) | val;
|
||||||
|
else
|
||||||
|
val = readl(usbmisc->base) & ~val;
|
||||||
|
writel(val, usbmisc->base);
|
||||||
|
spin_unlock_irqrestore(&usbmisc->lock, flags);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int usbmisc_imx53_init(struct imx_usbmisc_data *data)
|
static int usbmisc_imx53_init(struct imx_usbmisc_data *data)
|
||||||
{
|
{
|
||||||
void __iomem *reg = NULL;
|
void __iomem *reg = NULL;
|
||||||
@ -128,6 +162,10 @@ static const struct usbmisc_ops imx25_usbmisc_ops = {
|
|||||||
.post = usbmisc_imx25_post,
|
.post = usbmisc_imx25_post,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct usbmisc_ops imx27_usbmisc_ops = {
|
||||||
|
.init = usbmisc_imx27_init,
|
||||||
|
};
|
||||||
|
|
||||||
static const struct usbmisc_ops imx53_usbmisc_ops = {
|
static const struct usbmisc_ops imx53_usbmisc_ops = {
|
||||||
.init = usbmisc_imx53_init,
|
.init = usbmisc_imx53_init,
|
||||||
};
|
};
|
||||||
@ -161,6 +199,10 @@ static const struct of_device_id usbmisc_imx_dt_ids[] = {
|
|||||||
.compatible = "fsl,imx25-usbmisc",
|
.compatible = "fsl,imx25-usbmisc",
|
||||||
.data = &imx25_usbmisc_ops,
|
.data = &imx25_usbmisc_ops,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.compatible = "fsl,imx27-usbmisc",
|
||||||
|
.data = &imx27_usbmisc_ops,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.compatible = "fsl,imx53-usbmisc",
|
.compatible = "fsl,imx53-usbmisc",
|
||||||
.data = &imx53_usbmisc_ops,
|
.data = &imx53_usbmisc_ops,
|
||||||
|
Reference in New Issue
Block a user