131 lines
		
	
	
	
		
			3.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			131 lines
		
	
	
	
		
			3.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Linux network driver for Brocade Converged Network Adapter.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * This program is free software; you can redistribute it and/or modify it
							 | 
						||
| 
								 | 
							
								 * under the terms of the GNU General Public License (GPL) Version 2 as
							 | 
						||
| 
								 | 
							
								 * published by the Free Software Foundation
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * This program is distributed in the hope that it will be useful, but
							 | 
						||
| 
								 | 
							
								 * WITHOUT ANY WARRANTY; without even the implied warranty of
							 | 
						||
| 
								 | 
							
								 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
							 | 
						||
| 
								 | 
							
								 * General Public License for more details.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Copyright (c) 2005-2011 Brocade Communications Systems, Inc.
							 | 
						||
| 
								 | 
							
								 * All rights reserved
							 | 
						||
| 
								 | 
							
								 * www.brocade.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
							 |