1 #define TCM_LOOP_VERSION "v2.1-rc2"
2 #define TL_WWN_ADDR_LEN 256
3 #define TL_TPGS_PER_HBA 32
6 * Used in tcm_loop_driver_probe() for struct Scsi_Host->max_cmd_len
8 #define TL_SCSI_MAX_CMD_LEN 32
11 /* State of Linux/SCSI CDB+Data descriptor */
13 /* Pointer to the CDB+Data descriptor from Linux/SCSI subsystem */
15 /* The TCM I/O descriptor that is accessed via container_of() */
16 struct se_cmd tl_se_cmd
;
17 struct work_struct work
;
18 /* Sense buffer that will be mapped into outgoing status */
19 unsigned char tl_sense_buf
[TRANSPORT_SENSE_BUFFER
];
23 atomic_t tmr_complete
;
24 wait_queue_head_t tl_tmr_wait
;
27 struct tcm_loop_nexus
{
29 * Pointer to TCM session for I_T Nexus
31 struct se_session
*se_sess
;
34 struct tcm_loop_nacl
{
35 struct se_node_acl se_node_acl
;
39 unsigned short tl_tpgt
;
40 atomic_t tl_tpg_port_count
;
41 struct se_portal_group tl_se_tpg
;
42 struct tcm_loop_hba
*tl_hba
;
43 struct tcm_loop_nexus
*tl_nexus
;
48 unsigned char tl_wwn_address
[TL_WWN_ADDR_LEN
];
49 struct se_hba_s
*se_hba
;
50 struct se_lun
*tl_hba_lun
;
51 struct se_port
*tl_hba_lun_sep
;
54 struct tcm_loop_tpg tl_hba_tpgs
[TL_TPGS_PER_HBA
];
55 struct se_wwn tl_hba_wwn
;