162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * arch/powerpc/platforms/embedded6xx/gamecube.c 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Nintendo GameCube board-specific support 662306a36Sopenharmony_ci * Copyright (C) 2004-2009 The GameCube Linux Team 762306a36Sopenharmony_ci * Copyright (C) 2007,2008,2009 Albert Herranz 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include <linux/kernel.h> 1162306a36Sopenharmony_ci#include <linux/init.h> 1262306a36Sopenharmony_ci#include <linux/irq.h> 1362306a36Sopenharmony_ci#include <linux/kexec.h> 1462306a36Sopenharmony_ci#include <linux/seq_file.h> 1562306a36Sopenharmony_ci#include <linux/of_platform.h> 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci#include <asm/io.h> 1862306a36Sopenharmony_ci#include <asm/machdep.h> 1962306a36Sopenharmony_ci#include <asm/time.h> 2062306a36Sopenharmony_ci#include <asm/udbg.h> 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci#include "flipper-pic.h" 2362306a36Sopenharmony_ci#include "usbgecko_udbg.h" 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_cistatic void __noreturn gamecube_spin(void) 2762306a36Sopenharmony_ci{ 2862306a36Sopenharmony_ci /* spin until power button pressed */ 2962306a36Sopenharmony_ci for (;;) 3062306a36Sopenharmony_ci cpu_relax(); 3162306a36Sopenharmony_ci} 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_cistatic void __noreturn gamecube_restart(char *cmd) 3462306a36Sopenharmony_ci{ 3562306a36Sopenharmony_ci local_irq_disable(); 3662306a36Sopenharmony_ci flipper_platform_reset(); 3762306a36Sopenharmony_ci gamecube_spin(); 3862306a36Sopenharmony_ci} 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_cistatic void gamecube_power_off(void) 4162306a36Sopenharmony_ci{ 4262306a36Sopenharmony_ci local_irq_disable(); 4362306a36Sopenharmony_ci gamecube_spin(); 4462306a36Sopenharmony_ci} 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_cistatic void __noreturn gamecube_halt(void) 4762306a36Sopenharmony_ci{ 4862306a36Sopenharmony_ci gamecube_restart(NULL); 4962306a36Sopenharmony_ci} 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cistatic int __init gamecube_probe(void) 5262306a36Sopenharmony_ci{ 5362306a36Sopenharmony_ci pm_power_off = gamecube_power_off; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci ug_udbg_init(); 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci return 1; 5862306a36Sopenharmony_ci} 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_cistatic void gamecube_shutdown(void) 6162306a36Sopenharmony_ci{ 6262306a36Sopenharmony_ci flipper_quiesce(); 6362306a36Sopenharmony_ci} 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_cidefine_machine(gamecube) { 6662306a36Sopenharmony_ci .name = "gamecube", 6762306a36Sopenharmony_ci .compatible = "nintendo,gamecube", 6862306a36Sopenharmony_ci .probe = gamecube_probe, 6962306a36Sopenharmony_ci .restart = gamecube_restart, 7062306a36Sopenharmony_ci .halt = gamecube_halt, 7162306a36Sopenharmony_ci .init_IRQ = flipper_pic_probe, 7262306a36Sopenharmony_ci .get_irq = flipper_pic_get_irq, 7362306a36Sopenharmony_ci .progress = udbg_progress, 7462306a36Sopenharmony_ci .machine_shutdown = gamecube_shutdown, 7562306a36Sopenharmony_ci}; 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_cistatic const struct of_device_id gamecube_of_bus[] = { 7962306a36Sopenharmony_ci { .compatible = "nintendo,flipper", }, 8062306a36Sopenharmony_ci { }, 8162306a36Sopenharmony_ci}; 8262306a36Sopenharmony_ci 8362306a36Sopenharmony_cistatic int __init gamecube_device_probe(void) 8462306a36Sopenharmony_ci{ 8562306a36Sopenharmony_ci of_platform_bus_probe(NULL, gamecube_of_bus, NULL); 8662306a36Sopenharmony_ci return 0; 8762306a36Sopenharmony_ci} 8862306a36Sopenharmony_cimachine_device_initcall(gamecube, gamecube_device_probe); 8962306a36Sopenharmony_ci 90