mirror of
https://github.com/FEX-Emu/linux.git
synced 2024-12-28 04:17:47 +00:00
ARM: OMAP2+: Add custom prwdm_operations for 81xx to support dm814x
Looking at the TI kernel tree I noticed that dm81xx need custom ti81xx_pwrdm_operations. Let's also change dm816x over to use them as the registers are different for dm81xx compared to others. Cc: Matthijs van Duin <matthijsvanduin@gmail.com> Cc: Paul Walmsley <paul@pwsan.com> Cc: Tero Kristo <t-kristo@ti.com> Signed-off-by: Tony Lindgren <tony@atomide.com>
This commit is contained in:
parent
185fde6d5b
commit
7c80a3f89c
@ -349,6 +349,41 @@ static struct powerdomain device_81xx_pwrdm = {
|
||||
.voltdm = { .name = "core" },
|
||||
};
|
||||
|
||||
static struct powerdomain gem_814x_pwrdm = {
|
||||
.name = "gem_pwrdm",
|
||||
.prcm_offs = TI814X_PRM_DSP_MOD,
|
||||
.pwrsts = PWRSTS_OFF_ON,
|
||||
.voltdm = { .name = "dsp" },
|
||||
};
|
||||
|
||||
static struct powerdomain ivahd_814x_pwrdm = {
|
||||
.name = "ivahd_pwrdm",
|
||||
.prcm_offs = TI814X_PRM_HDVICP_MOD,
|
||||
.pwrsts = PWRSTS_OFF_ON,
|
||||
.voltdm = { .name = "iva" },
|
||||
};
|
||||
|
||||
static struct powerdomain hdvpss_814x_pwrdm = {
|
||||
.name = "hdvpss_pwrdm",
|
||||
.prcm_offs = TI814X_PRM_HDVPSS_MOD,
|
||||
.pwrsts = PWRSTS_OFF_ON,
|
||||
.voltdm = { .name = "dsp" },
|
||||
};
|
||||
|
||||
static struct powerdomain sgx_814x_pwrdm = {
|
||||
.name = "sgx_pwrdm",
|
||||
.prcm_offs = TI814X_PRM_GFX_MOD,
|
||||
.pwrsts = PWRSTS_OFF_ON,
|
||||
.voltdm = { .name = "core" },
|
||||
};
|
||||
|
||||
static struct powerdomain isp_814x_pwrdm = {
|
||||
.name = "isp_pwrdm",
|
||||
.prcm_offs = TI814X_PRM_ISP_MOD,
|
||||
.pwrsts = PWRSTS_OFF_ON,
|
||||
.voltdm = { .name = "core" },
|
||||
};
|
||||
|
||||
static struct powerdomain active_816x_pwrdm = {
|
||||
.name = "active_pwrdm",
|
||||
.prcm_offs = TI816X_PRM_ACTIVE_MOD,
|
||||
@ -448,7 +483,18 @@ static struct powerdomain *powerdomains_am35x[] __initdata = {
|
||||
NULL
|
||||
};
|
||||
|
||||
static struct powerdomain *powerdomains_ti81xx[] __initdata = {
|
||||
static struct powerdomain *powerdomains_ti814x[] __initdata = {
|
||||
&alwon_81xx_pwrdm,
|
||||
&device_81xx_pwrdm,
|
||||
&gem_814x_pwrdm,
|
||||
&ivahd_814x_pwrdm,
|
||||
&hdvpss_814x_pwrdm,
|
||||
&sgx_814x_pwrdm,
|
||||
&isp_814x_pwrdm,
|
||||
NULL
|
||||
};
|
||||
|
||||
static struct powerdomain *powerdomains_ti816x[] __initdata = {
|
||||
&alwon_81xx_pwrdm,
|
||||
&device_81xx_pwrdm,
|
||||
&active_816x_pwrdm,
|
||||
@ -460,6 +506,73 @@ static struct powerdomain *powerdomains_ti81xx[] __initdata = {
|
||||
NULL
|
||||
};
|
||||
|
||||
/* TI81XX specific ops */
|
||||
#define TI81XX_PM_PWSTCTRL 0x0000
|
||||
#define TI81XX_RM_RSTCTRL 0x0010
|
||||
#define TI81XX_PM_PWSTST 0x0004
|
||||
|
||||
static int ti81xx_pwrdm_set_next_pwrst(struct powerdomain *pwrdm, u8 pwrst)
|
||||
{
|
||||
omap2_prm_rmw_mod_reg_bits(OMAP_POWERSTATE_MASK,
|
||||
(pwrst << OMAP_POWERSTATE_SHIFT),
|
||||
pwrdm->prcm_offs, TI81XX_PM_PWSTCTRL);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int ti81xx_pwrdm_read_next_pwrst(struct powerdomain *pwrdm)
|
||||
{
|
||||
return omap2_prm_read_mod_bits_shift(pwrdm->prcm_offs,
|
||||
TI81XX_PM_PWSTCTRL,
|
||||
OMAP_POWERSTATE_MASK);
|
||||
}
|
||||
|
||||
static int ti81xx_pwrdm_read_pwrst(struct powerdomain *pwrdm)
|
||||
{
|
||||
return omap2_prm_read_mod_bits_shift(pwrdm->prcm_offs,
|
||||
(pwrdm->prcm_offs == TI814X_PRM_GFX_MOD) ? TI81XX_RM_RSTCTRL :
|
||||
TI81XX_PM_PWSTST,
|
||||
OMAP_POWERSTATEST_MASK);
|
||||
}
|
||||
|
||||
static int ti81xx_pwrdm_read_logic_pwrst(struct powerdomain *pwrdm)
|
||||
{
|
||||
return omap2_prm_read_mod_bits_shift(pwrdm->prcm_offs,
|
||||
(pwrdm->prcm_offs == TI814X_PRM_GFX_MOD) ? TI81XX_RM_RSTCTRL :
|
||||
TI81XX_PM_PWSTST,
|
||||
OMAP3430_LOGICSTATEST_MASK);
|
||||
}
|
||||
|
||||
static int ti81xx_pwrdm_wait_transition(struct powerdomain *pwrdm)
|
||||
{
|
||||
u32 c = 0;
|
||||
|
||||
while ((omap2_prm_read_mod_reg(pwrdm->prcm_offs,
|
||||
(pwrdm->prcm_offs == TI814X_PRM_GFX_MOD) ? TI81XX_RM_RSTCTRL :
|
||||
TI81XX_PM_PWSTST) &
|
||||
OMAP_INTRANSITION_MASK) &&
|
||||
(c++ < PWRDM_TRANSITION_BAILOUT))
|
||||
udelay(1);
|
||||
|
||||
if (c > PWRDM_TRANSITION_BAILOUT) {
|
||||
pr_err("powerdomain: %s timeout waiting for transition\n",
|
||||
pwrdm->name);
|
||||
return -EAGAIN;
|
||||
}
|
||||
|
||||
pr_debug("powerdomain: completed transition in %d loops\n", c);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* For dm814x we need to fix up fix GFX pwstst and rstctrl reg offsets */
|
||||
static struct pwrdm_ops ti81xx_pwrdm_operations = {
|
||||
.pwrdm_set_next_pwrst = ti81xx_pwrdm_set_next_pwrst,
|
||||
.pwrdm_read_next_pwrst = ti81xx_pwrdm_read_next_pwrst,
|
||||
.pwrdm_read_pwrst = ti81xx_pwrdm_read_pwrst,
|
||||
.pwrdm_read_logic_pwrst = ti81xx_pwrdm_read_logic_pwrst,
|
||||
.pwrdm_wait_transition = ti81xx_pwrdm_wait_transition,
|
||||
};
|
||||
|
||||
void __init omap3xxx_powerdomains_init(void)
|
||||
{
|
||||
unsigned int rev;
|
||||
@ -467,15 +580,18 @@ void __init omap3xxx_powerdomains_init(void)
|
||||
if (!cpu_is_omap34xx() && !cpu_is_ti81xx())
|
||||
return;
|
||||
|
||||
pwrdm_register_platform_funcs(&omap3_pwrdm_operations);
|
||||
pwrdm_register_platform_funcs(&ti81xx_pwrdm_operations);
|
||||
|
||||
rev = omap_rev();
|
||||
|
||||
if (rev == AM35XX_REV_ES1_0 || rev == AM35XX_REV_ES1_1) {
|
||||
pwrdm_register_pwrdms(powerdomains_am35x);
|
||||
} else if (rev == TI8148_REV_ES1_0 || rev == TI8148_REV_ES2_0 ||
|
||||
rev == TI8148_REV_ES2_1) {
|
||||
pwrdm_register_pwrdms(powerdomains_ti814x);
|
||||
} else if (rev == TI8168_REV_ES1_0 || rev == TI8168_REV_ES1_1
|
||||
|| rev == TI8168_REV_ES2_0 || rev == TI8168_REV_ES2_1) {
|
||||
pwrdm_register_pwrdms(powerdomains_ti81xx);
|
||||
pwrdm_register_pwrdms(powerdomains_ti816x);
|
||||
} else {
|
||||
pwrdm_register_pwrdms(powerdomains_omap3430_common);
|
||||
|
||||
|
@ -51,6 +51,12 @@
|
||||
/*
|
||||
* TI81XX PRM module offsets
|
||||
*/
|
||||
#define TI814X_PRM_DSP_MOD 0x0a00
|
||||
#define TI814X_PRM_HDVICP_MOD 0x0c00
|
||||
#define TI814X_PRM_ISP_MOD 0x0d00
|
||||
#define TI814X_PRM_HDVPSS_MOD 0x0e00
|
||||
#define TI814X_PRM_GFX_MOD 0x0f00
|
||||
|
||||
#define TI81XX_PRM_DEVICE_MOD 0x0000
|
||||
#define TI816X_PRM_ACTIVE_MOD 0x0a00
|
||||
#define TI81XX_PRM_DEFAULT_MOD 0x0b00
|
||||
|
Loading…
Reference in New Issue
Block a user