blob: 1a152cd594712bda3ac3a987b98d803152133668 [file] [log] [blame]
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -08001#ifndef TARGET_CORE_ALUA_H
2#define TARGET_CORE_ALUA_H
3
4/*
5 * INQUIRY response data, TPGS Field
6 *
7 * from spc4r17 section 6.4.2 Table 135
8 */
9#define TPGS_NO_ALUA 0x00
Hannes Reinecke125d0112013-11-19 09:07:46 +010010#define TPGS_IMPLICIT_ALUA 0x10
11#define TPGS_EXPLICIT_ALUA 0x20
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080012
13/*
14 * ASYMMETRIC ACCESS STATE field
15 *
16 * from spc4r17 section 6.27 Table 245
17 */
Hannes Reinecke73f3bf52013-11-19 09:07:48 +010018#define ALUA_ACCESS_STATE_ACTIVE_OPTIMIZED 0x0
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080019#define ALUA_ACCESS_STATE_ACTIVE_NON_OPTIMIZED 0x1
20#define ALUA_ACCESS_STATE_STANDBY 0x2
21#define ALUA_ACCESS_STATE_UNAVAILABLE 0x3
22#define ALUA_ACCESS_STATE_OFFLINE 0xe
23#define ALUA_ACCESS_STATE_TRANSITION 0xf
24
25/*
Hannes Reineckec0dc9412013-11-19 09:07:49 +010026 * from spc4r36j section 6.37 Table 306
27 */
28#define ALUA_T_SUP 0x80
29#define ALUA_O_SUP 0x40
30#define ALUA_LBD_SUP 0x10
31#define ALUA_U_SUP 0x08
32#define ALUA_S_SUP 0x04
33#define ALUA_AN_SUP 0x02
34#define ALUA_AO_SUP 0x01
35
36/*
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080037 * REPORT_TARGET_PORT_GROUP STATUS CODE
38 *
39 * from spc4r17 section 6.27 Table 246
40 */
41#define ALUA_STATUS_NONE 0x00
Hannes Reinecke125d0112013-11-19 09:07:46 +010042#define ALUA_STATUS_ALTERED_BY_EXPLICIT_STPG 0x01
43#define ALUA_STATUS_ALTERED_BY_IMPLICIT_ALUA 0x02
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080044
45/*
46 * From spc4r17, Table D.1: ASC and ASCQ Assignement
47 */
48#define ASCQ_04H_ALUA_STATE_TRANSITION 0x0a
49#define ASCQ_04H_ALUA_TG_PT_STANDBY 0x0b
50#define ASCQ_04H_ALUA_TG_PT_UNAVAILABLE 0x0c
51#define ASCQ_04H_ALUA_OFFLINE 0x12
52
53/*
54 * Used as the default for Active/NonOptimized delay (in milliseconds)
55 * This can also be changed via configfs on a per target port group basis..
56 */
57#define ALUA_DEFAULT_NONOP_DELAY_MSECS 100
58#define ALUA_MAX_NONOP_DELAY_MSECS 10000 /* 10 seconds */
59/*
Hannes Reinecke125d0112013-11-19 09:07:46 +010060 * Used for implicit and explicit ALUA transitional delay, that is disabled
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080061 * by default, and is intended to be used for debugging client side ALUA code.
62 */
63#define ALUA_DEFAULT_TRANS_DELAY_MSECS 0
64#define ALUA_MAX_TRANS_DELAY_MSECS 30000 /* 30 seconds */
65/*
Hannes Reinecke125d0112013-11-19 09:07:46 +010066 * Used for the recommended application client implicit transition timeout
Nicholas Bellinger5b9a4d72012-05-16 22:02:34 -070067 * in seconds, returned by the REPORT_TARGET_PORT_GROUPS w/ extended header.
68 */
Hannes Reinecke125d0112013-11-19 09:07:46 +010069#define ALUA_DEFAULT_IMPLICIT_TRANS_SECS 0
70#define ALUA_MAX_IMPLICIT_TRANS_SECS 255
Nicholas Bellinger5b9a4d72012-05-16 22:02:34 -070071/*
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080072 * Used by core_alua_update_tpg_primary_metadata() and
73 * core_alua_update_tpg_secondary_metadata()
74 */
75#define ALUA_METADATA_PATH_LEN 512
76/*
77 * Used by core_alua_update_tpg_secondary_metadata()
78 */
79#define ALUA_SECONDARY_METADATA_WWN_LEN 256
80
Hannes Reinecke1e0b9402013-12-17 09:18:44 +010081/* Used by core_alua_update_tpg_(primary,secondary)_metadata */
82#define ALUA_MD_BUF_LEN 1024
83
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080084extern struct kmem_cache *t10_alua_lu_gp_cache;
85extern struct kmem_cache *t10_alua_lu_gp_mem_cache;
86extern struct kmem_cache *t10_alua_tg_pt_gp_cache;
87extern struct kmem_cache *t10_alua_tg_pt_gp_mem_cache;
88
Christoph Hellwigde103c92012-11-06 12:24:09 -080089extern sense_reason_t target_emulate_report_target_port_groups(struct se_cmd *);
90extern sense_reason_t target_emulate_set_target_port_groups(struct se_cmd *);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -080091extern int core_alua_check_nonop_delay(struct se_cmd *);
92extern int core_alua_do_port_transition(struct t10_alua_tg_pt_gp *,
93 struct se_device *, struct se_port *,
94 struct se_node_acl *, int, int);
95extern char *core_alua_dump_status(int);
96extern struct t10_alua_lu_gp *core_alua_allocate_lu_gp(const char *, int);
97extern int core_alua_set_lu_gp_id(struct t10_alua_lu_gp *, u16);
98extern void core_alua_free_lu_gp(struct t10_alua_lu_gp *);
99extern void core_alua_free_lu_gp_mem(struct se_device *);
100extern struct t10_alua_lu_gp *core_alua_get_lu_gp_by_name(const char *);
101extern void core_alua_put_lu_gp_from_name(struct t10_alua_lu_gp *);
102extern void __core_alua_attach_lu_gp_mem(struct t10_alua_lu_gp_member *,
103 struct t10_alua_lu_gp *);
104extern void __core_alua_drop_lu_gp_mem(struct t10_alua_lu_gp_member *,
105 struct t10_alua_lu_gp *);
106extern void core_alua_drop_lu_gp_dev(struct se_device *);
107extern struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp(
Christoph Hellwig0fd97cc2012-10-08 00:03:19 -0400108 struct se_device *, const char *, int);
Nicholas Bellingerc66ac9d2010-12-17 11:11:26 -0800109extern int core_alua_set_tg_pt_gp_id(struct t10_alua_tg_pt_gp *, u16);
110extern struct t10_alua_tg_pt_gp_member *core_alua_allocate_tg_pt_gp_mem(
111 struct se_port *);
112extern void core_alua_free_tg_pt_gp(struct t10_alua_tg_pt_gp *);
113extern void core_alua_free_tg_pt_gp_mem(struct se_port *);
114extern void __core_alua_attach_tg_pt_gp_mem(struct t10_alua_tg_pt_gp_member *,
115 struct t10_alua_tg_pt_gp *);
116extern ssize_t core_alua_show_tg_pt_gp_info(struct se_port *, char *);
117extern ssize_t core_alua_store_tg_pt_gp_info(struct se_port *, const char *,
118 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 */