iscsi_target_nodeattrib.c 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*******************************************************************************
  3. * This file contains the main functions related to Initiator Node Attributes.
  4. *
  5. * (c) Copyright 2007-2013 Datera, Inc.
  6. *
  7. * Author: Nicholas A. Bellinger <[email protected]>
  8. *
  9. ******************************************************************************/
  10. #include <target/target_core_base.h>
  11. #include <target/iscsi/iscsi_target_core.h>
  12. #include "iscsi_target_device.h"
  13. #include "iscsi_target_tpg.h"
  14. #include "iscsi_target_util.h"
  15. #include "iscsi_target_nodeattrib.h"
  16. static inline char *iscsit_na_get_initiatorname(
  17. struct iscsi_node_acl *nacl)
  18. {
  19. struct se_node_acl *se_nacl = &nacl->se_node_acl;
  20. return &se_nacl->initiatorname[0];
  21. }
  22. void iscsit_set_default_node_attribues(
  23. struct iscsi_node_acl *acl,
  24. struct iscsi_portal_group *tpg)
  25. {
  26. struct iscsi_node_attrib *a = &acl->node_attrib;
  27. a->authentication = NA_AUTHENTICATION_INHERITED;
  28. a->dataout_timeout = NA_DATAOUT_TIMEOUT;
  29. a->dataout_timeout_retries = NA_DATAOUT_TIMEOUT_RETRIES;
  30. a->nopin_timeout = NA_NOPIN_TIMEOUT;
  31. a->nopin_response_timeout = NA_NOPIN_RESPONSE_TIMEOUT;
  32. a->random_datain_pdu_offsets = NA_RANDOM_DATAIN_PDU_OFFSETS;
  33. a->random_datain_seq_offsets = NA_RANDOM_DATAIN_SEQ_OFFSETS;
  34. a->random_r2t_offsets = NA_RANDOM_R2T_OFFSETS;
  35. a->default_erl = tpg->tpg_attrib.default_erl;
  36. }
  37. int iscsit_na_dataout_timeout(
  38. struct iscsi_node_acl *acl,
  39. u32 dataout_timeout)
  40. {
  41. struct iscsi_node_attrib *a = &acl->node_attrib;
  42. if (dataout_timeout > NA_DATAOUT_TIMEOUT_MAX) {
  43. pr_err("Requested DataOut Timeout %u larger than"
  44. " maximum %u\n", dataout_timeout,
  45. NA_DATAOUT_TIMEOUT_MAX);
  46. return -EINVAL;
  47. } else if (dataout_timeout < NA_DATAOUT_TIMEOUT_MIX) {
  48. pr_err("Requested DataOut Timeout %u smaller than"
  49. " minimum %u\n", dataout_timeout,
  50. NA_DATAOUT_TIMEOUT_MIX);
  51. return -EINVAL;
  52. }
  53. a->dataout_timeout = dataout_timeout;
  54. pr_debug("Set DataOut Timeout to %u for Initiator Node"
  55. " %s\n", a->dataout_timeout, iscsit_na_get_initiatorname(acl));
  56. return 0;
  57. }
  58. int iscsit_na_dataout_timeout_retries(
  59. struct iscsi_node_acl *acl,
  60. u32 dataout_timeout_retries)
  61. {
  62. struct iscsi_node_attrib *a = &acl->node_attrib;
  63. if (dataout_timeout_retries > NA_DATAOUT_TIMEOUT_RETRIES_MAX) {
  64. pr_err("Requested DataOut Timeout Retries %u larger"
  65. " than maximum %u", dataout_timeout_retries,
  66. NA_DATAOUT_TIMEOUT_RETRIES_MAX);
  67. return -EINVAL;
  68. } else if (dataout_timeout_retries < NA_DATAOUT_TIMEOUT_RETRIES_MIN) {
  69. pr_err("Requested DataOut Timeout Retries %u smaller"
  70. " than minimum %u", dataout_timeout_retries,
  71. NA_DATAOUT_TIMEOUT_RETRIES_MIN);
  72. return -EINVAL;
  73. }
  74. a->dataout_timeout_retries = dataout_timeout_retries;
  75. pr_debug("Set DataOut Timeout Retries to %u for"
  76. " Initiator Node %s\n", a->dataout_timeout_retries,
  77. iscsit_na_get_initiatorname(acl));
  78. return 0;
  79. }
  80. int iscsit_na_nopin_timeout(
  81. struct iscsi_node_acl *acl,
  82. u32 nopin_timeout)
  83. {
  84. struct iscsi_node_attrib *a = &acl->node_attrib;
  85. struct iscsit_session *sess;
  86. struct iscsit_conn *conn;
  87. struct se_node_acl *se_nacl = &a->nacl->se_node_acl;
  88. struct se_session *se_sess;
  89. u32 orig_nopin_timeout = a->nopin_timeout;
  90. if (nopin_timeout > NA_NOPIN_TIMEOUT_MAX) {
  91. pr_err("Requested NopIn Timeout %u larger than maximum"
  92. " %u\n", nopin_timeout, NA_NOPIN_TIMEOUT_MAX);
  93. return -EINVAL;
  94. } else if ((nopin_timeout < NA_NOPIN_TIMEOUT_MIN) &&
  95. (nopin_timeout != 0)) {
  96. pr_err("Requested NopIn Timeout %u smaller than"
  97. " minimum %u and not 0\n", nopin_timeout,
  98. NA_NOPIN_TIMEOUT_MIN);
  99. return -EINVAL;
  100. }
  101. a->nopin_timeout = nopin_timeout;
  102. pr_debug("Set NopIn Timeout to %u for Initiator"
  103. " Node %s\n", a->nopin_timeout,
  104. iscsit_na_get_initiatorname(acl));
  105. /*
  106. * Reenable disabled nopin_timeout timer for all iSCSI connections.
  107. */
  108. if (!orig_nopin_timeout) {
  109. spin_lock_bh(&se_nacl->nacl_sess_lock);
  110. se_sess = se_nacl->nacl_sess;
  111. if (se_sess) {
  112. sess = se_sess->fabric_sess_ptr;
  113. spin_lock(&sess->conn_lock);
  114. list_for_each_entry(conn, &sess->sess_conn_list,
  115. conn_list) {
  116. if (conn->conn_state !=
  117. TARG_CONN_STATE_LOGGED_IN)
  118. continue;
  119. spin_lock(&conn->nopin_timer_lock);
  120. __iscsit_start_nopin_timer(conn);
  121. spin_unlock(&conn->nopin_timer_lock);
  122. }
  123. spin_unlock(&sess->conn_lock);
  124. }
  125. spin_unlock_bh(&se_nacl->nacl_sess_lock);
  126. }
  127. return 0;
  128. }
  129. int iscsit_na_nopin_response_timeout(
  130. struct iscsi_node_acl *acl,
  131. u32 nopin_response_timeout)
  132. {
  133. struct iscsi_node_attrib *a = &acl->node_attrib;
  134. if (nopin_response_timeout > NA_NOPIN_RESPONSE_TIMEOUT_MAX) {
  135. pr_err("Requested NopIn Response Timeout %u larger"
  136. " than maximum %u\n", nopin_response_timeout,
  137. NA_NOPIN_RESPONSE_TIMEOUT_MAX);
  138. return -EINVAL;
  139. } else if (nopin_response_timeout < NA_NOPIN_RESPONSE_TIMEOUT_MIN) {
  140. pr_err("Requested NopIn Response Timeout %u smaller"
  141. " than minimum %u\n", nopin_response_timeout,
  142. NA_NOPIN_RESPONSE_TIMEOUT_MIN);
  143. return -EINVAL;
  144. }
  145. a->nopin_response_timeout = nopin_response_timeout;
  146. pr_debug("Set NopIn Response Timeout to %u for"
  147. " Initiator Node %s\n", a->nopin_timeout,
  148. iscsit_na_get_initiatorname(acl));
  149. return 0;
  150. }
  151. int iscsit_na_random_datain_pdu_offsets(
  152. struct iscsi_node_acl *acl,
  153. u32 random_datain_pdu_offsets)
  154. {
  155. struct iscsi_node_attrib *a = &acl->node_attrib;
  156. if (random_datain_pdu_offsets != 0 && random_datain_pdu_offsets != 1) {
  157. pr_err("Requested Random DataIN PDU Offsets: %u not"
  158. " 0 or 1\n", random_datain_pdu_offsets);
  159. return -EINVAL;
  160. }
  161. a->random_datain_pdu_offsets = random_datain_pdu_offsets;
  162. pr_debug("Set Random DataIN PDU Offsets to %u for"
  163. " Initiator Node %s\n", a->random_datain_pdu_offsets,
  164. iscsit_na_get_initiatorname(acl));
  165. return 0;
  166. }
  167. int iscsit_na_random_datain_seq_offsets(
  168. struct iscsi_node_acl *acl,
  169. u32 random_datain_seq_offsets)
  170. {
  171. struct iscsi_node_attrib *a = &acl->node_attrib;
  172. if (random_datain_seq_offsets != 0 && random_datain_seq_offsets != 1) {
  173. pr_err("Requested Random DataIN Sequence Offsets: %u"
  174. " not 0 or 1\n", random_datain_seq_offsets);
  175. return -EINVAL;
  176. }
  177. a->random_datain_seq_offsets = random_datain_seq_offsets;
  178. pr_debug("Set Random DataIN Sequence Offsets to %u for"
  179. " Initiator Node %s\n", a->random_datain_seq_offsets,
  180. iscsit_na_get_initiatorname(acl));
  181. return 0;
  182. }
  183. int iscsit_na_random_r2t_offsets(
  184. struct iscsi_node_acl *acl,
  185. u32 random_r2t_offsets)
  186. {
  187. struct iscsi_node_attrib *a = &acl->node_attrib;
  188. if (random_r2t_offsets != 0 && random_r2t_offsets != 1) {
  189. pr_err("Requested Random R2T Offsets: %u not"
  190. " 0 or 1\n", random_r2t_offsets);
  191. return -EINVAL;
  192. }
  193. a->random_r2t_offsets = random_r2t_offsets;
  194. pr_debug("Set Random R2T Offsets to %u for"
  195. " Initiator Node %s\n", a->random_r2t_offsets,
  196. iscsit_na_get_initiatorname(acl));
  197. return 0;
  198. }
  199. int iscsit_na_default_erl(
  200. struct iscsi_node_acl *acl,
  201. u32 default_erl)
  202. {
  203. struct iscsi_node_attrib *a = &acl->node_attrib;
  204. if (default_erl != 0 && default_erl != 1 && default_erl != 2) {
  205. pr_err("Requested default ERL: %u not 0, 1, or 2\n",
  206. default_erl);
  207. return -EINVAL;
  208. }
  209. a->default_erl = default_erl;
  210. pr_debug("Set use ERL0 flag to %u for Initiator"
  211. " Node %s\n", a->default_erl,
  212. iscsit_na_get_initiatorname(acl));
  213. return 0;
  214. }