aboutsummaryrefslogtreecommitdiffstats
path: root/lib/genalloc.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/genalloc.c')
-rw-r--r--lib/genalloc.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/genalloc.c b/lib/genalloc.c
index 38d2db82228c..166f17b9f169 100644
--- a/lib/genalloc.c
+++ b/lib/genalloc.c
@@ -481,6 +481,26 @@ unsigned long gen_pool_first_fit(unsigned long *map, unsigned long size,
481EXPORT_SYMBOL(gen_pool_first_fit); 481EXPORT_SYMBOL(gen_pool_first_fit);
482 482
483/** 483/**
484 * gen_pool_first_fit_order_align - find the first available region
485 * of memory matching the size requirement. The region will be aligned
486 * to the order of the size specified.
487 * @map: The address to base the search on
488 * @size: The bitmap size in bits
489 * @start: The bitnumber to start searching at
490 * @nr: The number of zeroed bits we're looking for
491 * @data: additional data - unused
492 */
493unsigned long gen_pool_first_fit_order_align(unsigned long *map,
494 unsigned long size, unsigned long start,
495 unsigned int nr, void *data)
496{
497 unsigned long align_mask = roundup_pow_of_two(nr) - 1;
498
499 return bitmap_find_next_zero_area(map, size, start, nr, align_mask);
500}
501EXPORT_SYMBOL(gen_pool_first_fit_order_align);
502
503/**
484 * gen_pool_best_fit - find the best fitting region of memory 504 * gen_pool_best_fit - find the best fitting region of memory
485 * macthing the size requirement (no alignment constraint) 505 * macthing the size requirement (no alignment constraint)
486 * @map: The address to base the search on 506 * @map: The address to base the search on