1 /* SPDX-License-Identifier: GPL-2.0-only */
3 * Huawei HiNIC PCI Express Linux driver
4 * Copyright(c) 2017 Huawei Technologies Co., Ltd
10 #include <linux/netdevice.h>
11 #include <linux/types.h>
12 #include <linux/semaphore.h>
13 #include <linux/workqueue.h>
14 #include <linux/bitops.h>
16 #include "hinic_hw_dev.h"
19 #include "hinic_sriov.h"
21 #define HINIC_DRV_NAME "hinic"
26 HINIC_LINK_UP = BIT(0),
27 HINIC_INTF_UP = BIT(1),
28 HINIC_RSS_ENABLE = BIT(2),
29 HINIC_LINK_DOWN = BIT(3),
30 HINIC_LP_TEST = BIT(4),
33 struct hinic_rx_mode_work {
34 struct work_struct work;
38 struct hinic_rss_type {
49 enum hinic_rss_hash_type {
50 HINIC_RSS_HASH_ENGINE_TYPE_XOR,
51 HINIC_RSS_HASH_ENGINE_TYPE_TOEP,
52 HINIC_RSS_HASH_ENGINE_TYPE_MAX,
55 struct hinic_intr_coal_info {
57 u8 coalesce_timer_cfg;
62 struct net_device *netdev;
63 struct hinic_hwdev *hwdev;
66 unsigned int tx_weight;
67 unsigned int rx_weight;
73 struct semaphore mgmt_lock;
74 unsigned long *vlan_bitmap;
76 struct hinic_rx_mode_work rx_mode_work;
77 struct workqueue_struct *workq;
79 struct hinic_txq *txqs;
80 struct hinic_rxq *rxqs;
84 struct hinic_txq_stats tx_stats;
85 struct hinic_rxq_stats rx_stats;
91 struct hinic_rss_type rss_type;
94 struct hinic_intr_coal_info *rx_intr_coalesce;
95 struct hinic_intr_coal_info *tx_intr_coalesce;
96 struct hinic_sriov_info sriov_info;
100 struct devlink *devlink;
101 bool cable_unplugged;
102 bool module_unrecognized;
105 struct hinic_devlink_priv {
106 struct hinic_hwdev *hwdev;
107 struct devlink_health_reporter *hw_fault_reporter;
108 struct devlink_health_reporter *fw_fault_reporter;