cvs commit: src/sys/conf files src/sys/kern kern_subr.c uipc_jumbo.c src/sys/pci if_ti.c src/sys/sys jumbo.h

Alan Cox alc at cs.rice.edu
Mon Dec 6 16:19:46 PST 2004


On Sun, Dec 05, 2004 at 08:22:54PM -0800, Nate Lawson wrote:
> Alan Cox wrote:
> >alc         2004-12-06 00:43:40 UTC
> >
> >  FreeBSD src repository
> >
> >  Modified files:
> >    sys/conf             files 
> >    sys/kern             kern_subr.c 
> >    sys/pci              if_ti.c 
> >  Removed files:
> >    sys/kern             uipc_jumbo.c 
> >    sys/sys              jumbo.h 
> >  Log:
> >  Update the Tigon 1 and 2 driver to use the sf_buf API for implementing
> >  zero-copy receive of jumbo frames.  This eliminates the need for the
> >  jumbo frame allocator implemented in kern/uipc_jumbo.c and sys/jumbo.h.
> >  Remove it.
> >  
> >  Note: Zero-copy receive of jumbo frames did not work without these 
> >  changes;
> >  I believe there was insufficient locking on the jumbo vm object.
> >  
> >  Tested by: ken@
> >  Discussed with: gallatin@
> >  
> >  Revision  Changes    Path
> >  1.973     +0 -1      src/sys/conf/files
> >  1.93      +4 -6      src/sys/kern/kern_subr.c
> >  1.12      +0 -254    src/sys/kern/uipc_jumbo.c (dead)
> >  1.98      +23 -15    src/sys/pci/if_ti.c
> >  1.6       +0 -59     src/sys/sys/jumbo.h (dead)
> 
> Excellent, thanks for doing this.  Having a generic zero-copy API was 
> something we had needed for a long time.  Perhaps cam_periph_mapmem() 
> (sys/cam/cam_periph.c) could also benefit?

Vmapbuf() is still probably the best method for cam_periph_mapmem().
A limitation of the sf_buf interface is that it cannot map two or more
physical pages to contiguous virtual pages.  Vmapbuf() does. 

Regards,
Alan


More information about the cvs-all mailing list