OSDN Git Service

e475186b70c77b9548db9a89b99524e94e1b6414
[uclinux-h8/linux.git] / drivers / net / dsa / ocelot / felix.c
1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright 2019-2021 NXP
3  *
4  * This is an umbrella module for all network switches that are
5  * register-compatible with Ocelot and that perform I/O to their host CPU
6  * through an NPI (Node Processor Interface) Ethernet port.
7  */
8 #include <uapi/linux/if_bridge.h>
9 #include <soc/mscc/ocelot_vcap.h>
10 #include <soc/mscc/ocelot_qsys.h>
11 #include <soc/mscc/ocelot_sys.h>
12 #include <soc/mscc/ocelot_dev.h>
13 #include <soc/mscc/ocelot_ana.h>
14 #include <soc/mscc/ocelot_ptp.h>
15 #include <soc/mscc/ocelot.h>
16 #include <linux/dsa/8021q.h>
17 #include <linux/dsa/ocelot.h>
18 #include <linux/platform_device.h>
19 #include <linux/ptp_classify.h>
20 #include <linux/module.h>
21 #include <linux/of_net.h>
22 #include <linux/pci.h>
23 #include <linux/of.h>
24 #include <net/pkt_sched.h>
25 #include <net/dsa.h>
26 #include "felix.h"
27
28 /* Translate the DSA database API into the ocelot switch library API,
29  * which uses VID 0 for all ports that aren't part of a bridge,
30  * and expects the bridge_dev to be NULL in that case.
31  */
32 static struct net_device *felix_classify_db(struct dsa_db db)
33 {
34         switch (db.type) {
35         case DSA_DB_PORT:
36         case DSA_DB_LAG:
37                 return NULL;
38         case DSA_DB_BRIDGE:
39                 return db.bridge.dev;
40         default:
41                 return ERR_PTR(-EOPNOTSUPP);
42         }
43 }
44
45 /* We are called before felix_npi_port_init(), so ocelot->npi is -1. */
46 static int felix_migrate_fdbs_to_npi_port(struct dsa_switch *ds, int port,
47                                           const unsigned char *addr, u16 vid,
48                                           struct dsa_db db)
49 {
50         struct net_device *bridge_dev = felix_classify_db(db);
51         struct ocelot *ocelot = ds->priv;
52         int cpu = ocelot->num_phys_ports;
53         int err;
54
55         err = ocelot_fdb_del(ocelot, port, addr, vid, bridge_dev);
56         if (err)
57                 return err;
58
59         return ocelot_fdb_add(ocelot, cpu, addr, vid, bridge_dev);
60 }
61
62 static int felix_migrate_mdbs_to_npi_port(struct dsa_switch *ds, int port,
63                                           const unsigned char *addr, u16 vid,
64                                           struct dsa_db db)
65 {
66         struct net_device *bridge_dev = felix_classify_db(db);
67         struct switchdev_obj_port_mdb mdb;
68         struct ocelot *ocelot = ds->priv;
69         int cpu = ocelot->num_phys_ports;
70         int err;
71
72         memset(&mdb, 0, sizeof(mdb));
73         ether_addr_copy(mdb.addr, addr);
74         mdb.vid = vid;
75
76         err = ocelot_port_mdb_del(ocelot, port, &mdb, bridge_dev);
77         if (err)
78                 return err;
79
80         return ocelot_port_mdb_add(ocelot, cpu, &mdb, bridge_dev);
81 }
82
83 static void felix_migrate_pgid_bit(struct dsa_switch *ds, int from, int to,
84                                    int pgid)
85 {
86         struct ocelot *ocelot = ds->priv;
87         bool on;
88         u32 val;
89
90         val = ocelot_read_rix(ocelot, ANA_PGID_PGID, pgid);
91         on = !!(val & BIT(from));
92         val &= ~BIT(from);
93         if (on)
94                 val |= BIT(to);
95         else
96                 val &= ~BIT(to);
97
98         ocelot_write_rix(ocelot, val, ANA_PGID_PGID, pgid);
99 }
100
101 static void felix_migrate_flood_to_npi_port(struct dsa_switch *ds, int port)
102 {
103         struct ocelot *ocelot = ds->priv;
104
105         felix_migrate_pgid_bit(ds, port, ocelot->num_phys_ports, PGID_UC);
106         felix_migrate_pgid_bit(ds, port, ocelot->num_phys_ports, PGID_MC);
107         felix_migrate_pgid_bit(ds, port, ocelot->num_phys_ports, PGID_BC);
108 }
109
110 static void
111 felix_migrate_flood_to_tag_8021q_port(struct dsa_switch *ds, int port)
112 {
113         struct ocelot *ocelot = ds->priv;
114
115         felix_migrate_pgid_bit(ds, ocelot->num_phys_ports, port, PGID_UC);
116         felix_migrate_pgid_bit(ds, ocelot->num_phys_ports, port, PGID_MC);
117         felix_migrate_pgid_bit(ds, ocelot->num_phys_ports, port, PGID_BC);
118 }
119
120 /* ocelot->npi was already set to -1 by felix_npi_port_deinit, so
121  * ocelot_fdb_add() will not redirect FDB entries towards the
122  * CPU port module here, which is what we want.
123  */
124 static int
125 felix_migrate_fdbs_to_tag_8021q_port(struct dsa_switch *ds, int port,
126                                      const unsigned char *addr, u16 vid,
127                                      struct dsa_db db)
128 {
129         struct net_device *bridge_dev = felix_classify_db(db);
130         struct ocelot *ocelot = ds->priv;
131         int cpu = ocelot->num_phys_ports;
132         int err;
133
134         err = ocelot_fdb_del(ocelot, cpu, addr, vid, bridge_dev);
135         if (err)
136                 return err;
137
138         return ocelot_fdb_add(ocelot, port, addr, vid, bridge_dev);
139 }
140
141 static int
142 felix_migrate_mdbs_to_tag_8021q_port(struct dsa_switch *ds, int port,
143                                      const unsigned char *addr, u16 vid,
144                                      struct dsa_db db)
145 {
146         struct net_device *bridge_dev = felix_classify_db(db);
147         struct switchdev_obj_port_mdb mdb;
148         struct ocelot *ocelot = ds->priv;
149         int cpu = ocelot->num_phys_ports;
150         int err;
151
152         memset(&mdb, 0, sizeof(mdb));
153         ether_addr_copy(mdb.addr, addr);
154         mdb.vid = vid;
155
156         err = ocelot_port_mdb_del(ocelot, cpu, &mdb, bridge_dev);
157         if (err)
158                 return err;
159
160         return ocelot_port_mdb_add(ocelot, port, &mdb, bridge_dev);
161 }
162
163 /* Set up VCAP ES0 rules for pushing a tag_8021q VLAN towards the CPU such that
164  * the tagger can perform RX source port identification.
165  */
166 static int felix_tag_8021q_vlan_add_rx(struct felix *felix, int port, u16 vid)
167 {
168         struct ocelot_vcap_filter *outer_tagging_rule;
169         struct ocelot *ocelot = &felix->ocelot;
170         struct dsa_switch *ds = felix->ds;
171         int key_length, upstream, err;
172
173         key_length = ocelot->vcap[VCAP_ES0].keys[VCAP_ES0_IGR_PORT].length;
174         upstream = dsa_upstream_port(ds, port);
175
176         outer_tagging_rule = kzalloc(sizeof(struct ocelot_vcap_filter),
177                                      GFP_KERNEL);
178         if (!outer_tagging_rule)
179                 return -ENOMEM;
180
181         outer_tagging_rule->key_type = OCELOT_VCAP_KEY_ANY;
182         outer_tagging_rule->prio = 1;
183         outer_tagging_rule->id.cookie = OCELOT_VCAP_ES0_TAG_8021Q_RXVLAN(ocelot, port);
184         outer_tagging_rule->id.tc_offload = false;
185         outer_tagging_rule->block_id = VCAP_ES0;
186         outer_tagging_rule->type = OCELOT_VCAP_FILTER_OFFLOAD;
187         outer_tagging_rule->lookup = 0;
188         outer_tagging_rule->ingress_port.value = port;
189         outer_tagging_rule->ingress_port.mask = GENMASK(key_length - 1, 0);
190         outer_tagging_rule->egress_port.value = upstream;
191         outer_tagging_rule->egress_port.mask = GENMASK(key_length - 1, 0);
192         outer_tagging_rule->action.push_outer_tag = OCELOT_ES0_TAG;
193         outer_tagging_rule->action.tag_a_tpid_sel = OCELOT_TAG_TPID_SEL_8021AD;
194         outer_tagging_rule->action.tag_a_vid_sel = 1;
195         outer_tagging_rule->action.vid_a_val = vid;
196
197         err = ocelot_vcap_filter_add(ocelot, outer_tagging_rule, NULL);
198         if (err)
199                 kfree(outer_tagging_rule);
200
201         return err;
202 }
203
204 static int felix_tag_8021q_vlan_del_rx(struct felix *felix, int port, u16 vid)
205 {
206         struct ocelot_vcap_filter *outer_tagging_rule;
207         struct ocelot_vcap_block *block_vcap_es0;
208         struct ocelot *ocelot = &felix->ocelot;
209
210         block_vcap_es0 = &ocelot->block[VCAP_ES0];
211
212         outer_tagging_rule = ocelot_vcap_block_find_filter_by_id(block_vcap_es0,
213                                                                  port, false);
214         if (!outer_tagging_rule)
215                 return -ENOENT;
216
217         return ocelot_vcap_filter_del(ocelot, outer_tagging_rule);
218 }
219
220 /* Set up VCAP IS1 rules for stripping the tag_8021q VLAN on TX and VCAP IS2
221  * rules for steering those tagged packets towards the correct destination port
222  */
223 static int felix_tag_8021q_vlan_add_tx(struct felix *felix, int port, u16 vid)
224 {
225         struct ocelot_vcap_filter *untagging_rule, *redirect_rule;
226         struct ocelot *ocelot = &felix->ocelot;
227         struct dsa_switch *ds = felix->ds;
228         int upstream, err;
229
230         untagging_rule = kzalloc(sizeof(struct ocelot_vcap_filter), GFP_KERNEL);
231         if (!untagging_rule)
232                 return -ENOMEM;
233
234         redirect_rule = kzalloc(sizeof(struct ocelot_vcap_filter), GFP_KERNEL);
235         if (!redirect_rule) {
236                 kfree(untagging_rule);
237                 return -ENOMEM;
238         }
239
240         upstream = dsa_upstream_port(ds, port);
241
242         untagging_rule->key_type = OCELOT_VCAP_KEY_ANY;
243         untagging_rule->ingress_port_mask = BIT(upstream);
244         untagging_rule->vlan.vid.value = vid;
245         untagging_rule->vlan.vid.mask = VLAN_VID_MASK;
246         untagging_rule->prio = 1;
247         untagging_rule->id.cookie = OCELOT_VCAP_IS1_TAG_8021Q_TXVLAN(ocelot, port);
248         untagging_rule->id.tc_offload = false;
249         untagging_rule->block_id = VCAP_IS1;
250         untagging_rule->type = OCELOT_VCAP_FILTER_OFFLOAD;
251         untagging_rule->lookup = 0;
252         untagging_rule->action.vlan_pop_cnt_ena = true;
253         untagging_rule->action.vlan_pop_cnt = 1;
254         untagging_rule->action.pag_override_mask = 0xff;
255         untagging_rule->action.pag_val = port;
256
257         err = ocelot_vcap_filter_add(ocelot, untagging_rule, NULL);
258         if (err) {
259                 kfree(untagging_rule);
260                 kfree(redirect_rule);
261                 return err;
262         }
263
264         redirect_rule->key_type = OCELOT_VCAP_KEY_ANY;
265         redirect_rule->ingress_port_mask = BIT(upstream);
266         redirect_rule->pag = port;
267         redirect_rule->prio = 1;
268         redirect_rule->id.cookie = OCELOT_VCAP_IS2_TAG_8021Q_TXVLAN(ocelot, port);
269         redirect_rule->id.tc_offload = false;
270         redirect_rule->block_id = VCAP_IS2;
271         redirect_rule->type = OCELOT_VCAP_FILTER_OFFLOAD;
272         redirect_rule->lookup = 0;
273         redirect_rule->action.mask_mode = OCELOT_MASK_MODE_REDIRECT;
274         redirect_rule->action.port_mask = BIT(port);
275
276         err = ocelot_vcap_filter_add(ocelot, redirect_rule, NULL);
277         if (err) {
278                 ocelot_vcap_filter_del(ocelot, untagging_rule);
279                 kfree(redirect_rule);
280                 return err;
281         }
282
283         return 0;
284 }
285
286 static int felix_tag_8021q_vlan_del_tx(struct felix *felix, int port, u16 vid)
287 {
288         struct ocelot_vcap_filter *untagging_rule, *redirect_rule;
289         struct ocelot_vcap_block *block_vcap_is1;
290         struct ocelot_vcap_block *block_vcap_is2;
291         struct ocelot *ocelot = &felix->ocelot;
292         int err;
293
294         block_vcap_is1 = &ocelot->block[VCAP_IS1];
295         block_vcap_is2 = &ocelot->block[VCAP_IS2];
296
297         untagging_rule = ocelot_vcap_block_find_filter_by_id(block_vcap_is1,
298                                                              port, false);
299         if (!untagging_rule)
300                 return -ENOENT;
301
302         err = ocelot_vcap_filter_del(ocelot, untagging_rule);
303         if (err)
304                 return err;
305
306         redirect_rule = ocelot_vcap_block_find_filter_by_id(block_vcap_is2,
307                                                             port, false);
308         if (!redirect_rule)
309                 return -ENOENT;
310
311         return ocelot_vcap_filter_del(ocelot, redirect_rule);
312 }
313
314 static int felix_tag_8021q_vlan_add(struct dsa_switch *ds, int port, u16 vid,
315                                     u16 flags)
316 {
317         struct ocelot *ocelot = ds->priv;
318         int err;
319
320         /* tag_8021q.c assumes we are implementing this via port VLAN
321          * membership, which we aren't. So we don't need to add any VCAP filter
322          * for the CPU port.
323          */
324         if (!dsa_is_user_port(ds, port))
325                 return 0;
326
327         err = felix_tag_8021q_vlan_add_rx(ocelot_to_felix(ocelot), port, vid);
328         if (err)
329                 return err;
330
331         err = felix_tag_8021q_vlan_add_tx(ocelot_to_felix(ocelot), port, vid);
332         if (err) {
333                 felix_tag_8021q_vlan_del_rx(ocelot_to_felix(ocelot), port, vid);
334                 return err;
335         }
336
337         return 0;
338 }
339
340 static int felix_tag_8021q_vlan_del(struct dsa_switch *ds, int port, u16 vid)
341 {
342         struct ocelot *ocelot = ds->priv;
343         int err;
344
345         if (!dsa_is_user_port(ds, port))
346                 return 0;
347
348         err = felix_tag_8021q_vlan_del_rx(ocelot_to_felix(ocelot), port, vid);
349         if (err)
350                 return err;
351
352         err = felix_tag_8021q_vlan_del_tx(ocelot_to_felix(ocelot), port, vid);
353         if (err) {
354                 felix_tag_8021q_vlan_add_rx(ocelot_to_felix(ocelot), port, vid);
355                 return err;
356         }
357
358         return 0;
359 }
360
361 /* Alternatively to using the NPI functionality, that same hardware MAC
362  * connected internally to the enetc or fman DSA master can be configured to
363  * use the software-defined tag_8021q frame format. As far as the hardware is
364  * concerned, it thinks it is a "dumb switch" - the queues of the CPU port
365  * module are now disconnected from it, but can still be accessed through
366  * register-based MMIO.
367  */
368 static void felix_8021q_cpu_port_init(struct ocelot *ocelot, int port)
369 {
370         mutex_lock(&ocelot->fwd_domain_lock);
371
372         ocelot_port_set_dsa_8021q_cpu(ocelot, port);
373
374         /* Overwrite PGID_CPU with the non-tagging port */
375         ocelot_write_rix(ocelot, BIT(port), ANA_PGID_PGID, PGID_CPU);
376
377         ocelot_apply_bridge_fwd_mask(ocelot, true);
378
379         mutex_unlock(&ocelot->fwd_domain_lock);
380 }
381
382 static void felix_8021q_cpu_port_deinit(struct ocelot *ocelot, int port)
383 {
384         mutex_lock(&ocelot->fwd_domain_lock);
385
386         ocelot_port_unset_dsa_8021q_cpu(ocelot, port);
387
388         /* Restore PGID_CPU */
389         ocelot_write_rix(ocelot, BIT(ocelot->num_phys_ports), ANA_PGID_PGID,
390                          PGID_CPU);
391
392         ocelot_apply_bridge_fwd_mask(ocelot, true);
393
394         mutex_unlock(&ocelot->fwd_domain_lock);
395 }
396
397 /* On switches with no extraction IRQ wired, trapped packets need to be
398  * replicated over Ethernet as well, otherwise we'd get no notification of
399  * their arrival when using the ocelot-8021q tagging protocol.
400  */
401 static int felix_update_trapping_destinations(struct dsa_switch *ds,
402                                               bool using_tag_8021q)
403 {
404         struct ocelot *ocelot = ds->priv;
405         struct felix *felix = ocelot_to_felix(ocelot);
406         struct ocelot_vcap_filter *trap;
407         enum ocelot_mask_mode mask_mode;
408         unsigned long port_mask;
409         struct dsa_port *dp;
410         bool cpu_copy_ena;
411         int cpu = -1, err;
412
413         if (!felix->info->quirk_no_xtr_irq)
414                 return 0;
415
416         /* Figure out the current CPU port */
417         dsa_switch_for_each_cpu_port(dp, ds) {
418                 cpu = dp->index;
419                 break;
420         }
421
422         /* We are sure that "cpu" was found, otherwise
423          * dsa_tree_setup_default_cpu() would have failed earlier.
424          */
425
426         /* Make sure all traps are set up for that destination */
427         list_for_each_entry(trap, &ocelot->traps, trap_list) {
428                 /* Figure out the current trapping destination */
429                 if (using_tag_8021q) {
430                         /* Redirect to the tag_8021q CPU port. If timestamps
431                          * are necessary, also copy trapped packets to the CPU
432                          * port module.
433                          */
434                         mask_mode = OCELOT_MASK_MODE_REDIRECT;
435                         port_mask = BIT(cpu);
436                         cpu_copy_ena = !!trap->take_ts;
437                 } else {
438                         /* Trap packets only to the CPU port module, which is
439                          * redirected to the NPI port (the DSA CPU port)
440                          */
441                         mask_mode = OCELOT_MASK_MODE_PERMIT_DENY;
442                         port_mask = 0;
443                         cpu_copy_ena = true;
444                 }
445
446                 if (trap->action.mask_mode == mask_mode &&
447                     trap->action.port_mask == port_mask &&
448                     trap->action.cpu_copy_ena == cpu_copy_ena)
449                         continue;
450
451                 trap->action.mask_mode = mask_mode;
452                 trap->action.port_mask = port_mask;
453                 trap->action.cpu_copy_ena = cpu_copy_ena;
454
455                 err = ocelot_vcap_filter_replace(ocelot, trap);
456                 if (err)
457                         return err;
458         }
459
460         return 0;
461 }
462
463 static int felix_setup_tag_8021q(struct dsa_switch *ds, int cpu)
464 {
465         struct ocelot *ocelot = ds->priv;
466         struct dsa_port *dp;
467         int err;
468
469         felix_8021q_cpu_port_init(ocelot, cpu);
470
471         dsa_switch_for_each_available_port(dp, ds) {
472                 /* This overwrites ocelot_init():
473                  * Do not forward BPDU frames to the CPU port module,
474                  * for 2 reasons:
475                  * - When these packets are injected from the tag_8021q
476                  *   CPU port, we want them to go out, not loop back
477                  *   into the system.
478                  * - STP traffic ingressing on a user port should go to
479                  *   the tag_8021q CPU port, not to the hardware CPU
480                  *   port module.
481                  */
482                 ocelot_write_gix(ocelot,
483                                  ANA_PORT_CPU_FWD_BPDU_CFG_BPDU_REDIR_ENA(0),
484                                  ANA_PORT_CPU_FWD_BPDU_CFG, dp->index);
485         }
486
487         err = dsa_tag_8021q_register(ds, htons(ETH_P_8021AD));
488         if (err)
489                 return err;
490
491         err = dsa_port_walk_fdbs(ds, cpu, felix_migrate_fdbs_to_tag_8021q_port);
492         if (err)
493                 goto out_tag_8021q_unregister;
494
495         err = dsa_port_walk_mdbs(ds, cpu, felix_migrate_mdbs_to_tag_8021q_port);
496         if (err)
497                 goto out_migrate_fdbs;
498
499         felix_migrate_flood_to_tag_8021q_port(ds, cpu);
500
501         err = felix_update_trapping_destinations(ds, true);
502         if (err)
503                 goto out_migrate_flood;
504
505         /* The ownership of the CPU port module's queues might have just been
506          * transferred to the tag_8021q tagger from the NPI-based tagger.
507          * So there might still be all sorts of crap in the queues. On the
508          * other hand, the MMIO-based matching of PTP frames is very brittle,
509          * so we need to be careful that there are no extra frames to be
510          * dequeued over MMIO, since we would never know to discard them.
511          */
512         ocelot_drain_cpu_queue(ocelot, 0);
513
514         return 0;
515
516 out_migrate_flood:
517         felix_migrate_flood_to_npi_port(ds, cpu);
518         dsa_port_walk_mdbs(ds, cpu, felix_migrate_mdbs_to_npi_port);
519 out_migrate_fdbs:
520         dsa_port_walk_fdbs(ds, cpu, felix_migrate_fdbs_to_npi_port);
521 out_tag_8021q_unregister:
522         dsa_tag_8021q_unregister(ds);
523         return err;
524 }
525
526 static void felix_teardown_tag_8021q(struct dsa_switch *ds, int cpu)
527 {
528         struct ocelot *ocelot = ds->priv;
529         struct dsa_port *dp;
530         int err;
531
532         err = felix_update_trapping_destinations(ds, false);
533         if (err)
534                 dev_err(ds->dev, "felix_teardown_mmio_filtering returned %d",
535                         err);
536
537         dsa_tag_8021q_unregister(ds);
538
539         dsa_switch_for_each_available_port(dp, ds) {
540                 /* Restore the logic from ocelot_init:
541                  * do not forward BPDU frames to the front ports.
542                  */
543                 ocelot_write_gix(ocelot,
544                                  ANA_PORT_CPU_FWD_BPDU_CFG_BPDU_REDIR_ENA(0xffff),
545                                  ANA_PORT_CPU_FWD_BPDU_CFG,
546                                  dp->index);
547         }
548
549         felix_8021q_cpu_port_deinit(ocelot, cpu);
550 }
551
552 /* The CPU port module is connected to the Node Processor Interface (NPI). This
553  * is the mode through which frames can be injected from and extracted to an
554  * external CPU, over Ethernet. In NXP SoCs, the "external CPU" is the ARM CPU
555  * running Linux, and this forms a DSA setup together with the enetc or fman
556  * DSA master.
557  */
558 static void felix_npi_port_init(struct ocelot *ocelot, int port)
559 {
560         ocelot->npi = port;
561
562         ocelot_write(ocelot, QSYS_EXT_CPU_CFG_EXT_CPUQ_MSK_M |
563                      QSYS_EXT_CPU_CFG_EXT_CPU_PORT(port),
564                      QSYS_EXT_CPU_CFG);
565
566         /* NPI port Injection/Extraction configuration */
567         ocelot_fields_write(ocelot, port, SYS_PORT_MODE_INCL_XTR_HDR,
568                             ocelot->npi_xtr_prefix);
569         ocelot_fields_write(ocelot, port, SYS_PORT_MODE_INCL_INJ_HDR,
570                             ocelot->npi_inj_prefix);
571
572         /* Disable transmission of pause frames */
573         ocelot_fields_write(ocelot, port, SYS_PAUSE_CFG_PAUSE_ENA, 0);
574 }
575
576 static void felix_npi_port_deinit(struct ocelot *ocelot, int port)
577 {
578         /* Restore hardware defaults */
579         int unused_port = ocelot->num_phys_ports + 2;
580
581         ocelot->npi = -1;
582
583         ocelot_write(ocelot, QSYS_EXT_CPU_CFG_EXT_CPU_PORT(unused_port),
584                      QSYS_EXT_CPU_CFG);
585
586         ocelot_fields_write(ocelot, port, SYS_PORT_MODE_INCL_XTR_HDR,
587                             OCELOT_TAG_PREFIX_DISABLED);
588         ocelot_fields_write(ocelot, port, SYS_PORT_MODE_INCL_INJ_HDR,
589                             OCELOT_TAG_PREFIX_DISABLED);
590
591         /* Enable transmission of pause frames */
592         ocelot_fields_write(ocelot, port, SYS_PAUSE_CFG_PAUSE_ENA, 1);
593 }
594
595 static int felix_setup_tag_npi(struct dsa_switch *ds, int cpu)
596 {
597         struct ocelot *ocelot = ds->priv;
598         int err;
599
600         err = dsa_port_walk_fdbs(ds, cpu, felix_migrate_fdbs_to_npi_port);
601         if (err)
602                 return err;
603
604         err = dsa_port_walk_mdbs(ds, cpu, felix_migrate_mdbs_to_npi_port);
605         if (err)
606                 goto out_migrate_fdbs;
607
608         felix_migrate_flood_to_npi_port(ds, cpu);
609
610         felix_npi_port_init(ocelot, cpu);
611
612         return 0;
613
614 out_migrate_fdbs:
615         dsa_port_walk_fdbs(ds, cpu, felix_migrate_fdbs_to_tag_8021q_port);
616
617         return err;
618 }
619
620 static void felix_teardown_tag_npi(struct dsa_switch *ds, int cpu)
621 {
622         struct ocelot *ocelot = ds->priv;
623
624         felix_npi_port_deinit(ocelot, cpu);
625 }
626
627 static int felix_set_tag_protocol(struct dsa_switch *ds, int cpu,
628                                   enum dsa_tag_protocol proto)
629 {
630         int err;
631
632         switch (proto) {
633         case DSA_TAG_PROTO_SEVILLE:
634         case DSA_TAG_PROTO_OCELOT:
635                 err = felix_setup_tag_npi(ds, cpu);
636                 break;
637         case DSA_TAG_PROTO_OCELOT_8021Q:
638                 err = felix_setup_tag_8021q(ds, cpu);
639                 break;
640         default:
641                 err = -EPROTONOSUPPORT;
642         }
643
644         return err;
645 }
646
647 static void felix_del_tag_protocol(struct dsa_switch *ds, int cpu,
648                                    enum dsa_tag_protocol proto)
649 {
650         switch (proto) {
651         case DSA_TAG_PROTO_SEVILLE:
652         case DSA_TAG_PROTO_OCELOT:
653                 felix_teardown_tag_npi(ds, cpu);
654                 break;
655         case DSA_TAG_PROTO_OCELOT_8021Q:
656                 felix_teardown_tag_8021q(ds, cpu);
657                 break;
658         default:
659                 break;
660         }
661 }
662
663 /* This always leaves the switch in a consistent state, because although the
664  * tag_8021q setup can fail, the NPI setup can't. So either the change is made,
665  * or the restoration is guaranteed to work.
666  */
667 static int felix_change_tag_protocol(struct dsa_switch *ds, int cpu,
668                                      enum dsa_tag_protocol proto)
669 {
670         struct ocelot *ocelot = ds->priv;
671         struct felix *felix = ocelot_to_felix(ocelot);
672         enum dsa_tag_protocol old_proto = felix->tag_proto;
673         int err;
674
675         if (proto != DSA_TAG_PROTO_SEVILLE &&
676             proto != DSA_TAG_PROTO_OCELOT &&
677             proto != DSA_TAG_PROTO_OCELOT_8021Q)
678                 return -EPROTONOSUPPORT;
679
680         felix_del_tag_protocol(ds, cpu, old_proto);
681
682         err = felix_set_tag_protocol(ds, cpu, proto);
683         if (err) {
684                 felix_set_tag_protocol(ds, cpu, old_proto);
685                 return err;
686         }
687
688         felix->tag_proto = proto;
689
690         return 0;
691 }
692
693 static enum dsa_tag_protocol felix_get_tag_protocol(struct dsa_switch *ds,
694                                                     int port,
695                                                     enum dsa_tag_protocol mp)
696 {
697         struct ocelot *ocelot = ds->priv;
698         struct felix *felix = ocelot_to_felix(ocelot);
699
700         return felix->tag_proto;
701 }
702
703 static int felix_set_ageing_time(struct dsa_switch *ds,
704                                  unsigned int ageing_time)
705 {
706         struct ocelot *ocelot = ds->priv;
707
708         ocelot_set_ageing_time(ocelot, ageing_time);
709
710         return 0;
711 }
712
713 static void felix_port_fast_age(struct dsa_switch *ds, int port)
714 {
715         struct ocelot *ocelot = ds->priv;
716         int err;
717
718         err = ocelot_mact_flush(ocelot, port);
719         if (err)
720                 dev_err(ds->dev, "Flushing MAC table on port %d returned %pe\n",
721                         port, ERR_PTR(err));
722 }
723
724 static int felix_fdb_dump(struct dsa_switch *ds, int port,
725                           dsa_fdb_dump_cb_t *cb, void *data)
726 {
727         struct ocelot *ocelot = ds->priv;
728
729         return ocelot_fdb_dump(ocelot, port, cb, data);
730 }
731
732 static int felix_fdb_add(struct dsa_switch *ds, int port,
733                          const unsigned char *addr, u16 vid,
734                          struct dsa_db db)
735 {
736         struct net_device *bridge_dev = felix_classify_db(db);
737         struct ocelot *ocelot = ds->priv;
738
739         if (IS_ERR(bridge_dev))
740                 return PTR_ERR(bridge_dev);
741
742         return ocelot_fdb_add(ocelot, port, addr, vid, bridge_dev);
743 }
744
745 static int felix_fdb_del(struct dsa_switch *ds, int port,
746                          const unsigned char *addr, u16 vid,
747                          struct dsa_db db)
748 {
749         struct net_device *bridge_dev = felix_classify_db(db);
750         struct ocelot *ocelot = ds->priv;
751
752         if (IS_ERR(bridge_dev))
753                 return PTR_ERR(bridge_dev);
754
755         return ocelot_fdb_del(ocelot, port, addr, vid, bridge_dev);
756 }
757
758 static int felix_lag_fdb_add(struct dsa_switch *ds, struct dsa_lag lag,
759                              const unsigned char *addr, u16 vid,
760                              struct dsa_db db)
761 {
762         struct net_device *bridge_dev = felix_classify_db(db);
763         struct ocelot *ocelot = ds->priv;
764
765         if (IS_ERR(bridge_dev))
766                 return PTR_ERR(bridge_dev);
767
768         return ocelot_lag_fdb_add(ocelot, lag.dev, addr, vid, bridge_dev);
769 }
770
771 static int felix_lag_fdb_del(struct dsa_switch *ds, struct dsa_lag lag,
772                              const unsigned char *addr, u16 vid,
773                              struct dsa_db db)
774 {
775         struct net_device *bridge_dev = felix_classify_db(db);
776         struct ocelot *ocelot = ds->priv;
777
778         if (IS_ERR(bridge_dev))
779                 return PTR_ERR(bridge_dev);
780
781         return ocelot_lag_fdb_del(ocelot, lag.dev, addr, vid, bridge_dev);
782 }
783
784 static int felix_mdb_add(struct dsa_switch *ds, int port,
785                          const struct switchdev_obj_port_mdb *mdb,
786                          struct dsa_db db)
787 {
788         struct net_device *bridge_dev = felix_classify_db(db);
789         struct ocelot *ocelot = ds->priv;
790
791         if (IS_ERR(bridge_dev))
792                 return PTR_ERR(bridge_dev);
793
794         return ocelot_port_mdb_add(ocelot, port, mdb, bridge_dev);
795 }
796
797 static int felix_mdb_del(struct dsa_switch *ds, int port,
798                          const struct switchdev_obj_port_mdb *mdb,
799                          struct dsa_db db)
800 {
801         struct net_device *bridge_dev = felix_classify_db(db);
802         struct ocelot *ocelot = ds->priv;
803
804         if (IS_ERR(bridge_dev))
805                 return PTR_ERR(bridge_dev);
806
807         return ocelot_port_mdb_del(ocelot, port, mdb, bridge_dev);
808 }
809
810 static void felix_bridge_stp_state_set(struct dsa_switch *ds, int port,
811                                        u8 state)
812 {
813         struct ocelot *ocelot = ds->priv;
814
815         return ocelot_bridge_stp_state_set(ocelot, port, state);
816 }
817
818 static int felix_pre_bridge_flags(struct dsa_switch *ds, int port,
819                                   struct switchdev_brport_flags val,
820                                   struct netlink_ext_ack *extack)
821 {
822         struct ocelot *ocelot = ds->priv;
823
824         return ocelot_port_pre_bridge_flags(ocelot, port, val);
825 }
826
827 static int felix_bridge_flags(struct dsa_switch *ds, int port,
828                               struct switchdev_brport_flags val,
829                               struct netlink_ext_ack *extack)
830 {
831         struct ocelot *ocelot = ds->priv;
832
833         ocelot_port_bridge_flags(ocelot, port, val);
834
835         return 0;
836 }
837
838 static int felix_bridge_join(struct dsa_switch *ds, int port,
839                              struct dsa_bridge bridge, bool *tx_fwd_offload,
840                              struct netlink_ext_ack *extack)
841 {
842         struct ocelot *ocelot = ds->priv;
843
844         return ocelot_port_bridge_join(ocelot, port, bridge.dev, bridge.num,
845                                        extack);
846 }
847
848 static void felix_bridge_leave(struct dsa_switch *ds, int port,
849                                struct dsa_bridge bridge)
850 {
851         struct ocelot *ocelot = ds->priv;
852
853         ocelot_port_bridge_leave(ocelot, port, bridge.dev);
854 }
855
856 static int felix_lag_join(struct dsa_switch *ds, int port,
857                           struct dsa_lag lag,
858                           struct netdev_lag_upper_info *info)
859 {
860         struct ocelot *ocelot = ds->priv;
861
862         return ocelot_port_lag_join(ocelot, port, lag.dev, info);
863 }
864
865 static int felix_lag_leave(struct dsa_switch *ds, int port,
866                            struct dsa_lag lag)
867 {
868         struct ocelot *ocelot = ds->priv;
869
870         ocelot_port_lag_leave(ocelot, port, lag.dev);
871
872         return 0;
873 }
874
875 static int felix_lag_change(struct dsa_switch *ds, int port)
876 {
877         struct dsa_port *dp = dsa_to_port(ds, port);
878         struct ocelot *ocelot = ds->priv;
879
880         ocelot_port_lag_change(ocelot, port, dp->lag_tx_enabled);
881
882         return 0;
883 }
884
885 static int felix_vlan_prepare(struct dsa_switch *ds, int port,
886                               const struct switchdev_obj_port_vlan *vlan,
887                               struct netlink_ext_ack *extack)
888 {
889         struct ocelot *ocelot = ds->priv;
890         u16 flags = vlan->flags;
891
892         /* Ocelot switches copy frames as-is to the CPU, so the flags:
893          * egress-untagged or not, pvid or not, make no difference. This
894          * behavior is already better than what DSA just tries to approximate
895          * when it installs the VLAN with the same flags on the CPU port.
896          * Just accept any configuration, and don't let ocelot deny installing
897          * multiple native VLANs on the NPI port, because the switch doesn't
898          * look at the port tag settings towards the NPI interface anyway.
899          */
900         if (port == ocelot->npi)
901                 return 0;
902
903         return ocelot_vlan_prepare(ocelot, port, vlan->vid,
904                                    flags & BRIDGE_VLAN_INFO_PVID,
905                                    flags & BRIDGE_VLAN_INFO_UNTAGGED,
906                                    extack);
907 }
908
909 static int felix_vlan_filtering(struct dsa_switch *ds, int port, bool enabled,
910                                 struct netlink_ext_ack *extack)
911 {
912         struct ocelot *ocelot = ds->priv;
913
914         return ocelot_port_vlan_filtering(ocelot, port, enabled, extack);
915 }
916
917 static int felix_vlan_add(struct dsa_switch *ds, int port,
918                           const struct switchdev_obj_port_vlan *vlan,
919                           struct netlink_ext_ack *extack)
920 {
921         struct ocelot *ocelot = ds->priv;
922         u16 flags = vlan->flags;
923         int err;
924
925         err = felix_vlan_prepare(ds, port, vlan, extack);
926         if (err)
927                 return err;
928
929         return ocelot_vlan_add(ocelot, port, vlan->vid,
930                                flags & BRIDGE_VLAN_INFO_PVID,
931                                flags & BRIDGE_VLAN_INFO_UNTAGGED);
932 }
933
934 static int felix_vlan_del(struct dsa_switch *ds, int port,
935                           const struct switchdev_obj_port_vlan *vlan)
936 {
937         struct ocelot *ocelot = ds->priv;
938
939         return ocelot_vlan_del(ocelot, port, vlan->vid);
940 }
941
942 static void felix_phylink_get_caps(struct dsa_switch *ds, int port,
943                                    struct phylink_config *config)
944 {
945         struct ocelot *ocelot = ds->priv;
946
947         /* This driver does not make use of the speed, duplex, pause or the
948          * advertisement in its mac_config, so it is safe to mark this driver
949          * as non-legacy.
950          */
951         config->legacy_pre_march2020 = false;
952
953         __set_bit(ocelot->ports[port]->phy_mode,
954                   config->supported_interfaces);
955 }
956
957 static void felix_phylink_validate(struct dsa_switch *ds, int port,
958                                    unsigned long *supported,
959                                    struct phylink_link_state *state)
960 {
961         struct ocelot *ocelot = ds->priv;
962         struct felix *felix = ocelot_to_felix(ocelot);
963
964         if (felix->info->phylink_validate)
965                 felix->info->phylink_validate(ocelot, port, supported, state);
966 }
967
968 static struct phylink_pcs *felix_phylink_mac_select_pcs(struct dsa_switch *ds,
969                                                         int port,
970                                                         phy_interface_t iface)
971 {
972         struct ocelot *ocelot = ds->priv;
973         struct felix *felix = ocelot_to_felix(ocelot);
974         struct phylink_pcs *pcs = NULL;
975
976         if (felix->pcs && felix->pcs[port])
977                 pcs = felix->pcs[port];
978
979         return pcs;
980 }
981
982 static void felix_phylink_mac_link_down(struct dsa_switch *ds, int port,
983                                         unsigned int link_an_mode,
984                                         phy_interface_t interface)
985 {
986         struct ocelot *ocelot = ds->priv;
987
988         ocelot_phylink_mac_link_down(ocelot, port, link_an_mode, interface,
989                                      FELIX_MAC_QUIRKS);
990 }
991
992 static void felix_phylink_mac_link_up(struct dsa_switch *ds, int port,
993                                       unsigned int link_an_mode,
994                                       phy_interface_t interface,
995                                       struct phy_device *phydev,
996                                       int speed, int duplex,
997                                       bool tx_pause, bool rx_pause)
998 {
999         struct ocelot *ocelot = ds->priv;
1000         struct felix *felix = ocelot_to_felix(ocelot);
1001
1002         ocelot_phylink_mac_link_up(ocelot, port, phydev, link_an_mode,
1003                                    interface, speed, duplex, tx_pause, rx_pause,
1004                                    FELIX_MAC_QUIRKS);
1005
1006         if (felix->info->port_sched_speed_set)
1007                 felix->info->port_sched_speed_set(ocelot, port, speed);
1008 }
1009
1010 static void felix_port_qos_map_init(struct ocelot *ocelot, int port)
1011 {
1012         int i;
1013
1014         ocelot_rmw_gix(ocelot,
1015                        ANA_PORT_QOS_CFG_QOS_PCP_ENA,
1016                        ANA_PORT_QOS_CFG_QOS_PCP_ENA,
1017                        ANA_PORT_QOS_CFG,
1018                        port);
1019
1020         for (i = 0; i < OCELOT_NUM_TC * 2; i++) {
1021                 ocelot_rmw_ix(ocelot,
1022                               (ANA_PORT_PCP_DEI_MAP_DP_PCP_DEI_VAL & i) |
1023                               ANA_PORT_PCP_DEI_MAP_QOS_PCP_DEI_VAL(i),
1024                               ANA_PORT_PCP_DEI_MAP_DP_PCP_DEI_VAL |
1025                               ANA_PORT_PCP_DEI_MAP_QOS_PCP_DEI_VAL_M,
1026                               ANA_PORT_PCP_DEI_MAP,
1027                               port, i);
1028         }
1029 }
1030
1031 static void felix_get_strings(struct dsa_switch *ds, int port,
1032                               u32 stringset, u8 *data)
1033 {
1034         struct ocelot *ocelot = ds->priv;
1035
1036         return ocelot_get_strings(ocelot, port, stringset, data);
1037 }
1038
1039 static void felix_get_ethtool_stats(struct dsa_switch *ds, int port, u64 *data)
1040 {
1041         struct ocelot *ocelot = ds->priv;
1042
1043         ocelot_get_ethtool_stats(ocelot, port, data);
1044 }
1045
1046 static int felix_get_sset_count(struct dsa_switch *ds, int port, int sset)
1047 {
1048         struct ocelot *ocelot = ds->priv;
1049
1050         return ocelot_get_sset_count(ocelot, port, sset);
1051 }
1052
1053 static int felix_get_ts_info(struct dsa_switch *ds, int port,
1054                              struct ethtool_ts_info *info)
1055 {
1056         struct ocelot *ocelot = ds->priv;
1057
1058         return ocelot_get_ts_info(ocelot, port, info);
1059 }
1060
1061 static const u32 felix_phy_match_table[PHY_INTERFACE_MODE_MAX] = {
1062         [PHY_INTERFACE_MODE_INTERNAL] = OCELOT_PORT_MODE_INTERNAL,
1063         [PHY_INTERFACE_MODE_SGMII] = OCELOT_PORT_MODE_SGMII,
1064         [PHY_INTERFACE_MODE_QSGMII] = OCELOT_PORT_MODE_QSGMII,
1065         [PHY_INTERFACE_MODE_USXGMII] = OCELOT_PORT_MODE_USXGMII,
1066         [PHY_INTERFACE_MODE_2500BASEX] = OCELOT_PORT_MODE_2500BASEX,
1067 };
1068
1069 static int felix_validate_phy_mode(struct felix *felix, int port,
1070                                    phy_interface_t phy_mode)
1071 {
1072         u32 modes = felix->info->port_modes[port];
1073
1074         if (felix_phy_match_table[phy_mode] & modes)
1075                 return 0;
1076         return -EOPNOTSUPP;
1077 }
1078
1079 static int felix_parse_ports_node(struct felix *felix,
1080                                   struct device_node *ports_node,
1081                                   phy_interface_t *port_phy_modes)
1082 {
1083         struct device *dev = felix->ocelot.dev;
1084         struct device_node *child;
1085
1086         for_each_available_child_of_node(ports_node, child) {
1087                 phy_interface_t phy_mode;
1088                 u32 port;
1089                 int err;
1090
1091                 /* Get switch port number from DT */
1092                 if (of_property_read_u32(child, "reg", &port) < 0) {
1093                         dev_err(dev, "Port number not defined in device tree "
1094                                 "(property \"reg\")\n");
1095                         of_node_put(child);
1096                         return -ENODEV;
1097                 }
1098
1099                 /* Get PHY mode from DT */
1100                 err = of_get_phy_mode(child, &phy_mode);
1101                 if (err) {
1102                         dev_err(dev, "Failed to read phy-mode or "
1103                                 "phy-interface-type property for port %d\n",
1104                                 port);
1105                         of_node_put(child);
1106                         return -ENODEV;
1107                 }
1108
1109                 err = felix_validate_phy_mode(felix, port, phy_mode);
1110                 if (err < 0) {
1111                         dev_err(dev, "Unsupported PHY mode %s on port %d\n",
1112                                 phy_modes(phy_mode), port);
1113                         of_node_put(child);
1114                         return err;
1115                 }
1116
1117                 port_phy_modes[port] = phy_mode;
1118         }
1119
1120         return 0;
1121 }
1122
1123 static int felix_parse_dt(struct felix *felix, phy_interface_t *port_phy_modes)
1124 {
1125         struct device *dev = felix->ocelot.dev;
1126         struct device_node *switch_node;
1127         struct device_node *ports_node;
1128         int err;
1129
1130         switch_node = dev->of_node;
1131
1132         ports_node = of_get_child_by_name(switch_node, "ports");
1133         if (!ports_node)
1134                 ports_node = of_get_child_by_name(switch_node, "ethernet-ports");
1135         if (!ports_node) {
1136                 dev_err(dev, "Incorrect bindings: absent \"ports\" or \"ethernet-ports\" node\n");
1137                 return -ENODEV;
1138         }
1139
1140         err = felix_parse_ports_node(felix, ports_node, port_phy_modes);
1141         of_node_put(ports_node);
1142
1143         return err;
1144 }
1145
1146 static int felix_init_structs(struct felix *felix, int num_phys_ports)
1147 {
1148         struct ocelot *ocelot = &felix->ocelot;
1149         phy_interface_t *port_phy_modes;
1150         struct resource res;
1151         int port, i, err;
1152
1153         ocelot->num_phys_ports = num_phys_ports;
1154         ocelot->ports = devm_kcalloc(ocelot->dev, num_phys_ports,
1155                                      sizeof(struct ocelot_port *), GFP_KERNEL);
1156         if (!ocelot->ports)
1157                 return -ENOMEM;
1158
1159         ocelot->map             = felix->info->map;
1160         ocelot->stats_layout    = felix->info->stats_layout;
1161         ocelot->num_stats       = felix->info->num_stats;
1162         ocelot->num_mact_rows   = felix->info->num_mact_rows;
1163         ocelot->vcap            = felix->info->vcap;
1164         ocelot->vcap_pol.base   = felix->info->vcap_pol_base;
1165         ocelot->vcap_pol.max    = felix->info->vcap_pol_max;
1166         ocelot->vcap_pol.base2  = felix->info->vcap_pol_base2;
1167         ocelot->vcap_pol.max2   = felix->info->vcap_pol_max2;
1168         ocelot->ops             = felix->info->ops;
1169         ocelot->npi_inj_prefix  = OCELOT_TAG_PREFIX_SHORT;
1170         ocelot->npi_xtr_prefix  = OCELOT_TAG_PREFIX_SHORT;
1171         ocelot->devlink         = felix->ds->devlink;
1172
1173         port_phy_modes = kcalloc(num_phys_ports, sizeof(phy_interface_t),
1174                                  GFP_KERNEL);
1175         if (!port_phy_modes)
1176                 return -ENOMEM;
1177
1178         err = felix_parse_dt(felix, port_phy_modes);
1179         if (err) {
1180                 kfree(port_phy_modes);
1181                 return err;
1182         }
1183
1184         for (i = 0; i < TARGET_MAX; i++) {
1185                 struct regmap *target;
1186
1187                 if (!felix->info->target_io_res[i].name)
1188                         continue;
1189
1190                 memcpy(&res, &felix->info->target_io_res[i], sizeof(res));
1191                 res.flags = IORESOURCE_MEM;
1192                 res.start += felix->switch_base;
1193                 res.end += felix->switch_base;
1194
1195                 target = felix->info->init_regmap(ocelot, &res);
1196                 if (IS_ERR(target)) {
1197                         dev_err(ocelot->dev,
1198                                 "Failed to map device memory space\n");
1199                         kfree(port_phy_modes);
1200                         return PTR_ERR(target);
1201                 }
1202
1203                 ocelot->targets[i] = target;
1204         }
1205
1206         err = ocelot_regfields_init(ocelot, felix->info->regfields);
1207         if (err) {
1208                 dev_err(ocelot->dev, "failed to init reg fields map\n");
1209                 kfree(port_phy_modes);
1210                 return err;
1211         }
1212
1213         for (port = 0; port < num_phys_ports; port++) {
1214                 struct ocelot_port *ocelot_port;
1215                 struct regmap *target;
1216
1217                 ocelot_port = devm_kzalloc(ocelot->dev,
1218                                            sizeof(struct ocelot_port),
1219                                            GFP_KERNEL);
1220                 if (!ocelot_port) {
1221                         dev_err(ocelot->dev,
1222                                 "failed to allocate port memory\n");
1223                         kfree(port_phy_modes);
1224                         return -ENOMEM;
1225                 }
1226
1227                 memcpy(&res, &felix->info->port_io_res[port], sizeof(res));
1228                 res.flags = IORESOURCE_MEM;
1229                 res.start += felix->switch_base;
1230                 res.end += felix->switch_base;
1231
1232                 target = felix->info->init_regmap(ocelot, &res);
1233                 if (IS_ERR(target)) {
1234                         dev_err(ocelot->dev,
1235                                 "Failed to map memory space for port %d\n",
1236                                 port);
1237                         kfree(port_phy_modes);
1238                         return PTR_ERR(target);
1239                 }
1240
1241                 ocelot_port->phy_mode = port_phy_modes[port];
1242                 ocelot_port->ocelot = ocelot;
1243                 ocelot_port->target = target;
1244                 ocelot->ports[port] = ocelot_port;
1245         }
1246
1247         kfree(port_phy_modes);
1248
1249         if (felix->info->mdio_bus_alloc) {
1250                 err = felix->info->mdio_bus_alloc(ocelot);
1251                 if (err < 0)
1252                         return err;
1253         }
1254
1255         return 0;
1256 }
1257
1258 static void ocelot_port_purge_txtstamp_skb(struct ocelot *ocelot, int port,
1259                                            struct sk_buff *skb)
1260 {
1261         struct ocelot_port *ocelot_port = ocelot->ports[port];
1262         struct sk_buff *clone = OCELOT_SKB_CB(skb)->clone;
1263         struct sk_buff *skb_match = NULL, *skb_tmp;
1264         unsigned long flags;
1265
1266         if (!clone)
1267                 return;
1268
1269         spin_lock_irqsave(&ocelot_port->tx_skbs.lock, flags);
1270
1271         skb_queue_walk_safe(&ocelot_port->tx_skbs, skb, skb_tmp) {
1272                 if (skb != clone)
1273                         continue;
1274                 __skb_unlink(skb, &ocelot_port->tx_skbs);
1275                 skb_match = skb;
1276                 break;
1277         }
1278
1279         spin_unlock_irqrestore(&ocelot_port->tx_skbs.lock, flags);
1280
1281         WARN_ONCE(!skb_match,
1282                   "Could not find skb clone in TX timestamping list\n");
1283 }
1284
1285 #define work_to_xmit_work(w) \
1286                 container_of((w), struct felix_deferred_xmit_work, work)
1287
1288 static void felix_port_deferred_xmit(struct kthread_work *work)
1289 {
1290         struct felix_deferred_xmit_work *xmit_work = work_to_xmit_work(work);
1291         struct dsa_switch *ds = xmit_work->dp->ds;
1292         struct sk_buff *skb = xmit_work->skb;
1293         u32 rew_op = ocelot_ptp_rew_op(skb);
1294         struct ocelot *ocelot = ds->priv;
1295         int port = xmit_work->dp->index;
1296         int retries = 10;
1297
1298         do {
1299                 if (ocelot_can_inject(ocelot, 0))
1300                         break;
1301
1302                 cpu_relax();
1303         } while (--retries);
1304
1305         if (!retries) {
1306                 dev_err(ocelot->dev, "port %d failed to inject skb\n",
1307                         port);
1308                 ocelot_port_purge_txtstamp_skb(ocelot, port, skb);
1309                 kfree_skb(skb);
1310                 return;
1311         }
1312
1313         ocelot_port_inject_frame(ocelot, port, 0, rew_op, skb);
1314
1315         consume_skb(skb);
1316         kfree(xmit_work);
1317 }
1318
1319 static int felix_connect_tag_protocol(struct dsa_switch *ds,
1320                                       enum dsa_tag_protocol proto)
1321 {
1322         struct ocelot_8021q_tagger_data *tagger_data;
1323
1324         switch (proto) {
1325         case DSA_TAG_PROTO_OCELOT_8021Q:
1326                 tagger_data = ocelot_8021q_tagger_data(ds);
1327                 tagger_data->xmit_work_fn = felix_port_deferred_xmit;
1328                 return 0;
1329         case DSA_TAG_PROTO_OCELOT:
1330         case DSA_TAG_PROTO_SEVILLE:
1331                 return 0;
1332         default:
1333                 return -EPROTONOSUPPORT;
1334         }
1335 }
1336
1337 /* Hardware initialization done here so that we can allocate structures with
1338  * devm without fear of dsa_register_switch returning -EPROBE_DEFER and causing
1339  * us to allocate structures twice (leak memory) and map PCI memory twice
1340  * (which will not work).
1341  */
1342 static int felix_setup(struct dsa_switch *ds)
1343 {
1344         struct ocelot *ocelot = ds->priv;
1345         struct felix *felix = ocelot_to_felix(ocelot);
1346         unsigned long cpu_flood;
1347         struct dsa_port *dp;
1348         int err;
1349
1350         err = felix_init_structs(felix, ds->num_ports);
1351         if (err)
1352                 return err;
1353
1354         err = ocelot_init(ocelot);
1355         if (err)
1356                 goto out_mdiobus_free;
1357
1358         if (ocelot->ptp) {
1359                 err = ocelot_init_timestamp(ocelot, felix->info->ptp_caps);
1360                 if (err) {
1361                         dev_err(ocelot->dev,
1362                                 "Timestamp initialization failed\n");
1363                         ocelot->ptp = 0;
1364                 }
1365         }
1366
1367         dsa_switch_for_each_available_port(dp, ds) {
1368                 ocelot_init_port(ocelot, dp->index);
1369
1370                 /* Set the default QoS Classification based on PCP and DEI
1371                  * bits of vlan tag.
1372                  */
1373                 felix_port_qos_map_init(ocelot, dp->index);
1374         }
1375
1376         err = ocelot_devlink_sb_register(ocelot);
1377         if (err)
1378                 goto out_deinit_ports;
1379
1380         dsa_switch_for_each_cpu_port(dp, ds) {
1381                 /* The initial tag protocol is NPI which always returns 0, so
1382                  * there's no real point in checking for errors.
1383                  */
1384                 felix_set_tag_protocol(ds, dp->index, felix->tag_proto);
1385
1386                 /* Start off with flooding disabled towards the NPI port
1387                  * (actually CPU port module).
1388                  */
1389                 cpu_flood = ANA_PGID_PGID_PGID(BIT(ocelot->num_phys_ports));
1390                 ocelot_rmw_rix(ocelot, 0, cpu_flood, ANA_PGID_PGID, PGID_UC);
1391                 ocelot_rmw_rix(ocelot, 0, cpu_flood, ANA_PGID_PGID, PGID_MC);
1392
1393                 break;
1394         }
1395
1396         ds->mtu_enforcement_ingress = true;
1397         ds->assisted_learning_on_cpu_port = true;
1398         ds->fdb_isolation = true;
1399         ds->max_num_bridges = ds->num_ports;
1400
1401         return 0;
1402
1403 out_deinit_ports:
1404         dsa_switch_for_each_available_port(dp, ds)
1405                 ocelot_deinit_port(ocelot, dp->index);
1406
1407         ocelot_deinit_timestamp(ocelot);
1408         ocelot_deinit(ocelot);
1409
1410 out_mdiobus_free:
1411         if (felix->info->mdio_bus_free)
1412                 felix->info->mdio_bus_free(ocelot);
1413
1414         return err;
1415 }
1416
1417 static void felix_teardown(struct dsa_switch *ds)
1418 {
1419         struct ocelot *ocelot = ds->priv;
1420         struct felix *felix = ocelot_to_felix(ocelot);
1421         struct dsa_port *dp;
1422
1423         dsa_switch_for_each_cpu_port(dp, ds) {
1424                 felix_del_tag_protocol(ds, dp->index, felix->tag_proto);
1425                 break;
1426         }
1427
1428         dsa_switch_for_each_available_port(dp, ds)
1429                 ocelot_deinit_port(ocelot, dp->index);
1430
1431         ocelot_devlink_sb_unregister(ocelot);
1432         ocelot_deinit_timestamp(ocelot);
1433         ocelot_deinit(ocelot);
1434
1435         if (felix->info->mdio_bus_free)
1436                 felix->info->mdio_bus_free(ocelot);
1437 }
1438
1439 static int felix_hwtstamp_get(struct dsa_switch *ds, int port,
1440                               struct ifreq *ifr)
1441 {
1442         struct ocelot *ocelot = ds->priv;
1443
1444         return ocelot_hwstamp_get(ocelot, port, ifr);
1445 }
1446
1447 static int felix_hwtstamp_set(struct dsa_switch *ds, int port,
1448                               struct ifreq *ifr)
1449 {
1450         struct ocelot *ocelot = ds->priv;
1451         struct felix *felix = ocelot_to_felix(ocelot);
1452         bool using_tag_8021q;
1453         int err;
1454
1455         err = ocelot_hwstamp_set(ocelot, port, ifr);
1456         if (err)
1457                 return err;
1458
1459         using_tag_8021q = felix->tag_proto == DSA_TAG_PROTO_OCELOT_8021Q;
1460
1461         return felix_update_trapping_destinations(ds, using_tag_8021q);
1462 }
1463
1464 static bool felix_check_xtr_pkt(struct ocelot *ocelot)
1465 {
1466         struct felix *felix = ocelot_to_felix(ocelot);
1467         int err = 0, grp = 0;
1468
1469         if (felix->tag_proto != DSA_TAG_PROTO_OCELOT_8021Q)
1470                 return false;
1471
1472         if (!felix->info->quirk_no_xtr_irq)
1473                 return false;
1474
1475         while (ocelot_read(ocelot, QS_XTR_DATA_PRESENT) & BIT(grp)) {
1476                 struct sk_buff *skb;
1477                 unsigned int type;
1478
1479                 err = ocelot_xtr_poll_frame(ocelot, grp, &skb);
1480                 if (err)
1481                         goto out;
1482
1483                 /* We trap to the CPU port module all PTP frames, but
1484                  * felix_rxtstamp() only gets called for event frames.
1485                  * So we need to avoid sending duplicate general
1486                  * message frames by running a second BPF classifier
1487                  * here and dropping those.
1488                  */
1489                 __skb_push(skb, ETH_HLEN);
1490
1491                 type = ptp_classify_raw(skb);
1492
1493                 __skb_pull(skb, ETH_HLEN);
1494
1495                 if (type == PTP_CLASS_NONE) {
1496                         kfree_skb(skb);
1497                         continue;
1498                 }
1499
1500                 netif_rx(skb);
1501         }
1502
1503 out:
1504         if (err < 0) {
1505                 dev_err_ratelimited(ocelot->dev,
1506                                     "Error during packet extraction: %pe\n",
1507                                     ERR_PTR(err));
1508                 ocelot_drain_cpu_queue(ocelot, 0);
1509         }
1510
1511         return true;
1512 }
1513
1514 static bool felix_rxtstamp(struct dsa_switch *ds, int port,
1515                            struct sk_buff *skb, unsigned int type)
1516 {
1517         u32 tstamp_lo = OCELOT_SKB_CB(skb)->tstamp_lo;
1518         struct skb_shared_hwtstamps *shhwtstamps;
1519         struct ocelot *ocelot = ds->priv;
1520         struct timespec64 ts;
1521         u32 tstamp_hi;
1522         u64 tstamp;
1523
1524         /* If the "no XTR IRQ" workaround is in use, tell DSA to defer this skb
1525          * for RX timestamping. Then free it, and poll for its copy through
1526          * MMIO in the CPU port module, and inject that into the stack from
1527          * ocelot_xtr_poll().
1528          */
1529         if (felix_check_xtr_pkt(ocelot)) {
1530                 kfree_skb(skb);
1531                 return true;
1532         }
1533
1534         ocelot_ptp_gettime64(&ocelot->ptp_info, &ts);
1535         tstamp = ktime_set(ts.tv_sec, ts.tv_nsec);
1536
1537         tstamp_hi = tstamp >> 32;
1538         if ((tstamp & 0xffffffff) < tstamp_lo)
1539                 tstamp_hi--;
1540
1541         tstamp = ((u64)tstamp_hi << 32) | tstamp_lo;
1542
1543         shhwtstamps = skb_hwtstamps(skb);
1544         memset(shhwtstamps, 0, sizeof(struct skb_shared_hwtstamps));
1545         shhwtstamps->hwtstamp = tstamp;
1546         return false;
1547 }
1548
1549 static void felix_txtstamp(struct dsa_switch *ds, int port,
1550                            struct sk_buff *skb)
1551 {
1552         struct ocelot *ocelot = ds->priv;
1553         struct sk_buff *clone = NULL;
1554
1555         if (!ocelot->ptp)
1556                 return;
1557
1558         if (ocelot_port_txtstamp_request(ocelot, port, skb, &clone)) {
1559                 dev_err_ratelimited(ds->dev,
1560                                     "port %d delivering skb without TX timestamp\n",
1561                                     port);
1562                 return;
1563         }
1564
1565         if (clone)
1566                 OCELOT_SKB_CB(skb)->clone = clone;
1567 }
1568
1569 static int felix_change_mtu(struct dsa_switch *ds, int port, int new_mtu)
1570 {
1571         struct ocelot *ocelot = ds->priv;
1572
1573         ocelot_port_set_maxlen(ocelot, port, new_mtu);
1574
1575         return 0;
1576 }
1577
1578 static int felix_get_max_mtu(struct dsa_switch *ds, int port)
1579 {
1580         struct ocelot *ocelot = ds->priv;
1581
1582         return ocelot_get_max_mtu(ocelot, port);
1583 }
1584
1585 static int felix_cls_flower_add(struct dsa_switch *ds, int port,
1586                                 struct flow_cls_offload *cls, bool ingress)
1587 {
1588         struct ocelot *ocelot = ds->priv;
1589         struct felix *felix = ocelot_to_felix(ocelot);
1590         bool using_tag_8021q;
1591         int err;
1592
1593         err = ocelot_cls_flower_replace(ocelot, port, cls, ingress);
1594         if (err)
1595                 return err;
1596
1597         using_tag_8021q = felix->tag_proto == DSA_TAG_PROTO_OCELOT_8021Q;
1598
1599         return felix_update_trapping_destinations(ds, using_tag_8021q);
1600 }
1601
1602 static int felix_cls_flower_del(struct dsa_switch *ds, int port,
1603                                 struct flow_cls_offload *cls, bool ingress)
1604 {
1605         struct ocelot *ocelot = ds->priv;
1606
1607         return ocelot_cls_flower_destroy(ocelot, port, cls, ingress);
1608 }
1609
1610 static int felix_cls_flower_stats(struct dsa_switch *ds, int port,
1611                                   struct flow_cls_offload *cls, bool ingress)
1612 {
1613         struct ocelot *ocelot = ds->priv;
1614
1615         return ocelot_cls_flower_stats(ocelot, port, cls, ingress);
1616 }
1617
1618 static int felix_port_policer_add(struct dsa_switch *ds, int port,
1619                                   struct dsa_mall_policer_tc_entry *policer)
1620 {
1621         struct ocelot *ocelot = ds->priv;
1622         struct ocelot_policer pol = {
1623                 .rate = div_u64(policer->rate_bytes_per_sec, 1000) * 8,
1624                 .burst = policer->burst,
1625         };
1626
1627         return ocelot_port_policer_add(ocelot, port, &pol);
1628 }
1629
1630 static void felix_port_policer_del(struct dsa_switch *ds, int port)
1631 {
1632         struct ocelot *ocelot = ds->priv;
1633
1634         ocelot_port_policer_del(ocelot, port);
1635 }
1636
1637 static int felix_port_setup_tc(struct dsa_switch *ds, int port,
1638                                enum tc_setup_type type,
1639                                void *type_data)
1640 {
1641         struct ocelot *ocelot = ds->priv;
1642         struct felix *felix = ocelot_to_felix(ocelot);
1643
1644         if (felix->info->port_setup_tc)
1645                 return felix->info->port_setup_tc(ds, port, type, type_data);
1646         else
1647                 return -EOPNOTSUPP;
1648 }
1649
1650 static int felix_sb_pool_get(struct dsa_switch *ds, unsigned int sb_index,
1651                              u16 pool_index,
1652                              struct devlink_sb_pool_info *pool_info)
1653 {
1654         struct ocelot *ocelot = ds->priv;
1655
1656         return ocelot_sb_pool_get(ocelot, sb_index, pool_index, pool_info);
1657 }
1658
1659 static int felix_sb_pool_set(struct dsa_switch *ds, unsigned int sb_index,
1660                              u16 pool_index, u32 size,
1661                              enum devlink_sb_threshold_type threshold_type,
1662                              struct netlink_ext_ack *extack)
1663 {
1664         struct ocelot *ocelot = ds->priv;
1665
1666         return ocelot_sb_pool_set(ocelot, sb_index, pool_index, size,
1667                                   threshold_type, extack);
1668 }
1669
1670 static int felix_sb_port_pool_get(struct dsa_switch *ds, int port,
1671                                   unsigned int sb_index, u16 pool_index,
1672                                   u32 *p_threshold)
1673 {
1674         struct ocelot *ocelot = ds->priv;
1675
1676         return ocelot_sb_port_pool_get(ocelot, port, sb_index, pool_index,
1677                                        p_threshold);
1678 }
1679
1680 static int felix_sb_port_pool_set(struct dsa_switch *ds, int port,
1681                                   unsigned int sb_index, u16 pool_index,
1682                                   u32 threshold, struct netlink_ext_ack *extack)
1683 {
1684         struct ocelot *ocelot = ds->priv;
1685
1686         return ocelot_sb_port_pool_set(ocelot, port, sb_index, pool_index,
1687                                        threshold, extack);
1688 }
1689
1690 static int felix_sb_tc_pool_bind_get(struct dsa_switch *ds, int port,
1691                                      unsigned int sb_index, u16 tc_index,
1692                                      enum devlink_sb_pool_type pool_type,
1693                                      u16 *p_pool_index, u32 *p_threshold)
1694 {
1695         struct ocelot *ocelot = ds->priv;
1696
1697         return ocelot_sb_tc_pool_bind_get(ocelot, port, sb_index, tc_index,
1698                                           pool_type, p_pool_index,
1699                                           p_threshold);
1700 }
1701
1702 static int felix_sb_tc_pool_bind_set(struct dsa_switch *ds, int port,
1703                                      unsigned int sb_index, u16 tc_index,
1704                                      enum devlink_sb_pool_type pool_type,
1705                                      u16 pool_index, u32 threshold,
1706                                      struct netlink_ext_ack *extack)
1707 {
1708         struct ocelot *ocelot = ds->priv;
1709
1710         return ocelot_sb_tc_pool_bind_set(ocelot, port, sb_index, tc_index,
1711                                           pool_type, pool_index, threshold,
1712                                           extack);
1713 }
1714
1715 static int felix_sb_occ_snapshot(struct dsa_switch *ds,
1716                                  unsigned int sb_index)
1717 {
1718         struct ocelot *ocelot = ds->priv;
1719
1720         return ocelot_sb_occ_snapshot(ocelot, sb_index);
1721 }
1722
1723 static int felix_sb_occ_max_clear(struct dsa_switch *ds,
1724                                   unsigned int sb_index)
1725 {
1726         struct ocelot *ocelot = ds->priv;
1727
1728         return ocelot_sb_occ_max_clear(ocelot, sb_index);
1729 }
1730
1731 static int felix_sb_occ_port_pool_get(struct dsa_switch *ds, int port,
1732                                       unsigned int sb_index, u16 pool_index,
1733                                       u32 *p_cur, u32 *p_max)
1734 {
1735         struct ocelot *ocelot = ds->priv;
1736
1737         return ocelot_sb_occ_port_pool_get(ocelot, port, sb_index, pool_index,
1738                                            p_cur, p_max);
1739 }
1740
1741 static int felix_sb_occ_tc_port_bind_get(struct dsa_switch *ds, int port,
1742                                          unsigned int sb_index, u16 tc_index,
1743                                          enum devlink_sb_pool_type pool_type,
1744                                          u32 *p_cur, u32 *p_max)
1745 {
1746         struct ocelot *ocelot = ds->priv;
1747
1748         return ocelot_sb_occ_tc_port_bind_get(ocelot, port, sb_index, tc_index,
1749                                               pool_type, p_cur, p_max);
1750 }
1751
1752 static int felix_mrp_add(struct dsa_switch *ds, int port,
1753                          const struct switchdev_obj_mrp *mrp)
1754 {
1755         struct ocelot *ocelot = ds->priv;
1756
1757         return ocelot_mrp_add(ocelot, port, mrp);
1758 }
1759
1760 static int felix_mrp_del(struct dsa_switch *ds, int port,
1761                          const struct switchdev_obj_mrp *mrp)
1762 {
1763         struct ocelot *ocelot = ds->priv;
1764
1765         return ocelot_mrp_add(ocelot, port, mrp);
1766 }
1767
1768 static int
1769 felix_mrp_add_ring_role(struct dsa_switch *ds, int port,
1770                         const struct switchdev_obj_ring_role_mrp *mrp)
1771 {
1772         struct ocelot *ocelot = ds->priv;
1773
1774         return ocelot_mrp_add_ring_role(ocelot, port, mrp);
1775 }
1776
1777 static int
1778 felix_mrp_del_ring_role(struct dsa_switch *ds, int port,
1779                         const struct switchdev_obj_ring_role_mrp *mrp)
1780 {
1781         struct ocelot *ocelot = ds->priv;
1782
1783         return ocelot_mrp_del_ring_role(ocelot, port, mrp);
1784 }
1785
1786 const struct dsa_switch_ops felix_switch_ops = {
1787         .get_tag_protocol               = felix_get_tag_protocol,
1788         .change_tag_protocol            = felix_change_tag_protocol,
1789         .connect_tag_protocol           = felix_connect_tag_protocol,
1790         .setup                          = felix_setup,
1791         .teardown                       = felix_teardown,
1792         .set_ageing_time                = felix_set_ageing_time,
1793         .get_strings                    = felix_get_strings,
1794         .get_ethtool_stats              = felix_get_ethtool_stats,
1795         .get_sset_count                 = felix_get_sset_count,
1796         .get_ts_info                    = felix_get_ts_info,
1797         .phylink_get_caps               = felix_phylink_get_caps,
1798         .phylink_validate               = felix_phylink_validate,
1799         .phylink_mac_select_pcs         = felix_phylink_mac_select_pcs,
1800         .phylink_mac_link_down          = felix_phylink_mac_link_down,
1801         .phylink_mac_link_up            = felix_phylink_mac_link_up,
1802         .port_fast_age                  = felix_port_fast_age,
1803         .port_fdb_dump                  = felix_fdb_dump,
1804         .port_fdb_add                   = felix_fdb_add,
1805         .port_fdb_del                   = felix_fdb_del,
1806         .lag_fdb_add                    = felix_lag_fdb_add,
1807         .lag_fdb_del                    = felix_lag_fdb_del,
1808         .port_mdb_add                   = felix_mdb_add,
1809         .port_mdb_del                   = felix_mdb_del,
1810         .port_pre_bridge_flags          = felix_pre_bridge_flags,
1811         .port_bridge_flags              = felix_bridge_flags,
1812         .port_bridge_join               = felix_bridge_join,
1813         .port_bridge_leave              = felix_bridge_leave,
1814         .port_lag_join                  = felix_lag_join,
1815         .port_lag_leave                 = felix_lag_leave,
1816         .port_lag_change                = felix_lag_change,
1817         .port_stp_state_set             = felix_bridge_stp_state_set,
1818         .port_vlan_filtering            = felix_vlan_filtering,
1819         .port_vlan_add                  = felix_vlan_add,
1820         .port_vlan_del                  = felix_vlan_del,
1821         .port_hwtstamp_get              = felix_hwtstamp_get,
1822         .port_hwtstamp_set              = felix_hwtstamp_set,
1823         .port_rxtstamp                  = felix_rxtstamp,
1824         .port_txtstamp                  = felix_txtstamp,
1825         .port_change_mtu                = felix_change_mtu,
1826         .port_max_mtu                   = felix_get_max_mtu,
1827         .port_policer_add               = felix_port_policer_add,
1828         .port_policer_del               = felix_port_policer_del,
1829         .cls_flower_add                 = felix_cls_flower_add,
1830         .cls_flower_del                 = felix_cls_flower_del,
1831         .cls_flower_stats               = felix_cls_flower_stats,
1832         .port_setup_tc                  = felix_port_setup_tc,
1833         .devlink_sb_pool_get            = felix_sb_pool_get,
1834         .devlink_sb_pool_set            = felix_sb_pool_set,
1835         .devlink_sb_port_pool_get       = felix_sb_port_pool_get,
1836         .devlink_sb_port_pool_set       = felix_sb_port_pool_set,
1837         .devlink_sb_tc_pool_bind_get    = felix_sb_tc_pool_bind_get,
1838         .devlink_sb_tc_pool_bind_set    = felix_sb_tc_pool_bind_set,
1839         .devlink_sb_occ_snapshot        = felix_sb_occ_snapshot,
1840         .devlink_sb_occ_max_clear       = felix_sb_occ_max_clear,
1841         .devlink_sb_occ_port_pool_get   = felix_sb_occ_port_pool_get,
1842         .devlink_sb_occ_tc_port_bind_get= felix_sb_occ_tc_port_bind_get,
1843         .port_mrp_add                   = felix_mrp_add,
1844         .port_mrp_del                   = felix_mrp_del,
1845         .port_mrp_add_ring_role         = felix_mrp_add_ring_role,
1846         .port_mrp_del_ring_role         = felix_mrp_del_ring_role,
1847         .tag_8021q_vlan_add             = felix_tag_8021q_vlan_add,
1848         .tag_8021q_vlan_del             = felix_tag_8021q_vlan_del,
1849 };
1850
1851 struct net_device *felix_port_to_netdev(struct ocelot *ocelot, int port)
1852 {
1853         struct felix *felix = ocelot_to_felix(ocelot);
1854         struct dsa_switch *ds = felix->ds;
1855
1856         if (!dsa_is_user_port(ds, port))
1857                 return NULL;
1858
1859         return dsa_to_port(ds, port)->slave;
1860 }
1861
1862 int felix_netdev_to_port(struct net_device *dev)
1863 {
1864         struct dsa_port *dp;
1865
1866         dp = dsa_port_from_netdev(dev);
1867         if (IS_ERR(dp))
1868                 return -EINVAL;
1869
1870         return dp->index;
1871 }