xref: /linux/drivers/net/ethernet/mediatek/mtk_ppe.c (revision fe7c551ea03e0df729966e33c58f9955f7408208)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /* Copyright (C) 2020 Felix Fietkau <nbd@nbd.name> */
3 
4 #include <linux/kernel.h>
5 #include <linux/io.h>
6 #include <linux/iopoll.h>
7 #include <linux/etherdevice.h>
8 #include <linux/platform_device.h>
9 #include <linux/if_ether.h>
10 #include <linux/if_vlan.h>
11 #include <net/dst_metadata.h>
12 #include <net/dsa.h>
13 #include "mtk_eth_soc.h"
14 #include "mtk_ppe.h"
15 #include "mtk_ppe_regs.h"
16 
17 static DEFINE_SPINLOCK(ppe_lock);
18 
19 static const struct rhashtable_params mtk_flow_l2_ht_params = {
20 	.head_offset = offsetof(struct mtk_flow_entry, l2_node),
21 	.key_offset = offsetof(struct mtk_flow_entry, data.bridge),
22 	.key_len = offsetof(struct mtk_foe_bridge, key_end),
23 	.automatic_shrinking = true,
24 };
25 
26 static void ppe_w32(struct mtk_ppe *ppe, u32 reg, u32 val)
27 {
28 	writel(val, ppe->base + reg);
29 }
30 
31 static u32 ppe_r32(struct mtk_ppe *ppe, u32 reg)
32 {
33 	return readl(ppe->base + reg);
34 }
35 
36 static u32 ppe_m32(struct mtk_ppe *ppe, u32 reg, u32 mask, u32 set)
37 {
38 	u32 val;
39 
40 	val = ppe_r32(ppe, reg);
41 	val &= ~mask;
42 	val |= set;
43 	ppe_w32(ppe, reg, val);
44 
45 	return val;
46 }
47 
48 static u32 ppe_set(struct mtk_ppe *ppe, u32 reg, u32 val)
49 {
50 	return ppe_m32(ppe, reg, 0, val);
51 }
52 
53 static u32 ppe_clear(struct mtk_ppe *ppe, u32 reg, u32 val)
54 {
55 	return ppe_m32(ppe, reg, val, 0);
56 }
57 
58 static u32 mtk_eth_timestamp(struct mtk_eth *eth)
59 {
60 	return mtk_r32(eth, 0x0010) & mtk_get_ib1_ts_mask(eth);
61 }
62 
63 static int mtk_ppe_wait_busy(struct mtk_ppe *ppe)
64 {
65 	int ret;
66 	u32 val;
67 
68 	ret = readl_poll_timeout(ppe->base + MTK_PPE_GLO_CFG, val,
69 				 !(val & MTK_PPE_GLO_CFG_BUSY),
70 				 20, MTK_PPE_WAIT_TIMEOUT_US);
71 
72 	if (ret)
73 		dev_err(ppe->dev, "PPE table busy");
74 
75 	return ret;
76 }
77 
78 static int mtk_ppe_mib_wait_busy(struct mtk_ppe *ppe)
79 {
80 	int ret;
81 	u32 val;
82 
83 	ret = readl_poll_timeout(ppe->base + MTK_PPE_MIB_SER_CR, val,
84 				 !(val & MTK_PPE_MIB_SER_CR_ST),
85 				 20, MTK_PPE_WAIT_TIMEOUT_US);
86 
87 	if (ret)
88 		dev_err(ppe->dev, "MIB table busy");
89 
90 	return ret;
91 }
92 
93 static int mtk_mib_entry_read(struct mtk_ppe *ppe, u16 index, u64 *bytes, u64 *packets)
94 {
95 	u32 val, cnt_r0, cnt_r1, cnt_r2;
96 	int ret;
97 
98 	val = FIELD_PREP(MTK_PPE_MIB_SER_CR_ADDR, index) | MTK_PPE_MIB_SER_CR_ST;
99 	ppe_w32(ppe, MTK_PPE_MIB_SER_CR, val);
100 
101 	ret = mtk_ppe_mib_wait_busy(ppe);
102 	if (ret)
103 		return ret;
104 
105 	cnt_r0 = readl(ppe->base + MTK_PPE_MIB_SER_R0);
106 	cnt_r1 = readl(ppe->base + MTK_PPE_MIB_SER_R1);
107 	cnt_r2 = readl(ppe->base + MTK_PPE_MIB_SER_R2);
108 
109 	if (mtk_is_netsys_v3_or_greater(ppe->eth)) {
110 		/* 64 bit for each counter */
111 		u32 cnt_r3 = readl(ppe->base + MTK_PPE_MIB_SER_R3);
112 		*bytes = ((u64)cnt_r1 << 32) | cnt_r0;
113 		*packets = ((u64)cnt_r3 << 32) | cnt_r2;
114 	} else {
115 		/* 48 bit byte counter, 40 bit packet counter */
116 		u32 byte_cnt_low = FIELD_GET(MTK_PPE_MIB_SER_R0_BYTE_CNT_LOW, cnt_r0);
117 		u32 byte_cnt_high = FIELD_GET(MTK_PPE_MIB_SER_R1_BYTE_CNT_HIGH, cnt_r1);
118 		u32 pkt_cnt_low = FIELD_GET(MTK_PPE_MIB_SER_R1_PKT_CNT_LOW, cnt_r1);
119 		u32 pkt_cnt_high = FIELD_GET(MTK_PPE_MIB_SER_R2_PKT_CNT_HIGH, cnt_r2);
120 		*bytes = ((u64)byte_cnt_high << 32) | byte_cnt_low;
121 		*packets = ((u64)pkt_cnt_high << 16) | pkt_cnt_low;
122 	}
123 
124 	return 0;
125 }
126 
127 static void mtk_ppe_cache_clear(struct mtk_ppe *ppe)
128 {
129 	ppe_set(ppe, MTK_PPE_CACHE_CTL, MTK_PPE_CACHE_CTL_CLEAR);
130 	ppe_clear(ppe, MTK_PPE_CACHE_CTL, MTK_PPE_CACHE_CTL_CLEAR);
131 }
132 
133 static void mtk_ppe_cache_enable(struct mtk_ppe *ppe, bool enable)
134 {
135 	mtk_ppe_cache_clear(ppe);
136 
137 	ppe_m32(ppe, MTK_PPE_CACHE_CTL, MTK_PPE_CACHE_CTL_EN,
138 		enable * MTK_PPE_CACHE_CTL_EN);
139 }
140 
141 static u32 mtk_ppe_hash_entry(struct mtk_eth *eth, struct mtk_foe_entry *e)
142 {
143 	u32 hv1, hv2, hv3;
144 	u32 hash;
145 
146 	switch (mtk_get_ib1_pkt_type(eth, e->ib1)) {
147 		case MTK_PPE_PKT_TYPE_IPV4_ROUTE:
148 		case MTK_PPE_PKT_TYPE_IPV4_HNAPT:
149 			hv1 = e->ipv4.orig.ports;
150 			hv2 = e->ipv4.orig.dest_ip;
151 			hv3 = e->ipv4.orig.src_ip;
152 			break;
153 		case MTK_PPE_PKT_TYPE_IPV6_ROUTE_3T:
154 		case MTK_PPE_PKT_TYPE_IPV6_ROUTE_5T:
155 			hv1 = e->ipv6.src_ip[3] ^ e->ipv6.dest_ip[3];
156 			hv1 ^= e->ipv6.ports;
157 
158 			hv2 = e->ipv6.src_ip[2] ^ e->ipv6.dest_ip[2];
159 			hv2 ^= e->ipv6.dest_ip[0];
160 
161 			hv3 = e->ipv6.src_ip[1] ^ e->ipv6.dest_ip[1];
162 			hv3 ^= e->ipv6.src_ip[0];
163 			break;
164 		case MTK_PPE_PKT_TYPE_IPV4_DSLITE:
165 		case MTK_PPE_PKT_TYPE_IPV6_6RD:
166 		default:
167 			WARN_ON_ONCE(1);
168 			return MTK_PPE_HASH_MASK;
169 	}
170 
171 	hash = (hv1 & hv2) | ((~hv1) & hv3);
172 	hash = (hash >> 24) | ((hash & 0xffffff) << 8);
173 	hash ^= hv1 ^ hv2 ^ hv3;
174 	hash ^= hash >> 16;
175 	hash <<= (ffs(eth->soc->hash_offset) - 1);
176 	hash &= MTK_PPE_ENTRIES - 1;
177 
178 	return hash;
179 }
180 
181 static inline struct mtk_foe_mac_info *
182 mtk_foe_entry_l2(struct mtk_eth *eth, struct mtk_foe_entry *entry)
183 {
184 	int type = mtk_get_ib1_pkt_type(eth, entry->ib1);
185 
186 	if (type == MTK_PPE_PKT_TYPE_BRIDGE)
187 		return &entry->bridge.l2;
188 
189 	if (type >= MTK_PPE_PKT_TYPE_IPV4_DSLITE)
190 		return &entry->ipv6.l2;
191 
192 	return &entry->ipv4.l2;
193 }
194 
195 static inline u32 *
196 mtk_foe_entry_ib2(struct mtk_eth *eth, struct mtk_foe_entry *entry)
197 {
198 	int type = mtk_get_ib1_pkt_type(eth, entry->ib1);
199 
200 	if (type == MTK_PPE_PKT_TYPE_BRIDGE)
201 		return &entry->bridge.ib2;
202 
203 	if (type >= MTK_PPE_PKT_TYPE_IPV4_DSLITE)
204 		return &entry->ipv6.ib2;
205 
206 	return &entry->ipv4.ib2;
207 }
208 
209 int mtk_foe_entry_prepare(struct mtk_eth *eth, struct mtk_foe_entry *entry,
210 			  int type, int l4proto, u8 pse_port, u8 *src_mac,
211 			  u8 *dest_mac)
212 {
213 	struct mtk_foe_mac_info *l2;
214 	u32 ports_pad, val;
215 
216 	memset(entry, 0, sizeof(*entry));
217 
218 	if (mtk_is_netsys_v2_or_greater(eth)) {
219 		val = FIELD_PREP(MTK_FOE_IB1_STATE, MTK_FOE_STATE_BIND) |
220 		      FIELD_PREP(MTK_FOE_IB1_PACKET_TYPE_V2, type) |
221 		      FIELD_PREP(MTK_FOE_IB1_UDP, l4proto == IPPROTO_UDP) |
222 		      MTK_FOE_IB1_BIND_CACHE_V2 | MTK_FOE_IB1_BIND_TTL_V2;
223 		entry->ib1 = val;
224 
225 		val = FIELD_PREP(MTK_FOE_IB2_DEST_PORT_V2, pse_port) |
226 		      FIELD_PREP(MTK_FOE_IB2_PORT_AG_V2, 0xf);
227 	} else {
228 		int port_mg = eth->soc->offload_version > 1 ? 0 : 0x3f;
229 
230 		val = FIELD_PREP(MTK_FOE_IB1_STATE, MTK_FOE_STATE_BIND) |
231 		      FIELD_PREP(MTK_FOE_IB1_PACKET_TYPE, type) |
232 		      FIELD_PREP(MTK_FOE_IB1_UDP, l4proto == IPPROTO_UDP) |
233 		      MTK_FOE_IB1_BIND_CACHE | MTK_FOE_IB1_BIND_TTL;
234 		entry->ib1 = val;
235 
236 		val = FIELD_PREP(MTK_FOE_IB2_DEST_PORT, pse_port) |
237 		      FIELD_PREP(MTK_FOE_IB2_PORT_MG, port_mg) |
238 		      FIELD_PREP(MTK_FOE_IB2_PORT_AG, 0x1f);
239 	}
240 
241 	if (is_multicast_ether_addr(dest_mac))
242 		val |= mtk_get_ib2_multicast_mask(eth);
243 
244 	ports_pad = 0xa5a5a500 | (l4proto & 0xff);
245 	if (type == MTK_PPE_PKT_TYPE_IPV4_ROUTE)
246 		entry->ipv4.orig.ports = ports_pad;
247 	if (type == MTK_PPE_PKT_TYPE_IPV6_ROUTE_3T)
248 		entry->ipv6.ports = ports_pad;
249 
250 	if (type == MTK_PPE_PKT_TYPE_BRIDGE) {
251 		ether_addr_copy(entry->bridge.src_mac, src_mac);
252 		ether_addr_copy(entry->bridge.dest_mac, dest_mac);
253 		entry->bridge.ib2 = val;
254 		l2 = &entry->bridge.l2;
255 	} else if (type >= MTK_PPE_PKT_TYPE_IPV4_DSLITE) {
256 		entry->ipv6.ib2 = val;
257 		l2 = &entry->ipv6.l2;
258 	} else {
259 		entry->ipv4.ib2 = val;
260 		l2 = &entry->ipv4.l2;
261 	}
262 
263 	l2->dest_mac_hi = get_unaligned_be32(dest_mac);
264 	l2->dest_mac_lo = get_unaligned_be16(dest_mac + 4);
265 	l2->src_mac_hi = get_unaligned_be32(src_mac);
266 	l2->src_mac_lo = get_unaligned_be16(src_mac + 4);
267 
268 	if (type >= MTK_PPE_PKT_TYPE_IPV6_ROUTE_3T)
269 		l2->etype = ETH_P_IPV6;
270 	else
271 		l2->etype = ETH_P_IP;
272 
273 	return 0;
274 }
275 
276 int mtk_foe_entry_set_pse_port(struct mtk_eth *eth,
277 			       struct mtk_foe_entry *entry, u8 port)
278 {
279 	u32 *ib2 = mtk_foe_entry_ib2(eth, entry);
280 	u32 val = *ib2;
281 
282 	if (mtk_is_netsys_v2_or_greater(eth)) {
283 		val &= ~MTK_FOE_IB2_DEST_PORT_V2;
284 		val |= FIELD_PREP(MTK_FOE_IB2_DEST_PORT_V2, port);
285 	} else {
286 		val &= ~MTK_FOE_IB2_DEST_PORT;
287 		val |= FIELD_PREP(MTK_FOE_IB2_DEST_PORT, port);
288 	}
289 	*ib2 = val;
290 
291 	return 0;
292 }
293 
294 int mtk_foe_entry_set_ipv4_tuple(struct mtk_eth *eth,
295 				 struct mtk_foe_entry *entry, bool egress,
296 				 __be32 src_addr, __be16 src_port,
297 				 __be32 dest_addr, __be16 dest_port)
298 {
299 	int type = mtk_get_ib1_pkt_type(eth, entry->ib1);
300 	struct mtk_ipv4_tuple *t;
301 
302 	switch (type) {
303 	case MTK_PPE_PKT_TYPE_IPV4_HNAPT:
304 		if (egress) {
305 			t = &entry->ipv4.new;
306 			break;
307 		}
308 		fallthrough;
309 	case MTK_PPE_PKT_TYPE_IPV4_DSLITE:
310 	case MTK_PPE_PKT_TYPE_IPV4_ROUTE:
311 		t = &entry->ipv4.orig;
312 		break;
313 	case MTK_PPE_PKT_TYPE_IPV6_6RD:
314 		entry->ipv6_6rd.tunnel_src_ip = be32_to_cpu(src_addr);
315 		entry->ipv6_6rd.tunnel_dest_ip = be32_to_cpu(dest_addr);
316 		return 0;
317 	default:
318 		WARN_ON_ONCE(1);
319 		return -EINVAL;
320 	}
321 
322 	t->src_ip = be32_to_cpu(src_addr);
323 	t->dest_ip = be32_to_cpu(dest_addr);
324 
325 	if (type == MTK_PPE_PKT_TYPE_IPV4_ROUTE)
326 		return 0;
327 
328 	t->src_port = be16_to_cpu(src_port);
329 	t->dest_port = be16_to_cpu(dest_port);
330 
331 	return 0;
332 }
333 
334 int mtk_foe_entry_set_ipv6_tuple(struct mtk_eth *eth,
335 				 struct mtk_foe_entry *entry,
336 				 __be32 *src_addr, __be16 src_port,
337 				 __be32 *dest_addr, __be16 dest_port)
338 {
339 	int type = mtk_get_ib1_pkt_type(eth, entry->ib1);
340 	u32 *src, *dest;
341 	int i;
342 
343 	switch (type) {
344 	case MTK_PPE_PKT_TYPE_IPV4_DSLITE:
345 		src = entry->dslite.tunnel_src_ip;
346 		dest = entry->dslite.tunnel_dest_ip;
347 		break;
348 	case MTK_PPE_PKT_TYPE_IPV6_ROUTE_5T:
349 	case MTK_PPE_PKT_TYPE_IPV6_6RD:
350 		entry->ipv6.src_port = be16_to_cpu(src_port);
351 		entry->ipv6.dest_port = be16_to_cpu(dest_port);
352 		fallthrough;
353 	case MTK_PPE_PKT_TYPE_IPV6_ROUTE_3T:
354 		src = entry->ipv6.src_ip;
355 		dest = entry->ipv6.dest_ip;
356 		break;
357 	default:
358 		WARN_ON_ONCE(1);
359 		return -EINVAL;
360 	}
361 
362 	for (i = 0; i < 4; i++)
363 		src[i] = be32_to_cpu(src_addr[i]);
364 	for (i = 0; i < 4; i++)
365 		dest[i] = be32_to_cpu(dest_addr[i]);
366 
367 	return 0;
368 }
369 
370 int mtk_foe_entry_set_dsa(struct mtk_eth *eth, struct mtk_foe_entry *entry,
371 			  int port)
372 {
373 	struct mtk_foe_mac_info *l2 = mtk_foe_entry_l2(eth, entry);
374 
375 	l2->etype = BIT(port);
376 
377 	if (!(entry->ib1 & mtk_get_ib1_vlan_layer_mask(eth)))
378 		entry->ib1 |= mtk_prep_ib1_vlan_layer(eth, 1);
379 	else
380 		l2->etype |= BIT(8);
381 
382 	entry->ib1 &= ~mtk_get_ib1_vlan_tag_mask(eth);
383 
384 	return 0;
385 }
386 
387 int mtk_foe_entry_set_vlan(struct mtk_eth *eth, struct mtk_foe_entry *entry,
388 			   int vid)
389 {
390 	struct mtk_foe_mac_info *l2 = mtk_foe_entry_l2(eth, entry);
391 
392 	switch (mtk_get_ib1_vlan_layer(eth, entry->ib1)) {
393 	case 0:
394 		entry->ib1 |= mtk_get_ib1_vlan_tag_mask(eth) |
395 			      mtk_prep_ib1_vlan_layer(eth, 1);
396 		l2->vlan1 = vid;
397 		return 0;
398 	case 1:
399 		if (!(entry->ib1 & mtk_get_ib1_vlan_tag_mask(eth))) {
400 			l2->vlan1 = vid;
401 			l2->etype |= BIT(8);
402 		} else {
403 			l2->vlan2 = vid;
404 			entry->ib1 += mtk_prep_ib1_vlan_layer(eth, 1);
405 		}
406 		return 0;
407 	default:
408 		return -ENOSPC;
409 	}
410 }
411 
412 int mtk_foe_entry_set_pppoe(struct mtk_eth *eth, struct mtk_foe_entry *entry,
413 			    int sid)
414 {
415 	struct mtk_foe_mac_info *l2 = mtk_foe_entry_l2(eth, entry);
416 
417 	if (!(entry->ib1 & mtk_get_ib1_vlan_layer_mask(eth)) ||
418 	    (entry->ib1 & mtk_get_ib1_vlan_tag_mask(eth)))
419 		l2->etype = ETH_P_PPP_SES;
420 
421 	entry->ib1 |= mtk_get_ib1_ppoe_mask(eth);
422 	l2->pppoe_id = sid;
423 
424 	return 0;
425 }
426 
427 int mtk_foe_entry_set_wdma(struct mtk_eth *eth, struct mtk_foe_entry *entry,
428 			   int wdma_idx, int txq, int bss, int wcid,
429 			   bool amsdu_en)
430 {
431 	struct mtk_foe_mac_info *l2 = mtk_foe_entry_l2(eth, entry);
432 	u32 *ib2 = mtk_foe_entry_ib2(eth, entry);
433 
434 	switch (eth->soc->version) {
435 	case 3:
436 		*ib2 &= ~MTK_FOE_IB2_PORT_MG_V2;
437 		*ib2 |=  FIELD_PREP(MTK_FOE_IB2_RX_IDX, txq) |
438 			 MTK_FOE_IB2_WDMA_WINFO_V2;
439 		l2->w3info = FIELD_PREP(MTK_FOE_WINFO_WCID_V3, wcid) |
440 			     FIELD_PREP(MTK_FOE_WINFO_BSS_V3, bss);
441 		l2->amsdu = FIELD_PREP(MTK_FOE_WINFO_AMSDU_EN, amsdu_en);
442 		break;
443 	case 2:
444 		*ib2 &= ~MTK_FOE_IB2_PORT_MG_V2;
445 		*ib2 |=  FIELD_PREP(MTK_FOE_IB2_RX_IDX, txq) |
446 			 MTK_FOE_IB2_WDMA_WINFO_V2;
447 		l2->winfo = FIELD_PREP(MTK_FOE_WINFO_WCID, wcid) |
448 			    FIELD_PREP(MTK_FOE_WINFO_BSS, bss);
449 		break;
450 	default:
451 		*ib2 &= ~MTK_FOE_IB2_PORT_MG;
452 		*ib2 |= MTK_FOE_IB2_WDMA_WINFO;
453 		if (wdma_idx)
454 			*ib2 |= MTK_FOE_IB2_WDMA_DEVIDX;
455 		l2->vlan2 = FIELD_PREP(MTK_FOE_VLAN2_WINFO_BSS, bss) |
456 			    FIELD_PREP(MTK_FOE_VLAN2_WINFO_WCID, wcid) |
457 			    FIELD_PREP(MTK_FOE_VLAN2_WINFO_RING, txq);
458 		break;
459 	}
460 
461 	return 0;
462 }
463 
464 int mtk_foe_entry_set_queue(struct mtk_eth *eth, struct mtk_foe_entry *entry,
465 			    unsigned int queue)
466 {
467 	u32 *ib2 = mtk_foe_entry_ib2(eth, entry);
468 
469 	if (mtk_is_netsys_v2_or_greater(eth)) {
470 		*ib2 &= ~MTK_FOE_IB2_QID_V2;
471 		*ib2 |= FIELD_PREP(MTK_FOE_IB2_QID_V2, queue);
472 		*ib2 |= MTK_FOE_IB2_PSE_QOS_V2;
473 	} else {
474 		*ib2 &= ~MTK_FOE_IB2_QID;
475 		*ib2 |= FIELD_PREP(MTK_FOE_IB2_QID, queue);
476 		*ib2 |= MTK_FOE_IB2_PSE_QOS;
477 	}
478 
479 	return 0;
480 }
481 
482 static bool
483 mtk_flow_entry_match(struct mtk_eth *eth, struct mtk_flow_entry *entry,
484 		     struct mtk_foe_entry *data)
485 {
486 	int type, len;
487 
488 	if ((data->ib1 ^ entry->data.ib1) & MTK_FOE_IB1_UDP)
489 		return false;
490 
491 	type = mtk_get_ib1_pkt_type(eth, entry->data.ib1);
492 	if (type > MTK_PPE_PKT_TYPE_IPV4_DSLITE)
493 		len = offsetof(struct mtk_foe_entry, ipv6._rsv);
494 	else
495 		len = offsetof(struct mtk_foe_entry, ipv4.ib2);
496 
497 	return !memcmp(&entry->data.data, &data->data, len - 4);
498 }
499 
500 static void
501 __mtk_foe_entry_clear(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
502 {
503 	struct hlist_head *head;
504 	struct hlist_node *tmp;
505 
506 	if (entry->type == MTK_FLOW_TYPE_L2) {
507 		rhashtable_remove_fast(&ppe->l2_flows, &entry->l2_node,
508 				       mtk_flow_l2_ht_params);
509 
510 		head = &entry->l2_flows;
511 		hlist_for_each_entry_safe(entry, tmp, head, l2_data.list)
512 			__mtk_foe_entry_clear(ppe, entry);
513 		return;
514 	}
515 
516 	hlist_del_init(&entry->list);
517 	if (entry->hash != 0xffff) {
518 		struct mtk_foe_entry *hwe = mtk_foe_get_entry(ppe, entry->hash);
519 
520 		hwe->ib1 &= ~MTK_FOE_IB1_STATE;
521 		hwe->ib1 |= FIELD_PREP(MTK_FOE_IB1_STATE, MTK_FOE_STATE_INVALID);
522 		dma_wmb();
523 		mtk_ppe_cache_clear(ppe);
524 
525 		if (ppe->accounting) {
526 			struct mtk_foe_accounting *acct;
527 
528 			acct = ppe->acct_table + entry->hash * sizeof(*acct);
529 			acct->packets = 0;
530 			acct->bytes = 0;
531 		}
532 	}
533 	entry->hash = 0xffff;
534 
535 	if (entry->type != MTK_FLOW_TYPE_L2_SUBFLOW)
536 		return;
537 
538 	hlist_del_init(&entry->l2_data.list);
539 	kfree(entry);
540 }
541 
542 static int __mtk_foe_entry_idle_time(struct mtk_ppe *ppe, u32 ib1)
543 {
544 	u32 ib1_ts_mask = mtk_get_ib1_ts_mask(ppe->eth);
545 	u16 now = mtk_eth_timestamp(ppe->eth);
546 	u16 timestamp = ib1 & ib1_ts_mask;
547 
548 	if (timestamp > now)
549 		return ib1_ts_mask + 1 - timestamp + now;
550 	else
551 		return now - timestamp;
552 }
553 
554 static void
555 mtk_flow_entry_update_l2(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
556 {
557 	u32 ib1_ts_mask = mtk_get_ib1_ts_mask(ppe->eth);
558 	struct mtk_flow_entry *cur;
559 	struct mtk_foe_entry *hwe;
560 	struct hlist_node *tmp;
561 	int idle;
562 
563 	idle = __mtk_foe_entry_idle_time(ppe, entry->data.ib1);
564 	hlist_for_each_entry_safe(cur, tmp, &entry->l2_flows, l2_data.list) {
565 		int cur_idle;
566 		u32 ib1;
567 
568 		hwe = mtk_foe_get_entry(ppe, cur->hash);
569 		ib1 = READ_ONCE(hwe->ib1);
570 
571 		if (FIELD_GET(MTK_FOE_IB1_STATE, ib1) != MTK_FOE_STATE_BIND) {
572 			cur->hash = 0xffff;
573 			__mtk_foe_entry_clear(ppe, cur);
574 			continue;
575 		}
576 
577 		cur_idle = __mtk_foe_entry_idle_time(ppe, ib1);
578 		if (cur_idle >= idle)
579 			continue;
580 
581 		idle = cur_idle;
582 		entry->data.ib1 &= ~ib1_ts_mask;
583 		entry->data.ib1 |= ib1 & ib1_ts_mask;
584 	}
585 }
586 
587 static void
588 mtk_flow_entry_update(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
589 {
590 	struct mtk_foe_entry foe = {};
591 	struct mtk_foe_entry *hwe;
592 
593 	spin_lock_bh(&ppe_lock);
594 
595 	if (entry->type == MTK_FLOW_TYPE_L2) {
596 		mtk_flow_entry_update_l2(ppe, entry);
597 		goto out;
598 	}
599 
600 	if (entry->hash == 0xffff)
601 		goto out;
602 
603 	hwe = mtk_foe_get_entry(ppe, entry->hash);
604 	memcpy(&foe, hwe, ppe->eth->soc->foe_entry_size);
605 	if (!mtk_flow_entry_match(ppe->eth, entry, &foe)) {
606 		entry->hash = 0xffff;
607 		goto out;
608 	}
609 
610 	entry->data.ib1 = foe.ib1;
611 
612 out:
613 	spin_unlock_bh(&ppe_lock);
614 }
615 
616 static void
617 __mtk_foe_entry_commit(struct mtk_ppe *ppe, struct mtk_foe_entry *entry,
618 		       u16 hash)
619 {
620 	struct mtk_eth *eth = ppe->eth;
621 	u16 timestamp = mtk_eth_timestamp(eth);
622 	struct mtk_foe_entry *hwe;
623 	u32 val;
624 
625 	if (mtk_is_netsys_v2_or_greater(eth)) {
626 		entry->ib1 &= ~MTK_FOE_IB1_BIND_TIMESTAMP_V2;
627 		entry->ib1 |= FIELD_PREP(MTK_FOE_IB1_BIND_TIMESTAMP_V2,
628 					 timestamp);
629 	} else {
630 		entry->ib1 &= ~MTK_FOE_IB1_BIND_TIMESTAMP;
631 		entry->ib1 |= FIELD_PREP(MTK_FOE_IB1_BIND_TIMESTAMP,
632 					 timestamp);
633 	}
634 
635 	hwe = mtk_foe_get_entry(ppe, hash);
636 	memcpy(&hwe->data, &entry->data, eth->soc->foe_entry_size - sizeof(hwe->ib1));
637 	wmb();
638 	hwe->ib1 = entry->ib1;
639 
640 	if (ppe->accounting) {
641 		if (mtk_is_netsys_v2_or_greater(eth))
642 			val = MTK_FOE_IB2_MIB_CNT_V2;
643 		else
644 			val = MTK_FOE_IB2_MIB_CNT;
645 		*mtk_foe_entry_ib2(eth, hwe) |= val;
646 	}
647 
648 	dma_wmb();
649 
650 	mtk_ppe_cache_clear(ppe);
651 }
652 
653 void mtk_foe_entry_clear(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
654 {
655 	spin_lock_bh(&ppe_lock);
656 	__mtk_foe_entry_clear(ppe, entry);
657 	spin_unlock_bh(&ppe_lock);
658 }
659 
660 static int
661 mtk_foe_entry_commit_l2(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
662 {
663 	struct mtk_flow_entry *prev;
664 
665 	entry->type = MTK_FLOW_TYPE_L2;
666 
667 	prev = rhashtable_lookup_get_insert_fast(&ppe->l2_flows, &entry->l2_node,
668 						 mtk_flow_l2_ht_params);
669 	if (likely(!prev))
670 		return 0;
671 
672 	if (IS_ERR(prev))
673 		return PTR_ERR(prev);
674 
675 	return rhashtable_replace_fast(&ppe->l2_flows, &prev->l2_node,
676 				       &entry->l2_node, mtk_flow_l2_ht_params);
677 }
678 
679 int mtk_foe_entry_commit(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
680 {
681 	const struct mtk_soc_data *soc = ppe->eth->soc;
682 	int type = mtk_get_ib1_pkt_type(ppe->eth, entry->data.ib1);
683 	u32 hash;
684 
685 	if (type == MTK_PPE_PKT_TYPE_BRIDGE)
686 		return mtk_foe_entry_commit_l2(ppe, entry);
687 
688 	hash = mtk_ppe_hash_entry(ppe->eth, &entry->data);
689 	entry->hash = 0xffff;
690 	spin_lock_bh(&ppe_lock);
691 	hlist_add_head(&entry->list, &ppe->foe_flow[hash / soc->hash_offset]);
692 	spin_unlock_bh(&ppe_lock);
693 
694 	return 0;
695 }
696 
697 static void
698 mtk_foe_entry_commit_subflow(struct mtk_ppe *ppe, struct mtk_flow_entry *entry,
699 			     u16 hash)
700 {
701 	const struct mtk_soc_data *soc = ppe->eth->soc;
702 	struct mtk_flow_entry *flow_info;
703 	struct mtk_foe_entry foe = {}, *hwe;
704 	struct mtk_foe_mac_info *l2;
705 	u32 ib1_mask = mtk_get_ib1_pkt_type_mask(ppe->eth) | MTK_FOE_IB1_UDP;
706 	int type;
707 
708 	flow_info = kzalloc(sizeof(*flow_info), GFP_ATOMIC);
709 	if (!flow_info)
710 		return;
711 
712 	flow_info->l2_data.base_flow = entry;
713 	flow_info->type = MTK_FLOW_TYPE_L2_SUBFLOW;
714 	flow_info->hash = hash;
715 	hlist_add_head(&flow_info->list,
716 		       &ppe->foe_flow[hash / soc->hash_offset]);
717 	hlist_add_head(&flow_info->l2_data.list, &entry->l2_flows);
718 
719 	hwe = mtk_foe_get_entry(ppe, hash);
720 	memcpy(&foe, hwe, soc->foe_entry_size);
721 	foe.ib1 &= ib1_mask;
722 	foe.ib1 |= entry->data.ib1 & ~ib1_mask;
723 
724 	l2 = mtk_foe_entry_l2(ppe->eth, &foe);
725 	memcpy(l2, &entry->data.bridge.l2, sizeof(*l2));
726 
727 	type = mtk_get_ib1_pkt_type(ppe->eth, foe.ib1);
728 	if (type == MTK_PPE_PKT_TYPE_IPV4_HNAPT)
729 		memcpy(&foe.ipv4.new, &foe.ipv4.orig, sizeof(foe.ipv4.new));
730 	else if (type >= MTK_PPE_PKT_TYPE_IPV6_ROUTE_3T && l2->etype == ETH_P_IP)
731 		l2->etype = ETH_P_IPV6;
732 
733 	*mtk_foe_entry_ib2(ppe->eth, &foe) = entry->data.bridge.ib2;
734 
735 	__mtk_foe_entry_commit(ppe, &foe, hash);
736 }
737 
738 void __mtk_ppe_check_skb(struct mtk_ppe *ppe, struct sk_buff *skb, u16 hash)
739 {
740 	const struct mtk_soc_data *soc = ppe->eth->soc;
741 	struct hlist_head *head = &ppe->foe_flow[hash / soc->hash_offset];
742 	struct mtk_foe_entry *hwe = mtk_foe_get_entry(ppe, hash);
743 	struct mtk_flow_entry *entry;
744 	struct mtk_foe_bridge key = {};
745 	struct hlist_node *n;
746 	struct ethhdr *eh;
747 	bool found = false;
748 	u8 *tag;
749 
750 	spin_lock_bh(&ppe_lock);
751 
752 	if (FIELD_GET(MTK_FOE_IB1_STATE, hwe->ib1) == MTK_FOE_STATE_BIND)
753 		goto out;
754 
755 	hlist_for_each_entry_safe(entry, n, head, list) {
756 		if (entry->type == MTK_FLOW_TYPE_L2_SUBFLOW) {
757 			if (unlikely(FIELD_GET(MTK_FOE_IB1_STATE, hwe->ib1) ==
758 				     MTK_FOE_STATE_BIND))
759 				continue;
760 
761 			entry->hash = 0xffff;
762 			__mtk_foe_entry_clear(ppe, entry);
763 			continue;
764 		}
765 
766 		if (found || !mtk_flow_entry_match(ppe->eth, entry, hwe)) {
767 			if (entry->hash != 0xffff)
768 				entry->hash = 0xffff;
769 			continue;
770 		}
771 
772 		entry->hash = hash;
773 		__mtk_foe_entry_commit(ppe, &entry->data, hash);
774 		found = true;
775 	}
776 
777 	if (found)
778 		goto out;
779 
780 	eh = eth_hdr(skb);
781 	ether_addr_copy(key.dest_mac, eh->h_dest);
782 	ether_addr_copy(key.src_mac, eh->h_source);
783 	tag = skb->data - 2;
784 	key.vlan = 0;
785 	switch (skb->protocol) {
786 #if IS_ENABLED(CONFIG_NET_DSA)
787 	case htons(ETH_P_XDSA):
788 		if (!netdev_uses_dsa(skb->dev) ||
789 		    skb->dev->dsa_ptr->tag_ops->proto != DSA_TAG_PROTO_MTK)
790 			goto out;
791 
792 		if (!skb_metadata_dst(skb))
793 			tag += 4;
794 
795 		if (get_unaligned_be16(tag) != ETH_P_8021Q)
796 			break;
797 
798 		fallthrough;
799 #endif
800 	case htons(ETH_P_8021Q):
801 		key.vlan = get_unaligned_be16(tag + 2) & VLAN_VID_MASK;
802 		break;
803 	default:
804 		break;
805 	}
806 
807 	entry = rhashtable_lookup_fast(&ppe->l2_flows, &key, mtk_flow_l2_ht_params);
808 	if (!entry)
809 		goto out;
810 
811 	mtk_foe_entry_commit_subflow(ppe, entry, hash);
812 
813 out:
814 	spin_unlock_bh(&ppe_lock);
815 }
816 
817 int mtk_foe_entry_idle_time(struct mtk_ppe *ppe, struct mtk_flow_entry *entry)
818 {
819 	mtk_flow_entry_update(ppe, entry);
820 
821 	return __mtk_foe_entry_idle_time(ppe, entry->data.ib1);
822 }
823 
824 int mtk_ppe_prepare_reset(struct mtk_ppe *ppe)
825 {
826 	if (!ppe)
827 		return -EINVAL;
828 
829 	/* disable KA */
830 	ppe_clear(ppe, MTK_PPE_TB_CFG, MTK_PPE_TB_CFG_KEEPALIVE);
831 	ppe_clear(ppe, MTK_PPE_BIND_LMT1, MTK_PPE_NTU_KEEPALIVE);
832 	ppe_w32(ppe, MTK_PPE_KEEPALIVE, 0);
833 	usleep_range(10000, 11000);
834 
835 	/* set KA timer to maximum */
836 	ppe_set(ppe, MTK_PPE_BIND_LMT1, MTK_PPE_NTU_KEEPALIVE);
837 	ppe_w32(ppe, MTK_PPE_KEEPALIVE, 0xffffffff);
838 
839 	/* set KA tick select */
840 	ppe_set(ppe, MTK_PPE_TB_CFG, MTK_PPE_TB_TICK_SEL);
841 	ppe_set(ppe, MTK_PPE_TB_CFG, MTK_PPE_TB_CFG_KEEPALIVE);
842 	usleep_range(10000, 11000);
843 
844 	/* disable scan mode */
845 	ppe_clear(ppe, MTK_PPE_TB_CFG, MTK_PPE_TB_CFG_SCAN_MODE);
846 	usleep_range(10000, 11000);
847 
848 	return mtk_ppe_wait_busy(ppe);
849 }
850 
851 struct mtk_foe_accounting *mtk_foe_entry_get_mib(struct mtk_ppe *ppe, u32 index,
852 						 struct mtk_foe_accounting *diff)
853 {
854 	struct mtk_foe_accounting *acct;
855 	int size = sizeof(struct mtk_foe_accounting);
856 	u64 bytes, packets;
857 
858 	if (!ppe->accounting)
859 		return NULL;
860 
861 	if (mtk_mib_entry_read(ppe, index, &bytes, &packets))
862 		return NULL;
863 
864 	acct = ppe->acct_table + index * size;
865 
866 	acct->bytes += bytes;
867 	acct->packets += packets;
868 
869 	if (diff) {
870 		diff->bytes = bytes;
871 		diff->packets = packets;
872 	}
873 
874 	return acct;
875 }
876 
877 struct mtk_ppe *mtk_ppe_init(struct mtk_eth *eth, void __iomem *base, int index)
878 {
879 	bool accounting = eth->soc->has_accounting;
880 	const struct mtk_soc_data *soc = eth->soc;
881 	struct mtk_foe_accounting *acct;
882 	struct device *dev = eth->dev;
883 	struct mtk_mib_entry *mib;
884 	struct mtk_ppe *ppe;
885 	u32 foe_flow_size;
886 	void *foe;
887 
888 	ppe = devm_kzalloc(dev, sizeof(*ppe), GFP_KERNEL);
889 	if (!ppe)
890 		return NULL;
891 
892 	rhashtable_init(&ppe->l2_flows, &mtk_flow_l2_ht_params);
893 
894 	/* need to allocate a separate device, since it PPE DMA access is
895 	 * not coherent.
896 	 */
897 	ppe->base = base;
898 	ppe->eth = eth;
899 	ppe->dev = dev;
900 	ppe->version = eth->soc->offload_version;
901 	ppe->accounting = accounting;
902 
903 	foe = dmam_alloc_coherent(ppe->dev,
904 				  MTK_PPE_ENTRIES * soc->foe_entry_size,
905 				  &ppe->foe_phys, GFP_KERNEL);
906 	if (!foe)
907 		goto err_free_l2_flows;
908 
909 	ppe->foe_table = foe;
910 
911 	foe_flow_size = (MTK_PPE_ENTRIES / soc->hash_offset) *
912 			sizeof(*ppe->foe_flow);
913 	ppe->foe_flow = devm_kzalloc(dev, foe_flow_size, GFP_KERNEL);
914 	if (!ppe->foe_flow)
915 		goto err_free_l2_flows;
916 
917 	if (accounting) {
918 		mib = dmam_alloc_coherent(ppe->dev, MTK_PPE_ENTRIES * sizeof(*mib),
919 					  &ppe->mib_phys, GFP_KERNEL);
920 		if (!mib)
921 			return NULL;
922 
923 		ppe->mib_table = mib;
924 
925 		acct = devm_kzalloc(dev, MTK_PPE_ENTRIES * sizeof(*acct),
926 				    GFP_KERNEL);
927 
928 		if (!acct)
929 			return NULL;
930 
931 		ppe->acct_table = acct;
932 	}
933 
934 	mtk_ppe_debugfs_init(ppe, index);
935 
936 	return ppe;
937 
938 err_free_l2_flows:
939 	rhashtable_destroy(&ppe->l2_flows);
940 	return NULL;
941 }
942 
943 void mtk_ppe_deinit(struct mtk_eth *eth)
944 {
945 	int i;
946 
947 	for (i = 0; i < ARRAY_SIZE(eth->ppe); i++) {
948 		if (!eth->ppe[i])
949 			return;
950 		rhashtable_destroy(&eth->ppe[i]->l2_flows);
951 	}
952 }
953 
954 static void mtk_ppe_init_foe_table(struct mtk_ppe *ppe)
955 {
956 	static const u8 skip[] = { 12, 25, 38, 51, 76, 89, 102 };
957 	int i, k;
958 
959 	memset(ppe->foe_table, 0,
960 	       MTK_PPE_ENTRIES * ppe->eth->soc->foe_entry_size);
961 
962 	if (!IS_ENABLED(CONFIG_SOC_MT7621))
963 		return;
964 
965 	/* skip all entries that cross the 1024 byte boundary */
966 	for (i = 0; i < MTK_PPE_ENTRIES; i += 128) {
967 		for (k = 0; k < ARRAY_SIZE(skip); k++) {
968 			struct mtk_foe_entry *hwe;
969 
970 			hwe = mtk_foe_get_entry(ppe, i + skip[k]);
971 			hwe->ib1 |= MTK_FOE_IB1_STATIC;
972 		}
973 	}
974 }
975 
976 void mtk_ppe_start(struct mtk_ppe *ppe)
977 {
978 	u32 val;
979 
980 	if (!ppe)
981 		return;
982 
983 	mtk_ppe_init_foe_table(ppe);
984 	ppe_w32(ppe, MTK_PPE_TB_BASE, ppe->foe_phys);
985 
986 	val = MTK_PPE_TB_CFG_AGE_NON_L4 |
987 	      MTK_PPE_TB_CFG_AGE_UNBIND |
988 	      MTK_PPE_TB_CFG_AGE_TCP |
989 	      MTK_PPE_TB_CFG_AGE_UDP |
990 	      MTK_PPE_TB_CFG_AGE_TCP_FIN |
991 	      FIELD_PREP(MTK_PPE_TB_CFG_SEARCH_MISS,
992 			 MTK_PPE_SEARCH_MISS_ACTION_FORWARD_BUILD) |
993 	      FIELD_PREP(MTK_PPE_TB_CFG_KEEPALIVE,
994 			 MTK_PPE_KEEPALIVE_DISABLE) |
995 	      FIELD_PREP(MTK_PPE_TB_CFG_HASH_MODE, 1) |
996 	      FIELD_PREP(MTK_PPE_TB_CFG_SCAN_MODE,
997 			 MTK_PPE_SCAN_MODE_CHECK_AGE) |
998 	      FIELD_PREP(MTK_PPE_TB_CFG_ENTRY_NUM,
999 			 MTK_PPE_ENTRIES_SHIFT);
1000 	if (mtk_is_netsys_v2_or_greater(ppe->eth))
1001 		val |= MTK_PPE_TB_CFG_INFO_SEL;
1002 	if (!mtk_is_netsys_v3_or_greater(ppe->eth))
1003 		val |= MTK_PPE_TB_CFG_ENTRY_80B;
1004 	ppe_w32(ppe, MTK_PPE_TB_CFG, val);
1005 
1006 	ppe_w32(ppe, MTK_PPE_IP_PROTO_CHK,
1007 		MTK_PPE_IP_PROTO_CHK_IPV4 | MTK_PPE_IP_PROTO_CHK_IPV6);
1008 
1009 	mtk_ppe_cache_enable(ppe, true);
1010 
1011 	val = MTK_PPE_FLOW_CFG_IP6_3T_ROUTE |
1012 	      MTK_PPE_FLOW_CFG_IP6_5T_ROUTE |
1013 	      MTK_PPE_FLOW_CFG_IP6_6RD |
1014 	      MTK_PPE_FLOW_CFG_IP4_NAT |
1015 	      MTK_PPE_FLOW_CFG_IP4_NAPT |
1016 	      MTK_PPE_FLOW_CFG_IP4_DSLITE |
1017 	      MTK_PPE_FLOW_CFG_IP4_NAT_FRAG;
1018 	if (mtk_is_netsys_v2_or_greater(ppe->eth))
1019 		val |= MTK_PPE_MD_TOAP_BYP_CRSN0 |
1020 		       MTK_PPE_MD_TOAP_BYP_CRSN1 |
1021 		       MTK_PPE_MD_TOAP_BYP_CRSN2 |
1022 		       MTK_PPE_FLOW_CFG_IP4_HASH_GRE_KEY;
1023 	else
1024 		val |= MTK_PPE_FLOW_CFG_IP4_TCP_FRAG |
1025 		       MTK_PPE_FLOW_CFG_IP4_UDP_FRAG;
1026 	ppe_w32(ppe, MTK_PPE_FLOW_CFG, val);
1027 
1028 	val = FIELD_PREP(MTK_PPE_UNBIND_AGE_MIN_PACKETS, 1000) |
1029 	      FIELD_PREP(MTK_PPE_UNBIND_AGE_DELTA, 3);
1030 	ppe_w32(ppe, MTK_PPE_UNBIND_AGE, val);
1031 
1032 	val = FIELD_PREP(MTK_PPE_BIND_AGE0_DELTA_UDP, 12) |
1033 	      FIELD_PREP(MTK_PPE_BIND_AGE0_DELTA_NON_L4, 1);
1034 	ppe_w32(ppe, MTK_PPE_BIND_AGE0, val);
1035 
1036 	val = FIELD_PREP(MTK_PPE_BIND_AGE1_DELTA_TCP_FIN, 1) |
1037 	      FIELD_PREP(MTK_PPE_BIND_AGE1_DELTA_TCP, 7);
1038 	ppe_w32(ppe, MTK_PPE_BIND_AGE1, val);
1039 
1040 	val = MTK_PPE_BIND_LIMIT0_QUARTER | MTK_PPE_BIND_LIMIT0_HALF;
1041 	ppe_w32(ppe, MTK_PPE_BIND_LIMIT0, val);
1042 
1043 	val = MTK_PPE_BIND_LIMIT1_FULL |
1044 	      FIELD_PREP(MTK_PPE_BIND_LIMIT1_NON_L4, 1);
1045 	ppe_w32(ppe, MTK_PPE_BIND_LIMIT1, val);
1046 
1047 	val = FIELD_PREP(MTK_PPE_BIND_RATE_BIND, 30) |
1048 	      FIELD_PREP(MTK_PPE_BIND_RATE_PREBIND, 1);
1049 	ppe_w32(ppe, MTK_PPE_BIND_RATE, val);
1050 
1051 	/* enable PPE */
1052 	val = MTK_PPE_GLO_CFG_EN |
1053 	      MTK_PPE_GLO_CFG_IP4_L4_CS_DROP |
1054 	      MTK_PPE_GLO_CFG_IP4_CS_DROP |
1055 	      MTK_PPE_GLO_CFG_FLOW_DROP_UPDATE;
1056 	ppe_w32(ppe, MTK_PPE_GLO_CFG, val);
1057 
1058 	ppe_w32(ppe, MTK_PPE_DEFAULT_CPU_PORT, 0);
1059 
1060 	if (mtk_is_netsys_v2_or_greater(ppe->eth)) {
1061 		ppe_w32(ppe, MTK_PPE_DEFAULT_CPU_PORT1, 0xcb777);
1062 		ppe_w32(ppe, MTK_PPE_SBW_CTRL, 0x7f);
1063 	}
1064 
1065 	if (ppe->accounting && ppe->mib_phys) {
1066 		ppe_w32(ppe, MTK_PPE_MIB_TB_BASE, ppe->mib_phys);
1067 		ppe_m32(ppe, MTK_PPE_MIB_CFG, MTK_PPE_MIB_CFG_EN,
1068 			MTK_PPE_MIB_CFG_EN);
1069 		ppe_m32(ppe, MTK_PPE_MIB_CFG, MTK_PPE_MIB_CFG_RD_CLR,
1070 			MTK_PPE_MIB_CFG_RD_CLR);
1071 		ppe_m32(ppe, MTK_PPE_MIB_CACHE_CTL, MTK_PPE_MIB_CACHE_CTL_EN,
1072 			MTK_PPE_MIB_CFG_RD_CLR);
1073 	}
1074 }
1075 
1076 int mtk_ppe_stop(struct mtk_ppe *ppe)
1077 {
1078 	u32 val;
1079 	int i;
1080 
1081 	if (!ppe)
1082 		return 0;
1083 
1084 	for (i = 0; i < MTK_PPE_ENTRIES; i++) {
1085 		struct mtk_foe_entry *hwe = mtk_foe_get_entry(ppe, i);
1086 
1087 		hwe->ib1 = FIELD_PREP(MTK_FOE_IB1_STATE,
1088 				      MTK_FOE_STATE_INVALID);
1089 	}
1090 
1091 	mtk_ppe_cache_enable(ppe, false);
1092 
1093 	/* disable aging */
1094 	val = MTK_PPE_TB_CFG_AGE_NON_L4 |
1095 	      MTK_PPE_TB_CFG_AGE_UNBIND |
1096 	      MTK_PPE_TB_CFG_AGE_TCP |
1097 	      MTK_PPE_TB_CFG_AGE_UDP |
1098 	      MTK_PPE_TB_CFG_AGE_TCP_FIN |
1099 		  MTK_PPE_TB_CFG_SCAN_MODE;
1100 	ppe_clear(ppe, MTK_PPE_TB_CFG, val);
1101 
1102 	if (mtk_ppe_wait_busy(ppe))
1103 		return -ETIMEDOUT;
1104 
1105 	/* disable offload engine */
1106 	ppe_clear(ppe, MTK_PPE_GLO_CFG, MTK_PPE_GLO_CFG_EN);
1107 	ppe_w32(ppe, MTK_PPE_FLOW_CFG, 0);
1108 
1109 	return 0;
1110 }
1111