hc
2024-05-10 37f49e37ab4cb5d0bc4c60eb5c6d4dd57db767bb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
 * Copyright (c) 2016 Chelsio Communications, Inc.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation.
 *
 */
 
#ifndef    __CXGBIT_LRO_H__
#define    __CXGBIT_LRO_H__
 
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/errno.h>
#include <linux/types.h>
#include <linux/skbuff.h>
 
#define LRO_FLUSH_LEN_MAX    65535
 
struct cxgbit_lro_cb {
   struct cxgbit_sock *csk;
   u32 pdu_totallen;
   u32 offset;
   u8 pdu_idx;
   bool complete;
};
 
enum cxgbit_pducb_flags {
   PDUCBF_RX_HDR        = (1 << 0), /* received pdu header */
   PDUCBF_RX_DATA        = (1 << 1), /* received pdu payload */
   PDUCBF_RX_STATUS    = (1 << 2), /* received ddp status */
   PDUCBF_RX_DATA_DDPD    = (1 << 3), /* pdu payload ddp'd */
   PDUCBF_RX_DDP_CMP    = (1 << 4), /* ddp completion */
   PDUCBF_RX_HCRC_ERR    = (1 << 5), /* header digest error */
   PDUCBF_RX_DCRC_ERR    = (1 << 6), /* data digest error */
};
 
struct cxgbit_lro_pdu_cb {
   u8 flags;
   u8 frags;
   u8 hfrag_idx;
   u8 nr_dfrags;
   u8 dfrag_idx;
   bool complete;
   u32 seq;
   u32 pdulen;
   u32 hlen;
   u32 dlen;
   u32 doffset;
   u32 ddigest;
   void *hdr;
};
 
#define LRO_SKB_MAX_HEADROOM  \
       (sizeof(struct cxgbit_lro_cb) + \
        (MAX_SKB_FRAGS * sizeof(struct cxgbit_lro_pdu_cb)))
 
#define LRO_SKB_MIN_HEADROOM  \
       (sizeof(struct cxgbit_lro_cb) + \
        sizeof(struct cxgbit_lro_pdu_cb))
 
#define cxgbit_skb_lro_cb(skb)    ((struct cxgbit_lro_cb *)skb->data)
#define cxgbit_skb_lro_pdu_cb(skb, i)    \
   ((struct cxgbit_lro_pdu_cb *)(skb->data + sizeof(struct cxgbit_lro_cb) \
       + (i * sizeof(struct cxgbit_lro_pdu_cb))))
 
#define CPL_RX_ISCSI_DDP_STATUS_DDP_SHIFT    16 /* ddp'able */
#define CPL_RX_ISCSI_DDP_STATUS_PAD_SHIFT    19 /* pad error */
#define CPL_RX_ISCSI_DDP_STATUS_HCRC_SHIFT    20 /* hcrc error */
#define CPL_RX_ISCSI_DDP_STATUS_DCRC_SHIFT    21 /* dcrc error */
 
#endif    /*__CXGBIT_LRO_H_*/