1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef __BCMASP_H 3 #define __BCMASP_H 4 5 #include <linux/netdevice.h> 6 #include <linux/phy.h> 7 #include <linux/io-64-nonatomic-hi-lo.h> 8 #include <uapi/linux/ethtool.h> 9 10 #define ASP_INTR2_OFFSET 0x1000 11 #define ASP_INTR2_STATUS 0x0 12 #define ASP_INTR2_SET 0x4 13 #define ASP_INTR2_CLEAR 0x8 14 #define ASP_INTR2_MASK_STATUS 0xc 15 #define ASP_INTR2_MASK_SET 0x10 16 #define ASP_INTR2_MASK_CLEAR 0x14 17 18 #define ASP_INTR2_RX_ECH(intr) BIT(intr) 19 #define ASP_INTR2_TX_DESC(intr) BIT((intr) + 14) 20 #define ASP_INTR2_UMC0_WAKE BIT(22) 21 #define ASP_INTR2_UMC1_WAKE BIT(28) 22 23 #define ASP_WAKEUP_INTR2_OFFSET 0x1200 24 #define ASP_WAKEUP_INTR2_STATUS 0x0 25 #define ASP_WAKEUP_INTR2_SET 0x4 26 #define ASP_WAKEUP_INTR2_CLEAR 0x8 27 #define ASP_WAKEUP_INTR2_MASK_STATUS 0xc 28 #define ASP_WAKEUP_INTR2_MASK_SET 0x10 29 #define ASP_WAKEUP_INTR2_MASK_CLEAR 0x14 30 #define ASP_WAKEUP_INTR2_MPD_0 BIT(0) 31 #define ASP_WAKEUP_INTR2_MPD_1 BIT(1) 32 #define ASP_WAKEUP_INTR2_FILT_0 BIT(2) 33 #define ASP_WAKEUP_INTR2_FILT_1 BIT(3) 34 #define ASP_WAKEUP_INTR2_FW BIT(4) 35 36 #define ASP_TX_ANALYTICS_OFFSET 0x4c000 37 #define ASP_TX_ANALYTICS_CTRL 0x0 38 39 #define ASP_RX_ANALYTICS_OFFSET 0x98000 40 #define ASP_RX_ANALYTICS_CTRL 0x0 41 42 #define ASP_RX_CTRL_OFFSET 0x9f000 43 #define ASP_RX_CTRL_UMAC_0_FRAME_COUNT 0x8 44 #define ASP_RX_CTRL_UMAC_1_FRAME_COUNT 0xc 45 #define ASP_RX_CTRL_FB_0_FRAME_COUNT 0x14 46 #define ASP_RX_CTRL_FB_1_FRAME_COUNT 0x18 47 #define ASP_RX_CTRL_FB_8_FRAME_COUNT 0x1c 48 /* asp2.1 diverges offsets here */ 49 /* ASP2.0 */ 50 #define ASP_RX_CTRL_FB_OUT_FRAME_COUNT 0x20 51 #define ASP_RX_CTRL_FB_FILT_OUT_FRAME_COUNT 0x24 52 #define ASP_RX_CTRL_FLUSH 0x28 53 #define ASP_CTRL_UMAC0_FLUSH_MASK (BIT(0) | BIT(12)) 54 #define ASP_CTRL_UMAC1_FLUSH_MASK (BIT(1) | BIT(13)) 55 #define ASP_CTRL_SPB_FLUSH_MASK (BIT(8) | BIT(20)) 56 #define ASP_RX_CTRL_FB_RX_FIFO_DEPTH 0x30 57 /* ASP2.1 */ 58 #define ASP_RX_CTRL_FB_9_FRAME_COUNT_2_1 0x20 59 #define ASP_RX_CTRL_FB_10_FRAME_COUNT_2_1 0x24 60 #define ASP_RX_CTRL_FB_OUT_FRAME_COUNT_2_1 0x28 61 #define ASP_RX_CTRL_FB_FILT_OUT_FRAME_COUNT_2_1 0x2c 62 #define ASP_RX_CTRL_FLUSH_2_1 0x30 63 #define ASP_RX_CTRL_FB_RX_FIFO_DEPTH_2_1 0x38 64 65 #define ASP_RX_FILTER_OFFSET 0x80000 66 #define ASP_RX_FILTER_BLK_CTRL 0x0 67 #define ASP_RX_FILTER_OPUT_EN BIT(0) 68 #define ASP_RX_FILTER_MDA_EN BIT(1) 69 #define ASP_RX_FILTER_LNR_MD BIT(2) 70 #define ASP_RX_FILTER_GEN_WK_EN BIT(3) 71 #define ASP_RX_FILTER_GEN_WK_CLR BIT(4) 72 #define ASP_RX_FILTER_NT_FLT_EN BIT(5) 73 #define ASP_RX_FILTER_MDA_CFG(sel) (((sel) * 0x14) + 0x100) 74 #define ASP_RX_FILTER_MDA_CFG_EN_SHIFT 8 75 #define ASP_RX_FILTER_MDA_CFG_UMC_SEL(sel) ((sel) > 1 ? BIT(17) : \ 76 BIT((sel) + 9)) 77 #define ASP_RX_FILTER_MDA_PAT_H(sel) (((sel) * 0x14) + 0x104) 78 #define ASP_RX_FILTER_MDA_PAT_L(sel) (((sel) * 0x14) + 0x108) 79 #define ASP_RX_FILTER_MDA_MSK_H(sel) (((sel) * 0x14) + 0x10c) 80 #define ASP_RX_FILTER_MDA_MSK_L(sel) (((sel) * 0x14) + 0x110) 81 #define ASP_RX_FILTER_MDA_CFG(sel) (((sel) * 0x14) + 0x100) 82 #define ASP_RX_FILTER_MDA_PAT_H(sel) (((sel) * 0x14) + 0x104) 83 #define ASP_RX_FILTER_MDA_PAT_L(sel) (((sel) * 0x14) + 0x108) 84 #define ASP_RX_FILTER_MDA_MSK_H(sel) (((sel) * 0x14) + 0x10c) 85 #define ASP_RX_FILTER_MDA_MSK_L(sel) (((sel) * 0x14) + 0x110) 86 #define ASP_RX_FILTER_NET_CFG(sel) (((sel) * 0xa04) + 0x400) 87 #define ASP_RX_FILTER_NET_CFG_CH(sel) ((sel) << 0) 88 #define ASP_RX_FILTER_NET_CFG_EN BIT(9) 89 #define ASP_RX_FILTER_NET_CFG_L2_EN BIT(10) 90 #define ASP_RX_FILTER_NET_CFG_L3_EN BIT(11) 91 #define ASP_RX_FILTER_NET_CFG_L4_EN BIT(12) 92 #define ASP_RX_FILTER_NET_CFG_L3_FRM(sel) ((sel) << 13) 93 #define ASP_RX_FILTER_NET_CFG_L4_FRM(sel) ((sel) << 15) 94 #define ASP_RX_FILTER_NET_CFG_UMC(sel) BIT((sel) + 19) 95 #define ASP_RX_FILTER_NET_CFG_DMA_EN BIT(27) 96 97 #define ASP_RX_FILTER_NET_OFFSET_MAX 32 98 #define ASP_RX_FILTER_NET_PAT(sel, block, off) \ 99 (((sel) * 0xa04) + ((block) * 0x200) + (off) + 0x600) 100 #define ASP_RX_FILTER_NET_MASK(sel, block, off) \ 101 (((sel) * 0xa04) + ((block) * 0x200) + (off) + 0x700) 102 103 #define ASP_RX_FILTER_NET_OFFSET(sel) (((sel) * 0xa04) + 0xe00) 104 #define ASP_RX_FILTER_NET_OFFSET_L2(val) ((val) << 0) 105 #define ASP_RX_FILTER_NET_OFFSET_L3_0(val) ((val) << 8) 106 #define ASP_RX_FILTER_NET_OFFSET_L3_1(val) ((val) << 16) 107 #define ASP_RX_FILTER_NET_OFFSET_L4(val) ((val) << 24) 108 109 enum asp_rx_net_filter_block { 110 ASP_RX_FILTER_NET_L2 = 0, 111 ASP_RX_FILTER_NET_L3_0, 112 ASP_RX_FILTER_NET_L3_1, 113 ASP_RX_FILTER_NET_L4, 114 ASP_RX_FILTER_NET_BLOCK_MAX 115 }; 116 117 #define ASP_EDPKT_OFFSET 0x9c000 118 #define ASP_EDPKT_ENABLE 0x4 119 #define ASP_EDPKT_ENABLE_EN BIT(0) 120 #define ASP_EDPKT_HDR_CFG 0xc 121 #define ASP_EDPKT_HDR_SZ_SHIFT 2 122 #define ASP_EDPKT_HDR_SZ_32 0 123 #define ASP_EDPKT_HDR_SZ_64 1 124 #define ASP_EDPKT_HDR_SZ_96 2 125 #define ASP_EDPKT_HDR_SZ_128 3 126 #define ASP_EDPKT_BURST_BUF_PSCAL_TOUT 0x10 127 #define ASP_EDPKT_BURST_BUF_WRITE_TOUT 0x14 128 #define ASP_EDPKT_BURST_BUF_READ_TOUT 0x18 129 #define ASP_EDPKT_RX_TS_COUNTER 0x38 130 #define ASP_EDPKT_ENDI 0x48 131 #define ASP_EDPKT_ENDI_DESC_SHIFT 8 132 #define ASP_EDPKT_ENDI_NO_BT_SWP 0 133 #define ASP_EDPKT_ENDI_BT_SWP_WD 1 134 #define ASP_EDPKT_RX_PKT_CNT 0x138 135 #define ASP_EDPKT_HDR_EXTR_CNT 0x13c 136 #define ASP_EDPKT_HDR_OUT_CNT 0x140 137 138 #define ASP_CTRL 0x101000 139 #define ASP_CTRL_ASP_SW_INIT 0x04 140 #define ASP_CTRL_ASP_SW_INIT_ACPUSS_CORE BIT(0) 141 #define ASP_CTRL_ASP_SW_INIT_ASP_TX BIT(1) 142 #define ASP_CTRL_ASP_SW_INIT_AS_RX BIT(2) 143 #define ASP_CTRL_ASP_SW_INIT_ASP_RGMII_UMAC0 BIT(3) 144 #define ASP_CTRL_ASP_SW_INIT_ASP_RGMII_UMAC1 BIT(4) 145 #define ASP_CTRL_ASP_SW_INIT_ASP_XMEMIF BIT(5) 146 #define ASP_CTRL_CLOCK_CTRL 0x04 147 #define ASP_CTRL_CLOCK_CTRL_ASP_TX_DISABLE BIT(0) 148 #define ASP_CTRL_CLOCK_CTRL_ASP_RX_DISABLE BIT(1) 149 #define ASP_CTRL_CLOCK_CTRL_ASP_RGMII_SHIFT 2 150 #define ASP_CTRL_CLOCK_CTRL_ASP_RGMII_MASK (0x7 << ASP_CTRL_CLOCK_CTRL_ASP_RGMII_SHIFT) 151 #define ASP_CTRL_CLOCK_CTRL_ASP_RGMII_DIS(x) BIT(ASP_CTRL_CLOCK_CTRL_ASP_RGMII_SHIFT + (x)) 152 #define ASP_CTRL_CLOCK_CTRL_ASP_ALL_DISABLE GENMASK(4, 0) 153 #define ASP_CTRL_CORE_CLOCK_SELECT 0x08 154 #define ASP_CTRL_CORE_CLOCK_SELECT_MAIN BIT(0) 155 #define ASP_CTRL_SCRATCH_0 0x0c 156 157 struct bcmasp_tx_cb { 158 struct sk_buff *skb; 159 unsigned int bytes_sent; 160 bool last; 161 162 DEFINE_DMA_UNMAP_ADDR(dma_addr); 163 DEFINE_DMA_UNMAP_LEN(dma_len); 164 }; 165 166 struct bcmasp_res { 167 /* Per interface resources */ 168 /* Port */ 169 void __iomem *umac; 170 void __iomem *umac2fb; 171 void __iomem *rgmii; 172 173 /* TX slowpath/configuration */ 174 void __iomem *tx_spb_ctrl; 175 void __iomem *tx_spb_top; 176 void __iomem *tx_epkt_core; 177 void __iomem *tx_pause_ctrl; 178 }; 179 180 #define DESC_ADDR(x) ((x) & GENMASK_ULL(39, 0)) 181 #define DESC_FLAGS(x) ((x) & GENMASK_ULL(63, 40)) 182 183 struct bcmasp_desc { 184 u64 buf; 185 #define DESC_CHKSUM BIT_ULL(40) 186 #define DESC_CRC_ERR BIT_ULL(41) 187 #define DESC_RX_SYM_ERR BIT_ULL(42) 188 #define DESC_NO_OCT_ALN BIT_ULL(43) 189 #define DESC_PKT_TRUC BIT_ULL(44) 190 /* 39:0 (TX/RX) bits 0-39 of buf addr 191 * 40 (RX) checksum 192 * 41 (RX) crc_error 193 * 42 (RX) rx_symbol_error 194 * 43 (RX) non_octet_aligned 195 * 44 (RX) pkt_truncated 196 * 45 Reserved 197 * 56:46 (RX) mac_filter_id 198 * 60:57 (RX) rx_port_num (0-unicmac0, 1-unimac1) 199 * 61 Reserved 200 * 63:62 (TX) forward CRC, overwrite CRC 201 */ 202 u32 size; 203 u32 flags; 204 #define DESC_INT_EN BIT(0) 205 #define DESC_SOF BIT(1) 206 #define DESC_EOF BIT(2) 207 #define DESC_EPKT_CMD BIT(3) 208 #define DESC_SCRAM_ST BIT(8) 209 #define DESC_SCRAM_END BIT(9) 210 #define DESC_PCPP BIT(10) 211 #define DESC_PPPP BIT(11) 212 /* 0 (TX) tx_int_en 213 * 1 (TX/RX) SOF 214 * 2 (TX/RX) EOF 215 * 3 (TX) epkt_command 216 * 6:4 (TX) PA 217 * 7 (TX) pause at desc end 218 * 8 (TX) scram_start 219 * 9 (TX) scram_end 220 * 10 (TX) PCPP 221 * 11 (TX) PPPP 222 * 14:12 Reserved 223 * 15 (TX) pid ch Valid 224 * 19:16 (TX) data_pkt_type 225 * 32:20 (TX) pid_channel (RX) nw_filter_id 226 */ 227 }; 228 229 struct bcmasp_intf; 230 231 struct bcmasp_intf_stats64 { 232 /* Rx Stats */ 233 u64_stats_t rx_packets; 234 u64_stats_t rx_bytes; 235 u64_stats_t rx_errors; 236 u64_stats_t rx_dropped; 237 u64_stats_t rx_crc_errs; 238 u64_stats_t rx_sym_errs; 239 240 /* Tx Stats*/ 241 u64_stats_t tx_packets; 242 u64_stats_t tx_bytes; 243 244 struct u64_stats_sync syncp; 245 }; 246 247 struct bcmasp_mib_counters { 248 u32 edpkt_ts; 249 u32 edpkt_rx_pkt_cnt; 250 u32 edpkt_hdr_ext_cnt; 251 u32 edpkt_hdr_out_cnt; 252 u32 umac_frm_cnt; 253 u32 fb_frm_cnt; 254 u32 fb_rx_fifo_depth; 255 u32 fb_out_frm_cnt; 256 u32 fb_filt_out_frm_cnt; 257 u32 alloc_rx_skb_failed; 258 u32 tx_dma_failed; 259 u32 mc_filters_full_cnt; 260 u32 uc_filters_full_cnt; 261 u32 filters_combine_cnt; 262 u32 promisc_filters_cnt; 263 u32 tx_realloc_offload_failed; 264 u32 tx_timeout_cnt; 265 }; 266 267 struct bcmasp_intf_ops { 268 unsigned long (*rx_desc_read)(struct bcmasp_intf *intf); 269 void (*rx_buffer_write)(struct bcmasp_intf *intf, dma_addr_t addr); 270 void (*rx_desc_write)(struct bcmasp_intf *intf, dma_addr_t addr); 271 unsigned long (*tx_read)(struct bcmasp_intf *intf); 272 void (*tx_write)(struct bcmasp_intf *intf, dma_addr_t addr); 273 }; 274 275 struct bcmasp_priv; 276 277 struct bcmasp_intf { 278 struct list_head list; 279 struct net_device *ndev; 280 struct bcmasp_priv *parent; 281 282 /* ASP Ch */ 283 int channel; 284 int port; 285 const struct bcmasp_intf_ops *ops; 286 287 /* Used for splitting shared resources */ 288 int index; 289 290 struct napi_struct tx_napi; 291 /* TX ring, starts on a new cacheline boundary */ 292 void __iomem *tx_spb_dma; 293 int tx_spb_index; 294 int tx_spb_clean_index; 295 struct bcmasp_desc *tx_spb_cpu; 296 dma_addr_t tx_spb_dma_addr; 297 dma_addr_t tx_spb_dma_valid; 298 dma_addr_t tx_spb_dma_read; 299 struct bcmasp_tx_cb *tx_cbs; 300 301 /* RX ring, starts on a new cacheline boundary */ 302 void __iomem *rx_edpkt_cfg; 303 void __iomem *rx_edpkt_dma; 304 int rx_edpkt_index; 305 int rx_buf_order; 306 struct bcmasp_desc *rx_edpkt_cpu; 307 dma_addr_t rx_edpkt_dma_addr; 308 dma_addr_t rx_edpkt_dma_read; 309 310 /* RX buffer prefetcher ring*/ 311 void *rx_ring_cpu; 312 dma_addr_t rx_ring_dma; 313 dma_addr_t rx_ring_dma_valid; 314 struct napi_struct rx_napi; 315 316 struct bcmasp_res res; 317 unsigned int crc_fwd; 318 319 /* PHY device */ 320 struct device_node *phy_dn; 321 struct device_node *ndev_dn; 322 phy_interface_t phy_interface; 323 bool internal_phy; 324 int old_pause; 325 int old_link; 326 int old_duplex; 327 328 u32 msg_enable; 329 330 /* Statistics */ 331 struct bcmasp_intf_stats64 stats64; 332 struct bcmasp_mib_counters mib; 333 334 u32 wolopts; 335 u8 sopass[SOPASS_MAX]; 336 /* Used if per intf wol irq */ 337 int wol_irq; 338 unsigned int wol_irq_enabled:1; 339 340 struct ethtool_eee eee; 341 }; 342 343 #define NUM_NET_FILTERS 32 344 struct bcmasp_net_filter { 345 struct ethtool_rx_flow_spec fs; 346 347 bool claimed; 348 bool wake_filter; 349 350 int port; 351 unsigned int hw_index; 352 }; 353 354 #define NUM_MDA_FILTERS 32 355 struct bcmasp_mda_filter { 356 /* Current owner of this filter */ 357 int port; 358 bool en; 359 u8 addr[ETH_ALEN]; 360 u8 mask[ETH_ALEN]; 361 }; 362 363 struct bcmasp_hw_info { 364 u32 rx_ctrl_flush; 365 u32 umac2fb; 366 u32 rx_ctrl_fb_out_frame_count; 367 u32 rx_ctrl_fb_filt_out_frame_count; 368 u32 rx_ctrl_fb_rx_fifo_depth; 369 }; 370 371 struct bcmasp_plat_data { 372 void (*init_wol)(struct bcmasp_priv *priv); 373 void (*enable_wol)(struct bcmasp_intf *intf, bool en); 374 void (*destroy_wol)(struct bcmasp_priv *priv); 375 struct bcmasp_hw_info *hw_info; 376 }; 377 378 struct bcmasp_priv { 379 struct platform_device *pdev; 380 struct clk *clk; 381 382 int irq; 383 u32 irq_mask; 384 385 /* Used if shared wol irq */ 386 struct mutex wol_lock; 387 int wol_irq; 388 unsigned long wol_irq_enabled_mask; 389 390 void (*init_wol)(struct bcmasp_priv *priv); 391 void (*enable_wol)(struct bcmasp_intf *intf, bool en); 392 void (*destroy_wol)(struct bcmasp_priv *priv); 393 394 void __iomem *base; 395 struct bcmasp_hw_info *hw_info; 396 397 struct list_head intfs; 398 399 struct bcmasp_mda_filter mda_filters[NUM_MDA_FILTERS]; 400 401 /* MAC destination address filters lock */ 402 spinlock_t mda_lock; 403 404 /* Protects accesses to ASP_CTRL_CLOCK_CTRL */ 405 spinlock_t clk_lock; 406 407 struct bcmasp_net_filter net_filters[NUM_NET_FILTERS]; 408 409 /* Network filter lock */ 410 struct mutex net_lock; 411 }; 412 413 static inline unsigned long bcmasp_intf_rx_desc_read(struct bcmasp_intf *intf) 414 { 415 return intf->ops->rx_desc_read(intf); 416 } 417 418 static inline void bcmasp_intf_rx_buffer_write(struct bcmasp_intf *intf, 419 dma_addr_t addr) 420 { 421 intf->ops->rx_buffer_write(intf, addr); 422 } 423 424 static inline void bcmasp_intf_rx_desc_write(struct bcmasp_intf *intf, 425 dma_addr_t addr) 426 { 427 intf->ops->rx_desc_write(intf, addr); 428 } 429 430 static inline unsigned long bcmasp_intf_tx_read(struct bcmasp_intf *intf) 431 { 432 return intf->ops->tx_read(intf); 433 } 434 435 static inline void bcmasp_intf_tx_write(struct bcmasp_intf *intf, 436 dma_addr_t addr) 437 { 438 intf->ops->tx_write(intf, addr); 439 } 440 441 #define __BCMASP_IO_MACRO(name, m) \ 442 static inline u32 name##_rl(struct bcmasp_intf *intf, u32 off) \ 443 { \ 444 u32 reg = readl_relaxed(intf->m + off); \ 445 return reg; \ 446 } \ 447 static inline void name##_wl(struct bcmasp_intf *intf, u32 val, u32 off)\ 448 { \ 449 writel_relaxed(val, intf->m + off); \ 450 } 451 452 #define BCMASP_IO_MACRO(name) __BCMASP_IO_MACRO(name, res.name) 453 #define BCMASP_FP_IO_MACRO(name) __BCMASP_IO_MACRO(name, name) 454 455 BCMASP_IO_MACRO(umac); 456 BCMASP_IO_MACRO(umac2fb); 457 BCMASP_IO_MACRO(rgmii); 458 BCMASP_FP_IO_MACRO(tx_spb_dma); 459 BCMASP_IO_MACRO(tx_spb_ctrl); 460 BCMASP_IO_MACRO(tx_spb_top); 461 BCMASP_IO_MACRO(tx_epkt_core); 462 BCMASP_IO_MACRO(tx_pause_ctrl); 463 BCMASP_FP_IO_MACRO(rx_edpkt_dma); 464 BCMASP_FP_IO_MACRO(rx_edpkt_cfg); 465 466 #define __BCMASP_FP_IO_MACRO_Q(name, m) \ 467 static inline u64 name##_rq(struct bcmasp_intf *intf, u32 off) \ 468 { \ 469 u64 reg = readq_relaxed(intf->m + off); \ 470 return reg; \ 471 } \ 472 static inline void name##_wq(struct bcmasp_intf *intf, u64 val, u32 off)\ 473 { \ 474 writeq_relaxed(val, intf->m + off); \ 475 } 476 477 #define BCMASP_FP_IO_MACRO_Q(name) __BCMASP_FP_IO_MACRO_Q(name, name) 478 479 BCMASP_FP_IO_MACRO_Q(tx_spb_dma); 480 BCMASP_FP_IO_MACRO_Q(rx_edpkt_dma); 481 BCMASP_FP_IO_MACRO_Q(rx_edpkt_cfg); 482 483 #define PKT_OFFLOAD_NOP (0 << 28) 484 #define PKT_OFFLOAD_HDR_OP (1 << 28) 485 #define PKT_OFFLOAD_HDR_WRBACK BIT(19) 486 #define PKT_OFFLOAD_HDR_COUNT(x) ((x) << 16) 487 #define PKT_OFFLOAD_HDR_SIZE_1(x) ((x) << 4) 488 #define PKT_OFFLOAD_HDR_SIZE_2(x) (x) 489 #define PKT_OFFLOAD_HDR2_SIZE_2(x) ((x) << 24) 490 #define PKT_OFFLOAD_HDR2_SIZE_3(x) ((x) << 12) 491 #define PKT_OFFLOAD_HDR2_SIZE_4(x) (x) 492 #define PKT_OFFLOAD_EPKT_OP (2 << 28) 493 #define PKT_OFFLOAD_EPKT_WRBACK BIT(23) 494 #define PKT_OFFLOAD_EPKT_IP(x) ((x) << 21) 495 #define PKT_OFFLOAD_EPKT_TP(x) ((x) << 19) 496 #define PKT_OFFLOAD_EPKT_LEN(x) ((x) << 16) 497 #define PKT_OFFLOAD_EPKT_CSUM_L3 BIT(15) 498 #define PKT_OFFLOAD_EPKT_CSUM_L2 BIT(14) 499 #define PKT_OFFLOAD_EPKT_ID(x) ((x) << 12) 500 #define PKT_OFFLOAD_EPKT_SEQ(x) ((x) << 10) 501 #define PKT_OFFLOAD_EPKT_TS(x) ((x) << 8) 502 #define PKT_OFFLOAD_EPKT_BLOC(x) (x) 503 #define PKT_OFFLOAD_END_OP (7 << 28) 504 505 struct bcmasp_pkt_offload { 506 __be32 nop; 507 __be32 header; 508 __be32 header2; 509 __be32 epkt; 510 __be32 end; 511 }; 512 513 #define BCMASP_CORE_IO_MACRO(name, offset) \ 514 static inline u32 name##_core_rl(struct bcmasp_priv *priv, \ 515 u32 off) \ 516 { \ 517 u32 reg = readl_relaxed(priv->base + (offset) + off); \ 518 return reg; \ 519 } \ 520 static inline void name##_core_wl(struct bcmasp_priv *priv, \ 521 u32 val, u32 off) \ 522 { \ 523 writel_relaxed(val, priv->base + (offset) + off); \ 524 } 525 526 BCMASP_CORE_IO_MACRO(intr2, ASP_INTR2_OFFSET); 527 BCMASP_CORE_IO_MACRO(wakeup_intr2, ASP_WAKEUP_INTR2_OFFSET); 528 BCMASP_CORE_IO_MACRO(tx_analytics, ASP_TX_ANALYTICS_OFFSET); 529 BCMASP_CORE_IO_MACRO(rx_analytics, ASP_RX_ANALYTICS_OFFSET); 530 BCMASP_CORE_IO_MACRO(rx_ctrl, ASP_RX_CTRL_OFFSET); 531 BCMASP_CORE_IO_MACRO(rx_filter, ASP_RX_FILTER_OFFSET); 532 BCMASP_CORE_IO_MACRO(rx_edpkt, ASP_EDPKT_OFFSET); 533 BCMASP_CORE_IO_MACRO(ctrl, ASP_CTRL); 534 535 struct bcmasp_intf *bcmasp_interface_create(struct bcmasp_priv *priv, 536 struct device_node *ndev_dn, int i); 537 538 void bcmasp_interface_destroy(struct bcmasp_intf *intf); 539 540 void bcmasp_enable_tx_irq(struct bcmasp_intf *intf, int en); 541 542 void bcmasp_enable_rx_irq(struct bcmasp_intf *intf, int en); 543 544 void bcmasp_flush_rx_port(struct bcmasp_intf *intf); 545 546 extern const struct ethtool_ops bcmasp_ethtool_ops; 547 548 int bcmasp_interface_suspend(struct bcmasp_intf *intf); 549 550 int bcmasp_interface_resume(struct bcmasp_intf *intf); 551 552 void bcmasp_set_promisc(struct bcmasp_intf *intf, bool en); 553 554 void bcmasp_set_allmulti(struct bcmasp_intf *intf, bool en); 555 556 void bcmasp_set_broad(struct bcmasp_intf *intf, bool en); 557 558 void bcmasp_set_oaddr(struct bcmasp_intf *intf, const unsigned char *addr, 559 bool en); 560 561 int bcmasp_set_en_mda_filter(struct bcmasp_intf *intf, unsigned char *addr, 562 unsigned char *mask); 563 564 void bcmasp_disable_all_filters(struct bcmasp_intf *intf); 565 566 void bcmasp_core_clock_set_intf(struct bcmasp_intf *intf, bool en); 567 568 struct bcmasp_net_filter *bcmasp_netfilt_get_init(struct bcmasp_intf *intf, 569 u32 loc, bool wake_filter, 570 bool init); 571 572 bool bcmasp_netfilt_check_dup(struct bcmasp_intf *intf, 573 struct ethtool_rx_flow_spec *fs); 574 575 void bcmasp_netfilt_release(struct bcmasp_intf *intf, 576 struct bcmasp_net_filter *nfilt); 577 578 int bcmasp_netfilt_get_active(struct bcmasp_intf *intf); 579 580 void bcmasp_netfilt_get_all_active(struct bcmasp_intf *intf, u32 *rule_locs, 581 u32 *rule_cnt); 582 583 void bcmasp_netfilt_suspend(struct bcmasp_intf *intf); 584 585 void bcmasp_eee_enable_set(struct bcmasp_intf *intf, bool enable); 586 #endif 587