rbd: add warning messages for missing arguments

Tell the user (via dmesg) what was wrong with the arguments provided
via /sys/bus/rbd/add.

Signed-off-by: Alex Elder <elder@inktank.com>
Reviewed-by: Dan Mick <dan.mick@inktank.com>
This commit is contained in:
Alex Elder 2012-11-01 10:17:15 -05:00 committed by Alex Elder
parent 06ecc6cbf7
commit 4fb5d67139
1 changed files with 16 additions and 8 deletions

View File

@ -3244,8 +3244,10 @@ static int rbd_add_parse_args(const char *buf,
/* The first four tokens are required */ /* The first four tokens are required */
len = next_token(&buf); len = next_token(&buf);
if (!len) if (!len) {
return -EINVAL; /* Missing monitor address(es) */ rbd_warn(NULL, "no monitor address(es) provided");
return -EINVAL;
}
mon_addrs = buf; mon_addrs = buf;
mon_addrs_size = len + 1; mon_addrs_size = len + 1;
buf += len; buf += len;
@ -3254,8 +3256,10 @@ static int rbd_add_parse_args(const char *buf,
options = dup_token(&buf, NULL); options = dup_token(&buf, NULL);
if (!options) if (!options)
return -ENOMEM; return -ENOMEM;
if (!*options) if (!*options) {
goto out_err; /* Missing options */ rbd_warn(NULL, "no options provided");
goto out_err;
}
spec = rbd_spec_alloc(); spec = rbd_spec_alloc();
if (!spec) if (!spec)
@ -3264,14 +3268,18 @@ static int rbd_add_parse_args(const char *buf,
spec->pool_name = dup_token(&buf, NULL); spec->pool_name = dup_token(&buf, NULL);
if (!spec->pool_name) if (!spec->pool_name)
goto out_mem; goto out_mem;
if (!*spec->pool_name) if (!*spec->pool_name) {
goto out_err; /* Missing pool name */ rbd_warn(NULL, "no pool name provided");
goto out_err;
}
spec->image_name = dup_token(&buf, NULL); spec->image_name = dup_token(&buf, NULL);
if (!spec->image_name) if (!spec->image_name)
goto out_mem; goto out_mem;
if (!*spec->image_name) if (!*spec->image_name) {
goto out_err; /* Missing image name */ rbd_warn(NULL, "no image name provided");
goto out_err;
}
/* /*
* Snapshot name is optional; default is to use "-" * Snapshot name is optional; default is to use "-"