@@ -4,5 +4,5 @@ obj-$(CONFIG_ARCH_R8A7791) += rcar-sysc.o r8a7791-sysc.o
# R-Car M2-N is identical to R-Car M2-W w.r.t. power domains.
obj-$(CONFIG_ARCH_R8A7793) += rcar-sysc.o r8a7791-sysc.o
obj-$(CONFIG_ARCH_R8A7794) += rcar-sysc.o r8a7794-sysc.o
-obj-$(CONFIG_ARCH_R8A7795) += rcar-sysc.o r8a7795-sysc.o
-obj-$(CONFIG_ARCH_R8A7796) += rcar-sysc.o r8a7796-sysc.o
+obj-$(CONFIG_ARCH_R8A7795) += rcar-sysc.o r8a7795-sysc.o rcar3-prr.o
+obj-$(CONFIG_ARCH_R8A7796) += rcar-sysc.o r8a7796-sysc.o rcar3-prr.o
new file mode 100644
@@ -0,0 +1,49 @@
+/*
+ * R-Car3 Product Register (PRR) support
+ *
+ * Copyright (C) 2016 Robert Bosch Car Multimedia GmbH
+ * Dirk Behme <dirk.behme@de.bosch.com>
+ *
+ * This file is subject to the terms and conditions of the GNU General Public
+ * License. See the file "COPYING" in the main directory of this archive
+ * for more details.
+ */
+
+#include <linux/io.h>
+#include <linux/of.h>
+#include <linux/of_address.h>
+
+unsigned int __rcar3_prr;
+EXPORT_SYMBOL(__rcar3_prr);
+
+static const struct of_device_id rcar3_prr_ids[] __initconst = {
+ { .compatible = "renesas,rcar-gen3-prr" },
+ {}
+};
+
+static int __init rcar3_read_prr(void)
+{
+ struct device_node *np;
+ void __iomem *prr;
+
+ np = of_find_matching_node(NULL, rcar3_prr_ids);
+ if (!np) {
+ pr_err("can't find renesas,rcar-gen3-prr device node");
+ return -ENOENT;
+ }
+
+ prr = of_iomap(np, 0);
+ if (!prr) {
+ pr_err("failed to map product register");
+ of_node_put(np);
+ return -ENOMEM;
+ }
+
+ __rcar3_prr = ioread32(prr);
+
+ iounmap(prr);
+ of_node_put(np);
+
+ return 0;
+}
+early_initcall(rcar3_read_prr);
The product register of the Renesas R-Car3 isn't part of any SoC module, but "just" a register at address 0xFFF00044. It provides some configuration information about the SoC itself, like the number of the CA57, CA53 and CR7 cores, the product description (R-Car H3, R-Car M3-W etc) and the sample revision. This information is needed by some drivers to enable or disable specific features which are present or not in the SoC. Signed-off-by: Dirk Behme <dirk.behme@de.bosch.com> --- drivers/soc/renesas/Makefile | 4 ++-- drivers/soc/renesas/rcar3-prr.c | 49 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 51 insertions(+), 2 deletions(-) create mode 100644 drivers/soc/renesas/rcar3-prr.c