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