Commit bc0b964d authored by Tony Lindgren's avatar Tony Lindgren

soc: ti: omap-prm: Allow hardware supported retention when idle

When moving the l4 interconnect instances to probe with simple-pm-bus and
genpd, we will have l4per and core domains stop idling unless we configure
the domain bits to allow retention when idle.

As the TI SoCs have hardware autoidle capabilities, this is safe to do.
The domains will only enter retention on WFI when none of the devices on
the domain block autoidle in the hardware. This follows what we are
already currently doing.

Cc: Santosh Shilimkar <ssantosh@kernel.org>
Cc: Tero Kristo <kristo@kernel.org>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent a15de032
...@@ -88,6 +88,7 @@ struct omap_reset_data { ...@@ -88,6 +88,7 @@ struct omap_reset_data {
#define OMAP_PRM_HAS_RSTCTRL BIT(0) #define OMAP_PRM_HAS_RSTCTRL BIT(0)
#define OMAP_PRM_HAS_RSTST BIT(1) #define OMAP_PRM_HAS_RSTST BIT(1)
#define OMAP_PRM_HAS_NO_CLKDM BIT(2) #define OMAP_PRM_HAS_NO_CLKDM BIT(2)
#define OMAP_PRM_RET_WHEN_IDLE BIT(3)
#define OMAP_PRM_HAS_RESETS (OMAP_PRM_HAS_RSTCTRL | OMAP_PRM_HAS_RSTST) #define OMAP_PRM_HAS_RESETS (OMAP_PRM_HAS_RSTCTRL | OMAP_PRM_HAS_RSTST)
...@@ -174,7 +175,8 @@ static const struct omap_prm_data omap4_prm_data[] = { ...@@ -174,7 +175,8 @@ static const struct omap_prm_data omap4_prm_data[] = {
.name = "core", .base = 0x4a306700, .name = "core", .base = 0x4a306700,
.pwrstctrl = 0x0, .pwrstst = 0x4, .dmap = &omap_prm_reton, .pwrstctrl = 0x0, .pwrstst = 0x4, .dmap = &omap_prm_reton,
.rstctrl = 0x210, .rstst = 0x214, .clkdm_name = "ducati", .rstctrl = 0x210, .rstst = 0x214, .clkdm_name = "ducati",
.rstmap = rst_map_012 .rstmap = rst_map_012,
.flags = OMAP_PRM_RET_WHEN_IDLE,
}, },
{ {
.name = "ivahd", .base = 0x4a306f00, .name = "ivahd", .base = 0x4a306f00,
...@@ -199,7 +201,8 @@ static const struct omap_prm_data omap4_prm_data[] = { ...@@ -199,7 +201,8 @@ static const struct omap_prm_data omap4_prm_data[] = {
}, },
{ {
.name = "l4per", .base = 0x4a307400, .name = "l4per", .base = 0x4a307400,
.pwrstctrl = 0x0, .pwrstst = 0x4, .dmap = &omap_prm_reton .pwrstctrl = 0x0, .pwrstst = 0x4, .dmap = &omap_prm_reton,
.flags = OMAP_PRM_RET_WHEN_IDLE,
}, },
{ {
.name = "cefuse", .base = 0x4a307600, .name = "cefuse", .base = 0x4a307600,
...@@ -517,7 +520,7 @@ static int omap_prm_domain_power_on(struct generic_pm_domain *domain) ...@@ -517,7 +520,7 @@ static int omap_prm_domain_power_on(struct generic_pm_domain *domain)
{ {
struct omap_prm_domain *prmd; struct omap_prm_domain *prmd;
int ret; int ret;
u32 v; u32 v, mode;
prmd = genpd_to_prm_domain(domain); prmd = genpd_to_prm_domain(domain);
if (!prmd->cap) if (!prmd->cap)
...@@ -530,7 +533,12 @@ static int omap_prm_domain_power_on(struct generic_pm_domain *domain) ...@@ -530,7 +533,12 @@ static int omap_prm_domain_power_on(struct generic_pm_domain *domain)
else else
v = readl_relaxed(prmd->prm->base + prmd->pwrstctrl); v = readl_relaxed(prmd->prm->base + prmd->pwrstctrl);
writel_relaxed(v | OMAP_PRMD_ON_ACTIVE, if (prmd->prm->data->flags & OMAP_PRM_RET_WHEN_IDLE)
mode = OMAP_PRMD_RETENTION;
else
mode = OMAP_PRMD_ON_ACTIVE;
writel_relaxed((v & ~PRM_POWERSTATE_MASK) | mode,
prmd->prm->base + prmd->pwrstctrl); prmd->prm->base + prmd->pwrstctrl);
/* wait for the transition bit to get cleared */ /* wait for the transition bit to get cleared */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment