1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20: #include <pthread.h>
21: #include <signal.h>
22: #include <unistd.h>
23:
24:
25: static int the_sig;
26:
27:
28: static void
29: eintr_handler (int sig)
30: {
31: if (sig != the_sig)
32: {
33: write (STDOUT_FILENO, "eintr_handler: signal number wrong\n", 35);
34: _exit (1);
35: }
36: write (STDOUT_FILENO, ".", 1);
37: }
38:
39:
40: static void *
41: eintr_source (void *arg)
42: {
43: struct timespec ts = { .tv_sec = 0, .tv_nsec = 500000 };
44:
45: if (arg == NULL)
46: {
47: sigset_t ss;
48: sigemptyset (&ss);
49: sigaddset (&ss, the_sig);
50: pthread_sigmask (SIG_BLOCK, &ss, NULL);
51: }
52:
53: while (1)
54: {
55: if (arg != NULL)
56: pthread_kill (*(pthread_t *) arg, the_sig);
57: else
58: kill (getpid (), the_sig);
59:
60: nanosleep (&ts, NULL);
61: }
62:
63:
64: return NULL;
65: }
66:
67:
68: static void
69: setup_eintr (int sig, pthread_t *thp)
70: {
71: struct sigaction sa;
72: sigemptyset (&sa.sa_mask);
73: sa.sa_flags = 0;
74: sa.sa_handler = eintr_handler;
75: if (sigaction (sig, &sa, NULL) != 0)
76: {
77: puts ("setup_eintr: sigaction failed");
78: exit (1);
79: }
80: the_sig = sig;
81:
82:
83: pthread_t th;
84: if (pthread_create (&th, NULL, eintr_source, thp) != 0)
85: {
86: puts ("setup_eintr: pthread_create failed");
87: exit (1);
88: }
89: }