Linux Audio

Check our new training course

Loading...
v3.5.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 <net/dsa.h>
 
 
 
 
 
 
 
16
17struct dsa_slave_priv {
18	/*
19	 * The linux network interface corresponding to this
20	 * switch port.
21	 */
22	struct net_device	*dev;
 
 
23
24	/*
25	 * Which switch this port is a part of, and the port index
26	 * for this port.
27	 */
28	struct dsa_switch	*parent;
29	u8			port;
30
31	/*
32	 * The phylib phy_device pointer for the PHY connected
33	 * to this port.
34	 */
35	struct phy_device	*phy;
 
 
 
 
 
 
 
 
 
36};
37
38/* dsa.c */
39extern char dsa_driver_version[];
40
41/* slave.c */
 
42void dsa_slave_mii_bus_init(struct dsa_switch *ds);
43struct net_device *dsa_slave_create(struct dsa_switch *ds,
44				    struct device *parent,
45				    int port, char *name);
 
 
 
 
46
47/* tag_dsa.c */
48netdev_tx_t dsa_xmit(struct sk_buff *skb, struct net_device *dev);
49extern struct packet_type dsa_packet_type;
50
51/* tag_edsa.c */
52netdev_tx_t edsa_xmit(struct sk_buff *skb, struct net_device *dev);
53extern struct packet_type edsa_packet_type;
54
55/* tag_trailer.c */
56netdev_tx_t trailer_xmit(struct sk_buff *skb, struct net_device *dev);
57extern struct packet_type trailer_packet_type;
 
 
58
59
60#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