diff options
author | Bin Meng <bin.meng@windriver.com> | 2022-10-06 23:19:19 +0800 |
---|---|---|
committer | Thomas Huth <thuth@redhat.com> | 2022-10-12 08:45:05 +0200 |
commit | 969d1f6e13fd34350b4b3fa72184e050ba77cd1c (patch) | |
tree | 712943945def9538c3fa6e6b66862dd6bc534bbc /tests | |
parent | e5553c1b8d28fde6b69dc9e6ac148515d361a86c (diff) | |
download | qemu-969d1f6e13fd34350b4b3fa72184e050ba77cd1c.zip qemu-969d1f6e13fd34350b4b3fa72184e050ba77cd1c.tar.gz qemu-969d1f6e13fd34350b4b3fa72184e050ba77cd1c.tar.bz2 |
tests/qtest: libqtest: Install signal handler via signal()
At present the codes uses sigaction() to install signal handler with
a flag SA_RESETHAND. Such usage can be covered by the signal() API
that is a simplified interface to the general sigaction() facility.
Update to use signal() to install the signal handler, as it is
available on Windows which we are going to support.
Signed-off-by: Bin Meng <bin.meng@windriver.com>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <20221006151927.2079583-11-bmeng.cn@gmail.com>
Signed-off-by: Thomas Huth <thuth@redhat.com>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/qtest/libqtest.c | 14 |
1 files changed, 3 insertions, 11 deletions
diff --git a/tests/qtest/libqtest.c b/tests/qtest/libqtest.c index 7b61528..b23eb3e 100644 --- a/tests/qtest/libqtest.c +++ b/tests/qtest/libqtest.c @@ -66,7 +66,7 @@ struct QTestState }; static GHookList abrt_hooks; -static struct sigaction sigact_old; +static void (*sighandler_old)(int); static int qtest_query_target_endianness(QTestState *s); @@ -179,20 +179,12 @@ static void sigabrt_handler(int signo) static void setup_sigabrt_handler(void) { - struct sigaction sigact; - - /* Catch SIGABRT to clean up on g_assert() failure */ - sigact = (struct sigaction){ - .sa_handler = sigabrt_handler, - .sa_flags = SA_RESETHAND, - }; - sigemptyset(&sigact.sa_mask); - sigaction(SIGABRT, &sigact, &sigact_old); + sighandler_old = signal(SIGABRT, sigabrt_handler); } static void cleanup_sigabrt_handler(void) { - sigaction(SIGABRT, &sigact_old, NULL); + signal(SIGABRT, sighandler_old); } static bool hook_list_is_empty(GHookList *hook_list) |