Lines Matching refs:tpg
43 struct se_portal_group *tpg, in __core_tpg_get_initiator_node_acl() argument
48 list_for_each_entry(acl, &tpg->acl_node_list, acl_list) { in __core_tpg_get_initiator_node_acl()
61 struct se_portal_group *tpg, in core_tpg_get_initiator_node_acl() argument
74 mutex_lock(&tpg->acl_node_mutex); in core_tpg_get_initiator_node_acl()
75 acl = __core_tpg_get_initiator_node_acl(tpg, initiatorname); in core_tpg_get_initiator_node_acl()
80 mutex_unlock(&tpg->acl_node_mutex); in core_tpg_get_initiator_node_acl()
108 struct se_portal_group *tpg, in core_tpg_add_node_to_devs() argument
115 mutex_lock(&tpg->tpg_lun_mutex); in core_tpg_add_node_to_devs()
116 hlist_for_each_entry_rcu(lun, &tpg->tpg_lun_hlist, link) { in core_tpg_add_node_to_devs()
121 lockdep_is_held(&tpg->tpg_lun_mutex)); in core_tpg_add_node_to_devs()
126 if (!tpg->se_tpg_tfo->tpg_check_demo_mode_write_protect(tpg)) { in core_tpg_add_node_to_devs()
141 tpg->se_tpg_tfo->fabric_name, in core_tpg_add_node_to_devs()
142 tpg->se_tpg_tfo->tpg_get_tag(tpg), lun->unpacked_lun, in core_tpg_add_node_to_devs()
146 lun_access_ro, acl, tpg); in core_tpg_add_node_to_devs()
152 core_scsi3_check_aptpl_registration(dev, tpg, lun, acl, in core_tpg_add_node_to_devs()
155 mutex_unlock(&tpg->tpg_lun_mutex); in core_tpg_add_node_to_devs()
159 target_set_nacl_queue_depth(struct se_portal_group *tpg, in target_set_nacl_queue_depth() argument
166 "defaulting to 1.\n", tpg->se_tpg_tfo->fabric_name, in target_set_nacl_queue_depth()
172 static struct se_node_acl *target_alloc_node_acl(struct se_portal_group *tpg, in target_alloc_node_acl() argument
178 acl = kzalloc(max(sizeof(*acl), tpg->se_tpg_tfo->node_acl_size), in target_alloc_node_acl()
192 if (tpg->se_tpg_tfo->tpg_get_default_depth) in target_alloc_node_acl()
193 queue_depth = tpg->se_tpg_tfo->tpg_get_default_depth(tpg); in target_alloc_node_acl()
196 target_set_nacl_queue_depth(tpg, acl, queue_depth); in target_alloc_node_acl()
199 acl->se_tpg = tpg; in target_alloc_node_acl()
202 tpg->se_tpg_tfo->set_default_node_attributes(acl); in target_alloc_node_acl()
209 struct se_portal_group *tpg = acl->se_tpg; in target_add_node_acl() local
211 mutex_lock(&tpg->acl_node_mutex); in target_add_node_acl()
212 list_add_tail(&acl->acl_list, &tpg->acl_node_list); in target_add_node_acl()
213 mutex_unlock(&tpg->acl_node_mutex); in target_add_node_acl()
217 tpg->se_tpg_tfo->fabric_name, in target_add_node_acl()
218 tpg->se_tpg_tfo->tpg_get_tag(tpg), in target_add_node_acl()
221 tpg->se_tpg_tfo->fabric_name, in target_add_node_acl()
225 bool target_tpg_has_node_acl(struct se_portal_group *tpg, in target_tpg_has_node_acl() argument
231 mutex_lock(&tpg->acl_node_mutex); in target_tpg_has_node_acl()
232 list_for_each_entry(acl, &tpg->acl_node_list, acl_list) { in target_tpg_has_node_acl()
238 mutex_unlock(&tpg->acl_node_mutex); in target_tpg_has_node_acl()
245 struct se_portal_group *tpg, in core_tpg_check_initiator_node_acl() argument
250 acl = core_tpg_get_initiator_node_acl(tpg, initiatorname); in core_tpg_check_initiator_node_acl()
254 if (!tpg->se_tpg_tfo->tpg_check_demo_mode(tpg)) in core_tpg_check_initiator_node_acl()
257 acl = target_alloc_node_acl(tpg, initiatorname); in core_tpg_check_initiator_node_acl()
276 if ((tpg->se_tpg_tfo->tpg_check_demo_mode_login_only == NULL) || in core_tpg_check_initiator_node_acl()
277 (tpg->se_tpg_tfo->tpg_check_demo_mode_login_only(tpg) != 1)) in core_tpg_check_initiator_node_acl()
278 core_tpg_add_node_to_devs(acl, tpg, NULL); in core_tpg_check_initiator_node_acl()
292 struct se_portal_group *tpg, in core_tpg_add_initiator_node_acl() argument
297 mutex_lock(&tpg->acl_node_mutex); in core_tpg_add_initiator_node_acl()
298 acl = __core_tpg_get_initiator_node_acl(tpg, initiatorname); in core_tpg_add_initiator_node_acl()
303 " for %s\n", tpg->se_tpg_tfo->fabric_name, in core_tpg_add_initiator_node_acl()
304 tpg->se_tpg_tfo->tpg_get_tag(tpg), initiatorname); in core_tpg_add_initiator_node_acl()
305 mutex_unlock(&tpg->acl_node_mutex); in core_tpg_add_initiator_node_acl()
311 " request.\n", tpg->se_tpg_tfo->fabric_name, in core_tpg_add_initiator_node_acl()
312 initiatorname, tpg->se_tpg_tfo->tpg_get_tag(tpg)); in core_tpg_add_initiator_node_acl()
313 mutex_unlock(&tpg->acl_node_mutex); in core_tpg_add_initiator_node_acl()
316 mutex_unlock(&tpg->acl_node_mutex); in core_tpg_add_initiator_node_acl()
318 acl = target_alloc_node_acl(tpg, initiatorname); in core_tpg_add_initiator_node_acl()
349 struct se_portal_group *tpg = acl->se_tpg; in core_tpg_del_initiator_node_acl() local
351 mutex_lock(&tpg->acl_node_mutex); in core_tpg_del_initiator_node_acl()
355 mutex_unlock(&tpg->acl_node_mutex); in core_tpg_del_initiator_node_acl()
367 core_free_device_list_for_node(acl, tpg); in core_tpg_del_initiator_node_acl()
370 " Initiator Node: %s\n", tpg->se_tpg_tfo->fabric_name, in core_tpg_del_initiator_node_acl()
371 tpg->se_tpg_tfo->tpg_get_tag(tpg), acl->queue_depth, in core_tpg_del_initiator_node_acl()
372 tpg->se_tpg_tfo->fabric_name, acl->initiatorname); in core_tpg_del_initiator_node_acl()
385 struct se_portal_group *tpg = acl->se_tpg; in core_tpg_set_initiator_node_queue_depth() local
399 target_set_nacl_queue_depth(tpg, acl, queue_depth); in core_tpg_set_initiator_node_queue_depth()
408 acl->initiatorname, tpg->se_tpg_tfo->fabric_name, in core_tpg_set_initiator_node_queue_depth()
409 tpg->se_tpg_tfo->tpg_get_tag(tpg)); in core_tpg_set_initiator_node_queue_depth()
422 struct se_portal_group *tpg, in core_tpg_set_initiator_node_tag() argument
555 struct se_portal_group *tpg, in core_tpg_alloc_lun() argument
575 lun->lun_tpg = tpg; in core_tpg_alloc_lun()
581 struct se_portal_group *tpg, in core_tpg_add_lun() argument
602 mutex_lock(&tpg->tpg_lun_mutex); in core_tpg_add_lun()
616 hlist_add_head_rcu(&lun->link, &tpg->tpg_lun_hlist); in core_tpg_add_lun()
617 mutex_unlock(&tpg->tpg_lun_mutex); in core_tpg_add_lun()
628 struct se_portal_group *tpg, in core_tpg_remove_lun() argument
639 core_clear_lun_from_tpg(lun, tpg); in core_tpg_remove_lun()
648 mutex_lock(&tpg->tpg_lun_mutex); in core_tpg_remove_lun()
662 mutex_unlock(&tpg->tpg_lun_mutex); in core_tpg_remove_lun()