tfrc.h 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. #ifndef _TFRC_H_
  2. #define _TFRC_H_
  3. /*
  4. * Copyright (c) 2007 The University of Aberdeen, Scotland, UK
  5. * Copyright (c) 2005-6 The University of Waikato, Hamilton, New Zealand.
  6. * Copyright (c) 2005-6 Ian McDonald <ian.mcdonald@jandi.co.nz>
  7. * Copyright (c) 2005 Arnaldo Carvalho de Melo <acme@conectiva.com.br>
  8. * Copyright (c) 2003 Nils-Erik Mattsson, Joacim Haggmark, Magnus Erixzon
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or
  13. * (at your option) any later version.
  14. */
  15. #include <linux/types.h>
  16. #include <linux/math64.h>
  17. #include "../../dccp.h"
  18. /* internal includes that this library exports: */
  19. #include "loss_interval.h"
  20. #include "packet_history.h"
  21. #ifdef CONFIG_IP_DCCP_TFRC_DEBUG
  22. #define tfrc_pr_debug(format, a...) DCCP_PR_DEBUG(tfrc_debug, format, ##a)
  23. #else
  24. #define tfrc_pr_debug(format, a...)
  25. #endif
  26. /* integer-arithmetic divisions of type (a * 1000000)/b */
  27. static inline u64 scaled_div(u64 a, u64 b)
  28. {
  29. BUG_ON(b == 0);
  30. return div64_u64(a * 1000000, b);
  31. }
  32. static inline u32 scaled_div32(u64 a, u64 b)
  33. {
  34. u64 result = scaled_div(a, b);
  35. if (result > UINT_MAX) {
  36. DCCP_CRIT("Overflow: %llu/%llu > UINT_MAX",
  37. (unsigned long long)a, (unsigned long long)b);
  38. return UINT_MAX;
  39. }
  40. return result;
  41. }
  42. /**
  43. * tfrc_ewma - Exponentially weighted moving average
  44. * @weight: Weight to be used as damping factor, in units of 1/10
  45. */
  46. static inline u32 tfrc_ewma(const u32 avg, const u32 newval, const u8 weight)
  47. {
  48. return avg ? (weight * avg + (10 - weight) * newval) / 10 : newval;
  49. }
  50. u32 tfrc_calc_x(u16 s, u32 R, u32 p);
  51. u32 tfrc_calc_x_reverse_lookup(u32 fvalue);
  52. u32 tfrc_invert_loss_event_rate(u32 loss_event_rate);
  53. int tfrc_tx_packet_history_init(void);
  54. void tfrc_tx_packet_history_exit(void);
  55. int tfrc_rx_packet_history_init(void);
  56. void tfrc_rx_packet_history_exit(void);
  57. int tfrc_li_init(void);
  58. void tfrc_li_exit(void);
  59. #ifdef CONFIG_IP_DCCP_TFRC_LIB
  60. int tfrc_lib_init(void);
  61. void tfrc_lib_exit(void);
  62. #else
  63. #define tfrc_lib_init() (0)
  64. #define tfrc_lib_exit()
  65. #endif
  66. #endif /* _TFRC_H_ */