test/run_filter: ensure that partial frames will not get passed to the filter
This commit is contained in:
parent
b4dc2c07d5
commit
1678a6eb59
@ -27,6 +27,7 @@
|
|||||||
#include "filter/Prepared.hxx"
|
#include "filter/Prepared.hxx"
|
||||||
#include "pcm/Volume.hxx"
|
#include "pcm/Volume.hxx"
|
||||||
#include "mixer/MixerControl.hxx"
|
#include "mixer/MixerControl.hxx"
|
||||||
|
#include "system/Error.hxx"
|
||||||
#include "util/ConstBuffer.hxx"
|
#include "util/ConstBuffer.hxx"
|
||||||
#include "util/StringBuffer.hxx"
|
#include "util/StringBuffer.hxx"
|
||||||
#include "util/RuntimeError.hxx"
|
#include "util/RuntimeError.hxx"
|
||||||
@ -60,6 +61,50 @@ LoadFilter(const ConfigData &config, const char *name)
|
|||||||
return filter_configured_new(*param);
|
return filter_configured_new(*param);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static size_t
|
||||||
|
ReadOrThrow(int fd, void *buffer, size_t size)
|
||||||
|
{
|
||||||
|
auto nbytes = read(fd, buffer, size);
|
||||||
|
if (nbytes < 0)
|
||||||
|
throw MakeErrno("Read failed");
|
||||||
|
|
||||||
|
return nbytes;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
FullRead(int fd, void *_buffer, size_t size)
|
||||||
|
{
|
||||||
|
auto buffer = (uint8_t *)_buffer;
|
||||||
|
|
||||||
|
while (size > 0) {
|
||||||
|
size_t nbytes = ReadOrThrow(fd, buffer, size);
|
||||||
|
if (nbytes == 0)
|
||||||
|
throw std::runtime_error("Premature end of input");
|
||||||
|
|
||||||
|
buffer += nbytes;
|
||||||
|
size -= nbytes;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static size_t
|
||||||
|
ReadFrames(int fd, void *_buffer, size_t size, size_t frame_size)
|
||||||
|
{
|
||||||
|
auto buffer = (uint8_t *)_buffer;
|
||||||
|
|
||||||
|
size = (size / frame_size) * frame_size;
|
||||||
|
|
||||||
|
size_t nbytes = ReadOrThrow(fd, buffer, size);
|
||||||
|
|
||||||
|
const size_t modulo = nbytes % frame_size;
|
||||||
|
if (modulo > 0) {
|
||||||
|
size_t rest = frame_size - modulo;
|
||||||
|
FullRead(fd, buffer + nbytes, rest);
|
||||||
|
nbytes += rest;
|
||||||
|
}
|
||||||
|
|
||||||
|
return nbytes;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
try {
|
try {
|
||||||
if (argc < 3 || argc > 4) {
|
if (argc < 3 || argc > 4) {
|
||||||
@ -80,6 +125,8 @@ try {
|
|||||||
if (argc > 3)
|
if (argc > 3)
|
||||||
audio_format = ParseAudioFormat(argv[3], false);
|
audio_format = ParseAudioFormat(argv[3], false);
|
||||||
|
|
||||||
|
const size_t in_frame_size = audio_format.GetFrameSize();
|
||||||
|
|
||||||
/* initialize the filter */
|
/* initialize the filter */
|
||||||
|
|
||||||
auto prepared_filter = LoadFilter(config, argv[2]);
|
auto prepared_filter = LoadFilter(config, argv[2]);
|
||||||
@ -98,10 +145,9 @@ try {
|
|||||||
while (true) {
|
while (true) {
|
||||||
char buffer[4096];
|
char buffer[4096];
|
||||||
|
|
||||||
ssize_t nbytes;
|
ssize_t nbytes = ReadFrames(0, buffer, sizeof(buffer),
|
||||||
|
in_frame_size);
|
||||||
nbytes = read(0, buffer, sizeof(buffer));
|
if (nbytes == 0)
|
||||||
if (nbytes <= 0)
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
auto dest = filter->FilterPCM({(const void *)buffer, (size_t)nbytes});
|
auto dest = filter->FilterPCM({(const void *)buffer, (size_t)nbytes});
|
||||||
|
Loading…
Reference in New Issue
Block a user