/* SPDX-License-Identifier: GPL-2.0-only */ /* * Huawei HiNIC PCI Express Linux driver * Copyright(c) 2017 Huawei Technologies Co., Ltd */ #ifndef HINIC_DEV_H #define HINIC_DEV_H #include #include #include #include #include #include "hinic_hw_dev.h" #include "hinic_tx.h" #include "hinic_rx.h" #define HINIC_DRV_NAME "hinic" enum hinic_flags { HINIC_LINK_UP = BIT(0), HINIC_INTF_UP = BIT(1), HINIC_RSS_ENABLE = BIT(2), }; struct hinic_rx_mode_work { struct work_struct work; u32 rx_mode; }; struct hinic_rss_type { u8 tcp_ipv6_ext; u8 ipv6_ext; u8 tcp_ipv6; u8 ipv6; u8 tcp_ipv4; u8 ipv4; u8 udp_ipv6; u8 udp_ipv4; }; enum hinic_rss_hash_type { HINIC_RSS_HASH_ENGINE_TYPE_XOR, HINIC_RSS_HASH_ENGINE_TYPE_TOEP, HINIC_RSS_HASH_ENGINE_TYPE_MAX, }; struct hinic_dev { struct net_device *netdev; struct hinic_hwdev *hwdev; u32 msg_enable; unsigned int tx_weight; unsigned int rx_weight; u16 num_qps; u16 max_qps; unsigned int flags; struct semaphore mgmt_lock; unsigned long *vlan_bitmap; struct hinic_rx_mode_work rx_mode_work; struct workqueue_struct *workq; struct hinic_txq *txqs; struct hinic_rxq *rxqs; struct hinic_txq_stats tx_stats; struct hinic_rxq_stats rx_stats; u8 rss_tmpl_idx; u8 rss_hash_engine; u16 num_rss; u16 rss_limit; struct hinic_rss_type rss_type; u8 *rss_hkey_user; s32 *rss_indir_user; }; #endif