sunvnet_common.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. #ifndef _SUNVNETCOMMON_H
  2. #define _SUNVNETCOMMON_H
  3. #include <linux/interrupt.h>
  4. /* length of time (or less) we expect pending descriptors to be marked
  5. * as VIO_DESC_DONE and skbs ready to be freed
  6. */
  7. #define VNET_CLEAN_TIMEOUT ((HZ / 100) + 1)
  8. #define VNET_MAXPACKET (65535ULL + ETH_HLEN + VLAN_HLEN)
  9. #define VNET_TX_RING_SIZE 512
  10. #define VNET_TX_WAKEUP_THRESH(dr) ((dr)->pending / 4)
  11. #define VNET_MINTSO 2048 /* VIO protocol's minimum TSO len */
  12. #define VNET_MAXTSO 65535 /* VIO protocol's maximum TSO len */
  13. #define VNET_MAX_MTU 65535
  14. /* VNET packets are sent in buffers with the first 6 bytes skipped
  15. * so that after the ethernet header the IPv4/IPv6 headers are aligned
  16. * properly.
  17. */
  18. #define VNET_PACKET_SKIP 6
  19. #define VNET_MAXCOOKIES (VNET_MAXPACKET / PAGE_SIZE + 1)
  20. #define VNET_MAX_TXQS 16
  21. struct vnet_tx_entry {
  22. struct sk_buff *skb;
  23. unsigned int ncookies;
  24. struct ldc_trans_cookie cookies[VNET_MAXCOOKIES];
  25. };
  26. struct vnet;
  27. struct vnet_port_stats {
  28. /* keep them all the same size */
  29. u32 rx_bytes;
  30. u32 tx_bytes;
  31. u32 rx_packets;
  32. u32 tx_packets;
  33. u32 event_up;
  34. u32 event_reset;
  35. u32 q_placeholder;
  36. };
  37. #define NUM_VNET_PORT_STATS (sizeof(struct vnet_port_stats) / sizeof(u32))
  38. /* Structure to describe a vnet-port or vsw-port in the MD.
  39. * If the vsw bit is set, this structure represents a vswitch
  40. * port, and the net_device can be found from ->dev. If the
  41. * vsw bit is not set, the net_device is available from ->vp->dev.
  42. * See the VNET_PORT_TO_NET_DEVICE macro below.
  43. */
  44. struct vnet_port {
  45. struct vio_driver_state vio;
  46. struct vnet_port_stats stats;
  47. struct hlist_node hash;
  48. u8 raddr[ETH_ALEN];
  49. unsigned switch_port:1;
  50. unsigned tso:1;
  51. unsigned vsw:1;
  52. unsigned __pad:13;
  53. struct vnet *vp;
  54. struct net_device *dev;
  55. struct vnet_tx_entry tx_bufs[VNET_TX_RING_SIZE];
  56. struct list_head list;
  57. u32 stop_rx_idx;
  58. bool stop_rx;
  59. bool start_cons;
  60. struct timer_list clean_timer;
  61. u64 rmtu;
  62. u16 tsolen;
  63. struct napi_struct napi;
  64. u32 napi_stop_idx;
  65. bool napi_resume;
  66. int rx_event;
  67. u16 q_index;
  68. };
  69. static inline struct vnet_port *to_vnet_port(struct vio_driver_state *vio)
  70. {
  71. return container_of(vio, struct vnet_port, vio);
  72. }
  73. #define VNET_PORT_HASH_SIZE 16
  74. #define VNET_PORT_HASH_MASK (VNET_PORT_HASH_SIZE - 1)
  75. static inline unsigned int vnet_hashfn(u8 *mac)
  76. {
  77. unsigned int val = mac[4] ^ mac[5];
  78. return val & (VNET_PORT_HASH_MASK);
  79. }
  80. struct vnet_mcast_entry {
  81. u8 addr[ETH_ALEN];
  82. u8 sent;
  83. u8 hit;
  84. struct vnet_mcast_entry *next;
  85. };
  86. struct vnet {
  87. spinlock_t lock; /* Protects port_list and port_hash. */
  88. struct net_device *dev;
  89. u32 msg_enable;
  90. u8 q_used[VNET_MAX_TXQS];
  91. struct list_head port_list;
  92. struct hlist_head port_hash[VNET_PORT_HASH_SIZE];
  93. struct vnet_mcast_entry *mcast_list;
  94. struct list_head list;
  95. u64 local_mac;
  96. int nports;
  97. };
  98. /* Def used by common code to get the net_device from the proper location */
  99. #define VNET_PORT_TO_NET_DEVICE(__port) \
  100. ((__port)->vsw ? (__port)->dev : (__port)->vp->dev)
  101. /* Common funcs */
  102. void sunvnet_clean_timer_expire_common(unsigned long port0);
  103. int sunvnet_open_common(struct net_device *dev);
  104. int sunvnet_close_common(struct net_device *dev);
  105. void sunvnet_set_rx_mode_common(struct net_device *dev, struct vnet *vp);
  106. int sunvnet_set_mac_addr_common(struct net_device *dev, void *p);
  107. void sunvnet_tx_timeout_common(struct net_device *dev);
  108. int sunvnet_start_xmit_common(struct sk_buff *skb, struct net_device *dev,
  109. struct vnet_port *(*vnet_tx_port)
  110. (struct sk_buff *, struct net_device *));
  111. #ifdef CONFIG_NET_POLL_CONTROLLER
  112. void sunvnet_poll_controller_common(struct net_device *dev, struct vnet *vp);
  113. #endif
  114. void sunvnet_event_common(void *arg, int event);
  115. int sunvnet_send_attr_common(struct vio_driver_state *vio);
  116. int sunvnet_handle_attr_common(struct vio_driver_state *vio, void *arg);
  117. void sunvnet_handshake_complete_common(struct vio_driver_state *vio);
  118. int sunvnet_poll_common(struct napi_struct *napi, int budget);
  119. void sunvnet_port_free_tx_bufs_common(struct vnet_port *port);
  120. void vnet_port_reset(struct vnet_port *port);
  121. bool sunvnet_port_is_up_common(struct vnet_port *vnet);
  122. void sunvnet_port_add_txq_common(struct vnet_port *port);
  123. void sunvnet_port_rm_txq_common(struct vnet_port *port);
  124. #endif /* _SUNVNETCOMMON_H */