* [PATCH] non-const dm_config_find_node
@ 2011-08-31 14:30 Petr Rockai
2011-08-31 14:44 ` Zdenek Kabelac
0 siblings, 1 reply; 2+ messages in thread
From: Petr Rockai @ 2011-08-31 14:30 UTC (permalink / raw)
To: lvm-devel
Hi,
this patch replaces const usage of dm_config_find_node with more
appropriate value-lookup functionality. A number of bugs (copied and
pasted all over the code) should disappear:
- most string lookup based on dm_config_find_node would segfault when
encountering a non-zero integer (the intention there was to print an
error message instead)
- check for required sections in metadata would have been satisfied by
values as well (i.e. not sections)
- encountering a section in place of expected flag value would have
segfaulted (due to assumed but unchecked cn->v != NULL)
Yours,
Petr
-------------- next part --------------
A non-text attachment was scrubbed...
Name: dm_config_find_node.diff
Type: text/x-diff
Size: 19939 bytes
Desc: not available
URL: <http://listman.redhat.com/archives/lvm-devel/attachments/20110831/54fa69e5/attachment.bin>
-------------- next part --------------
--
id' Ash = Ash; id' Dust = Dust; id' _ = undefined
^ permalink raw reply [flat|nested] 2+ messages in thread
* [PATCH] non-const dm_config_find_node
2011-08-31 14:30 [PATCH] non-const dm_config_find_node Petr Rockai
@ 2011-08-31 14:44 ` Zdenek Kabelac
0 siblings, 0 replies; 2+ messages in thread
From: Zdenek Kabelac @ 2011-08-31 14:44 UTC (permalink / raw)
To: lvm-devel
Dne 31.8.2011 16:30, Petr Rockai napsal(a):
> Hi,
>
> this patch replaces const usage of dm_config_find_node with more
> appropriate value-lookup functionality. A number of bugs (copied and
> pasted all over the code) should disappear:
>
> - most string lookup based on dm_config_find_node would segfault when
> encountering a non-zero integer (the intention there was to print an
> error message instead)
> - check for required sections in metadata would have been satisfied by
> values as well (i.e. not sections)
> - encountering a section in place of expected flag value would have
> segfaulted (due to assumed but unchecked cn->v != NULL)
>
> Yours,
> Petr
>
>
>
> dm_config_find_node.diff
>
>
> Index: lib/mirror/mirrored.c
>
> - if ((cn = dm_config_find_node(sn, "mirror_log"))) {
> - if (!cn->v || !cn->v->v.str) {
> - log_error("Mirror log type must be a string.");
> - return 0;
> - }
> - logname = cn->v->v.str;
> + if (dm_config_get_str(sn, "mirror_log", &logname)) {
> if (!(seg->log_lv = find_lv(seg->lv->vg, logname))) {
> log_error("Unrecognised mirror log in "
> "segment %s of logical volume %s.",
When we are doing this change maybe there is some way to combine
dm_config_get_str() and find_lv() to one internal lvm function call - though
error reporting might be tricky so not sure whether it's worth to make some
change here, but this call sequence is used several times.
> @@ -130,14 +125,14 @@ static int _mirrored_text_import(struct
> +int dm_config_get_list(const struct dm_config_node *cn, const char *path,
> + const struct dm_config_value **result)
> +{
> + const struct dm_config_node *n;
> +
> + n = _find_config_node(cn, path);
> + /* TODO when we represent single-item lists consistently, add a check
> + * for n->v->next != NULL */
> + if (!n || !n->v)
> + return 0;
> +
> + *result = n->v;
> + return 1;
> +}
> +
> +int dm_config_get_section(const struct dm_config_node *cn, const char *path,
> + const struct dm_config_node **result)
> +{
> + const struct dm_config_node *n;
> +
> + n = _find_config_node(cn, path);
> + if (!n || n->v)
> + return 0;
> +
> + *result = n;
> + return 1;
> +}
Cosmetic - preferring empty break before return;
ACK, Like this one
Zdenek
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2011-08-31 14:44 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-08-31 14:30 [PATCH] non-const dm_config_find_node Petr Rockai
2011-08-31 14:44 ` Zdenek Kabelac
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.