From c48e40391bf7fb8b2fb8d2a43963fbb28096efcf Mon Sep 17 00:00:00 2001 From: Peter Rajnoha Date: Wed, 7 Jan 2009 12:17:40 +0000 Subject: [PATCH] Add checks for device names in dmsetup and show proper error messages. Checks added for DM device names to allow only names < DM_NAME_LEN, otherwise a part of lengthy name would be silently ignored and could cause confusion while using dmsetup. Also, the name should not contain '/' character, if it is used in context of creating a new device or renaming the existing one (because we do not consider full path to devices, they do not exist in filesystem yet) and appropriate error messages are shown. --- WHATS_NEW_DM | 1 + libdm/ioctl/libdm-iface.c | 10 ++++++++++ libdm/libdm-common.c | 13 +++++++++++-- 3 files changed, 22 insertions(+), 2 deletions(-) diff --git a/WHATS_NEW_DM b/WHATS_NEW_DM index cec869690..ee9b53d88 100644 --- a/WHATS_NEW_DM +++ b/WHATS_NEW_DM @@ -1,5 +1,6 @@ Version 1.02.30 - ==================================== + Add checks for device names in dmsetup and show proper error messages. Replace _dm_snprintf with EMIT_PARAMS macro for creating target lines Version 1.02.29 - 10th November 2008 diff --git a/libdm/ioctl/libdm-iface.c b/libdm/ioctl/libdm-iface.c index 05b689407..0c5a73047 100644 --- a/libdm/ioctl/libdm-iface.c +++ b/libdm/ioctl/libdm-iface.c @@ -1018,6 +1018,16 @@ int dm_task_suppress_identical_reload(struct dm_task *dmt) int dm_task_set_newname(struct dm_task *dmt, const char *newname) { + if (strchr(newname, '/')) { + log_error("Name \"%s\" invalid. It contains \"/\".", newname); + return 0; + } + + if (strlen(newname) >= DM_NAME_LEN) { + log_error("Name \"%s\" too long", newname); + return 0; + } + if (!(dmt->newname = dm_strdup(newname))) { log_error("dm_task_set_newname: strdup(%s) failed", newname); return 0; diff --git a/libdm/libdm-common.c b/libdm/libdm-common.c index 26fc0437d..bbb46f51c 100644 --- a/libdm/libdm-common.c +++ b/libdm/libdm-common.c @@ -143,18 +143,27 @@ int dm_task_set_name(struct dm_task *dmt, const char *name) * as its last component. */ if ((pos = strrchr(name, '/'))) { + if (dmt->type == DM_DEVICE_CREATE) { + log_error("Name \"%s\" invalid. It contains \"/\".", name); + return 0; + } + snprintf(path, sizeof(path), "%s/%s", _dm_dir, pos + 1); if (stat(name, &st1) || stat(path, &st2) || !(st1.st_dev == st2.st_dev)) { - log_error("dm_task_set_name: Device %s not found", - name); + log_error("Device %s not found", name); return 0; } name = pos + 1; } + if (strlen(name) >= DM_NAME_LEN) { + log_error("Name \"%s\" too long", name); + return 0; + } + if (!(dmt->dev_name = dm_strdup(name))) { log_error("dm_task_set_name: strdup(%s) failed", name); return 0;