1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21#ifndef LIBISCSI_TCP_H
22#define LIBISCSI_TCP_H
23
24#include <scsi/libiscsi.h>
25
26struct iscsi_tcp_conn;
27struct iscsi_segment;
28struct sk_buff;
29struct hash_desc;
30
31typedef int iscsi_segment_done_fn_t(struct iscsi_tcp_conn *,
32 struct iscsi_segment *);
33
34struct iscsi_segment {
35 unsigned char *data;
36 unsigned int size;
37 unsigned int copied;
38 unsigned int total_size;
39 unsigned int total_copied;
40
41 struct hash_desc *hash;
42 unsigned char padbuf[ISCSI_PAD_LEN];
43 unsigned char recv_digest[ISCSI_DIGEST_SIZE];
44 unsigned char digest[ISCSI_DIGEST_SIZE];
45 unsigned int digest_len;
46
47 struct scatterlist *sg;
48 void *sg_mapped;
49 unsigned int sg_offset;
50
51 iscsi_segment_done_fn_t *done;
52};
53
54
55struct iscsi_tcp_recv {
56 struct iscsi_hdr *hdr;
57 struct iscsi_segment segment;
58
59
60 uint32_t hdr_buf[64];
61
62
63 int datalen;
64};
65
66struct iscsi_tcp_conn {
67 struct iscsi_conn *iscsi_conn;
68 void *dd_data;
69 int stop_stage;
70
71
72
73 struct iscsi_tcp_recv in;
74
75 struct hash_desc *rx_hash;
76};
77
78struct iscsi_tcp_task {
79 uint32_t exp_datasn;
80 int data_offset;
81 struct iscsi_r2t_info *r2t;
82 struct iscsi_pool r2tpool;
83 struct kfifo *r2tqueue;
84 void *dd_data;
85};
86
87enum {
88 ISCSI_TCP_SEGMENT_DONE,
89 ISCSI_TCP_SKB_DONE,
90 ISCSI_TCP_CONN_ERR,
91 ISCSI_TCP_SUSPENDED,
92};
93
94extern void iscsi_tcp_hdr_recv_prep(struct iscsi_tcp_conn *tcp_conn);
95extern int iscsi_tcp_recv_skb(struct iscsi_conn *conn, struct sk_buff *skb,
96 unsigned int offset, bool offloaded, int *status);
97extern void iscsi_tcp_cleanup_task(struct iscsi_task *task);
98extern int iscsi_tcp_task_init(struct iscsi_task *task);
99extern int iscsi_tcp_task_xmit(struct iscsi_task *task);
100
101
102extern int iscsi_tcp_recv_segment_is_hdr(struct iscsi_tcp_conn *tcp_conn);
103extern int iscsi_tcp_segment_done(struct iscsi_tcp_conn *tcp_conn,
104 struct iscsi_segment *segment, int recv,
105 unsigned copied);
106extern void iscsi_tcp_segment_unmap(struct iscsi_segment *segment);
107
108extern void iscsi_segment_init_linear(struct iscsi_segment *segment,
109 void *data, size_t size,
110 iscsi_segment_done_fn_t *done,
111 struct hash_desc *hash);
112extern int
113iscsi_segment_seek_sg(struct iscsi_segment *segment,
114 struct scatterlist *sg_list, unsigned int sg_count,
115 unsigned int offset, size_t size,
116 iscsi_segment_done_fn_t *done, struct hash_desc *hash);
117
118
119extern void iscsi_tcp_dgst_header(struct hash_desc *hash, const void *hdr,
120 size_t hdrlen,
121 unsigned char digest[ISCSI_DIGEST_SIZE]);
122extern struct iscsi_cls_conn *
123iscsi_tcp_conn_setup(struct iscsi_cls_session *cls_session, int dd_data_size,
124 uint32_t conn_idx);
125extern void iscsi_tcp_conn_teardown(struct iscsi_cls_conn *cls_conn);
126
127
128extern int iscsi_tcp_r2tpool_alloc(struct iscsi_session *session);
129extern void iscsi_tcp_r2tpool_free(struct iscsi_session *session);
130
131extern void iscsi_tcp_conn_get_stats(struct iscsi_cls_conn *cls_conn,
132 struct iscsi_stats *stats);
133#endif
134