Subject: Re: mmap(2) performance netbsd-1-6 vs. -current
To: Jason Thorpe <thorpej@wasabisystems.com>
From: Bang Jun-Young <junyoung@netbsd.org>
List: tech-perform
Date: 10/20/2003 05:06:33
On Sun, Oct 19, 2003 at 11:18:18AM -0700, Jason Thorpe wrote:
> 
> 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].

Oops, I was too lucky... :-)

After fixing the bugs you pointed out, the result is a bit more
interesting (and rather disappointing):

-current:
	real 17.606s user 0.580s sys 17.026s

netbsd-1-6:
	real 17.831s user 0.648s sys 16.985s

This time numbers varied slightly, so I took the median values of 10
trials. Here, -current was only marginally faster than netbsd-1-6,
and it's obvious that it had nothing to do with improvements made in
UVM in -current. This result makes me wonder why the previous silly
test showed such a noticable difference.

Jun-Young

-- 
Bang Jun-Young <junyoung@NetBSD.org>