* [PATCH v2] power: reset: Add reset driver for R-Mobile platforms
@ 2014-12-04 15:33 Geert Uytterhoeven
2014-12-04 16:19 ` Guenter Roeck
2015-01-21 15:58 ` Sebastian Reichel
0 siblings, 2 replies; 3+ messages in thread
From: Geert Uytterhoeven @ 2014-12-04 15:33 UTC (permalink / raw)
To: Sebastian Reichel, Dmitry Eremin-Solenikov, David Woodhouse
Cc: Simon Horman, Arnd Bergmann, Guenter Roeck, linux-pm, linux-sh,
Geert Uytterhoeven
Add a reset driver for Renesas R-Mobile and SH-Mobile SoCs. It registers
a restart handler to trigger a soft power-on reset through the R-Mobile
System Controller.
The priority of this restart handler is 192, to allow a watchdog driver
to use priority 128.
Note that we do not use syscon-reboot, as the HPB (Peripheral Bus
Bridge) semaphore should be acquired on systems where both the ARM and
SH core are in use. The driver can be extended later to support this,
when needed.
Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
---
Tested on R-Mobile A1 (r8a7740) and SH-Mobile AG5 (sh73a0).
This can be considered v2 of "[PATCH 1/4] ARM: shmobile: R-Mobile: Add
SYSC restart handler"
(http://www.spinics.net/lists/arm-kernel/msg383402.html).
Changes:
- Move to a standalone driver under drivers/power/reset that can be
modular,
- Use register_restart_handler() instead of setting arm_pm_restart,
---
drivers/power/reset/Kconfig | 6 +++
drivers/power/reset/Makefile | 1 +
drivers/power/reset/rmobile-reset.c | 93 +++++++++++++++++++++++++++++++++++++
3 files changed, 100 insertions(+)
create mode 100644 drivers/power/reset/rmobile-reset.c
diff --git a/drivers/power/reset/Kconfig b/drivers/power/reset/Kconfig
index 028e765045196f89..d743145e0001f466 100644
--- a/drivers/power/reset/Kconfig
+++ b/drivers/power/reset/Kconfig
@@ -159,5 +159,11 @@ config POWER_RESET_SYSCON
help
Reboot support for generic SYSCON mapped register reset.
+config POWER_RESET_RMOBILE
+ tristate "Renesas R-Mobile reset driver"
+ depends on ARCH_RMOBILE || COMPILE_TEST
+ help
+ Reboot support for Renesas R-Mobile and SH-Mobile SoCs.
+
endif
diff --git a/drivers/power/reset/Makefile b/drivers/power/reset/Makefile
index 1d4804d6b3237c1c..1631652009acc32d 100644
--- a/drivers/power/reset/Makefile
+++ b/drivers/power/reset/Makefile
@@ -18,3 +18,4 @@ obj-$(CONFIG_POWER_RESET_VEXPRESS) += vexpress-poweroff.o
obj-$(CONFIG_POWER_RESET_XGENE) += xgene-reboot.o
obj-$(CONFIG_POWER_RESET_KEYSTONE) += keystone-reset.o
obj-$(CONFIG_POWER_RESET_SYSCON) += syscon-reboot.o
+obj-$(CONFIG_POWER_RESET_RMOBILE) += rmobile-reset.o
diff --git a/drivers/power/reset/rmobile-reset.c b/drivers/power/reset/rmobile-reset.c
new file mode 100644
index 0000000000000000..ff3bbcfd03d1e7b4
--- /dev/null
+++ b/drivers/power/reset/rmobile-reset.c
@@ -0,0 +1,93 @@
+/*
+ * Renesas R-Mobile Reset Driver
+ *
+ * Copyright (C) 2014 Glider bvba
+ *
+ * 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/module.h>
+#include <linux/notifier.h>
+#include <linux/of_address.h>
+#include <linux/platform_device.h>
+#include <linux/printk.h>
+#include <linux/reboot.h>
+
+
+/* SYSC Register Bank 2 */
+#define RESCNT2 0x20 /* Reset Control Register 2 */
+
+/* Reset Control Register 2 */
+#define RESCNT2_PRES 0x80000000 /* Soft power-on reset */
+
+
+static void __iomem *sysc_base2;
+
+static int rmobile_reset_handler(struct notifier_block *this,
+ unsigned long mode, void *cmd)
+{
+ pr_debug("%s %lu\n", __func__, mode);
+
+ /* Let's assume we have acquired the HPB semaphore */
+ writel(RESCNT2_PRES, sysc_base2 + RESCNT2);
+
+ return NOTIFY_DONE;
+}
+
+static struct notifier_block rmobile_reset_nb = {
+ .notifier_call = rmobile_reset_handler,
+ .priority = 192,
+};
+
+static int rmobile_reset_probe(struct platform_device *pdev)
+{
+ int error;
+
+ sysc_base2 = of_iomap(pdev->dev.of_node, 1);
+ if (!sysc_base2)
+ return -ENODEV;
+
+ error = register_restart_handler(&rmobile_reset_nb);
+ if (error) {
+ dev_err(&pdev->dev,
+ "cannot register restart handler (err=%d)\n", error);
+ goto fail_unmap;
+ }
+
+ return 0;
+
+fail_unmap:
+ iounmap(sysc_base2);
+ return error;
+}
+
+static int rmobile_reset_remove(struct platform_device *pdev)
+{
+ unregister_restart_handler(&rmobile_reset_nb);
+ iounmap(sysc_base2);
+ return 0;
+}
+
+static const struct of_device_id rmobile_reset_of_match[] = {
+ { .compatible = "renesas,sysc-rmobile", },
+ { /* sentinel */ }
+};
+MODULE_DEVICE_TABLE(of, rmobile_reset_of_match);
+
+static struct platform_driver rmobile_reset_driver = {
+ .probe = rmobile_reset_probe,
+ .remove = rmobile_reset_remove,
+ .driver = {
+ .name = "rmobile_reset",
+ .of_match_table = rmobile_reset_of_match,
+ },
+};
+
+module_platform_driver(rmobile_reset_driver);
+
+MODULE_DESCRIPTION("Renesas R-Mobile Reset Driver");
+MODULE_AUTHOR("Geert Uytterhoeven <geert+renesas@glider.be>");
+MODULE_LICENSE("GPL v2");
--
1.9.1
^ permalink raw reply related [flat|nested] 3+ messages in thread* Re: [PATCH v2] power: reset: Add reset driver for R-Mobile platforms
2014-12-04 15:33 [PATCH v2] power: reset: Add reset driver for R-Mobile platforms Geert Uytterhoeven
@ 2014-12-04 16:19 ` Guenter Roeck
2015-01-21 15:58 ` Sebastian Reichel
1 sibling, 0 replies; 3+ messages in thread
From: Guenter Roeck @ 2014-12-04 16:19 UTC (permalink / raw)
To: Geert Uytterhoeven
Cc: Sebastian Reichel, Dmitry Eremin-Solenikov, David Woodhouse,
Simon Horman, Arnd Bergmann, linux-pm, linux-sh
On Thu, Dec 04, 2014 at 04:33:21PM +0100, Geert Uytterhoeven wrote:
> Add a reset driver for Renesas R-Mobile and SH-Mobile SoCs. It registers
> a restart handler to trigger a soft power-on reset through the R-Mobile
> System Controller.
> The priority of this restart handler is 192, to allow a watchdog driver
> to use priority 128.
>
Also because it is conreolled by devicetree and thus by definition should have
higher priority.
> Note that we do not use syscon-reboot, as the HPB (Peripheral Bus
> Bridge) semaphore should be acquired on systems where both the ARM and
> SH core are in use. The driver can be extended later to support this,
> when needed.
>
> Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
Looks good to me (except for the dual empty lines ;-).
Reviewed-by: Guenter Roeck <linux@roeck-us.net>
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v2] power: reset: Add reset driver for R-Mobile platforms
2014-12-04 15:33 [PATCH v2] power: reset: Add reset driver for R-Mobile platforms Geert Uytterhoeven
2014-12-04 16:19 ` Guenter Roeck
@ 2015-01-21 15:58 ` Sebastian Reichel
1 sibling, 0 replies; 3+ messages in thread
From: Sebastian Reichel @ 2015-01-21 15:58 UTC (permalink / raw)
To: Geert Uytterhoeven
Cc: Dmitry Eremin-Solenikov, David Woodhouse, Simon Horman,
Arnd Bergmann, Guenter Roeck, linux-pm, linux-sh
[-- Attachment #1: Type: text/plain, Size: 648 bytes --]
Hi,
On Thu, Dec 04, 2014 at 04:33:21PM +0100, Geert Uytterhoeven wrote:
> Add a reset driver for Renesas R-Mobile and SH-Mobile SoCs. It registers
> a restart handler to trigger a soft power-on reset through the R-Mobile
> System Controller.
> The priority of this restart handler is 192, to allow a watchdog driver
> to use priority 128.
>
> Note that we do not use syscon-reboot, as the HPB (Peripheral Bus
> Bridge) semaphore should be acquired on systems where both the ARM and
> SH core are in use. The driver can be extended later to support this,
> when needed.
Applied with Reviewed-By from Guenter Roeck.
-- Sebastian
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 819 bytes --]
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2015-01-21 15:58 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-12-04 15:33 [PATCH v2] power: reset: Add reset driver for R-Mobile platforms Geert Uytterhoeven
2014-12-04 16:19 ` Guenter Roeck
2015-01-21 15:58 ` Sebastian Reichel
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox