[FFmpeg-cvslog] r18009 - in trunk/libavformat: rdt.c rm.h rmdec.c
rbultje
subversion
Mon Mar 16 13:57:49 CET 2009
Author: rbultje
Date: Mon Mar 16 13:57:49 2009
New Revision: 18009
Log:
Remove packet returning in ff_rm_parse_packet() if we're using the packet
cache, since this can already be accessed through ff_rm_retrieve_cache().
See "[PATCH] rmdec.c: remove cache access duplication" thread.
Modified:
trunk/libavformat/rdt.c
trunk/libavformat/rm.h
trunk/libavformat/rmdec.c
Modified: trunk/libavformat/rdt.c
==============================================================================
--- trunk/libavformat/rdt.c Mon Mar 16 13:56:22 2009 (r18008)
+++ trunk/libavformat/rdt.c Mon Mar 16 13:57:49 2009 (r18009)
@@ -312,14 +312,16 @@ rdt_parse_packet (AVFormatContext *ctx,
pos = url_ftell(&pb);
if (res < 0)
return res;
- rdt->audio_pkt_cnt = res;
- if (rdt->audio_pkt_cnt > 0 &&
- st->codec->codec_id == CODEC_ID_AAC) {
+ if (res > 0) {
+ if (st->codec->codec_id == CODEC_ID_AAC) {
memcpy (rdt->buffer, buf + pos, len - pos);
rdt->rmctx->pb = av_alloc_put_byte (rdt->buffer, len - pos, 0,
NULL, NULL, NULL, NULL);
+ }
+ goto get_cache;
}
} else {
+get_cache:
rdt->audio_pkt_cnt =
ff_rm_retrieve_cache (rdt->rmctx, rdt->rmctx->pb,
st, rdt->rmst[st->index], pkt);
Modified: trunk/libavformat/rm.h
==============================================================================
--- trunk/libavformat/rm.h Mon Mar 16 13:56:22 2009 (r18008)
+++ trunk/libavformat/rm.h Mon Mar 16 13:57:49 2009 (r18009)
@@ -64,9 +64,9 @@ int ff_rm_read_mdpr_codecdata (AVFormatC
* @param flags pointer to an integer containing the packet flags, may be
updated
* @param ts pointer to timestamp, may be updated
- * @return >=0 on success (where >0 indicates there are cached samples that
- * can be retrieved with subsequent calls to ff_rm_retrieve_cache()),
- * errno codes on error
+ * @return <0 on error, 0 if a packet was placed in the \p pkt pointer. A
+ * value >0 means that no data was placed in \p pkt, but that cached
+ * data is available by calling ff_rm_retrieve_cache().
*/
int ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
AVStream *st, RMStream *rst, int len,
Modified: trunk/libavformat/rmdec.c
==============================================================================
--- trunk/libavformat/rmdec.c Mon Mar 16 13:56:22 2009 (r18008)
+++ trunk/libavformat/rmdec.c Mon Mar 16 13:57:49 2009 (r18009)
@@ -627,16 +627,9 @@ ff_rm_parse_packet (AVFormatContext *s,
if (++(ast->sub_packet_cnt) < h)
return -1;
- else {
ast->sub_packet_cnt = 0;
rm->audio_stream_num = st->index;
- rm->audio_pkt_cnt = h * w / st->codec->block_align - 1;
- // Release first audio packet
- av_new_packet(pkt, st->codec->block_align);
- memcpy(pkt->data, ast->pkt.data, st->codec->block_align); //FIXME avoid this
- *timestamp = ast->audiotimestamp;
- *flags = 2; // Mark first packet as keyframe
- }
+ rm->audio_pkt_cnt = h * w / st->codec->block_align;
} else if (st->codec->codec_id == CODEC_ID_AAC) {
int x;
rm->audio_stream_num = st->index;
@@ -644,11 +637,10 @@ ff_rm_parse_packet (AVFormatContext *s,
if (ast->sub_packet_cnt) {
for (x = 0; x < ast->sub_packet_cnt; x++)
ast->sub_packet_lengths[x] = get_be16(pb);
- // Release first audio packet
- rm->audio_pkt_cnt = ast->sub_packet_cnt - 1;
- av_get_packet(pb, pkt, ast->sub_packet_lengths[0]);
- *flags = 2; // Mark first packet as keyframe
- }
+ rm->audio_pkt_cnt = ast->sub_packet_cnt;
+ ast->audiotimestamp = *timestamp;
+ } else
+ return -1;
} else {
av_get_packet(pb, pkt, len);
rm_ac3_swap_bytes(st, pkt);
More information about the ffmpeg-cvslog
mailing list