X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=discover%2Fdevice-handler.c;h=4ba7405f2de73f29ded296340ec310104393a8d6;hp=ab27b51b2eaf764d98a37b7df3185dd49d46a20b;hb=12a5c9153ce95ddde7fb14eaba9d779933a3637c;hpb=bd06734362bb727b09b943688d9b69aa0a84590d;ds=sidebyside diff --git a/discover/device-handler.c b/discover/device-handler.c index ab27b51..4ba7405 100644 --- a/discover/device-handler.c +++ b/discover/device-handler.c @@ -347,23 +347,25 @@ static int handle_add_user_event(struct device_handler *handler, assert(event->device); - device = talloc_zero(handler, struct device); + device = device_handler_find(handler, event->device); - if (!device) - goto fail; + if (!device) { + device = talloc_zero(handler, struct device); - device->id = talloc_strdup(device, event->device); - list_init(&device->boot_options); + if (!device) + goto fail; - parse_user_event(device, event); + device->id = talloc_strdup(device, event->device); + list_init(&device->boot_options); - discover_server_notify_device_add(handler->server, device); + /* add device to handler device array */ + device_handler_add(handler, device); - list_for_each_entry(&device->boot_options, opt, list) - discover_server_notify_boot_option_add(handler->server, opt); + discover_server_notify_device_add(handler->server, device); + } - /* add device to handler device array */ - device_handler_add(handler, device); + opt = parse_user_event(device, event); + discover_server_notify_boot_option_add(handler->server, opt); return 0;