1 #ifndef __UAPI_LINUX_MSM_CAMSENSOR_SDK_H 2 #define __UAPI_LINUX_MSM_CAMSENSOR_SDK_H 3 4 #include <linux/videodev2.h> 5 6 #define KVERSION 0x1 7 8 #define MAX_POWER_CONFIG 12 9 #define GPIO_OUT_LOW (0 << 1) 10 #define GPIO_OUT_HIGH (1 << 1) 11 #define CSI_EMBED_DATA 0x12 12 #define CSI_RESERVED_DATA_0 0x13 13 #define CSI_YUV422_8 0x1E 14 #define CSI_RAW8 0x2A 15 #define CSI_RAW10 0x2B 16 #define CSI_RAW12 0x2C 17 #define CSI_DECODE_6BIT 0 18 #define CSI_DECODE_8BIT 1 19 #define CSI_DECODE_10BIT 2 20 #define CSI_DECODE_12BIT 3 21 #define CSI_DECODE_DPCM_10_6_10 4 22 #define CSI_DECODE_DPCM_10_8_10 5 23 #define MAX_CID 16 24 #define I2C_SEQ_REG_DATA_MAX 1024 25 #define I2C_REG_DATA_MAX (8*1024) 26 27 #define MSM_V4L2_PIX_FMT_META v4l2_fourcc('M', 'E', 'T', 'A') /* META */ 28 #define MSM_V4L2_PIX_FMT_SBGGR14 v4l2_fourcc('B', 'G', '1', '4') 29 /* 14 BGBG.. GRGR.. */ 30 #define MSM_V4L2_PIX_FMT_SGBRG14 v4l2_fourcc('G', 'B', '1', '4') 31 /* 14 GBGB.. RGRG.. */ 32 #define MSM_V4L2_PIX_FMT_SGRBG14 v4l2_fourcc('B', 'A', '1', '4') 33 /* 14 GRGR.. BGBG.. */ 34 #define MSM_V4L2_PIX_FMT_SRGGB14 v4l2_fourcc('R', 'G', '1', '4') 35 /* 14 RGRG.. GBGB.. */ 36 37 #define MAX_ACTUATOR_REG_TBL_SIZE 8 38 #define MAX_ACTUATOR_REGION 5 39 #define NUM_ACTUATOR_DIR 2 40 #define MAX_ACTUATOR_SCENARIO 8 41 #define MAX_ACT_MOD_NAME_SIZE 32 42 #define MAX_ACT_NAME_SIZE 32 43 #define MAX_ACTUATOR_INIT_SET 120 44 #define MAX_I2C_REG_SET 12 45 46 #define MAX_LED_TRIGGERS 3 47 48 #define MSM_EEPROM_MEMORY_MAP_MAX_SIZE 80 49 #define MSM_EEPROM_MAX_MEM_MAP_CNT 20 50 51 enum msm_sensor_camera_id_t { 52 CAMERA_0, 53 CAMERA_1, 54 CAMERA_2, 55 CAMERA_3, 56 MAX_CAMERAS, 57 }; 58 59 enum i2c_freq_mode_t { 60 I2C_STANDARD_MODE, 61 I2C_FAST_MODE, 62 I2C_CUSTOM_MODE, 63 I2C_FAST_PLUS_MODE, 64 I2C_MAX_MODES, 65 }; 66 67 enum camb_position_t { 68 BACK_CAMERA_B, 69 FRONT_CAMERA_B, 70 AUX_CAMERA_B = 0x100, 71 INVALID_CAMERA_B, 72 }; 73 74 enum msm_sensor_power_seq_type_t { 75 SENSOR_CLK, 76 SENSOR_GPIO, 77 SENSOR_VREG, 78 SENSOR_I2C_MUX, 79 SENSOR_I2C, 80 }; 81 82 enum msm_camera_i2c_reg_addr_type { 83 MSM_CAMERA_I2C_BYTE_ADDR = 1, 84 MSM_CAMERA_I2C_WORD_ADDR, 85 MSM_CAMERA_I2C_3B_ADDR, 86 MSM_CAMERA_I2C_ADDR_TYPE_MAX, 87 }; 88 89 enum msm_camera_i2c_data_type { 90 MSM_CAMERA_I2C_BYTE_DATA = 1, 91 MSM_CAMERA_I2C_WORD_DATA, 92 MSM_CAMERA_I2C_DWORD_DATA, 93 MSM_CAMERA_I2C_SET_BYTE_MASK, 94 MSM_CAMERA_I2C_UNSET_BYTE_MASK, 95 MSM_CAMERA_I2C_SET_WORD_MASK, 96 MSM_CAMERA_I2C_UNSET_WORD_MASK, 97 MSM_CAMERA_I2C_SET_BYTE_WRITE_MASK_DATA, 98 MSM_CAMERA_I2C_DATA_TYPE_MAX, 99 }; 100 101 enum msm_sensor_power_seq_gpio_t { 102 SENSOR_GPIO_RESET, 103 SENSOR_GPIO_STANDBY, 104 SENSOR_GPIO_AF_PWDM, 105 SENSOR_GPIO_VIO, 106 SENSOR_GPIO_VANA, 107 SENSOR_GPIO_VDIG, 108 SENSOR_GPIO_VAF, 109 SENSOR_GPIO_FL_EN, 110 SENSOR_GPIO_FL_NOW, 111 SENSOR_GPIO_FL_RESET, 112 SENSOR_GPIO_CUSTOM1, 113 SENSOR_GPIO_CUSTOM2, 114 SENSOR_GPIO_MAX, 115 }; 116 117 enum msm_ir_cut_filter_gpio_t { 118 IR_CUT_FILTER_GPIO_P = 0, 119 IR_CUT_FILTER_GPIO_M, 120 IR_CUT_FILTER_GPIO_MAX, 121 }; 122 #define IR_CUT_FILTER_GPIO_P IR_CUT_FILTER_GPIO_P 123 #define IR_CUT_FILTER_GPIO_M IR_CUT_FILTER_GPIO_M 124 #define R_CUT_FILTER_GPIO_MAX IR_CUT_FILTER_GPIO_MAX 125 126 enum msm_camera_vreg_name_t { 127 CAM_VDIG, 128 CAM_VIO, 129 CAM_VANA, 130 CAM_VAF, 131 CAM_V_CUSTOM1, 132 CAM_V_CUSTOM2, 133 CAM_VREG_MAX, 134 }; 135 136 enum msm_sensor_clk_type_t { 137 SENSOR_CAM_MCLK, 138 SENSOR_CAM_CLK, 139 SENSOR_CAM_CLK_MAX, 140 }; 141 142 enum camerab_mode_t { 143 CAMERA_MODE_2D_B = (1<<0), 144 CAMERA_MODE_3D_B = (1<<1), 145 CAMERA_MODE_INVALID = (1<<2), 146 }; 147 148 enum msm_actuator_data_type { 149 MSM_ACTUATOR_BYTE_DATA = 1, 150 MSM_ACTUATOR_WORD_DATA, 151 }; 152 153 enum msm_actuator_addr_type { 154 MSM_ACTUATOR_BYTE_ADDR = 1, 155 MSM_ACTUATOR_WORD_ADDR, 156 }; 157 158 enum msm_actuator_write_type { 159 MSM_ACTUATOR_WRITE_HW_DAMP, 160 MSM_ACTUATOR_WRITE_DAC, 161 MSM_ACTUATOR_WRITE, 162 MSM_ACTUATOR_WRITE_DIR_REG, 163 MSM_ACTUATOR_POLL, 164 MSM_ACTUATOR_READ_WRITE, 165 }; 166 167 enum msm_actuator_i2c_operation { 168 MSM_ACT_WRITE = 0, 169 MSM_ACT_POLL, 170 }; 171 172 enum actuator_type { 173 ACTUATOR_VCM, 174 ACTUATOR_PIEZO, 175 ACTUATOR_HVCM, 176 ACTUATOR_BIVCM, 177 }; 178 179 enum msm_flash_driver_type { 180 FLASH_DRIVER_PMIC, 181 FLASH_DRIVER_I2C, 182 FLASH_DRIVER_GPIO, 183 FLASH_DRIVER_DEFAULT 184 }; 185 186 enum msm_flash_cfg_type_t { 187 CFG_FLASH_INIT, 188 CFG_FLASH_RELEASE, 189 CFG_FLASH_OFF, 190 CFG_FLASH_LOW, 191 CFG_FLASH_HIGH, 192 }; 193 194 enum msm_ir_led_cfg_type_t { 195 CFG_IR_LED_INIT = 0, 196 CFG_IR_LED_RELEASE, 197 CFG_IR_LED_OFF, 198 CFG_IR_LED_ON, 199 }; 200 #define CFG_IR_LED_INIT CFG_IR_LED_INIT 201 #define CFG_IR_LED_RELEASE CFG_IR_LED_RELEASE 202 #define CFG_IR_LED_OFF CFG_IR_LED_OFF 203 #define CFG_IR_LED_ON CFG_IR_LED_ON 204 205 enum msm_ir_cut_cfg_type_t { 206 CFG_IR_CUT_INIT = 0, 207 CFG_IR_CUT_RELEASE, 208 CFG_IR_CUT_OFF, 209 CFG_IR_CUT_ON, 210 }; 211 #define CFG_IR_CUT_INIT CFG_IR_CUT_INIT 212 #define CFG_IR_CUT_RELEASE CFG_IR_CUT_RELEASE 213 #define CFG_IR_CUT_OFF CFG_IR_CUT_OFF 214 #define CFG_IR_CUT_ON CFG_IR_CUT_ON 215 216 enum msm_sensor_output_format_t { 217 MSM_SENSOR_BAYER, 218 MSM_SENSOR_YCBCR, 219 MSM_SENSOR_META, 220 }; 221 222 struct msm_sensor_power_setting { 223 enum msm_sensor_power_seq_type_t seq_type; 224 unsigned short seq_val; 225 long config_val; 226 unsigned short delay; 227 void *data[10]; 228 }; 229 230 struct msm_sensor_power_setting_array { 231 struct msm_sensor_power_setting power_setting_a[MAX_POWER_CONFIG]; 232 struct msm_sensor_power_setting *power_setting; 233 unsigned short size; 234 struct msm_sensor_power_setting power_down_setting_a[MAX_POWER_CONFIG]; 235 struct msm_sensor_power_setting *power_down_setting; 236 unsigned short size_down; 237 }; 238 239 enum msm_camera_i2c_operation { 240 MSM_CAM_WRITE = 0, 241 MSM_CAM_POLL, 242 MSM_CAM_READ, 243 }; 244 245 struct msm_sensor_i2c_sync_params { 246 unsigned int cid; 247 int csid; 248 unsigned short line; 249 unsigned short delay; 250 }; 251 252 struct msm_camera_reg_settings_t { 253 uint16_t reg_addr; 254 enum msm_camera_i2c_reg_addr_type addr_type; 255 uint16_t reg_data; 256 enum msm_camera_i2c_data_type data_type; 257 enum msm_camera_i2c_operation i2c_operation; 258 uint16_t delay; 259 }; 260 261 struct msm_eeprom_mem_map_t { 262 int slave_addr; 263 struct msm_camera_reg_settings_t 264 mem_settings[MSM_EEPROM_MEMORY_MAP_MAX_SIZE]; 265 int memory_map_size; 266 }; 267 268 struct msm_eeprom_memory_map_array { 269 struct msm_eeprom_mem_map_t memory_map[MSM_EEPROM_MAX_MEM_MAP_CNT]; 270 uint32_t msm_size_of_max_mappings; 271 }; 272 273 struct msm_sensor_init_params { 274 /* mask of modes supported: 2D, 3D */ 275 int modes_supported; 276 /* sensor position: front, back */ 277 enum camb_position_t position; 278 /* sensor mount angle */ 279 unsigned int sensor_mount_angle; 280 }; 281 282 struct msm_sensor_id_info_t { 283 unsigned short sensor_id_reg_addr; 284 unsigned short sensor_id; 285 unsigned short sensor_id_mask; 286 }; 287 288 struct msm_camera_sensor_slave_info { 289 char sensor_name[32]; 290 char eeprom_name[32]; 291 char actuator_name[32]; 292 char ois_name[32]; 293 char flash_name[32]; 294 enum msm_sensor_camera_id_t camera_id; 295 unsigned short slave_addr; 296 enum i2c_freq_mode_t i2c_freq_mode; 297 enum msm_camera_i2c_reg_addr_type addr_type; 298 struct msm_sensor_id_info_t sensor_id_info; 299 struct msm_sensor_power_setting_array power_setting_array; 300 unsigned char is_init_params_valid; 301 struct msm_sensor_init_params sensor_init_params; 302 enum msm_sensor_output_format_t output_format; 303 }; 304 305 struct msm_camera_i2c_reg_array { 306 unsigned short reg_addr; 307 unsigned short reg_data; 308 unsigned int delay; 309 }; 310 311 struct msm_camera_i2c_reg_setting { 312 struct msm_camera_i2c_reg_array *reg_setting; 313 unsigned short size; 314 enum msm_camera_i2c_reg_addr_type addr_type; 315 enum msm_camera_i2c_data_type data_type; 316 unsigned short delay; 317 }; 318 319 struct msm_camera_csid_vc_cfg { 320 unsigned char cid; 321 unsigned char dt; 322 unsigned char decode_format; 323 }; 324 325 struct msm_camera_csid_lut_params { 326 unsigned char num_cid; 327 struct msm_camera_csid_vc_cfg vc_cfg_a[MAX_CID]; 328 struct msm_camera_csid_vc_cfg *vc_cfg[MAX_CID]; 329 }; 330 331 struct msm_camera_csid_params { 332 unsigned char lane_cnt; 333 unsigned short lane_assign; 334 unsigned char phy_sel; 335 unsigned int csi_clk; 336 struct msm_camera_csid_lut_params lut_params; 337 unsigned char csi_3p_sel; 338 }; 339 340 struct msm_camera_csid_testmode_parms { 341 unsigned int num_bytes_per_line; 342 unsigned int num_lines; 343 unsigned int h_blanking_count; 344 unsigned int v_blanking_count; 345 unsigned int payload_mode; 346 }; 347 348 struct msm_camera_csiphy_params { 349 unsigned char lane_cnt; 350 unsigned char settle_cnt; 351 unsigned short lane_mask; 352 unsigned char combo_mode; 353 unsigned char csid_core; 354 unsigned int csiphy_clk; 355 unsigned char csi_3phase; 356 }; 357 358 struct msm_camera_i2c_seq_reg_array { 359 unsigned short reg_addr; 360 unsigned char reg_data[I2C_SEQ_REG_DATA_MAX]; 361 unsigned short reg_data_size; 362 }; 363 364 struct msm_camera_i2c_seq_reg_setting { 365 struct msm_camera_i2c_seq_reg_array *reg_setting; 366 unsigned short size; 367 enum msm_camera_i2c_reg_addr_type addr_type; 368 unsigned short delay; 369 }; 370 371 struct msm_actuator_reg_params_t { 372 enum msm_actuator_write_type reg_write_type; 373 unsigned int hw_mask; 374 unsigned short reg_addr; 375 unsigned short hw_shift; 376 unsigned short data_shift; 377 unsigned short data_type; 378 unsigned short addr_type; 379 unsigned short reg_data; 380 unsigned short delay; 381 }; 382 383 384 struct damping_params_t { 385 unsigned int damping_step; 386 unsigned int damping_delay; 387 unsigned int hw_params; 388 }; 389 390 struct region_params_t { 391 /* [0] = ForwardDirection Macro boundary 392 [1] = ReverseDirection Inf boundary 393 */ 394 unsigned short step_bound[2]; 395 unsigned short code_per_step; 396 /* qvalue for converting float type numbers to integer format */ 397 unsigned int qvalue; 398 }; 399 400 struct reg_settings_t { 401 unsigned short reg_addr; 402 enum msm_camera_i2c_reg_addr_type addr_type; 403 unsigned short reg_data; 404 enum msm_camera_i2c_data_type data_type; 405 enum msm_actuator_i2c_operation i2c_operation; 406 unsigned int delay; 407 }; 408 409 struct msm_camera_i2c_reg_setting_array { 410 struct msm_camera_i2c_reg_array reg_setting_a[MAX_I2C_REG_SET]; 411 unsigned short size; 412 enum msm_camera_i2c_reg_addr_type addr_type; 413 enum msm_camera_i2c_data_type data_type; 414 unsigned short delay; 415 }; 416 417 #endif 418