@@ -52,6 +52,8 @@ int main(void)
if (!udev)
return EXIT_FAILURE;
+ udev_trigger(udev);
+
for (running = 1; running;) {
if (waiter_poll())
break;
@@ -208,6 +208,16 @@ out_err:
return NULL;
}
+int udev_trigger(struct udev __attribute__((unused)) *udev)
+{
+ int rc = system("/sbin/udevadm trigger --subsystem-match=block");
+
+ if (rc)
+ pb_log("udev trigger failed: %d (%d)\n", rc, WEXITSTATUS(rc));
+
+ return WEXITSTATUS(rc);
+}
+
void udev_destroy(struct udev *udev)
{
talloc_free(udev);
@@ -21,6 +21,7 @@ struct udev;
struct device_handler;
struct udev *udev_init(struct device_handler *handler);
+int udev_trigger(struct udev *udev);
void udev_destroy(struct udev *udev);
Add a new routine udev_trigger() that requests a replay of system udev events. Signed-off-by: Geoff Levand <geoffrey.levand@am.sony.com> --- discover/pb-discover.c | 2 ++ discover/udev.c | 10 ++++++++++ discover/udev.h | 1 + 3 files changed, 13 insertions(+)