Yinghai Lu
752bea4abb
x86: reserve dma32 early for gart
...
a system with 256 GB of RAM, when NUMA is disabled crashes the
following way:
Your BIOS doesn't leave a aperture memory hole
Please enable the IOMMU option in the BIOS setup
This costs you 64 MB of RAM
Cannot allocate aperture memory hole (ffff8101c0000000,65536K)
Kernel panic - not syncing: Not enough memory for aperture
Pid: 0, comm: swapper Not tainted 2.6.25-rc4-x86-latest.git #33
Call Trace:
[<ffffffff84037c62>] panic+0xb2/0x190
[<ffffffff840381fc>] ? release_console_sem+0x7c/0x250
[<ffffffff847b1628>] ? __alloc_bootmem_nopanic+0x48/0x90
[<ffffffff847b0ac9>] ? free_bootmem+0x29/0x50
[<ffffffff847ac1f7>] gart_iommu_hole_init+0x5e7/0x680
[<ffffffff847b255b>] ? alloc_large_system_hash+0x16b/0x310
[<ffffffff84506a2f>] ? _etext+0x0/0x1
[<ffffffff847a2e8c>] pci_iommu_alloc+0x1c/0x40
[<ffffffff847ac795>] mem_init+0x45/0x1a0
[<ffffffff8479ff35>] start_kernel+0x295/0x380
[<ffffffff8479f1c2>] _sinittext+0x1c2/0x230
the root cause is : memmap PMD is too big,
[ffffe200e0600000-ffffe200e07fffff] PMD ->ffff81383c000000 on node 0
almost near 4G..., and vmemmap_alloc_block will use up the ram under 4G.
solution will be:
1. make memmap allocation get memory above 4G...
2. reserve some dma32 range early before we try to set up memmap for all.
and release that before pci_iommu_alloc, so gart or swiotlb could get some
range under 4g limit for sure.
the patch is using method 2.
because method1 may need more code to handle SPARSEMEM and SPASEMEM_VMEMMAP
will get
Your BIOS doesn't leave a aperture memory hole
Please enable the IOMMU option in the BIOS setup
This costs you 64 MB of RAM
Mapping aperture over 65536 KB of RAM @ 4000000
Memory: 264245736k/268959744k available (8484k kernel code, 4187464k reserved, 4004k data, 724k init)
Signed-off-by: Yinghai Lu <yhlu.kernel@gmail.com >
Signed-off-by: Ingo Molnar <mingo@elte.hu >
Signed-off-by: Thomas Gleixner <tglx@linutronix.de >
2008-04-19 19:19:55 +02:00
..
2008-04-17 17:41:07 +02:00
2008-04-17 17:41:34 +02:00
2008-04-17 17:41:33 +02:00
2008-04-17 17:41:08 +02:00
2008-04-17 17:41:08 +02:00
2008-03-27 16:08:45 +01:00
2008-04-17 17:41:08 +02:00
2008-04-17 17:41:33 +02:00
2008-02-03 16:20:13 +02:00
2008-04-17 17:41:33 +02:00
2008-04-17 17:41:21 +02:00
2008-02-08 09:22:29 -08:00
2008-04-17 17:41:21 +02:00
2008-01-30 13:34:07 +01:00
2007-10-17 20:16:29 +02:00
2008-04-17 17:41:21 +02:00
2008-04-17 17:41:21 +02:00
2008-04-17 17:41:33 +02:00
2008-01-30 13:30:17 +01:00
2008-02-04 16:47:56 +01:00
2008-04-17 17:41:21 +02:00
2008-04-17 17:41:21 +02:00
2007-10-17 20:17:13 +02:00
2008-04-17 17:41:05 +02:00
2008-04-17 17:41:21 +02:00
2008-04-17 17:41:22 +02:00
2008-04-17 17:41:22 +02:00
2008-04-19 19:19:54 +02:00
2008-01-30 13:31:19 +01:00
2008-04-17 17:41:22 +02:00
2008-02-04 16:48:04 +01:00
2008-04-17 17:41:22 +02:00
2007-10-17 20:17:15 +02:00
2008-04-17 17:41:31 +02:00
2008-01-30 13:32:49 +01:00
2008-04-17 17:41:22 +02:00
2008-04-17 17:41:22 +02:00
2008-04-17 17:41:22 +02:00
2008-04-17 17:41:22 +02:00
2008-04-17 17:41:22 +02:00
2008-02-01 17:49:43 +01:00
2008-04-17 17:41:19 +02:00
2007-10-17 20:17:08 +02:00
2008-04-17 17:41:22 +02:00
2008-04-17 17:41:22 +02:00
2007-10-17 20:35:37 +02:00
2008-02-06 10:41:06 -08:00
2008-04-17 17:41:22 +02:00
2008-04-17 17:41:22 +02:00
2007-10-22 08:13:19 -07:00
2008-04-17 17:41:22 +02:00
2007-10-22 21:20:01 +02:00
2007-10-16 11:26:02 +02:00
2008-04-17 17:41:22 +02:00
2008-01-30 13:33:44 +01:00
2008-01-30 13:32:03 +01:00
2008-04-17 17:41:22 +02:00
2008-04-19 19:19:55 +02:00
2008-04-17 17:41:22 +02:00
2008-01-30 13:34:06 +01:00
2008-04-17 17:41:23 +02:00
2008-04-17 17:41:23 +02:00
2008-04-17 17:41:23 +02:00
2008-01-30 13:32:51 +01:00
2007-10-17 20:17:08 +02:00
2007-10-17 20:17:21 +02:00
2008-04-17 17:41:23 +02:00
2008-04-17 17:41:23 +02:00
2008-04-17 17:41:30 +02:00
2007-10-17 20:16:29 +02:00
2008-04-17 17:41:23 +02:00
2008-01-30 13:33:09 +01:00
2008-04-17 17:41:33 +02:00
2008-04-17 17:41:33 +02:00
2008-04-17 17:41:23 +02:00
2008-01-30 13:33:35 +01:00
2007-10-17 20:16:53 +02:00
2008-04-17 17:41:23 +02:00
2008-01-30 13:33:28 +01:00
2008-02-04 16:48:03 +01:00
2008-04-17 17:41:23 +02:00
2008-04-17 17:41:23 +02:00
2008-04-19 19:19:55 +02:00
2008-01-30 13:33:14 +01:00
2008-04-17 17:41:23 +02:00
2008-01-30 13:30:28 +01:00
2008-04-17 17:41:23 +02:00
2008-04-18 00:46:35 +02:00
2008-01-30 13:30:28 +01:00
2007-10-17 20:17:10 +02:00
2008-04-17 17:41:23 +02:00
2008-04-17 17:41:23 +02:00
2008-04-17 17:41:35 +02:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:23 +02:00
2007-10-30 00:22:22 +01:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:24 +02:00
2007-10-23 15:49:47 +10:00
2008-01-30 13:30:16 +01:00
2008-04-17 17:41:33 +02:00
2008-04-18 08:37:01 -07:00
2008-04-17 17:41:24 +02:00
2008-04-17 20:05:37 +02:00
2007-10-17 20:26:13 +02:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:24 +02:00
2008-01-30 17:52:55 +02:00
2008-04-17 17:41:24 +02:00
2008-01-30 18:01:22 +02:00
2007-10-17 20:16:47 +02:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:40:51 +02:00
2008-04-17 17:41:24 +02:00
2008-01-30 13:31:55 +01:00
2008-04-17 17:41:24 +02:00
2008-04-17 17:41:25 +02:00
2008-01-30 13:30:56 +01:00
2007-10-17 20:26:15 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2008-01-30 13:31:43 +01:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:35 +02:00
2007-10-23 22:37:24 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:30 +02:00
2008-04-17 17:41:30 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2007-10-17 20:17:10 +02:00
2008-04-17 17:41:01 +02:00
2008-04-17 17:40:58 +02:00
2008-01-30 13:34:10 +01:00
2008-04-19 19:19:55 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:25 +02:00
2008-04-17 17:41:30 +02:00
2008-04-17 17:41:30 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:30 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:19 +02:00
2007-10-12 15:03:20 -07:00
2008-04-19 19:19:55 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:26 +02:00
2008-02-08 09:22:42 -08:00
2008-02-08 09:22:42 -08:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:26 +02:00
2007-10-16 11:51:29 -07:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:29 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:41:26 +02:00
2008-04-17 17:40:58 +02:00
2007-10-13 10:18:19 +02:00
2008-04-19 19:19:55 +02:00
2008-04-17 17:41:30 +02:00
2008-02-29 18:55:43 +01:00
2008-04-17 17:41:33 +02:00
2008-04-17 17:41:27 +02:00
2007-10-23 22:37:24 +02:00
2007-10-17 20:17:08 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:27 +02:00
2007-10-17 20:17:08 +02:00
2008-01-30 13:30:34 +01:00
2008-04-17 17:41:27 +02:00
2008-01-30 13:30:21 +01:00
2007-10-17 20:17:08 +02:00
2008-04-17 17:41:29 +02:00
2008-04-17 10:42:34 -04:00
2007-10-17 20:17:10 +02:00
2007-10-17 20:17:09 +02:00
2008-04-17 17:41:27 +02:00
2007-10-23 22:37:24 +02:00
2007-10-17 20:17:10 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:27 +02:00
2007-10-17 20:26:17 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:37 +02:00
2008-01-31 19:27:19 -08:00
2007-10-17 20:17:09 +02:00
2008-04-17 17:41:33 +02:00
2008-01-30 13:31:21 +01:00
2008-04-17 17:41:29 +02:00
2008-04-17 17:41:27 +02:00
2008-01-30 13:33:07 +01:00
2007-10-23 22:37:24 +02:00
2007-10-23 22:37:24 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:27 +02:00
2008-04-17 17:41:30 +02:00
2008-01-30 13:31:08 +01:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:28 +02:00
2007-10-17 20:17:10 +02:00
2008-02-07 08:42:16 -08:00
2008-04-19 19:19:55 +02:00
2008-04-19 19:19:55 +02:00
2008-04-19 19:19:55 +02:00
2008-01-30 13:31:10 +01:00
2008-01-30 13:30:06 +01:00
2008-02-06 10:41:02 -08:00
2007-10-17 20:26:18 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:34 +02:00
2008-04-17 17:41:37 +02:00
2008-04-19 19:19:55 +02:00
2007-10-17 20:32:07 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:28 +02:00
2007-10-17 20:17:10 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:40:58 +02:00
2007-10-17 20:32:38 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:28 +02:00
2008-02-07 08:42:30 -08:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:33 +02:00
2008-04-17 17:41:28 +02:00
2008-04-17 17:41:29 +02:00
2008-01-30 13:32:39 +01:00
2008-04-17 17:41:29 +02:00
2008-04-17 17:41:29 +02:00