tfrc.h 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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. extern bool tfrc_debug;
  23. #define tfrc_pr_debug(format, a...) DCCP_PR_DEBUG(tfrc_debug, format, ##a)
  24. #else
  25. #define tfrc_pr_debug(format, a...)
  26. #endif
  27. /* integer-arithmetic divisions of type (a * 1000000)/b */
  28. static inline u64 scaled_div(u64 a, u64 b)
  29. {
  30. BUG_ON(b == 0);
  31. return div64_u64(a * 1000000, b);
  32. }
  33. static inline u32 scaled_div32(u64 a, u64 b)
  34. {
  35. u64 result = scaled_div(a, b);
  36. if (result > UINT_MAX) {
  37. DCCP_CRIT("Overflow: %llu/%llu > UINT_MAX",
  38. (unsigned long long)a, (unsigned long long)b);
  39. return UINT_MAX;
  40. }
  41. return result;
  42. }
  43. /**
  44. * tfrc_ewma - Exponentially weighted moving average
  45. * @weight: Weight to be used as damping factor, in units of 1/10
  46. */
  47. static inline u32 tfrc_ewma(const u32 avg, const u32 newval, const u8 weight)
  48. {
  49. return avg ? (weight * avg + (10 - weight) * newval) / 10 : newval;
  50. }
  51. u32 tfrc_calc_x(u16 s, u32 R, u32 p);
  52. u32 tfrc_calc_x_reverse_lookup(u32 fvalue);
  53. u32 tfrc_invert_loss_event_rate(u32 loss_event_rate);
  54. int tfrc_tx_packet_history_init(void);
  55. void tfrc_tx_packet_history_exit(void);
  56. int tfrc_rx_packet_history_init(void);
  57. void tfrc_rx_packet_history_exit(void);
  58. int tfrc_li_init(void);
  59. void tfrc_li_exit(void);
  60. #ifdef CONFIG_IP_DCCP_TFRC_LIB
  61. int tfrc_lib_init(void);
  62. void tfrc_lib_exit(void);
  63. #else
  64. #define tfrc_lib_init() (0)
  65. #define tfrc_lib_exit()
  66. #endif
  67. #endif /* _TFRC_H_ */