xref: /aosp_15_r20/external/libaom/av1/common/frame_buffers.h (revision 77c1e3ccc04c968bd2bc212e87364f250e820521)
1*77c1e3ccSAndroid Build Coastguard Worker /*
2*77c1e3ccSAndroid Build Coastguard Worker  * Copyright (c) 2016, Alliance for Open Media. All rights reserved.
3*77c1e3ccSAndroid Build Coastguard Worker  *
4*77c1e3ccSAndroid Build Coastguard Worker  * This source code is subject to the terms of the BSD 2 Clause License and
5*77c1e3ccSAndroid Build Coastguard Worker  * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6*77c1e3ccSAndroid Build Coastguard Worker  * was not distributed with this source code in the LICENSE file, you can
7*77c1e3ccSAndroid Build Coastguard Worker  * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8*77c1e3ccSAndroid Build Coastguard Worker  * Media Patent License 1.0 was not distributed with this source code in the
9*77c1e3ccSAndroid Build Coastguard Worker  * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10*77c1e3ccSAndroid Build Coastguard Worker  */
11*77c1e3ccSAndroid Build Coastguard Worker 
12*77c1e3ccSAndroid Build Coastguard Worker #ifndef AOM_AV1_COMMON_FRAME_BUFFERS_H_
13*77c1e3ccSAndroid Build Coastguard Worker #define AOM_AV1_COMMON_FRAME_BUFFERS_H_
14*77c1e3ccSAndroid Build Coastguard Worker 
15*77c1e3ccSAndroid Build Coastguard Worker #include "aom/aom_frame_buffer.h"
16*77c1e3ccSAndroid Build Coastguard Worker #include "aom/aom_integer.h"
17*77c1e3ccSAndroid Build Coastguard Worker 
18*77c1e3ccSAndroid Build Coastguard Worker #ifdef __cplusplus
19*77c1e3ccSAndroid Build Coastguard Worker extern "C" {
20*77c1e3ccSAndroid Build Coastguard Worker #endif
21*77c1e3ccSAndroid Build Coastguard Worker 
22*77c1e3ccSAndroid Build Coastguard Worker typedef struct InternalFrameBuffer {
23*77c1e3ccSAndroid Build Coastguard Worker   uint8_t *data;
24*77c1e3ccSAndroid Build Coastguard Worker   size_t size;
25*77c1e3ccSAndroid Build Coastguard Worker   int in_use;
26*77c1e3ccSAndroid Build Coastguard Worker } InternalFrameBuffer;
27*77c1e3ccSAndroid Build Coastguard Worker 
28*77c1e3ccSAndroid Build Coastguard Worker typedef struct InternalFrameBufferList {
29*77c1e3ccSAndroid Build Coastguard Worker   int num_internal_frame_buffers;
30*77c1e3ccSAndroid Build Coastguard Worker   InternalFrameBuffer *int_fb;
31*77c1e3ccSAndroid Build Coastguard Worker } InternalFrameBufferList;
32*77c1e3ccSAndroid Build Coastguard Worker 
33*77c1e3ccSAndroid Build Coastguard Worker // Initializes |list|. Returns 0 on success.
34*77c1e3ccSAndroid Build Coastguard Worker int av1_alloc_internal_frame_buffers(InternalFrameBufferList *list);
35*77c1e3ccSAndroid Build Coastguard Worker 
36*77c1e3ccSAndroid Build Coastguard Worker // Free any data allocated to the frame buffers.
37*77c1e3ccSAndroid Build Coastguard Worker void av1_free_internal_frame_buffers(InternalFrameBufferList *list);
38*77c1e3ccSAndroid Build Coastguard Worker 
39*77c1e3ccSAndroid Build Coastguard Worker // Zeros all unused internal frame buffers. In particular, this zeros the
40*77c1e3ccSAndroid Build Coastguard Worker // frame borders. Call this function after a sequence header change to
41*77c1e3ccSAndroid Build Coastguard Worker // re-initialize the frame borders for the different width, height, or bit
42*77c1e3ccSAndroid Build Coastguard Worker // depth.
43*77c1e3ccSAndroid Build Coastguard Worker void av1_zero_unused_internal_frame_buffers(InternalFrameBufferList *list);
44*77c1e3ccSAndroid Build Coastguard Worker 
45*77c1e3ccSAndroid Build Coastguard Worker // Callback used by libaom to request an external frame buffer. |cb_priv|
46*77c1e3ccSAndroid Build Coastguard Worker // Callback private data, which points to an InternalFrameBufferList.
47*77c1e3ccSAndroid Build Coastguard Worker // |min_size| is the minimum size in bytes needed to decode the next frame.
48*77c1e3ccSAndroid Build Coastguard Worker // |fb| pointer to the frame buffer.
49*77c1e3ccSAndroid Build Coastguard Worker int av1_get_frame_buffer(void *cb_priv, size_t min_size,
50*77c1e3ccSAndroid Build Coastguard Worker                          aom_codec_frame_buffer_t *fb);
51*77c1e3ccSAndroid Build Coastguard Worker 
52*77c1e3ccSAndroid Build Coastguard Worker // Callback used by libaom when there are no references to the frame buffer.
53*77c1e3ccSAndroid Build Coastguard Worker // |cb_priv| is not used. |fb| pointer to the frame buffer.
54*77c1e3ccSAndroid Build Coastguard Worker int av1_release_frame_buffer(void *cb_priv, aom_codec_frame_buffer_t *fb);
55*77c1e3ccSAndroid Build Coastguard Worker 
56*77c1e3ccSAndroid Build Coastguard Worker #ifdef __cplusplus
57*77c1e3ccSAndroid Build Coastguard Worker }  // extern "C"
58*77c1e3ccSAndroid Build Coastguard Worker #endif
59*77c1e3ccSAndroid Build Coastguard Worker 
60*77c1e3ccSAndroid Build Coastguard Worker #endif  // AOM_AV1_COMMON_FRAME_BUFFERS_H_
61