1 // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
2 /* Copyright (c) 2019-2020 Marvell International Ltd. All rights reserved */
3
4 #include <linux/etherdevice.h>
5 #include <linux/jiffies.h>
6 #include <linux/list.h>
7 #include <linux/module.h>
8 #include <linux/netdev_features.h>
9 #include <linux/of.h>
10 #include <linux/of_net.h>
11 #include <linux/if_vlan.h>
12 #include <linux/phylink.h>
13
14 #include "prestera.h"
15 #include "prestera_hw.h"
16 #include "prestera_acl.h"
17 #include "prestera_flow.h"
18 #include "prestera_span.h"
19 #include "prestera_rxtx.h"
20 #include "prestera_devlink.h"
21 #include "prestera_ethtool.h"
22 #include "prestera_counter.h"
23 #include "prestera_switchdev.h"
24
25 #define PRESTERA_MTU_DEFAULT 1536
26
27 #define PRESTERA_STATS_DELAY_MS 1000
28
29 #define PRESTERA_MAC_ADDR_NUM_MAX 255
30
31 static struct workqueue_struct *prestera_wq;
32 static struct workqueue_struct *prestera_owq;
33
prestera_queue_work(struct work_struct * work)34 void prestera_queue_work(struct work_struct *work)
35 {
36 queue_work(prestera_owq, work);
37 }
38
prestera_queue_delayed_work(struct delayed_work * work,unsigned long delay)39 void prestera_queue_delayed_work(struct delayed_work *work, unsigned long delay)
40 {
41 queue_delayed_work(prestera_wq, work, delay);
42 }
43
prestera_queue_drain(void)44 void prestera_queue_drain(void)
45 {
46 drain_workqueue(prestera_wq);
47 drain_workqueue(prestera_owq);
48 }
49
prestera_port_learning_set(struct prestera_port * port,bool learn)50 int prestera_port_learning_set(struct prestera_port *port, bool learn)
51 {
52 return prestera_hw_port_learning_set(port, learn);
53 }
54
prestera_port_uc_flood_set(struct prestera_port * port,bool flood)55 int prestera_port_uc_flood_set(struct prestera_port *port, bool flood)
56 {
57 return prestera_hw_port_uc_flood_set(port, flood);
58 }
59
prestera_port_mc_flood_set(struct prestera_port * port,bool flood)60 int prestera_port_mc_flood_set(struct prestera_port *port, bool flood)
61 {
62 return prestera_hw_port_mc_flood_set(port, flood);
63 }
64
prestera_port_br_locked_set(struct prestera_port * port,bool br_locked)65 int prestera_port_br_locked_set(struct prestera_port *port, bool br_locked)
66 {
67 return prestera_hw_port_br_locked_set(port, br_locked);
68 }
69
prestera_port_pvid_set(struct prestera_port * port,u16 vid)70 int prestera_port_pvid_set(struct prestera_port *port, u16 vid)
71 {
72 enum prestera_accept_frm_type frm_type;
73 int err;
74
75 frm_type = PRESTERA_ACCEPT_FRAME_TYPE_TAGGED;
76
77 if (vid) {
78 err = prestera_hw_vlan_port_vid_set(port, vid);
79 if (err)
80 return err;
81
82 frm_type = PRESTERA_ACCEPT_FRAME_TYPE_ALL;
83 }
84
85 err = prestera_hw_port_accept_frm_type(port, frm_type);
86 if (err && frm_type == PRESTERA_ACCEPT_FRAME_TYPE_ALL)
87 prestera_hw_vlan_port_vid_set(port, port->pvid);
88
89 port->pvid = vid;
90 return 0;
91 }
92
prestera_port_find_by_hwid(struct prestera_switch * sw,u32 dev_id,u32 hw_id)93 struct prestera_port *prestera_port_find_by_hwid(struct prestera_switch *sw,
94 u32 dev_id, u32 hw_id)
95 {
96 struct prestera_port *port = NULL, *tmp;
97
98 read_lock(&sw->port_list_lock);
99 list_for_each_entry(tmp, &sw->port_list, list) {
100 if (tmp->dev_id == dev_id && tmp->hw_id == hw_id) {
101 port = tmp;
102 break;
103 }
104 }
105 read_unlock(&sw->port_list_lock);
106
107 return port;
108 }
109
prestera_find_port(struct prestera_switch * sw,u32 id)110 struct prestera_port *prestera_find_port(struct prestera_switch *sw, u32 id)
111 {
112 struct prestera_port *port = NULL, *tmp;
113
114 read_lock(&sw->port_list_lock);
115 list_for_each_entry(tmp, &sw->port_list, list) {
116 if (tmp->id == id) {
117 port = tmp;
118 break;
119 }
120 }
121 read_unlock(&sw->port_list_lock);
122
123 return port;
124 }
125
prestera_switch_get(struct net_device * dev)126 struct prestera_switch *prestera_switch_get(struct net_device *dev)
127 {
128 struct prestera_port *port;
129
130 port = prestera_port_dev_lower_find(dev);
131 return port ? port->sw : NULL;
132 }
133
prestera_port_cfg_mac_read(struct prestera_port * port,struct prestera_port_mac_config * cfg)134 int prestera_port_cfg_mac_read(struct prestera_port *port,
135 struct prestera_port_mac_config *cfg)
136 {
137 *cfg = port->cfg_mac;
138 return 0;
139 }
140
prestera_port_cfg_mac_write(struct prestera_port * port,struct prestera_port_mac_config * cfg)141 int prestera_port_cfg_mac_write(struct prestera_port *port,
142 struct prestera_port_mac_config *cfg)
143 {
144 int err;
145
146 err = prestera_hw_port_mac_mode_set(port, cfg->admin,
147 cfg->mode, cfg->inband, cfg->speed,
148 cfg->duplex, cfg->fec);
149 if (err)
150 return err;
151
152 port->cfg_mac = *cfg;
153 return 0;
154 }
155
prestera_port_open(struct net_device * dev)156 static int prestera_port_open(struct net_device *dev)
157 {
158 struct prestera_port *port = netdev_priv(dev);
159 struct prestera_port_mac_config cfg_mac;
160 int err = 0;
161
162 if (port->phy_link) {
163 phylink_start(port->phy_link);
164 } else {
165 if (port->caps.transceiver == PRESTERA_PORT_TCVR_SFP) {
166 err = prestera_port_cfg_mac_read(port, &cfg_mac);
167 if (!err) {
168 cfg_mac.admin = true;
169 err = prestera_port_cfg_mac_write(port,
170 &cfg_mac);
171 }
172 } else {
173 port->cfg_phy.admin = true;
174 err = prestera_hw_port_phy_mode_set(port, true,
175 port->autoneg,
176 port->cfg_phy.mode,
177 port->adver_link_modes,
178 port->cfg_phy.mdix);
179 }
180 }
181
182 netif_start_queue(dev);
183
184 return err;
185 }
186
prestera_port_close(struct net_device * dev)187 static int prestera_port_close(struct net_device *dev)
188 {
189 struct prestera_port *port = netdev_priv(dev);
190 struct prestera_port_mac_config cfg_mac;
191 int err = 0;
192
193 netif_stop_queue(dev);
194
195 if (port->phy_link) {
196 phylink_stop(port->phy_link);
197 phylink_disconnect_phy(port->phy_link);
198 err = prestera_port_cfg_mac_read(port, &cfg_mac);
199 if (!err) {
200 cfg_mac.admin = false;
201 prestera_port_cfg_mac_write(port, &cfg_mac);
202 }
203 } else {
204 if (port->caps.transceiver == PRESTERA_PORT_TCVR_SFP) {
205 err = prestera_port_cfg_mac_read(port, &cfg_mac);
206 if (!err) {
207 cfg_mac.admin = false;
208 prestera_port_cfg_mac_write(port, &cfg_mac);
209 }
210 } else {
211 port->cfg_phy.admin = false;
212 err = prestera_hw_port_phy_mode_set(port, false, port->autoneg,
213 port->cfg_phy.mode,
214 port->adver_link_modes,
215 port->cfg_phy.mdix);
216 }
217 }
218
219 return err;
220 }
221
222 static void
prestera_port_mac_state_cache_read(struct prestera_port * port,struct prestera_port_mac_state * state)223 prestera_port_mac_state_cache_read(struct prestera_port *port,
224 struct prestera_port_mac_state *state)
225 {
226 spin_lock(&port->state_mac_lock);
227 *state = port->state_mac;
228 spin_unlock(&port->state_mac_lock);
229 }
230
231 static void
prestera_port_mac_state_cache_write(struct prestera_port * port,struct prestera_port_mac_state * state)232 prestera_port_mac_state_cache_write(struct prestera_port *port,
233 struct prestera_port_mac_state *state)
234 {
235 spin_lock(&port->state_mac_lock);
236 port->state_mac = *state;
237 spin_unlock(&port->state_mac_lock);
238 }
239
prestera_pcs_to_port(struct phylink_pcs * pcs)240 static struct prestera_port *prestera_pcs_to_port(struct phylink_pcs *pcs)
241 {
242 return container_of(pcs, struct prestera_port, phylink_pcs);
243 }
244
prestera_mac_config(struct phylink_config * config,unsigned int an_mode,const struct phylink_link_state * state)245 static void prestera_mac_config(struct phylink_config *config,
246 unsigned int an_mode,
247 const struct phylink_link_state *state)
248 {
249 }
250
prestera_mac_link_down(struct phylink_config * config,unsigned int mode,phy_interface_t interface)251 static void prestera_mac_link_down(struct phylink_config *config,
252 unsigned int mode, phy_interface_t interface)
253 {
254 struct net_device *ndev = to_net_dev(config->dev);
255 struct prestera_port *port = netdev_priv(ndev);
256 struct prestera_port_mac_state state_mac;
257
258 /* Invalidate. Parameters will update on next link event. */
259 memset(&state_mac, 0, sizeof(state_mac));
260 state_mac.valid = false;
261 prestera_port_mac_state_cache_write(port, &state_mac);
262 }
263
prestera_mac_link_up(struct phylink_config * config,struct phy_device * phy,unsigned int mode,phy_interface_t interface,int speed,int duplex,bool tx_pause,bool rx_pause)264 static void prestera_mac_link_up(struct phylink_config *config,
265 struct phy_device *phy,
266 unsigned int mode, phy_interface_t interface,
267 int speed, int duplex,
268 bool tx_pause, bool rx_pause)
269 {
270 }
271
272 static struct phylink_pcs *
prestera_mac_select_pcs(struct phylink_config * config,phy_interface_t interface)273 prestera_mac_select_pcs(struct phylink_config *config,
274 phy_interface_t interface)
275 {
276 struct net_device *dev = to_net_dev(config->dev);
277 struct prestera_port *port = netdev_priv(dev);
278
279 return &port->phylink_pcs;
280 }
281
prestera_pcs_get_state(struct phylink_pcs * pcs,unsigned int neg_mode,struct phylink_link_state * state)282 static void prestera_pcs_get_state(struct phylink_pcs *pcs,
283 unsigned int neg_mode,
284 struct phylink_link_state *state)
285 {
286 struct prestera_port *port = container_of(pcs, struct prestera_port,
287 phylink_pcs);
288 struct prestera_port_mac_state smac;
289
290 prestera_port_mac_state_cache_read(port, &smac);
291
292 if (smac.valid) {
293 state->link = smac.oper ? 1 : 0;
294 /* AN is completed, when port is up */
295 state->an_complete = (smac.oper && port->autoneg) ? 1 : 0;
296 state->speed = smac.speed;
297 state->duplex = smac.duplex;
298 } else {
299 state->link = 0;
300 state->an_complete = 0;
301 }
302 }
303
prestera_pcs_config(struct phylink_pcs * pcs,unsigned int neg_mode,phy_interface_t interface,const unsigned long * advertising,bool permit_pause_to_mac)304 static int prestera_pcs_config(struct phylink_pcs *pcs, unsigned int neg_mode,
305 phy_interface_t interface,
306 const unsigned long *advertising,
307 bool permit_pause_to_mac)
308 {
309 struct prestera_port *port = prestera_pcs_to_port(pcs);
310 struct prestera_port_mac_config cfg_mac;
311 int err;
312
313 err = prestera_port_cfg_mac_read(port, &cfg_mac);
314 if (err)
315 return err;
316
317 cfg_mac.admin = true;
318 cfg_mac.fec = PRESTERA_PORT_FEC_OFF;
319 cfg_mac.inband = neg_mode == PHYLINK_PCS_NEG_INBAND_ENABLED;
320
321 switch (interface) {
322 case PHY_INTERFACE_MODE_10GBASER:
323 cfg_mac.speed = SPEED_10000;
324 cfg_mac.mode = PRESTERA_MAC_MODE_SR_LR;
325 break;
326 case PHY_INTERFACE_MODE_2500BASEX:
327 cfg_mac.speed = SPEED_2500;
328 cfg_mac.duplex = DUPLEX_FULL;
329 cfg_mac.mode = PRESTERA_MAC_MODE_SGMII;
330 break;
331 case PHY_INTERFACE_MODE_SGMII:
332 cfg_mac.mode = PRESTERA_MAC_MODE_SGMII;
333 break;
334 case PHY_INTERFACE_MODE_1000BASEX:
335 default:
336 cfg_mac.speed = SPEED_1000;
337 cfg_mac.duplex = DUPLEX_FULL;
338 cfg_mac.mode = PRESTERA_MAC_MODE_1000BASE_X;
339 break;
340 }
341
342 err = prestera_port_cfg_mac_write(port, &cfg_mac);
343 if (err)
344 return err;
345
346 return 0;
347 }
348
prestera_pcs_an_restart(struct phylink_pcs * pcs)349 static void prestera_pcs_an_restart(struct phylink_pcs *pcs)
350 {
351 /* TODO: add 1000basex AN restart support
352 * (Currently FW has no support for 1000baseX AN restart, but it will in the future,
353 * so as for now the function would stay empty.)
354 */
355 }
356
357 static const struct phylink_mac_ops prestera_mac_ops = {
358 .mac_select_pcs = prestera_mac_select_pcs,
359 .mac_config = prestera_mac_config,
360 .mac_link_down = prestera_mac_link_down,
361 .mac_link_up = prestera_mac_link_up,
362 };
363
364 static const struct phylink_pcs_ops prestera_pcs_ops = {
365 .pcs_get_state = prestera_pcs_get_state,
366 .pcs_config = prestera_pcs_config,
367 .pcs_an_restart = prestera_pcs_an_restart,
368 };
369
prestera_port_sfp_bind(struct prestera_port * port)370 static int prestera_port_sfp_bind(struct prestera_port *port)
371 {
372 struct prestera_switch *sw = port->sw;
373 struct device_node *ports, *node;
374 struct fwnode_handle *fwnode;
375 struct phylink *phy_link;
376 int err;
377
378 if (!sw->np)
379 return 0;
380
381 of_node_get(sw->np);
382 ports = of_find_node_by_name(sw->np, "ports");
383
384 for_each_child_of_node(ports, node) {
385 int num;
386
387 err = of_property_read_u32(node, "prestera,port-num", &num);
388 if (err) {
389 dev_err(sw->dev->dev,
390 "device node %pOF has no valid reg property: %d\n",
391 node, err);
392 goto out;
393 }
394
395 if (port->fp_id != num)
396 continue;
397
398 port->phylink_pcs.ops = &prestera_pcs_ops;
399 port->phylink_pcs.neg_mode = true;
400
401 port->phy_config.dev = &port->dev->dev;
402 port->phy_config.type = PHYLINK_NETDEV;
403
404 fwnode = of_fwnode_handle(node);
405
406 __set_bit(PHY_INTERFACE_MODE_10GBASER,
407 port->phy_config.supported_interfaces);
408 __set_bit(PHY_INTERFACE_MODE_2500BASEX,
409 port->phy_config.supported_interfaces);
410 __set_bit(PHY_INTERFACE_MODE_SGMII,
411 port->phy_config.supported_interfaces);
412 __set_bit(PHY_INTERFACE_MODE_1000BASEX,
413 port->phy_config.supported_interfaces);
414
415 port->phy_config.mac_capabilities =
416 MAC_1000 | MAC_2500FD | MAC_10000FD;
417
418 phy_link = phylink_create(&port->phy_config, fwnode,
419 PHY_INTERFACE_MODE_INTERNAL,
420 &prestera_mac_ops);
421 if (IS_ERR(phy_link)) {
422 netdev_err(port->dev, "failed to create phylink\n");
423 err = PTR_ERR(phy_link);
424 goto out;
425 }
426
427 port->phy_link = phy_link;
428 break;
429 }
430
431 out:
432 of_node_put(node);
433 of_node_put(ports);
434 return err;
435 }
436
prestera_port_sfp_unbind(struct prestera_port * port)437 static int prestera_port_sfp_unbind(struct prestera_port *port)
438 {
439 if (port->phy_link)
440 phylink_destroy(port->phy_link);
441
442 return 0;
443 }
444
prestera_port_xmit(struct sk_buff * skb,struct net_device * dev)445 static netdev_tx_t prestera_port_xmit(struct sk_buff *skb,
446 struct net_device *dev)
447 {
448 return prestera_rxtx_xmit(netdev_priv(dev), skb);
449 }
450
prestera_is_valid_mac_addr(struct prestera_port * port,const u8 * addr)451 int prestera_is_valid_mac_addr(struct prestera_port *port, const u8 *addr)
452 {
453 if (!is_valid_ether_addr(addr))
454 return -EADDRNOTAVAIL;
455
456 /* firmware requires that port's MAC address contains first 5 bytes
457 * of the base MAC address
458 */
459 if (memcmp(port->sw->base_mac, addr, ETH_ALEN - 1))
460 return -EINVAL;
461
462 return 0;
463 }
464
prestera_port_set_mac_address(struct net_device * dev,void * p)465 static int prestera_port_set_mac_address(struct net_device *dev, void *p)
466 {
467 struct prestera_port *port = netdev_priv(dev);
468 struct sockaddr *addr = p;
469 int err;
470
471 err = prestera_is_valid_mac_addr(port, addr->sa_data);
472 if (err)
473 return err;
474
475 err = prestera_hw_port_mac_set(port, addr->sa_data);
476 if (err)
477 return err;
478
479 eth_hw_addr_set(dev, addr->sa_data);
480
481 return 0;
482 }
483
prestera_port_change_mtu(struct net_device * dev,int mtu)484 static int prestera_port_change_mtu(struct net_device *dev, int mtu)
485 {
486 struct prestera_port *port = netdev_priv(dev);
487 int err;
488
489 err = prestera_hw_port_mtu_set(port, mtu);
490 if (err)
491 return err;
492
493 WRITE_ONCE(dev->mtu, mtu);
494
495 return 0;
496 }
497
prestera_port_get_stats64(struct net_device * dev,struct rtnl_link_stats64 * stats)498 static void prestera_port_get_stats64(struct net_device *dev,
499 struct rtnl_link_stats64 *stats)
500 {
501 struct prestera_port *port = netdev_priv(dev);
502 struct prestera_port_stats *port_stats = &port->cached_hw_stats.stats;
503
504 stats->rx_packets = port_stats->broadcast_frames_received +
505 port_stats->multicast_frames_received +
506 port_stats->unicast_frames_received;
507
508 stats->tx_packets = port_stats->broadcast_frames_sent +
509 port_stats->multicast_frames_sent +
510 port_stats->unicast_frames_sent;
511
512 stats->rx_bytes = port_stats->good_octets_received;
513
514 stats->tx_bytes = port_stats->good_octets_sent;
515
516 stats->rx_errors = port_stats->rx_error_frame_received;
517 stats->tx_errors = port_stats->mac_trans_error;
518
519 stats->rx_dropped = port_stats->buffer_overrun;
520 stats->tx_dropped = 0;
521
522 stats->multicast = port_stats->multicast_frames_received;
523 stats->collisions = port_stats->excessive_collision;
524
525 stats->rx_crc_errors = port_stats->bad_crc;
526 }
527
prestera_port_get_hw_stats(struct prestera_port * port)528 static void prestera_port_get_hw_stats(struct prestera_port *port)
529 {
530 prestera_hw_port_stats_get(port, &port->cached_hw_stats.stats);
531 }
532
prestera_port_stats_update(struct work_struct * work)533 static void prestera_port_stats_update(struct work_struct *work)
534 {
535 struct prestera_port *port =
536 container_of(work, struct prestera_port,
537 cached_hw_stats.caching_dw.work);
538
539 prestera_port_get_hw_stats(port);
540
541 queue_delayed_work(prestera_wq, &port->cached_hw_stats.caching_dw,
542 msecs_to_jiffies(PRESTERA_STATS_DELAY_MS));
543 }
544
prestera_port_setup_tc(struct net_device * dev,enum tc_setup_type type,void * type_data)545 static int prestera_port_setup_tc(struct net_device *dev,
546 enum tc_setup_type type,
547 void *type_data)
548 {
549 struct prestera_port *port = netdev_priv(dev);
550
551 switch (type) {
552 case TC_SETUP_BLOCK:
553 return prestera_flow_block_setup(port, type_data);
554 default:
555 return -EOPNOTSUPP;
556 }
557 }
558
559 static const struct net_device_ops prestera_netdev_ops = {
560 .ndo_open = prestera_port_open,
561 .ndo_stop = prestera_port_close,
562 .ndo_start_xmit = prestera_port_xmit,
563 .ndo_setup_tc = prestera_port_setup_tc,
564 .ndo_change_mtu = prestera_port_change_mtu,
565 .ndo_get_stats64 = prestera_port_get_stats64,
566 .ndo_set_mac_address = prestera_port_set_mac_address,
567 };
568
prestera_port_autoneg_set(struct prestera_port * port,u64 link_modes)569 int prestera_port_autoneg_set(struct prestera_port *port, u64 link_modes)
570 {
571 int err;
572
573 if (port->autoneg && port->adver_link_modes == link_modes)
574 return 0;
575
576 err = prestera_hw_port_phy_mode_set(port, port->cfg_phy.admin,
577 true, 0, link_modes,
578 port->cfg_phy.mdix);
579 if (err)
580 return err;
581
582 port->adver_fec = BIT(PRESTERA_PORT_FEC_OFF);
583 port->adver_link_modes = link_modes;
584 port->cfg_phy.mode = 0;
585 port->autoneg = true;
586
587 return 0;
588 }
589
prestera_port_list_add(struct prestera_port * port)590 static void prestera_port_list_add(struct prestera_port *port)
591 {
592 write_lock(&port->sw->port_list_lock);
593 list_add(&port->list, &port->sw->port_list);
594 write_unlock(&port->sw->port_list_lock);
595 }
596
prestera_port_list_del(struct prestera_port * port)597 static void prestera_port_list_del(struct prestera_port *port)
598 {
599 write_lock(&port->sw->port_list_lock);
600 list_del(&port->list);
601 write_unlock(&port->sw->port_list_lock);
602 }
603
prestera_port_create(struct prestera_switch * sw,u32 id)604 static int prestera_port_create(struct prestera_switch *sw, u32 id)
605 {
606 struct prestera_port_mac_config cfg_mac;
607 struct prestera_port *port;
608 struct net_device *dev;
609 int err;
610
611 dev = alloc_etherdev(sizeof(*port));
612 if (!dev)
613 return -ENOMEM;
614
615 port = netdev_priv(dev);
616
617 INIT_LIST_HEAD(&port->vlans_list);
618 port->pvid = PRESTERA_DEFAULT_VID;
619 port->lag = NULL;
620 port->dev = dev;
621 port->id = id;
622 port->sw = sw;
623
624 spin_lock_init(&port->state_mac_lock);
625
626 err = prestera_hw_port_info_get(port, &port->dev_id, &port->hw_id,
627 &port->fp_id);
628 if (err) {
629 dev_err(prestera_dev(sw), "Failed to get port(%u) info\n", id);
630 goto err_port_info_get;
631 }
632
633 err = prestera_devlink_port_register(port);
634 if (err)
635 goto err_dl_port_register;
636
637 dev->features |= NETIF_F_HW_TC;
638 dev->netns_local = true;
639 dev->netdev_ops = &prestera_netdev_ops;
640 dev->ethtool_ops = &prestera_ethtool_ops;
641 SET_NETDEV_DEV(dev, sw->dev->dev);
642 SET_NETDEV_DEVLINK_PORT(dev, &port->dl_port);
643
644 if (port->caps.transceiver != PRESTERA_PORT_TCVR_SFP)
645 netif_carrier_off(dev);
646
647 dev->mtu = min_t(unsigned int, sw->mtu_max, PRESTERA_MTU_DEFAULT);
648 dev->min_mtu = sw->mtu_min;
649 dev->max_mtu = sw->mtu_max;
650
651 err = prestera_hw_port_mtu_set(port, dev->mtu);
652 if (err) {
653 dev_err(prestera_dev(sw), "Failed to set port(%u) mtu(%d)\n",
654 id, dev->mtu);
655 goto err_port_init;
656 }
657
658 if (port->fp_id >= PRESTERA_MAC_ADDR_NUM_MAX) {
659 err = -EINVAL;
660 goto err_port_init;
661 }
662
663 eth_hw_addr_gen(dev, sw->base_mac, port->fp_id);
664 /* firmware requires that port's MAC address consist of the first
665 * 5 bytes of the base MAC address
666 */
667 if (memcmp(dev->dev_addr, sw->base_mac, ETH_ALEN - 1)) {
668 dev_warn(prestera_dev(sw), "Port MAC address wraps for port(%u)\n", id);
669 dev_addr_mod(dev, 0, sw->base_mac, ETH_ALEN - 1);
670 }
671
672 err = prestera_hw_port_mac_set(port, dev->dev_addr);
673 if (err) {
674 dev_err(prestera_dev(sw), "Failed to set port(%u) mac addr\n", id);
675 goto err_port_init;
676 }
677
678 err = prestera_hw_port_cap_get(port, &port->caps);
679 if (err) {
680 dev_err(prestera_dev(sw), "Failed to get port(%u) caps\n", id);
681 goto err_port_init;
682 }
683
684 port->adver_link_modes = port->caps.supp_link_modes;
685 port->adver_fec = 0;
686 port->autoneg = true;
687
688 /* initialize config mac */
689 if (port->caps.transceiver != PRESTERA_PORT_TCVR_SFP) {
690 cfg_mac.admin = true;
691 cfg_mac.mode = PRESTERA_MAC_MODE_INTERNAL;
692 } else {
693 cfg_mac.admin = false;
694 cfg_mac.mode = PRESTERA_MAC_MODE_MAX;
695 }
696 cfg_mac.inband = 0;
697 cfg_mac.speed = 0;
698 cfg_mac.duplex = DUPLEX_UNKNOWN;
699 cfg_mac.fec = PRESTERA_PORT_FEC_OFF;
700
701 err = prestera_port_cfg_mac_write(port, &cfg_mac);
702 if (err) {
703 dev_err(prestera_dev(sw),
704 "Failed to set port(%u) mac mode\n", id);
705 goto err_port_init;
706 }
707
708 /* initialize config phy (if this is inegral) */
709 if (port->caps.transceiver != PRESTERA_PORT_TCVR_SFP) {
710 port->cfg_phy.mdix = ETH_TP_MDI_AUTO;
711 port->cfg_phy.admin = false;
712 err = prestera_hw_port_phy_mode_set(port,
713 port->cfg_phy.admin,
714 false, 0, 0,
715 port->cfg_phy.mdix);
716 if (err) {
717 dev_err(prestera_dev(sw),
718 "Failed to set port(%u) phy mode\n", id);
719 goto err_port_init;
720 }
721 }
722
723 err = prestera_rxtx_port_init(port);
724 if (err)
725 goto err_port_init;
726
727 INIT_DELAYED_WORK(&port->cached_hw_stats.caching_dw,
728 &prestera_port_stats_update);
729
730 prestera_port_list_add(port);
731
732 err = register_netdev(dev);
733 if (err)
734 goto err_register_netdev;
735
736 err = prestera_port_sfp_bind(port);
737 if (err)
738 goto err_sfp_bind;
739
740 return 0;
741
742 err_sfp_bind:
743 unregister_netdev(dev);
744 err_register_netdev:
745 prestera_port_list_del(port);
746 err_port_init:
747 prestera_devlink_port_unregister(port);
748 err_dl_port_register:
749 err_port_info_get:
750 free_netdev(dev);
751 return err;
752 }
753
prestera_port_destroy(struct prestera_port * port)754 static void prestera_port_destroy(struct prestera_port *port)
755 {
756 struct net_device *dev = port->dev;
757
758 cancel_delayed_work_sync(&port->cached_hw_stats.caching_dw);
759 unregister_netdev(dev);
760 prestera_port_list_del(port);
761 prestera_devlink_port_unregister(port);
762 free_netdev(dev);
763 }
764
prestera_destroy_ports(struct prestera_switch * sw)765 static void prestera_destroy_ports(struct prestera_switch *sw)
766 {
767 struct prestera_port *port, *tmp;
768
769 list_for_each_entry_safe(port, tmp, &sw->port_list, list)
770 prestera_port_destroy(port);
771 }
772
prestera_create_ports(struct prestera_switch * sw)773 static int prestera_create_ports(struct prestera_switch *sw)
774 {
775 struct prestera_port *port, *tmp;
776 u32 port_idx;
777 int err;
778
779 for (port_idx = 0; port_idx < sw->port_count; port_idx++) {
780 err = prestera_port_create(sw, port_idx);
781 if (err)
782 goto err_port_create;
783 }
784
785 return 0;
786
787 err_port_create:
788 list_for_each_entry_safe(port, tmp, &sw->port_list, list) {
789 prestera_port_sfp_unbind(port);
790 prestera_port_destroy(port);
791 }
792
793 return err;
794 }
795
prestera_port_handle_event(struct prestera_switch * sw,struct prestera_event * evt,void * arg)796 static void prestera_port_handle_event(struct prestera_switch *sw,
797 struct prestera_event *evt, void *arg)
798 {
799 struct prestera_port_mac_state smac;
800 struct prestera_port_event *pevt;
801 struct delayed_work *caching_dw;
802 struct prestera_port *port;
803
804 if (evt->id == PRESTERA_PORT_EVENT_MAC_STATE_CHANGED) {
805 pevt = &evt->port_evt;
806 port = prestera_find_port(sw, pevt->port_id);
807 if (!port || !port->dev)
808 return;
809
810 caching_dw = &port->cached_hw_stats.caching_dw;
811
812 memset(&smac, 0, sizeof(smac));
813 smac.valid = true;
814 smac.oper = pevt->data.mac.oper;
815 if (smac.oper) {
816 smac.mode = pevt->data.mac.mode;
817 smac.speed = pevt->data.mac.speed;
818 smac.duplex = pevt->data.mac.duplex;
819 smac.fc = pevt->data.mac.fc;
820 smac.fec = pevt->data.mac.fec;
821 }
822 prestera_port_mac_state_cache_write(port, &smac);
823
824 if (port->state_mac.oper) {
825 if (port->phy_link)
826 phylink_pcs_change(&port->phylink_pcs, true);
827 else
828 netif_carrier_on(port->dev);
829
830 if (!delayed_work_pending(caching_dw))
831 queue_delayed_work(prestera_wq, caching_dw, 0);
832 } else {
833 if (port->phy_link)
834 phylink_pcs_change(&port->phylink_pcs, false);
835 else if (netif_running(port->dev) && netif_carrier_ok(port->dev))
836 netif_carrier_off(port->dev);
837
838 if (delayed_work_pending(caching_dw))
839 cancel_delayed_work(caching_dw);
840 }
841 }
842 }
843
prestera_event_handlers_register(struct prestera_switch * sw)844 static int prestera_event_handlers_register(struct prestera_switch *sw)
845 {
846 return prestera_hw_event_handler_register(sw, PRESTERA_EVENT_TYPE_PORT,
847 prestera_port_handle_event,
848 NULL);
849 }
850
prestera_event_handlers_unregister(struct prestera_switch * sw)851 static void prestera_event_handlers_unregister(struct prestera_switch *sw)
852 {
853 prestera_hw_event_handler_unregister(sw, PRESTERA_EVENT_TYPE_PORT,
854 prestera_port_handle_event);
855 }
856
prestera_switch_set_base_mac_addr(struct prestera_switch * sw)857 static int prestera_switch_set_base_mac_addr(struct prestera_switch *sw)
858 {
859 int ret;
860
861 if (sw->np)
862 ret = of_get_mac_address(sw->np, sw->base_mac);
863 if (!is_valid_ether_addr(sw->base_mac) || ret) {
864 eth_random_addr(sw->base_mac);
865 dev_info(prestera_dev(sw), "using random base mac address\n");
866 }
867
868 return prestera_hw_switch_mac_set(sw, sw->base_mac);
869 }
870
prestera_lag_by_id(struct prestera_switch * sw,u16 id)871 struct prestera_lag *prestera_lag_by_id(struct prestera_switch *sw, u16 id)
872 {
873 return id < sw->lag_max ? &sw->lags[id] : NULL;
874 }
875
prestera_lag_by_dev(struct prestera_switch * sw,struct net_device * dev)876 static struct prestera_lag *prestera_lag_by_dev(struct prestera_switch *sw,
877 struct net_device *dev)
878 {
879 struct prestera_lag *lag;
880 u16 id;
881
882 for (id = 0; id < sw->lag_max; id++) {
883 lag = &sw->lags[id];
884 if (lag->dev == dev)
885 return lag;
886 }
887
888 return NULL;
889 }
890
prestera_lag_id(struct prestera_switch * sw,struct net_device * lag_dev,u16 * lag_id)891 int prestera_lag_id(struct prestera_switch *sw,
892 struct net_device *lag_dev, u16 *lag_id)
893 {
894 struct prestera_lag *lag;
895 int free_id = -1;
896 int id;
897
898 for (id = 0; id < sw->lag_max; id++) {
899 lag = prestera_lag_by_id(sw, id);
900 if (lag->member_count) {
901 if (lag->dev == lag_dev) {
902 *lag_id = id;
903 return 0;
904 }
905 } else if (free_id < 0) {
906 free_id = id;
907 }
908 }
909 if (free_id < 0)
910 return -ENOSPC;
911 *lag_id = free_id;
912 return 0;
913 }
914
prestera_lag_create(struct prestera_switch * sw,struct net_device * lag_dev)915 static struct prestera_lag *prestera_lag_create(struct prestera_switch *sw,
916 struct net_device *lag_dev)
917 {
918 struct prestera_lag *lag = NULL;
919 u16 id;
920
921 for (id = 0; id < sw->lag_max; id++) {
922 lag = &sw->lags[id];
923 if (!lag->dev)
924 break;
925 }
926 if (lag) {
927 INIT_LIST_HEAD(&lag->members);
928 lag->dev = lag_dev;
929 }
930
931 return lag;
932 }
933
prestera_lag_destroy(struct prestera_switch * sw,struct prestera_lag * lag)934 static void prestera_lag_destroy(struct prestera_switch *sw,
935 struct prestera_lag *lag)
936 {
937 WARN_ON(!list_empty(&lag->members));
938 lag->member_count = 0;
939 lag->dev = NULL;
940 }
941
prestera_lag_port_add(struct prestera_port * port,struct net_device * lag_dev)942 static int prestera_lag_port_add(struct prestera_port *port,
943 struct net_device *lag_dev)
944 {
945 struct prestera_switch *sw = port->sw;
946 struct prestera_lag *lag;
947 int err;
948
949 lag = prestera_lag_by_dev(sw, lag_dev);
950 if (!lag) {
951 lag = prestera_lag_create(sw, lag_dev);
952 if (!lag)
953 return -ENOSPC;
954 }
955
956 if (lag->member_count >= sw->lag_member_max)
957 return -ENOSPC;
958
959 err = prestera_hw_lag_member_add(port, lag->lag_id);
960 if (err) {
961 if (!lag->member_count)
962 prestera_lag_destroy(sw, lag);
963 return err;
964 }
965
966 list_add(&port->lag_member, &lag->members);
967 lag->member_count++;
968 port->lag = lag;
969
970 return 0;
971 }
972
prestera_lag_port_del(struct prestera_port * port)973 static int prestera_lag_port_del(struct prestera_port *port)
974 {
975 struct prestera_switch *sw = port->sw;
976 struct prestera_lag *lag = port->lag;
977 int err;
978
979 if (!lag || !lag->member_count)
980 return -EINVAL;
981
982 err = prestera_hw_lag_member_del(port, lag->lag_id);
983 if (err)
984 return err;
985
986 list_del(&port->lag_member);
987 lag->member_count--;
988 port->lag = NULL;
989
990 if (netif_is_bridge_port(lag->dev)) {
991 struct net_device *br_dev;
992
993 br_dev = netdev_master_upper_dev_get(lag->dev);
994
995 prestera_bridge_port_leave(br_dev, port);
996 }
997
998 if (!lag->member_count)
999 prestera_lag_destroy(sw, lag);
1000
1001 return 0;
1002 }
1003
prestera_port_is_lag_member(const struct prestera_port * port)1004 bool prestera_port_is_lag_member(const struct prestera_port *port)
1005 {
1006 return !!port->lag;
1007 }
1008
prestera_port_lag_id(const struct prestera_port * port)1009 u16 prestera_port_lag_id(const struct prestera_port *port)
1010 {
1011 return port->lag->lag_id;
1012 }
1013
prestera_lag_init(struct prestera_switch * sw)1014 static int prestera_lag_init(struct prestera_switch *sw)
1015 {
1016 u16 id;
1017
1018 sw->lags = kcalloc(sw->lag_max, sizeof(*sw->lags), GFP_KERNEL);
1019 if (!sw->lags)
1020 return -ENOMEM;
1021
1022 for (id = 0; id < sw->lag_max; id++)
1023 sw->lags[id].lag_id = id;
1024
1025 return 0;
1026 }
1027
prestera_lag_fini(struct prestera_switch * sw)1028 static void prestera_lag_fini(struct prestera_switch *sw)
1029 {
1030 u8 idx;
1031
1032 for (idx = 0; idx < sw->lag_max; idx++)
1033 WARN_ON(sw->lags[idx].member_count);
1034
1035 kfree(sw->lags);
1036 }
1037
prestera_netdev_check(const struct net_device * dev)1038 bool prestera_netdev_check(const struct net_device *dev)
1039 {
1040 return dev->netdev_ops == &prestera_netdev_ops;
1041 }
1042
prestera_lower_dev_walk(struct net_device * dev,struct netdev_nested_priv * priv)1043 static int prestera_lower_dev_walk(struct net_device *dev,
1044 struct netdev_nested_priv *priv)
1045 {
1046 struct prestera_port **pport = (struct prestera_port **)priv->data;
1047
1048 if (prestera_netdev_check(dev)) {
1049 *pport = netdev_priv(dev);
1050 return 1;
1051 }
1052
1053 return 0;
1054 }
1055
prestera_port_dev_lower_find(struct net_device * dev)1056 struct prestera_port *prestera_port_dev_lower_find(struct net_device *dev)
1057 {
1058 struct prestera_port *port = NULL;
1059 struct netdev_nested_priv priv = {
1060 .data = (void *)&port,
1061 };
1062
1063 if (prestera_netdev_check(dev))
1064 return netdev_priv(dev);
1065
1066 netdev_walk_all_lower_dev(dev, prestera_lower_dev_walk, &priv);
1067
1068 return port;
1069 }
1070
prestera_netdev_port_lower_event(struct net_device * dev,unsigned long event,void * ptr)1071 static int prestera_netdev_port_lower_event(struct net_device *dev,
1072 unsigned long event, void *ptr)
1073 {
1074 struct netdev_notifier_changelowerstate_info *info = ptr;
1075 struct netdev_lag_lower_state_info *lower_state_info;
1076 struct prestera_port *port = netdev_priv(dev);
1077 bool enabled;
1078
1079 if (!netif_is_lag_port(dev))
1080 return 0;
1081 if (!prestera_port_is_lag_member(port))
1082 return 0;
1083
1084 lower_state_info = info->lower_state_info;
1085 enabled = lower_state_info->link_up && lower_state_info->tx_enabled;
1086
1087 return prestera_hw_lag_member_enable(port, port->lag->lag_id, enabled);
1088 }
1089
prestera_lag_master_check(struct net_device * lag_dev,struct netdev_lag_upper_info * info,struct netlink_ext_ack * ext_ack)1090 static bool prestera_lag_master_check(struct net_device *lag_dev,
1091 struct netdev_lag_upper_info *info,
1092 struct netlink_ext_ack *ext_ack)
1093 {
1094 if (info->tx_type != NETDEV_LAG_TX_TYPE_HASH) {
1095 NL_SET_ERR_MSG_MOD(ext_ack, "Unsupported LAG Tx type");
1096 return false;
1097 }
1098
1099 return true;
1100 }
1101
prestera_netdev_port_event(struct net_device * lower,struct net_device * dev,unsigned long event,void * ptr)1102 static int prestera_netdev_port_event(struct net_device *lower,
1103 struct net_device *dev,
1104 unsigned long event, void *ptr)
1105 {
1106 struct netdev_notifier_info *info = ptr;
1107 struct netdev_notifier_changeupper_info *cu_info;
1108 struct prestera_port *port = netdev_priv(dev);
1109 struct netlink_ext_ack *extack;
1110 struct net_device *upper;
1111
1112 extack = netdev_notifier_info_to_extack(info);
1113 cu_info = container_of(info,
1114 struct netdev_notifier_changeupper_info,
1115 info);
1116
1117 switch (event) {
1118 case NETDEV_PRECHANGEUPPER:
1119 upper = cu_info->upper_dev;
1120 if (!netif_is_bridge_master(upper) &&
1121 !netif_is_lag_master(upper)) {
1122 NL_SET_ERR_MSG_MOD(extack, "Unknown upper device type");
1123 return -EINVAL;
1124 }
1125
1126 if (!cu_info->linking)
1127 break;
1128
1129 if (netdev_has_any_upper_dev(upper)) {
1130 NL_SET_ERR_MSG_MOD(extack, "Upper device is already enslaved");
1131 return -EINVAL;
1132 }
1133
1134 if (netif_is_lag_master(upper) &&
1135 !prestera_lag_master_check(upper, cu_info->upper_info, extack))
1136 return -EOPNOTSUPP;
1137 if (netif_is_lag_master(upper) && vlan_uses_dev(dev)) {
1138 NL_SET_ERR_MSG_MOD(extack,
1139 "Master device is a LAG master and port has a VLAN");
1140 return -EINVAL;
1141 }
1142 if (netif_is_lag_port(dev) && is_vlan_dev(upper) &&
1143 !netif_is_lag_master(vlan_dev_real_dev(upper))) {
1144 NL_SET_ERR_MSG_MOD(extack,
1145 "Can not put a VLAN on a LAG port");
1146 return -EINVAL;
1147 }
1148 break;
1149
1150 case NETDEV_CHANGEUPPER:
1151 upper = cu_info->upper_dev;
1152 if (netif_is_bridge_master(upper)) {
1153 if (cu_info->linking)
1154 return prestera_bridge_port_join(upper, port,
1155 extack);
1156 else
1157 prestera_bridge_port_leave(upper, port);
1158 } else if (netif_is_lag_master(upper)) {
1159 if (cu_info->linking)
1160 return prestera_lag_port_add(port, upper);
1161 else
1162 prestera_lag_port_del(port);
1163 }
1164 break;
1165
1166 case NETDEV_CHANGELOWERSTATE:
1167 return prestera_netdev_port_lower_event(dev, event, ptr);
1168 }
1169
1170 return 0;
1171 }
1172
prestera_netdevice_lag_event(struct net_device * lag_dev,unsigned long event,void * ptr)1173 static int prestera_netdevice_lag_event(struct net_device *lag_dev,
1174 unsigned long event, void *ptr)
1175 {
1176 struct net_device *dev;
1177 struct list_head *iter;
1178 int err;
1179
1180 netdev_for_each_lower_dev(lag_dev, dev, iter) {
1181 if (prestera_netdev_check(dev)) {
1182 err = prestera_netdev_port_event(lag_dev, dev, event,
1183 ptr);
1184 if (err)
1185 return err;
1186 }
1187 }
1188
1189 return 0;
1190 }
1191
prestera_netdev_event_handler(struct notifier_block * nb,unsigned long event,void * ptr)1192 static int prestera_netdev_event_handler(struct notifier_block *nb,
1193 unsigned long event, void *ptr)
1194 {
1195 struct net_device *dev = netdev_notifier_info_to_dev(ptr);
1196 int err = 0;
1197
1198 if (prestera_netdev_check(dev))
1199 err = prestera_netdev_port_event(dev, dev, event, ptr);
1200 else if (netif_is_lag_master(dev))
1201 err = prestera_netdevice_lag_event(dev, event, ptr);
1202
1203 return notifier_from_errno(err);
1204 }
1205
1206 struct prestera_mdb_entry *
prestera_mdb_entry_create(struct prestera_switch * sw,const unsigned char * addr,u16 vid)1207 prestera_mdb_entry_create(struct prestera_switch *sw,
1208 const unsigned char *addr, u16 vid)
1209 {
1210 struct prestera_flood_domain *flood_domain;
1211 struct prestera_mdb_entry *mdb_entry;
1212
1213 mdb_entry = kzalloc(sizeof(*mdb_entry), GFP_KERNEL);
1214 if (!mdb_entry)
1215 goto err_mdb_alloc;
1216
1217 flood_domain = prestera_flood_domain_create(sw);
1218 if (!flood_domain)
1219 goto err_flood_domain_create;
1220
1221 mdb_entry->sw = sw;
1222 mdb_entry->vid = vid;
1223 mdb_entry->flood_domain = flood_domain;
1224 ether_addr_copy(mdb_entry->addr, addr);
1225
1226 if (prestera_hw_mdb_create(mdb_entry))
1227 goto err_mdb_hw_create;
1228
1229 return mdb_entry;
1230
1231 err_mdb_hw_create:
1232 prestera_flood_domain_destroy(flood_domain);
1233 err_flood_domain_create:
1234 kfree(mdb_entry);
1235 err_mdb_alloc:
1236 return NULL;
1237 }
1238
prestera_mdb_entry_destroy(struct prestera_mdb_entry * mdb_entry)1239 void prestera_mdb_entry_destroy(struct prestera_mdb_entry *mdb_entry)
1240 {
1241 prestera_hw_mdb_destroy(mdb_entry);
1242 prestera_flood_domain_destroy(mdb_entry->flood_domain);
1243 kfree(mdb_entry);
1244 }
1245
1246 struct prestera_flood_domain *
prestera_flood_domain_create(struct prestera_switch * sw)1247 prestera_flood_domain_create(struct prestera_switch *sw)
1248 {
1249 struct prestera_flood_domain *domain;
1250
1251 domain = kzalloc(sizeof(*domain), GFP_KERNEL);
1252 if (!domain)
1253 return NULL;
1254
1255 domain->sw = sw;
1256
1257 if (prestera_hw_flood_domain_create(domain)) {
1258 kfree(domain);
1259 return NULL;
1260 }
1261
1262 INIT_LIST_HEAD(&domain->flood_domain_port_list);
1263
1264 return domain;
1265 }
1266
prestera_flood_domain_destroy(struct prestera_flood_domain * flood_domain)1267 void prestera_flood_domain_destroy(struct prestera_flood_domain *flood_domain)
1268 {
1269 WARN_ON(!list_empty(&flood_domain->flood_domain_port_list));
1270 WARN_ON_ONCE(prestera_hw_flood_domain_destroy(flood_domain));
1271 kfree(flood_domain);
1272 }
1273
1274 int
prestera_flood_domain_port_create(struct prestera_flood_domain * flood_domain,struct net_device * dev,u16 vid)1275 prestera_flood_domain_port_create(struct prestera_flood_domain *flood_domain,
1276 struct net_device *dev,
1277 u16 vid)
1278 {
1279 struct prestera_flood_domain_port *flood_domain_port;
1280 bool is_first_port_in_list = false;
1281 int err;
1282
1283 flood_domain_port = kzalloc(sizeof(*flood_domain_port), GFP_KERNEL);
1284 if (!flood_domain_port) {
1285 err = -ENOMEM;
1286 goto err_port_alloc;
1287 }
1288
1289 flood_domain_port->vid = vid;
1290
1291 if (list_empty(&flood_domain->flood_domain_port_list))
1292 is_first_port_in_list = true;
1293
1294 list_add(&flood_domain_port->flood_domain_port_node,
1295 &flood_domain->flood_domain_port_list);
1296
1297 flood_domain_port->flood_domain = flood_domain;
1298 flood_domain_port->dev = dev;
1299
1300 if (!is_first_port_in_list) {
1301 err = prestera_hw_flood_domain_ports_reset(flood_domain);
1302 if (err)
1303 goto err_prestera_mdb_port_create_hw;
1304 }
1305
1306 err = prestera_hw_flood_domain_ports_set(flood_domain);
1307 if (err)
1308 goto err_prestera_mdb_port_create_hw;
1309
1310 return 0;
1311
1312 err_prestera_mdb_port_create_hw:
1313 list_del(&flood_domain_port->flood_domain_port_node);
1314 kfree(flood_domain_port);
1315 err_port_alloc:
1316 return err;
1317 }
1318
1319 void
prestera_flood_domain_port_destroy(struct prestera_flood_domain_port * port)1320 prestera_flood_domain_port_destroy(struct prestera_flood_domain_port *port)
1321 {
1322 struct prestera_flood_domain *flood_domain = port->flood_domain;
1323
1324 list_del(&port->flood_domain_port_node);
1325
1326 WARN_ON_ONCE(prestera_hw_flood_domain_ports_reset(flood_domain));
1327
1328 if (!list_empty(&flood_domain->flood_domain_port_list))
1329 WARN_ON_ONCE(prestera_hw_flood_domain_ports_set(flood_domain));
1330
1331 kfree(port);
1332 }
1333
1334 struct prestera_flood_domain_port *
prestera_flood_domain_port_find(struct prestera_flood_domain * flood_domain,struct net_device * dev,u16 vid)1335 prestera_flood_domain_port_find(struct prestera_flood_domain *flood_domain,
1336 struct net_device *dev, u16 vid)
1337 {
1338 struct prestera_flood_domain_port *flood_domain_port;
1339
1340 list_for_each_entry(flood_domain_port,
1341 &flood_domain->flood_domain_port_list,
1342 flood_domain_port_node)
1343 if (flood_domain_port->dev == dev &&
1344 vid == flood_domain_port->vid)
1345 return flood_domain_port;
1346
1347 return NULL;
1348 }
1349
prestera_netdev_event_handler_register(struct prestera_switch * sw)1350 static int prestera_netdev_event_handler_register(struct prestera_switch *sw)
1351 {
1352 sw->netdev_nb.notifier_call = prestera_netdev_event_handler;
1353
1354 return register_netdevice_notifier(&sw->netdev_nb);
1355 }
1356
prestera_netdev_event_handler_unregister(struct prestera_switch * sw)1357 static void prestera_netdev_event_handler_unregister(struct prestera_switch *sw)
1358 {
1359 unregister_netdevice_notifier(&sw->netdev_nb);
1360 }
1361
prestera_switch_init(struct prestera_switch * sw)1362 static int prestera_switch_init(struct prestera_switch *sw)
1363 {
1364 int err;
1365
1366 sw->np = sw->dev->dev->of_node;
1367
1368 err = prestera_hw_switch_init(sw);
1369 if (err) {
1370 dev_err(prestera_dev(sw), "Failed to init Switch device\n");
1371 return err;
1372 }
1373
1374 rwlock_init(&sw->port_list_lock);
1375 INIT_LIST_HEAD(&sw->port_list);
1376
1377 err = prestera_switch_set_base_mac_addr(sw);
1378 if (err)
1379 return err;
1380
1381 err = prestera_netdev_event_handler_register(sw);
1382 if (err)
1383 return err;
1384
1385 err = prestera_router_init(sw);
1386 if (err)
1387 goto err_router_init;
1388
1389 err = prestera_switchdev_init(sw);
1390 if (err)
1391 goto err_swdev_register;
1392
1393 err = prestera_rxtx_switch_init(sw);
1394 if (err)
1395 goto err_rxtx_register;
1396
1397 err = prestera_event_handlers_register(sw);
1398 if (err)
1399 goto err_handlers_register;
1400
1401 err = prestera_counter_init(sw);
1402 if (err)
1403 goto err_counter_init;
1404
1405 err = prestera_acl_init(sw);
1406 if (err)
1407 goto err_acl_init;
1408
1409 err = prestera_span_init(sw);
1410 if (err)
1411 goto err_span_init;
1412
1413 err = prestera_devlink_traps_register(sw);
1414 if (err)
1415 goto err_dl_register;
1416
1417 err = prestera_lag_init(sw);
1418 if (err)
1419 goto err_lag_init;
1420
1421 err = prestera_create_ports(sw);
1422 if (err)
1423 goto err_ports_create;
1424
1425 prestera_devlink_register(sw);
1426 return 0;
1427
1428 err_ports_create:
1429 prestera_lag_fini(sw);
1430 err_lag_init:
1431 prestera_devlink_traps_unregister(sw);
1432 err_dl_register:
1433 prestera_span_fini(sw);
1434 err_span_init:
1435 prestera_acl_fini(sw);
1436 err_acl_init:
1437 prestera_counter_fini(sw);
1438 err_counter_init:
1439 prestera_event_handlers_unregister(sw);
1440 err_handlers_register:
1441 prestera_rxtx_switch_fini(sw);
1442 err_rxtx_register:
1443 prestera_switchdev_fini(sw);
1444 err_swdev_register:
1445 prestera_router_fini(sw);
1446 err_router_init:
1447 prestera_netdev_event_handler_unregister(sw);
1448 prestera_hw_switch_fini(sw);
1449
1450 return err;
1451 }
1452
prestera_switch_fini(struct prestera_switch * sw)1453 static void prestera_switch_fini(struct prestera_switch *sw)
1454 {
1455 prestera_devlink_unregister(sw);
1456 prestera_destroy_ports(sw);
1457 prestera_lag_fini(sw);
1458 prestera_devlink_traps_unregister(sw);
1459 prestera_span_fini(sw);
1460 prestera_acl_fini(sw);
1461 prestera_counter_fini(sw);
1462 prestera_event_handlers_unregister(sw);
1463 prestera_rxtx_switch_fini(sw);
1464 prestera_switchdev_fini(sw);
1465 prestera_router_fini(sw);
1466 prestera_netdev_event_handler_unregister(sw);
1467 prestera_hw_switch_fini(sw);
1468 of_node_put(sw->np);
1469 }
1470
prestera_device_register(struct prestera_device * dev)1471 int prestera_device_register(struct prestera_device *dev)
1472 {
1473 struct prestera_switch *sw;
1474 int err;
1475
1476 sw = prestera_devlink_alloc(dev);
1477 if (!sw)
1478 return -ENOMEM;
1479
1480 dev->priv = sw;
1481 sw->dev = dev;
1482
1483 err = prestera_switch_init(sw);
1484 if (err) {
1485 prestera_devlink_free(sw);
1486 return err;
1487 }
1488
1489 return 0;
1490 }
1491 EXPORT_SYMBOL(prestera_device_register);
1492
prestera_device_unregister(struct prestera_device * dev)1493 void prestera_device_unregister(struct prestera_device *dev)
1494 {
1495 struct prestera_switch *sw = dev->priv;
1496
1497 prestera_switch_fini(sw);
1498 prestera_devlink_free(sw);
1499 }
1500 EXPORT_SYMBOL(prestera_device_unregister);
1501
prestera_module_init(void)1502 static int __init prestera_module_init(void)
1503 {
1504 prestera_wq = alloc_workqueue("prestera", 0, 0);
1505 if (!prestera_wq)
1506 return -ENOMEM;
1507
1508 prestera_owq = alloc_ordered_workqueue("prestera_ordered", 0);
1509 if (!prestera_owq) {
1510 destroy_workqueue(prestera_wq);
1511 return -ENOMEM;
1512 }
1513
1514 return 0;
1515 }
1516
prestera_module_exit(void)1517 static void __exit prestera_module_exit(void)
1518 {
1519 destroy_workqueue(prestera_wq);
1520 destroy_workqueue(prestera_owq);
1521 }
1522
1523 module_init(prestera_module_init);
1524 module_exit(prestera_module_exit);
1525
1526 MODULE_LICENSE("Dual BSD/GPL");
1527 MODULE_DESCRIPTION("Marvell Prestera switch driver");
1528