diff options
-rw-r--r-- | arch/x86/kernel/aperture_64.c | 54 |
1 files changed, 26 insertions, 28 deletions
diff --git a/arch/x86/kernel/aperture_64.c b/arch/x86/kernel/aperture_64.c index 9fa8aa051f54..b11edf2b656d 100644 --- a/arch/x86/kernel/aperture_64.c +++ b/arch/x86/kernel/aperture_64.c | |||
@@ -10,6 +10,8 @@ | |||
10 | * | 10 | * |
11 | * Copyright 2002 Andi Kleen, SuSE Labs. | 11 | * Copyright 2002 Andi Kleen, SuSE Labs. |
12 | */ | 12 | */ |
13 | #define pr_fmt(fmt) "AGP: " fmt | ||
14 | |||
13 | #include <linux/kernel.h> | 15 | #include <linux/kernel.h> |
14 | #include <linux/types.h> | 16 | #include <linux/types.h> |
15 | #include <linux/init.h> | 17 | #include <linux/init.h> |
@@ -75,14 +77,13 @@ static u32 __init allocate_aperture(void) | |||
75 | addr = memblock_find_in_range(GART_MIN_ADDR, GART_MAX_ADDR, | 77 | addr = memblock_find_in_range(GART_MIN_ADDR, GART_MAX_ADDR, |
76 | aper_size, aper_size); | 78 | aper_size, aper_size); |
77 | if (!addr) { | 79 | if (!addr) { |
78 | printk(KERN_ERR | 80 | pr_err("Cannot allocate aperture memory hole (%lx,%uK)\n", |
79 | "Cannot allocate aperture memory hole (%lx,%uK)\n", | 81 | addr, aper_size>>10); |
80 | addr, aper_size>>10); | ||
81 | return 0; | 82 | return 0; |
82 | } | 83 | } |
83 | memblock_reserve(addr, aper_size); | 84 | memblock_reserve(addr, aper_size); |
84 | printk(KERN_INFO "Mapping aperture over %d KB of RAM @ %lx\n", | 85 | pr_info("Mapping aperture over %d KB of RAM @ %lx\n", aper_size >> 10, |
85 | aper_size >> 10, addr); | 86 | addr); |
86 | register_nosave_region(addr >> PAGE_SHIFT, | 87 | register_nosave_region(addr >> PAGE_SHIFT, |
87 | (addr+aper_size) >> PAGE_SHIFT); | 88 | (addr+aper_size) >> PAGE_SHIFT); |
88 | 89 | ||
@@ -126,10 +127,10 @@ static u32 __init read_agp(int bus, int slot, int func, int cap, u32 *order) | |||
126 | u64 aper; | 127 | u64 aper; |
127 | u32 old_order; | 128 | u32 old_order; |
128 | 129 | ||
129 | printk(KERN_INFO "AGP bridge at %02x:%02x:%02x\n", bus, slot, func); | 130 | pr_info("AGP bridge at %02x:%02x:%02x\n", bus, slot, func); |
130 | apsizereg = read_pci_config_16(bus, slot, func, cap + 0x14); | 131 | apsizereg = read_pci_config_16(bus, slot, func, cap + 0x14); |
131 | if (apsizereg == 0xffffffff) { | 132 | if (apsizereg == 0xffffffff) { |
132 | printk(KERN_ERR "APSIZE in AGP bridge unreadable\n"); | 133 | pr_err("APSIZE in AGP bridge unreadable\n"); |
133 | return 0; | 134 | return 0; |
134 | } | 135 | } |
135 | 136 | ||
@@ -153,16 +154,16 @@ static u32 __init read_agp(int bus, int slot, int func, int cap, u32 *order) | |||
153 | * On some sick chips, APSIZE is 0. It means it wants 4G | 154 | * On some sick chips, APSIZE is 0. It means it wants 4G |
154 | * so let double check that order, and lets trust AMD NB settings: | 155 | * so let double check that order, and lets trust AMD NB settings: |
155 | */ | 156 | */ |
156 | printk(KERN_INFO "Aperture from AGP @ %Lx old size %u MB\n", | 157 | pr_info("Aperture from AGP @ %Lx old size %u MB\n", |
157 | aper, 32 << old_order); | 158 | aper, 32 << old_order); |
158 | if (aper + (32ULL<<(20 + *order)) > 0x100000000ULL) { | 159 | if (aper + (32ULL<<(20 + *order)) > 0x100000000ULL) { |
159 | printk(KERN_INFO "Aperture size %u MB (APSIZE %x) is not right, using settings from NB\n", | 160 | pr_info("Aperture size %u MB (APSIZE %x) is not right, using settings from NB\n", |
160 | 32 << *order, apsizereg); | 161 | 32 << *order, apsizereg); |
161 | *order = old_order; | 162 | *order = old_order; |
162 | } | 163 | } |
163 | 164 | ||
164 | printk(KERN_INFO "Aperture from AGP @ %Lx size %u MB (APSIZE %x)\n", | 165 | pr_info("Aperture from AGP @ %Lx size %u MB (APSIZE %x)\n", aper, |
165 | aper, 32 << *order, apsizereg); | 166 | 32 << *order, apsizereg); |
166 | 167 | ||
167 | if (!aperture_valid(aper, (32*1024*1024) << *order, 32<<20)) | 168 | if (!aperture_valid(aper, (32*1024*1024) << *order, 32<<20)) |
168 | return 0; | 169 | return 0; |
@@ -218,7 +219,7 @@ static u32 __init search_agp_bridge(u32 *order, int *valid_agp) | |||
218 | } | 219 | } |
219 | } | 220 | } |
220 | } | 221 | } |
221 | printk(KERN_INFO "No AGP bridge found\n"); | 222 | pr_info("No AGP bridge found\n"); |
222 | 223 | ||
223 | return 0; | 224 | return 0; |
224 | } | 225 | } |
@@ -310,7 +311,7 @@ void __init early_gart_iommu_check(void) | |||
310 | if (e820_any_mapped(aper_base, aper_base + aper_size, | 311 | if (e820_any_mapped(aper_base, aper_base + aper_size, |
311 | E820_RAM)) { | 312 | E820_RAM)) { |
312 | /* reserve it, so we can reuse it in second kernel */ | 313 | /* reserve it, so we can reuse it in second kernel */ |
313 | printk(KERN_INFO "update e820 for GART\n"); | 314 | pr_info("update e820 for GART\n"); |
314 | e820_add_region(aper_base, aper_size, E820_RESERVED); | 315 | e820_add_region(aper_base, aper_size, E820_RESERVED); |
315 | update_e820(); | 316 | update_e820(); |
316 | } | 317 | } |
@@ -354,7 +355,7 @@ int __init gart_iommu_hole_init(void) | |||
354 | !early_pci_allowed()) | 355 | !early_pci_allowed()) |
355 | return -ENODEV; | 356 | return -ENODEV; |
356 | 357 | ||
357 | printk(KERN_INFO "Checking aperture...\n"); | 358 | pr_info("Checking aperture...\n"); |
358 | 359 | ||
359 | if (!fallback_aper_force) | 360 | if (!fallback_aper_force) |
360 | agp_aper_base = search_agp_bridge(&agp_aper_order, &valid_agp); | 361 | agp_aper_base = search_agp_bridge(&agp_aper_order, &valid_agp); |
@@ -395,8 +396,8 @@ int __init gart_iommu_hole_init(void) | |||
395 | aper_base = read_pci_config(bus, slot, 3, AMD64_GARTAPERTUREBASE) & 0x7fff; | 396 | aper_base = read_pci_config(bus, slot, 3, AMD64_GARTAPERTUREBASE) & 0x7fff; |
396 | aper_base <<= 25; | 397 | aper_base <<= 25; |
397 | 398 | ||
398 | printk(KERN_INFO "Node %d: aperture @ %Lx size %u MB\n", | 399 | pr_info("Node %d: aperture @ %Lx size %u MB\n", |
399 | node, aper_base, aper_size >> 20); | 400 | node, aper_base, aper_size >> 20); |
400 | node++; | 401 | node++; |
401 | 402 | ||
402 | if (!aperture_valid(aper_base, aper_size, 64<<20)) { | 403 | if (!aperture_valid(aper_base, aper_size, 64<<20)) { |
@@ -407,9 +408,9 @@ int __init gart_iommu_hole_init(void) | |||
407 | if (!no_iommu && | 408 | if (!no_iommu && |
408 | max_pfn > MAX_DMA32_PFN && | 409 | max_pfn > MAX_DMA32_PFN && |
409 | !printed_gart_size_msg) { | 410 | !printed_gart_size_msg) { |
410 | printk(KERN_ERR "you are using iommu with agp, but GART size is less than 64M\n"); | 411 | pr_err("you are using iommu with agp, but GART size is less than 64M\n"); |
411 | printk(KERN_ERR "please increase GART size in your BIOS setup\n"); | 412 | pr_err("please increase GART size in your BIOS setup\n"); |
412 | printk(KERN_ERR "if BIOS doesn't have that option, contact your HW vendor!\n"); | 413 | pr_err("if BIOS doesn't have that option, contact your HW vendor!\n"); |
413 | printed_gart_size_msg = 1; | 414 | printed_gart_size_msg = 1; |
414 | } | 415 | } |
415 | } else { | 416 | } else { |
@@ -446,13 +447,10 @@ out: | |||
446 | force_iommu || | 447 | force_iommu || |
447 | valid_agp || | 448 | valid_agp || |
448 | fallback_aper_force) { | 449 | fallback_aper_force) { |
449 | printk(KERN_INFO | 450 | pr_info("Your BIOS doesn't leave a aperture memory hole\n"); |
450 | "Your BIOS doesn't leave a aperture memory hole\n"); | 451 | pr_info("Please enable the IOMMU option in the BIOS setup\n"); |
451 | printk(KERN_INFO | 452 | pr_info("This costs you %d MB of RAM\n", |
452 | "Please enable the IOMMU option in the BIOS setup\n"); | 453 | 32 << fallback_aper_order); |
453 | printk(KERN_INFO | ||
454 | "This costs you %d MB of RAM\n", | ||
455 | 32 << fallback_aper_order); | ||
456 | 454 | ||
457 | aper_order = fallback_aper_order; | 455 | aper_order = fallback_aper_order; |
458 | aper_alloc = allocate_aperture(); | 456 | aper_alloc = allocate_aperture(); |