17505576dSThomas Bogendoerfer // SPDX-License-Identifier: GPL-2.0 27505576dSThomas Bogendoerfer /* 37505576dSThomas Bogendoerfer * ip30-power.c: Software powerdown and reset handling for IP30 architecture. 47505576dSThomas Bogendoerfer * 57505576dSThomas Bogendoerfer * Copyright (C) 2004-2007 Stanislaw Skowronek <skylark@unaligned.org> 67505576dSThomas Bogendoerfer * 2014 Joshua Kinard <kumba@gentoo.org> 77505576dSThomas Bogendoerfer * 2009 Johannes Dickgreber <tanzy@gmx.de> 87505576dSThomas Bogendoerfer */ 97505576dSThomas Bogendoerfer 107505576dSThomas Bogendoerfer #include <linux/init.h> 117505576dSThomas Bogendoerfer #include <linux/kernel.h> 127505576dSThomas Bogendoerfer #include <linux/module.h> 137505576dSThomas Bogendoerfer #include <linux/sched.h> 147505576dSThomas Bogendoerfer #include <linux/notifier.h> 157505576dSThomas Bogendoerfer #include <linux/delay.h> 167505576dSThomas Bogendoerfer #include <linux/rtc/ds1685.h> 177505576dSThomas Bogendoerfer #include <linux/interrupt.h> 187505576dSThomas Bogendoerfer #include <linux/pm.h> 197505576dSThomas Bogendoerfer 207505576dSThomas Bogendoerfer #include <asm/reboot.h> 217505576dSThomas Bogendoerfer #include <asm/sgi/heart.h> 227505576dSThomas Bogendoerfer ip30_machine_restart(char * cmd)237505576dSThomas Bogendoerferstatic void __noreturn ip30_machine_restart(char *cmd) 247505576dSThomas Bogendoerfer { 257505576dSThomas Bogendoerfer /* 267505576dSThomas Bogendoerfer * Execute HEART cold reset 277505576dSThomas Bogendoerfer * Yes, it's cold-HEARTed! 287505576dSThomas Bogendoerfer */ 297505576dSThomas Bogendoerfer heart_write((heart_read(&heart_regs->mode) | HM_COLD_RST), 307505576dSThomas Bogendoerfer &heart_regs->mode); 317505576dSThomas Bogendoerfer unreachable(); 327505576dSThomas Bogendoerfer } 337505576dSThomas Bogendoerfer ip30_reboot_setup(void)347505576dSThomas Bogendoerferstatic int __init ip30_reboot_setup(void) 357505576dSThomas Bogendoerfer { 367505576dSThomas Bogendoerfer _machine_restart = ip30_machine_restart; 377505576dSThomas Bogendoerfer 387505576dSThomas Bogendoerfer return 0; 397505576dSThomas Bogendoerfer } 407505576dSThomas Bogendoerfer 417505576dSThomas Bogendoerfer subsys_initcall(ip30_reboot_setup); 42