mirror of
https://git.libcamera.org/libcamera/libcamera.git
synced 2025-07-14 16:09:51 +03:00
ipa: raspberrypi: Add frame_length to DeviceStatus
Store the frame length into the DeviceStatus struct. The value is extracted from embedded data when available, or calculated from the VBLANK value passed from DelayedControls otherwise. Update imx477 and imx219 CamHelper classes to extract the frame length from the embedded data buffer. Signed-off-by: Naushir Patuck <naush@raspberrypi.com> Reviewed-by: David Plowman <david.plowman@raspberrypi.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Jacopo Mondi <jacopo@jmondi.org> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
This commit is contained in:
parent
f24d83720f
commit
2d6a9b3592
6 changed files with 19 additions and 4 deletions
|
@ -187,6 +187,7 @@ void CamHelper::parseEmbeddedData(Span<const uint8_t> buffer,
|
|||
|
||||
deviceStatus.shutter_speed = parsedDeviceStatus.shutter_speed;
|
||||
deviceStatus.analogue_gain = parsedDeviceStatus.analogue_gain;
|
||||
deviceStatus.frame_length = parsedDeviceStatus.frame_length;
|
||||
|
||||
LOG(IPARPI, Debug) << "Metadata updated - " << deviceStatus;
|
||||
|
||||
|
|
|
@ -30,7 +30,10 @@ using namespace RPiController;
|
|||
constexpr uint32_t gainReg = 0x157;
|
||||
constexpr uint32_t expHiReg = 0x15a;
|
||||
constexpr uint32_t expLoReg = 0x15b;
|
||||
constexpr std::initializer_list<uint32_t> registerList [[maybe_unused]] = { expHiReg, expLoReg, gainReg };
|
||||
constexpr uint32_t frameLengthHiReg = 0x160;
|
||||
constexpr uint32_t frameLengthLoReg = 0x161;
|
||||
constexpr std::initializer_list<uint32_t> registerList [[maybe_unused]]
|
||||
= { expHiReg, expLoReg, gainReg, frameLengthHiReg, frameLengthLoReg };
|
||||
|
||||
class CamHelperImx219 : public CamHelper
|
||||
{
|
||||
|
@ -93,6 +96,7 @@ void CamHelperImx219::PopulateMetadata(const MdParser::RegisterMap ®isters,
|
|||
|
||||
deviceStatus.shutter_speed = Exposure(registers.at(expHiReg) * 256 + registers.at(expLoReg));
|
||||
deviceStatus.analogue_gain = Gain(registers.at(gainReg));
|
||||
deviceStatus.frame_length = registers.at(frameLengthHiReg) * 256 + registers.at(frameLengthLoReg);
|
||||
|
||||
metadata.Set("device.status", deviceStatus);
|
||||
}
|
||||
|
|
|
@ -23,7 +23,10 @@ constexpr uint32_t expHiReg = 0x0202;
|
|||
constexpr uint32_t expLoReg = 0x0203;
|
||||
constexpr uint32_t gainHiReg = 0x0204;
|
||||
constexpr uint32_t gainLoReg = 0x0205;
|
||||
constexpr std::initializer_list<uint32_t> registerList = { expHiReg, expLoReg, gainHiReg, gainLoReg };
|
||||
constexpr uint32_t frameLengthHiReg = 0x0340;
|
||||
constexpr uint32_t frameLengthLoReg = 0x0341;
|
||||
constexpr std::initializer_list<uint32_t> registerList =
|
||||
{ expHiReg, expLoReg, gainHiReg, gainLoReg, frameLengthHiReg, frameLengthLoReg };
|
||||
|
||||
class CamHelperImx477 : public CamHelper
|
||||
{
|
||||
|
@ -81,6 +84,7 @@ void CamHelperImx477::PopulateMetadata(const MdParser::RegisterMap ®isters,
|
|||
|
||||
deviceStatus.shutter_speed = Exposure(registers.at(expHiReg) * 256 + registers.at(expLoReg));
|
||||
deviceStatus.analogue_gain = Gain(registers.at(gainHiReg) * 256 + registers.at(gainLoReg));
|
||||
deviceStatus.frame_length = registers.at(frameLengthHiReg) * 256 + registers.at(frameLengthLoReg);
|
||||
|
||||
metadata.Set("device.status", deviceStatus);
|
||||
}
|
||||
|
|
|
@ -11,6 +11,7 @@ using namespace libcamera; /* for the Duration operator<< overload */
|
|||
std::ostream &operator<<(std::ostream &out, const DeviceStatus &d)
|
||||
{
|
||||
out << "Exposure: " << d.shutter_speed
|
||||
<< " Frame length: " << d.frame_length
|
||||
<< " Gain: " << d.analogue_gain
|
||||
<< " Aperture: " << d.aperture
|
||||
<< " Lens: " << d.lens_position
|
||||
|
|
|
@ -17,8 +17,9 @@
|
|||
|
||||
struct DeviceStatus {
|
||||
DeviceStatus()
|
||||
: shutter_speed(std::chrono::seconds(0)), analogue_gain(0.0),
|
||||
lens_position(0.0), aperture(0.0), flash_intensity(0.0)
|
||||
: shutter_speed(std::chrono::seconds(0)), frame_length(0),
|
||||
analogue_gain(0.0), lens_position(0.0), aperture(0.0),
|
||||
flash_intensity(0.0)
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -26,6 +27,8 @@ struct DeviceStatus {
|
|||
|
||||
/* time shutter is open */
|
||||
libcamera::utils::Duration shutter_speed;
|
||||
/* frame length given in number of lines */
|
||||
uint32_t frame_length;
|
||||
double analogue_gain;
|
||||
/* 1.0/distance-in-metres, or 0 if unknown */
|
||||
double lens_position;
|
||||
|
|
|
@ -1015,9 +1015,11 @@ void IPARPi::fillDeviceStatus(const ControlList &sensorControls)
|
|||
|
||||
int32_t exposureLines = sensorControls.get(V4L2_CID_EXPOSURE).get<int32_t>();
|
||||
int32_t gainCode = sensorControls.get(V4L2_CID_ANALOGUE_GAIN).get<int32_t>();
|
||||
int32_t vblank = sensorControls.get(V4L2_CID_VBLANK).get<int32_t>();
|
||||
|
||||
deviceStatus.shutter_speed = helper_->Exposure(exposureLines);
|
||||
deviceStatus.analogue_gain = helper_->Gain(gainCode);
|
||||
deviceStatus.frame_length = mode_.height + vblank;
|
||||
|
||||
LOG(IPARPI, Debug) << "Metadata - " << deviceStatus;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue