/* Copyright (c) 2011-2016, 2018, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * */ #ifndef __CAMERA2_H__ #define __CAMERA2_H__ #include #include #include #include #include #define MAX_SPECIAL_SUPPORT_SIZE 10 enum msm_camera_device_type_t { MSM_CAMERA_I2C_DEVICE, MSM_CAMERA_PLATFORM_DEVICE, MSM_CAMERA_SPI_DEVICE, }; enum msm_bus_perf_setting { S_INIT, S_PREVIEW, S_VIDEO, S_CAPTURE, S_ZSL, S_STEREO_VIDEO, S_STEREO_CAPTURE, S_DEFAULT, S_LIVESHOT, S_DUAL, S_EXIT }; struct msm_camera_slave_info { uint16_t sensor_slave_addr; uint16_t sensor_id_reg_addr; uint16_t sensor_id; uint16_t sensor_id_mask; struct msm_camera_i2c_reg_setting *setting; }; struct msm_cam_clk_info { const char *clk_name; long clk_rate; uint32_t delay; }; struct msm_pinctrl_info { struct pinctrl *pinctrl; struct pinctrl_state *gpio_state_active; struct pinctrl_state *gpio_state_suspend; bool use_pinctrl; }; struct msm_cam_clk_setting { struct msm_cam_clk_info *clk_info; uint16_t num_clk_info; uint8_t enable; }; struct v4l2_subdev_info { uint32_t code; enum v4l2_colorspace colorspace; uint16_t fmt; uint16_t order; }; struct msm_camera_gpio_num_info { uint16_t gpio_num[SENSOR_GPIO_MAX]; uint8_t valid[SENSOR_GPIO_MAX]; }; struct msm_camera_gpio_conf { void *cam_gpiomux_conf_tbl; uint8_t cam_gpiomux_conf_tbl_size; struct gpio *cam_gpio_common_tbl; uint8_t cam_gpio_common_tbl_size; struct gpio *cam_gpio_req_tbl; uint8_t cam_gpio_req_tbl_size; uint32_t gpio_no_mux; uint32_t *camera_off_table; uint8_t camera_off_table_size; uint32_t *camera_on_table; uint8_t camera_on_table_size; struct msm_camera_gpio_num_info *gpio_num_info; }; struct msm_camera_power_ctrl_t { struct device *dev; struct msm_sensor_power_setting *power_setting; uint16_t power_setting_size; struct msm_sensor_power_setting *power_down_setting; uint16_t power_down_setting_size; struct msm_camera_gpio_conf *gpio_conf; struct camera_vreg_t *cam_vreg; int num_vreg; struct msm_camera_i2c_conf *i2c_conf; struct clk **clk_ptr; struct msm_cam_clk_info *clk_info; struct msm_pinctrl_info pinctrl_info; uint8_t cam_pinctrl_status; size_t clk_info_size; }; enum msm_camera_actuator_name { MSM_ACTUATOR_MAIN_CAM_0, MSM_ACTUATOR_MAIN_CAM_1, MSM_ACTUATOR_MAIN_CAM_2, MSM_ACTUATOR_MAIN_CAM_3, MSM_ACTUATOR_MAIN_CAM_4, MSM_ACTUATOR_MAIN_CAM_5, MSM_ACTUATOR_WEB_CAM_0, MSM_ACTUATOR_WEB_CAM_1, MSM_ACTUATOR_WEB_CAM_2, }; struct msm_actuator_info { struct i2c_board_info const *board_info; enum msm_camera_actuator_name cam_name; int bus_id; int vcm_pwd; int vcm_enable; }; enum msm_camera_i2c_mux_mode { MODE_R, MODE_L, MODE_DUAL }; struct msm_camera_i2c_conf { uint8_t use_i2c_mux; struct platform_device *mux_dev; enum msm_camera_i2c_mux_mode i2c_mux_mode; }; struct msm_camera_sensor_board_info { const char *sensor_name; const char *eeprom_name; const char *actuator_name; const char *ois_name; const char *flash_name; const char *special_support_sensors[MAX_SPECIAL_SUPPORT_SIZE]; int32_t special_support_size; struct msm_camera_slave_info *slave_info; struct msm_camera_csi_lane_params *csi_lane_params; struct msm_camera_sensor_strobe_flash_data *strobe_flash_data; struct msm_actuator_info *actuator_info; struct msm_sensor_info_t *sensor_info; const char *misc_regulator; struct msm_camera_power_ctrl_t power_info; struct msm_camera_sensor_slave_info *cam_slave_info; }; enum msm_camera_i2c_cmd_type { MSM_CAMERA_I2C_CMD_WRITE, MSM_CAMERA_I2C_CMD_POLL, }; struct msm_camera_i2c_reg_conf { uint16_t reg_addr; uint16_t reg_data; enum msm_camera_i2c_data_type dt; enum msm_camera_i2c_cmd_type cmd_type; int16_t mask; }; struct msm_camera_i2c_conf_array { struct msm_camera_i2c_reg_conf *conf; uint16_t size; uint16_t delay; enum msm_camera_i2c_data_type data_type; }; struct eeprom_map_t { uint32_t valid_size; uint32_t addr; uint32_t addr_t; uint32_t data; uint32_t data_t; uint32_t delay; }; struct eeprom_slave_add_t { uint32_t addr; }; struct msm_eeprom_memory_map_t { struct eeprom_map_t page; struct eeprom_map_t pageen; struct eeprom_map_t poll; struct eeprom_map_t mem; struct eeprom_slave_add_t saddr; }; struct msm_eeprom_memory_block_t { struct msm_eeprom_memory_map_t *map; uint32_t num_map; /* number of map blocks */ uint8_t *mapdata; uint32_t num_data; /* size of total mapdata */ }; struct msm_eeprom_cmm_t { uint32_t cmm_support; uint32_t cmm_compression; uint32_t cmm_offset; uint32_t cmm_size; }; struct msm_eeprom_board_info { const char *eeprom_name; uint16_t i2c_slaveaddr; struct msm_camera_power_ctrl_t power_info; struct msm_eeprom_cmm_t cmm_data; enum i2c_freq_mode_t i2c_freq_mode; }; #endif