mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-19 14:04:17 +03:00
alloc: enhance estimation of sufficient_pes_free
Since commit 77fdc17d70e62cab75efaaf0dad02493b948610d always include log_len size into needed extents - however now we may need sometimes more extents then necessary - mainly when multiple PVs are involved into allocation. Add logs_still_needed into calculation of sufficient_pes_free()
This commit is contained in:
parent
a4c56a3bc3
commit
0b6ee6a912
@ -1,5 +1,6 @@
|
|||||||
Version 2.03.12 -
|
Version 2.03.12 -
|
||||||
===================================
|
===================================
|
||||||
|
Fix corner case allocation for thin-pools.
|
||||||
|
|
||||||
Version 2.03.11 - 08th January 2021
|
Version 2.03.11 - 08th January 2021
|
||||||
===================================
|
===================================
|
||||||
|
@ -1850,11 +1850,13 @@ static uint32_t _mirror_log_extents(uint32_t region_size, uint32_t pe_size, uint
|
|||||||
|
|
||||||
/* Is there enough total space or should we give up immediately? */
|
/* Is there enough total space or should we give up immediately? */
|
||||||
static int _sufficient_pes_free(struct alloc_handle *ah, struct dm_list *pvms,
|
static int _sufficient_pes_free(struct alloc_handle *ah, struct dm_list *pvms,
|
||||||
uint32_t allocated, uint32_t extents_still_needed)
|
uint32_t allocated, uint32_t log_still_needed,
|
||||||
|
uint32_t extents_still_needed)
|
||||||
{
|
{
|
||||||
uint32_t area_extents_needed = (extents_still_needed - allocated) * ah->area_count / ah->area_multiple;
|
uint32_t area_extents_needed = (extents_still_needed - allocated) * ah->area_count / ah->area_multiple;
|
||||||
uint32_t parity_extents_needed = (extents_still_needed - allocated) * ah->parity_count / ah->area_multiple;
|
uint32_t parity_extents_needed = (extents_still_needed - allocated) * ah->parity_count / ah->area_multiple;
|
||||||
uint32_t metadata_extents_needed = ah->alloc_and_split_meta ? 0 : ah->metadata_area_count * RAID_METADATA_AREA_LEN + ah->log_len; /* One each */
|
uint32_t metadata_extents_needed = (ah->alloc_and_split_meta ? 0 : ah->metadata_area_count * RAID_METADATA_AREA_LEN) +
|
||||||
|
(log_still_needed ? ah->log_len : 0); /* One each */
|
||||||
uint64_t total_extents_needed = (uint64_t)area_extents_needed + parity_extents_needed + metadata_extents_needed;
|
uint64_t total_extents_needed = (uint64_t)area_extents_needed + parity_extents_needed + metadata_extents_needed;
|
||||||
uint32_t free_pes = pv_maps_size(pvms);
|
uint32_t free_pes = pv_maps_size(pvms);
|
||||||
|
|
||||||
@ -3359,7 +3361,9 @@ static int _allocate(struct alloc_handle *ah,
|
|||||||
old_allocated = alloc_state.allocated;
|
old_allocated = alloc_state.allocated;
|
||||||
log_debug_alloc("Trying allocation using %s policy.", get_alloc_string(alloc));
|
log_debug_alloc("Trying allocation using %s policy.", get_alloc_string(alloc));
|
||||||
|
|
||||||
if (!ah->approx_alloc && !_sufficient_pes_free(ah, pvms, alloc_state.allocated, ah->new_extents))
|
if (!ah->approx_alloc && !_sufficient_pes_free(ah, pvms, alloc_state.allocated,
|
||||||
|
alloc_state.log_area_count_still_needed,
|
||||||
|
ah->new_extents))
|
||||||
goto_out;
|
goto_out;
|
||||||
|
|
||||||
_init_alloc_parms(ah, &alloc_parms, alloc, prev_lvseg,
|
_init_alloc_parms(ah, &alloc_parms, alloc, prev_lvseg,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user