#include <linux/module.h>
#include <linux/types.h>
#include <linux/kernel.h>
#include <linux/mm.h>
#include <linux/string.h>
#include <linux/errno.h>
#include <linux/init.h>
#include <linux/kmod.h>
#include <linux/device.h>
#include <linux/fs.h>
#include <linux/slab.h>
#include <linux/delay.h>
#include <linux/i2c.h>
#include <linux/acpi.h>
#include "../include/linux/atomisp_gmin_platform.h"
#include <media/v4l2-device.h>
#include "mt9m114.h"
#define to_mt9m114_sensor(s) …
static int debug;
static int aaalock;
module_param(debug, int, 0644);
MODULE_PARM_DESC(…) …;
static int mt9m114_t_vflip(struct v4l2_subdev *sd, int value);
static int mt9m114_t_hflip(struct v4l2_subdev *sd, int value);
static int mt9m114_wait_state(struct i2c_client *client, int timeout);
static int
mt9m114_read_reg(struct i2c_client *client, u16 data_length, u32 reg, u32 *val)
{ … }
static int
mt9m114_write_reg(struct i2c_client *client, u16 data_length, u16 reg, u32 val)
{ … }
static int
misensor_rmw_reg(struct i2c_client *client, u16 data_length, u16 reg,
u32 mask, u32 set)
{ … }
static int __mt9m114_flush_reg_array(struct i2c_client *client,
struct mt9m114_write_ctrl *ctrl)
{ … }
static int __mt9m114_buf_reg_array(struct i2c_client *client,
struct mt9m114_write_ctrl *ctrl,
const struct misensor_reg *next)
{ … }
static int
__mt9m114_write_reg_is_consecutive(struct i2c_client *client,
struct mt9m114_write_ctrl *ctrl,
const struct misensor_reg *next)
{ … }
static int mt9m114_write_reg_array(struct i2c_client *client,
const struct misensor_reg *reglist,
int poll)
{ … }
static int mt9m114_wait_state(struct i2c_client *client, int timeout)
{ … }
static int mt9m114_set_suspend(struct v4l2_subdev *sd)
{ … }
static int mt9m114_init_common(struct v4l2_subdev *sd)
{ … }
static int power_ctrl(struct v4l2_subdev *sd, bool flag)
{ … }
static int gpio_ctrl(struct v4l2_subdev *sd, bool flag)
{ … }
static int power_up(struct v4l2_subdev *sd)
{ … }
static int power_down(struct v4l2_subdev *sd)
{ … }
static int mt9m114_s_power(struct v4l2_subdev *sd, int power)
{ … }
static int mt9m114_res2size(struct v4l2_subdev *sd, int *h_size, int *v_size)
{ … }
static int mt9m114_get_fmt(struct v4l2_subdev *sd,
struct v4l2_subdev_state *sd_state,
struct v4l2_subdev_format *format)
{ … }
static int mt9m114_set_fmt(struct v4l2_subdev *sd,
struct v4l2_subdev_state *sd_state,
struct v4l2_subdev_format *format)
{ … }
static int mt9m114_g_hflip(struct v4l2_subdev *sd, s32 *val)
{ … }
static int mt9m114_g_vflip(struct v4l2_subdev *sd, s32 *val)
{ … }
static long mt9m114_s_exposure(struct v4l2_subdev *sd,
struct atomisp_exposure *exposure)
{ … }
static long mt9m114_ioctl(struct v4l2_subdev *sd, unsigned int cmd, void *arg)
{ … }
static int mt9m114_g_exposure(struct v4l2_subdev *sd, s32 *value)
{ … }
static int mt9m114_g_exposure_zone_num(struct v4l2_subdev *sd, s32 *val)
{ … }
static int mt9m114_s_exposure_metering(struct v4l2_subdev *sd, s32 val)
{ … }
static int mt9m114_s_exposure_selection(struct v4l2_subdev *sd,
struct v4l2_subdev_state *sd_state,
struct v4l2_subdev_selection *sel)
{ … }
static int mt9m114_s_ev(struct v4l2_subdev *sd, s32 val)
{ … }
static int mt9m114_g_ev(struct v4l2_subdev *sd, s32 *val)
{ … }
static int mt9m114_s_3a_lock(struct v4l2_subdev *sd, s32 val)
{ … }
static int mt9m114_g_3a_lock(struct v4l2_subdev *sd, s32 *val)
{ … }
static int mt9m114_s_ctrl(struct v4l2_ctrl *ctrl)
{ … }
static int mt9m114_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
{ … }
static const struct v4l2_ctrl_ops ctrl_ops = …;
static struct v4l2_ctrl_config mt9m114_controls[] = …;
static int mt9m114_detect(struct mt9m114_device *dev, struct i2c_client *client)
{ … }
static int
mt9m114_s_config(struct v4l2_subdev *sd, int irq, void *platform_data)
{ … }
static int mt9m114_t_hflip(struct v4l2_subdev *sd, int value)
{ … }
static int mt9m114_t_vflip(struct v4l2_subdev *sd, int value)
{ … }
static int mt9m114_get_frame_interval(struct v4l2_subdev *sd,
struct v4l2_subdev_state *sd_state,
struct v4l2_subdev_frame_interval *interval)
{ … }
static int mt9m114_s_stream(struct v4l2_subdev *sd, int enable)
{ … }
static int mt9m114_enum_mbus_code(struct v4l2_subdev *sd,
struct v4l2_subdev_state *sd_state,
struct v4l2_subdev_mbus_code_enum *code)
{ … }
static int mt9m114_enum_frame_size(struct v4l2_subdev *sd,
struct v4l2_subdev_state *sd_state,
struct v4l2_subdev_frame_size_enum *fse)
{ … }
static int mt9m114_g_skip_frames(struct v4l2_subdev *sd, u32 *frames)
{ … }
static const struct v4l2_subdev_video_ops mt9m114_video_ops = …;
static const struct v4l2_subdev_sensor_ops mt9m114_sensor_ops = …;
static const struct v4l2_subdev_core_ops mt9m114_core_ops = …;
static const struct v4l2_subdev_pad_ops mt9m114_pad_ops = …;
static const struct v4l2_subdev_ops mt9m114_ops = …;
static void mt9m114_remove(struct i2c_client *client)
{ … }
static int mt9m114_probe(struct i2c_client *client)
{ … }
static const struct acpi_device_id mt9m114_acpi_match[] = …;
MODULE_DEVICE_TABLE(acpi, mt9m114_acpi_match);
static struct i2c_driver mt9m114_driver = …;
module_i2c_driver(…) …;
MODULE_AUTHOR(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;