Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Bart Van Assche | 8dcf07b | 2016-11-14 15:47:14 -0800 | [diff] [blame] | 2 | #include <linux/types.h> |
| 3 | #include <linux/device.h> |
| 4 | #include <target/target_core_base.h> /* struct se_cmd */ |
| 5 | |
Nicholas Bellinger | 9765b1f | 2012-03-10 14:50:19 -0800 | [diff] [blame] | 6 | #define TCM_LOOP_VERSION "v2.1-rc2" |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 7 | #define TL_WWN_ADDR_LEN 256 |
| 8 | #define TL_TPGS_PER_HBA 32 |
Christoph Hellwig | 2e88efd | 2011-11-29 03:20:41 -0500 | [diff] [blame] | 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; |
Bart Van Assche | d17203c | 2017-05-23 16:48:40 -0700 | [diff] [blame] | 20 | struct completion tmr_done; |
Bart Van Assche | 4d3895d | 2017-05-23 16:48:39 -0700 | [diff] [blame] | 21 | /* Sense buffer that will be mapped into outgoing status */ |
| 22 | unsigned char tl_sense_buf[TRANSPORT_SENSE_BUFFER]; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 23 | }; |
| 24 | |
| 25 | struct tcm_loop_nexus { |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 26 | /* |
| 27 | * Pointer to TCM session for I_T Nexus |
| 28 | */ |
| 29 | struct se_session *se_sess; |
| 30 | }; |
| 31 | |
Hannes Reinecke | fb2b284 | 2013-10-16 09:12:53 +0200 | [diff] [blame] | 32 | #define TCM_TRANSPORT_ONLINE 0 |
| 33 | #define TCM_TRANSPORT_OFFLINE 1 |
| 34 | |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 35 | struct tcm_loop_tpg { |
| 36 | unsigned short tl_tpgt; |
Hannes Reinecke | fb2b284 | 2013-10-16 09:12:53 +0200 | [diff] [blame] | 37 | unsigned short tl_transport_status; |
Nicholas Bellinger | 436f4a0 | 2015-02-08 12:31:39 -0800 | [diff] [blame] | 38 | enum target_prot_type tl_fabric_prot_type; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 39 | atomic_t tl_tpg_port_count; |
| 40 | struct se_portal_group tl_se_tpg; |
| 41 | struct tcm_loop_hba *tl_hba; |
Hannes Reinecke | 506787a | 2014-11-26 14:58:57 +0100 | [diff] [blame] | 42 | struct tcm_loop_nexus *tl_nexus; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 43 | }; |
| 44 | |
| 45 | struct tcm_loop_hba { |
| 46 | u8 tl_proto_id; |
| 47 | unsigned char tl_wwn_address[TL_WWN_ADDR_LEN]; |
| 48 | struct se_hba_s *se_hba; |
| 49 | struct se_lun *tl_hba_lun; |
| 50 | struct se_port *tl_hba_lun_sep; |
Nicholas Bellinger | 3703b2c | 2011-03-18 15:39:17 -0700 | [diff] [blame] | 51 | struct device dev; |
| 52 | struct Scsi_Host *sh; |
| 53 | struct tcm_loop_tpg tl_hba_tpgs[TL_TPGS_PER_HBA]; |
| 54 | struct se_wwn tl_hba_wwn; |
| 55 | }; |