[SCSI] iscsi_tcp: rewrite recv path

Rewrite recv path. Fixes:
- data digest processing and error handling.
- ahs support.

Some fixups by Mike Christie

Signed-off-by: Olaf Kirch <olaf.kirch@oracle.com>
Signed-off-by: Mike Christie <michaelc@cs.wisc.edu>
Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
This commit is contained in:
Olaf Kirch 2007-12-13 12:43:21 -06:00 коммит произвёл James Bottomley
Родитель 843c0a8a76
Коммит da32dd681f
3 изменённых файлов: 556 добавлений и 540 удалений

Разница между файлами не показана из-за своего большого размера Загрузить разницу

Просмотреть файл

@ -24,13 +24,6 @@
#include <scsi/libiscsi.h> #include <scsi/libiscsi.h>
/* Socket's Receive state machine */
#define IN_PROGRESS_WAIT_HEADER 0x0
#define IN_PROGRESS_HEADER_GATHER 0x1
#define IN_PROGRESS_DATA_RECV 0x2
#define IN_PROGRESS_DDIGEST_RECV 0x3
#define IN_PROGRESS_PAD_RECV 0x4
/* xmit state machine */ /* xmit state machine */
#define XMSTATE_IDLE 0x0 #define XMSTATE_IDLE 0x0
#define XMSTATE_CMD_HDR_INIT 0x1 #define XMSTATE_CMD_HDR_INIT 0x1
@ -54,41 +47,64 @@
struct crypto_hash; struct crypto_hash;
struct socket; struct socket;
struct iscsi_tcp_conn;
struct iscsi_chunk;
typedef int iscsi_chunk_done_fn_t(struct iscsi_tcp_conn *,
struct iscsi_chunk *);
struct iscsi_chunk {
unsigned char *data;
unsigned int size;
unsigned int copied;
unsigned int total_size;
unsigned int total_copied;
struct hash_desc *hash;
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;
unsigned int sg_index;
unsigned int sg_count;
iscsi_chunk_done_fn_t *done;
};
/* Socket connection recieve helper */ /* Socket connection recieve helper */
struct iscsi_tcp_recv { struct iscsi_tcp_recv {
struct iscsi_hdr *hdr; struct iscsi_hdr *hdr;
struct sk_buff *skb; struct iscsi_chunk chunk;
int offset;
int len; /* Allocate buffer for BHS + AHS */
int hdr_offset; uint32_t hdr_buf[64];
int copy;
int copied;
int padding;
struct iscsi_cmd_task *ctask; /* current cmd in progress */
/* copied and flipped values */ /* copied and flipped values */
int datalen; int datalen;
int datadgst; };
char zero_copy_hdr;
/* Socket connection send helper */
struct iscsi_tcp_send {
struct iscsi_hdr *hdr;
struct iscsi_chunk chunk;
struct iscsi_chunk data_chunk;
/* Allocate buffer for BHS + AHS */
uint32_t hdr_buf[64];
}; };
struct iscsi_tcp_conn { struct iscsi_tcp_conn {
struct iscsi_conn *iscsi_conn; struct iscsi_conn *iscsi_conn;
struct socket *sock; struct socket *sock;
struct iscsi_hdr hdr; /* header placeholder */
char hdrext[4*sizeof(__u16) +
sizeof(__u32)];
int data_copied;
int stop_stage; /* conn_stop() flag: * int stop_stage; /* conn_stop() flag: *
* stop to recover, * * stop to recover, *
* stop to terminate */ * stop to terminate */
/* iSCSI connection-wide sequencing */
int hdr_size; /* PDU header size */
/* control data */ /* control data */
struct iscsi_tcp_recv in; /* TCP receive context */ struct iscsi_tcp_recv in; /* TCP receive context */
int in_progress; /* connection state machine */ struct iscsi_tcp_send out; /* TCP send context */
/* old values for socket callbacks */ /* old values for socket callbacks */
void (*old_data_ready)(struct sock *, int); void (*old_data_ready)(struct sock *, int);

Просмотреть файл

@ -77,6 +77,10 @@ enum {
#define ISCSI_ADDRESS_BUF_LEN 64 #define ISCSI_ADDRESS_BUF_LEN 64
enum {
ISCSI_DIGEST_SIZE = sizeof(__u32),
};
struct iscsi_mgmt_task { struct iscsi_mgmt_task {
/* /*
* Becuae LLDs allocate their hdr differently, this is a pointer to * Becuae LLDs allocate their hdr differently, this is a pointer to