hc
2023-12-06 08f87f769b595151be1afeff53e144f543faa614
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Copyright (C) 2005 - 2016 Broadcom
 * All rights reserved.
 *
 * Contact Information:
 * linux-drivers@emulex.com
 *
 * Emulex
 * 3333 Susan Street
 * Costa Mesa, CA 92626
 */
 
#ifndef BE_ROCE_H
#define BE_ROCE_H
 
#include <linux/pci.h>
#include <linux/netdevice.h>
 
#define BE_ROCE_ABI_VERSION    1
 
struct ocrdma_dev;
 
enum be_interrupt_mode {
   BE_INTERRUPT_MODE_MSIX    = 0,
   BE_INTERRUPT_MODE_INTX    = 1,
   BE_INTERRUPT_MODE_MSI    = 2,
};
 
#define MAX_MSIX_VECTORS        32
struct be_dev_info {
   u8 __iomem *db;
   u64 unmapped_db;
   u32 db_page_size;
   u32 db_total_size;
   u64 dpp_unmapped_addr;
   u32 dpp_unmapped_len;
   struct pci_dev *pdev;
   struct net_device *netdev;
   u8 mac_addr[ETH_ALEN];
   u32 dev_family;
   enum be_interrupt_mode intr_mode;
   struct {
       int num_vectors;
       int start_vector;
       u32 vector_list[MAX_MSIX_VECTORS];
   } msix;
};
 
/* ocrdma driver register's the callback functions with nic driver. */
struct ocrdma_driver {
   unsigned char name[32];
   u32 be_abi_version;
   struct ocrdma_dev *(*add) (struct be_dev_info *dev_info);
   void (*remove) (struct ocrdma_dev *);
   void (*state_change_handler) (struct ocrdma_dev *, u32 new_state);
};
 
enum be_roce_event {
   BE_DEV_SHUTDOWN = 2
};
 
/* APIs for RoCE driver to register callback handlers,
 * which will be invoked when device is added, removed, ifup, ifdown
 */
int be_roce_register_driver(struct ocrdma_driver *drv);
void be_roce_unregister_driver(struct ocrdma_driver *drv);
 
/* API for RoCE driver to issue mailbox commands */
int be_roce_mcc_cmd(void *netdev_handle, void *wrb_payload,
           int wrb_payload_size, u16 *cmd_status, u16 *ext_status);
 
#endif /* BE_ROCE_H */