Commit f532e5ff authored by rtogni's avatar rtogni

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)


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@11052 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 6f8215ee
...@@ -519,14 +519,11 @@ static int rm_assemble_video_frame(AVFormatContext *s, RMContext *rm, AVPacket * ...@@ -519,14 +519,11 @@ static int rm_assemble_video_frame(AVFormatContext *s, RMContext *rm, AVPacket *
rm->remaining_len-= len; rm->remaining_len-= len;
if(type == 2 || (rm->videobufpos) == rm->videobufsize){ 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; 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); 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->pts = AV_NOPTS_VALUE;
pkt->pos = rm->pktpos; pkt->pos = rm->pktpos;
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment