2019-05-23 17:14:42 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2010-12-10 20:28:20 +08:00
|
|
|
/*
|
|
|
|
* This file configures the internal USB PHY in OMAP4430. Used
|
|
|
|
* with TWL6030 transceiver and MUSB on OMAP4430.
|
|
|
|
*
|
2020-07-19 18:30:33 +08:00
|
|
|
* Copyright (C) 2010 Texas Instruments Incorporated - https://www.ti.com
|
2010-12-10 20:28:20 +08:00
|
|
|
* Author: Hema HK <hemahk@ti.com>
|
|
|
|
*/
|
|
|
|
|
2014-10-07 22:16:16 +08:00
|
|
|
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
|
|
|
|
|
2010-12-10 20:28:20 +08:00
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/delay.h>
|
|
|
|
#include <linux/clk.h>
|
|
|
|
#include <linux/io.h>
|
|
|
|
#include <linux/err.h>
|
|
|
|
#include <linux/usb.h>
|
2012-10-25 05:26:18 +08:00
|
|
|
#include <linux/usb/musb.h>
|
2012-08-28 08:43:01 +08:00
|
|
|
|
2012-09-01 01:59:07 +08:00
|
|
|
#include "soc.h"
|
2011-02-16 20:04:40 +08:00
|
|
|
#include "control.h"
|
2010-12-10 20:28:20 +08:00
|
|
|
|
2012-11-09 22:30:35 +08:00
|
|
|
#define CONTROL_DEV_CONF 0x300
|
|
|
|
#define PHY_PD 0x1
|
|
|
|
|
|
|
|
/**
|
|
|
|
* omap4430_phy_power_down: disable MUSB PHY during early init
|
|
|
|
*
|
|
|
|
* OMAP4 MUSB PHY module is enabled by default on reset, but this will
|
|
|
|
* prevent core retention if not disabled by SW. USB driver will
|
|
|
|
* later on enable this, once and if the driver needs it.
|
|
|
|
*/
|
|
|
|
static int __init omap4430_phy_power_down(void)
|
|
|
|
{
|
|
|
|
void __iomem *ctrl_base;
|
|
|
|
|
|
|
|
if (!cpu_is_omap44xx())
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
ctrl_base = ioremap(OMAP443X_SCM_BASE, SZ_1K);
|
|
|
|
if (!ctrl_base) {
|
|
|
|
pr_err("control module ioremap failed\n");
|
|
|
|
return -ENOMEM;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Power down the phy */
|
2014-04-16 01:37:46 +08:00
|
|
|
writel_relaxed(PHY_PD, ctrl_base + CONTROL_DEV_CONF);
|
2012-11-09 22:30:35 +08:00
|
|
|
|
|
|
|
iounmap(ctrl_base);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2013-01-12 03:24:18 +08:00
|
|
|
omap_early_initcall(omap4430_phy_power_down);
|