162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/* Marvell RVU Admin Function driver
362306a36Sopenharmony_ci *
462306a36Sopenharmony_ci * Copyright (C) 2018 Marvell.
562306a36Sopenharmony_ci *
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#ifndef MBOX_H
962306a36Sopenharmony_ci#define MBOX_H
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <linux/etherdevice.h>
1262306a36Sopenharmony_ci#include <linux/sizes.h>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci#include "rvu_struct.h"
1562306a36Sopenharmony_ci#include "common.h"
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci#define MBOX_SIZE		SZ_64K
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci#define MBOX_DOWN_MSG		1
2062306a36Sopenharmony_ci#define MBOX_UP_MSG		2
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci/* AF/PF: PF initiated, PF/VF VF initiated */
2362306a36Sopenharmony_ci#define MBOX_DOWN_RX_START	0
2462306a36Sopenharmony_ci#define MBOX_DOWN_RX_SIZE	(46 * SZ_1K)
2562306a36Sopenharmony_ci#define MBOX_DOWN_TX_START	(MBOX_DOWN_RX_START + MBOX_DOWN_RX_SIZE)
2662306a36Sopenharmony_ci#define MBOX_DOWN_TX_SIZE	(16 * SZ_1K)
2762306a36Sopenharmony_ci/* AF/PF: AF initiated, PF/VF PF initiated */
2862306a36Sopenharmony_ci#define MBOX_UP_RX_START	(MBOX_DOWN_TX_START + MBOX_DOWN_TX_SIZE)
2962306a36Sopenharmony_ci#define MBOX_UP_RX_SIZE		SZ_1K
3062306a36Sopenharmony_ci#define MBOX_UP_TX_START	(MBOX_UP_RX_START + MBOX_UP_RX_SIZE)
3162306a36Sopenharmony_ci#define MBOX_UP_TX_SIZE		SZ_1K
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci#if MBOX_UP_TX_SIZE + MBOX_UP_TX_START != MBOX_SIZE
3462306a36Sopenharmony_ci# error "incorrect mailbox area sizes"
3562306a36Sopenharmony_ci#endif
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci#define INTR_MASK(pfvfs) ((pfvfs < 64) ? (BIT_ULL(pfvfs) - 1) : (~0ull))
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci#define MBOX_RSP_TIMEOUT	6000 /* Time(ms) to wait for mbox response */
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci#define MBOX_MSG_ALIGN		16  /* Align mbox msg start to 16bytes */
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci/* Mailbox directions */
4462306a36Sopenharmony_ci#define MBOX_DIR_AFPF		0  /* AF replies to PF */
4562306a36Sopenharmony_ci#define MBOX_DIR_PFAF		1  /* PF sends messages to AF */
4662306a36Sopenharmony_ci#define MBOX_DIR_PFVF		2  /* PF replies to VF */
4762306a36Sopenharmony_ci#define MBOX_DIR_VFPF		3  /* VF sends messages to PF */
4862306a36Sopenharmony_ci#define MBOX_DIR_AFPF_UP	4  /* AF sends messages to PF */
4962306a36Sopenharmony_ci#define MBOX_DIR_PFAF_UP	5  /* PF replies to AF */
5062306a36Sopenharmony_ci#define MBOX_DIR_PFVF_UP	6  /* PF sends messages to VF */
5162306a36Sopenharmony_ci#define MBOX_DIR_VFPF_UP	7  /* VF replies to PF */
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_cistruct otx2_mbox_dev {
5462306a36Sopenharmony_ci	void	    *mbase;   /* This dev's mbox region */
5562306a36Sopenharmony_ci	void	    *hwbase;
5662306a36Sopenharmony_ci	spinlock_t  mbox_lock;
5762306a36Sopenharmony_ci	u16         msg_size; /* Total msg size to be sent */
5862306a36Sopenharmony_ci	u16         rsp_size; /* Total rsp size to be sure the reply is ok */
5962306a36Sopenharmony_ci	u16         num_msgs; /* No of msgs sent or waiting for response */
6062306a36Sopenharmony_ci	u16         msgs_acked; /* No of msgs for which response is received */
6162306a36Sopenharmony_ci};
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_cistruct otx2_mbox {
6462306a36Sopenharmony_ci	struct pci_dev *pdev;
6562306a36Sopenharmony_ci	void   *hwbase;  /* Mbox region advertised by HW */
6662306a36Sopenharmony_ci	void   *reg_base;/* CSR base for this dev */
6762306a36Sopenharmony_ci	u64    trigger;  /* Trigger mbox notification */
6862306a36Sopenharmony_ci	u16    tr_shift; /* Mbox trigger shift */
6962306a36Sopenharmony_ci	u64    rx_start; /* Offset of Rx region in mbox memory */
7062306a36Sopenharmony_ci	u64    tx_start; /* Offset of Tx region in mbox memory */
7162306a36Sopenharmony_ci	u16    rx_size;  /* Size of Rx region */
7262306a36Sopenharmony_ci	u16    tx_size;  /* Size of Tx region */
7362306a36Sopenharmony_ci	u16    ndevs;    /* The number of peers */
7462306a36Sopenharmony_ci	struct otx2_mbox_dev *dev;
7562306a36Sopenharmony_ci};
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ci/* Header which precedes all mbox messages */
7862306a36Sopenharmony_cistruct mbox_hdr {
7962306a36Sopenharmony_ci	u64 msg_size;	/* Total msgs size embedded */
8062306a36Sopenharmony_ci	u16  num_msgs;   /* No of msgs embedded */
8162306a36Sopenharmony_ci};
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci/* Header which precedes every msg and is also part of it */
8462306a36Sopenharmony_cistruct mbox_msghdr {
8562306a36Sopenharmony_ci	u16 pcifunc;     /* Who's sending this msg */
8662306a36Sopenharmony_ci	u16 id;          /* Mbox message ID */
8762306a36Sopenharmony_ci#define OTX2_MBOX_REQ_SIG (0xdead)
8862306a36Sopenharmony_ci#define OTX2_MBOX_RSP_SIG (0xbeef)
8962306a36Sopenharmony_ci	u16 sig;         /* Signature, for validating corrupted msgs */
9062306a36Sopenharmony_ci#define OTX2_MBOX_VERSION (0x000a)
9162306a36Sopenharmony_ci	u16 ver;         /* Version of msg's structure for this ID */
9262306a36Sopenharmony_ci	u16 next_msgoff; /* Offset of next msg within mailbox region */
9362306a36Sopenharmony_ci	int rc;          /* Msg process'ed response code */
9462306a36Sopenharmony_ci};
9562306a36Sopenharmony_ci
9662306a36Sopenharmony_civoid otx2_mbox_reset(struct otx2_mbox *mbox, int devid);
9762306a36Sopenharmony_civoid __otx2_mbox_reset(struct otx2_mbox *mbox, int devid);
9862306a36Sopenharmony_civoid otx2_mbox_destroy(struct otx2_mbox *mbox);
9962306a36Sopenharmony_ciint otx2_mbox_init(struct otx2_mbox *mbox, void __force *hwbase,
10062306a36Sopenharmony_ci		   struct pci_dev *pdev, void __force *reg_base,
10162306a36Sopenharmony_ci		   int direction, int ndevs);
10262306a36Sopenharmony_ci
10362306a36Sopenharmony_ciint otx2_mbox_regions_init(struct otx2_mbox *mbox, void __force **hwbase,
10462306a36Sopenharmony_ci			   struct pci_dev *pdev, void __force *reg_base,
10562306a36Sopenharmony_ci			   int direction, int ndevs, unsigned long *bmap);
10662306a36Sopenharmony_civoid otx2_mbox_msg_send(struct otx2_mbox *mbox, int devid);
10762306a36Sopenharmony_civoid otx2_mbox_msg_send_up(struct otx2_mbox *mbox, int devid);
10862306a36Sopenharmony_ciint otx2_mbox_wait_for_rsp(struct otx2_mbox *mbox, int devid);
10962306a36Sopenharmony_ciint otx2_mbox_busy_poll_for_rsp(struct otx2_mbox *mbox, int devid);
11062306a36Sopenharmony_cistruct mbox_msghdr *otx2_mbox_alloc_msg_rsp(struct otx2_mbox *mbox, int devid,
11162306a36Sopenharmony_ci					    int size, int size_rsp);
11262306a36Sopenharmony_cistruct mbox_msghdr *otx2_mbox_get_rsp(struct otx2_mbox *mbox, int devid,
11362306a36Sopenharmony_ci				      struct mbox_msghdr *msg);
11462306a36Sopenharmony_ciint otx2_mbox_check_rsp_msgs(struct otx2_mbox *mbox, int devid);
11562306a36Sopenharmony_ciint otx2_reply_invalid_msg(struct otx2_mbox *mbox, int devid,
11662306a36Sopenharmony_ci			   u16 pcifunc, u16 id);
11762306a36Sopenharmony_cibool otx2_mbox_nonempty(struct otx2_mbox *mbox, int devid);
11862306a36Sopenharmony_ciconst char *otx2_mbox_id2name(u16 id);
11962306a36Sopenharmony_cistatic inline struct mbox_msghdr *otx2_mbox_alloc_msg(struct otx2_mbox *mbox,
12062306a36Sopenharmony_ci						      int devid, int size)
12162306a36Sopenharmony_ci{
12262306a36Sopenharmony_ci	return otx2_mbox_alloc_msg_rsp(mbox, devid, size, 0);
12362306a36Sopenharmony_ci}
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_cibool otx2_mbox_wait_for_zero(struct otx2_mbox *mbox, int devid);
12662306a36Sopenharmony_ci
12762306a36Sopenharmony_ci/* Mailbox message types */
12862306a36Sopenharmony_ci#define MBOX_MSG_MASK				0xFFFF
12962306a36Sopenharmony_ci#define MBOX_MSG_INVALID			0xFFFE
13062306a36Sopenharmony_ci#define MBOX_MSG_MAX				0xFFFF
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_ci#define MBOX_MESSAGES							\
13362306a36Sopenharmony_ci/* Generic mbox IDs (range 0x000 - 0x1FF) */				\
13462306a36Sopenharmony_ciM(READY,		0x001, ready, msg_req, ready_msg_rsp)		\
13562306a36Sopenharmony_ciM(ATTACH_RESOURCES,	0x002, attach_resources, rsrc_attach, msg_rsp)	\
13662306a36Sopenharmony_ciM(DETACH_RESOURCES,	0x003, detach_resources, rsrc_detach, msg_rsp)	\
13762306a36Sopenharmony_ciM(FREE_RSRC_CNT,	0x004, free_rsrc_cnt, msg_req, free_rsrcs_rsp)	\
13862306a36Sopenharmony_ciM(MSIX_OFFSET,		0x005, msix_offset, msg_req, msix_offset_rsp)	\
13962306a36Sopenharmony_ciM(VF_FLR,		0x006, vf_flr, msg_req, msg_rsp)		\
14062306a36Sopenharmony_ciM(PTP_OP,		0x007, ptp_op, ptp_req, ptp_rsp)		\
14162306a36Sopenharmony_ciM(GET_HW_CAP,		0x008, get_hw_cap, msg_req, get_hw_cap_rsp)	\
14262306a36Sopenharmony_ciM(LMTST_TBL_SETUP,	0x00a, lmtst_tbl_setup, lmtst_tbl_setup_req,    \
14362306a36Sopenharmony_ci				msg_rsp)				\
14462306a36Sopenharmony_ciM(SET_VF_PERM,		0x00b, set_vf_perm, set_vf_perm, msg_rsp)	\
14562306a36Sopenharmony_ciM(PTP_GET_CAP,		0x00c, ptp_get_cap, msg_req, ptp_get_cap_rsp)	\
14662306a36Sopenharmony_ci/* CGX mbox IDs (range 0x200 - 0x3FF) */				\
14762306a36Sopenharmony_ciM(CGX_START_RXTX,	0x200, cgx_start_rxtx, msg_req, msg_rsp)	\
14862306a36Sopenharmony_ciM(CGX_STOP_RXTX,	0x201, cgx_stop_rxtx, msg_req, msg_rsp)		\
14962306a36Sopenharmony_ciM(CGX_STATS,		0x202, cgx_stats, msg_req, cgx_stats_rsp)	\
15062306a36Sopenharmony_ciM(CGX_MAC_ADDR_SET,	0x203, cgx_mac_addr_set, cgx_mac_addr_set_or_get,    \
15162306a36Sopenharmony_ci				cgx_mac_addr_set_or_get)		\
15262306a36Sopenharmony_ciM(CGX_MAC_ADDR_GET,	0x204, cgx_mac_addr_get, cgx_mac_addr_set_or_get,    \
15362306a36Sopenharmony_ci				cgx_mac_addr_set_or_get)		\
15462306a36Sopenharmony_ciM(CGX_PROMISC_ENABLE,	0x205, cgx_promisc_enable, msg_req, msg_rsp)	\
15562306a36Sopenharmony_ciM(CGX_PROMISC_DISABLE,	0x206, cgx_promisc_disable, msg_req, msg_rsp)	\
15662306a36Sopenharmony_ciM(CGX_START_LINKEVENTS, 0x207, cgx_start_linkevents, msg_req, msg_rsp)	\
15762306a36Sopenharmony_ciM(CGX_STOP_LINKEVENTS,	0x208, cgx_stop_linkevents, msg_req, msg_rsp)	\
15862306a36Sopenharmony_ciM(CGX_GET_LINKINFO,	0x209, cgx_get_linkinfo, msg_req, cgx_link_info_msg) \
15962306a36Sopenharmony_ciM(CGX_INTLBK_ENABLE,	0x20A, cgx_intlbk_enable, msg_req, msg_rsp)	\
16062306a36Sopenharmony_ciM(CGX_INTLBK_DISABLE,	0x20B, cgx_intlbk_disable, msg_req, msg_rsp)	\
16162306a36Sopenharmony_ciM(CGX_PTP_RX_ENABLE,	0x20C, cgx_ptp_rx_enable, msg_req, msg_rsp)	\
16262306a36Sopenharmony_ciM(CGX_PTP_RX_DISABLE,	0x20D, cgx_ptp_rx_disable, msg_req, msg_rsp)	\
16362306a36Sopenharmony_ciM(CGX_CFG_PAUSE_FRM,	0x20E, cgx_cfg_pause_frm, cgx_pause_frm_cfg,	\
16462306a36Sopenharmony_ci			       cgx_pause_frm_cfg)			\
16562306a36Sopenharmony_ciM(CGX_FW_DATA_GET,	0x20F, cgx_get_aux_link_info, msg_req, cgx_fw_data) \
16662306a36Sopenharmony_ciM(CGX_FEC_SET,		0x210, cgx_set_fec_param, fec_mode, fec_mode) \
16762306a36Sopenharmony_ciM(CGX_MAC_ADDR_ADD,	0x211, cgx_mac_addr_add, cgx_mac_addr_add_req,    \
16862306a36Sopenharmony_ci				cgx_mac_addr_add_rsp)		\
16962306a36Sopenharmony_ciM(CGX_MAC_ADDR_DEL,	0x212, cgx_mac_addr_del, cgx_mac_addr_del_req,    \
17062306a36Sopenharmony_ci			       msg_rsp)		\
17162306a36Sopenharmony_ciM(CGX_MAC_MAX_ENTRIES_GET, 0x213, cgx_mac_max_entries_get, msg_req,    \
17262306a36Sopenharmony_ci				  cgx_max_dmac_entries_get_rsp)		\
17362306a36Sopenharmony_ciM(CGX_FEC_STATS,	0x217, cgx_fec_stats, msg_req, cgx_fec_stats_rsp) \
17462306a36Sopenharmony_ciM(CGX_SET_LINK_MODE,	0x218, cgx_set_link_mode, cgx_set_link_mode_req,\
17562306a36Sopenharmony_ci			       cgx_set_link_mode_rsp)	\
17662306a36Sopenharmony_ciM(CGX_GET_PHY_FEC_STATS, 0x219, cgx_get_phy_fec_stats, msg_req, msg_rsp) \
17762306a36Sopenharmony_ciM(CGX_FEATURES_GET,	0x21B, cgx_features_get, msg_req,		\
17862306a36Sopenharmony_ci			       cgx_features_info_msg)			\
17962306a36Sopenharmony_ciM(RPM_STATS,		0x21C, rpm_stats, msg_req, rpm_stats_rsp)	\
18062306a36Sopenharmony_ciM(CGX_MAC_ADDR_RESET,	0x21D, cgx_mac_addr_reset, cgx_mac_addr_reset_req, \
18162306a36Sopenharmony_ci							msg_rsp) \
18262306a36Sopenharmony_ciM(CGX_MAC_ADDR_UPDATE,	0x21E, cgx_mac_addr_update, cgx_mac_addr_update_req, \
18362306a36Sopenharmony_ci						    cgx_mac_addr_update_rsp) \
18462306a36Sopenharmony_ciM(CGX_PRIO_FLOW_CTRL_CFG, 0x21F, cgx_prio_flow_ctrl_cfg, cgx_pfc_cfg,  \
18562306a36Sopenharmony_ci				 cgx_pfc_rsp)                               \
18662306a36Sopenharmony_ci/* NPA mbox IDs (range 0x400 - 0x5FF) */				\
18762306a36Sopenharmony_ciM(NPA_LF_ALLOC,		0x400, npa_lf_alloc,				\
18862306a36Sopenharmony_ci				npa_lf_alloc_req, npa_lf_alloc_rsp)	\
18962306a36Sopenharmony_ciM(NPA_LF_FREE,		0x401, npa_lf_free, msg_req, msg_rsp)		\
19062306a36Sopenharmony_ciM(NPA_AQ_ENQ,		0x402, npa_aq_enq, npa_aq_enq_req, npa_aq_enq_rsp)   \
19162306a36Sopenharmony_ciM(NPA_HWCTX_DISABLE,	0x403, npa_hwctx_disable, hwctx_disable_req, msg_rsp)\
19262306a36Sopenharmony_ci/* SSO/SSOW mbox IDs (range 0x600 - 0x7FF) */				\
19362306a36Sopenharmony_ci/* TIM mbox IDs (range 0x800 - 0x9FF) */				\
19462306a36Sopenharmony_ci/* CPT mbox IDs (range 0xA00 - 0xBFF) */				\
19562306a36Sopenharmony_ciM(CPT_LF_ALLOC,		0xA00, cpt_lf_alloc, cpt_lf_alloc_req_msg,	\
19662306a36Sopenharmony_ci			       msg_rsp)					\
19762306a36Sopenharmony_ciM(CPT_LF_FREE,		0xA01, cpt_lf_free, msg_req, msg_rsp)		\
19862306a36Sopenharmony_ciM(CPT_RD_WR_REGISTER,	0xA02, cpt_rd_wr_register,  cpt_rd_wr_reg_msg,	\
19962306a36Sopenharmony_ci			       cpt_rd_wr_reg_msg)			\
20062306a36Sopenharmony_ciM(CPT_INLINE_IPSEC_CFG,	0xA04, cpt_inline_ipsec_cfg,			\
20162306a36Sopenharmony_ci			       cpt_inline_ipsec_cfg_msg, msg_rsp)	\
20262306a36Sopenharmony_ciM(CPT_STATS,            0xA05, cpt_sts, cpt_sts_req, cpt_sts_rsp)	\
20362306a36Sopenharmony_ciM(CPT_RXC_TIME_CFG,     0xA06, cpt_rxc_time_cfg, cpt_rxc_time_cfg_req,  \
20462306a36Sopenharmony_ci			       msg_rsp)                                 \
20562306a36Sopenharmony_ciM(CPT_CTX_CACHE_SYNC,   0xA07, cpt_ctx_cache_sync, msg_req, msg_rsp)    \
20662306a36Sopenharmony_ciM(CPT_LF_RESET,         0xA08, cpt_lf_reset, cpt_lf_rst_req, msg_rsp)	\
20762306a36Sopenharmony_ciM(CPT_FLT_ENG_INFO,     0xA09, cpt_flt_eng_info, cpt_flt_eng_info_req,	\
20862306a36Sopenharmony_ci			       cpt_flt_eng_info_rsp)			\
20962306a36Sopenharmony_ci/* SDP mbox IDs (range 0x1000 - 0x11FF) */				\
21062306a36Sopenharmony_ciM(SET_SDP_CHAN_INFO, 0x1000, set_sdp_chan_info, sdp_chan_info_msg, msg_rsp) \
21162306a36Sopenharmony_ciM(GET_SDP_CHAN_INFO, 0x1001, get_sdp_chan_info, msg_req, sdp_get_chan_info_msg) \
21262306a36Sopenharmony_ci/* NPC mbox IDs (range 0x6000 - 0x7FFF) */				\
21362306a36Sopenharmony_ciM(NPC_MCAM_ALLOC_ENTRY,	0x6000, npc_mcam_alloc_entry, npc_mcam_alloc_entry_req,\
21462306a36Sopenharmony_ci				npc_mcam_alloc_entry_rsp)		\
21562306a36Sopenharmony_ciM(NPC_MCAM_FREE_ENTRY,	0x6001, npc_mcam_free_entry,			\
21662306a36Sopenharmony_ci				 npc_mcam_free_entry_req, msg_rsp)	\
21762306a36Sopenharmony_ciM(NPC_MCAM_WRITE_ENTRY,	0x6002, npc_mcam_write_entry,			\
21862306a36Sopenharmony_ci				 npc_mcam_write_entry_req, msg_rsp)	\
21962306a36Sopenharmony_ciM(NPC_MCAM_ENA_ENTRY,   0x6003, npc_mcam_ena_entry,			\
22062306a36Sopenharmony_ci				 npc_mcam_ena_dis_entry_req, msg_rsp)	\
22162306a36Sopenharmony_ciM(NPC_MCAM_DIS_ENTRY,   0x6004, npc_mcam_dis_entry,			\
22262306a36Sopenharmony_ci				 npc_mcam_ena_dis_entry_req, msg_rsp)	\
22362306a36Sopenharmony_ciM(NPC_MCAM_SHIFT_ENTRY, 0x6005, npc_mcam_shift_entry, npc_mcam_shift_entry_req,\
22462306a36Sopenharmony_ci				npc_mcam_shift_entry_rsp)		\
22562306a36Sopenharmony_ciM(NPC_MCAM_ALLOC_COUNTER, 0x6006, npc_mcam_alloc_counter,		\
22662306a36Sopenharmony_ci					npc_mcam_alloc_counter_req,	\
22762306a36Sopenharmony_ci					npc_mcam_alloc_counter_rsp)	\
22862306a36Sopenharmony_ciM(NPC_MCAM_FREE_COUNTER,  0x6007, npc_mcam_free_counter,		\
22962306a36Sopenharmony_ci				    npc_mcam_oper_counter_req, msg_rsp)	\
23062306a36Sopenharmony_ciM(NPC_MCAM_UNMAP_COUNTER, 0x6008, npc_mcam_unmap_counter,		\
23162306a36Sopenharmony_ci				   npc_mcam_unmap_counter_req, msg_rsp)	\
23262306a36Sopenharmony_ciM(NPC_MCAM_CLEAR_COUNTER, 0x6009, npc_mcam_clear_counter,		\
23362306a36Sopenharmony_ci				   npc_mcam_oper_counter_req, msg_rsp)	\
23462306a36Sopenharmony_ciM(NPC_MCAM_COUNTER_STATS, 0x600a, npc_mcam_counter_stats,		\
23562306a36Sopenharmony_ci				   npc_mcam_oper_counter_req,		\
23662306a36Sopenharmony_ci				   npc_mcam_oper_counter_rsp)		\
23762306a36Sopenharmony_ciM(NPC_MCAM_ALLOC_AND_WRITE_ENTRY, 0x600b, npc_mcam_alloc_and_write_entry,      \
23862306a36Sopenharmony_ci					  npc_mcam_alloc_and_write_entry_req,  \
23962306a36Sopenharmony_ci					  npc_mcam_alloc_and_write_entry_rsp)  \
24062306a36Sopenharmony_ciM(NPC_GET_KEX_CFG,	  0x600c, npc_get_kex_cfg,			\
24162306a36Sopenharmony_ci				   msg_req, npc_get_kex_cfg_rsp)	\
24262306a36Sopenharmony_ciM(NPC_INSTALL_FLOW,	  0x600d, npc_install_flow,			       \
24362306a36Sopenharmony_ci				  npc_install_flow_req, npc_install_flow_rsp)  \
24462306a36Sopenharmony_ciM(NPC_DELETE_FLOW,	  0x600e, npc_delete_flow,			\
24562306a36Sopenharmony_ci				  npc_delete_flow_req, npc_delete_flow_rsp)		\
24662306a36Sopenharmony_ciM(NPC_MCAM_READ_ENTRY,	  0x600f, npc_mcam_read_entry,			\
24762306a36Sopenharmony_ci				  npc_mcam_read_entry_req,		\
24862306a36Sopenharmony_ci				  npc_mcam_read_entry_rsp)		\
24962306a36Sopenharmony_ciM(NPC_SET_PKIND,        0x6010,   npc_set_pkind,                        \
25062306a36Sopenharmony_ci				  npc_set_pkind, msg_rsp)               \
25162306a36Sopenharmony_ciM(NPC_MCAM_READ_BASE_RULE, 0x6011, npc_read_base_steer_rule,            \
25262306a36Sopenharmony_ci				   msg_req, npc_mcam_read_base_rule_rsp)  \
25362306a36Sopenharmony_ciM(NPC_MCAM_GET_STATS, 0x6012, npc_mcam_entry_stats,                     \
25462306a36Sopenharmony_ci				   npc_mcam_get_stats_req,              \
25562306a36Sopenharmony_ci				   npc_mcam_get_stats_rsp)              \
25662306a36Sopenharmony_ciM(NPC_GET_FIELD_HASH_INFO, 0x6013, npc_get_field_hash_info,                     \
25762306a36Sopenharmony_ci				   npc_get_field_hash_info_req,              \
25862306a36Sopenharmony_ci				   npc_get_field_hash_info_rsp)              \
25962306a36Sopenharmony_ciM(NPC_GET_FIELD_STATUS, 0x6014, npc_get_field_status,                     \
26062306a36Sopenharmony_ci				   npc_get_field_status_req,              \
26162306a36Sopenharmony_ci				   npc_get_field_status_rsp)              \
26262306a36Sopenharmony_ci/* NIX mbox IDs (range 0x8000 - 0xFFFF) */				\
26362306a36Sopenharmony_ciM(NIX_LF_ALLOC,		0x8000, nix_lf_alloc,				\
26462306a36Sopenharmony_ci				 nix_lf_alloc_req, nix_lf_alloc_rsp)	\
26562306a36Sopenharmony_ciM(NIX_LF_FREE,		0x8001, nix_lf_free, nix_lf_free_req, msg_rsp)	\
26662306a36Sopenharmony_ciM(NIX_AQ_ENQ,		0x8002, nix_aq_enq, nix_aq_enq_req, nix_aq_enq_rsp)  \
26762306a36Sopenharmony_ciM(NIX_HWCTX_DISABLE,	0x8003, nix_hwctx_disable,			\
26862306a36Sopenharmony_ci				 hwctx_disable_req, msg_rsp)		\
26962306a36Sopenharmony_ciM(NIX_TXSCH_ALLOC,	0x8004, nix_txsch_alloc,			\
27062306a36Sopenharmony_ci				 nix_txsch_alloc_req, nix_txsch_alloc_rsp)   \
27162306a36Sopenharmony_ciM(NIX_TXSCH_FREE,	0x8005, nix_txsch_free, nix_txsch_free_req, msg_rsp) \
27262306a36Sopenharmony_ciM(NIX_TXSCHQ_CFG,	0x8006, nix_txschq_cfg, nix_txschq_config,	\
27362306a36Sopenharmony_ci				nix_txschq_config)			\
27462306a36Sopenharmony_ciM(NIX_STATS_RST,	0x8007, nix_stats_rst, msg_req, msg_rsp)	\
27562306a36Sopenharmony_ciM(NIX_VTAG_CFG,		0x8008, nix_vtag_cfg, nix_vtag_config,		\
27662306a36Sopenharmony_ci				 nix_vtag_config_rsp)			\
27762306a36Sopenharmony_ciM(NIX_RSS_FLOWKEY_CFG,  0x8009, nix_rss_flowkey_cfg,			\
27862306a36Sopenharmony_ci				 nix_rss_flowkey_cfg,			\
27962306a36Sopenharmony_ci				 nix_rss_flowkey_cfg_rsp)		\
28062306a36Sopenharmony_ciM(NIX_SET_MAC_ADDR,	0x800a, nix_set_mac_addr, nix_set_mac_addr, msg_rsp) \
28162306a36Sopenharmony_ciM(NIX_SET_RX_MODE,	0x800b, nix_set_rx_mode, nix_rx_mode, msg_rsp)	\
28262306a36Sopenharmony_ciM(NIX_SET_HW_FRS,	0x800c, nix_set_hw_frs, nix_frs_cfg, msg_rsp)	\
28362306a36Sopenharmony_ciM(NIX_LF_START_RX,	0x800d, nix_lf_start_rx, msg_req, msg_rsp)	\
28462306a36Sopenharmony_ciM(NIX_LF_STOP_RX,	0x800e, nix_lf_stop_rx, msg_req, msg_rsp)	\
28562306a36Sopenharmony_ciM(NIX_MARK_FORMAT_CFG,	0x800f, nix_mark_format_cfg,			\
28662306a36Sopenharmony_ci				 nix_mark_format_cfg,			\
28762306a36Sopenharmony_ci				 nix_mark_format_cfg_rsp)		\
28862306a36Sopenharmony_ciM(NIX_SET_RX_CFG,	0x8010, nix_set_rx_cfg, nix_rx_cfg, msg_rsp)	\
28962306a36Sopenharmony_ciM(NIX_LSO_FORMAT_CFG,	0x8011, nix_lso_format_cfg,			\
29062306a36Sopenharmony_ci				 nix_lso_format_cfg,			\
29162306a36Sopenharmony_ci				 nix_lso_format_cfg_rsp)		\
29262306a36Sopenharmony_ciM(NIX_LF_PTP_TX_ENABLE, 0x8013, nix_lf_ptp_tx_enable, msg_req, msg_rsp)	\
29362306a36Sopenharmony_ciM(NIX_LF_PTP_TX_DISABLE, 0x8014, nix_lf_ptp_tx_disable, msg_req, msg_rsp) \
29462306a36Sopenharmony_ciM(NIX_BP_ENABLE,	0x8016, nix_bp_enable, nix_bp_cfg_req,	\
29562306a36Sopenharmony_ci				nix_bp_cfg_rsp)	\
29662306a36Sopenharmony_ciM(NIX_BP_DISABLE,	0x8017, nix_bp_disable, nix_bp_cfg_req, msg_rsp) \
29762306a36Sopenharmony_ciM(NIX_GET_MAC_ADDR, 0x8018, nix_get_mac_addr, msg_req, nix_get_mac_addr_rsp) \
29862306a36Sopenharmony_ciM(NIX_INLINE_IPSEC_CFG, 0x8019, nix_inline_ipsec_cfg,			\
29962306a36Sopenharmony_ci				nix_inline_ipsec_cfg, msg_rsp)		\
30062306a36Sopenharmony_ciM(NIX_INLINE_IPSEC_LF_CFG, 0x801a, nix_inline_ipsec_lf_cfg,		\
30162306a36Sopenharmony_ci				nix_inline_ipsec_lf_cfg, msg_rsp)	\
30262306a36Sopenharmony_ciM(NIX_CN10K_AQ_ENQ,	0x801b, nix_cn10k_aq_enq, nix_cn10k_aq_enq_req, \
30362306a36Sopenharmony_ci				nix_cn10k_aq_enq_rsp)			\
30462306a36Sopenharmony_ciM(NIX_GET_HW_INFO,	0x801c, nix_get_hw_info, msg_req, nix_hw_info)	\
30562306a36Sopenharmony_ciM(NIX_BANDPROF_ALLOC,	0x801d, nix_bandprof_alloc, nix_bandprof_alloc_req, \
30662306a36Sopenharmony_ci				nix_bandprof_alloc_rsp)			    \
30762306a36Sopenharmony_ciM(NIX_BANDPROF_FREE,	0x801e, nix_bandprof_free, nix_bandprof_free_req,   \
30862306a36Sopenharmony_ci				msg_rsp)				    \
30962306a36Sopenharmony_ciM(NIX_BANDPROF_GET_HWINFO, 0x801f, nix_bandprof_get_hwinfo, msg_req,		\
31062306a36Sopenharmony_ci				nix_bandprof_get_hwinfo_rsp)		    \
31162306a36Sopenharmony_ciM(NIX_READ_INLINE_IPSEC_CFG, 0x8023, nix_read_inline_ipsec_cfg,		\
31262306a36Sopenharmony_ci				msg_req, nix_inline_ipsec_cfg)		\
31362306a36Sopenharmony_ci/* MCS mbox IDs (range 0xA000 - 0xBFFF) */					\
31462306a36Sopenharmony_ciM(MCS_ALLOC_RESOURCES,	0xa000, mcs_alloc_resources, mcs_alloc_rsrc_req,	\
31562306a36Sopenharmony_ci				mcs_alloc_rsrc_rsp)				\
31662306a36Sopenharmony_ciM(MCS_FREE_RESOURCES,	0xa001, mcs_free_resources, mcs_free_rsrc_req, msg_rsp) \
31762306a36Sopenharmony_ciM(MCS_FLOWID_ENTRY_WRITE, 0xa002, mcs_flowid_entry_write, mcs_flowid_entry_write_req,	\
31862306a36Sopenharmony_ci				msg_rsp)					\
31962306a36Sopenharmony_ciM(MCS_SECY_PLCY_WRITE,	0xa003, mcs_secy_plcy_write, mcs_secy_plcy_write_req,	\
32062306a36Sopenharmony_ci				msg_rsp)					\
32162306a36Sopenharmony_ciM(MCS_RX_SC_CAM_WRITE,	0xa004, mcs_rx_sc_cam_write, mcs_rx_sc_cam_write_req,	\
32262306a36Sopenharmony_ci				msg_rsp)					\
32362306a36Sopenharmony_ciM(MCS_SA_PLCY_WRITE,	0xa005, mcs_sa_plcy_write, mcs_sa_plcy_write_req,	\
32462306a36Sopenharmony_ci				msg_rsp)					\
32562306a36Sopenharmony_ciM(MCS_TX_SC_SA_MAP_WRITE, 0xa006, mcs_tx_sc_sa_map_write, mcs_tx_sc_sa_map,	\
32662306a36Sopenharmony_ci				  msg_rsp)					\
32762306a36Sopenharmony_ciM(MCS_RX_SC_SA_MAP_WRITE, 0xa007, mcs_rx_sc_sa_map_write, mcs_rx_sc_sa_map,	\
32862306a36Sopenharmony_ci				  msg_rsp)					\
32962306a36Sopenharmony_ciM(MCS_FLOWID_ENA_ENTRY,	0xa008, mcs_flowid_ena_entry, mcs_flowid_ena_dis_entry,	\
33062306a36Sopenharmony_ci				msg_rsp)					\
33162306a36Sopenharmony_ciM(MCS_PN_TABLE_WRITE,	0xa009, mcs_pn_table_write, mcs_pn_table_write_req,	\
33262306a36Sopenharmony_ci				msg_rsp)					\
33362306a36Sopenharmony_ciM(MCS_SET_ACTIVE_LMAC,	0xa00a,	mcs_set_active_lmac, mcs_set_active_lmac,	\
33462306a36Sopenharmony_ci				msg_rsp)					\
33562306a36Sopenharmony_ciM(MCS_GET_HW_INFO,	0xa00b,	mcs_get_hw_info, msg_req, mcs_hw_info)		\
33662306a36Sopenharmony_ciM(MCS_GET_FLOWID_STATS, 0xa00c, mcs_get_flowid_stats, mcs_stats_req,		\
33762306a36Sopenharmony_ci				mcs_flowid_stats)				\
33862306a36Sopenharmony_ciM(MCS_GET_SECY_STATS,	0xa00d, mcs_get_secy_stats, mcs_stats_req,		\
33962306a36Sopenharmony_ci				mcs_secy_stats)					\
34062306a36Sopenharmony_ciM(MCS_GET_SC_STATS,	0xa00e, mcs_get_sc_stats, mcs_stats_req, mcs_sc_stats)	\
34162306a36Sopenharmony_ciM(MCS_GET_SA_STATS,	0xa00f, mcs_get_sa_stats, mcs_stats_req, mcs_sa_stats)	\
34262306a36Sopenharmony_ciM(MCS_GET_PORT_STATS,	0xa010, mcs_get_port_stats, mcs_stats_req,		\
34362306a36Sopenharmony_ci				mcs_port_stats)					\
34462306a36Sopenharmony_ciM(MCS_CLEAR_STATS,	0xa011,	mcs_clear_stats, mcs_clear_stats, msg_rsp)	\
34562306a36Sopenharmony_ciM(MCS_INTR_CFG,		0xa012, mcs_intr_cfg, mcs_intr_cfg, msg_rsp)		\
34662306a36Sopenharmony_ciM(MCS_SET_LMAC_MODE,	0xa013, mcs_set_lmac_mode, mcs_set_lmac_mode, msg_rsp)	\
34762306a36Sopenharmony_ciM(MCS_SET_PN_THRESHOLD, 0xa014, mcs_set_pn_threshold, mcs_set_pn_threshold,	\
34862306a36Sopenharmony_ci				msg_rsp)					\
34962306a36Sopenharmony_ciM(MCS_ALLOC_CTRL_PKT_RULE, 0xa015, mcs_alloc_ctrl_pkt_rule,			\
35062306a36Sopenharmony_ci				   mcs_alloc_ctrl_pkt_rule_req,			\
35162306a36Sopenharmony_ci				   mcs_alloc_ctrl_pkt_rule_rsp)			\
35262306a36Sopenharmony_ciM(MCS_FREE_CTRL_PKT_RULE, 0xa016, mcs_free_ctrl_pkt_rule,			\
35362306a36Sopenharmony_ci				  mcs_free_ctrl_pkt_rule_req, msg_rsp)		\
35462306a36Sopenharmony_ciM(MCS_CTRL_PKT_RULE_WRITE, 0xa017, mcs_ctrl_pkt_rule_write,			\
35562306a36Sopenharmony_ci				   mcs_ctrl_pkt_rule_write_req, msg_rsp)	\
35662306a36Sopenharmony_ciM(MCS_PORT_RESET,	0xa018, mcs_port_reset, mcs_port_reset_req, msg_rsp)	\
35762306a36Sopenharmony_ciM(MCS_PORT_CFG_SET,	0xa019, mcs_port_cfg_set, mcs_port_cfg_set_req, msg_rsp)\
35862306a36Sopenharmony_ciM(MCS_PORT_CFG_GET,	0xa020, mcs_port_cfg_get, mcs_port_cfg_get_req,		\
35962306a36Sopenharmony_ci				mcs_port_cfg_get_rsp)				\
36062306a36Sopenharmony_ciM(MCS_CUSTOM_TAG_CFG_GET, 0xa021, mcs_custom_tag_cfg_get,			\
36162306a36Sopenharmony_ci				  mcs_custom_tag_cfg_get_req,			\
36262306a36Sopenharmony_ci				  mcs_custom_tag_cfg_get_rsp)
36362306a36Sopenharmony_ci
36462306a36Sopenharmony_ci/* Messages initiated by AF (range 0xC00 - 0xEFF) */
36562306a36Sopenharmony_ci#define MBOX_UP_CGX_MESSAGES						\
36662306a36Sopenharmony_ciM(CGX_LINK_EVENT,	0xC00, cgx_link_event, cgx_link_info_msg, msg_rsp)
36762306a36Sopenharmony_ci
36862306a36Sopenharmony_ci#define MBOX_UP_CPT_MESSAGES						\
36962306a36Sopenharmony_ciM(CPT_INST_LMTST,	0xD00, cpt_inst_lmtst, cpt_inst_lmtst_req, msg_rsp)
37062306a36Sopenharmony_ci
37162306a36Sopenharmony_ci#define MBOX_UP_MCS_MESSAGES						\
37262306a36Sopenharmony_ciM(MCS_INTR_NOTIFY,	0xE00, mcs_intr_notify, mcs_intr_info, msg_rsp)
37362306a36Sopenharmony_ci
37462306a36Sopenharmony_cienum {
37562306a36Sopenharmony_ci#define M(_name, _id, _1, _2, _3) MBOX_MSG_ ## _name = _id,
37662306a36Sopenharmony_ciMBOX_MESSAGES
37762306a36Sopenharmony_ciMBOX_UP_CGX_MESSAGES
37862306a36Sopenharmony_ciMBOX_UP_CPT_MESSAGES
37962306a36Sopenharmony_ciMBOX_UP_MCS_MESSAGES
38062306a36Sopenharmony_ci#undef M
38162306a36Sopenharmony_ci};
38262306a36Sopenharmony_ci
38362306a36Sopenharmony_ci/* Mailbox message formats */
38462306a36Sopenharmony_ci
38562306a36Sopenharmony_ci#define RVU_DEFAULT_PF_FUNC     0xFFFF
38662306a36Sopenharmony_ci
38762306a36Sopenharmony_ci/* Generic request msg used for those mbox messages which
38862306a36Sopenharmony_ci * don't send any data in the request.
38962306a36Sopenharmony_ci */
39062306a36Sopenharmony_cistruct msg_req {
39162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
39262306a36Sopenharmony_ci};
39362306a36Sopenharmony_ci
39462306a36Sopenharmony_ci/* Generic response msg used an ack or response for those mbox
39562306a36Sopenharmony_ci * messages which don't have a specific rsp msg format.
39662306a36Sopenharmony_ci */
39762306a36Sopenharmony_cistruct msg_rsp {
39862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
39962306a36Sopenharmony_ci};
40062306a36Sopenharmony_ci
40162306a36Sopenharmony_ci/* RVU mailbox error codes
40262306a36Sopenharmony_ci * Range 256 - 300.
40362306a36Sopenharmony_ci */
40462306a36Sopenharmony_cienum rvu_af_status {
40562306a36Sopenharmony_ci	RVU_INVALID_VF_ID           = -256,
40662306a36Sopenharmony_ci};
40762306a36Sopenharmony_ci
40862306a36Sopenharmony_cistruct ready_msg_rsp {
40962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
41062306a36Sopenharmony_ci	u16    sclk_freq;	/* SCLK frequency (in MHz) */
41162306a36Sopenharmony_ci	u16    rclk_freq;	/* RCLK frequency (in MHz) */
41262306a36Sopenharmony_ci};
41362306a36Sopenharmony_ci
41462306a36Sopenharmony_ci/* Structure for requesting resource provisioning.
41562306a36Sopenharmony_ci * 'modify' flag to be used when either requesting more
41662306a36Sopenharmony_ci * or to detach partial of a certain resource type.
41762306a36Sopenharmony_ci * Rest of the fields specify how many of what type to
41862306a36Sopenharmony_ci * be attached.
41962306a36Sopenharmony_ci * To request LFs from two blocks of same type this mailbox
42062306a36Sopenharmony_ci * can be sent twice as below:
42162306a36Sopenharmony_ci *      struct rsrc_attach *attach;
42262306a36Sopenharmony_ci *       .. Allocate memory for message ..
42362306a36Sopenharmony_ci *       attach->cptlfs = 3; <3 LFs from CPT0>
42462306a36Sopenharmony_ci *       .. Send message ..
42562306a36Sopenharmony_ci *       .. Allocate memory for message ..
42662306a36Sopenharmony_ci *       attach->modify = 1;
42762306a36Sopenharmony_ci *       attach->cpt_blkaddr = BLKADDR_CPT1;
42862306a36Sopenharmony_ci *       attach->cptlfs = 2; <2 LFs from CPT1>
42962306a36Sopenharmony_ci *       .. Send message ..
43062306a36Sopenharmony_ci */
43162306a36Sopenharmony_cistruct rsrc_attach {
43262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
43362306a36Sopenharmony_ci	u8   modify:1;
43462306a36Sopenharmony_ci	u8   npalf:1;
43562306a36Sopenharmony_ci	u8   nixlf:1;
43662306a36Sopenharmony_ci	u16  sso;
43762306a36Sopenharmony_ci	u16  ssow;
43862306a36Sopenharmony_ci	u16  timlfs;
43962306a36Sopenharmony_ci	u16  cptlfs;
44062306a36Sopenharmony_ci	int  cpt_blkaddr; /* BLKADDR_CPT0/BLKADDR_CPT1 or 0 for BLKADDR_CPT0 */
44162306a36Sopenharmony_ci};
44262306a36Sopenharmony_ci
44362306a36Sopenharmony_ci/* Structure for relinquishing resources.
44462306a36Sopenharmony_ci * 'partial' flag to be used when relinquishing all resources
44562306a36Sopenharmony_ci * but only of a certain type. If not set, all resources of all
44662306a36Sopenharmony_ci * types provisioned to the RVU function will be detached.
44762306a36Sopenharmony_ci */
44862306a36Sopenharmony_cistruct rsrc_detach {
44962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
45062306a36Sopenharmony_ci	u8 partial:1;
45162306a36Sopenharmony_ci	u8 npalf:1;
45262306a36Sopenharmony_ci	u8 nixlf:1;
45362306a36Sopenharmony_ci	u8 sso:1;
45462306a36Sopenharmony_ci	u8 ssow:1;
45562306a36Sopenharmony_ci	u8 timlfs:1;
45662306a36Sopenharmony_ci	u8 cptlfs:1;
45762306a36Sopenharmony_ci};
45862306a36Sopenharmony_ci
45962306a36Sopenharmony_ci/* Number of resources available to the caller.
46062306a36Sopenharmony_ci * In reply to MBOX_MSG_FREE_RSRC_CNT.
46162306a36Sopenharmony_ci */
46262306a36Sopenharmony_cistruct free_rsrcs_rsp {
46362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
46462306a36Sopenharmony_ci	u16 schq[NIX_TXSCH_LVL_CNT];
46562306a36Sopenharmony_ci	u16  sso;
46662306a36Sopenharmony_ci	u16  tim;
46762306a36Sopenharmony_ci	u16  ssow;
46862306a36Sopenharmony_ci	u16  cpt;
46962306a36Sopenharmony_ci	u8   npa;
47062306a36Sopenharmony_ci	u8   nix;
47162306a36Sopenharmony_ci	u16  schq_nix1[NIX_TXSCH_LVL_CNT];
47262306a36Sopenharmony_ci	u8   nix1;
47362306a36Sopenharmony_ci	u8   cpt1;
47462306a36Sopenharmony_ci	u8   ree0;
47562306a36Sopenharmony_ci	u8   ree1;
47662306a36Sopenharmony_ci};
47762306a36Sopenharmony_ci
47862306a36Sopenharmony_ci#define MSIX_VECTOR_INVALID	0xFFFF
47962306a36Sopenharmony_ci#define MAX_RVU_BLKLF_CNT	256
48062306a36Sopenharmony_ci
48162306a36Sopenharmony_cistruct msix_offset_rsp {
48262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
48362306a36Sopenharmony_ci	u16  npa_msixoff;
48462306a36Sopenharmony_ci	u16  nix_msixoff;
48562306a36Sopenharmony_ci	u16  sso;
48662306a36Sopenharmony_ci	u16  ssow;
48762306a36Sopenharmony_ci	u16  timlfs;
48862306a36Sopenharmony_ci	u16  cptlfs;
48962306a36Sopenharmony_ci	u16  sso_msixoff[MAX_RVU_BLKLF_CNT];
49062306a36Sopenharmony_ci	u16  ssow_msixoff[MAX_RVU_BLKLF_CNT];
49162306a36Sopenharmony_ci	u16  timlf_msixoff[MAX_RVU_BLKLF_CNT];
49262306a36Sopenharmony_ci	u16  cptlf_msixoff[MAX_RVU_BLKLF_CNT];
49362306a36Sopenharmony_ci	u16  cpt1_lfs;
49462306a36Sopenharmony_ci	u16  ree0_lfs;
49562306a36Sopenharmony_ci	u16  ree1_lfs;
49662306a36Sopenharmony_ci	u16  cpt1_lf_msixoff[MAX_RVU_BLKLF_CNT];
49762306a36Sopenharmony_ci	u16  ree0_lf_msixoff[MAX_RVU_BLKLF_CNT];
49862306a36Sopenharmony_ci	u16  ree1_lf_msixoff[MAX_RVU_BLKLF_CNT];
49962306a36Sopenharmony_ci};
50062306a36Sopenharmony_ci
50162306a36Sopenharmony_cistruct get_hw_cap_rsp {
50262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
50362306a36Sopenharmony_ci	u8 nix_fixed_txschq_mapping; /* Schq mapping fixed or flexible */
50462306a36Sopenharmony_ci	u8 nix_shaping;		     /* Is shaping and coloring supported */
50562306a36Sopenharmony_ci	u8 npc_hash_extract;	/* Is hash extract supported */
50662306a36Sopenharmony_ci};
50762306a36Sopenharmony_ci
50862306a36Sopenharmony_ci/* CGX mbox message formats */
50962306a36Sopenharmony_ci
51062306a36Sopenharmony_cistruct cgx_stats_rsp {
51162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
51262306a36Sopenharmony_ci#define CGX_RX_STATS_COUNT	9
51362306a36Sopenharmony_ci#define CGX_TX_STATS_COUNT	18
51462306a36Sopenharmony_ci	u64 rx_stats[CGX_RX_STATS_COUNT];
51562306a36Sopenharmony_ci	u64 tx_stats[CGX_TX_STATS_COUNT];
51662306a36Sopenharmony_ci};
51762306a36Sopenharmony_ci
51862306a36Sopenharmony_cistruct cgx_fec_stats_rsp {
51962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
52062306a36Sopenharmony_ci	u64 fec_corr_blks;
52162306a36Sopenharmony_ci	u64 fec_uncorr_blks;
52262306a36Sopenharmony_ci};
52362306a36Sopenharmony_ci/* Structure for requesting the operation for
52462306a36Sopenharmony_ci * setting/getting mac address in the CGX interface
52562306a36Sopenharmony_ci */
52662306a36Sopenharmony_cistruct cgx_mac_addr_set_or_get {
52762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
52862306a36Sopenharmony_ci	u8 mac_addr[ETH_ALEN];
52962306a36Sopenharmony_ci	u32 index;
53062306a36Sopenharmony_ci};
53162306a36Sopenharmony_ci
53262306a36Sopenharmony_ci/* Structure for requesting the operation to
53362306a36Sopenharmony_ci * add DMAC filter entry into CGX interface
53462306a36Sopenharmony_ci */
53562306a36Sopenharmony_cistruct cgx_mac_addr_add_req {
53662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
53762306a36Sopenharmony_ci	u8 mac_addr[ETH_ALEN];
53862306a36Sopenharmony_ci};
53962306a36Sopenharmony_ci
54062306a36Sopenharmony_ci/* Structure for response against the operation to
54162306a36Sopenharmony_ci * add DMAC filter entry into CGX interface
54262306a36Sopenharmony_ci */
54362306a36Sopenharmony_cistruct cgx_mac_addr_add_rsp {
54462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
54562306a36Sopenharmony_ci	u32 index;
54662306a36Sopenharmony_ci};
54762306a36Sopenharmony_ci
54862306a36Sopenharmony_ci/* Structure for requesting the operation to
54962306a36Sopenharmony_ci * delete DMAC filter entry from CGX interface
55062306a36Sopenharmony_ci */
55162306a36Sopenharmony_cistruct cgx_mac_addr_del_req {
55262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
55362306a36Sopenharmony_ci	u32 index;
55462306a36Sopenharmony_ci};
55562306a36Sopenharmony_ci
55662306a36Sopenharmony_ci/* Structure for response against the operation to
55762306a36Sopenharmony_ci * get maximum supported DMAC filter entries
55862306a36Sopenharmony_ci */
55962306a36Sopenharmony_cistruct cgx_max_dmac_entries_get_rsp {
56062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
56162306a36Sopenharmony_ci	u32 max_dmac_filters;
56262306a36Sopenharmony_ci};
56362306a36Sopenharmony_ci
56462306a36Sopenharmony_cistruct cgx_link_user_info {
56562306a36Sopenharmony_ci	uint64_t link_up:1;
56662306a36Sopenharmony_ci	uint64_t full_duplex:1;
56762306a36Sopenharmony_ci	uint64_t lmac_type_id:4;
56862306a36Sopenharmony_ci	uint64_t speed:20; /* speed in Mbps */
56962306a36Sopenharmony_ci	uint64_t an:1;		/* AN supported or not */
57062306a36Sopenharmony_ci	uint64_t fec:2;	 /* FEC type if enabled else 0 */
57162306a36Sopenharmony_ci#define LMACTYPE_STR_LEN 16
57262306a36Sopenharmony_ci	char lmac_type[LMACTYPE_STR_LEN];
57362306a36Sopenharmony_ci};
57462306a36Sopenharmony_ci
57562306a36Sopenharmony_cistruct cgx_link_info_msg {
57662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
57762306a36Sopenharmony_ci	struct cgx_link_user_info link_info;
57862306a36Sopenharmony_ci};
57962306a36Sopenharmony_ci
58062306a36Sopenharmony_cistruct cgx_pause_frm_cfg {
58162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
58262306a36Sopenharmony_ci	u8 set;
58362306a36Sopenharmony_ci	/* set = 1 if the request is to config pause frames */
58462306a36Sopenharmony_ci	/* set = 0 if the request is to fetch pause frames config */
58562306a36Sopenharmony_ci	u8 rx_pause;
58662306a36Sopenharmony_ci	u8 tx_pause;
58762306a36Sopenharmony_ci};
58862306a36Sopenharmony_ci
58962306a36Sopenharmony_cienum fec_type {
59062306a36Sopenharmony_ci	OTX2_FEC_NONE,
59162306a36Sopenharmony_ci	OTX2_FEC_BASER,
59262306a36Sopenharmony_ci	OTX2_FEC_RS,
59362306a36Sopenharmony_ci	OTX2_FEC_STATS_CNT = 2,
59462306a36Sopenharmony_ci	OTX2_FEC_OFF,
59562306a36Sopenharmony_ci};
59662306a36Sopenharmony_ci
59762306a36Sopenharmony_cistruct fec_mode {
59862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
59962306a36Sopenharmony_ci	int fec;
60062306a36Sopenharmony_ci};
60162306a36Sopenharmony_ci
60262306a36Sopenharmony_cistruct sfp_eeprom_s {
60362306a36Sopenharmony_ci#define SFP_EEPROM_SIZE 256
60462306a36Sopenharmony_ci	u16 sff_id;
60562306a36Sopenharmony_ci	u8 buf[SFP_EEPROM_SIZE];
60662306a36Sopenharmony_ci	u64 reserved;
60762306a36Sopenharmony_ci};
60862306a36Sopenharmony_ci
60962306a36Sopenharmony_cistruct phy_s {
61062306a36Sopenharmony_ci	struct {
61162306a36Sopenharmony_ci		u64 can_change_mod_type:1;
61262306a36Sopenharmony_ci		u64 mod_type:1;
61362306a36Sopenharmony_ci		u64 has_fec_stats:1;
61462306a36Sopenharmony_ci	} misc;
61562306a36Sopenharmony_ci	struct fec_stats_s {
61662306a36Sopenharmony_ci		u32 rsfec_corr_cws;
61762306a36Sopenharmony_ci		u32 rsfec_uncorr_cws;
61862306a36Sopenharmony_ci		u32 brfec_corr_blks;
61962306a36Sopenharmony_ci		u32 brfec_uncorr_blks;
62062306a36Sopenharmony_ci	} fec_stats;
62162306a36Sopenharmony_ci};
62262306a36Sopenharmony_ci
62362306a36Sopenharmony_cistruct cgx_lmac_fwdata_s {
62462306a36Sopenharmony_ci	u16 rw_valid;
62562306a36Sopenharmony_ci	u64 supported_fec;
62662306a36Sopenharmony_ci	u64 supported_an;
62762306a36Sopenharmony_ci	u64 supported_link_modes;
62862306a36Sopenharmony_ci	/* only applicable if AN is supported */
62962306a36Sopenharmony_ci	u64 advertised_fec;
63062306a36Sopenharmony_ci	u64 advertised_link_modes;
63162306a36Sopenharmony_ci	/* Only applicable if SFP/QSFP slot is present */
63262306a36Sopenharmony_ci	struct sfp_eeprom_s sfp_eeprom;
63362306a36Sopenharmony_ci	struct phy_s phy;
63462306a36Sopenharmony_ci#define LMAC_FWDATA_RESERVED_MEM 1021
63562306a36Sopenharmony_ci	u64 reserved[LMAC_FWDATA_RESERVED_MEM];
63662306a36Sopenharmony_ci};
63762306a36Sopenharmony_ci
63862306a36Sopenharmony_cistruct cgx_fw_data {
63962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
64062306a36Sopenharmony_ci	struct cgx_lmac_fwdata_s fwdata;
64162306a36Sopenharmony_ci};
64262306a36Sopenharmony_ci
64362306a36Sopenharmony_cistruct cgx_set_link_mode_args {
64462306a36Sopenharmony_ci	u32 speed;
64562306a36Sopenharmony_ci	u8 duplex;
64662306a36Sopenharmony_ci	u8 an;
64762306a36Sopenharmony_ci	u8 ports;
64862306a36Sopenharmony_ci	u64 mode;
64962306a36Sopenharmony_ci};
65062306a36Sopenharmony_ci
65162306a36Sopenharmony_cistruct cgx_set_link_mode_req {
65262306a36Sopenharmony_ci#define AUTONEG_UNKNOWN		0xff
65362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
65462306a36Sopenharmony_ci	struct cgx_set_link_mode_args args;
65562306a36Sopenharmony_ci};
65662306a36Sopenharmony_ci
65762306a36Sopenharmony_cistruct cgx_set_link_mode_rsp {
65862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
65962306a36Sopenharmony_ci	int status;
66062306a36Sopenharmony_ci};
66162306a36Sopenharmony_ci
66262306a36Sopenharmony_cistruct cgx_mac_addr_reset_req {
66362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
66462306a36Sopenharmony_ci	u32 index;
66562306a36Sopenharmony_ci};
66662306a36Sopenharmony_ci
66762306a36Sopenharmony_cistruct cgx_mac_addr_update_req {
66862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
66962306a36Sopenharmony_ci	u8 mac_addr[ETH_ALEN];
67062306a36Sopenharmony_ci	u32 index;
67162306a36Sopenharmony_ci};
67262306a36Sopenharmony_ci
67362306a36Sopenharmony_cistruct cgx_mac_addr_update_rsp {
67462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
67562306a36Sopenharmony_ci	u32 index;
67662306a36Sopenharmony_ci};
67762306a36Sopenharmony_ci
67862306a36Sopenharmony_ci#define RVU_LMAC_FEAT_FC		BIT_ULL(0) /* pause frames */
67962306a36Sopenharmony_ci#define	RVU_LMAC_FEAT_HIGIG2		BIT_ULL(1)
68062306a36Sopenharmony_ci			/* flow control from physical link higig2 messages */
68162306a36Sopenharmony_ci#define RVU_LMAC_FEAT_PTP		BIT_ULL(2) /* precison time protocol */
68262306a36Sopenharmony_ci#define RVU_LMAC_FEAT_DMACF		BIT_ULL(3) /* DMAC FILTER */
68362306a36Sopenharmony_ci#define RVU_MAC_VERSION			BIT_ULL(4)
68462306a36Sopenharmony_ci#define RVU_MAC_CGX			BIT_ULL(5)
68562306a36Sopenharmony_ci#define RVU_MAC_RPM			BIT_ULL(6)
68662306a36Sopenharmony_ci
68762306a36Sopenharmony_cistruct cgx_features_info_msg {
68862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
68962306a36Sopenharmony_ci	u64    lmac_features;
69062306a36Sopenharmony_ci};
69162306a36Sopenharmony_ci
69262306a36Sopenharmony_cistruct rpm_stats_rsp {
69362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
69462306a36Sopenharmony_ci#define RPM_RX_STATS_COUNT		43
69562306a36Sopenharmony_ci#define RPM_TX_STATS_COUNT		34
69662306a36Sopenharmony_ci	u64 rx_stats[RPM_RX_STATS_COUNT];
69762306a36Sopenharmony_ci	u64 tx_stats[RPM_TX_STATS_COUNT];
69862306a36Sopenharmony_ci};
69962306a36Sopenharmony_ci
70062306a36Sopenharmony_cistruct cgx_pfc_cfg {
70162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
70262306a36Sopenharmony_ci	u8 rx_pause;
70362306a36Sopenharmony_ci	u8 tx_pause;
70462306a36Sopenharmony_ci	u16 pfc_en; /*  bitmap indicating pfc enabled traffic classes */
70562306a36Sopenharmony_ci};
70662306a36Sopenharmony_ci
70762306a36Sopenharmony_cistruct cgx_pfc_rsp {
70862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
70962306a36Sopenharmony_ci	u8 rx_pause;
71062306a36Sopenharmony_ci	u8 tx_pause;
71162306a36Sopenharmony_ci};
71262306a36Sopenharmony_ci
71362306a36Sopenharmony_ci /* NPA mbox message formats */
71462306a36Sopenharmony_ci
71562306a36Sopenharmony_cistruct npc_set_pkind {
71662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
71762306a36Sopenharmony_ci#define OTX2_PRIV_FLAGS_DEFAULT  BIT_ULL(0)
71862306a36Sopenharmony_ci#define OTX2_PRIV_FLAGS_CUSTOM   BIT_ULL(63)
71962306a36Sopenharmony_ci	u64 mode;
72062306a36Sopenharmony_ci#define PKIND_TX		BIT_ULL(0)
72162306a36Sopenharmony_ci#define PKIND_RX		BIT_ULL(1)
72262306a36Sopenharmony_ci	u8 dir;
72362306a36Sopenharmony_ci	u8 pkind; /* valid only in case custom flag */
72462306a36Sopenharmony_ci	u8 var_len_off; /* Offset of custom header length field.
72562306a36Sopenharmony_ci			 * Valid only for pkind NPC_RX_CUSTOM_PRE_L2_PKIND
72662306a36Sopenharmony_ci			 */
72762306a36Sopenharmony_ci	u8 var_len_off_mask; /* Mask for length with in offset */
72862306a36Sopenharmony_ci	u8 shift_dir; /* shift direction to get length of the header at var_len_off */
72962306a36Sopenharmony_ci};
73062306a36Sopenharmony_ci
73162306a36Sopenharmony_ci/* NPA mbox message formats */
73262306a36Sopenharmony_ci
73362306a36Sopenharmony_ci/* NPA mailbox error codes
73462306a36Sopenharmony_ci * Range 301 - 400.
73562306a36Sopenharmony_ci */
73662306a36Sopenharmony_cienum npa_af_status {
73762306a36Sopenharmony_ci	NPA_AF_ERR_PARAM            = -301,
73862306a36Sopenharmony_ci	NPA_AF_ERR_AQ_FULL          = -302,
73962306a36Sopenharmony_ci	NPA_AF_ERR_AQ_ENQUEUE       = -303,
74062306a36Sopenharmony_ci	NPA_AF_ERR_AF_LF_INVALID    = -304,
74162306a36Sopenharmony_ci	NPA_AF_ERR_AF_LF_ALLOC      = -305,
74262306a36Sopenharmony_ci	NPA_AF_ERR_LF_RESET         = -306,
74362306a36Sopenharmony_ci};
74462306a36Sopenharmony_ci
74562306a36Sopenharmony_ci/* For NPA LF context alloc and init */
74662306a36Sopenharmony_cistruct npa_lf_alloc_req {
74762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
74862306a36Sopenharmony_ci	int node;
74962306a36Sopenharmony_ci	int aura_sz;  /* No of auras */
75062306a36Sopenharmony_ci	u32 nr_pools; /* No of pools */
75162306a36Sopenharmony_ci	u64 way_mask;
75262306a36Sopenharmony_ci};
75362306a36Sopenharmony_ci
75462306a36Sopenharmony_cistruct npa_lf_alloc_rsp {
75562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
75662306a36Sopenharmony_ci	u32 stack_pg_ptrs;  /* No of ptrs per stack page */
75762306a36Sopenharmony_ci	u32 stack_pg_bytes; /* Size of stack page */
75862306a36Sopenharmony_ci	u16 qints; /* NPA_AF_CONST::QINTS */
75962306a36Sopenharmony_ci	u8 cache_lines; /*BATCH ALLOC DMA */
76062306a36Sopenharmony_ci};
76162306a36Sopenharmony_ci
76262306a36Sopenharmony_ci/* NPA AQ enqueue msg */
76362306a36Sopenharmony_cistruct npa_aq_enq_req {
76462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
76562306a36Sopenharmony_ci	u32 aura_id;
76662306a36Sopenharmony_ci	u8 ctype;
76762306a36Sopenharmony_ci	u8 op;
76862306a36Sopenharmony_ci	union {
76962306a36Sopenharmony_ci		/* Valid when op == WRITE/INIT and ctype == AURA.
77062306a36Sopenharmony_ci		 * LF fills the pool_id in aura.pool_addr. AF will translate
77162306a36Sopenharmony_ci		 * the pool_id to pool context pointer.
77262306a36Sopenharmony_ci		 */
77362306a36Sopenharmony_ci		struct npa_aura_s aura;
77462306a36Sopenharmony_ci		/* Valid when op == WRITE/INIT and ctype == POOL */
77562306a36Sopenharmony_ci		struct npa_pool_s pool;
77662306a36Sopenharmony_ci	};
77762306a36Sopenharmony_ci	/* Mask data when op == WRITE (1=write, 0=don't write) */
77862306a36Sopenharmony_ci	union {
77962306a36Sopenharmony_ci		/* Valid when op == WRITE and ctype == AURA */
78062306a36Sopenharmony_ci		struct npa_aura_s aura_mask;
78162306a36Sopenharmony_ci		/* Valid when op == WRITE and ctype == POOL */
78262306a36Sopenharmony_ci		struct npa_pool_s pool_mask;
78362306a36Sopenharmony_ci	};
78462306a36Sopenharmony_ci};
78562306a36Sopenharmony_ci
78662306a36Sopenharmony_cistruct npa_aq_enq_rsp {
78762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
78862306a36Sopenharmony_ci	union {
78962306a36Sopenharmony_ci		/* Valid when op == READ and ctype == AURA */
79062306a36Sopenharmony_ci		struct npa_aura_s aura;
79162306a36Sopenharmony_ci		/* Valid when op == READ and ctype == POOL */
79262306a36Sopenharmony_ci		struct npa_pool_s pool;
79362306a36Sopenharmony_ci	};
79462306a36Sopenharmony_ci};
79562306a36Sopenharmony_ci
79662306a36Sopenharmony_ci/* Disable all contexts of type 'ctype' */
79762306a36Sopenharmony_cistruct hwctx_disable_req {
79862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
79962306a36Sopenharmony_ci	u8 ctype;
80062306a36Sopenharmony_ci};
80162306a36Sopenharmony_ci
80262306a36Sopenharmony_ci/* NIX mbox message formats */
80362306a36Sopenharmony_ci
80462306a36Sopenharmony_ci/* NIX mailbox error codes
80562306a36Sopenharmony_ci * Range 401 - 500.
80662306a36Sopenharmony_ci */
80762306a36Sopenharmony_cienum nix_af_status {
80862306a36Sopenharmony_ci	NIX_AF_ERR_PARAM            = -401,
80962306a36Sopenharmony_ci	NIX_AF_ERR_AQ_FULL          = -402,
81062306a36Sopenharmony_ci	NIX_AF_ERR_AQ_ENQUEUE       = -403,
81162306a36Sopenharmony_ci	NIX_AF_ERR_AF_LF_INVALID    = -404,
81262306a36Sopenharmony_ci	NIX_AF_ERR_AF_LF_ALLOC      = -405,
81362306a36Sopenharmony_ci	NIX_AF_ERR_TLX_ALLOC_FAIL   = -406,
81462306a36Sopenharmony_ci	NIX_AF_ERR_TLX_INVALID      = -407,
81562306a36Sopenharmony_ci	NIX_AF_ERR_RSS_SIZE_INVALID = -408,
81662306a36Sopenharmony_ci	NIX_AF_ERR_RSS_GRPS_INVALID = -409,
81762306a36Sopenharmony_ci	NIX_AF_ERR_FRS_INVALID      = -410,
81862306a36Sopenharmony_ci	NIX_AF_ERR_RX_LINK_INVALID  = -411,
81962306a36Sopenharmony_ci	NIX_AF_INVAL_TXSCHQ_CFG     = -412,
82062306a36Sopenharmony_ci	NIX_AF_SMQ_FLUSH_FAILED     = -413,
82162306a36Sopenharmony_ci	NIX_AF_ERR_LF_RESET         = -414,
82262306a36Sopenharmony_ci	NIX_AF_ERR_RSS_NOSPC_FIELD  = -415,
82362306a36Sopenharmony_ci	NIX_AF_ERR_RSS_NOSPC_ALGO   = -416,
82462306a36Sopenharmony_ci	NIX_AF_ERR_MARK_CFG_FAIL    = -417,
82562306a36Sopenharmony_ci	NIX_AF_ERR_LSO_CFG_FAIL     = -418,
82662306a36Sopenharmony_ci	NIX_AF_INVAL_NPA_PF_FUNC    = -419,
82762306a36Sopenharmony_ci	NIX_AF_INVAL_SSO_PF_FUNC    = -420,
82862306a36Sopenharmony_ci	NIX_AF_ERR_TX_VTAG_NOSPC    = -421,
82962306a36Sopenharmony_ci	NIX_AF_ERR_RX_VTAG_INUSE    = -422,
83062306a36Sopenharmony_ci	NIX_AF_ERR_PTP_CONFIG_FAIL  = -423,
83162306a36Sopenharmony_ci	NIX_AF_ERR_NPC_KEY_NOT_SUPP = -424,
83262306a36Sopenharmony_ci	NIX_AF_ERR_INVALID_NIXBLK   = -425,
83362306a36Sopenharmony_ci	NIX_AF_ERR_INVALID_BANDPROF = -426,
83462306a36Sopenharmony_ci	NIX_AF_ERR_IPOLICER_NOTSUPP = -427,
83562306a36Sopenharmony_ci	NIX_AF_ERR_BANDPROF_INVAL_REQ  = -428,
83662306a36Sopenharmony_ci	NIX_AF_ERR_CQ_CTX_WRITE_ERR  = -429,
83762306a36Sopenharmony_ci	NIX_AF_ERR_AQ_CTX_RETRY_WRITE  = -430,
83862306a36Sopenharmony_ci	NIX_AF_ERR_LINK_CREDITS  = -431,
83962306a36Sopenharmony_ci};
84062306a36Sopenharmony_ci
84162306a36Sopenharmony_ci/* For NIX RX vtag action  */
84262306a36Sopenharmony_cienum nix_rx_vtag0_type {
84362306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE0, /* reserved for rx vlan offload */
84462306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE1,
84562306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE2,
84662306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE3,
84762306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE4,
84862306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE5,
84962306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE6,
85062306a36Sopenharmony_ci	NIX_AF_LFX_RX_VTAG_TYPE7,
85162306a36Sopenharmony_ci};
85262306a36Sopenharmony_ci
85362306a36Sopenharmony_ci/* For NIX LF context alloc and init */
85462306a36Sopenharmony_cistruct nix_lf_alloc_req {
85562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
85662306a36Sopenharmony_ci	int node;
85762306a36Sopenharmony_ci	u32 rq_cnt;   /* No of receive queues */
85862306a36Sopenharmony_ci	u32 sq_cnt;   /* No of send queues */
85962306a36Sopenharmony_ci	u32 cq_cnt;   /* No of completion queues */
86062306a36Sopenharmony_ci	u8  xqe_sz;
86162306a36Sopenharmony_ci	u16 rss_sz;
86262306a36Sopenharmony_ci	u8  rss_grps;
86362306a36Sopenharmony_ci	u16 npa_func;
86462306a36Sopenharmony_ci	u16 sso_func;
86562306a36Sopenharmony_ci	u64 rx_cfg;   /* See NIX_AF_LF(0..127)_RX_CFG */
86662306a36Sopenharmony_ci	u64 way_mask;
86762306a36Sopenharmony_ci#define NIX_LF_RSS_TAG_LSB_AS_ADDER BIT_ULL(0)
86862306a36Sopenharmony_ci#define NIX_LF_LBK_BLK_SEL	    BIT_ULL(1)
86962306a36Sopenharmony_ci	u64 flags;
87062306a36Sopenharmony_ci};
87162306a36Sopenharmony_ci
87262306a36Sopenharmony_cistruct nix_lf_alloc_rsp {
87362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
87462306a36Sopenharmony_ci	u16	sqb_size;
87562306a36Sopenharmony_ci	u16	rx_chan_base;
87662306a36Sopenharmony_ci	u16	tx_chan_base;
87762306a36Sopenharmony_ci	u8      rx_chan_cnt; /* total number of RX channels */
87862306a36Sopenharmony_ci	u8      tx_chan_cnt; /* total number of TX channels */
87962306a36Sopenharmony_ci	u8	lso_tsov4_idx;
88062306a36Sopenharmony_ci	u8	lso_tsov6_idx;
88162306a36Sopenharmony_ci	u8      mac_addr[ETH_ALEN];
88262306a36Sopenharmony_ci	u8	lf_rx_stats; /* NIX_AF_CONST1::LF_RX_STATS */
88362306a36Sopenharmony_ci	u8	lf_tx_stats; /* NIX_AF_CONST1::LF_TX_STATS */
88462306a36Sopenharmony_ci	u16	cints; /* NIX_AF_CONST2::CINTS */
88562306a36Sopenharmony_ci	u16	qints; /* NIX_AF_CONST2::QINTS */
88662306a36Sopenharmony_ci	u8	cgx_links;  /* No. of CGX links present in HW */
88762306a36Sopenharmony_ci	u8	lbk_links;  /* No. of LBK links present in HW */
88862306a36Sopenharmony_ci	u8	sdp_links;  /* No. of SDP links present in HW */
88962306a36Sopenharmony_ci	u8	tx_link;    /* Transmit channel link number */
89062306a36Sopenharmony_ci};
89162306a36Sopenharmony_ci
89262306a36Sopenharmony_cistruct nix_lf_free_req {
89362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
89462306a36Sopenharmony_ci#define NIX_LF_DISABLE_FLOWS		BIT_ULL(0)
89562306a36Sopenharmony_ci#define NIX_LF_DONT_FREE_TX_VTAG	BIT_ULL(1)
89662306a36Sopenharmony_ci	u64 flags;
89762306a36Sopenharmony_ci};
89862306a36Sopenharmony_ci
89962306a36Sopenharmony_ci/* CN10K NIX AQ enqueue msg */
90062306a36Sopenharmony_cistruct nix_cn10k_aq_enq_req {
90162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
90262306a36Sopenharmony_ci	u32  qidx;
90362306a36Sopenharmony_ci	u8 ctype;
90462306a36Sopenharmony_ci	u8 op;
90562306a36Sopenharmony_ci	union {
90662306a36Sopenharmony_ci		struct nix_cn10k_rq_ctx_s rq;
90762306a36Sopenharmony_ci		struct nix_cn10k_sq_ctx_s sq;
90862306a36Sopenharmony_ci		struct nix_cq_ctx_s cq;
90962306a36Sopenharmony_ci		struct nix_rsse_s   rss;
91062306a36Sopenharmony_ci		struct nix_rx_mce_s mce;
91162306a36Sopenharmony_ci		struct nix_bandprof_s prof;
91262306a36Sopenharmony_ci	};
91362306a36Sopenharmony_ci	union {
91462306a36Sopenharmony_ci		struct nix_cn10k_rq_ctx_s rq_mask;
91562306a36Sopenharmony_ci		struct nix_cn10k_sq_ctx_s sq_mask;
91662306a36Sopenharmony_ci		struct nix_cq_ctx_s cq_mask;
91762306a36Sopenharmony_ci		struct nix_rsse_s   rss_mask;
91862306a36Sopenharmony_ci		struct nix_rx_mce_s mce_mask;
91962306a36Sopenharmony_ci		struct nix_bandprof_s prof_mask;
92062306a36Sopenharmony_ci	};
92162306a36Sopenharmony_ci};
92262306a36Sopenharmony_ci
92362306a36Sopenharmony_cistruct nix_cn10k_aq_enq_rsp {
92462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
92562306a36Sopenharmony_ci	union {
92662306a36Sopenharmony_ci		struct nix_cn10k_rq_ctx_s rq;
92762306a36Sopenharmony_ci		struct nix_cn10k_sq_ctx_s sq;
92862306a36Sopenharmony_ci		struct nix_cq_ctx_s cq;
92962306a36Sopenharmony_ci		struct nix_rsse_s   rss;
93062306a36Sopenharmony_ci		struct nix_rx_mce_s mce;
93162306a36Sopenharmony_ci		struct nix_bandprof_s prof;
93262306a36Sopenharmony_ci	};
93362306a36Sopenharmony_ci};
93462306a36Sopenharmony_ci
93562306a36Sopenharmony_ci/* NIX AQ enqueue msg */
93662306a36Sopenharmony_cistruct nix_aq_enq_req {
93762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
93862306a36Sopenharmony_ci	u32  qidx;
93962306a36Sopenharmony_ci	u8 ctype;
94062306a36Sopenharmony_ci	u8 op;
94162306a36Sopenharmony_ci	union {
94262306a36Sopenharmony_ci		struct nix_rq_ctx_s rq;
94362306a36Sopenharmony_ci		struct nix_sq_ctx_s sq;
94462306a36Sopenharmony_ci		struct nix_cq_ctx_s cq;
94562306a36Sopenharmony_ci		struct nix_rsse_s   rss;
94662306a36Sopenharmony_ci		struct nix_rx_mce_s mce;
94762306a36Sopenharmony_ci		struct nix_bandprof_s prof;
94862306a36Sopenharmony_ci	};
94962306a36Sopenharmony_ci	union {
95062306a36Sopenharmony_ci		struct nix_rq_ctx_s rq_mask;
95162306a36Sopenharmony_ci		struct nix_sq_ctx_s sq_mask;
95262306a36Sopenharmony_ci		struct nix_cq_ctx_s cq_mask;
95362306a36Sopenharmony_ci		struct nix_rsse_s   rss_mask;
95462306a36Sopenharmony_ci		struct nix_rx_mce_s mce_mask;
95562306a36Sopenharmony_ci		struct nix_bandprof_s prof_mask;
95662306a36Sopenharmony_ci	};
95762306a36Sopenharmony_ci};
95862306a36Sopenharmony_ci
95962306a36Sopenharmony_cistruct nix_aq_enq_rsp {
96062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
96162306a36Sopenharmony_ci	union {
96262306a36Sopenharmony_ci		struct nix_rq_ctx_s rq;
96362306a36Sopenharmony_ci		struct nix_sq_ctx_s sq;
96462306a36Sopenharmony_ci		struct nix_cq_ctx_s cq;
96562306a36Sopenharmony_ci		struct nix_rsse_s   rss;
96662306a36Sopenharmony_ci		struct nix_rx_mce_s mce;
96762306a36Sopenharmony_ci		struct nix_bandprof_s prof;
96862306a36Sopenharmony_ci	};
96962306a36Sopenharmony_ci};
97062306a36Sopenharmony_ci
97162306a36Sopenharmony_ci/* Tx scheduler/shaper mailbox messages */
97262306a36Sopenharmony_ci
97362306a36Sopenharmony_ci#define MAX_TXSCHQ_PER_FUNC		128
97462306a36Sopenharmony_ci
97562306a36Sopenharmony_cistruct nix_txsch_alloc_req {
97662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
97762306a36Sopenharmony_ci	/* Scheduler queue count request at each level */
97862306a36Sopenharmony_ci	u16 schq_contig[NIX_TXSCH_LVL_CNT]; /* No of contiguous queues */
97962306a36Sopenharmony_ci	u16 schq[NIX_TXSCH_LVL_CNT]; /* No of non-contiguous queues */
98062306a36Sopenharmony_ci};
98162306a36Sopenharmony_ci
98262306a36Sopenharmony_cistruct nix_txsch_alloc_rsp {
98362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
98462306a36Sopenharmony_ci	/* Scheduler queue count allocated at each level */
98562306a36Sopenharmony_ci	u16 schq_contig[NIX_TXSCH_LVL_CNT];
98662306a36Sopenharmony_ci	u16 schq[NIX_TXSCH_LVL_CNT];
98762306a36Sopenharmony_ci	/* Scheduler queue list allocated at each level */
98862306a36Sopenharmony_ci	u16 schq_contig_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC];
98962306a36Sopenharmony_ci	u16 schq_list[NIX_TXSCH_LVL_CNT][MAX_TXSCHQ_PER_FUNC];
99062306a36Sopenharmony_ci	u8  aggr_level; /* Traffic aggregation scheduler level */
99162306a36Sopenharmony_ci	u8  aggr_lvl_rr_prio; /* Aggregation lvl's RR_PRIO config */
99262306a36Sopenharmony_ci	u8  link_cfg_lvl; /* LINKX_CFG CSRs mapped to TL3 or TL2's index ? */
99362306a36Sopenharmony_ci};
99462306a36Sopenharmony_ci
99562306a36Sopenharmony_cistruct nix_txsch_free_req {
99662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
99762306a36Sopenharmony_ci#define TXSCHQ_FREE_ALL BIT_ULL(0)
99862306a36Sopenharmony_ci	u16 flags;
99962306a36Sopenharmony_ci	/* Scheduler queue level to be freed */
100062306a36Sopenharmony_ci	u16 schq_lvl;
100162306a36Sopenharmony_ci	/* List of scheduler queues to be freed */
100262306a36Sopenharmony_ci	u16 schq;
100362306a36Sopenharmony_ci};
100462306a36Sopenharmony_ci
100562306a36Sopenharmony_cistruct nix_txschq_config {
100662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
100762306a36Sopenharmony_ci	u8 lvl;	/* SMQ/MDQ/TL4/TL3/TL2/TL1 */
100862306a36Sopenharmony_ci	u8 read;
100962306a36Sopenharmony_ci#define TXSCHQ_IDX_SHIFT	16
101062306a36Sopenharmony_ci#define TXSCHQ_IDX_MASK		(BIT_ULL(10) - 1)
101162306a36Sopenharmony_ci#define TXSCHQ_IDX(reg, shift)	(((reg) >> (shift)) & TXSCHQ_IDX_MASK)
101262306a36Sopenharmony_ci	u8 num_regs;
101362306a36Sopenharmony_ci#define MAX_REGS_PER_MBOX_MSG	20
101462306a36Sopenharmony_ci	u64 reg[MAX_REGS_PER_MBOX_MSG];
101562306a36Sopenharmony_ci	u64 regval[MAX_REGS_PER_MBOX_MSG];
101662306a36Sopenharmony_ci	/* All 0's => overwrite with new value */
101762306a36Sopenharmony_ci	u64 regval_mask[MAX_REGS_PER_MBOX_MSG];
101862306a36Sopenharmony_ci};
101962306a36Sopenharmony_ci
102062306a36Sopenharmony_cistruct nix_vtag_config {
102162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
102262306a36Sopenharmony_ci	/* '0' for 4 octet VTAG, '1' for 8 octet VTAG */
102362306a36Sopenharmony_ci	u8 vtag_size;
102462306a36Sopenharmony_ci	/* cfg_type is '0' for tx vlan cfg
102562306a36Sopenharmony_ci	 * cfg_type is '1' for rx vlan cfg
102662306a36Sopenharmony_ci	 */
102762306a36Sopenharmony_ci	u8 cfg_type;
102862306a36Sopenharmony_ci	union {
102962306a36Sopenharmony_ci		/* valid when cfg_type is '0' */
103062306a36Sopenharmony_ci		struct {
103162306a36Sopenharmony_ci			u64 vtag0;
103262306a36Sopenharmony_ci			u64 vtag1;
103362306a36Sopenharmony_ci
103462306a36Sopenharmony_ci			/* cfg_vtag0 & cfg_vtag1 fields are valid
103562306a36Sopenharmony_ci			 * when free_vtag0 & free_vtag1 are '0's.
103662306a36Sopenharmony_ci			 */
103762306a36Sopenharmony_ci			/* cfg_vtag0 = 1 to configure vtag0 */
103862306a36Sopenharmony_ci			u8 cfg_vtag0 :1;
103962306a36Sopenharmony_ci			/* cfg_vtag1 = 1 to configure vtag1 */
104062306a36Sopenharmony_ci			u8 cfg_vtag1 :1;
104162306a36Sopenharmony_ci
104262306a36Sopenharmony_ci			/* vtag0_idx & vtag1_idx are only valid when
104362306a36Sopenharmony_ci			 * both cfg_vtag0 & cfg_vtag1 are '0's,
104462306a36Sopenharmony_ci			 * these fields are used along with free_vtag0
104562306a36Sopenharmony_ci			 * & free_vtag1 to free the nix lf's tx_vlan
104662306a36Sopenharmony_ci			 * configuration.
104762306a36Sopenharmony_ci			 *
104862306a36Sopenharmony_ci			 * Denotes the indices of tx_vtag def registers
104962306a36Sopenharmony_ci			 * that needs to be cleared and freed.
105062306a36Sopenharmony_ci			 */
105162306a36Sopenharmony_ci			int vtag0_idx;
105262306a36Sopenharmony_ci			int vtag1_idx;
105362306a36Sopenharmony_ci
105462306a36Sopenharmony_ci			/* free_vtag0 & free_vtag1 fields are valid
105562306a36Sopenharmony_ci			 * when cfg_vtag0 & cfg_vtag1 are '0's.
105662306a36Sopenharmony_ci			 */
105762306a36Sopenharmony_ci			/* free_vtag0 = 1 clears vtag0 configuration
105862306a36Sopenharmony_ci			 * vtag0_idx denotes the index to be cleared.
105962306a36Sopenharmony_ci			 */
106062306a36Sopenharmony_ci			u8 free_vtag0 :1;
106162306a36Sopenharmony_ci			/* free_vtag1 = 1 clears vtag1 configuration
106262306a36Sopenharmony_ci			 * vtag1_idx denotes the index to be cleared.
106362306a36Sopenharmony_ci			 */
106462306a36Sopenharmony_ci			u8 free_vtag1 :1;
106562306a36Sopenharmony_ci		} tx;
106662306a36Sopenharmony_ci
106762306a36Sopenharmony_ci		/* valid when cfg_type is '1' */
106862306a36Sopenharmony_ci		struct {
106962306a36Sopenharmony_ci			/* rx vtag type index, valid values are in 0..7 range */
107062306a36Sopenharmony_ci			u8 vtag_type;
107162306a36Sopenharmony_ci			/* rx vtag strip */
107262306a36Sopenharmony_ci			u8 strip_vtag :1;
107362306a36Sopenharmony_ci			/* rx vtag capture */
107462306a36Sopenharmony_ci			u8 capture_vtag :1;
107562306a36Sopenharmony_ci		} rx;
107662306a36Sopenharmony_ci	};
107762306a36Sopenharmony_ci};
107862306a36Sopenharmony_ci
107962306a36Sopenharmony_cistruct nix_vtag_config_rsp {
108062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
108162306a36Sopenharmony_ci	int vtag0_idx;
108262306a36Sopenharmony_ci	int vtag1_idx;
108362306a36Sopenharmony_ci	/* Indices of tx_vtag def registers used to configure
108462306a36Sopenharmony_ci	 * tx vtag0 & vtag1 headers, these indices are valid
108562306a36Sopenharmony_ci	 * when nix_vtag_config mbox requested for vtag0 and/
108662306a36Sopenharmony_ci	 * or vtag1 configuration.
108762306a36Sopenharmony_ci	 */
108862306a36Sopenharmony_ci};
108962306a36Sopenharmony_ci
109062306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_L3_L4_MASK (~(0xf << 28))
109162306a36Sopenharmony_ci
109262306a36Sopenharmony_cistruct nix_rss_flowkey_cfg {
109362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
109462306a36Sopenharmony_ci	int	mcam_index;  /* MCAM entry index to modify */
109562306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_PORT	BIT(0)
109662306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_IPV4	BIT(1)
109762306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_IPV6	BIT(2)
109862306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_TCP	BIT(3)
109962306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_UDP	BIT(4)
110062306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_SCTP	BIT(5)
110162306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_NVGRE    BIT(6)
110262306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_VXLAN    BIT(7)
110362306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_GENEVE   BIT(8)
110462306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_ETH_DMAC BIT(9)
110562306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_IPV6_EXT BIT(10)
110662306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_GTPU       BIT(11)
110762306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_INNR_IPV4     BIT(12)
110862306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_INNR_IPV6     BIT(13)
110962306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_INNR_TCP      BIT(14)
111062306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_INNR_UDP      BIT(15)
111162306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_INNR_SCTP     BIT(16)
111262306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_INNR_ETH_DMAC BIT(17)
111362306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_VLAN		BIT(20)
111462306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_IPV4_PROTO	BIT(21)
111562306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_AH		BIT(22)
111662306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_ESP		BIT(23)
111762306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_L4_DST_ONLY BIT(28)
111862306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_L4_SRC_ONLY BIT(29)
111962306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_L3_DST_ONLY BIT(30)
112062306a36Sopenharmony_ci#define NIX_FLOW_KEY_TYPE_L3_SRC_ONLY BIT(31)
112162306a36Sopenharmony_ci	u32	flowkey_cfg; /* Flowkey types selected */
112262306a36Sopenharmony_ci	u8	group;       /* RSS context or group */
112362306a36Sopenharmony_ci};
112462306a36Sopenharmony_ci
112562306a36Sopenharmony_cistruct nix_rss_flowkey_cfg_rsp {
112662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
112762306a36Sopenharmony_ci	u8	alg_idx; /* Selected algo index */
112862306a36Sopenharmony_ci};
112962306a36Sopenharmony_ci
113062306a36Sopenharmony_cistruct nix_set_mac_addr {
113162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
113262306a36Sopenharmony_ci	u8 mac_addr[ETH_ALEN]; /* MAC address to be set for this pcifunc */
113362306a36Sopenharmony_ci};
113462306a36Sopenharmony_ci
113562306a36Sopenharmony_cistruct nix_get_mac_addr_rsp {
113662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
113762306a36Sopenharmony_ci	u8 mac_addr[ETH_ALEN];
113862306a36Sopenharmony_ci};
113962306a36Sopenharmony_ci
114062306a36Sopenharmony_cistruct nix_mark_format_cfg {
114162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
114262306a36Sopenharmony_ci	u8 offset;
114362306a36Sopenharmony_ci	u8 y_mask;
114462306a36Sopenharmony_ci	u8 y_val;
114562306a36Sopenharmony_ci	u8 r_mask;
114662306a36Sopenharmony_ci	u8 r_val;
114762306a36Sopenharmony_ci};
114862306a36Sopenharmony_ci
114962306a36Sopenharmony_cistruct nix_mark_format_cfg_rsp {
115062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
115162306a36Sopenharmony_ci	u8 mark_format_idx;
115262306a36Sopenharmony_ci};
115362306a36Sopenharmony_ci
115462306a36Sopenharmony_cistruct nix_rx_mode {
115562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
115662306a36Sopenharmony_ci#define NIX_RX_MODE_UCAST	BIT(0)
115762306a36Sopenharmony_ci#define NIX_RX_MODE_PROMISC	BIT(1)
115862306a36Sopenharmony_ci#define NIX_RX_MODE_ALLMULTI	BIT(2)
115962306a36Sopenharmony_ci#define NIX_RX_MODE_USE_MCE	BIT(3)
116062306a36Sopenharmony_ci	u16	mode;
116162306a36Sopenharmony_ci};
116262306a36Sopenharmony_ci
116362306a36Sopenharmony_cistruct nix_rx_cfg {
116462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
116562306a36Sopenharmony_ci#define NIX_RX_OL3_VERIFY   BIT(0)
116662306a36Sopenharmony_ci#define NIX_RX_OL4_VERIFY   BIT(1)
116762306a36Sopenharmony_ci#define NIX_RX_DROP_RE      BIT(2)
116862306a36Sopenharmony_ci	u8 len_verify; /* Outer L3/L4 len check */
116962306a36Sopenharmony_ci#define NIX_RX_CSUM_OL4_VERIFY  BIT(0)
117062306a36Sopenharmony_ci	u8 csum_verify; /* Outer L4 checksum verification */
117162306a36Sopenharmony_ci};
117262306a36Sopenharmony_ci
117362306a36Sopenharmony_cistruct nix_frs_cfg {
117462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
117562306a36Sopenharmony_ci	u8	update_smq;    /* Update SMQ's min/max lens */
117662306a36Sopenharmony_ci	u8	update_minlen; /* Set minlen also */
117762306a36Sopenharmony_ci	u8	sdp_link;      /* Set SDP RX link */
117862306a36Sopenharmony_ci	u16	maxlen;
117962306a36Sopenharmony_ci	u16	minlen;
118062306a36Sopenharmony_ci};
118162306a36Sopenharmony_ci
118262306a36Sopenharmony_cistruct nix_lso_format_cfg {
118362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
118462306a36Sopenharmony_ci	u64 field_mask;
118562306a36Sopenharmony_ci#define NIX_LSO_FIELD_MAX	8
118662306a36Sopenharmony_ci	u64 fields[NIX_LSO_FIELD_MAX];
118762306a36Sopenharmony_ci};
118862306a36Sopenharmony_ci
118962306a36Sopenharmony_cistruct nix_lso_format_cfg_rsp {
119062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
119162306a36Sopenharmony_ci	u8 lso_format_idx;
119262306a36Sopenharmony_ci};
119362306a36Sopenharmony_ci
119462306a36Sopenharmony_cistruct nix_bp_cfg_req {
119562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
119662306a36Sopenharmony_ci	u16	chan_base; /* Starting channel number */
119762306a36Sopenharmony_ci	u8	chan_cnt; /* Number of channels */
119862306a36Sopenharmony_ci	u8	bpid_per_chan;
119962306a36Sopenharmony_ci	/* bpid_per_chan = 0 assigns single bp id for range of channels */
120062306a36Sopenharmony_ci	/* bpid_per_chan = 1 assigns separate bp id for each channel */
120162306a36Sopenharmony_ci};
120262306a36Sopenharmony_ci
120362306a36Sopenharmony_ci/* PF can be mapped to either CGX or LBK interface,
120462306a36Sopenharmony_ci * so maximum 64 channels are possible.
120562306a36Sopenharmony_ci */
120662306a36Sopenharmony_ci#define NIX_MAX_BPID_CHAN	64
120762306a36Sopenharmony_cistruct nix_bp_cfg_rsp {
120862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
120962306a36Sopenharmony_ci	u16	chan_bpid[NIX_MAX_BPID_CHAN]; /* Channel and bpid mapping */
121062306a36Sopenharmony_ci	u8	chan_cnt; /* Number of channel for which bpids are assigned */
121162306a36Sopenharmony_ci};
121262306a36Sopenharmony_ci
121362306a36Sopenharmony_ci/* Global NIX inline IPSec configuration */
121462306a36Sopenharmony_cistruct nix_inline_ipsec_cfg {
121562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
121662306a36Sopenharmony_ci	u32 cpt_credit;
121762306a36Sopenharmony_ci	struct {
121862306a36Sopenharmony_ci		u8 egrp;
121962306a36Sopenharmony_ci		u16 opcode;
122062306a36Sopenharmony_ci		u16 param1;
122162306a36Sopenharmony_ci		u16 param2;
122262306a36Sopenharmony_ci	} gen_cfg;
122362306a36Sopenharmony_ci	struct {
122462306a36Sopenharmony_ci		u16 cpt_pf_func;
122562306a36Sopenharmony_ci		u8 cpt_slot;
122662306a36Sopenharmony_ci	} inst_qsel;
122762306a36Sopenharmony_ci	u8 enable;
122862306a36Sopenharmony_ci	u16 bpid;
122962306a36Sopenharmony_ci	u32 credit_th;
123062306a36Sopenharmony_ci};
123162306a36Sopenharmony_ci
123262306a36Sopenharmony_ci/* Per NIX LF inline IPSec configuration */
123362306a36Sopenharmony_cistruct nix_inline_ipsec_lf_cfg {
123462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
123562306a36Sopenharmony_ci	u64 sa_base_addr;
123662306a36Sopenharmony_ci	struct {
123762306a36Sopenharmony_ci		u32 tag_const;
123862306a36Sopenharmony_ci		u16 lenm1_max;
123962306a36Sopenharmony_ci		u8 sa_pow2_size;
124062306a36Sopenharmony_ci		u8 tt;
124162306a36Sopenharmony_ci	} ipsec_cfg0;
124262306a36Sopenharmony_ci	struct {
124362306a36Sopenharmony_ci		u32 sa_idx_max;
124462306a36Sopenharmony_ci		u8 sa_idx_w;
124562306a36Sopenharmony_ci	} ipsec_cfg1;
124662306a36Sopenharmony_ci	u8 enable;
124762306a36Sopenharmony_ci};
124862306a36Sopenharmony_ci
124962306a36Sopenharmony_cistruct nix_hw_info {
125062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
125162306a36Sopenharmony_ci	u16 rsvs16;
125262306a36Sopenharmony_ci	u16 max_mtu;
125362306a36Sopenharmony_ci	u16 min_mtu;
125462306a36Sopenharmony_ci	u32 rpm_dwrr_mtu;
125562306a36Sopenharmony_ci	u32 sdp_dwrr_mtu;
125662306a36Sopenharmony_ci	u32 lbk_dwrr_mtu;
125762306a36Sopenharmony_ci	u32 rsvd32[1];
125862306a36Sopenharmony_ci	u64 rsvd[15]; /* Add reserved fields for future expansion */
125962306a36Sopenharmony_ci};
126062306a36Sopenharmony_ci
126162306a36Sopenharmony_cistruct nix_bandprof_alloc_req {
126262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
126362306a36Sopenharmony_ci	/* Count of profiles needed per layer */
126462306a36Sopenharmony_ci	u16 prof_count[BAND_PROF_NUM_LAYERS];
126562306a36Sopenharmony_ci};
126662306a36Sopenharmony_ci
126762306a36Sopenharmony_cistruct nix_bandprof_alloc_rsp {
126862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
126962306a36Sopenharmony_ci	u16 prof_count[BAND_PROF_NUM_LAYERS];
127062306a36Sopenharmony_ci
127162306a36Sopenharmony_ci	/* There is no need to allocate morethan 1 bandwidth profile
127262306a36Sopenharmony_ci	 * per RQ of a PF_FUNC's NIXLF. So limit the maximum
127362306a36Sopenharmony_ci	 * profiles to 64 per PF_FUNC.
127462306a36Sopenharmony_ci	 */
127562306a36Sopenharmony_ci#define MAX_BANDPROF_PER_PFFUNC	64
127662306a36Sopenharmony_ci	u16 prof_idx[BAND_PROF_NUM_LAYERS][MAX_BANDPROF_PER_PFFUNC];
127762306a36Sopenharmony_ci};
127862306a36Sopenharmony_ci
127962306a36Sopenharmony_cistruct nix_bandprof_free_req {
128062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
128162306a36Sopenharmony_ci	u8 free_all;
128262306a36Sopenharmony_ci	u16 prof_count[BAND_PROF_NUM_LAYERS];
128362306a36Sopenharmony_ci	u16 prof_idx[BAND_PROF_NUM_LAYERS][MAX_BANDPROF_PER_PFFUNC];
128462306a36Sopenharmony_ci};
128562306a36Sopenharmony_ci
128662306a36Sopenharmony_cistruct nix_bandprof_get_hwinfo_rsp {
128762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
128862306a36Sopenharmony_ci	u16 prof_count[BAND_PROF_NUM_LAYERS];
128962306a36Sopenharmony_ci	u32 policer_timeunit;
129062306a36Sopenharmony_ci};
129162306a36Sopenharmony_ci
129262306a36Sopenharmony_ci/* NPC mbox message structs */
129362306a36Sopenharmony_ci
129462306a36Sopenharmony_ci#define NPC_MCAM_ENTRY_INVALID	0xFFFF
129562306a36Sopenharmony_ci#define NPC_MCAM_INVALID_MAP	0xFFFF
129662306a36Sopenharmony_ci
129762306a36Sopenharmony_ci/* NPC mailbox error codes
129862306a36Sopenharmony_ci * Range 701 - 800.
129962306a36Sopenharmony_ci */
130062306a36Sopenharmony_cienum npc_af_status {
130162306a36Sopenharmony_ci	NPC_MCAM_INVALID_REQ	= -701,
130262306a36Sopenharmony_ci	NPC_MCAM_ALLOC_DENIED	= -702,
130362306a36Sopenharmony_ci	NPC_MCAM_ALLOC_FAILED	= -703,
130462306a36Sopenharmony_ci	NPC_MCAM_PERM_DENIED	= -704,
130562306a36Sopenharmony_ci	NPC_FLOW_INTF_INVALID	= -707,
130662306a36Sopenharmony_ci	NPC_FLOW_CHAN_INVALID	= -708,
130762306a36Sopenharmony_ci	NPC_FLOW_NO_NIXLF	= -709,
130862306a36Sopenharmony_ci	NPC_FLOW_NOT_SUPPORTED	= -710,
130962306a36Sopenharmony_ci	NPC_FLOW_VF_PERM_DENIED	= -711,
131062306a36Sopenharmony_ci	NPC_FLOW_VF_NOT_INIT	= -712,
131162306a36Sopenharmony_ci	NPC_FLOW_VF_OVERLAP	= -713,
131262306a36Sopenharmony_ci};
131362306a36Sopenharmony_ci
131462306a36Sopenharmony_cistruct npc_mcam_alloc_entry_req {
131562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
131662306a36Sopenharmony_ci#define NPC_MAX_NONCONTIG_ENTRIES	256
131762306a36Sopenharmony_ci	u8  contig;   /* Contiguous entries ? */
131862306a36Sopenharmony_ci#define NPC_MCAM_ANY_PRIO		0
131962306a36Sopenharmony_ci#define NPC_MCAM_LOWER_PRIO		1
132062306a36Sopenharmony_ci#define NPC_MCAM_HIGHER_PRIO		2
132162306a36Sopenharmony_ci	u8  priority; /* Lower or higher w.r.t ref_entry */
132262306a36Sopenharmony_ci	u16 ref_entry;
132362306a36Sopenharmony_ci	u16 count;    /* Number of entries requested */
132462306a36Sopenharmony_ci};
132562306a36Sopenharmony_ci
132662306a36Sopenharmony_cistruct npc_mcam_alloc_entry_rsp {
132762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
132862306a36Sopenharmony_ci	u16 entry; /* Entry allocated or start index if contiguous.
132962306a36Sopenharmony_ci		    * Invalid incase of non-contiguous.
133062306a36Sopenharmony_ci		    */
133162306a36Sopenharmony_ci	u16 count; /* Number of entries allocated */
133262306a36Sopenharmony_ci	u16 free_count; /* Number of entries available */
133362306a36Sopenharmony_ci	u16 entry_list[NPC_MAX_NONCONTIG_ENTRIES];
133462306a36Sopenharmony_ci};
133562306a36Sopenharmony_ci
133662306a36Sopenharmony_cistruct npc_mcam_free_entry_req {
133762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
133862306a36Sopenharmony_ci	u16 entry; /* Entry index to be freed */
133962306a36Sopenharmony_ci	u8  all;   /* If all entries allocated to this PFVF to be freed */
134062306a36Sopenharmony_ci};
134162306a36Sopenharmony_ci
134262306a36Sopenharmony_cistruct mcam_entry {
134362306a36Sopenharmony_ci#define NPC_MAX_KWS_IN_KEY	7 /* Number of keywords in max keywidth */
134462306a36Sopenharmony_ci	u64	kw[NPC_MAX_KWS_IN_KEY];
134562306a36Sopenharmony_ci	u64	kw_mask[NPC_MAX_KWS_IN_KEY];
134662306a36Sopenharmony_ci	u64	action;
134762306a36Sopenharmony_ci	u64	vtag_action;
134862306a36Sopenharmony_ci};
134962306a36Sopenharmony_ci
135062306a36Sopenharmony_cistruct npc_mcam_write_entry_req {
135162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
135262306a36Sopenharmony_ci	struct mcam_entry entry_data;
135362306a36Sopenharmony_ci	u16 entry;	 /* MCAM entry to write this match key */
135462306a36Sopenharmony_ci	u16 cntr;	 /* Counter for this MCAM entry */
135562306a36Sopenharmony_ci	u8  intf;	 /* Rx or Tx interface */
135662306a36Sopenharmony_ci	u8  enable_entry;/* Enable this MCAM entry ? */
135762306a36Sopenharmony_ci	u8  set_cntr;    /* Set counter for this entry ? */
135862306a36Sopenharmony_ci};
135962306a36Sopenharmony_ci
136062306a36Sopenharmony_ci/* Enable/Disable a given entry */
136162306a36Sopenharmony_cistruct npc_mcam_ena_dis_entry_req {
136262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
136362306a36Sopenharmony_ci	u16 entry;
136462306a36Sopenharmony_ci};
136562306a36Sopenharmony_ci
136662306a36Sopenharmony_cistruct npc_mcam_shift_entry_req {
136762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
136862306a36Sopenharmony_ci#define NPC_MCAM_MAX_SHIFTS	64
136962306a36Sopenharmony_ci	u16 curr_entry[NPC_MCAM_MAX_SHIFTS];
137062306a36Sopenharmony_ci	u16 new_entry[NPC_MCAM_MAX_SHIFTS];
137162306a36Sopenharmony_ci	u16 shift_count; /* Number of entries to shift */
137262306a36Sopenharmony_ci};
137362306a36Sopenharmony_ci
137462306a36Sopenharmony_cistruct npc_mcam_shift_entry_rsp {
137562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
137662306a36Sopenharmony_ci	u16 failed_entry_idx; /* Index in 'curr_entry', not entry itself */
137762306a36Sopenharmony_ci};
137862306a36Sopenharmony_ci
137962306a36Sopenharmony_cistruct npc_mcam_alloc_counter_req {
138062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
138162306a36Sopenharmony_ci	u8  contig;	/* Contiguous counters ? */
138262306a36Sopenharmony_ci#define NPC_MAX_NONCONTIG_COUNTERS       64
138362306a36Sopenharmony_ci	u16 count;	/* Number of counters requested */
138462306a36Sopenharmony_ci};
138562306a36Sopenharmony_ci
138662306a36Sopenharmony_cistruct npc_mcam_alloc_counter_rsp {
138762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
138862306a36Sopenharmony_ci	u16 cntr;   /* Counter allocated or start index if contiguous.
138962306a36Sopenharmony_ci		     * Invalid incase of non-contiguous.
139062306a36Sopenharmony_ci		     */
139162306a36Sopenharmony_ci	u16 count;  /* Number of counters allocated */
139262306a36Sopenharmony_ci	u16 cntr_list[NPC_MAX_NONCONTIG_COUNTERS];
139362306a36Sopenharmony_ci};
139462306a36Sopenharmony_ci
139562306a36Sopenharmony_cistruct npc_mcam_oper_counter_req {
139662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
139762306a36Sopenharmony_ci	u16 cntr;   /* Free a counter or clear/fetch it's stats */
139862306a36Sopenharmony_ci};
139962306a36Sopenharmony_ci
140062306a36Sopenharmony_cistruct npc_mcam_oper_counter_rsp {
140162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
140262306a36Sopenharmony_ci	u64 stat;  /* valid only while fetching counter's stats */
140362306a36Sopenharmony_ci};
140462306a36Sopenharmony_ci
140562306a36Sopenharmony_cistruct npc_mcam_unmap_counter_req {
140662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
140762306a36Sopenharmony_ci	u16 cntr;
140862306a36Sopenharmony_ci	u16 entry; /* Entry and counter to be unmapped */
140962306a36Sopenharmony_ci	u8  all;   /* Unmap all entries using this counter ? */
141062306a36Sopenharmony_ci};
141162306a36Sopenharmony_ci
141262306a36Sopenharmony_cistruct npc_mcam_alloc_and_write_entry_req {
141362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
141462306a36Sopenharmony_ci	struct mcam_entry entry_data;
141562306a36Sopenharmony_ci	u16 ref_entry;
141662306a36Sopenharmony_ci	u8  priority;    /* Lower or higher w.r.t ref_entry */
141762306a36Sopenharmony_ci	u8  intf;	 /* Rx or Tx interface */
141862306a36Sopenharmony_ci	u8  enable_entry;/* Enable this MCAM entry ? */
141962306a36Sopenharmony_ci	u8  alloc_cntr;  /* Allocate counter and map ? */
142062306a36Sopenharmony_ci};
142162306a36Sopenharmony_ci
142262306a36Sopenharmony_cistruct npc_mcam_alloc_and_write_entry_rsp {
142362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
142462306a36Sopenharmony_ci	u16 entry;
142562306a36Sopenharmony_ci	u16 cntr;
142662306a36Sopenharmony_ci};
142762306a36Sopenharmony_ci
142862306a36Sopenharmony_cistruct npc_get_kex_cfg_rsp {
142962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
143062306a36Sopenharmony_ci	u64 rx_keyx_cfg;   /* NPC_AF_INTF(0)_KEX_CFG */
143162306a36Sopenharmony_ci	u64 tx_keyx_cfg;   /* NPC_AF_INTF(1)_KEX_CFG */
143262306a36Sopenharmony_ci#define NPC_MAX_INTF	2
143362306a36Sopenharmony_ci#define NPC_MAX_LID	8
143462306a36Sopenharmony_ci#define NPC_MAX_LT	16
143562306a36Sopenharmony_ci#define NPC_MAX_LD	2
143662306a36Sopenharmony_ci#define NPC_MAX_LFL	16
143762306a36Sopenharmony_ci	/* NPC_AF_KEX_LDATA(0..1)_FLAGS_CFG */
143862306a36Sopenharmony_ci	u64 kex_ld_flags[NPC_MAX_LD];
143962306a36Sopenharmony_ci	/* NPC_AF_INTF(0..1)_LID(0..7)_LT(0..15)_LD(0..1)_CFG */
144062306a36Sopenharmony_ci	u64 intf_lid_lt_ld[NPC_MAX_INTF][NPC_MAX_LID][NPC_MAX_LT][NPC_MAX_LD];
144162306a36Sopenharmony_ci	/* NPC_AF_INTF(0..1)_LDATA(0..1)_FLAGS(0..15)_CFG */
144262306a36Sopenharmony_ci	u64 intf_ld_flags[NPC_MAX_INTF][NPC_MAX_LD][NPC_MAX_LFL];
144362306a36Sopenharmony_ci#define MKEX_NAME_LEN 128
144462306a36Sopenharmony_ci	u8 mkex_pfl_name[MKEX_NAME_LEN];
144562306a36Sopenharmony_ci};
144662306a36Sopenharmony_ci
144762306a36Sopenharmony_cistruct ptp_get_cap_rsp {
144862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
144962306a36Sopenharmony_ci#define        PTP_CAP_HW_ATOMIC_UPDATE BIT_ULL(0)
145062306a36Sopenharmony_ci	u64 cap;
145162306a36Sopenharmony_ci};
145262306a36Sopenharmony_ci
145362306a36Sopenharmony_cistruct flow_msg {
145462306a36Sopenharmony_ci	unsigned char dmac[6];
145562306a36Sopenharmony_ci	unsigned char smac[6];
145662306a36Sopenharmony_ci	__be16 etype;
145762306a36Sopenharmony_ci	__be16 vlan_etype;
145862306a36Sopenharmony_ci	__be16 vlan_tci;
145962306a36Sopenharmony_ci	union {
146062306a36Sopenharmony_ci		__be32 ip4src;
146162306a36Sopenharmony_ci		__be32 ip6src[4];
146262306a36Sopenharmony_ci	};
146362306a36Sopenharmony_ci	union {
146462306a36Sopenharmony_ci		__be32 ip4dst;
146562306a36Sopenharmony_ci		__be32 ip6dst[4];
146662306a36Sopenharmony_ci	};
146762306a36Sopenharmony_ci	union {
146862306a36Sopenharmony_ci		__be32 spi;
146962306a36Sopenharmony_ci	};
147062306a36Sopenharmony_ci
147162306a36Sopenharmony_ci	u8 tos;
147262306a36Sopenharmony_ci	u8 ip_ver;
147362306a36Sopenharmony_ci	u8 ip_proto;
147462306a36Sopenharmony_ci	u8 tc;
147562306a36Sopenharmony_ci	__be16 sport;
147662306a36Sopenharmony_ci	__be16 dport;
147762306a36Sopenharmony_ci	union {
147862306a36Sopenharmony_ci		u8 ip_flag;
147962306a36Sopenharmony_ci		u8 next_header;
148062306a36Sopenharmony_ci	};
148162306a36Sopenharmony_ci	__be16 vlan_itci;
148262306a36Sopenharmony_ci};
148362306a36Sopenharmony_ci
148462306a36Sopenharmony_cistruct npc_install_flow_req {
148562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
148662306a36Sopenharmony_ci	struct flow_msg packet;
148762306a36Sopenharmony_ci	struct flow_msg mask;
148862306a36Sopenharmony_ci	u64 features;
148962306a36Sopenharmony_ci	u16 entry;
149062306a36Sopenharmony_ci	u16 channel;
149162306a36Sopenharmony_ci	u16 chan_mask;
149262306a36Sopenharmony_ci	u8 intf;
149362306a36Sopenharmony_ci	u8 set_cntr; /* If counter is available set counter for this entry ? */
149462306a36Sopenharmony_ci	u8 default_rule;
149562306a36Sopenharmony_ci	u8 append; /* overwrite(0) or append(1) flow to default rule? */
149662306a36Sopenharmony_ci	u16 vf;
149762306a36Sopenharmony_ci	/* action */
149862306a36Sopenharmony_ci	u32 index;
149962306a36Sopenharmony_ci	u16 match_id;
150062306a36Sopenharmony_ci	u8 flow_key_alg;
150162306a36Sopenharmony_ci	u8 op;
150262306a36Sopenharmony_ci	/* vtag rx action */
150362306a36Sopenharmony_ci	u8 vtag0_type;
150462306a36Sopenharmony_ci	u8 vtag0_valid;
150562306a36Sopenharmony_ci	u8 vtag1_type;
150662306a36Sopenharmony_ci	u8 vtag1_valid;
150762306a36Sopenharmony_ci	/* vtag tx action */
150862306a36Sopenharmony_ci	u16 vtag0_def;
150962306a36Sopenharmony_ci	u8  vtag0_op;
151062306a36Sopenharmony_ci	u16 vtag1_def;
151162306a36Sopenharmony_ci	u8  vtag1_op;
151262306a36Sopenharmony_ci	/* old counter value */
151362306a36Sopenharmony_ci	u16 cntr_val;
151462306a36Sopenharmony_ci};
151562306a36Sopenharmony_ci
151662306a36Sopenharmony_cistruct npc_install_flow_rsp {
151762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
151862306a36Sopenharmony_ci	int counter; /* negative if no counter else counter number */
151962306a36Sopenharmony_ci};
152062306a36Sopenharmony_ci
152162306a36Sopenharmony_cistruct npc_delete_flow_req {
152262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
152362306a36Sopenharmony_ci	u16 entry;
152462306a36Sopenharmony_ci	u16 start;/*Disable range of entries */
152562306a36Sopenharmony_ci	u16 end;
152662306a36Sopenharmony_ci	u8 all; /* PF + VFs */
152762306a36Sopenharmony_ci};
152862306a36Sopenharmony_ci
152962306a36Sopenharmony_cistruct npc_delete_flow_rsp {
153062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
153162306a36Sopenharmony_ci	u16 cntr_val;
153262306a36Sopenharmony_ci};
153362306a36Sopenharmony_ci
153462306a36Sopenharmony_cistruct npc_mcam_read_entry_req {
153562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
153662306a36Sopenharmony_ci	u16 entry;	 /* MCAM entry to read */
153762306a36Sopenharmony_ci};
153862306a36Sopenharmony_ci
153962306a36Sopenharmony_cistruct npc_mcam_read_entry_rsp {
154062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
154162306a36Sopenharmony_ci	struct mcam_entry entry_data;
154262306a36Sopenharmony_ci	u8 intf;
154362306a36Sopenharmony_ci	u8 enable;
154462306a36Sopenharmony_ci};
154562306a36Sopenharmony_ci
154662306a36Sopenharmony_cistruct npc_mcam_read_base_rule_rsp {
154762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
154862306a36Sopenharmony_ci	struct mcam_entry entry;
154962306a36Sopenharmony_ci};
155062306a36Sopenharmony_ci
155162306a36Sopenharmony_cistruct npc_mcam_get_stats_req {
155262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
155362306a36Sopenharmony_ci	u16 entry; /* mcam entry */
155462306a36Sopenharmony_ci};
155562306a36Sopenharmony_ci
155662306a36Sopenharmony_cistruct npc_mcam_get_stats_rsp {
155762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
155862306a36Sopenharmony_ci	u64 stat;  /* counter stats */
155962306a36Sopenharmony_ci	u8 stat_ena; /* enabled */
156062306a36Sopenharmony_ci};
156162306a36Sopenharmony_ci
156262306a36Sopenharmony_cistruct npc_get_field_hash_info_req {
156362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
156462306a36Sopenharmony_ci	u8 intf;
156562306a36Sopenharmony_ci};
156662306a36Sopenharmony_ci
156762306a36Sopenharmony_cistruct npc_get_field_hash_info_rsp {
156862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
156962306a36Sopenharmony_ci	u64 secret_key[3];
157062306a36Sopenharmony_ci#define NPC_MAX_HASH 2
157162306a36Sopenharmony_ci#define NPC_MAX_HASH_MASK 2
157262306a36Sopenharmony_ci	/* NPC_AF_INTF(0..1)_HASH(0..1)_MASK(0..1) */
157362306a36Sopenharmony_ci	u64 hash_mask[NPC_MAX_INTF][NPC_MAX_HASH][NPC_MAX_HASH_MASK];
157462306a36Sopenharmony_ci	/* NPC_AF_INTF(0..1)_HASH(0..1)_RESULT_CTRL */
157562306a36Sopenharmony_ci	u64 hash_ctrl[NPC_MAX_INTF][NPC_MAX_HASH];
157662306a36Sopenharmony_ci};
157762306a36Sopenharmony_ci
157862306a36Sopenharmony_cienum ptp_op {
157962306a36Sopenharmony_ci	PTP_OP_ADJFINE = 0,
158062306a36Sopenharmony_ci	PTP_OP_GET_CLOCK = 1,
158162306a36Sopenharmony_ci	PTP_OP_GET_TSTMP = 2,
158262306a36Sopenharmony_ci	PTP_OP_SET_THRESH = 3,
158362306a36Sopenharmony_ci	PTP_OP_EXTTS_ON = 4,
158462306a36Sopenharmony_ci	PTP_OP_ADJTIME = 5,
158562306a36Sopenharmony_ci	PTP_OP_SET_CLOCK = 6,
158662306a36Sopenharmony_ci};
158762306a36Sopenharmony_ci
158862306a36Sopenharmony_cistruct ptp_req {
158962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
159062306a36Sopenharmony_ci	u8 op;
159162306a36Sopenharmony_ci	s64 scaled_ppm;
159262306a36Sopenharmony_ci	u64 thresh;
159362306a36Sopenharmony_ci	int extts_on;
159462306a36Sopenharmony_ci	s64 delta;
159562306a36Sopenharmony_ci	u64 clk;
159662306a36Sopenharmony_ci};
159762306a36Sopenharmony_ci
159862306a36Sopenharmony_cistruct ptp_rsp {
159962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
160062306a36Sopenharmony_ci	u64 clk;
160162306a36Sopenharmony_ci	u64 tsc;
160262306a36Sopenharmony_ci};
160362306a36Sopenharmony_ci
160462306a36Sopenharmony_cistruct npc_get_field_status_req {
160562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
160662306a36Sopenharmony_ci	u8 intf;
160762306a36Sopenharmony_ci	u8 field;
160862306a36Sopenharmony_ci};
160962306a36Sopenharmony_ci
161062306a36Sopenharmony_cistruct npc_get_field_status_rsp {
161162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
161262306a36Sopenharmony_ci	u8 enable;
161362306a36Sopenharmony_ci};
161462306a36Sopenharmony_ci
161562306a36Sopenharmony_cistruct set_vf_perm  {
161662306a36Sopenharmony_ci	struct  mbox_msghdr hdr;
161762306a36Sopenharmony_ci	u16	vf;
161862306a36Sopenharmony_ci#define RESET_VF_PERM		BIT_ULL(0)
161962306a36Sopenharmony_ci#define	VF_TRUSTED		BIT_ULL(1)
162062306a36Sopenharmony_ci	u64	flags;
162162306a36Sopenharmony_ci};
162262306a36Sopenharmony_ci
162362306a36Sopenharmony_cistruct lmtst_tbl_setup_req {
162462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
162562306a36Sopenharmony_ci	u64 dis_sched_early_comp :1;
162662306a36Sopenharmony_ci	u64 sch_ena		 :1;
162762306a36Sopenharmony_ci	u64 dis_line_pref	 :1;
162862306a36Sopenharmony_ci	u64 ssow_pf_func	 :13;
162962306a36Sopenharmony_ci	u16 base_pcifunc;
163062306a36Sopenharmony_ci	u8  use_local_lmt_region;
163162306a36Sopenharmony_ci	u64 lmt_iova;
163262306a36Sopenharmony_ci	u64 rsvd[4];
163362306a36Sopenharmony_ci};
163462306a36Sopenharmony_ci
163562306a36Sopenharmony_ci/* CPT mailbox error codes
163662306a36Sopenharmony_ci * Range 901 - 1000.
163762306a36Sopenharmony_ci */
163862306a36Sopenharmony_cienum cpt_af_status {
163962306a36Sopenharmony_ci	CPT_AF_ERR_PARAM		= -901,
164062306a36Sopenharmony_ci	CPT_AF_ERR_GRP_INVALID		= -902,
164162306a36Sopenharmony_ci	CPT_AF_ERR_LF_INVALID		= -903,
164262306a36Sopenharmony_ci	CPT_AF_ERR_ACCESS_DENIED	= -904,
164362306a36Sopenharmony_ci	CPT_AF_ERR_SSO_PF_FUNC_INVALID	= -905,
164462306a36Sopenharmony_ci	CPT_AF_ERR_NIX_PF_FUNC_INVALID	= -906,
164562306a36Sopenharmony_ci	CPT_AF_ERR_INLINE_IPSEC_INB_ENA	= -907,
164662306a36Sopenharmony_ci	CPT_AF_ERR_INLINE_IPSEC_OUT_ENA	= -908
164762306a36Sopenharmony_ci};
164862306a36Sopenharmony_ci
164962306a36Sopenharmony_ci/* CPT mbox message formats */
165062306a36Sopenharmony_cistruct cpt_rd_wr_reg_msg {
165162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
165262306a36Sopenharmony_ci	u64 reg_offset;
165362306a36Sopenharmony_ci	u64 *ret_val;
165462306a36Sopenharmony_ci	u64 val;
165562306a36Sopenharmony_ci	u8 is_write;
165662306a36Sopenharmony_ci	int blkaddr;
165762306a36Sopenharmony_ci};
165862306a36Sopenharmony_ci
165962306a36Sopenharmony_cistruct cpt_lf_alloc_req_msg {
166062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
166162306a36Sopenharmony_ci	u16 nix_pf_func;
166262306a36Sopenharmony_ci	u16 sso_pf_func;
166362306a36Sopenharmony_ci	u16 eng_grpmsk;
166462306a36Sopenharmony_ci	int blkaddr;
166562306a36Sopenharmony_ci	u8 ctx_ilen_valid : 1;
166662306a36Sopenharmony_ci	u8 ctx_ilen : 7;
166762306a36Sopenharmony_ci};
166862306a36Sopenharmony_ci
166962306a36Sopenharmony_ci#define CPT_INLINE_INBOUND      0
167062306a36Sopenharmony_ci#define CPT_INLINE_OUTBOUND     1
167162306a36Sopenharmony_ci
167262306a36Sopenharmony_ci/* Mailbox message request format for CPT IPsec
167362306a36Sopenharmony_ci * inline inbound and outbound configuration.
167462306a36Sopenharmony_ci */
167562306a36Sopenharmony_cistruct cpt_inline_ipsec_cfg_msg {
167662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
167762306a36Sopenharmony_ci	u8 enable;
167862306a36Sopenharmony_ci	u8 slot;
167962306a36Sopenharmony_ci	u8 dir;
168062306a36Sopenharmony_ci	u8 sso_pf_func_ovrd;
168162306a36Sopenharmony_ci	u16 sso_pf_func; /* inbound path SSO_PF_FUNC */
168262306a36Sopenharmony_ci	u16 nix_pf_func; /* outbound path NIX_PF_FUNC */
168362306a36Sopenharmony_ci};
168462306a36Sopenharmony_ci
168562306a36Sopenharmony_ci/* Mailbox message request and response format for CPT stats. */
168662306a36Sopenharmony_cistruct cpt_sts_req {
168762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
168862306a36Sopenharmony_ci	u8 blkaddr;
168962306a36Sopenharmony_ci};
169062306a36Sopenharmony_ci
169162306a36Sopenharmony_cistruct cpt_sts_rsp {
169262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
169362306a36Sopenharmony_ci	u64 inst_req_pc;
169462306a36Sopenharmony_ci	u64 inst_lat_pc;
169562306a36Sopenharmony_ci	u64 rd_req_pc;
169662306a36Sopenharmony_ci	u64 rd_lat_pc;
169762306a36Sopenharmony_ci	u64 rd_uc_pc;
169862306a36Sopenharmony_ci	u64 active_cycles_pc;
169962306a36Sopenharmony_ci	u64 ctx_mis_pc;
170062306a36Sopenharmony_ci	u64 ctx_hit_pc;
170162306a36Sopenharmony_ci	u64 ctx_aop_pc;
170262306a36Sopenharmony_ci	u64 ctx_aop_lat_pc;
170362306a36Sopenharmony_ci	u64 ctx_ifetch_pc;
170462306a36Sopenharmony_ci	u64 ctx_ifetch_lat_pc;
170562306a36Sopenharmony_ci	u64 ctx_ffetch_pc;
170662306a36Sopenharmony_ci	u64 ctx_ffetch_lat_pc;
170762306a36Sopenharmony_ci	u64 ctx_wback_pc;
170862306a36Sopenharmony_ci	u64 ctx_wback_lat_pc;
170962306a36Sopenharmony_ci	u64 ctx_psh_pc;
171062306a36Sopenharmony_ci	u64 ctx_psh_lat_pc;
171162306a36Sopenharmony_ci	u64 ctx_err;
171262306a36Sopenharmony_ci	u64 ctx_enc_id;
171362306a36Sopenharmony_ci	u64 ctx_flush_timer;
171462306a36Sopenharmony_ci	u64 rxc_time;
171562306a36Sopenharmony_ci	u64 rxc_time_cfg;
171662306a36Sopenharmony_ci	u64 rxc_active_sts;
171762306a36Sopenharmony_ci	u64 rxc_zombie_sts;
171862306a36Sopenharmony_ci	u64 busy_sts_ae;
171962306a36Sopenharmony_ci	u64 free_sts_ae;
172062306a36Sopenharmony_ci	u64 busy_sts_se;
172162306a36Sopenharmony_ci	u64 free_sts_se;
172262306a36Sopenharmony_ci	u64 busy_sts_ie;
172362306a36Sopenharmony_ci	u64 free_sts_ie;
172462306a36Sopenharmony_ci	u64 exe_err_info;
172562306a36Sopenharmony_ci	u64 cptclk_cnt;
172662306a36Sopenharmony_ci	u64 diag;
172762306a36Sopenharmony_ci	u64 rxc_dfrg;
172862306a36Sopenharmony_ci	u64 x2p_link_cfg0;
172962306a36Sopenharmony_ci	u64 x2p_link_cfg1;
173062306a36Sopenharmony_ci};
173162306a36Sopenharmony_ci
173262306a36Sopenharmony_ci/* Mailbox message request format to configure reassembly timeout. */
173362306a36Sopenharmony_cistruct cpt_rxc_time_cfg_req {
173462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
173562306a36Sopenharmony_ci	int blkaddr;
173662306a36Sopenharmony_ci	u32 step;
173762306a36Sopenharmony_ci	u16 zombie_thres;
173862306a36Sopenharmony_ci	u16 zombie_limit;
173962306a36Sopenharmony_ci	u16 active_thres;
174062306a36Sopenharmony_ci	u16 active_limit;
174162306a36Sopenharmony_ci};
174262306a36Sopenharmony_ci
174362306a36Sopenharmony_ci/* Mailbox message request format to request for CPT_INST_S lmtst. */
174462306a36Sopenharmony_cistruct cpt_inst_lmtst_req {
174562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
174662306a36Sopenharmony_ci	u64 inst[8];
174762306a36Sopenharmony_ci	u64 rsvd;
174862306a36Sopenharmony_ci};
174962306a36Sopenharmony_ci
175062306a36Sopenharmony_ci/* Mailbox message format to request for CPT LF reset */
175162306a36Sopenharmony_cistruct cpt_lf_rst_req {
175262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
175362306a36Sopenharmony_ci	u32 slot;
175462306a36Sopenharmony_ci	u32 rsvd;
175562306a36Sopenharmony_ci};
175662306a36Sopenharmony_ci
175762306a36Sopenharmony_ci/* Mailbox message format to request for CPT faulted engines */
175862306a36Sopenharmony_cistruct cpt_flt_eng_info_req {
175962306a36Sopenharmony_ci	struct mbox_msghdr hdr;
176062306a36Sopenharmony_ci	int blkaddr;
176162306a36Sopenharmony_ci	bool reset;
176262306a36Sopenharmony_ci	u32 rsvd;
176362306a36Sopenharmony_ci};
176462306a36Sopenharmony_ci
176562306a36Sopenharmony_cistruct cpt_flt_eng_info_rsp {
176662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
176762306a36Sopenharmony_ci	u64 flt_eng_map[CPT_10K_AF_INT_VEC_RVU];
176862306a36Sopenharmony_ci	u64 rcvrd_eng_map[CPT_10K_AF_INT_VEC_RVU];
176962306a36Sopenharmony_ci	u64 rsvd;
177062306a36Sopenharmony_ci};
177162306a36Sopenharmony_ci
177262306a36Sopenharmony_cistruct sdp_node_info {
177362306a36Sopenharmony_ci	/* Node to which this PF belons to */
177462306a36Sopenharmony_ci	u8 node_id;
177562306a36Sopenharmony_ci	u8 max_vfs;
177662306a36Sopenharmony_ci	u8 num_pf_rings;
177762306a36Sopenharmony_ci	u8 pf_srn;
177862306a36Sopenharmony_ci#define SDP_MAX_VFS	128
177962306a36Sopenharmony_ci	u8 vf_rings[SDP_MAX_VFS];
178062306a36Sopenharmony_ci};
178162306a36Sopenharmony_ci
178262306a36Sopenharmony_cistruct sdp_chan_info_msg {
178362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
178462306a36Sopenharmony_ci	struct sdp_node_info info;
178562306a36Sopenharmony_ci};
178662306a36Sopenharmony_ci
178762306a36Sopenharmony_cistruct sdp_get_chan_info_msg {
178862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
178962306a36Sopenharmony_ci	u16 chan_base;
179062306a36Sopenharmony_ci	u16 num_chan;
179162306a36Sopenharmony_ci};
179262306a36Sopenharmony_ci
179362306a36Sopenharmony_ci/* CGX mailbox error codes
179462306a36Sopenharmony_ci * Range 1101 - 1200.
179562306a36Sopenharmony_ci */
179662306a36Sopenharmony_cienum cgx_af_status {
179762306a36Sopenharmony_ci	LMAC_AF_ERR_INVALID_PARAM	= -1101,
179862306a36Sopenharmony_ci	LMAC_AF_ERR_PF_NOT_MAPPED	= -1102,
179962306a36Sopenharmony_ci	LMAC_AF_ERR_PERM_DENIED		= -1103,
180062306a36Sopenharmony_ci	LMAC_AF_ERR_PFC_ENADIS_PERM_DENIED       = -1104,
180162306a36Sopenharmony_ci	LMAC_AF_ERR_8023PAUSE_ENADIS_PERM_DENIED = -1105,
180262306a36Sopenharmony_ci	LMAC_AF_ERR_CMD_TIMEOUT = -1106,
180362306a36Sopenharmony_ci	LMAC_AF_ERR_FIRMWARE_DATA_NOT_MAPPED = -1107,
180462306a36Sopenharmony_ci	LMAC_AF_ERR_EXACT_MATCH_TBL_ADD_FAILED = -1108,
180562306a36Sopenharmony_ci	LMAC_AF_ERR_EXACT_MATCH_TBL_DEL_FAILED = -1109,
180662306a36Sopenharmony_ci	LMAC_AF_ERR_EXACT_MATCH_TBL_LOOK_UP_FAILED = -1110,
180762306a36Sopenharmony_ci};
180862306a36Sopenharmony_ci
180962306a36Sopenharmony_cienum mcs_direction {
181062306a36Sopenharmony_ci	MCS_RX,
181162306a36Sopenharmony_ci	MCS_TX,
181262306a36Sopenharmony_ci};
181362306a36Sopenharmony_ci
181462306a36Sopenharmony_cienum mcs_rsrc_type {
181562306a36Sopenharmony_ci	MCS_RSRC_TYPE_FLOWID,
181662306a36Sopenharmony_ci	MCS_RSRC_TYPE_SECY,
181762306a36Sopenharmony_ci	MCS_RSRC_TYPE_SC,
181862306a36Sopenharmony_ci	MCS_RSRC_TYPE_SA,
181962306a36Sopenharmony_ci};
182062306a36Sopenharmony_ci
182162306a36Sopenharmony_cistruct mcs_alloc_rsrc_req {
182262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
182362306a36Sopenharmony_ci	u8 rsrc_type;
182462306a36Sopenharmony_ci	u8 rsrc_cnt;	/* Resources count */
182562306a36Sopenharmony_ci	u8 mcs_id;	/* MCS block ID	*/
182662306a36Sopenharmony_ci	u8 dir;		/* Macsec ingress or egress side */
182762306a36Sopenharmony_ci	u8 all;		/* Allocate all resource type one each */
182862306a36Sopenharmony_ci	u64 rsvd;
182962306a36Sopenharmony_ci};
183062306a36Sopenharmony_ci
183162306a36Sopenharmony_cistruct mcs_alloc_rsrc_rsp {
183262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
183362306a36Sopenharmony_ci	u8 flow_ids[128];	/* Index of reserved entries */
183462306a36Sopenharmony_ci	u8 secy_ids[128];
183562306a36Sopenharmony_ci	u8 sc_ids[128];
183662306a36Sopenharmony_ci	u8 sa_ids[256];
183762306a36Sopenharmony_ci	u8 rsrc_type;
183862306a36Sopenharmony_ci	u8 rsrc_cnt;		/* No of entries reserved */
183962306a36Sopenharmony_ci	u8 mcs_id;
184062306a36Sopenharmony_ci	u8 dir;
184162306a36Sopenharmony_ci	u8 all;
184262306a36Sopenharmony_ci	u8 rsvd[256];		/* reserved fields for future expansion */
184362306a36Sopenharmony_ci};
184462306a36Sopenharmony_ci
184562306a36Sopenharmony_cistruct mcs_free_rsrc_req {
184662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
184762306a36Sopenharmony_ci	u8 rsrc_id;		/* Index of the entry to be freed */
184862306a36Sopenharmony_ci	u8 rsrc_type;
184962306a36Sopenharmony_ci	u8 mcs_id;
185062306a36Sopenharmony_ci	u8 dir;
185162306a36Sopenharmony_ci	u8 all;			/* Free all the cam resources */
185262306a36Sopenharmony_ci	u64 rsvd;
185362306a36Sopenharmony_ci};
185462306a36Sopenharmony_ci
185562306a36Sopenharmony_cistruct mcs_flowid_entry_write_req {
185662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
185762306a36Sopenharmony_ci	u64 data[4];
185862306a36Sopenharmony_ci	u64 mask[4];
185962306a36Sopenharmony_ci	u64 sci;	/* CNF10K-B for tx_secy_mem_map */
186062306a36Sopenharmony_ci	u8 flow_id;
186162306a36Sopenharmony_ci	u8 secy_id;	/* secyid for which flowid is mapped */
186262306a36Sopenharmony_ci	u8 sc_id;	/* Valid if dir = MCS_TX, SC_CAM id mapped to flowid */
186362306a36Sopenharmony_ci	u8 ena;		/* Enable tcam entry */
186462306a36Sopenharmony_ci	u8 ctrl_pkt;
186562306a36Sopenharmony_ci	u8 mcs_id;
186662306a36Sopenharmony_ci	u8 dir;
186762306a36Sopenharmony_ci	u64 rsvd;
186862306a36Sopenharmony_ci};
186962306a36Sopenharmony_ci
187062306a36Sopenharmony_cistruct mcs_secy_plcy_write_req {
187162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
187262306a36Sopenharmony_ci	u64 plcy;
187362306a36Sopenharmony_ci	u8 secy_id;
187462306a36Sopenharmony_ci	u8 mcs_id;
187562306a36Sopenharmony_ci	u8 dir;
187662306a36Sopenharmony_ci	u64 rsvd;
187762306a36Sopenharmony_ci};
187862306a36Sopenharmony_ci
187962306a36Sopenharmony_ci/* RX SC_CAM mapping */
188062306a36Sopenharmony_cistruct mcs_rx_sc_cam_write_req {
188162306a36Sopenharmony_ci	struct mbox_msghdr hdr;
188262306a36Sopenharmony_ci	u64 sci;	/* SCI */
188362306a36Sopenharmony_ci	u64 secy_id;	/* secy index mapped to SC */
188462306a36Sopenharmony_ci	u8 sc_id;	/* SC CAM entry index */
188562306a36Sopenharmony_ci	u8 mcs_id;
188662306a36Sopenharmony_ci	u64 rsvd;
188762306a36Sopenharmony_ci};
188862306a36Sopenharmony_ci
188962306a36Sopenharmony_cistruct mcs_sa_plcy_write_req {
189062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
189162306a36Sopenharmony_ci	u64 plcy[2][9];		/* Support 2 SA policy */
189262306a36Sopenharmony_ci	u8 sa_index[2];
189362306a36Sopenharmony_ci	u8 sa_cnt;
189462306a36Sopenharmony_ci	u8 mcs_id;
189562306a36Sopenharmony_ci	u8 dir;
189662306a36Sopenharmony_ci	u64 rsvd;
189762306a36Sopenharmony_ci};
189862306a36Sopenharmony_ci
189962306a36Sopenharmony_cistruct mcs_tx_sc_sa_map {
190062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
190162306a36Sopenharmony_ci	u8 sa_index0;
190262306a36Sopenharmony_ci	u8 sa_index1;
190362306a36Sopenharmony_ci	u8 rekey_ena;
190462306a36Sopenharmony_ci	u8 sa_index0_vld;
190562306a36Sopenharmony_ci	u8 sa_index1_vld;
190662306a36Sopenharmony_ci	u8 tx_sa_active;
190762306a36Sopenharmony_ci	u64 sectag_sci;
190862306a36Sopenharmony_ci	u8 sc_id;	/* used as index for SA_MEM_MAP */
190962306a36Sopenharmony_ci	u8 mcs_id;
191062306a36Sopenharmony_ci	u64 rsvd;
191162306a36Sopenharmony_ci};
191262306a36Sopenharmony_ci
191362306a36Sopenharmony_cistruct mcs_rx_sc_sa_map {
191462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
191562306a36Sopenharmony_ci	u8 sa_index;
191662306a36Sopenharmony_ci	u8 sa_in_use;
191762306a36Sopenharmony_ci	u8 sc_id;
191862306a36Sopenharmony_ci	u8 an;		/* value range 0-3, sc_id + an used as index SA_MEM_MAP */
191962306a36Sopenharmony_ci	u8 mcs_id;
192062306a36Sopenharmony_ci	u64 rsvd;
192162306a36Sopenharmony_ci};
192262306a36Sopenharmony_ci
192362306a36Sopenharmony_cistruct mcs_flowid_ena_dis_entry {
192462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
192562306a36Sopenharmony_ci	u8 flow_id;
192662306a36Sopenharmony_ci	u8 ena;
192762306a36Sopenharmony_ci	u8 mcs_id;
192862306a36Sopenharmony_ci	u8 dir;
192962306a36Sopenharmony_ci	u64 rsvd;
193062306a36Sopenharmony_ci};
193162306a36Sopenharmony_ci
193262306a36Sopenharmony_cistruct mcs_pn_table_write_req {
193362306a36Sopenharmony_ci	struct mbox_msghdr hdr;
193462306a36Sopenharmony_ci	u64 next_pn;
193562306a36Sopenharmony_ci	u8 pn_id;
193662306a36Sopenharmony_ci	u8 mcs_id;
193762306a36Sopenharmony_ci	u8 dir;
193862306a36Sopenharmony_ci	u64 rsvd;
193962306a36Sopenharmony_ci};
194062306a36Sopenharmony_ci
194162306a36Sopenharmony_cistruct mcs_hw_info {
194262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
194362306a36Sopenharmony_ci	u8 num_mcs_blks;	/* Number of MCS blocks */
194462306a36Sopenharmony_ci	u8 tcam_entries;	/* RX/TX Tcam entries per mcs block */
194562306a36Sopenharmony_ci	u8 secy_entries;	/* RX/TX SECY entries per mcs block */
194662306a36Sopenharmony_ci	u8 sc_entries;		/* RX/TX SC CAM entries per mcs block */
194762306a36Sopenharmony_ci	u16 sa_entries;		/* PN table entries = SA entries */
194862306a36Sopenharmony_ci	u64 rsvd[16];
194962306a36Sopenharmony_ci};
195062306a36Sopenharmony_ci
195162306a36Sopenharmony_cistruct mcs_set_active_lmac {
195262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
195362306a36Sopenharmony_ci	u32 lmac_bmap;	/* bitmap of active lmac per mcs block */
195462306a36Sopenharmony_ci	u8 mcs_id;
195562306a36Sopenharmony_ci	u16 chan_base; /* MCS channel base */
195662306a36Sopenharmony_ci	u64 rsvd;
195762306a36Sopenharmony_ci};
195862306a36Sopenharmony_ci
195962306a36Sopenharmony_cistruct mcs_set_lmac_mode {
196062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
196162306a36Sopenharmony_ci	u8 mode;	/* 1:Bypass 0:Operational */
196262306a36Sopenharmony_ci	u8 lmac_id;
196362306a36Sopenharmony_ci	u8 mcs_id;
196462306a36Sopenharmony_ci	u64 rsvd;
196562306a36Sopenharmony_ci};
196662306a36Sopenharmony_ci
196762306a36Sopenharmony_cistruct mcs_port_reset_req {
196862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
196962306a36Sopenharmony_ci	u8 reset;
197062306a36Sopenharmony_ci	u8 mcs_id;
197162306a36Sopenharmony_ci	u8 port_id;
197262306a36Sopenharmony_ci	u64 rsvd;
197362306a36Sopenharmony_ci};
197462306a36Sopenharmony_ci
197562306a36Sopenharmony_cistruct mcs_port_cfg_set_req {
197662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
197762306a36Sopenharmony_ci	u8 cstm_tag_rel_mode_sel;
197862306a36Sopenharmony_ci	u8 custom_hdr_enb;
197962306a36Sopenharmony_ci	u8 fifo_skid;
198062306a36Sopenharmony_ci	u8 port_mode;
198162306a36Sopenharmony_ci	u8 port_id;
198262306a36Sopenharmony_ci	u8 mcs_id;
198362306a36Sopenharmony_ci	u64 rsvd;
198462306a36Sopenharmony_ci};
198562306a36Sopenharmony_ci
198662306a36Sopenharmony_cistruct mcs_port_cfg_get_req {
198762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
198862306a36Sopenharmony_ci	u8 port_id;
198962306a36Sopenharmony_ci	u8 mcs_id;
199062306a36Sopenharmony_ci	u64 rsvd;
199162306a36Sopenharmony_ci};
199262306a36Sopenharmony_ci
199362306a36Sopenharmony_cistruct mcs_port_cfg_get_rsp {
199462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
199562306a36Sopenharmony_ci	u8 cstm_tag_rel_mode_sel;
199662306a36Sopenharmony_ci	u8 custom_hdr_enb;
199762306a36Sopenharmony_ci	u8 fifo_skid;
199862306a36Sopenharmony_ci	u8 port_mode;
199962306a36Sopenharmony_ci	u8 port_id;
200062306a36Sopenharmony_ci	u8 mcs_id;
200162306a36Sopenharmony_ci	u64 rsvd;
200262306a36Sopenharmony_ci};
200362306a36Sopenharmony_ci
200462306a36Sopenharmony_cistruct mcs_custom_tag_cfg_get_req {
200562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
200662306a36Sopenharmony_ci	u8 mcs_id;
200762306a36Sopenharmony_ci	u8 dir;
200862306a36Sopenharmony_ci	u64 rsvd;
200962306a36Sopenharmony_ci};
201062306a36Sopenharmony_ci
201162306a36Sopenharmony_cistruct mcs_custom_tag_cfg_get_rsp {
201262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
201362306a36Sopenharmony_ci	u16 cstm_etype[8];
201462306a36Sopenharmony_ci	u8 cstm_indx[8];
201562306a36Sopenharmony_ci	u8 cstm_etype_en;
201662306a36Sopenharmony_ci	u8 mcs_id;
201762306a36Sopenharmony_ci	u8 dir;
201862306a36Sopenharmony_ci	u64 rsvd;
201962306a36Sopenharmony_ci};
202062306a36Sopenharmony_ci
202162306a36Sopenharmony_ci/* MCS mailbox error codes
202262306a36Sopenharmony_ci * Range 1201 - 1300.
202362306a36Sopenharmony_ci */
202462306a36Sopenharmony_cienum mcs_af_status {
202562306a36Sopenharmony_ci	MCS_AF_ERR_INVALID_MCSID        = -1201,
202662306a36Sopenharmony_ci	MCS_AF_ERR_NOT_MAPPED           = -1202,
202762306a36Sopenharmony_ci};
202862306a36Sopenharmony_ci
202962306a36Sopenharmony_cistruct mcs_set_pn_threshold {
203062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
203162306a36Sopenharmony_ci	u64 threshold;
203262306a36Sopenharmony_ci	u8 xpn; /* '1' for setting xpn threshold */
203362306a36Sopenharmony_ci	u8 mcs_id;
203462306a36Sopenharmony_ci	u8 dir;
203562306a36Sopenharmony_ci	u64 rsvd;
203662306a36Sopenharmony_ci};
203762306a36Sopenharmony_ci
203862306a36Sopenharmony_cienum mcs_ctrl_pkt_rulew_type {
203962306a36Sopenharmony_ci	MCS_CTRL_PKT_RULE_TYPE_ETH,
204062306a36Sopenharmony_ci	MCS_CTRL_PKT_RULE_TYPE_DA,
204162306a36Sopenharmony_ci	MCS_CTRL_PKT_RULE_TYPE_RANGE,
204262306a36Sopenharmony_ci	MCS_CTRL_PKT_RULE_TYPE_COMBO,
204362306a36Sopenharmony_ci	MCS_CTRL_PKT_RULE_TYPE_MAC,
204462306a36Sopenharmony_ci};
204562306a36Sopenharmony_ci
204662306a36Sopenharmony_cistruct mcs_alloc_ctrl_pkt_rule_req {
204762306a36Sopenharmony_ci	struct mbox_msghdr hdr;
204862306a36Sopenharmony_ci	u8 rule_type;
204962306a36Sopenharmony_ci	u8 mcs_id;	/* MCS block ID	*/
205062306a36Sopenharmony_ci	u8 dir;		/* Macsec ingress or egress side */
205162306a36Sopenharmony_ci	u64 rsvd;
205262306a36Sopenharmony_ci};
205362306a36Sopenharmony_ci
205462306a36Sopenharmony_cistruct mcs_alloc_ctrl_pkt_rule_rsp {
205562306a36Sopenharmony_ci	struct mbox_msghdr hdr;
205662306a36Sopenharmony_ci	u8 rule_idx;
205762306a36Sopenharmony_ci	u8 rule_type;
205862306a36Sopenharmony_ci	u8 mcs_id;
205962306a36Sopenharmony_ci	u8 dir;
206062306a36Sopenharmony_ci	u64 rsvd;
206162306a36Sopenharmony_ci};
206262306a36Sopenharmony_ci
206362306a36Sopenharmony_cistruct mcs_free_ctrl_pkt_rule_req {
206462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
206562306a36Sopenharmony_ci	u8 rule_idx;
206662306a36Sopenharmony_ci	u8 rule_type;
206762306a36Sopenharmony_ci	u8 mcs_id;
206862306a36Sopenharmony_ci	u8 dir;
206962306a36Sopenharmony_ci	u8 all;
207062306a36Sopenharmony_ci	u64 rsvd;
207162306a36Sopenharmony_ci};
207262306a36Sopenharmony_ci
207362306a36Sopenharmony_cistruct mcs_ctrl_pkt_rule_write_req {
207462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
207562306a36Sopenharmony_ci	u64 data0;
207662306a36Sopenharmony_ci	u64 data1;
207762306a36Sopenharmony_ci	u64 data2;
207862306a36Sopenharmony_ci	u8 rule_idx;
207962306a36Sopenharmony_ci	u8 rule_type;
208062306a36Sopenharmony_ci	u8 mcs_id;
208162306a36Sopenharmony_ci	u8 dir;
208262306a36Sopenharmony_ci	u64 rsvd;
208362306a36Sopenharmony_ci};
208462306a36Sopenharmony_ci
208562306a36Sopenharmony_cistruct mcs_stats_req {
208662306a36Sopenharmony_ci	struct mbox_msghdr hdr;
208762306a36Sopenharmony_ci	u8 id;
208862306a36Sopenharmony_ci	u8 mcs_id;
208962306a36Sopenharmony_ci	u8 dir;
209062306a36Sopenharmony_ci	u64 rsvd;
209162306a36Sopenharmony_ci};
209262306a36Sopenharmony_ci
209362306a36Sopenharmony_cistruct mcs_flowid_stats {
209462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
209562306a36Sopenharmony_ci	u64 tcam_hit_cnt;
209662306a36Sopenharmony_ci	u64 rsvd;
209762306a36Sopenharmony_ci};
209862306a36Sopenharmony_ci
209962306a36Sopenharmony_cistruct mcs_secy_stats {
210062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
210162306a36Sopenharmony_ci	u64 ctl_pkt_bcast_cnt;
210262306a36Sopenharmony_ci	u64 ctl_pkt_mcast_cnt;
210362306a36Sopenharmony_ci	u64 ctl_pkt_ucast_cnt;
210462306a36Sopenharmony_ci	u64 ctl_octet_cnt;
210562306a36Sopenharmony_ci	u64 unctl_pkt_bcast_cnt;
210662306a36Sopenharmony_ci	u64 unctl_pkt_mcast_cnt;
210762306a36Sopenharmony_ci	u64 unctl_pkt_ucast_cnt;
210862306a36Sopenharmony_ci	u64 unctl_octet_cnt;
210962306a36Sopenharmony_ci	/* Valid only for RX */
211062306a36Sopenharmony_ci	u64 octet_decrypted_cnt;
211162306a36Sopenharmony_ci	u64 octet_validated_cnt;
211262306a36Sopenharmony_ci	u64 pkt_port_disabled_cnt;
211362306a36Sopenharmony_ci	u64 pkt_badtag_cnt;
211462306a36Sopenharmony_ci	u64 pkt_nosa_cnt;
211562306a36Sopenharmony_ci	u64 pkt_nosaerror_cnt;
211662306a36Sopenharmony_ci	u64 pkt_tagged_ctl_cnt;
211762306a36Sopenharmony_ci	u64 pkt_untaged_cnt;
211862306a36Sopenharmony_ci	u64 pkt_ctl_cnt;	/* CN10K-B */
211962306a36Sopenharmony_ci	u64 pkt_notag_cnt;	/* CNF10K-B */
212062306a36Sopenharmony_ci	/* Valid only for TX */
212162306a36Sopenharmony_ci	u64 octet_encrypted_cnt;
212262306a36Sopenharmony_ci	u64 octet_protected_cnt;
212362306a36Sopenharmony_ci	u64 pkt_noactivesa_cnt;
212462306a36Sopenharmony_ci	u64 pkt_toolong_cnt;
212562306a36Sopenharmony_ci	u64 pkt_untagged_cnt;
212662306a36Sopenharmony_ci	u64 rsvd[4];
212762306a36Sopenharmony_ci};
212862306a36Sopenharmony_ci
212962306a36Sopenharmony_cistruct mcs_port_stats {
213062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
213162306a36Sopenharmony_ci	u64 tcam_miss_cnt;
213262306a36Sopenharmony_ci	u64 parser_err_cnt;
213362306a36Sopenharmony_ci	u64 preempt_err_cnt;  /* CNF10K-B */
213462306a36Sopenharmony_ci	u64 sectag_insert_err_cnt;
213562306a36Sopenharmony_ci	u64 rsvd[4];
213662306a36Sopenharmony_ci};
213762306a36Sopenharmony_ci
213862306a36Sopenharmony_ci/* Only for CN10K-B */
213962306a36Sopenharmony_cistruct mcs_sa_stats {
214062306a36Sopenharmony_ci	struct mbox_msghdr hdr;
214162306a36Sopenharmony_ci	/* RX */
214262306a36Sopenharmony_ci	u64 pkt_invalid_cnt;
214362306a36Sopenharmony_ci	u64 pkt_nosaerror_cnt;
214462306a36Sopenharmony_ci	u64 pkt_notvalid_cnt;
214562306a36Sopenharmony_ci	u64 pkt_ok_cnt;
214662306a36Sopenharmony_ci	u64 pkt_nosa_cnt;
214762306a36Sopenharmony_ci	/* TX */
214862306a36Sopenharmony_ci	u64 pkt_encrypt_cnt;
214962306a36Sopenharmony_ci	u64 pkt_protected_cnt;
215062306a36Sopenharmony_ci	u64 rsvd[4];
215162306a36Sopenharmony_ci};
215262306a36Sopenharmony_ci
215362306a36Sopenharmony_cistruct mcs_sc_stats {
215462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
215562306a36Sopenharmony_ci	/* RX */
215662306a36Sopenharmony_ci	u64 hit_cnt;
215762306a36Sopenharmony_ci	u64 pkt_invalid_cnt;
215862306a36Sopenharmony_ci	u64 pkt_late_cnt;
215962306a36Sopenharmony_ci	u64 pkt_notvalid_cnt;
216062306a36Sopenharmony_ci	u64 pkt_unchecked_cnt;
216162306a36Sopenharmony_ci	u64 pkt_delay_cnt;	/* CNF10K-B */
216262306a36Sopenharmony_ci	u64 pkt_ok_cnt;		/* CNF10K-B */
216362306a36Sopenharmony_ci	u64 octet_decrypt_cnt;	/* CN10K-B */
216462306a36Sopenharmony_ci	u64 octet_validate_cnt;	/* CN10K-B */
216562306a36Sopenharmony_ci	/* TX */
216662306a36Sopenharmony_ci	u64 pkt_encrypt_cnt;
216762306a36Sopenharmony_ci	u64 pkt_protected_cnt;
216862306a36Sopenharmony_ci	u64 octet_encrypt_cnt;		/* CN10K-B */
216962306a36Sopenharmony_ci	u64 octet_protected_cnt;	/* CN10K-B */
217062306a36Sopenharmony_ci	u64 rsvd[4];
217162306a36Sopenharmony_ci};
217262306a36Sopenharmony_ci
217362306a36Sopenharmony_cistruct mcs_clear_stats {
217462306a36Sopenharmony_ci	struct mbox_msghdr hdr;
217562306a36Sopenharmony_ci#define MCS_FLOWID_STATS	0
217662306a36Sopenharmony_ci#define MCS_SECY_STATS		1
217762306a36Sopenharmony_ci#define MCS_SC_STATS		2
217862306a36Sopenharmony_ci#define MCS_SA_STATS		3
217962306a36Sopenharmony_ci#define MCS_PORT_STATS		4
218062306a36Sopenharmony_ci	u8 type;	/* FLOWID, SECY, SC, SA, PORT */
218162306a36Sopenharmony_ci	u8 id;		/* type = PORT, If id = FF(invalid) port no is derived from pcifunc */
218262306a36Sopenharmony_ci	u8 mcs_id;
218362306a36Sopenharmony_ci	u8 dir;
218462306a36Sopenharmony_ci	u8 all;		/* All resources stats mapped to PF are cleared */
218562306a36Sopenharmony_ci};
218662306a36Sopenharmony_ci
218762306a36Sopenharmony_cistruct mcs_intr_cfg {
218862306a36Sopenharmony_ci	struct mbox_msghdr hdr;
218962306a36Sopenharmony_ci#define MCS_CPM_RX_SECTAG_V_EQ1_INT		BIT_ULL(0)
219062306a36Sopenharmony_ci#define MCS_CPM_RX_SECTAG_E_EQ0_C_EQ1_INT	BIT_ULL(1)
219162306a36Sopenharmony_ci#define MCS_CPM_RX_SECTAG_SL_GTE48_INT		BIT_ULL(2)
219262306a36Sopenharmony_ci#define MCS_CPM_RX_SECTAG_ES_EQ1_SC_EQ1_INT	BIT_ULL(3)
219362306a36Sopenharmony_ci#define MCS_CPM_RX_SECTAG_SC_EQ1_SCB_EQ1_INT	BIT_ULL(4)
219462306a36Sopenharmony_ci#define MCS_CPM_RX_PACKET_XPN_EQ0_INT		BIT_ULL(5)
219562306a36Sopenharmony_ci#define MCS_CPM_RX_PN_THRESH_REACHED_INT	BIT_ULL(6)
219662306a36Sopenharmony_ci#define MCS_CPM_TX_PACKET_XPN_EQ0_INT		BIT_ULL(7)
219762306a36Sopenharmony_ci#define MCS_CPM_TX_PN_THRESH_REACHED_INT	BIT_ULL(8)
219862306a36Sopenharmony_ci#define MCS_CPM_TX_SA_NOT_VALID_INT		BIT_ULL(9)
219962306a36Sopenharmony_ci#define MCS_BBE_RX_DFIFO_OVERFLOW_INT		BIT_ULL(10)
220062306a36Sopenharmony_ci#define MCS_BBE_RX_PLFIFO_OVERFLOW_INT		BIT_ULL(11)
220162306a36Sopenharmony_ci#define MCS_BBE_TX_DFIFO_OVERFLOW_INT		BIT_ULL(12)
220262306a36Sopenharmony_ci#define MCS_BBE_TX_PLFIFO_OVERFLOW_INT		BIT_ULL(13)
220362306a36Sopenharmony_ci#define MCS_PAB_RX_CHAN_OVERFLOW_INT		BIT_ULL(14)
220462306a36Sopenharmony_ci#define MCS_PAB_TX_CHAN_OVERFLOW_INT		BIT_ULL(15)
220562306a36Sopenharmony_ci	u64 intr_mask;		/* Interrupt enable mask */
220662306a36Sopenharmony_ci	u8 mcs_id;
220762306a36Sopenharmony_ci	u8 lmac_id;
220862306a36Sopenharmony_ci	u64 rsvd;
220962306a36Sopenharmony_ci};
221062306a36Sopenharmony_ci
221162306a36Sopenharmony_cistruct mcs_intr_info {
221262306a36Sopenharmony_ci	struct mbox_msghdr hdr;
221362306a36Sopenharmony_ci	u64 intr_mask;
221462306a36Sopenharmony_ci	int sa_id;
221562306a36Sopenharmony_ci	u8 mcs_id;
221662306a36Sopenharmony_ci	u8 lmac_id;
221762306a36Sopenharmony_ci	u64 rsvd;
221862306a36Sopenharmony_ci};
221962306a36Sopenharmony_ci
222062306a36Sopenharmony_ci#endif /* MBOX_H */
2221