diff options
-rw-r--r-- | test/malloc/Makefile | 22 | ||||
-rw-r--r-- | test/malloc/malloc.c | 43 |
2 files changed, 65 insertions, 0 deletions
diff --git a/test/malloc/Makefile b/test/malloc/Makefile new file mode 100644 index 000000000..d0274d2ce --- /dev/null +++ b/test/malloc/Makefile @@ -0,0 +1,22 @@ +TESTDIR=../ +include $(TESTDIR)/Rules.mak + + +TARGETS=malloc +all: $(TARGETS) + +malloc: malloc.c Makefile $(TESTDIR)/Config $(TESTDIR)/Rules.mak $(TESTCC) + -@ echo "-------" + -@ echo " " + -@ echo "Compiling vs uClibc: " + -@ echo " " + $(TESTCC) $(CFLAGS) -c $< -o $@.o + $(TESTCC) $(LDFLAGS) $@.o -o $@ $(EXTRA_LIBS) + $(STRIPTOOL) -x -R .note -R .comment $@ + -./$@ + -@ echo " " + +clean: + rm -f *.[oa] *~ core $(TARGETS) + + diff --git a/test/malloc/malloc.c b/test/malloc/malloc.c new file mode 100644 index 000000000..698ab5e70 --- /dev/null +++ b/test/malloc/malloc.c @@ -0,0 +1,43 @@ + +#include <unistd.h> +#include <stdlib.h> +#include <stdio.h> + +#define N_PTRS 1000 +#define N_ALLOCS 10000 +#define MAX_SIZE 0x10000 + +#define random_size() (random()%MAX_SIZE) +#define random_ptr() (random()%N_PTRS) + +int main(int argc,char *argv[]) +{ + void **ptrs; + int i,j; + int size; + + srandom(0x19730929); + + ptrs = malloc(N_PTRS*sizeof(void *)); + + for(i=0;i<N_PTRS;i++){ + ptrs[i]=malloc(random_size()); + } + for(i=0;i<N_ALLOCS;i++){ + j=random_ptr(); + free(ptrs[j]); + + size=random_size(); + ptrs[j]=malloc(size); + if(!ptrs[j]){ + printf("malloc failed! %d\n",i); + } + memset(ptrs[j],0,size); + } + for(i=0;i<N_PTRS;i++){ + free(ptrs[i]); + } + + return 0; +} + |