18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * arch/powerpc/platforms/83xx/mpc837x_rdb.c 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved. 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * MPC837x RDB board specific routines 88c2ecf20Sopenharmony_ci */ 98c2ecf20Sopenharmony_ci 108c2ecf20Sopenharmony_ci#include <linux/pci.h> 118c2ecf20Sopenharmony_ci#include <linux/of_platform.h> 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci#include <asm/time.h> 148c2ecf20Sopenharmony_ci#include <asm/ipic.h> 158c2ecf20Sopenharmony_ci#include <asm/udbg.h> 168c2ecf20Sopenharmony_ci#include <sysdev/fsl_soc.h> 178c2ecf20Sopenharmony_ci#include <sysdev/fsl_pci.h> 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ci#include "mpc83xx.h" 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_cistatic void mpc837x_rdb_sd_cfg(void) 228c2ecf20Sopenharmony_ci{ 238c2ecf20Sopenharmony_ci void __iomem *im; 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci im = ioremap(get_immrbase(), 0x1000); 268c2ecf20Sopenharmony_ci if (!im) { 278c2ecf20Sopenharmony_ci WARN_ON(1); 288c2ecf20Sopenharmony_ci return; 298c2ecf20Sopenharmony_ci } 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_ci /* 328c2ecf20Sopenharmony_ci * On RDB boards (in contrast to MDS) USBB pins are used for SD only, 338c2ecf20Sopenharmony_ci * so we can safely mux them away from the USB block. 348c2ecf20Sopenharmony_ci */ 358c2ecf20Sopenharmony_ci clrsetbits_be32(im + MPC83XX_SICRL_OFFS, MPC837X_SICRL_USBB_MASK, 368c2ecf20Sopenharmony_ci MPC837X_SICRL_SD); 378c2ecf20Sopenharmony_ci clrsetbits_be32(im + MPC83XX_SICRH_OFFS, MPC837X_SICRH_SPI_MASK, 388c2ecf20Sopenharmony_ci MPC837X_SICRH_SD); 398c2ecf20Sopenharmony_ci iounmap(im); 408c2ecf20Sopenharmony_ci} 418c2ecf20Sopenharmony_ci 428c2ecf20Sopenharmony_ci/* ************************************************************************ 438c2ecf20Sopenharmony_ci * 448c2ecf20Sopenharmony_ci * Setup the architecture 458c2ecf20Sopenharmony_ci * 468c2ecf20Sopenharmony_ci */ 478c2ecf20Sopenharmony_cistatic void __init mpc837x_rdb_setup_arch(void) 488c2ecf20Sopenharmony_ci{ 498c2ecf20Sopenharmony_ci mpc83xx_setup_arch(); 508c2ecf20Sopenharmony_ci mpc837x_usb_cfg(); 518c2ecf20Sopenharmony_ci mpc837x_rdb_sd_cfg(); 528c2ecf20Sopenharmony_ci} 538c2ecf20Sopenharmony_ci 548c2ecf20Sopenharmony_cimachine_device_initcall(mpc837x_rdb, mpc83xx_declare_of_platform_devices); 558c2ecf20Sopenharmony_ci 568c2ecf20Sopenharmony_cistatic const char * const board[] __initconst = { 578c2ecf20Sopenharmony_ci "fsl,mpc8377rdb", 588c2ecf20Sopenharmony_ci "fsl,mpc8378rdb", 598c2ecf20Sopenharmony_ci "fsl,mpc8379rdb", 608c2ecf20Sopenharmony_ci "fsl,mpc8377wlan", 618c2ecf20Sopenharmony_ci NULL 628c2ecf20Sopenharmony_ci}; 638c2ecf20Sopenharmony_ci 648c2ecf20Sopenharmony_ci/* 658c2ecf20Sopenharmony_ci * Called very early, MMU is off, device-tree isn't unflattened 668c2ecf20Sopenharmony_ci */ 678c2ecf20Sopenharmony_cistatic int __init mpc837x_rdb_probe(void) 688c2ecf20Sopenharmony_ci{ 698c2ecf20Sopenharmony_ci return of_device_compatible_match(of_root, board); 708c2ecf20Sopenharmony_ci} 718c2ecf20Sopenharmony_ci 728c2ecf20Sopenharmony_cidefine_machine(mpc837x_rdb) { 738c2ecf20Sopenharmony_ci .name = "MPC837x RDB/WLAN", 748c2ecf20Sopenharmony_ci .probe = mpc837x_rdb_probe, 758c2ecf20Sopenharmony_ci .setup_arch = mpc837x_rdb_setup_arch, 768c2ecf20Sopenharmony_ci .init_IRQ = mpc83xx_ipic_init_IRQ, 778c2ecf20Sopenharmony_ci .get_irq = ipic_get_irq, 788c2ecf20Sopenharmony_ci .restart = mpc83xx_restart, 798c2ecf20Sopenharmony_ci .time_init = mpc83xx_time_init, 808c2ecf20Sopenharmony_ci .calibrate_decr = generic_calibrate_decr, 818c2ecf20Sopenharmony_ci .progress = udbg_progress, 828c2ecf20Sopenharmony_ci}; 83