Subject: Re: mmap(2) performance netbsd-1-6 vs. -current
To: Bang Jun-Young <junyoung@netbsd.org>
From: Jason Thorpe <thorpej@wasabisystems.com>
List: tech-perform
Date: 10/19/2003 11:18:18
On Sunday, October 19, 2003, at 09:51 AM, Bang Jun-Young wrote:
> The test program used is as follows (please don't blame me for its
> silliness, I just wanted to see a rough difference in minutes :-):
Ok, I'll ignore the silliness, but I will point out a couple of bugs :-)
> #include <stdio.h>
> #include <sys/mman.h>
>
> main()
> {
> void *ptr[15];
> int i, j;
> size_t size;
>
> for (j = 0; j < 40960; j++) {
> for (i = 0; i < 15; i++) {
> size = 4096 << i;
> ptr[i] = mmap(NULL, size, PROT_READ|PROT_WRITE, MAP_ANON, -1, 0);
> if (ptr == NULL)
> err("NULL returned, i=%d\n", i);
There are two problems with this code:
- mmap() returns MAP_FAILED, not NULL, on faulure.
- "ptr" will never be null anyway! I think you really want to
be testing ptr[i].
> *((int *)ptr) = 0xdeadbeef;
...and, here again, you want to be dereferencing ptr[i].
> }
> for (i = 0; i < 15; i++) {
> size = 4096 << i;
> munmap(ptr[i], size);
> }
> }
> }
>
> Jun-Young
>
> --
> Bang Jun-Young <junyoung@NetBSD.org>
>
-- Jason R. Thorpe <thorpej@wasabisystems.com>