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