Author: scottl
Date: Sun Jan 25 22:29:23 2015
New Revision: 277717
URL: https://svnweb.freebsd.org/changeset/base/277717

Log:
  Fix the ioctl interface to properly support fetching the header of regular
  and extended config pages.
  
  Obtained from:        Netflix, Inc.
  MFC after:    3 days

Modified:
  head/sys/dev/mps/mps.c
  head/sys/dev/mps/mps_user.c

Modified: head/sys/dev/mps/mps.c
==============================================================================
--- head/sys/dev/mps/mps.c      Sun Jan 25 22:08:36 2015        (r277716)
+++ head/sys/dev/mps/mps.c      Sun Jan 25 22:29:23 2015        (r277717)
@@ -2621,9 +2621,12 @@ mps_read_config_page(struct mps_softc *s
 
        cm->cm_data = params->buffer;
        cm->cm_length = params->length;
-       cm->cm_sge = &req->PageBufferSGE;
-       cm->cm_sglsize = sizeof(MPI2_SGE_IO_UNION);
-       cm->cm_flags = MPS_CM_FLAGS_SGE_SIMPLE | MPS_CM_FLAGS_DATAIN;
+       if (cm->cm_data != NULL) {
+               cm->cm_sge = &req->PageBufferSGE;
+               cm->cm_sglsize = sizeof(MPI2_SGE_IO_UNION);
+               cm->cm_flags = MPS_CM_FLAGS_SGE_SIMPLE | MPS_CM_FLAGS_DATAIN;
+       } else
+               cm->cm_sge = NULL;
        cm->cm_desc.Default.RequestFlags = MPI2_REQ_DESCRIPT_FLAGS_DEFAULT_TYPE;
 
        cm->cm_complete_data = params;
@@ -2680,9 +2683,12 @@ mps_config_complete(struct mps_softc *sc
                goto done;
        }
        params->status = reply->IOCStatus;
-       if (params->hdr.Ext.ExtPageType != 0) {
+       if (params->hdr.Struct.PageType == MPI2_CONFIG_PAGETYPE_EXTENDED) {
                params->hdr.Ext.ExtPageType = reply->ExtPageType;
                params->hdr.Ext.ExtPageLength = reply->ExtPageLength;
+               params->hdr.Ext.PageType = reply->Header.PageType;
+               params->hdr.Ext.PageNumber = reply->Header.PageNumber;
+               params->hdr.Ext.PageVersion = reply->Header.PageVersion;
        } else {
                params->hdr.Struct.PageType = reply->Header.PageType;
                params->hdr.Struct.PageNumber = reply->Header.PageNumber;

Modified: head/sys/dev/mps/mps_user.c
==============================================================================
--- head/sys/dev/mps/mps_user.c Sun Jan 25 22:08:36 2015        (r277716)
+++ head/sys/dev/mps/mps_user.c Sun Jan 25 22:29:23 2015        (r277717)
@@ -309,6 +309,10 @@ mps_user_read_extcfg_header(struct mps_s
        hdr->PageNumber = ext_page_req->header.PageNumber;
        hdr->ExtPageType = ext_page_req->header.ExtPageType;
        params.page_address = le32toh(ext_page_req->page_address);
+       params.buffer = NULL;
+       params.length = 0;
+       params.callback = NULL;
+
        if ((error = mps_read_config_page(sc, &params)) != 0) {
                /*
                 * Leave the request. Without resetting the chip, it's
_______________________________________________
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