/* SPDX-License-Identifier: GPL-2.0 */ /* Copyright(c) 2009 - 2018 Intel Corporation. */ /* Linux PRO/1000 Ethernet Driver main header file */ #ifndef _IGBVF_H_ #define _IGBVF_H_ #include #include #include #include #include #include "vf.h" /* Forward declarations */ struct igbvf_info; struct igbvf_adapter; /* Interrupt defines */ #define IGBVF_START_ITR 488 /* ~8000 ints/sec */ #define IGBVF_4K_ITR 980 #define IGBVF_20K_ITR 196 #define IGBVF_70K_ITR 56 enum latency_range { lowest_latency = 0, low_latency = 1, bulk_latency = 2, latency_invalid = 255 }; /* Interrupt modes, as used by the IntMode parameter */ #define IGBVF_INT_MODE_LEGACY 0 #define IGBVF_INT_MODE_MSI 1 #define IGBVF_INT_MODE_MSIX 2 /* Tx/Rx descriptor defines */ #define IGBVF_DEFAULT_TXD 256 #define IGBVF_MAX_TXD 4096 #define IGBVF_MIN_TXD 64 #define IGBVF_DEFAULT_RXD 256 #define IGBVF_MAX_RXD 4096 #define IGBVF_MIN_RXD 64 #define IGBVF_MIN_ITR_USECS 10 /* 100000 irq/sec */ #define IGBVF_MAX_ITR_USECS 10000 /* 100 irq/sec */ /* RX descriptor control thresholds. * PTHRESH - MAC will consider prefetch if it has fewer than this number of * descriptors available in its onboard memory. * Setting this to 0 disables RX descriptor prefetch. * HTHRESH - MAC will only prefetch if there are at least this many descriptors * available in host memory. * If PTHRESH is 0, this should also be 0. * WTHRESH - RX descriptor writeback threshold - MAC will delay writing back * descriptors until either it has this many to write back, or the * ITR timer expires. */ #define IGBVF_RX_PTHRESH 16 #define IGBVF_RX_HTHRESH 8 #define IGBVF_RX_WTHRESH 1 /* this is the size past which hardware will drop packets when setting LPE=0 */ #define MAXIMUM_ETHERNET_VLAN_SIZE 1522 #define IGBVF_FC_PAUSE_TIME 0x0680 /* 858 usec */ /* How many Tx Descriptors do we need to call netif_wake_queue ? */ #define IGBVF_TX_QUEUE_WAKE 32 /* How many Rx Buffers do we bundle into one write to the hardware ? */ #define IGBVF_RX_BUFFER_WRITE 16 /* Must be power of 2 */ #define AUTO_ALL_MODES 0 #define IGBVF_EEPROM_APME 0x0400 #define IGBVF_MNG_VLAN_NONE (-1) #define IGBVF_MAX_MAC_FILTERS 3 /* Number of packet split data buffers (not including the header buffer) */ #define PS_PAGE_BUFFERS (MAX_PS_BUFFERS - 1) enum igbvf_boards { board_vf, board_i350_vf, }; struct igbvf_queue_stats { u64 packets; u64 bytes; }; /* wrappers around a pointer to a socket buffer, * so a DMA handle can be stored along with the buffer */ struct igbvf_buffer { dma_addr_t dma; struct sk_buff *skb; union { /* Tx */ struct { unsigned long time_stamp; union e1000_adv_tx_desc *next_to_watch; u16 length; u16 mapped_as_page; }; /* Rx */ struct { struct page *page; u64 page_dma; unsigned int page_offset; }; }; }; union igbvf_desc { union e1000_adv_rx_desc rx_desc; union e1000_adv_tx_desc tx_desc; struct e1000_adv_tx_context_desc tx_context_desc; }; struct igbvf_ring { struct igbvf_adapter *adapter; /* backlink */ union igbvf_desc *desc; /* pointer to ring memory */ dma_addr_t dma; /* phys address of ring */ unsigned int size; /* length of ring in bytes */ unsigned int count; /* number of desc. in ring */ u16 next_to_use; u16 next_to_clean; u16 head; u16 tail; /* array of buffer information structs */ struct igbvf_buffer *buffer_info; struct napi_struct napi; char name[IFNAMSIZ + 5]; u32 eims_value; u32 itr_val; enum latency_range itr_range; u16 itr_register; int set_itr; struct sk_buff *rx_skb_top; struct igbvf_queue_stats stats; }; /* board specific private data structure */ struct igbvf_adapter { struct timer_list watchdog_timer; struct timer_list blink_timer; struct work_struct reset_task; struct work_struct watchdog_task; const struct igbvf_info *ei; unsigned long active_vlans[BITS_TO_LONGS(VLAN_N_VID)]; u32 bd_number; u32 rx_buffer_len; u32 polling_interval; u16 mng_vlan_id; u16 link_speed; u16 link_duplex; spinlock_t tx_queue_lock; /* prevent concurrent tail updates */ /* track device up/down/testing state */ unsigned long state; /* Interrupt Throttle Rate */ u32 requested_itr; /* ints/sec or adaptive */ u32 current_itr; /* Actual ITR register value, not ints/sec */ /* Tx */ struct igbvf_ring *tx_ring /* One per active queue */ ____cacheline_aligned_in_smp; unsigned int restart_queue; u32 txd_cmd; u32 tx_int_delay; u32 tx_abs_int_delay; unsigned int total_tx_bytes; unsigned int total_tx_packets; unsigned int total_rx_bytes; unsigned int total_rx_packets; /* Tx stats */ u32 tx_timeout_count; u32 tx_fifo_head; u32 tx_head_addr; u32 tx_fifo_size; u32 tx_dma_failed; /* Rx */ struct igbvf_ring *rx_ring; u32 rx_int_delay; u32 rx_abs_int_delay; /* Rx stats */ u64 hw_csum_err; u64 hw_csum_good; u64 rx_hdr_split; u32 alloc_rx_buff_failed; u32 rx_dma_failed; unsigned int rx_ps_hdr_size; u32 max_frame_size; u32 min_frame_size; /* OS defined structs */ struct net_device *netdev; struct pci_dev *pdev; spinlock_t stats_lock; /* prevent concurrent stats updates */ /* structs defined in e1000_hw.h */ struct e1000_hw hw; /* The VF counters don't clear on read so we have to get a base * count on driver start up and always subtract that base on * the first update, thus the flag.. */ struct e1000_vf_stats stats; u64 zero_base; struct igbvf_ring test_tx_ring; struct igbvf_ring test_rx_ring; u32 test_icr; u32 msg_enable; struct msix_entry *msix_entries; int int_mode; u32 eims_enable_mask; u32 eims_other; u32 int_counter0; u32 int_counter1; u32 eeprom_wol; u32 wol; u32 pba; bool fc_autoneg; unsigned long led_status; unsigned int flags; unsigned long last_reset; }; struct igbvf_info { enum e1000_mac_type mac; unsigned int flags; u32 pba; void (*init_ops)(struct e1000_hw *); s32 (*get_variants)(struct igbvf_adapter *); }; /* hardware capability, feature, and workaround flags */ #define IGBVF_FLAG_RX_CSUM_DISABLED BIT(0) #define IGBVF_FLAG_RX_LB_VLAN_BSWAP BIT(1) #define IGBVF_RX_DESC_ADV(R, i) \ (&((((R).desc))[i].rx_desc)) #define IGBVF_TX_DESC_ADV(R, i) \ (&((((R).desc))[i].tx_desc)) #define IGBVF_TX_CTXTDESC_ADV(R, i) \ (&((((R).desc))[i].tx_context_desc)) enum igbvf_state_t { __IGBVF_TESTING, __IGBVF_RESETTING, __IGBVF_DOWN }; extern char igbvf_driver_name[]; void igbvf_set_ethtool_ops(struct net_device *); int igbvf_up(struct igbvf_adapter *); void igbvf_down(struct igbvf_adapter *); void igbvf_reinit_locked(struct igbvf_adapter *); int igbvf_setup_rx_resources(struct igbvf_adapter *, struct igbvf_ring *); int igbvf_setup_tx_resources(struct igbvf_adapter *, struct igbvf_ring *); void igbvf_free_rx_resources(struct igbvf_ring *); void igbvf_free_tx_resources(struct igbvf_ring *); void igbvf_update_stats(struct igbvf_adapter *); extern unsigned int copybreak; #endif /* _IGBVF_H_ */