| =========================== | 
 | Boot time memory management | 
 | =========================== | 
 |  | 
 | Early system initialization cannot use "normal" memory management | 
 | simply because it is not set up yet. But there is still need to | 
 | allocate memory for various data structures, for instance for the | 
 | physical page allocator. | 
 |  | 
 | A specialized allocator called ``memblock`` performs the | 
 | boot time memory management. The architecture specific initialization | 
 | must set it up in :c:func:`setup_arch` and tear it down in | 
 | :c:func:`mem_init` functions. | 
 |  | 
 | Once the early memory management is available it offers a variety of | 
 | functions and macros for memory allocations. The allocation request | 
 | may be directed to the first (and probably the only) node or to a | 
 | particular node in a NUMA system. There are API variants that panic | 
 | when an allocation fails and those that don't. | 
 |  | 
 | Memblock also offers a variety of APIs that control its own behaviour. | 
 |  | 
 | Memblock Overview | 
 | ================= | 
 |  | 
 | .. kernel-doc:: mm/memblock.c | 
 |    :doc: memblock overview | 
 |  | 
 |  | 
 | Functions and structures | 
 | ======================== | 
 |  | 
 | Here is the description of memblock data structures, functions and | 
 | macros. Some of them are actually internal, but since they are | 
 | documented it would be silly to omit them. Besides, reading the | 
 | descriptions for the internal functions can help to understand what | 
 | really happens under the hood. | 
 |  | 
 | .. kernel-doc:: include/linux/memblock.h | 
 | .. kernel-doc:: mm/memblock.c | 
 |    :functions: |