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 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}; 22 23struct dsa_slave_priv { 24 /* 25 * The linux network interface corresponding to this 26 * switch port. 27 */ 28 struct net_device *dev; 29 netdev_tx_t (*xmit)(struct sk_buff *skb, 30 struct net_device *dev); 31 32 /* 33 * Which switch this port is a part of, and the port index 34 * for this port. 35 */ 36 struct dsa_switch *parent; 37 u8 port; 38 39 /* 40 * The phylib phy_device pointer for the PHY connected 41 * to this port. 42 */ 43 struct phy_device *phy; 44 phy_interface_t phy_interface; 45 int old_link; 46 int old_pause; 47 int old_duplex; 48}; 49 50/* dsa.c */ 51extern char dsa_driver_version[]; 52 53/* slave.c */ 54extern const struct dsa_device_ops notag_netdev_ops; 55void dsa_slave_mii_bus_init(struct dsa_switch *ds); 56struct net_device *dsa_slave_create(struct dsa_switch *ds, 57 struct device *parent, 58 int port, char *name); 59int dsa_slave_suspend(struct net_device *slave_dev); 60int dsa_slave_resume(struct net_device *slave_dev); 61 62/* tag_dsa.c */ 63extern const struct dsa_device_ops dsa_netdev_ops; 64 65/* tag_edsa.c */ 66extern const struct dsa_device_ops edsa_netdev_ops; 67 68/* tag_trailer.c */ 69extern const struct dsa_device_ops trailer_netdev_ops; 70 71/* tag_brcm.c */ 72extern const struct dsa_device_ops brcm_netdev_ops; 73 74 75#endif 76