blob: c4db5172b27ab34de9af690f8a1af8075565def8 [file] [log] [blame]
Kim Phillipsb3590492007-02-07 22:19:12 -06001/*
Kim Phillips519fd802008-01-24 20:45:51 -06002 * arch/powerpc/platforms/83xx/mpc831x_rdb.c
Kim Phillipsb3590492007-02-07 22:19:12 -06003 *
Kim Phillips519fd802008-01-24 20:45:51 -06004 * Description: MPC831x RDB board specific routines.
Kim Phillipsb3590492007-02-07 22:19:12 -06005 * This file is based on mpc834x_sys.c
6 * Author: Lo Wlison <r43300@freescale.com>
7 *
8 * Copyright (C) Freescale Semiconductor, Inc. 2006. All rights reserved.
9 *
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU General Public License as published by the
12 * Free Software Foundation; either version 2 of the License, or (at your
13 * option) any later version.
14 */
15
16#include <linux/pci.h>
Scott Woodff5ac762008-01-17 16:37:51 -060017#include <linux/of_platform.h>
Kim Phillipsb3590492007-02-07 22:19:12 -060018
19#include <asm/time.h>
20#include <asm/ipic.h>
21#include <asm/udbg.h>
22
23#include "mpc83xx.h"
24
Kim Phillips519fd802008-01-24 20:45:51 -060025/*
Kim Phillipsb3590492007-02-07 22:19:12 -060026 * Setup the architecture
Kim Phillipsb3590492007-02-07 22:19:12 -060027 */
Kim Phillips519fd802008-01-24 20:45:51 -060028static void __init mpc831x_rdb_setup_arch(void)
Kim Phillipsb3590492007-02-07 22:19:12 -060029{
Li Yangb38d06d2007-05-10 11:14:57 +080030#ifdef CONFIG_PCI
Kim Phillipsb3590492007-02-07 22:19:12 -060031 struct device_node *np;
Li Yangb38d06d2007-05-10 11:14:57 +080032#endif
Kim Phillipsb3590492007-02-07 22:19:12 -060033
34 if (ppc_md.progress)
Kim Phillips519fd802008-01-24 20:45:51 -060035 ppc_md.progress("mpc831x_rdb_setup_arch()", 0);
Kim Phillipsb3590492007-02-07 22:19:12 -060036
37#ifdef CONFIG_PCI
Kumar Galac9438af2007-10-04 00:28:43 -050038 for_each_compatible_node(np, "pci", "fsl,mpc8349-pci")
Arnd Bergmann09b55f72007-06-18 01:06:54 +020039 mpc83xx_add_bridge(np);
Kim Phillipsb3590492007-02-07 22:19:12 -060040#endif
Li Yange5a94af2007-07-03 17:43:16 +080041 mpc831x_usb_cfg();
Kim Phillipsb3590492007-02-07 22:19:12 -060042}
43
Kim Phillips519fd802008-01-24 20:45:51 -060044void __init mpc831x_rdb_init_IRQ(void)
Kim Phillipsb3590492007-02-07 22:19:12 -060045{
46 struct device_node *np;
47
48 np = of_find_node_by_type(NULL, "ipic");
49 if (!np)
50 return;
51
52 ipic_init(np, 0);
53
54 /* Initialize the default interrupt mapping priorities,
55 * in case the boot rom changed something on us.
56 */
57 ipic_set_default_priority();
58}
59
60/*
61 * Called very early, MMU is off, device-tree isn't unflattened
62 */
Kim Phillips519fd802008-01-24 20:45:51 -060063static int __init mpc831x_rdb_probe(void)
Kim Phillipsb3590492007-02-07 22:19:12 -060064{
Scott Wood255b09e2007-12-13 11:16:32 -060065 unsigned long root = of_get_flat_dt_root();
Kim Phillipsb3590492007-02-07 22:19:12 -060066
Kim Phillips846aace2008-01-24 20:46:00 -060067 return of_flat_dt_is_compatible(root, "MPC8313ERDB") ||
68 of_flat_dt_is_compatible(root, "fsl,mpc8315erdb");
Kim Phillipsb3590492007-02-07 22:19:12 -060069}
70
Scott Woodff5ac762008-01-17 16:37:51 -060071static struct of_device_id __initdata of_bus_ids[] = {
72 { .compatible = "simple-bus" },
73 {},
74};
75
76static int __init declare_of_platform_devices(void)
77{
78 of_platform_bus_probe(NULL, of_bus_ids, NULL);
79 return 0;
80}
Kim Phillips519fd802008-01-24 20:45:51 -060081machine_device_initcall(mpc831x_rdb, declare_of_platform_devices);
Scott Woodff5ac762008-01-17 16:37:51 -060082
Kim Phillips519fd802008-01-24 20:45:51 -060083define_machine(mpc831x_rdb) {
84 .name = "MPC831x RDB",
85 .probe = mpc831x_rdb_probe,
86 .setup_arch = mpc831x_rdb_setup_arch,
87 .init_IRQ = mpc831x_rdb_init_IRQ,
Kim Phillipsb3590492007-02-07 22:19:12 -060088 .get_irq = ipic_get_irq,
89 .restart = mpc83xx_restart,
90 .time_init = mpc83xx_time_init,
91 .calibrate_decr = generic_calibrate_decr,
92 .progress = udbg_progress,
93};