hc
2024-10-22 8ac6c7a54ed1b98d142dce24b11c6de6a1e239a5
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Linux network driver for QLogic BR-series Converged Network Adapter.
 */
/*
 * Copyright (c) 2005-2014 Brocade Communications Systems, Inc.
 * Copyright (c) 2014-2015 QLogic Corporation
 * All rights reserved
 * www.qlogic.com
 */
 
#ifndef __BFA_MSGQ_H__
#define __BFA_MSGQ_H__
 
#include "bfa_defs.h"
#include "bfi.h"
#include "bfa_ioc.h"
#include "bfa_cs.h"
 
#define BFA_MSGQ_FREE_CNT(_q)                        \
   (((_q)->consumer_index - (_q)->producer_index - 1) & ((_q)->depth - 1))
 
#define BFA_MSGQ_INDX_ADD(_q_indx, _qe_num, _q_depth)            \
   ((_q_indx) = (((_q_indx) + (_qe_num)) & ((_q_depth) - 1)))
 
#define BFA_MSGQ_CMDQ_NUM_ENTRY        128
#define BFA_MSGQ_CMDQ_SIZE                        \
   (BFI_MSGQ_CMD_ENTRY_SIZE * BFA_MSGQ_CMDQ_NUM_ENTRY)
 
#define BFA_MSGQ_RSPQ_NUM_ENTRY        128
#define BFA_MSGQ_RSPQ_SIZE                        \
   (BFI_MSGQ_RSP_ENTRY_SIZE * BFA_MSGQ_RSPQ_NUM_ENTRY)
 
#define bfa_msgq_cmd_set(_cmd, _cbfn, _cbarg, _msg_size, _msg_hdr)    \
do {                                    \
   (_cmd)->cbfn = (_cbfn);                        \
   (_cmd)->cbarg = (_cbarg);                    \
   (_cmd)->msg_size = (_msg_size);                    \
   (_cmd)->msg_hdr = (_msg_hdr);                    \
} while (0)
 
struct bfa_msgq;
 
typedef void (*bfa_msgq_cmdcbfn_t)(void *cbarg, enum bfa_status status);
 
struct bfa_msgq_cmd_entry {
   struct list_head                qe;
   bfa_msgq_cmdcbfn_t        cbfn;
   void                *cbarg;
   size_t                msg_size;
   struct bfi_msgq_mhdr *msg_hdr;
};
 
enum bfa_msgq_cmdq_flags {
   BFA_MSGQ_CMDQ_F_DB_UPDATE    = 1,
};
 
struct bfa_msgq_cmdq {
   bfa_fsm_t            fsm;
   enum bfa_msgq_cmdq_flags flags;
 
   u16            producer_index;
   u16            consumer_index;
   u16            depth; /* FW Q depth is 16 bits */
   struct bfa_dma addr;
   struct bfa_mbox_cmd dbell_mb;
 
   u16            token;
   int                offset;
   int                bytes_to_copy;
   struct bfa_mbox_cmd copy_mb;
 
   struct list_head        pending_q; /* pending command queue */
 
   struct bfa_msgq *msgq;
};
 
enum bfa_msgq_rspq_flags {
   BFA_MSGQ_RSPQ_F_DB_UPDATE    = 1,
};
 
typedef void (*bfa_msgq_mcfunc_t)(void *cbarg, struct bfi_msgq_mhdr *mhdr);
 
struct bfa_msgq_rspq {
   bfa_fsm_t            fsm;
   enum bfa_msgq_rspq_flags flags;
 
   u16            producer_index;
   u16            consumer_index;
   u16            depth; /* FW Q depth is 16 bits */
   struct bfa_dma addr;
   struct bfa_mbox_cmd dbell_mb;
 
   int                nmclass;
   struct {
       bfa_msgq_mcfunc_t    cbfn;
       void            *cbarg;
   } rsphdlr[BFI_MC_MAX];
 
   struct bfa_msgq *msgq;
};
 
struct bfa_msgq {
   struct bfa_msgq_cmdq cmdq;
   struct bfa_msgq_rspq rspq;
 
   struct bfa_wc            init_wc;
   struct bfa_mbox_cmd init_mb;
 
   struct bfa_ioc_notify ioc_notify;
   struct bfa_ioc *ioc;
};
 
u32 bfa_msgq_meminfo(void);
void bfa_msgq_memclaim(struct bfa_msgq *msgq, u8 *kva, u64 pa);
void bfa_msgq_attach(struct bfa_msgq *msgq, struct bfa_ioc *ioc);
void bfa_msgq_regisr(struct bfa_msgq *msgq, enum bfi_mclass mc,
            bfa_msgq_mcfunc_t cbfn, void *cbarg);
void bfa_msgq_cmd_post(struct bfa_msgq *msgq,
              struct bfa_msgq_cmd_entry *cmd);
void bfa_msgq_rsp_copy(struct bfa_msgq *msgq, u8 *buf, size_t buf_len);
 
#endif