162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Tehuti Networks(R) Network Driver 462306a36Sopenharmony_ci * Copyright (C) 2007 Tehuti Networks Ltd. All rights reserved 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#ifndef _TEHUTI_H 862306a36Sopenharmony_ci#define _TEHUTI_H 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include <linux/module.h> 1162306a36Sopenharmony_ci#include <linux/kernel.h> 1262306a36Sopenharmony_ci#include <linux/netdevice.h> 1362306a36Sopenharmony_ci#include <linux/etherdevice.h> 1462306a36Sopenharmony_ci#include <linux/pci.h> 1562306a36Sopenharmony_ci#include <linux/delay.h> 1662306a36Sopenharmony_ci#include <linux/ethtool.h> 1762306a36Sopenharmony_ci#include <linux/mii.h> 1862306a36Sopenharmony_ci#include <linux/crc32.h> 1962306a36Sopenharmony_ci#include <linux/uaccess.h> 2062306a36Sopenharmony_ci#include <linux/in.h> 2162306a36Sopenharmony_ci#include <linux/ip.h> 2262306a36Sopenharmony_ci#include <linux/tcp.h> 2362306a36Sopenharmony_ci#include <linux/sched.h> 2462306a36Sopenharmony_ci#include <linux/tty.h> 2562306a36Sopenharmony_ci#include <linux/if_vlan.h> 2662306a36Sopenharmony_ci#include <linux/interrupt.h> 2762306a36Sopenharmony_ci#include <linux/vmalloc.h> 2862306a36Sopenharmony_ci#include <linux/firmware.h> 2962306a36Sopenharmony_ci#include <asm/byteorder.h> 3062306a36Sopenharmony_ci#include <linux/dma-mapping.h> 3162306a36Sopenharmony_ci#include <linux/slab.h> 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci/* Compile Time Switches */ 3462306a36Sopenharmony_ci/* start */ 3562306a36Sopenharmony_ci#define BDX_TSO 3662306a36Sopenharmony_ci#define BDX_LLTX 3762306a36Sopenharmony_ci#define BDX_DELAY_WPTR 3862306a36Sopenharmony_ci/* #define BDX_MSI */ 3962306a36Sopenharmony_ci/* end */ 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci#if !defined CONFIG_PCI_MSI 4262306a36Sopenharmony_ci# undef BDX_MSI 4362306a36Sopenharmony_ci#endif 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci#define BDX_DEF_MSG_ENABLE (NETIF_MSG_DRV | \ 4662306a36Sopenharmony_ci NETIF_MSG_PROBE | \ 4762306a36Sopenharmony_ci NETIF_MSG_LINK) 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci/* ioctl ops */ 5062306a36Sopenharmony_ci#define BDX_OP_READ 1 5162306a36Sopenharmony_ci#define BDX_OP_WRITE 2 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci/* RX copy break size */ 5462306a36Sopenharmony_ci#define BDX_COPYBREAK 257 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci#define DRIVER_AUTHOR "Tehuti Networks(R)" 5762306a36Sopenharmony_ci#define BDX_DRV_DESC "Tehuti Networks(R) Network Driver" 5862306a36Sopenharmony_ci#define BDX_DRV_NAME "tehuti" 5962306a36Sopenharmony_ci#define BDX_NIC_NAME "Tehuti 10 Giga TOE SmartNIC" 6062306a36Sopenharmony_ci#define BDX_NIC2PORT_NAME "Tehuti 2-Port 10 Giga TOE SmartNIC" 6162306a36Sopenharmony_ci#define BDX_DRV_VERSION "7.29.3" 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci#ifdef BDX_MSI 6462306a36Sopenharmony_ci# define BDX_MSI_STRING "msi " 6562306a36Sopenharmony_ci#else 6662306a36Sopenharmony_ci# define BDX_MSI_STRING "" 6762306a36Sopenharmony_ci#endif 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_ci/* netdev tx queue len for Luxor. default value is, btw, 1000 7062306a36Sopenharmony_ci * ifcontig eth1 txqueuelen 3000 - to change it at runtime */ 7162306a36Sopenharmony_ci#define BDX_NDEV_TXQ_LEN 3000 7262306a36Sopenharmony_ci 7362306a36Sopenharmony_ci/* Max MTU for Jumbo Frame mode, per tehutinetworks.net Features FAQ is 16k */ 7462306a36Sopenharmony_ci#define BDX_MAX_MTU (16 * 1024) 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_ci#define FIFO_SIZE 4096 7762306a36Sopenharmony_ci#define FIFO_EXTRA_SPACE 1024 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci#if BITS_PER_LONG == 64 8062306a36Sopenharmony_ci# define H32_64(x) (u32) ((u64)(x) >> 32) 8162306a36Sopenharmony_ci# define L32_64(x) (u32) ((u64)(x) & 0xffffffff) 8262306a36Sopenharmony_ci#elif BITS_PER_LONG == 32 8362306a36Sopenharmony_ci# define H32_64(x) 0 8462306a36Sopenharmony_ci# define L32_64(x) ((u32) (x)) 8562306a36Sopenharmony_ci#else /* BITS_PER_LONG == ?? */ 8662306a36Sopenharmony_ci# error BITS_PER_LONG is undefined. Must be 64 or 32 8762306a36Sopenharmony_ci#endif /* BITS_PER_LONG */ 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci#ifdef __BIG_ENDIAN 9062306a36Sopenharmony_ci# define CPU_CHIP_SWAP32(x) swab32(x) 9162306a36Sopenharmony_ci# define CPU_CHIP_SWAP16(x) swab16(x) 9262306a36Sopenharmony_ci#else 9362306a36Sopenharmony_ci# define CPU_CHIP_SWAP32(x) (x) 9462306a36Sopenharmony_ci# define CPU_CHIP_SWAP16(x) (x) 9562306a36Sopenharmony_ci#endif 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ci#define READ_REG(pp, reg) readl(pp->pBdxRegs + reg) 9862306a36Sopenharmony_ci#define WRITE_REG(pp, reg, val) writel(val, pp->pBdxRegs + reg) 9962306a36Sopenharmony_ci 10062306a36Sopenharmony_ci#ifndef NET_IP_ALIGN 10162306a36Sopenharmony_ci# define NET_IP_ALIGN 2 10262306a36Sopenharmony_ci#endif 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ci#ifndef NETDEV_TX_OK 10562306a36Sopenharmony_ci# define NETDEV_TX_OK 0 10662306a36Sopenharmony_ci#endif 10762306a36Sopenharmony_ci 10862306a36Sopenharmony_ci#define LUXOR_MAX_PORT 2 10962306a36Sopenharmony_ci#define BDX_MAX_RX_DONE 150 11062306a36Sopenharmony_ci#define BDX_TXF_DESC_SZ 16 11162306a36Sopenharmony_ci#define BDX_MAX_TX_LEVEL (priv->txd_fifo0.m.memsz - 16) 11262306a36Sopenharmony_ci#define BDX_MIN_TX_LEVEL 256 11362306a36Sopenharmony_ci#define BDX_NO_UPD_PACKETS 40 11462306a36Sopenharmony_ci 11562306a36Sopenharmony_cistruct pci_nic { 11662306a36Sopenharmony_ci int port_num; 11762306a36Sopenharmony_ci void __iomem *regs; 11862306a36Sopenharmony_ci int irq_type; 11962306a36Sopenharmony_ci struct bdx_priv *priv[LUXOR_MAX_PORT]; 12062306a36Sopenharmony_ci}; 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_cienum { IRQ_INTX, IRQ_MSI, IRQ_MSIX }; 12362306a36Sopenharmony_ci 12462306a36Sopenharmony_ci#define PCK_TH_MULT 128 12562306a36Sopenharmony_ci#define INT_COAL_MULT 2 12662306a36Sopenharmony_ci 12762306a36Sopenharmony_ci#define BITS_MASK(nbits) ((1<<nbits)-1) 12862306a36Sopenharmony_ci#define GET_BITS_SHIFT(x, nbits, nshift) (((x)>>nshift)&BITS_MASK(nbits)) 12962306a36Sopenharmony_ci#define BITS_SHIFT_MASK(nbits, nshift) (BITS_MASK(nbits)<<nshift) 13062306a36Sopenharmony_ci#define BITS_SHIFT_VAL(x, nbits, nshift) (((x)&BITS_MASK(nbits))<<nshift) 13162306a36Sopenharmony_ci#define BITS_SHIFT_CLEAR(x, nbits, nshift) \ 13262306a36Sopenharmony_ci ((x)&(~BITS_SHIFT_MASK(nbits, nshift))) 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci#define GET_INT_COAL(x) GET_BITS_SHIFT(x, 15, 0) 13562306a36Sopenharmony_ci#define GET_INT_COAL_RC(x) GET_BITS_SHIFT(x, 1, 15) 13662306a36Sopenharmony_ci#define GET_RXF_TH(x) GET_BITS_SHIFT(x, 4, 16) 13762306a36Sopenharmony_ci#define GET_PCK_TH(x) GET_BITS_SHIFT(x, 4, 20) 13862306a36Sopenharmony_ci 13962306a36Sopenharmony_ci#define INT_REG_VAL(coal, coal_rc, rxf_th, pck_th) \ 14062306a36Sopenharmony_ci ((coal)|((coal_rc)<<15)|((rxf_th)<<16)|((pck_th)<<20)) 14162306a36Sopenharmony_ci 14262306a36Sopenharmony_cistruct fifo { 14362306a36Sopenharmony_ci dma_addr_t da; /* physical address of fifo (used by HW) */ 14462306a36Sopenharmony_ci char *va; /* virtual address of fifo (used by SW) */ 14562306a36Sopenharmony_ci u32 rptr, wptr; /* cached values of RPTR and WPTR registers, 14662306a36Sopenharmony_ci they're 32 bits on both 32 and 64 archs */ 14762306a36Sopenharmony_ci u16 reg_CFG0, reg_CFG1; 14862306a36Sopenharmony_ci u16 reg_RPTR, reg_WPTR; 14962306a36Sopenharmony_ci u16 memsz; /* memory size allocated for fifo */ 15062306a36Sopenharmony_ci u16 size_mask; 15162306a36Sopenharmony_ci u16 pktsz; /* skb packet size to allocate */ 15262306a36Sopenharmony_ci u16 rcvno; /* number of buffers that come from this RXF */ 15362306a36Sopenharmony_ci}; 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_cistruct txf_fifo { 15662306a36Sopenharmony_ci struct fifo m; /* minimal set of variables used by all fifos */ 15762306a36Sopenharmony_ci}; 15862306a36Sopenharmony_ci 15962306a36Sopenharmony_cistruct txd_fifo { 16062306a36Sopenharmony_ci struct fifo m; /* minimal set of variables used by all fifos */ 16162306a36Sopenharmony_ci}; 16262306a36Sopenharmony_ci 16362306a36Sopenharmony_cistruct rxf_fifo { 16462306a36Sopenharmony_ci struct fifo m; /* minimal set of variables used by all fifos */ 16562306a36Sopenharmony_ci}; 16662306a36Sopenharmony_ci 16762306a36Sopenharmony_cistruct rxd_fifo { 16862306a36Sopenharmony_ci struct fifo m; /* minimal set of variables used by all fifos */ 16962306a36Sopenharmony_ci}; 17062306a36Sopenharmony_ci 17162306a36Sopenharmony_cistruct rx_map { 17262306a36Sopenharmony_ci u64 dma; 17362306a36Sopenharmony_ci struct sk_buff *skb; 17462306a36Sopenharmony_ci}; 17562306a36Sopenharmony_ci 17662306a36Sopenharmony_cistruct rxdb { 17762306a36Sopenharmony_ci int *stack; 17862306a36Sopenharmony_ci struct rx_map *elems; 17962306a36Sopenharmony_ci int nelem; 18062306a36Sopenharmony_ci int top; 18162306a36Sopenharmony_ci}; 18262306a36Sopenharmony_ci 18362306a36Sopenharmony_ciunion bdx_dma_addr { 18462306a36Sopenharmony_ci dma_addr_t dma; 18562306a36Sopenharmony_ci struct sk_buff *skb; 18662306a36Sopenharmony_ci}; 18762306a36Sopenharmony_ci 18862306a36Sopenharmony_ci/* Entry in the db. 18962306a36Sopenharmony_ci * if len == 0 addr is dma 19062306a36Sopenharmony_ci * if len != 0 addr is skb */ 19162306a36Sopenharmony_cistruct tx_map { 19262306a36Sopenharmony_ci union bdx_dma_addr addr; 19362306a36Sopenharmony_ci int len; 19462306a36Sopenharmony_ci}; 19562306a36Sopenharmony_ci 19662306a36Sopenharmony_ci/* tx database - implemented as circular fifo buffer*/ 19762306a36Sopenharmony_cistruct txdb { 19862306a36Sopenharmony_ci struct tx_map *start; /* points to the first element */ 19962306a36Sopenharmony_ci struct tx_map *end; /* points just AFTER the last element */ 20062306a36Sopenharmony_ci struct tx_map *rptr; /* points to the next element to read */ 20162306a36Sopenharmony_ci struct tx_map *wptr; /* points to the next element to write */ 20262306a36Sopenharmony_ci int size; /* number of elements in the db */ 20362306a36Sopenharmony_ci}; 20462306a36Sopenharmony_ci 20562306a36Sopenharmony_ci/*Internal stats structure*/ 20662306a36Sopenharmony_cistruct bdx_stats { 20762306a36Sopenharmony_ci u64 InUCast; /* 0x7200 */ 20862306a36Sopenharmony_ci u64 InMCast; /* 0x7210 */ 20962306a36Sopenharmony_ci u64 InBCast; /* 0x7220 */ 21062306a36Sopenharmony_ci u64 InPkts; /* 0x7230 */ 21162306a36Sopenharmony_ci u64 InErrors; /* 0x7240 */ 21262306a36Sopenharmony_ci u64 InDropped; /* 0x7250 */ 21362306a36Sopenharmony_ci u64 FrameTooLong; /* 0x7260 */ 21462306a36Sopenharmony_ci u64 FrameSequenceErrors; /* 0x7270 */ 21562306a36Sopenharmony_ci u64 InVLAN; /* 0x7280 */ 21662306a36Sopenharmony_ci u64 InDroppedDFE; /* 0x7290 */ 21762306a36Sopenharmony_ci u64 InDroppedIntFull; /* 0x72A0 */ 21862306a36Sopenharmony_ci u64 InFrameAlignErrors; /* 0x72B0 */ 21962306a36Sopenharmony_ci 22062306a36Sopenharmony_ci /* 0x72C0-0x72E0 RSRV */ 22162306a36Sopenharmony_ci 22262306a36Sopenharmony_ci u64 OutUCast; /* 0x72F0 */ 22362306a36Sopenharmony_ci u64 OutMCast; /* 0x7300 */ 22462306a36Sopenharmony_ci u64 OutBCast; /* 0x7310 */ 22562306a36Sopenharmony_ci u64 OutPkts; /* 0x7320 */ 22662306a36Sopenharmony_ci 22762306a36Sopenharmony_ci /* 0x7330-0x7360 RSRV */ 22862306a36Sopenharmony_ci 22962306a36Sopenharmony_ci u64 OutVLAN; /* 0x7370 */ 23062306a36Sopenharmony_ci u64 InUCastOctects; /* 0x7380 */ 23162306a36Sopenharmony_ci u64 OutUCastOctects; /* 0x7390 */ 23262306a36Sopenharmony_ci 23362306a36Sopenharmony_ci /* 0x73A0-0x73B0 RSRV */ 23462306a36Sopenharmony_ci 23562306a36Sopenharmony_ci u64 InBCastOctects; /* 0x73C0 */ 23662306a36Sopenharmony_ci u64 OutBCastOctects; /* 0x73D0 */ 23762306a36Sopenharmony_ci u64 InOctects; /* 0x73E0 */ 23862306a36Sopenharmony_ci u64 OutOctects; /* 0x73F0 */ 23962306a36Sopenharmony_ci}; 24062306a36Sopenharmony_ci 24162306a36Sopenharmony_cistruct bdx_priv { 24262306a36Sopenharmony_ci void __iomem *pBdxRegs; 24362306a36Sopenharmony_ci struct net_device *ndev; 24462306a36Sopenharmony_ci 24562306a36Sopenharmony_ci struct napi_struct napi; 24662306a36Sopenharmony_ci 24762306a36Sopenharmony_ci /* RX FIFOs: 1 for data (full) descs, and 2 for free descs */ 24862306a36Sopenharmony_ci struct rxd_fifo rxd_fifo0; 24962306a36Sopenharmony_ci struct rxf_fifo rxf_fifo0; 25062306a36Sopenharmony_ci struct rxdb *rxdb; /* rx dbs to store skb pointers */ 25162306a36Sopenharmony_ci int napi_stop; 25262306a36Sopenharmony_ci 25362306a36Sopenharmony_ci /* Tx FIFOs: 1 for data desc, 1 for empty (acks) desc */ 25462306a36Sopenharmony_ci struct txd_fifo txd_fifo0; 25562306a36Sopenharmony_ci struct txf_fifo txf_fifo0; 25662306a36Sopenharmony_ci 25762306a36Sopenharmony_ci struct txdb txdb; 25862306a36Sopenharmony_ci int tx_level; 25962306a36Sopenharmony_ci#ifdef BDX_DELAY_WPTR 26062306a36Sopenharmony_ci int tx_update_mark; 26162306a36Sopenharmony_ci int tx_noupd; 26262306a36Sopenharmony_ci#endif 26362306a36Sopenharmony_ci spinlock_t tx_lock; /* NETIF_F_LLTX mode */ 26462306a36Sopenharmony_ci 26562306a36Sopenharmony_ci /* rarely used */ 26662306a36Sopenharmony_ci u8 port; 26762306a36Sopenharmony_ci u32 msg_enable; 26862306a36Sopenharmony_ci int stats_flag; 26962306a36Sopenharmony_ci struct bdx_stats hw_stats; 27062306a36Sopenharmony_ci struct pci_dev *pdev; 27162306a36Sopenharmony_ci 27262306a36Sopenharmony_ci struct pci_nic *nic; 27362306a36Sopenharmony_ci 27462306a36Sopenharmony_ci u8 txd_size; 27562306a36Sopenharmony_ci u8 txf_size; 27662306a36Sopenharmony_ci u8 rxd_size; 27762306a36Sopenharmony_ci u8 rxf_size; 27862306a36Sopenharmony_ci u32 rdintcm; 27962306a36Sopenharmony_ci u32 tdintcm; 28062306a36Sopenharmony_ci}; 28162306a36Sopenharmony_ci 28262306a36Sopenharmony_ci/* RX FREE descriptor - 64bit*/ 28362306a36Sopenharmony_cistruct rxf_desc { 28462306a36Sopenharmony_ci u32 info; /* Buffer Count + Info - described below */ 28562306a36Sopenharmony_ci u32 va_lo; /* VAdr[31:0] */ 28662306a36Sopenharmony_ci u32 va_hi; /* VAdr[63:32] */ 28762306a36Sopenharmony_ci u32 pa_lo; /* PAdr[31:0] */ 28862306a36Sopenharmony_ci u32 pa_hi; /* PAdr[63:32] */ 28962306a36Sopenharmony_ci u32 len; /* Buffer Length */ 29062306a36Sopenharmony_ci}; 29162306a36Sopenharmony_ci 29262306a36Sopenharmony_ci#define GET_RXD_BC(x) GET_BITS_SHIFT((x), 5, 0) 29362306a36Sopenharmony_ci#define GET_RXD_RXFQ(x) GET_BITS_SHIFT((x), 2, 8) 29462306a36Sopenharmony_ci#define GET_RXD_TO(x) GET_BITS_SHIFT((x), 1, 15) 29562306a36Sopenharmony_ci#define GET_RXD_TYPE(x) GET_BITS_SHIFT((x), 4, 16) 29662306a36Sopenharmony_ci#define GET_RXD_ERR(x) GET_BITS_SHIFT((x), 6, 21) 29762306a36Sopenharmony_ci#define GET_RXD_RXP(x) GET_BITS_SHIFT((x), 1, 27) 29862306a36Sopenharmony_ci#define GET_RXD_PKT_ID(x) GET_BITS_SHIFT((x), 3, 28) 29962306a36Sopenharmony_ci#define GET_RXD_VTAG(x) GET_BITS_SHIFT((x), 1, 31) 30062306a36Sopenharmony_ci#define GET_RXD_VLAN_ID(x) GET_BITS_SHIFT((x), 12, 0) 30162306a36Sopenharmony_ci#define GET_RXD_VLAN_TCI(x) GET_BITS_SHIFT((x), 16, 0) 30262306a36Sopenharmony_ci#define GET_RXD_CFI(x) GET_BITS_SHIFT((x), 1, 12) 30362306a36Sopenharmony_ci#define GET_RXD_PRIO(x) GET_BITS_SHIFT((x), 3, 13) 30462306a36Sopenharmony_ci 30562306a36Sopenharmony_cistruct rxd_desc { 30662306a36Sopenharmony_ci u32 rxd_val1; 30762306a36Sopenharmony_ci u16 len; 30862306a36Sopenharmony_ci u16 rxd_vlan; 30962306a36Sopenharmony_ci u32 va_lo; 31062306a36Sopenharmony_ci u32 va_hi; 31162306a36Sopenharmony_ci}; 31262306a36Sopenharmony_ci 31362306a36Sopenharmony_ci/* PBL describes each virtual buffer to be */ 31462306a36Sopenharmony_ci/* transmitted from the host.*/ 31562306a36Sopenharmony_cistruct pbl { 31662306a36Sopenharmony_ci u32 pa_lo; 31762306a36Sopenharmony_ci u32 pa_hi; 31862306a36Sopenharmony_ci u32 len; 31962306a36Sopenharmony_ci}; 32062306a36Sopenharmony_ci 32162306a36Sopenharmony_ci/* First word for TXD descriptor. It means: type = 3 for regular Tx packet, 32262306a36Sopenharmony_ci * hw_csum = 7 for ip+udp+tcp hw checksums */ 32362306a36Sopenharmony_ci#define TXD_W1_VAL(bc, checksum, vtag, lgsnd, vlan_id) \ 32462306a36Sopenharmony_ci ((bc) | ((checksum)<<5) | ((vtag)<<8) | \ 32562306a36Sopenharmony_ci ((lgsnd)<<9) | (0x30000) | ((vlan_id)<<20)) 32662306a36Sopenharmony_ci 32762306a36Sopenharmony_cistruct txd_desc { 32862306a36Sopenharmony_ci u32 txd_val1; 32962306a36Sopenharmony_ci u16 mss; 33062306a36Sopenharmony_ci u16 length; 33162306a36Sopenharmony_ci u32 va_lo; 33262306a36Sopenharmony_ci u32 va_hi; 33362306a36Sopenharmony_ci struct pbl pbl[]; /* Fragments */ 33462306a36Sopenharmony_ci} __packed; 33562306a36Sopenharmony_ci 33662306a36Sopenharmony_ci/* Register region size */ 33762306a36Sopenharmony_ci#define BDX_REGS_SIZE 0x1000 33862306a36Sopenharmony_ci 33962306a36Sopenharmony_ci/* Registers from 0x0000-0x00fc were remapped to 0x4000-0x40fc */ 34062306a36Sopenharmony_ci#define regTXD_CFG1_0 0x4000 34162306a36Sopenharmony_ci#define regRXF_CFG1_0 0x4010 34262306a36Sopenharmony_ci#define regRXD_CFG1_0 0x4020 34362306a36Sopenharmony_ci#define regTXF_CFG1_0 0x4030 34462306a36Sopenharmony_ci#define regTXD_CFG0_0 0x4040 34562306a36Sopenharmony_ci#define regRXF_CFG0_0 0x4050 34662306a36Sopenharmony_ci#define regRXD_CFG0_0 0x4060 34762306a36Sopenharmony_ci#define regTXF_CFG0_0 0x4070 34862306a36Sopenharmony_ci#define regTXD_WPTR_0 0x4080 34962306a36Sopenharmony_ci#define regRXF_WPTR_0 0x4090 35062306a36Sopenharmony_ci#define regRXD_WPTR_0 0x40A0 35162306a36Sopenharmony_ci#define regTXF_WPTR_0 0x40B0 35262306a36Sopenharmony_ci#define regTXD_RPTR_0 0x40C0 35362306a36Sopenharmony_ci#define regRXF_RPTR_0 0x40D0 35462306a36Sopenharmony_ci#define regRXD_RPTR_0 0x40E0 35562306a36Sopenharmony_ci#define regTXF_RPTR_0 0x40F0 35662306a36Sopenharmony_ci#define regTXF_RPTR_3 0x40FC 35762306a36Sopenharmony_ci 35862306a36Sopenharmony_ci/* hardware versioning */ 35962306a36Sopenharmony_ci#define FW_VER 0x5010 36062306a36Sopenharmony_ci#define SROM_VER 0x5020 36162306a36Sopenharmony_ci#define FPGA_VER 0x5030 36262306a36Sopenharmony_ci#define FPGA_SEED 0x5040 36362306a36Sopenharmony_ci 36462306a36Sopenharmony_ci/* Registers from 0x0100-0x0150 were remapped to 0x5100-0x5150 */ 36562306a36Sopenharmony_ci#define regISR regISR0 36662306a36Sopenharmony_ci#define regISR0 0x5100 36762306a36Sopenharmony_ci 36862306a36Sopenharmony_ci#define regIMR regIMR0 36962306a36Sopenharmony_ci#define regIMR0 0x5110 37062306a36Sopenharmony_ci 37162306a36Sopenharmony_ci#define regRDINTCM0 0x5120 37262306a36Sopenharmony_ci#define regRDINTCM2 0x5128 37362306a36Sopenharmony_ci 37462306a36Sopenharmony_ci#define regTDINTCM0 0x5130 37562306a36Sopenharmony_ci 37662306a36Sopenharmony_ci#define regISR_MSK0 0x5140 37762306a36Sopenharmony_ci 37862306a36Sopenharmony_ci#define regINIT_SEMAPHORE 0x5170 37962306a36Sopenharmony_ci#define regINIT_STATUS 0x5180 38062306a36Sopenharmony_ci 38162306a36Sopenharmony_ci#define regMAC_LNK_STAT 0x0200 38262306a36Sopenharmony_ci#define MAC_LINK_STAT 0x4 /* Link state */ 38362306a36Sopenharmony_ci 38462306a36Sopenharmony_ci#define regGMAC_RXF_A 0x1240 38562306a36Sopenharmony_ci 38662306a36Sopenharmony_ci#define regUNC_MAC0_A 0x1250 38762306a36Sopenharmony_ci#define regUNC_MAC1_A 0x1260 38862306a36Sopenharmony_ci#define regUNC_MAC2_A 0x1270 38962306a36Sopenharmony_ci 39062306a36Sopenharmony_ci#define regVLAN_0 0x1800 39162306a36Sopenharmony_ci 39262306a36Sopenharmony_ci#define regMAX_FRAME_A 0x12C0 39362306a36Sopenharmony_ci 39462306a36Sopenharmony_ci#define regRX_MAC_MCST0 0x1A80 39562306a36Sopenharmony_ci#define regRX_MAC_MCST1 0x1A84 39662306a36Sopenharmony_ci#define MAC_MCST_NUM 15 39762306a36Sopenharmony_ci#define regRX_MCST_HASH0 0x1A00 39862306a36Sopenharmony_ci#define MAC_MCST_HASH_NUM 8 39962306a36Sopenharmony_ci 40062306a36Sopenharmony_ci#define regVPC 0x2300 40162306a36Sopenharmony_ci#define regVIC 0x2320 40262306a36Sopenharmony_ci#define regVGLB 0x2340 40362306a36Sopenharmony_ci 40462306a36Sopenharmony_ci#define regCLKPLL 0x5000 40562306a36Sopenharmony_ci 40662306a36Sopenharmony_ci/*for 10G only*/ 40762306a36Sopenharmony_ci#define regREVISION 0x6000 40862306a36Sopenharmony_ci#define regSCRATCH 0x6004 40962306a36Sopenharmony_ci#define regCTRLST 0x6008 41062306a36Sopenharmony_ci#define regMAC_ADDR_0 0x600C 41162306a36Sopenharmony_ci#define regMAC_ADDR_1 0x6010 41262306a36Sopenharmony_ci#define regFRM_LENGTH 0x6014 41362306a36Sopenharmony_ci#define regPAUSE_QUANT 0x6018 41462306a36Sopenharmony_ci#define regRX_FIFO_SECTION 0x601C 41562306a36Sopenharmony_ci#define regTX_FIFO_SECTION 0x6020 41662306a36Sopenharmony_ci#define regRX_FULLNESS 0x6024 41762306a36Sopenharmony_ci#define regTX_FULLNESS 0x6028 41862306a36Sopenharmony_ci#define regHASHTABLE 0x602C 41962306a36Sopenharmony_ci#define regMDIO_ST 0x6030 42062306a36Sopenharmony_ci#define regMDIO_CTL 0x6034 42162306a36Sopenharmony_ci#define regMDIO_DATA 0x6038 42262306a36Sopenharmony_ci#define regMDIO_ADDR 0x603C 42362306a36Sopenharmony_ci 42462306a36Sopenharmony_ci#define regRST_PORT 0x7000 42562306a36Sopenharmony_ci#define regDIS_PORT 0x7010 42662306a36Sopenharmony_ci#define regRST_QU 0x7020 42762306a36Sopenharmony_ci#define regDIS_QU 0x7030 42862306a36Sopenharmony_ci 42962306a36Sopenharmony_ci#define regCTRLST_TX_ENA 0x0001 43062306a36Sopenharmony_ci#define regCTRLST_RX_ENA 0x0002 43162306a36Sopenharmony_ci#define regCTRLST_PRM_ENA 0x0010 43262306a36Sopenharmony_ci#define regCTRLST_PAD_ENA 0x0020 43362306a36Sopenharmony_ci 43462306a36Sopenharmony_ci#define regCTRLST_BASE (regCTRLST_PAD_ENA|regCTRLST_PRM_ENA) 43562306a36Sopenharmony_ci 43662306a36Sopenharmony_ci#define regRX_FLT 0x1400 43762306a36Sopenharmony_ci 43862306a36Sopenharmony_ci/* TXD TXF RXF RXD CONFIG 0x0000 --- 0x007c*/ 43962306a36Sopenharmony_ci#define TX_RX_CFG1_BASE 0xffffffff /*0-31 */ 44062306a36Sopenharmony_ci#define TX_RX_CFG0_BASE 0xfffff000 /*31:12 */ 44162306a36Sopenharmony_ci#define TX_RX_CFG0_RSVD 0x0ffc /*11:2 */ 44262306a36Sopenharmony_ci#define TX_RX_CFG0_SIZE 0x0003 /*1:0 */ 44362306a36Sopenharmony_ci 44462306a36Sopenharmony_ci/* TXD TXF RXF RXD WRITE 0x0080 --- 0x00BC */ 44562306a36Sopenharmony_ci#define TXF_WPTR_WR_PTR 0x7ff8 /*14:3 */ 44662306a36Sopenharmony_ci 44762306a36Sopenharmony_ci/* TXD TXF RXF RXD READ 0x00CO --- 0x00FC */ 44862306a36Sopenharmony_ci#define TXF_RPTR_RD_PTR 0x7ff8 /*14:3 */ 44962306a36Sopenharmony_ci 45062306a36Sopenharmony_ci#define TXF_WPTR_MASK 0x7ff0 /* last 4 bits are dropped 45162306a36Sopenharmony_ci * size is rounded to 16 */ 45262306a36Sopenharmony_ci 45362306a36Sopenharmony_ci/* regISR 0x0100 */ 45462306a36Sopenharmony_ci/* regIMR 0x0110 */ 45562306a36Sopenharmony_ci#define IMR_INPROG 0x80000000 /*31 */ 45662306a36Sopenharmony_ci#define IR_LNKCHG1 0x10000000 /*28 */ 45762306a36Sopenharmony_ci#define IR_LNKCHG0 0x08000000 /*27 */ 45862306a36Sopenharmony_ci#define IR_GPIO 0x04000000 /*26 */ 45962306a36Sopenharmony_ci#define IR_RFRSH 0x02000000 /*25 */ 46062306a36Sopenharmony_ci#define IR_RSVD 0x01000000 /*24 */ 46162306a36Sopenharmony_ci#define IR_SWI 0x00800000 /*23 */ 46262306a36Sopenharmony_ci#define IR_RX_FREE_3 0x00400000 /*22 */ 46362306a36Sopenharmony_ci#define IR_RX_FREE_2 0x00200000 /*21 */ 46462306a36Sopenharmony_ci#define IR_RX_FREE_1 0x00100000 /*20 */ 46562306a36Sopenharmony_ci#define IR_RX_FREE_0 0x00080000 /*19 */ 46662306a36Sopenharmony_ci#define IR_TX_FREE_3 0x00040000 /*18 */ 46762306a36Sopenharmony_ci#define IR_TX_FREE_2 0x00020000 /*17 */ 46862306a36Sopenharmony_ci#define IR_TX_FREE_1 0x00010000 /*16 */ 46962306a36Sopenharmony_ci#define IR_TX_FREE_0 0x00008000 /*15 */ 47062306a36Sopenharmony_ci#define IR_RX_DESC_3 0x00004000 /*14 */ 47162306a36Sopenharmony_ci#define IR_RX_DESC_2 0x00002000 /*13 */ 47262306a36Sopenharmony_ci#define IR_RX_DESC_1 0x00001000 /*12 */ 47362306a36Sopenharmony_ci#define IR_RX_DESC_0 0x00000800 /*11 */ 47462306a36Sopenharmony_ci#define IR_PSE 0x00000400 /*10 */ 47562306a36Sopenharmony_ci#define IR_TMR3 0x00000200 /*9 */ 47662306a36Sopenharmony_ci#define IR_TMR2 0x00000100 /*8 */ 47762306a36Sopenharmony_ci#define IR_TMR1 0x00000080 /*7 */ 47862306a36Sopenharmony_ci#define IR_TMR0 0x00000040 /*6 */ 47962306a36Sopenharmony_ci#define IR_VNT 0x00000020 /*5 */ 48062306a36Sopenharmony_ci#define IR_RxFL 0x00000010 /*4 */ 48162306a36Sopenharmony_ci#define IR_SDPERR 0x00000008 /*3 */ 48262306a36Sopenharmony_ci#define IR_TR 0x00000004 /*2 */ 48362306a36Sopenharmony_ci#define IR_PCIE_LINK 0x00000002 /*1 */ 48462306a36Sopenharmony_ci#define IR_PCIE_TOUT 0x00000001 /*0 */ 48562306a36Sopenharmony_ci 48662306a36Sopenharmony_ci#define IR_EXTRA (IR_RX_FREE_0 | IR_LNKCHG0 | IR_PSE | \ 48762306a36Sopenharmony_ci IR_TMR0 | IR_PCIE_LINK | IR_PCIE_TOUT) 48862306a36Sopenharmony_ci#define IR_RUN (IR_EXTRA | IR_RX_DESC_0 | IR_TX_FREE_0) 48962306a36Sopenharmony_ci#define IR_ALL 0xfdfffff7 49062306a36Sopenharmony_ci 49162306a36Sopenharmony_ci#define IR_LNKCHG0_ofst 27 49262306a36Sopenharmony_ci 49362306a36Sopenharmony_ci#define GMAC_RX_FILTER_OSEN 0x1000 /* shared OS enable */ 49462306a36Sopenharmony_ci#define GMAC_RX_FILTER_TXFC 0x0400 /* Tx flow control */ 49562306a36Sopenharmony_ci#define GMAC_RX_FILTER_RSV0 0x0200 /* reserved */ 49662306a36Sopenharmony_ci#define GMAC_RX_FILTER_FDA 0x0100 /* filter out direct address */ 49762306a36Sopenharmony_ci#define GMAC_RX_FILTER_AOF 0x0080 /* accept over run */ 49862306a36Sopenharmony_ci#define GMAC_RX_FILTER_ACF 0x0040 /* accept control frames */ 49962306a36Sopenharmony_ci#define GMAC_RX_FILTER_ARUNT 0x0020 /* accept under run */ 50062306a36Sopenharmony_ci#define GMAC_RX_FILTER_ACRC 0x0010 /* accept crc error */ 50162306a36Sopenharmony_ci#define GMAC_RX_FILTER_AM 0x0008 /* accept multicast */ 50262306a36Sopenharmony_ci#define GMAC_RX_FILTER_AB 0x0004 /* accept broadcast */ 50362306a36Sopenharmony_ci#define GMAC_RX_FILTER_PRM 0x0001 /* [0:1] promiscuous mode */ 50462306a36Sopenharmony_ci 50562306a36Sopenharmony_ci#define MAX_FRAME_AB_VAL 0x3fff /* 13:0 */ 50662306a36Sopenharmony_ci 50762306a36Sopenharmony_ci#define CLKPLL_PLLLKD 0x0200 /*9 */ 50862306a36Sopenharmony_ci#define CLKPLL_RSTEND 0x0100 /*8 */ 50962306a36Sopenharmony_ci#define CLKPLL_SFTRST 0x0001 /*0 */ 51062306a36Sopenharmony_ci 51162306a36Sopenharmony_ci#define CLKPLL_LKD (CLKPLL_PLLLKD|CLKPLL_RSTEND) 51262306a36Sopenharmony_ci 51362306a36Sopenharmony_ci/* 51462306a36Sopenharmony_ci * PCI-E Device Control Register (Offset 0x88) 51562306a36Sopenharmony_ci * Source: Luxor Data Sheet, 7.1.3.3.3 51662306a36Sopenharmony_ci */ 51762306a36Sopenharmony_ci#define PCI_DEV_CTRL_REG 0x88 51862306a36Sopenharmony_ci#define GET_DEV_CTRL_MAXPL(x) GET_BITS_SHIFT(x, 3, 5) 51962306a36Sopenharmony_ci#define GET_DEV_CTRL_MRRS(x) GET_BITS_SHIFT(x, 3, 12) 52062306a36Sopenharmony_ci 52162306a36Sopenharmony_ci/* 52262306a36Sopenharmony_ci * PCI-E Link Status Register (Offset 0x92) 52362306a36Sopenharmony_ci * Source: Luxor Data Sheet, 7.1.3.3.7 52462306a36Sopenharmony_ci */ 52562306a36Sopenharmony_ci#define PCI_LINK_STATUS_REG 0x92 52662306a36Sopenharmony_ci#define GET_LINK_STATUS_LANES(x) GET_BITS_SHIFT(x, 6, 4) 52762306a36Sopenharmony_ci 52862306a36Sopenharmony_ci/* Debugging Macros */ 52962306a36Sopenharmony_ci 53062306a36Sopenharmony_ci#define DBG2(fmt, args...) \ 53162306a36Sopenharmony_ci pr_err("%s:%-5d: " fmt, __func__, __LINE__, ## args) 53262306a36Sopenharmony_ci 53362306a36Sopenharmony_ci#define BDX_ASSERT(x) BUG_ON(x) 53462306a36Sopenharmony_ci 53562306a36Sopenharmony_ci#ifdef DEBUG 53662306a36Sopenharmony_ci 53762306a36Sopenharmony_ci#define ENTER \ 53862306a36Sopenharmony_cido { \ 53962306a36Sopenharmony_ci pr_err("%s:%-5d: ENTER\n", __func__, __LINE__); \ 54062306a36Sopenharmony_ci} while (0) 54162306a36Sopenharmony_ci 54262306a36Sopenharmony_ci#define RET(args...) \ 54362306a36Sopenharmony_cido { \ 54462306a36Sopenharmony_ci pr_err("%s:%-5d: RETURN\n", __func__, __LINE__); \ 54562306a36Sopenharmony_ci return args; \ 54662306a36Sopenharmony_ci} while (0) 54762306a36Sopenharmony_ci 54862306a36Sopenharmony_ci#define DBG(fmt, args...) \ 54962306a36Sopenharmony_ci pr_err("%s:%-5d: " fmt, __func__, __LINE__, ## args) 55062306a36Sopenharmony_ci#else 55162306a36Sopenharmony_ci#define ENTER do { } while (0) 55262306a36Sopenharmony_ci#define RET(args...) return args 55362306a36Sopenharmony_ci#define DBG(fmt, args...) \ 55462306a36Sopenharmony_cido { \ 55562306a36Sopenharmony_ci if (0) \ 55662306a36Sopenharmony_ci pr_err(fmt, ##args); \ 55762306a36Sopenharmony_ci} while (0) 55862306a36Sopenharmony_ci#endif 55962306a36Sopenharmony_ci 56062306a36Sopenharmony_ci#endif /* _BDX__H */ 561