ov511.h
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:18k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. #ifndef __LINUX_OV511_H
  2. #define __LINUX_OV511_H
  3. #include <asm/uaccess.h>
  4. #include <linux/videodev.h>
  5. #include <linux/smp_lock.h>
  6. #include <linux/usb.h>
  7. #define OV511_DEBUG /* Turn on debug messages */
  8. #ifdef OV511_DEBUG
  9. #  define PDEBUG(level, fmt, args...) 
  10. if (debug >= (level)) info("[" __PRETTY_FUNCTION__ ":%d] " fmt, __LINE__ , 
  11. ## args)
  12. #else
  13. #  define PDEBUG(level, fmt, args...) do {} while(0)
  14. #endif
  15. /* This macro restricts an int variable to an inclusive range */
  16. #define RESTRICT_TO_RANGE(v,mi,ma) { 
  17. if ((v) < (mi)) (v) = (mi); 
  18. else if ((v) > (ma)) (v) = (ma); 
  19. }
  20. /* --------------------------------- */
  21. /* DEFINES FOR OV511 AND OTHER CHIPS */
  22. /* --------------------------------- */
  23. /* USB IDs */
  24. #define VEND_OMNIVISION 0x05A9
  25. #define PROD_OV511 0x0511
  26. #define PROD_OV511PLUS 0xA511
  27. #define PROD_OV518 0x0518
  28. #define PROD_OV518PLUS 0xA518
  29. #define VEND_MATTEL 0x0813
  30. #define PROD_ME2CAM 0x0002
  31. /* Camera interface register numbers */
  32. #define OV511_REG_CAMERA_DELAY_MODE 0x10
  33. #define OV511_REG_CAMERA_EDGE_MODE 0x11
  34. #define OV511_REG_CAMERA_CLAMPED_PIXEL_NUM 0x12
  35. #define OV511_REG_CAMERA_CLAMPED_LINE_NUM 0x13
  36. #define OV511_REG_CAMERA_PIXEL_DIVISOR 0x14
  37. #define OV511_REG_CAMERA_LINE_DIVISOR 0x15
  38. #define OV511_REG_CAMERA_DATA_INPUT_SELECT 0x16
  39. #define OV511_REG_CAMERA_RESERVED_LINE_MODE 0x17
  40. #define OV511_REG_CAMERA_BITMASK 0x18
  41. /* Snapshot mode camera interface register numbers */
  42. #define OV511_REG_SNAP_CAPTURED_FRAME 0x19
  43. #define OV511_REG_SNAP_CLAMPED_PIXEL_NUM 0x1A
  44. #define OV511_REG_SNAP_CLAMPED_LINE_NUM 0x1B
  45. #define OV511_REG_SNAP_PIXEL_DIVISOR 0x1C
  46. #define OV511_REG_SNAP_LINE_DIVISOR 0x1D
  47. #define OV511_REG_SNAP_DATA_INPUT_SELECT 0x1E
  48. #define OV511_REG_SNAP_BITMASK 0x1F
  49. /* DRAM register numbers */
  50. #define OV511_REG_DRAM_ENABLE_FLOW_CONTROL 0x20
  51. #define OV511_REG_DRAM_READ_CYCLE_PREDICT 0x21
  52. #define OV511_REG_DRAM_MANUAL_READ_CYCLE 0x22
  53. #define OV511_REG_DRAM_REFRESH_COUNTER 0x23
  54. /* ISO FIFO register numbers */
  55. #define OV511_REG_FIFO_PACKET_SIZE 0x30
  56. #define OV511_REG_FIFO_BITMASK 0x31
  57. /* PIO register numbers */
  58. #define OV511_REG_PIO_BITMASK 0x38
  59. #define OV511_REG_PIO_DATA_PORT 0x39
  60. #define OV511_REG_PIO_BIST 0x3E
  61. /* I2C register numbers */
  62. #define OV511_REG_I2C_CONTROL 0x40
  63. #define OV518_REG_I2C_CONTROL 0x47 /* OV518(+) only */
  64. #define OV511_REG_I2C_SLAVE_ID_WRITE 0x41
  65. #define OV511_REG_I2C_SUB_ADDRESS_3_BYTE 0x42
  66. #define OV511_REG_I2C_SUB_ADDRESS_2_BYTE 0x43
  67. #define OV511_REG_I2C_SLAVE_ID_READ 0x44
  68. #define OV511_REG_I2C_DATA_PORT 0x45
  69. #define OV511_REG_I2C_CLOCK_PRESCALER 0x46
  70. #define OV511_REG_I2C_TIME_OUT_COUNTER 0x47
  71. /* I2C snapshot register numbers */
  72. #define OV511_REG_I2C_SNAP_SUB_ADDRESS 0x48
  73. #define OV511_REG_I2C_SNAP_DATA_PORT 0x49
  74. /* System control register numbers */
  75. #define OV511_REG_SYSTEM_RESET 0x50
  76. #define  OV511_RESET_UDC 0x01
  77. #define  OV511_RESET_I2C 0x02
  78. #define  OV511_RESET_FIFO 0x04
  79. #define  OV511_RESET_OMNICE 0x08
  80. #define  OV511_RESET_DRAM_INTF 0x10
  81. #define  OV511_RESET_CAMERA_INTF 0x20
  82. #define  OV511_RESET_OV511 0x40
  83. #define  OV511_RESET_NOREGS 0x3F /* All but OV511 & regs */
  84. #define  OV511_RESET_ALL 0x7F
  85. #define OV511_REG_SYSTEM_CLOCK_DIVISOR 0x51
  86. #define OV511_REG_SYSTEM_SNAPSHOT 0x52
  87. #define OV511_REG_SYSTEM_INIT          0x53
  88. #define OV511_REG_SYSTEM_PWR_CLK 0x54 /* OV511+/OV518(+) only */
  89. #define OV511_REG_SYSTEM_LED_CTL 0x55 /* OV511+ only */
  90. #define OV518_REG_GPIO_IN 0x55 /* OV518(+) only */
  91. #define OV518_REG_GPIO_OUT 0x56 /* OV518(+) only */
  92. #define OV518_REG_GPIO_CTL 0x57 /* OV518(+) only */
  93. #define OV518_REG_GPIO_PULSE_IN 0x58 /* OV518(+) only */
  94. #define OV518_REG_GPIO_PULSE_CLEAR 0x59 /* OV518(+) only */
  95. #define OV518_REG_GPIO_PULSE_POLARITY 0x5a /* OV518(+) only */
  96. #define OV518_REG_GPIO_PULSE_EN 0x5b /* OV518(+) only */
  97. #define OV518_REG_GPIO_RESET 0x5c /* OV518(+) only */
  98. #define OV511_REG_SYSTEM_USER_DEFINED 0x5E
  99. #define OV511_REG_SYSTEM_CUSTOM_ID 0x5F
  100. /* OmniCE register numbers */
  101. #define OV511_OMNICE_PREDICTION_HORIZ_Y 0x70
  102. #define OV511_OMNICE_PREDICTION_HORIZ_UV 0x71
  103. #define OV511_OMNICE_PREDICTION_VERT_Y 0x72
  104. #define OV511_OMNICE_PREDICTION_VERT_UV 0x73
  105. #define OV511_OMNICE_QUANTIZATION_HORIZ_Y 0x74
  106. #define OV511_OMNICE_QUANTIZATION_HORIZ_UV 0x75
  107. #define OV511_OMNICE_QUANTIZATION_VERT_Y 0x76
  108. #define OV511_OMNICE_QUANTIZATION_VERT_UV 0x77
  109. #define OV511_OMNICE_ENABLE 0x78
  110. #define OV511_OMNICE_LUT_ENABLE 0x79
  111. #define OV511_OMNICE_Y_LUT_BEGIN 0x80
  112. #define OV511_OMNICE_Y_LUT_END 0x9F
  113. #define OV511_OMNICE_UV_LUT_BEGIN 0xA0
  114. #define OV511_OMNICE_UV_LUT_END 0xBF
  115. /* Alternate numbers for various max packet sizes (OV511 only) */
  116. #define OV511_ALT_SIZE_992 0
  117. #define OV511_ALT_SIZE_993 1
  118. #define OV511_ALT_SIZE_768 2
  119. #define OV511_ALT_SIZE_769 3
  120. #define OV511_ALT_SIZE_512 4
  121. #define OV511_ALT_SIZE_513 5
  122. #define OV511_ALT_SIZE_257 6
  123. #define OV511_ALT_SIZE_0 7
  124. /* Alternate numbers for various max packet sizes (OV511+ only) */
  125. #define OV511PLUS_ALT_SIZE_0 0
  126. #define OV511PLUS_ALT_SIZE_33 1
  127. #define OV511PLUS_ALT_SIZE_129 2
  128. #define OV511PLUS_ALT_SIZE_257 3
  129. #define OV511PLUS_ALT_SIZE_385 4
  130. #define OV511PLUS_ALT_SIZE_513 5
  131. #define OV511PLUS_ALT_SIZE_769 6
  132. #define OV511PLUS_ALT_SIZE_961 7
  133. /* Alternate numbers for various max packet sizes (OV518(+) only) */
  134. #define OV518_ALT_SIZE_0 0
  135. #define OV518_ALT_SIZE_128 1
  136. #define OV518_ALT_SIZE_256 2
  137. #define OV518_ALT_SIZE_384 3
  138. #define OV518_ALT_SIZE_512 4
  139. #define OV518_ALT_SIZE_640 5
  140. #define OV518_ALT_SIZE_768 6
  141. #define OV518_ALT_SIZE_896 7
  142. /* OV7610 registers */
  143. #define OV7610_REG_GAIN          0x00 /* gain setting (5:0) */
  144. #define OV7610_REG_BLUE          0x01 /* blue channel balance */
  145. #define OV7610_REG_RED           0x02 /* red channel balance */
  146. #define OV7610_REG_SAT           0x03 /* saturation */
  147. /* 04 reserved */
  148. #define OV7610_REG_CNT           0x05 /* Y contrast */
  149. #define OV7610_REG_BRT           0x06 /* Y brightness */
  150. /* 08-0b reserved */
  151. #define OV7610_REG_BLUE_BIAS     0x0C /* blue channel bias (5:0) */
  152. #define OV7610_REG_RED_BIAS      0x0D /* read channel bias (5:0) */
  153. #define OV7610_REG_GAMMA_COEFF   0x0E /* gamma settings */
  154. #define OV7610_REG_WB_RANGE      0x0F /* AEC/ALC/S-AWB settings */
  155. #define OV7610_REG_EXP           0x10 /* manual exposure setting */
  156. #define OV7610_REG_CLOCK         0x11 /* polarity/clock prescaler */
  157. #define OV7610_REG_COM_A         0x12 /* misc common regs */
  158. #define OV7610_REG_COM_B         0x13 /* misc common regs */
  159. #define OV7610_REG_COM_C         0x14 /* misc common regs */
  160. #define OV7610_REG_COM_D         0x15 /* misc common regs */
  161. #define OV7610_REG_FIELD_DIVIDE  0x16 /* field interval/mode settings */
  162. #define OV7610_REG_HWIN_START    0x17 /* horizontal window start */
  163. #define OV7610_REG_HWIN_END      0x18 /* horizontal window end */
  164. #define OV7610_REG_VWIN_START    0x19 /* vertical window start */
  165. #define OV7610_REG_VWIN_END      0x1A /* vertical window end */
  166. #define OV7610_REG_PIXEL_SHIFT   0x1B /* pixel shift */
  167. #define OV7610_REG_ID_HIGH       0x1C /* manufacturer ID MSB */
  168. #define OV7610_REG_ID_LOW        0x1D /* manufacturer ID LSB */
  169. /* 0e-0f reserved */
  170. #define OV7610_REG_COM_E         0x20 /* misc common regs */
  171. #define OV7610_REG_YOFFSET       0x21 /* Y channel offset */
  172. #define OV7610_REG_UOFFSET       0x22 /* U channel offset */
  173. /* 23 reserved */
  174. #define OV7610_REG_ECW           0x24 /* Exposure white level for AEC */
  175. #define OV7610_REG_ECB           0x25 /* Exposure black level for AEC */
  176. #define OV7610_REG_COM_F         0x26 /* misc settings */
  177. #define OV7610_REG_COM_G         0x27 /* misc settings */
  178. #define OV7610_REG_COM_H         0x28 /* misc settings */
  179. #define OV7610_REG_COM_I         0x29 /* misc settings */
  180. #define OV7610_REG_FRAMERATE_H   0x2A /* frame rate MSB + misc */
  181. #define OV7610_REG_FRAMERATE_L   0x2B /* frame rate LSB */
  182. #define OV7610_REG_ALC           0x2C /* Auto Level Control settings */
  183. #define OV7610_REG_COM_J         0x2D /* misc settings */
  184. #define OV7610_REG_VOFFSET       0x2E /* V channel offset adjustment */
  185. #define OV7610_REG_ARRAY_BIAS  0x2F /* Array bias -- don't change */
  186. /* 30-32 reserved */
  187. #define OV7610_REG_YGAMMA        0x33 /* misc gamma settings (7:6) */
  188. #define OV7610_REG_BIAS_ADJUST   0x34 /* misc bias settings */
  189. #define OV7610_REG_COM_L         0x35 /* misc settings */
  190. /* 36-37 reserved */
  191. #define OV7610_REG_COM_K         0x38 /* misc registers */
  192. #define FRAMES_PER_DESC 10 /* FIXME - What should this be? */
  193. #define FRAME_SIZE_PER_DESC 993 /* FIXME - Deprecated */
  194. #define MAX_FRAME_SIZE_PER_DESC 993 /* For statically allocated stuff */
  195. #define PIXELS_PER_SEG 256 /* Pixels per segment */
  196. #define OV511_ENDPOINT_ADDRESS 1 /* Isoc endpoint number */
  197. /* I2C addresses */
  198. #define OV7xx0_I2C_WRITE_ID   0x42
  199. #define OV7xx0_I2C_READ_ID    0x43
  200. #define OV6xx0_I2C_WRITE_ID   0xC0
  201. #define OV6xx0_I2C_READ_ID    0xC1
  202. #define OV8xx0_I2C_WRITE_ID   0xA0
  203. #define OV8xx0_I2C_READ_ID    0xA1
  204. #define KS0127_I2C_WRITE_ID   0xD8
  205. #define KS0127_I2C_READ_ID    0xD9
  206. #define SAA7111A_I2C_WRITE_ID 0x48
  207. #define SAA7111A_I2C_READ_ID  0x49
  208. #define OV511_I2C_CLOCK_PRESCALER 0x03
  209. /* Bridge types */
  210. enum {
  211. BRG_UNKNOWN,
  212. BRG_OV511,
  213. BRG_OV511PLUS,
  214. BRG_OV518,
  215. BRG_OV518PLUS,
  216. };
  217. /* Bridge classes */
  218. enum {
  219. BCL_UNKNOWN,
  220. BCL_OV511,
  221. BCL_OV518,
  222. };
  223. /* Sensor types */
  224. enum {
  225. SEN_UNKNOWN,
  226. SEN_OV76BE,
  227. SEN_OV7610,
  228. SEN_OV7620,
  229. SEN_OV7620AE,
  230. SEN_OV6620,
  231. SEN_OV6630,
  232. SEN_OV6630AE,
  233. SEN_OV6630AF,
  234. SEN_OV8600,
  235. SEN_KS0127,
  236. SEN_KS0127B,
  237. SEN_SAA7111A,
  238. };
  239. // Not implemented yet
  240. #if 0
  241. /* Sensor classes */
  242. enum {
  243. SCL_UNKNOWN,
  244. SCL_OV7610, /* 7610, 76BE, 7620AE (for now) */
  245. SCL_OV7620,
  246. SCL_OV6620,
  247. SCL_OV6630, /* 6630, 6630AE, 6630AF */
  248. SCL_OV8600,
  249. SCL_KS0127, /* SEN_KS0127, SEN_KS0127B */
  250. SCL_SAA7111A,
  251. };
  252. #endif
  253. enum {
  254. STATE_SCANNING, /* Scanning for start */
  255. STATE_HEADER, /* Parsing header */
  256. STATE_LINES, /* Parsing lines */
  257. };
  258. /* Buffer states */
  259. enum {
  260. BUF_NOT_ALLOCATED,
  261. BUF_ALLOCATED,
  262. BUF_PEND_DEALLOC, /* ov511->buf_timer is set */
  263. };
  264. /* --------- Definition of ioctl interface --------- */
  265. #define OV511_INTERFACE_VER 101
  266. /* LED options */
  267. enum {
  268. LED_OFF,
  269. LED_ON,
  270. LED_AUTO,
  271. };
  272. /* Raw frame formats */
  273. enum {
  274. RAWFMT_INVALID,
  275. RAWFMT_YUV400,
  276. RAWFMT_YUV420,
  277. RAWFMT_YUV422,
  278. RAWFMT_GBR422,
  279. };
  280. /* Unsigned short option numbers */
  281. enum {
  282. OV511_USOPT_INVALID,
  283. OV511_USOPT_BRIGHT,
  284. OV511_USOPT_SAT,
  285. OV511_USOPT_HUE,
  286. OV511_USOPT_CONTRAST,
  287. };
  288. /* Unsigned int option numbers */
  289. enum {
  290. OV511_UIOPT_INVALID,
  291. OV511_UIOPT_POWER_FREQ,
  292. OV511_UIOPT_BFILTER,
  293. OV511_UIOPT_LED,
  294. OV511_UIOPT_DEBUG,
  295. OV511_UIOPT_COMPRESS,
  296. };
  297. struct ov511_ushort_opt {
  298. int optnum; /* Specific option number */
  299. unsigned short val;
  300. };
  301. struct ov511_uint_opt {
  302. int optnum; /* Specific option number */
  303. unsigned int val;
  304. };
  305. struct ov511_i2c_struct {
  306. unsigned char slave; /* Write slave ID (read ID - 1) */
  307. unsigned char reg;   /* Index of register */
  308. unsigned char value; /* User sets this w/ write, driver does w/ read */
  309. unsigned char mask;  /* Bits to be changed. Not used with read ops */
  310. };
  311. /* ioctls */
  312. #define OV511IOC_GINTVER  _IOR('v', BASE_VIDIOCPRIVATE + 0, int)
  313. #define OV511IOC_GUSHORT _IOWR('v', BASE_VIDIOCPRIVATE + 1, 
  314.        struct ov511_ushort_opt)
  315. #define OV511IOC_SUSHORT  _IOW('v', BASE_VIDIOCPRIVATE + 2, 
  316.        struct ov511_ushort_opt)
  317. #define OV511IOC_GUINT   _IOWR('v', BASE_VIDIOCPRIVATE + 3, 
  318.        struct ov511_uint_opt)
  319. #define OV511IOC_SUINT    _IOW('v', BASE_VIDIOCPRIVATE + 4, 
  320.        struct ov511_uint_opt)
  321. #define OV511IOC_WI2C     _IOW('v', BASE_VIDIOCPRIVATE + 5, 
  322.        struct ov511_i2c_struct)
  323. #define OV511IOC_RI2C    _IOWR('v', BASE_VIDIOCPRIVATE + 6, 
  324.        struct ov511_i2c_struct)
  325. /* ------------- End IOCTL interface -------------- */
  326. struct ov511_sbuf {
  327. char *data;
  328. urb_t *urb;
  329. };
  330. enum {
  331. FRAME_UNUSED, /* Unused (no MCAPTURE) */
  332. FRAME_READY, /* Ready to start grabbing */
  333. FRAME_GRABBING, /* In the process of being grabbed into */
  334. FRAME_DONE, /* Finished grabbing, but not been synced yet */
  335. FRAME_ERROR, /* Something bad happened while processing */
  336. };
  337. struct ov511_regvals {
  338. enum {
  339. OV511_DONE_BUS,
  340. OV511_REG_BUS,
  341. OV511_I2C_BUS,
  342. } bus;
  343. unsigned char reg;
  344. unsigned char val;
  345. };
  346. struct ov511_frame {
  347. int framenum; /* Index of this frame */
  348. char *data; /* Frame buffer */
  349. char *tempdata; /* Temp buffer for multi-stage conversions */
  350. char *rawdata; /* Raw camera data buffer */
  351. int depth; /* Bytes per pixel */
  352. int width; /* Width application is expecting */
  353. int height; /* Height application is expecting */
  354. int rawwidth; /* Actual width of frame sent from camera */
  355. int rawheight; /* Actual height of frame sent from camera */
  356. int sub_flag; /* Sub-capture mode for this frame? */
  357. unsigned int format; /* Format for this frame */
  358. int compressed; /* Is frame compressed? */
  359. volatile int grabstate; /* State of grabbing */
  360. int scanstate; /* State of scanning */
  361. int bytes_recvd; /* Number of image bytes received from camera */
  362. long bytes_read; /* Amount that has been read() */
  363. wait_queue_head_t wq; /* Processes waiting */
  364. int snapshot; /* True if frame was a snapshot */
  365. };
  366. #define DECOMP_INTERFACE_VER 2
  367. /* Compression module operations */
  368. struct ov51x_decomp_ops {
  369. int (*decomp_400)(unsigned char *, unsigned char *, int, int, int);
  370. int (*decomp_420)(unsigned char *, unsigned char *, int, int, int);
  371. int (*decomp_422)(unsigned char *, unsigned char *, int, int, int);
  372. void (*decomp_lock)(void);
  373. void (*decomp_unlock)(void);
  374. };
  375. #define OV511_NUMFRAMES 2
  376. #if OV511_NUMFRAMES > VIDEO_MAX_FRAME
  377. #error "OV511_NUMFRAMES is too high"
  378. #endif
  379. #define OV511_NUMSBUF 2
  380. struct usb_ov511 {
  381. struct video_device vdev;
  382. /* Device structure */
  383. struct usb_device *dev;
  384. int customid;
  385. int desc;
  386. unsigned char iface;
  387. /* Determined by sensor type */
  388. int maxwidth;
  389. int maxheight;
  390. int minwidth;
  391. int minheight;
  392. int brightness;
  393. int colour;
  394. int contrast;
  395. int hue;
  396. int whiteness;
  397. int exposure;
  398. int auto_brt; /* Auto brightness enabled flag */
  399. int auto_gain; /* Auto gain control enabled flag */
  400. int auto_exp; /* Auto exposure enabled flag */
  401. int backlight; /* Backlight exposure algorithm flag */
  402. int led_policy; /* LED: off|on|auto; OV511+ only */
  403. struct semaphore lock; /* Serializes user-accessible operations */
  404. int user; /* user count for exclusive use */
  405. int streaming; /* Are we streaming Isochronous? */
  406. int grabbing; /* Are we grabbing? */
  407. int compress; /* Should the next frame be compressed? */
  408. int compress_inited; /* Are compression params uploaded? */
  409. int lightfreq; /* Power (lighting) frequency */
  410. int bandfilt; /* Banding filter enabled flag */
  411. char *fbuf; /* Videodev buffer area */
  412. char *tempfbuf; /* Temporary (intermediate) buffer area */
  413. char *rawfbuf; /* Raw camera data buffer area */
  414. int sub_flag; /* Pix Array subcapture on flag */
  415. int subx; /* Pix Array subcapture x offset */
  416. int suby; /* Pix Array subcapture y offset */
  417. int subw; /* Pix Array subcapture width */
  418. int subh; /* Pix Array subcapture height */
  419. int curframe; /* Current receiving sbuf */
  420. struct ov511_frame frame[OV511_NUMFRAMES];
  421. struct ov511_sbuf sbuf[OV511_NUMSBUF];
  422. wait_queue_head_t wq; /* Processes waiting */
  423. int snap_enabled; /* Snapshot mode enabled */
  424. int bridge; /* Type of bridge (BRG_*) */
  425. int bclass; /* Class of bridge (BCL_*) */
  426. int sensor; /* Type of image sensor chip (SEN_*) */
  427. int sclass; /* Type of image sensor chip (SCL_*) */
  428. int tuner; /* Type of TV tuner */
  429. int packet_size; /* Frame size per isoc desc */
  430. struct semaphore param_lock; /* params lock for this camera */
  431. /* /proc entries, relative to /proc/video/ov511/ */
  432. struct proc_dir_entry *proc_devdir;   /* Per-device proc directory */
  433. struct proc_dir_entry *proc_info;     /* <minor#>/info entry */
  434. struct proc_dir_entry *proc_button;   /* <minor#>/button entry */
  435. struct proc_dir_entry *proc_control;  /* <minor#>/control entry */
  436. /* Framebuffer/sbuf management */
  437. int buf_state;
  438. struct semaphore buf_lock;
  439. struct timer_list buf_timer;
  440. struct ov51x_decomp_ops *decomp_ops;
  441. /* Stop streaming while changing picture settings */
  442. int stop_during_set;
  443. int stopped; /* Streaming is temporarily paused */
  444. /* Video decoder stuff */
  445. int input; /* Composite, S-VIDEO, etc... */
  446. int num_inputs; /* Number of inputs */
  447. int norm;  /* NTSC / PAL / SECAM */
  448. int has_decoder; /* Device has a video decoder */
  449. int has_tuner; /* Device has a TV tuner */
  450. int has_audio_proc; /* Device has an audio processor */
  451. int freq; /* Current tuner frequency */
  452. int tuner_type; /* Specific tuner model */
  453. /* I2C interface to kernel */
  454. struct semaphore i2c_lock;   /* Protect I2C controller regs */
  455. unsigned char primary_i2c_slave;  /* I2C write id of sensor */
  456. };
  457. struct cam_list {
  458. int id;
  459. char *description;
  460. };
  461. struct palette_list {
  462. int num;
  463. char *name;
  464. };
  465. struct mode_list_518 {
  466. int width;
  467. int height;
  468. u8 reg28;
  469. u8 reg29;
  470. u8 reg2a;
  471. u8 reg2c;
  472. u8 reg2e;
  473. u8 reg24;
  474. u8 reg25;
  475. };
  476. /* Compression stuff */
  477. #define OV511_QUANTABLESIZE 64
  478. #define OV518_QUANTABLESIZE 32
  479. #define OV511_YQUANTABLE { 
  480. 0, 1, 1, 2, 2, 3, 3, 4, 
  481. 1, 1, 1, 2, 2, 3, 4, 4, 
  482. 1, 1, 2, 2, 3, 4, 4, 4, 
  483. 2, 2, 2, 3, 4, 4, 4, 4, 
  484. 2, 2, 3, 4, 4, 5, 5, 5, 
  485. 3, 3, 4, 4, 5, 5, 5, 5, 
  486. 3, 4, 4, 4, 5, 5, 5, 5, 
  487. 4, 4, 4, 4, 5, 5, 5, 5  
  488. }
  489. #define OV511_UVQUANTABLE { 
  490. 0, 2, 2, 3, 4, 4, 4, 4, 
  491. 2, 2, 2, 4, 4, 4, 4, 4, 
  492. 2, 2, 3, 4, 4, 4, 4, 4, 
  493. 3, 4, 4, 4, 4, 4, 4, 4, 
  494. 4, 4, 4, 4, 4, 4, 4, 4, 
  495. 4, 4, 4, 4, 4, 4, 4, 4, 
  496. 4, 4, 4, 4, 4, 4, 4, 4, 
  497. 4, 4, 4, 4, 4, 4, 4, 4  
  498. }
  499. #define OV518_YQUANTABLE { 
  500. 5, 4, 5, 6, 6, 7, 7, 7, 
  501. 5, 5, 5, 5, 6, 7, 7, 7, 
  502. 6, 6, 6, 6, 7, 7, 7, 8, 
  503. 7, 7, 6, 7, 7, 7, 8, 8  
  504. }
  505. #define OV518_UVQUANTABLE { 
  506. 6, 6, 6, 7, 7, 7, 7, 7, 
  507. 6, 6, 6, 7, 7, 7, 7, 7, 
  508. 6, 6, 6, 7, 7, 7, 7, 8, 
  509. 7, 7, 7, 7, 7, 7, 8, 8  
  510. }
  511. #endif