1
0
mirror of https://github.com/corundum/corundum.git synced 2025-01-16 08:12:53 +08:00

604 lines
16 KiB
C
Raw Normal View History

/* SPDX-License-Identifier: BSD-2-Clause-Views */
2019-07-17 18:13:51 -07:00
/*
* Copyright 2019-2021, The Regents of the University of California.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* The views and conclusions contained in the software and documentation
* are those of the authors and should not be interpreted as representing
* official policies, either expressed or implied, of The Regents of the
* University of California.
*/
2019-07-17 18:13:51 -07:00
#ifndef MQNIC_H
#define MQNIC_H
#include <linux/kernel.h>
#ifdef CONFIG_PCI
2019-07-17 18:13:51 -07:00
#include <linux/pci.h>
#endif
#ifdef CONFIG_AUXILIARY_BUS
#include <linux/auxiliary_bus.h>
#endif
#include <linux/platform_device.h>
2019-07-17 18:13:51 -07:00
#include <linux/miscdevice.h>
#include <linux/netdevice.h>
#include <linux/etherdevice.h>
#include <linux/net_tstamp.h>
#include <linux/ptp_clock_kernel.h>
#include <linux/i2c.h>
#include <linux/i2c-algo-bit.h>
#define DRIVER_NAME "mqnic"
#define DRIVER_VERSION "0.1"
#include "mqnic_hw.h"
extern unsigned int mqnic_num_ev_queue_entries;
extern unsigned int mqnic_num_tx_queue_entries;
extern unsigned int mqnic_num_rx_queue_entries;
struct mqnic_dev;
2021-12-12 17:28:43 -08:00
struct mqnic_if;
2021-12-29 22:31:46 -08:00
struct reg_block {
2022-03-26 00:18:07 -07:00
u32 type;
u32 version;
u8 __iomem *regs;
u8 __iomem *base;
2021-12-29 22:31:46 -08:00
};
struct mqnic_board_ops {
2021-10-08 18:31:53 -07:00
int (*init)(struct mqnic_dev *mqnic);
void (*deinit)(struct mqnic_dev *mqnic);
};
2021-10-08 18:31:53 -07:00
struct mqnic_i2c_bus {
struct mqnic_dev *mqnic;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
u8 __iomem *scl_in_reg;
u8 __iomem *scl_out_reg;
u8 __iomem *sda_in_reg;
u8 __iomem *sda_out_reg;
2019-07-17 18:13:51 -07:00
2021-10-21 22:19:01 -07:00
u32 scl_in_mask;
u32 scl_out_mask;
u32 sda_in_mask;
u32 sda_out_mask;
2021-10-08 18:31:53 -07:00
struct list_head head;
2021-10-08 18:31:53 -07:00
struct i2c_algo_bit_data algo;
struct i2c_adapter adapter;
2019-07-17 18:13:51 -07:00
};
2021-12-12 13:34:33 -08:00
struct mqnic_irq {
int index;
int irqn;
char name[16 + 3];
2021-12-12 13:34:33 -08:00
struct atomic_notifier_head nh;
};
#ifdef CONFIG_AUXILIARY_BUS
struct mqnic_adev {
struct auxiliary_device adev;
struct mqnic_dev *mdev;
struct mqnic_adev **ptr;
char name[32];
};
#endif
2019-07-17 18:13:51 -07:00
struct mqnic_dev {
2021-10-08 18:31:53 -07:00
struct device *dev;
#ifdef CONFIG_PCI
2021-10-08 18:31:53 -07:00
struct pci_dev *pdev;
#endif
struct platform_device *pfdev;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
resource_size_t hw_regs_size;
phys_addr_t hw_regs_phys;
u8 __iomem *hw_addr;
u8 __iomem *phc_hw_addr;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
resource_size_t app_hw_regs_size;
phys_addr_t app_hw_regs_phys;
u8 __iomem *app_hw_addr;
2021-09-09 17:50:44 -07:00
2021-10-08 18:31:53 -07:00
resource_size_t ram_hw_regs_size;
phys_addr_t ram_hw_regs_phys;
u8 __iomem *ram_hw_addr;
2021-09-09 17:50:44 -07:00
2021-10-08 18:31:53 -07:00
struct mutex state_lock;
2019-11-18 16:17:27 -08:00
2021-10-08 18:31:53 -07:00
int mac_count;
u8 mac_list[MQNIC_MAX_IF][ETH_ALEN];
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
char name[16];
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
int irq_count;
2021-12-12 13:34:33 -08:00
struct mqnic_irq *irq[MQNIC_MAX_IRQ];
2019-09-13 13:53:36 -07:00
2021-10-08 18:31:53 -07:00
unsigned int id;
struct list_head dev_list_node;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
struct miscdevice misc_dev;
2019-07-17 18:13:51 -07:00
#ifdef CONFIG_AUXILIARY_BUS
struct mqnic_adev *app_adev;
#endif
2021-12-29 22:31:46 -08:00
struct reg_block *rb_list;
struct reg_block *fw_id_rb;
struct reg_block *if_rb;
struct reg_block *phc_rb;
2021-12-29 14:29:55 -08:00
int dev_port_max;
int dev_port_limit;
2021-12-29 22:31:46 -08:00
u32 fpga_id;
2021-10-08 18:31:53 -07:00
u32 fw_id;
u32 fw_ver;
u32 board_id;
u32 board_ver;
2021-12-29 22:31:46 -08:00
u32 build_date;
u32 git_hash;
u32 rel_info;
2019-07-17 18:13:51 -07:00
u32 app_id;
2021-12-29 22:31:46 -08:00
u32 if_offset;
2021-10-08 18:31:53 -07:00
u32 if_count;
u32 if_stride;
u32 if_csr_offset;
2019-07-17 18:13:51 -07:00
2021-12-12 17:28:43 -08:00
struct mqnic_if *interface[MQNIC_MAX_IF];
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
struct ptp_clock *ptp_clock;
struct ptp_clock_info ptp_clock_info;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
struct mqnic_board_ops *board_ops;
2021-10-08 18:31:53 -07:00
struct list_head i2c_bus;
int i2c_adapter_count;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
int mod_i2c_client_count;
struct i2c_client *mod_i2c_client[MQNIC_MAX_IF];
struct i2c_client *eeprom_i2c_client;
2019-07-17 18:13:51 -07:00
};
2020-04-21 17:18:58 -07:00
struct mqnic_frag {
2021-10-08 18:31:53 -07:00
dma_addr_t dma_addr;
u32 len;
2020-04-21 17:18:58 -07:00
};
2019-07-17 18:13:51 -07:00
struct mqnic_tx_info {
2021-10-08 18:31:53 -07:00
struct sk_buff *skb;
DEFINE_DMA_UNMAP_ADDR(dma_addr);
DEFINE_DMA_UNMAP_LEN(len);
u32 frag_count;
struct mqnic_frag frags[MQNIC_MAX_FRAGS - 1];
int ts_requested;
2019-07-17 18:13:51 -07:00
};
struct mqnic_rx_info {
2021-10-08 18:31:53 -07:00
struct page *page;
u32 page_order;
u32 page_offset;
dma_addr_t dma_addr;
u32 len;
2019-07-17 18:13:51 -07:00
};
struct mqnic_ring {
2021-10-08 18:31:53 -07:00
// written on enqueue (i.e. start_xmit)
u32 head_ptr;
u64 bytes;
u64 packets;
u64 dropped_packets;
struct netdev_queue *tx_queue;
// written from completion
u32 tail_ptr ____cacheline_aligned_in_smp;
u32 clean_tail_ptr;
u64 ts_s;
u8 ts_valid;
// mostly constant
u32 size;
u32 full_size;
u32 size_mask;
u32 stride;
u32 cpl_index;
u32 mtu;
u32 page_order;
u32 desc_block_size;
u32 log_desc_block_size;
size_t buf_size;
u8 *buf;
dma_addr_t buf_dma_addr;
union {
struct mqnic_tx_info *tx_info;
struct mqnic_rx_info *rx_info;
};
2021-12-10 20:59:44 -08:00
struct device *dev;
2021-12-12 17:28:43 -08:00
struct mqnic_if *interface;
2021-12-10 20:59:44 -08:00
struct mqnic_priv *priv;
2021-12-12 13:46:09 -08:00
int index;
2021-12-12 14:20:56 -08:00
struct mqnic_cq_ring *cq_ring;
2021-12-10 21:04:52 -08:00
int active;
2021-12-10 20:59:44 -08:00
2021-10-08 18:31:53 -07:00
u32 hw_ptr_mask;
u8 __iomem *hw_addr;
u8 __iomem *hw_head_ptr;
u8 __iomem *hw_tail_ptr;
2019-07-17 18:13:51 -07:00
} ____cacheline_aligned_in_smp;
struct mqnic_cq_ring {
2021-10-08 18:31:53 -07:00
u32 head_ptr;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
u32 tail_ptr;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
u32 size;
u32 size_mask;
u32 stride;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
size_t buf_size;
u8 *buf;
dma_addr_t buf_dma_addr;
2019-07-17 18:13:51 -07:00
2021-12-12 01:53:38 -08:00
struct device *dev;
2021-12-12 17:28:43 -08:00
struct mqnic_if *interface;
2021-10-08 18:31:53 -07:00
struct napi_struct napi;
2021-12-12 13:46:09 -08:00
int index;
2021-12-12 13:58:26 -08:00
struct mqnic_eq_ring *eq_ring;
2021-12-12 14:20:56 -08:00
struct mqnic_ring *src_ring;
2021-10-08 18:31:53 -07:00
int eq_index;
2021-12-10 21:04:52 -08:00
int active;
2019-07-17 18:13:51 -07:00
void (*handler)(struct mqnic_cq_ring *ring);
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
u32 hw_ptr_mask;
u8 __iomem *hw_addr;
u8 __iomem *hw_head_ptr;
u8 __iomem *hw_tail_ptr;
2019-07-17 18:13:51 -07:00
};
struct mqnic_eq_ring {
2021-10-08 18:31:53 -07:00
u32 head_ptr;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
u32 tail_ptr;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
u32 size;
u32 size_mask;
u32 stride;
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
size_t buf_size;
u8 *buf;
dma_addr_t buf_dma_addr;
2019-07-17 18:13:51 -07:00
2021-12-12 01:53:38 -08:00
struct device *dev;
2021-12-12 17:28:43 -08:00
struct mqnic_if *interface;
2021-12-12 13:46:09 -08:00
int index;
2021-12-12 13:34:33 -08:00
struct mqnic_irq *irq;
int irq_index;
2021-12-10 21:04:52 -08:00
int active;
2019-07-17 18:13:51 -07:00
struct notifier_block irq_nb;
2019-09-13 13:53:36 -07:00
void (*handler)(struct mqnic_eq_ring *ring);
2019-07-17 18:13:51 -07:00
2021-10-08 18:31:53 -07:00
u32 hw_ptr_mask;
u8 __iomem *hw_addr;
u8 __iomem *hw_head_ptr;
u8 __iomem *hw_tail_ptr;
2019-07-17 18:13:51 -07:00
};
2021-12-29 22:31:46 -08:00
struct mqnic_sched {
struct device *dev;
struct mqnic_if *interface;
struct mqnic_sched_block *sched_block;
2021-12-29 22:31:46 -08:00
struct reg_block *rb;
int index;
u32 type;
u32 offset;
u32 channel_count;
u32 channel_stride;
u8 __iomem *hw_addr;
};
struct mqnic_sched_block {
2021-10-08 18:31:53 -07:00
struct device *dev;
2021-12-12 17:28:43 -08:00
struct mqnic_if *interface;
2019-08-19 15:59:57 -07:00
2021-12-29 22:31:46 -08:00
struct reg_block *block_rb;
struct reg_block *rb_list;
2021-10-08 18:31:53 -07:00
int index;
2019-08-19 15:59:57 -07:00
2021-10-08 18:31:53 -07:00
u32 tx_queue_count;
2021-10-08 18:31:53 -07:00
u32 sched_count;
2021-12-29 22:31:46 -08:00
struct mqnic_sched *sched[MQNIC_MAX_PORTS];
2019-08-19 15:59:57 -07:00
};
2021-12-12 17:28:43 -08:00
struct mqnic_if {
2021-10-08 18:31:53 -07:00
struct device *dev;
struct mqnic_dev *mdev;
2021-12-29 22:31:46 -08:00
struct reg_block *rb_list;
2022-01-15 21:53:13 -08:00
struct reg_block *if_ctrl_rb;
2021-12-29 22:31:46 -08:00
struct reg_block *event_queue_rb;
struct reg_block *tx_queue_rb;
struct reg_block *tx_cpl_queue_rb;
struct reg_block *rx_queue_rb;
struct reg_block *rx_cpl_queue_rb;
struct reg_block *rx_queue_map_rb;
2021-12-29 22:31:46 -08:00
int index;
2021-10-08 18:31:53 -07:00
2021-12-29 14:29:55 -08:00
int dev_port_base;
int dev_port_max;
int dev_port_limit;
2022-01-15 21:53:13 -08:00
u32 if_features;
2021-12-29 22:31:46 -08:00
u32 max_tx_mtu;
u32 max_rx_mtu;
2021-12-12 17:28:43 -08:00
2021-10-08 18:31:53 -07:00
u32 event_queue_offset;
2021-12-29 22:31:46 -08:00
u32 event_queue_count;
u32 event_queue_stride;
2021-12-12 17:28:43 -08:00
struct mqnic_eq_ring *event_ring[MQNIC_MAX_EVENT_RINGS];
2021-10-08 18:31:53 -07:00
u32 tx_queue_offset;
2021-12-29 22:31:46 -08:00
u32 tx_queue_count;
u32 tx_queue_stride;
2021-12-12 17:28:43 -08:00
struct mqnic_ring *tx_ring[MQNIC_MAX_TX_RINGS];
2021-10-08 18:31:53 -07:00
u32 tx_cpl_queue_offset;
2021-12-29 22:31:46 -08:00
u32 tx_cpl_queue_count;
u32 tx_cpl_queue_stride;
2021-12-12 17:28:43 -08:00
struct mqnic_cq_ring *tx_cpl_ring[MQNIC_MAX_TX_CPL_RINGS];
2021-10-08 18:31:53 -07:00
u32 rx_queue_offset;
2021-12-29 22:31:46 -08:00
u32 rx_queue_count;
u32 rx_queue_stride;
2021-12-12 17:28:43 -08:00
struct mqnic_ring *rx_ring[MQNIC_MAX_RX_RINGS];
2021-10-08 18:31:53 -07:00
u32 rx_cpl_queue_offset;
2021-12-29 22:31:46 -08:00
u32 rx_cpl_queue_count;
u32 rx_cpl_queue_stride;
2021-12-12 17:28:43 -08:00
struct mqnic_cq_ring *rx_cpl_ring[MQNIC_MAX_RX_CPL_RINGS];
2021-10-08 18:31:53 -07:00
u32 port_count;
u32 sched_block_count;
struct mqnic_sched_block *sched_block[MQNIC_MAX_PORTS];
2021-10-08 18:31:53 -07:00
u32 max_desc_block_size;
2021-12-29 22:31:46 -08:00
resource_size_t hw_regs_size;
2021-10-08 18:31:53 -07:00
u8 __iomem *hw_addr;
u8 __iomem *csr_hw_addr;
2021-12-12 17:28:43 -08:00
u32 ndev_count;
struct net_device *ndev[MQNIC_MAX_PORTS];
struct i2c_client *mod_i2c_client;
};
struct mqnic_priv {
struct device *dev;
struct net_device *ndev;
struct mqnic_dev *mdev;
struct mqnic_if *interface;
spinlock_t stats_lock;
int index;
bool registered;
bool port_up;
2022-01-15 21:53:13 -08:00
u32 if_features;
2021-12-12 17:28:43 -08:00
u32 event_queue_count;
2021-10-08 18:31:53 -07:00
struct mqnic_eq_ring *event_ring[MQNIC_MAX_EVENT_RINGS];
2021-12-12 17:28:43 -08:00
u32 tx_queue_count;
2021-10-08 18:31:53 -07:00
struct mqnic_ring *tx_ring[MQNIC_MAX_TX_RINGS];
2021-12-12 17:28:43 -08:00
u32 tx_cpl_queue_count;
2021-10-08 18:31:53 -07:00
struct mqnic_cq_ring *tx_cpl_ring[MQNIC_MAX_TX_CPL_RINGS];
2021-12-12 17:28:43 -08:00
u32 rx_queue_count;
2021-10-08 18:31:53 -07:00
struct mqnic_ring *rx_ring[MQNIC_MAX_RX_RINGS];
2021-12-12 17:28:43 -08:00
u32 rx_cpl_queue_count;
2021-10-08 18:31:53 -07:00
struct mqnic_cq_ring *rx_cpl_ring[MQNIC_MAX_RX_CPL_RINGS];
2021-12-12 17:28:43 -08:00
u32 sched_block_count;
struct mqnic_sched_block *sched_block[MQNIC_MAX_PORTS];
2021-10-08 18:31:53 -07:00
2021-12-12 17:28:43 -08:00
u32 max_desc_block_size;
2021-10-08 18:31:53 -07:00
struct hwtstamp_config hwts_config;
struct i2c_client *mod_i2c_client;
2019-07-17 18:13:51 -07:00
};
// mqnic_main.c
2021-12-29 22:31:46 -08:00
// mqnic_reg_block.c
struct reg_block *enumerate_reg_block_list(u8 __iomem *base, size_t offset, size_t size);
struct reg_block *find_reg_block(struct reg_block *list, u32 type, u32 version, int index);
void free_reg_block_list(struct reg_block *list);
2021-12-12 13:34:33 -08:00
// mqnic_irq.c
int mqnic_irq_init_pcie(struct mqnic_dev *mdev);
void mqnic_irq_deinit_pcie(struct mqnic_dev *mdev);
int mqnic_irq_init_platform(struct mqnic_dev *mdev);
2021-12-12 13:34:33 -08:00
2019-07-17 18:13:51 -07:00
// mqnic_dev.c
extern const struct file_operations mqnic_fops;
2021-12-12 17:28:43 -08:00
// mqnic_if.c
int mqnic_create_interface(struct mqnic_dev *mdev, struct mqnic_if **interface_ptr,
int index, u8 __iomem *hw_addr);
void mqnic_destroy_interface(struct mqnic_if **interface_ptr);
2021-12-29 22:31:46 -08:00
u32 mqnic_interface_get_tx_mtu(struct mqnic_if *interface);
void mqnic_interface_set_tx_mtu(struct mqnic_if *interface, u32 mtu);
u32 mqnic_interface_get_rx_mtu(struct mqnic_if *interface);
void mqnic_interface_set_rx_mtu(struct mqnic_if *interface, u32 mtu);
u32 mqnic_interface_get_rx_queue_map_offset(struct mqnic_if *interface, int port);
void mqnic_interface_set_rx_queue_map_offset(struct mqnic_if *interface, int port, u32 val);
u32 mqnic_interface_get_rx_queue_map_rss_mask(struct mqnic_if *interface, int port);
void mqnic_interface_set_rx_queue_map_rss_mask(struct mqnic_if *interface, int port, u32 val);
u32 mqnic_interface_get_rx_queue_map_app_mask(struct mqnic_if *interface, int port);
void mqnic_interface_set_rx_queue_map_app_mask(struct mqnic_if *interface, int port, u32 val);
2021-12-12 17:28:43 -08:00
2019-07-17 18:13:51 -07:00
// mqnic_netdev.c
void mqnic_update_stats(struct net_device *ndev);
2021-12-29 14:29:55 -08:00
int mqnic_create_netdev(struct mqnic_if *interface, struct net_device **ndev_ptr,
int index, int dev_port);
2021-12-10 21:02:57 -08:00
void mqnic_destroy_netdev(struct net_device **ndev_ptr);
2019-07-17 18:13:51 -07:00
// mqnic_sched_block.c
int mqnic_create_sched_block(struct mqnic_if *interface, struct mqnic_sched_block **block_ptr,
2021-12-29 22:31:46 -08:00
int index, struct reg_block *rb);
void mqnic_destroy_sched_block(struct mqnic_sched_block **block_ptr);
int mqnic_activate_sched_block(struct mqnic_sched_block *block);
void mqnic_deactivate_sched_block(struct mqnic_sched_block *block);
2021-12-29 22:31:46 -08:00
// mqnic_scheduler.c
int mqnic_create_scheduler(struct mqnic_sched_block *block, struct mqnic_sched **sched_ptr,
2021-12-29 22:31:46 -08:00
int index, struct reg_block *rb);
void mqnic_destroy_scheduler(struct mqnic_sched **sched_ptr);
int mqnic_scheduler_enable(struct mqnic_sched *sched);
void mqnic_scheduler_disable(struct mqnic_sched *sched);
2019-08-19 15:59:57 -07:00
2019-07-17 18:13:51 -07:00
// mqnic_ptp.c
void mqnic_register_phc(struct mqnic_dev *mdev);
void mqnic_unregister_phc(struct mqnic_dev *mdev);
2021-10-08 18:31:53 -07:00
ktime_t mqnic_read_cpl_ts(struct mqnic_dev *mdev, struct mqnic_ring *ring,
const struct mqnic_cpl *cpl);
2019-07-17 18:13:51 -07:00
// mqnic_i2c.c
2021-12-29 22:31:46 -08:00
struct mqnic_i2c_bus *mqnic_i2c_bus_create(struct mqnic_dev *mqnic, int index);
struct i2c_adapter *mqnic_i2c_adapter_create(struct mqnic_dev *mqnic, int index);
void mqnic_i2c_bus_release(struct mqnic_i2c_bus *bus);
void mqnic_i2c_adapter_release(struct i2c_adapter *adapter);
int mqnic_i2c_init(struct mqnic_dev *mqnic);
void mqnic_i2c_deinit(struct mqnic_dev *mqnic);
// mqnic_board.c
int mqnic_board_init(struct mqnic_dev *mqnic);
void mqnic_board_deinit(struct mqnic_dev *mqnic);
2019-07-17 18:13:51 -07:00
// mqnic_eq.c
2021-12-12 17:28:43 -08:00
int mqnic_create_eq_ring(struct mqnic_if *interface, struct mqnic_eq_ring **ring_ptr,
int index, u8 __iomem *hw_addr);
2021-12-10 20:59:44 -08:00
void mqnic_destroy_eq_ring(struct mqnic_eq_ring **ring_ptr);
int mqnic_alloc_eq_ring(struct mqnic_eq_ring *ring, int size, int stride);
void mqnic_free_eq_ring(struct mqnic_eq_ring *ring);
2021-12-12 13:34:33 -08:00
int mqnic_activate_eq_ring(struct mqnic_eq_ring *ring, struct mqnic_irq *irq);
2021-12-10 20:59:44 -08:00
void mqnic_deactivate_eq_ring(struct mqnic_eq_ring *ring);
2019-07-17 18:13:51 -07:00
bool mqnic_is_eq_ring_empty(const struct mqnic_eq_ring *ring);
bool mqnic_is_eq_ring_full(const struct mqnic_eq_ring *ring);
void mqnic_eq_read_head_ptr(struct mqnic_eq_ring *ring);
void mqnic_eq_write_tail_ptr(struct mqnic_eq_ring *ring);
void mqnic_arm_eq(struct mqnic_eq_ring *ring);
2021-12-10 20:59:44 -08:00
void mqnic_process_eq(struct mqnic_eq_ring *eq_ring);
2019-07-17 18:13:51 -07:00
// mqnic_cq.c
2021-12-12 17:28:43 -08:00
int mqnic_create_cq_ring(struct mqnic_if *interface, struct mqnic_cq_ring **ring_ptr,
int index, u8 __iomem *hw_addr);
2021-12-10 20:59:44 -08:00
void mqnic_destroy_cq_ring(struct mqnic_cq_ring **ring_ptr);
int mqnic_alloc_cq_ring(struct mqnic_cq_ring *ring, int size, int stride);
void mqnic_free_cq_ring(struct mqnic_cq_ring *ring);
2021-12-12 13:58:26 -08:00
int mqnic_activate_cq_ring(struct mqnic_cq_ring *ring, struct mqnic_eq_ring *eq_ring);
2021-12-10 20:59:44 -08:00
void mqnic_deactivate_cq_ring(struct mqnic_cq_ring *ring);
2019-07-17 18:13:51 -07:00
bool mqnic_is_cq_ring_empty(const struct mqnic_cq_ring *ring);
bool mqnic_is_cq_ring_full(const struct mqnic_cq_ring *ring);
void mqnic_cq_read_head_ptr(struct mqnic_cq_ring *ring);
void mqnic_cq_write_tail_ptr(struct mqnic_cq_ring *ring);
void mqnic_arm_cq(struct mqnic_cq_ring *ring);
// mqnic_tx.c
2021-12-12 17:28:43 -08:00
int mqnic_create_tx_ring(struct mqnic_if *interface, struct mqnic_ring **ring_ptr,
int index, u8 __iomem *hw_addr);
2021-12-10 20:59:44 -08:00
void mqnic_destroy_tx_ring(struct mqnic_ring **ring_ptr);
int mqnic_alloc_tx_ring(struct mqnic_ring *ring, int size, int stride);
void mqnic_free_tx_ring(struct mqnic_ring *ring);
2021-12-12 17:28:43 -08:00
int mqnic_activate_tx_ring(struct mqnic_ring *ring, struct mqnic_priv *priv,
struct mqnic_cq_ring *cq_ring);
2021-12-10 20:59:44 -08:00
void mqnic_deactivate_tx_ring(struct mqnic_ring *ring);
2019-07-17 18:13:51 -07:00
bool mqnic_is_tx_ring_empty(const struct mqnic_ring *ring);
bool mqnic_is_tx_ring_full(const struct mqnic_ring *ring);
void mqnic_tx_read_tail_ptr(struct mqnic_ring *ring);
void mqnic_tx_write_head_ptr(struct mqnic_ring *ring);
2021-12-10 20:59:44 -08:00
void mqnic_free_tx_desc(struct mqnic_ring *ring, int index, int napi_budget);
int mqnic_free_tx_buf(struct mqnic_ring *ring);
int mqnic_process_tx_cq(struct mqnic_cq_ring *cq_ring, int napi_budget);
2019-07-17 18:13:51 -07:00
void mqnic_tx_irq(struct mqnic_cq_ring *cq);
int mqnic_poll_tx_cq(struct napi_struct *napi, int budget);
netdev_tx_t mqnic_start_xmit(struct sk_buff *skb, struct net_device *dev);
// mqnic_rx.c
2021-12-12 17:28:43 -08:00
int mqnic_create_rx_ring(struct mqnic_if *interface, struct mqnic_ring **ring_ptr,
int index, u8 __iomem *hw_addr);
2021-12-10 20:59:44 -08:00
void mqnic_destroy_rx_ring(struct mqnic_ring **ring_ptr);
int mqnic_alloc_rx_ring(struct mqnic_ring *ring, int size, int stride);
void mqnic_free_rx_ring(struct mqnic_ring *ring);
2021-12-12 17:28:43 -08:00
int mqnic_activate_rx_ring(struct mqnic_ring *ring, struct mqnic_priv *priv,
struct mqnic_cq_ring *cq_ring);
2021-12-10 20:59:44 -08:00
void mqnic_deactivate_rx_ring(struct mqnic_ring *ring);
2019-07-17 18:13:51 -07:00
bool mqnic_is_rx_ring_empty(const struct mqnic_ring *ring);
bool mqnic_is_rx_ring_full(const struct mqnic_ring *ring);
void mqnic_rx_read_tail_ptr(struct mqnic_ring *ring);
void mqnic_rx_write_head_ptr(struct mqnic_ring *ring);
2021-12-10 20:59:44 -08:00
void mqnic_free_rx_desc(struct mqnic_ring *ring, int index);
int mqnic_free_rx_buf(struct mqnic_ring *ring);
int mqnic_prepare_rx_desc(struct mqnic_ring *ring, int index);
void mqnic_refill_rx_buffers(struct mqnic_ring *ring);
int mqnic_process_rx_cq(struct mqnic_cq_ring *cq_ring, int napi_budget);
2019-07-17 18:13:51 -07:00
void mqnic_rx_irq(struct mqnic_cq_ring *cq);
int mqnic_poll_rx_cq(struct napi_struct *napi, int budget);
// mqnic_ethtool.c
extern const struct ethtool_ops mqnic_ethtool_ops;
#endif /* MQNIC_H */