tcm_loop.h 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. #define TCM_LOOP_VERSION "v2.1-rc1"
  2. #define TL_WWN_ADDR_LEN 256
  3. #define TL_TPGS_PER_HBA 32
  4. /*
  5. * Defaults for struct scsi_host_template tcm_loop_driver_template
  6. *
  7. * We use large can_queue and cmd_per_lun here and let TCM enforce
  8. * the underlying se_device_t->queue_depth.
  9. */
  10. #define TL_SCSI_CAN_QUEUE 1024
  11. #define TL_SCSI_CMD_PER_LUN 1024
  12. #define TL_SCSI_MAX_SECTORS 1024
  13. #define TL_SCSI_SG_TABLESIZE 256
  14. /*
  15. * Used in tcm_loop_driver_probe() for struct Scsi_Host->max_cmd_len
  16. */
  17. #define TL_SCSI_MAX_CMD_LEN 32
  18. #ifdef CONFIG_LOOPBACK_TARGET_CDB_DEBUG
  19. # define TL_CDB_DEBUG(x...) printk(KERN_INFO x)
  20. #else
  21. # define TL_CDB_DEBUG(x...)
  22. #endif
  23. struct tcm_loop_cmd {
  24. /* State of Linux/SCSI CDB+Data descriptor */
  25. u32 sc_cmd_state;
  26. /* Pointer to the CDB+Data descriptor from Linux/SCSI subsystem */
  27. struct scsi_cmnd *sc;
  28. struct list_head *tl_cmd_list;
  29. /* The TCM I/O descriptor that is accessed via container_of() */
  30. struct se_cmd tl_se_cmd;
  31. /* Sense buffer that will be mapped into outgoing status */
  32. unsigned char tl_sense_buf[TRANSPORT_SENSE_BUFFER];
  33. };
  34. struct tcm_loop_tmr {
  35. atomic_t tmr_complete;
  36. wait_queue_head_t tl_tmr_wait;
  37. };
  38. struct tcm_loop_nexus {
  39. int it_nexus_active;
  40. /*
  41. * Pointer to Linux/SCSI HBA from linux/include/scsi_host.h
  42. */
  43. struct scsi_host *sh;
  44. /*
  45. * Pointer to TCM session for I_T Nexus
  46. */
  47. struct se_session *se_sess;
  48. };
  49. struct tcm_loop_nacl {
  50. struct se_node_acl se_node_acl;
  51. };
  52. struct tcm_loop_tpg {
  53. unsigned short tl_tpgt;
  54. atomic_t tl_tpg_port_count;
  55. struct se_portal_group tl_se_tpg;
  56. struct tcm_loop_hba *tl_hba;
  57. };
  58. struct tcm_loop_hba {
  59. u8 tl_proto_id;
  60. unsigned char tl_wwn_address[TL_WWN_ADDR_LEN];
  61. struct se_hba_s *se_hba;
  62. struct se_lun *tl_hba_lun;
  63. struct se_port *tl_hba_lun_sep;
  64. struct se_device_s *se_dev_hba_ptr;
  65. struct tcm_loop_nexus *tl_nexus;
  66. struct device dev;
  67. struct Scsi_Host *sh;
  68. struct tcm_loop_tpg tl_hba_tpgs[TL_TPGS_PER_HBA];
  69. struct se_wwn tl_hba_wwn;
  70. };