[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PULL 1/9] Fix segmentation fault when qemu_signal_init fai
From: |
Dr. David Alan Gilbert (git) |
Subject: |
[Qemu-devel] [PULL 1/9] Fix segmentation fault when qemu_signal_init fails |
Date: |
Wed, 23 Jan 2019 15:58:22 +0000 |
From: Fei Li <address@hidden>
When qemu_signal_init() fails in qemu_init_main_loop(), we return
without setting an error. Its callers crash then when they try to
report the error with error_report_err().
To avoid such segmentation fault, add a new Error parameter to make
the call trace to propagate the err to the final caller.
Fixes: 2f78e491d7b46542158ce0b8132ee4e05bc0ade4
Cc: Paolo Bonzini <address@hidden>
Signed-off-by: Fei Li <address@hidden>
Reviewed-by: Fam Zheng <address@hidden>
Reviewed-by: Markus Armbruster <address@hidden>
Message-Id: <address@hidden>
Signed-off-by: Dr. David Alan Gilbert <address@hidden>
---
util/main-loop.c | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/util/main-loop.c b/util/main-loop.c
index affe0403c5..443cb4cfe8 100644
--- a/util/main-loop.c
+++ b/util/main-loop.c
@@ -71,7 +71,7 @@ static void sigfd_handler(void *opaque)
}
}
-static int qemu_signal_init(void)
+static int qemu_signal_init(Error **errp)
{
int sigfd;
sigset_t set;
@@ -96,7 +96,7 @@ static int qemu_signal_init(void)
sigdelset(&set, SIG_IPI);
sigfd = qemu_signalfd(&set);
if (sigfd == -1) {
- fprintf(stderr, "failed to create signalfd\n");
+ error_setg_errno(errp, errno, "failed to create signalfd");
return -errno;
}
@@ -109,7 +109,7 @@ static int qemu_signal_init(void)
#else /* _WIN32 */
-static int qemu_signal_init(void)
+static int qemu_signal_init(Error **errp)
{
return 0;
}
@@ -148,7 +148,7 @@ int qemu_init_main_loop(Error **errp)
init_clocks(qemu_timer_notify_cb);
- ret = qemu_signal_init();
+ ret = qemu_signal_init(errp);
if (ret) {
return ret;
}
--
2.20.1
- [Qemu-devel] [PULL 0/9] migration queue, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 1/9] Fix segmentation fault when qemu_signal_init fails,
Dr. David Alan Gilbert (git) <=
- [Qemu-devel] [PULL 2/9] migration: fix the multifd code when receiving less channels, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 3/9] migration: multifd_save_cleanup() can't fail, simplify, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 4/9] migration: add more error handling for postcopy_ram_enable_notify, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 5/9] migration: unify error handling for process_incoming_migration_co, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 6/9] migration/rdma: unregister fd handler, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 7/9] tests: add /vmstate/simple/array, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 8/9] vmstate: constify SaveVMHandlers, Dr. David Alan Gilbert (git), 2019/01/23
- [Qemu-devel] [PULL 9/9] migration: introduce pages-per-second, Dr. David Alan Gilbert (git), 2019/01/23
- Re: [Qemu-devel] [PULL 0/9] migration queue, Peter Maydell, 2019/01/24