xref: /aosp_15_r20/external/webrtc/common_audio/ring_buffer.h (revision d9f758449e529ab9291ac668be2861e7a55c2422)
1*d9f75844SAndroid Build Coastguard Worker /*
2*d9f75844SAndroid Build Coastguard Worker  *  Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
3*d9f75844SAndroid Build Coastguard Worker  *
4*d9f75844SAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker  */
10*d9f75844SAndroid Build Coastguard Worker 
11*d9f75844SAndroid Build Coastguard Worker // A ring buffer to hold arbitrary data. Provides no thread safety. Unless
12*d9f75844SAndroid Build Coastguard Worker // otherwise specified, functions return 0 on success and -1 on error.
13*d9f75844SAndroid Build Coastguard Worker 
14*d9f75844SAndroid Build Coastguard Worker #ifndef COMMON_AUDIO_RING_BUFFER_H_
15*d9f75844SAndroid Build Coastguard Worker #define COMMON_AUDIO_RING_BUFFER_H_
16*d9f75844SAndroid Build Coastguard Worker 
17*d9f75844SAndroid Build Coastguard Worker // TODO(alessiob): Used by AEC, AECm and AudioRingBuffer. Remove when possible.
18*d9f75844SAndroid Build Coastguard Worker 
19*d9f75844SAndroid Build Coastguard Worker #ifdef __cplusplus
20*d9f75844SAndroid Build Coastguard Worker extern "C" {
21*d9f75844SAndroid Build Coastguard Worker #endif
22*d9f75844SAndroid Build Coastguard Worker 
23*d9f75844SAndroid Build Coastguard Worker #include <stddef.h>  // size_t
24*d9f75844SAndroid Build Coastguard Worker 
25*d9f75844SAndroid Build Coastguard Worker enum Wrap { SAME_WRAP, DIFF_WRAP };
26*d9f75844SAndroid Build Coastguard Worker 
27*d9f75844SAndroid Build Coastguard Worker typedef struct RingBuffer {
28*d9f75844SAndroid Build Coastguard Worker   size_t read_pos;
29*d9f75844SAndroid Build Coastguard Worker   size_t write_pos;
30*d9f75844SAndroid Build Coastguard Worker   size_t element_count;
31*d9f75844SAndroid Build Coastguard Worker   size_t element_size;
32*d9f75844SAndroid Build Coastguard Worker   enum Wrap rw_wrap;
33*d9f75844SAndroid Build Coastguard Worker   char* data;
34*d9f75844SAndroid Build Coastguard Worker } RingBuffer;
35*d9f75844SAndroid Build Coastguard Worker 
36*d9f75844SAndroid Build Coastguard Worker // Creates and initializes the buffer. Returns null on failure.
37*d9f75844SAndroid Build Coastguard Worker RingBuffer* WebRtc_CreateBuffer(size_t element_count, size_t element_size);
38*d9f75844SAndroid Build Coastguard Worker void WebRtc_InitBuffer(RingBuffer* handle);
39*d9f75844SAndroid Build Coastguard Worker void WebRtc_FreeBuffer(void* handle);
40*d9f75844SAndroid Build Coastguard Worker 
41*d9f75844SAndroid Build Coastguard Worker // Reads data from the buffer. Returns the number of elements that were read.
42*d9f75844SAndroid Build Coastguard Worker // The `data_ptr` will point to the address where the read data is located.
43*d9f75844SAndroid Build Coastguard Worker // If no data can be read, `data_ptr` is set to `NULL`. If all data can be read
44*d9f75844SAndroid Build Coastguard Worker // without buffer wrap around then `data_ptr` will point to the location in the
45*d9f75844SAndroid Build Coastguard Worker // buffer. Otherwise, the data will be copied to `data` (memory allocation done
46*d9f75844SAndroid Build Coastguard Worker // by the user) and `data_ptr` points to the address of `data`. `data_ptr` is
47*d9f75844SAndroid Build Coastguard Worker // only guaranteed to be valid until the next call to WebRtc_WriteBuffer().
48*d9f75844SAndroid Build Coastguard Worker //
49*d9f75844SAndroid Build Coastguard Worker // To force a copying to `data`, pass a null `data_ptr`.
50*d9f75844SAndroid Build Coastguard Worker //
51*d9f75844SAndroid Build Coastguard Worker // Returns number of elements read.
52*d9f75844SAndroid Build Coastguard Worker size_t WebRtc_ReadBuffer(RingBuffer* handle,
53*d9f75844SAndroid Build Coastguard Worker                          void** data_ptr,
54*d9f75844SAndroid Build Coastguard Worker                          void* data,
55*d9f75844SAndroid Build Coastguard Worker                          size_t element_count);
56*d9f75844SAndroid Build Coastguard Worker 
57*d9f75844SAndroid Build Coastguard Worker // Writes `data` to buffer and returns the number of elements written.
58*d9f75844SAndroid Build Coastguard Worker size_t WebRtc_WriteBuffer(RingBuffer* handle,
59*d9f75844SAndroid Build Coastguard Worker                           const void* data,
60*d9f75844SAndroid Build Coastguard Worker                           size_t element_count);
61*d9f75844SAndroid Build Coastguard Worker 
62*d9f75844SAndroid Build Coastguard Worker // Moves the buffer read position and returns the number of elements moved.
63*d9f75844SAndroid Build Coastguard Worker // Positive `element_count` moves the read position towards the write position,
64*d9f75844SAndroid Build Coastguard Worker // that is, flushing the buffer. Negative `element_count` moves the read
65*d9f75844SAndroid Build Coastguard Worker // position away from the the write position, that is, stuffing the buffer.
66*d9f75844SAndroid Build Coastguard Worker // Returns number of elements moved.
67*d9f75844SAndroid Build Coastguard Worker int WebRtc_MoveReadPtr(RingBuffer* handle, int element_count);
68*d9f75844SAndroid Build Coastguard Worker 
69*d9f75844SAndroid Build Coastguard Worker // Returns number of available elements to read.
70*d9f75844SAndroid Build Coastguard Worker size_t WebRtc_available_read(const RingBuffer* handle);
71*d9f75844SAndroid Build Coastguard Worker 
72*d9f75844SAndroid Build Coastguard Worker // Returns number of available elements for write.
73*d9f75844SAndroid Build Coastguard Worker size_t WebRtc_available_write(const RingBuffer* handle);
74*d9f75844SAndroid Build Coastguard Worker 
75*d9f75844SAndroid Build Coastguard Worker #ifdef __cplusplus
76*d9f75844SAndroid Build Coastguard Worker }
77*d9f75844SAndroid Build Coastguard Worker #endif
78*d9f75844SAndroid Build Coastguard Worker 
79*d9f75844SAndroid Build Coastguard Worker #endif  // COMMON_AUDIO_RING_BUFFER_H_
80