summaryrefslogtreecommitdiff
path: root/libavformat/rmdec.c
diff options
context:
space:
mode:
authorRonald S. Bultje <rsbultje@gmail.com>2009-07-30 15:04:19 +0000
committerRonald S. Bultje <rsbultje@gmail.com>2009-07-30 15:04:19 +0000
commit34bddc39b4c3af9472c99a9835af4dc12160f48e (patch)
treefde342f16cafe124db5cbd6c930ce88de93d7b17 /libavformat/rmdec.c
parente4b8d05d476f34d1b5daba87db190cc06cea5805 (diff)
downloadffmpeg-34bddc39b4c3af9472c99a9835af4dc12160f48e.tar.gz
Don't use a pointer-to-flags/timestamp in ff_rm_parse_packet(); the function
used to return packet data, which might update the flags/timestamp to be used for the next packet data returned by the demuxer. However, that was separated out into a new function, and the flags/timestamp are thus never updated within ff_rm_parse_packet() anymore, and thus do not need to be a pointer. Originally committed as revision 19539 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/rmdec.c')
-rw-r--r--libavformat/rmdec.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/libavformat/rmdec.c b/libavformat/rmdec.c
index 0c133246f3..f3c3019dec 100644
--- a/libavformat/rmdec.c
+++ b/libavformat/rmdec.c
@@ -689,7 +689,7 @@ rm_reorder_sipr_data (RMStream *ast)
int
ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
AVStream *st, RMStream *ast, int len, AVPacket *pkt,
- int *seq, int *flags, int64_t *timestamp)
+ int *seq, int flags, int64_t timestamp)
{
RMDemuxContext *rm = s->priv_data;
@@ -709,10 +709,10 @@ ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
int y = ast->sub_packet_cnt;
int w = ast->audio_framesize;
- if (*flags & 2)
+ if (flags & 2)
y = ast->sub_packet_cnt = 0;
if (!y)
- ast->audiotimestamp = *timestamp;
+ ast->audiotimestamp = timestamp;
switch(st->codec->codec_id) {
case CODEC_ID_RA_288:
@@ -745,7 +745,7 @@ ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
for (x = 0; x < ast->sub_packet_cnt; x++)
ast->sub_packet_lengths[x] = get_be16(pb);
rm->audio_pkt_cnt = ast->sub_packet_cnt;
- ast->audiotimestamp = *timestamp;
+ ast->audiotimestamp = timestamp;
} else
return -1;
} else {
@@ -763,15 +763,15 @@ ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
int seq= 128*(pkt->data[2]&0x7F) + (pkt->data[3]>>1);
av_log(s, AV_LOG_DEBUG, "%d %"PRId64" %d\n", *timestamp, *timestamp*512LL/25, seq);
- seq |= (*timestamp&~0x3FFF);
- if(seq - *timestamp > 0x2000) seq -= 0x4000;
- if(seq - *timestamp < -0x2000) seq += 0x4000;
+ seq |= (timestamp&~0x3FFF);
+ if(seq - timestamp > 0x2000) seq -= 0x4000;
+ if(seq - timestamp < -0x2000) seq += 0x4000;
}
}
#endif
- pkt->pts= *timestamp;
- if (*flags & 2)
+ pkt->pts= timestamp;
+ if (flags & 2)
pkt->flags |= PKT_FLAG_KEY;
return st->codec->codec_type == CODEC_TYPE_AUDIO ? rm->audio_pkt_cnt : 0;
@@ -838,7 +838,7 @@ static int rm_read_packet(AVFormatContext *s, AVPacket *pkt)
old_flags = flags;
res = ff_rm_parse_packet (s, s->pb, st, st->priv_data, len, pkt,
- &seq, &flags, &timestamp);
+ &seq, flags, timestamp);
if((old_flags&2) && (seq&0x7F) == 1)
av_add_index_entry(st, pos, timestamp, 0, 0, AVINDEX_KEYFRAME);
if (res)