[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-id: <4549A261.9010007@cosmosbay.com>
Date: Thu, 02 Nov 2006 08:46:41 +0100
From: Eric Dumazet <dada1@...mosbay.com>
To: zhou drangon <drangon.mail@...il.com>
Cc: linux-kernel@...r.kernel.org,
Evgeniy Polyakov <johnpol@....mipt.ru>
Subject: Re: [take22 0/4] kevent: Generic event handling mechanism.
zhou drangon a écrit :
> performance is great, and we are exciting at the result.
>
> I want to know why there can be so much improvement, can we improve
> epoll too ?
Why did you remove most of CC addresses but lkml ?
Dont do that please...
Good question :)
Hum, I think I can look into epoll and see how it can be improved (if necessary)
This is not to say we dont need kevent ! Please Evgeniy continue your work !
Just to remind you that according to
http://www.xmailserver.org/linux-patches/nio-improve.html David Libenzi had to
wait 18 months before epoll being officialy added into kernel.
At that time, many applications were using epoll, and we were patching our
kernels for that.
I cooked a very simple program (attached in this mail), using pipes and epoll,
and got 250.000 events received per second on an otherwise lightly loaded
machine (dual opteron 246 , 2GHz, 1MB cache per cpu) with 10.000 pipes (20.000
handles)
It could be nice to add support for other event providers in this program
(AF_INET & AF_UNIX sockets for example), and also add support for kevent, so
that we really can compare epoll/kevent without a complex setup.
I should extend the program to also add/remove sources during lifetime, not
only insert at setup time.
# gcc -O2 -o epoll_pipe_bench epoll_pipe_bench.c -lpthread
# ulimit -n 1000000
# epoll_pipe_bench -n 10000
^C after a while...
oprofile results say that ep_poll_callback() and sys_epoll_wait() use 20% of
cpu time.
Even if we gain a two factor in cpu time or cache usage, we wont eliminate
other costs...
oprofile results gave :
Counted CPU_CLK_UNHALTED events (Cycles outside of halt state) with a unit
mask of 0x00 (No unit mask) count 50000
samples % symbol name
2015420 11.1309 ep_poll_callback
1867431 10.3136 pipe_writev
1791872 9.8963 sys_epoll_wait
1357297 7.4962 fget_light
1277515 7.0556 pipe_readv
998447 5.5143 current_fs_time
801597 4.4271 __mark_inode_dirty
755268 4.1713 __wake_up
587065 3.2423 __write_lock_failed
582931 3.2195 system_call
297132 1.6410 iov_fault_in_pages_read
296136 1.6355 sys_write
290106 1.6022 __wake_up_common
270692 1.4950 bad_pipe_w
261516 1.4443 do_pipe
257208 1.4205 tg3_start_xmit_dma_bug
254917 1.4079 pipe_poll
252925 1.3969 copy_user_generic_c
234212 1.2935 generic_pipe_buf_map
228659 1.2629 ret_from_sys_call
212541 1.1738 sysret_check
166529 0.9197 sys_read
160038 0.8839 vfs_write
151091 0.8345 pipe_ioctl
136301 0.7528 file_update_time
107173 0.5919 tg3_poll
77846 0.4299 ipt_do_table
75081 0.4147 schedule
73059 0.4035 vfs_read
69787 0.3854 get_task_comm
63923 0.3530 memcpy
60019 0.3315 touch_atime
57490 0.3175 eventpoll_release_file
56152 0.3101 tg3_write_flush_reg32
54468 0.3008 rw_verify_area
47833 0.2642 generic_pipe_buf_unmap
47777 0.2639 __switch_to
44106 0.2436 bad_pipe_r
41824 0.2310 proc_nr_files
41319 0.2282 pipe_iov_copy_from_user
Eric
View attachment "epoll_pipe_bench.c" of type "text/plain" (2425 bytes)
Powered by blists - more mailing lists