178 lines
5.7 KiB
C
178 lines
5.7 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only OR BSD-3-Clause */
|
|
|
|
/* Header file for Gigabit Ethernet driver for Mellanox BlueField SoC
|
|
* - this file contains software data structures and any chip-specific
|
|
* data structures (e.g. TX WQE format) that are memory resident.
|
|
*
|
|
* Copyright (C) 2020-2021 NVIDIA CORPORATION & AFFILIATES
|
|
*/
|
|
|
|
#ifndef __MLXBF_GIGE_H__
|
|
#define __MLXBF_GIGE_H__
|
|
|
|
#include <linux/io-64-nonatomic-lo-hi.h>
|
|
#include <linux/irqreturn.h>
|
|
#include <linux/netdevice.h>
|
|
#include <linux/irq.h>
|
|
|
|
/* The silicon design supports a maximum RX ring size of
|
|
* 32K entries. Based on current testing this maximum size
|
|
* is not required to be supported. Instead the RX ring
|
|
* will be capped at a realistic value of 1024 entries.
|
|
*/
|
|
#define MLXBF_GIGE_MIN_RXQ_SZ 32
|
|
#define MLXBF_GIGE_MAX_RXQ_SZ 1024
|
|
#define MLXBF_GIGE_DEFAULT_RXQ_SZ 128
|
|
|
|
#define MLXBF_GIGE_MIN_TXQ_SZ 4
|
|
#define MLXBF_GIGE_MAX_TXQ_SZ 256
|
|
#define MLXBF_GIGE_DEFAULT_TXQ_SZ 128
|
|
|
|
#define MLXBF_GIGE_DEFAULT_BUF_SZ 2048
|
|
|
|
#define MLXBF_GIGE_DMA_PAGE_SZ 4096
|
|
#define MLXBF_GIGE_DMA_PAGE_SHIFT 12
|
|
|
|
/* There are four individual MAC RX filters. Currently
|
|
* two of them are being used: one for the broadcast MAC
|
|
* (index 0) and one for local MAC (index 1)
|
|
*/
|
|
#define MLXBF_GIGE_BCAST_MAC_FILTER_IDX 0
|
|
#define MLXBF_GIGE_LOCAL_MAC_FILTER_IDX 1
|
|
|
|
/* Define for broadcast MAC literal */
|
|
#define BCAST_MAC_ADDR 0xFFFFFFFFFFFF
|
|
|
|
/* There are three individual interrupts:
|
|
* 1) Errors, "OOB" interrupt line
|
|
* 2) Receive Packet, "OOB_LLU" interrupt line
|
|
* 3) LLU and PLU Events, "OOB_PLU" interrupt line
|
|
*/
|
|
#define MLXBF_GIGE_ERROR_INTR_IDX 0
|
|
#define MLXBF_GIGE_RECEIVE_PKT_INTR_IDX 1
|
|
#define MLXBF_GIGE_LLU_PLU_INTR_IDX 2
|
|
|
|
struct mlxbf_gige_stats {
|
|
u64 hw_access_errors;
|
|
u64 tx_invalid_checksums;
|
|
u64 tx_small_frames;
|
|
u64 tx_index_errors;
|
|
u64 sw_config_errors;
|
|
u64 sw_access_errors;
|
|
u64 rx_truncate_errors;
|
|
u64 rx_mac_errors;
|
|
u64 rx_din_dropped_pkts;
|
|
u64 tx_fifo_full;
|
|
u64 rx_filter_passed_pkts;
|
|
u64 rx_filter_discard_pkts;
|
|
};
|
|
|
|
struct mlxbf_gige {
|
|
void __iomem *base;
|
|
void __iomem *llu_base;
|
|
void __iomem *plu_base;
|
|
struct device *dev;
|
|
struct net_device *netdev;
|
|
struct platform_device *pdev;
|
|
void __iomem *mdio_io;
|
|
void __iomem *clk_io;
|
|
struct mii_bus *mdiobus;
|
|
spinlock_t lock; /* for packet processing indices */
|
|
u16 rx_q_entries;
|
|
u16 tx_q_entries;
|
|
u64 *tx_wqe_base;
|
|
dma_addr_t tx_wqe_base_dma;
|
|
u64 *tx_wqe_next;
|
|
u64 *tx_cc;
|
|
dma_addr_t tx_cc_dma;
|
|
dma_addr_t *rx_wqe_base;
|
|
dma_addr_t rx_wqe_base_dma;
|
|
u64 *rx_cqe_base;
|
|
dma_addr_t rx_cqe_base_dma;
|
|
u16 tx_pi;
|
|
u16 prev_tx_ci;
|
|
struct sk_buff *rx_skb[MLXBF_GIGE_MAX_RXQ_SZ];
|
|
struct sk_buff *tx_skb[MLXBF_GIGE_MAX_TXQ_SZ];
|
|
int error_irq;
|
|
int rx_irq;
|
|
int llu_plu_irq;
|
|
int phy_irq;
|
|
int hw_phy_irq;
|
|
bool promisc_enabled;
|
|
u8 valid_polarity;
|
|
struct napi_struct napi;
|
|
struct mlxbf_gige_stats stats;
|
|
};
|
|
|
|
/* Rx Work Queue Element definitions */
|
|
#define MLXBF_GIGE_RX_WQE_SZ 8
|
|
|
|
/* Rx Completion Queue Element definitions */
|
|
#define MLXBF_GIGE_RX_CQE_SZ 8
|
|
#define MLXBF_GIGE_RX_CQE_PKT_LEN_MASK GENMASK(10, 0)
|
|
#define MLXBF_GIGE_RX_CQE_VALID_MASK GENMASK(11, 11)
|
|
#define MLXBF_GIGE_RX_CQE_PKT_STATUS_MASK GENMASK(15, 12)
|
|
#define MLXBF_GIGE_RX_CQE_PKT_STATUS_MAC_ERR GENMASK(12, 12)
|
|
#define MLXBF_GIGE_RX_CQE_PKT_STATUS_TRUNCATED GENMASK(13, 13)
|
|
#define MLXBF_GIGE_RX_CQE_CHKSUM_MASK GENMASK(31, 16)
|
|
|
|
/* Tx Work Queue Element definitions */
|
|
#define MLXBF_GIGE_TX_WQE_SZ_QWORDS 2
|
|
#define MLXBF_GIGE_TX_WQE_SZ 16
|
|
#define MLXBF_GIGE_TX_WQE_PKT_LEN_MASK GENMASK(10, 0)
|
|
#define MLXBF_GIGE_TX_WQE_UPDATE_MASK GENMASK(31, 31)
|
|
#define MLXBF_GIGE_TX_WQE_CHKSUM_LEN_MASK GENMASK(42, 32)
|
|
#define MLXBF_GIGE_TX_WQE_CHKSUM_START_MASK GENMASK(55, 48)
|
|
#define MLXBF_GIGE_TX_WQE_CHKSUM_OFFSET_MASK GENMASK(63, 56)
|
|
|
|
/* Macro to return packet length of specified TX WQE */
|
|
#define MLXBF_GIGE_TX_WQE_PKT_LEN(tx_wqe_addr) \
|
|
(*((tx_wqe_addr) + 1) & MLXBF_GIGE_TX_WQE_PKT_LEN_MASK)
|
|
|
|
/* Tx Completion Count */
|
|
#define MLXBF_GIGE_TX_CC_SZ 8
|
|
|
|
/* List of resources in ACPI table */
|
|
enum mlxbf_gige_res {
|
|
MLXBF_GIGE_RES_MAC,
|
|
MLXBF_GIGE_RES_MDIO9,
|
|
MLXBF_GIGE_RES_GPIO0,
|
|
MLXBF_GIGE_RES_LLU,
|
|
MLXBF_GIGE_RES_PLU,
|
|
MLXBF_GIGE_RES_CLK
|
|
};
|
|
|
|
/* Version of register data returned by mlxbf_gige_get_regs() */
|
|
#define MLXBF_GIGE_REGS_VERSION 1
|
|
|
|
int mlxbf_gige_mdio_probe(struct platform_device *pdev,
|
|
struct mlxbf_gige *priv);
|
|
void mlxbf_gige_mdio_remove(struct mlxbf_gige *priv);
|
|
irqreturn_t mlxbf_gige_mdio_handle_phy_interrupt(int irq, void *dev_id);
|
|
void mlxbf_gige_mdio_enable_phy_int(struct mlxbf_gige *priv);
|
|
|
|
void mlxbf_gige_set_mac_rx_filter(struct mlxbf_gige *priv,
|
|
unsigned int index, u64 dmac);
|
|
void mlxbf_gige_get_mac_rx_filter(struct mlxbf_gige *priv,
|
|
unsigned int index, u64 *dmac);
|
|
void mlxbf_gige_enable_promisc(struct mlxbf_gige *priv);
|
|
void mlxbf_gige_disable_promisc(struct mlxbf_gige *priv);
|
|
int mlxbf_gige_rx_init(struct mlxbf_gige *priv);
|
|
void mlxbf_gige_rx_deinit(struct mlxbf_gige *priv);
|
|
int mlxbf_gige_tx_init(struct mlxbf_gige *priv);
|
|
void mlxbf_gige_tx_deinit(struct mlxbf_gige *priv);
|
|
bool mlxbf_gige_handle_tx_complete(struct mlxbf_gige *priv);
|
|
netdev_tx_t mlxbf_gige_start_xmit(struct sk_buff *skb,
|
|
struct net_device *netdev);
|
|
struct sk_buff *mlxbf_gige_alloc_skb(struct mlxbf_gige *priv,
|
|
unsigned int map_len,
|
|
dma_addr_t *buf_dma,
|
|
enum dma_data_direction dir);
|
|
int mlxbf_gige_request_irqs(struct mlxbf_gige *priv);
|
|
void mlxbf_gige_free_irqs(struct mlxbf_gige *priv);
|
|
int mlxbf_gige_poll(struct napi_struct *napi, int budget);
|
|
extern const struct ethtool_ops mlxbf_gige_ethtool_ops;
|
|
void mlxbf_gige_update_tx_wqe_next(struct mlxbf_gige *priv);
|
|
|
|
#endif /* !defined(__MLXBF_GIGE_H__) */
|