dsa_priv.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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. /* DSA port data, such as switch, port index, etc. */
  24. struct dsa_port *dp;
  25. /*
  26. * The phylib phy_device pointer for the PHY connected
  27. * to this port.
  28. */
  29. struct phy_device *phy;
  30. phy_interface_t phy_interface;
  31. int old_link;
  32. int old_pause;
  33. int old_duplex;
  34. #ifdef CONFIG_NET_POLL_CONTROLLER
  35. struct netpoll *netpoll;
  36. #endif
  37. /* TC context */
  38. struct list_head mall_tc_list;
  39. };
  40. /* dsa.c */
  41. int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct device *dev,
  42. struct dsa_port *dport, int port);
  43. void dsa_cpu_dsa_destroy(struct dsa_port *dport);
  44. const struct dsa_device_ops *dsa_resolve_tag_protocol(int tag_protocol);
  45. int dsa_cpu_port_ethtool_setup(struct dsa_switch *ds);
  46. void dsa_cpu_port_ethtool_restore(struct dsa_switch *ds);
  47. /* slave.c */
  48. extern const struct dsa_device_ops notag_netdev_ops;
  49. void dsa_slave_mii_bus_init(struct dsa_switch *ds);
  50. void dsa_cpu_port_ethtool_init(struct ethtool_ops *ops);
  51. int dsa_slave_create(struct dsa_switch *ds, struct device *parent,
  52. int port, const char *name);
  53. void dsa_slave_destroy(struct net_device *slave_dev);
  54. int dsa_slave_suspend(struct net_device *slave_dev);
  55. int dsa_slave_resume(struct net_device *slave_dev);
  56. int dsa_slave_register_notifier(void);
  57. void dsa_slave_unregister_notifier(void);
  58. /* switch.c */
  59. int dsa_switch_register_notifier(struct dsa_switch *ds);
  60. void dsa_switch_unregister_notifier(struct dsa_switch *ds);
  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