18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Sam440ep board specific routines based off bamboo.c code 48c2ecf20Sopenharmony_ci * original copyrights below 58c2ecf20Sopenharmony_ci * 68c2ecf20Sopenharmony_ci * Wade Farnsworth <wfarnsworth@mvista.com> 78c2ecf20Sopenharmony_ci * Copyright 2004 MontaVista Software Inc. 88c2ecf20Sopenharmony_ci * 98c2ecf20Sopenharmony_ci * Rewritten and ported to the merged powerpc tree: 108c2ecf20Sopenharmony_ci * Josh Boyer <jwboyer@linux.vnet.ibm.com> 118c2ecf20Sopenharmony_ci * Copyright 2007 IBM Corporation 128c2ecf20Sopenharmony_ci * 138c2ecf20Sopenharmony_ci * Modified from bamboo.c for sam440ep: 148c2ecf20Sopenharmony_ci * Copyright 2008 Giuseppe Coviello <gicoviello@gmail.com> 158c2ecf20Sopenharmony_ci */ 168c2ecf20Sopenharmony_ci#include <linux/init.h> 178c2ecf20Sopenharmony_ci#include <linux/of_platform.h> 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ci#include <asm/machdep.h> 208c2ecf20Sopenharmony_ci#include <asm/prom.h> 218c2ecf20Sopenharmony_ci#include <asm/udbg.h> 228c2ecf20Sopenharmony_ci#include <asm/time.h> 238c2ecf20Sopenharmony_ci#include <asm/uic.h> 248c2ecf20Sopenharmony_ci#include <asm/pci-bridge.h> 258c2ecf20Sopenharmony_ci#include <asm/ppc4xx.h> 268c2ecf20Sopenharmony_ci#include <linux/i2c.h> 278c2ecf20Sopenharmony_ci 288c2ecf20Sopenharmony_cistatic const struct of_device_id sam440ep_of_bus[] __initconst = { 298c2ecf20Sopenharmony_ci { .compatible = "ibm,plb4", }, 308c2ecf20Sopenharmony_ci { .compatible = "ibm,opb", }, 318c2ecf20Sopenharmony_ci { .compatible = "ibm,ebc", }, 328c2ecf20Sopenharmony_ci {}, 338c2ecf20Sopenharmony_ci}; 348c2ecf20Sopenharmony_ci 358c2ecf20Sopenharmony_cistatic int __init sam440ep_device_probe(void) 368c2ecf20Sopenharmony_ci{ 378c2ecf20Sopenharmony_ci of_platform_bus_probe(NULL, sam440ep_of_bus, NULL); 388c2ecf20Sopenharmony_ci 398c2ecf20Sopenharmony_ci return 0; 408c2ecf20Sopenharmony_ci} 418c2ecf20Sopenharmony_cimachine_device_initcall(sam440ep, sam440ep_device_probe); 428c2ecf20Sopenharmony_ci 438c2ecf20Sopenharmony_cistatic int __init sam440ep_probe(void) 448c2ecf20Sopenharmony_ci{ 458c2ecf20Sopenharmony_ci if (!of_machine_is_compatible("acube,sam440ep")) 468c2ecf20Sopenharmony_ci return 0; 478c2ecf20Sopenharmony_ci 488c2ecf20Sopenharmony_ci pci_set_flags(PCI_REASSIGN_ALL_RSRC); 498c2ecf20Sopenharmony_ci 508c2ecf20Sopenharmony_ci return 1; 518c2ecf20Sopenharmony_ci} 528c2ecf20Sopenharmony_ci 538c2ecf20Sopenharmony_cidefine_machine(sam440ep) { 548c2ecf20Sopenharmony_ci .name = "Sam440ep", 558c2ecf20Sopenharmony_ci .probe = sam440ep_probe, 568c2ecf20Sopenharmony_ci .progress = udbg_progress, 578c2ecf20Sopenharmony_ci .init_IRQ = uic_init_tree, 588c2ecf20Sopenharmony_ci .get_irq = uic_get_irq, 598c2ecf20Sopenharmony_ci .restart = ppc4xx_reset_system, 608c2ecf20Sopenharmony_ci .calibrate_decr = generic_calibrate_decr, 618c2ecf20Sopenharmony_ci}; 628c2ecf20Sopenharmony_ci 638c2ecf20Sopenharmony_cistatic struct i2c_board_info sam440ep_rtc_info = { 648c2ecf20Sopenharmony_ci .type = "m41st85", 658c2ecf20Sopenharmony_ci .addr = 0x68, 668c2ecf20Sopenharmony_ci .irq = -1, 678c2ecf20Sopenharmony_ci}; 688c2ecf20Sopenharmony_ci 698c2ecf20Sopenharmony_cistatic int __init sam440ep_setup_rtc(void) 708c2ecf20Sopenharmony_ci{ 718c2ecf20Sopenharmony_ci return i2c_register_board_info(0, &sam440ep_rtc_info, 1); 728c2ecf20Sopenharmony_ci} 738c2ecf20Sopenharmony_cimachine_device_initcall(sam440ep, sam440ep_setup_rtc); 74