X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavutil%2Fsamplefmt.c;h=102376ae38d9a79c1e6ec7c7b80838077a5f5940;hb=b9141aa346b736adffd27e1a98bd12aa7b628a8f;hp=2e0aa98f582e3a26b4256d714e15503680ff948c;hpb=0109a09dc3850eb5dbff84a7bb50eb252a5a8f22;p=ffmpeg diff --git a/libavutil/samplefmt.c b/libavutil/samplefmt.c index 2e0aa98f582..102376ae38d 100644 --- a/libavutil/samplefmt.c +++ b/libavutil/samplefmt.c @@ -16,6 +16,7 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ +#include "common.h" #include "samplefmt.h" #include @@ -124,8 +125,10 @@ int av_samples_get_buffer_size(int *linesize, int nb_channels, int nb_samples, return AVERROR(EINVAL); /* auto-select alignment if not specified */ - if (!align) - align = 32; + if (!align) { + align = 1; + nb_samples = FFALIGN(nb_samples, 32); + } /* check for integer overflow */ if (nb_channels > INT_MAX / align || @@ -141,7 +144,7 @@ int av_samples_get_buffer_size(int *linesize, int nb_channels, int nb_samples, } int av_samples_fill_arrays(uint8_t **audio_data, int *linesize, - uint8_t *buf, int nb_channels, int nb_samples, + const uint8_t *buf, int nb_channels, int nb_samples, enum AVSampleFormat sample_fmt, int align) { int ch, planar, buf_size, line_size; @@ -183,3 +186,41 @@ int av_samples_alloc(uint8_t **audio_data, int *linesize, int nb_channels, } return 0; } + +int av_samples_copy(uint8_t **dst, uint8_t * const *src, int dst_offset, + int src_offset, int nb_samples, int nb_channels, + enum AVSampleFormat sample_fmt) +{ + int planar = av_sample_fmt_is_planar(sample_fmt); + int planes = planar ? nb_channels : 1; + int block_align = av_get_bytes_per_sample(sample_fmt) * (planar ? 1 : nb_channels); + int data_size = nb_samples * block_align; + int i; + + dst_offset *= block_align; + src_offset *= block_align; + + for (i = 0; i < planes; i++) + memcpy(dst[i] + dst_offset, src[i] + src_offset, data_size); + + return 0; +} + +int av_samples_set_silence(uint8_t **audio_data, int offset, int nb_samples, + int nb_channels, enum AVSampleFormat sample_fmt) +{ + int planar = av_sample_fmt_is_planar(sample_fmt); + int planes = planar ? nb_channels : 1; + int block_align = av_get_bytes_per_sample(sample_fmt) * (planar ? 1 : nb_channels); + int data_size = nb_samples * block_align; + int fill_char = (sample_fmt == AV_SAMPLE_FMT_U8 || + sample_fmt == AV_SAMPLE_FMT_U8P) ? 0x80 : 0x00; + int i; + + offset *= block_align; + + for (i = 0; i < planes; i++) + memset(audio_data[i] + offset, fill_char, data_size); + + return 0; +}