162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (C) 2005 - 2016 Broadcom
462306a36Sopenharmony_ci * All rights reserved.
562306a36Sopenharmony_ci *
662306a36Sopenharmony_ci * Contact Information:
762306a36Sopenharmony_ci * linux-drivers@emulex.com
862306a36Sopenharmony_ci *
962306a36Sopenharmony_ci * Emulex
1062306a36Sopenharmony_ci * 3333 Susan Street
1162306a36Sopenharmony_ci * Costa Mesa, CA 92626
1262306a36Sopenharmony_ci */
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci#ifndef BE_ROCE_H
1562306a36Sopenharmony_ci#define BE_ROCE_H
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci#include <linux/pci.h>
1862306a36Sopenharmony_ci#include <linux/netdevice.h>
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci#define BE_ROCE_ABI_VERSION	1
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_cistruct ocrdma_dev;
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_cienum be_interrupt_mode {
2562306a36Sopenharmony_ci	BE_INTERRUPT_MODE_MSIX	= 0,
2662306a36Sopenharmony_ci	BE_INTERRUPT_MODE_INTX	= 1,
2762306a36Sopenharmony_ci	BE_INTERRUPT_MODE_MSI	= 2,
2862306a36Sopenharmony_ci};
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci#define MAX_MSIX_VECTORS		32
3162306a36Sopenharmony_cistruct be_dev_info {
3262306a36Sopenharmony_ci	u8 __iomem *db;
3362306a36Sopenharmony_ci	u64 unmapped_db;
3462306a36Sopenharmony_ci	u32 db_page_size;
3562306a36Sopenharmony_ci	u32 db_total_size;
3662306a36Sopenharmony_ci	u64 dpp_unmapped_addr;
3762306a36Sopenharmony_ci	u32 dpp_unmapped_len;
3862306a36Sopenharmony_ci	struct pci_dev *pdev;
3962306a36Sopenharmony_ci	struct net_device *netdev;
4062306a36Sopenharmony_ci	u8 mac_addr[ETH_ALEN];
4162306a36Sopenharmony_ci	u32 dev_family;
4262306a36Sopenharmony_ci	enum be_interrupt_mode intr_mode;
4362306a36Sopenharmony_ci	struct {
4462306a36Sopenharmony_ci		int num_vectors;
4562306a36Sopenharmony_ci		int start_vector;
4662306a36Sopenharmony_ci		u32 vector_list[MAX_MSIX_VECTORS];
4762306a36Sopenharmony_ci	} msix;
4862306a36Sopenharmony_ci};
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci/* ocrdma driver register's the callback functions with nic driver. */
5162306a36Sopenharmony_cistruct ocrdma_driver {
5262306a36Sopenharmony_ci	unsigned char name[32];
5362306a36Sopenharmony_ci	u32 be_abi_version;
5462306a36Sopenharmony_ci	struct ocrdma_dev *(*add) (struct be_dev_info *dev_info);
5562306a36Sopenharmony_ci	void (*remove) (struct ocrdma_dev *);
5662306a36Sopenharmony_ci	void (*state_change_handler) (struct ocrdma_dev *, u32 new_state);
5762306a36Sopenharmony_ci};
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_cienum be_roce_event {
6062306a36Sopenharmony_ci	BE_DEV_SHUTDOWN = 2
6162306a36Sopenharmony_ci};
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci/* APIs for RoCE driver to register callback handlers,
6462306a36Sopenharmony_ci * which will be invoked when device is added, removed, ifup, ifdown
6562306a36Sopenharmony_ci */
6662306a36Sopenharmony_ciint be_roce_register_driver(struct ocrdma_driver *drv);
6762306a36Sopenharmony_civoid be_roce_unregister_driver(struct ocrdma_driver *drv);
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ci/* API for RoCE driver to issue mailbox commands */
7062306a36Sopenharmony_ciint be_roce_mcc_cmd(void *netdev_handle, void *wrb_payload,
7162306a36Sopenharmony_ci		    int wrb_payload_size, u16 *cmd_status, u16 *ext_status);
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci#endif /* BE_ROCE_H */
74