vkernel observations and time
Matthew Dillon
dillon at apollo.backplane.com
Wed Apr 4 11:32:18 PDT 2007
:Hi,
:
:I have been playing about with vkernels some more and have noticed
:weirdness with time - which i suppose can be more than expected
:running in userland.
:
:For example if the real machine is heavily loaded u can get some odd
:results when doing stuff in the vkernel:
:
:>
:> time sleep 10
:0.000u 0.000s 0:27.45 0.0% 0+0k 2+0io 2pf+0w
:>
Yah, this is because the nanosleep() system call is based on
process ticks and currently the virtual kernel cannot set fine-grained
timeouts via kqueue or select or other mechanisms, so the tick counters
(including 'user' and 'system' time counters) are all going to
be considerably off. Real time should still be correct, though you
might want to also time it manually to be sure.
:I was interested to see the performance hit when doing things under
:a vkernel. The openssl test runs about 3 times slower in the vkernel
:and bonnie is about 1.5 times slower.
:
:Some numbers:
:
:vkernel:
:
:Version: 1.03
:vd1# time openssl speed rsa
:To get the most accurate results, try to run this
Any benchmark which is heavily syscall or VM oriented is going to be
significantly slower. This particular benchmark seems to want to
call getpid() a lot (why I don't know). A pure cpu-bound program
will run at about the same speed in the vkernel verses the real
kernel, but anything else is going to run more slowly.
Same goes with bonnie, though in the case of Bonnie the issue is
probably related more to the fact that our simulated disk drive uses
synchronous I/O calls that stall the whole vkernel.
I wanted to do a benchmark of my own, timing a buildworld, but it looks
like the vkernel platform directory is missing some header files needed
for that. I'm working on making buildworlds work under a vkernel
right now.
-Matt
More information about the Users
mailing list