📄 usbvision.c
字号:
/* * USB USBVISION Video device driver 0.9.8.2cvs (For Kernel 2.4.19-2.4.30 + 2.6.0-2.6.11) * * * * Copyright (c) 1999-2005 Joerg Heckenbach <joerg@heckenbach-aw.de> * * This module is part of usbvision driver project. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * Let's call the version 0.... until compression decoding is completely * implemented. * * This driver is written by Jose Ignacio Gijon and Joerg Heckenbach. * It was based on USB CPiA driver written by Peter Pregler, * Scott J. Bertin and Johannes Erdfelt * Ideas are taken from bttv driver by Ralph Metzler, Marcus Metzler & * Gerd Knorr and zoran 36120/36125 driver by Pauline Middelink * Updates to driver completed by Dwaine P. Garden * * History: * * Mar. 2000 - 15.12.2000: (0.0.0 - 0.2.0) * Several alpha drivers and the first beta. * * Since Dec. 2000: (0.2.1) or (v2.1) * Code changes or updates by Dwaine Garden and every other person. * * Added: New Hauppauge TV device Vendor ID: 0x0573 * Product ID: 0x4D01 * (Thanks to Giovanni Garberoglio) * * Added: UK Hauppauge WinTV-USB Vendor ID: 0x0573 * Product ID: 0x4D02 * (Thanks to Derek Freeman-Jones) * * Feb, 2001 - Apr 08, 2001: (0.3.0) * - Some fixes. Driver is now more stable. * - Scratch is organized as ring-buffer now for better performance * - DGA (overlay) is now supported. * !!!!Danger!!!! Clipping is not yet implemented. Your system will * crash if your video window leaves the screen!!! * - Max. Framesize is set to 320x240. There isn't more memory on the * nt1003 video device for the FIFO. * - Supported video palettes: RGB565, RGB555, RGB24, RGB32 * * * Apr 15, 2001: (0.3.1-test...) * - Clipping is implemented * - NTSC is now coloured (Thanks to Dwaine Garden) * - Added SECAM colour detection in saa7111-new * - Added: French Hauppauge WinTV USB Vendor ID: 0x0573 * Product ID: 0x4D03 * (Thanks to Julius Hrivnac) * - Added: US Hauppauge WINTV USB Vendor ID: 0x0573 * Product ID: 0x4D00 * (Thanks to Derrick J Brashear) * - Changes for adding new devices. There's now a table in usbvision.h. * Adding your devices data to the usbvision_device_data table is all * you need to add a new device. * * May 11, 2001: (0.3.2-test...) (Thanks to Derek Freeman-Jones) * - Support YUV422 raw format for people with hardware scaling. * - Only power on the device when opened (use option PowerOnAtOpen=0 to disable it). * - Turn off audio so we can listen to Line In. * * July 5, 2001 - (Patch the driver to run with Kernel 2.4.6) * - Fixed a problem with the number of parameters passed to video_register_device. * * July 6, 2001 - Added: HAUPPAUGE WINTV-USB FM USA Vendor ID: 0x0573 * Product ID: 0x4D10 * (Thanks to Braddock Gaskill) * Added: USBGear USBG-V1 resp. HAMA USB * Vendor ID: 0x0573 * Product ID: 0x0003 * (Thanks to Bradley A. Singletary and Juergen Weigert) * * Jan 24, 2002 - (0.3.3-test...) * - Moved all global variables that are device specific the usb_usbvision struct * - Fixed the 64x48 unchangable image in xawtv when starting it with overlay * - Add VideoNorm and TunerType to the usb_device_data table * - Checked the audio channels and mute for HAUPPAUGE WinTV USB FM * - Implemented the power on when opening the device. But some software opens * the device several times when starting. So the i2c parts are just registered * by an open, when they become deregistered by the next close. You can speed * up tuner detection, when adding "options tuner addr=your_addr" to /etc/modules.conf * - Begin to resize the frame in width and height. So it will be possible to watch i.e. * 384x288 pixels at 23 fps. * * Feb 10, 2002 * - Added radio device * * * Jul 30, 2002 - (Thanks Cameron Maxwell) * - Changes to usbvision.h --fixed usbvision device data structure, incorrectly had (0x0573, 0x4d21) for WinTV-USB II, should be 0x4d20. * - Changes for device WinTV-USB II (0x0573. 0x4D21). It does not have a FM tuner. * - Added the real device HAUPPAUGE WINTV-USB II (PAL) to the device structure in usbvision.h. * - Changes to saa7113-new, the video is 8 bit data for the Phillips SAA7113 not 16bit like SAA7111. * - Tuned lots of setup registers for the Phillips SAA7113 video chipset. * - Changes to the supplied makefile. (Dwaine Garden) Still needs to be fixed so it will compile modules on different distrubutions. * * * Aug 10, 2002 - (Thanks Mike Klinke) * - Changes to usbvision.txt -- Fixed instructions on the location to copy the contents of the tgz file. * - Added device WinTV-USB FM Model 621 (0x0573. 0x4D30). There is another device which carries the same name. Kept that device in the device structure. * * Aug 12, 2002 - Dwaine Garden * - Added the ability to read the NT100x chip for the MaxISOPacketLength and USB Bandwidth * Setting of the video device. * - Adjustments to the SAA7113H code for proper video output. * - Changes to usbvision.h, so all the devices with FM tuners are working. * * Feb 10, 2003 - Joerg Heckenbach * - fixed endian bug for Motorola PPC * * Feb 13, 2003 - Joerg Heckenbach * - fixed Vin_Reg setting and presetting from usbvision_device_data() * * Apr 19, 2003 - Dwaine Garden * - Fixed compiling errors under RedHat v9.0. from uvirt_to_kva and usbvision_mmap. (Thanks Cameron Maxwell) * - Changed pte_offset to pte_offset_kernel. * - Changed remap_page_range and added additional parameter to function. * - Change setup parameters for the D-Link V100 USB device * - Added a new device to the usbvision driver. Pinnacle Studio PCTV USB (PAL) 0x2304 0x0110 * - Screwed up the sourceforge.net cvs respository! 8*) * * Apr 22, 2002 - Dwaine Garden * - Added a new device to the usbvision driver. Dazzle DVC-80 (PAL) 0x07d0 0x0004. (Thanks Carl Anderson) * - Changes to some of the comments. * * June 06, 2002 - Ivan, Dwaine Garden * - Ivan updates for fine tuning device parameters without driver recompiling. (Ivan) * - Changes to some of the comments. (Dwaine Garden) * - Changes to the makefile - Better CPU settings. (Ivan) * - Changes to device Hauppauge WinTv-USB III (PAL) FM Model 568 - Fine tuning parameters (Ivan) * * * Oct 16, 2003 - 0.9.0 - Joerg Heckenbach * - Implementation of the first part of the decompression algorithm for intra frames. * The resolution has to be 320x240. A dynamic adaption of compression deepth is * missing yet. * * Oct 22, 2003 - 0.9.1 - Joerg Heckenbach * - Implementation of the decompression algorithm for inter frames. * The resolution still has to be 320x240. * * Nov 2003 - Feb 2004 - 0.9.2 to 0.9.3 - Joerg Heckenbach * - Implement last unknown compressed block type. But color is still noisy. * - Finding criteria for adaptive compression adjustment. * - Porting to 2.6 kernels, but still working under 2.4 * * Feb 04, 2004 - 0.9.4 Joerg Heckenbach * - Found bug in color decompression. Color is OK now. * * Feb 09, 2004 - 0.9.5 Joerg Heckenbach * - Add auto-recognition of chip type NT1003 or NT1004. * - Add adaptive compression adjustment. * - Patched saa7113 multiplexer switching (Thanks to Orlando F.S. Bordoni) * * Feb 24, 2004 - 0.9.6 Joerg Heckenbach * - Add a timer to wait before poweroff at close, to save start time in * some video applications * * Mar 4, 2004 - 0.9.6 Dwaine Garden * - Added device Global Village GV-007 (NTSC) to usbvision.h (Thanks to Abe Skolnik) * - Forgot to add this device to the driver. 8*) * * June 2, 2004 - 0.9.6 Dwaine Garden * - Fixed sourceforge.net cvs repository. * - Added #if LINUX_VERSION_CODE > KERNEL_VERSION(2,4,26) for .owner to help compiling under kernels 2.4.x which do not have the i2c v2.8.x updates. * - Added device Hauppauge WinTv-USB III (PAL) FM Model 597 to usbvision.h * * July 1, 2004 -0.9.6 Dwaine Garden * - Patch was submitted by Hal Finkel to fix the problem with the tuner not working under kernel 2.6.7. * - Thanks Hal..... * * July 30, 2004 - 0.9.6 Dwaine Garden * - Patch was submitted by Tobias Diaz to fix Model ID mismatch in usbvision.h. * - Thanks..... * * August 12, 2004 - 0.9.6 Dwaine Garden * - Updated the readme file so people could install the driver under the configuration file for kernel 2.6.x recompiles. Now people can use make xconfig! * - Added new device "Camtel Technology Corp TVB330-USB FM". * - Sourceforge.net CVS has been updated with all the changes. * * August 20, 2004 - 0.9.7 Dwaine Garden * - Added Device "Hauppauge USB Live Model 600" * - Fixed up all the devices which did not have a default tuner type in usbvision.h. It's best guess, at least until someone with the device tells me otherwise. * - Sourceforge.net CVS has been updated with all the changes. * - Clean up the driver. * * September 13, 2004 - 0.9.8 Dwaine Garden * - Changed usbvision_muxsel to address the problem with black & white s-video output for NT1004 devices with saa7114 video decoder. Thanks to Emmanuel for the patch and testing. * - Fixed up SECAM devices which could not properly output video. Changes to usbmuxsel. Thanks to Emmanuel for the patch and everyone with a SECAM device which help test. * - Removed some commented out code. Clean up. * - Tried to fix up the annoying empty directories in the sourceforge.net cvs. Fuck it up again. 8*( * * November 15, 2004 - 0.9.8 Dwaine Garden * - Release new tar - 0.9.8 on sourceforge.net * - Added some new devices to usbvision.h WinTV USB Model 602 40201 Rev B282, Hauppague WinTV USB Model 602 40201 Rev B285 * - Added better compatibility for 2.6.x kernels. * - Hardware full screen scaling in grabdisplay mode. * - Better support for sysfs. More code to follow for both video device and radio device. Device information is located at /sys/class/video4linux/video0 * - Added module_param so loaded module parameters are displayed in sysfs. Driver parameters should show up in /sys/module/usbvision * - Adjusted the SAA7111 registers to match the 2.6.x kernel SAA7111 code. Thanks to the person which helped test. * - Changed to wait_event_interruptible. For all the people running Fedora 2. * - Added some screenshots of actual video captures on sourceforge.net. * * November 24, 2004 - 0.9.8.1cvs Dwaine Garden * - Added patch to check for palette and format in VIDIOCSPICT. Helix Producer should work fine with the driver now. Thanks Jason Simpson * - Two device description changes and two additions for the maintainer of usb.ids. * * December 2, 2004 - 0.9.8.1cvs Dwaine Garden * - Added patch for YUV420P and YUV422P video output. Thanks to Alex Smith. * - Better support for mythtv. * * January 2, 2005 - 0.9.8.1cvs Dwaine Garden * - Setup that you can specify which device is used for video. Default is auto detect next available device number eg. /dev/videoX * - Setup that you can specify which device is used for radio. Default is auto detect next available device number eg. /dev/radioX * - usb_unlink_urb() is deprecated for synchronous unlinks. Using usb_kill_urb instead. * - usbvision_kvirt_to_pa is deprecated. Removed. * - Changes are related to kernel changes for 2.6.10. (Fedora 4) * * February 2, 2005 - 0.9.8.1cvs Dwaine Garden * - Added a new device to usbvision.h Dazzle DVC 50. Thanks to Luiz S. * * March 29, 2005 - 0.9.8.1cvs Dwaine Garden * - Fixed compile error with saa7113 under kernels 2.6.11+ * - Added module parameter to help people with Black and White output with using s-video input. Some cables and input device are wired differently. * - Removed the .id from the i2c usbvision template. There was a change to the i2c with kernels 2.6.11+. * * April 9, 2005 - 0.9.8.1cvs Dwaine Garden * - Added in the 2.4 and 2.6 readme files the SwitchSVideoInput parameter information. This will help people setup the right values for the parameter. * If your device experiences Black and White images with the S-Video Input. Set this parameter to 1 when loading the module. * - Replaced the wrong 2.6 readme file. I lost the right version. Someone sent me the right version by e-mail. Thanks. * - Released new module version on sourceforge.net. So everyone can enjoy all the fixes and additional device support. * * April 20, 2005 - 0.9.8.2cvs Dwaine Garden * - Release lock in usbvision_v4l_read_done. -Thanks to nplanel for the patch. * - Additional comments to the driver. * - Fixed some spelling mistakes. 8*) * * April 23, 2005 - 0.9.8.2cvs Joerg Heckenbach * - Found bug in usbvision line counting. Now there should be no spurious lines in the image any longer. * - Swapped usbvision_register_video and usbvision_configure_video to fix problem with PowerOnAtOpen=0. * Thanks to Erwan Velu * * April 26, 2005 - 0.9.8.2cvs Joerg Heckenbach * - Fixed problem with rmmod module and oppses. Replaced vfree(usbvision->overlay_base) with iounmap(usbvision->overlay_base). * - Added function usb_get_dev(dev) and ; To help with unloading the module multiple times without crashing. * (Keep the reference count in kobjects correct) * * TODO: * - use submit_urb for all setup packets * - Fix memory settings for nt1004. It is 4 times as big as the * nt1003 memory. * - Add audio on endpoint 3 for nt1004 chip. Seems impossible, needs a codec interface. Which one? * - Clean up the driver. * - optimization for performance. * - Add Videotext capability (VBI). Working on it..... * - Check audio for other devices * - Add v4l2 interface * */#include <linux/kernel.h>#include <linux/sched.h>#include <linux/list.h>#include <linux/timer.h>#include <linux/slab.h>#include <linux/mm.h>#include <linux/highmem.h>#include <linux/smp_lock.h>#include <linux/videodev.h>#include <linux/vmalloc.h>#include <linux/module.h>#include <linux/init.h>#include <linux/spinlock.h>#include <linux/usb.h>#include <asm/io.h>#include <linux/video_decoder.h>#include <linux/i2c.h>#include "i2c-algo-usb.h"#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 0) #include <linux/proc_fs.h> #include <linux/tqueue.h> #include <linux/wrapper.h> #include <../drivers/media/video/tuner.h> #include <../drivers/media/video/audiochip.h>#else #include <linux/moduleparam.h> #include <linux/workqueue.h> #include <media/tuner.h> #include <media/audiochip.h>#endif#ifdef CONFIG_KMOD#include <linux/kmod.h>#endif#include "usbvision.h"#include "usbvision_ioctl.h"#define DRIVER_VERSION "0.9.8.2cvs for Linux kernels 2.4.19-2.4.30 + 2.6.0-2.6.11, compiled at "__DATE__", "__TIME__#define EMAIL "joerg@heckenbach-aw.de"#define DRIVER_AUTHOR "Joerg Heckenbach <joerg@heckenbach-aw.de>, Dwaine Garden <DwaineGarden@rogers.com>"#define DRIVER_DESC "USBVision USB Video Device Driver for Linux"#define DRIVER_LICENSE "GPL"#define DRIVER_ALIAS "USBVision"#define ENABLE_HEXDUMP 0 /* Enable if you need it */#define USBVISION_DEBUG /* Turn on debug messages */#ifdef USBVISION_DEBUG #define PDEBUG(level, fmt, args...) \ if (debug & (level)) info("[%s:%d] " fmt, __PRETTY_FUNCTION__, __LINE__ , ## args)#else #define PDEBUG(level, fmt, args...) do {} while(0)#endif#define DBG_PROCFS 1<<2#define DBG_IOCTL 1<<3#define DBG_IO 1<<4#define DBG_RIO 1<<5#define DBG_HEADER 1<<7#define DBG_PROBE 1<<8#define DBG_IRQ 1<<9#define DBG_ISOC 1<<10#define DBG_PARSE 1<<11#define DBG_SCRATCH 1<<12#define DBG_FUNC 1<<13#define DBG_I2C 1<<14#define DEBUG(x...) /* General Debug */#define IODEBUG(x...) /* Debug IO */#define OVDEBUG(x...) /* Debug overlay */#define MDEBUG(x...) /* Debug memory management *///String operations#define rmspace(str) while(*str==' ') str++;#define goto2next(str) while(*str!=' ') str++; while(*str==' ') str++;static int usbvision_nr = 0; // sequential number of usbvision devicestatic const int max_imgwidth = MAX_FRAME_WIDTH;static const int max_imgheight = MAX_FRAME_HEIGHT;static const int min_imgwidth = MIN_FRAME_WIDTH;static const int min_imgheight = MIN_FRAME_HEIGHT;#define FRAMERATE_MIN 0#define FRAMERATE_MAX 31enum { ISOC_MODE_YUV422 = 0x03, ISOC_MODE_YUV420 = 0x14, ISOC_MODE_COMPRESS = 0x60,};/* * The value of 'scratch_buf_size' affects quality of the picture * in many ways. Shorter buffers may cause loss of data when client * is too slow. Larger buffers are memory-consuming and take longer * to work with. This setting can be adjusted, but the default value * should be OK for most desktop users. */#define DEFAULT_SCRATCH_BUF_SIZE (0x20000) // 128kB memory scratch bufferstatic const int scratch_buf_size = DEFAULT_SCRATCH_BUF_SIZE;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -