Commit e7cc455f authored by Rajendra Nayak's avatar Rajendra Nayak Committed by Stephen Boyd

clk: qcom: Handle the clamp_io assert/deassert sequence

Add a flag to mark gdscs which need to support the clamp deassert/assert
before and after the gdsc enable/disable
Signed-off-by: default avatarRajendra Nayak <rnayak@codeaurora.org>
Signed-off-by: default avatarStephen Boyd <sboyd@codeaurora.org>
parent c5a8045a
...@@ -30,6 +30,7 @@ ...@@ -30,6 +30,7 @@
#define SW_OVERRIDE_MASK BIT(2) #define SW_OVERRIDE_MASK BIT(2)
#define HW_CONTROL_MASK BIT(1) #define HW_CONTROL_MASK BIT(1)
#define SW_COLLAPSE_MASK BIT(0) #define SW_COLLAPSE_MASK BIT(0)
#define GMEM_CLAMP_IO_MASK BIT(0)
/* Wait 2^n CXO cycles between all states. Here, n=2 (4 cycles). */ /* Wait 2^n CXO cycles between all states. Here, n=2 (4 cycles). */
#define EN_REST_WAIT_VAL (0x2 << 20) #define EN_REST_WAIT_VAL (0x2 << 20)
...@@ -140,6 +141,18 @@ static inline void gdsc_clear_mem_on(struct gdsc *sc) ...@@ -140,6 +141,18 @@ static inline void gdsc_clear_mem_on(struct gdsc *sc)
regmap_update_bits(sc->regmap, sc->cxcs[i], mask, 0); regmap_update_bits(sc->regmap, sc->cxcs[i], mask, 0);
} }
static inline void gdsc_deassert_clamp_io(struct gdsc *sc)
{
regmap_update_bits(sc->regmap, sc->clamp_io_ctrl,
GMEM_CLAMP_IO_MASK, 0);
}
static inline void gdsc_assert_clamp_io(struct gdsc *sc)
{
regmap_update_bits(sc->regmap, sc->clamp_io_ctrl,
GMEM_CLAMP_IO_MASK, 1);
}
static int gdsc_enable(struct generic_pm_domain *domain) static int gdsc_enable(struct generic_pm_domain *domain)
{ {
struct gdsc *sc = domain_to_gdsc(domain); struct gdsc *sc = domain_to_gdsc(domain);
...@@ -148,6 +161,9 @@ static int gdsc_enable(struct generic_pm_domain *domain) ...@@ -148,6 +161,9 @@ static int gdsc_enable(struct generic_pm_domain *domain)
if (sc->pwrsts == PWRSTS_ON) if (sc->pwrsts == PWRSTS_ON)
return gdsc_deassert_reset(sc); return gdsc_deassert_reset(sc);
if (sc->flags & CLAMP_IO)
gdsc_deassert_clamp_io(sc);
ret = gdsc_toggle_logic(sc, true); ret = gdsc_toggle_logic(sc, true);
if (ret) if (ret)
return ret; return ret;
...@@ -170,6 +186,7 @@ static int gdsc_enable(struct generic_pm_domain *domain) ...@@ -170,6 +186,7 @@ static int gdsc_enable(struct generic_pm_domain *domain)
static int gdsc_disable(struct generic_pm_domain *domain) static int gdsc_disable(struct generic_pm_domain *domain)
{ {
struct gdsc *sc = domain_to_gdsc(domain); struct gdsc *sc = domain_to_gdsc(domain);
int ret;
if (sc->pwrsts == PWRSTS_ON) if (sc->pwrsts == PWRSTS_ON)
return gdsc_assert_reset(sc); return gdsc_assert_reset(sc);
...@@ -177,7 +194,14 @@ static int gdsc_disable(struct generic_pm_domain *domain) ...@@ -177,7 +194,14 @@ static int gdsc_disable(struct generic_pm_domain *domain)
if (sc->pwrsts & PWRSTS_OFF) if (sc->pwrsts & PWRSTS_OFF)
gdsc_clear_mem_on(sc); gdsc_clear_mem_on(sc);
return gdsc_toggle_logic(sc, false); ret = gdsc_toggle_logic(sc, false);
if (ret)
return ret;
if (sc->flags & CLAMP_IO)
gdsc_assert_clamp_io(sc);
return 0;
} }
static int gdsc_init(struct gdsc *sc) static int gdsc_init(struct gdsc *sc)
......
...@@ -39,6 +39,7 @@ struct gdsc { ...@@ -39,6 +39,7 @@ struct gdsc {
struct regmap *regmap; struct regmap *regmap;
unsigned int gdscr; unsigned int gdscr;
unsigned int gds_hw_ctrl; unsigned int gds_hw_ctrl;
unsigned int clamp_io_ctrl;
unsigned int *cxcs; unsigned int *cxcs;
unsigned int cxc_count; unsigned int cxc_count;
const u8 pwrsts; const u8 pwrsts;
...@@ -50,6 +51,7 @@ struct gdsc { ...@@ -50,6 +51,7 @@ struct gdsc {
#define PWRSTS_RET_ON (PWRSTS_RET | PWRSTS_ON) #define PWRSTS_RET_ON (PWRSTS_RET | PWRSTS_ON)
const u8 flags; const u8 flags;
#define VOTABLE BIT(0) #define VOTABLE BIT(0)
#define CLAMP_IO BIT(1)
struct reset_controller_dev *rcdev; struct reset_controller_dev *rcdev;
unsigned int *resets; unsigned int *resets;
unsigned int reset_count; unsigned int reset_count;
......
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