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