/******************************************************************************
*
* 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
* ih264e_rc_mem_interface.h
*
* @brief
* This file contains function declaration and structures for rate control
* memtabs
*
* @author
* ittiam
*
* @remarks
* The rate control library is a global library across various codecs. It
* anticipates certain structures definitions. Those definitions are to be
* imported from global workspace. Instead of that, the structures needed for
* rc library are copied in to this file and exported to rc library. If the
* structures / enums / ... in the global workspace change, this file also needs
* to be modified accordingly.
*
******************************************************************************
*/
#ifndef IH264E_RC_MEM_INTERFACE_H_
#define IH264E_RC_MEM_INTERFACE_H_
/*****************************************************************************/
/* Function Macros */
/*****************************************************************************/
#define FILL_MEMTAB(m_pv_mem_rec, m_j, m_mem_size, m_align, m_type) \
{ \
m_pv_mem_rec[m_j].u4_size = sizeof(iv_mem_rec_t); \
m_pv_mem_rec[m_j].u4_mem_size = m_mem_size; \
m_pv_mem_rec[m_j].u4_mem_alignment = m_align; \
m_pv_mem_rec[m_j].e_mem_type = m_type; \
}
/*****************************************************************************/
/* Enums */
/*****************************************************************************/
typedef enum
{
ALIGN_BYTE = 1,
ALIGN_WORD16 = 2,
ALIGN_WORD32 = 4,
ALIGN_WORD64 = 8,
ALIGN_128_BYTE = 128
}ITT_MEM_ALIGNMENT_TYPE_E;
typedef enum
{
SCRATCH = 0,
PERSISTENT = 1,
WRITEONCE = 2
}ITT_MEM_USAGE_TYPE_E;
typedef enum
{
L1D = 0,
SL2 = 1,
DDR = 3
}ITT_MEM_REGION_E;
typedef enum
{
GET_NUM_MEMTAB = 0,
FILL_MEMTAB = 1,
USE_BASE = 2,
FILL_BASE =3
}ITT_FUNC_TYPE_E;
/*****************************************************************************/
/* Structures */
/*****************************************************************************/
/*NOTE : This should be an exact replica of IALG_MemRec, any change in IALG_MemRec
must be replicated here*/
typedef struct
{
/* Size in bytes */
UWORD32 u4_size;
/* Alignment in bytes */
WORD32 i4_alignment;
/* decides which memory region to be placed */
ITT_MEM_REGION_E e_mem_region;
/* memory is scratch or persistent */
ITT_MEM_USAGE_TYPE_E e_usage;
/* Base pointer for allocated memory */
void *pv_base;
} itt_memtab_t;
/*****************************************************************************/
/* Extern Function Declarations */
/*****************************************************************************/
/**
******************************************************************************
*
* @brief This function fills memory record attributes
*
* @par Description
* This function fills memory record attributes
*
* @param[in] ps_mem_tab
* pointer to mem records
*
* @param[in] u4_size
* size of the record
*
* @param[in] i4_alignment
* memory alignment size
*
* @param[in] e_usage
* usage
*
* @param[in] e_mem_region
* mem region
*
* @return void
*
******************************************************************************
*/
void 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);
/**
******************************************************************************
*
* @brief This function fills memory record attributes
*
* @par Description
* This function fills memory record attributes
*
* @param[in] ps_mem_tab
* pointer to mem records
*
* @param[in] ptr_to_be_filled
* handle to the memory record storage space
*
* @param[in] e_func_type
* enum that dictates fill memory records or use memory records
*
* @return void
*
******************************************************************************
*/
WORD32 use_or_fill_base(itt_memtab_t *ps_mem_tab, void **ptr_to_be_filled,
ITT_FUNC_TYPE_E e_func_type);
#endif // IH264E_RC_MEM_INTERFACE_H_