qcacmn: add peer_id and msdu_len in qdf_nbuf_cb

Add peer_id and msdu_len in qdf_nbuf_cb these
fields are used for lithium rx performance
optimization

Change-Id: Iba291812397a5e7648953c2dc1b2c18a5c5a18af
This commit is contained in:
Chaithanya Garrepalli
2018-12-11 19:50:35 +05:30
committed by nshrivas
parent 5753f9bbe0
commit 4ff6e41de9
4 changed files with 210 additions and 6 deletions

View File

@@ -1101,6 +1101,122 @@ static inline int qdf_nbuf_is_rx_chfrag_end(qdf_nbuf_t buf)
return __qdf_nbuf_is_rx_chfrag_end(buf); return __qdf_nbuf_is_rx_chfrag_end(buf);
} }
/**
* qdf_nbuf_set_da_mcbc() - set da is mcbc
* @buf: Network buffer
* @val: 0/1
*
* Return: void
*/
static inline void
qdf_nbuf_set_da_mcbc(qdf_nbuf_t buf, uint8_t val)
{
__qdf_nbuf_set_da_mcbc(buf, val);
}
/**
* qdf_nbuf_is_da_mcbc() - get da is mcbc bit
* @buf: Network buffer
*
* Return: integer value - 0/1
*/
static inline int qdf_nbuf_is_da_mcbc(qdf_nbuf_t buf)
{
return __qdf_nbuf_is_da_mcbc(buf);
}
/**
* qdf_nbuf_set_da_valid() - set da valid bit
* @buf: Network buffer
* @val: 0/1
*
* Return: void
*/
static inline void qdf_nbuf_set_da_valid(qdf_nbuf_t buf, uint8_t val)
{
__qdf_nbuf_set_da_valid(buf, val);
}
/**
* qdf_nbuf_is_da_valid() - get da valid bit
* @buf: Network buffer
*
* Return: integer value - 0/1
*/
static inline int qdf_nbuf_is_da_valid(qdf_nbuf_t buf)
{
return __qdf_nbuf_is_da_valid(buf);
}
/**
* qdf_nbuf_set_sa_valid() - set sa valid bit
* @buf: Network buffer
* @val: 0/1
*
* Return: void
*/
static inline void qdf_nbuf_set_sa_valid(qdf_nbuf_t buf, uint8_t val)
{
__qdf_nbuf_set_sa_valid(buf, val);
}
/**
* qdf_nbuf_is_sa_valid() - get da valid bit
* @buf: Network buffer
*
* Return: integer value - 0/1
*/
static inline int qdf_nbuf_is_sa_valid(qdf_nbuf_t buf)
{
return __qdf_nbuf_is_sa_valid(buf);
}
/**
* qdf_nbuf_set_raw_frame() - set raw_frame bit
* @buf: Network buffer
* @val: 0/1
*
* Return: void
*/
static inline void qdf_nbuf_set_raw_frame(qdf_nbuf_t buf, uint8_t val)
{
__qdf_nbuf_set_raw_frame(buf, val);
}
/**
* qdf_nbuf_is_raw_frame() - get raw_frame bit
* @buf: Network buffer
*
* Return: integer value - 0/1
*/
static inline int qdf_nbuf_is_raw_frame(qdf_nbuf_t buf)
{
return __qdf_nbuf_is_raw_frame(buf);
}
/**
* qdf_nbuf_set_frag_list() - set frag list bit
* @buf: Network buffer
* @val: 0/1
*
* Return: void
*/
static inline void qdf_nbuf_set_is_frag(qdf_nbuf_t buf, uint8_t val)
{
__qdf_nbuf_set_is_frag(buf, val);
}
/**
* qdf_nbuf_is_sa_valid() - get da frag list bit
* @buf: Network buffer
*
* Return: integer value - 0/1
*/
static inline int qdf_nbuf_is_frag(qdf_nbuf_t buf)
{
return __qdf_nbuf_is_frag(buf);
}
/** /**
* qdf_nbuf_set_tx_chfrag_start() - set msdu start bit * qdf_nbuf_set_tx_chfrag_start() - set msdu start bit
* @buf: Network buffer * @buf: Network buffer

View File

@@ -99,13 +99,16 @@ typedef union {
* *
* @rx.dev.priv_cb_w.ext_cb_ptr: extended cb pointer * @rx.dev.priv_cb_w.ext_cb_ptr: extended cb pointer
* @rx.dev.priv_cb_w.fctx: ctx to handle special pkts defined by ftype * @rx.dev.priv_cb_w.fctx: ctx to handle special pkts defined by ftype
* @rx.dev.priv_cb_w.msdu_len: length of RX packet
* @rx.dev.priv_cb_w.peer_id: peer_id for RX packet
* @rx.dev.priv_cb_w.reserved1: reserved * @rx.dev.priv_cb_w.reserved1: reserved
* @rx.dev.priv_cb_w.reserved2: reserved
* *
* @rx.dev.priv_cb_m.tcp_seq_num: TCP sequence number * @rx.dev.priv_cb_m.tcp_seq_num: TCP sequence number
* @rx.dev.priv_cb_m.tcp_ack_num: TCP ACK number * @rx.dev.priv_cb_m.tcp_ack_num: TCP ACK number
* @rx.dev.priv_cb_m.lro_ctx: LRO context * @rx.dev.priv_cb_m.lro_ctx: LRO context
* @rx.dev.priv_cb_m.map_index: * @rx.dev.priv_cb_m.dp.wifi3.msdu_len: length of RX packet
* @rx.dev.priv_cb_m.dp.wifi3.peer_id: peer_id for RX packet
* @rx.dev.priv_cb_m.dp.wifi2.map_index:
* @rx.dev.priv_cb_m.peer_local_id: peer_local_id for RX pkt * @rx.dev.priv_cb_m.peer_local_id: peer_local_id for RX pkt
* @rx.dev.priv_cb_m.ipa_owned: packet owned by IPA * @rx.dev.priv_cb_m.ipa_owned: packet owned by IPA
* *
@@ -129,6 +132,10 @@ typedef union {
* @rx.flag_chfrag_cont: middle or part of MSDU in an AMSDU * @rx.flag_chfrag_cont: middle or part of MSDU in an AMSDU
* @rx.flag_chfrag_end: last MSDU in an AMSDU * @rx.flag_chfrag_end: last MSDU in an AMSDU
* @rx.packet_buff_pool: indicate packet from pre-allocated pool for Rx ring * @rx.packet_buff_pool: indicate packet from pre-allocated pool for Rx ring
* @rx.flag_da_mcbc: flag to indicate mulicast or broadcast packets
* @rx.flag_da_valid: flag to indicate DA is valid for RX packet
* @rx.flag_sa_valid: flag to indicate SA is valid for RX packet
* @rx.flag_is_frag: flag to indicate skb has frag list
* @rx.rsrvd: reserved * @rx.rsrvd: reserved
* *
* @rx.trace: combined structure for DP and protocol trace * @rx.trace: combined structure for DP and protocol trace
@@ -139,6 +146,7 @@ typedef union {
* @rx.trace.rsrvd: enable packet logging * @rx.trace.rsrvd: enable packet logging
* *
* @rx.ftype: mcast2ucast, TSO, SG, MESH * @rx.ftype: mcast2ucast, TSO, SG, MESH
* @rx.is_raw_frame: RAW frame
* @rx.reserved: reserved * @rx.reserved: reserved
* *
* @tx.dev.priv_cb_w.fctx: ctx to handle special pkts defined by ftype * @tx.dev.priv_cb_w.fctx: ctx to handle special pkts defined by ftype
@@ -196,8 +204,9 @@ struct qdf_nbuf_cb {
struct { struct {
void *ext_cb_ptr; void *ext_cb_ptr;
void *fctx; void *fctx;
uint16_t msdu_len;
uint16_t peer_id;
uint32_t reserved1; uint32_t reserved1;
uint32_t reserved2;
} priv_cb_w; } priv_cb_w;
struct { struct {
/* ipa_owned bit is common between rx /* ipa_owned bit is common between rx
@@ -209,7 +218,15 @@ struct qdf_nbuf_cb {
peer_local_id:16; peer_local_id:16;
uint32_t tcp_seq_num; uint32_t tcp_seq_num;
uint32_t tcp_ack_num; uint32_t tcp_ack_num;
uint32_t map_index; union {
struct {
uint16_t msdu_len;
uint16_t peer_id;
} wifi3;
struct {
uint32_t map_index;
} wifi2;
} dp;
unsigned char *lro_ctx; unsigned char *lro_ctx;
} priv_cb_m; } priv_cb_m;
} dev; } dev;
@@ -230,7 +247,10 @@ struct qdf_nbuf_cb {
flag_chfrag_cont:1, flag_chfrag_cont:1,
flag_chfrag_end:1, flag_chfrag_end:1,
packet_buff_pool:1, packet_buff_pool:1,
rsrvd:4; flag_da_mcbc:1,
flag_da_valid:1,
flag_sa_valid:1,
flag_is_frag:1;
union { union {
uint8_t packet_state; uint8_t packet_state;
uint8_t dp_trace:1, uint8_t dp_trace:1,
@@ -238,7 +258,8 @@ struct qdf_nbuf_cb {
rsrvd:3; rsrvd:3;
} trace; } trace;
uint8_t ftype; uint8_t ftype;
uint8_t reserved; uint8_t is_raw_frame:1,
reserved:7;
} rx; } rx;
/* Note: MAX: 40 bytes */ /* Note: MAX: 40 bytes */
@@ -365,6 +386,26 @@ QDF_COMPILE_TIME_ASSERT(qdf_nbuf_cb_size,
(((struct qdf_nbuf_cb *) \ (((struct qdf_nbuf_cb *) \
((skb)->cb))->u.rx.packet_buff_pool) ((skb)->cb))->u.rx.packet_buff_pool)
#define QDF_NBUF_CB_RX_DA_MCBC(skb) \
(((struct qdf_nbuf_cb *) \
((skb)->cb))->u.rx.flag_da_mcbc)
#define QDF_NBUF_CB_RX_DA_VALID(skb) \
(((struct qdf_nbuf_cb *) \
((skb)->cb))->u.rx.flag_da_valid)
#define QDF_NBUF_CB_RX_SA_VALID(skb) \
(((struct qdf_nbuf_cb *) \
((skb)->cb))->u.rx.flag_sa_valid)
#define QDF_NBUF_CB_RX_RAW_FRAME(skb) \
(((struct qdf_nbuf_cb *) \
((skb)->cb))->u.rx.is_raw_frame)
#define QDF_NBUF_CB_RX_IS_FRAG(skb) \
(((struct qdf_nbuf_cb *) \
((skb)->cb))->u.rx.flag_is_frag)
#define QDF_NBUF_UPDATE_TX_PKT_COUNT(skb, PACKET_STATE) \ #define QDF_NBUF_UPDATE_TX_PKT_COUNT(skb, PACKET_STATE) \
qdf_nbuf_set_state(skb, PACKET_STATE) qdf_nbuf_set_state(skb, PACKET_STATE)
@@ -570,6 +611,35 @@ typedef void (*qdf_nbuf_free_t)(__qdf_nbuf_t);
#define __qdf_nbuf_is_rx_chfrag_end(skb) \ #define __qdf_nbuf_is_rx_chfrag_end(skb) \
(QDF_NBUF_CB_RX_CHFRAG_END((skb))) (QDF_NBUF_CB_RX_CHFRAG_END((skb)))
#define __qdf_nbuf_set_da_mcbc(skb, val) \
((QDF_NBUF_CB_RX_DA_MCBC((skb))) = val)
#define __qdf_nbuf_is_da_mcbc(skb) \
(QDF_NBUF_CB_RX_DA_MCBC((skb)))
#define __qdf_nbuf_set_da_valid(skb, val) \
((QDF_NBUF_CB_RX_DA_VALID((skb))) = val)
#define __qdf_nbuf_is_da_valid(skb) \
(QDF_NBUF_CB_RX_DA_VALID((skb)))
#define __qdf_nbuf_set_sa_valid(skb, val) \
((QDF_NBUF_CB_RX_SA_VALID((skb))) = val)
#define __qdf_nbuf_is_sa_valid(skb) \
(QDF_NBUF_CB_RX_SA_VALID((skb)))
#define __qdf_nbuf_set_raw_frame(skb, val) \
((QDF_NBUF_CB_RX_RAW_FRAME((skb))) = val)
#define __qdf_nbuf_is_raw_frame(skb) \
(QDF_NBUF_CB_RX_RAW_FRAME((skb)))
#define __qdf_nbuf_set_is_frag(skb, val) \
((QDF_NBUF_CB_RX_IS_FRAG((skb))) = val)
#define __qdf_nbuf_is_frag(skb) \
(QDF_NBUF_CB_RX_IS_FRAG((skb)))
#define __qdf_nbuf_set_tx_chfrag_start(skb, val) \ #define __qdf_nbuf_set_tx_chfrag_start(skb, val) \
((QDF_NBUF_CB_TX_EXTRA_FRAG_FLAGS_CHFRAG_START((skb))) = val) ((QDF_NBUF_CB_TX_EXTRA_FRAG_FLAGS_CHFRAG_START((skb))) = val)

View File

@@ -49,6 +49,18 @@
(((struct qdf_nbuf_cb *)((skb)->cb))->u.tx.dev.priv_cb_m. \ (((struct qdf_nbuf_cb *)((skb)->cb))->u.tx.dev.priv_cb_m. \
dma_option.bi_map) dma_option.bi_map)
#define QDF_NBUF_CB_RX_PEER_ID(skb) \
(((struct qdf_nbuf_cb *)((skb)->cb))->u.rx.dev.priv_cb_m.dp. \
wifi3.peer_id)
#define QDF_NBUF_CB_RX_PKT_LEN(skb) \
(((struct qdf_nbuf_cb *)((skb)->cb))->u.rx.dev.priv_cb_m.dp. \
wifi3.msdu_len)
#define QDF_NBUF_CB_RX_MAP_IDX(skb) \
(((struct qdf_nbuf_cb *)((skb)->cb))->u.rx.dev.priv_cb_m.dp. \
wifi2.map_index)
#define __qdf_nbuf_ipa_owned_get(skb) \ #define __qdf_nbuf_ipa_owned_get(skb) \
QDF_NBUF_CB_TX_IPA_OWNED(skb) QDF_NBUF_CB_TX_IPA_OWNED(skb)

View File

@@ -48,6 +48,12 @@
#define QDF_NBUF_CB_TX_FCTX(skb) \ #define QDF_NBUF_CB_TX_FCTX(skb) \
(((struct qdf_nbuf_cb *)((skb)->cb))->u.tx.dev.priv_cb_w.fctx) (((struct qdf_nbuf_cb *)((skb)->cb))->u.tx.dev.priv_cb_w.fctx)
#define QDF_NBUF_CB_RX_PEER_ID(skb) \
(((struct qdf_nbuf_cb *)((skb)->cb))->u.rx.dev.priv_cb_w.peer_id)
#define QDF_NBUF_CB_RX_PKT_LEN(skb) \
(((struct qdf_nbuf_cb *)((skb)->cb))->u.rx.dev.priv_cb_w.msdu_len)
#define __qdf_nbuf_set_rx_fctx_type(skb, ctx, type) \ #define __qdf_nbuf_set_rx_fctx_type(skb, ctx, type) \
do { \ do { \
QDF_NBUF_CB_RX_FCTX((skb)) = (ctx); \ QDF_NBUF_CB_RX_FCTX((skb)) = (ctx); \