Commit | Line | Data |
---|---|---|
c66ac9db NB |
1 | #ifndef TARGET_CORE_TRANSPORT_H |
2 | #define TARGET_CORE_TRANSPORT_H | |
3 | ||
4 | #define TARGET_CORE_VERSION TARGET_CORE_MOD_VERSION | |
5 | ||
6 | /* Attempts before moving from SHORT to LONG */ | |
7 | #define PYX_TRANSPORT_WINDOW_CLOSED_THRESHOLD 3 | |
8 | #define PYX_TRANSPORT_WINDOW_CLOSED_WAIT_SHORT 3 /* In milliseconds */ | |
9 | #define PYX_TRANSPORT_WINDOW_CLOSED_WAIT_LONG 10 /* In milliseconds */ | |
10 | ||
11 | #define PYX_TRANSPORT_STATUS_INTERVAL 5 /* In seconds */ | |
12 | ||
13 | #define PYX_TRANSPORT_SENT_TO_TRANSPORT 0 | |
14 | #define PYX_TRANSPORT_WRITE_PENDING 1 | |
15 | ||
16 | #define PYX_TRANSPORT_UNKNOWN_SAM_OPCODE -1 | |
17 | #define PYX_TRANSPORT_HBA_QUEUE_FULL -2 | |
18 | #define PYX_TRANSPORT_REQ_TOO_MANY_SECTORS -3 | |
19 | #define PYX_TRANSPORT_OUT_OF_MEMORY_RESOURCES -4 | |
20 | #define PYX_TRANSPORT_INVALID_CDB_FIELD -5 | |
21 | #define PYX_TRANSPORT_INVALID_PARAMETER_LIST -6 | |
22 | #define PYX_TRANSPORT_LU_COMM_FAILURE -7 | |
23 | #define PYX_TRANSPORT_UNKNOWN_MODE_PAGE -8 | |
24 | #define PYX_TRANSPORT_WRITE_PROTECTED -9 | |
25 | #define PYX_TRANSPORT_TASK_TIMEOUT -10 | |
26 | #define PYX_TRANSPORT_RESERVATION_CONFLICT -11 | |
27 | #define PYX_TRANSPORT_ILLEGAL_REQUEST -12 | |
28 | #define PYX_TRANSPORT_USE_SENSE_REASON -13 | |
29 | ||
30 | #ifndef SAM_STAT_RESERVATION_CONFLICT | |
31 | #define SAM_STAT_RESERVATION_CONFLICT 0x18 | |
32 | #endif | |
33 | ||
34 | #define TRANSPORT_PLUGIN_FREE 0 | |
35 | #define TRANSPORT_PLUGIN_REGISTERED 1 | |
36 | ||
37 | #define TRANSPORT_PLUGIN_PHBA_PDEV 1 | |
38 | #define TRANSPORT_PLUGIN_VHBA_PDEV 2 | |
39 | #define TRANSPORT_PLUGIN_VHBA_VDEV 3 | |
40 | ||
41 | /* For SE OBJ Plugins, in seconds */ | |
42 | #define TRANSPORT_TIMEOUT_TUR 10 | |
43 | #define TRANSPORT_TIMEOUT_TYPE_DISK 60 | |
44 | #define TRANSPORT_TIMEOUT_TYPE_ROM 120 | |
45 | #define TRANSPORT_TIMEOUT_TYPE_TAPE 600 | |
46 | #define TRANSPORT_TIMEOUT_TYPE_OTHER 300 | |
47 | ||
c66ac9db NB |
48 | /* |
49 | * struct se_subsystem_dev->su_dev_flags | |
50 | */ | |
51 | #define SDF_FIRMWARE_VPD_UNIT_SERIAL 0x00000001 | |
52 | #define SDF_EMULATED_VPD_UNIT_SERIAL 0x00000002 | |
53 | #define SDF_USING_UDEV_PATH 0x00000004 | |
54 | #define SDF_USING_ALIAS 0x00000008 | |
55 | ||
56 | /* | |
57 | * struct se_device->dev_flags | |
58 | */ | |
59 | #define DF_READ_ONLY 0x00000001 | |
60 | #define DF_SPC2_RESERVATIONS 0x00000002 | |
61 | #define DF_SPC2_RESERVATIONS_WITH_ISID 0x00000004 | |
62 | ||
63 | /* struct se_dev_attrib sanity values */ | |
64 | /* 10 Minutes */ | |
65 | #define DA_TASK_TIMEOUT_MAX 600 | |
66 | /* Default max_unmap_lba_count */ | |
67 | #define DA_MAX_UNMAP_LBA_COUNT 0 | |
68 | /* Default max_unmap_block_desc_count */ | |
69 | #define DA_MAX_UNMAP_BLOCK_DESC_COUNT 0 | |
70 | /* Default unmap_granularity */ | |
71 | #define DA_UNMAP_GRANULARITY_DEFAULT 0 | |
72 | /* Default unmap_granularity_alignment */ | |
73 | #define DA_UNMAP_GRANULARITY_ALIGNMENT_DEFAULT 0 | |
74 | /* Emulation for Direct Page Out */ | |
75 | #define DA_EMULATE_DPO 0 | |
76 | /* Emulation for Forced Unit Access WRITEs */ | |
77 | #define DA_EMULATE_FUA_WRITE 1 | |
78 | /* Emulation for Forced Unit Access READs */ | |
79 | #define DA_EMULATE_FUA_READ 0 | |
80 | /* Emulation for WriteCache and SYNCHRONIZE_CACHE */ | |
81 | #define DA_EMULATE_WRITE_CACHE 0 | |
82 | /* Emulation for UNIT ATTENTION Interlock Control */ | |
83 | #define DA_EMULATE_UA_INTLLCK_CTRL 0 | |
84 | /* Emulation for TASK_ABORTED status (TAS) by default */ | |
85 | #define DA_EMULATE_TAS 1 | |
86 | /* Emulation for Thin Provisioning UNMAP using block/blk-lib.c:blkdev_issue_discard() */ | |
87 | #define DA_EMULATE_TPU 0 | |
88 | /* | |
89 | * Emulation for Thin Provisioning WRITE_SAME w/ UNMAP=1 bit using | |
90 | * block/blk-lib.c:blkdev_issue_discard() | |
91 | */ | |
92 | #define DA_EMULATE_TPWS 0 | |
93 | /* No Emulation for PSCSI by default */ | |
94 | #define DA_EMULATE_RESERVATIONS 0 | |
95 | /* No Emulation for PSCSI by default */ | |
96 | #define DA_EMULATE_ALUA 0 | |
97 | /* Enforce SCSI Initiator Port TransportID with 'ISID' for PR */ | |
98 | #define DA_ENFORCE_PR_ISIDS 1 | |
99 | #define DA_STATUS_MAX_SECTORS_MIN 16 | |
100 | #define DA_STATUS_MAX_SECTORS_MAX 8192 | |
e22a7f07 RD |
101 | /* By default don't report non-rotating (solid state) medium */ |
102 | #define DA_IS_NONROT 0 | |
5de619a3 NB |
103 | /* Queue Algorithm Modifier default for restricted reordering in control mode page */ |
104 | #define DA_EMULATE_REST_REORD 0 | |
c66ac9db NB |
105 | |
106 | #define SE_MODE_PAGE_BUF 512 | |
107 | ||
108 | #define MOD_MAX_SECTORS(ms, bs) (ms % (PAGE_SIZE / bs)) | |
109 | ||
c66ac9db NB |
110 | struct se_subsystem_api; |
111 | ||
e3d6f909 AG |
112 | extern int init_se_kmem_caches(void); |
113 | extern void release_se_kmem_caches(void); | |
e89d15ee | 114 | extern u32 scsi_get_new_index(scsi_index_t); |
c66ac9db NB |
115 | extern void transport_init_queue_obj(struct se_queue_obj *); |
116 | extern int transport_subsystem_check_init(void); | |
117 | extern int transport_subsystem_register(struct se_subsystem_api *); | |
118 | extern void transport_subsystem_release(struct se_subsystem_api *); | |
119 | extern void transport_load_plugins(void); | |
120 | extern struct se_session *transport_init_session(void); | |
121 | extern void __transport_register_session(struct se_portal_group *, | |
122 | struct se_node_acl *, | |
123 | struct se_session *, void *); | |
124 | extern void transport_register_session(struct se_portal_group *, | |
125 | struct se_node_acl *, | |
126 | struct se_session *, void *); | |
127 | extern void transport_free_session(struct se_session *); | |
128 | extern void transport_deregister_session_configfs(struct se_session *); | |
129 | extern void transport_deregister_session(struct se_session *); | |
130 | extern void transport_cmd_finish_abort(struct se_cmd *, int); | |
c66ac9db NB |
131 | extern void transport_complete_sync_cache(struct se_cmd *, int); |
132 | extern void transport_complete_task(struct se_task *, int); | |
133 | extern void transport_add_task_to_execute_queue(struct se_task *, | |
134 | struct se_task *, | |
135 | struct se_device *); | |
52208ae3 NB |
136 | extern void transport_remove_task_from_execute_queue(struct se_task *, |
137 | struct se_device *); | |
c66ac9db NB |
138 | unsigned char *transport_dump_cmd_direction(struct se_cmd *); |
139 | extern void transport_dump_dev_state(struct se_device *, char *, int *); | |
140 | extern void transport_dump_dev_info(struct se_device *, struct se_lun *, | |
141 | unsigned long long, char *, int *); | |
142 | extern void transport_dump_vpd_proto_id(struct t10_vpd *, | |
143 | unsigned char *, int); | |
144 | extern void transport_set_vpd_proto_id(struct t10_vpd *, unsigned char *); | |
145 | extern int transport_dump_vpd_assoc(struct t10_vpd *, | |
146 | unsigned char *, int); | |
147 | extern int transport_set_vpd_assoc(struct t10_vpd *, unsigned char *); | |
148 | extern int transport_dump_vpd_ident_type(struct t10_vpd *, | |
149 | unsigned char *, int); | |
150 | extern int transport_set_vpd_ident_type(struct t10_vpd *, unsigned char *); | |
151 | extern int transport_dump_vpd_ident(struct t10_vpd *, | |
152 | unsigned char *, int); | |
153 | extern int transport_set_vpd_ident(struct t10_vpd *, unsigned char *); | |
154 | extern struct se_device *transport_add_device_to_core_hba(struct se_hba *, | |
155 | struct se_subsystem_api *, | |
156 | struct se_subsystem_dev *, u32, | |
157 | void *, struct se_dev_limits *, | |
158 | const char *, const char *); | |
c66ac9db NB |
159 | extern void transport_init_se_cmd(struct se_cmd *, |
160 | struct target_core_fabric_ops *, | |
161 | struct se_session *, u32, int, int, | |
162 | unsigned char *); | |
05d1c7c0 AG |
163 | void *transport_kmap_first_data_page(struct se_cmd *cmd); |
164 | void transport_kunmap_first_data_page(struct se_cmd *cmd); | |
c66ac9db | 165 | extern int transport_generic_allocate_tasks(struct se_cmd *, unsigned char *); |
695434e1 | 166 | extern int transport_handle_cdb_direct(struct se_cmd *); |
c66ac9db NB |
167 | extern int transport_generic_handle_cdb_map(struct se_cmd *); |
168 | extern int transport_generic_handle_data(struct se_cmd *); | |
169 | extern void transport_new_cmd_failure(struct se_cmd *); | |
170 | extern int transport_generic_handle_tmr(struct se_cmd *); | |
f4366772 | 171 | extern void transport_generic_free_cmd_intr(struct se_cmd *); |
c66ac9db | 172 | extern void __transport_stop_task_timer(struct se_task *, unsigned long *); |
c66ac9db NB |
173 | extern int transport_generic_map_mem_to_cmd(struct se_cmd *cmd, struct scatterlist *, u32, |
174 | struct scatterlist *, u32); | |
175 | extern int transport_clear_lun_from_sessions(struct se_lun *); | |
d14921d6 | 176 | extern void transport_wait_for_tasks(struct se_cmd *); |
c66ac9db NB |
177 | extern int transport_check_aborted_status(struct se_cmd *, int); |
178 | extern int transport_send_check_condition_and_sense(struct se_cmd *, u8, int); | |
179 | extern void transport_send_task_abort(struct se_cmd *); | |
35462975 | 180 | extern void transport_release_cmd(struct se_cmd *); |
39c05f32 | 181 | extern void transport_generic_free_cmd(struct se_cmd *, int); |
c66ac9db | 182 | extern void transport_generic_wait_for_cmds(struct se_cmd *, int); |
c66ac9db NB |
183 | extern void transport_do_task_sg_chain(struct se_cmd *); |
184 | extern void transport_generic_process_write(struct se_cmd *); | |
a1d8b49a | 185 | extern int transport_generic_new_cmd(struct se_cmd *); |
c66ac9db NB |
186 | extern int transport_generic_do_tmr(struct se_cmd *); |
187 | /* From target_core_alua.c */ | |
188 | extern int core_alua_check_nonop_delay(struct se_cmd *); | |
5dd7ed2e DC |
189 | /* From target_core_cdb.c */ |
190 | extern int transport_emulate_control_cdb(struct se_task *); | |
c66ac9db NB |
191 | |
192 | /* | |
193 | * Each se_transport_task_t can have N number of possible struct se_task's | |
194 | * for the storage transport(s) to possibly execute. | |
195 | * Used primarily for splitting up CDBs that exceed the physical storage | |
196 | * HBA's maximum sector count per task. | |
197 | */ | |
198 | struct se_mem { | |
199 | struct page *se_page; | |
200 | u32 se_len; | |
201 | u32 se_off; | |
202 | struct list_head se_list; | |
203 | } ____cacheline_aligned; | |
204 | ||
205 | /* | |
206 | * Each type of disk transport supported MUST have a template defined | |
207 | * within its .h file. | |
208 | */ | |
209 | struct se_subsystem_api { | |
210 | /* | |
211 | * The Name. :-) | |
212 | */ | |
213 | char name[16]; | |
214 | /* | |
215 | * Transport Type. | |
216 | */ | |
217 | u8 transport_type; | |
218 | /* | |
219 | * struct module for struct se_hba references | |
220 | */ | |
221 | struct module *owner; | |
222 | /* | |
223 | * Used for global se_subsystem_api list_head | |
224 | */ | |
225 | struct list_head sub_api_list; | |
c66ac9db NB |
226 | /* |
227 | * attach_hba(): | |
228 | */ | |
229 | int (*attach_hba)(struct se_hba *, u32); | |
230 | /* | |
231 | * detach_hba(): | |
232 | */ | |
233 | void (*detach_hba)(struct se_hba *); | |
234 | /* | |
235 | * pmode_hba(): Used for TCM/pSCSI subsystem plugin HBA -> | |
236 | * Linux/SCSI struct Scsi_Host passthrough | |
237 | */ | |
238 | int (*pmode_enable_hba)(struct se_hba *, unsigned long); | |
239 | /* | |
240 | * allocate_virtdevice(): | |
241 | */ | |
242 | void *(*allocate_virtdevice)(struct se_hba *, const char *); | |
243 | /* | |
244 | * create_virtdevice(): Only for Virtual HBAs | |
245 | */ | |
246 | struct se_device *(*create_virtdevice)(struct se_hba *, | |
247 | struct se_subsystem_dev *, void *); | |
248 | /* | |
249 | * free_device(): | |
250 | */ | |
251 | void (*free_device)(void *); | |
252 | ||
253 | /* | |
254 | * dpo_emulated(): | |
255 | */ | |
256 | int (*dpo_emulated)(struct se_device *); | |
257 | /* | |
258 | * fua_write_emulated(): | |
259 | */ | |
260 | int (*fua_write_emulated)(struct se_device *); | |
261 | /* | |
262 | * fua_read_emulated(): | |
263 | */ | |
264 | int (*fua_read_emulated)(struct se_device *); | |
265 | /* | |
266 | * write_cache_emulated(): | |
267 | */ | |
268 | int (*write_cache_emulated)(struct se_device *); | |
269 | /* | |
270 | * transport_complete(): | |
271 | * | |
272 | * Use transport_generic_complete() for majority of DAS transport | |
273 | * drivers. Provided out of convenience. | |
274 | */ | |
275 | int (*transport_complete)(struct se_task *task); | |
6708bb27 | 276 | struct se_task *(*alloc_task)(unsigned char *cdb); |
c66ac9db NB |
277 | /* |
278 | * do_task(): | |
279 | */ | |
280 | int (*do_task)(struct se_task *); | |
281 | /* | |
282 | * Used by virtual subsystem plugins IBLOCK and FILEIO to emulate | |
283 | * UNMAP and WRITE_SAME_* w/ UNMAP=1 <-> Linux/Block Discard | |
284 | */ | |
285 | int (*do_discard)(struct se_device *, sector_t, u32); | |
286 | /* | |
287 | * Used by virtual subsystem plugins IBLOCK and FILEIO to emulate | |
288 | * SYNCHRONIZE_CACHE_* <-> Linux/Block blkdev_issue_flush() | |
289 | */ | |
290 | void (*do_sync_cache)(struct se_task *); | |
291 | /* | |
292 | * free_task(): | |
293 | */ | |
294 | void (*free_task)(struct se_task *); | |
295 | /* | |
296 | * check_configfs_dev_params(): | |
297 | */ | |
298 | ssize_t (*check_configfs_dev_params)(struct se_hba *, struct se_subsystem_dev *); | |
299 | /* | |
300 | * set_configfs_dev_params(): | |
301 | */ | |
302 | ssize_t (*set_configfs_dev_params)(struct se_hba *, struct se_subsystem_dev *, | |
303 | const char *, ssize_t); | |
304 | /* | |
305 | * show_configfs_dev_params(): | |
306 | */ | |
307 | ssize_t (*show_configfs_dev_params)(struct se_hba *, struct se_subsystem_dev *, | |
308 | char *); | |
309 | /* | |
310 | * get_cdb(): | |
311 | */ | |
312 | unsigned char *(*get_cdb)(struct se_task *); | |
313 | /* | |
314 | * get_device_rev(): | |
315 | */ | |
316 | u32 (*get_device_rev)(struct se_device *); | |
317 | /* | |
318 | * get_device_type(): | |
319 | */ | |
320 | u32 (*get_device_type)(struct se_device *); | |
321 | /* | |
322 | * Get the sector_t from a subsystem backstore.. | |
323 | */ | |
324 | sector_t (*get_blocks)(struct se_device *); | |
c66ac9db NB |
325 | /* |
326 | * get_sense_buffer(): | |
327 | */ | |
328 | unsigned char *(*get_sense_buffer)(struct se_task *); | |
329 | } ____cacheline_aligned; | |
330 | ||
c66ac9db | 331 | #endif /* TARGET_CORE_TRANSPORT_H */ |