162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Support for 'mpc5200-simple-platform' compatible boards.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Written by Marian Balakowicz <m8@semihalf.com>
662306a36Sopenharmony_ci * Copyright (C) 2007 Semihalf
762306a36Sopenharmony_ci *
862306a36Sopenharmony_ci * Description:
962306a36Sopenharmony_ci * This code implements support for a simple MPC52xx based boards which
1062306a36Sopenharmony_ci * do not need a custom platform specific setup. Such boards are
1162306a36Sopenharmony_ci * supported assuming the following:
1262306a36Sopenharmony_ci *
1362306a36Sopenharmony_ci * - GPIO pins are configured by the firmware,
1462306a36Sopenharmony_ci * - CDM configuration (clocking) is setup correctly by firmware,
1562306a36Sopenharmony_ci * - if the 'fsl,has-wdt' property is present in one of the
1662306a36Sopenharmony_ci *   gpt nodes, then it is safe to use such gpt to reset the board,
1762306a36Sopenharmony_ci * - PCI is supported if enabled in the kernel configuration
1862306a36Sopenharmony_ci *   and if there is a PCI bus node defined in the device tree.
1962306a36Sopenharmony_ci *
2062306a36Sopenharmony_ci * Boards that are compatible with this generic platform support
2162306a36Sopenharmony_ci * are listed in a 'board' table.
2262306a36Sopenharmony_ci */
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci#undef DEBUG
2562306a36Sopenharmony_ci#include <linux/of.h>
2662306a36Sopenharmony_ci#include <asm/time.h>
2762306a36Sopenharmony_ci#include <asm/machdep.h>
2862306a36Sopenharmony_ci#include <asm/mpc52xx.h>
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci/*
3162306a36Sopenharmony_ci * Setup the architecture
3262306a36Sopenharmony_ci */
3362306a36Sopenharmony_cistatic void __init mpc5200_simple_setup_arch(void)
3462306a36Sopenharmony_ci{
3562306a36Sopenharmony_ci	if (ppc_md.progress)
3662306a36Sopenharmony_ci		ppc_md.progress("mpc5200_simple_setup_arch()", 0);
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci	/* Map important registers from the internal memory map */
3962306a36Sopenharmony_ci	mpc52xx_map_common_devices();
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci	/* Some mpc5200 & mpc5200b related configuration */
4262306a36Sopenharmony_ci	mpc5200_setup_xlb_arbiter();
4362306a36Sopenharmony_ci}
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci/* list of the supported boards */
4662306a36Sopenharmony_cistatic const char *board[] __initdata = {
4762306a36Sopenharmony_ci	"anonymous,a3m071",
4862306a36Sopenharmony_ci	"anonymous,a4m072",
4962306a36Sopenharmony_ci	"anon,charon",
5062306a36Sopenharmony_ci	"ifm,o2d",
5162306a36Sopenharmony_ci	"intercontrol,digsy-mtc",
5262306a36Sopenharmony_ci	"manroland,mucmc52",
5362306a36Sopenharmony_ci	"manroland,uc101",
5462306a36Sopenharmony_ci	"phytec,pcm030",
5562306a36Sopenharmony_ci	"phytec,pcm032",
5662306a36Sopenharmony_ci	"promess,motionpro",
5762306a36Sopenharmony_ci	"schindler,cm5200",
5862306a36Sopenharmony_ci	"tqc,tqm5200",
5962306a36Sopenharmony_ci	NULL
6062306a36Sopenharmony_ci};
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci/*
6362306a36Sopenharmony_ci * Called very early, MMU is off, device-tree isn't unflattened
6462306a36Sopenharmony_ci */
6562306a36Sopenharmony_cistatic int __init mpc5200_simple_probe(void)
6662306a36Sopenharmony_ci{
6762306a36Sopenharmony_ci	return of_device_compatible_match(of_root, board);
6862306a36Sopenharmony_ci}
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_cidefine_machine(mpc5200_simple_platform) {
7162306a36Sopenharmony_ci	.name		= "mpc5200-simple-platform",
7262306a36Sopenharmony_ci	.probe		= mpc5200_simple_probe,
7362306a36Sopenharmony_ci	.setup_arch	= mpc5200_simple_setup_arch,
7462306a36Sopenharmony_ci	.discover_phbs	= mpc52xx_setup_pci,
7562306a36Sopenharmony_ci	.init		= mpc52xx_declare_of_platform_devices,
7662306a36Sopenharmony_ci	.init_IRQ	= mpc52xx_init_irq,
7762306a36Sopenharmony_ci	.get_irq	= mpc52xx_get_irq,
7862306a36Sopenharmony_ci	.restart	= mpc52xx_restart,
7962306a36Sopenharmony_ci};
80