summaryrefslogtreecommitdiff
path: root/libavfilter/defaults.c
diff options
context:
space:
mode:
authorStefano Sabatini <stefano.sabatini-lala@poste.it>2010-11-25 20:50:28 +0000
committerStefano Sabatini <stefano.sabatini-lala@poste.it>2010-11-25 20:50:28 +0000
commitd38c340fdc970c913866f5e8461cf33ab200a51b (patch)
tree52a0e1f03ba1c0a4062ef9fc19298efbd2489d5f /libavfilter/defaults.c
parent4723bc286812ded7150cd543e6348d04683ce997 (diff)
Implement avfilter_get_video_buffer_ref_from_arrays().
Originally committed as revision 25827 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavfilter/defaults.c')
-rw-r--r--libavfilter/defaults.c49
1 files changed, 15 insertions, 34 deletions
diff --git a/libavfilter/defaults.c b/libavfilter/defaults.c
index e895ccdadd..44262ca734 100644
--- a/libavfilter/defaults.c
+++ b/libavfilter/defaults.c
@@ -37,49 +37,30 @@ void ff_avfilter_default_free_buffer(AVFilterBuffer *ptr)
* alloc & free cycle currently implemented. */
AVFilterBufferRef *avfilter_default_get_video_buffer(AVFilterLink *link, int perms, int w, int h)
{
- AVFilterBuffer *pic = av_mallocz(sizeof(AVFilterBuffer));
- AVFilterBufferRef *ref = NULL;
- int i, tempsize;
char *buf = NULL;
+ int linesize[4], i, tempsize;
+ uint8_t *data[4];
+ AVFilterBufferRef *picref = NULL;
- if (!pic || !(ref = av_mallocz(sizeof(AVFilterBufferRef))))
- goto fail;
-
- ref->buf = pic;
- ref->video = av_mallocz(sizeof(AVFilterBufferRefVideoProps));
- ref->video->w = w;
- ref->video->h = h;
-
- /* make sure the buffer gets read permission or it's useless for output */
- ref->perms = perms | AV_PERM_READ;
-
- pic->refcount = 1;
- ref->format = link->format;
- pic->free = ff_avfilter_default_free_buffer;
- av_image_fill_linesizes(pic->linesize, ref->format, ref->video->w);
-
+ av_image_fill_linesizes(linesize, link->format, w);
for (i = 0; i < 4; i++)
- pic->linesize[i] = FFALIGN(pic->linesize[i], 16);
-
- tempsize = av_image_fill_pointers(pic->data, ref->format, ref->video->h, NULL, pic->linesize);
+ linesize[i] = FFALIGN(linesize[i], 16);
+ tempsize = av_image_fill_pointers(data, link->format, h, NULL, linesize);
buf = av_malloc(tempsize + 16); // +2 is needed for swscaler, +16 to be
// SIMD-friendly
if (!buf)
- goto fail;
- av_image_fill_pointers(pic->data, ref->format, ref->video->h, buf, pic->linesize);
+ return NULL;
- memcpy(ref->data, pic->data, sizeof(ref->data));
- memcpy(ref->linesize, pic->linesize, sizeof(ref->linesize));
+ av_image_fill_pointers(data, link->format, h, buf, linesize);
- return ref;
+ picref = avfilter_get_video_buffer_ref_from_arrays(data, linesize,
+ perms, w, h, link->format);
+ if (!picref) {
+ av_free(buf);
+ return NULL;
+ }
-fail:
- av_free(buf);
- if (ref && ref->video)
- av_free(ref->video);
- av_free(ref);
- av_free(pic);
- return NULL;
+ return picref;
}
AVFilterBufferRef *avfilter_default_get_audio_buffer(AVFilterLink *link, int perms,