/linux/drivers/acpi/acpica/ |
H A D | uttrack.c | 4 * Module Name: uttrack - Memory allocation tracking routines (debug only) 14 * Each memory allocation is tracked via a doubly linked list. Each 32 *allocation); 80 * PARAMETERS: size - Size of the allocation 94 struct acpi_debug_mem_block *allocation; in acpi_ut_allocate_and_track() local 105 allocation = in acpi_ut_allocate_and_track() 107 if (!allocation) { in acpi_ut_allocate_and_track() 109 /* Report allocation error */ in acpi_ut_allocate_and_track() 118 acpi_ut_track_allocation(allocation, size, ACPI_MEM_MALLOC, in acpi_ut_allocate_and_track() 121 acpi_os_free(allocation); in acpi_ut_allocate_and_track() [all …]
|
/linux/tools/testing/selftests/resctrl/ |
H A D | mba_test.c | 3 * Memory Bandwidth Allocation (MBA) test 36 * For each allocation, run 5 times in order to get average values. 42 static int runs_per_allocation, allocation = 100; in mba_setup() local 53 if (allocation < ALLOCATION_MIN || allocation > ALLOCATION_MAX) in mba_setup() 56 sprintf(allocation_str, "%d", allocation); in mba_setup() 62 allocation -= ALLOCATION_STEP; in mba_setup() 75 int allocation, runs; in show_mba_info() local 80 for (allocation = 0; allocation < ALLOCATION_MAX / ALLOCATION_STEP; in show_mba_info() 81 allocation++) { in show_mba_info() 91 for (runs = NUM_OF_RUNS * allocation + 1; in show_mba_info() [all …]
|
/linux/Documentation/core-api/ |
H A D | memory-allocation.rst | 4 Memory Allocation Guide 7 Linux provides a variety of APIs for memory allocation. You can 14 Most of the memory allocation APIs use GFP flags to express how that 16 pages", the underlying memory allocation function. 18 Diversity of the allocation APIs combined with the numerous GFP flags 26 Of course there are cases when other allocation APIs and different GFP 45 * If the allocation is performed from an atomic context, e.g interrupt 48 ``GFP_NOWAIT`` allocation is likely to fail. Users of this flag need 52 will be stressed unless allocation succeeds, you may use ``GFP_ATOMIC``. 67 example may be a hardware allocation that maps data directly into [all …]
|
/linux/tools/perf/pmu-events/arch/x86/sapphirerapids/ |
H A D | uncore-cxl.json | 12 "BriefDescription": "Number of Allocation to Mem Rxx AGF 0", 22 "BriefDescription": "Number of Allocation to Cache Req AGF0", 32 "BriefDescription": "Number of Allocation to Cache Rsp AGF", 42 "BriefDescription": "Number of Allocation to Cache Data AGF", 52 "BriefDescription": "Number of Allocation to Cache Rsp AGF", 62 "BriefDescription": "Number of Allocation to Cache Req AGF 1", 72 "BriefDescription": "Number of Allocation to Mem Data AGF", 252 "BriefDescription": "Number of Allocation to Cache Data Packing buffer", 262 "BriefDescription": "Number of Allocation to Cache Req Packing buffer", 272 "BriefDescription": "Number of Allocation to Cache Rsp Packing buffer", [all …]
|
/linux/tools/perf/pmu-events/arch/x86/emeraldrapids/ |
H A D | uncore-cxl.json | 12 "BriefDescription": "Number of Allocation to Mem Rxx AGF 0", 22 "BriefDescription": "Number of Allocation to Cache Req AGF0", 32 "BriefDescription": "Number of Allocation to Cache Rsp AGF", 42 "BriefDescription": "Number of Allocation to Cache Data AGF", 52 "BriefDescription": "Number of Allocation to Cache Rsp AGF", 62 "BriefDescription": "Number of Allocation to Cache Req AGF 1", 72 "BriefDescription": "Number of Allocation to Mem Data AGF", 252 "BriefDescription": "Number of Allocation to Cache Data Packing buffer", 262 "BriefDescription": "Number of Allocation to Cache Req Packing buffer", 272 "BriefDescription": "Number of Allocation to Cache Rsp Packing buffer", [all …]
|
/linux/drivers/md/dm-vdo/ |
H A D | physical-zone.c | 477 * @allocation: The struct allocation of the data_vio attempting to allocate. 483 static int allocate_and_lock_block(struct allocation *allocation) in allocate_and_lock_block() argument 488 VDO_ASSERT_LOG_ONLY(allocation->lock == NULL, in allocate_and_lock_block() 491 result = vdo_allocate_block(allocation->zone->allocator, &allocation->pbn); in allocate_and_lock_block() 495 result = vdo_attempt_physical_zone_pbn_lock(allocation->zone, allocation->pbn, in allocate_and_lock_block() 496 allocation->write_lock_type, &lock); in allocate_and_lock_block() 504 (unsigned long long) allocation->pbn, in allocate_and_lock_block() 510 allocation->lock = lock; in allocate_and_lock_block() 524 /* Now that some slab has scrubbed, restart the allocation process. */ in retry_allocation() 525 data_vio->allocation.wait_for_clean_slab = false; in retry_allocation() [all …]
|
/linux/mm/ |
H A D | zbud.c | 38 * allocation function, zbud_alloc(), returns an opaque handle to the user, 41 * allocation data and unmap the handle with zbud_unmap() when operations 42 * on the allocation data are complete. 60 * NCHUNKS_ORDER determines the internal allocation granularity, effectively 63 * allocation granularity will be in chunks of size PAGE_SIZE/64. As one chunk 126 /* Converts an allocation size in bytes to size in zbud chunks */ 162 * Add CHUNK_SIZE to the handle if it is the first allocation to jump in encode_handle() 197 * Return: pointer to the new zbud pool or NULL if the metadata allocation 230 * @size: size in bytes of the desired allocation 232 * @handle: handle of the new allocation [all...] |
H A D | dmapool.c | 57 unsigned int allocation; member 63 struct dma_page { /* cacheable header for 'allocation' bytes */ 127 if ((dma - page->dma) < pool->allocation) in pool_find_page() 161 memset(page->vaddr, POOL_POISON_FREED, pool->allocation); in pool_init_page() 221 * Return: a dma allocation pool with the requested characteristics, or 228 size_t allocation; in dma_pool_create() local 245 allocation = max_t(size_t, size, PAGE_SIZE); in dma_pool_create() 248 boundary = allocation; in dma_pool_create() 252 boundary = min(boundary, allocation); in dma_pool_create() 266 retval->allocation = allocation; in dma_pool_create() [all …]
|
/linux/Documentation/trace/ |
H A D | events-kmem.rst | 5 The kmem tracing system captures events related to object and page allocation 8 - Slab allocation of small objects of unknown type (kmalloc) 9 - Slab allocation of small objects of known type 10 - Page allocation 17 1. Slab allocation of small objects of unknown type 27 internal fragmented as a result of the allocation pattern. By correlating 29 the allocation sites were. 32 2. Slab allocation of small objects of known type 45 3. Page allocation 54 These four events deal with page allocation and freeing. mm_page_alloc is [all …]
|
/linux/fs/jfs/ |
H A D | jfs_dmap.c | 19 * SERIALIZATION of the Block Allocation Map. 21 * the working state of the block allocation map is accessed in 24 * 1) allocation and free requests that start at the dmap 28 * 2) allocation requests that start at dmap control page 46 * the working state of the block allocation map also includes read/ 48 * free block count, allocation group level free block counts). 53 * accesses to the persistent state of the block allocation map (limited 139 * FUNCTION: initializate the block allocation map. 252 * FUNCTION: terminate the block allocation map in preparation for 341 * allocation map. [all …]
|
H A D | jfs_imap.h | 21 #define MAXAG 128 /* maximum number of allocation groups */ 23 #define AMAPSIZE 512 /* bytes in the IAG allocation maps */ 39 * inode allocation map: 41 * inode allocation map consists of 43 * . inode allocation group pages (per 4096 inodes) 47 * inode allocation group page (per 4096 inodes of an AG) 51 __le32 iagnum; /* 4: inode allocation group number */ 73 /* allocation bit map: 1 bit per inode (0 - free, 1 - allocated) */ 74 __le32 wmap[EXTSPERIAG]; /* 512: working allocation map */ 75 __le32 pmap[EXTSPERIAG]; /* 512: persistent allocation map */ [all …]
|
H A D | jfs_mount.c | 18 * allocation map inode" (aka fileset inode): 21 * allocation map inode" (aka aggregate inode) where each inode 98 * initialize aggregate inode allocation map in jfs_mount() 106 * open aggregate block allocation map in jfs_mount() 119 * initialize aggregate block allocation map in jfs_mount() 127 * open the secondary aggregate inode allocation map in jfs_mount() 129 * This is a duplicate of the aggregate inode allocation map. in jfs_mount() 149 * initialize secondary aggregate inode allocation map in jfs_mount() 164 * open fileset inode allocation map (aka fileset inode) in jfs_mount() 169 /* open fileset secondary inode allocation map */ in jfs_mount() [all …]
|
/linux/Documentation/admin-guide/mm/ |
H A D | numa_memory_policy.rst | 38 use "local allocation" described below. However, during boot 82 A VMA policy will govern the allocation of pages that back 138 support allocation at fault time--a.k.a lazy allocation--so hugetlbfs 140 Although hugetlbfs segments now support lazy allocation, their support 197 closest to the node where the allocation takes place. 200 This mode specifies that the allocation should be attempted 202 allocation fails, the kernel will search other nodes, in order 209 and the policy is interpreted as local allocation. "Local" 210 allocation policy can be viewed as a Preferred policy that 211 starts at the node containing the cpu where the allocation [all …]
|
/linux/Documentation/mm/ |
H A D | allocation-profiling.rst | 4 MEMORY ALLOCATION PROFILING 23 When set to "never", memory allocation profiling overhead is minimized and it 52 Memory allocation profiling builds off of code tagging, which is a library for 57 To add accounting for an allocation call, we replace it with a macro 61 - calls the real allocation function 66 do not properly belong to the outer allocation context and should be counted 70 Thus, proper usage requires determining which function in an allocation call 77 - switch its allocation call to the _noprof() version, e.g. kmalloc_noprof() 93 - Hook your data structure's init function, like any other allocation function.
|
H A D | page_frags.rst | 11 simple allocation framework for page fragments. This is used by the 17 cache is needed. This provides a central point for the fragment allocation 20 which can be expensive at allocation time. However due to the nature of 23 to be disabled when executing the fragment allocation. 26 allocation. The netdev_alloc_cache is used by callers making use of the 41 avoid calling get_page per allocation.
|
H A D | numa.rst | 75 selected zone/node cannot satisfy the allocation request. This situation, 87 By default, Linux will attempt to satisfy memory allocation requests from the 90 for the node where the request originates. This is called "local allocation." 95 Local allocation will tend to keep subsequent access to the allocated memory 110 allocation behavior using Linux NUMA memory policy. [see 127 Some kernel allocations do not want or cannot tolerate this allocation fallback 132 A typical model for making such an allocation is to obtain the node id of the 135 the node id returned. When such an allocation fails, the requesting subsystem 138 itself on allocation failure. The kernel profiling subsystem is an example of
|
/linux/include/linux/ |
H A D | gfp_types.h | 10 * typedef gfp_t - Memory allocation flags. 14 * the underlying memory allocation function. Not every GFP flag is 138 * pages being in one zone (fair zone allocation policy). 140 * %__GFP_HARDWALL enforces the cpuset memory allocation policy. 142 * %__GFP_THISNODE forces the allocation to be satisfied from the requested 145 * %__GFP_ACCOUNT causes the allocation to be accounted to kmemcg. 147 * %__GFP_NO_OBJ_EXT causes slab allocation to have no object extension. 168 * the caller guarantees the allocation will allow more memory to be freed 206 * canonical example is THP allocation where a fallback is cheap but 242 * If the allocation does fail, and the caller is in a position to [all …]
|
H A D | kasan.h | 284 * kasan_mempool_poison_pages - Check and poison a mempool page allocation. 285 * @page: Pointer to the page allocation. 286 * @order: Order of the allocation. 294 * Before the poisoned allocation can be reused, it must be unpoisoned via 297 * Return: true if the allocation can be safely reused; false otherwise. 310 * kasan_mempool_unpoison_pages - Unpoison a mempool page allocation. 311 * @page: Pointer to the page allocation. 312 * @order: Order of the allocation. 317 * This function unpoisons a page allocation that was previously poisoned by 318 * kasan_mempool_poison_pages() without zeroing the allocation's memory. For [all …]
|
H A D | dmapool.h | 4 * Allocation pools for DMAable (coherent) memory. 22 size_t size, size_t align, size_t allocation); 34 size_t size, size_t align, size_t allocation); 39 struct device *dev, size_t size, size_t align, size_t allocation) in dma_pool_create() argument 47 struct device *dev, size_t size, size_t align, size_t allocation) in dmam_pool_create() argument
|
/linux/sound/core/ |
H A D | pcm_memory.c | 31 MODULE_PARM_DESC(max_alloc_per_card, "Max total allocation bytes per card."); 71 /* the actual allocation size might be bigger than requested, in do_alloc_pages() 77 /* take back on allocation failure */ in do_alloc_pages() 313 * snd_pcm_lib_preallocate_pages - pre-allocation for the given DMA type 317 * @size: the requested pre-allocation size in bytes 318 * @max: the max. allowed pre-allocation size 320 * Do pre-allocation for the given DMA buffer type. 331 …* snd_pcm_lib_preallocate_pages_for_all - pre-allocation for continuous memory type (all substream… 335 * @size: the requested pre-allocation size in bytes 336 * @max: the max. allowed pre-allocation size [all …]
|
/linux/arch/x86/include/asm/ |
H A D | hw_irq.h | 61 * irq_alloc_info - X86 specific interrupt allocation info 62 * @type: X86 specific allocation type 63 * @flags: Flags for allocation tweaks 66 * @mask: CPU mask for vector allocation 68 * @data: Allocation specific data 70 * @ioapic: IOAPIC specific allocation data 71 * @uv: UV specific allocation data
|
/linux/fs/ocfs2/ |
H A D | reservations.h | 5 * Allocation reservations function prototypes and structures. 108 * @cstart: start of proposed allocation 109 * @clen: length (in clusters) of proposed allocation 116 * On success, zero is returned and the valid allocation area is set in cstart 129 * @cstart: start of allocation in clusters 130 * @clen: end of allocation in clusters. 132 * Tell the reservation code that bits were used to fulfill allocation in 136 * reservations bitmap. If resv is passed, it's next allocation window will be
|
/linux/fs/xfs/libxfs/ |
H A D | xfs_alloc.h | 40 xfs_agnumber_t agno; /* allocation group number */ 41 xfs_agblock_t agbno; /* allocation group-relative block # */ 54 char wasdel; /* set if allocation was prev delayed */ 55 char wasfromfl; /* set if allocation is from freelist */ 64 #define XFS_ALLOC_USERDATA (1 << 0)/* allocation is for user data*/ 104 * space matching the requirements in that AG, then the allocation will fail. 110 * viable candidates in the AG, then fail the allocation. 117 * then the allocation fails. 123 * Best effort full filesystem allocation scan. 125 * Locality aware allocation will be attempted in the initial AG, but on failure [all …]
|
H A D | xfs_trans_resv.c | 84 * in the same transaction as an allocation or a free, so we compute them 142 * the allocation btrees: 2 trees * (max depth - 1) * block size 160 * the tree during individual inode allocation. Therefore the finobt 161 * reservation is unconditional for both the inode chunk allocation and 162 * individual inode allocation (modify) cases. 165 * traditional inobt: cover a full finobt shape change plus block allocation. 181 * the allocation btrees: 2 trees * (max depth - 1) * block size 185 * allocation or free and which type of create transaction is in use. An inode 187 * headers (N == 0). An inode chunk allocation requires a chunk sized 189 * reservation is required for allocation on v5 supers, which use ordered [all …]
|
/linux/Documentation/filesystems/ext4/ |
H A D | bigalloc.rst | 15 use clustered allocation, so that each bit in the ext4 block allocation 19 This means that each bit in the block allocation bitmap now addresses 20 256 4k blocks. This shrinks the total size of the block allocation 29 128MiB); however, the minimum allocation unit becomes a cluster, not a
|