162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Maxtor Shared Storage II Board Setup 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Maintainer: Sylver Bruneau <sylver.bruneau@googlemail.com> 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#include <linux/kernel.h> 962306a36Sopenharmony_ci#include <linux/init.h> 1062306a36Sopenharmony_ci#include <linux/platform_device.h> 1162306a36Sopenharmony_ci#include <linux/pci.h> 1262306a36Sopenharmony_ci#include <linux/irq.h> 1362306a36Sopenharmony_ci#include <asm/mach-types.h> 1462306a36Sopenharmony_ci#include <asm/mach/arch.h> 1562306a36Sopenharmony_ci#include <asm/mach/pci.h> 1662306a36Sopenharmony_ci#include "orion5x.h" 1762306a36Sopenharmony_ci#include "bridge-regs.h" 1862306a36Sopenharmony_ci#include "common.h" 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci/***************************************************************************** 2162306a36Sopenharmony_ci * Maxtor Shared Storage II Info 2262306a36Sopenharmony_ci ****************************************************************************/ 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci/**************************************************************************** 2562306a36Sopenharmony_ci * PCI setup 2662306a36Sopenharmony_ci ****************************************************************************/ 2762306a36Sopenharmony_cistatic int __init mss2_pci_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) 2862306a36Sopenharmony_ci{ 2962306a36Sopenharmony_ci int irq; 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci /* 3262306a36Sopenharmony_ci * Check for devices with hard-wired IRQs. 3362306a36Sopenharmony_ci */ 3462306a36Sopenharmony_ci irq = orion5x_pci_map_irq(dev, slot, pin); 3562306a36Sopenharmony_ci if (irq != -1) 3662306a36Sopenharmony_ci return irq; 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci return -1; 3962306a36Sopenharmony_ci} 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_cistatic struct hw_pci mss2_pci __initdata = { 4262306a36Sopenharmony_ci .nr_controllers = 2, 4362306a36Sopenharmony_ci .setup = orion5x_pci_sys_setup, 4462306a36Sopenharmony_ci .scan = orion5x_pci_sys_scan_bus, 4562306a36Sopenharmony_ci .map_irq = mss2_pci_map_irq, 4662306a36Sopenharmony_ci}; 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_cistatic int __init mss2_pci_init(void) 4962306a36Sopenharmony_ci{ 5062306a36Sopenharmony_ci if (machine_is_mss2()) 5162306a36Sopenharmony_ci pci_common_init(&mss2_pci); 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci return 0; 5462306a36Sopenharmony_ci} 5562306a36Sopenharmony_cisubsys_initcall(mss2_pci_init); 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci/***************************************************************************** 5862306a36Sopenharmony_ci * MSS2 power off method 5962306a36Sopenharmony_ci ****************************************************************************/ 6062306a36Sopenharmony_ci/* 6162306a36Sopenharmony_ci * On the Maxtor Shared Storage II, the shutdown process is the following : 6262306a36Sopenharmony_ci * - Userland modifies U-boot env to tell U-boot to go idle at next boot 6362306a36Sopenharmony_ci * - The board reboots 6462306a36Sopenharmony_ci * - U-boot starts and go into an idle mode until the user press "power" 6562306a36Sopenharmony_ci */ 6662306a36Sopenharmony_cistatic void mss2_power_off(void) 6762306a36Sopenharmony_ci{ 6862306a36Sopenharmony_ci u32 reg; 6962306a36Sopenharmony_ci 7062306a36Sopenharmony_ci /* 7162306a36Sopenharmony_ci * Enable and issue soft reset 7262306a36Sopenharmony_ci */ 7362306a36Sopenharmony_ci reg = readl(RSTOUTn_MASK); 7462306a36Sopenharmony_ci reg |= 1 << 2; 7562306a36Sopenharmony_ci writel(reg, RSTOUTn_MASK); 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci reg = readl(CPU_SOFT_RESET); 7862306a36Sopenharmony_ci reg |= 1; 7962306a36Sopenharmony_ci writel(reg, CPU_SOFT_RESET); 8062306a36Sopenharmony_ci} 8162306a36Sopenharmony_ci 8262306a36Sopenharmony_civoid __init mss2_init(void) 8362306a36Sopenharmony_ci{ 8462306a36Sopenharmony_ci /* register mss2 specific power-off method */ 8562306a36Sopenharmony_ci pm_power_off = mss2_power_off; 8662306a36Sopenharmony_ci} 87