mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 21:29:32 +00:00 
			
		
		
		
	 2f671e2dbf
			
		
	
	
		2f671e2dbf
		
	
	
	
	
		
			
			We currently refuse to touch the ASPM registers if the BIOS tells us that ASPM isn't supported. This can cause problems if the BIOS has (for any reason) enabled ASPM on some devices anyway. Change the code such that we explicitly clear ASPM if the FADT indicates that ASPM isn't supported, and make sure we tidy up appropriately on device removal in order to deal with the hotplug case. If ASPM is disabled because the BIOS doesn't hand over control then we won't touch the registers. Signed-off-by: Matthew Garrett <mjg@redhat.com> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *	aspm.h
 | |
|  *
 | |
|  *	PCI Express ASPM defines and function prototypes
 | |
|  *
 | |
|  *	Copyright (C) 2007 Intel Corp.
 | |
|  *		Zhang Yanmin (yanmin.zhang@intel.com)
 | |
|  *		Shaohua Li (shaohua.li@intel.com)
 | |
|  *
 | |
|  *	For more information, please consult the following manuals (look at
 | |
|  *	http://www.pcisig.com/ for how to get them):
 | |
|  *
 | |
|  *	PCI Express Specification
 | |
|  */
 | |
| 
 | |
| #ifndef LINUX_ASPM_H
 | |
| #define LINUX_ASPM_H
 | |
| 
 | |
| #include <linux/pci.h>
 | |
| 
 | |
| #define PCIE_LINK_STATE_L0S	1
 | |
| #define PCIE_LINK_STATE_L1	2
 | |
| #define PCIE_LINK_STATE_CLKPM	4
 | |
| 
 | |
| #ifdef CONFIG_PCIEASPM
 | |
| extern void pcie_aspm_init_link_state(struct pci_dev *pdev);
 | |
| extern void pcie_aspm_exit_link_state(struct pci_dev *pdev);
 | |
| extern void pcie_aspm_pm_state_change(struct pci_dev *pdev);
 | |
| extern void pci_disable_link_state(struct pci_dev *pdev, int state);
 | |
| extern void pcie_clear_aspm(void);
 | |
| extern void pcie_no_aspm(void);
 | |
| #else
 | |
| static inline void pcie_aspm_init_link_state(struct pci_dev *pdev)
 | |
| {
 | |
| }
 | |
| static inline void pcie_aspm_exit_link_state(struct pci_dev *pdev)
 | |
| {
 | |
| }
 | |
| static inline void pcie_aspm_pm_state_change(struct pci_dev *pdev)
 | |
| {
 | |
| }
 | |
| static inline void pci_disable_link_state(struct pci_dev *pdev, int state)
 | |
| {
 | |
| }
 | |
| static inline void pcie_clear_aspm(void)
 | |
| {
 | |
| }
 | |
| static inline void pcie_no_aspm(void)
 | |
| {
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_PCIEASPM_DEBUG /* this depends on CONFIG_PCIEASPM */
 | |
| extern void pcie_aspm_create_sysfs_dev_files(struct pci_dev *pdev);
 | |
| extern void pcie_aspm_remove_sysfs_dev_files(struct pci_dev *pdev);
 | |
| #else
 | |
| static inline void pcie_aspm_create_sysfs_dev_files(struct pci_dev *pdev)
 | |
| {
 | |
| }
 | |
| static inline void pcie_aspm_remove_sysfs_dev_files(struct pci_dev *pdev)
 | |
| {
 | |
| }
 | |
| #endif
 | |
| #endif /* LINUX_ASPM_H */
 |