dsa_priv.h 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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. #ifndef __DSA_PRIV_H
  11. #define __DSA_PRIV_H
  12. #include <linux/phy.h>
  13. #include <linux/netdevice.h>
  14. #include <linux/netpoll.h>
  15. struct dsa_device_ops {
  16. struct sk_buff *(*xmit)(struct sk_buff *skb, struct net_device *dev);
  17. int (*rcv)(struct sk_buff *skb, struct net_device *dev,
  18. struct packet_type *pt, struct net_device *orig_dev);
  19. };
  20. struct dsa_slave_priv {
  21. struct sk_buff * (*xmit)(struct sk_buff *skb,
  22. struct net_device *dev);
  23. /*
  24. * Which switch this port is a part of, and the port index
  25. * for this port.
  26. */
  27. struct dsa_switch *parent;
  28. u8 port;
  29. /*
  30. * The phylib phy_device pointer for the PHY connected
  31. * to this port.
  32. */
  33. struct phy_device *phy;
  34. phy_interface_t phy_interface;
  35. int old_link;
  36. int old_pause;
  37. int old_duplex;
  38. struct net_device *bridge_dev;
  39. #ifdef CONFIG_NET_POLL_CONTROLLER
  40. struct netpoll *netpoll;
  41. #endif
  42. };
  43. /* dsa.c */
  44. int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct device *dev,
  45. struct dsa_port *dport, int port);
  46. void dsa_cpu_dsa_destroy(struct dsa_port *dport);
  47. const struct dsa_device_ops *dsa_resolve_tag_protocol(int tag_protocol);
  48. int dsa_cpu_port_ethtool_setup(struct dsa_switch *ds);
  49. void dsa_cpu_port_ethtool_restore(struct dsa_switch *ds);
  50. /* slave.c */
  51. extern const struct dsa_device_ops notag_netdev_ops;
  52. void dsa_slave_mii_bus_init(struct dsa_switch *ds);
  53. void dsa_cpu_port_ethtool_init(struct ethtool_ops *ops);
  54. int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
  55. int port, const char *name);
  56. void dsa_slave_destroy(struct net_device *slave_dev);
  57. int dsa_slave_suspend(struct net_device *slave_dev);
  58. int dsa_slave_resume(struct net_device *slave_dev);
  59. int dsa_slave_netdevice_event(struct notifier_block *unused,
  60. unsigned long event, void *ptr);
  61. /* tag_dsa.c */
  62. extern const struct dsa_device_ops dsa_netdev_ops;
  63. /* tag_edsa.c */
  64. extern const struct dsa_device_ops edsa_netdev_ops;
  65. /* tag_trailer.c */
  66. extern const struct dsa_device_ops trailer_netdev_ops;
  67. /* tag_brcm.c */
  68. extern const struct dsa_device_ops brcm_netdev_ops;
  69. /* tag_qca.c */
  70. extern const struct dsa_device_ops qca_netdev_ops;
  71. #endif