ring_buffer.c 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /* Copyright (C) 2007-2013 B.A.T.M.A.N. contributors:
  2. *
  3. * Marek Lindner
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of version 2 of the GNU General Public
  7. * License as published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful, but
  10. * WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  17. * 02110-1301, USA
  18. */
  19. #include "main.h"
  20. #include "ring_buffer.h"
  21. void batadv_ring_buffer_set(uint8_t lq_recv[], uint8_t *lq_index,
  22. uint8_t value)
  23. {
  24. lq_recv[*lq_index] = value;
  25. *lq_index = (*lq_index + 1) % BATADV_TQ_GLOBAL_WINDOW_SIZE;
  26. }
  27. uint8_t batadv_ring_buffer_avg(const uint8_t lq_recv[])
  28. {
  29. const uint8_t *ptr;
  30. uint16_t count = 0, i = 0, sum = 0;
  31. ptr = lq_recv;
  32. while (i < BATADV_TQ_GLOBAL_WINDOW_SIZE) {
  33. if (*ptr != 0) {
  34. count++;
  35. sum += *ptr;
  36. }
  37. i++;
  38. ptr++;
  39. }
  40. if (count == 0)
  41. return 0;
  42. return (uint8_t)(sum / count);
  43. }