android: capabilities: Initialize camera state when building properties
Now that building the list of supported stream configuration requires applying a configuration to the Camera, re-initialize the camera controls by applying a configuration generated for the Viewfinder stream role before building the list of static metadata. Signed-off-by: Jacopo Mondi <jacopo@jmondi.org> Reviewed-by: Paul Elder <paul.elder@ideasonboard.com> Reviewed-by: Umang Jain <umang.jain@ideasonboard.com> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
This commit is contained in:
parent
56ee14e16d
commit
5a995a01bc
1 changed files with 25 additions and 3 deletions
|
@ -394,11 +394,14 @@ int CameraCapabilities::initialize(std::shared_ptr<Camera> camera,
|
|||
}
|
||||
|
||||
ret = initializeStreamConfigurations();
|
||||
if (ret) {
|
||||
camera_->release();
|
||||
if (ret)
|
||||
return ret;
|
||||
}
|
||||
|
||||
return initializeStaticMetadata();
|
||||
ret = initializeStaticMetadata();
|
||||
camera_->release();
|
||||
return ret;
|
||||
}
|
||||
|
||||
std::vector<Size>
|
||||
|
@ -696,6 +699,25 @@ int CameraCapabilities::initializeStaticMetadata()
|
|||
return -EINVAL;
|
||||
}
|
||||
|
||||
/*
|
||||
* Generate and apply a new configuration for the Viewfinder role to
|
||||
* collect control limits and properties from a known state.
|
||||
*/
|
||||
std::unique_ptr<CameraConfiguration> cameraConfig =
|
||||
camera_->generateConfiguration({ StreamRole::Viewfinder });
|
||||
if (!cameraConfig) {
|
||||
LOG(HAL, Error) << "Failed to generate camera configuration";
|
||||
staticMetadata_.reset();
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
int ret = camera_->configure(cameraConfig.get());
|
||||
if (ret) {
|
||||
LOG(HAL, Error) << "Failed to initialize the camera state";
|
||||
staticMetadata_.reset();
|
||||
return ret;
|
||||
}
|
||||
|
||||
const ControlInfoMap &controlsInfo = camera_->controls();
|
||||
const ControlList &properties = camera_->properties();
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue