Handle invalid buffer pointers when count is zero.
[glibc/history.git] / nptl / tst-cancel1.c
blob690319d8c783eabfaf7d19803b3b1e356e7fc44e
1 /* Copyright (C) 2002, 2003 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3 Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library 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 GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, write to the Free
17 Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18 02111-1307 USA. */
20 #include <pthread.h>
21 #include <signal.h>
22 #include <stdio.h>
23 #include <stdlib.h>
24 #include <string.h>
27 static pthread_mutex_t m1 = PTHREAD_MUTEX_INITIALIZER;
28 static pthread_mutex_t m2 = PTHREAD_MUTEX_INITIALIZER;
30 static int cntr;
33 static void
34 cleanup (void *arg)
36 if (arg != (void *) 42l)
37 cntr = 42;
38 else
39 cntr = 1;
43 static void *
44 tf (void *arg)
46 /* Ignore all signals. This must not have any effect on delivering
47 the cancellation signal. */
48 sigset_t ss;
50 sigfillset (&ss);
52 if (pthread_sigmask (SIG_BLOCK, &ss, NULL) != 0)
54 puts ("pthread_sigmask failed");
55 exit (1);
58 pthread_cleanup_push (cleanup, (void *) 42l);
60 int err = pthread_setcanceltype (PTHREAD_CANCEL_ASYNCHRONOUS, NULL);
61 if (err != 0)
63 printf ("setcanceltype failed: %s\n", strerror (err));
64 exit (1);
66 /* The following code is not standard compliant: the mutex functions
67 must not be called with asynchronous cancellation enabled. */
69 err = pthread_mutex_unlock (&m2);
70 if (err != 0)
72 printf ("child: mutex_unlock failed: %s\n", strerror (err));
73 exit (1);
76 err = pthread_mutex_lock (&m1);
77 if (err != 0)
79 printf ("child: 1st mutex_lock failed: %s\n", strerror (err));
80 exit (1);
83 /* We should never come here. */
85 pthread_cleanup_pop (0);
87 return NULL;
91 static int
92 do_test (void)
94 int err;
95 pthread_t th;
96 int result = 0;
97 void *retval;
99 /* Get the mutexes. */
100 err = pthread_mutex_lock (&m1);
101 if (err != 0)
103 printf ("parent: 1st mutex_lock failed: %s\n", strerror (err));
104 return 1;
106 err = pthread_mutex_lock (&m2);
107 if (err != 0)
109 printf ("parent: 2nd mutex_lock failed: %s\n", strerror (err));
110 return 1;
113 err = pthread_create (&th, NULL, tf, NULL);
114 if (err != 0)
116 printf ("create failed: %s\n", strerror (err));
117 return 1;
120 err = pthread_mutex_lock (&m2);
121 if (err != 0)
123 printf ("parent: 3rd mutex_lock failed: %s\n", strerror (err));
124 return 1;
127 err = pthread_cancel (th);
128 if (err != 0)
130 printf ("cancel failed: %s\n", strerror (err));
131 return 1;
134 err = pthread_join (th, &retval);
135 if (err != 0)
137 printf ("join failed: %s\n", strerror (err));
138 return 1;
141 if (retval != PTHREAD_CANCELED)
143 printf ("wrong return value: %p\n", retval);
144 result = 1;
147 if (cntr == 42)
149 puts ("cleanup handler called with wrong argument");
150 result = 1;
152 else if (cntr != 1)
154 puts ("cleanup handling not called");
155 result = 1;
158 return result;
162 #define TEST_FUNCTION do_test ()
163 #include "../test-skeleton.c"