1 /* This testcase is part of GDB, the GNU debugger.
3 Copyright 2004, 2007, 2008, 2009 Free Software Foundation, Inc.
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
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
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.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
26 static volatile int done
;
34 struct itimerval itime
;
35 struct sigaction action
;
37 /* The enum is so that GDB can easily see these macro values. */
39 itimer_real
= ITIMER_REAL
,
40 itimer_virtual
= ITIMER_VIRTUAL
41 } itimer
= ITIMER_VIRTUAL
;
48 /* Set up the signal handler. */
49 memset (&action
, 0, sizeof (action
));
50 action
.sa_handler
= handler
;
51 sigaction (SIGVTALRM
, &action
, NULL
);
52 sigaction (SIGALRM
, &action
, NULL
);
54 /* The values needed for the itimer. This needs to be at least long
55 enough for the setitimer() call to return. */
56 memset (&itime
, 0, sizeof (itime
));
57 itime
.it_value
.tv_usec
= 250 * 1000;
59 /* Loop for ever, constantly taking an interrupt. */
62 /* Set up a one-off timer. A timer, rather than SIGSEGV, is
63 used as after a timer handler finishes the interrupted code
65 res
= setitimer (itimer
, &itime
, NULL
);
68 printf ("First call to setitimer failed, errno = %d\r\n",errno
);
70 res
= setitimer (itimer
, &itime
, NULL
);
73 printf ("Second call to setitimer failed, errno = %d\r\n",errno
);