android_mt6572_jiabo/hardware/ti/omap4/camera/inc/VideoMetadata.h
2025-09-05 16:56:03 +08:00

54 lines
1.6 KiB
C++

/*
* Copyright (C) Texas Instruments - http://www.ti.com/
*
* 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.
*/
#ifndef VIDEO_METADATA_H
#define VIDEO_METADATA_H
#include <MetadataBufferType.h>
#ifdef __cplusplus
using namespace android;
#endif
#ifdef ANDROID_API_N_OR_LATER
#define CAMERA_METADATA_BUFFER_TYPE kMetadataBufferTypeNativeHandleSource
#else
#define CAMERA_METADATA_BUFFER_TYPE kMetadataBufferTypeCameraSource
#endif
/* This structure is used to pass buffer offset from Camera-Hal to Encoder component
* for specific algorithms like VSTAB & VNF
*
* With mediaserver hardening, Camera-Hal and Encoder are in separate processes.
* These must use VideoNativeHandleMetadata. Ideally, we'd just do something like:
* #include <HardwareAPI.h>
* typedef struct VideoNativeHandleMetadata video_metadata_t;"
* But HardwareAPI.h can't be included from C code like domx.
*
* So: REMEMBER TO ENSURE video_metadata_t MATCHES VideoNativeHandleMetadata!
*/
typedef struct
{
MetadataBufferType eType;
native_handle_t* pHandle;
#ifndef ANDROID_API_N_OR_LATER
int offset;
#endif
}
video_metadata_t;
#endif