scsi_transport_iscsi.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. /*
  2. * iSCSI transport class definitions
  3. *
  4. * Copyright (C) IBM Corporation, 2004
  5. * Copyright (C) Mike Christie, 2004 - 2005
  6. * Copyright (C) Dmitry Yusupov, 2004 - 2005
  7. * Copyright (C) Alex Aizman, 2004 - 2005
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 2 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program; if not, write to the Free Software
  21. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  22. */
  23. #ifndef SCSI_TRANSPORT_ISCSI_H
  24. #define SCSI_TRANSPORT_ISCSI_H
  25. #include <linux/device.h>
  26. #include <scsi/iscsi_if.h>
  27. struct scsi_transport_template;
  28. struct Scsi_Host;
  29. struct mempool_zone;
  30. struct iscsi_cls_conn;
  31. /**
  32. * struct iscsi_transport - iSCSI Transport template
  33. *
  34. * @name: transport name
  35. * @caps: iSCSI Data-Path capabilities
  36. * @create_session: create new iSCSI session object
  37. * @destroy_session: destroy existing iSCSI session object
  38. * @create_conn: create new iSCSI connection
  39. * @bind_conn: associate this connection with existing iSCSI session
  40. * and specified transport descriptor
  41. * @destroy_conn: destroy inactive iSCSI connection
  42. * @set_param: set iSCSI Data-Path operational parameter
  43. * @start_conn: set connection to be operational
  44. * @stop_conn: suspend/recover/terminate connection
  45. * @send_pdu: send iSCSI PDU, Login, Logout, NOP-Out, Reject, Text.
  46. *
  47. * Template API provided by iSCSI Transport
  48. */
  49. struct iscsi_transport {
  50. struct module *owner;
  51. char *name;
  52. unsigned int caps;
  53. struct scsi_host_template *host_template;
  54. /* LLD session/scsi_host data size */
  55. int hostdata_size;
  56. /* LLD iscsi_host data size */
  57. int ihostdata_size;
  58. /* LLD connection data size */
  59. int conndata_size;
  60. int max_lun;
  61. unsigned int max_conn;
  62. unsigned int max_cmd_len;
  63. struct Scsi_Host *(*create_session) (struct scsi_transport_template *t,
  64. uint32_t initial_cmdsn);
  65. void (*destroy_session) (struct Scsi_Host *shost);
  66. struct iscsi_cls_conn *(*create_conn) (struct Scsi_Host *shost,
  67. uint32_t cid);
  68. int (*bind_conn) (iscsi_sessionh_t session, iscsi_connh_t conn,
  69. uint32_t transport_fd, int is_leading);
  70. int (*start_conn) (iscsi_connh_t conn);
  71. void (*stop_conn) (iscsi_connh_t conn, int flag);
  72. void (*destroy_conn) (struct iscsi_cls_conn *conn);
  73. int (*set_param) (iscsi_connh_t conn, enum iscsi_param param,
  74. uint32_t value);
  75. int (*get_conn_param) (void *conndata, enum iscsi_param param,
  76. uint32_t *value);
  77. int (*get_session_param) (struct Scsi_Host *shost,
  78. enum iscsi_param param, uint32_t *value);
  79. int (*send_pdu) (iscsi_connh_t conn, struct iscsi_hdr *hdr,
  80. char *data, uint32_t data_size);
  81. void (*get_stats) (iscsi_connh_t conn, struct iscsi_stats *stats);
  82. };
  83. /*
  84. * transport registration upcalls
  85. */
  86. extern struct scsi_transport_template *iscsi_register_transport(struct iscsi_transport *tt);
  87. extern int iscsi_unregister_transport(struct iscsi_transport *tt);
  88. /*
  89. * control plane upcalls
  90. */
  91. extern void iscsi_conn_error(iscsi_connh_t conn, enum iscsi_err error);
  92. extern int iscsi_recv_pdu(iscsi_connh_t conn, struct iscsi_hdr *hdr,
  93. char *data, uint32_t data_size);
  94. struct iscsi_cls_conn {
  95. struct list_head conn_list; /* item in connlist */
  96. void *dd_data; /* LLD private data */
  97. struct iscsi_transport *transport;
  98. iscsi_connh_t connh;
  99. int active; /* must be accessed with the connlock */
  100. struct device dev; /* sysfs transport/container device */
  101. struct mempool_zone *z_error;
  102. struct mempool_zone *z_pdu;
  103. struct list_head freequeue;
  104. };
  105. #define iscsi_dev_to_conn(_dev) \
  106. container_of(_dev, struct iscsi_cls_conn, dev)
  107. struct iscsi_cls_session {
  108. struct list_head list; /* item in session_list */
  109. struct iscsi_transport *transport;
  110. struct device dev; /* sysfs transport/container device */
  111. };
  112. #define iscsi_dev_to_session(_dev) \
  113. container_of(_dev, struct iscsi_cls_session, dev)
  114. #define iscsi_session_to_shost(_session) \
  115. dev_to_shost(_session->dev.parent)
  116. /*
  117. * session and connection functions that can be used by HW iSCSI LLDs
  118. */
  119. extern struct iscsi_cls_session *iscsi_create_session(struct Scsi_Host *shost,
  120. struct iscsi_transport *t);
  121. extern int iscsi_destroy_session(struct iscsi_cls_session *session);
  122. extern struct iscsi_cls_conn *iscsi_create_conn(struct iscsi_cls_session *sess,
  123. uint32_t cid);
  124. extern int iscsi_destroy_conn(struct iscsi_cls_conn *conn);
  125. /*
  126. * session functions used by software iscsi
  127. */
  128. extern struct Scsi_Host *
  129. iscsi_transport_create_session(struct scsi_transport_template *scsit,
  130. struct iscsi_transport *transport);
  131. extern int iscsi_transport_destroy_session(struct Scsi_Host *shost);
  132. #endif