target_core_alua.c 55.2 KB
Newer Older
1 2 3 4 5
/*******************************************************************************
 * Filename:  target_core_alua.c
 *
 * This file contains SPC-3 compliant asymmetric logical unit assigntment (ALUA)
 *
6
 * (c) Copyright 2009-2013 Datera, Inc.
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
 *
 * Nicholas A. Bellinger <nab@kernel.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 *
 ******************************************************************************/

#include <linux/slab.h>
#include <linux/spinlock.h>
#include <linux/configfs.h>
29
#include <linux/export.h>
30
#include <linux/file.h>
31 32
#include <scsi/scsi.h>
#include <scsi/scsi_cmnd.h>
33
#include <asm/unaligned.h>
34 35

#include <target/target_core_base.h>
36 37
#include <target/target_core_backend.h>
#include <target/target_core_fabric.h>
38 39
#include <target/target_core_configfs.h>

C
Christoph Hellwig 已提交
40
#include "target_core_internal.h"
41 42 43
#include "target_core_alua.h"
#include "target_core_ua.h"

44 45
static sense_reason_t core_alua_check_transition(int state, int valid,
						 int *primary);
46 47
static int core_alua_set_tg_pt_secondary_state(
		struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem,
48
		struct se_port *port, int explicit, int offline);
49

50 51
static char *core_alua_dump_state(int state);

52 53 54 55 56 57 58 59
static u16 alua_lu_gps_counter;
static u32 alua_lu_gps_count;

static DEFINE_SPINLOCK(lu_gps_lock);
static LIST_HEAD(lu_gps_list);

struct t10_alua_lu_gp *default_lu_gp;

60 61 62 63 64
/*
 * REPORT_TARGET_PORT_GROUPS
 *
 * See spc4r17 section 6.27
 */
65 66
sense_reason_t
target_emulate_report_target_port_groups(struct se_cmd *cmd)
67
{
68
	struct se_device *dev = cmd->se_dev;
69 70 71
	struct se_port *port;
	struct t10_alua_tg_pt_gp *tg_pt_gp;
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem;
72
	unsigned char *buf;
73 74
	u32 rd_len = 0, off;
	int ext_hdr = (cmd->t_task_cdb[1] & 0x20);
75

76
	/*
77 78
	 * Skip over RESERVED area to first Target port group descriptor
	 * depending on the PARAMETER DATA FORMAT type..
79
	 */
80 81 82 83 84 85 86 87 88
	if (ext_hdr != 0)
		off = 8;
	else
		off = 4;

	if (cmd->data_length < off) {
		pr_warn("REPORT TARGET PORT GROUPS allocation length %u too"
			" small for %s header\n", cmd->data_length,
			(ext_hdr) ? "extended" : "normal");
89
		return TCM_INVALID_CDB_FIELD;
90
	}
91
	buf = transport_kmap_data_sg(cmd);
92 93
	if (!buf)
		return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE;
94

95 96
	spin_lock(&dev->t10_alua.tg_pt_gps_lock);
	list_for_each_entry(tg_pt_gp, &dev->t10_alua.tg_pt_gps_list,
97
			tg_pt_gp_list) {
98 99 100 101 102 103 104 105 106 107 108
		/*
		 * Check if the Target port group and Target port descriptor list
		 * based on tg_pt_gp_members count will fit into the response payload.
		 * Otherwise, bump rd_len to let the initiator know we have exceeded
		 * the allocation length and the response is truncated.
		 */
		if ((off + 8 + (tg_pt_gp->tg_pt_gp_members * 4)) >
		     cmd->data_length) {
			rd_len += 8 + (tg_pt_gp->tg_pt_gp_members * 4);
			continue;
		}
109 110 111 112 113 114 115 116 117 118 119 120 121 122
		/*
		 * PREF: Preferred target port bit, determine if this
		 * bit should be set for port group.
		 */
		if (tg_pt_gp->tg_pt_gp_pref)
			buf[off] = 0x80;
		/*
		 * Set the ASYMMETRIC ACCESS State
		 */
		buf[off++] |= (atomic_read(
			&tg_pt_gp->tg_pt_gp_alua_access_state) & 0xff);
		/*
		 * Set supported ASYMMETRIC ACCESS State bits
		 */
123
		buf[off++] |= tg_pt_gp->tg_pt_gp_alua_supported_states;
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
		/*
		 * TARGET PORT GROUP
		 */
		buf[off++] = ((tg_pt_gp->tg_pt_gp_id >> 8) & 0xff);
		buf[off++] = (tg_pt_gp->tg_pt_gp_id & 0xff);

		off++; /* Skip over Reserved */
		/*
		 * STATUS CODE
		 */
		buf[off++] = (tg_pt_gp->tg_pt_gp_alua_access_status & 0xff);
		/*
		 * Vendor Specific field
		 */
		buf[off++] = 0x00;
		/*
		 * TARGET PORT COUNT
		 */
		buf[off++] = (tg_pt_gp->tg_pt_gp_members & 0xff);
		rd_len += 8;

		spin_lock(&tg_pt_gp->tg_pt_gp_lock);
		list_for_each_entry(tg_pt_gp_mem, &tg_pt_gp->tg_pt_gp_mem_list,
				tg_pt_gp_mem_list) {
			port = tg_pt_gp_mem->tg_pt;
			/*
			 * Start Target Port descriptor format
			 *
			 * See spc4r17 section 6.2.7 Table 247
			 */
			off += 2; /* Skip over Obsolete */
			/*
			 * Set RELATIVE TARGET PORT IDENTIFIER
			 */
			buf[off++] = ((port->sep_rtpi >> 8) & 0xff);
			buf[off++] = (port->sep_rtpi & 0xff);
			rd_len += 4;
		}
		spin_unlock(&tg_pt_gp->tg_pt_gp_lock);
	}
164
	spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
165 166 167
	/*
	 * Set the RETURN DATA LENGTH set in the header of the DataIN Payload
	 */
168
	put_unaligned_be32(rd_len, &buf[0]);
169

170 171 172 173 174 175
	/*
	 * Fill in the Extended header parameter data format if requested
	 */
	if (ext_hdr != 0) {
		buf[4] = 0x10;
		/*
176
		 * Set the implicit transition time (in seconds) for the application
177 178 179 180 181 182 183 184 185 186 187 188
		 * client to use as a base for it's transition timeout value.
		 *
		 * Use the current tg_pt_gp_mem -> tg_pt_gp membership from the LUN
		 * this CDB was received upon to determine this value individually
		 * for ALUA target port group.
		 */
		port = cmd->se_lun->lun_sep;
		tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem;
		if (tg_pt_gp_mem) {
			spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
			tg_pt_gp = tg_pt_gp_mem->tg_pt_gp;
			if (tg_pt_gp)
189
				buf[5] = tg_pt_gp->tg_pt_gp_implicit_trans_secs;
190 191 192
			spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
		}
	}
193
	transport_kunmap_data_sg(cmd);
194

195
	target_complete_cmd(cmd, GOOD);
196 197 198 199
	return 0;
}

/*
200
 * SET_TARGET_PORT_GROUPS for explicit ALUA operation.
201 202 203
 *
 * See spc4r17 section 6.35
 */
204 205
sense_reason_t
target_emulate_set_target_port_groups(struct se_cmd *cmd)
206
{
207
	struct se_device *dev = cmd->se_dev;
208 209
	struct se_port *port, *l_port = cmd->se_lun->lun_sep;
	struct se_node_acl *nacl = cmd->se_sess->se_node_acl;
210 211
	struct t10_alua_tg_pt_gp *tg_pt_gp = NULL, *l_tg_pt_gp;
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem, *l_tg_pt_gp_mem;
212 213
	unsigned char *buf;
	unsigned char *ptr;
214
	sense_reason_t rc = TCM_NO_SENSE;
215
	u32 len = 4; /* Skip over RESERVED area in header */
216
	int alua_access_state, primary = 0, valid_states;
217 218
	u16 tg_pt_id, rtpi;

219 220 221
	if (!l_port)
		return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE;

222 223 224
	if (cmd->data_length < 4) {
		pr_warn("SET TARGET PORT GROUPS parameter list length %u too"
			" small\n", cmd->data_length);
225
		return TCM_INVALID_PARAMETER_LIST;
226 227
	}

228
	buf = transport_kmap_data_sg(cmd);
229 230
	if (!buf)
		return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE;
231

232
	/*
233
	 * Determine if explicit ALUA via SET_TARGET_PORT_GROUPS is allowed
234 235 236
	 * for the local tg_pt_gp.
	 */
	l_tg_pt_gp_mem = l_port->sep_alua_tg_pt_gp_mem;
237 238
	if (!l_tg_pt_gp_mem) {
		pr_err("Unable to access l_port->sep_alua_tg_pt_gp_mem\n");
239
		rc = TCM_UNSUPPORTED_SCSI_OPCODE;
240
		goto out;
241 242 243
	}
	spin_lock(&l_tg_pt_gp_mem->tg_pt_gp_mem_lock);
	l_tg_pt_gp = l_tg_pt_gp_mem->tg_pt_gp;
244
	if (!l_tg_pt_gp) {
245
		spin_unlock(&l_tg_pt_gp_mem->tg_pt_gp_mem_lock);
246
		pr_err("Unable to access *l_tg_pt_gp_mem->tg_pt_gp\n");
247
		rc = TCM_UNSUPPORTED_SCSI_OPCODE;
248
		goto out;
249 250 251
	}
	spin_unlock(&l_tg_pt_gp_mem->tg_pt_gp_mem_lock);

252
	if (!(l_tg_pt_gp->tg_pt_gp_alua_access_type & TPGS_EXPLICIT_ALUA)) {
253
		pr_debug("Unable to process SET_TARGET_PORT_GROUPS"
254
				" while TPGS_EXPLICIT_ALUA is disabled\n");
255
		rc = TCM_UNSUPPORTED_SCSI_OPCODE;
256
		goto out;
257
	}
258
	valid_states = l_tg_pt_gp->tg_pt_gp_alua_supported_states;
259

260 261
	ptr = &buf[4]; /* Skip over RESERVED area in header */

262
	while (len < cmd->data_length) {
263
		bool found = false;
264 265 266 267 268 269
		alua_access_state = (ptr[0] & 0x0f);
		/*
		 * Check the received ALUA access state, and determine if
		 * the state is a primary or secondary target port asymmetric
		 * access state.
		 */
270 271
		rc = core_alua_check_transition(alua_access_state,
						valid_states, &primary);
272
		if (rc) {
273 274 275 276 277 278 279 280 281 282
			/*
			 * If the SET TARGET PORT GROUPS attempts to establish
			 * an invalid combination of target port asymmetric
			 * access states or attempts to establish an
			 * unsupported target port asymmetric access state,
			 * then the command shall be terminated with CHECK
			 * CONDITION status, with the sense key set to ILLEGAL
			 * REQUEST, and the additional sense code set to INVALID
			 * FIELD IN PARAMETER LIST.
			 */
283
			goto out;
284
		}
285

286 287 288 289 290 291 292 293 294 295 296 297 298 299
		/*
		 * If the ASYMMETRIC ACCESS STATE field (see table 267)
		 * specifies a primary target port asymmetric access state,
		 * then the TARGET PORT GROUP OR TARGET PORT field specifies
		 * a primary target port group for which the primary target
		 * port asymmetric access state shall be changed. If the
		 * ASYMMETRIC ACCESS STATE field specifies a secondary target
		 * port asymmetric access state, then the TARGET PORT GROUP OR
		 * TARGET PORT field specifies the relative target port
		 * identifier (see 3.1.120) of the target port for which the
		 * secondary target port asymmetric access state shall be
		 * changed.
		 */
		if (primary) {
300
			tg_pt_id = get_unaligned_be16(ptr + 2);
301 302 303 304
			/*
			 * Locate the matching target port group ID from
			 * the global tg_pt_gp list
			 */
305
			spin_lock(&dev->t10_alua.tg_pt_gps_lock);
306
			list_for_each_entry(tg_pt_gp,
307
					&dev->t10_alua.tg_pt_gps_list,
308
					tg_pt_gp_list) {
309
				if (!tg_pt_gp->tg_pt_gp_valid_id)
310 311 312 313 314 315 316
					continue;

				if (tg_pt_id != tg_pt_gp->tg_pt_gp_id)
					continue;

				atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt);
				smp_mb__after_atomic_inc();
317

318
				spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
319

320
				if (!core_alua_do_port_transition(tg_pt_gp,
321
						dev, l_port, nacl,
322 323
						alua_access_state, 1))
					found = true;
324

325
				spin_lock(&dev->t10_alua.tg_pt_gps_lock);
326 327 328 329
				atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt);
				smp_mb__after_atomic_dec();
				break;
			}
330
			spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
331 332
		} else {
			/*
H
Hannes Reinecke 已提交
333
			 * Extract the RELATIVE TARGET PORT IDENTIFIER to identify
334 335 336
			 * the Target Port in question for the the incoming
			 * SET_TARGET_PORT_GROUPS op.
			 */
337
			rtpi = get_unaligned_be16(ptr + 2);
338
			/*
339
			 * Locate the matching relative target port identifier
340 341 342 343 344 345 346 347 348
			 * for the struct se_device storage object.
			 */
			spin_lock(&dev->se_port_lock);
			list_for_each_entry(port, &dev->dev_sep_list,
							sep_list) {
				if (port->sep_rtpi != rtpi)
					continue;

				tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem;
349

350 351
				spin_unlock(&dev->se_port_lock);

352 353 354
				if (!core_alua_set_tg_pt_secondary_state(
						tg_pt_gp_mem, port, 1, 1))
					found = true;
355 356 357 358 359

				spin_lock(&dev->se_port_lock);
				break;
			}
			spin_unlock(&dev->se_port_lock);
360 361 362 363 364
		}

		if (!found) {
			rc = TCM_INVALID_PARAMETER_LIST;
			goto out;
365 366 367 368 369 370
		}

		ptr += 4;
		len += 4;
	}

371
out:
372
	transport_kunmap_data_sg(cmd);
373 374 375
	if (!rc)
		target_complete_cmd(cmd, GOOD);
	return rc;
376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411
}

static inline int core_alua_state_nonoptimized(
	struct se_cmd *cmd,
	unsigned char *cdb,
	int nonop_delay_msecs,
	u8 *alua_ascq)
{
	/*
	 * Set SCF_ALUA_NON_OPTIMIZED here, this value will be checked
	 * later to determine if processing of this cmd needs to be
	 * temporarily delayed for the Active/NonOptimized primary access state.
	 */
	cmd->se_cmd_flags |= SCF_ALUA_NON_OPTIMIZED;
	cmd->alua_nonop_delay = nonop_delay_msecs;
	return 0;
}

static inline int core_alua_state_standby(
	struct se_cmd *cmd,
	unsigned char *cdb,
	u8 *alua_ascq)
{
	/*
	 * Allowed CDBs for ALUA_ACCESS_STATE_STANDBY as defined by
	 * spc4r17 section 5.9.2.4.4
	 */
	switch (cdb[0]) {
	case INQUIRY:
	case LOG_SELECT:
	case LOG_SENSE:
	case MODE_SELECT:
	case MODE_SENSE:
	case REPORT_LUNS:
	case RECEIVE_DIAGNOSTIC:
	case SEND_DIAGNOSTIC:
412
		return 0;
413
	case MAINTENANCE_IN:
414
		switch (cdb[1] & 0x1f) {
415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454
		case MI_REPORT_TARGET_PGS:
			return 0;
		default:
			*alua_ascq = ASCQ_04H_ALUA_TG_PT_STANDBY;
			return 1;
		}
	case MAINTENANCE_OUT:
		switch (cdb[1]) {
		case MO_SET_TARGET_PGS:
			return 0;
		default:
			*alua_ascq = ASCQ_04H_ALUA_TG_PT_STANDBY;
			return 1;
		}
	case REQUEST_SENSE:
	case PERSISTENT_RESERVE_IN:
	case PERSISTENT_RESERVE_OUT:
	case READ_BUFFER:
	case WRITE_BUFFER:
		return 0;
	default:
		*alua_ascq = ASCQ_04H_ALUA_TG_PT_STANDBY;
		return 1;
	}

	return 0;
}

static inline int core_alua_state_unavailable(
	struct se_cmd *cmd,
	unsigned char *cdb,
	u8 *alua_ascq)
{
	/*
	 * Allowed CDBs for ALUA_ACCESS_STATE_UNAVAILABLE as defined by
	 * spc4r17 section 5.9.2.4.5
	 */
	switch (cdb[0]) {
	case INQUIRY:
	case REPORT_LUNS:
455
		return 0;
456
	case MAINTENANCE_IN:
457
		switch (cdb[1] & 0x1f) {
458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489
		case MI_REPORT_TARGET_PGS:
			return 0;
		default:
			*alua_ascq = ASCQ_04H_ALUA_TG_PT_UNAVAILABLE;
			return 1;
		}
	case MAINTENANCE_OUT:
		switch (cdb[1]) {
		case MO_SET_TARGET_PGS:
			return 0;
		default:
			*alua_ascq = ASCQ_04H_ALUA_TG_PT_UNAVAILABLE;
			return 1;
		}
	case REQUEST_SENSE:
	case READ_BUFFER:
	case WRITE_BUFFER:
		return 0;
	default:
		*alua_ascq = ASCQ_04H_ALUA_TG_PT_UNAVAILABLE;
		return 1;
	}

	return 0;
}

static inline int core_alua_state_transition(
	struct se_cmd *cmd,
	unsigned char *cdb,
	u8 *alua_ascq)
{
	/*
H
Hannes Reinecke 已提交
490
	 * Allowed CDBs for ALUA_ACCESS_STATE_TRANSITION as defined by
491 492 493 494 495
	 * spc4r17 section 5.9.2.5
	 */
	switch (cdb[0]) {
	case INQUIRY:
	case REPORT_LUNS:
496
		return 0;
497
	case MAINTENANCE_IN:
498
		switch (cdb[1] & 0x1f) {
499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517
		case MI_REPORT_TARGET_PGS:
			return 0;
		default:
			*alua_ascq = ASCQ_04H_ALUA_STATE_TRANSITION;
			return 1;
		}
	case REQUEST_SENSE:
	case READ_BUFFER:
	case WRITE_BUFFER:
		return 0;
	default:
		*alua_ascq = ASCQ_04H_ALUA_STATE_TRANSITION;
		return 1;
	}

	return 0;
}

/*
H
Hannes Reinecke 已提交
518
 * return 1: Is used to signal LUN not accessible, and check condition/not ready
519
 * return 0: Used to signal success
H
Hannes Reinecke 已提交
520
 * return -1: Used to signal failure, and invalid cdb field
521
 */
522 523
sense_reason_t
target_alua_state_check(struct se_cmd *cmd)
524
{
C
Christoph Hellwig 已提交
525 526
	struct se_device *dev = cmd->se_dev;
	unsigned char *cdb = cmd->t_task_cdb;
527
	struct se_lun *lun = cmd->se_lun;
528 529 530 531
	struct se_port *port = lun->lun_sep;
	struct t10_alua_tg_pt_gp *tg_pt_gp;
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem;
	int out_alua_state, nonop_delay_msecs;
C
Christoph Hellwig 已提交
532 533 534 535 536 537 538
	u8 alua_ascq;
	int ret;

	if (dev->se_hba->hba_flags & HBA_FLAGS_INTERNAL_USE)
		return 0;
	if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV)
		return 0;
539

540
	if (!port)
541 542 543 544 545 546
		return 0;
	/*
	 * First, check for a struct se_port specific secondary ALUA target port
	 * access state: OFFLINE
	 */
	if (atomic_read(&port->sep_tg_pt_secondary_offline)) {
547
		pr_debug("ALUA: Got secondary offline status for local"
548
				" target port\n");
C
Christoph Hellwig 已提交
549 550 551
		alua_ascq = ASCQ_04H_ALUA_OFFLINE;
		ret = 1;
		goto out;
552 553 554 555 556 557 558 559
	}
	 /*
	 * Second, obtain the struct t10_alua_tg_pt_gp_member pointer to the
	 * ALUA target port group, to obtain current ALUA access state.
	 * Otherwise look for the underlying struct se_device association with
	 * a ALUA logical unit group.
	 */
	tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem;
560 561 562
	if (!tg_pt_gp_mem)
		return 0;

563 564 565 566 567 568
	spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	tg_pt_gp = tg_pt_gp_mem->tg_pt_gp;
	out_alua_state = atomic_read(&tg_pt_gp->tg_pt_gp_alua_access_state);
	nonop_delay_msecs = tg_pt_gp->tg_pt_gp_nonop_delay_msecs;
	spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	/*
569
	 * Process ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED in a separate conditional
L
Lucas De Marchi 已提交
570
	 * statement so the compiler knows explicitly to check this case first.
571 572 573
	 * For the Optimized ALUA access state case, we want to process the
	 * incoming fabric cmd ASAP..
	 */
574
	if (out_alua_state == ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED)
575 576 577 578
		return 0;

	switch (out_alua_state) {
	case ALUA_ACCESS_STATE_ACTIVE_NON_OPTIMIZED:
C
Christoph Hellwig 已提交
579 580 581
		ret = core_alua_state_nonoptimized(cmd, cdb,
					nonop_delay_msecs, &alua_ascq);
		break;
582
	case ALUA_ACCESS_STATE_STANDBY:
C
Christoph Hellwig 已提交
583 584
		ret = core_alua_state_standby(cmd, cdb, &alua_ascq);
		break;
585
	case ALUA_ACCESS_STATE_UNAVAILABLE:
C
Christoph Hellwig 已提交
586 587
		ret = core_alua_state_unavailable(cmd, cdb, &alua_ascq);
		break;
588
	case ALUA_ACCESS_STATE_TRANSITION:
C
Christoph Hellwig 已提交
589 590
		ret = core_alua_state_transition(cmd, cdb, &alua_ascq);
		break;
591 592 593 594 595 596
	/*
	 * OFFLINE is a secondary ALUA target port group access state, that is
	 * handled above with struct se_port->sep_tg_pt_secondary_offline=1
	 */
	case ALUA_ACCESS_STATE_OFFLINE:
	default:
597
		pr_err("Unknown ALUA access state: 0x%02x\n",
598
				out_alua_state);
599
		return TCM_INVALID_CDB_FIELD;
600 601
	}

C
Christoph Hellwig 已提交
602 603 604 605 606 607 608 609 610 611 612 613 614 615
out:
	if (ret > 0) {
		/*
		 * Set SCSI additional sense code (ASC) to 'LUN Not Accessible';
		 * The ALUA additional sense code qualifier (ASCQ) is determined
		 * by the ALUA primary or secondary access state..
		 */
		pr_debug("[%s]: ALUA TG Port not available, "
			"SenseKey: NOT_READY, ASC/ASCQ: "
			"0x04/0x%02x\n",
			cmd->se_tfo->get_fabric_name(), alua_ascq);

		cmd->scsi_asc = 0x04;
		cmd->scsi_ascq = alua_ascq;
616
		return TCM_CHECK_CONDITION_NOT_READY;
C
Christoph Hellwig 已提交
617 618
	}

619
	return 0;
620 621 622
}

/*
623
 * Check implicit and explicit ALUA state change request.
624
 */
625
static sense_reason_t
626
core_alua_check_transition(int state, int valid, int *primary)
627
{
628 629 630 631
	/*
	 * OPTIMIZED, NON-OPTIMIZED, STANDBY and UNAVAILABLE are
	 * defined as primary target port asymmetric access states.
	 */
632
	switch (state) {
633
	case ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED:
634 635 636 637
		if (!(valid & ALUA_AO_SUP))
			goto not_supported;
		*primary = 1;
		break;
638
	case ALUA_ACCESS_STATE_ACTIVE_NON_OPTIMIZED:
639 640 641 642
		if (!(valid & ALUA_AN_SUP))
			goto not_supported;
		*primary = 1;
		break;
643
	case ALUA_ACCESS_STATE_STANDBY:
644 645 646 647
		if (!(valid & ALUA_S_SUP))
			goto not_supported;
		*primary = 1;
		break;
648
	case ALUA_ACCESS_STATE_UNAVAILABLE:
649 650
		if (!(valid & ALUA_U_SUP))
			goto not_supported;
651 652 653 654 655 656 657
		*primary = 1;
		break;
	case ALUA_ACCESS_STATE_OFFLINE:
		/*
		 * OFFLINE state is defined as a secondary target port
		 * asymmetric access state.
		 */
658 659
		if (!(valid & ALUA_O_SUP))
			goto not_supported;
660 661
		*primary = 0;
		break;
662 663 664 665 666 667
	case ALUA_ACCESS_STATE_TRANSITION:
		/*
		 * Transitioning is set internally, and
		 * cannot be selected manually.
		 */
		goto not_supported;
668
	default:
669
		pr_err("Unknown ALUA access state: 0x%02x\n", state);
670
		return TCM_INVALID_PARAMETER_LIST;
671 672 673
	}

	return 0;
674 675 676 677 678

not_supported:
	pr_err("ALUA access state %s not supported",
	       core_alua_dump_state(state));
	return TCM_INVALID_PARAMETER_LIST;
679 680 681 682 683
}

static char *core_alua_dump_state(int state)
{
	switch (state) {
684
	case ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED:
685 686 687 688 689 690 691 692 693
		return "Active/Optimized";
	case ALUA_ACCESS_STATE_ACTIVE_NON_OPTIMIZED:
		return "Active/NonOptimized";
	case ALUA_ACCESS_STATE_STANDBY:
		return "Standby";
	case ALUA_ACCESS_STATE_UNAVAILABLE:
		return "Unavailable";
	case ALUA_ACCESS_STATE_OFFLINE:
		return "Offline";
694 695
	case ALUA_ACCESS_STATE_TRANSITION:
		return "Transitioning";
696 697 698 699 700 701 702 703 704 705 706 707
	default:
		return "Unknown";
	}

	return NULL;
}

char *core_alua_dump_status(int status)
{
	switch (status) {
	case ALUA_STATUS_NONE:
		return "None";
708 709 710 711
	case ALUA_STATUS_ALTERED_BY_EXPLICIT_STPG:
		return "Altered by Explicit STPG";
	case ALUA_STATUS_ALTERED_BY_IMPLICIT_ALUA:
		return "Altered by Implicit ALUA";
712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733
	default:
		return "Unknown";
	}

	return NULL;
}

/*
 * Used by fabric modules to determine when we need to delay processing
 * for the Active/NonOptimized paths..
 */
int core_alua_check_nonop_delay(
	struct se_cmd *cmd)
{
	if (!(cmd->se_cmd_flags & SCF_ALUA_NON_OPTIMIZED))
		return 0;
	if (in_interrupt())
		return 0;
	/*
	 * The ALUA Active/NonOptimized access state delay can be disabled
	 * in via configfs with a value of zero
	 */
734
	if (!cmd->alua_nonop_delay)
735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753
		return 0;
	/*
	 * struct se_cmd->alua_nonop_delay gets set by a target port group
	 * defined interval in core_alua_state_nonoptimized()
	 */
	msleep_interruptible(cmd->alua_nonop_delay);
	return 0;
}
EXPORT_SYMBOL(core_alua_check_nonop_delay);

/*
 * Called with tg_pt_gp->tg_pt_gp_md_mutex or tg_pt_gp_mem->sep_tg_pt_md_mutex
 *
 */
static int core_alua_write_tpg_metadata(
	const char *path,
	unsigned char *md_buf,
	u32 md_buf_len)
{
754 755
	struct file *file = filp_open(path, O_RDWR | O_CREAT | O_TRUNC, 0600);
	int ret;
756

757 758
	if (IS_ERR(file)) {
		pr_err("filp_open(%s) for ALUA metadata failed\n", path);
759 760
		return -ENODEV;
	}
761 762
	ret = kernel_write(file, md_buf, md_buf_len, 0);
	if (ret < 0)
763
		pr_err("Error writing ALUA metadata file: %s\n", path);
764
	fput(file);
765
	return (ret < 0) ? -EIO : 0;
766 767 768 769 770 771 772 773 774 775
}

/*
 * Called with tg_pt_gp->tg_pt_gp_md_mutex held
 */
static int core_alua_update_tpg_primary_metadata(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	int primary_state,
	unsigned char *md_buf)
{
776
	struct t10_wwn *wwn = &tg_pt_gp->tg_pt_gp_dev->t10_wwn;
777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801
	char path[ALUA_METADATA_PATH_LEN];
	int len;

	memset(path, 0, ALUA_METADATA_PATH_LEN);

	len = snprintf(md_buf, tg_pt_gp->tg_pt_gp_md_buf_len,
			"tg_pt_gp_id=%hu\n"
			"alua_access_state=0x%02x\n"
			"alua_access_status=0x%02x\n",
			tg_pt_gp->tg_pt_gp_id, primary_state,
			tg_pt_gp->tg_pt_gp_alua_access_status);

	snprintf(path, ALUA_METADATA_PATH_LEN,
		"/var/target/alua/tpgs_%s/%s", &wwn->unit_serial[0],
		config_item_name(&tg_pt_gp->tg_pt_gp_group.cg_item));

	return core_alua_write_tpg_metadata(path, md_buf, len);
}

static int core_alua_do_transition_tg_pt(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	struct se_port *l_port,
	struct se_node_acl *nacl,
	unsigned char *md_buf,
	int new_state,
802
	int explicit)
803 804 805 806 807 808 809 810 811 812 813 814 815
{
	struct se_dev_entry *se_deve;
	struct se_lun_acl *lacl;
	struct se_port *port;
	struct t10_alua_tg_pt_gp_member *mem;
	int old_state = 0;
	/*
	 * Save the old primary ALUA access state, and set the current state
	 * to ALUA_ACCESS_STATE_TRANSITION.
	 */
	old_state = atomic_read(&tg_pt_gp->tg_pt_gp_alua_access_state);
	atomic_set(&tg_pt_gp->tg_pt_gp_alua_access_state,
			ALUA_ACCESS_STATE_TRANSITION);
816 817 818
	tg_pt_gp->tg_pt_gp_alua_access_status = (explicit) ?
				ALUA_STATUS_ALTERED_BY_EXPLICIT_STPG :
				ALUA_STATUS_ALTERED_BY_IMPLICIT_ALUA;
819 820 821 822 823 824 825 826 827 828 829 830 831 832 833
	/*
	 * Check for the optional ALUA primary state transition delay
	 */
	if (tg_pt_gp->tg_pt_gp_trans_delay_msecs != 0)
		msleep_interruptible(tg_pt_gp->tg_pt_gp_trans_delay_msecs);

	spin_lock(&tg_pt_gp->tg_pt_gp_lock);
	list_for_each_entry(mem, &tg_pt_gp->tg_pt_gp_mem_list,
				tg_pt_gp_mem_list) {
		port = mem->tg_pt;
		/*
		 * After an implicit target port asymmetric access state
		 * change, a device server shall establish a unit attention
		 * condition for the initiator port associated with every I_T
		 * nexus with the additional sense code set to ASYMMETRIC
H
Hannes Reinecke 已提交
834
		 * ACCESS STATE CHANGED.
835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852
		 *
		 * After an explicit target port asymmetric access state
		 * change, a device server shall establish a unit attention
		 * condition with the additional sense code set to ASYMMETRIC
		 * ACCESS STATE CHANGED for the initiator port associated with
		 * every I_T nexus other than the I_T nexus on which the SET
		 * TARGET PORT GROUPS command
		 */
		atomic_inc(&mem->tg_pt_gp_mem_ref_cnt);
		smp_mb__after_atomic_inc();
		spin_unlock(&tg_pt_gp->tg_pt_gp_lock);

		spin_lock_bh(&port->sep_alua_lock);
		list_for_each_entry(se_deve, &port->sep_alua_list,
					alua_port_list) {
			lacl = se_deve->se_lun_acl;
			/*
			 * se_deve->se_lun_acl pointer may be NULL for a
853
			 * entry created without explicit Node+MappedLUN ACLs
854
			 */
855
			if (!lacl)
856 857
				continue;

858
			if (explicit &&
859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896
			   (nacl != NULL) && (nacl == lacl->se_lun_nacl) &&
			   (l_port != NULL) && (l_port == port))
				continue;

			core_scsi3_ua_allocate(lacl->se_lun_nacl,
				se_deve->mapped_lun, 0x2A,
				ASCQ_2AH_ASYMMETRIC_ACCESS_STATE_CHANGED);
		}
		spin_unlock_bh(&port->sep_alua_lock);

		spin_lock(&tg_pt_gp->tg_pt_gp_lock);
		atomic_dec(&mem->tg_pt_gp_mem_ref_cnt);
		smp_mb__after_atomic_dec();
	}
	spin_unlock(&tg_pt_gp->tg_pt_gp_lock);
	/*
	 * Update the ALUA metadata buf that has been allocated in
	 * core_alua_do_port_transition(), this metadata will be written
	 * to struct file.
	 *
	 * Note that there is the case where we do not want to update the
	 * metadata when the saved metadata is being parsed in userspace
	 * when setting the existing port access state and access status.
	 *
	 * Also note that the failure to write out the ALUA metadata to
	 * struct file does NOT affect the actual ALUA transition.
	 */
	if (tg_pt_gp->tg_pt_gp_write_metadata) {
		mutex_lock(&tg_pt_gp->tg_pt_gp_md_mutex);
		core_alua_update_tpg_primary_metadata(tg_pt_gp,
					new_state, md_buf);
		mutex_unlock(&tg_pt_gp->tg_pt_gp_md_mutex);
	}
	/*
	 * Set the current primary ALUA access state to the requested new state
	 */
	atomic_set(&tg_pt_gp->tg_pt_gp_alua_access_state, new_state);

897
	pr_debug("Successful %s ALUA transition TG PT Group: %s ID: %hu"
898 899
		" from primary access state %s to %s\n", (explicit) ? "explicit" :
		"implicit", config_item_name(&tg_pt_gp->tg_pt_gp_group.cg_item),
900 901 902 903 904 905 906 907 908 909 910 911
		tg_pt_gp->tg_pt_gp_id, core_alua_dump_state(old_state),
		core_alua_dump_state(new_state));

	return 0;
}

int core_alua_do_port_transition(
	struct t10_alua_tg_pt_gp *l_tg_pt_gp,
	struct se_device *l_dev,
	struct se_port *l_port,
	struct se_node_acl *l_nacl,
	int new_state,
912
	int explicit)
913 914 915 916 917 918 919 920
{
	struct se_device *dev;
	struct se_port *port;
	struct se_node_acl *nacl;
	struct t10_alua_lu_gp *lu_gp;
	struct t10_alua_lu_gp_member *lu_gp_mem, *local_lu_gp_mem;
	struct t10_alua_tg_pt_gp *tg_pt_gp;
	unsigned char *md_buf;
921
	int primary, valid_states;
922

923 924
	valid_states = l_tg_pt_gp->tg_pt_gp_alua_supported_states;
	if (core_alua_check_transition(new_state, valid_states, &primary) != 0)
925 926 927
		return -EINVAL;

	md_buf = kzalloc(l_tg_pt_gp->tg_pt_gp_md_buf_len, GFP_KERNEL);
928 929
	if (!md_buf) {
		pr_err("Unable to allocate buf for ALUA metadata\n");
930 931 932 933 934 935 936 937 938 939 940 941 942 943
		return -ENOMEM;
	}

	local_lu_gp_mem = l_dev->dev_alua_lu_gp_mem;
	spin_lock(&local_lu_gp_mem->lu_gp_mem_lock);
	lu_gp = local_lu_gp_mem->lu_gp;
	atomic_inc(&lu_gp->lu_gp_ref_cnt);
	smp_mb__after_atomic_inc();
	spin_unlock(&local_lu_gp_mem->lu_gp_mem_lock);
	/*
	 * For storage objects that are members of the 'default_lu_gp',
	 * we only do transition on the passed *l_tp_pt_gp, and not
	 * on all of the matching target port groups IDs in default_lu_gp.
	 */
944
	if (!lu_gp->lu_gp_id) {
945 946 947 948 949
		/*
		 * core_alua_do_transition_tg_pt() will always return
		 * success.
		 */
		core_alua_do_transition_tg_pt(l_tg_pt_gp, l_port, l_nacl,
950
					md_buf, new_state, explicit);
951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969
		atomic_dec(&lu_gp->lu_gp_ref_cnt);
		smp_mb__after_atomic_dec();
		kfree(md_buf);
		return 0;
	}
	/*
	 * For all other LU groups aside from 'default_lu_gp', walk all of
	 * the associated storage objects looking for a matching target port
	 * group ID from the local target port group.
	 */
	spin_lock(&lu_gp->lu_gp_lock);
	list_for_each_entry(lu_gp_mem, &lu_gp->lu_gp_mem_list,
				lu_gp_mem_list) {

		dev = lu_gp_mem->lu_gp_mem_dev;
		atomic_inc(&lu_gp_mem->lu_gp_mem_ref_cnt);
		smp_mb__after_atomic_inc();
		spin_unlock(&lu_gp->lu_gp_lock);

970
		spin_lock(&dev->t10_alua.tg_pt_gps_lock);
971
		list_for_each_entry(tg_pt_gp,
972
				&dev->t10_alua.tg_pt_gps_list,
973 974
				tg_pt_gp_list) {

975
			if (!tg_pt_gp->tg_pt_gp_valid_id)
976 977 978
				continue;
			/*
			 * If the target behavior port asymmetric access state
H
Hannes Reinecke 已提交
979
			 * is changed for any target port group accessible via
980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996
			 * a logical unit within a LU group, the target port
			 * behavior group asymmetric access states for the same
			 * target port group accessible via other logical units
			 * in that LU group will also change.
			 */
			if (l_tg_pt_gp->tg_pt_gp_id != tg_pt_gp->tg_pt_gp_id)
				continue;

			if (l_tg_pt_gp == tg_pt_gp) {
				port = l_port;
				nacl = l_nacl;
			} else {
				port = NULL;
				nacl = NULL;
			}
			atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt);
			smp_mb__after_atomic_inc();
997
			spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
998 999 1000 1001 1002
			/*
			 * core_alua_do_transition_tg_pt() will always return
			 * success.
			 */
			core_alua_do_transition_tg_pt(tg_pt_gp, port,
1003
					nacl, md_buf, new_state, explicit);
1004

1005
			spin_lock(&dev->t10_alua.tg_pt_gps_lock);
1006 1007 1008
			atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt);
			smp_mb__after_atomic_dec();
		}
1009
		spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1010 1011 1012 1013 1014 1015 1016

		spin_lock(&lu_gp->lu_gp_lock);
		atomic_dec(&lu_gp_mem->lu_gp_mem_ref_cnt);
		smp_mb__after_atomic_dec();
	}
	spin_unlock(&lu_gp->lu_gp_lock);

1017
	pr_debug("Successfully processed LU Group: %s all ALUA TG PT"
1018 1019
		" Group IDs: %hu %s transition to primary state: %s\n",
		config_item_name(&lu_gp->lu_gp_group.cg_item),
1020
		l_tg_pt_gp->tg_pt_gp_id, (explicit) ? "explicit" : "implicit",
1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045
		core_alua_dump_state(new_state));

	atomic_dec(&lu_gp->lu_gp_ref_cnt);
	smp_mb__after_atomic_dec();
	kfree(md_buf);
	return 0;
}

/*
 * Called with tg_pt_gp_mem->sep_tg_pt_md_mutex held
 */
static int core_alua_update_tpg_secondary_metadata(
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem,
	struct se_port *port,
	unsigned char *md_buf,
	u32 md_buf_len)
{
	struct se_portal_group *se_tpg = port->sep_tpg;
	char path[ALUA_METADATA_PATH_LEN], wwn[ALUA_SECONDARY_METADATA_WWN_LEN];
	int len;

	memset(path, 0, ALUA_METADATA_PATH_LEN);
	memset(wwn, 0, ALUA_SECONDARY_METADATA_WWN_LEN);

	len = snprintf(wwn, ALUA_SECONDARY_METADATA_WWN_LEN, "%s",
1046
			se_tpg->se_tpg_tfo->tpg_get_wwn(se_tpg));
1047

1048
	if (se_tpg->se_tpg_tfo->tpg_get_tag != NULL)
1049
		snprintf(wwn+len, ALUA_SECONDARY_METADATA_WWN_LEN-len, "+%hu",
1050
				se_tpg->se_tpg_tfo->tpg_get_tag(se_tpg));
1051 1052 1053 1054 1055 1056 1057

	len = snprintf(md_buf, md_buf_len, "alua_tg_pt_offline=%d\n"
			"alua_tg_pt_status=0x%02x\n",
			atomic_read(&port->sep_tg_pt_secondary_offline),
			port->sep_tg_pt_secondary_stat);

	snprintf(path, ALUA_METADATA_PATH_LEN, "/var/target/alua/%s/%s/lun_%u",
1058
			se_tpg->se_tpg_tfo->get_fabric_name(), wwn,
1059 1060 1061 1062 1063 1064 1065 1066
			port->sep_lun->unpacked_lun);

	return core_alua_write_tpg_metadata(path, md_buf, len);
}

static int core_alua_set_tg_pt_secondary_state(
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem,
	struct se_port *port,
1067
	int explicit,
1068 1069 1070 1071 1072 1073 1074 1075 1076
	int offline)
{
	struct t10_alua_tg_pt_gp *tg_pt_gp;
	unsigned char *md_buf;
	u32 md_buf_len;
	int trans_delay_msecs;

	spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	tg_pt_gp = tg_pt_gp_mem->tg_pt_gp;
1077
	if (!tg_pt_gp) {
1078
		spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
1079
		pr_err("Unable to complete secondary state"
1080
				" transition\n");
1081
		return -EINVAL;
1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093
	}
	trans_delay_msecs = tg_pt_gp->tg_pt_gp_trans_delay_msecs;
	/*
	 * Set the secondary ALUA target port access state to OFFLINE
	 * or release the previously secondary state for struct se_port
	 */
	if (offline)
		atomic_set(&port->sep_tg_pt_secondary_offline, 1);
	else
		atomic_set(&port->sep_tg_pt_secondary_offline, 0);

	md_buf_len = tg_pt_gp->tg_pt_gp_md_buf_len;
1094 1095 1096
	port->sep_tg_pt_secondary_stat = (explicit) ?
			ALUA_STATUS_ALTERED_BY_EXPLICIT_STPG :
			ALUA_STATUS_ALTERED_BY_IMPLICIT_ALUA;
1097

1098
	pr_debug("Successful %s ALUA transition TG PT Group: %s ID: %hu"
1099 1100
		" to secondary access state: %s\n", (explicit) ? "explicit" :
		"implicit", config_item_name(&tg_pt_gp->tg_pt_gp_group.cg_item),
1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115
		tg_pt_gp->tg_pt_gp_id, (offline) ? "OFFLINE" : "ONLINE");

	spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	/*
	 * Do the optional transition delay after we set the secondary
	 * ALUA access state.
	 */
	if (trans_delay_msecs != 0)
		msleep_interruptible(trans_delay_msecs);
	/*
	 * See if we need to update the ALUA fabric port metadata for
	 * secondary state and status
	 */
	if (port->sep_tg_pt_secondary_write_md) {
		md_buf = kzalloc(md_buf_len, GFP_KERNEL);
1116 1117
		if (!md_buf) {
			pr_err("Unable to allocate md_buf for"
1118
				" secondary ALUA access metadata\n");
1119
			return -ENOMEM;
1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137
		}
		mutex_lock(&port->sep_tg_pt_md_mutex);
		core_alua_update_tpg_secondary_metadata(tg_pt_gp_mem, port,
				md_buf, md_buf_len);
		mutex_unlock(&port->sep_tg_pt_md_mutex);

		kfree(md_buf);
	}

	return 0;
}

struct t10_alua_lu_gp *
core_alua_allocate_lu_gp(const char *name, int def_group)
{
	struct t10_alua_lu_gp *lu_gp;

	lu_gp = kmem_cache_zalloc(t10_alua_lu_gp_cache, GFP_KERNEL);
1138 1139
	if (!lu_gp) {
		pr_err("Unable to allocate struct t10_alua_lu_gp\n");
1140
		return ERR_PTR(-ENOMEM);
1141
	}
1142
	INIT_LIST_HEAD(&lu_gp->lu_gp_node);
1143 1144 1145 1146 1147
	INIT_LIST_HEAD(&lu_gp->lu_gp_mem_list);
	spin_lock_init(&lu_gp->lu_gp_lock);
	atomic_set(&lu_gp->lu_gp_ref_cnt, 0);

	if (def_group) {
1148
		lu_gp->lu_gp_id = alua_lu_gps_counter++;
1149
		lu_gp->lu_gp_valid_id = 1;
1150
		alua_lu_gps_count++;
1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163
	}

	return lu_gp;
}

int core_alua_set_lu_gp_id(struct t10_alua_lu_gp *lu_gp, u16 lu_gp_id)
{
	struct t10_alua_lu_gp *lu_gp_tmp;
	u16 lu_gp_id_tmp;
	/*
	 * The lu_gp->lu_gp_id may only be set once..
	 */
	if (lu_gp->lu_gp_valid_id) {
1164
		pr_warn("ALUA LU Group already has a valid ID,"
1165
			" ignoring request\n");
1166
		return -EINVAL;
1167 1168
	}

1169 1170
	spin_lock(&lu_gps_lock);
	if (alua_lu_gps_count == 0x0000ffff) {
1171
		pr_err("Maximum ALUA alua_lu_gps_count:"
1172
				" 0x0000ffff reached\n");
1173
		spin_unlock(&lu_gps_lock);
1174
		kmem_cache_free(t10_alua_lu_gp_cache, lu_gp);
1175
		return -ENOSPC;
1176 1177 1178
	}
again:
	lu_gp_id_tmp = (lu_gp_id != 0) ? lu_gp_id :
1179
				alua_lu_gps_counter++;
1180

1181
	list_for_each_entry(lu_gp_tmp, &lu_gps_list, lu_gp_node) {
1182
		if (lu_gp_tmp->lu_gp_id == lu_gp_id_tmp) {
1183
			if (!lu_gp_id)
1184 1185
				goto again;

1186
			pr_warn("ALUA Logical Unit Group ID: %hu"
1187 1188
				" already exists, ignoring request\n",
				lu_gp_id);
1189 1190
			spin_unlock(&lu_gps_lock);
			return -EINVAL;
1191 1192 1193 1194 1195
		}
	}

	lu_gp->lu_gp_id = lu_gp_id_tmp;
	lu_gp->lu_gp_valid_id = 1;
1196 1197 1198
	list_add_tail(&lu_gp->lu_gp_node, &lu_gps_list);
	alua_lu_gps_count++;
	spin_unlock(&lu_gps_lock);
1199 1200 1201 1202 1203 1204 1205 1206 1207 1208

	return 0;
}

static struct t10_alua_lu_gp_member *
core_alua_allocate_lu_gp_mem(struct se_device *dev)
{
	struct t10_alua_lu_gp_member *lu_gp_mem;

	lu_gp_mem = kmem_cache_zalloc(t10_alua_lu_gp_mem_cache, GFP_KERNEL);
1209 1210
	if (!lu_gp_mem) {
		pr_err("Unable to allocate struct t10_alua_lu_gp_member\n");
1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233
		return ERR_PTR(-ENOMEM);
	}
	INIT_LIST_HEAD(&lu_gp_mem->lu_gp_mem_list);
	spin_lock_init(&lu_gp_mem->lu_gp_mem_lock);
	atomic_set(&lu_gp_mem->lu_gp_mem_ref_cnt, 0);

	lu_gp_mem->lu_gp_mem_dev = dev;
	dev->dev_alua_lu_gp_mem = lu_gp_mem;

	return lu_gp_mem;
}

void core_alua_free_lu_gp(struct t10_alua_lu_gp *lu_gp)
{
	struct t10_alua_lu_gp_member *lu_gp_mem, *lu_gp_mem_tmp;
	/*
	 * Once we have reached this point, config_item_put() has
	 * already been called from target_core_alua_drop_lu_gp().
	 *
	 * Here, we remove the *lu_gp from the global list so that
	 * no associations can be made while we are releasing
	 * struct t10_alua_lu_gp.
	 */
1234 1235 1236 1237
	spin_lock(&lu_gps_lock);
	list_del(&lu_gp->lu_gp_node);
	alua_lu_gps_count--;
	spin_unlock(&lu_gps_lock);
1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259
	/*
	 * Allow struct t10_alua_lu_gp * referenced by core_alua_get_lu_gp_by_name()
	 * in target_core_configfs.c:target_core_store_alua_lu_gp() to be
	 * released with core_alua_put_lu_gp_from_name()
	 */
	while (atomic_read(&lu_gp->lu_gp_ref_cnt))
		cpu_relax();
	/*
	 * Release reference to struct t10_alua_lu_gp * from all associated
	 * struct se_device.
	 */
	spin_lock(&lu_gp->lu_gp_lock);
	list_for_each_entry_safe(lu_gp_mem, lu_gp_mem_tmp,
				&lu_gp->lu_gp_mem_list, lu_gp_mem_list) {
		if (lu_gp_mem->lu_gp_assoc) {
			list_del(&lu_gp_mem->lu_gp_mem_list);
			lu_gp->lu_gp_members--;
			lu_gp_mem->lu_gp_assoc = 0;
		}
		spin_unlock(&lu_gp->lu_gp_lock);
		/*
		 *
L
Lucas De Marchi 已提交
1260
		 * lu_gp_mem is associated with a single
1261 1262 1263 1264
		 * struct se_device->dev_alua_lu_gp_mem, and is released when
		 * struct se_device is released via core_alua_free_lu_gp_mem().
		 *
		 * If the passed lu_gp does NOT match the default_lu_gp, assume
H
Hannes Reinecke 已提交
1265
		 * we want to re-associate a given lu_gp_mem with default_lu_gp.
1266 1267
		 */
		spin_lock(&lu_gp_mem->lu_gp_mem_lock);
1268
		if (lu_gp != default_lu_gp)
1269
			__core_alua_attach_lu_gp_mem(lu_gp_mem,
1270
					default_lu_gp);
1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287
		else
			lu_gp_mem->lu_gp = NULL;
		spin_unlock(&lu_gp_mem->lu_gp_mem_lock);

		spin_lock(&lu_gp->lu_gp_lock);
	}
	spin_unlock(&lu_gp->lu_gp_lock);

	kmem_cache_free(t10_alua_lu_gp_cache, lu_gp);
}

void core_alua_free_lu_gp_mem(struct se_device *dev)
{
	struct t10_alua_lu_gp *lu_gp;
	struct t10_alua_lu_gp_member *lu_gp_mem;

	lu_gp_mem = dev->dev_alua_lu_gp_mem;
1288
	if (!lu_gp_mem)
1289 1290 1291 1292 1293 1294 1295
		return;

	while (atomic_read(&lu_gp_mem->lu_gp_mem_ref_cnt))
		cpu_relax();

	spin_lock(&lu_gp_mem->lu_gp_mem_lock);
	lu_gp = lu_gp_mem->lu_gp;
1296
	if (lu_gp) {
1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315
		spin_lock(&lu_gp->lu_gp_lock);
		if (lu_gp_mem->lu_gp_assoc) {
			list_del(&lu_gp_mem->lu_gp_mem_list);
			lu_gp->lu_gp_members--;
			lu_gp_mem->lu_gp_assoc = 0;
		}
		spin_unlock(&lu_gp->lu_gp_lock);
		lu_gp_mem->lu_gp = NULL;
	}
	spin_unlock(&lu_gp_mem->lu_gp_mem_lock);

	kmem_cache_free(t10_alua_lu_gp_mem_cache, lu_gp_mem);
}

struct t10_alua_lu_gp *core_alua_get_lu_gp_by_name(const char *name)
{
	struct t10_alua_lu_gp *lu_gp;
	struct config_item *ci;

1316 1317
	spin_lock(&lu_gps_lock);
	list_for_each_entry(lu_gp, &lu_gps_list, lu_gp_node) {
1318
		if (!lu_gp->lu_gp_valid_id)
1319 1320
			continue;
		ci = &lu_gp->lu_gp_group.cg_item;
1321
		if (!strcmp(config_item_name(ci), name)) {
1322
			atomic_inc(&lu_gp->lu_gp_ref_cnt);
1323
			spin_unlock(&lu_gps_lock);
1324 1325 1326
			return lu_gp;
		}
	}
1327
	spin_unlock(&lu_gps_lock);
1328 1329 1330 1331 1332 1333

	return NULL;
}

void core_alua_put_lu_gp_from_name(struct t10_alua_lu_gp *lu_gp)
{
1334
	spin_lock(&lu_gps_lock);
1335
	atomic_dec(&lu_gp->lu_gp_ref_cnt);
1336
	spin_unlock(&lu_gps_lock);
1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368
}

/*
 * Called with struct t10_alua_lu_gp_member->lu_gp_mem_lock
 */
void __core_alua_attach_lu_gp_mem(
	struct t10_alua_lu_gp_member *lu_gp_mem,
	struct t10_alua_lu_gp *lu_gp)
{
	spin_lock(&lu_gp->lu_gp_lock);
	lu_gp_mem->lu_gp = lu_gp;
	lu_gp_mem->lu_gp_assoc = 1;
	list_add_tail(&lu_gp_mem->lu_gp_mem_list, &lu_gp->lu_gp_mem_list);
	lu_gp->lu_gp_members++;
	spin_unlock(&lu_gp->lu_gp_lock);
}

/*
 * Called with struct t10_alua_lu_gp_member->lu_gp_mem_lock
 */
void __core_alua_drop_lu_gp_mem(
	struct t10_alua_lu_gp_member *lu_gp_mem,
	struct t10_alua_lu_gp *lu_gp)
{
	spin_lock(&lu_gp->lu_gp_lock);
	list_del(&lu_gp_mem->lu_gp_mem_list);
	lu_gp_mem->lu_gp = NULL;
	lu_gp_mem->lu_gp_assoc = 0;
	lu_gp->lu_gp_members--;
	spin_unlock(&lu_gp->lu_gp_lock);
}

1369 1370
struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp(struct se_device *dev,
		const char *name, int def_group)
1371 1372 1373 1374
{
	struct t10_alua_tg_pt_gp *tg_pt_gp;

	tg_pt_gp = kmem_cache_zalloc(t10_alua_tg_pt_gp_cache, GFP_KERNEL);
1375 1376
	if (!tg_pt_gp) {
		pr_err("Unable to allocate struct t10_alua_tg_pt_gp\n");
1377 1378 1379 1380 1381 1382 1383
		return NULL;
	}
	INIT_LIST_HEAD(&tg_pt_gp->tg_pt_gp_list);
	INIT_LIST_HEAD(&tg_pt_gp->tg_pt_gp_mem_list);
	mutex_init(&tg_pt_gp->tg_pt_gp_md_mutex);
	spin_lock_init(&tg_pt_gp->tg_pt_gp_lock);
	atomic_set(&tg_pt_gp->tg_pt_gp_ref_cnt, 0);
1384
	tg_pt_gp->tg_pt_gp_dev = dev;
1385 1386
	tg_pt_gp->tg_pt_gp_md_buf_len = ALUA_MD_BUF_LEN;
	atomic_set(&tg_pt_gp->tg_pt_gp_alua_access_state,
1387
		ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED);
1388
	/*
1389
	 * Enable both explicit and implicit ALUA support by default
1390 1391
	 */
	tg_pt_gp->tg_pt_gp_alua_access_type =
1392
			TPGS_EXPLICIT_ALUA | TPGS_IMPLICIT_ALUA;
1393 1394 1395 1396 1397
	/*
	 * Set the default Active/NonOptimized Delay in milliseconds
	 */
	tg_pt_gp->tg_pt_gp_nonop_delay_msecs = ALUA_DEFAULT_NONOP_DELAY_MSECS;
	tg_pt_gp->tg_pt_gp_trans_delay_msecs = ALUA_DEFAULT_TRANS_DELAY_MSECS;
1398
	tg_pt_gp->tg_pt_gp_implicit_trans_secs = ALUA_DEFAULT_IMPLICIT_TRANS_SECS;
1399

1400 1401 1402 1403 1404 1405 1406
	/*
	 * Enable all supported states
	 */
	tg_pt_gp->tg_pt_gp_alua_supported_states =
	    ALUA_T_SUP | ALUA_O_SUP |
	    ALUA_U_SUP | ALUA_S_SUP | ALUA_AN_SUP | ALUA_AO_SUP;

1407
	if (def_group) {
1408
		spin_lock(&dev->t10_alua.tg_pt_gps_lock);
1409
		tg_pt_gp->tg_pt_gp_id =
1410
				dev->t10_alua.alua_tg_pt_gps_counter++;
1411
		tg_pt_gp->tg_pt_gp_valid_id = 1;
1412
		dev->t10_alua.alua_tg_pt_gps_count++;
1413
		list_add_tail(&tg_pt_gp->tg_pt_gp_list,
1414 1415
			      &dev->t10_alua.tg_pt_gps_list);
		spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1416 1417 1418 1419 1420 1421 1422 1423 1424
	}

	return tg_pt_gp;
}

int core_alua_set_tg_pt_gp_id(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	u16 tg_pt_gp_id)
{
1425
	struct se_device *dev = tg_pt_gp->tg_pt_gp_dev;
1426 1427
	struct t10_alua_tg_pt_gp *tg_pt_gp_tmp;
	u16 tg_pt_gp_id_tmp;
1428

1429 1430 1431 1432
	/*
	 * The tg_pt_gp->tg_pt_gp_id may only be set once..
	 */
	if (tg_pt_gp->tg_pt_gp_valid_id) {
1433
		pr_warn("ALUA TG PT Group already has a valid ID,"
1434
			" ignoring request\n");
1435
		return -EINVAL;
1436 1437
	}

1438 1439
	spin_lock(&dev->t10_alua.tg_pt_gps_lock);
	if (dev->t10_alua.alua_tg_pt_gps_count == 0x0000ffff) {
1440
		pr_err("Maximum ALUA alua_tg_pt_gps_count:"
1441
			" 0x0000ffff reached\n");
1442
		spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1443
		kmem_cache_free(t10_alua_tg_pt_gp_cache, tg_pt_gp);
1444
		return -ENOSPC;
1445 1446 1447
	}
again:
	tg_pt_gp_id_tmp = (tg_pt_gp_id != 0) ? tg_pt_gp_id :
1448
			dev->t10_alua.alua_tg_pt_gps_counter++;
1449

1450
	list_for_each_entry(tg_pt_gp_tmp, &dev->t10_alua.tg_pt_gps_list,
1451 1452
			tg_pt_gp_list) {
		if (tg_pt_gp_tmp->tg_pt_gp_id == tg_pt_gp_id_tmp) {
1453
			if (!tg_pt_gp_id)
1454 1455
				goto again;

1456
			pr_err("ALUA Target Port Group ID: %hu already"
1457
				" exists, ignoring request\n", tg_pt_gp_id);
1458
			spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1459
			return -EINVAL;
1460 1461 1462 1463 1464 1465
		}
	}

	tg_pt_gp->tg_pt_gp_id = tg_pt_gp_id_tmp;
	tg_pt_gp->tg_pt_gp_valid_id = 1;
	list_add_tail(&tg_pt_gp->tg_pt_gp_list,
1466 1467 1468
			&dev->t10_alua.tg_pt_gps_list);
	dev->t10_alua.alua_tg_pt_gps_count++;
	spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479

	return 0;
}

struct t10_alua_tg_pt_gp_member *core_alua_allocate_tg_pt_gp_mem(
	struct se_port *port)
{
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem;

	tg_pt_gp_mem = kmem_cache_zalloc(t10_alua_tg_pt_gp_mem_cache,
				GFP_KERNEL);
1480 1481
	if (!tg_pt_gp_mem) {
		pr_err("Unable to allocate struct t10_alua_tg_pt_gp_member\n");
1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496
		return ERR_PTR(-ENOMEM);
	}
	INIT_LIST_HEAD(&tg_pt_gp_mem->tg_pt_gp_mem_list);
	spin_lock_init(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	atomic_set(&tg_pt_gp_mem->tg_pt_gp_mem_ref_cnt, 0);

	tg_pt_gp_mem->tg_pt = port;
	port->sep_alua_tg_pt_gp_mem = tg_pt_gp_mem;

	return tg_pt_gp_mem;
}

void core_alua_free_tg_pt_gp(
	struct t10_alua_tg_pt_gp *tg_pt_gp)
{
1497
	struct se_device *dev = tg_pt_gp->tg_pt_gp_dev;
1498
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem, *tg_pt_gp_mem_tmp;
1499

1500 1501 1502 1503 1504
	/*
	 * Once we have reached this point, config_item_put() has already
	 * been called from target_core_alua_drop_tg_pt_gp().
	 *
	 * Here we remove *tg_pt_gp from the global list so that
H
Hannes Reinecke 已提交
1505
	 * no associations *OR* explicit ALUA via SET_TARGET_PORT_GROUPS
1506 1507
	 * can be made while we are releasing struct t10_alua_tg_pt_gp.
	 */
1508
	spin_lock(&dev->t10_alua.tg_pt_gps_lock);
1509
	list_del(&tg_pt_gp->tg_pt_gp_list);
1510 1511 1512
	dev->t10_alua.alua_tg_pt_gps_counter--;
	spin_unlock(&dev->t10_alua.tg_pt_gps_lock);

1513 1514 1515 1516 1517 1518 1519 1520
	/*
	 * Allow a struct t10_alua_tg_pt_gp_member * referenced by
	 * core_alua_get_tg_pt_gp_by_name() in
	 * target_core_configfs.c:target_core_store_alua_tg_pt_gp()
	 * to be released with core_alua_put_tg_pt_gp_from_name().
	 */
	while (atomic_read(&tg_pt_gp->tg_pt_gp_ref_cnt))
		cpu_relax();
1521

1522 1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535
	/*
	 * Release reference to struct t10_alua_tg_pt_gp from all associated
	 * struct se_port.
	 */
	spin_lock(&tg_pt_gp->tg_pt_gp_lock);
	list_for_each_entry_safe(tg_pt_gp_mem, tg_pt_gp_mem_tmp,
			&tg_pt_gp->tg_pt_gp_mem_list, tg_pt_gp_mem_list) {
		if (tg_pt_gp_mem->tg_pt_gp_assoc) {
			list_del(&tg_pt_gp_mem->tg_pt_gp_mem_list);
			tg_pt_gp->tg_pt_gp_members--;
			tg_pt_gp_mem->tg_pt_gp_assoc = 0;
		}
		spin_unlock(&tg_pt_gp->tg_pt_gp_lock);
		/*
L
Lucas De Marchi 已提交
1536
		 * tg_pt_gp_mem is associated with a single
1537 1538 1539 1540
		 * se_port->sep_alua_tg_pt_gp_mem, and is released via
		 * core_alua_free_tg_pt_gp_mem().
		 *
		 * If the passed tg_pt_gp does NOT match the default_tg_pt_gp,
H
Hannes Reinecke 已提交
1541
		 * assume we want to re-associate a given tg_pt_gp_mem with
1542 1543 1544
		 * default_tg_pt_gp.
		 */
		spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
1545
		if (tg_pt_gp != dev->t10_alua.default_tg_pt_gp) {
1546
			__core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem,
1547
					dev->t10_alua.default_tg_pt_gp);
1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564
		} else
			tg_pt_gp_mem->tg_pt_gp = NULL;
		spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);

		spin_lock(&tg_pt_gp->tg_pt_gp_lock);
	}
	spin_unlock(&tg_pt_gp->tg_pt_gp_lock);

	kmem_cache_free(t10_alua_tg_pt_gp_cache, tg_pt_gp);
}

void core_alua_free_tg_pt_gp_mem(struct se_port *port)
{
	struct t10_alua_tg_pt_gp *tg_pt_gp;
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem;

	tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem;
1565
	if (!tg_pt_gp_mem)
1566 1567 1568 1569 1570 1571 1572
		return;

	while (atomic_read(&tg_pt_gp_mem->tg_pt_gp_mem_ref_cnt))
		cpu_relax();

	spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	tg_pt_gp = tg_pt_gp_mem->tg_pt_gp;
1573
	if (tg_pt_gp) {
1574 1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588
		spin_lock(&tg_pt_gp->tg_pt_gp_lock);
		if (tg_pt_gp_mem->tg_pt_gp_assoc) {
			list_del(&tg_pt_gp_mem->tg_pt_gp_mem_list);
			tg_pt_gp->tg_pt_gp_members--;
			tg_pt_gp_mem->tg_pt_gp_assoc = 0;
		}
		spin_unlock(&tg_pt_gp->tg_pt_gp_lock);
		tg_pt_gp_mem->tg_pt_gp = NULL;
	}
	spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);

	kmem_cache_free(t10_alua_tg_pt_gp_mem_cache, tg_pt_gp_mem);
}

static struct t10_alua_tg_pt_gp *core_alua_get_tg_pt_gp_by_name(
1589
		struct se_device *dev, const char *name)
1590 1591 1592 1593
{
	struct t10_alua_tg_pt_gp *tg_pt_gp;
	struct config_item *ci;

1594 1595
	spin_lock(&dev->t10_alua.tg_pt_gps_lock);
	list_for_each_entry(tg_pt_gp, &dev->t10_alua.tg_pt_gps_list,
1596
			tg_pt_gp_list) {
1597
		if (!tg_pt_gp->tg_pt_gp_valid_id)
1598 1599
			continue;
		ci = &tg_pt_gp->tg_pt_gp_group.cg_item;
1600
		if (!strcmp(config_item_name(ci), name)) {
1601
			atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt);
1602
			spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1603 1604 1605
			return tg_pt_gp;
		}
	}
1606
	spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1607 1608 1609 1610 1611 1612 1613

	return NULL;
}

static void core_alua_put_tg_pt_gp_from_name(
	struct t10_alua_tg_pt_gp *tg_pt_gp)
{
1614
	struct se_device *dev = tg_pt_gp->tg_pt_gp_dev;
1615

1616
	spin_lock(&dev->t10_alua.tg_pt_gps_lock);
1617
	atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt);
1618
	spin_unlock(&dev->t10_alua.tg_pt_gps_lock);
1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659
}

/*
 * Called with struct t10_alua_tg_pt_gp_member->tg_pt_gp_mem_lock held
 */
void __core_alua_attach_tg_pt_gp_mem(
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem,
	struct t10_alua_tg_pt_gp *tg_pt_gp)
{
	spin_lock(&tg_pt_gp->tg_pt_gp_lock);
	tg_pt_gp_mem->tg_pt_gp = tg_pt_gp;
	tg_pt_gp_mem->tg_pt_gp_assoc = 1;
	list_add_tail(&tg_pt_gp_mem->tg_pt_gp_mem_list,
			&tg_pt_gp->tg_pt_gp_mem_list);
	tg_pt_gp->tg_pt_gp_members++;
	spin_unlock(&tg_pt_gp->tg_pt_gp_lock);
}

/*
 * Called with struct t10_alua_tg_pt_gp_member->tg_pt_gp_mem_lock held
 */
static void __core_alua_drop_tg_pt_gp_mem(
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem,
	struct t10_alua_tg_pt_gp *tg_pt_gp)
{
	spin_lock(&tg_pt_gp->tg_pt_gp_lock);
	list_del(&tg_pt_gp_mem->tg_pt_gp_mem_list);
	tg_pt_gp_mem->tg_pt_gp = NULL;
	tg_pt_gp_mem->tg_pt_gp_assoc = 0;
	tg_pt_gp->tg_pt_gp_members--;
	spin_unlock(&tg_pt_gp->tg_pt_gp_lock);
}

ssize_t core_alua_show_tg_pt_gp_info(struct se_port *port, char *page)
{
	struct config_item *tg_pt_ci;
	struct t10_alua_tg_pt_gp *tg_pt_gp;
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem;
	ssize_t len = 0;

	tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem;
1660
	if (!tg_pt_gp_mem)
1661 1662 1663 1664
		return len;

	spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	tg_pt_gp = tg_pt_gp_mem->tg_pt_gp;
1665
	if (tg_pt_gp) {
1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676 1677 1678 1679 1680 1681 1682 1683 1684 1685 1686 1687 1688 1689 1690 1691
		tg_pt_ci = &tg_pt_gp->tg_pt_gp_group.cg_item;
		len += sprintf(page, "TG Port Alias: %s\nTG Port Group ID:"
			" %hu\nTG Port Primary Access State: %s\nTG Port "
			"Primary Access Status: %s\nTG Port Secondary Access"
			" State: %s\nTG Port Secondary Access Status: %s\n",
			config_item_name(tg_pt_ci), tg_pt_gp->tg_pt_gp_id,
			core_alua_dump_state(atomic_read(
					&tg_pt_gp->tg_pt_gp_alua_access_state)),
			core_alua_dump_status(
				tg_pt_gp->tg_pt_gp_alua_access_status),
			(atomic_read(&port->sep_tg_pt_secondary_offline)) ?
			"Offline" : "None",
			core_alua_dump_status(port->sep_tg_pt_secondary_stat));
	}
	spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);

	return len;
}

ssize_t core_alua_store_tg_pt_gp_info(
	struct se_port *port,
	const char *page,
	size_t count)
{
	struct se_portal_group *tpg;
	struct se_lun *lun;
1692
	struct se_device *dev = port->sep_lun->lun_se_dev;
1693 1694 1695 1696 1697 1698 1699 1700
	struct t10_alua_tg_pt_gp *tg_pt_gp = NULL, *tg_pt_gp_new = NULL;
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem;
	unsigned char buf[TG_PT_GROUP_NAME_BUF];
	int move = 0;

	tpg = port->sep_tpg;
	lun = port->sep_lun;

C
Christoph Hellwig 已提交
1701 1702 1703
	tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem;
	if (!tg_pt_gp_mem)
		return 0;
1704 1705

	if (count > TG_PT_GROUP_NAME_BUF) {
1706
		pr_err("ALUA Target Port Group alias too large!\n");
1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720
		return -EINVAL;
	}
	memset(buf, 0, TG_PT_GROUP_NAME_BUF);
	memcpy(buf, page, count);
	/*
	 * Any ALUA target port group alias besides "NULL" means we will be
	 * making a new group association.
	 */
	if (strcmp(strstrip(buf), "NULL")) {
		/*
		 * core_alua_get_tg_pt_gp_by_name() will increment reference to
		 * struct t10_alua_tg_pt_gp.  This reference is released with
		 * core_alua_put_tg_pt_gp_from_name() below.
		 */
1721
		tg_pt_gp_new = core_alua_get_tg_pt_gp_by_name(dev,
1722
					strstrip(buf));
1723
		if (!tg_pt_gp_new)
1724 1725 1726 1727 1728
			return -ENODEV;
	}

	spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
	tg_pt_gp = tg_pt_gp_mem->tg_pt_gp;
1729
	if (tg_pt_gp) {
1730 1731 1732 1733
		/*
		 * Clearing an existing tg_pt_gp association, and replacing
		 * with the default_tg_pt_gp.
		 */
1734 1735
		if (!tg_pt_gp_new) {
			pr_debug("Target_Core_ConfigFS: Moving"
1736 1737 1738
				" %s/tpgt_%hu/%s from ALUA Target Port Group:"
				" alua/%s, ID: %hu back to"
				" default_tg_pt_gp\n",
1739 1740
				tpg->se_tpg_tfo->tpg_get_wwn(tpg),
				tpg->se_tpg_tfo->tpg_get_tag(tpg),
1741 1742 1743 1744 1745 1746 1747
				config_item_name(&lun->lun_group.cg_item),
				config_item_name(
					&tg_pt_gp->tg_pt_gp_group.cg_item),
				tg_pt_gp->tg_pt_gp_id);

			__core_alua_drop_tg_pt_gp_mem(tg_pt_gp_mem, tg_pt_gp);
			__core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem,
1748
					dev->t10_alua.default_tg_pt_gp);
1749 1750 1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763
			spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);

			return count;
		}
		/*
		 * Removing existing association of tg_pt_gp_mem with tg_pt_gp
		 */
		__core_alua_drop_tg_pt_gp_mem(tg_pt_gp_mem, tg_pt_gp);
		move = 1;
	}
	/*
	 * Associate tg_pt_gp_mem with tg_pt_gp_new.
	 */
	__core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem, tg_pt_gp_new);
	spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
1764
	pr_debug("Target_Core_ConfigFS: %s %s/tpgt_%hu/%s to ALUA"
1765
		" Target Port Group: alua/%s, ID: %hu\n", (move) ?
1766 1767
		"Moving" : "Adding", tpg->se_tpg_tfo->tpg_get_wwn(tpg),
		tpg->se_tpg_tfo->tpg_get_tag(tpg),
1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779
		config_item_name(&lun->lun_group.cg_item),
		config_item_name(&tg_pt_gp_new->tg_pt_gp_group.cg_item),
		tg_pt_gp_new->tg_pt_gp_id);

	core_alua_put_tg_pt_gp_from_name(tg_pt_gp_new);
	return count;
}

ssize_t core_alua_show_access_type(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	char *page)
{
1780 1781 1782 1783 1784 1785 1786
	if ((tg_pt_gp->tg_pt_gp_alua_access_type & TPGS_EXPLICIT_ALUA) &&
	    (tg_pt_gp->tg_pt_gp_alua_access_type & TPGS_IMPLICIT_ALUA))
		return sprintf(page, "Implicit and Explicit\n");
	else if (tg_pt_gp->tg_pt_gp_alua_access_type & TPGS_IMPLICIT_ALUA)
		return sprintf(page, "Implicit\n");
	else if (tg_pt_gp->tg_pt_gp_alua_access_type & TPGS_EXPLICIT_ALUA)
		return sprintf(page, "Explicit\n");
1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797 1798
	else
		return sprintf(page, "None\n");
}

ssize_t core_alua_store_access_type(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	const char *page,
	size_t count)
{
	unsigned long tmp;
	int ret;

1799
	ret = kstrtoul(page, 0, &tmp);
1800
	if (ret < 0) {
1801
		pr_err("Unable to extract alua_access_type\n");
1802
		return ret;
1803 1804
	}
	if ((tmp != 0) && (tmp != 1) && (tmp != 2) && (tmp != 3)) {
1805
		pr_err("Illegal value for alua_access_type:"
1806 1807 1808 1809 1810
				" %lu\n", tmp);
		return -EINVAL;
	}
	if (tmp == 3)
		tg_pt_gp->tg_pt_gp_alua_access_type =
1811
			TPGS_IMPLICIT_ALUA | TPGS_EXPLICIT_ALUA;
1812
	else if (tmp == 2)
1813
		tg_pt_gp->tg_pt_gp_alua_access_type = TPGS_EXPLICIT_ALUA;
1814
	else if (tmp == 1)
1815
		tg_pt_gp->tg_pt_gp_alua_access_type = TPGS_IMPLICIT_ALUA;
1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 1836
	else
		tg_pt_gp->tg_pt_gp_alua_access_type = 0;

	return count;
}

ssize_t core_alua_show_nonop_delay_msecs(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	char *page)
{
	return sprintf(page, "%d\n", tg_pt_gp->tg_pt_gp_nonop_delay_msecs);
}

ssize_t core_alua_store_nonop_delay_msecs(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	const char *page,
	size_t count)
{
	unsigned long tmp;
	int ret;

1837
	ret = kstrtoul(page, 0, &tmp);
1838
	if (ret < 0) {
1839
		pr_err("Unable to extract nonop_delay_msecs\n");
1840
		return ret;
1841 1842
	}
	if (tmp > ALUA_MAX_NONOP_DELAY_MSECS) {
1843
		pr_err("Passed nonop_delay_msecs: %lu, exceeds"
1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867
			" ALUA_MAX_NONOP_DELAY_MSECS: %d\n", tmp,
			ALUA_MAX_NONOP_DELAY_MSECS);
		return -EINVAL;
	}
	tg_pt_gp->tg_pt_gp_nonop_delay_msecs = (int)tmp;

	return count;
}

ssize_t core_alua_show_trans_delay_msecs(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	char *page)
{
	return sprintf(page, "%d\n", tg_pt_gp->tg_pt_gp_trans_delay_msecs);
}

ssize_t core_alua_store_trans_delay_msecs(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	const char *page,
	size_t count)
{
	unsigned long tmp;
	int ret;

1868
	ret = kstrtoul(page, 0, &tmp);
1869
	if (ret < 0) {
1870
		pr_err("Unable to extract trans_delay_msecs\n");
1871
		return ret;
1872 1873
	}
	if (tmp > ALUA_MAX_TRANS_DELAY_MSECS) {
1874
		pr_err("Passed trans_delay_msecs: %lu, exceeds"
1875 1876 1877 1878 1879 1880 1881 1882 1883
			" ALUA_MAX_TRANS_DELAY_MSECS: %d\n", tmp,
			ALUA_MAX_TRANS_DELAY_MSECS);
		return -EINVAL;
	}
	tg_pt_gp->tg_pt_gp_trans_delay_msecs = (int)tmp;

	return count;
}

1884
ssize_t core_alua_show_implicit_trans_secs(
1885 1886 1887
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	char *page)
{
1888
	return sprintf(page, "%d\n", tg_pt_gp->tg_pt_gp_implicit_trans_secs);
1889 1890
}

1891
ssize_t core_alua_store_implicit_trans_secs(
1892 1893 1894 1895 1896 1897 1898
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	const char *page,
	size_t count)
{
	unsigned long tmp;
	int ret;

1899
	ret = kstrtoul(page, 0, &tmp);
1900
	if (ret < 0) {
1901
		pr_err("Unable to extract implicit_trans_secs\n");
1902
		return ret;
1903
	}
1904 1905 1906 1907
	if (tmp > ALUA_MAX_IMPLICIT_TRANS_SECS) {
		pr_err("Passed implicit_trans_secs: %lu, exceeds"
			" ALUA_MAX_IMPLICIT_TRANS_SECS: %d\n", tmp,
			ALUA_MAX_IMPLICIT_TRANS_SECS);
1908 1909
		return  -EINVAL;
	}
1910
	tg_pt_gp->tg_pt_gp_implicit_trans_secs = (int)tmp;
1911 1912 1913 1914

	return count;
}

1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929
ssize_t core_alua_show_preferred_bit(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	char *page)
{
	return sprintf(page, "%d\n", tg_pt_gp->tg_pt_gp_pref);
}

ssize_t core_alua_store_preferred_bit(
	struct t10_alua_tg_pt_gp *tg_pt_gp,
	const char *page,
	size_t count)
{
	unsigned long tmp;
	int ret;

1930
	ret = kstrtoul(page, 0, &tmp);
1931
	if (ret < 0) {
1932
		pr_err("Unable to extract preferred ALUA value\n");
1933
		return ret;
1934 1935
	}
	if ((tmp != 0) && (tmp != 1)) {
1936
		pr_err("Illegal value for preferred ALUA: %lu\n", tmp);
1937 1938 1939 1940 1941 1942 1943 1944 1945
		return -EINVAL;
	}
	tg_pt_gp->tg_pt_gp_pref = (int)tmp;

	return count;
}

ssize_t core_alua_show_offline_bit(struct se_lun *lun, char *page)
{
1946
	if (!lun->lun_sep)
1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961
		return -ENODEV;

	return sprintf(page, "%d\n",
		atomic_read(&lun->lun_sep->sep_tg_pt_secondary_offline));
}

ssize_t core_alua_store_offline_bit(
	struct se_lun *lun,
	const char *page,
	size_t count)
{
	struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem;
	unsigned long tmp;
	int ret;

1962
	if (!lun->lun_sep)
1963 1964
		return -ENODEV;

1965
	ret = kstrtoul(page, 0, &tmp);
1966
	if (ret < 0) {
1967
		pr_err("Unable to extract alua_tg_pt_offline value\n");
1968
		return ret;
1969 1970
	}
	if ((tmp != 0) && (tmp != 1)) {
1971
		pr_err("Illegal value for alua_tg_pt_offline: %lu\n",
1972 1973 1974 1975
				tmp);
		return -EINVAL;
	}
	tg_pt_gp_mem = lun->lun_sep->sep_alua_tg_pt_gp_mem;
1976 1977
	if (!tg_pt_gp_mem) {
		pr_err("Unable to locate *tg_pt_gp_mem\n");
1978 1979 1980 1981 1982 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003
		return -EINVAL;
	}

	ret = core_alua_set_tg_pt_secondary_state(tg_pt_gp_mem,
			lun->lun_sep, 0, (int)tmp);
	if (ret < 0)
		return -EINVAL;

	return count;
}

ssize_t core_alua_show_secondary_status(
	struct se_lun *lun,
	char *page)
{
	return sprintf(page, "%d\n", lun->lun_sep->sep_tg_pt_secondary_stat);
}

ssize_t core_alua_store_secondary_status(
	struct se_lun *lun,
	const char *page,
	size_t count)
{
	unsigned long tmp;
	int ret;

2004
	ret = kstrtoul(page, 0, &tmp);
2005
	if (ret < 0) {
2006
		pr_err("Unable to extract alua_tg_pt_status\n");
2007
		return ret;
2008 2009
	}
	if ((tmp != ALUA_STATUS_NONE) &&
2010 2011
	    (tmp != ALUA_STATUS_ALTERED_BY_EXPLICIT_STPG) &&
	    (tmp != ALUA_STATUS_ALTERED_BY_IMPLICIT_ALUA)) {
2012
		pr_err("Illegal value for alua_tg_pt_status: %lu\n",
2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036
				tmp);
		return -EINVAL;
	}
	lun->lun_sep->sep_tg_pt_secondary_stat = (int)tmp;

	return count;
}

ssize_t core_alua_show_secondary_write_metadata(
	struct se_lun *lun,
	char *page)
{
	return sprintf(page, "%d\n",
			lun->lun_sep->sep_tg_pt_secondary_write_md);
}

ssize_t core_alua_store_secondary_write_metadata(
	struct se_lun *lun,
	const char *page,
	size_t count)
{
	unsigned long tmp;
	int ret;

2037
	ret = kstrtoul(page, 0, &tmp);
2038
	if (ret < 0) {
2039
		pr_err("Unable to extract alua_tg_pt_write_md\n");
2040
		return ret;
2041 2042
	}
	if ((tmp != 0) && (tmp != 1)) {
2043
		pr_err("Illegal value for alua_tg_pt_write_md:"
2044 2045 2046 2047 2048 2049 2050 2051
				" %lu\n", tmp);
		return -EINVAL;
	}
	lun->lun_sep->sep_tg_pt_secondary_write_md = (int)tmp;

	return count;
}

2052
int core_setup_alua(struct se_device *dev)
2053
{
C
Christoph Hellwig 已提交
2054 2055 2056
	if (dev->transport->transport_type != TRANSPORT_PLUGIN_PHBA_PDEV &&
	    !(dev->se_hba->hba_flags & HBA_FLAGS_INTERNAL_USE)) {
		struct t10_alua_lu_gp_member *lu_gp_mem;
2057

2058
		/*
L
Lucas De Marchi 已提交
2059
		 * Associate this struct se_device with the default ALUA
2060 2061 2062
		 * LUN Group.
		 */
		lu_gp_mem = core_alua_allocate_lu_gp_mem(dev);
2063 2064
		if (IS_ERR(lu_gp_mem))
			return PTR_ERR(lu_gp_mem);
2065 2066 2067

		spin_lock(&lu_gp_mem->lu_gp_mem_lock);
		__core_alua_attach_lu_gp_mem(lu_gp_mem,
2068
				default_lu_gp);
2069 2070
		spin_unlock(&lu_gp_mem->lu_gp_mem_lock);

2071
		pr_debug("%s: Adding to default ALUA LU Group:"
2072
			" core/alua/lu_gps/default_lu_gp\n",
2073
			dev->transport->name);
2074 2075 2076 2077
	}

	return 0;
}