diff options
author | NeilBrown <neilb@suse.com> | 2017-04-28 07:05:50 +0200 |
---|---|---|
committer | Jes Sorensen <jsorensen@fb.com> | 2017-05-02 15:41:39 +0200 |
commit | cd6cbb08c458cee07acb1d854e04532b29ec87bf (patch) | |
tree | ca6482225586ea4d423af1e674dd5ca7021daa4a /mdopen.c | |
parent | Incremental: Cleanup some if() statement spaghetti (diff) | |
download | mdadm-cd6cbb08c458cee07acb1d854e04532b29ec87bf.tar.xz mdadm-cd6cbb08c458cee07acb1d854e04532b29ec87bf.zip |
Create: tell udev md device is not ready when first created.
When an array is created the content is not initialized,
so it could have remnants of an old filesystem or md array
etc on it.
udev will see this and might try to activate it, which is almost
certainly not what is wanted.
So create a mechanism for mdadm to communicate with udev to tell
it that the device isn't ready. This mechanism is the existance
of a file /run/mdadm/created-mdXXX where mdXXX is the md device name.
When creating an array, mdadm will create the file.
A new udev rule file, 01-md-raid-creating.rules, will detect the
precense of thst file and set ENV{SYSTEMD_READY}="0".
This is fairly uniformly used to suppress actions based on the
contents of the device.
Signed-off-by: NeilBrown <neilb@suse.com>
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
Diffstat (limited to 'mdopen.c')
-rw-r--r-- | mdopen.c | 52 |
1 files changed, 33 insertions, 19 deletions
@@ -135,7 +135,7 @@ void make_parts(char *dev, int cnt) */ int create_mddev(char *dev, char *name, int autof, int trustworthy, - char *chosen) + char *chosen, int block_udev) { int mdfd; struct stat stb; @@ -147,6 +147,10 @@ int create_mddev(char *dev, char *name, int autof, int trustworthy, char devname[37]; char devnm[32]; char cbuf[400]; + + if (!use_udev()) + block_udev = 0; + if (chosen == NULL) chosen = cbuf; @@ -305,43 +309,53 @@ int create_mddev(char *dev, char *name, int autof, int trustworthy, int fd; int n = -1; sprintf(devnm, "md_%s", cname); + if (block_udev) + udev_block(devnm); fd = open("/sys/module/md_mod/parameters/new_array", O_WRONLY); if (fd >= 0) { n = write(fd, devnm, strlen(devnm)); close(fd); } - if (n < 0) + if (n < 0) { devnm[0] = 0; + udev_unblock(); + } } if (num >= 0) { int fd; int n = -1; sprintf(devnm, "md%d", num); + if (block_udev) + udev_block(devnm); fd = open("/sys/module/md_mod/parameters/new_array", O_WRONLY); if (fd >= 0) { n = write(fd, devnm, strlen(devnm)); close(fd); } - if (n < 0) + if (n < 0) { devnm[0] = 0; - } - if (devnm[0]) - ; - else if (num < 0) { - /* need to choose a free number. */ - char *_devnm = find_free_devnm(use_mdp); - if (_devnm == NULL) { - pr_err("No avail md devices - aborting\n"); - return -1; + udev_unblock(); } - strcpy(devnm, _devnm); - } else { - sprintf(devnm, "%s%d", use_mdp?"md_d":"md", num); - if (mddev_busy(devnm)) { - pr_err("%s is already in use.\n", - dev); - return -1; + } + if (devnm[0] == 0) { + if (num < 0) { + /* need to choose a free number. */ + char *_devnm = find_free_devnm(use_mdp); + if (_devnm == NULL) { + pr_err("No avail md devices - aborting\n"); + return -1; + } + strcpy(devnm, _devnm); + } else { + sprintf(devnm, "%s%d", use_mdp?"md_d":"md", num); + if (mddev_busy(devnm)) { + pr_err("%s is already in use.\n", + dev); + return -1; + } } + if (block_udev) + udev_block(devnm); } sprintf(devname, "/dev/%s", devnm); |