Stefano Stabellini
2010-May-06 13:46 UTC
[Xen-devel] [PATCH] if the domain creation fails, destroy the domain
Hi all, this patch makes sure that if the domain creation fails for any reason, no zombie domains are left around. Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com> --- diff -r ccae861f52f7 tools/libxl/xl_cmdimpl.c --- a/tools/libxl/xl_cmdimpl.c Thu May 06 11:59:55 2010 +0100 +++ b/tools/libxl/xl_cmdimpl.c Thu May 06 14:44:16 2010 +0100 @@ -937,14 +937,16 @@ ret = libxl_domain_make(&ctx, &info1, &domid); if (ret) { fprintf(stderr, "cannot make domain: %d\n", ret); - return ERROR_FAIL; + ret = ERROR_FAIL; + goto error_out; } ret = libxl_userdata_store(&ctx, domid, "xl", config_data, config_len); if (ret) { perror("cannot save config file"); - return ERROR_FAIL; + ret = ERROR_FAIL; + goto error_out; } if (!restore_file || !need_daemon) { @@ -959,7 +961,8 @@ if (ret) { fprintf(stderr, "cannot (re-)build domain: %d\n", ret); - return ERROR_FAIL; + ret = ERROR_FAIL; + goto error_out; } for (i = 0; i < num_disks; i++) { @@ -967,7 +970,8 @@ ret = libxl_device_disk_add(&ctx, domid, &disks[i]); if (ret) { fprintf(stderr, "cannot add disk %d to domain: %d\n", i, ret); - return ERROR_FAIL; + ret = ERROR_FAIL; + goto error_out; } } for (i = 0; i < num_vifs; i++) { @@ -975,7 +979,8 @@ ret = libxl_device_nic_add(&ctx, domid, &vifs[i]); if (ret) { fprintf(stderr, "cannot add nic %d to domain: %d\n", i, ret); - return ERROR_FAIL; + ret = ERROR_FAIL; + goto error_out; } } if (info1.hvm) { @@ -1023,13 +1028,15 @@ assert(got_child == -1); if (errno != EINTR) { perror("failed to wait for daemonizing child"); - return ERROR_FAIL; + ret = ERROR_FAIL; + goto error_out; } } if (status) { libxl_report_child_exitstatus(&ctx, XL_LOG_ERROR, "daemonizing child", child1, status); - return ERROR_FAIL; + ret = ERROR_FAIL; + goto error_out; } return domid; /* caller gets success in parent */ } @@ -1113,6 +1120,11 @@ close(logfile); exit(0); + +error_out: + if (domid) + libxl_domain_destroy(&ctx, domid, 0); + return ret; } void help(char *command) _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel