unicast.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * Copyright (C) 2010-2012 B.A.T.M.A.N. contributors:
  3. *
  4. * Andreas Langer
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of version 2 of the GNU General Public
  8. * License as published by the Free Software Foundation.
  9. *
  10. * This program is distributed in the hope that it will be useful, but
  11. * WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  13. * General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  18. * 02110-1301, USA
  19. *
  20. */
  21. #ifndef _NET_BATMAN_ADV_UNICAST_H_
  22. #define _NET_BATMAN_ADV_UNICAST_H_
  23. #include "packet.h"
  24. #define FRAG_TIMEOUT 10000 /* purge frag list entries after time in ms */
  25. #define FRAG_BUFFER_SIZE 6 /* number of list elements in buffer */
  26. int frag_reassemble_skb(struct sk_buff *skb, struct bat_priv *bat_priv,
  27. struct sk_buff **new_skb);
  28. void frag_list_free(struct list_head *head);
  29. int unicast_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv);
  30. int frag_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv,
  31. struct hard_iface *hard_iface, const uint8_t dstaddr[]);
  32. static inline int frag_can_reassemble(const struct sk_buff *skb, int mtu)
  33. {
  34. const struct unicast_frag_packet *unicast_packet;
  35. int uneven_correction = 0;
  36. unsigned int merged_size;
  37. unicast_packet = (struct unicast_frag_packet *)skb->data;
  38. if (unicast_packet->flags & UNI_FRAG_LARGETAIL) {
  39. if (unicast_packet->flags & UNI_FRAG_HEAD)
  40. uneven_correction = 1;
  41. else
  42. uneven_correction = -1;
  43. }
  44. merged_size = (skb->len - sizeof(*unicast_packet)) * 2;
  45. merged_size += sizeof(struct unicast_packet) + uneven_correction;
  46. return merged_size <= mtu;
  47. }
  48. #endif /* _NET_BATMAN_ADV_UNICAST_H_ */