mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
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. Originally committed as revision 18009 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
748a4312b4
commit
c5efef7be9
@ -312,14 +312,16 @@ rdt_parse_packet (AVFormatContext *ctx, PayloadContext *rdt, AVStream *st,
|
|||||||
pos = url_ftell(&pb);
|
pos = url_ftell(&pb);
|
||||||
if (res < 0)
|
if (res < 0)
|
||||||
return res;
|
return res;
|
||||||
rdt->audio_pkt_cnt = res;
|
if (res > 0) {
|
||||||
if (rdt->audio_pkt_cnt > 0 &&
|
if (st->codec->codec_id == CODEC_ID_AAC) {
|
||||||
st->codec->codec_id == CODEC_ID_AAC) {
|
|
||||||
memcpy (rdt->buffer, buf + pos, len - pos);
|
memcpy (rdt->buffer, buf + pos, len - pos);
|
||||||
rdt->rmctx->pb = av_alloc_put_byte (rdt->buffer, len - pos, 0,
|
rdt->rmctx->pb = av_alloc_put_byte (rdt->buffer, len - pos, 0,
|
||||||
NULL, NULL, NULL, NULL);
|
NULL, NULL, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
goto get_cache;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
|
get_cache:
|
||||||
rdt->audio_pkt_cnt =
|
rdt->audio_pkt_cnt =
|
||||||
ff_rm_retrieve_cache (rdt->rmctx, rdt->rmctx->pb,
|
ff_rm_retrieve_cache (rdt->rmctx, rdt->rmctx->pb,
|
||||||
st, rdt->rmst[st->index], pkt);
|
st, rdt->rmst[st->index], pkt);
|
||||||
|
@ -64,9 +64,9 @@ int ff_rm_read_mdpr_codecdata (AVFormatContext *s, ByteIOContext *pb,
|
|||||||
* @param flags pointer to an integer containing the packet flags, may be
|
* @param flags pointer to an integer containing the packet flags, may be
|
||||||
updated
|
updated
|
||||||
* @param ts pointer to timestamp, may be updated
|
* @param ts pointer to timestamp, may be updated
|
||||||
* @return >=0 on success (where >0 indicates there are cached samples that
|
* @return <0 on error, 0 if a packet was placed in the \p pkt pointer. A
|
||||||
* can be retrieved with subsequent calls to ff_rm_retrieve_cache()),
|
* value >0 means that no data was placed in \p pkt, but that cached
|
||||||
* errno codes on error
|
* data is available by calling ff_rm_retrieve_cache().
|
||||||
*/
|
*/
|
||||||
int ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
|
int ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
|
||||||
AVStream *st, RMStream *rst, int len,
|
AVStream *st, RMStream *rst, int len,
|
||||||
|
@ -627,16 +627,9 @@ ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
|
|||||||
|
|
||||||
if (++(ast->sub_packet_cnt) < h)
|
if (++(ast->sub_packet_cnt) < h)
|
||||||
return -1;
|
return -1;
|
||||||
else {
|
|
||||||
ast->sub_packet_cnt = 0;
|
ast->sub_packet_cnt = 0;
|
||||||
rm->audio_stream_num = st->index;
|
rm->audio_stream_num = st->index;
|
||||||
rm->audio_pkt_cnt = h * w / st->codec->block_align - 1;
|
rm->audio_pkt_cnt = h * w / st->codec->block_align;
|
||||||
// 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
|
|
||||||
}
|
|
||||||
} else if (st->codec->codec_id == CODEC_ID_AAC) {
|
} else if (st->codec->codec_id == CODEC_ID_AAC) {
|
||||||
int x;
|
int x;
|
||||||
rm->audio_stream_num = st->index;
|
rm->audio_stream_num = st->index;
|
||||||
@ -644,11 +637,10 @@ ff_rm_parse_packet (AVFormatContext *s, ByteIOContext *pb,
|
|||||||
if (ast->sub_packet_cnt) {
|
if (ast->sub_packet_cnt) {
|
||||||
for (x = 0; x < ast->sub_packet_cnt; x++)
|
for (x = 0; x < ast->sub_packet_cnt; x++)
|
||||||
ast->sub_packet_lengths[x] = get_be16(pb);
|
ast->sub_packet_lengths[x] = get_be16(pb);
|
||||||
// Release first audio packet
|
rm->audio_pkt_cnt = ast->sub_packet_cnt;
|
||||||
rm->audio_pkt_cnt = ast->sub_packet_cnt - 1;
|
ast->audiotimestamp = *timestamp;
|
||||||
av_get_packet(pb, pkt, ast->sub_packet_lengths[0]);
|
} else
|
||||||
*flags = 2; // Mark first packet as keyframe
|
return -1;
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
av_get_packet(pb, pkt, len);
|
av_get_packet(pb, pkt, len);
|
||||||
rm_ac3_swap_bytes(st, pkt);
|
rm_ac3_swap_bytes(st, pkt);
|
||||||
|
Loading…
Reference in New Issue
Block a user