2008-10-01 15:51:53 +08:00
|
|
|
/*
|
|
|
|
* USB Driver for ALi m5602 based webcams
|
|
|
|
*
|
2008-10-17 03:43:16 +08:00
|
|
|
* Copyright (C) 2008 Erik Andrén
|
2008-10-01 15:51:53 +08:00
|
|
|
* Copyright (C) 2007 Ilyes Gouta. Based on the m5603x Linux Driver Project.
|
|
|
|
* Copyright (C) 2005 m5603x Linux Driver Project <m5602@x3ng.com.br>
|
|
|
|
*
|
|
|
|
* Portions of code to USB interface and ALi driver software,
|
|
|
|
* Copyright (c) 2006 Willem Duinker
|
|
|
|
* v4l2 interface modeled after the V4L2 driver
|
|
|
|
* for SN9C10x PC Camera Controllers
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation, version 2.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef M5602_SENSOR_H_
|
|
|
|
#define M5602_SENSOR_H_
|
|
|
|
|
|
|
|
#include "m5602_bridge.h"
|
|
|
|
|
2009-01-14 00:55:52 +08:00
|
|
|
#define M5602_V4L2_CID_GREEN_BALANCE (V4L2_CID_PRIVATE_BASE + 0)
|
2009-01-14 03:40:28 +08:00
|
|
|
#define M5602_V4L2_CID_NOISE_SUPPRESION (V4L2_CID_PRIVATE_BASE + 1)
|
2009-01-14 00:55:52 +08:00
|
|
|
|
2008-10-01 15:51:53 +08:00
|
|
|
/* Enumerates all supported sensors */
|
|
|
|
enum sensors {
|
|
|
|
OV9650_SENSOR = 1,
|
|
|
|
S5K83A_SENSOR = 2,
|
|
|
|
S5K4AA_SENSOR = 3,
|
|
|
|
MT9M111_SENSOR = 4,
|
2009-01-22 00:39:17 +08:00
|
|
|
PO1030_SENSOR = 5,
|
|
|
|
OV7660_SENSOR = 6,
|
2008-10-01 15:51:53 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Enumerates all possible instruction types */
|
|
|
|
enum instruction {
|
|
|
|
BRIDGE,
|
|
|
|
SENSOR,
|
|
|
|
SENSOR_LONG
|
|
|
|
};
|
|
|
|
|
|
|
|
struct m5602_sensor {
|
|
|
|
/* Defines the name of a sensor */
|
|
|
|
char name[32];
|
|
|
|
|
|
|
|
/* What i2c address the sensor is connected to */
|
|
|
|
u8 i2c_slave_id;
|
|
|
|
|
2008-11-26 15:01:40 +08:00
|
|
|
/* Width of each i2c register (in bytes) */
|
|
|
|
u8 i2c_regW;
|
|
|
|
|
2008-10-01 15:51:53 +08:00
|
|
|
/* Probes if the sensor is connected */
|
|
|
|
int (*probe)(struct sd *sd);
|
|
|
|
|
|
|
|
/* Performs a initialization sequence */
|
|
|
|
int (*init)(struct sd *sd);
|
|
|
|
|
2013-02-20 01:57:03 +08:00
|
|
|
/* Controls initialization, maybe NULL */
|
|
|
|
int (*init_controls)(struct sd *sd);
|
|
|
|
|
2008-12-22 04:25:25 +08:00
|
|
|
/* Executed when the camera starts to send data */
|
|
|
|
int (*start)(struct sd *sd);
|
|
|
|
|
2008-12-29 01:09:21 +08:00
|
|
|
/* Executed when the camera ends to send data */
|
|
|
|
int (*stop)(struct sd *sd);
|
|
|
|
|
2009-01-03 23:10:11 +08:00
|
|
|
/* Executed when the device is disconnected */
|
|
|
|
void (*disconnect)(struct sd *sd);
|
2008-10-01 15:51:53 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|