blob: 7e130224dc531c400c0a4d10ec6d1c5c7b3df7b0 [file] [edit]
/*
* This file is part of FFmpeg.
*
* FFmpeg is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* FFmpeg is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with FFmpeg; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include <errno.h>
#include <limits.h>
#include <stdio.h>
#include <string.h>
#include "libavutil/error.h"
#include "libavutil/mem.h"
#include "libavutil/samplefmt.h"
int main(void)
{
char buf[64];
/* av_get_sample_fmt_name and av_get_sample_fmt round-trip */
printf("Testing name/format round-trip\n");
for (int i = 0; i < AV_SAMPLE_FMT_NB; i++) {
const char *name = av_get_sample_fmt_name(i);
enum AVSampleFormat fmt = av_get_sample_fmt(name);
printf("%2d: name=%-5s roundtrip=%s\n", i, name, fmt == i ? "OK" : "FAIL");
}
/* boundary: NONE and out-of-range */
printf("NONE name: %s\n", av_get_sample_fmt_name(AV_SAMPLE_FMT_NONE) == NULL ? "(null)" : "?");
printf("NB name: %s\n", av_get_sample_fmt_name(AV_SAMPLE_FMT_NB) == NULL ? "(null)" : "?");
printf("unknown: %d\n", av_get_sample_fmt("nonexistent"));
/* av_get_bytes_per_sample */
printf("\nTesting av_get_bytes_per_sample()\n");
for (int i = 0; i < AV_SAMPLE_FMT_NB; i++)
printf("%s: %d\n", av_get_sample_fmt_name(i), av_get_bytes_per_sample(i));
printf("NONE: %d\n", av_get_bytes_per_sample(AV_SAMPLE_FMT_NONE));
/* av_sample_fmt_is_planar */
printf("\nTesting av_sample_fmt_is_planar()\n");
for (int i = 0; i < AV_SAMPLE_FMT_NB; i++)
printf("%s: %d\n", av_get_sample_fmt_name(i), av_sample_fmt_is_planar(i));
printf("NONE: %d\n", av_sample_fmt_is_planar(AV_SAMPLE_FMT_NONE));
/* av_get_packed_sample_fmt and av_get_planar_sample_fmt */
printf("\nTesting packed/planar conversions\n");
for (int i = 0; i < AV_SAMPLE_FMT_NB; i++) {
enum AVSampleFormat packed = av_get_packed_sample_fmt(i);
enum AVSampleFormat planar = av_get_planar_sample_fmt(i);
printf("%s: packed=%-4s planar=%s\n",
av_get_sample_fmt_name(i),
av_get_sample_fmt_name(packed),
av_get_sample_fmt_name(planar));
}
/* av_get_alt_sample_fmt */
printf("\nTesting av_get_alt_sample_fmt()\n");
for (int i = 0; i < AV_SAMPLE_FMT_NB; i++) {
enum AVSampleFormat alt_packed = av_get_alt_sample_fmt(i, 0);
enum AVSampleFormat alt_planar = av_get_alt_sample_fmt(i, 1);
printf("%s: alt_packed=%-4s alt_planar=%s\n",
av_get_sample_fmt_name(i),
av_get_sample_fmt_name(alt_packed),
av_get_sample_fmt_name(alt_planar));
}
/* av_get_sample_fmt_string */
printf("\nTesting av_get_sample_fmt_string()\n");
av_get_sample_fmt_string(buf, sizeof(buf), -1);
printf("header: %s\n", buf);
for (int i = 0; i < AV_SAMPLE_FMT_NB; i++) {
av_get_sample_fmt_string(buf, sizeof(buf), i);
printf("%s\n", buf);
}
/* av_samples_get_buffer_size */
printf("\nTesting av_samples_get_buffer_size()\n");
{
int linesize;
printf("2ch 1024smp s16: %d\n",
av_samples_get_buffer_size(NULL, 2, 1024, AV_SAMPLE_FMT_S16, 1));
printf("2ch 1024smp s16p: %d\n",
av_samples_get_buffer_size(NULL, 2, 1024, AV_SAMPLE_FMT_S16P, 1));
printf("6ch 512smp s32: %d\n",
av_samples_get_buffer_size(NULL, 6, 512, AV_SAMPLE_FMT_S32, 1));
av_samples_get_buffer_size(&linesize, 2, 1024, AV_SAMPLE_FMT_S16, 0);
printf("linesize (2ch 1024smp s16 align=0): %d\n", linesize);
printf("0ch error: %d\n",
av_samples_get_buffer_size(NULL, 0, 1024, AV_SAMPLE_FMT_S16, 1) < 0);
}
/* av_samples_alloc and av_samples_fill_arrays */
printf("\nTesting av_samples_alloc()\n");
{
uint8_t *data[8] = { 0 };
int linesize, ret;
ret = av_samples_alloc(data, &linesize, 2, 1024, AV_SAMPLE_FMT_S16, 0);
printf("alloc 2ch s16: ret=%d linesize=%d data[0]=%s\n",
ret > 0, linesize, data[0] ? "set" : "null");
av_freep(&data[0]);
ret = av_samples_alloc(data, &linesize, 2, 1024, AV_SAMPLE_FMT_S16P, 0);
printf("alloc 2ch s16p: ret=%d linesize=%d data[0]=%s data[1]=%s\n",
ret > 0, linesize,
data[0] ? "set" : "null", data[1] ? "set" : "null");
av_freep(&data[0]);
}
/* av_samples_alloc_array_and_samples */
printf("\nTesting av_samples_alloc_array_and_samples()\n");
{
uint8_t **data = NULL;
int linesize, ret;
ret = av_samples_alloc_array_and_samples(&data, &linesize, 2, 1024,
AV_SAMPLE_FMT_S16P, 0);
printf("alloc_array 2ch s16p: ret=%d linesize=%d data[0]=%s data[1]=%s\n",
ret > 0, linesize,
data[0] ? "set" : "null", data[1] ? "set" : "null");
if (data)
av_freep(&data[0]);
av_freep(&data);
}
/* av_samples_copy */
printf("\nTesting av_samples_copy()\n");
{
uint8_t *src[1] = { 0 }, *dst[1] = { 0 };
int linesize;
av_samples_alloc(src, &linesize, 1, 4, AV_SAMPLE_FMT_S16, 1);
av_samples_alloc(dst, &linesize, 1, 4, AV_SAMPLE_FMT_S16, 1);
if (src[0] && dst[0]) {
memset(src[0], 0xAB, 8);
av_samples_copy(dst, src, 0, 0, 4, 1, AV_SAMPLE_FMT_S16);
printf("copy: %s\n", memcmp(src[0], dst[0], 8) == 0 ? "OK" : "FAIL");
}
av_freep(&src[0]);
av_freep(&dst[0]);
}
/* OOM paths via av_max_alloc */
printf("\nTesting OOM paths\n");
{
uint8_t *data[8] = { 0 };
uint8_t **array_data = NULL;
int linesize, ret;
av_max_alloc(1);
ret = av_samples_alloc(data, &linesize, 2, 1024, AV_SAMPLE_FMT_S16, 0);
printf("alloc OOM: ret=%d data[0]=%s\n",
ret == AVERROR(ENOMEM), data[0] ? "set" : "null");
ret = av_samples_alloc_array_and_samples(&array_data, &linesize, 2, 1024,
AV_SAMPLE_FMT_S16P, 0);
printf("alloc_array OOM: ret=%d data=%s\n",
ret == AVERROR(ENOMEM), array_data ? "set" : "null");
av_max_alloc(INT_MAX);
}
/* av_samples_set_silence */
printf("\nTesting av_samples_set_silence()\n");
{
uint8_t *data[1] = { 0 };
int linesize;
av_samples_alloc(data, &linesize, 1, 4, AV_SAMPLE_FMT_S16, 1);
if (data[0]) {
memset(data[0], 0xFF, 8);
av_samples_set_silence(data, 0, 4, 1, AV_SAMPLE_FMT_S16);
/* silence for s16 is zero */
int silent = 1;
for (int i = 0; i < 8; i++)
if (data[0][i] != 0) silent = 0;
printf("silence s16: %s\n", silent ? "OK" : "FAIL");
}
av_freep(&data[0]);
av_samples_alloc(data, &linesize, 1, 4, AV_SAMPLE_FMT_U8, 1);
if (data[0]) {
memset(data[0], 0xFF, 4);
av_samples_set_silence(data, 0, 4, 1, AV_SAMPLE_FMT_U8);
/* silence for u8 is 0x80 */
int silent = 1;
for (int i = 0; i < 4; i++)
if (data[0][i] != 0x80) silent = 0;
printf("silence u8: %s\n", silent ? "OK" : "FAIL");
}
av_freep(&data[0]);
}
return 0;
}