Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 517fe726 authored by Rajesh Bondugula's avatar Rajesh Bondugula
Browse files

msm: camera: sensor: Remove media bus inclusion



Remove media bus file from msm_camsensr_sdk.h and
add in msm_cam_sensor.h.
msm_camsensor_sdk.h is used for developing drivers with sdk
Hence it should not depend on v4l2-mediabus.h.
fourcc format is derived from output format and decode format.

Change-Id: I9add1613cab6effc71dc36fece0362f74bcaa89a
Signed-off-by: default avatarRajesh Bondugula <rajeshb@codeaurora.org>
parent 89e32cb5
Loading
Loading
Loading
Loading
+11 −0
Original line number Original line Diff line number Diff line
@@ -5,6 +5,7 @@
#include <sys/types.h>
#include <sys/types.h>
#endif
#endif


#include <linux/v4l2-mediabus.h>
#include <media/msm_camsensor_sdk.h>
#include <media/msm_camsensor_sdk.h>


#include <linux/types.h>
#include <linux/types.h>
@@ -37,6 +38,16 @@
#define MAX_AF_ITERATIONS 3
#define MAX_AF_ITERATIONS 3
#define MAX_NUMBER_OF_STEPS 47
#define MAX_NUMBER_OF_STEPS 47


#define MSM_V4L2_PIX_FMT_META v4l2_fourcc('M', 'E', 'T', 'A') /* META */
#define MSM_V4L2_PIX_FMT_SBGGR14 v4l2_fourcc('B', 'G', '1', '4')
	/* 14  BGBG.. GRGR.. */
#define MSM_V4L2_PIX_FMT_SGBRG14 v4l2_fourcc('G', 'B', '1', '4')
	/* 14  GBGB.. RGRG.. */
#define MSM_V4L2_PIX_FMT_SGRBG14 v4l2_fourcc('B', 'A', '1', '4')
	/* 14  GRGR.. BGBG.. */
#define MSM_V4L2_PIX_FMT_SRGGB14 v4l2_fourcc('R', 'G', '1', '4')
	/* 14  RGRG.. GBGB.. */

enum flash_type {
enum flash_type {
	LED_FLASH = 1,
	LED_FLASH = 1,
	STROBE_FLASH,
	STROBE_FLASH,
+54 −65
Original line number Original line Diff line number Diff line
#ifndef __LINUX_MSM_CAMSENSOR_SDK_H
#ifndef __LINUX_MSM_CAMSENSOR_SDK_H
#define __LINUX_MSM_CAMSENSOR_SDK_H
#define __LINUX_MSM_CAMSENSOR_SDK_H


#include <linux/v4l2-mediabus.h>

#define KVERSION 0x1
#define KVERSION 0x1


#define MAX_POWER_CONFIG      12
#define MAX_POWER_CONFIG      12
@@ -20,15 +18,6 @@
#define CSI_DECODE_DPCM_10_8_10 5
#define CSI_DECODE_DPCM_10_8_10 5
#define MAX_CID                 16
#define MAX_CID                 16
#define I2C_SEQ_REG_DATA_MAX    256
#define I2C_SEQ_REG_DATA_MAX    256
#define MSM_V4L2_PIX_FMT_META v4l2_fourcc('M', 'E', 'T', 'A') /* META */
#define MSM_V4L2_PIX_FMT_SBGGR14 v4l2_fourcc('B', 'G', '1', '4')
	/* 14  BGBG.. GRGR.. */
#define MSM_V4L2_PIX_FMT_SGBRG14 v4l2_fourcc('G', 'B', '1', '4')
	/* 14  GBGB.. RGRG.. */
#define MSM_V4L2_PIX_FMT_SGRBG14 v4l2_fourcc('B', 'A', '1', '4')
	/* 14  GRGR.. BGBG.. */
#define MSM_V4L2_PIX_FMT_SRGGB14 v4l2_fourcc('R', 'G', '1', '4')
	/* 14  RGRG.. GBGB.. */


#define MAX_ACTUATOR_REG_TBL_SIZE 8
#define MAX_ACTUATOR_REG_TBL_SIZE 8
#define MAX_ACTUATOR_REGION       5
#define MAX_ACTUATOR_REGION       5
@@ -182,19 +171,19 @@ enum msm_flash_cfg_type_t {


struct msm_sensor_power_setting {
struct msm_sensor_power_setting {
	enum msm_sensor_power_seq_type_t seq_type;
	enum msm_sensor_power_seq_type_t seq_type;
	uint16_t seq_val;
	unsigned short seq_val;
	long config_val;
	long config_val;
	uint16_t delay;
	unsigned short delay;
	void *data[10];
	void *data[10];
};
};


struct msm_sensor_power_setting_array {
struct msm_sensor_power_setting_array {
	struct msm_sensor_power_setting  power_setting_a[MAX_POWER_CONFIG];
	struct msm_sensor_power_setting  power_setting_a[MAX_POWER_CONFIG];
	struct msm_sensor_power_setting *power_setting;
	struct msm_sensor_power_setting *power_setting;
	uint16_t size;
	unsigned short size;
	struct msm_sensor_power_setting  power_down_setting_a[MAX_POWER_CONFIG];
	struct msm_sensor_power_setting  power_down_setting_a[MAX_POWER_CONFIG];
	struct msm_sensor_power_setting *power_down_setting;
	struct msm_sensor_power_setting *power_down_setting;
	uint16_t size_down;
	unsigned short size_down;
};
};


struct msm_sensor_init_params {
struct msm_sensor_init_params {
@@ -203,13 +192,13 @@ struct msm_sensor_init_params {
	/* sensor position: front, back */
	/* sensor position: front, back */
	enum camb_position_t position;
	enum camb_position_t position;
	/* sensor mount angle */
	/* sensor mount angle */
	uint32_t            sensor_mount_angle;
	unsigned int            sensor_mount_angle;
};
};


struct msm_sensor_id_info_t {
struct msm_sensor_id_info_t {
	uint16_t sensor_id_reg_addr;
	unsigned short sensor_id_reg_addr;
	uint16_t sensor_id;
	unsigned short sensor_id;
	uint16_t sensor_id_mask;
	unsigned short sensor_id_mask;
};
};


struct msm_camera_sensor_slave_info {
struct msm_camera_sensor_slave_info {
@@ -219,115 +208,115 @@ struct msm_camera_sensor_slave_info {
	char ois_name[32];
	char ois_name[32];
	char flash_name[32];
	char flash_name[32];
	enum msm_sensor_camera_id_t camera_id;
	enum msm_sensor_camera_id_t camera_id;
	uint16_t slave_addr;
	unsigned short slave_addr;
	enum i2c_freq_mode_t i2c_freq_mode;
	enum i2c_freq_mode_t i2c_freq_mode;
	enum msm_camera_i2c_reg_addr_type addr_type;
	enum msm_camera_i2c_reg_addr_type addr_type;
	struct msm_sensor_id_info_t sensor_id_info;
	struct msm_sensor_id_info_t sensor_id_info;
	struct msm_sensor_power_setting_array power_setting_array;
	struct msm_sensor_power_setting_array power_setting_array;
	uint8_t  is_init_params_valid;
	unsigned char  is_init_params_valid;
	struct msm_sensor_init_params sensor_init_params;
	struct msm_sensor_init_params sensor_init_params;
	uint8_t is_flash_supported;
	unsigned char is_flash_supported;
};
};


struct msm_camera_i2c_reg_array {
struct msm_camera_i2c_reg_array {
	uint16_t reg_addr;
	unsigned short reg_addr;
	uint16_t reg_data;
	unsigned short reg_data;
	uint32_t delay;
	unsigned int delay;
};
};


struct msm_camera_i2c_reg_setting {
struct msm_camera_i2c_reg_setting {
	struct msm_camera_i2c_reg_array *reg_setting;
	struct msm_camera_i2c_reg_array *reg_setting;
	uint16_t size;
	unsigned short size;
	enum msm_camera_i2c_reg_addr_type addr_type;
	enum msm_camera_i2c_reg_addr_type addr_type;
	enum msm_camera_i2c_data_type data_type;
	enum msm_camera_i2c_data_type data_type;
	uint16_t delay;
	unsigned short delay;
};
};


struct msm_camera_csid_vc_cfg {
struct msm_camera_csid_vc_cfg {
	uint8_t cid;
	unsigned char cid;
	uint8_t dt;
	unsigned char dt;
	uint8_t decode_format;
	unsigned char decode_format;
};
};


struct msm_camera_csid_lut_params {
struct msm_camera_csid_lut_params {
	uint8_t num_cid;
	unsigned char num_cid;
	struct msm_camera_csid_vc_cfg vc_cfg_a[MAX_CID];
	struct msm_camera_csid_vc_cfg vc_cfg_a[MAX_CID];
	struct msm_camera_csid_vc_cfg *vc_cfg[MAX_CID];
	struct msm_camera_csid_vc_cfg *vc_cfg[MAX_CID];
};
};


struct msm_camera_csid_params {
struct msm_camera_csid_params {
	uint8_t lane_cnt;
	unsigned char lane_cnt;
	uint16_t lane_assign;
	unsigned short lane_assign;
	uint8_t phy_sel;
	unsigned char phy_sel;
	uint32_t csi_clk;
	unsigned int csi_clk;
	struct msm_camera_csid_lut_params lut_params;
	struct msm_camera_csid_lut_params lut_params;
};
};


struct msm_camera_csiphy_params {
struct msm_camera_csiphy_params {
	uint8_t lane_cnt;
	unsigned char lane_cnt;
	uint8_t settle_cnt;
	unsigned char settle_cnt;
	uint16_t lane_mask;
	unsigned short lane_mask;
	uint8_t combo_mode;
	unsigned char combo_mode;
	uint8_t csid_core;
	unsigned char csid_core;
	uint32_t csiphy_clk;
	unsigned int csiphy_clk;
};
};


struct msm_camera_i2c_seq_reg_array {
struct msm_camera_i2c_seq_reg_array {
	uint16_t reg_addr;
	unsigned short reg_addr;
	uint8_t reg_data[I2C_SEQ_REG_DATA_MAX];
	unsigned char reg_data[I2C_SEQ_REG_DATA_MAX];
	uint16_t reg_data_size;
	unsigned short reg_data_size;
};
};


struct msm_camera_i2c_seq_reg_setting {
struct msm_camera_i2c_seq_reg_setting {
	struct msm_camera_i2c_seq_reg_array *reg_setting;
	struct msm_camera_i2c_seq_reg_array *reg_setting;
	uint16_t size;
	unsigned short size;
	enum msm_camera_i2c_reg_addr_type addr_type;
	enum msm_camera_i2c_reg_addr_type addr_type;
	uint16_t delay;
	unsigned short delay;
};
};


struct msm_actuator_reg_params_t {
struct msm_actuator_reg_params_t {
	enum msm_actuator_write_type reg_write_type;
	enum msm_actuator_write_type reg_write_type;
	uint32_t hw_mask;
	unsigned int hw_mask;
	uint16_t reg_addr;
	unsigned short reg_addr;
	uint16_t hw_shift;
	unsigned short hw_shift;
	uint16_t data_shift;
	unsigned short data_shift;
	uint16_t data_type;
	unsigned short data_type;
	uint16_t addr_type;
	unsigned short addr_type;
	uint16_t reg_data;
	unsigned short reg_data;
	uint16_t delay;
	unsigned short delay;
};
};




struct damping_params_t {
struct damping_params_t {
	uint32_t damping_step;
	unsigned int damping_step;
	uint32_t damping_delay;
	unsigned int damping_delay;
	uint32_t hw_params;
	unsigned int hw_params;
};
};


struct region_params_t {
struct region_params_t {
	/* [0] = ForwardDirection Macro boundary
	/* [0] = ForwardDirection Macro boundary
	   [1] = ReverseDirection Inf boundary
	   [1] = ReverseDirection Inf boundary
	*/
	*/
	uint16_t step_bound[2];
	unsigned short step_bound[2];
	uint16_t code_per_step;
	unsigned short code_per_step;
	/* qvalue for converting float type numbers to integer format */
	/* qvalue for converting float type numbers to integer format */
	uint32_t qvalue;
	unsigned int qvalue;
};
};


struct reg_settings_t {
struct reg_settings_t {
	uint16_t reg_addr;
	unsigned short reg_addr;
	enum msm_actuator_addr_type addr_type;
	enum msm_actuator_addr_type addr_type;
	uint16_t reg_data;
	unsigned short reg_data;
	enum msm_actuator_data_type data_type;
	enum msm_actuator_data_type data_type;
	enum msm_actuator_i2c_operation i2c_operation;
	enum msm_actuator_i2c_operation i2c_operation;
	uint32_t delay;
	unsigned int delay;
};
};


struct msm_camera_i2c_reg_setting_array {
struct msm_camera_i2c_reg_setting_array {
	struct msm_camera_i2c_reg_array reg_setting_a[MAX_I2C_REG_SET];
	struct msm_camera_i2c_reg_array reg_setting_a[MAX_I2C_REG_SET];
	uint16_t size;
	unsigned short size;
	enum msm_camera_i2c_reg_addr_type addr_type;
	enum msm_camera_i2c_reg_addr_type addr_type;
	enum msm_camera_i2c_data_type data_type;
	enum msm_camera_i2c_data_type data_type;
	uint16_t delay;
	unsigned short delay;
};
};
#endif /* __LINUX_MSM_CAM_SENSOR_H */
#endif /* __LINUX_MSM_CAM_SENSOR_H */