Commit 9fcb57f3 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Nicholas Bellinger

target/pr: cleanup core_scsi3_pr_seq_non_holder

Clean up the mess of registered variables, and pass the isid mismatch
flag explicitly instead of overloading the registration type.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
Signed-off-by: default avatarNicholas Bellinger <nab@linux-iscsi.org>
parent 79dc9c9e
...@@ -312,34 +312,31 @@ target_scsi2_reservation_reserve(struct se_cmd *cmd) ...@@ -312,34 +312,31 @@ target_scsi2_reservation_reserve(struct se_cmd *cmd)
* This function is called by those initiator ports who are *NOT* * This function is called by those initiator ports who are *NOT*
* the active PR reservation holder when a reservation is present. * the active PR reservation holder when a reservation is present.
*/ */
static int core_scsi3_pr_seq_non_holder( static int core_scsi3_pr_seq_non_holder(struct se_cmd *cmd, u32 pr_reg_type,
struct se_cmd *cmd, bool isid_mismatch)
u32 pr_reg_type)
{ {
unsigned char *cdb = cmd->t_task_cdb; unsigned char *cdb = cmd->t_task_cdb;
struct se_dev_entry *se_deve;
struct se_session *se_sess = cmd->se_sess; struct se_session *se_sess = cmd->se_sess;
struct se_node_acl *nacl = se_sess->se_node_acl; struct se_node_acl *nacl = se_sess->se_node_acl;
int other_cdb = 0, ignore_reg; int other_cdb = 0;
int registered_nexus = 0, ret = 1; /* Conflict by default */ int registered_nexus = 0, ret = 1; /* Conflict by default */
int all_reg = 0, reg_only = 0; /* ALL_REG, REG_ONLY */ int all_reg = 0, reg_only = 0; /* ALL_REG, REG_ONLY */
int we = 0; /* Write Exclusive */ int we = 0; /* Write Exclusive */
int legacy = 0; /* Act like a legacy device and return int legacy = 0; /* Act like a legacy device and return
* RESERVATION CONFLICT on some CDBs */ * RESERVATION CONFLICT on some CDBs */
bool registered = false;
rcu_read_lock(); if (isid_mismatch) {
se_deve = target_nacl_find_deve(nacl, cmd->orig_fe_lun); registered_nexus = 0;
if (se_deve) } else {
registered = test_bit(DEF_PR_REG_ACTIVE, &se_deve->deve_flags); struct se_dev_entry *se_deve;
rcu_read_unlock();
/* rcu_read_lock();
* Determine if the registration should be ignored due to se_deve = target_nacl_find_deve(nacl, cmd->orig_fe_lun);
* non-matching ISIDs in target_scsi3_pr_reservation_check(). if (se_deve)
*/ registered_nexus = test_bit(DEF_PR_REG_ACTIVE,
ignore_reg = (pr_reg_type & 0x80000000); &se_deve->deve_flags);
if (ignore_reg) rcu_read_unlock();
pr_reg_type &= ~0x80000000; }
switch (pr_reg_type) { switch (pr_reg_type) {
case PR_TYPE_WRITE_EXCLUSIVE: case PR_TYPE_WRITE_EXCLUSIVE:
...@@ -349,8 +346,6 @@ static int core_scsi3_pr_seq_non_holder( ...@@ -349,8 +346,6 @@ static int core_scsi3_pr_seq_non_holder(
* Some commands are only allowed for the persistent reservation * Some commands are only allowed for the persistent reservation
* holder. * holder.
*/ */
if ((registered) && !(ignore_reg))
registered_nexus = 1;
break; break;
case PR_TYPE_WRITE_EXCLUSIVE_REGONLY: case PR_TYPE_WRITE_EXCLUSIVE_REGONLY:
we = 1; we = 1;
...@@ -359,8 +354,6 @@ static int core_scsi3_pr_seq_non_holder( ...@@ -359,8 +354,6 @@ static int core_scsi3_pr_seq_non_holder(
* Some commands are only allowed for registered I_T Nexuses. * Some commands are only allowed for registered I_T Nexuses.
*/ */
reg_only = 1; reg_only = 1;
if ((registered) && !(ignore_reg))
registered_nexus = 1;
break; break;
case PR_TYPE_WRITE_EXCLUSIVE_ALLREG: case PR_TYPE_WRITE_EXCLUSIVE_ALLREG:
we = 1; we = 1;
...@@ -369,8 +362,6 @@ static int core_scsi3_pr_seq_non_holder( ...@@ -369,8 +362,6 @@ static int core_scsi3_pr_seq_non_holder(
* Each registered I_T Nexus is a reservation holder. * Each registered I_T Nexus is a reservation holder.
*/ */
all_reg = 1; all_reg = 1;
if ((registered) && !(ignore_reg))
registered_nexus = 1;
break; break;
default: default:
return -EINVAL; return -EINVAL;
...@@ -576,6 +567,7 @@ target_scsi3_pr_reservation_check(struct se_cmd *cmd) ...@@ -576,6 +567,7 @@ target_scsi3_pr_reservation_check(struct se_cmd *cmd)
struct se_device *dev = cmd->se_dev; struct se_device *dev = cmd->se_dev;
struct se_session *sess = cmd->se_sess; struct se_session *sess = cmd->se_sess;
u32 pr_reg_type; u32 pr_reg_type;
bool isid_mismatch = false;
if (!dev->dev_pr_res_holder) if (!dev->dev_pr_res_holder)
return 0; return 0;
...@@ -588,7 +580,7 @@ target_scsi3_pr_reservation_check(struct se_cmd *cmd) ...@@ -588,7 +580,7 @@ target_scsi3_pr_reservation_check(struct se_cmd *cmd)
if (dev->dev_pr_res_holder->isid_present_at_reg) { if (dev->dev_pr_res_holder->isid_present_at_reg) {
if (dev->dev_pr_res_holder->pr_reg_bin_isid != if (dev->dev_pr_res_holder->pr_reg_bin_isid !=
sess->sess_bin_isid) { sess->sess_bin_isid) {
pr_reg_type |= 0x80000000; isid_mismatch = true;
goto check_nonholder; goto check_nonholder;
} }
} }
...@@ -596,7 +588,7 @@ target_scsi3_pr_reservation_check(struct se_cmd *cmd) ...@@ -596,7 +588,7 @@ target_scsi3_pr_reservation_check(struct se_cmd *cmd)
return 0; return 0;
check_nonholder: check_nonholder:
if (core_scsi3_pr_seq_non_holder(cmd, pr_reg_type)) if (core_scsi3_pr_seq_non_holder(cmd, pr_reg_type, isid_mismatch))
return TCM_RESERVATION_CONFLICT; return TCM_RESERVATION_CONFLICT;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment