Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 7 Jul 2004 22:58:52 -0600
From:      "Kenneth D. Merry" <ken@freebsd.org>
To:        Robert Watson <rwatson@freebsd.org>
Cc:        ticso@cicely.de
Subject:   Re: speeding up ugen by an order of magnitude.
Message-ID:  <20040708045852.GA86788@panzer.kdm.org>
In-Reply-To: <Pine.NEB.3.96L.1040707144843.37929O-100000@fledge.watson.org>
References:  <Pine.BSF.4.21.0407071111040.80217-100000@InterJet.elischer.org> <Pine.NEB.3.96L.1040707144843.37929O-100000@fledge.watson.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On Wed, Jul 07, 2004 at 14:53:38 -0400, Robert Watson wrote:
> On Wed, 7 Jul 2004, Julian Elischer wrote:
> > Yes that's why I brought it up here.  That was only a "proof-of-concept"
> > that showed that teh slowdown was coming from the fact that the ugen was
> > only pushing one KB of data per frame (1mSec) interrupt. (it was pinned
> > at 1MB/sec)  The correct answer may be to do what pould-henning
> > suggested and use teh physio facility to do this. I considerred that
> > originally but there is overhead in that too, and it is also possible
> > that the NetBSD and FreeBSD physio facilities have diverged enough to
> > make this non trivial as far as keeping diffs to a minimum. (It is after
> > all NetBSD code). 
> 
> You might want to take a look at the ZERO_COPY socket send code, as well
> as the sendfile() code...  FYI, I'm in the process of reformulating some
> of the zero copy send code on the advice of Alan Cox to make it less
> strict about alignment, etc.

That would be pretty cool.  I'm interested to see what you guys have come
up with. :)  The size and alignment restrictions make it less effective than
it could be.  (Depends on the application, obviously.)

The problems are worse on receive, but then most cards can't do the header
splitting necessary for zero copy receive.

Ken
-- 
Kenneth Merry
ken@FreeBSD.ORG



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