xref: /aosp_15_r20/external/libhevc/encoder/mem_req_and_acq.h (revision c83a76b084498d55f252f48b2e3786804cdf24b7)
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  * @file mem_req_and_acq.h
22*c83a76b0SSuyog Pawar  * @brief Interface for mem request, acquiring and freeing
23*c83a76b0SSuyog Pawar  * @author K. J. Nitthilan
24*c83a76b0SSuyog Pawar  * @version 1.0
25*c83a76b0SSuyog Pawar  * @date 2009-04-21
26*c83a76b0SSuyog Pawar  */
27*c83a76b0SSuyog Pawar #ifndef _MEM_REQ_AND_ACQ_H_
28*c83a76b0SSuyog Pawar #define _MEM_REQ_AND_ACQ_H_
29*c83a76b0SSuyog Pawar 
30*c83a76b0SSuyog Pawar typedef enum
31*c83a76b0SSuyog Pawar {
32*c83a76b0SSuyog Pawar     ALIGN_BYTE = 1,
33*c83a76b0SSuyog Pawar     ALIGN_WORD16 = 2,
34*c83a76b0SSuyog Pawar     ALIGN_WORD32 = 4,
35*c83a76b0SSuyog Pawar     ALIGN_WORD64 = 8,
36*c83a76b0SSuyog Pawar     ALIGN_128_BYTE = 128
37*c83a76b0SSuyog Pawar } ITT_MEM_ALIGNMENT_TYPE_E;
38*c83a76b0SSuyog Pawar 
39*c83a76b0SSuyog Pawar typedef enum
40*c83a76b0SSuyog Pawar {
41*c83a76b0SSuyog Pawar     SCRATCH = 0,
42*c83a76b0SSuyog Pawar     PERSISTENT = 1,
43*c83a76b0SSuyog Pawar     WRITEONCE = 2
44*c83a76b0SSuyog Pawar } ITT_MEM_USAGE_TYPE_E;
45*c83a76b0SSuyog Pawar 
46*c83a76b0SSuyog Pawar typedef enum
47*c83a76b0SSuyog Pawar {
48*c83a76b0SSuyog Pawar     L1D = 0,
49*c83a76b0SSuyog Pawar     SL2 = 1,
50*c83a76b0SSuyog Pawar     DDR = 3
51*c83a76b0SSuyog Pawar } ITT_MEM_REGION_E;
52*c83a76b0SSuyog Pawar 
53*c83a76b0SSuyog Pawar typedef enum
54*c83a76b0SSuyog Pawar {
55*c83a76b0SSuyog Pawar     GET_NUM_MEMTAB = 0,
56*c83a76b0SSuyog Pawar     FILL_MEMTAB = 1,
57*c83a76b0SSuyog Pawar     USE_BASE = 2,
58*c83a76b0SSuyog Pawar     FILL_BASE = 3
59*c83a76b0SSuyog Pawar } ITT_FUNC_TYPE_E;
60*c83a76b0SSuyog Pawar 
61*c83a76b0SSuyog Pawar /*NOTE : This should be an exact replica of IALG_MemRec, any change in IALG_MemRec
62*c83a76b0SSuyog Pawar          must be replected here*/
63*c83a76b0SSuyog Pawar typedef struct
64*c83a76b0SSuyog Pawar {
65*c83a76b0SSuyog Pawar     UWORD32 u4_size; /* Size in bytes */
66*c83a76b0SSuyog Pawar     WORD32 i4_alignment; /* Alignment in bytes */
67*c83a76b0SSuyog Pawar     ITT_MEM_REGION_E
68*c83a76b0SSuyog Pawar     e_mem_region; /* decides which memory region to be placed */
69*c83a76b0SSuyog Pawar     ITT_MEM_USAGE_TYPE_E e_usage; /* memory is scratch or persistent */
70*c83a76b0SSuyog Pawar     void *pv_base; /* Base pointer for allocated memory */
71*c83a76b0SSuyog Pawar } itt_memtab_t;
72*c83a76b0SSuyog Pawar 
fill_memtab(itt_memtab_t * ps_mem_tab,WORD32 u4_size,WORD32 i4_alignment,ITT_MEM_USAGE_TYPE_E e_usage,ITT_MEM_REGION_E e_mem_region)73*c83a76b0SSuyog Pawar static __inline void fill_memtab(
74*c83a76b0SSuyog Pawar     itt_memtab_t *ps_mem_tab,
75*c83a76b0SSuyog Pawar     WORD32 u4_size,
76*c83a76b0SSuyog Pawar     WORD32 i4_alignment,
77*c83a76b0SSuyog Pawar     ITT_MEM_USAGE_TYPE_E e_usage,
78*c83a76b0SSuyog Pawar     ITT_MEM_REGION_E e_mem_region)
79*c83a76b0SSuyog Pawar {
80*c83a76b0SSuyog Pawar     /* Make the size next multiple of alignment */
81*c83a76b0SSuyog Pawar     WORD32 i4_aligned_size = (((u4_size) + (i4_alignment - 1)) & (~(i4_alignment - 1)));
82*c83a76b0SSuyog Pawar 
83*c83a76b0SSuyog Pawar     /* Fill the memtab */
84*c83a76b0SSuyog Pawar     ps_mem_tab->u4_size = i4_aligned_size;
85*c83a76b0SSuyog Pawar     ps_mem_tab->i4_alignment = i4_alignment;
86*c83a76b0SSuyog Pawar     ps_mem_tab->e_usage = e_usage;
87*c83a76b0SSuyog Pawar     ps_mem_tab->e_mem_region = e_mem_region;
88*c83a76b0SSuyog Pawar }
89*c83a76b0SSuyog Pawar 
90*c83a76b0SSuyog Pawar static __inline WORD32
use_or_fill_base(itt_memtab_t * ps_mem_tab,void ** ptr_to_be_filled,ITT_FUNC_TYPE_E e_func_type)91*c83a76b0SSuyog Pawar     use_or_fill_base(itt_memtab_t *ps_mem_tab, void **ptr_to_be_filled, ITT_FUNC_TYPE_E e_func_type)
92*c83a76b0SSuyog Pawar {
93*c83a76b0SSuyog Pawar     /* Fill base for freeing the allocated memory */
94*c83a76b0SSuyog Pawar     if(e_func_type == FILL_BASE)
95*c83a76b0SSuyog Pawar     {
96*c83a76b0SSuyog Pawar         if(ptr_to_be_filled[0] != 0)
97*c83a76b0SSuyog Pawar         {
98*c83a76b0SSuyog Pawar             ps_mem_tab->pv_base = ptr_to_be_filled[0];
99*c83a76b0SSuyog Pawar             return (0);
100*c83a76b0SSuyog Pawar         }
101*c83a76b0SSuyog Pawar         else
102*c83a76b0SSuyog Pawar         {
103*c83a76b0SSuyog Pawar             return (-1);
104*c83a76b0SSuyog Pawar         }
105*c83a76b0SSuyog Pawar     }
106*c83a76b0SSuyog Pawar     /* obtain the allocated memory from base pointer */
107*c83a76b0SSuyog Pawar     if(e_func_type == USE_BASE)
108*c83a76b0SSuyog Pawar     {
109*c83a76b0SSuyog Pawar         if(ps_mem_tab->pv_base != 0)
110*c83a76b0SSuyog Pawar         {
111*c83a76b0SSuyog Pawar             ptr_to_be_filled[0] = ps_mem_tab->pv_base;
112*c83a76b0SSuyog Pawar             return (0);
113*c83a76b0SSuyog Pawar         }
114*c83a76b0SSuyog Pawar         else
115*c83a76b0SSuyog Pawar         {
116*c83a76b0SSuyog Pawar             return (-1);
117*c83a76b0SSuyog Pawar         }
118*c83a76b0SSuyog Pawar     }
119*c83a76b0SSuyog Pawar     return (0);
120*c83a76b0SSuyog Pawar }
121*c83a76b0SSuyog Pawar 
122*c83a76b0SSuyog Pawar #endif /* _MEM_REQ_AND_ACQ_H_*/
123