|
@@ -89,6 +89,7 @@ struct imx6_pm_base {
|
|
|
|
|
|
struct imx6_pm_socdata {
|
|
struct imx6_pm_socdata {
|
|
u32 ddr_type;
|
|
u32 ddr_type;
|
|
|
|
+ const char *ccm_compat;
|
|
const char *mmdc_compat;
|
|
const char *mmdc_compat;
|
|
const char *src_compat;
|
|
const char *src_compat;
|
|
const char *iomuxc_compat;
|
|
const char *iomuxc_compat;
|
|
@@ -138,6 +139,7 @@ static const u32 imx6sx_mmdc_io_offset[] __initconst = {
|
|
};
|
|
};
|
|
|
|
|
|
static const struct imx6_pm_socdata imx6q_pm_data __initconst = {
|
|
static const struct imx6_pm_socdata imx6q_pm_data __initconst = {
|
|
|
|
+ .ccm_compat = "fsl,imx6q-ccm",
|
|
.mmdc_compat = "fsl,imx6q-mmdc",
|
|
.mmdc_compat = "fsl,imx6q-mmdc",
|
|
.src_compat = "fsl,imx6q-src",
|
|
.src_compat = "fsl,imx6q-src",
|
|
.iomuxc_compat = "fsl,imx6q-iomuxc",
|
|
.iomuxc_compat = "fsl,imx6q-iomuxc",
|
|
@@ -147,6 +149,7 @@ static const struct imx6_pm_socdata imx6q_pm_data __initconst = {
|
|
};
|
|
};
|
|
|
|
|
|
static const struct imx6_pm_socdata imx6dl_pm_data __initconst = {
|
|
static const struct imx6_pm_socdata imx6dl_pm_data __initconst = {
|
|
|
|
+ .ccm_compat = "fsl,imx6q-ccm",
|
|
.mmdc_compat = "fsl,imx6q-mmdc",
|
|
.mmdc_compat = "fsl,imx6q-mmdc",
|
|
.src_compat = "fsl,imx6q-src",
|
|
.src_compat = "fsl,imx6q-src",
|
|
.iomuxc_compat = "fsl,imx6dl-iomuxc",
|
|
.iomuxc_compat = "fsl,imx6dl-iomuxc",
|
|
@@ -156,6 +159,7 @@ static const struct imx6_pm_socdata imx6dl_pm_data __initconst = {
|
|
};
|
|
};
|
|
|
|
|
|
static const struct imx6_pm_socdata imx6sl_pm_data __initconst = {
|
|
static const struct imx6_pm_socdata imx6sl_pm_data __initconst = {
|
|
|
|
+ .ccm_compat = "fsl,imx6sl-ccm",
|
|
.mmdc_compat = "fsl,imx6sl-mmdc",
|
|
.mmdc_compat = "fsl,imx6sl-mmdc",
|
|
.src_compat = "fsl,imx6sl-src",
|
|
.src_compat = "fsl,imx6sl-src",
|
|
.iomuxc_compat = "fsl,imx6sl-iomuxc",
|
|
.iomuxc_compat = "fsl,imx6sl-iomuxc",
|
|
@@ -165,6 +169,7 @@ static const struct imx6_pm_socdata imx6sl_pm_data __initconst = {
|
|
};
|
|
};
|
|
|
|
|
|
static const struct imx6_pm_socdata imx6sx_pm_data __initconst = {
|
|
static const struct imx6_pm_socdata imx6sx_pm_data __initconst = {
|
|
|
|
+ .ccm_compat = "fsl,imx6sx-ccm",
|
|
.mmdc_compat = "fsl,imx6sx-mmdc",
|
|
.mmdc_compat = "fsl,imx6sx-mmdc",
|
|
.src_compat = "fsl,imx6sx-src",
|
|
.src_compat = "fsl,imx6sx-src",
|
|
.iomuxc_compat = "fsl,imx6sx-iomuxc",
|
|
.iomuxc_compat = "fsl,imx6sx-iomuxc",
|
|
@@ -392,11 +397,6 @@ static const struct platform_suspend_ops imx6q_pm_ops = {
|
|
.valid = imx6q_pm_valid,
|
|
.valid = imx6q_pm_valid,
|
|
};
|
|
};
|
|
|
|
|
|
-void __init imx6q_pm_set_ccm_base(void __iomem *base)
|
|
|
|
-{
|
|
|
|
- ccm_base = base;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
static int __init imx6_pm_get_base(struct imx6_pm_base *base,
|
|
static int __init imx6_pm_get_base(struct imx6_pm_base *base,
|
|
const char *compat)
|
|
const char *compat)
|
|
{
|
|
{
|
|
@@ -482,8 +482,7 @@ static int __init imx6q_suspend_init(const struct imx6_pm_socdata *socdata)
|
|
|
|
|
|
/*
|
|
/*
|
|
* ccm physical address is not used by asm code currently,
|
|
* ccm physical address is not used by asm code currently,
|
|
- * so get ccm virtual address directly, as we already have
|
|
|
|
- * it from ccm driver.
|
|
|
|
|
|
+ * so get ccm virtual address directly.
|
|
*/
|
|
*/
|
|
pm_info->ccm_base.vbase = ccm_base;
|
|
pm_info->ccm_base.vbase = ccm_base;
|
|
|
|
|
|
@@ -554,9 +553,12 @@ put_node:
|
|
static void __init imx6_pm_common_init(const struct imx6_pm_socdata
|
|
static void __init imx6_pm_common_init(const struct imx6_pm_socdata
|
|
*socdata)
|
|
*socdata)
|
|
{
|
|
{
|
|
|
|
+ struct device_node *np;
|
|
struct regmap *gpr;
|
|
struct regmap *gpr;
|
|
int ret;
|
|
int ret;
|
|
|
|
|
|
|
|
+ np = of_find_compatible_node(NULL, NULL, socdata->ccm_compat);
|
|
|
|
+ ccm_base = of_iomap(np, 0);
|
|
WARN_ON(!ccm_base);
|
|
WARN_ON(!ccm_base);
|
|
|
|
|
|
imx6_set_lpm(WAIT_CLOCKED);
|
|
imx6_set_lpm(WAIT_CLOCKED);
|