11bd4fe43Sopenharmony_ci/* 21bd4fe43Sopenharmony_ci * Copyright (c) 2022 HiSilicon (Shanghai) Technologies CO., LIMITED. 31bd4fe43Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 41bd4fe43Sopenharmony_ci * you may not use this file except in compliance with the License. 51bd4fe43Sopenharmony_ci * You may obtain a copy of the License at 61bd4fe43Sopenharmony_ci * 71bd4fe43Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 81bd4fe43Sopenharmony_ci * 91bd4fe43Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 101bd4fe43Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 111bd4fe43Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 121bd4fe43Sopenharmony_ci * See the License for the specific language governing permissions and 131bd4fe43Sopenharmony_ci * limitations under the License. 141bd4fe43Sopenharmony_ci */ 151bd4fe43Sopenharmony_ci 161bd4fe43Sopenharmony_ci#ifndef __MPI_VPSS_H__ 171bd4fe43Sopenharmony_ci#define __MPI_VPSS_H__ 181bd4fe43Sopenharmony_ci 191bd4fe43Sopenharmony_ci#include "hi_common.h" 201bd4fe43Sopenharmony_ci#include "hi_comm_video.h" 211bd4fe43Sopenharmony_ci#include "hi_comm_vb.h" 221bd4fe43Sopenharmony_ci#include "hi_comm_vpss.h" 231bd4fe43Sopenharmony_ci#include "hi_comm_gdc.h" 241bd4fe43Sopenharmony_ci 251bd4fe43Sopenharmony_ci#ifdef __cplusplus 261bd4fe43Sopenharmony_ci#if __cplusplus 271bd4fe43Sopenharmony_ciextern "C" { 281bd4fe43Sopenharmony_ci#endif 291bd4fe43Sopenharmony_ci#endif /* __cplusplus */ 301bd4fe43Sopenharmony_ci 311bd4fe43Sopenharmony_ci/* Group Settings */ 321bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_CreateGrp(VPSS_GRP VpssGrp, const VPSS_GRP_ATTR_S *pstGrpAttr); 331bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_DestroyGrp(VPSS_GRP VpssGrp); 341bd4fe43Sopenharmony_ci 351bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_StartGrp(VPSS_GRP VpssGrp); 361bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_StopGrp(VPSS_GRP VpssGrp); 371bd4fe43Sopenharmony_ci 381bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_ResetGrp(VPSS_GRP VpssGrp); 391bd4fe43Sopenharmony_ci 401bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpAttr(VPSS_GRP VpssGrp, VPSS_GRP_ATTR_S *pstGrpAttr); 411bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetGrpAttr(VPSS_GRP VpssGrp, const VPSS_GRP_ATTR_S *pstGrpAttr); 421bd4fe43Sopenharmony_ci 431bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetGrpCrop(VPSS_GRP VpssGrp, const VPSS_CROP_INFO_S *pstCropInfo); 441bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpCrop(VPSS_GRP VpssGrp, VPSS_CROP_INFO_S *pstCropInfo); 451bd4fe43Sopenharmony_ci 461bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SendFrame(VPSS_GRP VpssGrp, VPSS_GRP_PIPE VpssGrpPipe, 471bd4fe43Sopenharmony_ci const VIDEO_FRAME_INFO_S *pstVideoFrame, HI_S32 s32MilliSec); 481bd4fe43Sopenharmony_ci 491bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpFrame(VPSS_GRP VpssGrp, VPSS_GRP_PIPE VpssGrpPipe, VIDEO_FRAME_INFO_S *pstVideoFrame); 501bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_ReleaseGrpFrame(VPSS_GRP VpssGrp, VPSS_GRP_PIPE VpssGrpPipe, 511bd4fe43Sopenharmony_ci const VIDEO_FRAME_INFO_S *pstVideoFrame); 521bd4fe43Sopenharmony_ci 531bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_EnableBackupFrame(VPSS_GRP VpssGrp); 541bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_DisableBackupFrame(VPSS_GRP VpssGrp); 551bd4fe43Sopenharmony_ci 561bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetGrpSharpen(VPSS_GRP VpssGrp, const VPSS_GRP_SHARPEN_ATTR_S *pstGrpSharpenAttr); 571bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpSharpen(VPSS_GRP VpssGrp, VPSS_GRP_SHARPEN_ATTR_S *pstGrpSharpenAttr); 581bd4fe43Sopenharmony_ci 591bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetGrpDelay(VPSS_GRP VpssGrp, HI_U32 u32Delay); 601bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpDelay(VPSS_GRP VpssGrp, HI_U32 *pu32Delay); 611bd4fe43Sopenharmony_ci 621bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetGrpFisheyeConfig(VPSS_GRP VpssGrp, const FISHEYE_CONFIG_S *pstFisheyeConfig); 631bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpFisheyeConfig(VPSS_GRP VpssGrp, FISHEYE_CONFIG_S *pstFisheyeConfig); 641bd4fe43Sopenharmony_ci 651bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_EnableUserFrameRateCtrl(VPSS_GRP VpssGrp); 661bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_DisableUserFrameRateCtrl(VPSS_GRP VpssGrp); 671bd4fe43Sopenharmony_ci 681bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetGrpFrameInterruptAttr(VPSS_GRP VpssGrp, const FRAME_INTERRUPT_ATTR_S *pstFrameIntAttr); 691bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpFrameInterruptAttr(VPSS_GRP VpssGrp, FRAME_INTERRUPT_ATTR_S *pstFrameIntAttr); 701bd4fe43Sopenharmony_ci 711bd4fe43Sopenharmony_ci/* Chn Settings */ 721bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VPSS_CHN_ATTR_S *pstChnAttr); 731bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_CHN_ATTR_S *pstChnAttr); 741bd4fe43Sopenharmony_ci 751bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_EnableChn(VPSS_GRP VpssGrp, VPSS_CHN VpssChn); 761bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_DisableChn(VPSS_GRP VpssGrp, VPSS_CHN VpssChn); 771bd4fe43Sopenharmony_ci 781bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnCrop(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VPSS_CROP_INFO_S *pstCropInfo); 791bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnCrop(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_CROP_INFO_S *pstCropInfo); 801bd4fe43Sopenharmony_ci 811bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnRotation(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, ROTATION_E enRotation); 821bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnRotation(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, ROTATION_E *penRotation); 831bd4fe43Sopenharmony_ci 841bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnRotationEx(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, 851bd4fe43Sopenharmony_ci const VPSS_ROTATION_EX_ATTR_S *pstRotationExAttr); 861bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnRotationEx(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_ROTATION_EX_ATTR_S *pstRotationExAttr); 871bd4fe43Sopenharmony_ci 881bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnLDCAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VPSS_LDC_ATTR_S *pstLDCAttr); 891bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnLDCAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_LDC_ATTR_S *pstLDCAttr); 901bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_LDCPosQueryDst2Src(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, 911bd4fe43Sopenharmony_ci const POINT_S *pstDstPointIn, POINT_S *pstSrcPointOut); 921bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_LDCPosQuerySrc2Dst(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, 931bd4fe43Sopenharmony_ci const POINT_S *pstSrcPointIn, POINT_S *pstDstPointOut); 941bd4fe43Sopenharmony_ci 951bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnLDCV3Attr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VPSS_LDCV3_ATTR_S *pstLDCV3Attr); 961bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnLDCV3Attr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_LDCV3_ATTR_S *pstLDCV3Attr); 971bd4fe43Sopenharmony_ci 981bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnSpreadAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const SPREAD_ATTR_S *pstSpreadAttr); 991bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnSpreadAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, SPREAD_ATTR_S *pstSpreadAttr); 1001bd4fe43Sopenharmony_ci 1011bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnFrame(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, 1021bd4fe43Sopenharmony_ci VIDEO_FRAME_INFO_S *pstVideoFrame, HI_S32 s32MilliSec); 1031bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_ReleaseChnFrame(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VIDEO_FRAME_INFO_S *pstVideoFrame); 1041bd4fe43Sopenharmony_ci 1051bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetRegionLuma(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VIDEO_REGION_INFO_S *pstRegionInfo, 1061bd4fe43Sopenharmony_ci HI_U64 *pu64LumaData, HI_S32 s32MilliSec); 1071bd4fe43Sopenharmony_ci 1081bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetLowDelayAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VPSS_LOW_DELAY_INFO_S *pstLowDelayInfo); 1091bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetLowDelayAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_LOW_DELAY_INFO_S *pstLowDelayInfo); 1101bd4fe43Sopenharmony_ci 1111bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnBufWrapAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VPSS_CHN_BUF_WRAP_S *pstVpssChnBufWrap); 1121bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnBufWrapAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_CHN_BUF_WRAP_S *pstVpssChnBufWrap); 1131bd4fe43Sopenharmony_ci 1141bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_TriggerSnapFrame(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, HI_U32 u32FrameCnt); 1151bd4fe43Sopenharmony_ci 1161bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_AttachVbPool(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VB_POOL hVbPool); 1171bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_DetachVbPool(VPSS_GRP VpssGrp, VPSS_CHN VpssChn); 1181bd4fe43Sopenharmony_ci 1191bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_EnableBufferShare(VPSS_GRP VpssGrp, VPSS_CHN VpssChn); 1201bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_DisableBufferShare(VPSS_GRP VpssGrp, VPSS_CHN VpssChn); 1211bd4fe43Sopenharmony_ci 1221bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnAlign(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, HI_U32 u32Align); 1231bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnAlign(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, HI_U32 *pu32Align); 1241bd4fe43Sopenharmony_ci 1251bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetChnProcMode(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_CHN_PROC_MODE_E enVpssChnProcMode); 1261bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnProcMode(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_CHN_PROC_MODE_E *penVpssChnProcMode); 1271bd4fe43Sopenharmony_ci 1281bd4fe43Sopenharmony_ci/* ExtChn Settings */ 1291bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetExtChnAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const VPSS_EXT_CHN_ATTR_S *pstExtChnAttr); 1301bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetExtChnAttr(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, VPSS_EXT_CHN_ATTR_S *pstExtChnAttr); 1311bd4fe43Sopenharmony_ci 1321bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetExtChnFisheye(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, const FISHEYE_ATTR_S *pstFishEyeAttr); 1331bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetExtChnFisheye(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, FISHEYE_ATTR_S *pstFishEyeAttr); 1341bd4fe43Sopenharmony_ci 1351bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_FisheyePosQueryDst2Src(VPSS_GRP VpssGrp, VPSS_CHN VpssChn, HI_U32 u32RegionIndex, 1361bd4fe43Sopenharmony_ci const POINT_S *pstDstPointIn, POINT_S *pstSrcPointOut); 1371bd4fe43Sopenharmony_ci 1381bd4fe43Sopenharmony_ci/* 3DNR */ 1391bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetGrpNRXParam(VPSS_GRP VpssGrp, const VPSS_GRP_NRX_PARAM_S *pstNRXParam); 1401bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetGrpNRXParam(VPSS_GRP VpssGrp, VPSS_GRP_NRX_PARAM_S *pstNRXParam); 1411bd4fe43Sopenharmony_ci 1421bd4fe43Sopenharmony_ci/* Module Param Settings */ 1431bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_SetModParam(const VPSS_MOD_PARAM_S *pstModParam); 1441bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetModParam(VPSS_MOD_PARAM_S *pstModParam); 1451bd4fe43Sopenharmony_ci 1461bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_GetChnFd(VPSS_GRP VpssGrp, VPSS_CHN VpssChn); 1471bd4fe43Sopenharmony_ciHI_S32 HI_MPI_VPSS_CloseFd(HI_VOID); 1481bd4fe43Sopenharmony_ci 1491bd4fe43Sopenharmony_ci#ifdef __cplusplus 1501bd4fe43Sopenharmony_ci#if __cplusplus 1511bd4fe43Sopenharmony_ci} 1521bd4fe43Sopenharmony_ci#endif 1531bd4fe43Sopenharmony_ci#endif /* __cplusplus */ 1541bd4fe43Sopenharmony_ci 1551bd4fe43Sopenharmony_ci#endif /* __MPI_VPSS_H__ */ 1561bd4fe43Sopenharmony_ci 157