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