mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-25 04:59:40 +07:00
2874c5fd28
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license as published by the free software foundation either version 2 of the license or at your option any later version extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 3029 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070032.746973796@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
101 lines
2.2 KiB
C
101 lines
2.2 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*
|
|
* arch/powerpc/platforms/83xx/mpc834x_mds.c
|
|
*
|
|
* MPC834x MDS board specific routines
|
|
*
|
|
* Maintainer: Kumar Gala <galak@kernel.crashing.org>
|
|
*/
|
|
|
|
#include <linux/stddef.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/init.h>
|
|
#include <linux/errno.h>
|
|
#include <linux/reboot.h>
|
|
#include <linux/pci.h>
|
|
#include <linux/kdev_t.h>
|
|
#include <linux/major.h>
|
|
#include <linux/console.h>
|
|
#include <linux/delay.h>
|
|
#include <linux/seq_file.h>
|
|
#include <linux/root_dev.h>
|
|
#include <linux/of_platform.h>
|
|
|
|
#include <linux/atomic.h>
|
|
#include <asm/time.h>
|
|
#include <asm/io.h>
|
|
#include <asm/machdep.h>
|
|
#include <asm/ipic.h>
|
|
#include <asm/irq.h>
|
|
#include <asm/prom.h>
|
|
#include <asm/udbg.h>
|
|
#include <sysdev/fsl_soc.h>
|
|
#include <sysdev/fsl_pci.h>
|
|
|
|
#include "mpc83xx.h"
|
|
|
|
#define BCSR5_INT_USB 0x02
|
|
static int mpc834xemds_usb_cfg(void)
|
|
{
|
|
struct device_node *np;
|
|
void __iomem *bcsr_regs = NULL;
|
|
u8 bcsr5;
|
|
|
|
mpc834x_usb_cfg();
|
|
/* Map BCSR area */
|
|
np = of_find_node_by_name(NULL, "bcsr");
|
|
if (np) {
|
|
struct resource res;
|
|
|
|
of_address_to_resource(np, 0, &res);
|
|
bcsr_regs = ioremap(res.start, resource_size(&res));
|
|
of_node_put(np);
|
|
}
|
|
if (!bcsr_regs)
|
|
return -1;
|
|
|
|
/*
|
|
* if Processor Board is plugged into PIB board,
|
|
* force to use the PHY on Processor Board
|
|
*/
|
|
bcsr5 = in_8(bcsr_regs + 5);
|
|
if (!(bcsr5 & BCSR5_INT_USB))
|
|
out_8(bcsr_regs + 5, (bcsr5 | BCSR5_INT_USB));
|
|
iounmap(bcsr_regs);
|
|
return 0;
|
|
}
|
|
|
|
/* ************************************************************************
|
|
*
|
|
* Setup the architecture
|
|
*
|
|
*/
|
|
static void __init mpc834x_mds_setup_arch(void)
|
|
{
|
|
mpc83xx_setup_arch();
|
|
|
|
mpc834xemds_usb_cfg();
|
|
}
|
|
|
|
machine_device_initcall(mpc834x_mds, mpc83xx_declare_of_platform_devices);
|
|
|
|
/*
|
|
* Called very early, MMU is off, device-tree isn't unflattened
|
|
*/
|
|
static int __init mpc834x_mds_probe(void)
|
|
{
|
|
return of_machine_is_compatible("MPC834xMDS");
|
|
}
|
|
|
|
define_machine(mpc834x_mds) {
|
|
.name = "MPC834x MDS",
|
|
.probe = mpc834x_mds_probe,
|
|
.setup_arch = mpc834x_mds_setup_arch,
|
|
.init_IRQ = mpc83xx_ipic_init_IRQ,
|
|
.get_irq = ipic_get_irq,
|
|
.restart = mpc83xx_restart,
|
|
.time_init = mpc83xx_time_init,
|
|
.calibrate_decr = generic_calibrate_decr,
|
|
.progress = udbg_progress,
|
|
};
|