Commit 378c5d87 authored by reimar's avatar reimar

Do D10 AES3 audio conversion in-place instead of using a large on-stack buffer.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@20567 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent f1c5c842
...@@ -214,18 +214,17 @@ static int mxf_get_stream_index(AVFormatContext *s, KLVPacket *klv) ...@@ -214,18 +214,17 @@ static int mxf_get_stream_index(AVFormatContext *s, KLVPacket *klv)
/* XXX: use AVBitStreamFilter */ /* XXX: use AVBitStreamFilter */
static int mxf_get_d10_aes3_packet(ByteIOContext *pb, AVStream *st, AVPacket *pkt, int64_t length) static int mxf_get_d10_aes3_packet(ByteIOContext *pb, AVStream *st, AVPacket *pkt, int64_t length)
{ {
uint8_t buffer[61444];
const uint8_t *buf_ptr, *end_ptr; const uint8_t *buf_ptr, *end_ptr;
uint8_t *data_ptr; uint8_t *data_ptr;
int i; int i;
if (length > 61444) /* worst case PAL 1920 samples 8 channels */ if (length > 61444) /* worst case PAL 1920 samples 8 channels */
return -1; return -1;
get_buffer(pb, buffer, length);
av_new_packet(pkt, length); av_new_packet(pkt, length);
get_buffer(pb, pkt->data, length);
data_ptr = pkt->data; data_ptr = pkt->data;
end_ptr = buffer + length; end_ptr = pkt->data + length;
buf_ptr = buffer + 4; /* skip SMPTE 331M header */ buf_ptr = pkt->data + 4; /* skip SMPTE 331M header */
for (; buf_ptr < end_ptr; ) { for (; buf_ptr < end_ptr; ) {
for (i = 0; i < st->codec->channels; i++) { for (i = 0; i < st->codec->channels; i++) {
uint32_t sample = bytestream_get_le32(&buf_ptr); uint32_t sample = bytestream_get_le32(&buf_ptr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment