70 lines
		
	
	
	
		
			1.7 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			70 lines
		
	
	
	
		
			1.7 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * P5020 DS Setup
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Maintained by Kumar Gala (see MAINTAINERS for contact information)
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Copyright 2009-2010 Freescale Semiconductor Inc.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * 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/kernel.h>
							 | 
						||
| 
								 | 
							
								#include <linux/pci.h>
							 | 
						||
| 
								 | 
							
								#include <linux/kdev_t.h>
							 | 
						||
| 
								 | 
							
								#include <linux/delay.h>
							 | 
						||
| 
								 | 
							
								#include <linux/interrupt.h>
							 | 
						||
| 
								 | 
							
								#include <linux/phy.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <asm/system.h>
							 | 
						||
| 
								 | 
							
								#include <asm/time.h>
							 | 
						||
| 
								 | 
							
								#include <asm/machdep.h>
							 | 
						||
| 
								 | 
							
								#include <asm/pci-bridge.h>
							 | 
						||
| 
								 | 
							
								#include <mm/mmu_decl.h>
							 | 
						||
| 
								 | 
							
								#include <asm/prom.h>
							 | 
						||
| 
								 | 
							
								#include <asm/udbg.h>
							 | 
						||
| 
								 | 
							
								#include <asm/mpic.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <linux/of_platform.h>
							 | 
						||
| 
								 | 
							
								#include <sysdev/fsl_soc.h>
							 | 
						||
| 
								 | 
							
								#include <sysdev/fsl_pci.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include "corenet_ds.h"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Called very early, device-tree isn't unflattened
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								static int __init p5020_ds_probe(void)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
									unsigned long root = of_get_flat_dt_root();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									return of_flat_dt_is_compatible(root, "fsl,P5020DS");
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								define_machine(p5020_ds) {
							 | 
						||
| 
								 | 
							
									.name			= "P5020 DS",
							 | 
						||
| 
								 | 
							
									.probe			= p5020_ds_probe,
							 | 
						||
| 
								 | 
							
									.setup_arch		= corenet_ds_setup_arch,
							 | 
						||
| 
								 | 
							
									.init_IRQ		= corenet_ds_pic_init,
							 | 
						||
| 
								 | 
							
								#ifdef CONFIG_PCI
							 | 
						||
| 
								 | 
							
									.pcibios_fixup_bus	= fsl_pcibios_fixup_bus,
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								/* coreint doesn't play nice with lazy EE, use legacy mpic for now */
							 | 
						||
| 
								 | 
							
								#ifdef CONFIG_PPC64
							 | 
						||
| 
								 | 
							
									.get_irq		= mpic_get_irq,
							 | 
						||
| 
								 | 
							
								#else
							 | 
						||
| 
								 | 
							
									.get_irq		= mpic_get_coreint_irq,
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
									.restart		= fsl_rstcr_restart,
							 | 
						||
| 
								 | 
							
									.calibrate_decr		= generic_calibrate_decr,
							 | 
						||
| 
								 | 
							
									.progress		= udbg_progress,
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								machine_device_initcall(p5020_ds, corenet_ds_publish_devices);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef CONFIG_SWIOTLB
							 | 
						||
| 
								 | 
							
								machine_arch_initcall(p5020_ds, swiotlb_setup_bus_notifier);
							 | 
						||
| 
								 | 
							
								#endif
							 |