loss_interval.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. #ifndef _DCCP_LI_HIST_
  2. #define _DCCP_LI_HIST_
  3. /*
  4. * net/dccp/ccids/lib/loss_interval.h
  5. *
  6. * Copyright (c) 2005 The University of Waikato, Hamilton, New Zealand.
  7. * Copyright (c) 2005 Ian McDonald <ian.mcdonald@jandi.co.nz>
  8. * Copyright (c) 2005 Arnaldo Carvalho de Melo <acme@conectiva.com.br>
  9. *
  10. * This program is free software; you can redistribute it and/or modify it
  11. * under the terms of the GNU General Public License as published by the Free
  12. * Software Foundation; either version 2 of the License, or (at your option)
  13. * any later version.
  14. */
  15. #include <linux/list.h>
  16. #include <linux/slab.h>
  17. #include <linux/time.h>
  18. #define DCCP_LI_HIST_IVAL_F_LENGTH 8
  19. struct dccp_li_hist {
  20. struct kmem_cache *dccplih_slab;
  21. };
  22. extern struct dccp_li_hist *dccp_li_hist_new(const char *name);
  23. extern void dccp_li_hist_delete(struct dccp_li_hist *hist);
  24. struct dccp_li_hist_entry {
  25. struct list_head dccplih_node;
  26. u64 dccplih_seqno:48,
  27. dccplih_win_count:4;
  28. u32 dccplih_interval;
  29. };
  30. static inline struct dccp_li_hist_entry *
  31. dccp_li_hist_entry_new(struct dccp_li_hist *hist,
  32. const gfp_t prio)
  33. {
  34. return kmem_cache_alloc(hist->dccplih_slab, prio);
  35. }
  36. static inline void dccp_li_hist_entry_delete(struct dccp_li_hist *hist,
  37. struct dccp_li_hist_entry *entry)
  38. {
  39. if (entry != NULL)
  40. kmem_cache_free(hist->dccplih_slab, entry);
  41. }
  42. extern void dccp_li_hist_purge(struct dccp_li_hist *hist,
  43. struct list_head *list);
  44. extern u32 dccp_li_hist_calc_i_mean(struct list_head *list);
  45. extern int dccp_li_hist_interval_new(struct dccp_li_hist *hist,
  46. struct list_head *list, const u64 seq_loss, const u8 win_loss);
  47. #endif /* _DCCP_LI_HIST_ */