1*c83a76b0SSuyog Pawar /****************************************************************************** 2*c83a76b0SSuyog Pawar * 3*c83a76b0SSuyog Pawar * Copyright (C) 2018 The Android Open Source Project 4*c83a76b0SSuyog Pawar * 5*c83a76b0SSuyog Pawar * Licensed under the Apache License, Version 2.0 (the "License"); 6*c83a76b0SSuyog Pawar * you may not use this file except in compliance with the License. 7*c83a76b0SSuyog Pawar * You may obtain a copy of the License at: 8*c83a76b0SSuyog Pawar * 9*c83a76b0SSuyog Pawar * http://www.apache.org/licenses/LICENSE-2.0 10*c83a76b0SSuyog Pawar * 11*c83a76b0SSuyog Pawar * Unless required by applicable law or agreed to in writing, software 12*c83a76b0SSuyog Pawar * distributed under the License is distributed on an "AS IS" BASIS, 13*c83a76b0SSuyog Pawar * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*c83a76b0SSuyog Pawar * See the License for the specific language governing permissions and 15*c83a76b0SSuyog Pawar * limitations under the License. 16*c83a76b0SSuyog Pawar * 17*c83a76b0SSuyog Pawar ***************************************************************************** 18*c83a76b0SSuyog Pawar * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore 19*c83a76b0SSuyog Pawar */ 20*c83a76b0SSuyog Pawar /*! 21*c83a76b0SSuyog Pawar ****************************************************************************** 22*c83a76b0SSuyog Pawar * \file ihevce_dep_mngr_private.h 23*c83a76b0SSuyog Pawar * 24*c83a76b0SSuyog Pawar * \brief 25*c83a76b0SSuyog Pawar * This file contains private structures & definations of Sync manager 26*c83a76b0SSuyog Pawar * 27*c83a76b0SSuyog Pawar * \date 28*c83a76b0SSuyog Pawar * 13/12/2013 29*c83a76b0SSuyog Pawar * 30*c83a76b0SSuyog Pawar * \author 31*c83a76b0SSuyog Pawar * Ittiam 32*c83a76b0SSuyog Pawar * 33*c83a76b0SSuyog Pawar ****************************************************************************** 34*c83a76b0SSuyog Pawar */ 35*c83a76b0SSuyog Pawar 36*c83a76b0SSuyog Pawar #ifndef _IHEVCE_DEP_MANAGER_PRIVATE_H_ 37*c83a76b0SSuyog Pawar #define _IHEVCE_DEP_MANAGER_PRIVATE_H_ 38*c83a76b0SSuyog Pawar 39*c83a76b0SSuyog Pawar /*****************************************************************************/ 40*c83a76b0SSuyog Pawar /* File Includes */ 41*c83a76b0SSuyog Pawar /*****************************************************************************/ 42*c83a76b0SSuyog Pawar 43*c83a76b0SSuyog Pawar /*****************************************************************************/ 44*c83a76b0SSuyog Pawar /* Constant Macros */ 45*c83a76b0SSuyog Pawar /*****************************************************************************/ 46*c83a76b0SSuyog Pawar 47*c83a76b0SSuyog Pawar /*****************************************************************************/ 48*c83a76b0SSuyog Pawar /* Function Macros */ 49*c83a76b0SSuyog Pawar /*****************************************************************************/ 50*c83a76b0SSuyog Pawar 51*c83a76b0SSuyog Pawar /*****************************************************************************/ 52*c83a76b0SSuyog Pawar /* Typedefs */ 53*c83a76b0SSuyog Pawar /*****************************************************************************/ 54*c83a76b0SSuyog Pawar 55*c83a76b0SSuyog Pawar /*****************************************************************************/ 56*c83a76b0SSuyog Pawar /* Enums */ 57*c83a76b0SSuyog Pawar /*****************************************************************************/ 58*c83a76b0SSuyog Pawar typedef enum 59*c83a76b0SSuyog Pawar { 60*c83a76b0SSuyog Pawar DEP_MNGR_CTXT = 0, 61*c83a76b0SSuyog Pawar DEP_MNGR_UNITS_PRCSD_MEM, 62*c83a76b0SSuyog Pawar DEP_MNGR_WAIT_THRD_ID_MEM, 63*c83a76b0SSuyog Pawar DEP_MNGR_SEM_HANDLE_MEM, 64*c83a76b0SSuyog Pawar 65*c83a76b0SSuyog Pawar /* should be last entry */ 66*c83a76b0SSuyog Pawar NUM_DEP_MNGR_MEM_RECS 67*c83a76b0SSuyog Pawar } DEP_MNGR_MEM_T; 68*c83a76b0SSuyog Pawar 69*c83a76b0SSuyog Pawar /*****************************************************************************/ 70*c83a76b0SSuyog Pawar /* Structure */ 71*c83a76b0SSuyog Pawar /*****************************************************************************/ 72*c83a76b0SSuyog Pawar 73*c83a76b0SSuyog Pawar typedef struct 74*c83a76b0SSuyog Pawar { 75*c83a76b0SSuyog Pawar /*! Number of Vertical units to be processed */ 76*c83a76b0SSuyog Pawar WORD32 i4_num_vert_units; 77*c83a76b0SSuyog Pawar 78*c83a76b0SSuyog Pawar /*! Maximun Number of Horizontal units to be processed */ 79*c83a76b0SSuyog Pawar WORD32 i4_num_horz_units; 80*c83a76b0SSuyog Pawar 81*c83a76b0SSuyog Pawar /*! Number of column tiles for which encoder is working */ 82*c83a76b0SSuyog Pawar WORD32 i4_num_tile_cols; 83*c83a76b0SSuyog Pawar 84*c83a76b0SSuyog Pawar /*! Array to update the units which got processed in each row */ 85*c83a76b0SSuyog Pawar /*! For num_tile_cols > 1 , the memory layout is 86*c83a76b0SSuyog Pawar 0-max_num_vert_units for col_tile 0 87*c83a76b0SSuyog Pawar 0-max_num_vert_units for col_tile 1 88*c83a76b0SSuyog Pawar .. 89*c83a76b0SSuyog Pawar .. 90*c83a76b0SSuyog Pawar 0-max_num_vert_units for col_tile N-1 91*c83a76b0SSuyog Pawar */ 92*c83a76b0SSuyog Pawar void *pv_units_prcsd_in_row; 93*c83a76b0SSuyog Pawar 94*c83a76b0SSuyog Pawar /*! Array to register the thread ids of waiting threads in each row */ 95*c83a76b0SSuyog Pawar /*! Memory Layout : (Row - Row) 1 entry per row 96*c83a76b0SSuyog Pawar Memory Layout : (Frame - Frame) Num threads per frame 97*c83a76b0SSuyog Pawar Memory layout : (Row - Frame) 98*c83a76b0SSuyog Pawar Num threads for Row 0 99*c83a76b0SSuyog Pawar Num threads for Row 1 100*c83a76b0SSuyog Pawar Num threads for Row 2 101*c83a76b0SSuyog Pawar .. 102*c83a76b0SSuyog Pawar .. 103*c83a76b0SSuyog Pawar Num threads for Row N-1 104*c83a76b0SSuyog Pawar */ 105*c83a76b0SSuyog Pawar WORD32 *pi4_wait_thrd_id; 106*c83a76b0SSuyog Pawar 107*c83a76b0SSuyog Pawar /*! Number of threads in the dependency chain */ 108*c83a76b0SSuyog Pawar WORD32 i4_num_thrds; 109*c83a76b0SSuyog Pawar 110*c83a76b0SSuyog Pawar /*! Pointer to Array of Thread semaphore handle */ 111*c83a76b0SSuyog Pawar void **ppv_thrd_sem_handles; 112*c83a76b0SSuyog Pawar 113*c83a76b0SSuyog Pawar /*! Dependency Manager Mode */ 114*c83a76b0SSuyog Pawar WORD32 i4_dep_mngr_mode; /* @sa DEP_MNGR_MODE_T */ 115*c83a76b0SSuyog Pawar 116*c83a76b0SSuyog Pawar /*! 0 : Semaphore not used., 1 : Uses semaphore */ 117*c83a76b0SSuyog Pawar /*! Note : This is required for using spin-lock for some dependencies. */ 118*c83a76b0SSuyog Pawar /*! If 0, uses spin-lock(do-while) rather than semaphore for Sync */ 119*c83a76b0SSuyog Pawar WORD8 i1_sem_enable; 120*c83a76b0SSuyog Pawar 121*c83a76b0SSuyog Pawar /*0: top, 1: left, 2: right, 3: bottom */ 122*c83a76b0SSuyog Pawar WORD8 ai4_tile_xtra_ctb[4]; 123*c83a76b0SSuyog Pawar 124*c83a76b0SSuyog Pawar /* temp var: delete it */ 125*c83a76b0SSuyog Pawar //WORD32 i4_frame_map_complete; 126*c83a76b0SSuyog Pawar 127*c83a76b0SSuyog Pawar } dep_mngr_state_t; 128*c83a76b0SSuyog Pawar 129*c83a76b0SSuyog Pawar /*****************************************************************************/ 130*c83a76b0SSuyog Pawar /* Extern Variable Declarations */ 131*c83a76b0SSuyog Pawar /*****************************************************************************/ 132*c83a76b0SSuyog Pawar 133*c83a76b0SSuyog Pawar /*****************************************************************************/ 134*c83a76b0SSuyog Pawar /* Extern Function Declarations */ 135*c83a76b0SSuyog Pawar /*****************************************************************************/ 136*c83a76b0SSuyog Pawar 137*c83a76b0SSuyog Pawar #endif //_IHEVCE_DEP_MANAGER_PRIVATE_H_ 138