ringblk_buf.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /*
  2. * Copyright (c) 2006-2018, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-08-25 armink the first version
  9. */
  10. #ifndef _RINGBLK_BUF_H_
  11. #define _RINGBLK_BUF_H_
  12. /*
  13. * Introduction:
  14. * The rbb is the ring buffer which is composed with many blocks. It is different from the ring buffer.
  15. * The ring buffer is only composed with chars. The rbb put and get supported zero copies. So the rbb
  16. * is very suitable for put block and get block by a certain order. Such as DMA block transmit,
  17. * communicate frame send/recv, and so on.
  18. */
  19. #ifdef __cplusplus
  20. extern "C" {
  21. #endif
  22. enum rt_rbb_status
  23. {
  24. /* unused status when first initialize or after blk_free() */
  25. RT_RBB_BLK_UNUSED,
  26. /* initialized status after blk_alloc() */
  27. RT_RBB_BLK_INITED,
  28. /* put status after blk_put() */
  29. RT_RBB_BLK_PUT,
  30. /* get status after blk_get() */
  31. RT_RBB_BLK_GET,
  32. };
  33. typedef enum rt_rbb_status rt_rbb_status_t;
  34. /**
  35. * the block of rbb
  36. */
  37. struct rt_rbb_blk
  38. {
  39. rt_rbb_status_t status :8;
  40. /* less then 2^24 */
  41. rt_size_t size :24;
  42. rt_uint8_t *buf;
  43. rt_slist_t list;
  44. };
  45. typedef struct rt_rbb_blk *rt_rbb_blk_t;
  46. /**
  47. * Rbb block queue: the blocks (from block1->buf to blockn->buf) memory which on this queue is continuous.
  48. */
  49. struct rt_rbb_blk_queue
  50. {
  51. rt_rbb_blk_t blocks;
  52. rt_size_t blk_num;
  53. };
  54. typedef struct rt_rbb_blk_queue *rt_rbb_blk_queue_t;
  55. /**
  56. * ring block buffer
  57. */
  58. struct rt_rbb
  59. {
  60. rt_uint8_t *buf;
  61. rt_size_t buf_size;
  62. /* all of blocks */
  63. rt_rbb_blk_t blk_set;
  64. rt_size_t blk_max_num;
  65. /* saved the initialized and put status blocks */
  66. rt_slist_t blk_list;
  67. };
  68. typedef struct rt_rbb *rt_rbb_t;
  69. /* rbb (ring block buffer) API */
  70. void rt_rbb_init(rt_rbb_t rbb, rt_uint8_t *buf, rt_size_t buf_size, rt_rbb_blk_t block_set, rt_size_t blk_max_num);
  71. rt_rbb_t rt_rbb_create(rt_size_t buf_size, rt_size_t blk_max_num);
  72. void rt_rbb_destroy(rt_rbb_t rbb);
  73. rt_size_t rt_rbb_get_buf_size(rt_rbb_t rbb);
  74. /* rbb block API */
  75. rt_rbb_blk_t rt_rbb_blk_alloc(rt_rbb_t rbb, rt_size_t blk_size);
  76. void rt_rbb_blk_put(rt_rbb_blk_t block);
  77. rt_rbb_blk_t rt_rbb_blk_get(rt_rbb_t rbb);
  78. void rt_rbb_blk_free(rt_rbb_t rbb, rt_rbb_blk_t block);
  79. /* rbb block queue API */
  80. rt_size_t rt_rbb_blk_queue_get(rt_rbb_t rbb, rt_size_t queue_data_len, rt_rbb_blk_queue_t blk_queue);
  81. rt_size_t rt_rbb_blk_queue_len(rt_rbb_blk_queue_t blk_queue);
  82. rt_uint8_t *rt_rbb_blk_queue_buf(rt_rbb_blk_queue_t blk_queue);
  83. void rt_rbb_blk_queue_free(rt_rbb_t rbb, rt_rbb_blk_queue_t blk_queue);
  84. rt_size_t rt_rbb_next_blk_queue_len(rt_rbb_t rbb);
  85. #ifdef __cplusplus
  86. }
  87. #endif
  88. #endif /* _RINGBLK_BUF_H_ */