SmartAudio/lichee/linux-4.9/drivers/media/platform/sunxi-vin/vin.h

232 lines
4.5 KiB
C

/*
* vin.h for all v4l2 subdev manage
*
* Copyright (c) 2017 by Allwinnertech Co., Ltd. http://www.allwinnertech.com
*
* Authors: Zhao Wei <zhaowei@allwinnertech.com>
* Yang Feng <yangfeng@allwinnertech.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#ifndef _VIN_H_
#define _VIN_H_
#include <media/media-device.h>
#include <media/media-entity.h>
#include "vin-video/vin_video.h"
#include "vin-video/vin_core.h"
#include "vin-csi/sunxi_csi.h"
#include "vin-isp/sunxi_isp.h"
#include "vin-vipp/sunxi_scaler.h"
#include "vin-mipi/sunxi_mipi.h"
#include "platform/platform_cfg.h"
#include "top_reg.h"
enum {
VIN_TOP_CLK = 0,
VIN_TOP_CLK_SRC,
VIN_MAX_CLK,
};
enum {
VIN_MIPI_CLK = 0,
VIN_MIPI_CLK_SRC,
VIN_MIPI_MAX_CLK,
};
#define VIN_CLK_RATE (432*1000*1000)
#define NO_VALID_SENSOR (-1)
struct vin_valid_sensor {
struct v4l2_subdev *sd;
char *name;
};
struct vin_csi_info {
struct v4l2_subdev *sd;
int id;
};
struct vin_mipi_info {
struct v4l2_subdev *sd;
int id;
};
struct vin_cci_info {
struct v4l2_subdev *sd;
int id;
};
struct vin_isp_info {
struct v4l2_subdev *sd;
int id;
};
struct vin_stat_info {
struct v4l2_subdev *sd;
int id;
};
struct vin_scaler_info {
struct v4l2_subdev *sd;
int id;
};
struct vin_clk_info {
struct clk *clock;
int use_count;
unsigned long frequency;
};
struct vin_mclk_info {
struct clk *mclk;
struct clk *clk_24m;
struct clk *clk_pll;
struct pinctrl *pin;
int use_count;
unsigned long frequency;
};
enum vin_sub_device_regulator {
ENUM_IOVDD,
ENUM_AVDD,
ENUM_DVDD,
ENUM_AFVDD,
ENUM_FLVDD,
ENUM_CAMERAVDD,
ENUM_MAX_REGU,
};
struct vin_power {
struct regulator *pmic;
int power_vol;
char power_str[32];
};
struct sensor_instance {
char cam_name[I2C_NAME_SIZE];
int cam_addr;
int cam_type;
int is_isp_used;
int is_bayer_raw;
int vflip;
int hflip;
int act_addr;
char act_name[I2C_NAME_SIZE];
char isp_cfg_name[I2C_NAME_SIZE];
};
struct sensor_list {
int use_sensor_list;
int used;
int csi_sel;
int device_sel;
int mclk_id;
int sensor_bus_sel;
int sensor_bus_type;
int act_bus_sel;
int act_bus_type;
int act_separate;
int power_set;
int detect_num;
char sensor_pos[32];
int valid_idx;
struct vin_power power[ENUM_MAX_REGU];
struct gpio_config gpio[MAX_GPIO_NUM];
struct sensor_instance inst[MAX_DETECT_NUM];
};
enum module_type {
VIN_MODULE_TYPE_I2C,
VIN_MODULE_TYPE_CCI,
VIN_MODULE_TYPE_SPI,
VIN_MODULE_TYPE_GPIO,
VIN_MODULE_TYPE_MAX,
};
struct vin_act_info {
struct v4l2_subdev *sd;
enum module_type type;
int id;
};
struct vin_flash_info {
struct v4l2_subdev *sd;
enum module_type type;
int id;
};
struct vin_sensor_info {
struct v4l2_subdev *sd;
enum module_type type;
int id;
};
struct vin_module_info {
struct vin_act_info act[MAX_DETECT_NUM];
struct vin_flash_info flash;
struct vin_sensor_info sensor[MAX_DETECT_NUM];
int id;
};
struct modules_config {
struct vin_module_info modules;
struct sensor_list sensors;
int flash_used;
int act_used;
};
struct vin_md {
struct vin_csi_info csi[VIN_MAX_CSI];
struct vin_mipi_info mipi[VIN_MAX_MIPI];
struct vin_cci_info cci[VIN_MAX_CCI];
struct vin_isp_info isp[VIN_MAX_ISP];
struct vin_stat_info stat[VIN_MAX_ISP];
struct vin_scaler_info scaler[VIN_MAX_SCALER];
struct vin_core *vinc[VIN_MAX_DEV];
struct vin_clk_info clk[VIN_MAX_CLK];
struct vin_clk_info mipi_clk[VIN_MIPI_MAX_CLK];
struct vin_mclk_info mclk[VIN_MAX_CCI];
struct vin_clk_info isp_clk;
struct modules_config modules[VIN_MAX_DEV];
unsigned int is_empty;
unsigned int id;
int use_count;
void __iomem *base;
struct media_device media_dev;
struct v4l2_device v4l2_dev;
struct platform_device *pdev;
bool user_subdev_api;
spinlock_t slock;
};
static inline struct vin_md *entity_to_vin_mdev(struct media_entity *me)
{
return me->graph_obj.mdev == NULL ? NULL :
container_of(me->graph_obj.mdev, struct vin_md, media_dev);
}
/*
* Media pipeline operations to be called from within the video
* node when it is the last entity of the pipeline. Implemented
* by corresponding media device driver.
*/
struct vin_pipeline_ops {
int (*open)(struct vin_pipeline *p, struct media_entity *me,
bool resume);
int (*close)(struct vin_pipeline *p);
int (*set_stream)(struct vin_pipeline *p, int state);
};
#define vin_pipeline_call(f, op, p, args...) \
(((f)->pipeline_ops && (f)->pipeline_ops->op) ? \
(f)->pipeline_ops->op((p), ##args) : -ENOIOCTLCMD)
#endif /*_VIN_H_*/