18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * Copyright (C) 2005 - 2016 Broadcom
48c2ecf20Sopenharmony_ci * All rights reserved.
58c2ecf20Sopenharmony_ci *
68c2ecf20Sopenharmony_ci * Contact Information:
78c2ecf20Sopenharmony_ci * linux-drivers@emulex.com
88c2ecf20Sopenharmony_ci *
98c2ecf20Sopenharmony_ci * Emulex
108c2ecf20Sopenharmony_ci * 3333 Susan Street
118c2ecf20Sopenharmony_ci * Costa Mesa, CA 92626
128c2ecf20Sopenharmony_ci */
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_ci#ifndef BE_ROCE_H
158c2ecf20Sopenharmony_ci#define BE_ROCE_H
168c2ecf20Sopenharmony_ci
178c2ecf20Sopenharmony_ci#include <linux/pci.h>
188c2ecf20Sopenharmony_ci#include <linux/netdevice.h>
198c2ecf20Sopenharmony_ci
208c2ecf20Sopenharmony_ci#define BE_ROCE_ABI_VERSION	1
218c2ecf20Sopenharmony_ci
228c2ecf20Sopenharmony_cistruct ocrdma_dev;
238c2ecf20Sopenharmony_ci
248c2ecf20Sopenharmony_cienum be_interrupt_mode {
258c2ecf20Sopenharmony_ci	BE_INTERRUPT_MODE_MSIX	= 0,
268c2ecf20Sopenharmony_ci	BE_INTERRUPT_MODE_INTX	= 1,
278c2ecf20Sopenharmony_ci	BE_INTERRUPT_MODE_MSI	= 2,
288c2ecf20Sopenharmony_ci};
298c2ecf20Sopenharmony_ci
308c2ecf20Sopenharmony_ci#define MAX_MSIX_VECTORS		32
318c2ecf20Sopenharmony_cistruct be_dev_info {
328c2ecf20Sopenharmony_ci	u8 __iomem *db;
338c2ecf20Sopenharmony_ci	u64 unmapped_db;
348c2ecf20Sopenharmony_ci	u32 db_page_size;
358c2ecf20Sopenharmony_ci	u32 db_total_size;
368c2ecf20Sopenharmony_ci	u64 dpp_unmapped_addr;
378c2ecf20Sopenharmony_ci	u32 dpp_unmapped_len;
388c2ecf20Sopenharmony_ci	struct pci_dev *pdev;
398c2ecf20Sopenharmony_ci	struct net_device *netdev;
408c2ecf20Sopenharmony_ci	u8 mac_addr[ETH_ALEN];
418c2ecf20Sopenharmony_ci	u32 dev_family;
428c2ecf20Sopenharmony_ci	enum be_interrupt_mode intr_mode;
438c2ecf20Sopenharmony_ci	struct {
448c2ecf20Sopenharmony_ci		int num_vectors;
458c2ecf20Sopenharmony_ci		int start_vector;
468c2ecf20Sopenharmony_ci		u32 vector_list[MAX_MSIX_VECTORS];
478c2ecf20Sopenharmony_ci	} msix;
488c2ecf20Sopenharmony_ci};
498c2ecf20Sopenharmony_ci
508c2ecf20Sopenharmony_ci/* ocrdma driver register's the callback functions with nic driver. */
518c2ecf20Sopenharmony_cistruct ocrdma_driver {
528c2ecf20Sopenharmony_ci	unsigned char name[32];
538c2ecf20Sopenharmony_ci	u32 be_abi_version;
548c2ecf20Sopenharmony_ci	struct ocrdma_dev *(*add) (struct be_dev_info *dev_info);
558c2ecf20Sopenharmony_ci	void (*remove) (struct ocrdma_dev *);
568c2ecf20Sopenharmony_ci	void (*state_change_handler) (struct ocrdma_dev *, u32 new_state);
578c2ecf20Sopenharmony_ci};
588c2ecf20Sopenharmony_ci
598c2ecf20Sopenharmony_cienum be_roce_event {
608c2ecf20Sopenharmony_ci	BE_DEV_SHUTDOWN = 2
618c2ecf20Sopenharmony_ci};
628c2ecf20Sopenharmony_ci
638c2ecf20Sopenharmony_ci/* APIs for RoCE driver to register callback handlers,
648c2ecf20Sopenharmony_ci * which will be invoked when device is added, removed, ifup, ifdown
658c2ecf20Sopenharmony_ci */
668c2ecf20Sopenharmony_ciint be_roce_register_driver(struct ocrdma_driver *drv);
678c2ecf20Sopenharmony_civoid be_roce_unregister_driver(struct ocrdma_driver *drv);
688c2ecf20Sopenharmony_ci
698c2ecf20Sopenharmony_ci/* API for RoCE driver to issue mailbox commands */
708c2ecf20Sopenharmony_ciint be_roce_mcc_cmd(void *netdev_handle, void *wrb_payload,
718c2ecf20Sopenharmony_ci		    int wrb_payload_size, u16 *cmd_status, u16 *ext_status);
728c2ecf20Sopenharmony_ci
738c2ecf20Sopenharmony_ci#endif /* BE_ROCE_H */
74