Stop the ipc thread when shutting down the hypervisor. This solves a bug where the .sock files weren't removed upon shutdown. Signed-off-by: Sasha Levin <levinsasha928@xxxxxxxxx> --- tools/kvm/include/kvm/kvm-ipc.h | 1 + tools/kvm/kvm-ipc.c | 30 +++++++++++++++++++++++++++--- tools/kvm/kvm.c | 1 + 3 files changed, 29 insertions(+), 3 deletions(-) diff --git a/tools/kvm/include/kvm/kvm-ipc.h b/tools/kvm/include/kvm/kvm-ipc.h index c932052..731767f 100644 --- a/tools/kvm/include/kvm/kvm-ipc.h +++ b/tools/kvm/include/kvm/kvm-ipc.h @@ -22,5 +22,6 @@ enum { int kvm_ipc__register_handler(u32 type, void (*cb)(int fd, u32 type, u32 len, u8 *msg)); int kvm_ipc__handle(int fd, struct kvm_ipc_msg *msg); int kvm_ipc__start(int sock); +int kvm_ipc__stop(void); #endif diff --git a/tools/kvm/kvm-ipc.c b/tools/kvm/kvm-ipc.c index f05e926..3131fe8 100644 --- a/tools/kvm/kvm-ipc.c +++ b/tools/kvm/kvm-ipc.c @@ -7,12 +7,14 @@ #include <sys/un.h> #include <sys/types.h> #include <sys/socket.h> +#include <sys/eventfd.h> #define KVM_IPC_MAX_MSGS 16 static void (*msgs[KVM_IPC_MAX_MSGS])(int fd, u32 type, u32 len, u8 *msg); static DECLARE_RWSEM(msgs_rwlock); -static int epoll_fd, server_fd; +static int epoll_fd, server_fd, stop_fd; +static pthread_t thread; int kvm_ipc__register_handler(u32 type, void (*cb)(int fd, u32 type, u32 len, u8 *msg)) { @@ -110,7 +112,9 @@ static void *kvm_ipc__thread(void *param) if (nfds > 0) { int fd = event.data.fd; - if (fd == server_fd) { + if (fd == stop_fd) { + break; + } else if (fd == server_fd) { int client; client = kvm_ipc__new_conn(fd); @@ -128,7 +132,6 @@ static void *kvm_ipc__thread(void *param) int kvm_ipc__start(int sock) { - pthread_t thread; struct epoll_event ev; server_fd = sock; @@ -140,8 +143,29 @@ int kvm_ipc__start(int sock) if (epoll_ctl(epoll_fd, EPOLL_CTL_ADD, sock, &ev) < 0) die("Failed starting IPC thread"); + stop_fd = eventfd(0, 0); + ev.events = EPOLLIN | EPOLLOUT | EPOLLRDHUP | EPOLLET; + ev.data.fd = stop_fd; + if (epoll_ctl(epoll_fd, EPOLL_CTL_ADD, stop_fd, &ev) < 0) + die("Failed adding stop event to epoll"); + if (pthread_create(&thread, NULL, kvm_ipc__thread, NULL) != 0) die("Failed starting IPC thread"); return 0; } + +int kvm_ipc__stop(void) +{ + u64 val = 1; + int ret; + + ret = write(stop_fd, &val, sizeof(val)); + if (ret < 0) + return ret; + + close(server_fd); + close(epoll_fd); + + return ret; +} diff --git a/tools/kvm/kvm.c b/tools/kvm/kvm.c index 40ae6a5..8d6b5e1 100644 --- a/tools/kvm/kvm.c +++ b/tools/kvm/kvm.c @@ -237,6 +237,7 @@ void kvm__delete(struct kvm *kvm) kvm__stop_timer(kvm); munmap(kvm->ram_start, kvm->ram_size); + kvm_ipc__stop(); kvm__remove_socket(kvm->name); free(kvm); } -- 1.7.7 -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html