lib/alsa/PeriodBuffer: add API documentation

This commit is contained in:
Max Kellermann 2019-06-27 14:58:19 +02:00
parent 048990cd2f
commit 127b464c59

View File

@ -28,6 +28,17 @@
namespace Alsa {
/**
* A buffer which shall hold the audio data of one period. It is
* filled by the #AlsaOutput, and then submitted to ALSA via
* snd_pcm_writei(). After that, it is cleared and can be reused for
* the next period.
*
* It is used to keep track how much of the current period was written
* already. Some methods such as AlsaOutput::Drain() need to make
* sure that the current period is finished before snd_pcm_drain() can
* be called.
*/
class PeriodBuffer {
size_t capacity, head, tail;
@ -61,16 +72,32 @@ public:
return tail >= capacity;
}
/**
* Returns the tail of the buffer, i.e. where new data can be
* written. Call GetSpaceBytes() to find out how much may be
* copied to the returned pointer, and call AppendBytes() to
* commit the operation.
*/
uint8_t *GetTail() noexcept {
return buffer + tail;
}
/**
* Determine how much data can be appended at GetTail().
*
* @return the number of free bytes at the end of the buffer
* in bytes
*/
size_t GetSpaceBytes() const noexcept {
assert(tail <= capacity);
return capacity - tail;
}
/**
* After copying data to the pointer returned by GetTail(),
* this methods commits the operation.
*/
void AppendBytes(size_t n) noexcept {
assert(n <= capacity);
assert(tail <= capacity - n);
@ -78,6 +105,13 @@ public:
tail += n;
}
/**
* Fill the rest of this period with silence. We do this when
* the decoder misses its deadline and we don't have enough
* data.
*
* @param _silence one period worth of silence
*/
void FillWithSilence(const uint8_t *_silence,
const size_t frame_size) noexcept {
size_t partial_frame = tail % frame_size;
@ -92,10 +126,20 @@ public:
tail = capacity + partial_frame;
}
/**
* Returns the head of the buffer, i.e. where data can be
* read. Call GetFrames() to find out how much may be read
* from the returned pointer, and call ConsumeBytes() to
* commit the operation.
*/
const uint8_t *GetHead() const noexcept {
return buffer + head;
}
/**
* Determine how many frames are available for reading from
* GetHead().
*/
snd_pcm_uframes_t GetFrames(size_t frame_size) const noexcept {
return (tail - head) / frame_size;
}