提交 bffb5128 编写于 作者: N Nicholas Bellinger

target: Ensure sess_prot_type is saved across session restart

The following incremental patch saves the current sess_prot_type into
se_node_acl, and will always reset sess_prot_type if a previous saved
value exists.  So the PI setting for the fabric's session with backend
devices not supporting PI is persistent across session restart.

(Fix se_node_acl dereference for discovery sessions - DanCarpenter)
Reviewed-by: NMartin Petersen <martin.petersen@oracle.com>
Reviewed-by: NSagi Grimberg <sagig@mellanox.com>
Signed-off-by: NNicholas Bellinger <nab@linux-iscsi.org>
上级 bfd9a53e
...@@ -327,13 +327,6 @@ void __transport_register_session( ...@@ -327,13 +327,6 @@ void __transport_register_session(
se_sess->se_tpg = se_tpg; se_sess->se_tpg = se_tpg;
se_sess->fabric_sess_ptr = fabric_sess_ptr; se_sess->fabric_sess_ptr = fabric_sess_ptr;
/*
* Determine if fabric allows for T10-PI feature bits to be exposed
* to initiators for device backends with !dev->dev_attrib.pi_prot_type
*/
if (tfo->tpg_check_prot_fabric_only)
se_sess->sess_prot_type = tfo->tpg_check_prot_fabric_only(se_tpg);
/* /*
* Used by struct se_node_acl's under ConfigFS to locate active se_session-t * Used by struct se_node_acl's under ConfigFS to locate active se_session-t
* *
...@@ -341,6 +334,21 @@ void __transport_register_session( ...@@ -341,6 +334,21 @@ void __transport_register_session(
* eg: *NOT* discovery sessions. * eg: *NOT* discovery sessions.
*/ */
if (se_nacl) { if (se_nacl) {
/*
*
* Determine if fabric allows for T10-PI feature bits exposed to
* initiators for device backends with !dev->dev_attrib.pi_prot_type.
*
* If so, then always save prot_type on a per se_node_acl node
* basis and re-instate the previous sess_prot_type to avoid
* disabling PI from below any previously initiator side
* registered LUNs.
*/
if (se_nacl->saved_prot_type)
se_sess->sess_prot_type = se_nacl->saved_prot_type;
else if (tfo->tpg_check_prot_fabric_only)
se_sess->sess_prot_type = se_nacl->saved_prot_type =
tfo->tpg_check_prot_fabric_only(se_tpg);
/* /*
* If the fabric module supports an ISID based TransportID, * If the fabric module supports an ISID based TransportID,
* save this value in binary from the fabric I_T Nexus now. * save this value in binary from the fabric I_T Nexus now.
......
...@@ -589,6 +589,7 @@ struct se_node_acl { ...@@ -589,6 +589,7 @@ struct se_node_acl {
bool acl_stop:1; bool acl_stop:1;
u32 queue_depth; u32 queue_depth;
u32 acl_index; u32 acl_index;
enum target_prot_type saved_prot_type;
#define MAX_ACL_TAG_SIZE 64 #define MAX_ACL_TAG_SIZE 64
char acl_tag[MAX_ACL_TAG_SIZE]; char acl_tag[MAX_ACL_TAG_SIZE];
/* Used for PR SPEC_I_PT=1 and REGISTER_AND_MOVE */ /* Used for PR SPEC_I_PT=1 and REGISTER_AND_MOVE */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册