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 5*4882a593Smuzhiyun #ifndef INCLUDE_RT_MPI_RK_MPI_AVS_H_ 6*4882a593Smuzhiyun #define INCLUDE_RT_MPI_RK_MPI_AVS_H_ 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #include "rk_common.h" 9*4882a593Smuzhiyun #include "rk_comm_video.h" 10*4882a593Smuzhiyun #include "rk_comm_mb.h" 11*4882a593Smuzhiyun #include "rk_comm_avs.h" 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #ifdef __cplusplus 14*4882a593Smuzhiyun #if __cplusplus 15*4882a593Smuzhiyun extern "C" { 16*4882a593Smuzhiyun #endif 17*4882a593Smuzhiyun #endif /* __cplusplus */ 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun /* Group Settings */ 20*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_CreateGrp(AVS_GRP AVSGrp, const AVS_GRP_ATTR_S *pstGrpAttr); 21*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_DestroyGrp(AVS_GRP AVSGrp); 22*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_StartGrp(AVS_GRP AVSGrp); 23*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_StopGrp(AVS_GRP AVSGrp); 24*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_ResetGrp(AVS_GRP AVSGrp); 25*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_GetGrpAttr(AVS_GRP AVSGrp, AVS_GRP_ATTR_S *pstGrpAttr); 26*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_SetGrpAttr(AVS_GRP AVSGrp, const AVS_GRP_ATTR_S *pstGrpAttr); 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun /* Pipe Settings */ 29*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_SendPipeFrame(AVS_GRP AVSGrp, AVS_PIPE AVSPipe, 30*4882a593Smuzhiyun const VIDEO_FRAME_INFO_S *pstVideoFrame, RK_S32 s32MilliSec); 31*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_GetPipeFrame(AVS_GRP AVSGrp, AVS_PIPE AVSPipe, 32*4882a593Smuzhiyun VIDEO_FRAME_INFO_S *pstVideoFrame); 33*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_ReleasePipeFrame(AVS_GRP AVSGrp, AVS_PIPE AVSPipe, 34*4882a593Smuzhiyun const VIDEO_FRAME_INFO_S *pstVideoFrame); 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun /* Channel Settings */ 37*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_SetChnAttr(AVS_GRP AVSGrp, AVS_CHN AVSChn, const AVS_CHN_ATTR_S *pstChnAttr); 38*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_GetChnAttr(AVS_GRP AVSGrp, AVS_CHN AVSChn, AVS_CHN_ATTR_S *pstChnAttr); 39*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_EnableChn(AVS_GRP AVSGrp, AVS_CHN AVSChn); 40*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_DisableChn(AVS_GRP AVSGrp, AVS_CHN AVSChn); 41*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_GetChnFrame(AVS_GRP AVSGrp, AVS_CHN AVSChn, 42*4882a593Smuzhiyun VIDEO_FRAME_INFO_S *pstVideoFrame, RK_S32 s32MilliSec); 43*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_ReleaseChnFrame(AVS_GRP AVSGrp, AVS_CHN AVSChn, 44*4882a593Smuzhiyun const VIDEO_FRAME_INFO_S *pstVideoFrame); 45*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_SetModParam(const AVS_MOD_PARAM_S *pstModParam); 46*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_GetModParam(AVS_MOD_PARAM_S *pstModParam); 47*4882a593Smuzhiyun 48*4882a593Smuzhiyun RK_S32 RK_MPI_AVS_GetFinalLut(AVS_GRP AVSGrp, AVS_FINAL_LUT_S *pstFinalLut); 49*4882a593Smuzhiyun 50*4882a593Smuzhiyun #ifdef __cplusplus 51*4882a593Smuzhiyun #if __cplusplus 52*4882a593Smuzhiyun } 53*4882a593Smuzhiyun #endif 54*4882a593Smuzhiyun #endif /* __cplusplus */ 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun #endif /* INCLUDE_RT_MPI_RK_MPI_AVS_H_ */ 57