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