diff options
Diffstat (limited to 'test/pthread')
-rw-r--r-- | test/pthread/Makefile | 64 | ||||
-rw-r--r-- | test/pthread/ex1.c | 42 |
2 files changed, 59 insertions, 47 deletions
diff --git a/test/pthread/Makefile b/test/pthread/Makefile index 247c07869..43e8c535e 100644 --- a/test/pthread/Makefile +++ b/test/pthread/Makefile @@ -1,5 +1,22 @@ -TESTDIR=../ -include $(TESTDIR)/Rules.mak +# Makefile for uClibc +# +# Copyright (C) 2000,2001 Erik Andersen <andersen@uclibc.org> +# +# This program is free software; you can redistribute it and/or modify it under +# the terms of the GNU Library General Public License as published by the Free +# Software Foundation; either version 2 of the License, or (at your option) any +# later version. +# +# This program is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +# FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more +# details. +# +# You should have received a copy of the GNU Library General Public License +# along with this program; if not, write to the Free Software Foundation, Inc., +# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + +include ../Rules.mak LDFLAGS += #EXTRA_LIBS += -lc -lgcc -lpthread @@ -8,83 +25,82 @@ EXTRA_LIBS += -lpthread TARGETS=ex1 ex2 ex3 ex4 ex5 ex6 ex7 all: $(TARGETS) -ex1: ex1.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak +ex1: ex1.c Makefile $(TESTDIR)/Rules.mak -@ echo "-------" -@ echo " " - -@ echo "Compiling vs uClibc: " + -@ echo "Compiling $@ vs uClibc: " -@ echo " " $(CC) $(CFLAGS) -c $< -o $@.o $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) $(STRIPTOOL) -x -R .note -R .comment $@ - -./$@ + ./$@ -@ echo " " -ex2: ex2.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak +ex2: ex2.c Makefile $(TESTDIR)/Rules.mak -@ echo "-------" -@ echo " " - -@ echo "Compiling vs uClibc: " + -@ echo "Compiling $@ vs uClibc: " -@ echo " " $(CC) $(CFLAGS) -c $< -o $@.o $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) $(STRIPTOOL) -x -R .note -R .comment $@ - -./$@ + ./$@ -@ echo " " -ex3: ex3.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak +ex3: ex3.c Makefile $(TESTDIR)/Rules.mak -@ echo "-------" -@ echo " " - -@ echo "Compiling vs uClibc: " + -@ echo "Compiling $@ vs uClibc: " -@ echo " " $(CC) $(CFLAGS) -c $< -o $@.o $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) $(STRIPTOOL) -x -R .note -R .comment $@ - -./$@ + ./$@ -@ echo " " -ex4: ex4.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak +ex4: ex4.c Makefile $(TESTDIR)/Rules.mak -@ echo "-------" -@ echo " " - -@ echo "Compiling vs uClibc: " + -@ echo "Compiling $@ vs uClibc: " -@ echo " " $(CC) $(CFLAGS) -c $< -o $@.o $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) $(STRIPTOOL) -x -R .note -R .comment $@ - -./$@ + ./$@ -@ echo " " -ex5: ex5.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak +ex5: ex5.c Makefile $(TESTDIR)/Rules.mak -@ echo "-------" -@ echo " " - -@ echo "Compiling vs uClibc: " + -@ echo "Compiling $@ vs uClibc: " -@ echo " " $(CC) $(CFLAGS) -c $< -o $@.o $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) $(STRIPTOOL) -x -R .note -R .comment $@ - -./$@ + ./$@ -@ echo " " -ex6: ex6.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak +ex6: ex6.c Makefile $(TESTDIR)/Rules.mak -@ echo "-------" -@ echo " " - -@ echo "Compiling vs uClibc: " + -@ echo "Compiling $@ vs uClibc: " -@ echo " " $(CC) $(CFLAGS) -c $< -o $@.o $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) $(STRIPTOOL) -x -R .note -R .comment $@ - -./$@ + ./$@ -@ echo " " -ex7: ex7.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak +ex7: ex7.c Makefile $(TESTDIR)/Rules.mak -@ echo "-------" -@ echo " " - -@ echo "Compiling vs uClibc: " + -@ echo "Compiling $@ vs uClibc: " -@ echo " " $(CC) $(CFLAGS) -c $< -o $@.o $(CC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) $(STRIPTOOL) -x -R .note -R .comment $@ - -./$@ + ./$@ -@ echo " " clean: $(RM) *.[oa] *~ core $(TARGETS) - diff --git a/test/pthread/ex1.c b/test/pthread/ex1.c index 09e6e3fbd..a1b24c31a 100644 --- a/test/pthread/ex1.c +++ b/test/pthread/ex1.c @@ -7,33 +7,29 @@ #include <unistd.h> #include "pthread.h" -void * process(void * arg) +void *process(void * arg) { - int i; - fprintf(stderr, "Starting process %s\n", (char *) arg); - for (i = 0; i < 10000; i++) { - write(1, (char *) arg, 1); - } - return NULL; + int i; + printf("Starting process %s\n", (char *)arg); + for (i = 0; i < 10000; i++) + write(1, (char *) arg, 1); + return NULL; } +#define sucfail(r) (r != 0 ? "failed" : "succeeded") int main(void) { - int retcode; - pthread_t th_a, th_b; - void * retval; + int pret, ret = 0; + pthread_t th_a, th_b; + void *retval; - retcode = pthread_create(&th_a, NULL, process, (void *) "a"); - if (retcode != 0) fprintf(stderr, "create a failed %d\n", retcode); - else fprintf(stderr, "create a succeeded %d\n", retcode); - retcode = pthread_create(&th_b, NULL, process, (void *) "b"); - if (retcode != 0) fprintf(stderr, "create b failed %d\n", retcode); - else fprintf(stderr, "create b succeeded %d\n", retcode); - retcode = pthread_join(th_a, &retval); - if (retcode != 0) fprintf(stderr, "join a failed %d\n", retcode); - else fprintf(stderr, "join a succeeded %d\n", retcode); - retcode = pthread_join(th_b, &retval); - if (retcode != 0) fprintf(stderr, "join b failed %d\n", retcode); - else fprintf(stderr, "join b succeeded %d\n", retcode); - return 0; + ret += (pret = pthread_create(&th_a, NULL, process, (void *)"a")); + printf("create a %s %d\n", sucfail(pret), pret); + ret += (pret = pthread_create(&th_b, NULL, process, (void *)"b")); + printf("create b %s %d\n", sucfail(pret), pret); + ret += (pret = pthread_join(th_a, &retval)); + printf("join a %s %d\n", sucfail(pret), pret); + ret += (pret = pthread_join(th_b, &retval)); + printf("join b %s %d\n", sucfail(pret), pret); + return ret; } |