Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 21 Mar 2008 19:59:50 -0700 (PDT)
From:      Barney Cordoba <barney_cordoba@yahoo.com>
To:        Julian Elischer <julian@elischer.org>
Cc:        current@freebsd.org
Subject:   Re: kvm_read() vs ioctl performance
Message-ID:  <494618.95957.qm@web63906.mail.re1.yahoo.com>
In-Reply-To: <47E46682.4020403@elischer.org>

next in thread | previous in thread | raw e-mail | index | archive | help

--- Julian Elischer <julian@elischer.org> wrote:

> Barney Cordoba wrote:
> > --- Julian Elischer <julian@elischer.org> wrote:
> > 
> >> Barney Cordoba wrote:
> >>> I have an app which reads stats from the kernel
> >>> periodically, and there can be a lot of
> >> iterations,
> >>> sometimes 20,000 or more. I'm thinking of
> >> converting
> >>> from an ioctl method to kvm_read(). KVM is
> >> certainly
> >>> simpler, but its not clear what overhead is
> >> involved,
> >>> since kvm_read() likely has to call the kernel
> >> also.
> >>> Does anyone have a handle on the difference in
> >>> overhead, assuming that the ioctl call is to a
> >> module
> >>> which does nothing more than copy the data and
> >> return?
> >>
> >> tried a shared memory page?
> > 
> > No, but I built a test and kvm_read is 70 times
> > faster, in
> > case anyone is interested.
> 
> cool..
> the only downside is that we are trying to get away
> from kvm direct 
> access. (which is why a shared page might give the
> same result with a 
> stable API which is not libkvm... BTW on an SMP
> machine you have
> no way to ensure that your stats are coherent if you
> use libkvm.

The app is portable, and I'd prefer not to have
different methods for LINUX and FreeBSD. When you say
"coherent", what exactly do you mean?

Barney


      ____________________________________________________________________________________
Never miss a thing.  Make Yahoo your home page. 
http://www.yahoo.com/r/hs



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?494618.95957.qm>