diff mbox series

[v2,4/4] soc: samsung: pm_domains: Provide real name for all supported domains

Message ID 1485528538-30256-1-git-send-email-m.szyprowski@samsung.com
State New
Headers show
Series None | expand

Commit Message

Marek Szyprowski Jan. 27, 2017, 2:48 p.m. UTC
Device tree nodes for each power domain should use generic "power-domain"
name, so using it as a domain name doesn't give much benefits. This patch
adds human readable names for all supported domains, what makes debugging
much easier.

Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>

---
Changelog:
v2:
- sorted all domains data by domain base address in the arrays
---
 drivers/soc/samsung/pm_domains.c | 125 ++++++++++++++++++++++++++++++++++++++-
 1 file changed, 123 insertions(+), 2 deletions(-)

-- 
1.9.1

--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Comments

Krzysztof Kozlowski Jan. 28, 2017, 3:16 p.m. UTC | #1
On Fri, Jan 27, 2017 at 03:48:58PM +0100, Marek Szyprowski wrote:
> Device tree nodes for each power domain should use generic "power-domain"

> name, so using it as a domain name doesn't give much benefits. This patch

> adds human readable names for all supported domains, what makes debugging

> much easier.

> 

> Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>

> ---

> Changelog:

> v2:

> - sorted all domains data by domain base address in the arrays

> ---

>  drivers/soc/samsung/pm_domains.c | 125 ++++++++++++++++++++++++++++++++++++++-

>  1 file changed, 123 insertions(+), 2 deletions(-)

> 

> diff --git a/drivers/soc/samsung/pm_domains.c b/drivers/soc/samsung/pm_domains.c

> index 5a0a46bcbe18..43003318b948 100644

> --- a/drivers/soc/samsung/pm_domains.c

> +++ b/drivers/soc/samsung/pm_domains.c

> @@ -30,6 +30,17 @@ struct exynos_pm_domain_config {

>  	u32 local_pwr_cfg;

>  };

>  

> +struct exynos_pm_domain_data {

> +	const char *name;

> +	u32 base;

> +};

> +

> +struct exynos_pm_domain_soc_data {

> +	const char *compatible;

> +	unsigned int nr_domains;

> +	const struct exynos_pm_domain_data *domains;

> +};

> +

>  /*

>   * Exynos specific wrapper around the generic power domain

>   */

> @@ -123,6 +134,91 @@ static int exynos_pd_power_off(struct generic_pm_domain *domain)

>  	return exynos_pd_power(domain, false);

>  }

>  

> +static const struct exynos_pm_domain_data exynos4210_domains[] __initconst = {

> +	{ "LCD1",	0x10023CA0 },

> +};

> +

> +static const struct exynos_pm_domain_data exynos4412_domains[] __initconst = {

> +	{ "CAM",	0x10023C00 },

> +	{ "TV",		0x10023C20 },

> +	{ "MFC",	0x10023C40 },

> +	{ "G3D",	0x10023C60 },

> +	{ "LCD0",	0x10023C80 },

> +	{ "ISP",	0x10023CA0 },

> +	{ "GPS",	0x10023CE0 },

> +	{ "GPS alive",	0x10023D00 },


That is a kind of duplication of DT and also spreading the description
of hardware between DT and driver. I understand the purpose. Messages
like:
	"power-domain has as child subdomain: power-domain."
are useless. However I do not like putting any of these in the driver.

How about adding a property "label" and parse it? Some other
drivers/nodes are using labels already to have a meaningful name, either
for user-space or for just user.

Patches 1-3 look fine.

Best regards,
Krzysztof
--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Marek Szyprowski Jan. 30, 2017, 10:41 a.m. UTC | #2
Hi Krzysztof,

On 2017-01-28 16:16, Krzysztof Kozlowski wrote:
> On Fri, Jan 27, 2017 at 03:48:58PM +0100, Marek Szyprowski wrote:

>> Device tree nodes for each power domain should use generic "power-domain"

>> name, so using it as a domain name doesn't give much benefits. This patch

>> adds human readable names for all supported domains, what makes debugging

>> much easier.

>>

>> Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>

>> ---

>> Changelog:

>> v2:

>> - sorted all domains data by domain base address in the arrays

>> ---

>>   drivers/soc/samsung/pm_domains.c | 125 ++++++++++++++++++++++++++++++++++++++-

>>   1 file changed, 123 insertions(+), 2 deletions(-)

>>

>> diff --git a/drivers/soc/samsung/pm_domains.c b/drivers/soc/samsung/pm_domains.c

>> index 5a0a46bcbe18..43003318b948 100644

>> --- a/drivers/soc/samsung/pm_domains.c

>> +++ b/drivers/soc/samsung/pm_domains.c

>> @@ -30,6 +30,17 @@ struct exynos_pm_domain_config {

>>   	u32 local_pwr_cfg;

>>   };

>>   

>> +struct exynos_pm_domain_data {

>> +	const char *name;

>> +	u32 base;

>> +};

>> +

>> +struct exynos_pm_domain_soc_data {

>> +	const char *compatible;

>> +	unsigned int nr_domains;

>> +	const struct exynos_pm_domain_data *domains;

>> +};

>> +

>>   /*

>>    * Exynos specific wrapper around the generic power domain

>>    */

>> @@ -123,6 +134,91 @@ static int exynos_pd_power_off(struct generic_pm_domain *domain)

>>   	return exynos_pd_power(domain, false);

>>   }

>>   

>> +static const struct exynos_pm_domain_data exynos4210_domains[] __initconst = {

>> +	{ "LCD1",	0x10023CA0 },

>> +};

>> +

>> +static const struct exynos_pm_domain_data exynos4412_domains[] __initconst = {

>> +	{ "CAM",	0x10023C00 },

>> +	{ "TV",		0x10023C20 },

>> +	{ "MFC",	0x10023C40 },

>> +	{ "G3D",	0x10023C60 },

>> +	{ "LCD0",	0x10023C80 },

>> +	{ "ISP",	0x10023CA0 },

>> +	{ "GPS",	0x10023CE0 },

>> +	{ "GPS alive",	0x10023D00 },

> That is a kind of duplication of DT and also spreading the description

> of hardware between DT and driver. I understand the purpose. Messages

> like:

> 	"power-domain has as child subdomain: power-domain."

> are useless. However I do not like putting any of these in the driver.

>

> How about adding a property "label" and parse it? Some other

> drivers/nodes are using labels already to have a meaningful name, either

> for user-space or for just user.

>

> Patches 1-3 look fine.


Okay, I will prepare a new patchset, which rely on 'label' property.

Best regards
-- 
Marek Szyprowski, PhD
Samsung R&D Institute Poland

--
To unsubscribe from this list: send the line "unsubscribe linux-pm" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox series

Patch

diff --git a/drivers/soc/samsung/pm_domains.c b/drivers/soc/samsung/pm_domains.c
index 5a0a46bcbe18..43003318b948 100644
--- a/drivers/soc/samsung/pm_domains.c
+++ b/drivers/soc/samsung/pm_domains.c
@@ -30,6 +30,17 @@  struct exynos_pm_domain_config {
 	u32 local_pwr_cfg;
 };
 
+struct exynos_pm_domain_data {
+	const char *name;
+	u32 base;
+};
+
+struct exynos_pm_domain_soc_data {
+	const char *compatible;
+	unsigned int nr_domains;
+	const struct exynos_pm_domain_data *domains;
+};
+
 /*
  * Exynos specific wrapper around the generic power domain
  */
@@ -123,6 +134,91 @@  static int exynos_pd_power_off(struct generic_pm_domain *domain)
 	return exynos_pd_power(domain, false);
 }
 
+static const struct exynos_pm_domain_data exynos4210_domains[] __initconst = {
+	{ "LCD1",	0x10023CA0 },
+};
+
+static const struct exynos_pm_domain_data exynos4412_domains[] __initconst = {
+	{ "CAM",	0x10023C00 },
+	{ "TV",		0x10023C20 },
+	{ "MFC",	0x10023C40 },
+	{ "G3D",	0x10023C60 },
+	{ "LCD0",	0x10023C80 },
+	{ "ISP",	0x10023CA0 },
+	{ "GPS",	0x10023CE0 },
+	{ "GPS alive",	0x10023D00 },
+};
+
+static const struct exynos_pm_domain_data exynos5250_domains[] __initconst = {
+	{ "GSCL",	0x10044000 },
+	{ "ISP",	0x10044020 },
+	{ "MFC",	0x10044040 },
+	{ "G3D",	0x10044060 },
+	{ "DISP1",	0x100440A0 },
+	{ "MAU",	0x100440C0 },
+};
+
+static const struct exynos_pm_domain_data exynos542x_domains[] __initconst = {
+	{ "SCALER",	0x10044000 },
+	{ "ISP",	0x10044020 },
+	{ "MFC",	0x10044060 },
+	{ "G3D",	0x10044080 },
+	{ "DISP1",	0x100440C0 },
+	{ "MAU",	0x100440E0 },
+	{ "G2D",	0x10044100 },
+	{ "MSCL",	0x10044120 },
+	{ "FSYS",	0x10044140 },
+	{ "PERIC",	0x100441A0 },
+	{ "CAM",	0x10045100 },
+};
+
+static const struct exynos_pm_domain_data exynos5433_domains[] __initconst = {
+	{ "GSCL",	0x105c4000 },
+	{ "CAM0",	0x105c4020 },
+	{ "MSCL",	0x105c4040 },
+	{ "G3D",	0x105c4060 },
+	{ "DISP",	0x105c4080 },
+	{ "CAM1",	0x105c40a0 },
+	{ "AUD",	0x105c40c0 },
+	{ "FSYS",	0x105c40e0 },
+	{ "G2D",	0x105c4120 },
+	{ "ISP",	0x105c4140 },
+	{ "MFC",	0x105c4180 },
+	{ "HEVC",	0x105c41c0 },
+};
+
+static const struct exynos_pm_domain_soc_data soc_domains_data[] __initconst = {
+	{ /* Exynos3250 uses a subset of 4412 domains */
+		.compatible = "samsung,exynos3250",
+		.nr_domains = ARRAY_SIZE(exynos4412_domains),
+		.domains = exynos4412_domains,
+	}, { /* first check samsung,exynos4210 to detect LCD1 domain */
+		.compatible = "samsung,exynos4210",
+		.nr_domains = ARRAY_SIZE(exynos4210_domains),
+		.domains = exynos4210_domains,
+	}, { /* remaining domains for Exynos4210 and 4412 */
+		.compatible = "samsung,exynos4",
+		.nr_domains = ARRAY_SIZE(exynos4412_domains),
+		.domains = exynos4412_domains
+	}, {
+		.compatible = "samsung,exynos5250",
+		.nr_domains = ARRAY_SIZE(exynos5250_domains),
+		.domains = exynos5250_domains,
+	}, {
+		.compatible = "samsung,exynos5420",
+		.nr_domains = ARRAY_SIZE(exynos542x_domains),
+		.domains = exynos542x_domains,
+	}, {
+		.compatible = "samsung,exynos5800",
+		.nr_domains = ARRAY_SIZE(exynos542x_domains),
+		.domains = exynos542x_domains,
+	}, {
+		.compatible = "samsung,exynos5433",
+		.nr_domains = ARRAY_SIZE(exynos5433_domains),
+		.domains = exynos5433_domains,
+	},
+};
+
 static const struct exynos_pm_domain_config exynos4210_cfg __initconst = {
 	.local_pwr_cfg		= 0x7,
 };
@@ -142,6 +238,32 @@  static int exynos_pd_power_off(struct generic_pm_domain *domain)
 	{ },
 };
 
+static __init const char *exynos_get_domain_name(struct device_node *np)
+{
+	const struct exynos_pm_domain_soc_data *soc = soc_domains_data;
+	const __be32 *reg;
+	u64 addr;
+	int i, j;
+
+
+	reg = of_get_property(np, "reg", NULL);
+	if (!reg || (addr = of_translate_address(np, reg)) == OF_BAD_ADDR)
+		goto not_found;
+
+	for (i = 0; i < ARRAY_SIZE(soc_domains_data); i++, soc++) {
+		if (!of_machine_is_compatible(soc->compatible))
+			continue;
+
+		for (j = 0; j < soc->nr_domains; j++) {
+			if (soc->domains[j].base == addr)
+				return kstrdup_const(soc->domains[j].name,
+						     GFP_KERNEL);
+		}
+	}
+not_found:
+	return kstrdup_const(strrchr(np->full_name, '/') + 1, GFP_KERNEL);
+}
+
 static __init int exynos4_pm_init_power_domain(void)
 {
 	struct device_node *np;
@@ -159,8 +281,7 @@  static __init int exynos4_pm_init_power_domain(void)
 			of_node_put(np);
 			return -ENOMEM;
 		}
-		pd->pd.name = kstrdup_const(strrchr(np->full_name, '/') + 1,
-					    GFP_KERNEL);
+		pd->pd.name = exynos_get_domain_name(np);
 		if (!pd->pd.name) {
 			kfree(pd);
 			of_node_put(np);