/****************************************************************************** * * Copyright (C) 2015 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ***************************************************************************** * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore */ /** ******************************************************************************* * @file * ih264_buf_mgr.h * * @brief * Function declarations used for buffer management * * @remarks * None * ******************************************************************************* */ #ifndef _IH264_BUF_MGR_H_ #define _IH264_BUF_MGR_H_ #define BUF_MGR_MAX_CNT 64 /** Flag for current encoding decoder */ #define BUF_MGR_CODEC (1 << 1) /** Flag for reference status */ #define BUF_MGR_REF (1 << 2) /** Flag for I/O - Display/output in case of decoder, capture/input in case of encoder */ #define BUF_MGR_IO (1 << 3) typedef struct { /** * Mutex used to keep the functions thread-safe */ void *pv_mutex; /** * max_buf_cnt */ WORD32 i4_max_buf_cnt; /** * active_buf_cnt */ WORD32 i4_active_buf_cnt; /** * au4_status[BUF_MGR_MAX_CNT] */ UWORD32 au4_status[BUF_MGR_MAX_CNT]; /* The last three bit of status are: */ /* Bit 0 - IN USE */ /* Bit 1 - CODEC */ /* Bit 2 - REF */ /* Bit 3 - DISP/IO/RECON */ void *apv_ptr[BUF_MGR_MAX_CNT]; }buf_mgr_t; // Returns size of the buffer manager context WORD32 ih264_buf_mgr_size(void); //Free buffer manager IH264_ERROR_T ih264_buf_mgr_free(buf_mgr_t *ps_buf_mgr); // Initializes the buffer API structure void *ih264_buf_mgr_init(void *pv_buf); // Add buffer to buffer manager. 0: success, -1: fail (u4_active_buf_cnt has reached u4_max_buf_cnt) IH264_ERROR_T ih264_buf_mgr_add(buf_mgr_t *ps_buf_mgr, void *pv_ptr, WORD32 buf_id); // this function will set the buffer status to DEC void* ih264_buf_mgr_get_next_free(buf_mgr_t *ps_buf_mgr, WORD32 *pi4_id); // this function will check if there are any free buffers IH264_ERROR_T ih264_buf_mgr_check_free(buf_mgr_t *ps_buf_mgr); // mask will have who released it: DISP:REF:DEC IH264_ERROR_T ih264_buf_mgr_release(buf_mgr_t *ps_buf_mgr, WORD32 id, UWORD32 mask); // sets the status to one or all of DISP:REF:DEC IH264_ERROR_T ih264_buf_mgr_set_status(buf_mgr_t *ps_buf_mgr, WORD32 id, UWORD32 mask); // Gets status of the buffer WORD32 ih264_buf_mgr_get_status(buf_mgr_t *ps_buf_mgr, WORD32 id); // pass the ID - buffer will be returned void* ih264_buf_mgr_get_buf(buf_mgr_t *ps_buf_mgr, WORD32 id); //Pass buffer to get ID WORD32 ih264_buf_mgr_get_bufid(buf_mgr_t *ps_buf_mgr, void *pv_buf); // will return number of active buffers UWORD32 ih264_buf_mgr_get_num_active_buf(buf_mgr_t *ps_buf_mgr); #endif /* _IH264_BUF_MGR_H_ */