Blame view

include/scsi/libiscsi_tcp.h 3.8 KB
c942fddf8   Thomas Gleixner   treewide: Replace...
1
  /* SPDX-License-Identifier: GPL-2.0-or-later */
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
2
3
4
5
6
7
  /*
   * iSCSI over TCP/IP Data-Path lib
   *
   * Copyright (C) 2008 Mike Christie
   * Copyright (C) 2008 Red Hat, Inc.  All rights reserved.
   * maintained by open-iscsi@googlegroups.com
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
8
9
10
11
12
13
14
15
16
17
   */
  
  #ifndef LIBISCSI_TCP_H
  #define LIBISCSI_TCP_H
  
  #include <scsi/libiscsi.h>
  
  struct iscsi_tcp_conn;
  struct iscsi_segment;
  struct sk_buff;
5d6ac29b9   Herbert Xu   iscsi_tcp: Use ahash
18
  struct ahash_request;
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
19
20
21
22
23
24
25
26
27
28
  
  typedef int iscsi_segment_done_fn_t(struct iscsi_tcp_conn *,
  				    struct iscsi_segment *);
  
  struct iscsi_segment {
  	unsigned char		*data;
  	unsigned int		size;
  	unsigned int		copied;
  	unsigned int		total_size;
  	unsigned int		total_copied;
5d6ac29b9   Herbert Xu   iscsi_tcp: Use ahash
29
  	struct ahash_request	*hash;
2856830bd   Karen Xie   [SCSI] iscsi_tcp:...
30
  	unsigned char		padbuf[ISCSI_PAD_LEN];
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
31
32
33
34
35
36
37
  	unsigned char		recv_digest[ISCSI_DIGEST_SIZE];
  	unsigned char		digest[ISCSI_DIGEST_SIZE];
  	unsigned int		digest_len;
  
  	struct scatterlist	*sg;
  	void			*sg_mapped;
  	unsigned int		sg_offset;
70c7c88a1   Mike Christie   [SCSI] libiscsi_t...
38
  	bool			atomic_mapped;
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
39
40
41
  
  	iscsi_segment_done_fn_t	*done;
  };
25985edce   Lucas De Marchi   Fix common misspe...
42
  /* Socket connection receive helper */
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
  struct iscsi_tcp_recv {
  	struct iscsi_hdr	*hdr;
  	struct iscsi_segment	segment;
  
  	/* Allocate buffer for BHS + AHS */
  	uint32_t		hdr_buf[64];
  
  	/* copied and flipped values */
  	int			datalen;
  };
  
  struct iscsi_tcp_conn {
  	struct iscsi_conn	*iscsi_conn;
  	void			*dd_data;
  	int			stop_stage;	/* conn_stop() flag: *
  						 * stop to recover,  *
  						 * stop to terminate */
  	/* control data */
  	struct iscsi_tcp_recv	in;		/* TCP receive context */
  	/* CRC32C (Rx) LLD should set this is they do not offload */
5d6ac29b9   Herbert Xu   iscsi_tcp: Use ahash
63
  	struct ahash_request	*rx_hash;
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
64
65
66
67
68
69
70
  };
  
  struct iscsi_tcp_task {
  	uint32_t		exp_datasn;	/* expected target's R2TSN/DataSN */
  	int			data_offset;
  	struct iscsi_r2t_info	*r2t;		/* in progress solict R2T */
  	struct iscsi_pool	r2tpool;
454654878   Stefani Seibold   kfifo: move struc...
71
  	struct kfifo		r2tqueue;
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
72
  	void			*dd_data;
659743b02   Shlomo Pongratz   [SCSI] libiscsi: ...
73
74
  	spinlock_t		pool2queue;
  	spinlock_t		queue2pool;
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
  };
  
  enum {
  	ISCSI_TCP_SEGMENT_DONE,		/* curr seg has been processed */
  	ISCSI_TCP_SKB_DONE,		/* skb is out of data */
  	ISCSI_TCP_CONN_ERR,		/* iscsi layer has fired a conn err */
  	ISCSI_TCP_SUSPENDED,		/* conn is suspended */
  };
  
  extern void iscsi_tcp_hdr_recv_prep(struct iscsi_tcp_conn *tcp_conn);
  extern int iscsi_tcp_recv_skb(struct iscsi_conn *conn, struct sk_buff *skb,
  			      unsigned int offset, bool offloaded, int *status);
  extern void iscsi_tcp_cleanup_task(struct iscsi_task *task);
  extern int iscsi_tcp_task_init(struct iscsi_task *task);
  extern int iscsi_tcp_task_xmit(struct iscsi_task *task);
  
  /* segment helpers */
  extern int iscsi_tcp_recv_segment_is_hdr(struct iscsi_tcp_conn *tcp_conn);
6df19a791   Mike Christie   [SCSI] libiscsi_t...
93
94
  extern int iscsi_tcp_segment_done(struct iscsi_tcp_conn *tcp_conn,
  				  struct iscsi_segment *segment, int recv,
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
95
96
97
98
99
100
  				  unsigned copied);
  extern void iscsi_tcp_segment_unmap(struct iscsi_segment *segment);
  
  extern void iscsi_segment_init_linear(struct iscsi_segment *segment,
  				      void *data, size_t size,
  				      iscsi_segment_done_fn_t *done,
5d6ac29b9   Herbert Xu   iscsi_tcp: Use ahash
101
  				      struct ahash_request *hash);
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
102
103
104
105
  extern int
  iscsi_segment_seek_sg(struct iscsi_segment *segment,
  		      struct scatterlist *sg_list, unsigned int sg_count,
  		      unsigned int offset, size_t size,
5d6ac29b9   Herbert Xu   iscsi_tcp: Use ahash
106
107
  		      iscsi_segment_done_fn_t *done,
  		      struct ahash_request *hash);
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
108
109
  
  /* digest helpers */
5d6ac29b9   Herbert Xu   iscsi_tcp: Use ahash
110
  extern void iscsi_tcp_dgst_header(struct ahash_request *hash, const void *hdr,
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
111
112
113
114
115
116
117
118
119
120
  				  size_t hdrlen,
  				  unsigned char digest[ISCSI_DIGEST_SIZE]);
  extern struct iscsi_cls_conn *
  iscsi_tcp_conn_setup(struct iscsi_cls_session *cls_session, int dd_data_size,
  		     uint32_t conn_idx);
  extern void iscsi_tcp_conn_teardown(struct iscsi_cls_conn *cls_conn);
  
  /* misc helpers */
  extern int iscsi_tcp_r2tpool_alloc(struct iscsi_session *session);
  extern void iscsi_tcp_r2tpool_free(struct iscsi_session *session);
1304be5fe   Mike Christie   [SCSI] libiscsi_t...
121
  extern int iscsi_tcp_set_max_r2t(struct iscsi_conn *conn, char *buf);
a081c13e3   Mike Christie   [SCSI] iscsi_tcp:...
122
123
124
  extern void iscsi_tcp_conn_get_stats(struct iscsi_cls_conn *cls_conn,
  				     struct iscsi_stats *stats);
  #endif /* LIBISCSI_TCP_H */