diff options
author | Blazej Kucman <blazej.kucman@intel.com> | 2021-12-03 15:31:15 +0100 |
---|---|---|
committer | Jes Sorensen <jsorensen@fb.com> | 2021-12-08 15:39:50 +0100 |
commit | ced5fa8b170ad448f4076e24a10c731b5cfb36ce (patch) | |
tree | 3d9bb069b988bb06da8445291076efcf31aebde6 /mdadm.c | |
parent | Correct checking if file descriptors are valid (diff) | |
download | mdadm-ced5fa8b170ad448f4076e24a10c731b5cfb36ce.tar.xz mdadm-ced5fa8b170ad448f4076e24a10c731b5cfb36ce.zip |
mdadm: block creation with long names
This fixes buffer overflows in create_mddev(). It prohibits
creation with not supported names for DDF and native. For IMSM,
mdadm will do silent cut to 16 later.
Signed-off-by: Mariusz Tkaczyk <mariusz.tkaczyk@linux.intel.com>
Signed-off-by: Blazej Kucman <blazej.kucman@intel.com>
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
Diffstat (limited to 'mdadm.c')
-rw-r--r-- | mdadm.c | 9 |
1 files changed, 8 insertions, 1 deletions
@@ -1359,9 +1359,16 @@ int main(int argc, char *argv[]) mdfd = open_mddev(devlist->devname, 1); if (mdfd < 0) exit(1); - } else + } else { + char *bname = basename(devlist->devname); + + if (strlen(bname) > MD_NAME_MAX) { + pr_err("Name %s is too long.\n", devlist->devname); + exit(1); + } /* non-existent device is OK */ mdfd = open_mddev(devlist->devname, 0); + } if (mdfd == -2) { pr_err("device %s exists but is not an md array.\n", devlist->devname); exit(1); |