pwc-if.c
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:60k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /* Linux driver for Philips webcam 
  2.    USB and Video4Linux interface part.
  3.    (C) 1999-2001 Nemosoft Unv.
  4.    This program is free software; you can redistribute it and/or modify
  5.    it under the terms of the GNU General Public License as published by
  6.    the Free Software Foundation; either version 2 of the License, or
  7.    (at your option) any later version.
  8.    This program is distributed in the hope that it will be useful,
  9.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  11.    GNU General Public License for more details.
  12.    You should have received a copy of the GNU General Public License
  13.    along with this program; if not, write to the Free Software
  14.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  15. */
  16. /*  
  17.    This code forms the interface between the USB layers and the Philips
  18.    specific stuff. Some adanved stuff of the driver falls under an
  19.    NDA, signed between me and Philips B.V., Eindhoven, the Netherlands, and
  20.    is thus not distributed in source form. The binary pwcx.o module 
  21.    contains the code that falls under the NDA.
  22.    
  23.    In case you're wondering: 'pwc' stands for "Philips WebCam", but 
  24.    I really didn't want to type 'philips_web_cam' every time (I'm lazy as
  25.    any Linux kernel hacker, but I don't like uncomprehensible abbreviations
  26.    without explanation).
  27.    
  28.    Oh yes, convention: to disctinguish between all the various pointers to
  29.    device-structures, I use these names for the pointer variables:
  30.    udev: struct usb_device *
  31.    vdev: struct video_device *
  32.    pdev: struct pwc_devive *
  33. */
  34. /* Contributors:
  35.    - Alvarado: adding whitebalance code
  36.    - Alistar Moire: QuickCam 3000 Pro device/product ID
  37.    - Tony Hoyle: Creative Labs Webcam 5 device/product ID
  38.    - Mark Burazin: solving hang in VIDIOCSYNC when camera gets unplugged
  39.    - Jk Fang: SOTEC device/product ID
  40. */
  41. #include <linux/errno.h>
  42. #include <linux/init.h>
  43. #include <linux/module.h>
  44. #include <linux/poll.h>
  45. #include <linux/slab.h>
  46. #include <linux/vmalloc.h>
  47. #include <linux/wrapper.h>
  48. #include <asm/io.h>
  49. #include "pwc.h"
  50. #include "pwc-ioctl.h"
  51. #include "pwc-uncompress.h"
  52. #if !defined(MAP_NR)
  53. #define MAP_NR(a) virt_to_page(a)
  54. #endif
  55. /* Function prototypes and driver templates */
  56. /* hotplug device table support */
  57. static __devinitdata struct usb_device_id pwc_device_table [] = {
  58. { USB_DEVICE(0x0471, 0x0302) },
  59. { USB_DEVICE(0x0471, 0x0303) },
  60. { USB_DEVICE(0x0471, 0x0304) },
  61. { USB_DEVICE(0x0471, 0x0307) },
  62. { USB_DEVICE(0x0471, 0x0308) },
  63. { USB_DEVICE(0x0471, 0x030C) },
  64. { USB_DEVICE(0x0471, 0x0310) },
  65. { USB_DEVICE(0x0471, 0x0311) },
  66. { USB_DEVICE(0x0471, 0x0312) },
  67. { USB_DEVICE(0x069A, 0x0001) },
  68. { USB_DEVICE(0x046D, 0x08b0) },
  69. { USB_DEVICE(0x055D, 0x9000) },
  70. { USB_DEVICE(0x055D, 0x9001) },
  71. { USB_DEVICE(0x041E, 0x400C) },
  72. { USB_DEVICE(0x04CC, 0x8116) },
  73. { }
  74. };
  75. MODULE_DEVICE_TABLE(usb, pwc_device_table);
  76. static void *usb_pwc_probe(struct usb_device *udev, unsigned int ifnum, const struct usb_device_id *id);
  77. static void usb_pwc_disconnect(struct usb_device *udev, void *ptr);
  78. static struct usb_driver pwc_driver =
  79. {
  80. name: "Philips webcam", /* name */
  81. id_table: pwc_device_table,
  82. probe: usb_pwc_probe, /* probe() */
  83. disconnect: usb_pwc_disconnect, /* disconnect() */
  84. };
  85. #define MAX_DEV_HINTS 10
  86. static int default_size = PSZ_QCIF;
  87. static int default_fps = 10;
  88. static int default_palette = VIDEO_PALETTE_YUV420P; /* This format is understood by most tools */
  89. static int default_fbufs = 3;   /* Default number of frame buffers */
  90. static int default_mbufs = 2; /* Default number of mmap() buffers */
  91.        int pwc_trace = TRACE_MODULE | TRACE_FLOW | TRACE_PWCX;
  92. static int power_save = 0;
  93. static int led_on = 1, led_off = 0; /* defaults to LED that is on while in use */
  94.        int pwc_preferred_compression = 2; /* 0..3 = uncompressed..high */
  95. static struct {
  96. int type;
  97. char serial_number[30];
  98. int device_node;
  99. struct pwc_device *pdev;
  100. } device_hint[MAX_DEV_HINTS];
  101. static struct semaphore mem_lock;
  102. static void *mem_leak = NULL; /* For delayed kfree()s. See below */
  103. /***/
  104. static int  pwc_video_open(struct video_device *vdev, int mode);
  105. static void pwc_video_close(struct video_device *vdev);
  106. static long pwc_video_read(struct video_device *vdev, char *buf, unsigned long count, int noblock);
  107. static long pwc_video_write(struct video_device *vdev, const char *buf, unsigned long count, int noblock);
  108. static unsigned int pwc_video_poll(struct video_device *vdev, struct file *file, poll_table *wait);
  109. static int  pwc_video_ioctl(struct video_device *vdev, unsigned int cmd, void *arg);
  110. static int  pwc_video_mmap(struct video_device *dev, const char *adr, unsigned long size);
  111. static struct video_device pwc_template = {
  112. owner: THIS_MODULE,
  113. name: "Philips Webcam", /* Filled in later */
  114. type: VID_TYPE_CAPTURE,
  115. hardware: VID_HARDWARE_PWC,
  116. open: pwc_video_open,
  117. close: pwc_video_close,
  118. read: pwc_video_read,
  119. write: pwc_video_write,
  120. poll: pwc_video_poll,
  121. ioctl: pwc_video_ioctl,
  122. mmap: pwc_video_mmap,
  123. initialize: NULL, /* initialize */
  124. minor: 0 /* minor */
  125. };
  126. /***************************************************************************/
  127. /* Okay, this is some magic that I worked out and the reasoning behind it...
  128.    The biggest problem with any USB device is of course: "what to do 
  129.    when the user unplugs the device while it is in use by an application?"
  130.    We have several options:
  131.    1) Curse them with the 7 plagues when they do (requires divine intervention)
  132.    2) Tell them not to (won't work: they'll do it anyway)
  133.    3) Oops the kernel (this will have a negative effect on a user's uptime)
  134.    4) Do something sensible.
  135.    
  136.    Of course, we go for option 4.
  137.    It happens that this device will be linked to two times, once from
  138.    usb_device and once from the video_device in their respective 'private'
  139.    pointers. This is done when the device is probed() and all initialization
  140.    succeeded. The pwc_device struct links back to both structures.
  141.    When a device is unplugged while in use it will be removed from the 
  142.    list of known USB devices; I also de-register as a V4L device, but 
  143.    unfortunately I can't free the memory since the struct is still in use
  144.    by the file descriptor. This free-ing is then deferend until the first
  145.    opportunity. Crude, but it works.
  146.    
  147.    A small 'advantage' is that if a user unplugs the cam and plugs it back
  148.    in, it should get assigned the same video device minor, but unfortunately
  149.    it's non-trivial to re-link the cam back to the video device... (that 
  150.    would surely be magic! :))
  151. */
  152. /***************************************************************************/
  153. /* Private functions */
  154. /* Memory management functions, nicked from cpia.c, which nicked them from
  155.    bttv.c. So far, I've counted duplication of this code 6 times 
  156.    (bttv, cpia, ibmcam, ov511, pwc, ieee1394).
  157.  */
  158. /* Given PGD from the address space's page table, return the kernel
  159.  * virtual mapping of the physical memory mapped at ADR.
  160.  */
  161. static inline unsigned long uvirt_to_kva(pgd_t *pgd, unsigned long adr)
  162. {
  163.         unsigned long ret = 0UL;
  164. pmd_t *pmd;
  165. pte_t *ptep, pte;
  166.   
  167. if (!pgd_none(*pgd)) {
  168.                 pmd = pmd_offset(pgd, adr);
  169.                 if (!pmd_none(*pmd)) {
  170.                         ptep = pte_offset(pmd, adr);
  171.                         pte = *ptep;
  172.                         if(pte_present(pte)) {
  173. ret  = (unsigned long) page_address(pte_page(pte));
  174. ret |= (adr & (PAGE_SIZE - 1));
  175. }
  176.                 }
  177.         }
  178. return ret;
  179. }
  180. /* Here we want the physical address of the memory.
  181.  * This is used when initializing the contents of the
  182.  * area and marking the pages as reserved.
  183.  */
  184. static inline unsigned long kvirt_to_pa(unsigned long adr) 
  185. {
  186.         unsigned long va, kva, ret;
  187.         va = VMALLOC_VMADDR(adr);
  188.         kva = uvirt_to_kva(pgd_offset_k(va), va);
  189. ret = __pa(kva);
  190.         return ret;
  191. }
  192. static void * rvmalloc(signed long size)
  193. {
  194. void * mem;
  195. unsigned long adr, page;
  196.         /* Round it off to PAGE_SIZE */
  197.         size += (PAGE_SIZE - 1);
  198.         size &= ~(PAGE_SIZE - 1);
  199.         
  200.         mem=vmalloc_32(size);
  201. if (mem) 
  202. {
  203. memset(mem, 0, size); /* Clear the ram out, no junk to the user */
  204.         adr=(unsigned long) mem;
  205. while (size > 0) 
  206.                 {
  207.                 page = kvirt_to_pa(adr);
  208. mem_map_reserve(virt_to_page(__va(page)));
  209. adr+=PAGE_SIZE;
  210. size-=PAGE_SIZE;
  211. }
  212. }
  213. return mem;
  214. }
  215. static void rvfree(void * mem, signed long size)
  216. {
  217.         unsigned long adr, page;
  218.         
  219.         /* Round it off to PAGE_SIZE */
  220.         size += (PAGE_SIZE - 1);
  221.         size &= ~(PAGE_SIZE - 1);
  222. if (mem) 
  223. {
  224.         adr=(unsigned long) mem;
  225. while (size > 0) 
  226.                 {
  227.                 page = kvirt_to_pa(adr);
  228. mem_map_unreserve(virt_to_page(__va(page)));
  229. adr+=PAGE_SIZE;
  230. size-=PAGE_SIZE;
  231. }
  232. vfree(mem);
  233. }
  234. }
  235. static int pwc_allocate_buffers(struct pwc_device *pdev)
  236. {
  237. int i;
  238. void *kbuf;
  239. Trace(TRACE_MEMORY, "Entering allocate_buffers(%p).n", pdev);
  240. if (pdev == NULL)
  241. return -ENXIO;
  242. #ifdef PWC_MAGIC
  243. if (pdev->magic != PWC_MAGIC) {
  244. Err("allocate_buffers(): magic failed.n");
  245. return -ENXIO;
  246. }
  247. #endif
  248. /* Allocate Isochronuous pipe buffers */
  249. for (i = 0; i < MAX_ISO_BUFS; i++) {
  250. if (pdev->sbuf[i].data == NULL) {
  251. kbuf = kmalloc(ISO_BUFFER_SIZE, GFP_KERNEL);
  252. if (kbuf == NULL) {
  253. Err("Failed to allocate iso buffer %d.n", i);
  254. return -ENOMEM;
  255. }
  256. Trace(TRACE_MEMORY, "Allocated iso buffer at %p.n", kbuf);
  257. pdev->sbuf[i].data = kbuf;
  258. memset(kbuf, 0, ISO_BUFFER_SIZE);
  259. }
  260. }
  261. /* Allocate frame buffer structure */
  262. if (pdev->fbuf == NULL) {
  263. kbuf = kmalloc(default_fbufs * sizeof(struct pwc_frame_buf), GFP_KERNEL);
  264. if (kbuf == NULL) {
  265. Err("Failed to allocate frame buffer structure.n");
  266. return -ENOMEM;
  267. }
  268. Trace(TRACE_MEMORY, "Allocated frame buffer structure at %p.n", kbuf);
  269. pdev->fbuf = kbuf;
  270. memset(kbuf, 0, default_fbufs * sizeof(struct pwc_frame_buf));
  271. }
  272. /* create frame buffers, and make circular ring */
  273. for (i = 0; i < default_fbufs; i++) {
  274. if (pdev->fbuf[i].data == NULL) {
  275. kbuf = vmalloc(PWC_FRAME_SIZE); /* need vmalloc since frame buffer > 128K */
  276. if (kbuf == NULL) {
  277. Err("Failed to allocate frame buffer %d.n", i);
  278. return -ENOMEM;
  279. }
  280. Trace(TRACE_MEMORY, "Allocated frame buffer %d at %p.n", i, kbuf);
  281. pdev->fbuf[i].data = kbuf;
  282. memset(kbuf, 128, PWC_FRAME_SIZE);
  283. }
  284. }
  285. /* Allocate decompressor table space */
  286. kbuf = NULL;
  287. if (pdev->decompressor != NULL) {
  288. kbuf = kmalloc(pdev->decompressor->table_size, GFP_KERNEL);
  289. if (kbuf == NULL) {
  290. Err("Failed to allocate decompress table.n");
  291. return -ENOMEM;
  292. }
  293. Trace(TRACE_MEMORY, "Allocated decompress table %p.n", kbuf);
  294. }
  295. pdev->decompress_data = kbuf;
  296. /* Allocate image buffer; double buffer for mmap() */
  297. kbuf = rvmalloc(default_mbufs * pdev->len_per_image);
  298. if (kbuf == NULL) {
  299. Err("Failed to allocate image buffer(s).n");
  300. return -ENOMEM;
  301. }
  302. Trace(TRACE_MEMORY, "Allocated image buffer at %p.n", kbuf);
  303. pdev->image_data = kbuf;
  304. for (i = 0; i < default_mbufs; i++)
  305. pdev->image_ptr[i] = kbuf + i * pdev->len_per_image;
  306. for (; i < MAX_IMAGES; i++)
  307. pdev->image_ptr[i] = NULL;
  308. Trace(TRACE_MEMORY, "Leaving pwc_allocate_buffers().n");
  309. return 0;
  310. }
  311. static void pwc_free_buffers(struct pwc_device *pdev)
  312. {
  313. int i;
  314. Trace(TRACE_MEMORY, "Entering free_buffers(%p).n", pdev);
  315. if (pdev == NULL)
  316. return;
  317. #ifdef PWC_MAGIC
  318. if (pdev->magic != PWC_MAGIC) {
  319. Err("free_buffers(): magic failed.n");
  320. return;
  321. }
  322. #endif
  323. /* Release Iso-pipe buffers */
  324. for (i = 0; i < MAX_ISO_BUFS; i++)
  325. if (pdev->sbuf[i].data != NULL) {
  326. Trace(TRACE_MEMORY, "Freeing ISO buffer at %p.n", pdev->sbuf[i].data);
  327. kfree(pdev->sbuf[i].data);
  328. pdev->sbuf[i].data = NULL;
  329. }
  330. /* The same for frame buffers */
  331. if (pdev->fbuf != NULL) {
  332. for (i = 0; i < default_fbufs; i++) {
  333. if (pdev->fbuf[i].data != NULL) {
  334. Trace(TRACE_MEMORY, "Freeing frame buffer %d at %p.n", i, pdev->fbuf[i].data);
  335. vfree(pdev->fbuf[i].data);
  336. pdev->fbuf[i].data = NULL;
  337. }
  338. }
  339. kfree(pdev->fbuf);
  340. pdev->fbuf = NULL;
  341. }
  342. /* Intermediate decompression buffer & tables */
  343. if (pdev->decompress_data != NULL) {
  344. Trace(TRACE_MEMORY, "Freeing decompression buffer at %p.n", pdev->decompress_data);
  345. kfree(pdev->decompress_data);
  346. pdev->decompress_data = NULL;
  347. }
  348. pdev->decompressor = NULL;
  349. /* Release image buffers */
  350. if (pdev->image_data != NULL) {
  351. Trace(TRACE_MEMORY, "Freeing image buffer at %p.n", pdev->image_data);
  352. rvfree(pdev->image_data, default_mbufs * pdev->len_per_image);
  353. }
  354. pdev->image_data = NULL;
  355. Trace(TRACE_MEMORY, "Leaving free_buffers().n");
  356. }
  357. /* The frame & image buffer mess. 
  358.    Yes, this is a mess. Well, it used to be simple, but alas...  In this
  359.    module, 3 buffers schemes are used to get the data from the USB bus to
  360.    the user program. The first scheme involves the ISO buffers (called thus
  361.    since they transport ISO data from the USB controller), and not really
  362.    interesting. Suffices to say the data from this buffer is quickly 
  363.    gathered in an interrupt handler (pwc_isoc_handler) and placed into the 
  364.    frame buffer.
  365.    
  366.    The frame buffer is the second scheme, and is the central element here.
  367.    It collects the data from a single frame from the camera (hence, the
  368.    name). Frames are delimited by the USB camera with a short USB packet,
  369.    so that's easy to detect. The frame buffers form a list that is filled
  370.    by the camera+USB controller and drained by the user process through 
  371.    either read() or mmap().
  372.    
  373.    The image buffer is the third scheme, in which frames are decompressed
  374.    and possibly converted into planar format. For mmap() there is more than
  375.    one image buffer available.
  376.    The frame buffers provide the image buffering, in case the user process
  377.    is a bit slow. This introduces lag and some undesired side-effects.
  378.    The problem arises when the frame buffer is full. I used to drop the last 
  379.    frame, which makes the data in the queue stale very quickly. But dropping 
  380.    the frame at the head of the queue proved to be a litte bit more difficult.
  381.    I tried a circular linked scheme, but this introduced more problems than
  382.    it solved.
  383.    Because filling and draining are completely asynchronous processes, this
  384.    requires some fiddling with pointers and mutexes.
  385.    
  386.    Eventually, I came up with a system with 2 lists: an 'empty' frame list
  387.    and a 'full' frame list:
  388.      * Initially, all frame buffers but one are on the 'empty' list; the one
  389.        remaining buffer is our initial fill frame.
  390.      * If a frame is needed for filling, we take it from the 'empty' list, 
  391.        unless that list is empty, in which case we take the buffer at the 
  392.        head of the 'full' list.
  393.      * When our fill buffer has been filled, it is appended to the 'full' 
  394.        list.
  395.      * If a frame is needed by read() or mmap(), it is taken from the head of 
  396.        the 'full' list, handled, and then appended to the 'empty' list. If no
  397.        buffer is present on the 'full' list, we wait.
  398.    The advantage is that the buffer that is currently being decompressed/
  399.    converted, is on neither list, and thus not in our way (any other scheme 
  400.    I tried had the problem of old data lingering in the queue).
  401.    Whatever strategy you choose, it always remains a tradeoff: with more
  402.    frame buffers the chances of a missed frame are reduced. On the other
  403.    hand, on slower machines it introduces lag because the queue will 
  404.    always be full.
  405.  */
  406. /**
  407.   brief Find next frame buffer to fill. Take from empty or full list, whichever comes first.
  408.  */
  409. static inline int pwc_next_fill_frame(struct pwc_device *pdev)
  410. {
  411. int ret;
  412. unsigned long flags;
  413. ret = 0;
  414. spin_lock_irqsave(&pdev->ptrlock, flags);
  415. if (pdev->fill_frame != NULL) {
  416. /* append to 'full' list */
  417. if (pdev->full_frames == NULL) {
  418. pdev->full_frames = pdev->fill_frame;
  419. pdev->full_frames_tail = pdev->full_frames;
  420. }
  421. else {
  422. pdev->full_frames_tail->next = pdev->fill_frame;
  423. pdev->full_frames_tail = pdev->fill_frame;
  424. }
  425. }
  426. if (pdev->empty_frames != NULL) {
  427. /* We have empty frames available. That's easy */
  428. pdev->fill_frame = pdev->empty_frames;
  429. pdev->empty_frames = pdev->empty_frames->next;
  430. }
  431. else {
  432. /* Hmm. Take it from the full list */
  433. #if PWC_DEBUG
  434. /* sanity check */
  435. if (pdev->full_frames == NULL) {
  436. Err("Neither empty or full frames available!n");
  437. spin_unlock_irqrestore(&pdev->ptrlock, flags);
  438. return -EINVAL;
  439. }
  440. #endif
  441. pdev->fill_frame = pdev->full_frames;
  442. pdev->full_frames = pdev->full_frames->next;
  443. ret = 1;
  444. }
  445. pdev->fill_frame->next = NULL;
  446. #if PWC_DEBUG
  447. Trace(TRACE_SEQUENCE, "Assigning sequence number %d.n", pdev->sequence);
  448. pdev->fill_frame->sequence = pdev->sequence++;
  449. #endif
  450. spin_unlock_irqrestore(&pdev->ptrlock, flags);
  451. return ret;
  452. }
  453.  
  454. /**
  455.   brief Reset all buffers, pointers and lists, except for the image_used[] buffer. 
  456.   
  457.   If the image_used[] buffer is cleared too, mmap()/VIDIOCSYNC will run into trouble.
  458.  */
  459. static void pwc_reset_buffers(struct pwc_device *pdev)
  460. {
  461. int i;
  462. unsigned long flags;
  463. spin_lock_irqsave(&pdev->ptrlock, flags);
  464. pdev->full_frames = NULL;
  465. pdev->full_frames_tail = NULL;
  466. for (i = 0; i < default_fbufs; i++) {
  467. pdev->fbuf[i].filled = 0;
  468. if (i > 0)
  469. pdev->fbuf[i].next = &pdev->fbuf[i - 1];
  470. else
  471. pdev->fbuf->next = NULL;
  472. }
  473. pdev->empty_frames = &pdev->fbuf[default_fbufs - 1];
  474. pdev->empty_frames_tail = pdev->fbuf;
  475. pdev->read_frame = NULL;
  476. pdev->fill_frame = pdev->empty_frames;
  477. pdev->empty_frames = pdev->empty_frames->next;
  478. pdev->image_read_pos = 0;
  479. pdev->fill_image = 0;
  480. spin_unlock_irqrestore(&pdev->ptrlock, flags);
  481. }
  482. /**
  483.   brief Do all the handling for getting one frame: get pointer, decompress, advance pointers.
  484.  */
  485. static int pwc_handle_frame(struct pwc_device *pdev)
  486. {
  487. int ret = 0;
  488. unsigned long flags;
  489. spin_lock_irqsave(&pdev->ptrlock, flags);
  490. /* First grab our read_frame; this is removed from all lists, so
  491.    we can release the lock after this without problems */
  492. if (pdev->read_frame != NULL) {
  493. /* This can't theoretically happen */
  494. Err("Huh? Read frame still in use?n");
  495. }
  496. else {
  497. if (pdev->full_frames == NULL) {
  498. Err("Woops. No frames ready.n");
  499. }
  500. else {
  501. pdev->read_frame = pdev->full_frames;
  502. pdev->full_frames = pdev->full_frames->next;
  503. pdev->read_frame->next = NULL;
  504. }
  505. if (pdev->read_frame != NULL) {
  506. #if PWC_DEBUG
  507. Trace(TRACE_SEQUENCE, "Decompressing frame %dn", pdev->read_frame->sequence);
  508. #endif
  509. /* Decompression is a lenghty process, so it's outside of the lock.
  510.    This gives the isoc_handler the opportunity to fill more frames 
  511.    in the mean time.
  512. */
  513. spin_unlock_irqrestore(&pdev->ptrlock, flags);
  514. ret = pwc_decompress(pdev);
  515. spin_lock_irqsave(&pdev->ptrlock, flags);
  516. /* We're done with read_buffer, tack it to the end of the empty buffer list */
  517. if (pdev->empty_frames == NULL) {
  518. pdev->empty_frames = pdev->read_frame;
  519. pdev->empty_frames_tail = pdev->empty_frames;
  520. }
  521. else {
  522. pdev->empty_frames_tail->next = pdev->read_frame;
  523. pdev->empty_frames_tail = pdev->read_frame;
  524. }
  525. pdev->read_frame = NULL;
  526. }
  527. }
  528. spin_unlock_irqrestore(&pdev->ptrlock, flags);
  529. return ret;
  530. }
  531. /**
  532.   brief Advance pointers of image buffer (after each user request) 
  533. */
  534. static inline void pwc_next_image(struct pwc_device *pdev)
  535. {
  536. pdev->image_used[pdev->fill_image] = 0;
  537. pdev->fill_image = (pdev->fill_image + 1) % default_mbufs;
  538. }
  539. /* 2001-10-14: The YUV420 is still there, but you can only set it from within 
  540.    a program (YUV420P being the default) */
  541. static int pwc_set_palette(struct pwc_device *pdev, int pal)
  542. {
  543. if (   pal == VIDEO_PALETTE_YUV420
  544.             || pal == VIDEO_PALETTE_YUV420P
  545. #if PWC_DEBUG
  546.             || pal == VIDEO_PALETTE_RAW
  547. #endif
  548. ) {
  549. pdev->vpalette = pal;
  550. pwc_set_image_buffer_size(pdev);
  551. return 0;
  552. }
  553. Trace(TRACE_READ, "Palette %d not supported.n", pal);
  554. return -1;
  555. }
  556. /* This gets called for the Isochronous pipe (video). This is done in
  557.  * interrupt time, so it has to be fast, not crash, and not stall. Neat.
  558.  */
  559. static void pwc_isoc_handler(purb_t urb)
  560. {
  561. struct pwc_device *pdev;
  562. int i, fst, flen;
  563. int awake;
  564. struct pwc_frame_buf *fbuf;
  565. unsigned char *fillptr, *iso_buf;
  566. pdev = (struct pwc_device *)urb->context;
  567. if (pdev == NULL) {
  568. Err("isoc_handler() called with NULL device?!n");
  569. return;
  570. }
  571. #ifdef PWC_MAGIC
  572. if (pdev->magic != PWC_MAGIC) {
  573. Err("isoc_handler() called with bad magic!n");
  574. return;
  575. }
  576. #endif
  577. if (urb->status == -ENOENT || urb->status == -ECONNRESET) {
  578. Trace(TRACE_OPEN, "pwc_isoc_handler(): URB unlinked.n");
  579. return;
  580. }
  581. if (urb->status != -EINPROGRESS && urb->status != 0) {
  582. char *errmsg;
  583. errmsg = "Unknown";
  584. switch(urb->status) {
  585. case -ENOSR: errmsg = "Buffer error (overrun)"; break;
  586. case -EPIPE: errmsg = "Stalled (device not responding)"; break;
  587. case -EOVERFLOW: errmsg = "Babble (bad cable?)"; break;
  588. case -EPROTO: errmsg = "Bit-stuff error (bad cable?)"; break;
  589. case -EILSEQ: errmsg = "CRC/Timeout"; break;
  590. case -ETIMEDOUT: errmsg = "NAK (device does not respond)"; break;
  591. }
  592. Trace(TRACE_FLOW, "pwc_isoc_handler() called with status %d [%s].n", urb->status, errmsg);
  593. return;
  594. }
  595. fbuf = pdev->fill_frame;
  596. if (fbuf == NULL) {
  597. Err("pwc_isoc_handler without valid fill frame.n");
  598. wake_up_interruptible(&pdev->frameq);
  599. return;
  600. }
  601. fillptr = fbuf->data + fbuf->filled;
  602. awake = 0;
  603. /* vsync: 0 = don't copy data
  604.           1 = sync-hunt
  605.           2 = synched 
  606.  */
  607. /* Compact data */
  608. for (i = 0; i < urb->number_of_packets; i++) {
  609. fst  = urb->iso_frame_desc[i].status;
  610. flen = urb->iso_frame_desc[i].actual_length;
  611. iso_buf = urb->transfer_buffer + urb->iso_frame_desc[i].offset;
  612. if (fst == 0) {
  613. if (flen > 0) { /* if valid data... */
  614. if (pdev->vsync > 0) { /* ...and we are not sync-hunting... */
  615. pdev->vsync = 2;
  616. /* ...copy data to frame buffer, if possible */
  617. if (flen + fbuf->filled > pdev->frame_size) {
  618. Trace(TRACE_FLOW, "Frame buffer overflow (flen = %d, frame_size = %d).n", flen, pdev->frame_size);
  619. pdev->vsync = 0; /* Hmm, let's wait for an EOF (end-of-frame) */
  620. pdev->vframes_error++;
  621. }
  622. else {
  623. memmove(fillptr, iso_buf, flen);
  624. fillptr += flen;
  625. }
  626. }
  627. fbuf->filled += flen;
  628. } /* ..flen > 0 */
  629. if (flen < pdev->vlast_packet_size) {
  630. /* Shorter packet... We probably have the end of an image-frame; 
  631.    wake up read() process and let select()/poll() do something.
  632.    Decompression is done in user time over there. 
  633.  */
  634. if (pdev->vsync == 2) {
  635. /* The ToUCam Fun CMOS sensor causes the firmware to send 2 or 3 bogus 
  636.    frames on the USB wire after an exposure change. This conditition is 
  637.    however detected  in the cam and a bit is set in the header.
  638.  */
  639. if (pdev->type == 730) {
  640. unsigned char *ptr = (unsigned char *)fbuf->data;
  641. if (ptr[1] == 1 && ptr[0] & 0x10) {
  642. #if PWC_DEBUG
  643. Debug("Hyundai CMOS sensor bug. Dropping frame %d.n", fbuf->sequence);
  644. #endif
  645. pdev->drop_frames = 2;
  646. pdev->vframes_error++;
  647. }
  648. /* Sometimes the trailer of the 730 is still sent as a 4 byte packet 
  649.    after a short frame; this condition is filtered out specifically. A 4 byte
  650.    frame doesn't make sense anyway.
  651.    So we get either this sequence: 
  652.     drop_bit set -> 4 byte frame -> short frame -> good frame
  653.    Or this one:
  654.     drop_bit set -> short frame -> good frame
  655.    So we drop either 3 or 2 frames in all!
  656.  */
  657. if (fbuf->filled == 4)
  658. pdev->drop_frames++;
  659. }
  660. /* In case we were instructed to drop the frame, do so silently.
  661.    The buffer pointers are not updated either (but the counters are reset below).
  662.  */
  663. if (pdev->drop_frames)
  664. pdev->drop_frames--;
  665. else {
  666. /* Check for underflow first */
  667. if (fbuf->filled < pdev->frame_size) {
  668. Trace(TRACE_FLOW, "Frame buffer underflow (%d bytes); discarded.n", fbuf->filled);
  669. pdev->vframes_error++;
  670. }
  671. else {
  672. /* Send only once per EOF */
  673. awake = 1; /* delay wake_ups */
  674. /* Find our next frame to fill. This will always succeed, since we
  675.  * nick a frame from either empty or full list, but if we had to
  676.  * take it from the full list, it means a frame got dropped.
  677.  */
  678. if (pwc_next_fill_frame(pdev)) {
  679. pdev->vframes_dumped++;
  680. if ((pdev->vframe_count > FRAME_LOWMARK) && (pwc_trace & TRACE_FLOW)) {
  681. if (pdev->vframes_dumped < 20)
  682. Trace(TRACE_FLOW, "Dumping frame %d.n", pdev->vframe_count);
  683. if (pdev->vframes_dumped == 20)
  684. Trace(TRACE_FLOW, "Dumping frame %d (last message).n", pdev->vframe_count);
  685. }
  686. }
  687. fbuf = pdev->fill_frame;
  688. }
  689. } /* !drop_frames */
  690. pdev->vframe_count++;
  691. }
  692. fbuf->filled = 0;
  693. fillptr = fbuf->data;
  694. pdev->vsync = 1;
  695. } /* .. flen < last_packet_size */
  696. pdev->vlast_packet_size = flen;
  697. } /* ..status == 0 */
  698. #ifdef PWC_DEBUG
  699. /* This is normally not interesting to the user, unless you are really debugging something */
  700. else 
  701. Trace(TRACE_FLOW, "Iso frame %d of USB has error %dn", i, fst);
  702. #endif
  703. }
  704. if (awake)
  705. wake_up_interruptible(&pdev->frameq);
  706. }
  707. static int pwc_isoc_init(struct pwc_device *pdev)
  708. {
  709. struct usb_device *udev;
  710. purb_t urb;
  711. int i, j, ret;
  712. struct usb_interface_descriptor *idesc;
  713. int cur_alt;
  714. if (pdev == NULL)
  715. return -EFAULT;
  716. if (pdev->iso_init)
  717. return 0;
  718. pdev->vsync = 0;
  719. udev = pdev->udev;
  720. /* Get the current alternate interface, adjust packet size */
  721. if (!udev->actconfig)
  722. return -EFAULT;
  723. cur_alt = udev->actconfig->interface[0].act_altsetting;
  724. idesc = &udev->actconfig->interface[0].altsetting[cur_alt];
  725. if (!idesc)
  726. return -EFAULT;
  727. /* Search video endpoint */
  728. pdev->vmax_packet_size = -1;
  729. for (i = 0; i < idesc->bNumEndpoints; i++)
  730. if ((idesc->endpoint[i].bEndpointAddress & 0xF) == pdev->vendpoint) {
  731. pdev->vmax_packet_size = idesc->endpoint[i].wMaxPacketSize;
  732. break;
  733. }
  734. if (pdev->vmax_packet_size < 0) {
  735. Err("Failed to find packet size for video endpoint in current alternate setting.n");
  736. return -ENFILE; /* Odd error, that should be noticable */
  737. }
  738. ret = 0;
  739. for (i = 0; i < MAX_ISO_BUFS; i++) {
  740. urb = usb_alloc_urb(ISO_FRAMES_PER_DESC);
  741. if (urb == NULL) {
  742. Err("Failed to allocate urb %dn", i);
  743. ret = -ENOMEM;
  744. break;
  745. }
  746. pdev->sbuf[i].urb = urb;
  747. }
  748. if (ret) {
  749. /* De-allocate in reverse order */
  750. while (i >= 0) {
  751. if (pdev->sbuf[i].urb != NULL)
  752. usb_free_urb(pdev->sbuf[i].urb);
  753. pdev->sbuf[i].urb = NULL;
  754. i--;
  755. }
  756. return ret;
  757. }
  758. /* init URB structure */
  759. for (i = 0; i < MAX_ISO_BUFS; i++) {
  760. urb = pdev->sbuf[i].urb;
  761. urb->next = pdev->sbuf[(i + 1) % MAX_ISO_BUFS].urb;
  762. urb->dev = udev;
  763.         urb->pipe = usb_rcvisocpipe(udev, pdev->vendpoint);
  764. urb->transfer_flags = USB_ISO_ASAP;
  765.         urb->transfer_buffer = pdev->sbuf[i].data;
  766.         urb->transfer_buffer_length = ISO_BUFFER_SIZE;
  767.         urb->complete = pwc_isoc_handler;
  768.         urb->context = pdev;
  769. urb->start_frame = 0;
  770. urb->number_of_packets = ISO_FRAMES_PER_DESC;
  771. for (j = 0; j < ISO_FRAMES_PER_DESC; j++) {
  772. urb->iso_frame_desc[j].offset = j * ISO_MAX_FRAME_SIZE;
  773. urb->iso_frame_desc[j].length = ISO_MAX_FRAME_SIZE;
  774. }
  775. }
  776. /* link */
  777. for (i = 0; i < MAX_ISO_BUFS; i++) {
  778. ret = usb_submit_urb(pdev->sbuf[i].urb);
  779. if (ret)
  780. Err("isoc_init() submit_urb %d failed with error %dn", i, ret);
  781. else
  782. Trace(TRACE_OPEN, "pwc_isoc_init(): URB submitted.n");
  783. }
  784. /* data should stream in now */
  785. pdev->iso_init = 1;
  786. return 0;
  787. }
  788. static void pwc_isoc_cleanup(struct pwc_device *pdev)
  789. {
  790. int i;
  791. if (pdev == NULL)
  792. return;
  793. if (!pdev->iso_init)
  794. return;
  795. /* Stop camera, but only if we are sure the camera is still there */
  796. if (!pdev->unplugged)
  797. usb_set_interface(pdev->udev, 0, 0);
  798. /* Unlinking ISOC buffers one by one */
  799. for (i = MAX_ISO_BUFS - 1; i >= 0; i--) {
  800. pdev->sbuf[i].urb->next = NULL;
  801. usb_unlink_urb(pdev->sbuf[i].urb);
  802. usb_free_urb(pdev->sbuf[i].urb);
  803. pdev->sbuf[i].urb = NULL;
  804. }
  805. pdev->iso_init = 0;
  806. }
  807. int pwc_try_video_mode(struct pwc_device *pdev, int width, int height, int new_fps, int new_compression, int new_snapshot)
  808. {
  809. int ret;
  810. /* Stop isoc stuff */
  811. pwc_isoc_cleanup(pdev);
  812. /* Reset parameters */
  813. pwc_reset_buffers(pdev);
  814. /* Try to set video mode... */
  815. ret = pwc_set_video_mode(pdev, width, height, new_fps, new_compression, new_snapshot);
  816. if (ret) /* That failed... restore old mode (we know that worked) */
  817. ret = pwc_set_video_mode(pdev, pdev->view.x, pdev->view.y, pdev->vframes, pdev->vcompression, pdev->vsnapshot);
  818. else /* Set (new) alternate interface */
  819. ret = usb_set_interface(pdev->udev, 0, pdev->valternate);
  820. if (!ret)
  821. ret = pwc_isoc_init(pdev);
  822. pdev->drop_frames = 1; /* try to avoid garbage during switch */
  823. return ret;
  824. }
  825. static inline void set_mem_leak(void *ptr)
  826. {
  827. down(&mem_lock);
  828. if (mem_leak != NULL)
  829. Err("Memleak: overwriting mem_leak pointer!n");
  830. Trace(TRACE_MEMORY, "Setting mem_leak to 0x%p.n", ptr);
  831. mem_leak = ptr;
  832. up(&mem_lock);
  833. }
  834. static inline void free_mem_leak(void)
  835. {
  836. down(&mem_lock);
  837. if (mem_leak != NULL) {
  838. Trace(TRACE_MEMORY, "Freeing mem_leak ptr 0x%p.n", mem_leak);
  839. kfree(mem_leak);
  840. mem_leak = NULL;
  841. }
  842. up(&mem_lock);
  843. }
  844. /***************************************************************************/
  845. /* Video4Linux functions */
  846. static int pwc_video_open(struct video_device *vdev, int mode)
  847. {
  848. int i;
  849. struct pwc_device *pdev;
  850. Trace(TRACE_OPEN, "video_open called(0x%p, 0%o).n", vdev, mode);
  851. if (vdev == NULL)
  852. BUG();
  853. pdev = (struct pwc_device *)vdev->priv;
  854. if (pdev == NULL)
  855. BUG();
  856. down(&pdev->modlock);
  857. if (!pdev->usb_init) {
  858. Trace(TRACE_OPEN, "Doing first time initialization.n");
  859. /* Reset camera */
  860. if (usb_set_interface(pdev->udev, 0, 0))
  861. Info("Failed to set alternate interface to 0.n");
  862. pdev->usb_init = 1;
  863. }
  864. /* Turn on camera */
  865. if (power_save) {
  866. i = pwc_camera_power(pdev, 1);
  867. if (i < 0)
  868. Info("Failed to restore power to the camera! (%d)n", i);
  869. }
  870. /* Set LED on/off time */
  871. if (pwc_set_leds(pdev, led_on, led_off) < 0)
  872. Info("Failed to set LED on/off time.n");
  873. /* Find our decompressor, if any */
  874. pdev->decompressor = pwc_find_decompressor(pdev->type);
  875. #if PWC_DEBUG
  876. Debug("Found decompressor for %d at 0x%pn", pdev->type, pdev->decompressor);
  877. #endif
  878. /* So far, so good. Allocate memory. */
  879. i = pwc_allocate_buffers(pdev);
  880. if (i < 0) {
  881. Trace(TRACE_OPEN, "Failed to allocate buffer memory.n");
  882. up(&pdev->modlock);
  883. return i;
  884. }
  885. /* Reset buffers & parameters */
  886. pwc_reset_buffers(pdev);
  887. for (i = 0; i < default_mbufs; i++)
  888. pdev->image_used[i] = 0;
  889. pdev->vframe_count = 0;
  890. pdev->vframes_dumped = 0;
  891. pdev->vframes_error = 0;
  892. pdev->vpalette = default_palette;
  893. #if PWC_DEBUG
  894. pdev->sequence = 0;
  895. #endif
  896. /* Set some defaults */
  897. pdev->vsnapshot = 0;
  898. if (pdev->type == 730 || pdev->type == 740 || pdev->type == 750)
  899. pdev->vsize = PSZ_QSIF;
  900. else
  901. pdev->vsize = PSZ_QCIF;
  902. pdev->vframes = 10;
  903. /* Start iso pipe for video; first try user-supplied size/fps, if
  904.    that fails try QCIF/10 or QSIF/10 (a reasonable default), 
  905.    then give up 
  906.  */
  907. i = pwc_set_video_mode(pdev, pwc_image_sizes[default_size].x, pwc_image_sizes[default_size].y, default_fps, pdev->vcompression, 0);
  908. if (i) {
  909. Trace(TRACE_OPEN, "First attempt at set_video_mode failed.n");
  910. if (pdev->type == 730 || pdev->type == 740 || pdev->type == 750)
  911. i = pwc_set_video_mode(pdev, pwc_image_sizes[PSZ_QSIF].x, pwc_image_sizes[PSZ_QSIF].y, 10, pdev->vcompression, 0);
  912. else
  913. i = pwc_set_video_mode(pdev, pwc_image_sizes[PSZ_QCIF].x, pwc_image_sizes[PSZ_QCIF].y, 10, pdev->vcompression, 0);
  914. }
  915. if (i) {
  916. Trace(TRACE_OPEN, "Second attempt at set_video_mode failed.n");
  917. up(&pdev->modlock);
  918. return i;
  919. }
  920. i = usb_set_interface(pdev->udev, 0, pdev->valternate);
  921. if (i) {
  922. Trace(TRACE_OPEN, "Failed to set alternate interface = %d.n", i);
  923. up(&pdev->modlock);
  924. return -EINVAL;
  925. }
  926. i = pwc_isoc_init(pdev);
  927. if (i) {
  928. Trace(TRACE_OPEN, "Failed to init ISOC stuff = %d.n", i);
  929. MOD_DEC_USE_COUNT;
  930. up(&pdev->modlock);
  931. return i;
  932. }
  933. pdev->vopen++;
  934. /* lock decompressor; this has a small race condition, since we 
  935.    could in theory unload pwcx.o between pwc_find_decompressor()
  936.    above and this call. I doubt it's ever going to be a problem.
  937.  */
  938. if (pdev->decompressor != NULL)
  939. pdev->decompressor->lock();
  940. up(&pdev->modlock);
  941. Trace(TRACE_OPEN, "video_open() returning 0.n");
  942. return 0;
  943. }
  944. /* Note that all cleanup is done in the reverse order as in _open */
  945. static void pwc_video_close(struct video_device *vdev)
  946. {
  947. struct pwc_device *pdev;
  948. int i;
  949. Trace(TRACE_OPEN, "video_close called(0x%p).n", vdev);
  950. pdev = (struct pwc_device *)vdev->priv;
  951. if (pdev->vopen == 0)
  952. Info("video_close() called on closed device?n");
  953. /* Free isoc URBs */
  954. pwc_isoc_cleanup(pdev);
  955. /* Dump statistics, but only if a reasonable amount of frames were
  956.    processed (to prevent endless log-entries in case of snap-shot
  957.    programs) 
  958.  */
  959. if (pdev->vframe_count > 20)
  960. Info("Closing video device: %d frames received, dumped %d frames, %d frames with errors.n", pdev->vframe_count, pdev->vframes_dumped, pdev->vframes_error);
  961. if (pdev->unplugged) {
  962. /* The device was unplugged or some other error occured */
  963. /* We unregister the video_device */
  964. Trace(TRACE_OPEN, "Delayed video device unregistered.n");
  965. video_unregister_device(pdev->vdev);
  966. }
  967. else {
  968. /* Normal close: stop isochronuous and interrupt endpoint */
  969. Trace(TRACE_OPEN, "Normal close(): setting interface to 0.n");
  970. usb_set_interface(pdev->udev, 0, 0);
  971. /* Turn LEDs off */
  972. if (pwc_set_leds(pdev, 0, 0) < 0)
  973. Info("Failed to set LED on/off time..n");
  974. /* Power down camere to save energy */
  975. if (power_save) {
  976. i = pwc_camera_power(pdev, 0);
  977. if (i < 0) 
  978. Err("Failed to power down camera (%d)n", i);
  979. }
  980. }
  981. pdev->vopen = 0;
  982. if (pdev->decompressor != NULL) {
  983. pdev->decompressor->exit();
  984. pdev->decompressor->unlock();
  985. }
  986. pwc_free_buffers(pdev);
  987. /* wake up _disconnect() routine */
  988. if (pdev->unplugged)
  989. wake_up(&pdev->remove_ok);
  990. }
  991. /*
  992.  * FIXME: what about two parallel reads ????
  993.  *      ANSWER: Not supported. You can't open the device more than once,
  994.                 despite what the V4L1 interface says. First, I don't see 
  995.                 the need, second there's no mechanism of alerting the 
  996.                 2nd/3rd/... process of events like changing image size.
  997.                 And I don't see the point of blocking that for the 
  998.                 2nd/3rd/... process.
  999.                 In multi-threaded environments reading parallel from any
  1000.                 device is tricky anyhow.
  1001.  */
  1002.  
  1003. static long pwc_video_read(struct video_device *vdev, char *buf, unsigned long count, int noblock)
  1004. {
  1005. struct pwc_device *pdev;
  1006. DECLARE_WAITQUEUE(wait, current);
  1007. Trace(TRACE_READ, "video_read(0x%p, %p, %ld, %d) called.n", vdev, buf, count, noblock);
  1008. if (vdev == NULL)
  1009. return -EFAULT;
  1010. pdev = vdev->priv;
  1011. if (pdev == NULL)
  1012. return -EFAULT;
  1013. if (pdev->unplugged) {
  1014. Info("pwc_video_read: Device got unplugged (1).n");
  1015. return -EPIPE; /* unplugged device! */
  1016. }
  1017. /* In case we're doing partial reads, we don't have to wait for a frame */
  1018. if (pdev->image_read_pos == 0) {
  1019. /* Do wait queueing according to the (doc)book */
  1020. add_wait_queue(&pdev->frameq, &wait);
  1021. while (pdev->full_frames == NULL) {
  1022.                 if (noblock) {
  1023.                  remove_wait_queue(&pdev->frameq, &wait);
  1024.                  set_current_state(TASK_RUNNING);
  1025.                  return -EWOULDBLOCK;
  1026.                 }
  1027.                 if (signal_pending(current)) {
  1028.                  remove_wait_queue(&pdev->frameq, &wait);
  1029.                  set_current_state(TASK_RUNNING);
  1030.                  return -ERESTARTSYS;
  1031.                 }
  1032.                 schedule();
  1033.                 set_current_state(TASK_INTERRUPTIBLE);
  1034. }
  1035. remove_wait_queue(&pdev->frameq, &wait);
  1036. set_current_state(TASK_RUNNING);
  1037.                                                                                                                                                                                 
  1038. /* Decompress [, convert] and release frame */
  1039. if (pwc_handle_frame(pdev))
  1040. return -EFAULT;
  1041. }
  1042. Trace(TRACE_READ, "Copying data to user space.n");
  1043. /* copy bytes to user space; we allow for partial reads */
  1044. if (count + pdev->image_read_pos > pdev->view.size)
  1045. count = pdev->view.size - pdev->image_read_pos;
  1046. if (copy_to_user(buf, pdev->image_ptr[pdev->fill_image] + pdev->image_read_pos, count))
  1047. return -EFAULT;
  1048. pdev->image_read_pos += count;
  1049. if (pdev->image_read_pos >= pdev->view.size) { /* All data has been read */
  1050. pdev->image_read_pos = 0;
  1051. pwc_next_image(pdev);
  1052. }
  1053. return count;
  1054. }
  1055. static long pwc_video_write(struct video_device *vdev, const char *buf, unsigned long count, int noblock)
  1056. {
  1057. return -EINVAL;   
  1058. }
  1059. static unsigned int pwc_video_poll(struct video_device *vdev, struct file *file, poll_table *wait)
  1060. {
  1061. struct pwc_device *pdev;
  1062. if (vdev == NULL)
  1063. return -EFAULT;
  1064. pdev = vdev->priv;
  1065. if (pdev == NULL)
  1066. return -EFAULT;
  1067. poll_wait(file, &pdev->frameq, wait);
  1068. if (pdev->unplugged) {
  1069. Info("pwc_video_poll: Device got unplugged.n");
  1070. return POLLERR;
  1071. }
  1072. if (pdev->full_frames != NULL) /* we have frames waiting */
  1073. return (POLLIN | POLLRDNORM);
  1074. return 0;
  1075. }
  1076.         
  1077. static int pwc_video_ioctl(struct video_device *vdev, unsigned int cmd, void *arg)
  1078. {
  1079. struct pwc_device *pdev;
  1080. DECLARE_WAITQUEUE(wait, current);
  1081. if (vdev == NULL)
  1082. return -EFAULT;
  1083. pdev = vdev->priv;
  1084. if (pdev == NULL)
  1085. return -EFAULT;
  1086. switch (cmd) {
  1087. /* Query cabapilities */
  1088. case VIDIOCGCAP: 
  1089. {
  1090. struct video_capability caps;
  1091. strcpy(caps.name, vdev->name);
  1092. caps.type = VID_TYPE_CAPTURE;
  1093. caps.channels = 1;
  1094. caps.audios = 1;
  1095. caps.minwidth  = pdev->view_min.x;
  1096. caps.minheight = pdev->view_min.y;
  1097. caps.maxwidth  = pdev->view_max.x;
  1098. caps.maxheight = pdev->view_max.y;
  1099. if (copy_to_user(arg, &caps, sizeof(caps)))
  1100. return -EFAULT;
  1101. break;
  1102. }
  1103. /* Channel functions (simulate 1 channel) */
  1104. case VIDIOCGCHAN:
  1105. {
  1106. struct video_channel v;
  1107. if (copy_from_user(&v, arg, sizeof(v)))
  1108. return -EFAULT;
  1109. if (v.channel != 0)
  1110. return -EINVAL;
  1111. v.flags = 0;
  1112. v.tuners = 0;
  1113. v.type = VIDEO_TYPE_CAMERA;
  1114. strcpy(v.name, "Webcam");
  1115. if (copy_to_user(arg, &v, sizeof(v)))
  1116. return -EFAULT;
  1117. return 0;
  1118. }
  1119. case VIDIOCSCHAN:
  1120. {
  1121. /* The spec says the argument is an integer, but
  1122.    the bttv driver uses a video_channel arg, which
  1123.    makes sense becasue it also has the norm flag.
  1124.  */
  1125. struct video_channel v;
  1126. if (copy_from_user(&v, arg, sizeof(v)))
  1127. return -EFAULT;
  1128. if (v.channel != 0)
  1129. return -EINVAL;
  1130. return 0;
  1131. }
  1132. /* Picture functions; contrast etc. */
  1133. case VIDIOCGPICT:
  1134. {
  1135. struct video_picture p;
  1136. int val;
  1137. p.colour = 0x8000;
  1138. p.hue = 0x8000;
  1139. val = pwc_get_brightness(pdev);
  1140. if (val >= 0)
  1141. p.brightness = val;
  1142. else
  1143. p.brightness = 0xffff;
  1144. val = pwc_get_contrast(pdev);
  1145. if (val >= 0)
  1146. p.contrast = val;
  1147. else
  1148. p.contrast = 0xffff;
  1149. /* Gamma, Whiteness, what's the difference? :) */
  1150. val = pwc_get_gamma(pdev);
  1151. if (val >= 0)
  1152. p.whiteness = val;
  1153. else
  1154. p.whiteness = 0xffff;
  1155. val = pwc_get_saturation(pdev);
  1156. if (val >= 0)
  1157. p.colour = val;
  1158. else
  1159. p.colour = 0xffff;
  1160. p.depth = 24;
  1161. p.palette = pdev->vpalette;
  1162. p.hue = 0xFFFF; /* N/A */
  1163. if (copy_to_user(arg, &p, sizeof(p)))
  1164. return -EFAULT;
  1165. break;
  1166. }
  1167. case VIDIOCSPICT:
  1168. {
  1169. struct video_picture p;
  1170. if (copy_from_user(&p, arg, sizeof(p)))
  1171. return -EFAULT;
  1172. /*
  1173.  * FIXME: Suppose we are mid read
  1174.         ANSWER: No problem: the firmware of the camera
  1175.                 can handle brightness/contrast/etc
  1176.                 changes at _any_ time, and the palette
  1177.                 is used exactly once in the uncompress
  1178.                 routine.
  1179.  */
  1180. pwc_set_brightness(pdev, p.brightness);
  1181. pwc_set_contrast(pdev, p.contrast);
  1182. pwc_set_gamma(pdev, p.whiteness);
  1183. pwc_set_saturation(pdev, p.colour);
  1184. if (p.palette && p.palette != pdev->vpalette) {
  1185. if (pwc_set_palette(pdev, p.palette) < 0)
  1186. return -EINVAL;
  1187. }
  1188. break;
  1189. }
  1190. /* Window/size parameters */
  1191. case VIDIOCGWIN:
  1192. {
  1193. struct video_window vw;
  1194. vw.x = 0;
  1195. vw.y = 0;
  1196. vw.width = pdev->view.x;
  1197. vw.height = pdev->view.y;
  1198. vw.chromakey = 0;
  1199. vw.flags = (pdev->vframes << PWC_FPS_SHIFT) | 
  1200.            (pdev->vsnapshot ? PWC_FPS_SNAPSHOT : 0);
  1201. if (copy_to_user(arg, &vw, sizeof(vw)))
  1202. return -EFAULT;
  1203. break;
  1204. }
  1205. case VIDIOCSWIN:
  1206. {
  1207. struct video_window vw;
  1208. int fps, snapshot, ret;
  1209. if (copy_from_user(&vw, arg, sizeof(vw)))
  1210. return -EFAULT;
  1211. fps = (vw.flags & PWC_FPS_FRMASK) >> PWC_FPS_SHIFT;
  1212. snapshot = vw.flags & PWC_FPS_SNAPSHOT;
  1213. if (fps == 0)
  1214. fps = pdev->vframes;
  1215. if (pdev->view.x == vw.width && pdev->view.y && fps == pdev->vframes && snapshot == pdev->vsnapshot)
  1216. return 0;
  1217. ret = pwc_try_video_mode(pdev, vw.width, vw.height, fps, pdev->vcompression, snapshot);
  1218. if (ret)
  1219. return ret;
  1220. break;
  1221. }
  1222. /* We don't have overlay support (yet) */
  1223. case VIDIOCGFBUF:
  1224. {
  1225. struct video_buffer vb;
  1226. vb.base = NULL;
  1227. vb.height = 0;
  1228. vb.width = 0;
  1229. vb.depth = 0;
  1230. vb.bytesperline = 0;
  1231. if (copy_to_user((void *)arg, (void *)&vb, sizeof(vb)))
  1232. return -EFAULT;
  1233. break;
  1234. }
  1235. /* mmap() functions */
  1236. case VIDIOCGMBUF:
  1237. {
  1238. /* Tell the user program how much memory is needed for a mmap() */
  1239. struct video_mbuf vm;
  1240. int i;
  1241. memset(&vm, 0, sizeof(vm));
  1242. vm.size = default_mbufs * pdev->len_per_image;
  1243. vm.frames = default_mbufs; /* double buffering should be enough for most applications */
  1244. for (i = 0; i < default_mbufs; i++)
  1245. vm.offsets[i] = i * pdev->len_per_image;
  1246. if (copy_to_user((void *)arg, (void *)&vm, sizeof(vm)))
  1247. return -EFAULT;
  1248. break;
  1249. }
  1250. case VIDIOCMCAPTURE:
  1251. {
  1252. /* Start capture into a given image buffer (called 'frame' in video_mmap structure) */
  1253. struct video_mmap vm;
  1254. if (copy_from_user((void *)&vm, (void *)arg, sizeof(vm)))
  1255. return -EFAULT;
  1256. Trace(TRACE_READ, "VIDIOCMCAPTURE: %dx%d, frame %d, format %dn", vm.width, vm.height, vm.frame, vm.format);
  1257. if (vm.frame < 0 || vm.frame >= default_mbufs)
  1258. return -EINVAL;
  1259. /* xawtv is nasty. It probes the available palettes
  1260.    by setting a very small image size and trying
  1261.    various palettes... The driver doesn't support
  1262.    such small images, so I'm working around it.
  1263.  */
  1264. if (vm.format && vm.format != pdev->vpalette)
  1265. if (pwc_set_palette(pdev, vm.format) < 0)
  1266. return -EINVAL;
  1267.  
  1268. if ((vm.width != pdev->view.x || vm.height != pdev->view.y) &&
  1269.     (vm.width >= pdev->view_min.x && vm.height >= pdev->view_min.y)) {
  1270. int ret;
  1271. Trace(TRACE_OPEN, "VIDIOCMCAPTURE: changing size to please xawtv :-(.n");
  1272. ret = pwc_try_video_mode(pdev, vm.width, vm.height, pdev->vframes, pdev->vcompression, pdev->vsnapshot);
  1273. if (ret)
  1274. return ret;
  1275. } /* ... size mismatch */
  1276. /* FIXME: should we lock here? */
  1277. if (pdev->image_used[vm.frame])
  1278. return -EBUSY; /* buffer wasn't available. Bummer */
  1279. pdev->image_used[vm.frame] = 1;
  1280. /* Okay, we're done here. In the SYNC call we wait until a 
  1281.    frame comes available, then expand image into the given 
  1282.    buffer.
  1283.    In contrast to the CPiA cam the Philips cams deliver a 
  1284.    constant stream, almost like a grabber card. Also,
  1285.    we have separate buffers for the rawdata and the image,
  1286.    meaning we can nearly always expand into the requested buffer.
  1287.  */
  1288. Trace(TRACE_READ, "VIDIOCMCAPTURE done.n");
  1289. break;
  1290. }
  1291. case VIDIOCSYNC:
  1292. {
  1293. /* The doc says: "Whenever a buffer is used it should
  1294.    call VIDIOCSYNC to free this frame up and continue."
  1295.    
  1296.    The only odd thing about this whole procedure is 
  1297.    that MCAPTURE flags the buffer as "in use", and
  1298.    SYNC immediately unmarks it, while it isn't 
  1299.    after SYNC that you know that the buffer actually
  1300.    got filled! So you better not start a CAPTURE in
  1301.    the same frame immediately (use double buffering). 
  1302.    This is not a problem for this cam, since it has 
  1303.    extra intermediate buffers, but a hardware 
  1304.    grabber card will then overwrite the buffer 
  1305.    you're working on.
  1306.  */
  1307. int mbuf, ret;
  1308. if (copy_from_user((void *)&mbuf, arg, sizeof(int)))
  1309. return -EFAULT;
  1310. Trace(TRACE_READ, "VIDIOCSYNC called (%d).n", mbuf);
  1311. /* bounds check */
  1312. if (mbuf < 0 || mbuf >= default_mbufs)
  1313. return -EINVAL;
  1314. /* check if this buffer was requested anyway */
  1315. if (pdev->image_used[mbuf] == 0)
  1316. return -EINVAL;
  1317. /* Add ourselves to the frame wait-queue.
  1318.    
  1319.    FIXME: needs auditing for safety.
  1320.    QUSTION: In what respect? I think that using the
  1321.             frameq is safe now.
  1322.  */
  1323. add_wait_queue(&pdev->frameq, &wait);
  1324. while (pdev->full_frames == NULL) {
  1325. if (pdev->unplugged) {
  1326. remove_wait_queue(&pdev->frameq, &wait);
  1327. set_current_state(TASK_RUNNING);
  1328. return -ENODEV;
  1329. }
  1330.                  if (signal_pending(current)) {
  1331.                  remove_wait_queue(&pdev->frameq, &wait);
  1332.                  set_current_state(TASK_RUNNING);
  1333.                  return -ERESTARTSYS;
  1334.                  }
  1335.                  schedule();
  1336.                 set_current_state(TASK_INTERRUPTIBLE);
  1337. }
  1338. remove_wait_queue(&pdev->frameq, &wait);
  1339. set_current_state(TASK_RUNNING);
  1340. /* The frame is ready. Expand in the image buffer 
  1341.    requested by the user. I don't care if you 
  1342.    mmap() 5 buffers and request data in this order: 
  1343.    buffer 4 2 3 0 1 2 3 0 4 3 1 . . .
  1344.    Grabber hardware may not be so forgiving.
  1345.  */
  1346. Trace(TRACE_READ, "VIDIOCSYNC: frame ready.n");
  1347. pdev->fill_image = mbuf; /* tell in which buffer we want the image to be expanded */
  1348. /* Decompress, etc */
  1349. ret = pwc_handle_frame(pdev);
  1350. pdev->image_used[mbuf] = 0;
  1351. if (ret)
  1352. return -EFAULT;
  1353. break;
  1354. }
  1355. case VIDIOCGAUDIO:
  1356. {
  1357. struct video_audio v;
  1358. strcpy(v.name, "Microphone");
  1359. v.audio = -1; /* unknown audio minor */
  1360. v.flags = 0;
  1361. v.mode = VIDEO_SOUND_MONO;
  1362. v.volume = 0;
  1363. v.bass = 0;
  1364. v.treble = 0;
  1365. v.balance = 0x8000;
  1366. v.step = 1;
  1367. if (copy_to_user(arg, &v, sizeof(v)))
  1368. return -EFAULT;
  1369. break;
  1370. }
  1371. case VIDIOCSAUDIO:
  1372. {
  1373. struct video_audio v;
  1374. if (copy_from_user(&v, arg, sizeof(v)))
  1375. return -EFAULT;
  1376. /* Dummy: nothing can be set */
  1377. break;
  1378. }
  1379. case VIDIOCGUNIT:
  1380. {
  1381. struct video_unit vu;
  1382. vu.video = pdev->vdev->minor & 0x3F;
  1383. vu.audio = -1; /* not known yet */
  1384. vu.vbi = -1;
  1385. vu.radio = -1;
  1386. vu.teletext = -1;
  1387. if (copy_to_user(arg, &vu, sizeof(vu)))
  1388. return -EFAULT;
  1389. break;
  1390. }
  1391. default:
  1392. return pwc_ioctl(pdev, cmd, arg);
  1393. } /* ..switch */
  1394. return 0;
  1395. }
  1396. static int pwc_video_mmap(struct video_device *vdev, const char *adr, unsigned long size)
  1397. {
  1398. struct pwc_device *pdev;
  1399. unsigned long start = (unsigned long)adr;
  1400. unsigned long page, pos;
  1401. Trace(TRACE_MEMORY, "mmap(0x%p, 0x%p, %lu) called.n", vdev, adr, size);
  1402. pdev = vdev->priv;
  1403. /* FIXME - audit mmap during a read */
  1404. pos = (unsigned long)pdev->image_data;
  1405. while (size > 0) {
  1406. page = kvirt_to_pa(pos);
  1407. if (remap_page_range(start, page, PAGE_SIZE, PAGE_SHARED))
  1408. return -EAGAIN;
  1409. start += PAGE_SIZE;
  1410. pos += PAGE_SIZE;
  1411. if (size > PAGE_SIZE)
  1412. size -= PAGE_SIZE;
  1413. else
  1414. size = 0;
  1415. }
  1416. return 0;
  1417. }
  1418. /***************************************************************************/
  1419. /* USB functions */
  1420. /* This function gets called when a new device is plugged in or the usb core
  1421.  * is loaded.
  1422.  */
  1423. static void *usb_pwc_probe(struct usb_device *udev, unsigned int ifnum, const struct usb_device_id *id)
  1424. {
  1425. struct pwc_device *pdev = NULL;
  1426. struct video_device *vdev;
  1427. int vendor_id, product_id, type_id;
  1428. int i, hint;
  1429. int video_nr = -1; /* default: use next available device */
  1430. char serial_number[30];
  1431. free_mem_leak();
  1432. /* Check if we can handle this device */
  1433. Trace(TRACE_PROBE, "probe() called [%04X %04X], if %dn", udev->descriptor.idVendor, udev->descriptor.idProduct, ifnum);
  1434. /* the interfaces are probed one by one. We are only interested in the
  1435.    video interface (0) now.
  1436.    Interface 1 is the Audio Control, and interface 2 Audio itself.
  1437.  */
  1438. if (ifnum > 0) 
  1439. return NULL;
  1440. vendor_id = udev->descriptor.idVendor;
  1441. product_id = udev->descriptor.idProduct;
  1442. if (vendor_id == 0x0471) {
  1443. switch (product_id) {
  1444. case 0x0302:
  1445. Info("Philips PCA645VC USB webcam detected.n");
  1446. type_id = 645;
  1447. break;
  1448. case 0x0303:
  1449. Info("Philips PCA646VC USB webcam detected.n");
  1450. type_id = 646;
  1451. break;
  1452. case 0x0304:
  1453. Info("Askey VC010 type 2 USB webcam detected.n");
  1454. type_id = 646;
  1455. break;
  1456. case 0x0307:
  1457. Info("Philips PCVC675K (Vesta) USB webcam detected.n");
  1458. type_id = 675;
  1459. break;
  1460. case 0x0308:
  1461. Info("Philips PCVC680K (Vesta Pro) USB webcam detected.n");
  1462. type_id = 680;
  1463. break;
  1464. case 0x030C:
  1465. Info("Philips PCVC690K (Vesta Pro Scan) USB webcam detected.n");
  1466. type_id = 690;
  1467. break;
  1468. case 0x0310:
  1469. Info("Philips PCVC730K (ToUCam Fun) USB webcam detected.n");
  1470. type_id = 730;
  1471. break;
  1472. case 0x0311:
  1473. Info("Philips PCVC740K (ToUCam Pro) USB webcam detected.n");
  1474. type_id = 740;
  1475. break;
  1476. case 0x0312:
  1477. Info("Philips PCVC750K (ToUCam Pro Scan) USB webcam detected.n");
  1478. type_id = 750;
  1479. break;
  1480. default:
  1481. return NULL;
  1482. break;
  1483. }
  1484. }
  1485. else if (vendor_id == 0x069A) {
  1486. switch(product_id) {
  1487. case 0x0001:
  1488. Info("Askey VC010 type 1 USB webcam detected.n");
  1489. type_id = 645;
  1490. break;
  1491. default:
  1492. return NULL;
  1493. break;
  1494. }
  1495. }
  1496. else if (vendor_id == 0x046d) {
  1497. switch(product_id) {
  1498. case 0x08b0:
  1499. Info("Logitech QuickCam 3000 Pro detected.n");
  1500. type_id = 730;
  1501.          break;
  1502.          default:
  1503.          return NULL;
  1504.          break;
  1505.          }
  1506.         }
  1507. else if (vendor_id == 0x055d) {
  1508. /* I don't know the difference between the C10 and the C30;
  1509.    I suppose the difference is the sensor, but both cameras
  1510.    work equally well with a type_id of 675
  1511.  */
  1512. switch(product_id) {
  1513. case 0x9000:
  1514. Info("Samsung MPC-C10 USB webcam detected.n");
  1515. type_id = 675;
  1516. break;
  1517. case 0x9001:
  1518. Info("Samsung MPC-C30 USB webcam detected.n");
  1519. type_id = 675;
  1520. break;
  1521. default:
  1522. return NULL;
  1523. break;
  1524. }
  1525. }
  1526. else if (vendor_id == 0x041e) {
  1527. switch(product_id) {
  1528. case 0x400c:
  1529. Info("Creative Labs Webcam 5 detected.n");
  1530. type_id = 730;
  1531. break;
  1532. default:
  1533. return NULL;
  1534. break;
  1535. }
  1536. }
  1537. else if (vendor_id == 0x04cc) { 
  1538. switch(product_id) {
  1539. case 0x8116:
  1540. Info("SOTEC CMS-001 USB webcam detected.n");
  1541. type_id = 730;
  1542. break;  
  1543. default:
  1544. return NULL;
  1545. break;
  1546. }
  1547. }
  1548. else return NULL; /* Not Philips, Askey, Logitech, Samsung, Creative or SOTEC, for sure. */
  1549. memset(serial_number, 0, 30);
  1550. usb_string(udev, udev->descriptor.iSerialNumber, serial_number, 29);
  1551. Trace(TRACE_PROBE, "Device serial number is %sn", serial_number);
  1552. if (udev->descriptor.bNumConfigurations > 1)
  1553. Info("Warning: more than 1 configuration available.n");
  1554. /* Allocate structure, initialize pointers, mutexes, etc. and link it to the usb_device */
  1555. pdev = kmalloc(sizeof(struct pwc_device), GFP_KERNEL);
  1556. if (pdev == NULL) {
  1557. Err("Oops, could not allocate memory for pwc_device.n");
  1558. return NULL;
  1559. }
  1560. memset(pdev, 0, sizeof(struct pwc_device));
  1561. pdev->type = type_id;
  1562. pwc_construct(pdev);
  1563. init_MUTEX(&pdev->modlock);
  1564. pdev->ptrlock = SPIN_LOCK_UNLOCKED;
  1565. pdev->udev = udev;
  1566. init_waitqueue_head(&pdev->frameq);
  1567. init_waitqueue_head(&pdev->remove_ok);
  1568. pdev->vcompression = pwc_preferred_compression;
  1569. /* Now hook it up to the video subsystem */
  1570. vdev = kmalloc(sizeof(struct video_device), GFP_KERNEL);
  1571. if (vdev == NULL) {
  1572. Err("Oops, could not allocate memory for video_device.n");
  1573. return NULL;
  1574. }
  1575. memcpy(vdev, &pwc_template, sizeof(pwc_template));
  1576. sprintf(vdev->name, "Philips %d webcam", pdev->type);
  1577. SET_MODULE_OWNER(vdev);
  1578. pdev->vdev = vdev;
  1579. vdev->priv = pdev;
  1580. pdev->release = udev->descriptor.bcdDevice;
  1581. Trace(TRACE_PROBE, "Release: %04xn", pdev->release);
  1582. /* Now search device_hint[] table for a match, so we can hint a node number. */
  1583. for (hint = 0; hint < MAX_DEV_HINTS; hint++) {
  1584. if (((device_hint[hint].type == -1) || (device_hint[hint].type == pdev->type)) &&
  1585.      (device_hint[hint].pdev == NULL)) {
  1586. /* so far, so good... try serial number */
  1587. if ((device_hint[hint].serial_number[0] == '*') || !strcmp(device_hint[hint].serial_number, serial_number)) {
  1588.      /* match! */
  1589.      video_nr = device_hint[hint].device_node;
  1590.      Trace(TRACE_PROBE, "Found hint, will try to register as /dev/video%dn", video_nr);
  1591.      break;
  1592. }
  1593. }
  1594. }
  1595. i = video_register_device(vdev, VFL_TYPE_GRABBER, video_nr);
  1596. if (i < 0) {
  1597. Err("Failed to register as video device (%d).n", i);
  1598. return NULL;
  1599. }
  1600. else {
  1601. Trace(TRACE_PROBE, "Registered video struct at 0x%p.n", vdev);
  1602. Info("Registered as /dev/video%d.n", vdev->minor & 0x3F);
  1603. }
  1604. /* occupy slot */
  1605. if (hint < MAX_DEV_HINTS) 
  1606. device_hint[hint].pdev = pdev;
  1607. Trace(TRACE_PROBE, "probe() function returning struct at 0x%p.n", pdev);
  1608. return pdev;
  1609. }
  1610. /* The user janked out the cable... */
  1611. static void usb_pwc_disconnect(struct usb_device *udev, void *ptr)
  1612. {
  1613. struct pwc_device *pdev;
  1614. int hint;
  1615. DECLARE_WAITQUEUE(wait, current);
  1616. lock_kernel();
  1617. free_mem_leak();
  1618. pdev = (struct pwc_device *)ptr;
  1619. if (pdev == NULL) {
  1620. Err("pwc_disconnect() Called without private pointer.n");
  1621. return;
  1622. }
  1623. if (pdev->udev == NULL) {
  1624. Err("pwc_disconnect() already called for %pn", pdev);
  1625. return;
  1626. }
  1627. if (pdev->udev != udev) {
  1628. Err("pwc_disconnect() Woops: pointer mismatch udev/pdev.n");
  1629. return;
  1630. }
  1631. #ifdef PWC_MAGIC
  1632. if (pdev->magic != PWC_MAGIC) {
  1633. Err("pwc_disconnect() Magic number failed. Consult your scrolls and try again.n");
  1634. return;
  1635. }
  1636. #endif
  1637. pdev->unplugged = 1;
  1638. if (pdev->vdev != NULL) {
  1639. if (pdev->vopen) {
  1640. Info("Disconnected while device/video is open!n");
  1641. /* Wake up any processes that might be waiting for
  1642.    a frame, let them return an error condition
  1643.  */
  1644. wake_up(&pdev->frameq);
  1645. /* Wait until we get a 'go' from _close(). This used
  1646.    to have a gigantic race condition, since we kfree()
  1647.    stuff here, but we have to wait until close() 
  1648.    is finished. 
  1649.  */
  1650.    
  1651. Trace(TRACE_PROBE, "Sleeping on remove_ok.n");
  1652. add_wait_queue(&pdev->remove_ok, &wait);
  1653. set_current_state(TASK_UNINTERRUPTIBLE);
  1654. /* ... wait ... */
  1655. schedule();
  1656. remove_wait_queue(&pdev->remove_ok, &wait);
  1657. set_current_state(TASK_RUNNING);
  1658. Trace(TRACE_PROBE, "Done sleeping.n");
  1659. set_mem_leak(pdev->vdev);
  1660. pdev->vdev = NULL;
  1661. }
  1662. else {
  1663. /* Normal disconnect; remove from available devices */
  1664. Trace(TRACE_PROBE, "Unregistering video device normally.n");
  1665. video_unregister_device(pdev->vdev); 
  1666. kfree(pdev->vdev);
  1667. pdev->vdev = NULL;
  1668. }
  1669. }
  1670. /* search device_hint[] table if we occupy a slot, by any chance */
  1671. for (hint = 0; hint < MAX_DEV_HINTS; hint++)
  1672. if (device_hint[hint].pdev == pdev)
  1673. device_hint[hint].pdev = NULL;
  1674. pdev->udev = NULL;
  1675. unlock_kernel();
  1676. kfree(pdev);
  1677. }
  1678. /* *grunt* We have to do atoi ourselves :-( */
  1679. static int pwc_atoi(char *s)
  1680. {
  1681. int k = 0;
  1682. k = 0;
  1683. while (*s != '' && *s >= '0' && *s <= '9') {
  1684. k = 10 * k + (*s - '0');
  1685. s++;
  1686. }
  1687. return k;
  1688. }
  1689. /* 
  1690.  * Initialization code & module stuff 
  1691.  */
  1692. static char *size = NULL;
  1693. static int fps = 0;
  1694. static int fbufs = 0;
  1695. static int mbufs = 0;
  1696. static int trace = -1;
  1697. static int compression = -1;
  1698. static int leds[2] = { -1, -1 };
  1699. static char *dev_hint[10] = { };
  1700. MODULE_PARM(size, "s");
  1701. MODULE_PARM_DESC(size, "Initial image size. One of sqcif, qsif, qcif, sif, cif, vga");
  1702. MODULE_PARM(fps, "i");
  1703. MODULE_PARM_DESC(fps, "Initial frames per second. Varies with model, useful range 5-30");
  1704. MODULE_PARM(fbufs, "i");
  1705. MODULE_PARM_DESC(fbufs, "Number of internal frame buffers to reserve");
  1706. MODULE_PARM(mbufs, "i");
  1707. MODULE_PARM_DESC(mbufs, "Number of external (mmap()ed) image buffers");
  1708. MODULE_PARM(trace, "i");
  1709. MODULE_PARM_DESC(trace, "For debugging purposes");
  1710. MODULE_PARM(power_save, "i");
  1711. MODULE_PARM_DESC(power_save, "Turn power save feature in camera on or off");
  1712. MODULE_PARM(compression, "i");
  1713. MODULE_PARM_DESC(compression, "Preferred compression quality. Range 0 (uncompressed) to 3 (high compression)");
  1714. MODULE_PARM(leds, "2i");
  1715. MODULE_PARM_DESC(leds, "LED on,off time in milliseconds");
  1716. MODULE_PARM(dev_hint, "0-10s");
  1717. MODULE_PARM_DESC(dev_hint, "Device node hints");
  1718. MODULE_DESCRIPTION("Philips USB webcam driver");
  1719. MODULE_AUTHOR("Nemosoft Unv. <nemosoft@smcc.demon.nl>");
  1720. MODULE_LICENSE("GPL");
  1721. static int __init usb_pwc_init(void)
  1722. {
  1723. int i, sz;
  1724. char *sizenames[PSZ_MAX] = { "sqcif", "qsif", "qcif", "sif", "cif", "vga" };
  1725. Info("Philips PCA645/646 + PCVC675/680/690 + PCVC730/740/750 webcam module version " PWC_VERSION " loaded.n");
  1726. Info("Also supports the Askey VC010, Logitech Quickcam 3000 Pro, Samsung MPC-C10 and MPC-C30, the Creative WebCam 5 and the SOTEC CMS-001.n");
  1727. if (fps) {
  1728. if (fps < 5 || fps > 30) {
  1729. Err("Framerate out of bounds (5-30).n");
  1730. return -EINVAL;
  1731. }
  1732. default_fps = fps;
  1733. Info("Default framerate set to %d.n", default_fps);
  1734. }
  1735. if (size) {
  1736. /* string; try matching with array */
  1737. for (sz = 0; sz < PSZ_MAX; sz++) {
  1738. if (!strcmp(sizenames[sz], size)) { /* Found! */
  1739. default_size = sz;
  1740. break;
  1741. }
  1742. }
  1743. if (sz == PSZ_MAX) {
  1744. Err("Size not recognized; try size=[sqcif | qsif | qcif | sif | cif | vga].n");
  1745. return -EINVAL;
  1746. }
  1747. Info("Default image size set to %s [%dx%d].n", sizenames[default_size], pwc_image_sizes[default_size].x, pwc_image_sizes[default_size].y);
  1748. }
  1749. if (mbufs) {
  1750. if (mbufs < 1 || mbufs > MAX_IMAGES) {
  1751. Err("Illegal number of mmap() buffers; use a number between 1 and %d.n", MAX_IMAGES);
  1752. return -EINVAL;
  1753. }
  1754. default_mbufs = mbufs;
  1755. Info("Number of image buffers set to %d.n", default_mbufs);
  1756. }
  1757. if (fbufs) {
  1758. if (fbufs < 2 || fbufs > MAX_FRAMES) {
  1759. Err("Illegal number of frame buffers; use a number between 2 and %d.n", MAX_FRAMES);
  1760. return -EINVAL;
  1761. }
  1762. default_fbufs = fbufs;
  1763. Info("Number of frame buffers set to %d.n", default_fbufs);
  1764. }
  1765. if (trace >= 0) {
  1766. Info("Trace options: 0x%04xn", trace);
  1767. pwc_trace = trace;
  1768. }
  1769. if (compression >= 0) {
  1770. if (compression > 3) {
  1771. Err("Invalid compression setting; use a number between 0 (uncompressed) and 3 (high).n");
  1772. return -EINVAL;
  1773. }
  1774. pwc_preferred_compression = compression;
  1775. Info("Preferred compression set to %d.n", pwc_preferred_compression);
  1776. }
  1777. if (power_save)
  1778. Info("Enabling power save on open/close.n");
  1779. if (leds[0] >= 0)
  1780. led_on = leds[0] / 100;
  1781. if (leds[1] >= 0)
  1782. led_off = leds[1] / 100;
  1783. /* Big device node whoopla. Basicly, it allows you to assign a 
  1784.    device node (/dev/videoX) to a camera, based on its type 
  1785.    & serial number. The format is [type[.serialnumber]:]node.
  1786.            Any camera that isn't matched by these rules gets the next 
  1787.            available free device node.
  1788.  */
  1789. for (i = 0; i < MAX_DEV_HINTS; i++) {
  1790. char *s, *colon, *dot;
  1791. /* This loop also initializes the array */
  1792. device_hint[i].pdev = NULL;
  1793. s = dev_hint[i];
  1794. if (s != NULL && *s != '') {
  1795. device_hint[i].type = -1; /* wildcard */
  1796. strcpy(device_hint[i].serial_number, "*");
  1797. /* parse string: chop at ':' & '/' */
  1798. colon = dot = s;
  1799. while (*colon != '' && *colon != ':')
  1800. colon++;
  1801. while (*dot != '' && *dot != '.')
  1802. dot++;
  1803. /* Few sanity checks */
  1804. if (*dot != '' && dot > colon) {
  1805. Err("Malformed camera hint: the colon must be after the dot.n");
  1806. return -EINVAL;
  1807. }
  1808. if (*colon == '') {
  1809. /* No colon */
  1810. if (*dot != '') {
  1811. Err("Malformed camera hint: no colon + device node given.n");
  1812. return -EINVAL;
  1813. }
  1814. else {
  1815. /* No type or serial number specified, just a number. */
  1816. device_hint[i].device_node = pwc_atoi(s);
  1817. }
  1818. }
  1819. else {
  1820. /* There's a colon, so we have at least a type and a device node */
  1821. device_hint[i].type = pwc_atoi(s);
  1822. device_hint[i].device_node = pwc_atoi(colon + 1);
  1823. if (*dot != '') {
  1824. /* There's a serial number as well */
  1825. int k;
  1826. dot++;
  1827. k = 0;
  1828. while (*dot != ':' && k < 29) {
  1829. device_hint[i].serial_number[k++] = *dot;
  1830. dot++;
  1831. }
  1832. device_hint[i].serial_number[k] = '';
  1833. }
  1834. }
  1835. #ifdef PWC_DEBUG
  1836. Debug("device_hint[%d]:n", i);
  1837. Debug("  type    : %dn", device_hint[i].type);
  1838. Debug("  serial# : %sn", device_hint[i].serial_number);
  1839. Debug("  node    : %dn", device_hint[i].device_node);
  1840. #endif
  1841. }
  1842. else
  1843. device_hint[i].type = 0; /* not filled */
  1844. } /* ..for MAX_DEV_HINTS */
  1845. init_MUTEX(&mem_lock);
  1846.   Trace(TRACE_PROBE, "Registering driver at address 0x%p.n", &pwc_driver);
  1847. return usb_register(&pwc_driver);
  1848. }
  1849. static void __exit usb_pwc_exit(void)
  1850. {
  1851. free_mem_leak();
  1852. Trace(TRACE_MODULE, "Deregistering driver.n");
  1853. usb_deregister(&pwc_driver);
  1854. Info("Philips webcam module removed.n");
  1855. }
  1856. module_init(usb_pwc_init);
  1857. module_exit(usb_pwc_exit);