X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;ds=inline;f=udev%2Fudevadm-monitor.c;h=10b2f2e71b8c1ce0f2d4b49f153bcb30342b7115;hb=dacea9ff6be55f1b115c13b1ab530812d0d66879;hp=d8ec066467e9fbb001d3587b7580e80bc08b1e67;hpb=f2b937440c682bca3837263a1bafd78e30b17e4d;p=elogind.git diff --git a/udev/udevadm-monitor.c b/udev/udevadm-monitor.c index d8ec06646..10b2f2e71 100644 --- a/udev/udevadm-monitor.c +++ b/udev/udevadm-monitor.c @@ -71,6 +71,7 @@ int udevadm_monitor(struct udev *udev, int argc, char *argv[]) int env = 0; int print_kernel = 0; int print_udev = 0; + struct udev_list_node subsystem_match_list; struct udev_monitor *udev_monitor = NULL; struct udev_monitor *kernel_monitor = NULL; fd_set readfds; @@ -80,12 +81,14 @@ int udevadm_monitor(struct udev *udev, int argc, char *argv[]) { "environment", no_argument, NULL, 'e' }, { "kernel", no_argument, NULL, 'k' }, { "udev", no_argument, NULL, 'u' }, + { "subsystem-match", required_argument, NULL, 's' }, { "help", no_argument, NULL, 'h' }, {} }; + udev_list_init(&subsystem_match_list); while (1) { - option = getopt_long(argc, argv, "ekuh", options, NULL); + option = getopt_long(argc, argv, "ekus:h", options, NULL); if (option == -1) break; @@ -99,6 +102,9 @@ int udevadm_monitor(struct udev *udev, int argc, char *argv[]) case 'u': print_udev = 1; break; + case 's': + udev_list_entry_add(udev, &subsystem_match_list, optarg, NULL, 1, 0); + break; case 'h': printf("Usage: udevadm monitor [--environment] [--kernel] [--udev] [--help]\n" " --env print the whole event environment\n" @@ -125,12 +131,24 @@ int udevadm_monitor(struct udev *udev, int argc, char *argv[]) printf("monitor will print the received events for:\n"); if (print_udev) { + struct udev_list_entry *entry; + udev_monitor = udev_monitor_new_from_netlink(udev, "udev"); if (udev_monitor == NULL) { + fprintf(stderr, "error: unable to create netlink socket\n"); rc = 1; goto out; } + + udev_list_entry_foreach(entry, udev_list_get_entry(&subsystem_match_list)) { + const char *subsys = udev_list_entry_get_name(entry); + + if (udev_monitor_filter_add_match_subsystem_devtype(udev_monitor, subsys, NULL) < 0) + fprintf(stderr, "error: unable to apply subsystem filter '%s'\n", subsys); + } + if (udev_monitor_enable_receiving(udev_monitor) < 0) { + fprintf(stderr, "error: unable to subscribe to udev events\n"); rc = 2; goto out; } @@ -139,11 +157,12 @@ int udevadm_monitor(struct udev *udev, int argc, char *argv[]) if (print_kernel) { kernel_monitor = udev_monitor_new_from_netlink(udev, "kernel"); if (kernel_monitor == NULL) { - fprintf(stderr, "unable to subscribe to kernel events\n"); + fprintf(stderr, "error: unable to create netlink socket\n"); rc = 3; goto out; } if (udev_monitor_enable_receiving(kernel_monitor) < 0) { + fprintf(stderr, "error: unable to subscribe to kernel events\n"); rc = 4; goto out; } @@ -192,5 +211,6 @@ int udevadm_monitor(struct udev *udev, int argc, char *argv[]) out: udev_monitor_unref(udev_monitor); udev_monitor_unref(kernel_monitor); + udev_list_cleanup_entries(udev, &subsystem_match_list); return rc; }