Author: jimharris
Date: Wed Dec 12 00:39:04 2012
New Revision: 244128
URL: http://svnweb.freebsd.org/changeset/base/244128

Log:
  MFC r243904:
  
  Don't call bus_dmamap_load in CAM_DIR_NONE case, since there is nothing
  to map, and technically this isn't allowed.
  
  Functionally, it works OK (at least on x86) to call bus_dmamap_load with
  a NULL data pointer and zero length, so this is primarily for correctness
  and consistency with other drivers.
  
  While here, remove check in isci_io_request_construct for nseg==0.
  Previously, bus_dmamap_load would pass nseg==1, even for case where
  buffer is NULL and length = 0, which allowed CAM_DIR_NONE CCBs
  to get processed.  This check is not correct though, and needed to be
  removed both for the changes elsewhere in this patch, as well as jeff's
  preliminary bus_dmamap_load_ccb patch (which uncovered all of this in
  the first place).

Modified:
  stable/9/sys/dev/isci/isci_io_request.c
Directory Properties:
  stable/9/sys/   (props changed)
  stable/9/sys/dev/   (props changed)

Modified: stable/9/sys/dev/isci/isci_io_request.c
==============================================================================
--- stable/9/sys/dev/isci/isci_io_request.c     Tue Dec 11 23:59:14 2012        
(r244127)
+++ stable/9/sys/dev/isci/isci_io_request.c     Wed Dec 12 00:39:04 2012        
(r244128)
@@ -670,8 +670,7 @@ isci_io_request_construct(void *arg, bus
        io_request->sge = seg;
        ccb = io_request->ccb;
 
-       /* XXX More cleanup is needed here */
-       if ((nseg == 0) || (error != 0)) {
+       if (error != 0) {
                ccb->ccb_h.status = CAM_REQ_INVALID;
                xpt_done(ccb);
                return;
@@ -757,18 +756,21 @@ isci_io_request_execute_scsi_io(union cc
                panic("Unexpected CAM_DATA_PHYS flag!  flags = 0x%x\n",
                    ccb->ccb_h.flags);
 
-       error = bus_dmamap_load(io_request->parent.dma_tag,
-           io_request->parent.dma_map, csio->data_ptr, csio->dxfer_len,
-           isci_io_request_construct, io_request, 0x0);
-
-       /* A resource shortage from BUSDMA will be automatically
-        * continued at a later point, pushing the CCB processing
-        * forward, which will in turn unfreeze the simq.
-        */
-       if (error == EINPROGRESS) {
-               xpt_freeze_simq(controller->sim, 1);
-               ccb->ccb_h.flags |= CAM_RELEASE_SIMQ;
-       }
+       if ((ccb->ccb_h.flags & CAM_DIR_MASK) != CAM_DIR_NONE) {
+               error = bus_dmamap_load(io_request->parent.dma_tag,
+                   io_request->parent.dma_map, csio->data_ptr, csio->dxfer_len,
+                   isci_io_request_construct, io_request, 0x0);
+
+               /* A resource shortage from BUSDMA will be automatically
+                * continued at a later point, pushing the CCB processing
+                * forward, which will in turn unfreeze the simq.
+                */
+               if (error == EINPROGRESS) {
+                       xpt_freeze_simq(controller->sim, 1);
+                       ccb->ccb_h.flags |= CAM_RELEASE_SIMQ;
+               }
+       } else
+               isci_io_request_construct(io_request, NULL, 0, 0);
 }
 
 void
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to