1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

raid: protect raid4 activation

Move check for presence of raid4 into the right place
so there is no way how to hit activation of any LV
with raid4 on kernel which does not support it.
This commit is contained in:
Zdenek Kabelac 2017-11-09 13:00:28 +01:00
parent f0d1c8429b
commit 05f9acdc7f
2 changed files with 16 additions and 20 deletions

View File

@ -1462,7 +1462,6 @@ int lv_active_change(struct cmd_context *cmd, struct logical_volume *lv,
enum activation_change activate, int needs_exclusive) enum activation_change activate, int needs_exclusive)
{ {
const char *ay_with_mode = NULL; const char *ay_with_mode = NULL;
struct lv_segment *seg = first_seg(lv);
if (activate == CHANGE_ASY) if (activate == CHANGE_ASY)
ay_with_mode = "sh"; ay_with_mode = "sh";
@ -1499,9 +1498,6 @@ deactivate:
break; break;
case CHANGE_ALY: case CHANGE_ALY:
case CHANGE_AAY: case CHANGE_AAY:
if (!raid4_is_supported(cmd, seg->segtype))
goto no_raid4;
if (needs_exclusive || _lv_is_exclusive(lv)) { if (needs_exclusive || _lv_is_exclusive(lv)) {
log_verbose("Activating logical volume %s exclusively locally.", log_verbose("Activating logical volume %s exclusively locally.",
display_lvname(lv)); display_lvname(lv));
@ -1516,9 +1512,6 @@ deactivate:
break; break;
case CHANGE_AEY: case CHANGE_AEY:
exclusive: exclusive:
if (!raid4_is_supported(cmd, seg->segtype))
goto no_raid4;
log_verbose("Activating logical volume %s exclusively.", log_verbose("Activating logical volume %s exclusively.",
display_lvname(lv)); display_lvname(lv));
if (!activate_lv_excl(cmd, lv)) if (!activate_lv_excl(cmd, lv))
@ -1527,9 +1520,6 @@ exclusive:
case CHANGE_ASY: case CHANGE_ASY:
case CHANGE_AY: case CHANGE_AY:
default: default:
if (!raid4_is_supported(cmd, seg->segtype))
goto no_raid4;
if (needs_exclusive || _lv_is_exclusive(lv)) if (needs_exclusive || _lv_is_exclusive(lv))
goto exclusive; goto exclusive;
log_verbose("Activating logical volume %s.", display_lvname(lv)); log_verbose("Activating logical volume %s.", display_lvname(lv));
@ -1542,10 +1532,6 @@ exclusive:
log_error("Failed to unlock logical volume %s.", display_lvname(lv)); log_error("Failed to unlock logical volume %s.", display_lvname(lv));
return 1; return 1;
no_raid4:
log_error("Failed to activate %s LV %s", lvseg_name(seg), display_lvname(lv));
return 0;
} }
char *lv_active_dup(struct dm_pool *mem, const struct logical_volume *lv) char *lv_active_dup(struct dm_pool *mem, const struct logical_volume *lv)

View File

@ -24,6 +24,10 @@
#include "metadata.h" #include "metadata.h"
#include "lv_alloc.h" #include "lv_alloc.h"
static int _raid_target_present(struct cmd_context *cmd,
const struct lv_segment *seg __attribute__((unused)),
unsigned *attributes);
static void _raid_display(const struct lv_segment *seg) static void _raid_display(const struct lv_segment *seg)
{ {
unsigned s; unsigned s;
@ -247,13 +251,19 @@ static int _raid_add_target_line(struct dev_manager *dm __attribute__((unused)),
int delta_disks = 0, delta_disks_minus = 0, delta_disks_plus = 0, data_offset = 0; int delta_disks = 0, delta_disks_minus = 0, delta_disks_plus = 0, data_offset = 0;
uint32_t s; uint32_t s;
uint64_t flags = 0; uint64_t flags = 0;
uint64_t rebuilds[RAID_BITMAP_SIZE]; uint64_t rebuilds[RAID_BITMAP_SIZE] = { 0 };
uint64_t writemostly[RAID_BITMAP_SIZE]; uint64_t writemostly[RAID_BITMAP_SIZE] = { 0 };
struct dm_tree_node_raid_params_v2 params; struct dm_tree_node_raid_params_v2 params = { 0 };
unsigned attrs;
memset(&params, 0, sizeof(params)); if (seg_is_raid4(seg)) {
memset(&rebuilds, 0, sizeof(rebuilds)); if (!_raid_target_present(cmd, NULL, &attrs) ||
memset(&writemostly, 0, sizeof(writemostly)); !(attrs & RAID_FEATURE_RAID4)) {
log_error("RAID target does not support RAID4 for LV %s.",
display_lvname(seg->lv));
return 0;
}
}
if (!seg->area_count) { if (!seg->area_count) {
log_error(INTERNAL_ERROR "_raid_add_target_line called " log_error(INTERNAL_ERROR "_raid_add_target_line called "