svn commit: r245343 - projects/altix2/sys/dev/isp

Marcel Moolenaar marcel at FreeBSD.org
Sat Jan 12 22:00:36 UTC 2013


Author: marcel
Date: Sat Jan 12 22:00:35 2013
New Revision: 245343
URL: http://svnweb.freebsd.org/changeset/base/245343

Log:
  Slightly optimize the request and response queue synchronization. We
  have a single map that's used for both and we only need to synchronize
  1 request and 1 rsponse. Avoid using busdma_sync with post R/W that
  may force a platform to synchronize 80KB worth of cache and instead use
  busdma_sync_range twice: once for the request with post write (64B) and
  once for the response with post read (64B).

Modified:
  projects/altix2/sys/dev/isp/isp_freebsd.h

Modified: projects/altix2/sys/dev/isp/isp_freebsd.h
==============================================================================
--- projects/altix2/sys/dev/isp/isp_freebsd.h	Sat Jan 12 21:52:04 2013	(r245342)
+++ projects/altix2/sys/dev/isp/isp_freebsd.h	Sat Jan 12 22:00:35 2013	(r245343)
@@ -431,8 +431,10 @@ case SYNC_SFORDEV:						\
 	break;							\
 }								\
 case SYNC_REQUEST:						\
-	busdma_sync(isp->isp_osinfo.cdmd,			\
-	   BUSDMA_SYNC_PREREAD | BUSDMA_SYNC_PREWRITE);		\
+	busdma_sync_range(isp->isp_osinfo.cdmd, BUSDMA_SYNC_PREWRITE,	\
+	    isp->isp_rquest_dma + (offset * size), size);	\
+	busdma_sync_range(isp->isp_osinfo.cdmd, BUSDMA_SYNC_PREREAD,	\
+	    isp->isp_result_dma + (offset * size), size);	\
 	break;							\
 case SYNC_SFORCPU:						\
 {								\
@@ -441,8 +443,10 @@ case SYNC_SFORCPU:						\
 	break;							\
 }								\
 case SYNC_RESULT:						\
-	busdma_sync(isp->isp_osinfo.cdmd,			\
-	   BUSDMA_SYNC_POSTREAD | BUSDMA_SYNC_POSTWRITE);	\
+	busdma_sync_range(isp->isp_osinfo.cdmd, BUSDMA_SYNC_POSTWRITE,	\
+	    isp->isp_rquest_dma + (offset * size), size);	\
+	busdma_sync_range(isp->isp_osinfo.cdmd, BUSDMA_SYNC_POSTREAD,	\
+	    isp->isp_result_dma + (offset * size), size);	\
 	break;							\
 case SYNC_REG:							\
 	bus_space_barrier(isp->isp_osinfo.bus_tag,		\


More information about the svn-src-projects mailing list