diff options
author | Chien-Yu Chen <cychen@google.com> | 2015-01-29 15:12:47 -0800 |
---|---|---|
committer | Zhijun He <zhijunhe@google.com> | 2015-03-17 20:02:22 -0700 |
commit | 126867ea94f97d1d480fe77e17546a5d4726c71d (patch) | |
tree | 572d7f8a95283d5540116d079c992394e8a17405 /include | |
parent | bd2929c03ce215e84cdf381197429c54908440e2 (diff) | |
download | hardware_libhardware-126867ea94f97d1d480fe77e17546a5d4726c71d.zip hardware_libhardware-126867ea94f97d1d480fe77e17546a5d4726c71d.tar.gz hardware_libhardware-126867ea94f97d1d480fe77e17546a5d4726c71d.tar.bz2 |
camera_common: add TORCH_MODE_STATUS_OFF
Add TORCH_MODE_STATUS_OFF for the case when HAL has to turn off the
torch mode that was turned on by a previous set_torch_mode() call
in order to turn on the torch mode for the current set_torch_mode()
call.
Bug: 2682206
Change-Id: Ia2f717ffaca8c4346ec5fcdf73895160f700f067
Diffstat (limited to 'include')
-rw-r--r-- | include/hardware/camera_common.h | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/include/hardware/camera_common.h b/include/hardware/camera_common.h index 971ed80..47a01c9 100644 --- a/include/hardware/camera_common.h +++ b/include/hardware/camera_common.h @@ -426,7 +426,10 @@ typedef enum camera_device_status { * up by this close() call. * * Note that the framework calling set_torch_mode() should not trigger any - * callbacks. + * callbacks except when HAL cannot keep multiple torch modes on + * simultaneously. In that case, HAL must notify the framework that any + * previously-on torch mode states have become TORCH_MODE_STATUS_OFF. + * */ typedef enum torch_mode_status { /** @@ -445,6 +448,15 @@ typedef enum torch_mode_status { */ TORCH_MODE_STATUS_RESOURCE_BUSY = 1, + /** + * The previously-on torch mode has been turned off by HAL but the flash + * unit is still available for set_torch_mode(). This may happen after the + * framework turned on the torch mode of some other camera device and HAL + * had to turn off the torch modes of any camera devices that were + * previously on. + */ + TORCH_MODE_STATUS_OFF = 2, + } torch_mode_status_t; /** @@ -713,6 +725,12 @@ typedef struct camera_module { * camera_module_callbacks.torch_mode_status_change() that the torch mode * state has become available for set_torch_mode() to be called. * + * When the framework calls set_torch_mode() to turn on the torch mode of a + * flash unit, if HAL cannot keep multiple torch modes on simultaneously, + * HAL should turn off the torch mode that was turned on by + * a previous set_torch_mode() call and notify the framework that the torch + * mode state of that flash unit has become TORCH_MODE_STATUS_OFF. + * * Version information (based on camera_module_t.common.module_api_version): * * CAMERA_MODULE_API_VERSION_1_x/2_0/2_1/2_2/2_3: @@ -737,7 +755,7 @@ typedef struct camera_module { * -EINVAL: camera_id is invalid. * */ - int (*set_torch_mode)(const char* camera_id, bool on); + int (*set_torch_mode)(const char* camera_id, bool enabled); /* reserved for future use */ void* reserved[6]; |