android: camera_device: Use the new CameraMetadata helper class
Simplify the implementation of metadata handling in the CameraDevice class by using the new CameraMetadata helper class. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Jacopo Mondi <jacopo@jmondi.org>
This commit is contained in:
parent
9214e2b493
commit
3986009cf1
2 changed files with 223 additions and 331 deletions
|
@ -7,10 +7,10 @@
|
||||||
|
|
||||||
#include "camera_device.h"
|
#include "camera_device.h"
|
||||||
|
|
||||||
#include <system/camera_metadata.h>
|
|
||||||
|
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
#include "utils.h"
|
||||||
|
|
||||||
|
#include "camera_metadata.h"
|
||||||
#include "thread_rpc.h"
|
#include "thread_rpc.h"
|
||||||
|
|
||||||
using namespace libcamera;
|
using namespace libcamera;
|
||||||
|
@ -59,12 +59,10 @@ CameraDevice::CameraDevice(unsigned int id, const std::shared_ptr<Camera> &camer
|
||||||
CameraDevice::~CameraDevice()
|
CameraDevice::~CameraDevice()
|
||||||
{
|
{
|
||||||
if (staticMetadata_)
|
if (staticMetadata_)
|
||||||
free_camera_metadata(staticMetadata_);
|
delete staticMetadata_;
|
||||||
staticMetadata_ = nullptr;
|
|
||||||
|
|
||||||
if (requestTemplate_)
|
if (requestTemplate_)
|
||||||
free_camera_metadata(requestTemplate_);
|
delete requestTemplate_;
|
||||||
requestTemplate_ = nullptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -117,10 +115,8 @@ void CameraDevice::setCallbacks(const camera3_callback_ops_t *callbacks)
|
||||||
*/
|
*/
|
||||||
camera_metadata_t *CameraDevice::getStaticMetadata()
|
camera_metadata_t *CameraDevice::getStaticMetadata()
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
|
|
||||||
if (staticMetadata_)
|
if (staticMetadata_)
|
||||||
return staticMetadata_;
|
return staticMetadata_->get();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The here reported metadata are enough to implement a basic capture
|
* The here reported metadata are enough to implement a basic capture
|
||||||
|
@ -130,18 +126,23 @@ camera_metadata_t *CameraDevice::getStaticMetadata()
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* \todo Keep this in sync with the actual number of entries.
|
* \todo Keep this in sync with the actual number of entries.
|
||||||
* Currently: 46 entries, 390 bytes
|
* Currently: 47 entries, 390 bytes
|
||||||
*/
|
*/
|
||||||
staticMetadata_ = allocate_camera_metadata(50, 500);
|
staticMetadata_ = new CameraMetadata(50, 500);
|
||||||
|
if (!staticMetadata_->isValid()) {
|
||||||
|
LOG(HAL, Error) << "Failed to allocate static metadata";
|
||||||
|
delete staticMetadata_;
|
||||||
|
staticMetadata_ = nullptr;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
/* Color correction static metadata. */
|
/* Color correction static metadata. */
|
||||||
std::vector<uint8_t> aberrationModes = {
|
std::vector<uint8_t> aberrationModes = {
|
||||||
ANDROID_COLOR_CORRECTION_ABERRATION_MODE_OFF,
|
ANDROID_COLOR_CORRECTION_ABERRATION_MODE_OFF,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_COLOR_CORRECTION_AVAILABLE_ABERRATION_MODES,
|
||||||
ANDROID_COLOR_CORRECTION_AVAILABLE_ABERRATION_MODES,
|
aberrationModes.data(),
|
||||||
aberrationModes.data(), aberrationModes.size());
|
aberrationModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Control static metadata. */
|
/* Control static metadata. */
|
||||||
std::vector<uint8_t> aeAvailableAntiBandingModes = {
|
std::vector<uint8_t> aeAvailableAntiBandingModes = {
|
||||||
|
@ -150,294 +151,228 @@ camera_metadata_t *CameraDevice::getStaticMetadata()
|
||||||
ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ,
|
ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ,
|
||||||
ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO,
|
ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES,
|
||||||
ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES,
|
|
||||||
aeAvailableAntiBandingModes.data(),
|
aeAvailableAntiBandingModes.data(),
|
||||||
aeAvailableAntiBandingModes.size());
|
aeAvailableAntiBandingModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> aeAvailableModes = {
|
std::vector<uint8_t> aeAvailableModes = {
|
||||||
ANDROID_CONTROL_AE_MODE_ON,
|
ANDROID_CONTROL_AE_MODE_ON,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AE_AVAILABLE_MODES,
|
||||||
ANDROID_CONTROL_AE_AVAILABLE_MODES,
|
aeAvailableModes.data(),
|
||||||
aeAvailableModes.data(), aeAvailableModes.size());
|
aeAvailableModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<int32_t> availableAeFpsTarget = {
|
std::vector<int32_t> availableAeFpsTarget = {
|
||||||
15, 30,
|
15, 30,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES,
|
||||||
ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES,
|
|
||||||
availableAeFpsTarget.data(),
|
availableAeFpsTarget.data(),
|
||||||
availableAeFpsTarget.size());
|
availableAeFpsTarget.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<int32_t> aeCompensationRange = {
|
std::vector<int32_t> aeCompensationRange = {
|
||||||
0, 0,
|
0, 0,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AE_COMPENSATION_RANGE,
|
||||||
ANDROID_CONTROL_AE_COMPENSATION_RANGE,
|
|
||||||
aeCompensationRange.data(),
|
aeCompensationRange.data(),
|
||||||
aeCompensationRange.size());
|
aeCompensationRange.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
const camera_metadata_rational_t aeCompensationStep[] = {
|
const camera_metadata_rational_t aeCompensationStep[] = {
|
||||||
{ 0, 1 }
|
{ 0, 1 }
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AE_COMPENSATION_STEP,
|
||||||
ANDROID_CONTROL_AE_COMPENSATION_STEP,
|
|
||||||
aeCompensationStep, 1);
|
aeCompensationStep, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> availableAfModes = {
|
std::vector<uint8_t> availableAfModes = {
|
||||||
ANDROID_CONTROL_AF_MODE_OFF,
|
ANDROID_CONTROL_AF_MODE_OFF,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AF_AVAILABLE_MODES,
|
||||||
ANDROID_CONTROL_AF_AVAILABLE_MODES,
|
availableAfModes.data(),
|
||||||
availableAfModes.data(), availableAfModes.size());
|
availableAfModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> availableEffects = {
|
std::vector<uint8_t> availableEffects = {
|
||||||
ANDROID_CONTROL_EFFECT_MODE_OFF,
|
ANDROID_CONTROL_EFFECT_MODE_OFF,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AVAILABLE_EFFECTS,
|
||||||
ANDROID_CONTROL_AVAILABLE_EFFECTS,
|
availableEffects.data(),
|
||||||
availableEffects.data(), availableEffects.size());
|
availableEffects.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> availableSceneModes = {
|
std::vector<uint8_t> availableSceneModes = {
|
||||||
ANDROID_CONTROL_SCENE_MODE_DISABLED,
|
ANDROID_CONTROL_SCENE_MODE_DISABLED,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AVAILABLE_SCENE_MODES,
|
||||||
ANDROID_CONTROL_AVAILABLE_SCENE_MODES,
|
availableSceneModes.data(),
|
||||||
availableSceneModes.data(), availableSceneModes.size());
|
availableSceneModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> availableStabilizationModes = {
|
std::vector<uint8_t> availableStabilizationModes = {
|
||||||
ANDROID_CONTROL_VIDEO_STABILIZATION_MODE_OFF,
|
ANDROID_CONTROL_VIDEO_STABILIZATION_MODE_OFF,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES,
|
||||||
ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES,
|
|
||||||
availableStabilizationModes.data(),
|
availableStabilizationModes.data(),
|
||||||
availableStabilizationModes.size());
|
availableStabilizationModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> availableAwbModes = {
|
std::vector<uint8_t> availableAwbModes = {
|
||||||
ANDROID_CONTROL_AWB_MODE_OFF,
|
ANDROID_CONTROL_AWB_MODE_OFF,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AWB_AVAILABLE_MODES,
|
||||||
ANDROID_CONTROL_AWB_AVAILABLE_MODES,
|
availableAwbModes.data(),
|
||||||
availableAwbModes.data(), availableAwbModes.size());
|
availableAwbModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<int32_t> availableMaxRegions = {
|
std::vector<int32_t> availableMaxRegions = {
|
||||||
0, 0, 0,
|
0, 0, 0,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_MAX_REGIONS,
|
||||||
ANDROID_CONTROL_MAX_REGIONS,
|
availableMaxRegions.data(),
|
||||||
availableMaxRegions.data(), availableMaxRegions.size());
|
availableMaxRegions.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> sceneModesOverride = {
|
std::vector<uint8_t> sceneModesOverride = {
|
||||||
ANDROID_CONTROL_AE_MODE_ON,
|
ANDROID_CONTROL_AE_MODE_ON,
|
||||||
ANDROID_CONTROL_AWB_MODE_AUTO,
|
ANDROID_CONTROL_AWB_MODE_AUTO,
|
||||||
ANDROID_CONTROL_AF_MODE_AUTO,
|
ANDROID_CONTROL_AF_MODE_AUTO,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_SCENE_MODE_OVERRIDES,
|
||||||
ANDROID_CONTROL_SCENE_MODE_OVERRIDES,
|
sceneModesOverride.data(),
|
||||||
sceneModesOverride.data(), sceneModesOverride.size());
|
sceneModesOverride.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t aeLockAvailable = ANDROID_CONTROL_AE_LOCK_AVAILABLE_FALSE;
|
uint8_t aeLockAvailable = ANDROID_CONTROL_AE_LOCK_AVAILABLE_FALSE;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AE_LOCK_AVAILABLE,
|
||||||
ANDROID_CONTROL_AE_LOCK_AVAILABLE,
|
|
||||||
&aeLockAvailable, 1);
|
&aeLockAvailable, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t awbLockAvailable = ANDROID_CONTROL_AWB_LOCK_AVAILABLE_FALSE;
|
uint8_t awbLockAvailable = ANDROID_CONTROL_AWB_LOCK_AVAILABLE_FALSE;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AWB_LOCK_AVAILABLE,
|
||||||
ANDROID_CONTROL_AWB_LOCK_AVAILABLE,
|
|
||||||
&awbLockAvailable, 1);
|
&awbLockAvailable, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
char availableControlModes = ANDROID_CONTROL_MODE_AUTO;
|
char availableControlModes = ANDROID_CONTROL_MODE_AUTO;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_CONTROL_AVAILABLE_MODES,
|
||||||
ANDROID_CONTROL_AVAILABLE_MODES,
|
|
||||||
&availableControlModes, 1);
|
&availableControlModes, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* JPEG static metadata. */
|
/* JPEG static metadata. */
|
||||||
std::vector<int32_t> availableThumbnailSizes = {
|
std::vector<int32_t> availableThumbnailSizes = {
|
||||||
0, 0,
|
0, 0,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES,
|
||||||
ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES,
|
|
||||||
availableThumbnailSizes.data(),
|
availableThumbnailSizes.data(),
|
||||||
availableThumbnailSizes.size());
|
availableThumbnailSizes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Sensor static metadata. */
|
/* Sensor static metadata. */
|
||||||
int32_t pixelArraySize[] = {
|
int32_t pixelArraySize[] = {
|
||||||
2592, 1944,
|
2592, 1944,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_INFO_PIXEL_ARRAY_SIZE,
|
||||||
ANDROID_SENSOR_INFO_PIXEL_ARRAY_SIZE,
|
|
||||||
&pixelArraySize, 2);
|
&pixelArraySize, 2);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
int32_t sensorSizes[] = {
|
int32_t sensorSizes[] = {
|
||||||
0, 0, 2560, 1920,
|
0, 0, 2560, 1920,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_INFO_ACTIVE_ARRAY_SIZE,
|
||||||
ANDROID_SENSOR_INFO_ACTIVE_ARRAY_SIZE,
|
|
||||||
&sensorSizes, 4);
|
&sensorSizes, 4);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
int32_t sensitivityRange[] = {
|
int32_t sensitivityRange[] = {
|
||||||
32, 2400,
|
32, 2400,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_INFO_SENSITIVITY_RANGE,
|
||||||
ANDROID_SENSOR_INFO_SENSITIVITY_RANGE,
|
|
||||||
&sensitivityRange, 2);
|
&sensitivityRange, 2);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint16_t filterArr = ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT_GRBG;
|
uint16_t filterArr = ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT_GRBG;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT,
|
||||||
ANDROID_SENSOR_INFO_COLOR_FILTER_ARRANGEMENT,
|
|
||||||
&filterArr, 1);
|
&filterArr, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
int64_t exposureTimeRange[] = {
|
int64_t exposureTimeRange[] = {
|
||||||
100000, 200000000,
|
100000, 200000000,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_INFO_EXPOSURE_TIME_RANGE,
|
||||||
ANDROID_SENSOR_INFO_EXPOSURE_TIME_RANGE,
|
|
||||||
&exposureTimeRange, 2);
|
&exposureTimeRange, 2);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
int32_t orientation = 0;
|
int32_t orientation = 0;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_ORIENTATION,
|
||||||
ANDROID_SENSOR_ORIENTATION,
|
|
||||||
&orientation, 1);
|
&orientation, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<int32_t> testPatterModes = {
|
std::vector<int32_t> testPatterModes = {
|
||||||
ANDROID_SENSOR_TEST_PATTERN_MODE_OFF,
|
ANDROID_SENSOR_TEST_PATTERN_MODE_OFF,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_AVAILABLE_TEST_PATTERN_MODES,
|
||||||
ANDROID_SENSOR_AVAILABLE_TEST_PATTERN_MODES,
|
testPatterModes.data(),
|
||||||
testPatterModes.data(), testPatterModes.size());
|
testPatterModes.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<float> physicalSize = {
|
std::vector<float> physicalSize = {
|
||||||
2592, 1944,
|
2592, 1944,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_INFO_PHYSICAL_SIZE,
|
||||||
ANDROID_SENSOR_INFO_PHYSICAL_SIZE,
|
physicalSize.data(),
|
||||||
physicalSize.data(), physicalSize.size());
|
physicalSize.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t timestampSource = ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE_UNKNOWN;
|
uint8_t timestampSource = ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE_UNKNOWN;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE,
|
||||||
ANDROID_SENSOR_INFO_TIMESTAMP_SOURCE,
|
|
||||||
×tampSource, 1);
|
×tampSource, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Statistics static metadata. */
|
/* Statistics static metadata. */
|
||||||
uint8_t faceDetectMode = ANDROID_STATISTICS_FACE_DETECT_MODE_OFF;
|
uint8_t faceDetectMode = ANDROID_STATISTICS_FACE_DETECT_MODE_OFF;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_STATISTICS_INFO_AVAILABLE_FACE_DETECT_MODES,
|
||||||
ANDROID_STATISTICS_INFO_AVAILABLE_FACE_DETECT_MODES,
|
|
||||||
&faceDetectMode, 1);
|
&faceDetectMode, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
int32_t maxFaceCount = 0;
|
int32_t maxFaceCount = 0;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_STATISTICS_INFO_MAX_FACE_COUNT,
|
||||||
ANDROID_STATISTICS_INFO_MAX_FACE_COUNT,
|
|
||||||
&maxFaceCount, 1);
|
&maxFaceCount, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Sync static metadata. */
|
/* Sync static metadata. */
|
||||||
int32_t maxLatency = ANDROID_SYNC_MAX_LATENCY_UNKNOWN;
|
int32_t maxLatency = ANDROID_SYNC_MAX_LATENCY_UNKNOWN;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SYNC_MAX_LATENCY, &maxLatency, 1);
|
||||||
ANDROID_SYNC_MAX_LATENCY, &maxLatency, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Flash static metadata. */
|
/* Flash static metadata. */
|
||||||
char flashAvailable = ANDROID_FLASH_INFO_AVAILABLE_FALSE;
|
char flashAvailable = ANDROID_FLASH_INFO_AVAILABLE_FALSE;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_FLASH_INFO_AVAILABLE,
|
||||||
ANDROID_FLASH_INFO_AVAILABLE,
|
|
||||||
&flashAvailable, 1);
|
&flashAvailable, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Lens static metadata. */
|
/* Lens static metadata. */
|
||||||
std::vector<float> lensApertures = {
|
std::vector<float> lensApertures = {
|
||||||
2.53 / 100,
|
2.53 / 100,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_LENS_INFO_AVAILABLE_APERTURES,
|
||||||
ANDROID_LENS_INFO_AVAILABLE_APERTURES,
|
lensApertures.data(),
|
||||||
lensApertures.data(), lensApertures.size());
|
lensApertures.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t lensFacing = ANDROID_LENS_FACING_FRONT;
|
uint8_t lensFacing = ANDROID_LENS_FACING_FRONT;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_LENS_FACING, &lensFacing, 1);
|
||||||
ANDROID_LENS_FACING, &lensFacing, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<float> lensFocalLenghts = {
|
std::vector<float> lensFocalLenghts = {
|
||||||
1,
|
1,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_LENS_INFO_AVAILABLE_FOCAL_LENGTHS,
|
||||||
ANDROID_LENS_INFO_AVAILABLE_FOCAL_LENGTHS,
|
|
||||||
lensFocalLenghts.data(),
|
lensFocalLenghts.data(),
|
||||||
lensFocalLenghts.size());
|
lensFocalLenghts.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> opticalStabilizations = {
|
std::vector<uint8_t> opticalStabilizations = {
|
||||||
ANDROID_LENS_OPTICAL_STABILIZATION_MODE_OFF,
|
ANDROID_LENS_OPTICAL_STABILIZATION_MODE_OFF,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_LENS_INFO_AVAILABLE_OPTICAL_STABILIZATION,
|
||||||
ANDROID_LENS_INFO_AVAILABLE_OPTICAL_STABILIZATION,
|
|
||||||
opticalStabilizations.data(),
|
opticalStabilizations.data(),
|
||||||
opticalStabilizations.size());
|
opticalStabilizations.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
float hypeFocalDistance = 0;
|
float hypeFocalDistance = 0;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_LENS_INFO_HYPERFOCAL_DISTANCE,
|
||||||
ANDROID_LENS_INFO_HYPERFOCAL_DISTANCE,
|
|
||||||
&hypeFocalDistance, 1);
|
&hypeFocalDistance, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
float minFocusDistance = 0;
|
float minFocusDistance = 0;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE,
|
||||||
ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE,
|
|
||||||
&minFocusDistance, 1);
|
&minFocusDistance, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Noise reduction modes. */
|
/* Noise reduction modes. */
|
||||||
uint8_t noiseReductionModes = ANDROID_NOISE_REDUCTION_MODE_OFF;
|
uint8_t noiseReductionModes = ANDROID_NOISE_REDUCTION_MODE_OFF;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_NOISE_REDUCTION_AVAILABLE_NOISE_REDUCTION_MODES,
|
||||||
ANDROID_NOISE_REDUCTION_AVAILABLE_NOISE_REDUCTION_MODES,
|
|
||||||
&noiseReductionModes, 1);
|
&noiseReductionModes, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Scaler static metadata. */
|
/* Scaler static metadata. */
|
||||||
float maxDigitalZoom = 1;
|
float maxDigitalZoom = 1;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SCALER_AVAILABLE_MAX_DIGITAL_ZOOM,
|
||||||
ANDROID_SCALER_AVAILABLE_MAX_DIGITAL_ZOOM,
|
|
||||||
&maxDigitalZoom, 1);
|
&maxDigitalZoom, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint32_t> availableStreamFormats = {
|
std::vector<uint32_t> availableStreamFormats = {
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB,
|
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB,
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_YCbCr_420_888,
|
ANDROID_SCALER_AVAILABLE_FORMATS_YCbCr_420_888,
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_IMPLEMENTATION_DEFINED,
|
ANDROID_SCALER_AVAILABLE_FORMATS_IMPLEMENTATION_DEFINED,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SCALER_AVAILABLE_FORMATS,
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS,
|
|
||||||
availableStreamFormats.data(),
|
availableStreamFormats.data(),
|
||||||
availableStreamFormats.size());
|
availableStreamFormats.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint32_t> availableStreamConfigurations = {
|
std::vector<uint32_t> availableStreamConfigurations = {
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB, 2560, 1920,
|
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB, 2560, 1920,
|
||||||
|
@ -447,65 +382,58 @@ camera_metadata_t *CameraDevice::getStaticMetadata()
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_IMPLEMENTATION_DEFINED, 2560, 1920,
|
ANDROID_SCALER_AVAILABLE_FORMATS_IMPLEMENTATION_DEFINED, 2560, 1920,
|
||||||
ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS_OUTPUT,
|
ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS_OUTPUT,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS,
|
||||||
ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS,
|
|
||||||
availableStreamConfigurations.data(),
|
availableStreamConfigurations.data(),
|
||||||
availableStreamConfigurations.size());
|
availableStreamConfigurations.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<int64_t> availableStallDurations = {
|
std::vector<int64_t> availableStallDurations = {
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB, 2560, 1920, 33333333,
|
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB, 2560, 1920, 33333333,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SCALER_AVAILABLE_STALL_DURATIONS,
|
||||||
ANDROID_SCALER_AVAILABLE_STALL_DURATIONS,
|
|
||||||
availableStallDurations.data(),
|
availableStallDurations.data(),
|
||||||
availableStallDurations.size());
|
availableStallDurations.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<int64_t> minFrameDurations = {
|
std::vector<int64_t> minFrameDurations = {
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB, 2560, 1920, 33333333,
|
ANDROID_SCALER_AVAILABLE_FORMATS_BLOB, 2560, 1920, 33333333,
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_IMPLEMENTATION_DEFINED, 2560, 1920, 33333333,
|
ANDROID_SCALER_AVAILABLE_FORMATS_IMPLEMENTATION_DEFINED, 2560, 1920, 33333333,
|
||||||
ANDROID_SCALER_AVAILABLE_FORMATS_YCbCr_420_888, 2560, 1920, 33333333,
|
ANDROID_SCALER_AVAILABLE_FORMATS_YCbCr_420_888, 2560, 1920, 33333333,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SCALER_AVAILABLE_MIN_FRAME_DURATIONS,
|
||||||
ANDROID_SCALER_AVAILABLE_MIN_FRAME_DURATIONS,
|
minFrameDurations.data(),
|
||||||
minFrameDurations.data(), minFrameDurations.size());
|
minFrameDurations.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t croppingType = ANDROID_SCALER_CROPPING_TYPE_CENTER_ONLY;
|
uint8_t croppingType = ANDROID_SCALER_CROPPING_TYPE_CENTER_ONLY;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_SCALER_CROPPING_TYPE, &croppingType, 1);
|
||||||
ANDROID_SCALER_CROPPING_TYPE, &croppingType, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* Info static metadata. */
|
/* Info static metadata. */
|
||||||
uint8_t supportedHWLevel = ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL_LIMITED;
|
uint8_t supportedHWLevel = ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL_LIMITED;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL,
|
||||||
ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL,
|
|
||||||
&supportedHWLevel, 1);
|
&supportedHWLevel, 1);
|
||||||
|
|
||||||
/* Request static metadata. */
|
/* Request static metadata. */
|
||||||
int32_t partialResultCount = 1;
|
int32_t partialResultCount = 1;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_REQUEST_PARTIAL_RESULT_COUNT,
|
||||||
ANDROID_REQUEST_PARTIAL_RESULT_COUNT,
|
|
||||||
&partialResultCount, 1);
|
&partialResultCount, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t maxPipelineDepth = 2;
|
uint8_t maxPipelineDepth = 2;
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_REQUEST_PIPELINE_MAX_DEPTH,
|
||||||
ANDROID_REQUEST_PIPELINE_MAX_DEPTH,
|
|
||||||
&maxPipelineDepth, 1);
|
&maxPipelineDepth, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
std::vector<uint8_t> availableCapabilities = {
|
std::vector<uint8_t> availableCapabilities = {
|
||||||
ANDROID_REQUEST_AVAILABLE_CAPABILITIES_BACKWARD_COMPATIBLE,
|
ANDROID_REQUEST_AVAILABLE_CAPABILITIES_BACKWARD_COMPATIBLE,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(staticMetadata_,
|
staticMetadata_->addEntry(ANDROID_REQUEST_AVAILABLE_CAPABILITIES,
|
||||||
ANDROID_REQUEST_AVAILABLE_CAPABILITIES,
|
|
||||||
availableCapabilities.data(),
|
availableCapabilities.data(),
|
||||||
availableCapabilities.size());
|
availableCapabilities.size());
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
return staticMetadata_;
|
if (!staticMetadata_->isValid()) {
|
||||||
|
LOG(HAL, Error) << "Failed to construct static metadata";
|
||||||
|
delete staticMetadata_;
|
||||||
|
staticMetadata_ = nullptr;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
return staticMetadata_->get();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -513,8 +441,6 @@ camera_metadata_t *CameraDevice::getStaticMetadata()
|
||||||
*/
|
*/
|
||||||
const camera_metadata_t *CameraDevice::constructDefaultRequestSettings(int type)
|
const camera_metadata_t *CameraDevice::constructDefaultRequestSettings(int type)
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* \todo Inspect type and pick the right metadata pack.
|
* \todo Inspect type and pick the right metadata pack.
|
||||||
* As of now just use a single one for all templates.
|
* As of now just use a single one for all templates.
|
||||||
|
@ -545,89 +471,75 @@ const camera_metadata_t *CameraDevice::constructDefaultRequestSettings(int type)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (requestTemplate_)
|
if (requestTemplate_)
|
||||||
return requestTemplate_;
|
return requestTemplate_->get();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* \todo Keep this in sync with the actual number of entries.
|
* \todo Keep this in sync with the actual number of entries.
|
||||||
* Currently: 12 entries, 15 bytes
|
* Currently: 12 entries, 15 bytes
|
||||||
*/
|
*/
|
||||||
requestTemplate_ = allocate_camera_metadata(15, 20);
|
requestTemplate_ = new CameraMetadata(15, 20);
|
||||||
if (!requestTemplate_) {
|
if (!requestTemplate_) {
|
||||||
LOG(HAL, Error) << "Failed to allocate template metadata";
|
LOG(HAL, Error) << "Failed to allocate template metadata";
|
||||||
|
delete requestTemplate_;
|
||||||
|
requestTemplate_ = nullptr;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t aeMode = ANDROID_CONTROL_AE_MODE_ON;
|
uint8_t aeMode = ANDROID_CONTROL_AE_MODE_ON;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_AE_MODE,
|
||||||
ANDROID_CONTROL_AE_MODE,
|
|
||||||
&aeMode, 1);
|
&aeMode, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
int32_t aeExposureCompensation = 0;
|
int32_t aeExposureCompensation = 0;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_AE_EXPOSURE_COMPENSATION,
|
||||||
ANDROID_CONTROL_AE_EXPOSURE_COMPENSATION,
|
|
||||||
&aeExposureCompensation, 1);
|
&aeExposureCompensation, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t aePrecaptureTrigger = ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER_IDLE;
|
uint8_t aePrecaptureTrigger = ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER_IDLE;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER,
|
||||||
ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER,
|
|
||||||
&aePrecaptureTrigger, 1);
|
&aePrecaptureTrigger, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t aeLock = ANDROID_CONTROL_AE_LOCK_OFF;
|
uint8_t aeLock = ANDROID_CONTROL_AE_LOCK_OFF;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_AE_LOCK,
|
||||||
ANDROID_CONTROL_AE_LOCK,
|
|
||||||
&aeLock, 1);
|
&aeLock, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t afTrigger = ANDROID_CONTROL_AF_TRIGGER_IDLE;
|
uint8_t afTrigger = ANDROID_CONTROL_AF_TRIGGER_IDLE;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_AF_TRIGGER,
|
||||||
ANDROID_CONTROL_AF_TRIGGER,
|
|
||||||
&afTrigger, 1);
|
&afTrigger, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t awbMode = ANDROID_CONTROL_AWB_MODE_AUTO;
|
uint8_t awbMode = ANDROID_CONTROL_AWB_MODE_AUTO;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_AWB_MODE,
|
||||||
ANDROID_CONTROL_AWB_MODE,
|
|
||||||
&awbMode, 1);
|
&awbMode, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t awbLock = ANDROID_CONTROL_AWB_LOCK_OFF;
|
uint8_t awbLock = ANDROID_CONTROL_AWB_LOCK_OFF;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_AWB_LOCK,
|
||||||
ANDROID_CONTROL_AWB_LOCK,
|
|
||||||
&awbLock, 1);
|
&awbLock, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t flashMode = ANDROID_FLASH_MODE_OFF;
|
uint8_t flashMode = ANDROID_FLASH_MODE_OFF;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_FLASH_MODE,
|
||||||
ANDROID_FLASH_MODE,
|
|
||||||
&flashMode, 1);
|
&flashMode, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t faceDetectMode = ANDROID_STATISTICS_FACE_DETECT_MODE_OFF;
|
uint8_t faceDetectMode = ANDROID_STATISTICS_FACE_DETECT_MODE_OFF;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_STATISTICS_FACE_DETECT_MODE,
|
||||||
ANDROID_STATISTICS_FACE_DETECT_MODE,
|
|
||||||
&faceDetectMode, 1);
|
&faceDetectMode, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t noiseReduction = ANDROID_NOISE_REDUCTION_MODE_OFF;
|
uint8_t noiseReduction = ANDROID_NOISE_REDUCTION_MODE_OFF;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_NOISE_REDUCTION_MODE,
|
||||||
ANDROID_NOISE_REDUCTION_MODE, &noiseReduction, 1);
|
&noiseReduction, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t aberrationMode = ANDROID_COLOR_CORRECTION_ABERRATION_MODE_OFF;
|
uint8_t aberrationMode = ANDROID_COLOR_CORRECTION_ABERRATION_MODE_OFF;
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_COLOR_CORRECTION_ABERRATION_MODE,
|
||||||
ANDROID_COLOR_CORRECTION_ABERRATION_MODE,
|
|
||||||
&aberrationMode, 1);
|
&aberrationMode, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
ret = add_camera_metadata_entry(requestTemplate_,
|
requestTemplate_->addEntry(ANDROID_CONTROL_CAPTURE_INTENT,
|
||||||
ANDROID_CONTROL_CAPTURE_INTENT,
|
|
||||||
&captureIntent, 1);
|
&captureIntent, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
return requestTemplate_;
|
if (!requestTemplate_->isValid()) {
|
||||||
|
LOG(HAL, Error) << "Failed to construct request template";
|
||||||
|
delete requestTemplate_;
|
||||||
|
requestTemplate_ = nullptr;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
return requestTemplate_->get();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -799,7 +711,7 @@ void CameraDevice::requestComplete(Request *request,
|
||||||
{
|
{
|
||||||
Buffer *libcameraBuffer = buffers.begin()->second;
|
Buffer *libcameraBuffer = buffers.begin()->second;
|
||||||
camera3_buffer_status status = CAMERA3_BUFFER_STATUS_OK;
|
camera3_buffer_status status = CAMERA3_BUFFER_STATUS_OK;
|
||||||
camera_metadata_t *resultMetadata = nullptr;
|
std::unique_ptr<CameraMetadata> resultMetadata;
|
||||||
|
|
||||||
if (request->status() != Request::RequestComplete) {
|
if (request->status() != Request::RequestComplete) {
|
||||||
LOG(HAL, Error) << "Request not succesfully completed: "
|
LOG(HAL, Error) << "Request not succesfully completed: "
|
||||||
|
@ -826,27 +738,30 @@ void CameraDevice::requestComplete(Request *request,
|
||||||
captureResult.output_buffers =
|
captureResult.output_buffers =
|
||||||
const_cast<const camera3_stream_buffer_t *>(descriptor->buffers);
|
const_cast<const camera3_stream_buffer_t *>(descriptor->buffers);
|
||||||
|
|
||||||
if (status == CAMERA3_BUFFER_STATUS_ERROR) {
|
if (status == CAMERA3_BUFFER_STATUS_OK) {
|
||||||
/* \todo Improve error handling. */
|
|
||||||
notifyError(descriptor->frameNumber,
|
|
||||||
descriptor->buffers[0].stream);
|
|
||||||
} else {
|
|
||||||
notifyShutter(descriptor->frameNumber,
|
notifyShutter(descriptor->frameNumber,
|
||||||
libcameraBuffer->timestamp());
|
libcameraBuffer->timestamp());
|
||||||
|
|
||||||
captureResult.partial_result = 1;
|
captureResult.partial_result = 1;
|
||||||
resultMetadata = getResultMetadata(descriptor->frameNumber,
|
resultMetadata = getResultMetadata(descriptor->frameNumber,
|
||||||
libcameraBuffer->timestamp());
|
libcameraBuffer->timestamp());
|
||||||
captureResult.result = resultMetadata;
|
captureResult.result = resultMetadata->get();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status == CAMERA3_BUFFER_STATUS_ERROR || !captureResult.result) {
|
||||||
|
/* \todo Improve error handling. In case we notify an error
|
||||||
|
* because the metadata generation fails, a shutter event has
|
||||||
|
* already been notified for this frame number before the error
|
||||||
|
* is here signalled. Make sure the error path plays well with
|
||||||
|
* the camera stack state machine.
|
||||||
|
*/
|
||||||
|
notifyError(descriptor->frameNumber,
|
||||||
|
descriptor->buffers[0].stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
callbacks_->process_capture_result(callbacks_, &captureResult);
|
callbacks_->process_capture_result(callbacks_, &captureResult);
|
||||||
|
|
||||||
delete descriptor;
|
delete descriptor;
|
||||||
if (resultMetadata)
|
|
||||||
free_camera_metadata(resultMetadata);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CameraDevice::notifyShutter(uint32_t frameNumber, uint64_t timestamp)
|
void CameraDevice::notifyShutter(uint32_t frameNumber, uint64_t timestamp)
|
||||||
|
@ -875,89 +790,71 @@ void CameraDevice::notifyError(uint32_t frameNumber, camera3_stream_t *stream)
|
||||||
/*
|
/*
|
||||||
* Produce a set of fixed result metadata.
|
* Produce a set of fixed result metadata.
|
||||||
*/
|
*/
|
||||||
camera_metadata_t *CameraDevice::getResultMetadata(int frame_number,
|
std::unique_ptr<CameraMetadata> CameraDevice::getResultMetadata(int frame_number,
|
||||||
int64_t timestamp)
|
int64_t timestamp)
|
||||||
{
|
{
|
||||||
int ret;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* \todo Keep this in sync with the actual number of entries.
|
* \todo Keep this in sync with the actual number of entries.
|
||||||
* Currently: 13 entries, 36 bytes
|
* Currently: 12 entries, 36 bytes
|
||||||
*/
|
*/
|
||||||
camera_metadata_t *resultMetadata = allocate_camera_metadata(15, 50);
|
std::unique_ptr<CameraMetadata> resultMetadata =
|
||||||
|
utils::make_unique<CameraMetadata>(15, 50);
|
||||||
|
if (!resultMetadata->isValid()) {
|
||||||
|
LOG(HAL, Error) << "Failed to allocate static metadata";
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
const uint8_t ae_state = ANDROID_CONTROL_AE_STATE_CONVERGED;
|
const uint8_t ae_state = ANDROID_CONTROL_AE_STATE_CONVERGED;
|
||||||
ret = add_camera_metadata_entry(resultMetadata, ANDROID_CONTROL_AE_STATE,
|
resultMetadata->addEntry(ANDROID_CONTROL_AE_STATE, &ae_state, 1);
|
||||||
&ae_state, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
const uint8_t ae_lock = ANDROID_CONTROL_AE_LOCK_OFF;
|
const uint8_t ae_lock = ANDROID_CONTROL_AE_LOCK_OFF;
|
||||||
ret = add_camera_metadata_entry(resultMetadata, ANDROID_CONTROL_AE_LOCK,
|
resultMetadata->addEntry(ANDROID_CONTROL_AE_LOCK, &ae_lock, 1);
|
||||||
&ae_lock, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
uint8_t af_state = ANDROID_CONTROL_AF_STATE_INACTIVE;
|
uint8_t af_state = ANDROID_CONTROL_AF_STATE_INACTIVE;
|
||||||
ret = add_camera_metadata_entry(resultMetadata, ANDROID_CONTROL_AF_STATE,
|
resultMetadata->addEntry(ANDROID_CONTROL_AF_STATE, &af_state, 1);
|
||||||
&af_state, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
const uint8_t awb_state = ANDROID_CONTROL_AWB_STATE_CONVERGED;
|
const uint8_t awb_state = ANDROID_CONTROL_AWB_STATE_CONVERGED;
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_CONTROL_AWB_STATE, &awb_state, 1);
|
||||||
ANDROID_CONTROL_AWB_STATE,
|
|
||||||
&awb_state, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
const uint8_t awb_lock = ANDROID_CONTROL_AWB_LOCK_OFF;
|
const uint8_t awb_lock = ANDROID_CONTROL_AWB_LOCK_OFF;
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_CONTROL_AWB_LOCK, &awb_lock, 1);
|
||||||
ANDROID_CONTROL_AWB_LOCK,
|
|
||||||
&awb_lock, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
const uint8_t lens_state = ANDROID_LENS_STATE_STATIONARY;
|
const uint8_t lens_state = ANDROID_LENS_STATE_STATIONARY;
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_LENS_STATE, &lens_state, 1);
|
||||||
ANDROID_LENS_STATE,
|
|
||||||
&lens_state, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
int32_t sensorSizes[] = {
|
int32_t sensorSizes[] = {
|
||||||
0, 0, 2560, 1920,
|
0, 0, 2560, 1920,
|
||||||
};
|
};
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_SCALER_CROP_REGION, sensorSizes, 4);
|
||||||
ANDROID_SCALER_CROP_REGION,
|
|
||||||
sensorSizes, 4);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_SENSOR_TIMESTAMP, ×tamp, 1);
|
||||||
ANDROID_SENSOR_TIMESTAMP,
|
|
||||||
×tamp, 1);
|
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* 33.3 msec */
|
/* 33.3 msec */
|
||||||
const int64_t rolling_shutter_skew = 33300000;
|
const int64_t rolling_shutter_skew = 33300000;
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_SENSOR_ROLLING_SHUTTER_SKEW,
|
||||||
ANDROID_SENSOR_ROLLING_SHUTTER_SKEW,
|
|
||||||
&rolling_shutter_skew, 1);
|
&rolling_shutter_skew, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
/* 16.6 msec */
|
/* 16.6 msec */
|
||||||
const int64_t exposure_time = 16600000;
|
const int64_t exposure_time = 16600000;
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_SENSOR_EXPOSURE_TIME,
|
||||||
ANDROID_SENSOR_EXPOSURE_TIME,
|
|
||||||
&exposure_time, 1);
|
&exposure_time, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
const uint8_t lens_shading_map_mode =
|
const uint8_t lens_shading_map_mode =
|
||||||
ANDROID_STATISTICS_LENS_SHADING_MAP_MODE_OFF;
|
ANDROID_STATISTICS_LENS_SHADING_MAP_MODE_OFF;
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_STATISTICS_LENS_SHADING_MAP_MODE,
|
||||||
ANDROID_STATISTICS_LENS_SHADING_MAP_MODE,
|
|
||||||
&lens_shading_map_mode, 1);
|
&lens_shading_map_mode, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
|
||||||
const uint8_t scene_flicker = ANDROID_STATISTICS_SCENE_FLICKER_NONE;
|
const uint8_t scene_flicker = ANDROID_STATISTICS_SCENE_FLICKER_NONE;
|
||||||
ret = add_camera_metadata_entry(resultMetadata,
|
resultMetadata->addEntry(ANDROID_STATISTICS_SCENE_FLICKER,
|
||||||
ANDROID_STATISTICS_SCENE_FLICKER,
|
|
||||||
&scene_flicker, 1);
|
&scene_flicker, 1);
|
||||||
METADATA_ASSERT(ret);
|
|
||||||
|
/*
|
||||||
|
* Return the result metadata pack even is not valid: get() will return
|
||||||
|
* nullptr.
|
||||||
|
*/
|
||||||
|
if (!resultMetadata->isValid()) {
|
||||||
|
LOG(HAL, Error) << "Failed to construct result metadata";
|
||||||
|
}
|
||||||
|
|
||||||
return resultMetadata;
|
return resultMetadata;
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,13 +19,7 @@
|
||||||
|
|
||||||
#include "message.h"
|
#include "message.h"
|
||||||
|
|
||||||
#define METADATA_ASSERT(_r) \
|
class CameraMetadata;
|
||||||
do { \
|
|
||||||
if (!(_r)) break; \
|
|
||||||
LOG(HAL, Error) << "Error: " << __func__ << ":" << __LINE__; \
|
|
||||||
return nullptr; \
|
|
||||||
} while(0);
|
|
||||||
|
|
||||||
class ThreadRpc;
|
class ThreadRpc;
|
||||||
|
|
||||||
class CameraDevice : public libcamera::Object
|
class CameraDevice : public libcamera::Object
|
||||||
|
@ -59,14 +53,15 @@ private:
|
||||||
|
|
||||||
void notifyShutter(uint32_t frameNumber, uint64_t timestamp);
|
void notifyShutter(uint32_t frameNumber, uint64_t timestamp);
|
||||||
void notifyError(uint32_t frameNumber, camera3_stream_t *stream);
|
void notifyError(uint32_t frameNumber, camera3_stream_t *stream);
|
||||||
camera_metadata_t *getResultMetadata(int frame_number, int64_t timestamp);
|
std::unique_ptr<CameraMetadata> getResultMetadata(int frame_number,
|
||||||
|
int64_t timestamp);
|
||||||
|
|
||||||
bool running_;
|
bool running_;
|
||||||
std::shared_ptr<libcamera::Camera> camera_;
|
std::shared_ptr<libcamera::Camera> camera_;
|
||||||
std::unique_ptr<libcamera::CameraConfiguration> config_;
|
std::unique_ptr<libcamera::CameraConfiguration> config_;
|
||||||
|
|
||||||
camera_metadata_t *staticMetadata_;
|
CameraMetadata *staticMetadata_;
|
||||||
camera_metadata_t *requestTemplate_;
|
CameraMetadata *requestTemplate_;
|
||||||
const camera3_callback_ops_t *callbacks_;
|
const camera3_callback_ops_t *callbacks_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue