From 75b213ed5425c7ca8be92c88d96effc73d0d9bbc Mon Sep 17 00:00:00 2001 From: Michael Niedermayer Date: Mon, 5 Mar 2007 17:54:49 +0000 Subject: prevent audio packets from being fragmented, wmp mac doesnt seem to like that and microshitty also doesnt seem to ever fragment them Originally committed as revision 8265 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavformat/asf-enc.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'libavformat/asf-enc.c') diff --git a/libavformat/asf-enc.c b/libavformat/asf-enc.c index 6c0ec59be8..7e53ffdd00 100644 --- a/libavformat/asf-enc.c +++ b/libavformat/asf-enc.c @@ -648,6 +648,7 @@ static void put_payload_header( static void put_frame( AVFormatContext *s, ASFStream *stream, + AVStream *avst, int timestamp, const uint8_t *buf, int m_obj_size, @@ -677,6 +678,11 @@ static void put_frame( frag_len1 = asf->packet_size_left - PAYLOAD_HEADER_SIZE_MULTIPLE_PAYLOADS - PACKET_HEADER_MIN_SIZE - 1; asf->packet_timestamp_start = timestamp; + + if(frag_len1 < payload_len && avst->codec->codec_type == CODEC_TYPE_AUDIO){ + flush_packet(s); + continue; + } } if (frag_len1 > 0) { if (payload_len > frag_len1) @@ -731,7 +737,7 @@ static int asf_write_packet(AVFormatContext *s, AVPacket *pkt) asf->duration= FFMAX(asf->duration, duration); packet_st = asf->nb_packets; - put_frame(s, stream, pkt->dts, pkt->data, pkt->size, flags); + put_frame(s, stream, s->streams[pkt->stream_index], pkt->dts, pkt->data, pkt->size, flags); /* check index */ if ((!asf->is_streamed) && (flags & PKT_FLAG_KEY)) { -- cgit v1.2.3