[OLPC-devel] Re: [sugar] Re: pygtk performance issue
Mike Hearn
mike
Wed Sep 6 09:29:32 EDT 2006
On Wed, 06 Sep 2006 14:26:32 +0200, Marco Pesenti Gritti wrote:
> The reduced test case I attached to the mail starting this thread is
> doing only "open".
>
> On the OLPC:
>
> Total "import gtk" time : 0.9 secs
> 500 opens with my testcase: 0.35 secs
> (import gtk cause around 500 opens)
>
> Note that I'm ignoring all the "stat". Still, this seem to be a good
> part of the startup time.
Profiles from my own system are here:
http://plan99.net/~mike/python.modules.oprofile
http://plan99.net/~mike/python.symbols.oprofile
I think the open() related parts would be:
53 0.5516 vmlinux-2.6.16.13-4-default do_page_fault
...
32 0.3330 vmlinux-2.6.16.13-4-default __d_lookup
One issue I see - your test case is written in Python itself, whereas the
Python VM is written in C. On my system this makes a big difference:
mike at linux:/tmp> time ./opentest
real 0m0.136s
user 0m0.000s
sys 0m0.076s
mike at linux:/tmp> time python ./opentest.py
10000 open: 0.507028
real 0m0.677s
user 0m0.456s
sys 0m0.112s
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <unistd.h>
int main()
{
char fname[1024];
for (int i = 0; i < 10000; i++)
{
sprintf(fname, "/tmp/foo.%04d", random() % 9999);
open(fname, O_RDONLY);
}
}
thanks -mike
More information about the Sugar-devel
mailing list