diff options
author | Arnd Bergmann <arnd@arndb.de> | 2016-11-30 10:39:48 -0500 |
---|---|---|
committer | Arnd Bergmann <arnd@arndb.de> | 2016-11-30 10:39:48 -0500 |
commit | d319fc6dc1bfb616d4d90e04967f9ec8f08d52d8 (patch) | |
tree | 8e41a2a7f6041ace560d5cf5b3ab20b17865ecbf | |
parent | 2aa488a6bc6a13d7aed6dbcfa5aab31ec09eaeba (diff) | |
parent | 141723e0cbdc1139410f77d8a572f17ce2de6bf5 (diff) |
Merge tag 'renesas-r8a7745-sysc-for-v4.10' of git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas into next/drivers
Pull "Renesas ARM Based SoC r8a7745 SYSC Driver Updates for v4.10" from Simon Horman:
* Add support for the r8a7745 SoC to rcar-sysc
* tag 'renesas-r8a7745-sysc-for-v4.10' of git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas:
soc: renesas: rcar-sysc: add R8A7745 support
ARM: shmobile: r8a7745: add power domain index macros
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
-rw-r--r-- | Documentation/devicetree/bindings/power/renesas,rcar-sysc.txt | 1 | ||||
-rw-r--r-- | drivers/soc/renesas/Makefile | 1 | ||||
-rw-r--r-- | drivers/soc/renesas/r8a7745-sysc.c | 32 | ||||
-rw-r--r-- | drivers/soc/renesas/rcar-sysc.c | 3 | ||||
-rw-r--r-- | drivers/soc/renesas/rcar-sysc.h | 1 | ||||
-rw-r--r-- | include/dt-bindings/power/r8a7745-sysc.h | 25 |
6 files changed, 63 insertions, 0 deletions
diff --git a/Documentation/devicetree/bindings/power/renesas,rcar-sysc.txt b/Documentation/devicetree/bindings/power/renesas,rcar-sysc.txt index c16ec1866ac4..d91715bc8d52 100644 --- a/Documentation/devicetree/bindings/power/renesas,rcar-sysc.txt +++ b/Documentation/devicetree/bindings/power/renesas,rcar-sysc.txt | |||
@@ -8,6 +8,7 @@ and various coprocessors. | |||
8 | Required properties: | 8 | Required properties: |
9 | - compatible: Must contain exactly one of the following: | 9 | - compatible: Must contain exactly one of the following: |
10 | - "renesas,r8a7743-sysc" (RZ/G1M) | 10 | - "renesas,r8a7743-sysc" (RZ/G1M) |
11 | - "renesas,r8a7745-sysc" (RZ/G1E) | ||
11 | - "renesas,r8a7779-sysc" (R-Car H1) | 12 | - "renesas,r8a7779-sysc" (R-Car H1) |
12 | - "renesas,r8a7790-sysc" (R-Car H2) | 13 | - "renesas,r8a7790-sysc" (R-Car H2) |
13 | - "renesas,r8a7791-sysc" (R-Car M2-W) | 14 | - "renesas,r8a7791-sysc" (R-Car M2-W) |
diff --git a/drivers/soc/renesas/Makefile b/drivers/soc/renesas/Makefile index 9e0bb329594c..e2249f01b2de 100644 --- a/drivers/soc/renesas/Makefile +++ b/drivers/soc/renesas/Makefile | |||
@@ -1,4 +1,5 @@ | |||
1 | obj-$(CONFIG_ARCH_R8A7743) += rcar-sysc.o r8a7743-sysc.o | 1 | obj-$(CONFIG_ARCH_R8A7743) += rcar-sysc.o r8a7743-sysc.o |
2 | obj-$(CONFIG_ARCH_R8A7745) += rcar-sysc.o r8a7745-sysc.o | ||
2 | obj-$(CONFIG_ARCH_R8A7779) += rcar-sysc.o r8a7779-sysc.o | 3 | obj-$(CONFIG_ARCH_R8A7779) += rcar-sysc.o r8a7779-sysc.o |
3 | obj-$(CONFIG_ARCH_R8A7790) += rcar-sysc.o r8a7790-sysc.o | 4 | obj-$(CONFIG_ARCH_R8A7790) += rcar-sysc.o r8a7790-sysc.o |
4 | obj-$(CONFIG_ARCH_R8A7791) += rcar-sysc.o r8a7791-sysc.o | 5 | obj-$(CONFIG_ARCH_R8A7791) += rcar-sysc.o r8a7791-sysc.o |
diff --git a/drivers/soc/renesas/r8a7745-sysc.c b/drivers/soc/renesas/r8a7745-sysc.c new file mode 100644 index 000000000000..d17887c08aa1 --- /dev/null +++ b/drivers/soc/renesas/r8a7745-sysc.c | |||
@@ -0,0 +1,32 @@ | |||
1 | /* | ||
2 | * Renesas RZ/G1E System Controller | ||
3 | * | ||
4 | * Copyright (C) 2016 Cogent Embedded Inc. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation; of the License. | ||
9 | */ | ||
10 | |||
11 | #include <linux/bug.h> | ||
12 | #include <linux/kernel.h> | ||
13 | |||
14 | #include <dt-bindings/power/r8a7745-sysc.h> | ||
15 | |||
16 | #include "rcar-sysc.h" | ||
17 | |||
18 | static const struct rcar_sysc_area r8a7745_areas[] __initconst = { | ||
19 | { "always-on", 0, 0, R8A7745_PD_ALWAYS_ON, -1, PD_ALWAYS_ON }, | ||
20 | { "ca7-scu", 0x100, 0, R8A7745_PD_CA7_SCU, R8A7745_PD_ALWAYS_ON, | ||
21 | PD_SCU }, | ||
22 | { "ca7-cpu0", 0x1c0, 0, R8A7745_PD_CA7_CPU0, R8A7745_PD_CA7_SCU, | ||
23 | PD_CPU_NOCR }, | ||
24 | { "ca7-cpu1", 0x1c0, 1, R8A7745_PD_CA7_CPU1, R8A7745_PD_CA7_SCU, | ||
25 | PD_CPU_NOCR }, | ||
26 | { "sgx", 0xc0, 0, R8A7745_PD_SGX, R8A7745_PD_ALWAYS_ON }, | ||
27 | }; | ||
28 | |||
29 | const struct rcar_sysc_info r8a7745_sysc_info __initconst = { | ||
30 | .areas = r8a7745_areas, | ||
31 | .num_areas = ARRAY_SIZE(r8a7745_areas), | ||
32 | }; | ||
diff --git a/drivers/soc/renesas/rcar-sysc.c b/drivers/soc/renesas/rcar-sysc.c index 71acd45b13f0..225c35c79d9a 100644 --- a/drivers/soc/renesas/rcar-sysc.c +++ b/drivers/soc/renesas/rcar-sysc.c | |||
@@ -278,6 +278,9 @@ static const struct of_device_id rcar_sysc_matches[] = { | |||
278 | #ifdef CONFIG_ARCH_R8A7743 | 278 | #ifdef CONFIG_ARCH_R8A7743 |
279 | { .compatible = "renesas,r8a7743-sysc", .data = &r8a7743_sysc_info }, | 279 | { .compatible = "renesas,r8a7743-sysc", .data = &r8a7743_sysc_info }, |
280 | #endif | 280 | #endif |
281 | #ifdef CONFIG_ARCH_R8A7745 | ||
282 | { .compatible = "renesas,r8a7745-sysc", .data = &r8a7745_sysc_info }, | ||
283 | #endif | ||
281 | #ifdef CONFIG_ARCH_R8A7779 | 284 | #ifdef CONFIG_ARCH_R8A7779 |
282 | { .compatible = "renesas,r8a7779-sysc", .data = &r8a7779_sysc_info }, | 285 | { .compatible = "renesas,r8a7779-sysc", .data = &r8a7779_sysc_info }, |
283 | #endif | 286 | #endif |
diff --git a/drivers/soc/renesas/rcar-sysc.h b/drivers/soc/renesas/rcar-sysc.h index 8ab9ca8a825a..f6e842e2976e 100644 --- a/drivers/soc/renesas/rcar-sysc.h +++ b/drivers/soc/renesas/rcar-sysc.h | |||
@@ -51,6 +51,7 @@ struct rcar_sysc_info { | |||
51 | }; | 51 | }; |
52 | 52 | ||
53 | extern const struct rcar_sysc_info r8a7743_sysc_info; | 53 | extern const struct rcar_sysc_info r8a7743_sysc_info; |
54 | extern const struct rcar_sysc_info r8a7745_sysc_info; | ||
54 | extern const struct rcar_sysc_info r8a7779_sysc_info; | 55 | extern const struct rcar_sysc_info r8a7779_sysc_info; |
55 | extern const struct rcar_sysc_info r8a7790_sysc_info; | 56 | extern const struct rcar_sysc_info r8a7790_sysc_info; |
56 | extern const struct rcar_sysc_info r8a7791_sysc_info; | 57 | extern const struct rcar_sysc_info r8a7791_sysc_info; |
diff --git a/include/dt-bindings/power/r8a7745-sysc.h b/include/dt-bindings/power/r8a7745-sysc.h new file mode 100644 index 000000000000..1844c1171c04 --- /dev/null +++ b/include/dt-bindings/power/r8a7745-sysc.h | |||
@@ -0,0 +1,25 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2016 Cogent Embedded Inc. | ||
3 | * | ||
4 | * This program is free software; you can redistribute it and/or modify | ||
5 | * it under the terms of the GNU General Public License version 2 as | ||
6 | * published by the Free Software Foundation. | ||
7 | */ | ||
8 | #ifndef __DT_BINDINGS_POWER_R8A7745_SYSC_H__ | ||
9 | #define __DT_BINDINGS_POWER_R8A7745_SYSC_H__ | ||
10 | |||
11 | /* | ||
12 | * These power domain indices match the numbers of the interrupt bits | ||
13 | * representing the power areas in the various Interrupt Registers | ||
14 | * (e.g. SYSCISR, Interrupt Status Register) | ||
15 | */ | ||
16 | |||
17 | #define R8A7745_PD_CA7_CPU0 5 | ||
18 | #define R8A7745_PD_CA7_CPU1 6 | ||
19 | #define R8A7745_PD_SGX 20 | ||
20 | #define R8A7745_PD_CA7_SCU 21 | ||
21 | |||
22 | /* Always-on power area */ | ||
23 | #define R8A7745_PD_ALWAYS_ON 32 | ||
24 | |||
25 | #endif /* __DT_BINDINGS_POWER_R8A7745_SYSC_H__ */ | ||