Fix parse_dataset error handling
A mount failure was accidentally introduced by commit 0c1171d which reworked the parse_dataset() function to read pool names from devices. The error case where a label is read from the device but the pool name/value pair doesn't exist was not handled properly. In this case we should fall back to the previous behavior. Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #1560
This commit is contained in:
parent
294f68063b
commit
c76955eaa5
@ -246,11 +246,13 @@ parse_dataset(char *dataset)
|
|||||||
|
|
||||||
error = nvlist_lookup_string(config,
|
error = nvlist_lookup_string(config,
|
||||||
ZPOOL_CONFIG_POOL_NAME, &name);
|
ZPOOL_CONFIG_POOL_NAME, &name);
|
||||||
if (error == 0)
|
if (error) {
|
||||||
|
nvlist_free(config);
|
||||||
|
} else {
|
||||||
dataset = strdup(name);
|
dataset = strdup(name);
|
||||||
|
nvlist_free(config);
|
||||||
nvlist_free(config);
|
return (dataset);
|
||||||
return (dataset);
|
}
|
||||||
}
|
}
|
||||||
out:
|
out:
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user