/* SPDX-License-Identifier: GPL-2.0 */ /* * This file is based on code from OCTEON SDK by Cavium Networks. * * Copyright (c) 2003-2010 Cavium Networks */ /* * External interface for the Cavium Octeon ethernet driver. */ #ifndef OCTEON_ETHERNET_H #define OCTEON_ETHERNET_H #include <linux/of.h> #include <linux/phy.h> #ifdef CONFIG_CAVIUM_OCTEON_SOC #include <asm/octeon/octeon.h> #include <asm/octeon/cvmx-asxx-defs.h> #include <asm/octeon/cvmx-config.h> #include <asm/octeon/cvmx-fau.h> #include <asm/octeon/cvmx-gmxx-defs.h> #include <asm/octeon/cvmx-helper.h> #include <asm/octeon/cvmx-helper-util.h> #include <asm/octeon/cvmx-ipd.h> #include <asm/octeon/cvmx-ipd-defs.h> #include <asm/octeon/cvmx-npi-defs.h> #include <asm/octeon/cvmx-pip.h> #include <asm/octeon/cvmx-pko.h> #include <asm/octeon/cvmx-pow.h> #include <asm/octeon/cvmx-scratch.h> #include <asm/octeon/cvmx-spi.h> #include <asm/octeon/cvmx-spxx-defs.h> #include <asm/octeon/cvmx-stxx-defs.h> #include <asm/octeon/cvmx-wqe.h> #else #include "octeon-stubs.h" #endif /** * This is the definition of the Ethernet driver's private * driver state stored in netdev_priv(dev). */ struct octeon_ethernet { /* PKO hardware output port */ int port; /* PKO hardware queue for the port */ int queue; /* Hardware fetch and add to count outstanding tx buffers */ int fau; /* My netdev. */ struct net_device *netdev; /* * Type of port. This is one of the enums in * cvmx_helper_interface_mode_t */ int imode; /* PHY mode */ phy_interface_t phy_mode; /* List of outstanding tx buffers per queue */ struct sk_buff_head tx_free_list[16]; unsigned int last_speed; unsigned int last_link; /* Last negotiated link state */ u64 link_info; /* Called periodically to check link status */ void (*poll)(struct net_device *dev); struct delayed_work port_periodic_work; struct device_node *of_node; }; int cvm_oct_free_work(void *work_queue_entry); int cvm_oct_rgmii_open(struct net_device *dev); int cvm_oct_sgmii_init(struct net_device *dev); int cvm_oct_sgmii_open(struct net_device *dev); int cvm_oct_spi_init(struct net_device *dev); void cvm_oct_spi_uninit(struct net_device *dev); int cvm_oct_common_init(struct net_device *dev); void cvm_oct_common_uninit(struct net_device *dev); void cvm_oct_adjust_link(struct net_device *dev); int cvm_oct_common_stop(struct net_device *dev); int cvm_oct_common_open(struct net_device *dev, void (*link_poll)(struct net_device *)); void cvm_oct_note_carrier(struct octeon_ethernet *priv, union cvmx_helper_link_info li); void cvm_oct_link_poll(struct net_device *dev); extern int always_use_pow; extern int pow_send_group; extern int pow_receive_groups; extern char pow_send_list[]; extern struct net_device *cvm_oct_device[]; extern atomic_t cvm_oct_poll_queue_stopping; extern u64 cvm_oct_tx_poll_interval; extern int rx_napi_weight; #endif