Blame view
include/net/dsa.h
10.8 KB
91da11f87 net: Distributed ... |
1 2 |
/* * include/net/dsa.h - Driver for Distributed Switch Architecture switch chips |
e84665c9c dsa: add switch c... |
3 |
* Copyright (c) 2008-2009 Marvell Semiconductor |
91da11f87 net: Distributed ... |
4 5 6 7 8 9 10 11 12 |
* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. */ #ifndef __LINUX_NET_DSA_H #define __LINUX_NET_DSA_H |
ea1f51bef dsa: Include linu... |
13 |
#include <linux/if_ether.h> |
c8f0b8699 dsa: Move all def... |
14 |
#include <linux/list.h> |
cf50dcc24 dsa: Change dsa_u... |
15 16 |
#include <linux/timer.h> #include <linux/workqueue.h> |
fa981d9af net: dsa: provide... |
17 |
#include <linux/of.h> |
ec9436bae net: dsa: allow d... |
18 |
#include <linux/phy.h> |
ce31b31c6 net: dsa: allow u... |
19 |
#include <linux/phy_fixed.h> |
a28205437 net: dsa: add inc... |
20 |
#include <linux/ethtool.h> |
cf50dcc24 dsa: Change dsa_u... |
21 |
|
ac7a04c33 net: dsa: change ... |
22 23 24 25 26 27 |
enum dsa_tag_protocol { DSA_TAG_PROTO_NONE = 0, DSA_TAG_PROTO_DSA, DSA_TAG_PROTO_TRAILER, DSA_TAG_PROTO_EDSA, DSA_TAG_PROTO_BRCM, |
cafdc45c9 net-next: dsa: ad... |
28 |
DSA_TAG_PROTO_QCA, |
39a7f2a4e net: dsa: Refacto... |
29 |
DSA_TAG_LAST, /* MUST BE LAST */ |
ac7a04c33 net: dsa: change ... |
30 |
}; |
5037d532b net: dsa: add Bro... |
31 |
|
e84665c9c dsa: add switch c... |
32 33 |
#define DSA_MAX_SWITCHES 4 #define DSA_MAX_PORTS 12 |
d390238c4 net: dsa: initial... |
34 |
#define DSA_RTABLE_NONE -1 |
e84665c9c dsa: add switch c... |
35 36 37 38 |
struct dsa_chip_data { /* * How to access the switch configuration registers. */ |
b4d2394d0 dsa: Replace mii_... |
39 |
struct device *host_dev; |
e84665c9c dsa: add switch c... |
40 |
int sw_addr; |
6793abb4e net: dsa: Add sup... |
41 42 |
/* set to size of eeprom if supported by the switch */ int eeprom_len; |
fa981d9af net: dsa: provide... |
43 44 45 46 47 |
/* Device tree node pointer for this specific switch chip * used during switch setup in case additional properties * and resources needs to be used */ struct device_node *of_node; |
e84665c9c dsa: add switch c... |
48 49 50 51 52 53 54 55 |
/* * The names of the switch's ports. Use "cpu" to * designate the switch port that the cpu is connected to, * "dsa" to indicate that this port is a DSA link to * another switch, NULL to indicate the port is unused, * or any other string to indicate this is a physical port. */ char *port_names[DSA_MAX_PORTS]; |
bd47497a0 net: dsa: retain ... |
56 |
struct device_node *port_dn[DSA_MAX_PORTS]; |
e84665c9c dsa: add switch c... |
57 58 |
/* |
4a7704ffa net: dsa: Remove ... |
59 60 61 |
* An array of which element [a] indicates which port on this * switch should be used to send packets to that are destined * for switch a. Can be NULL if there is only one switch chip. |
e84665c9c dsa: add switch c... |
62 |
*/ |
4a7704ffa net: dsa: Remove ... |
63 |
s8 rtable[DSA_MAX_SWITCHES]; |
e84665c9c dsa: add switch c... |
64 |
}; |
91da11f87 net: Distributed ... |
65 66 67 68 |
struct dsa_platform_data { /* * Reference to a Linux network interface that connects |
e84665c9c dsa: add switch c... |
69 |
* to the root switch chip of the tree. |
91da11f87 net: Distributed ... |
70 71 |
*/ struct device *netdev; |
769a02028 net: dsa: utilize... |
72 |
struct net_device *of_netdev; |
91da11f87 net: Distributed ... |
73 74 |
/* |
e84665c9c dsa: add switch c... |
75 76 |
* Info structs describing each of the switch chips * connected via this network interface. |
91da11f87 net: Distributed ... |
77 |
*/ |
e84665c9c dsa: add switch c... |
78 79 |
int nr_chips; struct dsa_chip_data *chip; |
91da11f87 net: Distributed ... |
80 |
}; |
5075314e4 dsa: Split ops up... |
81 |
struct packet_type; |
3e8a72d1d net: dsa: reduce ... |
82 |
|
cf50dcc24 dsa: Change dsa_u... |
83 |
struct dsa_switch_tree { |
83c0afaec net: dsa: Add new... |
84 85 86 87 88 89 90 91 92 93 |
struct list_head list; /* Tree identifier */ u32 tree; /* Number of switches attached to this tree */ struct kref refcount; /* Has this tree been applied to the hardware? */ bool applied; |
cf50dcc24 dsa: Change dsa_u... |
94 95 96 97 98 99 100 101 102 103 104 |
/* * Configuration data for the platform device that owns * this dsa switch tree instance. */ struct dsa_platform_data *pd; /* * Reference to network device to use, and which tagging * protocol to use. */ struct net_device *master_netdev; |
5075314e4 dsa: Split ops up... |
105 106 107 108 |
int (*rcv)(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt, struct net_device *orig_dev); |
cf50dcc24 dsa: Change dsa_u... |
109 110 |
/* |
badf3ada6 net: dsa: Provide... |
111 112 113 |
* Original copy of the master netdev ethtool_ops */ struct ethtool_ops master_ethtool_ops; |
0c73c523c net: dsa: Initial... |
114 |
const struct ethtool_ops *master_orig_ethtool_ops; |
badf3ada6 net: dsa: Provide... |
115 116 |
/* |
cf50dcc24 dsa: Change dsa_u... |
117 118 119 120 121 122 |
* The switch and port to which the CPU is attached. */ s8 cpu_switch; s8 cpu_port; /* |
cf50dcc24 dsa: Change dsa_u... |
123 124 125 |
* Data for the individual switch chips. */ struct dsa_switch *ds[DSA_MAX_SWITCHES]; |
39a7f2a4e net: dsa: Refacto... |
126 127 128 129 130 131 |
/* * Tagging protocol operations for adding and removing an * encapsulation tag. */ const struct dsa_device_ops *tag_ops; |
cf50dcc24 dsa: Change dsa_u... |
132 |
}; |
c8b098086 net: dsa: Add a p... |
133 134 |
struct dsa_port { struct net_device *netdev; |
189b0d93e net: dsa: Move po... |
135 |
struct device_node *dn; |
34a79f63b net: dsa: support... |
136 |
unsigned int ageing_time; |
732f794c1 net: dsa: add por... |
137 |
u8 stp_state; |
c8b098086 net: dsa: Add a p... |
138 |
}; |
c8f0b8699 dsa: Move all def... |
139 |
struct dsa_switch { |
c33063d6a dsa: Remove maste... |
140 |
struct device *dev; |
c8f0b8699 dsa: Move all def... |
141 142 143 144 145 146 147 |
/* * Parent switch tree, and switch index. */ struct dsa_switch_tree *dst; int index; /* |
7543a6d53 net: dsa: Have th... |
148 149 150 151 152 153 |
* Give the switch driver somewhere to hang its private data * structure. */ void *priv; /* |
c8f0b8699 dsa: Move all def... |
154 155 |
* Configuration data for this switch. */ |
ff04955c2 dsa: Rename switc... |
156 |
struct dsa_chip_data *cd; |
c8f0b8699 dsa: Move all def... |
157 158 |
/* |
9d490b4ee net: dsa: rename ... |
159 |
* The switch operations. |
c8f0b8699 dsa: Move all def... |
160 |
*/ |
9d490b4ee net: dsa: rename ... |
161 |
struct dsa_switch_ops *ops; |
c8f0b8699 dsa: Move all def... |
162 |
|
66472fc04 net: dsa: Copy th... |
163 164 165 166 167 168 |
/* * An array of which element [a] indicates which port on this * switch should be used to send packets to that are destined * for switch a. Can be NULL if there is only one switch chip. */ s8 rtable[DSA_MAX_SWITCHES]; |
51579c3f1 net: dsa: Add sup... |
169 170 171 172 173 174 175 |
#ifdef CONFIG_NET_DSA_HWMON /* * Hardware monitoring information */ char hwmon_name[IFNAMSIZ + 8]; struct device *hwmon_dev; #endif |
c8f0b8699 dsa: Move all def... |
176 |
/* |
83c0afaec net: dsa: Add new... |
177 178 179 180 181 |
* The lower device this switch uses to talk to the host */ struct net_device *master_netdev; /* |
c8f0b8699 dsa: Move all def... |
182 183 184 |
* Slave mii_bus and devices for the individual ports. */ u32 dsa_port_mask; |
83c0afaec net: dsa: Add new... |
185 |
u32 cpu_port_mask; |
74c3e2a54 dsa: Rename phys_... |
186 |
u32 enabled_port_mask; |
0d8bcdd38 net: dsa: allow f... |
187 |
u32 phys_mii_mask; |
c8b098086 net: dsa: Add a p... |
188 |
struct dsa_port ports[DSA_MAX_PORTS]; |
c8f0b8699 dsa: Move all def... |
189 |
struct mii_bus *slave_mii_bus; |
c8f0b8699 dsa: Move all def... |
190 191 192 193 194 195 |
}; static inline bool dsa_is_cpu_port(struct dsa_switch *ds, int p) { return !!(ds->index == ds->dst->cpu_switch && p == ds->dst->cpu_port); } |
60045cbfc net: dsa: Add dsa... |
196 197 198 199 |
static inline bool dsa_is_dsa_port(struct dsa_switch *ds, int p) { return !!((ds->dsa_port_mask) & (1 << p)); } |
d79d21073 net: dsa: Introdu... |
200 201 |
static inline bool dsa_is_port_initialized(struct dsa_switch *ds, int p) { |
c8b098086 net: dsa: Add a p... |
202 |
return ds->enabled_port_mask & (1 << p) && ds->ports[p].netdev; |
d79d21073 net: dsa: Introdu... |
203 |
} |
c8f0b8699 dsa: Move all def... |
204 205 206 207 208 209 210 211 212 213 214 215 216 |
static inline u8 dsa_upstream_port(struct dsa_switch *ds) { struct dsa_switch_tree *dst = ds->dst; /* * If this is the root switch (i.e. the switch that connects * to the CPU), return the cpu port number on this switch. * Else return the (DSA) port number that connects to the * switch that is one hop closer to the cpu. */ if (dst->cpu_switch == ds->index) return dst->cpu_port; else |
66472fc04 net: dsa: Copy th... |
217 |
return ds->rtable[dst->cpu_switch]; |
c8f0b8699 dsa: Move all def... |
218 |
} |
146a32067 net: dsa: add por... |
219 |
struct switchdev_trans; |
ea70ba980 net: dsa: add por... |
220 |
struct switchdev_obj; |
146a32067 net: dsa: add por... |
221 |
struct switchdev_obj_port_fdb; |
8df302552 net: dsa: add MDB... |
222 |
struct switchdev_obj_port_mdb; |
76e398a62 net: dsa: use swi... |
223 |
struct switchdev_obj_port_vlan; |
146a32067 net: dsa: add por... |
224 |
|
9d490b4ee net: dsa: rename ... |
225 |
struct dsa_switch_ops { |
c8f0b8699 dsa: Move all def... |
226 |
struct list_head list; |
c8f0b8699 dsa: Move all def... |
227 228 229 |
/* * Probing and setup. */ |
0209d144e net: dsa: constif... |
230 231 232 |
const char *(*probe)(struct device *dsa_dev, struct device *host_dev, int sw_addr, void **priv); |
7b314362a net: dsa: Allow t... |
233 234 |
enum dsa_tag_protocol (*get_tag_protocol)(struct dsa_switch *ds); |
c8f0b8699 dsa: Move all def... |
235 236 |
int (*setup)(struct dsa_switch *ds); int (*set_addr)(struct dsa_switch *ds, u8 *addr); |
6819563e6 net: dsa: allow s... |
237 |
u32 (*get_phy_flags)(struct dsa_switch *ds, int port); |
c8f0b8699 dsa: Move all def... |
238 239 240 241 242 243 244 245 246 |
/* * Access to the switch's PHY registers. */ int (*phy_read)(struct dsa_switch *ds, int port, int regnum); int (*phy_write)(struct dsa_switch *ds, int port, int regnum, u16 val); /* |
ec9436bae net: dsa: allow d... |
247 248 249 250 |
* Link state adjustment (called from libphy) */ void (*adjust_link)(struct dsa_switch *ds, int port, struct phy_device *phydev); |
ce31b31c6 net: dsa: allow u... |
251 252 |
void (*fixed_link_update)(struct dsa_switch *ds, int port, struct fixed_phy_status *st); |
ec9436bae net: dsa: allow d... |
253 254 |
/* |
c8f0b8699 dsa: Move all def... |
255 256 257 258 259 260 |
* ethtool hardware statistics. */ void (*get_strings)(struct dsa_switch *ds, int port, uint8_t *data); void (*get_ethtool_stats)(struct dsa_switch *ds, int port, uint64_t *data); int (*get_sset_count)(struct dsa_switch *ds); |
244625491 net: dsa: allow s... |
261 262 |
/* |
19e57c4e6 net: dsa: add {ge... |
263 264 265 266 267 268 269 270 |
* ethtool Wake-on-LAN */ void (*get_wol)(struct dsa_switch *ds, int port, struct ethtool_wolinfo *w); int (*set_wol)(struct dsa_switch *ds, int port, struct ethtool_wolinfo *w); /* |
244625491 net: dsa: allow s... |
271 272 273 274 |
* Suspend and resume */ int (*suspend)(struct dsa_switch *ds); int (*resume)(struct dsa_switch *ds); |
b2f2af21e net: dsa: allow e... |
275 276 277 278 279 280 281 282 |
/* * Port enable/disable */ int (*port_enable)(struct dsa_switch *ds, int port, struct phy_device *phy); void (*port_disable)(struct dsa_switch *ds, int port, struct phy_device *phy); |
7905288f0 net: dsa: allow s... |
283 284 285 286 287 288 289 290 291 |
/* * EEE setttings */ int (*set_eee)(struct dsa_switch *ds, int port, struct phy_device *phydev, struct ethtool_eee *e); int (*get_eee)(struct dsa_switch *ds, int port, struct ethtool_eee *e); |
51579c3f1 net: dsa: Add sup... |
292 293 294 295 296 297 298 299 |
#ifdef CONFIG_NET_DSA_HWMON /* Hardware monitoring */ int (*get_temp)(struct dsa_switch *ds, int *temp); int (*get_temp_limit)(struct dsa_switch *ds, int *temp); int (*set_temp_limit)(struct dsa_switch *ds, int temp); int (*get_temp_alarm)(struct dsa_switch *ds, bool *alarm); #endif |
6793abb4e net: dsa: Add sup... |
300 301 302 303 304 305 306 |
/* EEPROM access */ int (*get_eeprom_len)(struct dsa_switch *ds); int (*get_eeprom)(struct dsa_switch *ds, struct ethtool_eeprom *eeprom, u8 *data); int (*set_eeprom)(struct dsa_switch *ds, struct ethtool_eeprom *eeprom, u8 *data); |
3d762a0f0 net: dsa: Add sup... |
307 308 309 310 311 312 313 |
/* * Register access. */ int (*get_regs_len)(struct dsa_switch *ds, int port); void (*get_regs)(struct dsa_switch *ds, int port, struct ethtool_regs *regs, void *p); |
b73adef67 net: dsa: integra... |
314 315 316 317 |
/* * Bridge integration */ |
34a79f63b net: dsa: support... |
318 |
int (*set_ageing_time)(struct dsa_switch *ds, unsigned int msecs); |
71327a4e7 net: dsa: rename ... |
319 |
int (*port_bridge_join)(struct dsa_switch *ds, int port, |
a6692754d net: dsa: pass br... |
320 |
struct net_device *bridge); |
16bfa7024 net: dsa: make po... |
321 |
void (*port_bridge_leave)(struct dsa_switch *ds, int port); |
43c44a9f6 net: dsa: make th... |
322 323 |
void (*port_stp_state_set)(struct dsa_switch *ds, int port, u8 state); |
732f794c1 net: dsa: add por... |
324 |
void (*port_fast_age)(struct dsa_switch *ds, int port); |
2a778e1b5 net: dsa: change ... |
325 326 |
/* |
111495361 net: dsa: add sup... |
327 328 |
* VLAN support */ |
fb2dabad6 net: dsa: support... |
329 330 |
int (*port_vlan_filtering)(struct dsa_switch *ds, int port, bool vlan_filtering); |
76e398a62 net: dsa: use swi... |
331 332 333 |
int (*port_vlan_prepare)(struct dsa_switch *ds, int port, const struct switchdev_obj_port_vlan *vlan, struct switchdev_trans *trans); |
4d5770b39 net: dsa: make th... |
334 |
void (*port_vlan_add)(struct dsa_switch *ds, int port, |
76e398a62 net: dsa: use swi... |
335 336 337 338 |
const struct switchdev_obj_port_vlan *vlan, struct switchdev_trans *trans); int (*port_vlan_del)(struct dsa_switch *ds, int port, const struct switchdev_obj_port_vlan *vlan); |
65aebfc00 net: dsa: add por... |
339 340 341 |
int (*port_vlan_dump)(struct dsa_switch *ds, int port, struct switchdev_obj_port_vlan *vlan, int (*cb)(struct switchdev_obj *obj)); |
111495361 net: dsa: add sup... |
342 343 |
/* |
2a778e1b5 net: dsa: change ... |
344 345 |
* Forwarding database */ |
146a32067 net: dsa: add por... |
346 347 348 |
int (*port_fdb_prepare)(struct dsa_switch *ds, int port, const struct switchdev_obj_port_fdb *fdb, struct switchdev_trans *trans); |
8497aa618 net: dsa: make th... |
349 |
void (*port_fdb_add)(struct dsa_switch *ds, int port, |
1f36faf26 net: dsa: push pr... |
350 351 |
const struct switchdev_obj_port_fdb *fdb, struct switchdev_trans *trans); |
2a778e1b5 net: dsa: change ... |
352 |
int (*port_fdb_del)(struct dsa_switch *ds, int port, |
8057b3e7a net: dsa: use swi... |
353 |
const struct switchdev_obj_port_fdb *fdb); |
ea70ba980 net: dsa: add por... |
354 355 356 |
int (*port_fdb_dump)(struct dsa_switch *ds, int port, struct switchdev_obj_port_fdb *fdb, int (*cb)(struct switchdev_obj *obj)); |
8df302552 net: dsa: add MDB... |
357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 |
/* * Multicast database */ int (*port_mdb_prepare)(struct dsa_switch *ds, int port, const struct switchdev_obj_port_mdb *mdb, struct switchdev_trans *trans); void (*port_mdb_add)(struct dsa_switch *ds, int port, const struct switchdev_obj_port_mdb *mdb, struct switchdev_trans *trans); int (*port_mdb_del)(struct dsa_switch *ds, int port, const struct switchdev_obj_port_mdb *mdb); int (*port_mdb_dump)(struct dsa_switch *ds, int port, struct switchdev_obj_port_mdb *mdb, int (*cb)(struct switchdev_obj *obj)); |
c8f0b8699 dsa: Move all def... |
372 |
}; |
9d490b4ee net: dsa: rename ... |
373 374 |
void register_switch_driver(struct dsa_switch_ops *type); void unregister_switch_driver(struct dsa_switch_ops *type); |
b4d2394d0 dsa: Replace mii_... |
375 |
struct mii_bus *dsa_host_dev_to_mii_bus(struct device *dev); |
c8f0b8699 dsa: Move all def... |
376 |
|
5aed85cec net: dsa: allow s... |
377 378 |
static inline bool dsa_uses_tagged_protocol(struct dsa_switch_tree *dst) { |
5075314e4 dsa: Split ops up... |
379 |
return dst->rcv != NULL; |
5aed85cec net: dsa: allow s... |
380 |
} |
83c0afaec net: dsa: Add new... |
381 382 383 |
void dsa_unregister_switch(struct dsa_switch *ds); int dsa_register_switch(struct dsa_switch *ds, struct device_node *np); |
ea825e70d net: dsa: Export ... |
384 385 386 387 388 389 390 391 392 393 394 395 396 |
#ifdef CONFIG_PM_SLEEP int dsa_switch_suspend(struct dsa_switch *ds); int dsa_switch_resume(struct dsa_switch *ds); #else static inline int dsa_switch_suspend(struct dsa_switch *ds) { return 0; } static inline int dsa_switch_resume(struct dsa_switch *ds) { return 0; } #endif /* CONFIG_PM_SLEEP */ |
91da11f87 net: Distributed ... |
397 |
#endif |