1 *7505576dSThomas Bogendoerfer // SPDX-License-Identifier: GPL-2.0 2 *7505576dSThomas Bogendoerfer /* 3 *7505576dSThomas Bogendoerfer * ip30-power.c: Software powerdown and reset handling for IP30 architecture. 4 *7505576dSThomas Bogendoerfer * 5 *7505576dSThomas Bogendoerfer * Copyright (C) 2004-2007 Stanislaw Skowronek <skylark@unaligned.org> 6 *7505576dSThomas Bogendoerfer * 2014 Joshua Kinard <kumba@gentoo.org> 7 *7505576dSThomas Bogendoerfer * 2009 Johannes Dickgreber <tanzy@gmx.de> 8 *7505576dSThomas Bogendoerfer */ 9 *7505576dSThomas Bogendoerfer 10 *7505576dSThomas Bogendoerfer #include <linux/init.h> 11 *7505576dSThomas Bogendoerfer #include <linux/kernel.h> 12 *7505576dSThomas Bogendoerfer #include <linux/module.h> 13 *7505576dSThomas Bogendoerfer #include <linux/sched.h> 14 *7505576dSThomas Bogendoerfer #include <linux/notifier.h> 15 *7505576dSThomas Bogendoerfer #include <linux/delay.h> 16 *7505576dSThomas Bogendoerfer #include <linux/rtc/ds1685.h> 17 *7505576dSThomas Bogendoerfer #include <linux/interrupt.h> 18 *7505576dSThomas Bogendoerfer #include <linux/pm.h> 19 *7505576dSThomas Bogendoerfer 20 *7505576dSThomas Bogendoerfer #include <asm/reboot.h> 21 *7505576dSThomas Bogendoerfer #include <asm/sgi/heart.h> 22 *7505576dSThomas Bogendoerfer ip30_machine_restart(char * cmd)23 *7505576dSThomas Bogendoerferstatic void __noreturn ip30_machine_restart(char *cmd) 24 *7505576dSThomas Bogendoerfer { 25 *7505576dSThomas Bogendoerfer /* 26 *7505576dSThomas Bogendoerfer * Execute HEART cold reset 27 *7505576dSThomas Bogendoerfer * Yes, it's cold-HEARTed! 28 *7505576dSThomas Bogendoerfer */ 29 *7505576dSThomas Bogendoerfer heart_write((heart_read(&heart_regs->mode) | HM_COLD_RST), 30 *7505576dSThomas Bogendoerfer &heart_regs->mode); 31 *7505576dSThomas Bogendoerfer unreachable(); 32 *7505576dSThomas Bogendoerfer } 33 *7505576dSThomas Bogendoerfer ip30_reboot_setup(void)34 *7505576dSThomas Bogendoerferstatic int __init ip30_reboot_setup(void) 35 *7505576dSThomas Bogendoerfer { 36 *7505576dSThomas Bogendoerfer _machine_restart = ip30_machine_restart; 37 *7505576dSThomas Bogendoerfer 38 *7505576dSThomas Bogendoerfer return 0; 39 *7505576dSThomas Bogendoerfer } 40 *7505576dSThomas Bogendoerfer 41 *7505576dSThomas Bogendoerfer subsys_initcall(ip30_reboot_setup); 42