blob: fc9637cce82564dfb2d8b83b160cf1cd8c8b5760 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -08002#ifndef TARGET_CORE_ALUA_H
3#define TARGET_CORE_ALUA_H
4
Bart Van Assche8dcf07b2016-11-14 15:47:14 -08005#include <target/target_core_base.h>
6
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -08007/*
8 * INQUIRY response data, TPGS Field
9 *
10 * from spc4r17 section 6.4.2 Table 135
11 */
12#define TPGS_NO_ALUA 0x00
Hannes Reinecke125d0112013-11-19 09:07:46 +010013#define TPGS_IMPLICIT_ALUA 0x10
14#define TPGS_EXPLICIT_ALUA 0x20
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080015
16/*
17 * ASYMMETRIC ACCESS STATE field
18 *
Hannes Reineckec66094b2013-12-17 09:18:49 +010019 * from spc4r36j section 6.37 Table 307
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080020 */
Hannes Reinecke73f3bf52013-11-19 09:07:48 +010021#define ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED 0x0
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080022#define ALUA_ACCESS_STATE_ACTIVE_NON_OPTIMIZED 0x1
23#define ALUA_ACCESS_STATE_STANDBY 0x2
24#define ALUA_ACCESS_STATE_UNAVAILABLE 0x3
Hannes Reineckec66094b2013-12-17 09:18:49 +010025#define ALUA_ACCESS_STATE_LBA_DEPENDENT 0x4
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080026#define ALUA_ACCESS_STATE_OFFLINE 0xe
27#define ALUA_ACCESS_STATE_TRANSITION 0xf
28
29/*
Hannes Reineckec0dc9412013-11-19 09:07:49 +010030 * from spc4r36j section 6.37 Table 306
31 */
32#define ALUA_T_SUP 0x80
33#define ALUA_O_SUP 0x40
34#define ALUA_LBD_SUP 0x10
35#define ALUA_U_SUP 0x08
36#define ALUA_S_SUP 0x04
37#define ALUA_AN_SUP 0x02
38#define ALUA_AO_SUP 0x01
39
40/*
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080041 * REPORT_TARGET_PORT_GROUP STATUS CODE
42 *
43 * from spc4r17 section 6.27 Table 246
44 */
45#define ALUA_STATUS_NONE 0x00
Hannes Reinecke125d0112013-11-19 09:07:46 +010046#define ALUA_STATUS_ALTERED_BY_EXPLICIT_STPG 0x01
47#define ALUA_STATUS_ALTERED_BY_IMPLICIT_ALUA 0x02
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080048
49/*
50 * From spc4r17, Table D.1: ASC and ASCQ Assignement
51 */
52#define ASCQ_04H_ALUA_STATE_TRANSITION 0x0a
53#define ASCQ_04H_ALUA_TG_PT_STANDBY 0x0b
54#define ASCQ_04H_ALUA_TG_PT_UNAVAILABLE 0x0c
55#define ASCQ_04H_ALUA_OFFLINE 0x12
56
57/*
58 * Used as the default for Active/NonOptimized delay (in milliseconds)
59 * This can also be changed via configfs on a per target port group basis..
60 */
61#define ALUA_DEFAULT_NONOP_DELAY_MSECS 100
62#define ALUA_MAX_NONOP_DELAY_MSECS 10000 /* 10 seconds */
63/*
Hannes Reinecke125d0112013-11-19 09:07:46 +010064 * Used for implicit and explicit ALUA transitional delay, that is disabled
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080065 * by default, and is intended to be used for debugging client side ALUA code.
66 */
67#define ALUA_DEFAULT_TRANS_DELAY_MSECS 0
68#define ALUA_MAX_TRANS_DELAY_MSECS 30000 /* 30 seconds */
69/*
Hannes Reinecke125d0112013-11-19 09:07:46 +010070 * Used for the recommended application client implicit transition timeout
Nicholas Bellinger5b9a4d72012-05-16 22:02:34 -070071 * in seconds, returned by the REPORT_TARGET_PORT_GROUPS w/ extended header.
72 */
Hannes Reinecke125d0112013-11-19 09:07:46 +010073#define ALUA_DEFAULT_IMPLICIT_TRANS_SECS 0
74#define ALUA_MAX_IMPLICIT_TRANS_SECS 255
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080075
Hannes Reinecke1e0b9402013-12-17 09:18:44 +010076/* Used by core_alua_update_tpg_(primary,secondary)_metadata */
77#define ALUA_MD_BUF_LEN 1024
78
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080079extern struct kmem_cache *t10_alua_lu_gp_cache;
80extern struct kmem_cache *t10_alua_lu_gp_mem_cache;
81extern struct kmem_cache *t10_alua_tg_pt_gp_cache;
Hannes Reinecke229d4f12013-12-17 09:18:50 +010082extern struct kmem_cache *t10_alua_lba_map_cache;
83extern struct kmem_cache *t10_alua_lba_map_mem_cache;
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080084
Christoph Hellwigde103c92012-11-06 12:24:09 -080085extern sense_reason_t target_emulate_report_target_port_groups(struct se_cmd *);
86extern sense_reason_t target_emulate_set_target_port_groups(struct se_cmd *);
Hannes Reineckec66094b2013-12-17 09:18:49 +010087extern sense_reason_t target_emulate_report_referrals(struct se_cmd *);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080088extern int core_alua_check_nonop_delay(struct se_cmd *);
89extern int core_alua_do_port_transition(struct t10_alua_tg_pt_gp *,
Christoph Hellwigadf653f2015-05-25 21:33:08 -070090 struct se_device *, struct se_lun *,
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080091 struct se_node_acl *, int, int);
92extern char *core_alua_dump_status(int);
Hannes Reinecke229d4f12013-12-17 09:18:50 +010093extern struct t10_alua_lba_map *core_alua_allocate_lba_map(
94 struct list_head *, u64, u64);
95extern int core_alua_allocate_lba_map_mem(struct t10_alua_lba_map *, int, int);
96extern void core_alua_free_lba_map(struct list_head *);
97extern void core_alua_set_lba_map(struct se_device *, struct list_head *,
98 int, int);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080099extern struct t10_alua_lu_gp *core_alua_allocate_lu_gp(const char *, int);
100extern int core_alua_set_lu_gp_id(struct t10_alua_lu_gp *, u16);
101extern void core_alua_free_lu_gp(struct t10_alua_lu_gp *);
102extern void core_alua_free_lu_gp_mem(struct se_device *);
103extern struct t10_alua_lu_gp *core_alua_get_lu_gp_by_name(const char *);
104extern void core_alua_put_lu_gp_from_name(struct t10_alua_lu_gp *);
105extern void __core_alua_attach_lu_gp_mem(struct t10_alua_lu_gp_member *,
106 struct t10_alua_lu_gp *);
107extern void __core_alua_drop_lu_gp_mem(struct t10_alua_lu_gp_member *,
108 struct t10_alua_lu_gp *);
109extern void core_alua_drop_lu_gp_dev(struct se_device *);
110extern struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp(
Christoph Hellwig0fd97cc2012-10-08 00:03:19 -0400111 struct se_device *, const char *, int);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -0800112extern int core_alua_set_tg_pt_gp_id(struct t10_alua_tg_pt_gp *, u16);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -0800113extern void core_alua_free_tg_pt_gp(struct t10_alua_tg_pt_gp *);
Christoph Hellwigadf653f2015-05-25 21:33:08 -0700114extern void target_detach_tg_pt_gp(struct se_lun *);
115extern void target_attach_tg_pt_gp(struct se_lun *, struct t10_alua_tg_pt_gp *);
116extern ssize_t core_alua_show_tg_pt_gp_info(struct se_lun *, char *);
117extern ssize_t core_alua_store_tg_pt_gp_info(struct se_lun *, const char *,
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -0800118 size_t);
119extern ssize_t core_alua_show_access_type(struct t10_alua_tg_pt_gp *, char *);
120extern ssize_t core_alua_store_access_type(struct t10_alua_tg_pt_gp *,
121 const char *, size_t);
122extern ssize_t core_alua_show_nonop_delay_msecs(struct t10_alua_tg_pt_gp *,
123 char *);
124extern ssize_t core_alua_store_nonop_delay_msecs(struct t10_alua_tg_pt_gp *,
125 const char *, size_t);
126extern ssize_t core_alua_show_trans_delay_msecs(struct t10_alua_tg_pt_gp *,
127 char *);
128extern ssize_t core_alua_store_trans_delay_msecs(struct t10_alua_tg_pt_gp *,
129 const char *, size_t);
Hannes Reinecke125d0112013-11-19 09:07:46 +0100130extern ssize_t core_alua_show_implicit_trans_secs(struct t10_alua_tg_pt_gp *,
Nicholas Bellinger5b9a4d72012-05-16 22:02:34 -0700131 char *);
Hannes Reinecke125d0112013-11-19 09:07:46 +0100132extern ssize_t core_alua_store_implicit_trans_secs(struct t10_alua_tg_pt_gp *,
Nicholas Bellinger5b9a4d72012-05-16 22:02:34 -0700133 const char *, size_t);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -0800134extern ssize_t core_alua_show_preferred_bit(struct t10_alua_tg_pt_gp *,
135 char *);
136extern ssize_t core_alua_store_preferred_bit(struct t10_alua_tg_pt_gp *,
137 const char *, size_t);
138extern ssize_t core_alua_show_offline_bit(struct se_lun *, char *);
139extern ssize_t core_alua_store_offline_bit(struct se_lun *, const char *,
140 size_t);
141extern ssize_t core_alua_show_secondary_status(struct se_lun *, char *);
142extern ssize_t core_alua_store_secondary_status(struct se_lun *,
143 const char *, size_t);
144extern ssize_t core_alua_show_secondary_write_metadata(struct se_lun *,
145 char *);
146extern ssize_t core_alua_store_secondary_write_metadata(struct se_lun *,
147 const char *, size_t);
Christoph Hellwig0fd97cc2012-10-08 00:03:19 -0400148extern int core_setup_alua(struct se_device *);
Christoph Hellwigde103c92012-11-06 12:24:09 -0800149extern sense_reason_t target_alua_state_check(struct se_cmd *cmd);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -0800150
151#endif /* TARGET_CORE_ALUA_H */