tcm_loop.h 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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. /*
  27. * Pointer to TCM session for I_T Nexus
  28. */
  29. struct se_session *se_sess;
  30. };
  31. struct tcm_loop_nacl {
  32. struct se_node_acl se_node_acl;
  33. };
  34. #define TCM_TRANSPORT_ONLINE 0
  35. #define TCM_TRANSPORT_OFFLINE 1
  36. struct tcm_loop_tpg {
  37. unsigned short tl_tpgt;
  38. unsigned short tl_transport_status;
  39. atomic_t tl_tpg_port_count;
  40. struct se_portal_group tl_se_tpg;
  41. struct tcm_loop_hba *tl_hba;
  42. struct tcm_loop_nexus *tl_nexus;
  43. };
  44. struct tcm_loop_hba {
  45. u8 tl_proto_id;
  46. unsigned char tl_wwn_address[TL_WWN_ADDR_LEN];
  47. struct se_hba_s *se_hba;
  48. struct se_lun *tl_hba_lun;
  49. struct se_port *tl_hba_lun_sep;
  50. struct device dev;
  51. struct Scsi_Host *sh;
  52. struct tcm_loop_tpg tl_hba_tpgs[TL_TPGS_PER_HBA];
  53. struct se_wwn tl_hba_wwn;
  54. };