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: Christoph Hellwig <hch@lst.de> Reviewed-by: Hannes Reinecke <hare@suse.de> Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
This commit is contained in:
parent
79dc9c9e86
commit
9fcb57f39c
1 changed files with 18 additions and 26 deletions
|
@ -312,34 +312,31 @@ out:
|
||||||
* 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;
|
|
||||||
|
if (isid_mismatch) {
|
||||||
|
registered_nexus = 0;
|
||||||
|
} else {
|
||||||
|
struct se_dev_entry *se_deve;
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
se_deve = target_nacl_find_deve(nacl, cmd->orig_fe_lun);
|
se_deve = target_nacl_find_deve(nacl, cmd->orig_fe_lun);
|
||||||
if (se_deve)
|
if (se_deve)
|
||||||
registered = test_bit(DEF_PR_REG_ACTIVE, &se_deve->deve_flags);
|
registered_nexus = test_bit(DEF_PR_REG_ACTIVE,
|
||||||
|
&se_deve->deve_flags);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
/*
|
}
|
||||||
* Determine if the registration should be ignored due to
|
|
||||||
* non-matching ISIDs in target_scsi3_pr_reservation_check().
|
|
||||||
*/
|
|
||||||
ignore_reg = (pr_reg_type & 0x80000000);
|
|
||||||
if (ignore_reg)
|
|
||||||
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(
|
||||||
* 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(
|
||||||
* 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(
|
||||||
* 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)
|
||||||
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)
|
||||||
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)
|
||||||
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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue