2014-01-09 17:38:13 +01:00
|
|
|
From 69092b1179f4fbd0fae7e054665ad049dffd9966 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Guangliang Zhao <gzhao@suse.com>
|
|
|
|
Date: Wed, 5 Dec 2012 18:25:04 +0800
|
|
|
|
Subject: [PATCH 2/2] mirror: improve mirror legs on different tag pvs
|
|
|
|
|
|
|
|
This patch will find the biggest eligible area every time,
|
|
|
|
and add it to the parallel areas.
|
|
|
|
|
|
|
|
The previous just find the different tag pv area with all
|
|
|
|
found ones, if the new area's tag has appeared, just throw
|
|
|
|
it. The new will compare the length, and choose the longer
|
|
|
|
one.
|
|
|
|
|
|
|
|
Signed-off-by: Guangliang Zhao <gzhao@suse.com>
|
|
|
|
---
|
2014-09-25 10:31:10 +02:00
|
|
|
lib/metadata/lv_manip.c | 34 +++++++++++++++++++++++++++++++---
|
|
|
|
1 file changed, 31 insertions(+), 3 deletions(-)
|
2014-01-09 17:38:13 +01:00
|
|
|
|
2016-01-28 05:41:36 +01:00
|
|
|
Index: LVM2.2.02.139/lib/metadata/lv_manip.c
|
|
|
|
===================================================================
|
|
|
|
--- LVM2.2.02.139.orig/lib/metadata/lv_manip.c
|
|
|
|
+++ LVM2.2.02.139/lib/metadata/lv_manip.c
|
|
|
|
@@ -2518,6 +2518,25 @@ static uint32_t _calc_required_extents(s
|
2014-01-09 17:38:13 +01:00
|
|
|
return required;
|
|
|
|
}
|
|
|
|
|
2014-09-25 10:31:10 +02:00
|
|
|
+static void _replace_required_area(struct alloc_handle *ah,
|
|
|
|
+ uint32_t max_to_allocate,
|
2014-01-09 17:38:13 +01:00
|
|
|
+ unsigned ix_pva, struct pv_area *pva,
|
2014-09-25 10:31:10 +02:00
|
|
|
+ struct alloc_state *alloc_state,
|
|
|
|
+ alloc_policy_t alloc)
|
2014-01-09 17:38:13 +01:00
|
|
|
+{
|
2014-09-25 10:31:10 +02:00
|
|
|
+ uint32_t required = _calc_required_extents(ah, pva, ix_pva,
|
|
|
|
+ max_to_allocate, alloc);
|
2014-01-09 17:38:13 +01:00
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * We don't worry about the area replaced, because _clear_areas() and
|
|
|
|
+ * _reset_unreserved() called by _find_some_parallel_space() will clear
|
|
|
|
+ * the alloc_state and reserved areas every time.
|
|
|
|
+ */
|
|
|
|
+ if (required > alloc_state->areas[ix_pva - 1].used)
|
2015-06-08 03:48:46 +02:00
|
|
|
+ _reserve_area(ah, alloc_state, pva, required, ix_pva - 1,
|
2014-09-25 10:31:10 +02:00
|
|
|
+ pva->unreserved);
|
2014-01-09 17:38:13 +01:00
|
|
|
+}
|
|
|
|
+
|
2014-09-25 10:31:10 +02:00
|
|
|
static void _clear_areas(struct alloc_state *alloc_state)
|
2014-01-09 17:38:13 +01:00
|
|
|
{
|
2014-09-25 10:31:10 +02:00
|
|
|
uint32_t s;
|
2016-01-28 05:41:36 +01:00
|
|
|
@@ -2646,6 +2665,7 @@ static int _find_some_parallel_space(str
|
2014-09-25 10:31:10 +02:00
|
|
|
const struct alloc_parms *alloc_parms = alloc_state->alloc_parms;
|
2014-01-09 17:38:13 +01:00
|
|
|
unsigned ix = 0;
|
|
|
|
unsigned last_ix;
|
|
|
|
+ int ret;
|
|
|
|
struct pv_map *pvm;
|
|
|
|
struct pv_area *pva;
|
|
|
|
unsigned preferred_count = 0;
|
2016-01-28 05:41:36 +01:00
|
|
|
@@ -2766,9 +2786,17 @@ static int _find_some_parallel_space(str
|
2014-01-09 17:38:13 +01:00
|
|
|
continue;
|
|
|
|
|
|
|
|
case USE_AREA:
|
2016-01-28 05:41:36 +01:00
|
|
|
- if(check_areas_separate_tags(ah, alloc_state, alloc_state->num_positional_areas,
|
|
|
|
- ix + alloc_state->num_positional_areas, pva) >= 0)
|
2014-01-09 17:38:13 +01:00
|
|
|
- goto next_pv;
|
2014-09-25 10:31:10 +02:00
|
|
|
+ ret = check_areas_separate_tags(ah,
|
2016-01-28 05:41:36 +01:00
|
|
|
+ alloc_state, alloc_state->num_positional_areas,
|
|
|
|
+ ix + alloc_state->num_positional_areas, pva);
|
2014-09-25 10:31:10 +02:00
|
|
|
+ if (ret >= 0) {
|
|
|
|
+ _replace_required_area(ah,
|
|
|
|
+ max_to_allocate,
|
|
|
|
+ ret + 1, pva,
|
|
|
|
+ alloc_state,
|
|
|
|
+ alloc_parms->alloc);
|
2014-01-09 17:38:13 +01:00
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Except with ALLOC_ANYWHERE, replace first area with this
|