summaryrefslogtreecommitdiffstats
path: root/discover/udev.c
diff options
context:
space:
mode:
authorJeremy Kerr <jk@ozlabs.org>2013-09-24 17:31:50 +0800
committerJeremy Kerr <jk@ozlabs.org>2013-09-24 17:31:50 +0800
commit995e08e3de9aaff81e72227587ffcb4cc78175d0 (patch)
tree3f523456384a0e5431c61eb5373c185614853736 /discover/udev.c
parent25e4608e9e4572b3a835f7c43a8ec9c77125f492 (diff)
downloadtalos-petitboot-995e08e3de9aaff81e72227587ffcb4cc78175d0.tar.gz
talos-petitboot-995e08e3de9aaff81e72227587ffcb4cc78175d0.zip
discover: Check for devices with duplicate serial properties
If we have multipath devices present in the system, we'll end up with duplicate mounts, parse results and boot options. This change adds a check to see if we've encountered a device with this serial number previously. Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Diffstat (limited to 'discover/udev.c')
-rw-r--r--discover/udev.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/discover/udev.c b/discover/udev.c
index 1c5cf71..e996e22 100644
--- a/discover/udev.c
+++ b/discover/udev.c
@@ -70,6 +70,7 @@ static int udev_handle_dev_add(struct pb_udev *udev, struct udev_device *dev)
{
struct discover_device *ddev;
const char *typestr;
+ const char *serial;
const char *path;
const char *name;
@@ -104,6 +105,12 @@ static int udev_handle_dev_add(struct pb_udev *udev, struct udev_device *dev)
return -1;
}
+ /* we may also see multipath devices; same dev nodes (hence id), but
+ * different serial numbers */
+ serial = udev_device_get_property_value(dev, "ID_SERIAL");
+ if (serial && device_lookup_by_serial(udev->handler, serial))
+ return -1;
+
ddev = discover_device_create(udev->handler, name);
ddev->device_path = udev_device_get_devnode(dev);
OpenPOWER on IntegriCloud