Nicholas Bellinger | 9765b1f | 2012-03-10 14:50:19 -0800 | [diff] [blame] | 1 | #define TCM_LOOP_VERSION "v2.1-rc2" |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 2 | #define TL_WWN_ADDR_LEN 256 |
| 3 | #define TL_TPGS_PER_HBA 32 |
Christoph Hellwig | 2e88efd | 2011-11-29 03:20:41 -0500 | [diff] [blame] | 4 | |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 5 | /* |
| 6 | * Used in tcm_loop_driver_probe() for struct Scsi_Host->max_cmd_len |
| 7 | */ |
| 8 | #define TL_SCSI_MAX_CMD_LEN 32 |
| 9 | |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 10 | struct tcm_loop_cmd { |
| 11 | /* State of Linux/SCSI CDB+Data descriptor */ |
| 12 | u32 sc_cmd_state; |
Hannes Reinecke | 969871c | 2013-10-16 09:12:55 +0200 | [diff] [blame] | 13 | /* Tagged command queueing */ |
| 14 | u32 sc_cmd_tag; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 15 | /* Pointer to the CDB+Data descriptor from Linux/SCSI subsystem */ |
| 16 | struct scsi_cmnd *sc; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 17 | /* The TCM I/O descriptor that is accessed via container_of() */ |
| 18 | struct se_cmd tl_se_cmd; |
Christoph Hellwig | afe2cb7 | 2012-02-02 17:04:41 -0500 | [diff] [blame] | 19 | struct work_struct work; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 20 | /* Sense buffer that will be mapped into outgoing status */ |
| 21 | unsigned char tl_sense_buf[TRANSPORT_SENSE_BUFFER]; |
| 22 | }; |
| 23 | |
| 24 | struct tcm_loop_tmr { |
| 25 | atomic_t tmr_complete; |
| 26 | wait_queue_head_t tl_tmr_wait; |
| 27 | }; |
| 28 | |
| 29 | struct tcm_loop_nexus { |
| 30 | int it_nexus_active; |
| 31 | /* |
| 32 | * Pointer to Linux/SCSI HBA from linux/include/scsi_host.h |
| 33 | */ |
| 34 | struct scsi_host *sh; |
| 35 | /* |
| 36 | * Pointer to TCM session for I_T Nexus |
| 37 | */ |
| 38 | struct se_session *se_sess; |
| 39 | }; |
| 40 | |
| 41 | struct tcm_loop_nacl { |
| 42 | struct se_node_acl se_node_acl; |
| 43 | }; |
| 44 | |
Hannes Reinecke | fb2b284 | 2013-10-16 09:12:53 +0200 | [diff] [blame] | 45 | #define TCM_TRANSPORT_ONLINE 0 |
| 46 | #define TCM_TRANSPORT_OFFLINE 1 |
| 47 | |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 48 | struct tcm_loop_tpg { |
| 49 | unsigned short tl_tpgt; |
Hannes Reinecke | fb2b284 | 2013-10-16 09:12:53 +0200 | [diff] [blame] | 50 | unsigned short tl_transport_status; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 51 | atomic_t tl_tpg_port_count; |
| 52 | struct se_portal_group tl_se_tpg; |
| 53 | struct tcm_loop_hba *tl_hba; |
| 54 | }; |
| 55 | |
| 56 | struct tcm_loop_hba { |
| 57 | u8 tl_proto_id; |
| 58 | unsigned char tl_wwn_address[TL_WWN_ADDR_LEN]; |
| 59 | struct se_hba_s *se_hba; |
| 60 | struct se_lun *tl_hba_lun; |
| 61 | struct se_port *tl_hba_lun_sep; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 62 | struct tcm_loop_nexus *tl_nexus; |
| 63 | struct device dev; |
| 64 | struct Scsi_Host *sh; |
| 65 | struct tcm_loop_tpg tl_hba_tpgs[TL_TPGS_PER_HBA]; |
| 66 | struct se_wwn tl_hba_wwn; |
| 67 | }; |