xiaoyu/media/samples/example/common/sample_comm_ivs.c

78 lines
1.9 KiB
C
Raw Normal View History

2025-03-04 22:36:42 +08:00
/*
* Copyright 2022 Rockchip Electronics Co. LTD
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
#ifdef __cplusplus
#if __cplusplus
extern "C" {
#endif
#endif /* End of #ifdef __cplusplus */
#include <errno.h>
#include <pthread.h>
#include <stdio.h>
#include <sys/poll.h>
#include <unistd.h>
#include "sample_comm.h"
RK_S32 SAMPLE_COMM_IVS_Create(SAMPLE_IVS_CTX_S *ctx) {
RK_S32 s32Ret = RK_FAILURE;
s32Ret = RK_MPI_IVS_CreateChn(ctx->s32ChnId, &ctx->stIvsAttr);
if (s32Ret != RK_SUCCESS) {
RK_LOGE("RK_MPI_IVS_CreateChn failure:%X", s32Ret);
return s32Ret;
}
#if defined(RV1106)
IVS_MD_ATTR_S stMdAttr;
memset(&stMdAttr, 0, sizeof(stMdAttr));
s32Ret = RK_MPI_IVS_GetMdAttr(0, &stMdAttr);
if (s32Ret) {
RK_LOGE("ivs get mdattr failed:%x", s32Ret);
return -1;
}
stMdAttr.s32ThreshSad = 40;
stMdAttr.s32ThreshMove = 2;
// stMdAttr.s32SwitchSad = 0;
s32Ret = RK_MPI_IVS_SetMdAttr(0, &stMdAttr);
if (s32Ret) {
RK_LOGE("ivs set mdattr failed:%x", s32Ret);
return -1;
}
#endif
return 0;
}
RK_S32 SAMPLE_COMM_IVS_Destroy(RK_S32 s32IvsChnid) {
RK_S32 s32Ret = RK_FAILURE;
s32Ret = RK_MPI_IVS_DestroyChn(s32IvsChnid);
if (s32Ret != RK_SUCCESS) {
RK_LOGE("RK_MPI_IVS_DestroyChn failure:%X", s32Ret);
return s32Ret;
}
#if defined(RV1106)
RK_MPI_SYS_WaitFreeMB();
#endif
return s32Ret;
}
#ifdef __cplusplus
#if __cplusplus
}
#endif
#endif /* End of #ifdef __cplusplus */