diff options
Diffstat (limited to 'include/asm-x86/gart.h')
-rw-r--r-- | include/asm-x86/gart.h | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/include/asm-x86/gart.h b/include/asm-x86/gart.h index 6f22786d2f0c..c818b96f936b 100644 --- a/include/asm-x86/gart.h +++ b/include/asm-x86/gart.h | |||
@@ -1,6 +1,8 @@ | |||
1 | #ifndef _ASM_X8664_IOMMU_H | 1 | #ifndef _ASM_X8664_IOMMU_H |
2 | #define _ASM_X8664_IOMMU_H 1 | 2 | #define _ASM_X8664_IOMMU_H 1 |
3 | 3 | ||
4 | #include <asm/e820.h> | ||
5 | |||
4 | extern void pci_iommu_shutdown(void); | 6 | extern void pci_iommu_shutdown(void); |
5 | extern void no_iommu_init(void); | 7 | extern void no_iommu_init(void); |
6 | extern int force_iommu, no_iommu; | 8 | extern int force_iommu, no_iommu; |
@@ -69,4 +71,26 @@ static inline void enable_gart_translation(struct pci_dev *dev, u64 addr) | |||
69 | pci_write_config_dword(dev, AMD64_GARTAPERTURECTL, ctl); | 71 | pci_write_config_dword(dev, AMD64_GARTAPERTURECTL, ctl); |
70 | } | 72 | } |
71 | 73 | ||
74 | static inline int aperture_valid(u64 aper_base, u32 aper_size, u32 min_size) | ||
75 | { | ||
76 | if (!aper_base) | ||
77 | return 0; | ||
78 | |||
79 | if (aper_base + aper_size > 0x100000000ULL) { | ||
80 | printk(KERN_ERR "Aperture beyond 4GB. Ignoring.\n"); | ||
81 | return 0; | ||
82 | } | ||
83 | if (e820_any_mapped(aper_base, aper_base + aper_size, E820_RAM)) { | ||
84 | printk(KERN_ERR "Aperture pointing to e820 RAM. Ignoring.\n"); | ||
85 | return 0; | ||
86 | } | ||
87 | if (aper_size < min_size) { | ||
88 | printk(KERN_ERR "Aperture too small (%d MB) than (%d MB)\n", | ||
89 | aper_size>>20, min_size>>20); | ||
90 | return 0; | ||
91 | } | ||
92 | |||
93 | return 1; | ||
94 | } | ||
95 | |||
72 | #endif | 96 | #endif |