aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArnd Bergmann <arnd@arndb.de>2016-11-30 10:39:48 -0500
committerArnd Bergmann <arnd@arndb.de>2016-11-30 10:39:48 -0500
commitd319fc6dc1bfb616d4d90e04967f9ec8f08d52d8 (patch)
tree8e41a2a7f6041ace560d5cf5b3ab20b17865ecbf
parent2aa488a6bc6a13d7aed6dbcfa5aab31ec09eaeba (diff)
parent141723e0cbdc1139410f77d8a572f17ce2de6bf5 (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.txt1
-rw-r--r--drivers/soc/renesas/Makefile1
-rw-r--r--drivers/soc/renesas/r8a7745-sysc.c32
-rw-r--r--drivers/soc/renesas/rcar-sysc.c3
-rw-r--r--drivers/soc/renesas/rcar-sysc.h1
-rw-r--r--include/dt-bindings/power/r8a7745-sysc.h25
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.
8Required properties: 8Required 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 @@
1obj-$(CONFIG_ARCH_R8A7743) += rcar-sysc.o r8a7743-sysc.o 1obj-$(CONFIG_ARCH_R8A7743) += rcar-sysc.o r8a7743-sysc.o
2obj-$(CONFIG_ARCH_R8A7745) += rcar-sysc.o r8a7745-sysc.o
2obj-$(CONFIG_ARCH_R8A7779) += rcar-sysc.o r8a7779-sysc.o 3obj-$(CONFIG_ARCH_R8A7779) += rcar-sysc.o r8a7779-sysc.o
3obj-$(CONFIG_ARCH_R8A7790) += rcar-sysc.o r8a7790-sysc.o 4obj-$(CONFIG_ARCH_R8A7790) += rcar-sysc.o r8a7790-sysc.o
4obj-$(CONFIG_ARCH_R8A7791) += rcar-sysc.o r8a7791-sysc.o 5obj-$(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
18static 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
29const 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
53extern const struct rcar_sysc_info r8a7743_sysc_info; 53extern const struct rcar_sysc_info r8a7743_sysc_info;
54extern const struct rcar_sysc_info r8a7745_sysc_info;
54extern const struct rcar_sysc_info r8a7779_sysc_info; 55extern const struct rcar_sysc_info r8a7779_sysc_info;
55extern const struct rcar_sysc_info r8a7790_sysc_info; 56extern const struct rcar_sysc_info r8a7790_sysc_info;
56extern const struct rcar_sysc_info r8a7791_sysc_info; 57extern 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__ */