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_MPI_VDEC_H_ 5*4882a593Smuzhiyun #define INCLUDE_RT_MPI_MPI_VDEC_H_ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #include "rk_common.h" 8*4882a593Smuzhiyun #include "rk_comm_video.h" 9*4882a593Smuzhiyun #include "rk_comm_vdec.h" 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #ifdef __cplusplus 12*4882a593Smuzhiyun #if __cplusplus 13*4882a593Smuzhiyun extern "C" { 14*4882a593Smuzhiyun #endif 15*4882a593Smuzhiyun #endif /* __cplusplus */ 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_CreateChn(VDEC_CHN VdChn, const VDEC_CHN_ATTR_S *pstAttr); 18*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_DestroyChn(VDEC_CHN VdChn); 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_GetChnAttr(VDEC_CHN VdChn, VDEC_CHN_ATTR_S *pstAttr); 21*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_SetChnAttr(VDEC_CHN VdChn, const VDEC_CHN_ATTR_S *pstAttr); 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_StartRecvStream(VDEC_CHN VdChn); 24*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_StopRecvStream(VDEC_CHN VdChn); 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_ResetChn(VDEC_CHN VdChn); 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun /* s32MilliSec: -1 is block,0 is no block,other positive number is timeout */ 29*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_SendStream(VDEC_CHN VdChn, const VDEC_STREAM_S *pstStream, RK_S32 s32MilliSec); 30*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_GetFrame(VDEC_CHN VdChn, VIDEO_FRAME_INFO_S *pstFrameInfo, RK_S32 s32MilliSec); 31*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_ReleaseFrame(VDEC_CHN VdChn, const VIDEO_FRAME_INFO_S *pstFrameInfo); 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_SetRotation(VDEC_CHN VdChn, ROTATION_E enRotation); 34*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_GetRotation(VDEC_CHN VdChn, ROTATION_E *penRotation); 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_GetModParam(VDEC_MOD_PARAM_S *pstModParam); 37*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_SetModParam(const VDEC_MOD_PARAM_S* pstModParam); 38*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_SetDisplayMode(VDEC_CHN VdChn, VIDEO_DISPLAY_MODE_E enDisplayMode); 39*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_GetDisplayMode(VDEC_CHN VdChn, VIDEO_DISPLAY_MODE_E *penDisplayMode); 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_QueryStatus(VDEC_CHN VdChn, VDEC_CHN_STATUS_S *pstStatus); 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_SetChnParam(VDEC_CHN VdChn, const VDEC_CHN_PARAM_S *pstParam); 44*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_GetChnParam(VDEC_CHN VdChn, VDEC_CHN_PARAM_S *pstParam); 45*4882a593Smuzhiyun 46*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_GetFd(VDEC_CHN VdChn); 47*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_CloseFd(VDEC_CHN VdChn); 48*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_AttachMbPool(VDEC_CHN VdChn, MB_POOL hMbPool); 49*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_DetachMbPool(VDEC_CHN VdChn); 50*4882a593Smuzhiyun 51*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_SetUserPic(VDEC_CHN VdChn, const VIDEO_FRAME_INFO_S *pstUsrPic); 52*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_EnableUserPic(VDEC_CHN VdChn, RK_BOOL bInstant); 53*4882a593Smuzhiyun RK_S32 RK_MPI_VDEC_DisableUserPic(VDEC_CHN VdChn); 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun #ifdef __cplusplus 56*4882a593Smuzhiyun #if __cplusplus 57*4882a593Smuzhiyun } 58*4882a593Smuzhiyun #endif 59*4882a593Smuzhiyun #endif /* __cplusplus */ 60*4882a593Smuzhiyun 61*4882a593Smuzhiyun #endif // INCLUDE_RT_MPI_MPI_VDEC_H_ 62