blob: 177e3e51207ab8873be92d9b9e2692c3161e80e3 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* drivers/media/i2c/smiapp/smiapp-reg-defs.h
*
* Generic driver for MIPI CCS/SMIA/SMIA++ compliant camera sensors
*
* Copyright (C) 2020 Intel Corporation
* Copyright (C) 2011--2012 Nokia Corporation
* Contact: Sakari Ailus <sakari.ailus@iki.fi>
*/
#ifndef __SMIAPP_REG_DEFS_H__
#define __SMIAPP_REG_DEFS_H__
/* Register addresses */
#define SMIAPP_REG_U16_MODEL_ID (0x0000 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_REVISION_NUMBER_MAJOR 0x0002
#define SMIAPP_REG_U8_MANUFACTURER_ID 0x0003
#define SMIAPP_REG_U8_SMIA_VERSION 0x0004
#define SMIAPP_REG_U8_FRAME_COUNT 0x0005
#define SMIAPP_REG_U8_PIXEL_ORDER 0x0006
#define SMIAPP_REG_U16_DATA_PEDESTAL (0x0008 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_PIXEL_DEPTH 0x000c
#define SMIAPP_REG_U8_REVISION_NUMBER_MINOR 0x0010
#define SMIAPP_REG_U8_SMIAPP_VERSION 0x0011
#define SMIAPP_REG_U8_MODULE_DATE_YEAR 0x0012
#define SMIAPP_REG_U8_MODULE_DATE_MONTH 0x0013
#define SMIAPP_REG_U8_MODULE_DATE_DAY 0x0014
#define SMIAPP_REG_U8_MODULE_DATE_PHASE 0x0015
#define SMIAPP_REG_U16_SENSOR_MODEL_ID (0x0016 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_SENSOR_REVISION_NUMBER 0x0018
#define SMIAPP_REG_U8_SENSOR_MANUFACTURER_ID 0x0019
#define SMIAPP_REG_U8_SENSOR_FIRMWARE_VERSION 0x001a
#define SMIAPP_REG_U32_SERIAL_NUMBER (0x001c | CCS_FL_32BIT)
#define SMIAPP_REG_U8_FRAME_FORMAT_MODEL_TYPE 0x0040
#define SMIAPP_REG_U8_FRAME_FORMAT_MODEL_SUBTYPE 0x0041
#define SMIAPP_REG_U16_FRAME_FORMAT_DESCRIPTOR_2(n) ((0x0042 + ((n) << 1)) | CCS_FL_16BIT) /* 0 <= n <= 14 */
#define SMIAPP_REG_U32_FRAME_FORMAT_DESCRIPTOR_4(n) ((0x0060 + ((n) << 2)) | CCS_FL_32BIT) /* 0 <= n <= 7 */
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CAPABILITY (0x0080 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_MIN (0x0084 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_MAX (0x0086 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_STEP (0x0088 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_TYPE (0x008a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_M0 (0x008c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_C0 (0x008e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_M1 (0x0090 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_C1 (0x0092 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_DATA_FORMAT_MODEL_TYPE 0x00c0
#define SMIAPP_REG_U8_DATA_FORMAT_MODEL_SUBTYPE 0x00c1
#define SMIAPP_REG_U16_DATA_FORMAT_DESCRIPTOR(n) ((0x00c2 + ((n) << 1)) | CCS_FL_16BIT)
#define SMIAPP_REG_U8_MODE_SELECT 0x0100
#define SMIAPP_REG_U8_IMAGE_ORIENTATION 0x0101
#define SMIAPP_REG_U8_SOFTWARE_RESET 0x0103
#define SMIAPP_REG_U8_GROUPED_PARAMETER_HOLD 0x0104
#define SMIAPP_REG_U8_MASK_CORRUPTED_FRAMES 0x0105
#define SMIAPP_REG_U8_FAST_STANDBY_CTRL 0x0106
#define SMIAPP_REG_U8_CCI_ADDRESS_CONTROL 0x0107
#define SMIAPP_REG_U8_2ND_CCI_IF_CONTROL 0x0108
#define SMIAPP_REG_U8_2ND_CCI_ADDRESS_CONTROL 0x0109
#define SMIAPP_REG_U8_CSI_CHANNEL_IDENTIFIER 0x0110
#define SMIAPP_REG_U8_CSI_SIGNALLING_MODE 0x0111
#define SMIAPP_REG_U16_CSI_DATA_FORMAT (0x0112 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_CSI_LANE_MODE 0x0114
#define SMIAPP_REG_U8_CSI2_10_TO_8_DT 0x0115
#define SMIAPP_REG_U8_CSI2_10_TO_7_DT 0x0116
#define SMIAPP_REG_U8_CSI2_10_TO_6_DT 0x0117
#define SMIAPP_REG_U8_CSI2_12_TO_8_DT 0x0118
#define SMIAPP_REG_U8_CSI2_12_TO_7_DT 0x0119
#define SMIAPP_REG_U8_CSI2_12_TO_6_DT 0x011a
#define SMIAPP_REG_U8_CSI2_14_TO_10_DT 0x011b
#define SMIAPP_REG_U8_CSI2_14_TO_8_DT 0x011c
#define SMIAPP_REG_U8_CSI2_16_TO_10_DT 0x011d
#define SMIAPP_REG_U8_CSI2_16_TO_8_DT 0x011e
#define SMIAPP_REG_U8_GAIN_MODE 0x0120
#define SMIAPP_REG_U16_VANA_VOLTAGE (0x0130 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_VDIG_VOLTAGE (0x0132 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_VIO_VOLTAGE (0x0134 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_EXTCLK_FREQUENCY_MHZ (0x0136 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_TEMP_SENSOR_CONTROL 0x0138
#define SMIAPP_REG_U8_TEMP_SENSOR_MODE 0x0139
#define SMIAPP_REG_U8_TEMP_SENSOR_OUTPUT 0x013a
#define SMIAPP_REG_U16_FINE_INTEGRATION_TIME (0x0200 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_COARSE_INTEGRATION_TIME (0x0202 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_GLOBAL (0x0204 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_GREENR (0x0206 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_RED (0x0208 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_BLUE (0x020a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ANALOGUE_GAIN_CODE_GREENB (0x020c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_GREENR (0x020e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_RED (0x0210 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_BLUE (0x0212 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_GREENB (0x0214 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_VT_PIX_CLK_DIV (0x0300 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_VT_SYS_CLK_DIV (0x0302 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_PRE_PLL_CLK_DIV (0x0304 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_PLL_MULTIPLIER (0x0306 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_OP_PIX_CLK_DIV (0x0308 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_OP_SYS_CLK_DIV (0x030a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FRAME_LENGTH_LINES (0x0340 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_LINE_LENGTH_PCK (0x0342 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_X_ADDR_START (0x0344 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_Y_ADDR_START (0x0346 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_X_ADDR_END (0x0348 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_Y_ADDR_END (0x034a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_X_OUTPUT_SIZE (0x034c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_Y_OUTPUT_SIZE (0x034e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_X_EVEN_INC (0x0380 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_X_ODD_INC (0x0382 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_Y_EVEN_INC (0x0384 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_Y_ODD_INC (0x0386 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALING_MODE (0x0400 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SPATIAL_SAMPLING (0x0402 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALE_M (0x0404 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALE_N (0x0406 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_CROP_X_OFFSET (0x0408 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_CROP_Y_OFFSET (0x040a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_CROP_IMAGE_WIDTH (0x040c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_CROP_IMAGE_HEIGHT (0x040e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_COMPRESSION_MODE (0x0500 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TEST_PATTERN_MODE (0x0600 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TEST_DATA_RED (0x0602 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TEST_DATA_GREENR (0x0604 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TEST_DATA_BLUE (0x0606 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TEST_DATA_GREENB (0x0608 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_HORIZONTAL_CURSOR_WIDTH (0x060a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_HORIZONTAL_CURSOR_POSITION (0x060c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_VERTICAL_CURSOR_WIDTH (0x060e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_VERTICAL_CURSOR_POSITION (0x0610 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FIFO_WATER_MARK_PIXELS (0x0700 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_TCLK_POST 0x0800
#define SMIAPP_REG_U8_THS_PREPARE 0x0801
#define SMIAPP_REG_U8_THS_ZERO_MIN 0x0802
#define SMIAPP_REG_U8_THS_TRAIL 0x0803
#define SMIAPP_REG_U8_TCLK_TRAIL_MIN 0x0804
#define SMIAPP_REG_U8_TCLK_PREPARE 0x0805
#define SMIAPP_REG_U8_TCLK_ZERO 0x0806
#define SMIAPP_REG_U8_TLPX 0x0807
#define SMIAPP_REG_U8_DPHY_CTRL 0x0808
#define SMIAPP_REG_U32_REQUESTED_LINK_BIT_RATE_MBPS (0x0820 | CCS_FL_32BIT)
#define SMIAPP_REG_U8_BINNING_MODE 0x0900
#define SMIAPP_REG_U8_BINNING_TYPE 0x0901
#define SMIAPP_REG_U8_BINNING_WEIGHTING 0x0902
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_CTRL 0x0a00
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_STATUS 0x0a01
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_PAGE_SELECT 0x0a02
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_0 0x0a04
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_1 0x0a05
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_2 0x0a06
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_3 0x0a07
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_4 0x0a08
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_5 0x0a09
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_12 0x0a10
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_13 0x0a11
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_14 0x0a12
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_15 0x0a13
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_16 0x0a14
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_17 0x0a15
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_18 0x0a16
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_19 0x0a17
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_20 0x0a18
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_21 0x0a19
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_22 0x0a1a
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_23 0x0a1b
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_24 0x0a1c
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_25 0x0a1d
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_26 0x0a1e
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_27 0x0a1f
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_28 0x0a20
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_29 0x0a21
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_30 0x0a22
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_31 0x0a23
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_32 0x0a24
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_33 0x0a25
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_34 0x0a26
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_35 0x0a27
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_36 0x0a28
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_37 0x0a29
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_38 0x0a2a
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_39 0x0a2b
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_40 0x0a2c
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_41 0x0a2d
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_42 0x0a2e
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_43 0x0a2f
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_44 0x0a30
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_45 0x0a31
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_46 0x0a32
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_47 0x0a33
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_48 0x0a34
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_49 0x0a35
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_50 0x0a36
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_51 0x0a37
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_52 0x0a38
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_53 0x0a39
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_54 0x0a3a
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_55 0x0a3b
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_56 0x0a3c
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_57 0x0a3d
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_58 0x0a3e
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_59 0x0a3f
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_60 0x0a40
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_61 0x0a41
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_62 0x0a42
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_1_DATA_63 0x0a43
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_CTRL 0x0a44
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_STATUS 0x0a45
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_PAGE_SELECT 0x0a46
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_0 0x0a48
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_1 0x0a49
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_2 0x0a4a
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_3 0x0a4b
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_4 0x0a4c
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_5 0x0a4d
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_6 0x0a4e
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_7 0x0a4f
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_8 0x0a50
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_9 0x0a51
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_10 0x0a52
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_11 0x0a53
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_12 0x0a54
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_13 0x0a55
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_14 0x0a56
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_15 0x0a57
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_16 0x0a58
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_17 0x0a59
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_18 0x0a5a
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_19 0x0a5b
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_20 0x0a5c
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_21 0x0a5d
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_22 0x0a5e
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_23 0x0a5f
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_24 0x0a60
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_25 0x0a61
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_26 0x0a62
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_27 0x0a63
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_28 0x0a64
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_29 0x0a65
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_30 0x0a66
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_31 0x0a67
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_32 0x0a68
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_33 0x0a69
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_34 0x0a6a
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_35 0x0a6b
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_36 0x0a6c
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_37 0x0a6d
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_38 0x0a6e
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_39 0x0a6f
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_40 0x0a70
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_41 0x0a71
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_42 0x0a72
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_43 0x0a73
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_44 0x0a74
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_45 0x0a75
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_46 0x0a76
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_47 0x0a77
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_48 0x0a78
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_49 0x0a79
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_50 0x0a7a
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_51 0x0a7b
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_52 0x0a7c
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_53 0x0a7d
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_54 0x0a7e
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_55 0x0a7f
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_56 0x0a80
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_57 0x0a81
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_58 0x0a82
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_59 0x0a83
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_60 0x0a84
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_61 0x0a85
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_62 0x0a86
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_2_DATA_63 0x0a87
#define SMIAPP_REG_U8_SHADING_CORRECTION_ENABLE 0x0b00
#define SMIAPP_REG_U8_LUMINANCE_CORRECTION_LEVEL 0x0b01
#define SMIAPP_REG_U8_GREEN_IMBALANCE_FILTER_ENABLE 0x0b02
#define SMIAPP_REG_U8_GREEN_IMBALANCE_FILTER_WEIGHT 0x0b03
#define SMIAPP_REG_U8_BLACK_LEVEL_CORRECTION_ENABLE 0x0b04
#define SMIAPP_REG_U8_MAPPED_COUPLET_CORRECT_ENABLE 0x0b05
#define SMIAPP_REG_U8_SINGLE_DEFECT_CORRECT_ENABLE 0x0b06
#define SMIAPP_REG_U8_SINGLE_DEFECT_CORRECT_WEIGHT 0x0b07
#define SMIAPP_REG_U8_DYNAMIC_COUPLET_CORRECT_ENABLE 0x0b08
#define SMIAPP_REG_U8_DYNAMIC_COUPLET_CORRECT_WEIGHT 0x0b09
#define SMIAPP_REG_U8_COMBINED_DEFECT_CORRECT_ENABLE 0x0b0a
#define SMIAPP_REG_U8_COMBINED_DEFECT_CORRECT_WEIGHT 0x0b0b
#define SMIAPP_REG_U8_MODULE_SPECIFIC_CORRECTION_ENABLE 0x0b0c
#define SMIAPP_REG_U8_MODULE_SPECIFIC_CORRECTION_WEIGHT 0x0b0d
#define SMIAPP_REG_U8_MAPPED_LINE_DEFECT_CORRECT_ENABLE 0x0b0e
#define SMIAPP_REG_U8_MAPPED_LINE_DEFECT_CORRECT_ADJUST 0x0b0f
#define SMIAPP_REG_U8_MAPPED_COUPLET_CORRECT_ADJUST 0x0b10
#define SMIAPP_REG_U8_MAPPED_TRIPLET_DEFECT_CORRECT_ENABLE 0x0b11
#define SMIAPP_REG_U8_MAPPED_TRIPLET_DEFECT_CORRECT_ADJUST 0x0b12
#define SMIAPP_REG_U8_DYNAMIC_TRIPLET_DEFECT_CORRECT_ENABLE 0x0b13
#define SMIAPP_REG_U8_DYNAMIC_TRIPLET_DEFECT_CORRECT_ADJUST 0x0b14
#define SMIAPP_REG_U8_DYNAMIC_LINE_DEFECT_CORRECT_ENABLE 0x0b15
#define SMIAPP_REG_U8_DYNAMIC_LINE_DEFECT_CORRECT_ADJUST 0x0b16
#define SMIAPP_REG_U8_EDOF_MODE 0x0b80
#define SMIAPP_REG_U8_SHARPNESS 0x0b83
#define SMIAPP_REG_U8_DENOISING 0x0b84
#define SMIAPP_REG_U8_MODULE_SPECIFIC 0x0b85
#define SMIAPP_REG_U16_DEPTH_OF_FIELD (0x0b86 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FOCUS_DISTANCE (0x0b88 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_ESTIMATION_MODE_CTRL 0x0b8a
#define SMIAPP_REG_U16_COLOUR_TEMPERATURE (0x0b8c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ABSOLUTE_GAIN_GREENR (0x0b8e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ABSOLUTE_GAIN_RED (0x0b90 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ABSOLUTE_GAIN_BLUE (0x0b92 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_ABSOLUTE_GAIN_GREENB (0x0b94 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_ESTIMATION_ZONE_MODE 0x0bc0
#define SMIAPP_REG_U16_FIXED_ZONE_WEIGHTING (0x0bc2 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_CUSTOM_ZONE_X_START (0x0bc4 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_CUSTOM_ZONE_Y_START (0x0bc6 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_CUSTOM_ZONE_WIDTH (0x0bc8 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_CUSTOM_ZONE_HEIGHT (0x0bca | CCS_FL_16BIT)
#define SMIAPP_REG_U8_GLOBAL_RESET_CTRL1 0x0c00
#define SMIAPP_REG_U8_GLOBAL_RESET_CTRL2 0x0c01
#define SMIAPP_REG_U8_GLOBAL_RESET_MODE_CONFIG_1 0x0c02
#define SMIAPP_REG_U8_GLOBAL_RESET_MODE_CONFIG_2 0x0c03
#define SMIAPP_REG_U16_TRDY_CTRL (0x0c04 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TRDOUT_CTRL (0x0c06 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TSHUTTER_STROBE_DELAY_CTRL (0x0c08 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TSHUTTER_STROBE_WIDTH_CTRL (0x0c0a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TFLASH_STROBE_DELAY_CTRL (0x0c0c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TFLASH_STROBE_WIDTH_HIGH_CTRL (0x0c0e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TGRST_INTERVAL_CTRL (0x0c10 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_FLASH_STROBE_ADJUSTMENT 0x0c12
#define SMIAPP_REG_U16_FLASH_STROBE_START_POINT (0x0c14 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TFLASH_STROBE_DELAY_RS_CTRL (0x0c16 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TFLASH_STROBE_WIDTH_HIGH_RS_CTRL (0x0c18 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_FLASH_MODE_RS 0x0c1a
#define SMIAPP_REG_U8_FLASH_TRIGGER_RS 0x0c1b
#define SMIAPP_REG_U8_FLASH_STATUS 0x0c1c
#define SMIAPP_REG_U8_SA_STROBE_MODE 0x0c1d
#define SMIAPP_REG_U16_SA_STROBE_START_POINT (0x0c1e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TSA_STROBE_DELAY_CTRL (0x0c20 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TSA_STROBE_WIDTH_CTRL (0x0c22 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_SA_STROBE_TRIGGER 0x0c24
#define SMIAPP_REG_U8_SPECIAL_ACTUATOR_STATUS 0x0c25
#define SMIAPP_REG_U16_TFLASH_STROBE_WIDTH2_HIGH_RS_CTRL (0x0c26 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TFLASH_STROBE_WIDTH_LOW_RS_CTRL (0x0c28 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_TFLASH_STROBE_COUNT_RS_CTRL 0x0c2a
#define SMIAPP_REG_U8_TFLASH_STROBE_COUNT_CTRL 0x0c2b
#define SMIAPP_REG_U16_TFLASH_STROBE_WIDTH2_HIGH_CTRL (0x0c2c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_TFLASH_STROBE_WIDTH_LOW_CTRL (0x0c2e | CCS_FL_16BIT)
#define SMIAPP_REG_U8_LOW_LEVEL_CTRL 0x0c80
#define SMIAPP_REG_U16_MAIN_TRIGGER_REF_POINT (0x0c82 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAIN_TRIGGER_T3 (0x0c84 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_MAIN_TRIGGER_COUNT 0x0c86
#define SMIAPP_REG_U16_PHASE1_TRIGGER_T3 (0x0c88 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_PHASE1_TRIGGER_COUNT 0x0c8a
#define SMIAPP_REG_U16_PHASE2_TRIGGER_T3 (0x0c8c | CCS_FL_16BIT)
#define SMIAPP_REG_U8_PHASE2_TRIGGER_COUNT 0x0c8e
#define SMIAPP_REG_U8_MECH_SHUTTER_CTRL 0x0d00
#define SMIAPP_REG_U8_OPERATION_MODE 0x0d01
#define SMIAPP_REG_U8_ACT_STATE1 0x0d02
#define SMIAPP_REG_U8_ACT_STATE2 0x0d03
#define SMIAPP_REG_U16_FOCUS_CHANGE (0x0d80 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FOCUS_CHANGE_CONTROL (0x0d82 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FOCUS_CHANGE_NUMBER_PHASE1 (0x0d84 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FOCUS_CHANGE_NUMBER_PHASE2 (0x0d86 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_STROBE_COUNT_PHASE1 0x0d88
#define SMIAPP_REG_U8_STROBE_COUNT_PHASE2 0x0d89
#define SMIAPP_REG_U8_POSITION 0x0d8a
#define SMIAPP_REG_U8_BRACKETING_LUT_CONTROL 0x0e00
#define SMIAPP_REG_U8_BRACKETING_LUT_MODE 0x0e01
#define SMIAPP_REG_U8_BRACKETING_LUT_ENTRY_CONTROL 0x0e02
#define SMIAPP_REG_U8_LUT_PARAMETERS_START 0x0e10
#define SMIAPP_REG_U8_LUT_PARAMETERS_END 0x0eff
#define SMIAPP_REG_U16_INTEGRATION_TIME_CAPABILITY (0x1000 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_COARSE_INTEGRATION_TIME_MIN (0x1004 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_COARSE_INTEGRATION_TIME_MAX_MARGIN (0x1006 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FINE_INTEGRATION_TIME_MIN (0x1008 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FINE_INTEGRATION_TIME_MAX_MARGIN (0x100a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_CAPABILITY (0x1080 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_MIN (0x1084 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_MAX (0x1086 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DIGITAL_GAIN_STEP_SIZE (0x1088 | CCS_FL_16BIT)
#define SMIAPP_REG_F32_MIN_EXT_CLK_FREQ_HZ (0x1100 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MAX_EXT_CLK_FREQ_HZ (0x1104 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_U16_MIN_PRE_PLL_CLK_DIV (0x1108 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_PRE_PLL_CLK_DIV (0x110a | CCS_FL_16BIT)
#define SMIAPP_REG_F32_MIN_PLL_IP_FREQ_HZ (0x110c | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MAX_PLL_IP_FREQ_HZ (0x1110 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_U16_MIN_PLL_MULTIPLIER (0x1114 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_PLL_MULTIPLIER (0x1116 | CCS_FL_16BIT)
#define SMIAPP_REG_F32_MIN_PLL_OP_FREQ_HZ (0x1118 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MAX_PLL_OP_FREQ_HZ (0x111c | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_U16_MIN_VT_SYS_CLK_DIV (0x1120 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_VT_SYS_CLK_DIV (0x1122 | CCS_FL_16BIT)
#define SMIAPP_REG_F32_MIN_VT_SYS_CLK_FREQ_HZ (0x1124 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MAX_VT_SYS_CLK_FREQ_HZ (0x1128 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MIN_VT_PIX_CLK_FREQ_HZ (0x112c | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MAX_VT_PIX_CLK_FREQ_HZ (0x1130 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_U16_MIN_VT_PIX_CLK_DIV (0x1134 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_VT_PIX_CLK_DIV (0x1136 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_FRAME_LENGTH_LINES (0x1140 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_FRAME_LENGTH_LINES (0x1142 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_LINE_LENGTH_PCK (0x1144 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_LINE_LENGTH_PCK (0x1146 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_LINE_BLANKING_PCK (0x1148 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_FRAME_BLANKING_LINES (0x114a | CCS_FL_16BIT)
#define SMIAPP_REG_U8_MIN_LINE_LENGTH_PCK_STEP_SIZE 0x114c
#define SMIAPP_REG_U16_MIN_OP_SYS_CLK_DIV (0x1160 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_OP_SYS_CLK_DIV (0x1162 | CCS_FL_16BIT)
#define SMIAPP_REG_F32_MIN_OP_SYS_CLK_FREQ_HZ (0x1164 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MAX_OP_SYS_CLK_FREQ_HZ (0x1168 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_U16_MIN_OP_PIX_CLK_DIV (0x116c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_OP_PIX_CLK_DIV (0x116e | CCS_FL_16BIT)
#define SMIAPP_REG_F32_MIN_OP_PIX_CLK_FREQ_HZ (0x1170 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_F32_MAX_OP_PIX_CLK_FREQ_HZ (0x1174 | CCS_FL_FLOAT_IREAL | CCS_FL_32BIT)
#define SMIAPP_REG_U16_X_ADDR_MIN (0x1180 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_Y_ADDR_MIN (0x1182 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_X_ADDR_MAX (0x1184 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_Y_ADDR_MAX (0x1186 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_X_OUTPUT_SIZE (0x1188 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_Y_OUTPUT_SIZE (0x118a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_X_OUTPUT_SIZE (0x118c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_Y_OUTPUT_SIZE (0x118e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_EVEN_INC (0x11c0 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_EVEN_INC (0x11c2 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_ODD_INC (0x11c4 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_ODD_INC (0x11c6 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALING_CAPABILITY (0x1200 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALER_M_MIN (0x1204 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALER_M_MAX (0x1206 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALER_N_MIN (0x1208 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SCALER_N_MAX (0x120a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_SPATIAL_SAMPLING_CAPABILITY (0x120c | CCS_FL_16BIT)
#define SMIAPP_REG_U8_DIGITAL_CROP_CAPABILITY 0x120e
#define SMIAPP_REG_U16_COMPRESSION_CAPABILITY (0x1300 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_REDINRED (0x1400 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_GREENINRED (0x1402 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_BLUEINRED (0x1404 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_REDINGREEN (0x1406 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_GREENINGREEN (0x1408 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_BLUEINGREEN (0x140a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_REDINBLUE (0x140c | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_GREENINBLUE (0x140e | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MATRIX_ELEMENT_BLUEINBLUE (0x1410 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FIFO_SIZE_PIXELS (0x1500 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_FIFO_SUPPORT_CAPABILITY 0x1502
#define SMIAPP_REG_U8_DPHY_CTRL_CAPABILITY 0x1600
#define SMIAPP_REG_U8_CSI_LANE_MODE_CAPABILITY 0x1601
#define SMIAPP_REG_U8_CSI_SIGNALLING_MODE_CAPABILITY 0x1602
#define SMIAPP_REG_U8_FAST_STANDBY_CAPABILITY 0x1603
#define SMIAPP_REG_U8_CCI_ADDRESS_CONTROL_CAPABILITY 0x1604
#define SMIAPP_REG_U32_MAX_PER_LANE_BITRATE_1_LANE_MODE_MBPS (0x1608 | CCS_FL_32BIT)
#define SMIAPP_REG_U32_MAX_PER_LANE_BITRATE_2_LANE_MODE_MBPS (0x160c | CCS_FL_32BIT)
#define SMIAPP_REG_U32_MAX_PER_LANE_BITRATE_3_LANE_MODE_MBPS (0x1610 | CCS_FL_32BIT)
#define SMIAPP_REG_U32_MAX_PER_LANE_BITRATE_4_LANE_MODE_MBPS (0x1614 | CCS_FL_32BIT)
#define SMIAPP_REG_U8_TEMP_SENSOR_CAPABILITY 0x1618
#define SMIAPP_REG_U16_MIN_FRAME_LENGTH_LINES_BIN (0x1700 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_FRAME_LENGTH_LINES_BIN (0x1702 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_LINE_LENGTH_PCK_BIN (0x1704 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MAX_LINE_LENGTH_PCK_BIN (0x1706 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_MIN_LINE_BLANKING_PCK_BIN (0x1708 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FINE_INTEGRATION_TIME_MIN_BIN (0x170a | CCS_FL_16BIT)
#define SMIAPP_REG_U16_FINE_INTEGRATION_TIME_MAX_MARGIN_BIN (0x170c | CCS_FL_16BIT)
#define SMIAPP_REG_U8_BINNING_CAPABILITY 0x1710
#define SMIAPP_REG_U8_BINNING_WEIGHTING_CAPABILITY 0x1711
#define SMIAPP_REG_U8_BINNING_SUBTYPES 0x1712
#define SMIAPP_REG_U8_BINNING_TYPE_n(n) (0x1713 + (n)) /* 1 <= n <= 237 */
#define SMIAPP_REG_U8_DATA_TRANSFER_IF_CAPABILITY 0x1800
#define SMIAPP_REG_U8_SHADING_CORRECTION_CAPABILITY 0x1900
#define SMIAPP_REG_U8_GREEN_IMBALANCE_CAPABILITY 0x1901
#define SMIAPP_REG_U8_BLACK_LEVEL_CAPABILITY 0x1902
#define SMIAPP_REG_U8_MODULE_SPECIFIC_CORRECTION_CAPABILITY 0x1903
#define SMIAPP_REG_U16_DEFECT_CORRECTION_CAPABILITY (0x1904 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_DEFECT_CORRECTION_CAPABILITY_2 (0x1906 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_EDOF_CAPABILITY 0x1980
#define SMIAPP_REG_U8_ESTIMATION_FRAMES 0x1981
#define SMIAPP_REG_U8_SUPPORTS_SHARPNESS_ADJ 0x1982
#define SMIAPP_REG_U8_SUPPORTS_DENOISING_ADJ 0x1983
#define SMIAPP_REG_U8_SUPPORTS_MODULE_SPECIFIC_ADJ 0x1984
#define SMIAPP_REG_U8_SUPPORTS_DEPTH_OF_FIELD_ADJ 0x1985
#define SMIAPP_REG_U8_SUPPORTS_FOCUS_DISTANCE_ADJ 0x1986
#define SMIAPP_REG_U8_COLOUR_FEEDBACK_CAPABILITY 0x1987
#define SMIAPP_REG_U8_EDOF_SUPPORT_AB_NXM 0x1988
#define SMIAPP_REG_U8_ESTIMATION_MODE_CAPABILITY 0x19c0
#define SMIAPP_REG_U8_ESTIMATION_ZONE_CAPABILITY 0x19c1
#define SMIAPP_REG_U16_EST_DEPTH_OF_FIELD (0x19c2 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_EST_FOCUS_DISTANCE (0x19c4 | CCS_FL_16BIT)
#define SMIAPP_REG_U16_CAPABILITY_TRDY_MIN (0x1a00 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_FLASH_MODE_CAPABILITY 0x1a02
#define SMIAPP_REG_U16_MECH_SHUT_AND_ACT_START_ADDR (0x1b02 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_ACTUATOR_CAPABILITY 0x1b04
#define SMIAPP_REG_U16_ACTUATOR_TYPE (0x1b40 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_AF_DEVICE_ADDRESS 0x1b42
#define SMIAPP_REG_U16_FOCUS_CHANGE_ADDRESS (0x1b44 | CCS_FL_16BIT)
#define SMIAPP_REG_U8_BRACKETING_LUT_CAPABILITY_1 0x1c00
#define SMIAPP_REG_U8_BRACKETING_LUT_CAPABILITY_2 0x1c01
#define SMIAPP_REG_U8_BRACKETING_LUT_SIZE 0x1c02
/* Register bit definitions */
#define SMIAPP_IMAGE_ORIENTATION_HFLIP BIT(0)
#define SMIAPP_IMAGE_ORIENTATION_VFLIP BIT(1)
#define SMIAPP_DATA_TRANSFER_IF_1_CTRL_EN BIT(0)
#define SMIAPP_DATA_TRANSFER_IF_1_CTRL_WR_EN BIT(1)
#define SMIAPP_DATA_TRANSFER_IF_1_CTRL_ERR_CLEAR BIT(2)
#define SMIAPP_DATA_TRANSFER_IF_1_STATUS_RD_READY BIT(0)
#define SMIAPP_DATA_TRANSFER_IF_1_STATUS_WR_READY BIT(1)
#define SMIAPP_DATA_TRANSFER_IF_1_STATUS_EDATA BIT(2)
#define SMIAPP_DATA_TRANSFER_IF_1_STATUS_EUSAGE BIT(3)
#define SMIAPP_DATA_TRANSFER_IF_CAPABILITY_SUPPORTED BIT(0)
#define SMIAPP_DATA_TRANSFER_IF_CAPABILITY_POLL BIT(2)
#define SMIAPP_SOFTWARE_RESET BIT(0)
#define SMIAPP_FLASH_MODE_CAPABILITY_SINGLE_STROBE BIT(0)
#define SMIAPP_FLASH_MODE_CAPABILITY_MULTIPLE_STROBE BIT(1)
#define SMIAPP_CSI_SIGNALLING_MODE_CCP2_DATA_CLOCK 0
#define SMIAPP_CSI_SIGNALLING_MODE_CCP2_DATA_STROBE 1
#define SMIAPP_CSI_SIGNALLING_MODE_CSI2 2
#define SMIAPP_DPHY_CTRL_AUTOMATIC 0
/* DPHY control based on REQUESTED_LINK_BIT_RATE_MBPS */
#define SMIAPP_DPHY_CTRL_UI 1
#define SMIAPP_DPHY_CTRL_REGISTER 2
#define SMIAPP_COMPRESSION_MODE_SIMPLE_PREDICTOR 1
#define SMIAPP_COMPRESSION_MODE_ADVANCED_PREDICTOR 2
#define SMIAPP_MODE_SELECT_SOFTWARE_STANDBY 0
#define SMIAPP_MODE_SELECT_STREAMING 1
#define SMIAPP_SCALING_MODE_NONE 0
#define SMIAPP_SCALING_MODE_HORIZONTAL 1
#define SMIAPP_SCALING_MODE_BOTH 2
#define SMIAPP_SCALING_CAPABILITY_NONE 0
#define SMIAPP_SCALING_CAPABILITY_HORIZONTAL 1
#define SMIAPP_SCALING_CAPABILITY_BOTH 2 /* horizontal/both */
/* digital crop right before scaler */
#define SMIAPP_DIGITAL_CROP_CAPABILITY_NONE 0
#define SMIAPP_DIGITAL_CROP_CAPABILITY_INPUT_CROP 1
#define SMIAPP_DIGITAL_GAIN_CAPABILITY_PER_CHANNEL 1
#define SMIAPP_BINNING_CAPABILITY_NO 0
#define SMIAPP_BINNING_CAPABILITY_YES 1
/* Maximum number of binning subtypes */
#define SMIAPP_BINNING_SUBTYPES 253
#define SMIAPP_PIXEL_ORDER_GRBG 0
#define SMIAPP_PIXEL_ORDER_RGGB 1
#define SMIAPP_PIXEL_ORDER_BGGR 2
#define SMIAPP_PIXEL_ORDER_GBRG 3
#define SMIAPP_DATA_FORMAT_MODEL_TYPE_NORMAL 1
#define SMIAPP_DATA_FORMAT_MODEL_TYPE_EXTENDED 2
#define SMIAPP_DATA_FORMAT_MODEL_TYPE_NORMAL_N 8
#define SMIAPP_DATA_FORMAT_MODEL_TYPE_EXTENDED_N 16
#define SMIAPP_FRAME_FORMAT_MODEL_TYPE_2BYTE 0x01
#define SMIAPP_FRAME_FORMAT_MODEL_TYPE_4BYTE 0x02
#define SMIAPP_FRAME_FORMAT_MODEL_SUBTYPE_NROWS_MASK 0x0f
#define SMIAPP_FRAME_FORMAT_MODEL_SUBTYPE_NCOLS_MASK 0xf0
#define SMIAPP_FRAME_FORMAT_MODEL_SUBTYPE_NCOLS_SHIFT 4
#define SMIAPP_FRAME_FORMAT_DESC_2_PIXELCODE_MASK 0xf000
#define SMIAPP_FRAME_FORMAT_DESC_2_PIXELCODE_SHIFT 12
#define SMIAPP_FRAME_FORMAT_DESC_2_PIXELS_MASK 0x0fff
#define SMIAPP_FRAME_FORMAT_DESC_4_PIXELCODE_MASK 0xf0000000
#define SMIAPP_FRAME_FORMAT_DESC_4_PIXELCODE_SHIFT 28
#define SMIAPP_FRAME_FORMAT_DESC_4_PIXELS_MASK 0x0000ffff
#define SMIAPP_FRAME_FORMAT_DESC_PIXELCODE_EMBEDDED 1
#define SMIAPP_FRAME_FORMAT_DESC_PIXELCODE_DUMMY 2
#define SMIAPP_FRAME_FORMAT_DESC_PIXELCODE_BLACK 3
#define SMIAPP_FRAME_FORMAT_DESC_PIXELCODE_DARK 4
#define SMIAPP_FRAME_FORMAT_DESC_PIXELCODE_VISIBLE 5
#define SMIAPP_FAST_STANDBY_CTRL_COMPLETE_FRAMES 0
#define SMIAPP_FAST_STANDBY_CTRL_IMMEDIATE 1
/* Scaling N factor */
#define SMIAPP_SCALE_N 16
#endif /* __SMIAPP_REG_DEFS_H__ */