1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-03-10 16:58:47 +03:00

libdm: simplify segtype search

For cache target use directly SEG_CACHE.
Hide dm_segtypes as internal static variable _dm_segtypes,
since noone is supposed to use it.
This commit is contained in:
Zdenek Kabelac 2014-04-04 22:34:22 +02:00
parent 6d3d2d5e3d
commit 6190ded5f1

View File

@ -51,15 +51,14 @@ enum {
SEG_RAID6_ZR, SEG_RAID6_ZR,
SEG_RAID6_NR, SEG_RAID6_NR,
SEG_RAID6_NC, SEG_RAID6_NC,
SEG_LAST,
}; };
/* FIXME Add crypt and multipath support */ /* FIXME Add crypt and multipath support */
struct { static const struct {
unsigned type; unsigned type;
const char *target; const char target[16];
} dm_segtypes[] = { } _dm_segtypes[] = {
{ SEG_CACHE, "cache" }, { SEG_CACHE, "cache" },
{ SEG_CRYPT, "crypt" }, { SEG_CRYPT, "crypt" },
{ SEG_ERROR, "error" }, { SEG_ERROR, "error" },
@ -91,7 +90,6 @@ struct {
*/ */
{ SEG_RAID5_LS, "raid5"}, /* same as "raid5_ls" (default for MD also) */ { SEG_RAID5_LS, "raid5"}, /* same as "raid5_ls" (default for MD also) */
{ SEG_RAID6_ZR, "raid6"}, /* same as "raid6_zr" */ { SEG_RAID6_ZR, "raid6"}, /* same as "raid6_zr" */
{ SEG_LAST, NULL },
}; };
/* Some segment types have a list of areas of other devices attached */ /* Some segment types have a list of areas of other devices attached */
@ -2243,7 +2241,7 @@ static int _raid_emit_segment_line(struct dm_task *dmt, uint32_t major,
if ((seg->type == SEG_RAID1) && seg->stripe_size) if ((seg->type == SEG_RAID1) && seg->stripe_size)
log_error("WARNING: Ignoring RAID1 stripe size"); log_error("WARNING: Ignoring RAID1 stripe size");
EMIT_PARAMS(pos, "%s %d %u", dm_segtypes[seg->type].target, EMIT_PARAMS(pos, "%s %d %u", _dm_segtypes[seg->type].target,
param_count, seg->stripe_size); param_count, seg->stripe_size);
if (seg->flags & DM_NOSYNC) if (seg->flags & DM_NOSYNC)
@ -2509,7 +2507,7 @@ static int _emit_segment_line(struct dm_task *dmt, uint32_t major,
} }
if (!params[0]) { if (!params[0]) {
log_error("No parameters supplied for %s target " log_error("No parameters supplied for %s target "
"%u:%u.", dm_segtypes[seg->type].target, "%u:%u.", _dm_segtypes[seg->type].target,
major, minor); major, minor);
return 0; return 0;
} }
@ -2519,11 +2517,11 @@ static int _emit_segment_line(struct dm_task *dmt, uint32_t major,
log_debug_activation("Adding target to (%" PRIu32 ":%" PRIu32 "): %" PRIu64 log_debug_activation("Adding target to (%" PRIu32 ":%" PRIu32 "): %" PRIu64
" %" PRIu64 " %s %s", major, minor, " %" PRIu64 " %s %s", major, minor,
*seg_start, seg->size, target_type_is_raid ? "raid" : *seg_start, seg->size, target_type_is_raid ? "raid" :
dm_segtypes[seg->type].target, params); _dm_segtypes[seg->type].target, params);
if (!dm_task_add_target(dmt, *seg_start, seg->size, if (!dm_task_add_target(dmt, *seg_start, seg->size,
target_type_is_raid ? "raid" : target_type_is_raid ? "raid" :
dm_segtypes[seg->type].target, params)) _dm_segtypes[seg->type].target, params))
return_0; return_0;
*seg_start += seg->size; *seg_start += seg->size;
@ -3110,12 +3108,11 @@ int dm_tree_node_add_raid_target_with_params(struct dm_tree_node *node,
int i; int i;
struct load_segment *seg = NULL; struct load_segment *seg = NULL;
for (i = 0; dm_segtypes[i].target && !seg; i++) for (i = 0; i < DM_ARRAY_SIZE(_dm_segtypes) && !seg; ++i)
if (!strcmp(p->raid_type, dm_segtypes[i].target)) if (!strcmp(p->raid_type, _dm_segtypes[i].target))
if (!(seg = _add_segment(node, if (!(seg = _add_segment(node,
dm_segtypes[i].type, size))) _dm_segtypes[i].type, size)))
return_0; return_0;
if (!seg) if (!seg)
return_0; return_0;
@ -3242,17 +3239,9 @@ int dm_tree_node_add_cache_target(struct dm_tree_node *node,
unsigned policy_argc, unsigned policy_argc,
const char *const *policy_argv) const char *const *policy_argv)
{ {
int i; struct load_segment *seg;
struct load_segment *seg = NULL;
for (i = 0; dm_segtypes[i].target && !seg; i++) { if (!(seg = _add_segment(node, SEG_CACHE, size)))
if (strcmp("cache", dm_segtypes[i].target))
continue;
if (!(seg = _add_segment(node, dm_segtypes[i].type, size)))
return_0;
}
if (!seg)
return_0; return_0;
if (!(seg->pool = dm_tree_find_node_by_uuid(node->dtree, if (!(seg->pool = dm_tree_find_node_by_uuid(node->dtree,
@ -3485,7 +3474,7 @@ int dm_tree_node_add_replicator_target(struct dm_tree_node *node,
rseg = dm_list_item(dm_list_last(&node->props.segs), struct load_segment); rseg = dm_list_item(dm_list_last(&node->props.segs), struct load_segment);
if (rseg->type != SEG_REPLICATOR) { if (rseg->type != SEG_REPLICATOR) {
log_error(INTERNAL_ERROR "Attempt to use non replicator segment %s.", log_error(INTERNAL_ERROR "Attempt to use non replicator segment %s.",
dm_segtypes[rseg->type].target); _dm_segtypes[rseg->type].target);
return 0; return 0;
} }
@ -3540,7 +3529,7 @@ int dm_tree_node_add_replicator_dev_target(struct dm_tree_node *node,
rep_seg = dm_list_item(dm_list_last(&rseg->replicator->props.segs), struct load_segment); rep_seg = dm_list_item(dm_list_last(&rseg->replicator->props.segs), struct load_segment);
if (rep_seg->type != SEG_REPLICATOR) { if (rep_seg->type != SEG_REPLICATOR) {
log_error(INTERNAL_ERROR "Attempt to use non replicator segment %s.", log_error(INTERNAL_ERROR "Attempt to use non replicator segment %s.",
dm_segtypes[rep_seg->type].target); _dm_segtypes[rep_seg->type].target);
return 0; return 0;
} }
rep_seg->rdevice_count++; rep_seg->rdevice_count++;
@ -3559,7 +3548,7 @@ int dm_tree_node_add_replicator_dev_target(struct dm_tree_node *node,
rseg = dm_list_item(dm_list_last(&node->props.segs), struct load_segment); rseg = dm_list_item(dm_list_last(&node->props.segs), struct load_segment);
if (rseg->type != SEG_REPLICATOR_DEV) { if (rseg->type != SEG_REPLICATOR_DEV) {
log_error(INTERNAL_ERROR "Attempt to use non replicator-dev segment %s.", log_error(INTERNAL_ERROR "Attempt to use non replicator-dev segment %s.",
dm_segtypes[rseg->type].target); _dm_segtypes[rseg->type].target);
return 0; return 0;
} }
} }
@ -3598,15 +3587,15 @@ static struct load_segment *_get_single_load_segment(struct dm_tree_node *node,
if (node->props.segment_count != 1) { if (node->props.segment_count != 1) {
log_error("Node %s must have only one segment.", log_error("Node %s must have only one segment.",
dm_segtypes[type].target); _dm_segtypes[type].target);
return NULL; return NULL;
} }
seg = dm_list_item(dm_list_last(&node->props.segs), struct load_segment); seg = dm_list_item(dm_list_last(&node->props.segs), struct load_segment);
if (seg->type != type) { if (seg->type != type) {
log_error("Node %s has segment type %s.", log_error("Node %s has segment type %s.",
dm_segtypes[type].target, _dm_segtypes[type].target,
dm_segtypes[seg->type].target); _dm_segtypes[seg->type].target);
return NULL; return NULL;
} }