tcm_loop.h 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #define TCM_LOOP_VERSION "v2.1-rc2"
  2. #define TL_WWN_ADDR_LEN 256
  3. #define TL_TPGS_PER_HBA 32
  4. /*
  5. * Used in tcm_loop_driver_probe() for struct Scsi_Host->max_cmd_len
  6. */
  7. #define TL_SCSI_MAX_CMD_LEN 32
  8. struct tcm_loop_cmd {
  9. /* State of Linux/SCSI CDB+Data descriptor */
  10. u32 sc_cmd_state;
  11. /* Tagged command queueing */
  12. u32 sc_cmd_tag;
  13. /* Pointer to the CDB+Data descriptor from Linux/SCSI subsystem */
  14. struct scsi_cmnd *sc;
  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];
  20. };
  21. struct tcm_loop_tmr {
  22. atomic_t tmr_complete;
  23. wait_queue_head_t tl_tmr_wait;
  24. };
  25. struct tcm_loop_nexus {
  26. int it_nexus_active;
  27. /*
  28. * Pointer to Linux/SCSI HBA from linux/include/scsi_host.h
  29. */
  30. struct scsi_host *sh;
  31. /*
  32. * Pointer to TCM session for I_T Nexus
  33. */
  34. struct se_session *se_sess;
  35. };
  36. struct tcm_loop_nacl {
  37. struct se_node_acl se_node_acl;
  38. };
  39. #define TCM_TRANSPORT_ONLINE 0
  40. #define TCM_TRANSPORT_OFFLINE 1
  41. struct tcm_loop_tpg {
  42. unsigned short tl_tpgt;
  43. unsigned short tl_transport_status;
  44. atomic_t tl_tpg_port_count;
  45. struct se_portal_group tl_se_tpg;
  46. struct tcm_loop_hba *tl_hba;
  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;
  54. struct tcm_loop_nexus *tl_nexus;
  55. struct device dev;
  56. struct Scsi_Host *sh;
  57. struct tcm_loop_tpg tl_hba_tpgs[TL_TPGS_PER_HBA];
  58. struct se_wwn tl_hba_wwn;
  59. };