git: kernel - u4b - Implement doorbell

Matthew Dillon dillon at crater.dragonflybsd.org
Fri Jan 10 12:07:25 PST 2014


commit e15d1b6823a13e8ae6c9a6f99c447c695146ac95
Author: Matthew Dillon <dillon at apollo.backplane.com>
Date:   Fri Jan 10 12:03:43 2014 -0800

    kernel - u4b - Implement doorbell
    
    * Implement the doorbell properly.
    
    * Use the doorbell to clear the previous transfer when reusing a transfer.
      This is a horribly inefficient hack but it's better than blowing up the
      controller
    
      (This is in addition to the xfer freeing fifo hack)
    
    * We also seem to need to ring the doorbell when queueing transfers.  This
      should not be necessary.
    
    * Enable ASP.  This allows qTD bursts, making high speed busses more
      efficient.
    
    * NOTE:  There are still problems with umass.  With some USB sticks,
     	 writing to the stick causes the cpu to stall for very long
    	 periods of time.  It is shown as 'interrupt' overhead but insofar
    	 as I can tell it's actually the controller stalling the memory
    	 bus for reasons unknown.
    
    	 This does not happen with e.g. a SATA SSD connected through a USB
    	 adapter.

Summary of changes:
 sys/bus/u4b/controller/ehci.c | 117 +++++++++++++++++++++++++++++++++++-------
 sys/bus/u4b/controller/ehci.h |   4 +-
 sys/bus/u4b/usb_core.h        |   3 ++
 sys/bus/u4b/usb_transfer.c    |   2 +-
 4 files changed, 105 insertions(+), 21 deletions(-)

http://gitweb.dragonflybsd.org/dragonfly.git/commitdiff/e15d1b6823a13e8ae6c9a6f99c447c695146ac95


-- 
DragonFly BSD source repository


More information about the Commits mailing list