[libcamera-devel] [RFC PATCH v4 12/21] controls: Replace AwbLocked with AwbState, and add AwbLock
Paul Elder
paul.elder at ideasonboard.com
Fri Jul 16 12:56:22 CEST 2021
AwbLocked alone isn't sufficient for reporting the AWB state, so replace
it with AwbState. Add an AwbLock control for instructing the camera to
lock the AWB values.
Signed-off-by: Paul Elder <paul.elder at ideasonboard.com>
---
No change in v3
---
src/libcamera/control_ids.yaml | 82 ++++++++++++++++++++--------------
1 file changed, 49 insertions(+), 33 deletions(-)
diff --git a/src/libcamera/control_ids.yaml b/src/libcamera/control_ids.yaml
index 2e62f61b..3a4f07cf 100644
--- a/src/libcamera/control_ids.yaml
+++ b/src/libcamera/control_ids.yaml
@@ -161,6 +161,55 @@ controls:
value: 3
description: Custom exposure mode.
+ - AwbLock:
+ type: bool
+ description: |
+ Control to lock the AWB values.
+ When set to true, the AWB algorithm is locked to its latest parameters,
+ and will not change exposure settings until set to false.
+ \sa AwbState
+
+ - AwbState:
+ type: int32_t
+ description: |
+ Control to report the current AWB algorithm state. Switching between or
+ enabling AWB modes (AwbMode) always resets the AwbState to
+ AwbStateInactive. The camera device can do several state transitions
+ between two results, if it is allowed by the state transition table.
+ For example, AwbStateInactive may never actually be seen in a result.
+
+ The state in the result is the state for this image (in sync with this
+ image). If AWB state becomes AwbStateConverged, then the image data
+ associated with the result should be good to use.
+
+ The state transitions mentioned below assume that AwbMode is auto.
+
+ \sa AwbLock
+ enum:
+ - name: AwbStateInactive
+ value: 0
+ description: |
+ The AWB algorithm is inactive.
+ If the camera initiates an AWB scan, the state shall go to Searching.
+ If AwbLock is on, the state shall go to Locked.
+ - name: AwbStateSearching
+ value: 1
+ description: |
+ The AWB algorithm has not converged yet.
+ If the camera finishes an AWB scan, the state shall go to Converged.
+ If AwbLock is on, the state shall go to Locked.
+ - name: AwbStateConverged
+ value: 2
+ description: |
+ The AWB algorithm has converged.
+ If the camera initiates an AWB scan, the state shall go to Searching.
+ If AwbLock is on, the state shall go to Locked.
+ - name: AwbStateLocked
+ value: 3
+ description: |
+ The AWB algorithm is locked.
+ If AwbLock is off, the state shall go to Searching.
+
- ExposureValue:
type: float
description: |
@@ -272,17 +321,6 @@ controls:
value: 10
description: Custom AWB mode.
- - AwbLocked:
- type: bool
- description: |
- Report the lock status of a running AWB algorithm.
-
- If the AWB algorithm is locked the value shall be set to true, if it's
- converging it shall be set to false. If the AWB algorithm is not
- running the control shall not be present in the metadata control list.
-
- \sa AwbEnable
-
- ColourGains:
type: float
description: |
@@ -572,28 +610,6 @@ controls:
description: |
AF has completed a passive scan without finding focus.
- - AwbState:
- type: int32_t
- draft: true
- description: |
- Control to report the current AWB algorithm state. Currently identical
- to ANDROID_CONTROL_AWB_STATE.
-
- Current state of the AWB algorithm.
- enum:
- - name: AwbStateInactive
- value: 0
- description: The AWB algorithm is inactive.
- - name: AwbStateSearching
- value: 1
- description: The AWB algorithm has not converged yet.
- - name: AwbConverged
- value: 2
- description: The AWB algorithm has converged.
- - name: AwbLocked
- value: 3
- description: The AWB algorithm is locked.
-
- SensorRollingShutterSkew:
type: int64_t
draft: true
--
2.27.0
More information about the libcamera-devel
mailing list