decoder: get rid of GstVaapiDecoderUnit::buffer field.
[vaapi:gstreamer-vaapi.git] / gst-libs / gst / vaapi / gstvaapidecoder_unit.c
1 /*
2  *  gstvaapidecoder_unit.c - VA decoder units
3  *
4  *  Copyright (C) 2012-2013 Intel Corporation
5  *
6  *  This library is free software; you can redistribute it and/or
7  *  modify it under the terms of the GNU Lesser General Public License
8  *  as published by the Free Software Foundation; either version 2.1
9  *  of the License, or (at your option) any later version.
10  *
11  *  This library is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  *  Lesser General Public License for more details.
15  *
16  *  You should have received a copy of the GNU Lesser General Public
17  *  License along with this library; if not, write to the Free
18  *  Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19  *  Boston, MA 02110-1301 USA
20  */
21
22 /**
23  * SECTION:gstvaapidecoder_unit
24  * @short_description: Decoder unit
25  */
26
27 #include "sysdeps.h"
28 #include "gstvaapidecoder_unit.h"
29
30 /**
31  * gst_vaapi_decoder_unit_init:
32  * @unit: a #GstVaapiDecoderUnit
33  *
34  * Initializes internal resources bound to the supplied decoder @unit.
35  *
36  * @note This is an internal function used to implement lightweight
37  * sub-classes.
38  */
39 void
40 gst_vaapi_decoder_unit_init(GstVaapiDecoderUnit *unit)
41 {
42     unit->flags = 0;
43     unit->size = 0;
44     unit->offset = 0;
45
46     unit->parsed_info = NULL;
47     unit->parsed_info_destroy_notify = NULL;
48 }
49
50 /**
51  * gst_vaapi_decoder_unit_clear:
52  * @unit: a #GstVaapiDecoderUnit
53  *
54  * Deallocates any internal resources bound to the supplied decoder
55  * @unit.
56  *
57  * @note This is an internal function used to implement lightweight
58  * sub-classes.
59  */
60 void
61 gst_vaapi_decoder_unit_clear(GstVaapiDecoderUnit *unit)
62 {
63     gst_vaapi_decoder_unit_set_parsed_info(unit, NULL, NULL);
64 }
65
66 /**
67  * gst_vaapi_decoder_unit_set_parsed_info:
68  * @unit: a #GstVaapiDecoderUnit
69  * @parsed_info: parser info
70  * @destroy_notify: (closure parsed_info): a #GDestroyNotify
71  *
72  * Sets @parsed_info on the object and the #GDestroyNotify that will be
73  * called when the data is freed.
74  *
75  * If some @parsed_info was previously set, then the former @destroy_notify
76  * function will be called before the @parsed_info is replaced.
77  */
78 void
79 gst_vaapi_decoder_unit_set_parsed_info(GstVaapiDecoderUnit *unit,
80     gpointer parsed_info, GDestroyNotify destroy_notify)
81 {
82     g_return_if_fail(GST_VAAPI_IS_DECODER_UNIT(unit));
83
84     if (unit->parsed_info && unit->parsed_info_destroy_notify)
85         unit->parsed_info_destroy_notify(unit->parsed_info);
86     unit->parsed_info = parsed_info;
87     unit->parsed_info_destroy_notify = destroy_notify;
88 }