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