1*c0909341SAndroid Build Coastguard Worker /* 2*c0909341SAndroid Build Coastguard Worker * Copyright © 2018, VideoLAN and dav1d authors 3*c0909341SAndroid Build Coastguard Worker * Copyright © 2018, Two Orioles, LLC 4*c0909341SAndroid Build Coastguard Worker * All rights reserved. 5*c0909341SAndroid Build Coastguard Worker * 6*c0909341SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 7*c0909341SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions are met: 8*c0909341SAndroid Build Coastguard Worker * 9*c0909341SAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright notice, this 10*c0909341SAndroid Build Coastguard Worker * list of conditions and the following disclaimer. 11*c0909341SAndroid Build Coastguard Worker * 12*c0909341SAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright notice, 13*c0909341SAndroid Build Coastguard Worker * this list of conditions and the following disclaimer in the documentation 14*c0909341SAndroid Build Coastguard Worker * and/or other materials provided with the distribution. 15*c0909341SAndroid Build Coastguard Worker * 16*c0909341SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 17*c0909341SAndroid Build Coastguard Worker * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 18*c0909341SAndroid Build Coastguard Worker * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 19*c0909341SAndroid Build Coastguard Worker * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR 20*c0909341SAndroid Build Coastguard Worker * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 21*c0909341SAndroid Build Coastguard Worker * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 22*c0909341SAndroid Build Coastguard Worker * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 23*c0909341SAndroid Build Coastguard Worker * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24*c0909341SAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 25*c0909341SAndroid Build Coastguard Worker * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26*c0909341SAndroid Build Coastguard Worker */ 27*c0909341SAndroid Build Coastguard Worker 28*c0909341SAndroid Build Coastguard Worker #ifndef DAV1D_DATA_H 29*c0909341SAndroid Build Coastguard Worker #define DAV1D_DATA_H 30*c0909341SAndroid Build Coastguard Worker 31*c0909341SAndroid Build Coastguard Worker #include <stddef.h> 32*c0909341SAndroid Build Coastguard Worker #include <stdint.h> 33*c0909341SAndroid Build Coastguard Worker 34*c0909341SAndroid Build Coastguard Worker #include "common.h" 35*c0909341SAndroid Build Coastguard Worker 36*c0909341SAndroid Build Coastguard Worker #ifdef __cplusplus 37*c0909341SAndroid Build Coastguard Worker extern "C" { 38*c0909341SAndroid Build Coastguard Worker #endif 39*c0909341SAndroid Build Coastguard Worker 40*c0909341SAndroid Build Coastguard Worker typedef struct Dav1dData { 41*c0909341SAndroid Build Coastguard Worker const uint8_t *data; ///< data pointer 42*c0909341SAndroid Build Coastguard Worker size_t sz; ///< data size 43*c0909341SAndroid Build Coastguard Worker struct Dav1dRef *ref; ///< allocation origin 44*c0909341SAndroid Build Coastguard Worker Dav1dDataProps m; ///< user provided metadata passed to the output picture 45*c0909341SAndroid Build Coastguard Worker } Dav1dData; 46*c0909341SAndroid Build Coastguard Worker 47*c0909341SAndroid Build Coastguard Worker /** 48*c0909341SAndroid Build Coastguard Worker * Allocate data. 49*c0909341SAndroid Build Coastguard Worker * 50*c0909341SAndroid Build Coastguard Worker * @param data Input context. 51*c0909341SAndroid Build Coastguard Worker * @param sz Size of the data that should be allocated. 52*c0909341SAndroid Build Coastguard Worker * 53*c0909341SAndroid Build Coastguard Worker * @return Pointer to the allocated buffer on success. NULL on error. 54*c0909341SAndroid Build Coastguard Worker */ 55*c0909341SAndroid Build Coastguard Worker DAV1D_API uint8_t * dav1d_data_create(Dav1dData *data, size_t sz); 56*c0909341SAndroid Build Coastguard Worker 57*c0909341SAndroid Build Coastguard Worker /** 58*c0909341SAndroid Build Coastguard Worker * Wrap an existing data array. 59*c0909341SAndroid Build Coastguard Worker * 60*c0909341SAndroid Build Coastguard Worker * @param data Input context. 61*c0909341SAndroid Build Coastguard Worker * @param buf The data to be wrapped. 62*c0909341SAndroid Build Coastguard Worker * @param sz Size of the data. 63*c0909341SAndroid Build Coastguard Worker * @param free_callback Function to be called when we release our last 64*c0909341SAndroid Build Coastguard Worker * reference to this data. In this callback, $buf will be 65*c0909341SAndroid Build Coastguard Worker * the $buf argument to this function, and $cookie will 66*c0909341SAndroid Build Coastguard Worker * be the $cookie input argument to this function. 67*c0909341SAndroid Build Coastguard Worker * @param cookie Opaque parameter passed to free_callback(). 68*c0909341SAndroid Build Coastguard Worker * 69*c0909341SAndroid Build Coastguard Worker * @return 0 on success. A negative DAV1D_ERR value on error. 70*c0909341SAndroid Build Coastguard Worker */ 71*c0909341SAndroid Build Coastguard Worker DAV1D_API int dav1d_data_wrap(Dav1dData *data, const uint8_t *buf, size_t sz, 72*c0909341SAndroid Build Coastguard Worker void (*free_callback)(const uint8_t *buf, void *cookie), 73*c0909341SAndroid Build Coastguard Worker void *cookie); 74*c0909341SAndroid Build Coastguard Worker 75*c0909341SAndroid Build Coastguard Worker /** 76*c0909341SAndroid Build Coastguard Worker * Wrap a user-provided data pointer into a reference counted object. 77*c0909341SAndroid Build Coastguard Worker * 78*c0909341SAndroid Build Coastguard Worker * data->m.user_data field will initialized to wrap the provided $user_data 79*c0909341SAndroid Build Coastguard Worker * pointer. 80*c0909341SAndroid Build Coastguard Worker * 81*c0909341SAndroid Build Coastguard Worker * $free_callback will be called on the same thread that released the last 82*c0909341SAndroid Build Coastguard Worker * reference. If frame threading is used, make sure $free_callback is 83*c0909341SAndroid Build Coastguard Worker * thread-safe. 84*c0909341SAndroid Build Coastguard Worker * 85*c0909341SAndroid Build Coastguard Worker * @param data Input context. 86*c0909341SAndroid Build Coastguard Worker * @param user_data The user data to be wrapped. 87*c0909341SAndroid Build Coastguard Worker * @param free_callback Function to be called when we release our last 88*c0909341SAndroid Build Coastguard Worker * reference to this data. In this callback, $user_data 89*c0909341SAndroid Build Coastguard Worker * will be the $user_data argument to this function, and 90*c0909341SAndroid Build Coastguard Worker * $cookie will be the $cookie input argument to this 91*c0909341SAndroid Build Coastguard Worker * function. 92*c0909341SAndroid Build Coastguard Worker * @param cookie Opaque parameter passed to $free_callback. 93*c0909341SAndroid Build Coastguard Worker * 94*c0909341SAndroid Build Coastguard Worker * @return 0 on success. A negative DAV1D_ERR value on error. 95*c0909341SAndroid Build Coastguard Worker */ 96*c0909341SAndroid Build Coastguard Worker DAV1D_API int dav1d_data_wrap_user_data(Dav1dData *data, 97*c0909341SAndroid Build Coastguard Worker const uint8_t *user_data, 98*c0909341SAndroid Build Coastguard Worker void (*free_callback)(const uint8_t *user_data, 99*c0909341SAndroid Build Coastguard Worker void *cookie), 100*c0909341SAndroid Build Coastguard Worker void *cookie); 101*c0909341SAndroid Build Coastguard Worker 102*c0909341SAndroid Build Coastguard Worker /** 103*c0909341SAndroid Build Coastguard Worker * Free the data reference. 104*c0909341SAndroid Build Coastguard Worker * 105*c0909341SAndroid Build Coastguard Worker * The reference count for data->m.user_data will be decremented (if it has been 106*c0909341SAndroid Build Coastguard Worker * initialized with dav1d_data_wrap_user_data). The $data object will be memset 107*c0909341SAndroid Build Coastguard Worker * to 0. 108*c0909341SAndroid Build Coastguard Worker * 109*c0909341SAndroid Build Coastguard Worker * @param data Input context. 110*c0909341SAndroid Build Coastguard Worker */ 111*c0909341SAndroid Build Coastguard Worker DAV1D_API void dav1d_data_unref(Dav1dData *data); 112*c0909341SAndroid Build Coastguard Worker 113*c0909341SAndroid Build Coastguard Worker #ifdef __cplusplus 114*c0909341SAndroid Build Coastguard Worker } /* extern "C" */ 115*c0909341SAndroid Build Coastguard Worker #endif 116*c0909341SAndroid Build Coastguard Worker 117*c0909341SAndroid Build Coastguard Worker #endif /* DAV1D_DATA_H */ 118