libcamera/src/ipa/raspberrypi/controller/camera_mode.h
Naushir Patuck 362301b131 ipa: raspberrypi: Limit the calculated vblank based on the sensor mode
The existing framerate/vblank calculations did not account for the
sensor mode limits. This commit extracts vblank limits from the sensor
v4l2 controls, and stores it in the camera modes structure.

Exposure and vblank value calculations now use values clamped to the
sensor mode limits. The libcamera::controls::FrameDurations metadata
return values now reflect the minimum and maximum after clamping.

Signed-off-by: Naushir Patuck <naush@raspberrypi.com>
Reviewed-by: David Plowman <david.plowman@raspberrypi.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>
2021-02-05 01:23:20 +02:00

46 lines
1.3 KiB
C

/* SPDX-License-Identifier: BSD-2-Clause */
/*
* Copyright (C) 2019-2020, Raspberry Pi (Trading) Limited
*
* camera_mode.h - description of a particular operating mode of a sensor
*/
#pragma once
#include <libcamera/transform.h>
// Description of a "camera mode", holding enough information for control
// algorithms to adapt their behaviour to the different modes of the camera,
// including binning, scaling, cropping etc.
#ifdef __cplusplus
extern "C" {
#endif
#define CAMERA_MODE_NAME_LEN 32
struct CameraMode {
// bit depth of the raw camera output
uint32_t bitdepth;
// size in pixels of frames in this mode
uint16_t width, height;
// size of full resolution uncropped frame ("sensor frame")
uint16_t sensor_width, sensor_height;
// binning factor (1 = no binning, 2 = 2-pixel binning etc.)
uint8_t bin_x, bin_y;
// location of top left pixel in the sensor frame
uint16_t crop_x, crop_y;
// scaling factor (so if uncropped, width*scale_x is sensor_width)
double scale_x, scale_y;
// scaling of the noise compared to the native sensor mode
double noise_factor;
// line time in nanoseconds
double line_length;
// any camera transform *not* reflected already in the camera tuning
libcamera::Transform transform;
// minimum and maximum fame lengths in units of lines
uint32_t min_frame_length, max_frame_length;
};
#ifdef __cplusplus
}
#endif