From fac5697318cb36135fc2df3dc3e0c2631983cd7a Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Thu, 6 Feb 2014 09:25:23 +0100 Subject: gcc/rtems_gcc_main.c: Add signal() workaround --- gcc/rtems_gcc_main.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/gcc/rtems_gcc_main.c b/gcc/rtems_gcc_main.c index 6f56a11..b5b3d38 100644 --- a/gcc/rtems_gcc_main.c +++ b/gcc/rtems_gcc_main.c @@ -12,6 +12,7 @@ #include #include #include +#include /* * Set up first argument @@ -22,8 +23,23 @@ static char *argv[20] = { arg0 }; int main(int argc, char **argv, char **environp); +/* + * Tests like "gcc.c-torture/execute/20101011-1.c" use signal() and raise(). + * RTEMS ignores signals installed via signal() by default. Enable SIGFPE for + * the initialization thread as a workaround. + */ +static void signal_workaround(void) +{ + sigset_t set; + + sigemptyset(&set); + sigaddset(&set, SIGFPE); + pthread_sigmask(SIG_UNBLOCK, &set, NULL); +} + rtems_task Init(rtems_task_argument ignored) { + signal_workaround(); mkdir( "/tmp", 0777 ); main(argc, argv, NULL); } -- cgit v1.2.3