* Use id(1) instead of grep(1) to detect the presence of the smmsp
[dragonfly.git] / lib / libc_r / test / join_leak_d.c
1 /*
2  * Copyright (C) 2001 Jason Evans <jasone@freebsd.org>.
3  * All rights reserved.
4  * 
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice(s), this list of conditions and the following disclaimer as
10  *    the first lines of this file unmodified other than the possible
11  *    addition of one or more copyright notices.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice(s), this list of conditions and the following disclaimer in
14  *    the documentation and/or other materials provided with the
15  *    distribution.
16  * 
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER(S) ``AS IS'' AND ANY
18  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
27  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28  *
29  * $FreeBSD: src/lib/libc_r/test/join_leak_d.c,v 1.1.2.1 2001/06/22 21:44:27 jasone Exp $
30  * $DragonFly: src/lib/libc_r/test/join_leak_d.c,v 1.2 2003/06/17 04:26:48 dillon Exp $
31  *
32  * Test for leaked joined threads.
33  */
34
35 #include <stdio.h>
36 #include <stdlib.h>
37 #include <unistd.h>
38
39 #include <errno.h>
40 #include <string.h>
41 #include <pthread.h>
42
43 #define NITERATIONS     16384
44 #define MAXGROWTH       16384
45
46 void *
47 thread_entry(void *a_arg)
48 {
49         return NULL;
50 }
51
52 int
53 main(void)
54 {
55         pthread_t       thread;
56         int             i, error;
57         char            *brk, *nbrk;
58         unsigned        growth;
59
60         fprintf(stderr, "Test begin\n");
61
62         /* Get an initial brk value. */
63         brk = sbrk(0);
64
65         /* Create threads and join them, one at a time. */
66         for (i = 0; i < NITERATIONS; i++) {
67                 if ((error = pthread_create(&thread, NULL, thread_entry, NULL))
68                     != 0) {
69                         fprintf(stderr, "Error in pthread_create(): %s\n",
70                             strerror(error));
71                         exit(1);
72                 }
73                 if ((error = pthread_join(thread, NULL)) != 0) {
74                         fprintf(stderr, "Error in pthread_join(): %s\n",
75                             strerror(error));
76                         exit(1);
77                 }
78         }
79
80         /* Get a final brk value. */
81         nbrk = sbrk(0);
82
83         /*
84          * Check that the amount of heap space allocated is below an acceptable
85          * threshold.  We could just compare brk and nbrk, but the test could
86          * conceivably break if the internals of the threads library changes.
87          */
88         if (nbrk > brk) {
89                 /* Heap grows up. */
90                 growth = nbrk - brk;
91         } else if (nbrk <= brk) {
92                 /* Heap grows down, or no growth. */
93                 growth = brk - nbrk;
94         }
95
96         if (growth > MAXGROWTH) {
97                 fprintf(stderr, "Heap growth exceeded maximum (%u > %u)\n",
98                     growth, MAXGROWTH);
99         }
100 #if (0)
101         else {
102                 fprintf(stderr, "Heap growth acceptable (%u <= %u)\n",
103                     growth, MAXGROWTH);
104         }
105 #endif
106
107         fprintf(stderr, "Test end\n");
108         return 0;
109 }