token_bucket.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /* Copyright (c) 2018, The Tor Project, Inc. */
  2. /* See LICENSE for licensing information */
  3. /**
  4. * \file token_bucket_rw.h
  5. * \brief Headers for token_bucket_rw.c
  6. **/
  7. #ifndef TOR_TOKEN_BUCKET_H
  8. #define TOR_TOKEN_BUCKET_H
  9. #include "torint.h"
  10. /** Largest allowable burst value for a token buffer. */
  11. #define TOKEN_BUCKET_MAX_BURST INT32_MAX
  12. /** A generic token buffer configuration: determines the number of tokens
  13. * added to the bucket in each time unit (the "rate"), and the maximum number
  14. * of tokens in the bucket (the "burst") */
  15. typedef struct token_bucket_cfg_t {
  16. uint32_t rate;
  17. int32_t burst;
  18. } token_bucket_cfg_t;
  19. /** A raw token bucket, decoupled from its configuration and timestamp. */
  20. typedef struct token_bucket_raw_t {
  21. int32_t bucket;
  22. } token_bucket_raw_t;
  23. void token_bucket_cfg_init(token_bucket_cfg_t *cfg,
  24. uint32_t rate,
  25. uint32_t burst);
  26. void token_bucket_raw_adjust(token_bucket_raw_t *bucket,
  27. const token_bucket_cfg_t *cfg);
  28. void token_bucket_raw_reset(token_bucket_raw_t *bucket,
  29. const token_bucket_cfg_t *cfg);
  30. int token_bucket_raw_dec(token_bucket_raw_t *bucket,
  31. ssize_t n);
  32. int token_bucket_raw_refill_steps(token_bucket_raw_t *bucket,
  33. const token_bucket_cfg_t *cfg,
  34. const uint32_t elapsed_steps);
  35. static inline size_t token_bucket_raw_get(const token_bucket_raw_t *bucket);
  36. /** Return the current number of bytes set in a token bucket. */
  37. static inline size_t
  38. token_bucket_raw_get(const token_bucket_raw_t *bucket)
  39. {
  40. return bucket->bucket >= 0 ? bucket->bucket : 0;
  41. }
  42. /** A convenience type containing all the pieces needed for a coupled
  43. * read-bucket and write-bucket that have the same rate limit, and which use
  44. * "timestamp units" (see compat_time.h) for their time. */
  45. typedef struct token_bucket_rw_t {
  46. token_bucket_cfg_t cfg;
  47. token_bucket_raw_t read_bucket;
  48. token_bucket_raw_t write_bucket;
  49. uint32_t last_refilled_at_timestamp;
  50. } token_bucket_rw_t;
  51. void token_bucket_rw_init(token_bucket_rw_t *bucket,
  52. uint32_t rate,
  53. uint32_t burst,
  54. uint32_t now_ts);
  55. void token_bucket_rw_adjust(token_bucket_rw_t *bucket,
  56. uint32_t rate, uint32_t burst);
  57. void token_bucket_rw_reset(token_bucket_rw_t *bucket,
  58. uint32_t now_ts);
  59. #define TB_READ 1
  60. #define TB_WRITE 2
  61. int token_bucket_rw_refill(token_bucket_rw_t *bucket,
  62. uint32_t now_ts);
  63. int token_bucket_rw_dec_read(token_bucket_rw_t *bucket,
  64. ssize_t n);
  65. int token_bucket_rw_dec_write(token_bucket_rw_t *bucket,
  66. ssize_t n);
  67. void token_bucket_rw_dec(token_bucket_rw_t *bucket,
  68. ssize_t n_read, ssize_t n_written);
  69. static inline size_t token_bucket_rw_get_read(const token_bucket_rw_t *bucket);
  70. static inline size_t
  71. token_bucket_rw_get_read(const token_bucket_rw_t *bucket)
  72. {
  73. return token_bucket_raw_get(&bucket->read_bucket);
  74. }
  75. static inline size_t token_bucket_rw_get_write(
  76. const token_bucket_rw_t *bucket);
  77. static inline size_t
  78. token_bucket_rw_get_write(const token_bucket_rw_t *bucket)
  79. {
  80. return token_bucket_raw_get(&bucket->write_bucket);
  81. }
  82. #ifdef TOKEN_BUCKET_PRIVATE
  83. /* To avoid making the rates too small, we consider units of "steps",
  84. * where a "step" is defined as this many timestamp ticks. Keep this
  85. * a power of two if you can. */
  86. #define TICKS_PER_STEP 16
  87. #endif
  88. #endif /* TOR_TOKEN_BUCKET_H */