blob: f4a88e4852138864081c1871fc882803e53247db [file] [log] [blame]
Lennert Buytenhek91da11f2008-10-07 13:44:02 +00001/*
2 * net/dsa/dsa_priv.h - Hardware switch handling
Lennert Buytenheke84665c2009-03-20 09:52:09 +00003 * Copyright (c) 2008-2009 Marvell Semiconductor
Lennert Buytenhek91da11f2008-10-07 13:44:02 +00004 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 */
10
11#ifndef __DSA_PRIV_H
12#define __DSA_PRIV_H
13
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000014#include <linux/phy.h>
Alexander Duyck50753142014-09-15 13:00:19 -040015#include <linux/netdevice.h>
Florian Fainelli04ff53f2015-07-31 11:42:57 -070016#include <linux/netpoll.h>
Alexander Duyck50753142014-09-15 13:00:19 -040017
18struct dsa_device_ops {
Florian Fainelli4ed70ce2015-07-31 11:42:56 -070019 struct sk_buff *(*xmit)(struct sk_buff *skb, struct net_device *dev);
Florian Fainellia86d8be2017-04-08 08:55:23 -070020 struct sk_buff *(*rcv)(struct sk_buff *skb, struct net_device *dev,
21 struct packet_type *pt,
22 struct net_device *orig_dev);
Alexander Duyck50753142014-09-15 13:00:19 -040023};
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000024
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000025struct dsa_slave_priv {
Florian Fainelli4ed70ce2015-07-31 11:42:56 -070026 struct sk_buff * (*xmit)(struct sk_buff *skb,
Alexander Duyck50753142014-09-15 13:00:19 -040027 struct net_device *dev);
Lennert Buytenheke84665c2009-03-20 09:52:09 +000028
Vivien Didelotafdcf152017-01-27 15:29:39 -050029 /* DSA port data, such as switch, port index, etc. */
30 struct dsa_port *dp;
Lennert Buytenheke84665c2009-03-20 09:52:09 +000031
32 /*
33 * The phylib phy_device pointer for the PHY connected
34 * to this port.
35 */
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000036 struct phy_device *phy;
Florian Fainelli0d8bcdd2014-08-27 17:04:51 -070037 phy_interface_t phy_interface;
38 int old_link;
39 int old_pause;
40 int old_duplex;
Florian Fainellib73adef2015-02-24 13:15:33 -080041
Florian Fainelli04ff53f2015-07-31 11:42:57 -070042#ifdef CONFIG_NET_POLL_CONTROLLER
43 struct netpoll *netpoll;
44#endif
Florian Fainellif50f2122017-01-30 12:41:40 -080045
46 /* TC context */
47 struct list_head mall_tc_list;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000048};
49
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000050/* dsa.c */
Andrew Lunn9b8e8952016-06-04 21:17:01 +020051int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct device *dev,
Florian Fainelli293784a2017-01-26 10:45:52 -080052 struct dsa_port *dport, int port);
53void dsa_cpu_dsa_destroy(struct dsa_port *dport);
Andrew Lunn39a7f2a2016-06-04 21:17:03 +020054const struct dsa_device_ops *dsa_resolve_tag_protocol(int tag_protocol);
Florian Fainelli0c73c522016-06-07 16:32:42 -070055int dsa_cpu_port_ethtool_setup(struct dsa_switch *ds);
56void dsa_cpu_port_ethtool_restore(struct dsa_switch *ds);
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000057
Vivien Didelota6a71f12017-04-12 12:45:03 -040058/* legacy.c */
59int dsa_legacy_register(void);
60void dsa_legacy_unregister(void);
61
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000062/* slave.c */
Alexander Duyck50753142014-09-15 13:00:19 -040063extern const struct dsa_device_ops notag_netdev_ops;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000064void dsa_slave_mii_bus_init(struct dsa_switch *ds);
Florian Fainelliaf421922016-06-07 16:32:41 -070065void dsa_cpu_port_ethtool_init(struct ethtool_ops *ops);
Guenter Roeckd87d6f42015-02-24 13:15:32 -080066int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
Andrew Lunn83c0afa2016-06-04 21:17:07 +020067 int port, const char *name);
Neil Armstrongcda5c152015-12-07 13:57:35 +010068void dsa_slave_destroy(struct net_device *slave_dev);
Florian Fainelli24462542014-09-18 17:31:22 -070069int dsa_slave_suspend(struct net_device *slave_dev);
70int dsa_slave_resume(struct net_device *slave_dev);
Vivien Didelot88e4f0c2017-02-03 13:20:16 -050071int dsa_slave_register_notifier(void);
72void dsa_slave_unregister_notifier(void);
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000073
Vivien Didelotf515f192017-02-03 13:20:20 -050074/* switch.c */
75int dsa_switch_register_notifier(struct dsa_switch *ds);
76void dsa_switch_unregister_notifier(struct dsa_switch *ds);
77
Lennert Buytenhekcf85d082008-10-07 13:45:02 +000078/* tag_dsa.c */
Florian Fainelli3e8a72d2014-08-27 17:04:46 -070079extern const struct dsa_device_ops dsa_netdev_ops;
Lennert Buytenhekcf85d082008-10-07 13:45:02 +000080
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000081/* tag_edsa.c */
Florian Fainelli3e8a72d2014-08-27 17:04:46 -070082extern const struct dsa_device_ops edsa_netdev_ops;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000083
Lennert Buytenhek396138f2008-10-07 13:46:07 +000084/* tag_trailer.c */
Florian Fainelli3e8a72d2014-08-27 17:04:46 -070085extern const struct dsa_device_ops trailer_netdev_ops;
Lennert Buytenhek396138f2008-10-07 13:46:07 +000086
Florian Fainelli5037d532014-08-27 17:04:55 -070087/* tag_brcm.c */
88extern const struct dsa_device_ops brcm_netdev_ops;
89
John Crispincafdc452016-09-15 16:26:40 +020090/* tag_qca.c */
91extern const struct dsa_device_ops qca_netdev_ops;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000092
Sean Wang5cd89852017-04-07 16:45:06 +080093/* tag_mtk.c */
94extern const struct dsa_device_ops mtk_netdev_ops;
95
Juergen Beiserte8fe1772017-04-18 10:48:24 +020096/* tag_lan9303.c */
97extern const struct dsa_device_ops lan9303_netdev_ops;
98
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000099#endif