dm ioctl: prevent rename to empty name or uuid
A device-mapper device must always have a name consisting of a non-empty string. If the device also has a uuid, this similarly must not be an empty string. The DM_DEV_CREATE ioctl enforces these rules when the device is created, but this patch is needed to enforce them when DM_DEV_RENAME is used to change the name or uuid. Reported-by: Zdenek Kabelac <zkabelac@redhat.com> Signed-off-by: Alasdair G Kergon <agk@redhat.com> Signed-off-by: Mike Snitzer <snitzer@redhat.com> Acked-by: Mikulas Patocka <mpatocka@redhat.com>
This commit is contained in:
parent
d6fc204201
commit
c2b0482462
|
@ -877,7 +877,7 @@ static int dev_rename(struct dm_ioctl *param, size_t param_size)
|
||||||
unsigned change_uuid = (param->flags & DM_UUID_FLAG) ? 1 : 0;
|
unsigned change_uuid = (param->flags & DM_UUID_FLAG) ? 1 : 0;
|
||||||
|
|
||||||
if (new_data < param->data ||
|
if (new_data < param->data ||
|
||||||
invalid_str(new_data, (void *) param + param_size) ||
|
invalid_str(new_data, (void *) param + param_size) || !*new_data ||
|
||||||
strlen(new_data) > (change_uuid ? DM_UUID_LEN - 1 : DM_NAME_LEN - 1)) {
|
strlen(new_data) > (change_uuid ? DM_UUID_LEN - 1 : DM_NAME_LEN - 1)) {
|
||||||
DMWARN("Invalid new mapped device name or uuid string supplied.");
|
DMWARN("Invalid new mapped device name or uuid string supplied.");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
Loading…
Reference in New Issue