Linux Audio

Check our new training course

Loading...
v4.10.11
 1/*
 2 * net/dsa/dsa_priv.h - Hardware switch handling
 3 * Copyright (c) 2008-2009 Marvell Semiconductor
 4 *
 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
14#include <linux/phy.h>
15#include <linux/netdevice.h>
16#include <linux/netpoll.h>
17
18struct dsa_device_ops {
19	struct sk_buff *(*xmit)(struct sk_buff *skb, struct net_device *dev);
20	int (*rcv)(struct sk_buff *skb, struct net_device *dev,
21		   struct packet_type *pt, struct net_device *orig_dev);
22};
23
24struct dsa_slave_priv {
 
 
 
 
 
25	struct sk_buff *	(*xmit)(struct sk_buff *skb,
26					struct net_device *dev);
27
28	/*
29	 * Which switch this port is a part of, and the port index
30	 * for this port.
31	 */
32	struct dsa_switch	*parent;
33	u8			port;
34
35	/*
36	 * The phylib phy_device pointer for the PHY connected
37	 * to this port.
38	 */
39	struct phy_device	*phy;
40	phy_interface_t		phy_interface;
41	int			old_link;
42	int			old_pause;
43	int			old_duplex;
44
45	struct net_device	*bridge_dev;
46#ifdef CONFIG_NET_POLL_CONTROLLER
47	struct netpoll		*netpoll;
48#endif
49};
50
51/* dsa.c */
52extern char dsa_driver_version[];
53int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct device *dev,
54		      struct device_node *port_dn, int port);
55void dsa_cpu_dsa_destroy(struct device_node *port_dn);
56const struct dsa_device_ops *dsa_resolve_tag_protocol(int tag_protocol);
57int dsa_cpu_port_ethtool_setup(struct dsa_switch *ds);
58void dsa_cpu_port_ethtool_restore(struct dsa_switch *ds);
59
60/* slave.c */
61extern const struct dsa_device_ops notag_netdev_ops;
62void dsa_slave_mii_bus_init(struct dsa_switch *ds);
63void dsa_cpu_port_ethtool_init(struct ethtool_ops *ops);
64int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
65		     int port, const char *name);
66void dsa_slave_destroy(struct net_device *slave_dev);
67int dsa_slave_suspend(struct net_device *slave_dev);
68int dsa_slave_resume(struct net_device *slave_dev);
69int dsa_slave_netdevice_event(struct notifier_block *unused,
70			      unsigned long event, void *ptr);
71
72/* tag_dsa.c */
73extern const struct dsa_device_ops dsa_netdev_ops;
74
75/* tag_edsa.c */
76extern const struct dsa_device_ops edsa_netdev_ops;
77
78/* tag_trailer.c */
79extern const struct dsa_device_ops trailer_netdev_ops;
80
81/* tag_brcm.c */
82extern const struct dsa_device_ops brcm_netdev_ops;
83
84/* tag_qca.c */
85extern const struct dsa_device_ops qca_netdev_ops;
86
87#endif
v4.6
 1/*
 2 * net/dsa/dsa_priv.h - Hardware switch handling
 3 * Copyright (c) 2008-2009 Marvell Semiconductor
 4 *
 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
14#include <linux/phy.h>
15#include <linux/netdevice.h>
16#include <linux/netpoll.h>
17
18struct dsa_device_ops {
19	struct sk_buff *(*xmit)(struct sk_buff *skb, struct net_device *dev);
20	int (*rcv)(struct sk_buff *skb, struct net_device *dev,
21		   struct packet_type *pt, struct net_device *orig_dev);
22};
23
24struct dsa_slave_priv {
25	/*
26	 * The linux network interface corresponding to this
27	 * switch port.
28	 */
29	struct net_device	*dev;
30	struct sk_buff *	(*xmit)(struct sk_buff *skb,
31					struct net_device *dev);
32
33	/*
34	 * Which switch this port is a part of, and the port index
35	 * for this port.
36	 */
37	struct dsa_switch	*parent;
38	u8			port;
39
40	/*
41	 * The phylib phy_device pointer for the PHY connected
42	 * to this port.
43	 */
44	struct phy_device	*phy;
45	phy_interface_t		phy_interface;
46	int			old_link;
47	int			old_pause;
48	int			old_duplex;
49
50	struct net_device	*bridge_dev;
51#ifdef CONFIG_NET_POLL_CONTROLLER
52	struct netpoll		*netpoll;
53#endif
54};
55
56/* dsa.c */
57extern char dsa_driver_version[];
 
 
 
 
 
 
58
59/* slave.c */
60extern const struct dsa_device_ops notag_netdev_ops;
61void dsa_slave_mii_bus_init(struct dsa_switch *ds);
 
62int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
63		     int port, char *name);
64void dsa_slave_destroy(struct net_device *slave_dev);
65int dsa_slave_suspend(struct net_device *slave_dev);
66int dsa_slave_resume(struct net_device *slave_dev);
67int dsa_slave_netdevice_event(struct notifier_block *unused,
68			      unsigned long event, void *ptr);
69
70/* tag_dsa.c */
71extern const struct dsa_device_ops dsa_netdev_ops;
72
73/* tag_edsa.c */
74extern const struct dsa_device_ops edsa_netdev_ops;
75
76/* tag_trailer.c */
77extern const struct dsa_device_ops trailer_netdev_ops;
78
79/* tag_brcm.c */
80extern const struct dsa_device_ops brcm_netdev_ops;
81
 
 
82
83#endif