| /* |
| * Copyright 2008-2011, IBM Corporation |
| * |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License |
| * as published by the Free Software Foundation; either version |
| * 2 of the License, or (at your option) any later version. |
| */ |
| |
| #include <linux/delay.h> |
| #include <linux/init.h> |
| #include <linux/irq.h> |
| #include <linux/kernel.h> |
| #include <linux/mm.h> |
| #include <linux/of.h> |
| #include <linux/smp.h> |
| |
| #include <asm/machdep.h> |
| #include <asm/system.h> |
| #include <asm/time.h> |
| #include <asm/udbg.h> |
| |
| #include "ics.h" |
| #include "wsp.h" |
| |
| |
| static void psr2_spin(void) |
| { |
| hard_irq_disable(); |
| for (;;) ; |
| } |
| |
| static void psr2_restart(char *cmd) |
| { |
| psr2_spin(); |
| } |
| |
| static int psr2_probe_devices(void) |
| { |
| struct device_node *np; |
| |
| /* Our RTC is a ds1500. It seems to be programatically compatible |
| * with the ds1511 for which we have a driver so let's use that |
| */ |
| np = of_find_compatible_node(NULL, NULL, "dallas,ds1500"); |
| if (np != NULL) { |
| struct resource res; |
| if (of_address_to_resource(np, 0, &res) == 0) |
| platform_device_register_simple("ds1511", 0, &res, 1); |
| } |
| return 0; |
| } |
| machine_arch_initcall(psr2_md, psr2_probe_devices); |
| |
| static void __init psr2_setup_arch(void) |
| { |
| /* init to some ~sane value until calibrate_delay() runs */ |
| loops_per_jiffy = 50000000; |
| |
| scom_init_wsp(); |
| |
| /* Setup SMP callback */ |
| #ifdef CONFIG_SMP |
| a2_setup_smp(); |
| #endif |
| } |
| |
| static int __init psr2_probe(void) |
| { |
| unsigned long root = of_get_flat_dt_root(); |
| |
| if (!of_flat_dt_is_compatible(root, "ibm,psr2")) |
| return 0; |
| |
| return 1; |
| } |
| |
| static void __init psr2_init_irq(void) |
| { |
| wsp_init_irq(); |
| opb_pic_init(); |
| } |
| |
| define_machine(psr2_md) { |
| .name = "PSR2 A2", |
| .probe = psr2_probe, |
| .setup_arch = psr2_setup_arch, |
| .restart = psr2_restart, |
| .power_off = psr2_spin, |
| .halt = psr2_spin, |
| .calibrate_decr = generic_calibrate_decr, |
| .init_IRQ = psr2_init_irq, |
| .progress = udbg_progress, |
| .power_save = book3e_idle, |
| }; |