mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 48b16180d0
			
		
	
	
		48b16180d0
		
	
	
	
	
		
			
			If we do nothing in suspend/resume, some platform PCIe ip-block can't guarantee the link back to L0 state from sleep, then, when we read the EP device will hang. Only we send pme turnoff message in pci controller suspend, and send pme exit message in resume, the link state will be normal. When we send pme turnoff message in pci controller suspend, the links will into l2/l3 ready, then, host cannot communicate with ep device, but pci-driver will call back EP device to save them state. So we need to change platform_driver->suspend/resume to syscore->suspend/resume. So the new suspend/resume implementation, send pme turnoff message in suspend, and send pme exit message in resume. And add a PME handler, to response PME & message interrupt. Change platform_driver->suspend/resume to syscore->suspend/resume. pci-driver will call back EP device, to save EP state in pci_pm_suspend_noirq, so we need to keep the link, until pci_pm_suspend_noirq finish. Signed-off-by: Wang Dongsheng <dongsheng.wang@freescale.com> Signed-off-by: Scott Wood <scottwood@freescale.com>
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * P1010RDB Board Setup
 | |
|  *
 | |
|  * Copyright 2011 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/stddef.h>
 | |
| #include <linux/kernel.h>
 | |
| #include <linux/pci.h>
 | |
| #include <linux/delay.h>
 | |
| #include <linux/interrupt.h>
 | |
| #include <linux/of_platform.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 <sysdev/fsl_soc.h>
 | |
| #include <sysdev/fsl_pci.h>
 | |
| 
 | |
| #include "mpc85xx.h"
 | |
| 
 | |
| void __init p1010_rdb_pic_init(void)
 | |
| {
 | |
| 	struct mpic *mpic = mpic_alloc(NULL, 0, MPIC_BIG_ENDIAN |
 | |
| 	  MPIC_SINGLE_DEST_CPU,
 | |
| 	  0, 256, " OpenPIC  ");
 | |
| 
 | |
| 	BUG_ON(mpic == NULL);
 | |
| 
 | |
| 	mpic_init(mpic);
 | |
| }
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * Setup the architecture
 | |
|  */
 | |
| static void __init p1010_rdb_setup_arch(void)
 | |
| {
 | |
| 	if (ppc_md.progress)
 | |
| 		ppc_md.progress("p1010_rdb_setup_arch()", 0);
 | |
| 
 | |
| 	fsl_pci_assign_primary();
 | |
| 
 | |
| 	printk(KERN_INFO "P1010 RDB board from Freescale Semiconductor\n");
 | |
| }
 | |
| 
 | |
| machine_arch_initcall(p1010_rdb, mpc85xx_common_publish_devices);
 | |
| machine_arch_initcall(p1010_rdb, swiotlb_setup_bus_notifier);
 | |
| 
 | |
| /*
 | |
|  * Called very early, device-tree isn't unflattened
 | |
|  */
 | |
| static int __init p1010_rdb_probe(void)
 | |
| {
 | |
| 	unsigned long root = of_get_flat_dt_root();
 | |
| 
 | |
| 	if (of_flat_dt_is_compatible(root, "fsl,P1010RDB"))
 | |
| 		return 1;
 | |
| 	if (of_flat_dt_is_compatible(root, "fsl,P1010RDB-PB"))
 | |
| 		return 1;
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| define_machine(p1010_rdb) {
 | |
| 	.name			= "P1010 RDB",
 | |
| 	.probe			= p1010_rdb_probe,
 | |
| 	.setup_arch		= p1010_rdb_setup_arch,
 | |
| 	.init_IRQ		= p1010_rdb_pic_init,
 | |
| #ifdef CONFIG_PCI
 | |
| 	.pcibios_fixup_bus	= fsl_pcibios_fixup_bus,
 | |
| 	.pcibios_fixup_phb      = fsl_pcibios_fixup_phb,
 | |
| #endif
 | |
| 	.get_irq		= mpic_get_irq,
 | |
| 	.restart		= fsl_rstcr_restart,
 | |
| 	.calibrate_decr		= generic_calibrate_decr,
 | |
| 	.progress		= udbg_progress,
 | |
| };
 |