18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Support for 'mpc5200-simple-platform' compatible boards. 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Written by Marian Balakowicz <m8@semihalf.com> 68c2ecf20Sopenharmony_ci * Copyright (C) 2007 Semihalf 78c2ecf20Sopenharmony_ci * 88c2ecf20Sopenharmony_ci * Description: 98c2ecf20Sopenharmony_ci * This code implements support for a simple MPC52xx based boards which 108c2ecf20Sopenharmony_ci * do not need a custom platform specific setup. Such boards are 118c2ecf20Sopenharmony_ci * supported assuming the following: 128c2ecf20Sopenharmony_ci * 138c2ecf20Sopenharmony_ci * - GPIO pins are configured by the firmware, 148c2ecf20Sopenharmony_ci * - CDM configuration (clocking) is setup correctly by firmware, 158c2ecf20Sopenharmony_ci * - if the 'fsl,has-wdt' property is present in one of the 168c2ecf20Sopenharmony_ci * gpt nodes, then it is safe to use such gpt to reset the board, 178c2ecf20Sopenharmony_ci * - PCI is supported if enabled in the kernel configuration 188c2ecf20Sopenharmony_ci * and if there is a PCI bus node defined in the device tree. 198c2ecf20Sopenharmony_ci * 208c2ecf20Sopenharmony_ci * Boards that are compatible with this generic platform support 218c2ecf20Sopenharmony_ci * are listed in a 'board' table. 228c2ecf20Sopenharmony_ci */ 238c2ecf20Sopenharmony_ci 248c2ecf20Sopenharmony_ci#undef DEBUG 258c2ecf20Sopenharmony_ci#include <asm/time.h> 268c2ecf20Sopenharmony_ci#include <asm/prom.h> 278c2ecf20Sopenharmony_ci#include <asm/machdep.h> 288c2ecf20Sopenharmony_ci#include <asm/mpc52xx.h> 298c2ecf20Sopenharmony_ci 308c2ecf20Sopenharmony_ci/* 318c2ecf20Sopenharmony_ci * Setup the architecture 328c2ecf20Sopenharmony_ci */ 338c2ecf20Sopenharmony_cistatic void __init mpc5200_simple_setup_arch(void) 348c2ecf20Sopenharmony_ci{ 358c2ecf20Sopenharmony_ci if (ppc_md.progress) 368c2ecf20Sopenharmony_ci ppc_md.progress("mpc5200_simple_setup_arch()", 0); 378c2ecf20Sopenharmony_ci 388c2ecf20Sopenharmony_ci /* Map important registers from the internal memory map */ 398c2ecf20Sopenharmony_ci mpc52xx_map_common_devices(); 408c2ecf20Sopenharmony_ci 418c2ecf20Sopenharmony_ci /* Some mpc5200 & mpc5200b related configuration */ 428c2ecf20Sopenharmony_ci mpc5200_setup_xlb_arbiter(); 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci mpc52xx_setup_pci(); 458c2ecf20Sopenharmony_ci} 468c2ecf20Sopenharmony_ci 478c2ecf20Sopenharmony_ci/* list of the supported boards */ 488c2ecf20Sopenharmony_cistatic const char *board[] __initdata = { 498c2ecf20Sopenharmony_ci "anonymous,a3m071", 508c2ecf20Sopenharmony_ci "anonymous,a4m072", 518c2ecf20Sopenharmony_ci "anon,charon", 528c2ecf20Sopenharmony_ci "ifm,o2d", 538c2ecf20Sopenharmony_ci "intercontrol,digsy-mtc", 548c2ecf20Sopenharmony_ci "manroland,mucmc52", 558c2ecf20Sopenharmony_ci "manroland,uc101", 568c2ecf20Sopenharmony_ci "phytec,pcm030", 578c2ecf20Sopenharmony_ci "phytec,pcm032", 588c2ecf20Sopenharmony_ci "promess,motionpro", 598c2ecf20Sopenharmony_ci "schindler,cm5200", 608c2ecf20Sopenharmony_ci "tqc,tqm5200", 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 mpc5200_simple_probe(void) 688c2ecf20Sopenharmony_ci{ 698c2ecf20Sopenharmony_ci return of_device_compatible_match(of_root, board); 708c2ecf20Sopenharmony_ci} 718c2ecf20Sopenharmony_ci 728c2ecf20Sopenharmony_cidefine_machine(mpc5200_simple_platform) { 738c2ecf20Sopenharmony_ci .name = "mpc5200-simple-platform", 748c2ecf20Sopenharmony_ci .probe = mpc5200_simple_probe, 758c2ecf20Sopenharmony_ci .setup_arch = mpc5200_simple_setup_arch, 768c2ecf20Sopenharmony_ci .init = mpc52xx_declare_of_platform_devices, 778c2ecf20Sopenharmony_ci .init_IRQ = mpc52xx_init_irq, 788c2ecf20Sopenharmony_ci .get_irq = mpc52xx_get_irq, 798c2ecf20Sopenharmony_ci .restart = mpc52xx_restart, 808c2ecf20Sopenharmony_ci .calibrate_decr = generic_calibrate_decr, 818c2ecf20Sopenharmony_ci}; 82