Merge branch 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab...
[pandora-kernel.git] / drivers / media / video / gspca / m5602 / m5602_sensor.h
1 /*
2  * USB Driver for ALi m5602 based webcams
3  *
4  * Copyright (C) 2008 Erik AndrĂ©n
5  * Copyright (C) 2007 Ilyes Gouta. Based on the m5603x Linux Driver Project.
6  * Copyright (C) 2005 m5603x Linux Driver Project <m5602@x3ng.com.br>
7  *
8  * Portions of code to USB interface and ALi driver software,
9  * Copyright (c) 2006 Willem Duinker
10  * v4l2 interface modeled after the V4L2 driver
11  * for SN9C10x PC Camera Controllers
12  *
13  * This program is free software; you can redistribute it and/or
14  * modify it under the terms of the GNU General Public License as
15  * published by the Free Software Foundation, version 2.
16  *
17  */
18
19 #ifndef M5602_SENSOR_H_
20 #define M5602_SENSOR_H_
21
22 #include "m5602_bridge.h"
23
24 /* Enumerates all supported sensors */
25 enum sensors {
26         OV9650_SENSOR   = 1,
27         S5K83A_SENSOR   = 2,
28         S5K4AA_SENSOR   = 3,
29         MT9M111_SENSOR  = 4,
30         PO1030_SENSOR   = 5
31 };
32
33 /* Enumerates all possible instruction types */
34 enum instruction {
35         BRIDGE,
36         SENSOR,
37         SENSOR_LONG
38 };
39
40 struct m5602_sensor {
41         /* Defines the name of a sensor */
42         char name[32];
43
44         /* What i2c address the sensor is connected to */
45         u8 i2c_slave_id;
46
47         /* Width of each i2c register (in bytes) */
48         u8 i2c_regW;
49
50         /* Probes if the sensor is connected */
51         int (*probe)(struct sd *sd);
52
53         /* Performs a initialization sequence */
54         int (*init)(struct sd *sd);
55
56         /* Executed when the camera starts to send data */
57         int (*start)(struct sd *sd);
58
59         /* Executed when the camera ends to send data */
60         int (*stop)(struct sd *sd);
61
62         /* Executed when the device is disconnected */
63         void (*disconnect)(struct sd *sd);
64
65         /* Performs a power down sequence */
66         int (*power_down)(struct sd *sd);
67 };
68
69 #endif