Commit | Line | Data |
---|---|---|
f0fd9238 AC |
1 | /* This testcase is part of GDB, the GNU debugger. |
2 | ||
ecd75fc8 | 3 | Copyright 2004-2014 Free Software Foundation, Inc. |
f0fd9238 AC |
4 | |
5 | This program is free software; you can redistribute it and/or modify | |
6 | it under the terms of the GNU General Public License as published by | |
a9762ec7 | 7 | the Free Software Foundation; either version 3 of the License, or |
f0fd9238 AC |
8 | (at your option) any later version. |
9 | ||
10 | This program is distributed in the hope that it will be useful, | |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
13 | GNU General Public License for more details. | |
a9762ec7 | 14 | |
f0fd9238 | 15 | You should have received a copy of the GNU General Public License |
a9762ec7 | 16 | along with this program. If not, see <http://www.gnu.org/licenses/>. |
f0fd9238 AC |
17 | |
18 | */ | |
19 | ||
20 | #include <stdio.h> | |
e425eb2b | 21 | #include <string.h> |
f0fd9238 AC |
22 | #include <signal.h> |
23 | #include <sys/time.h> | |
501b79c1 | 24 | #include <errno.h> |
f0fd9238 AC |
25 | |
26 | static volatile int done; | |
e5f8a7cc | 27 | static volatile int dummy; |
f0fd9238 AC |
28 | |
29 | static void | |
30 | handler (int sig) | |
31 | { | |
32 | done = 1; | |
33 | } /* handler */ | |
34 | ||
b04e311d AC |
35 | struct itimerval itime; |
36 | struct sigaction action; | |
37 | ||
38 | /* The enum is so that GDB can easily see these macro values. */ | |
39 | enum { | |
40 | itimer_real = ITIMER_REAL, | |
41 | itimer_virtual = ITIMER_VIRTUAL | |
42 | } itimer = ITIMER_VIRTUAL; | |
43 | ||
501b79c1 | 44 | int |
f0fd9238 AC |
45 | main () |
46 | { | |
b04e311d | 47 | |
501b79c1 | 48 | int res; |
f0fd9238 | 49 | /* Set up the signal handler. */ |
b04e311d AC |
50 | memset (&action, 0, sizeof (action)); |
51 | action.sa_handler = handler; | |
52 | sigaction (SIGVTALRM, &action, NULL); | |
53 | sigaction (SIGALRM, &action, NULL); | |
54 | ||
55 | /* The values needed for the itimer. This needs to be at least long | |
56 | enough for the setitimer() call to return. */ | |
57 | memset (&itime, 0, sizeof (itime)); | |
58 | itime.it_value.tv_usec = 250 * 1000; | |
59 | ||
60 | /* Loop for ever, constantly taking an interrupt. */ | |
61 | while (1) | |
62 | { | |
63 | /* Set up a one-off timer. A timer, rather than SIGSEGV, is | |
64 | used as after a timer handler finishes the interrupted code | |
65 | can safely resume. */ | |
501b79c1 PM |
66 | res = setitimer (itimer, &itime, NULL); |
67 | if (res == -1) | |
68 | { | |
69 | printf ("First call to setitimer failed, errno = %d\r\n",errno); | |
70 | itimer = ITIMER_REAL; | |
71 | res = setitimer (itimer, &itime, NULL); | |
72 | if (res == -1) | |
73 | { | |
74 | printf ("Second call to setitimer failed, errno = %d\r\n",errno); | |
75 | return 1; | |
76 | } | |
77 | } | |
e5f8a7cc PA |
78 | /* Wait. Issue a couple writes to a dummy volatile var to be |
79 | reasonably sure our simple "get-next-pc" logic doesn't | |
80 | stumble on branches. */ | |
81 | dummy = 0; dummy = 0; while (!done); | |
b04e311d AC |
82 | done = 0; |
83 | } | |
501b79c1 | 84 | return 0; |
b04e311d | 85 | } |