Author: mav
Date: Mon Oct  5 09:06:18 2015
New Revision: 288742
URL: https://svnweb.freebsd.org/changeset/base/288742

Log:
  MFC r287720: Fix false CTL_UA_RES_RELEASE on secondary HA node.

Modified:
  stable/10/sys/cam/ctl/ctl.c
Directory Properties:
  stable/10/   (props changed)

Modified: stable/10/sys/cam/ctl/ctl.c
==============================================================================
--- stable/10/sys/cam/ctl/ctl.c Mon Oct  5 09:05:23 2015        (r288741)
+++ stable/10/sys/cam/ctl/ctl.c Mon Oct  5 09:06:18 2015        (r288742)
@@ -8406,7 +8406,7 @@ ctl_hndl_per_res_out_on_other_sc(union c
        struct ctl_lun *lun;
        struct ctl_softc *softc;
        int i;
-       uint32_t targ_lun;
+       uint32_t residx, targ_lun;
 
        softc = control_softc;
        targ_lun = msg->hdr.nexus.targ_mapped_lun;
@@ -8422,6 +8422,7 @@ ctl_hndl_per_res_out_on_other_sc(union c
                mtx_unlock(&lun->lun_lock);
                return;
        }
+       residx = ctl_get_initindex(&msg->hdr.nexus);
        switch(msg->pr.pr_info.action) {
        case CTL_PR_REG_KEY:
                ctl_alloc_prkey(lun, msg->pr.pr_info.residx);
@@ -8486,8 +8487,9 @@ ctl_hndl_per_res_out_on_other_sc(union c
                if (lun->res_type != SPR_TYPE_EX_AC
                 && lun->res_type != SPR_TYPE_WR_EX) {
                        for (i = softc->init_min; i < softc->init_max; i++)
-                               if (ctl_get_prkey(lun, i) != 0)
-                                       ctl_est_ua(lun, i, CTL_UA_RES_RELEASE);
+                               if (i == residx || ctl_get_prkey(lun, i) == 0)
+                                       continue;
+                               ctl_est_ua(lun, i, CTL_UA_RES_RELEASE);
                }
 
                lun->flags &= ~CTL_LUN_PR_RESERVED;
_______________________________________________
svn-src-stable-10@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-stable-10
To unsubscribe, send any mail to "svn-src-stable-10-unsubscr...@freebsd.org"

Reply via email to