blob: 9aa7ae2f4164ba45c51f0522aac1bb5ccccc032d [file] [log] [blame]
Grant Likely486ba7e2007-10-02 12:15:29 +10001/*
2 * Xilinx Virtex (IIpro & 4FX) based board support
3 *
4 * Copyright 2007 Secret Lab Technologies Ltd.
5 *
6 * This file is licensed under the terms of the GNU General Public License
7 * version 2. This program is licensed "as is" without any warranty of any
8 * kind, whether express or implied.
9 */
10
11#include <linux/init.h>
12#include <linux/of_platform.h>
13#include <asm/machdep.h>
14#include <asm/prom.h>
15#include <asm/time.h>
16#include <asm/xilinx_intc.h>
Roderick Colenbrander64f16502009-06-06 10:14:22 -060017#include <asm/xilinx_pci.h>
Stefan Roese93173ce2008-03-28 01:43:31 +110018#include <asm/ppc4xx.h>
Grant Likely486ba7e2007-10-02 12:15:29 +100019
Uwe Kleine-Königce6d73c2014-09-10 21:56:38 +020020static const struct of_device_id xilinx_of_bus_ids[] __initconst = {
Stephen Neuendorfferfaa65112008-01-09 06:35:06 +110021 { .compatible = "xlnx,plb-v46-1.00.a", },
22 { .compatible = "xlnx,plb-v34-1.01.a", },
23 { .compatible = "xlnx,plb-v34-1.02.a", },
24 { .compatible = "xlnx,opb-v20-1.10.c", },
25 { .compatible = "xlnx,dcr-v29-1.00.a", },
26 { .compatible = "xlnx,compound", },
27 {}
28};
29
Grant Likely486ba7e2007-10-02 12:15:29 +100030static int __init virtex_device_probe(void)
31{
Stephen Neuendorfferfaa65112008-01-09 06:35:06 +110032 of_platform_bus_probe(NULL, xilinx_of_bus_ids, NULL);
Grant Likely486ba7e2007-10-02 12:15:29 +100033
34 return 0;
35}
Josh Boyer3f8c5c32007-12-24 10:42:02 -060036machine_device_initcall(virtex, virtex_device_probe);
Grant Likely486ba7e2007-10-02 12:15:29 +100037
38static int __init virtex_probe(void)
39{
40 unsigned long root = of_get_flat_dt_root();
41
Stephen Neuendorffer0e349b02008-01-09 06:35:05 +110042 if (!of_flat_dt_is_compatible(root, "xlnx,virtex"))
Grant Likely486ba7e2007-10-02 12:15:29 +100043 return 0;
44
45 return 1;
46}
47
Grant Likely486ba7e2007-10-02 12:15:29 +100048define_machine(virtex) {
49 .name = "Xilinx Virtex",
50 .probe = virtex_probe,
Roderick Colenbrander64f16502009-06-06 10:14:22 -060051 .setup_arch = xilinx_pci_init,
Grant Likely486ba7e2007-10-02 12:15:29 +100052 .init_IRQ = xilinx_intc_init_tree,
53 .get_irq = xilinx_intc_get_irq,
Stefan Roese93173ce2008-03-28 01:43:31 +110054 .restart = ppc4xx_reset_system,
Grant Likely486ba7e2007-10-02 12:15:29 +100055 .calibrate_decr = generic_calibrate_decr,
56};