xref: /linux/drivers/net/ethernet/meta/fbnic/fbnic_rpc.c (revision f72aa1b276281b4e4f75261af8425bc99d903f3e)
1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright (c) Meta Platforms, Inc. and affiliates. */
3 
4 #include <linux/etherdevice.h>
5 #include <linux/ethtool.h>
6 
7 #include "fbnic.h"
8 #include "fbnic_netdev.h"
9 #include "fbnic_rpc.h"
10 
11 void fbnic_reset_indir_tbl(struct fbnic_net *fbn)
12 {
13 	unsigned int num_rx = fbn->num_rx_queues;
14 	unsigned int i;
15 
16 	for (i = 0; i < FBNIC_RPC_RSS_TBL_SIZE; i++) {
17 		fbn->indir_tbl[0][i] = ethtool_rxfh_indir_default(i, num_rx);
18 		fbn->indir_tbl[1][i] = ethtool_rxfh_indir_default(i, num_rx);
19 	}
20 }
21 
22 void fbnic_rss_key_fill(u32 *buffer)
23 {
24 	static u32 rss_key[FBNIC_RPC_RSS_KEY_DWORD_LEN];
25 
26 	net_get_random_once(rss_key, sizeof(rss_key));
27 	rss_key[FBNIC_RPC_RSS_KEY_LAST_IDX] &= FBNIC_RPC_RSS_KEY_LAST_MASK;
28 
29 	memcpy(buffer, rss_key, sizeof(rss_key));
30 }
31 
32 #define RX_HASH_OPT_L4 \
33 	(RXH_IP_SRC | RXH_IP_DST | RXH_L4_B_0_1 | RXH_L4_B_2_3)
34 #define RX_HASH_OPT_L3 \
35 	(RXH_IP_SRC | RXH_IP_DST)
36 #define RX_HASH_OPT_L2 RXH_L2DA
37 
38 void fbnic_rss_init_en_mask(struct fbnic_net *fbn)
39 {
40 	fbn->rss_flow_hash[FBNIC_TCP4_HASH_OPT] = RX_HASH_OPT_L4;
41 	fbn->rss_flow_hash[FBNIC_TCP6_HASH_OPT] = RX_HASH_OPT_L4;
42 
43 	fbn->rss_flow_hash[FBNIC_UDP4_HASH_OPT] = RX_HASH_OPT_L3;
44 	fbn->rss_flow_hash[FBNIC_UDP6_HASH_OPT] = RX_HASH_OPT_L3;
45 	fbn->rss_flow_hash[FBNIC_IPV4_HASH_OPT] = RX_HASH_OPT_L3;
46 	fbn->rss_flow_hash[FBNIC_IPV6_HASH_OPT] = RX_HASH_OPT_L3;
47 
48 	fbn->rss_flow_hash[FBNIC_ETHER_HASH_OPT] = RX_HASH_OPT_L2;
49 }
50 
51 void fbnic_rss_disable_hw(struct fbnic_dev *fbd)
52 {
53 	/* Disable RPC by clearing enable bit and configuration */
54 	if (!fbnic_bmc_present(fbd))
55 		wr32(fbd, FBNIC_RPC_RMI_CONFIG,
56 		     FIELD_PREP(FBNIC_RPC_RMI_CONFIG_OH_BYTES, 20));
57 }
58 
59 #define FBNIC_FH_2_RSSEM_BIT(_fh, _rssem, _val)		\
60 	FIELD_PREP(FBNIC_RPC_ACT_TBL1_RSS_ENA_##_rssem,	\
61 		   FIELD_GET(RXH_##_fh, _val))
62 static u16 fbnic_flow_hash_2_rss_en_mask(struct fbnic_net *fbn, int flow_type)
63 {
64 	u32 flow_hash = fbn->rss_flow_hash[flow_type];
65 	u32 rss_en_mask = 0;
66 
67 	rss_en_mask |= FBNIC_FH_2_RSSEM_BIT(L2DA, L2_DA, flow_hash);
68 	rss_en_mask |= FBNIC_FH_2_RSSEM_BIT(IP_SRC, IP_SRC, flow_hash);
69 	rss_en_mask |= FBNIC_FH_2_RSSEM_BIT(IP_DST, IP_DST, flow_hash);
70 	rss_en_mask |= FBNIC_FH_2_RSSEM_BIT(L4_B_0_1, L4_SRC, flow_hash);
71 	rss_en_mask |= FBNIC_FH_2_RSSEM_BIT(L4_B_2_3, L4_DST, flow_hash);
72 
73 	return rss_en_mask;
74 }
75 
76 void fbnic_rss_reinit_hw(struct fbnic_dev *fbd, struct fbnic_net *fbn)
77 {
78 	unsigned int i;
79 
80 	for (i = 0; i < FBNIC_RPC_RSS_TBL_SIZE; i++) {
81 		wr32(fbd, FBNIC_RPC_RSS_TBL(0, i), fbn->indir_tbl[0][i]);
82 		wr32(fbd, FBNIC_RPC_RSS_TBL(1, i), fbn->indir_tbl[1][i]);
83 	}
84 
85 	for (i = 0; i < FBNIC_RPC_RSS_KEY_DWORD_LEN; i++)
86 		wr32(fbd, FBNIC_RPC_RSS_KEY(i), fbn->rss_key[i]);
87 
88 	/* Default action for this to drop w/ no destination */
89 	wr32(fbd, FBNIC_RPC_ACT_TBL0_DEFAULT, FBNIC_RPC_ACT_TBL0_DROP);
90 	wrfl(fbd);
91 
92 	wr32(fbd, FBNIC_RPC_ACT_TBL1_DEFAULT, 0);
93 
94 	/* If it isn't already enabled set the RMI Config value to enable RPC */
95 	wr32(fbd, FBNIC_RPC_RMI_CONFIG,
96 	     FIELD_PREP(FBNIC_RPC_RMI_CONFIG_MTU, FBNIC_MAX_JUMBO_FRAME_SIZE) |
97 	     FIELD_PREP(FBNIC_RPC_RMI_CONFIG_OH_BYTES, 20) |
98 	     FBNIC_RPC_RMI_CONFIG_ENABLE);
99 }
100 
101 void fbnic_bmc_rpc_all_multi_config(struct fbnic_dev *fbd,
102 				    bool enable_host)
103 {
104 	struct fbnic_act_tcam *act_tcam;
105 	struct fbnic_mac_addr *mac_addr;
106 	int j;
107 
108 	/* We need to add the all multicast filter at the end of the
109 	 * multicast address list. This way if there are any that are
110 	 * shared between the host and the BMC they can be directed to
111 	 * both. Otherwise the remainder just get sent directly to the
112 	 * BMC.
113 	 */
114 	mac_addr = &fbd->mac_addr[fbd->mac_addr_boundary - 1];
115 	if (fbnic_bmc_present(fbd) && fbd->fw_cap.all_multi) {
116 		if (mac_addr->state != FBNIC_TCAM_S_VALID) {
117 			eth_zero_addr(mac_addr->value.addr8);
118 			eth_broadcast_addr(mac_addr->mask.addr8);
119 			mac_addr->value.addr8[0] ^= 1;
120 			mac_addr->mask.addr8[0] ^= 1;
121 			set_bit(FBNIC_MAC_ADDR_T_BMC, mac_addr->act_tcam);
122 			mac_addr->state = FBNIC_TCAM_S_ADD;
123 		}
124 		if (enable_host)
125 			set_bit(FBNIC_MAC_ADDR_T_ALLMULTI,
126 				mac_addr->act_tcam);
127 		else
128 			clear_bit(FBNIC_MAC_ADDR_T_ALLMULTI,
129 				  mac_addr->act_tcam);
130 	} else if (!test_bit(FBNIC_MAC_ADDR_T_BMC, mac_addr->act_tcam) &&
131 		   !is_zero_ether_addr(mac_addr->mask.addr8) &&
132 		   mac_addr->state == FBNIC_TCAM_S_VALID) {
133 		clear_bit(FBNIC_MAC_ADDR_T_ALLMULTI, mac_addr->act_tcam);
134 		clear_bit(FBNIC_MAC_ADDR_T_BMC, mac_addr->act_tcam);
135 		mac_addr->state = FBNIC_TCAM_S_DELETE;
136 	}
137 
138 	/* We have to add a special handler for multicast as the
139 	 * BMC may have an all-multi rule already in place. As such
140 	 * adding a rule ourselves won't do any good so we will have
141 	 * to modify the rules for the ALL MULTI below if the BMC
142 	 * already has the rule in place.
143 	 */
144 	act_tcam = &fbd->act_tcam[FBNIC_RPC_ACT_TBL_BMC_ALL_MULTI_OFFSET];
145 
146 	/* If we are not enabling the rule just delete it. We will fall
147 	 * back to the RSS rules that support the multicast addresses.
148 	 */
149 	if (!fbnic_bmc_present(fbd) || !fbd->fw_cap.all_multi || enable_host) {
150 		if (act_tcam->state == FBNIC_TCAM_S_VALID)
151 			act_tcam->state = FBNIC_TCAM_S_DELETE;
152 		return;
153 	}
154 
155 	/* Rewrite TCAM rule 23 to handle BMC all-multi traffic */
156 	act_tcam->dest = FIELD_PREP(FBNIC_RPC_ACT_TBL0_DEST_MASK,
157 				    FBNIC_RPC_ACT_TBL0_DEST_BMC);
158 	act_tcam->mask.tcam[0] = 0xffff;
159 
160 	/* MACDA 0 - 3 is reserved for the BMC MAC address */
161 	act_tcam->value.tcam[1] =
162 			FIELD_PREP(FBNIC_RPC_TCAM_ACT1_L2_MACDA_IDX,
163 				   fbd->mac_addr_boundary - 1) |
164 			FBNIC_RPC_TCAM_ACT1_L2_MACDA_VALID;
165 	act_tcam->mask.tcam[1] = 0xffff &
166 			 ~FBNIC_RPC_TCAM_ACT1_L2_MACDA_IDX &
167 			 ~FBNIC_RPC_TCAM_ACT1_L2_MACDA_VALID;
168 
169 	for (j = 2; j < FBNIC_RPC_TCAM_ACT_WORD_LEN; j++)
170 		act_tcam->mask.tcam[j] = 0xffff;
171 
172 	act_tcam->state = FBNIC_TCAM_S_UPDATE;
173 }
174 
175 void fbnic_bmc_rpc_init(struct fbnic_dev *fbd)
176 {
177 	int i = FBNIC_RPC_TCAM_MACDA_BMC_ADDR_IDX;
178 	struct fbnic_act_tcam *act_tcam;
179 	struct fbnic_mac_addr *mac_addr;
180 	int j;
181 
182 	/* Check if BMC is present */
183 	if (!fbnic_bmc_present(fbd))
184 		return;
185 
186 	/* Fetch BMC MAC addresses from firmware capabilities */
187 	for (j = 0; j < 4; j++) {
188 		u8 *bmc_mac = fbd->fw_cap.bmc_mac_addr[j];
189 
190 		/* Validate BMC MAC addresses */
191 		if (is_zero_ether_addr(bmc_mac))
192 			continue;
193 
194 		if (is_multicast_ether_addr(bmc_mac))
195 			mac_addr = __fbnic_mc_sync(fbd, bmc_mac);
196 		else
197 			mac_addr = &fbd->mac_addr[i++];
198 
199 		if (!mac_addr) {
200 			netdev_err(fbd->netdev,
201 				   "No slot for BMC MAC address[%d]\n", j);
202 			continue;
203 		}
204 
205 		ether_addr_copy(mac_addr->value.addr8, bmc_mac);
206 		eth_zero_addr(mac_addr->mask.addr8);
207 
208 		set_bit(FBNIC_MAC_ADDR_T_BMC, mac_addr->act_tcam);
209 		mac_addr->state = FBNIC_TCAM_S_ADD;
210 	}
211 
212 	/* Validate Broadcast is also present, record it and tag it */
213 	mac_addr = &fbd->mac_addr[FBNIC_RPC_TCAM_MACDA_BROADCAST_IDX];
214 	eth_broadcast_addr(mac_addr->value.addr8);
215 	set_bit(FBNIC_MAC_ADDR_T_BMC, mac_addr->act_tcam);
216 	mac_addr->state = FBNIC_TCAM_S_ADD;
217 
218 	/* Rewrite TCAM rule 0 if it isn't present to relocate BMC rules */
219 	act_tcam = &fbd->act_tcam[FBNIC_RPC_ACT_TBL_BMC_OFFSET];
220 	act_tcam->dest = FIELD_PREP(FBNIC_RPC_ACT_TBL0_DEST_MASK,
221 				    FBNIC_RPC_ACT_TBL0_DEST_BMC);
222 	act_tcam->mask.tcam[0] = 0xffff;
223 
224 	/* MACDA 0 - 3 is reserved for the BMC MAC address
225 	 * to account for that we have to mask out the lower 2 bits
226 	 * of the macda by performing an &= with 0x1c.
227 	 */
228 	act_tcam->value.tcam[1] = FBNIC_RPC_TCAM_ACT1_L2_MACDA_VALID;
229 	act_tcam->mask.tcam[1] = 0xffff &
230 			~FIELD_PREP(FBNIC_RPC_TCAM_ACT1_L2_MACDA_IDX, 0x1c) &
231 			~FBNIC_RPC_TCAM_ACT1_L2_MACDA_VALID;
232 
233 	for (j = 2; j < FBNIC_RPC_TCAM_ACT_WORD_LEN; j++)
234 		act_tcam->mask.tcam[j] = 0xffff;
235 
236 	act_tcam->state = FBNIC_TCAM_S_UPDATE;
237 
238 	fbnic_bmc_rpc_all_multi_config(fbd, false);
239 }
240 
241 #define FBNIC_ACT1_INIT(_l4, _udp, _ip, _v6)		\
242 	(((_l4) ? FBNIC_RPC_TCAM_ACT1_L4_VALID : 0) |	\
243 	 ((_udp) ? FBNIC_RPC_TCAM_ACT1_L4_IS_UDP : 0) |	\
244 	 ((_ip) ? FBNIC_RPC_TCAM_ACT1_IP_VALID : 0) |	\
245 	 ((_v6) ? FBNIC_RPC_TCAM_ACT1_IP_IS_V6 : 0))
246 
247 #define FBNIC_TSTAMP_MASK(_all, _udp, _ether)			\
248 	(((_all) ? ((1u << FBNIC_NUM_HASH_OPT) - 1) : 0) |	\
249 	 ((_udp) ? (1u << FBNIC_UDP6_HASH_OPT) |		\
250 		   (1u << FBNIC_UDP4_HASH_OPT) : 0) |		\
251 	 ((_ether) ? (1u << FBNIC_ETHER_HASH_OPT) : 0))
252 
253 void fbnic_rss_reinit(struct fbnic_dev *fbd, struct fbnic_net *fbn)
254 {
255 	static const u32 act1_value[FBNIC_NUM_HASH_OPT] = {
256 		FBNIC_ACT1_INIT(1, 1, 1, 1),	/* UDP6 */
257 		FBNIC_ACT1_INIT(1, 1, 1, 0),	/* UDP4 */
258 		FBNIC_ACT1_INIT(1, 0, 1, 1),	/* TCP6 */
259 		FBNIC_ACT1_INIT(1, 0, 1, 0),	/* TCP4 */
260 		FBNIC_ACT1_INIT(0, 0, 1, 1),	/* IP6 */
261 		FBNIC_ACT1_INIT(0, 0, 1, 0),	/* IP4 */
262 		0				/* Ether */
263 	};
264 	u32 tstamp_mask = 0;
265 	unsigned int i;
266 
267 	/* To support scenarios where a BMC is present we must write the
268 	 * rules twice, once for the unicast cases, and once again for
269 	 * the broadcast/multicast cases as we have to support 2 destinations.
270 	 */
271 	BUILD_BUG_ON(FBNIC_RSS_EN_NUM_UNICAST * 2 != FBNIC_RSS_EN_NUM_ENTRIES);
272 	BUILD_BUG_ON(ARRAY_SIZE(act1_value) != FBNIC_NUM_HASH_OPT);
273 
274 	/* Set timestamp mask with 1b per flow type */
275 	if (fbn->hwtstamp_config.rx_filter != HWTSTAMP_FILTER_NONE) {
276 		switch (fbn->hwtstamp_config.rx_filter) {
277 		case HWTSTAMP_FILTER_ALL:
278 			tstamp_mask = FBNIC_TSTAMP_MASK(1, 1, 1);
279 			break;
280 		case HWTSTAMP_FILTER_PTP_V2_EVENT:
281 			tstamp_mask = FBNIC_TSTAMP_MASK(0, 1, 1);
282 			break;
283 		case HWTSTAMP_FILTER_PTP_V1_L4_EVENT:
284 		case HWTSTAMP_FILTER_PTP_V2_L4_EVENT:
285 			tstamp_mask = FBNIC_TSTAMP_MASK(0, 1, 0);
286 			break;
287 		case HWTSTAMP_FILTER_PTP_V2_L2_EVENT:
288 			tstamp_mask = FBNIC_TSTAMP_MASK(0, 0, 1);
289 			break;
290 		default:
291 			netdev_warn(fbn->netdev, "Unsupported hwtstamp_rx_filter\n");
292 			break;
293 		}
294 	}
295 
296 	/* Program RSS hash enable mask for host in action TCAM/table. */
297 	for (i = fbnic_bmc_present(fbd) ? 0 : FBNIC_RSS_EN_NUM_UNICAST;
298 	     i < FBNIC_RSS_EN_NUM_ENTRIES; i++) {
299 		unsigned int idx = i + FBNIC_RPC_ACT_TBL_RSS_OFFSET;
300 		struct fbnic_act_tcam *act_tcam = &fbd->act_tcam[idx];
301 		u32 flow_hash, dest, rss_en_mask;
302 		int flow_type, j;
303 		u16 value = 0;
304 
305 		flow_type = i % FBNIC_RSS_EN_NUM_UNICAST;
306 		flow_hash = fbn->rss_flow_hash[flow_type];
307 
308 		/* Set DEST_HOST based on absence of RXH_DISCARD */
309 		dest = FIELD_PREP(FBNIC_RPC_ACT_TBL0_DEST_MASK,
310 				  !(RXH_DISCARD & flow_hash) ?
311 				  FBNIC_RPC_ACT_TBL0_DEST_HOST : 0);
312 
313 		if (i >= FBNIC_RSS_EN_NUM_UNICAST && fbnic_bmc_present(fbd))
314 			dest |= FIELD_PREP(FBNIC_RPC_ACT_TBL0_DEST_MASK,
315 					   FBNIC_RPC_ACT_TBL0_DEST_BMC);
316 
317 		if (!dest)
318 			dest = FBNIC_RPC_ACT_TBL0_DROP;
319 		else if (tstamp_mask & (1u << flow_type))
320 			dest |= FBNIC_RPC_ACT_TBL0_TS_ENA;
321 
322 		if (act1_value[flow_type] & FBNIC_RPC_TCAM_ACT1_L4_VALID)
323 			dest |= FIELD_PREP(FBNIC_RPC_ACT_TBL0_DMA_HINT,
324 					   FBNIC_RCD_HDR_AL_DMA_HINT_L4);
325 
326 		rss_en_mask = fbnic_flow_hash_2_rss_en_mask(fbn, flow_type);
327 
328 		act_tcam->dest = dest;
329 		act_tcam->rss_en_mask = rss_en_mask;
330 		act_tcam->state = FBNIC_TCAM_S_UPDATE;
331 
332 		act_tcam->mask.tcam[0] = 0xffff;
333 
334 		/* We reserve the upper 8 MACDA TCAM entries for host
335 		 * unicast. So we set the value to 24, and the mask the
336 		 * lower bits so that the lower entries can be used as
337 		 * multicast or BMC addresses.
338 		 */
339 		if (i < FBNIC_RSS_EN_NUM_UNICAST)
340 			value = FIELD_PREP(FBNIC_RPC_TCAM_ACT1_L2_MACDA_IDX,
341 					   fbd->mac_addr_boundary);
342 		value |= FBNIC_RPC_TCAM_ACT1_L2_MACDA_VALID;
343 
344 		flow_type = i % FBNIC_RSS_EN_NUM_UNICAST;
345 		value |= act1_value[flow_type];
346 
347 		act_tcam->value.tcam[1] = value;
348 		act_tcam->mask.tcam[1] = ~value;
349 
350 		for (j = 2; j < FBNIC_RPC_TCAM_ACT_WORD_LEN; j++)
351 			act_tcam->mask.tcam[j] = 0xffff;
352 
353 		act_tcam->state = FBNIC_TCAM_S_UPDATE;
354 	}
355 }
356 
357 struct fbnic_mac_addr *__fbnic_uc_sync(struct fbnic_dev *fbd,
358 				       const unsigned char *addr)
359 {
360 	struct fbnic_mac_addr *avail_addr = NULL;
361 	unsigned int i;
362 
363 	/* Scan from middle of list to bottom, filling bottom up.
364 	 * Skip the first entry which is reserved for dev_addr and
365 	 * leave the last entry to use for promiscuous filtering.
366 	 */
367 	for (i = fbd->mac_addr_boundary - 1;
368 	     i < FBNIC_RPC_TCAM_MACDA_HOST_ADDR_IDX; i++) {
369 		struct fbnic_mac_addr *mac_addr = &fbd->mac_addr[i];
370 
371 		if (mac_addr->state == FBNIC_TCAM_S_DISABLED) {
372 			avail_addr = mac_addr;
373 		} else if (ether_addr_equal(mac_addr->value.addr8, addr)) {
374 			avail_addr = mac_addr;
375 			break;
376 		}
377 	}
378 
379 	if (avail_addr && avail_addr->state == FBNIC_TCAM_S_DISABLED) {
380 		ether_addr_copy(avail_addr->value.addr8, addr);
381 		eth_zero_addr(avail_addr->mask.addr8);
382 		avail_addr->state = FBNIC_TCAM_S_ADD;
383 	}
384 
385 	return avail_addr;
386 }
387 
388 struct fbnic_mac_addr *__fbnic_mc_sync(struct fbnic_dev *fbd,
389 				       const unsigned char *addr)
390 {
391 	struct fbnic_mac_addr *avail_addr = NULL;
392 	unsigned int i;
393 
394 	/* Scan from middle of list to top, filling top down.
395 	 * Skip over the address reserved for the BMC MAC and
396 	 * exclude index 0 as that belongs to the broadcast address
397 	 */
398 	for (i = fbd->mac_addr_boundary;
399 	     --i > FBNIC_RPC_TCAM_MACDA_BROADCAST_IDX;) {
400 		struct fbnic_mac_addr *mac_addr = &fbd->mac_addr[i];
401 
402 		if (mac_addr->state == FBNIC_TCAM_S_DISABLED) {
403 			avail_addr = mac_addr;
404 		} else if (ether_addr_equal(mac_addr->value.addr8, addr)) {
405 			avail_addr = mac_addr;
406 			break;
407 		}
408 	}
409 
410 	/* Scan the BMC addresses to see if it may have already
411 	 * reserved the address.
412 	 */
413 	while (--i) {
414 		struct fbnic_mac_addr *mac_addr = &fbd->mac_addr[i];
415 
416 		if (!is_zero_ether_addr(mac_addr->mask.addr8))
417 			continue;
418 
419 		/* Only move on if we find a match */
420 		if (!ether_addr_equal(mac_addr->value.addr8, addr))
421 			continue;
422 
423 		/* We need to pull this address to the shared area */
424 		if (avail_addr) {
425 			memcpy(avail_addr, mac_addr, sizeof(*mac_addr));
426 			mac_addr->state = FBNIC_TCAM_S_DELETE;
427 			avail_addr->state = FBNIC_TCAM_S_ADD;
428 		}
429 
430 		break;
431 	}
432 
433 	if (avail_addr && avail_addr->state == FBNIC_TCAM_S_DISABLED) {
434 		ether_addr_copy(avail_addr->value.addr8, addr);
435 		eth_zero_addr(avail_addr->mask.addr8);
436 		avail_addr->state = FBNIC_TCAM_S_ADD;
437 	}
438 
439 	return avail_addr;
440 }
441 
442 int __fbnic_xc_unsync(struct fbnic_mac_addr *mac_addr, unsigned int tcam_idx)
443 {
444 	if (!test_and_clear_bit(tcam_idx, mac_addr->act_tcam))
445 		return -ENOENT;
446 
447 	if (bitmap_empty(mac_addr->act_tcam, FBNIC_RPC_TCAM_ACT_NUM_ENTRIES))
448 		mac_addr->state = FBNIC_TCAM_S_DELETE;
449 
450 	return 0;
451 }
452 
453 void fbnic_sift_macda(struct fbnic_dev *fbd)
454 {
455 	int dest, src;
456 
457 	/* Move BMC only addresses back into BMC region */
458 	for (dest = FBNIC_RPC_TCAM_MACDA_BMC_ADDR_IDX,
459 	     src = FBNIC_RPC_TCAM_MACDA_MULTICAST_IDX;
460 	     ++dest < FBNIC_RPC_TCAM_MACDA_BROADCAST_IDX &&
461 	     src < fbd->mac_addr_boundary;) {
462 		struct fbnic_mac_addr *dest_addr = &fbd->mac_addr[dest];
463 
464 		if (dest_addr->state != FBNIC_TCAM_S_DISABLED)
465 			continue;
466 
467 		while (src < fbd->mac_addr_boundary) {
468 			struct fbnic_mac_addr *src_addr = &fbd->mac_addr[src++];
469 
470 			/* Verify BMC bit is set */
471 			if (!test_bit(FBNIC_MAC_ADDR_T_BMC, src_addr->act_tcam))
472 				continue;
473 
474 			/* Verify filter isn't already disabled */
475 			if (src_addr->state == FBNIC_TCAM_S_DISABLED ||
476 			    src_addr->state == FBNIC_TCAM_S_DELETE)
477 				continue;
478 
479 			/* Verify only BMC bit is set */
480 			if (bitmap_weight(src_addr->act_tcam,
481 					  FBNIC_RPC_TCAM_ACT_NUM_ENTRIES) != 1)
482 				continue;
483 
484 			/* Verify we are not moving wildcard address */
485 			if (!is_zero_ether_addr(src_addr->mask.addr8))
486 				continue;
487 
488 			memcpy(dest_addr, src_addr, sizeof(*src_addr));
489 			src_addr->state = FBNIC_TCAM_S_DELETE;
490 			dest_addr->state = FBNIC_TCAM_S_ADD;
491 		}
492 	}
493 }
494 
495 static void fbnic_clear_macda_entry(struct fbnic_dev *fbd, unsigned int idx)
496 {
497 	int i;
498 
499 	/* Invalidate entry and clear addr state info */
500 	for (i = 0; i <= FBNIC_RPC_TCAM_MACDA_WORD_LEN; i++)
501 		wr32(fbd, FBNIC_RPC_TCAM_MACDA(idx, i), 0);
502 }
503 
504 static void fbnic_clear_macda(struct fbnic_dev *fbd)
505 {
506 	int idx;
507 
508 	for (idx = ARRAY_SIZE(fbd->mac_addr); idx--;) {
509 		struct fbnic_mac_addr *mac_addr = &fbd->mac_addr[idx];
510 
511 		if (mac_addr->state == FBNIC_TCAM_S_DISABLED)
512 			continue;
513 
514 		if (test_bit(FBNIC_MAC_ADDR_T_BMC, mac_addr->act_tcam)) {
515 			if (fbnic_bmc_present(fbd))
516 				continue;
517 			dev_warn_once(fbd->dev,
518 				      "Found BMC MAC address w/ BMC not present\n");
519 		}
520 
521 		fbnic_clear_macda_entry(fbd, idx);
522 
523 		/* If rule was already destined for deletion just wipe it now */
524 		if (mac_addr->state == FBNIC_TCAM_S_DELETE) {
525 			memset(mac_addr, 0, sizeof(*mac_addr));
526 			continue;
527 		}
528 
529 		/* Change state to update so that we will rewrite
530 		 * this tcam the next time fbnic_write_macda is called.
531 		 */
532 		mac_addr->state = FBNIC_TCAM_S_UPDATE;
533 	}
534 }
535 
536 static void fbnic_write_macda_entry(struct fbnic_dev *fbd, unsigned int idx,
537 				    struct fbnic_mac_addr *mac_addr)
538 {
539 	__be16 *mask, *value;
540 	int i;
541 
542 	mask = &mac_addr->mask.addr16[FBNIC_RPC_TCAM_MACDA_WORD_LEN - 1];
543 	value = &mac_addr->value.addr16[FBNIC_RPC_TCAM_MACDA_WORD_LEN - 1];
544 
545 	for (i = 0; i < FBNIC_RPC_TCAM_MACDA_WORD_LEN; i++)
546 		wr32(fbd, FBNIC_RPC_TCAM_MACDA(idx, i),
547 		     FIELD_PREP(FBNIC_RPC_TCAM_MACDA_MASK, ntohs(*mask--)) |
548 		     FIELD_PREP(FBNIC_RPC_TCAM_MACDA_VALUE, ntohs(*value--)));
549 
550 	wrfl(fbd);
551 
552 	wr32(fbd, FBNIC_RPC_TCAM_MACDA(idx, i), FBNIC_RPC_TCAM_VALIDATE);
553 }
554 
555 void fbnic_write_macda(struct fbnic_dev *fbd)
556 {
557 	int idx;
558 
559 	for (idx = ARRAY_SIZE(fbd->mac_addr); idx--;) {
560 		struct fbnic_mac_addr *mac_addr = &fbd->mac_addr[idx];
561 
562 		/* Check if update flag is set else exit. */
563 		if (!(mac_addr->state & FBNIC_TCAM_S_UPDATE))
564 			continue;
565 
566 		/* Clear by writing 0s. */
567 		if (mac_addr->state == FBNIC_TCAM_S_DELETE) {
568 			/* Invalidate entry and clear addr state info */
569 			fbnic_clear_macda_entry(fbd, idx);
570 			memset(mac_addr, 0, sizeof(*mac_addr));
571 
572 			continue;
573 		}
574 
575 		fbnic_write_macda_entry(fbd, idx, mac_addr);
576 
577 		mac_addr->state = FBNIC_TCAM_S_VALID;
578 	}
579 }
580 
581 static void fbnic_clear_act_tcam(struct fbnic_dev *fbd, unsigned int idx)
582 {
583 	int i;
584 
585 	/* Invalidate entry and clear addr state info */
586 	for (i = 0; i <= FBNIC_RPC_TCAM_ACT_WORD_LEN; i++)
587 		wr32(fbd, FBNIC_RPC_TCAM_ACT(idx, i), 0);
588 }
589 
590 void fbnic_clear_rules(struct fbnic_dev *fbd)
591 {
592 	u32 dest = FIELD_PREP(FBNIC_RPC_ACT_TBL0_DEST_MASK,
593 			      FBNIC_RPC_ACT_TBL0_DEST_BMC);
594 	int i = FBNIC_RPC_TCAM_ACT_NUM_ENTRIES - 1;
595 	struct fbnic_act_tcam *act_tcam;
596 
597 	/* Clear MAC rules */
598 	fbnic_clear_macda(fbd);
599 
600 	/* If BMC is present we need to preserve the last rule which
601 	 * will be used to route traffic to the BMC if it is received.
602 	 *
603 	 * At this point it should be the only MAC address in the MACDA
604 	 * so any unicast or multicast traffic received should be routed
605 	 * to it. So leave the last rule in place.
606 	 *
607 	 * It will be rewritten to add the host again when we bring
608 	 * the interface back up.
609 	 */
610 	if (fbnic_bmc_present(fbd)) {
611 		act_tcam = &fbd->act_tcam[i];
612 
613 		if (act_tcam->state == FBNIC_TCAM_S_VALID &&
614 		    (act_tcam->dest & dest)) {
615 			wr32(fbd, FBNIC_RPC_ACT_TBL0(i), dest);
616 			wr32(fbd, FBNIC_RPC_ACT_TBL1(i), 0);
617 
618 			act_tcam->state = FBNIC_TCAM_S_UPDATE;
619 
620 			i--;
621 		}
622 	}
623 
624 	/* Work from the bottom up deleting all other rules from hardware */
625 	do {
626 		act_tcam = &fbd->act_tcam[i];
627 
628 		if (act_tcam->state != FBNIC_TCAM_S_VALID)
629 			continue;
630 
631 		fbnic_clear_act_tcam(fbd, i);
632 		act_tcam->state = FBNIC_TCAM_S_UPDATE;
633 	} while (i--);
634 }
635 
636 static void fbnic_delete_act_tcam(struct fbnic_dev *fbd, unsigned int idx)
637 {
638 	fbnic_clear_act_tcam(fbd, idx);
639 	memset(&fbd->act_tcam[idx], 0, sizeof(struct fbnic_act_tcam));
640 }
641 
642 static void fbnic_update_act_tcam(struct fbnic_dev *fbd, unsigned int idx)
643 {
644 	struct fbnic_act_tcam *act_tcam = &fbd->act_tcam[idx];
645 	int i;
646 
647 	/* Update entry by writing the destination and RSS mask */
648 	wr32(fbd, FBNIC_RPC_ACT_TBL0(idx), act_tcam->dest);
649 	wr32(fbd, FBNIC_RPC_ACT_TBL1(idx), act_tcam->rss_en_mask);
650 
651 	/* Write new TCAM rule to hardware */
652 	for (i = 0; i < FBNIC_RPC_TCAM_ACT_WORD_LEN; i++)
653 		wr32(fbd, FBNIC_RPC_TCAM_ACT(idx, i),
654 		     FIELD_PREP(FBNIC_RPC_TCAM_ACT_MASK,
655 				act_tcam->mask.tcam[i]) |
656 		     FIELD_PREP(FBNIC_RPC_TCAM_ACT_VALUE,
657 				act_tcam->value.tcam[i]));
658 
659 	wrfl(fbd);
660 
661 	wr32(fbd, FBNIC_RPC_TCAM_ACT(idx, i), FBNIC_RPC_TCAM_VALIDATE);
662 	act_tcam->state = FBNIC_TCAM_S_VALID;
663 }
664 
665 void fbnic_write_rules(struct fbnic_dev *fbd)
666 {
667 	int i;
668 
669 	/* Flush any pending action table rules */
670 	for (i = 0; i < FBNIC_RPC_ACT_TBL_NUM_ENTRIES; i++) {
671 		struct fbnic_act_tcam *act_tcam = &fbd->act_tcam[i];
672 
673 		/* Check if update flag is set else exit. */
674 		if (!(act_tcam->state & FBNIC_TCAM_S_UPDATE))
675 			continue;
676 
677 		if (act_tcam->state == FBNIC_TCAM_S_DELETE)
678 			fbnic_delete_act_tcam(fbd, i);
679 		else
680 			fbnic_update_act_tcam(fbd, i);
681 	}
682 }
683