[FFmpeg-cvslog] r11052 - trunk/libavformat/rmdec.c
rtogni
subversion
Sun Nov 18 23:40:03 CET 2007
Author: rtogni
Date: Sun Nov 18 23:40:02 2007
New Revision: 11052
Log:
Optimize memory management to create an av_packet from multiple slices:
- remove memmove to pack the data, instead copy only the used areas
from the temp buffer in their final position
- use the minimum possible size for the av_packet (relevant when some
slices are missing)
Modified:
trunk/libavformat/rmdec.c
Modified: trunk/libavformat/rmdec.c
==============================================================================
--- trunk/libavformat/rmdec.c (original)
+++ trunk/libavformat/rmdec.c Sun Nov 18 23:40:02 2007
@@ -519,14 +519,11 @@ static int rm_assemble_video_frame(AVFor
rm->remaining_len-= len;
if(type == 2 || (rm->videobufpos) == rm->videobufsize){
- //adjust slice headers
- memmove(rm->videobuf + 1 + 8*rm->cur_slice, rm->videobuf + 1 + 8*rm->slices, rm->videobufsize - 1 - 8*rm->slices);
- ssize = rm->videobufsize - 8*(rm->slices - rm->cur_slice);
-
rm->videobuf[0] = rm->cur_slice-1;
- if(av_new_packet(pkt, ssize) < 0)
+ if(av_new_packet(pkt, rm->videobufpos - 8*(rm->slices - rm->cur_slice)) < 0)
return AVERROR(ENOMEM);
- memcpy(pkt->data, rm->videobuf, ssize);
+ memcpy(pkt->data, rm->videobuf, 1 + 8*rm->cur_slice);
+ memcpy(pkt->data + 1 + 8*rm->cur_slice, rm->videobuf + 1 + 8*rm->slices, rm->videobufpos - 1 - 8*rm->slices);
pkt->pts = AV_NOPTS_VALUE;
pkt->pos = rm->pktpos;
return 0;
More information about the ffmpeg-cvslog
mailing list