1*4882a593Smuzhiyun /* GPL-2.0 WITH Linux-syscall-note OR Apache 2.0 */ 2*4882a593Smuzhiyun /* Copyright (c) 2021 Fuzhou Rockchip Electronics Co., Ltd */ 3*4882a593Smuzhiyun 4*4882a593Smuzhiyun #ifndef INCLUDE_RT_MPI_RK_MPI_SYS_H__ 5*4882a593Smuzhiyun #define INCLUDE_RT_MPI_RK_MPI_SYS_H__ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #include "rk_type.h" 8*4882a593Smuzhiyun #include "rk_debug.h" 9*4882a593Smuzhiyun #include "rk_common.h" 10*4882a593Smuzhiyun #include "rk_comm_sys.h" 11*4882a593Smuzhiyun #include "rk_comm_mb.h" 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #ifdef __cplusplus 14*4882a593Smuzhiyun #if __cplusplus 15*4882a593Smuzhiyun extern "C" { 16*4882a593Smuzhiyun #endif 17*4882a593Smuzhiyun #endif /* End of #ifdef __cplusplus */ 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_Init(RK_VOID); 20*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_Exit(RK_VOID); 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_Bind(const MPP_CHN_S *pstSrcChn, const MPP_CHN_S *pstDestChn); 23*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_UnBind(const MPP_CHN_S *pstSrcChn, const MPP_CHN_S *pstDestChn); 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_GetBindbyDest(const MPP_CHN_S *pstDestChn, MPP_CHN_S *pstSrcChn); 26*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_GetBindbySrc(const MPP_CHN_S *pstSrcChn, MPP_BIND_DEST_S *pstBindDest); 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun /* alloc mmz memory in user context */ 29*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_MmzAlloc(MB_BLK *pBlk, const RK_CHAR *pstrMmb, const RK_CHAR *pstrZone, RK_U32 u32Len); 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun /* alloc mmz memory with cache */ 32*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_MmzAlloc_Cached(MB_BLK *pBlk, const RK_CHAR *pstrMmb, const RK_CHAR *pstrZone, RK_U32 u32Len); 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun /* alloc mmz memory with flags */ 35*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_MmzAllocEx(MB_BLK *pBlk, const RK_CHAR *pstrMmb, const RK_CHAR *pstrZone, 36*4882a593Smuzhiyun RK_U32 u32Len, RK_U32 u32HeapFlags); 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun /* free mmz memory in user context */ 39*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_MmzFree(MB_BLK blk); 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun /* flush cache */ 42*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_MmzFlushCache(MB_BLK blk, RK_BOOL bReadOnly); 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_Malloc(MB_BLK *pBlk, RK_U32 u32Len); 45*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_Free(MB_BLK blk); 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_CreateMB(MB_BLK *pBlk, MB_EXT_CONFIG_S *pstMbExtConfig); 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun /* 50*4882a593Smuzhiyun ** u64Base is the global PTS of the system. 51*4882a593Smuzhiyun ** ADVICE: 52*4882a593Smuzhiyun ** 1. Better to call RK_MPI_SYS_GetCurPTS on the host board to get u64Base. 53*4882a593Smuzhiyun ** 2. When os start up, call RK_MPI_SYS_InitPTSBase to set the init PTS. 54*4882a593Smuzhiyun ** 3. When media bussines is running, synchronize the PTS one time per minute 55*4882a593Smuzhiyun ** by calling RK_MPI_SYS_SyncPTS. 56*4882a593Smuzhiyun */ 57*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_GetCurPTS(RK_U64 *pu64CurPTS); 58*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_InitPTSBase(RK_U64 u64PTSBase); 59*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_SyncPTS(RK_U64 u64PTSBase); 60*4882a593Smuzhiyun 61*4882a593Smuzhiyun /* set mpp channel input stream mode */ 62*4882a593Smuzhiyun RK_S32 RK_MPI_SYS_SetChnInputMode(const MPP_CHN_S *pstChn, CHN_INPUT_MODE_E mode); 63*4882a593Smuzhiyun 64*4882a593Smuzhiyun /* log level configuration */ 65*4882a593Smuzhiyun RK_S32 RK_MPI_LOG_SetLevelConf(LOG_LEVEL_CONF_S *pstConf); 66*4882a593Smuzhiyun RK_S32 RK_MPI_LOG_GetLevelConf(LOG_LEVEL_CONF_S *pstConf); 67*4882a593Smuzhiyun 68*4882a593Smuzhiyun #ifdef __cplusplus 69*4882a593Smuzhiyun #if __cplusplus 70*4882a593Smuzhiyun } 71*4882a593Smuzhiyun #endif 72*4882a593Smuzhiyun #endif /* End of #ifdef __cplusplus */ 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun #endif /* INCLUDE_RT_MPI_RK_MPI_SYS_H__ */ 75*4882a593Smuzhiyun 76