225 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			225 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /* Marvell Octeon EP (EndPoint) Ethernet Driver
 | |
|  *
 | |
|  * Copyright (C) 2020 Marvell.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #ifndef _OCTEP_RX_H_
 | |
| #define _OCTEP_RX_H_
 | |
| 
 | |
| /* struct octep_oq_desc_hw - Octeon Hardware OQ descriptor format.
 | |
|  *
 | |
|  * The descriptor ring is made of descriptors which have 2 64-bit values:
 | |
|  *
 | |
|  *   @buffer_ptr: DMA address of the skb->data
 | |
|  *   @info_ptr:  DMA address of host memory, used to update pkt count by hw.
 | |
|  *               This is currently unused to save pci writes.
 | |
|  */
 | |
| struct octep_oq_desc_hw {
 | |
| 	dma_addr_t buffer_ptr;
 | |
| 	u64 info_ptr;
 | |
| };
 | |
| 
 | |
| static_assert(sizeof(struct octep_oq_desc_hw) == 16);
 | |
| 
 | |
| #define OCTEP_OQ_DESC_SIZE    (sizeof(struct octep_oq_desc_hw))
 | |
| 
 | |
| /* Rx offload flags */
 | |
| #define OCTEP_RX_OFFLOAD_VLAN_STRIP	BIT(0)
 | |
| #define OCTEP_RX_OFFLOAD_IPV4_CKSUM	BIT(1)
 | |
| #define OCTEP_RX_OFFLOAD_UDP_CKSUM	BIT(2)
 | |
| #define OCTEP_RX_OFFLOAD_TCP_CKSUM	BIT(3)
 | |
| 
 | |
| #define OCTEP_RX_OFFLOAD_CKSUM		(OCTEP_RX_OFFLOAD_IPV4_CKSUM | \
 | |
| 					 OCTEP_RX_OFFLOAD_UDP_CKSUM | \
 | |
| 					 OCTEP_RX_OFFLOAD_TCP_CKSUM)
 | |
| 
 | |
| #define OCTEP_RX_IP_CSUM(flags)		((flags) & \
 | |
| 					 (OCTEP_RX_OFFLOAD_IPV4_CKSUM | \
 | |
| 					  OCTEP_RX_OFFLOAD_TCP_CKSUM | \
 | |
| 					  OCTEP_RX_OFFLOAD_UDP_CKSUM))
 | |
| 
 | |
| /* bit 0 is vlan strip */
 | |
| #define OCTEP_RX_CSUM_IP_VERIFIED	BIT(1)
 | |
| #define OCTEP_RX_CSUM_L4_VERIFIED	BIT(2)
 | |
| 
 | |
| #define OCTEP_RX_CSUM_VERIFIED(flags)	((flags) & \
 | |
| 					 (OCTEP_RX_CSUM_L4_VERIFIED | \
 | |
| 					  OCTEP_RX_CSUM_IP_VERIFIED))
 | |
| 
 | |
| /* Extended Response Header in packet data received from Hardware.
 | |
|  * Includes metadata like checksum status.
 | |
|  * this is valid only if hardware/firmware published support for this.
 | |
|  * This is at offset 0 of packet data (skb->data).
 | |
|  */
 | |
| struct octep_oq_resp_hw_ext {
 | |
| 	/* Reserved. */
 | |
| 	u64 rsvd:48;
 | |
| 
 | |
| 	/* offload flags */
 | |
| 	u16 rx_ol_flags;
 | |
| };
 | |
| 
 | |
| static_assert(sizeof(struct octep_oq_resp_hw_ext) == 8);
 | |
| 
 | |
| #define  OCTEP_OQ_RESP_HW_EXT_SIZE   (sizeof(struct octep_oq_resp_hw_ext))
 | |
| 
 | |
| /* Length of Rx packet DMA'ed by Octeon to Host.
 | |
|  * this is in bigendian; so need to be converted to cpu endian.
 | |
|  * Octeon writes this at the beginning of Rx buffer (skb->data).
 | |
|  */
 | |
| struct octep_oq_resp_hw {
 | |
| 	/* The Length of the packet. */
 | |
| 	__be64 length;
 | |
| };
 | |
| 
 | |
| static_assert(sizeof(struct octep_oq_resp_hw) == 8);
 | |
| 
 | |
| #define OCTEP_OQ_RESP_HW_SIZE   (sizeof(struct octep_oq_resp_hw))
 | |
| 
 | |
| /* Pointer to data buffer.
 | |
|  * Driver keeps a pointer to the data buffer that it made available to
 | |
|  * the Octeon device. Since the descriptor ring keeps physical (bus)
 | |
|  * addresses, this field is required for the driver to keep track of
 | |
|  * the virtual address pointers. The fields are operated by
 | |
|  * OS-dependent routines.
 | |
|  */
 | |
| struct octep_rx_buffer {
 | |
| 	struct page *page;
 | |
| 
 | |
| 	/* length from rx hardware descriptor after converting to cpu endian */
 | |
| 	u64 len;
 | |
| };
 | |
| 
 | |
| #define OCTEP_OQ_RECVBUF_SIZE    (sizeof(struct octep_rx_buffer))
 | |
| 
 | |
| /* Output Queue statistics. Each output queue has four stats fields. */
 | |
| struct octep_oq_stats {
 | |
| 	/* Number of packets received from the Device. */
 | |
| 	u64 packets;
 | |
| 
 | |
| 	/* Number of bytes received from the Device. */
 | |
| 	u64 bytes;
 | |
| 
 | |
| 	/* Number of times failed to allocate buffers. */
 | |
| 	u64 alloc_failures;
 | |
| };
 | |
| 
 | |
| #define OCTEP_OQ_STATS_SIZE   (sizeof(struct octep_oq_stats))
 | |
| 
 | |
| /* Hardware interface Rx statistics */
 | |
| struct octep_iface_rx_stats {
 | |
| 	/* Received packets */
 | |
| 	u64 pkts;
 | |
| 
 | |
| 	/* Octets of received packets */
 | |
| 	u64 octets;
 | |
| 
 | |
| 	/* Received PAUSE and Control packets */
 | |
| 	u64 pause_pkts;
 | |
| 
 | |
| 	/* Received PAUSE and Control octets */
 | |
| 	u64 pause_octets;
 | |
| 
 | |
| 	/* Filtered DMAC0 packets */
 | |
| 	u64 dmac0_pkts;
 | |
| 
 | |
| 	/* Filtered DMAC0 octets */
 | |
| 	u64 dmac0_octets;
 | |
| 
 | |
| 	/* Packets dropped due to RX FIFO full */
 | |
| 	u64 dropped_pkts_fifo_full;
 | |
| 
 | |
| 	/* Octets dropped due to RX FIFO full */
 | |
| 	u64 dropped_octets_fifo_full;
 | |
| 
 | |
| 	/* Error packets */
 | |
| 	u64 err_pkts;
 | |
| 
 | |
| 	/* Filtered DMAC1 packets */
 | |
| 	u64 dmac1_pkts;
 | |
| 
 | |
| 	/* Filtered DMAC1 octets */
 | |
| 	u64 dmac1_octets;
 | |
| 
 | |
| 	/* NCSI-bound packets dropped */
 | |
| 	u64 ncsi_dropped_pkts;
 | |
| 
 | |
| 	/* NCSI-bound octets dropped */
 | |
| 	u64 ncsi_dropped_octets;
 | |
| 
 | |
| 	/* Multicast packets received. */
 | |
| 	u64 mcast_pkts;
 | |
| 
 | |
| 	/* Broadcast packets received. */
 | |
| 	u64 bcast_pkts;
 | |
| 
 | |
| };
 | |
| 
 | |
| /* The Descriptor Ring Output Queue structure.
 | |
|  * This structure has all the information required to implement a
 | |
|  * Octeon OQ.
 | |
|  */
 | |
| struct octep_oq {
 | |
| 	u32 q_no;
 | |
| 
 | |
| 	struct octep_device *octep_dev;
 | |
| 	struct net_device *netdev;
 | |
| 	struct device *dev;
 | |
| 
 | |
| 	struct napi_struct *napi;
 | |
| 
 | |
| 	/* The receive buffer list. This list has the virtual addresses
 | |
| 	 * of the buffers.
 | |
| 	 */
 | |
| 	struct octep_rx_buffer *buff_info;
 | |
| 
 | |
| 	/* Pointer to the mapped packet credit register.
 | |
| 	 * Host writes number of info/buffer ptrs available to this register
 | |
| 	 */
 | |
| 	u8 __iomem *pkts_credit_reg;
 | |
| 
 | |
| 	/* Pointer to the mapped packet sent register.
 | |
| 	 * Octeon writes the number of packets DMA'ed to host memory
 | |
| 	 * in this register.
 | |
| 	 */
 | |
| 	u8 __iomem *pkts_sent_reg;
 | |
| 
 | |
| 	/* Statistics for this OQ. */
 | |
| 	struct octep_oq_stats stats;
 | |
| 
 | |
| 	/* Packets pending to be processed */
 | |
| 	u32 pkts_pending;
 | |
| 	u32 last_pkt_count;
 | |
| 
 | |
| 	/* Index in the ring where the driver should read the next packet */
 | |
| 	u32 host_read_idx;
 | |
| 
 | |
| 	/* Number of  descriptors in this ring. */
 | |
| 	u32 max_count;
 | |
| 	u32 ring_size_mask;
 | |
| 
 | |
| 	/* The number of descriptors pending refill. */
 | |
| 	u32 refill_count;
 | |
| 
 | |
| 	/* Index in the ring where the driver will refill the
 | |
| 	 * descriptor's buffer
 | |
| 	 */
 | |
| 	u32 host_refill_idx;
 | |
| 	u32 refill_threshold;
 | |
| 
 | |
| 	/* The size of each buffer pointed by the buffer pointer. */
 | |
| 	u32 buffer_size;
 | |
| 	u32 max_single_buffer_size;
 | |
| 
 | |
| 	/* The 8B aligned descriptor ring starts at this address. */
 | |
| 	struct octep_oq_desc_hw *desc_ring;
 | |
| 
 | |
| 	/* DMA mapped address of the OQ descriptor ring. */
 | |
| 	dma_addr_t desc_ring_dma;
 | |
| };
 | |
| 
 | |
| #define OCTEP_OQ_SIZE   (sizeof(struct octep_oq))
 | |
| #endif	/* _OCTEP_RX_H_ */
 |