From: Lai Jiangshan Date: Tue, 27 Dec 2011 07:36:38 +0000 (+0800) Subject: kvm tools: Don't remove any file which is not created by itself X-Git-Tag: next-20120402~5^2~63 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=a54ef434364b377228f4746d52e654e911a7a4dd;p=karo-tx-linux.git kvm tools: Don't remove any file which is not created by itself It is user's or other program's reponsibility, not the current program. Just try best to let the user know what happen. Also make print_guest() keep the same behavior as do_debug() do_pause() ...etc. when it failed. Signed-off-by: Lai Jiangshan Signed-off-by: Pekka Enberg --- diff --git a/tools/kvm/builtin-list.c b/tools/kvm/builtin-list.c index 885543f440ce..9299f17b6f00 100644 --- a/tools/kvm/builtin-list.c +++ b/tools/kvm/builtin-list.c @@ -77,7 +77,7 @@ static int print_guest(const char *name, int sock) vmstate = get_vmstate(sock); if ((int)pid < 0 || vmstate < 0) - goto cleanup; + return -1; if (vmstate == KVM_VMSTATE_PAUSED) printf("%5d %-20s %s\n", pid, name, KVM_INSTANCE_PAUSED); @@ -85,10 +85,6 @@ static int print_guest(const char *name, int sock) printf("%5d %-20s %s\n", pid, name, KVM_INSTANCE_RUNNING); return 0; - -cleanup: - kvm__remove_socket(name); - return -1; } static int kvm_list_running_instances(void) diff --git a/tools/kvm/kvm.c b/tools/kvm/kvm.c index 29cc4b4cf80f..cb4e5a0d7121 100644 --- a/tools/kvm/kvm.c +++ b/tools/kvm/kvm.c @@ -150,7 +150,6 @@ static int kvm__create_socket(struct kvm *kvm) return s; local.sun_family = AF_UNIX; strcpy(local.sun_path, full_name); - unlink(local.sun_path); len = strlen(local.sun_path) + sizeof(local.sun_family); r = bind(s, (struct sockaddr *)&local, len); if (r < 0) @@ -190,8 +189,9 @@ int kvm__get_sock_by_instance(const char *name) r = connect(s, &local, len); if (r < 0 && errno == ECONNREFUSED) { - /* Clean ghost socket file */ - unlink(sock_file); + /* Tell the user clean ghost socket file */ + pr_err("\"%s\" could be a ghost socket file, please remove it", + sock_file); return -1; } else if (r < 0) { die("Failed connecting to instance");