cam_types.h revision 152ee3049941f9d51276932f0b507b800723b1de
1/* Copyright (c) 2012-2013, The Linux Foundation. All rights reserved. 2 * 3 * Redistribution and use in source and binary forms, with or without 4 * modification, are permitted provided that the following conditions are 5 * met: 6 * * Redistributions of source code must retain the above copyright 7 * notice, this list of conditions and the following disclaimer. 8 * * Redistributions in binary form must reproduce the above 9 * copyright notice, this list of conditions and the following 10 * disclaimer in the documentation and/or other materials provided 11 * with the distribution. 12 * * Neither the name of The Linux Foundation nor the names of its 13 * contributors may be used to endorse or promote products derived 14 * from this software without specific prior written permission. 15 * 16 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 23 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 25 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN 26 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 * 28 */ 29 30#ifndef __QCAMERA_TYPES_H__ 31#define __QCAMERA_TYPES_H__ 32 33#include <stdint.h> 34#include <pthread.h> 35#include <inttypes.h> 36#include <media/msmb_camera.h> 37 38#define CAM_MAX_NUM_BUFS_PER_STREAM 24 39#define MAX_METADATA_PAYLOAD_SIZE 1024 40 41#define CEILING32(X) (((X) + 0x0001F) & 0xFFFFFFE0) 42#define CEILING16(X) (((X) + 0x000F) & 0xFFF0) 43#define CEILING4(X) (((X) + 0x0003) & 0xFFFC) 44#define CEILING2(X) (((X) + 0x0001) & 0xFFFE) 45 46#define MAX_ZOOMS_CNT 64 47#define MAX_SIZES_CNT 24 48#define MAX_EXP_BRACKETING_LENGTH 32 49#define MAX_ROI 5 50#define MAX_STREAM_NUM_IN_BUNDLE 4 51#define MAX_NUM_STREAMS 8 52 53typedef enum { 54 CAM_HAL_V1 = 1, 55 CAM_HAL_V3 = 3 56} cam_hal_version_t; 57 58typedef enum { 59 CAM_STATUS_SUCCESS, /* Operation Succeded */ 60 CAM_STATUS_FAILED, /* Failure in doing operation */ 61 CAM_STATUS_INVALID_PARM, /* Inavlid parameter provided */ 62 CAM_STATUS_NOT_SUPPORTED, /* Parameter/operation not supported */ 63 CAM_STATUS_ACCEPTED, /* Parameter accepted */ 64 CAM_STATUS_MAX, 65} cam_status_t; 66 67typedef enum { 68 CAM_POSITION_BACK, 69 CAM_POSITION_FRONT 70} cam_position_t; 71 72typedef enum { 73 CAM_FORMAT_JPEG = 0, 74 CAM_FORMAT_YUV_420_NV12 = 1, 75 CAM_FORMAT_YUV_420_NV21, 76 CAM_FORMAT_YUV_420_NV21_ADRENO, 77 CAM_FORMAT_YUV_420_YV12, 78 CAM_FORMAT_YUV_422_NV16, 79 CAM_FORMAT_YUV_422_NV61, 80 CAM_FORMAT_YUV_420_NV12_VENUS, 81 82 /* Please note below are the defintions for raw image. 83 * Any format other than raw image format should be declared 84 * before this line!!!!!!!!!!!!! */ 85 86 /* Note: For all raw formats, each scanline needs to be 16 bytes aligned */ 87 88 /* Packed YUV/YVU raw format, 16 bpp: 8 bits Y and 8 bits UV. 89 * U and V are interleaved with Y: YUYV or YVYV */ 90 CAM_FORMAT_YUV_RAW_8BIT_YUYV, 91 CAM_FORMAT_YUV_RAW_8BIT_YVYU, 92 CAM_FORMAT_YUV_RAW_8BIT_UYVY, 93 CAM_FORMAT_YUV_RAW_8BIT_VYUY, 94 95 /* QCOM RAW formats where data is packed into 64bit word. 96 * 8BPP: 1 64-bit word contains 8 pixels p0 - p7, where p0 is 97 * stored at LSB. 98 * 10BPP: 1 64-bit word contains 6 pixels p0 - p5, where most 99 * significant 4 bits are set to 0. P0 is stored at LSB. 100 * 12BPP: 1 64-bit word contains 5 pixels p0 - p4, where most 101 * significant 4 bits are set to 0. P0 is stored at LSB. */ 102 CAM_FORMAT_BAYER_QCOM_RAW_8BPP_GBRG, 103 CAM_FORMAT_BAYER_QCOM_RAW_8BPP_GRBG, 104 CAM_FORMAT_BAYER_QCOM_RAW_8BPP_RGGB, 105 CAM_FORMAT_BAYER_QCOM_RAW_8BPP_BGGR, 106 CAM_FORMAT_BAYER_QCOM_RAW_10BPP_GBRG, 107 CAM_FORMAT_BAYER_QCOM_RAW_10BPP_GRBG, 108 CAM_FORMAT_BAYER_QCOM_RAW_10BPP_RGGB, 109 CAM_FORMAT_BAYER_QCOM_RAW_10BPP_BGGR, 110 CAM_FORMAT_BAYER_QCOM_RAW_12BPP_GBRG, 111 CAM_FORMAT_BAYER_QCOM_RAW_12BPP_GRBG, 112 CAM_FORMAT_BAYER_QCOM_RAW_12BPP_RGGB, 113 CAM_FORMAT_BAYER_QCOM_RAW_12BPP_BGGR, 114 /* MIPI RAW formats based on MIPI CSI-2 specifiction. 115 * 8BPP: Each pixel occupies one bytes, starting at LSB. 116 * Output with of image has no restrictons. 117 * 10BPP: Four pixels are held in every 5 bytes. The output 118 * with of image must be a multiple of 4 pixels. 119 * 12BPP: Two pixels are held in every 3 bytes. The output 120 * width of image must be a multiple of 2 pixels. */ 121 CAM_FORMAT_BAYER_MIPI_RAW_8BPP_GBRG, 122 CAM_FORMAT_BAYER_MIPI_RAW_8BPP_GRBG, 123 CAM_FORMAT_BAYER_MIPI_RAW_8BPP_RGGB, 124 CAM_FORMAT_BAYER_MIPI_RAW_8BPP_BGGR, 125 CAM_FORMAT_BAYER_MIPI_RAW_10BPP_GBRG, 126 CAM_FORMAT_BAYER_MIPI_RAW_10BPP_GRBG, 127 CAM_FORMAT_BAYER_MIPI_RAW_10BPP_RGGB, 128 CAM_FORMAT_BAYER_MIPI_RAW_10BPP_BGGR, 129 CAM_FORMAT_BAYER_MIPI_RAW_12BPP_GBRG, 130 CAM_FORMAT_BAYER_MIPI_RAW_12BPP_GRBG, 131 CAM_FORMAT_BAYER_MIPI_RAW_12BPP_RGGB, 132 CAM_FORMAT_BAYER_MIPI_RAW_12BPP_BGGR, 133 /* Ideal raw formats where image data has gone through black 134 * correction, lens rolloff, demux/channel gain, bad pixel 135 * correction, and ABF. 136 * Ideal raw formats could output any of QCOM_RAW and MIPI_RAW 137 * formats, plus plain8 8bbp, plain16 800, plain16 10bpp, and 138 * plain 16 12bpp */ 139 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_8BPP_GBRG, 140 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_8BPP_GRBG, 141 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_8BPP_RGGB, 142 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_8BPP_BGGR, 143 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_10BPP_GBRG, 144 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_10BPP_GRBG, 145 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_10BPP_RGGB, 146 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_10BPP_BGGR, 147 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_12BPP_GBRG, 148 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_12BPP_GRBG, 149 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_12BPP_RGGB, 150 CAM_FORMAT_BAYER_IDEAL_RAW_QCOM_12BPP_BGGR, 151 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_8BPP_GBRG, 152 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_8BPP_GRBG, 153 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_8BPP_RGGB, 154 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_8BPP_BGGR, 155 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_10BPP_GBRG, 156 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_10BPP_GRBG, 157 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_10BPP_RGGB, 158 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_10BPP_BGGR, 159 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_12BPP_GBRG, 160 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_12BPP_GRBG, 161 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_12BPP_RGGB, 162 CAM_FORMAT_BAYER_IDEAL_RAW_MIPI_12BPP_BGGR, 163 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN8_8BPP_GBRG, 164 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN8_8BPP_GRBG, 165 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN8_8BPP_RGGB, 166 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN8_8BPP_BGGR, 167 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_8BPP_GBRG, 168 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_8BPP_GRBG, 169 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_8BPP_RGGB, 170 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_8BPP_BGGR, 171 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_10BPP_GBRG, 172 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_10BPP_GRBG, 173 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_10BPP_RGGB, 174 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_10BPP_BGGR, 175 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_12BPP_GBRG, 176 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_12BPP_GRBG, 177 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_12BPP_RGGB, 178 CAM_FORMAT_BAYER_IDEAL_RAW_PLAIN16_12BPP_BGGR, 179 180 /* generic 8-bit raw */ 181 CAM_FORMAT_JPEG_RAW_8BIT, 182 CAM_FORMAT_META_RAW_8BIT, 183 184 CAM_FORMAT_MAX 185} cam_format_t; 186 187typedef enum { 188 /* applies to HAL 1 */ 189 CAM_STREAM_TYPE_DEFAULT, /* default stream type */ 190 CAM_STREAM_TYPE_PREVIEW, /* preview */ 191 CAM_STREAM_TYPE_POSTVIEW, /* postview */ 192 CAM_STREAM_TYPE_SNAPSHOT, /* snapshot */ 193 CAM_STREAM_TYPE_VIDEO, /* video */ 194 195 /* applies to HAL 3 */ 196 CAM_STREAM_TYPE_IMPL_DEFINED, /* opaque format: could be display, video enc, ZSL YUV */ 197 CAM_STREAM_TYPE_YUV, /* app requested callback stream type */ 198 199 /* applies to both HAL 1 and HAL 3 */ 200 CAM_STREAM_TYPE_METADATA, /* meta data */ 201 CAM_STREAM_TYPE_RAW, /* raw dump from camif */ 202 CAM_STREAM_TYPE_OFFLINE_PROC, /* offline process */ 203 CAM_STREAM_TYPE_MAX, 204} cam_stream_type_t; 205 206typedef enum { 207 CAM_PAD_NONE = 1, 208 CAM_PAD_TO_2 = 2, 209 CAM_PAD_TO_4 = 4, 210 CAM_PAD_TO_WORD = CAM_PAD_TO_4, 211 CAM_PAD_TO_8 = 8, 212 CAM_PAD_TO_16 = 16, 213 CAM_PAD_TO_32 = 32, 214 CAM_PAD_TO_64 = 64, 215 CAM_PAD_TO_1K = 1024, 216 CAM_PAD_TO_2K = 2048, 217 CAM_PAD_TO_4K = 4096, 218 CAM_PAD_TO_8K = 8192 219} cam_pad_format_t; 220 221typedef enum { 222 /* followings are per camera */ 223 CAM_MAPPING_BUF_TYPE_CAPABILITY, /* mapping camera capability buffer */ 224 CAM_MAPPING_BUF_TYPE_PARM_BUF, /* mapping parameters buffer */ 225 226 /* followings are per stream */ 227 CAM_MAPPING_BUF_TYPE_STREAM_BUF, /* mapping stream buffers */ 228 CAM_MAPPING_BUF_TYPE_STREAM_INFO, /* mapping stream information buffer */ 229 CAM_MAPPING_BUF_TYPE_OFFLINE_INPUT_BUF, /* mapping offline process input buffer */ 230 CAM_MAPPING_BUF_TYPE_MAX 231} cam_mapping_buf_type; 232 233typedef struct { 234 cam_mapping_buf_type type; 235 uint32_t stream_id; /* stream id: valid if STREAM_BUF */ 236 uint32_t frame_idx; /* frame index: valid if type is STREAM_BUF */ 237 int32_t plane_idx; /* planner index. valid if type is STREAM_BUF. 238 * -1 means all planners shanre the same fd; 239 * otherwise, each planner has its own fd */ 240 unsigned long cookie; /* could be job_id(uint32_t) to identify mapping job */ 241 int fd; /* origin fd */ 242 uint32_t size; /* size of the buffer */ 243} cam_buf_map_type; 244 245typedef struct { 246 cam_mapping_buf_type type; 247 uint32_t stream_id; /* stream id: valid if STREAM_BUF */ 248 uint32_t frame_idx; /* frame index: valid if STREAM_BUF or HIST_BUF */ 249 int32_t plane_idx; /* planner index. valid if type is STREAM_BUF. 250 * -1 means all planners shanre the same fd; 251 * otherwise, each planner has its own fd */ 252 unsigned long cookie; /* could be job_id(uint32_t) to identify unmapping job */ 253} cam_buf_unmap_type; 254 255typedef enum { 256 CAM_MAPPING_TYPE_FD_MAPPING, 257 CAM_MAPPING_TYPE_FD_UNMAPPING, 258 CAM_MAPPING_TYPE_MAX 259} cam_mapping_type; 260 261typedef struct { 262 cam_mapping_type msg_type; 263 union { 264 cam_buf_map_type buf_map; 265 cam_buf_unmap_type buf_unmap; 266 } payload; 267} cam_sock_packet_t; 268 269typedef enum { 270 CAM_MODE_2D = (1<<0), 271 CAM_MODE_3D = (1<<1) 272} cam_mode_t; 273 274typedef struct { 275 uint32_t len; 276 uint32_t y_offset; 277 uint32_t cbcr_offset; 278} cam_sp_len_offset_t; 279 280typedef struct{ 281 uint32_t len; 282 uint32_t offset; 283 int32_t offset_x; 284 int32_t offset_y; 285 int32_t stride; 286 int32_t scanline; 287} cam_mp_len_offset_t; 288 289typedef struct { 290 uint32_t width_padding; 291 uint32_t height_padding; 292 uint32_t plane_padding; 293} cam_padding_info_t; 294 295typedef struct { 296 int num_planes; 297 union { 298 cam_sp_len_offset_t sp; 299 cam_mp_len_offset_t mp[VIDEO_MAX_PLANES]; 300 }; 301 uint32_t frame_len; 302} cam_frame_len_offset_t; 303 304typedef struct { 305 int32_t width; 306 int32_t height; 307} cam_dimension_t; 308 309typedef struct { 310 cam_frame_len_offset_t plane_info; 311} cam_stream_buf_plane_info_t; 312 313typedef struct { 314 float min_fps; 315 float max_fps; 316} cam_fps_range_t; 317 318typedef enum { 319 CAM_HFR_MODE_OFF, 320 CAM_HFR_MODE_60FPS, 321 CAM_HFR_MODE_90FPS, 322 CAM_HFR_MODE_120FPS, 323 CAM_HFR_MODE_150FPS, 324 CAM_HFR_MODE_MAX 325} cam_hfr_mode_t; 326 327typedef struct { 328 cam_hfr_mode_t mode; 329 cam_dimension_t dim; 330 uint8_t frame_skip; 331 uint8_t livesnapshot_sizes_tbl_cnt; /* livesnapshot sizes table size */ 332 cam_dimension_t livesnapshot_sizes_tbl[MAX_SIZES_CNT]; /* livesnapshot sizes table */ 333} cam_hfr_info_t; 334 335typedef enum { 336 CAM_WB_MODE_AUTO, 337 CAM_WB_MODE_CUSTOM, 338 CAM_WB_MODE_INCANDESCENT, 339 CAM_WB_MODE_FLUORESCENT, 340 CAM_WB_MODE_WARM_FLUORESCENT, 341 CAM_WB_MODE_DAYLIGHT, 342 CAM_WB_MODE_CLOUDY_DAYLIGHT, 343 CAM_WB_MODE_TWILIGHT, 344 CAM_WB_MODE_SHADE, 345 CAM_WB_MODE_OFF, 346 CAM_WB_MODE_MAX 347} cam_wb_mode_type; 348 349typedef enum { 350 CAM_ANTIBANDING_MODE_OFF, 351 CAM_ANTIBANDING_MODE_60HZ, 352 CAM_ANTIBANDING_MODE_50HZ, 353 CAM_ANTIBANDING_MODE_AUTO, 354 CAM_ANTIBANDING_MODE_AUTO_50HZ, 355 CAM_ANTIBANDING_MODE_AUTO_60HZ, 356 CAM_ANTIBANDING_MODE_MAX, 357} cam_antibanding_mode_type; 358 359/* Enum Type for different ISO Mode supported */ 360typedef enum { 361 CAM_ISO_MODE_AUTO, 362 CAM_ISO_MODE_DEBLUR, 363 CAM_ISO_MODE_100, 364 CAM_ISO_MODE_200, 365 CAM_ISO_MODE_400, 366 CAM_ISO_MODE_800, 367 CAM_ISO_MODE_1600, 368 CAM_ISO_MODE_MAX 369} cam_iso_mode_type; 370 371typedef enum { 372 CAM_AEC_MODE_FRAME_AVERAGE, 373 CAM_AEC_MODE_CENTER_WEIGHTED, 374 CAM_AEC_MODE_SPOT_METERING, 375 CAM_AEC_MODE_SMART_METERING, 376 CAM_AEC_MODE_USER_METERING, 377 CAM_AEC_MODE_SPOT_METERING_ADV, 378 CAM_AEC_MODE_CENTER_WEIGHTED_ADV, 379 CAM_AEC_MODE_MAX 380} cam_auto_exposure_mode_type; 381 382typedef enum { 383 CAM_AE_MODE_OFF, 384 CAM_AE_MODE_ON, 385 CAM_AE_MODE_MAX 386} cam_ae_mode_type; 387 388typedef enum { 389 CAM_FOCUS_ALGO_AUTO, 390 CAM_FOCUS_ALGO_SPOT, 391 CAM_FOCUS_ALGO_CENTER_WEIGHTED, 392 CAM_FOCUS_ALGO_AVERAGE, 393 CAM_FOCUS_ALGO_MAX 394} cam_focus_algorithm_type; 395 396/* Auto focus mode */ 397typedef enum { 398 CAM_FOCUS_MODE_AUTO, 399 CAM_FOCUS_MODE_INFINITY, 400 CAM_FOCUS_MODE_MACRO, 401 CAM_FOCUS_MODE_FIXED, 402 CAM_FOCUS_MODE_EDOF, 403 CAM_FOCUS_MODE_CONTINOUS_VIDEO, 404 CAM_FOCUS_MODE_CONTINOUS_PICTURE, 405 CAM_FOCUS_MODE_MAX 406} cam_focus_mode_type; 407 408typedef enum { 409 CAM_SCENE_MODE_OFF, 410 CAM_SCENE_MODE_AUTO, 411 CAM_SCENE_MODE_LANDSCAPE, 412 CAM_SCENE_MODE_SNOW, 413 CAM_SCENE_MODE_BEACH, 414 CAM_SCENE_MODE_SUNSET, 415 CAM_SCENE_MODE_NIGHT, 416 CAM_SCENE_MODE_PORTRAIT, 417 CAM_SCENE_MODE_BACKLIGHT, 418 CAM_SCENE_MODE_SPORTS, 419 CAM_SCENE_MODE_ANTISHAKE, 420 CAM_SCENE_MODE_FLOWERS, 421 CAM_SCENE_MODE_CANDLELIGHT, 422 CAM_SCENE_MODE_FIREWORKS, 423 CAM_SCENE_MODE_PARTY, 424 CAM_SCENE_MODE_NIGHT_PORTRAIT, 425 CAM_SCENE_MODE_THEATRE, 426 CAM_SCENE_MODE_ACTION, 427 CAM_SCENE_MODE_AR, 428 CAM_SCENE_MODE_FACE_PRIORITY, 429 CAM_SCENE_MODE_BARCODE, 430 CAM_SCENE_MODE_MAX 431} cam_scene_mode_type; 432 433typedef enum { 434 CAM_EFFECT_MODE_OFF, 435 CAM_EFFECT_MODE_MONO, 436 CAM_EFFECT_MODE_NEGATIVE, 437 CAM_EFFECT_MODE_SOLARIZE, 438 CAM_EFFECT_MODE_SEPIA, 439 CAM_EFFECT_MODE_POSTERIZE, 440 CAM_EFFECT_MODE_WHITEBOARD, 441 CAM_EFFECT_MODE_BLACKBOARD, 442 CAM_EFFECT_MODE_AQUA, 443 CAM_EFFECT_MODE_EMBOSS, 444 CAM_EFFECT_MODE_SKETCH, 445 CAM_EFFECT_MODE_NEON, 446 CAM_EFFECT_MODE_MAX 447} cam_effect_mode_type; 448 449typedef enum { 450 CAM_FLASH_MODE_OFF, 451 CAM_FLASH_MODE_AUTO, 452 CAM_FLASH_MODE_ON, 453 CAM_FLASH_MODE_TORCH, 454 CAM_FLASH_MODE_MAX 455} cam_flash_mode_t; 456 457typedef enum { 458 CAM_AEC_TRIGGER_IDLE, 459 CAM_AEC_TRIGGER_START 460} cam_aec_trigger_type_t; 461 462typedef enum { 463 CAM_AF_TRIGGER_IDLE, 464 CAM_AF_TRIGGER_START, 465 CAM_AF_TRIGGER_CANCEL 466} cam_af_trigger_type_t; 467 468typedef enum { 469 CAM_AE_STATE_INACTIVE, 470 CAM_AE_STATE_SEARCHING, 471 CAM_AE_STATE_CONVERGED, 472 CAM_AE_STATE_LOCKED, 473 CAM_AE_STATE_FLASH_REQUIRED, 474 CAM_AE_STATE_PRECAPTURE 475} cam_ae_state_t; 476 477typedef struct { 478 int32_t left; 479 int32_t top; 480 int32_t width; 481 int32_t height; 482} cam_rect_t; 483 484typedef struct { 485 cam_rect_t rect; 486 int32_t weight; /* weight of the area, valid for focusing/metering areas */ 487} cam_area_t; 488 489typedef enum { 490 CAM_STREAMING_MODE_CONTINUOUS, /* continous streaming */ 491 CAM_STREAMING_MODE_BURST, /* burst streaming */ 492 CAM_STREAMING_MODE_MAX 493} cam_streaming_mode_t; 494 495#define CAM_REPROCESS_MASK_TYPE_WNR (1<<0) 496 497/* event from server */ 498typedef enum { 499 CAM_EVENT_TYPE_MAP_UNMAP_DONE = (1<<0), 500 CAM_EVENT_TYPE_AUTO_FOCUS_DONE = (1<<1), 501 CAM_EVENT_TYPE_ZOOM_DONE = (1<<2), 502 CAM_EVENT_TYPE_DAEMON_DIED = (1<<3), 503 CAM_EVENT_TYPE_MAX 504} cam_event_type_t; 505 506typedef enum { 507 CAM_EXP_BRACKETING_OFF, 508 CAM_EXP_BRACKETING_ON 509} cam_bracket_mode; 510 511typedef struct { 512 cam_bracket_mode mode; 513 char values[MAX_EXP_BRACKETING_LENGTH]; /* user defined values */ 514} cam_exp_bracketing_t; 515 516typedef enum { 517 CAM_AEC_ROI_OFF, 518 CAM_AEC_ROI_ON 519} cam_aec_roi_ctrl_t; 520 521typedef enum { 522 CAM_AEC_ROI_BY_INDEX, 523 CAM_AEC_ROI_BY_COORDINATE, 524} cam_aec_roi_type_t; 525 526typedef struct { 527 uint32_t x; 528 uint32_t y; 529} cam_coordinate_type_t; 530 531typedef struct { 532 int32_t numerator; 533 int32_t denominator; 534} cam_rational_type_t; 535 536typedef struct { 537 cam_aec_roi_ctrl_t aec_roi_enable; 538 cam_aec_roi_type_t aec_roi_type; 539 union { 540 cam_coordinate_type_t coordinate[MAX_ROI]; 541 uint32_t aec_roi_idx[MAX_ROI]; 542 } cam_aec_roi_position; 543} cam_set_aec_roi_t; 544 545typedef struct { 546 uint32_t frm_id; 547 uint8_t num_roi; 548 cam_rect_t roi[MAX_ROI]; 549 int32_t weight[MAX_ROI]; 550 uint8_t is_multiwindow; 551} cam_roi_info_t; 552 553typedef enum { 554 CAM_WAVELET_DENOISE_YCBCR_PLANE, 555 CAM_WAVELET_DENOISE_CBCR_ONLY, 556 CAM_WAVELET_DENOISE_STREAMLINE_YCBCR, 557 CAM_WAVELET_DENOISE_STREAMLINED_CBCR 558} cam_denoise_process_type_t; 559 560typedef struct { 561 int denoise_enable; 562 cam_denoise_process_type_t process_plates; 563} cam_denoise_param_t; 564 565#define CAM_FACE_PROCESS_MASK_DETECTION (1<<0) 566#define CAM_FACE_PROCESS_MASK_RECOGNITION (1<<1) 567typedef struct { 568 int fd_mode; /* mask of face process */ 569 int num_fd; 570} cam_fd_set_parm_t; 571 572typedef struct { 573 int8_t face_id; /* unique id for face tracking within view unless view changes */ 574 int8_t score; /* score of confidence (0, -100) */ 575 cam_rect_t face_boundary; /* boundary of face detected */ 576 cam_coordinate_type_t left_eye_center; /* coordinate of center of left eye */ 577 cam_coordinate_type_t right_eye_center; /* coordinate of center of right eye */ 578 cam_coordinate_type_t mouth_center; /* coordinate of center of mouth */ 579 uint8_t smile_degree; /* smile degree (0, -100) */ 580 uint8_t smile_confidence; /* smile confidence (0, 100) */ 581 uint8_t face_recognised; /* if face is recognised */ 582 int8_t gaze_angle; /* -90 -45 0 45 90 for head left to rigth tilt */ 583 int8_t updown_dir; /* up down direction (-90, 90) */ 584 int8_t leftright_dir; /* left right direction (-90, 90) */ 585 int8_t roll_dir; /* roll direction (-90, 90) */ 586 int8_t left_right_gaze; /* left right gaze degree (-50, 50) */ 587 int8_t top_bottom_gaze; /* up down gaze degree (-50, 50) */ 588 uint8_t blink_detected; /* if blink is detected */ 589 uint8_t left_blink; /* left eye blink degeree (0, -100) */ 590 uint8_t right_blink; /* right eye blink degree (0, - 100) */ 591} cam_face_detection_info_t; 592 593typedef struct { 594 uint32_t frame_id; /* frame index of which faces are detected */ 595 uint8_t num_faces_detected; /* number of faces detected */ 596 cam_face_detection_info_t faces[MAX_ROI]; /* detailed information of faces detected */ 597} cam_face_detection_data_t; 598 599#define CAM_HISTOGRAM_STATS_SIZE 256 600typedef struct { 601 uint32_t max_hist_value; 602 uint32_t hist_buf[CAM_HISTOGRAM_STATS_SIZE]; /* buf holding histogram stats data */ 603} cam_histogram_data_t; 604 605typedef struct { 606 cam_histogram_data_t r_stats; 607 cam_histogram_data_t b_stats; 608 cam_histogram_data_t gr_stats; 609 cam_histogram_data_t gb_stats; 610} cam_bayer_hist_stats_t; 611 612typedef enum { 613 CAM_HISTOGRAM_TYPE_BAYER, 614 CAM_HISTOGRAM_TYPE_YUV 615} cam_histogram_type_t; 616 617typedef struct { 618 cam_histogram_type_t type; 619 union { 620 cam_bayer_hist_stats_t bayer_stats; 621 cam_histogram_data_t yuv_stats; 622 }; 623} cam_hist_stats_t; 624 625enum cam_focus_distance_index{ 626 CAM_FOCUS_DISTANCE_NEAR_INDEX, /* 0 */ 627 CAM_FOCUS_DISTANCE_OPTIMAL_INDEX, 628 CAM_FOCUS_DISTANCE_FAR_INDEX, 629 CAM_FOCUS_DISTANCE_MAX_INDEX 630}; 631 632typedef struct { 633 float focus_distance[CAM_FOCUS_DISTANCE_MAX_INDEX]; 634} cam_focus_distances_info_t; 635 636/* Different autofocus cycle when calling do_autoFocus 637 * CAM_AF_COMPLETE_EXISTING_SWEEP: Complete existing sweep 638 * if one is ongoing, and lock. 639 * CAM_AF_DO_ONE_FULL_SWEEP: Do one full sweep, regardless 640 * of the current state, and lock. 641 * CAM_AF_START_CONTINUOUS_SWEEP: Start continous sweep. 642 * After do_autoFocus, HAL receives an event: CAM_AF_FOCUSED, 643 * or CAM_AF_NOT_FOCUSED. 644 * cancel_autoFocus stops any lens movement. 645 * Each do_autoFocus call only produces 1 FOCUSED/NOT_FOCUSED 646 * event, not both. 647 */ 648typedef enum { 649 CAM_AF_COMPLETE_EXISTING_SWEEP, 650 CAM_AF_DO_ONE_FULL_SWEEP, 651 CAM_AF_START_CONTINUOUS_SWEEP 652} cam_autofocus_cycle_t; 653 654typedef enum { 655 CAM_AF_SCANNING, 656 CAM_AF_FOCUSED, 657 CAM_AF_NOT_FOCUSED 658} cam_autofocus_state_t; 659 660typedef struct { 661 cam_autofocus_state_t focus_state; /* state of focus */ 662 cam_focus_distances_info_t focus_dist; /* focus distance */ 663} cam_auto_focus_data_t; 664 665typedef struct { 666 uint32_t stream_id; 667 cam_rect_t crop; 668} cam_stream_crop_info_t; 669 670typedef struct { 671 uint8_t num_of_streams; 672 cam_stream_crop_info_t crop_info[MAX_NUM_STREAMS]; 673} cam_crop_data_t; 674 675typedef enum { 676 DO_NOT_NEED_FUTURE_FRAME, 677 NEED_FUTURE_FRAME, 678} cam_prep_snapshot_state_t; 679 680typedef struct { 681 uint32_t min_frame_idx; 682 uint32_t max_frame_idx; 683} cam_frame_idx_range_t; 684 685typedef struct { 686 uint8_t is_stats_valid; /* if histgram data is valid */ 687 cam_hist_stats_t stats_data; /* histogram data */ 688 689 uint8_t is_faces_valid; /* if face detection data is valid */ 690 cam_face_detection_data_t faces_data; /* face detection result */ 691 692 uint8_t is_focus_valid; /* if focus data is valid */ 693 cam_auto_focus_data_t focus_data; /* focus data */ 694 695 uint8_t is_crop_valid; /* if crop data is valid */ 696 cam_crop_data_t crop_data; /* crop data */ 697 698 uint8_t is_prep_snapshot_done_valid; /* if prep snapshot done is valid */ 699 cam_prep_snapshot_state_t prep_snapshot_done_state; /* prepare snapshot done state */ 700 701 /* if good frame idx range is valid */ 702 uint8_t is_good_frame_idx_range_valid; 703 /* good frame idx range, make sure: 704 * 1. good_frame_idx_range.min_frame_idx > current_frame_idx 705 * 2. good_frame_idx_range.min_frame_idx - current_frame_idx < 100 */ 706 cam_frame_idx_range_t good_frame_idx_range; 707 708 char private_metadata[MAX_METADATA_PAYLOAD_SIZE]; 709 710} cam_metadata_info_t; 711 712typedef enum { 713 CAM_INTF_PARM_HAL_VERSION, 714 /* common between HAL1 and HAL3 */ 715 CAM_INTF_PARM_ANTIBANDING, 716 CAM_INTF_PARM_EXPOSURE_COMPENSATION, 717 CAM_INTF_PARM_AEC_LOCK, 718 CAM_INTF_PARM_FPS_RANGE, 719 CAM_INTF_PARM_AWB_LOCK, 720 CAM_INTF_PARM_WHITE_BALANCE, 721 CAM_INTF_PARM_EFFECT, 722 CAM_INTF_PARM_BESTSHOT_MODE, 723 CAM_INTF_PARM_DIS_ENABLE, 724 CAM_INTF_PARM_LED_MODE, 725 CAM_INTF_META_HISTOGRAM, /* 10 */ 726 CAM_INTF_META_FACE_DETECTION, 727 CAM_INTF_META_AUTOFOCUS_DATA, 728 729 /* specific to HAl1 */ 730 CAM_INTF_PARM_QUERY_FLASH4SNAP, 731 CAM_INTF_PARM_EXPOSURE, 732 CAM_INTF_PARM_SHARPNESS, 733 CAM_INTF_PARM_CONTRAST, 734 CAM_INTF_PARM_SATURATION, 735 CAM_INTF_PARM_BRIGHTNESS, 736 CAM_INTF_PARM_ISO, 737 CAM_INTF_PARM_ZOOM, /* 20 */ 738 CAM_INTF_PARM_ROLLOFF, 739 CAM_INTF_PARM_MODE, /* camera mode */ 740 CAM_INTF_PARM_AEC_ALGO_TYPE, /* auto exposure algorithm */ 741 CAM_INTF_PARM_FOCUS_ALGO_TYPE, /* focus algorithm */ 742 CAM_INTF_PARM_AEC_ROI, 743 CAM_INTF_PARM_AF_ROI, 744 CAM_INTF_PARM_FOCUS_MODE, 745 CAM_INTF_PARM_SCE_FACTOR, 746 CAM_INTF_PARM_FD, 747 CAM_INTF_PARM_MCE, /* 30 */ 748 CAM_INTF_PARM_HFR, 749 CAM_INTF_PARM_REDEYE_REDUCTION, 750 CAM_INTF_PARM_WAVELET_DENOISE, 751 CAM_INTF_PARM_HISTOGRAM, 752 CAM_INTF_PARM_ASD_ENABLE, 753 CAM_INTF_PARM_RECORDING_HINT, 754 CAM_INTF_PARM_HDR, 755 CAM_INTF_PARM_FRAMESKIP, 756 CAM_INTF_PARM_ZSL_MODE, /* indicating if it's running in ZSL mode */ 757 CAM_INTF_PARM_HDR_NEED_1X, /* if HDR needs 1x output */ /* 40 */ 758 CAM_INTF_PARM_LOCK_CAF, 759 CAM_INTF_PARM_VIDEO_HDR, 760 CAM_INTF_PARM_ROTATION, 761 CAM_INTF_META_CROP_DATA, 762 CAM_INTF_META_PREP_SNAPSHOT_DONE, 763 CAM_INTF_META_GOOD_FRAME_IDX_RANGE, 764 765 /* stream based parameters */ 766 CAM_INTF_PARM_DO_REPROCESS, 767 CAM_INTF_PARM_SET_BUNDLE, 768 769 /* specific to HAL3 */ 770 /* Whether the metadata maps to a valid frame number */ 771 CAM_INTF_META_FRAME_NUMBER_VALID, 772 /* Number of pending requests yet to be processed */ 773 CAM_INTF_META_PENDING_REQUESTS, 774 /* COLOR CORRECTION.*/ 775 CAM_INTF_META_COLOR_CORRECT_MODE, 776 /* A transform matrix to chromatically adapt pixels in the CIE XYZ (1931) 777 * color space from the scene illuminant to the sRGB-standard D65-illuminant. */ 778 CAM_INTF_META_COLOR_CORRECT_TRANSFORM, /* 50 */ 779 /* CONTROL */ 780// CAM_INTF_META_REQUEST_ID, 781 /* A frame counter set by the framework. Must be maintained unchanged in 782 * output frame. */ 783 CAM_INTF_META_FRAME_NUMBER, 784 /* Whether AE is currently updating the sensor exposure and sensitivity 785 * fields */ 786 CAM_INTF_META_AEC_MODE, 787 /* List of areas to use for metering */ 788 CAM_INTF_META_AEC_ROI, 789 /* Whether the HAL must trigger precapture metering.*/ 790 CAM_INTF_META_AEC_PRECAPTURE_TRIGGER, 791 /* The ID sent with the latest CAMERA2_TRIGGER_PRECAPTURE_METERING call */ 792 CAM_INTF_META_AEC_PRECAPTURE_ID, 793 /* Current state of AE algorithm */ 794 CAM_INTF_META_AEC_STATE, 795 /* List of areas to use for focus estimation */ 796 CAM_INTF_META_AF_ROI, 797 /* Whether the HAL must trigger autofocus. */ 798 CAM_INTF_META_AF_TRIGGER, 799 /* Current state of AF algorithm */ 800 CAM_INTF_META_AF_STATE, 801 /* The ID sent with the latest CAMERA2_TRIGGER_AUTOFOCUS call */ 802 CAM_INTF_META_AF_TRIGGER_ID, 803 /* List of areas to use for illuminant estimation */ 804 CAM_INTF_META_AWB_REGIONS, 805 /* Current state of AWB algorithm */ 806 CAM_INTF_META_AWB_STATE, 807 /* Information to 3A routines about the purpose of this capture, to help 808 * decide optimal 3A strategy */ 809 CAM_INTF_META_CAPTURE_INTENT, 810 /* Overall mode of 3A control routines. We need to have this parameter 811 * because not all android.control.* have an OFF option, for example, 812 * AE_FPS_Range, aePrecaptureTrigger */ 813 CAM_INTF_META_MODE, 814 /* DEMOSAIC */ 815 /* Controls the quality of the demosaicing processing */ 816 CAM_INTF_META_DEMOSAIC, 817 /* EDGE */ 818 /* Operation mode for edge enhancement */ 819 CAM_INTF_META_EDGE, 820 /* Control the amount of edge enhancement applied to the images.*/ 821 /* 1-10; 10 is maximum sharpening */ 822 CAM_INTF_META_SHARPNESS_STRENGTH, 823 /* FLASH */ 824 /* Power for flash firing/torch, 10 is max power; 0 is no flash. Linear */ 825 CAM_INTF_META_FLASH_POWER, 826 /* Firing time of flash relative to start of exposure, in nanoseconds*/ 827 CAM_INTF_META_FLASH_FIRING_TIME, 828 /* Current state of the flash unit */ 829 CAM_INTF_META_FLASH_STATE, 830 /* GEOMETRIC */ 831 /* Operating mode of geometric correction */ 832 CAM_INTF_META_GEOMETRIC_MODE, 833 /* Control the amount of shading correction applied to the images */ 834 CAM_INTF_META_GEOMETRIC_STRENGTH, 835 /* HOT PIXEL */ 836 /* Set operational mode for hot pixel correction */ 837 CAM_INTF_META_HOTPIXEL_MODE, 838 /* LENS */ 839 /* Size of the lens aperture */ 840 CAM_INTF_META_LENS_APERTURE, 841 /* State of lens neutral density filter(s) */ 842 CAM_INTF_META_LENS_FILTERDENSITY, 843 /* Lens optical zoom setting */ 844 CAM_INTF_META_LENS_FOCAL_LENGTH, 845 /* Distance to plane of sharpest focus, measured from frontmost surface 846 * of the lens */ 847 CAM_INTF_META_LENS_FOCUS_DISTANCE, 848 /* The range of scene distances that are in sharp focus (depth of field) */ 849 CAM_INTF_META_LENS_FOCUS_RANGE, 850 /* Whether optical image stabilization is enabled. */ 851 CAM_INTF_META_LENS_OPT_STAB_MODE, 852 /* Current lens status */ 853 CAM_INTF_META_LENS_STATE, 854 /* NOISE REDUCTION */ 855 /* Mode of operation for the noise reduction algorithm */ 856 CAM_INTF_META_NOISE_REDUCTION_MODE, 857 /* Control the amount of noise reduction applied to the images. 858 * 1-10; 10 is max noise reduction */ 859 CAM_INTF_META_NOISE_REDUCTION_STRENGTH, 860 /* SCALER */ 861 /* Top-left corner and width of the output region to select from the active 862 * pixel array */ 863 CAM_INTF_META_SCALER_CROP_REGION, 864 /* SENSOR */ 865 /* Duration each pixel is exposed to light, in nanoseconds */ 866 CAM_INTF_META_SENSOR_EXPOSURE_TIME, 867 /* Duration from start of frame exposure to start of next frame exposure, 868 * in nanoseconds */ 869 CAM_INTF_META_SENSOR_FRAME_DURATION, 870 /* Gain applied to image data. Must be implemented through analog gain only 871 * if set to values below 'maximum analog sensitivity'. */ 872 CAM_INTF_META_SENSOR_SENSITIVITY, 873 /* Time at start of exposure of first row */ 874 CAM_INTF_META_SENSOR_TIMESTAMP, 875 /* SHADING */ 876 /* Quality of lens shading correction applied to the image data */ 877 CAM_INTF_META_SHADING_MODE, 878 /* Control the amount of shading correction applied to the images. 879 * unitless: 1-10; 10 is full shading compensation */ 880 CAM_INTF_META_SHADING_STRENGTH, 881 /* STATISTICS */ 882 /* State of the face detector unit */ 883 CAM_INTF_META_STATS_FACEDETECT_MODE, 884 /* Operating mode for histogram generation */ 885 CAM_INTF_META_STATS_HISTOGRAM_MODE, 886 /* Operating mode for sharpness map generation */ 887 CAM_INTF_META_STATS_SHARPNESS_MAP_MODE, 888 /* A 3-channel sharpness map, based on the raw sensor data, 889 * If only a monochrome sharpness map is supported, all channels 890 * should have the same data 891 */ 892 CAM_INTF_META_STATS_SHARPNESS_MAP, 893 894 /* TONEMAP */ 895 /* Table mapping blue input values to output values */ 896 CAM_INTF_META_TONEMAP_CURVE_BLUE, 897 /* Table mapping green input values to output values */ 898 CAM_INTF_META_TONEMAP_CURVE_GREEN, 899 /* Table mapping red input values to output values */ 900 CAM_INTF_META_TONEMAP_CURVE_RED, 901 /* Tone map mode */ 902 CAM_INTF_META_TONEMAP_MODE, 903 CAM_INTF_META_FLASH_MODE, 904 CAM_INTF_META_PRIVATE_DATA, 905 CAM_INTF_PARM_MAX 906} cam_intf_parm_type_t; 907 908/***************************************************************************** 909 * Code for HAL3 data types * 910 ****************************************************************************/ 911typedef enum { 912 CAM_INTF_METADATA_MAX 913} cam_intf_metadata_type_t; 914 915typedef enum { 916 CAM_INTENT_CUSTOM, 917 CAM_INTENT_PREVIEW, 918 CAM_INTENT_STILL_CAPTURE, 919 CAM_INTENT_VIDEO_RECORD, 920 CAM_INTENT_VIDEO_SNAPSHOT, 921 CAM_INTENT_ZERO_SHUTTER_LAG, 922 CAM_INTENT_MAX, 923} cam_intent_t; 924 925typedef enum { 926 /* Full application control of pipeline. All 3A routines are disabled, 927 * no other settings in android.control.* have any effect */ 928 CAM_CONTROL_OFF, 929 /* Use settings for each individual 3A routine. Manual control of capture 930 * parameters is disabled. All controls in android.control.* besides sceneMode 931 * take effect */ 932 CAM_CONTROL_AUTO, 933 /* Use specific scene mode. Enabling this disables control.aeMode, 934 * control.awbMode and control.afMode controls; the HAL must ignore those 935 * settings while USE_SCENE_MODE is active (except for FACE_PRIORITY scene mode). 936 * Other control entries are still active. This setting can only be used if 937 * availableSceneModes != UNSUPPORTED. TODO: Should we remove this and handle this 938 * in HAL ?*/ 939 CAM_CONTROL_USE_SCENE_MODE, 940 CAM_CONTROL_MAX 941} cam_control_mode_t; 942 943typedef enum { 944 /* Use the android.colorCorrection.transform matrix to do color conversion */ 945 CAM_COLOR_CORRECTION_TRANSFORM_MATRIX, 946 /* Must not slow down frame rate relative to raw bayer output */ 947 CAM_COLOR_CORRECTION_FAST, 948 /* Frame rate may be reduced by high quality */ 949 CAM_COLOR_CORRECTION_HIGH_QUALITY, 950} cam_color_correct_mode_t; 951 952typedef struct { 953 /* 3x3 float matrix in row-major order. each element is in range of (0, 1) */ 954 float transform[3][3]; 955} cam_color_correct_matrix_t; 956 957#define CAM_FOCAL_LENGTHS_MAX 1 958#define CAM_APERTURES_MAX 1 959#define CAM_FILTER_DENSITIES_MAX 1 960#define CAM_MAX_MAP_HEIGHT 6 961#define CAM_MAX_MAP_WIDTH 6 962 963#define CAM_MAX_TONEMAP_CURVE_SIZE 128 964 965typedef struct { 966 int tonemap_points_cnt; 967 968 /* A 1D array of pairs of floats. 969 * Mapping a 0-1 input range to a 0-1 output range. 970 * The input range must be monotonically increasing with N, 971 * and values between entries should be linearly interpolated. 972 * For example, if the array is: [0.0, 0.0, 0.3, 0.5, 1.0, 1.0], 973 * then the input->output mapping for a few sample points would be: 974 * 0 -> 0, 0.15 -> 0.25, 0.3 -> 0.5, 0.5 -> 0.64 */ 975 float tonemap_points[CAM_MAX_TONEMAP_CURVE_SIZE][2]; 976} cam_tonemap_curve_t; 977 978typedef enum { 979 OFF, 980 FAST, 981 QUALITY, 982} cam_quality_preference_t; 983 984typedef enum { 985 CAM_FLASH_CTRL_OFF, 986 CAM_FLASH_CTRL_SINGLE, 987 CAM_FLASH_CTRL_TORCH 988} cam_flash_ctrl_t; 989 990typedef struct { 991 uint8_t ae_mode; 992 uint8_t awb_mode; 993 uint8_t af_mode; 994} cam_scene_mode_overrides_t; 995 996typedef struct { 997 int32_t left; 998 int32_t top; 999 int32_t width; 1000 int32_t height; 1001} cam_crop_region_t; 1002 1003typedef struct { 1004 /* Estimated sharpness for each region of the input image. 1005 * Normalized to be between 0 and maxSharpnessMapValue. 1006 * Higher values mean sharper (better focused) */ 1007 int32_t sharpness[CAM_MAX_MAP_WIDTH][CAM_MAX_MAP_HEIGHT]; 1008} cam_sharpness_map_t; 1009 1010typedef struct { 1011 int32_t min_value; 1012 int32_t max_value; 1013 int32_t def_value; 1014 int32_t step; 1015} cam_control_range_t; 1016 1017#define CAM_QCOM_FEATURE_FACE_DETECTION (1<<0) 1018#define CAM_QCOM_FEATURE_DENOISE2D (1<<1) 1019#define CAM_QCOM_FEATURE_CROP (1<<2) 1020#define CAM_QCOM_FEATURE_ROTATION (1<<3) 1021#define CAM_QCOM_FEATURE_FLIP (1<<4) 1022#define CAM_QCOM_FEATURE_HDR (1<<5) 1023#define CAM_QCOM_FEATURE_REGISTER_FACE (1<<6) 1024#define CAM_QCOM_FEATURE_SHARPNESS (1<<7) 1025#define CAM_QCOM_FEATURE_VIDEO_HDR (1<<8) 1026#define CAM_QCOM_FEATURE_CAC (1<<9) 1027 1028// Counter clock wise 1029typedef enum { 1030 ROTATE_0 = 1<<0, 1031 ROTATE_90 = 1<<1, 1032 ROTATE_180 = 1<<2, 1033 ROTATE_270 = 1<<3, 1034} cam_rotation_t; 1035 1036typedef enum { 1037 FLIP_H = 1<<0, 1038 FLIP_V = 1<<1, 1039} cam_flip_t; 1040 1041typedef struct { 1042 uint32_t bundle_id; /* bundle id */ 1043 uint8_t num_of_streams; /* number of streams in the bundle */ 1044 uint32_t stream_ids[MAX_STREAM_NUM_IN_BUNDLE]; /* array of stream ids to be bundled */ 1045} cam_bundle_config_t; 1046 1047typedef enum { 1048 CAM_ONLINE_REPROCESS_TYPE, /* online reprocess, frames from running streams */ 1049 CAM_OFFLINE_REPROCESS_TYPE, /* offline reprocess, frames from external source */ 1050} cam_reprocess_type_enum_t; 1051 1052typedef struct { 1053 /* reprocess feature mask */ 1054 uint32_t feature_mask; 1055 1056 /* individual setting for features to be reprocessed */ 1057 cam_denoise_param_t denoise2d; 1058 cam_rect_t input_crop; 1059 cam_rotation_t rotation; 1060 uint32_t flip; 1061 int32_t sharpness; 1062 int32_t hdr_need_1x; /* when CAM_QCOM_FEATURE_HDR enabled, indicate if 1x is needed for output */ 1063} cam_pp_feature_config_t; 1064 1065typedef struct { 1066 uint32_t input_stream_id; 1067 /* input source stream type */ 1068 cam_stream_type_t input_stream_type; 1069} cam_pp_online_src_config_t; 1070 1071typedef struct { 1072 /* image format */ 1073 cam_format_t input_fmt; 1074 1075 /* image dimension */ 1076 cam_dimension_t input_dim; 1077 1078 /* buffer plane information, will be calc based on stream_type, fmt, 1079 dim, and padding_info(from stream config). Info including: 1080 offset_x, offset_y, stride, scanline, plane offset */ 1081 cam_stream_buf_plane_info_t input_buf_planes; 1082 1083 /* number of input reprocess buffers */ 1084 uint8_t num_of_bufs; 1085} cam_pp_offline_src_config_t; 1086 1087/* reprocess stream input configuration */ 1088typedef struct { 1089 /* input source config */ 1090 cam_reprocess_type_enum_t pp_type; 1091 union { 1092 cam_pp_online_src_config_t online; 1093 cam_pp_offline_src_config_t offline; 1094 }; 1095 1096 /* pp feature config */ 1097 cam_pp_feature_config_t pp_feature_config; 1098} cam_stream_reproc_config_t; 1099 1100typedef struct { 1101 uint8_t crop_enabled; 1102 cam_rect_t input_crop; 1103} cam_crop_param_t; 1104 1105typedef struct { 1106 uint8_t trigger; 1107 int32_t trigger_id; 1108} cam_trigger_t; 1109 1110typedef struct { 1111 cam_denoise_param_t denoise; 1112 cam_crop_param_t crop; 1113 uint32_t flip; /* 0 means no flip */ 1114 int32_t sharpness; /* 0 means no sharpness */ 1115} cam_per_frame_pp_config_t; 1116 1117typedef enum { 1118 CAM_OPT_STAB_OFF, 1119 CAM_OPT_STAB_ON, 1120 CAM_OPT_STAB_MAX 1121} cam_optical_stab_modes_t; 1122 1123typedef enum { 1124 CAM_FILTER_ARRANGEMENT_RGGB, 1125 CAM_FILTER_ARRANGEMENT_GRBG, 1126 CAM_FILTER_ARRANGEMENT_GBRG, 1127 CAM_FILTER_ARRANGEMENT_BGGR, 1128 1129 /* Sensor is not Bayer; output has 3 16-bit values for each pixel, 1130 * instead of just 1 16-bit value per pixel.*/ 1131 CAM_FILTER_ARRANGEMENT_RGB 1132} cam_color_filter_arrangement_t; 1133 1134typedef enum { 1135 CAM_AF_STATE_INACTIVE, 1136 CAM_AF_STATE_PASSIVE_SCAN, 1137 CAM_AF_STATE_PASSIVE_FOCUSED, 1138 CAM_AF_STATE_ACTIVE_SCAN, 1139 CAM_AF_STATE_FOCUSED_LOCKED, 1140 CAM_AF_STATE_NOT_FOCUSED_LOCKED 1141} cam_af_state_t; 1142 1143typedef enum { 1144 CAM_AWB_STATE_INACTIVE, 1145 CAM_AWB_STATE_SEARCHING, 1146 CAM_AWB_STATE_CONVERGED, 1147 CAM_AWB_STATE_LOCKED 1148} cam_awb_state_t; 1149 1150#endif /* __QCAMERA_TYPES_H__ */ 1151