public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH -v5 0/38] x86: not use  bootmem for x86
@ 2010-01-22  9:24 Yinghai Lu
  2010-01-22  9:24 ` [PATCH 01/38] x86: move range related operation to one file Yinghai Lu
                   ` (38 more replies)
  0 siblings, 39 replies; 44+ messages in thread
From: Yinghai Lu @ 2010-01-22  9:24 UTC (permalink / raw)
  To: Ingo Molnar, Thomas Gleixner, H. Peter Anvin, Andrew Morton,
	Linus Torvalds
  Cc: Jesse Barnes, Christoph Lameter, linux-kernel, linux-pci,
	Yinghai Lu

please check the patches regarding with early_res and bootmem

it will use early_res instead of bootmem with x86 code.
but still can use CONFIG_NO_BOOMEM to use bootmem or not
so could make transistion more smoothly

-v2: allocate vmemmap on one node together, and also seperate early_res
-v3: make x86 32 bit support early_res to use bootmem too
     move related early_res to kernel/
     sparse vmemmap together: address Ingo.
-v4: some patches could go with tip with acked-by Jesse
     radix and logical flat etc
-v5: put back to 2 patches into this patch to make it consistent
     as linus pointed out that some place should replace size_t
     with resource_size_t, and acctually that is done already in
     those patches in pci/linux-next.

------------------------
http://lkml.indiana.edu/hypermail/linux/kernel/0910.3/01432.html
Ingo said:
" I think we could remove the bootmem allocator middle man altogether.

This can be done by initializing the page allocator sooner and by
extending (already existing) 'reserve memory early on' mechanisms in
architecture code. (the reserve_early*() APIs in x86 for example)

Right now we have 5 memory allocation models on x86, initialized
gradually:

- allocator (buddy) [generic]
- early allocator (bootmem) [generic]
- very early allocator (reserve_early*()) [x86]
- very very early allocator (early brk model) [x86]
- very very very early allocator (build time .data/.bss) [generic]

Seems excessive.

The reserve_early() method is list/range based and can handle vast
amounts of not very fragmented memory - perfect for basically all the
real bootmem purposes (which is to bootstrap the buddy).

reserve_early() allocated memory could be freed into the buddy later on
as well. The main reason why bootmem is 'destroyed' during free-to-buddy
is because it has excessive internal bitmaps we want to free. With a
list/range based reserve_early() mechanism there's no such problem -
they can linger indefinitely and there's near zero allocation management
overhead. "


--------x86 early_res related-------------
6177dab: x86: move range related operation to one file
286b89f: x86: check range in update range
533fe49: x86/pci: use resource_size_t in update_res
8cbccb6: x86/pci: amd one chain system to use pci read out res
468ee0f: x86/pci: use u64 instead of size_t in amd_bus.c
a172402: x86/pci: add cap_resource
b413799: x86/pci: enable pci root res read out for 32bit too
c468433: x86: call early_res_to_bootmem one time
12f337a: x86: introduce max_early_res and early_res_count
d5c865f: x86: dynamic increase early_res array size
5f01502: x86: print bootmem free before pci_iommu_alloc and free_all_bootmem -v2
40f0e84: x86: make early_node_mem get mem > 4g if possible
ce55404: x86: only call dma32_reserve_bootmem 64bit !CONFIG_NUMA
204800e: x86: make 64 bit use early_res instead of bootmem before slab
72baf8f: sparsemem: put usemap for one node together
b7c8e11: sparsemem: put mem map for one node together.
85b21ab: x86: change range end to start+size
a273204: x86: move bios page reserve early to head32/64.c
3bd2a608: x86: seperate early_res related code from e820.c
a585c37: x86: add find_early_area_size
e7ab98a: x86: move back find_e820_area to e820.c
c1c9ac5: early_res: enhance check_and_double_early_res
379a00d: x86: make 32bit support NO_BOOTMEM
08e88ed: move round_up/down to kernel.h
6aaa2f6: x86: add find_fw_memmap_area
6feb12b: core: move early_res
3ef2c47: x86: print out for RAM buffer
37d0914: x86: remove bios data range from e820
c2ca100: x86/pci: add mmconf range into e820 for when it is from MSR with amd faml0h

---------spareirq radix tree related ----------------
7b4e03a: irq: remove not need bootmem code
a52a59f: radix: move radix init early
dae4819: sparseirq: change irq_desc_ptrs to static
8dba1e8: sparseirq: use radix_tree instead of ptrs array
99e4f33: x86: remove arch_probe_nr_irqs

---------------x86 logical flat related -----------
8f5be57: use nr_cpus= to set nr_cpu_ids early
52db1e9: x86: according to nr_cpu_ids to decide if need to leave logical flat
289c6fc: x86: make 32bit apic flat to physflat switch like 64bit
4e5585b: x86: use num_processors for possible cpus

Thanks

Yinghai

^ permalink raw reply	[flat|nested] 44+ messages in thread

end of thread, other threads:[~2010-01-26  2:16 UTC | newest]

Thread overview: 44+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-01-22  9:24 [PATCH -v5 0/38] x86: not use bootmem for x86 Yinghai Lu
2010-01-22  9:24 ` [PATCH 01/38] x86: move range related operation to one file Yinghai Lu
2010-01-22  9:24 ` [PATCH 02/38] x86: check range in update range Yinghai Lu
2010-01-22  9:24 ` [PATCH 03/38] x86/pci: use resource_size_t in update_res Yinghai Lu
2010-01-22  9:24 ` [PATCH 04/38] x86/pci: amd one chain system to use pci read out res Yinghai Lu
2010-01-22  9:24 ` [PATCH 05/38] x86/pci: use u64 instead of size_t in amd_bus.c Yinghai Lu
2010-01-22  9:24 ` [PATCH 06/38] x86/pci: add cap_resource Yinghai Lu
2010-01-22  9:24 ` [PATCH 07/38] x86/pci: enable pci root res read out for 32bit too Yinghai Lu
2010-01-22  9:24 ` [PATCH 08/38] x86: call early_res_to_bootmem one time Yinghai Lu
2010-01-22  9:24 ` [PATCH 09/38] x86: introduce max_early_res and early_res_count Yinghai Lu
2010-01-22  9:24 ` [PATCH 10/38] x86: dynamic increase early_res array size Yinghai Lu
2010-01-22  9:24 ` [PATCH 11/38] x86: print bootmem free before pci_iommu_alloc and free_all_bootmem -v2 Yinghai Lu
2010-01-22  9:24 ` [PATCH 12/38] x86: make early_node_mem get mem > 4g if possible Yinghai Lu
2010-01-22  9:24 ` [PATCH 13/38] x86: only call dma32_reserve_bootmem 64bit !CONFIG_NUMA Yinghai Lu
2010-01-22  9:24 ` [PATCH 14/38] x86: make 64 bit use early_res instead of bootmem before slab Yinghai Lu
2010-01-22  9:24 ` [PATCH 15/38] sparsemem: put usemap for one node together Yinghai Lu
2010-01-22  9:24 ` [PATCH 16/38] sparsemem: put mem map " Yinghai Lu
2010-01-22  9:24 ` [PATCH 17/38] x86: change range end to start+size Yinghai Lu
2010-01-22  9:24 ` [PATCH 18/38] x86: move bios page reserve early to head32/64.c Yinghai Lu
2010-01-22  9:24 ` [PATCH 19/38] x86: seperate early_res related code from e820.c Yinghai Lu
2010-01-22  9:24 ` [PATCH 20/38] x86: add find_early_area_size Yinghai Lu
2010-01-22  9:24 ` [PATCH 21/38] x86: move back find_e820_area to e820.c Yinghai Lu
2010-01-22  9:24 ` [PATCH 22/38] early_res: enhance check_and_double_early_res Yinghai Lu
2010-01-22  9:24 ` [PATCH 23/38] x86: make 32bit support NO_BOOTMEM Yinghai Lu
2010-01-22  9:24 ` [PATCH 24/38] move round_up/down to kernel.h Yinghai Lu
2010-01-22 14:52   ` Christoph Lameter
2010-01-22 19:28     ` Joe Perches
2010-01-22 20:08       ` H. Peter Anvin
2010-01-22  9:24 ` [PATCH 25/38] x86: add find_fw_memmap_area Yinghai Lu
2010-01-22  9:24 ` [PATCH 26/38] core: move early_res Yinghai Lu
2010-01-22  9:24 ` [PATCH 27/38] x86: print out for RAM buffer Yinghai Lu
2010-01-22  9:24 ` [PATCH 28/38] x86: remove bios data range from e820 Yinghai Lu
2010-01-22  9:24 ` [PATCH 29/38] x86/pci: add mmconf range into e820 for when it is from MSR with amd faml0h Yinghai Lu
2010-01-22  9:24 ` [PATCH 30/38] irq: remove not need bootmem code Yinghai Lu
2010-01-22  9:24 ` [PATCH 31/38] radix: move radix init early Yinghai Lu
2010-01-22  9:24 ` [PATCH 32/38] sparseirq: change irq_desc_ptrs to static Yinghai Lu
2010-01-22  9:24 ` [PATCH 33/38] sparseirq: use radix_tree instead of ptrs array Yinghai Lu
2010-01-22  9:24 ` [PATCH 34/38] x86: remove arch_probe_nr_irqs Yinghai Lu
2010-01-22  9:24 ` [PATCH 35/38] use nr_cpus= to set nr_cpu_ids early Yinghai Lu
2010-01-22  9:24 ` [PATCH 36/38] x86: according to nr_cpu_ids to decide if need to leave logical flat Yinghai Lu
2010-01-22  9:24 ` [PATCH 37/38] x86: make 32bit apic flat to physflat switch like 64bit Yinghai Lu
2010-01-22  9:24 ` [PATCH 38/38] x86: use num_processors for possible cpus Yinghai Lu
2010-01-26  0:40 ` [PATCH -v5 0/38] x86: not use bootmem for x86 H. Peter Anvin
2010-01-26  2:14   ` Yinghai Lu

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox