blob: d5f1f9b862ea5f4794ba2fab277e19aed8e51d2a [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>
16
17struct dsa_device_ops {
18 netdev_tx_t (*xmit)(struct sk_buff *skb, struct net_device *dev);
19 int (*rcv)(struct sk_buff *skb, struct net_device *dev,
20 struct packet_type *pt, struct net_device *orig_dev);
21};
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000022
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000023struct dsa_slave_priv {
Lennert Buytenheke84665c2009-03-20 09:52:09 +000024 /*
25 * The linux network interface corresponding to this
26 * switch port.
27 */
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000028 struct net_device *dev;
Alexander Duyck50753142014-09-15 13:00:19 -040029 netdev_tx_t (*xmit)(struct sk_buff *skb,
30 struct net_device *dev);
Lennert Buytenheke84665c2009-03-20 09:52:09 +000031
32 /*
33 * Which switch this port is a part of, and the port index
34 * for this port.
35 */
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000036 struct dsa_switch *parent;
Lennert Buytenheke84665c2009-03-20 09:52:09 +000037 u8 port;
38
39 /*
40 * The phylib phy_device pointer for the PHY connected
41 * to this port.
42 */
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000043 struct phy_device *phy;
Florian Fainelli0d8bcdd2014-08-27 17:04:51 -070044 phy_interface_t phy_interface;
45 int old_link;
46 int old_pause;
47 int old_duplex;
Florian Fainellib73adef2015-02-24 13:15:33 -080048
49 struct net_device *bridge_dev;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000050};
51
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000052/* dsa.c */
53extern char dsa_driver_version[];
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000054
55/* slave.c */
Alexander Duyck50753142014-09-15 13:00:19 -040056extern const struct dsa_device_ops notag_netdev_ops;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000057void dsa_slave_mii_bus_init(struct dsa_switch *ds);
Guenter Roeckd87d6f42015-02-24 13:15:32 -080058int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
59 int port, char *name);
Florian Fainelli24462542014-09-18 17:31:22 -070060int dsa_slave_suspend(struct net_device *slave_dev);
61int dsa_slave_resume(struct net_device *slave_dev);
Florian Fainellib73adef2015-02-24 13:15:33 -080062int dsa_slave_netdevice_event(struct notifier_block *unused,
63 unsigned long event, void *ptr);
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000064
Lennert Buytenhekcf85d082008-10-07 13:45:02 +000065/* tag_dsa.c */
Florian Fainelli3e8a72d2014-08-27 17:04:46 -070066extern const struct dsa_device_ops dsa_netdev_ops;
Lennert Buytenhekcf85d082008-10-07 13:45:02 +000067
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000068/* tag_edsa.c */
Florian Fainelli3e8a72d2014-08-27 17:04:46 -070069extern const struct dsa_device_ops edsa_netdev_ops;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000070
Lennert Buytenhek396138f2008-10-07 13:46:07 +000071/* tag_trailer.c */
Florian Fainelli3e8a72d2014-08-27 17:04:46 -070072extern const struct dsa_device_ops trailer_netdev_ops;
Lennert Buytenhek396138f2008-10-07 13:46:07 +000073
Florian Fainelli5037d532014-08-27 17:04:55 -070074/* tag_brcm.c */
75extern const struct dsa_device_ops brcm_netdev_ops;
76
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000077
78#endif