diff options
author | Ingo Molnar <mingo@elte.hu> | 2008-07-18 07:53:16 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-18 07:53:16 -0400 |
commit | cdbfc557c43ea1f1f9b7062300ecb1254969814b (patch) | |
tree | 255f1cf62cea2c3dec208799a00a116e714a6128 /arch/x86/kernel/pci-dma.c | |
parent | 4d8cc874d7ed43eda72765e9c0e141e170fee4f3 (diff) | |
parent | 5b664cb235e97afbf34db9c4d77f08ebd725335e (diff) |
Merge branch 'linus' into x86/cleanups
Diffstat (limited to 'arch/x86/kernel/pci-dma.c')
-rw-r--r-- | arch/x86/kernel/pci-dma.c | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/arch/x86/kernel/pci-dma.c b/arch/x86/kernel/pci-dma.c index 3cc36b872ae4..8467ec2320f1 100644 --- a/arch/x86/kernel/pci-dma.c +++ b/arch/x86/kernel/pci-dma.c | |||
@@ -7,6 +7,7 @@ | |||
7 | #include <asm/dma.h> | 7 | #include <asm/dma.h> |
8 | #include <asm/gart.h> | 8 | #include <asm/gart.h> |
9 | #include <asm/calgary.h> | 9 | #include <asm/calgary.h> |
10 | #include <asm/amd_iommu.h> | ||
10 | 11 | ||
11 | int forbid_dac __read_mostly; | 12 | int forbid_dac __read_mostly; |
12 | EXPORT_SYMBOL(forbid_dac); | 13 | EXPORT_SYMBOL(forbid_dac); |
@@ -74,13 +75,17 @@ early_param("dma32_size", parse_dma32_size_opt); | |||
74 | void __init dma32_reserve_bootmem(void) | 75 | void __init dma32_reserve_bootmem(void) |
75 | { | 76 | { |
76 | unsigned long size, align; | 77 | unsigned long size, align; |
77 | if (end_pfn <= MAX_DMA32_PFN) | 78 | if (max_pfn <= MAX_DMA32_PFN) |
78 | return; | 79 | return; |
79 | 80 | ||
81 | /* | ||
82 | * check aperture_64.c allocate_aperture() for reason about | ||
83 | * using 512M as goal | ||
84 | */ | ||
80 | align = 64ULL<<20; | 85 | align = 64ULL<<20; |
81 | size = round_up(dma32_bootmem_size, align); | 86 | size = round_up(dma32_bootmem_size, align); |
82 | dma32_bootmem_ptr = __alloc_bootmem_nopanic(size, align, | 87 | dma32_bootmem_ptr = __alloc_bootmem_nopanic(size, align, |
83 | __pa(MAX_DMA_ADDRESS)); | 88 | 512ULL<<20); |
84 | if (dma32_bootmem_ptr) | 89 | if (dma32_bootmem_ptr) |
85 | dma32_bootmem_size = size; | 90 | dma32_bootmem_size = size; |
86 | else | 91 | else |
@@ -88,17 +93,14 @@ void __init dma32_reserve_bootmem(void) | |||
88 | } | 93 | } |
89 | static void __init dma32_free_bootmem(void) | 94 | static void __init dma32_free_bootmem(void) |
90 | { | 95 | { |
91 | int node; | ||
92 | 96 | ||
93 | if (end_pfn <= MAX_DMA32_PFN) | 97 | if (max_pfn <= MAX_DMA32_PFN) |
94 | return; | 98 | return; |
95 | 99 | ||
96 | if (!dma32_bootmem_ptr) | 100 | if (!dma32_bootmem_ptr) |
97 | return; | 101 | return; |
98 | 102 | ||
99 | for_each_online_node(node) | 103 | free_bootmem(__pa(dma32_bootmem_ptr), dma32_bootmem_size); |
100 | free_bootmem_node(NODE_DATA(node), __pa(dma32_bootmem_ptr), | ||
101 | dma32_bootmem_size); | ||
102 | 104 | ||
103 | dma32_bootmem_ptr = NULL; | 105 | dma32_bootmem_ptr = NULL; |
104 | dma32_bootmem_size = 0; | 106 | dma32_bootmem_size = 0; |
@@ -122,6 +124,8 @@ void __init pci_iommu_alloc(void) | |||
122 | 124 | ||
123 | detect_intel_iommu(); | 125 | detect_intel_iommu(); |
124 | 126 | ||
127 | amd_iommu_detect(); | ||
128 | |||
125 | #ifdef CONFIG_SWIOTLB | 129 | #ifdef CONFIG_SWIOTLB |
126 | pci_swiotlb_init(); | 130 | pci_swiotlb_init(); |
127 | #endif | 131 | #endif |
@@ -502,6 +506,8 @@ static int __init pci_iommu_init(void) | |||
502 | 506 | ||
503 | intel_iommu_init(); | 507 | intel_iommu_init(); |
504 | 508 | ||
509 | amd_iommu_init(); | ||
510 | |||
505 | #ifdef CONFIG_GART_IOMMU | 511 | #ifdef CONFIG_GART_IOMMU |
506 | gart_iommu_init(); | 512 | gart_iommu_init(); |
507 | #endif | 513 | #endif |