diff options
author | Peter Rajnoha <prajnoha@redhat.com> | 2009-10-26 14:29:33 +0000 |
---|---|---|
committer | Peter Rajnoha <prajnoha@redhat.com> | 2009-10-26 14:29:33 +0000 |
commit | 421671b1c2aadc9babe96e353b788feaf272a832 (patch) | |
tree | 79709de1851201be14e59fe2622faf4240f6a17b /tools/dmsetup.c | |
parent | 5a3bd513803db04c70a14a1d4d9085b437ecdd4b (diff) | |
download | lvm2-421671b1c2aadc9babe96e353b788feaf272a832.tar.gz lvm2-421671b1c2aadc9babe96e353b788feaf272a832.tar.xz lvm2-421671b1c2aadc9babe96e353b788feaf272a832.zip |
Several changes to udev support code:
- we have these levels when the udev rules are processed:
10-dm.rules --> [11-dm-<subsystem>.rules] --> [12-dm-permissions.rules] -->
13-dm-disk.rules --> [...all the other foreign rules...] --> 95-dm-notify.rules
- each level can be disabled now by
DM_UDEV_DISABLE_{DM, SUBSYSTEM, DISK, OTHER}_RULES_FLAG
- add DM_UDEV_DISABLE_DM_RULES_FLAG to disable 10-dm.rules
- add DM_UDEV_DISABLE_OTHER_RULES_FLAG to disable all the other (non-dm) rules.
We cutoff these rules by using the 'last_rule', so this one should really be
used with great care and in well-founded situations. We use this for lvm's
hidden and layer devices now.
- add a parameter for add_dev_node, rm_dev_node and rename_dev_node so it's
possible to switch on/off udev checks
- use DM_UDEV_DISABLE_DM_RULES_FLAG and DM_UDEV_DISABLE_SUBSYSTEM_RULES_FLAG
if there's no cookie set and we have resume, remove and rename ioctl.
This could happen when someone uses the libdevmapper that is compiled with
udev_sync but the software does not make use of it. This way we can switch
off the rules and fallback to libdevmapper node creation so there's no
udev/libdevmapper race.
Diffstat (limited to 'tools/dmsetup.c')
-rw-r--r-- | tools/dmsetup.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/tools/dmsetup.c b/tools/dmsetup.c index c0b9316e..a7f1d257 100644 --- a/tools/dmsetup.c +++ b/tools/dmsetup.c @@ -779,10 +779,12 @@ static int _udevflags(int args, char **argv, void *data __attribute((unused))) uint32_t cookie; uint16_t flags; int i; - static const char *dm_flag_names[] = {"DISABLE_SUBSYSTEM_RULES", + static const char *dm_flag_names[] = {"DISABLE_DM_RULES", + "DISABLE_SUBSYSTEM_RULES", "DISABLE_DISK_RULES", + "DISABLE_OTHER_RULES", "LOW_PRIORITY", - 0, 0, 0, 0, 0}; + 0, 0, 0}; if (!(cookie = _get_cookie_value(argv[1]))) return 0; |