18c2ecf20Sopenharmony_ci/* 28c2ecf20Sopenharmony_ci * Copyright 2012 (C), Thomas Petazzoni <thomas.petazzoni@free-electrons.com> 38c2ecf20Sopenharmony_ci * 48c2ecf20Sopenharmony_ci * arch/arm/mach-orion5x/board-dt.c 58c2ecf20Sopenharmony_ci * 68c2ecf20Sopenharmony_ci * Flattened Device Tree board initialization 78c2ecf20Sopenharmony_ci * 88c2ecf20Sopenharmony_ci * This file is licensed under the terms of the GNU General Public 98c2ecf20Sopenharmony_ci * License version 2. This program is licensed "as is" without any 108c2ecf20Sopenharmony_ci * warranty of any kind, whether express or implied. 118c2ecf20Sopenharmony_ci */ 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci#include <linux/kernel.h> 148c2ecf20Sopenharmony_ci#include <linux/init.h> 158c2ecf20Sopenharmony_ci#include <linux/of.h> 168c2ecf20Sopenharmony_ci#include <linux/of_platform.h> 178c2ecf20Sopenharmony_ci#include <linux/cpu.h> 188c2ecf20Sopenharmony_ci#include <linux/mbus.h> 198c2ecf20Sopenharmony_ci#include <linux/clocksource.h> 208c2ecf20Sopenharmony_ci#include <asm/system_misc.h> 218c2ecf20Sopenharmony_ci#include <asm/mach/arch.h> 228c2ecf20Sopenharmony_ci#include <asm/mach/map.h> 238c2ecf20Sopenharmony_ci#include <plat/irq.h> 248c2ecf20Sopenharmony_ci#include <plat/time.h> 258c2ecf20Sopenharmony_ci#include "orion5x.h" 268c2ecf20Sopenharmony_ci#include "bridge-regs.h" 278c2ecf20Sopenharmony_ci#include "common.h" 288c2ecf20Sopenharmony_ci 298c2ecf20Sopenharmony_cistatic struct of_dev_auxdata orion5x_auxdata_lookup[] __initdata = { 308c2ecf20Sopenharmony_ci OF_DEV_AUXDATA("marvell,orion-spi", 0xf1010600, "orion_spi.0", NULL), 318c2ecf20Sopenharmony_ci OF_DEV_AUXDATA("marvell,mv64xxx-i2c", 0xf1011000, "mv64xxx_i2c.0", 328c2ecf20Sopenharmony_ci NULL), 338c2ecf20Sopenharmony_ci OF_DEV_AUXDATA("marvell,orion-wdt", 0xf1020300, "orion_wdt", NULL), 348c2ecf20Sopenharmony_ci OF_DEV_AUXDATA("marvell,orion-sata", 0xf1080000, "sata_mv.0", NULL), 358c2ecf20Sopenharmony_ci OF_DEV_AUXDATA("marvell,orion-crypto", 0xf1090000, "mv_crypto", NULL), 368c2ecf20Sopenharmony_ci {}, 378c2ecf20Sopenharmony_ci}; 388c2ecf20Sopenharmony_ci 398c2ecf20Sopenharmony_cistatic void __init orion5x_dt_init(void) 408c2ecf20Sopenharmony_ci{ 418c2ecf20Sopenharmony_ci char *dev_name; 428c2ecf20Sopenharmony_ci u32 dev, rev; 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci orion5x_id(&dev, &rev, &dev_name); 458c2ecf20Sopenharmony_ci printk(KERN_INFO "Orion ID: %s. TCLK=%d.\n", dev_name, orion5x_tclk); 468c2ecf20Sopenharmony_ci 478c2ecf20Sopenharmony_ci BUG_ON(mvebu_mbus_dt_init(false)); 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_ci /* 508c2ecf20Sopenharmony_ci * Setup Orion address map 518c2ecf20Sopenharmony_ci */ 528c2ecf20Sopenharmony_ci orion5x_setup_wins(); 538c2ecf20Sopenharmony_ci 548c2ecf20Sopenharmony_ci /* 558c2ecf20Sopenharmony_ci * Don't issue "Wait for Interrupt" instruction if we are 568c2ecf20Sopenharmony_ci * running on D0 5281 silicon. 578c2ecf20Sopenharmony_ci */ 588c2ecf20Sopenharmony_ci if (dev == MV88F5281_DEV_ID && rev == MV88F5281_REV_D0) { 598c2ecf20Sopenharmony_ci printk(KERN_INFO "Orion: Applying 5281 D0 WFI workaround.\n"); 608c2ecf20Sopenharmony_ci cpu_idle_poll_ctrl(true); 618c2ecf20Sopenharmony_ci } 628c2ecf20Sopenharmony_ci 638c2ecf20Sopenharmony_ci if (of_machine_is_compatible("maxtor,shared-storage-2")) 648c2ecf20Sopenharmony_ci mss2_init(); 658c2ecf20Sopenharmony_ci 668c2ecf20Sopenharmony_ci if (of_machine_is_compatible("lacie,d2-network")) 678c2ecf20Sopenharmony_ci d2net_init(); 688c2ecf20Sopenharmony_ci 698c2ecf20Sopenharmony_ci of_platform_default_populate(NULL, orion5x_auxdata_lookup, NULL); 708c2ecf20Sopenharmony_ci} 718c2ecf20Sopenharmony_ci 728c2ecf20Sopenharmony_cistatic const char *orion5x_dt_compat[] = { 738c2ecf20Sopenharmony_ci "marvell,orion5x", 748c2ecf20Sopenharmony_ci NULL, 758c2ecf20Sopenharmony_ci}; 768c2ecf20Sopenharmony_ci 778c2ecf20Sopenharmony_ciDT_MACHINE_START(ORION5X_DT, "Marvell Orion5x (Flattened Device Tree)") 788c2ecf20Sopenharmony_ci /* Maintainer: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> */ 798c2ecf20Sopenharmony_ci .map_io = orion5x_map_io, 808c2ecf20Sopenharmony_ci .init_machine = orion5x_dt_init, 818c2ecf20Sopenharmony_ci .restart = orion5x_restart, 828c2ecf20Sopenharmony_ci .dt_compat = orion5x_dt_compat, 838c2ecf20Sopenharmony_ciMACHINE_END 84