ringbuffer.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. #include "ringbuffer.h"
  2. /**
  3. * @file
  4. * Implementation of ring buffer functions.
  5. */
  6. void ring_buffer_init(ring_buffer_t *buffer, char *buf, size_t buf_size) {
  7. RING_BUFFER_ASSERT(RING_BUFFER_IS_POWER_OF_TWO(buf_size) == 1);
  8. buffer->buffer = buf;
  9. buffer->buffer_mask = buf_size - 1;
  10. buffer->tail_index = 0;
  11. buffer->head_index = 0;
  12. }
  13. void ring_buffer_queue(ring_buffer_t *buffer, char data) {
  14. /* Is buffer full? */
  15. if(ring_buffer_is_full(buffer)) {
  16. /* Is going to overwrite the oldest byte */
  17. /* Increase tail index */
  18. buffer->tail_index = ((buffer->tail_index + 1) & RING_BUFFER_MASK(buffer));
  19. }
  20. /* Place data in buffer */
  21. buffer->buffer[buffer->head_index] = data;
  22. buffer->head_index = ((buffer->head_index + 1) & RING_BUFFER_MASK(buffer));
  23. }
  24. void ring_buffer_queue_arr(ring_buffer_t *buffer, const char *data, ring_buffer_size_t size) {
  25. /* Add bytes; one by one */
  26. ring_buffer_size_t i;
  27. for(i = 0; i < size; i++) {
  28. ring_buffer_queue(buffer, data[i]);
  29. }
  30. }
  31. uint8_t ring_buffer_dequeue(ring_buffer_t *buffer, char *data) {
  32. if(ring_buffer_is_empty(buffer)) {
  33. /* No items */
  34. return 0;
  35. }
  36. *data = buffer->buffer[buffer->tail_index];
  37. buffer->tail_index = ((buffer->tail_index + 1) & RING_BUFFER_MASK(buffer));
  38. return 1;
  39. }
  40. ring_buffer_size_t ring_buffer_dequeue_arr(ring_buffer_t *buffer, char *data, ring_buffer_size_t len) {
  41. if(ring_buffer_is_empty(buffer)) {
  42. /* No items */
  43. return 0;
  44. }
  45. char *data_ptr = data;
  46. ring_buffer_size_t cnt = 0;
  47. while((cnt < len) && ring_buffer_dequeue(buffer, data_ptr)) {
  48. cnt++;
  49. data_ptr++;
  50. }
  51. return cnt;
  52. }
  53. uint8_t ring_buffer_peek(ring_buffer_t *buffer, char *data, ring_buffer_size_t index) {
  54. if(index >= ring_buffer_num_items(buffer)) {
  55. /* No items at index */
  56. return 0;
  57. }
  58. /* Add index to pointer */
  59. ring_buffer_size_t data_index = ((buffer->tail_index + index) & RING_BUFFER_MASK(buffer));
  60. *data = buffer->buffer[data_index];
  61. return 1;
  62. }
  63. extern inline uint8_t ring_buffer_is_empty(ring_buffer_t *buffer);
  64. extern inline uint8_t ring_buffer_is_full(ring_buffer_t *buffer);
  65. extern inline ring_buffer_size_t ring_buffer_num_items(ring_buffer_t *buffer);
  66. #if 0 //测试函数
  67. #include <stdio.h>
  68. int main()
  69. {
  70. ring_buffer_t buff;
  71. uint8_t buff_data[8]={0};
  72. ring_buffer_init(&buff, buff_data, sizeof(buff_data)); //环形大小要求是2的幂
  73. printf("初始化长度: %d\r\n", buff.buffer_mask);
  74. ring_buffer_queue_arr(&buff, "0123456789", 8);
  75. printf("写入%2d: %s\r\n", 10, buff_data);
  76. printf("当前长度: %d, 剩余长度: %d\r\n", ring_buffer_num_items(&buff), buff.buffer_mask-ring_buffer_num_items(&buff));
  77. uint8_t data[8]={0}; /* Application working data */
  78. ring_buffer_size_t len = ring_buffer_dequeue_arr(&buff, data, sizeof(data));
  79. printf("读取%2d: %s\r\n", len, data);
  80. printf("当前长度: %d, 剩余长度: %d\r\n", ring_buffer_num_items(&buff), buff.buffer_mask-ring_buffer_num_items(&buff));
  81. return 0;
  82. }
  83. #endif