162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * arch/powerpc/platforms/83xx/mpc837x_rdb.c
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved.
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * MPC837x RDB board specific routines
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#include <linux/pci.h>
1162306a36Sopenharmony_ci#include <linux/of_platform.h>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include <asm/time.h>
1462306a36Sopenharmony_ci#include <asm/ipic.h>
1562306a36Sopenharmony_ci#include <asm/udbg.h>
1662306a36Sopenharmony_ci#include <sysdev/fsl_soc.h>
1762306a36Sopenharmony_ci#include <sysdev/fsl_pci.h>
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci#include "mpc83xx.h"
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_cistatic void __init mpc837x_rdb_sd_cfg(void)
2262306a36Sopenharmony_ci{
2362306a36Sopenharmony_ci	void __iomem *im;
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci	im = ioremap(get_immrbase(), 0x1000);
2662306a36Sopenharmony_ci	if (!im) {
2762306a36Sopenharmony_ci		WARN_ON(1);
2862306a36Sopenharmony_ci		return;
2962306a36Sopenharmony_ci	}
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci	/*
3262306a36Sopenharmony_ci	 * On RDB boards (in contrast to MDS) USBB pins are used for SD only,
3362306a36Sopenharmony_ci	 * so we can safely mux them away from the USB block.
3462306a36Sopenharmony_ci	 */
3562306a36Sopenharmony_ci	clrsetbits_be32(im + MPC83XX_SICRL_OFFS, MPC837X_SICRL_USBB_MASK,
3662306a36Sopenharmony_ci						 MPC837X_SICRL_SD);
3762306a36Sopenharmony_ci	clrsetbits_be32(im + MPC83XX_SICRH_OFFS, MPC837X_SICRH_SPI_MASK,
3862306a36Sopenharmony_ci						 MPC837X_SICRH_SD);
3962306a36Sopenharmony_ci	iounmap(im);
4062306a36Sopenharmony_ci}
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci/* ************************************************************************
4362306a36Sopenharmony_ci *
4462306a36Sopenharmony_ci * Setup the architecture
4562306a36Sopenharmony_ci *
4662306a36Sopenharmony_ci */
4762306a36Sopenharmony_cistatic void __init mpc837x_rdb_setup_arch(void)
4862306a36Sopenharmony_ci{
4962306a36Sopenharmony_ci	mpc83xx_setup_arch();
5062306a36Sopenharmony_ci	mpc837x_usb_cfg();
5162306a36Sopenharmony_ci	mpc837x_rdb_sd_cfg();
5262306a36Sopenharmony_ci}
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_cimachine_device_initcall(mpc837x_rdb, mpc83xx_declare_of_platform_devices);
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cistatic const char * const board[] __initconst = {
5762306a36Sopenharmony_ci	"fsl,mpc8377rdb",
5862306a36Sopenharmony_ci	"fsl,mpc8378rdb",
5962306a36Sopenharmony_ci	"fsl,mpc8379rdb",
6062306a36Sopenharmony_ci	"fsl,mpc8377wlan",
6162306a36Sopenharmony_ci	NULL
6262306a36Sopenharmony_ci};
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci/*
6562306a36Sopenharmony_ci * Called very early, MMU is off, device-tree isn't unflattened
6662306a36Sopenharmony_ci */
6762306a36Sopenharmony_cistatic int __init mpc837x_rdb_probe(void)
6862306a36Sopenharmony_ci{
6962306a36Sopenharmony_ci	return of_device_compatible_match(of_root, board);
7062306a36Sopenharmony_ci}
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_cidefine_machine(mpc837x_rdb) {
7362306a36Sopenharmony_ci	.name			= "MPC837x RDB/WLAN",
7462306a36Sopenharmony_ci	.probe			= mpc837x_rdb_probe,
7562306a36Sopenharmony_ci	.setup_arch		= mpc837x_rdb_setup_arch,
7662306a36Sopenharmony_ci	.discover_phbs  	= mpc83xx_setup_pci,
7762306a36Sopenharmony_ci	.init_IRQ		= mpc83xx_ipic_init_IRQ,
7862306a36Sopenharmony_ci	.get_irq		= ipic_get_irq,
7962306a36Sopenharmony_ci	.restart		= mpc83xx_restart,
8062306a36Sopenharmony_ci	.time_init		= mpc83xx_time_init,
8162306a36Sopenharmony_ci	.progress		= udbg_progress,
8262306a36Sopenharmony_ci};
83