The default has been 1, that is, the first encountered free extent with any length from 1 to requested is allocated and returned. So, allow changing minimal extent length to allocate. Signed-off-by: Ivan Shapovalov <intelfx100@xxxxxxxxx> --- fs/reiser4/block_alloc.h | 2 ++ fs/reiser4/plugin/space/bitmap.c | 18 ++++++++++++++---- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/fs/reiser4/block_alloc.h b/fs/reiser4/block_alloc.h index 08b3941..16f9810 100644 --- a/fs/reiser4/block_alloc.h +++ b/fs/reiser4/block_alloc.h @@ -45,6 +45,8 @@ struct reiser4_blocknr_hint { reiser4_block_nr blk; /* if not zero, it is a region size we search for free blocks in */ reiser4_block_nr max_dist; + /* if not zero, minimal length of an extent to allocate */ + reiser4_block_nr min_len; /* level for allocation, may be useful have branch-level and higher write-optimized. */ tree_level level; diff --git a/fs/reiser4/plugin/space/bitmap.c b/fs/reiser4/plugin/space/bitmap.c index 9beaf66..8309cf9 100644 --- a/fs/reiser4/plugin/space/bitmap.c +++ b/fs/reiser4/plugin/space/bitmap.c @@ -1101,7 +1101,7 @@ static int alloc_blocks_forward(reiser4_blocknr_hint *hint, int needed, reiser4_block_nr *start, reiser4_block_nr *len) { struct super_block *super = get_current_context()->super; - int actual_len; + int min_len, actual_len; reiser4_block_nr search_start; reiser4_block_nr search_end; @@ -1117,12 +1117,17 @@ static int alloc_blocks_forward(reiser4_blocknr_hint *hint, int needed, LIMIT(hint->blk + hint->max_dist, reiser4_block_count(super)); + if (hint->min_len == 0) + min_len = 1; + else + min_len = (int)hint->min_len; + /* We use @hint -> blk as a search start and search from it to the end of the disk or in given region if @hint -> max_dist is not zero */ search_start = hint->blk; actual_len = - bitmap_alloc_forward(&search_start, &search_end, 1, needed); + bitmap_alloc_forward(&search_start, &search_end, min_len, needed); /* There is only one bitmap search if max_dist was specified or first pass was from the beginning of the bitmap. We also do one pass for @@ -1150,7 +1155,7 @@ static int alloc_blocks_backward(reiser4_blocknr_hint * hint, int needed, { reiser4_block_nr search_start; reiser4_block_nr search_end; - int actual_len; + int min_len, actual_len; ON_DEBUG(struct super_block *super = reiser4_get_current_sb()); @@ -1164,8 +1169,13 @@ static int alloc_blocks_backward(reiser4_blocknr_hint * hint, int needed, else search_end = search_start - hint->max_dist; + if (hint->min_len == 0) + min_len = 1; + else + min_len = (int)hint->min_len; + actual_len = - bitmap_alloc_backward(&search_start, &search_end, 1, needed); + bitmap_alloc_backward(&search_start, &search_end, min_len, needed); if (actual_len == 0) return RETERR(-ENOSPC); if (actual_len < 0) -- 2.0.4 -- To unsubscribe from this list: send the line "unsubscribe reiserfs-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html