// SPDX-License-Identifier: GPL-2.0-or-later /* * Maxtor Shared Storage II Board Setup * * Maintainer: Sylver Bruneau */ #include #include #include #include #include #include #include #include #include "orion5x.h" #include "bridge-regs.h" #include "common.h" /***************************************************************************** * Maxtor Shared Storage II Info ****************************************************************************/ /**************************************************************************** * PCI setup ****************************************************************************/ static int __init mss2_pci_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) { int irq; /* * Check for devices with hard-wired IRQs. */ irq = orion5x_pci_map_irq(dev, slot, pin); if (irq != -1) return irq; return -1; } static struct hw_pci mss2_pci __initdata = { .nr_controllers = 2, .setup = orion5x_pci_sys_setup, .scan = orion5x_pci_sys_scan_bus, .map_irq = mss2_pci_map_irq, }; static int __init mss2_pci_init(void) { if (machine_is_mss2()) pci_common_init(&mss2_pci); return 0; } subsys_initcall(mss2_pci_init); /***************************************************************************** * MSS2 power off method ****************************************************************************/ /* * On the Maxtor Shared Storage II, the shutdown process is the following : * - Userland modifies U-boot env to tell U-boot to go idle at next boot * - The board reboots * - U-boot starts and go into an idle mode until the user press "power" */ static void mss2_power_off(void) { u32 reg; /* * Enable and issue soft reset */ reg = readl(RSTOUTn_MASK); reg |= 1 << 2; writel(reg, RSTOUTn_MASK); reg = readl(CPU_SOFT_RESET); reg |= 1; writel(reg, CPU_SOFT_RESET); } void __init mss2_init(void) { /* register mss2 specific power-off method */ pm_power_off = mss2_power_off; }