|
@@ -0,0 +1,481 @@
|
|
|
|
+This is a driver for the WIS GO7007SB multi-format video encoder.
|
|
|
|
+
|
|
|
|
+Pete Eberlein <pete@sensoray.com>
|
|
|
|
+
|
|
|
|
+The driver was orignally released under the GPL and is currently hosted at:
|
|
|
|
+http://nikosapi.org/wiki/index.php/WIS_Go7007_Linux_driver
|
|
|
|
+The go7007 firmware can be acquired from the package on the site above.
|
|
|
|
+
|
|
|
|
+I've modified the driver to support the following Video4Linux2 MPEG
|
|
|
|
+controls, with acceptable values:
|
|
|
|
+
|
|
|
|
+V4L2_CID_MPEG_STREAM_TYPE V4L2_MPEG_STREAM_TYPE_MPEG2_DVD
|
|
|
|
+ V4L2_MPEG_STREAM_TYPE_MPEG_ELEM
|
|
|
|
+V4L2_CID_MPEG_VIDEO_ENCODING V4L2_MPEG_VIDEO_ENCODING_MPEG_1
|
|
|
|
+ V4L2_MPEG_VIDEO_ENCODING_MPEG_2
|
|
|
|
+ V4L2_MPEG_VIDEO_ENCODING_MPEG_4
|
|
|
|
+V4L2_CID_MPEG_VIDEO_ASPECT V4L2_MPEG_VIDEO_ASPECT_1x1
|
|
|
|
+ V4L2_MPEG_VIDEO_ASPECT_4x3
|
|
|
|
+ V4L2_MPEG_VIDEO_ASPECT_16x9
|
|
|
|
+V4L2_CID_MPEG_VIDEO_GOP_SIZE integer
|
|
|
|
+V4L2_CID_MPEG_VIDEO_BITRATE 64000 .. 10000000
|
|
|
|
+
|
|
|
|
+These should be used instead of the non-standard GO7007 ioctls described
|
|
|
|
+below.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+The README files from the orignal package appear below:
|
|
|
|
+
|
|
|
|
+---------------------------------------------------------------------------
|
|
|
|
+ WIS GO7007SB Public Linux Driver
|
|
|
|
+---------------------------------------------------------------------------
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+*** Please see the file RELEASE-NOTES for important last-minute updates ***
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ 0. OVERVIEW AND LICENSING/DISCLAIMER
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+This driver kit contains Linux drivers for the WIS GO7007SB multi-format
|
|
|
|
+video encoder. Only kernel version 2.6.x is supported. The video stream
|
|
|
|
+is available through the Video4Linux2 API and the audio stream is available
|
|
|
|
+through the ALSA API (or the OSS emulation layer of the ALSA system).
|
|
|
|
+
|
|
|
|
+The files in kernel/ and hotplug/ are licensed under the GNU General Public
|
|
|
|
+License Version 2 from the Free Software Foundation. A copy of the license
|
|
|
|
+is included in the file COPYING.
|
|
|
|
+
|
|
|
|
+The example applications in apps/ and C header files in include/ are
|
|
|
|
+licensed under a permissive license included in the source files which
|
|
|
|
+allows copying, modification and redistribution for any purpose without
|
|
|
|
+attribution.
|
|
|
|
+
|
|
|
|
+The firmware files included in the firmware/ directory may be freely
|
|
|
|
+redistributed only in conjunction with this document; but modification,
|
|
|
|
+tampering and reverse engineering are prohibited.
|
|
|
|
+
|
|
|
|
+MICRONAS USA, INC., MAKES NO WARRANTIES TO ANY PERSON OR ENTITY WITH
|
|
|
|
+RESPECT TO THE SOFTWARE OR ANY DERIVATIVES THEREOF OR ANY SERVICES OR
|
|
|
|
+LICENSES AND DISCLAIMS ALL IMPLIED WARRANTIES, INCLUDING WITHOUT LIMITATION
|
|
|
|
+WARRANTIES OF MERCHANTABILITY, SUPPORT, AND FITNESS FOR A PARTICULAR
|
|
|
|
+PURPOSE AND NON-INFRINGEMENT.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ 1. SYSTEM REQUIREMENTS
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+This driver requires Linux kernel 2.6. Kernel 2.4 is not supported. Using
|
|
|
|
+kernel 2.6.10 or later is recommended, as earlier kernels are known to have
|
|
|
|
+unstable USB 2.0 support.
|
|
|
|
+
|
|
|
|
+A fully built kernel source tree must be available. Typically this will be
|
|
|
|
+linked from "/lib/modules/<KERNEL VERSION>/build" for convenience. If this
|
|
|
|
+link does not exist, an extra parameter will need to be passed to the
|
|
|
|
+`make` command.
|
|
|
|
+
|
|
|
|
+All vendor-built kernels should already be configured properly. However,
|
|
|
|
+for custom-built kernels, the following options need to be enabled in the
|
|
|
|
+kernel as built-in or modules:
|
|
|
|
+
|
|
|
|
+ CONFIG_HOTPLUG - Support for hot-pluggable devices
|
|
|
|
+ CONFIG_MODULES - Enable loadable module support
|
|
|
|
+ CONFIG_KMOD - Automatic kernel module loading
|
|
|
|
+ CONFIG_FW_LOADER - Hotplug firmware loading support
|
|
|
|
+ CONFIG_I2C - I2C support
|
|
|
|
+ CONFIG_VIDEO_DEV - Video For Linux
|
|
|
|
+ CONFIG_SOUND - Sound card support
|
|
|
|
+ CONFIG_SND - Advanced Linux Sound Architecture
|
|
|
|
+ CONFIG_USB - Support for Host-side USB
|
|
|
|
+ CONFIG_USB_DEVICEFS - USB device filesystem
|
|
|
|
+ CONFIG_USB_EHCI_HCD - EHCI HCD (USB 2.0) support
|
|
|
|
+
|
|
|
|
+Additionally, to use the example application, the following options need to
|
|
|
|
+be enabled in the ALSA section:
|
|
|
|
+
|
|
|
|
+ CONFIG_SND_MIXER_OSS - OSS Mixer API
|
|
|
|
+ CONFIG_SND_PCM_OSS - OSS PCM (digital audio) API
|
|
|
|
+
|
|
|
|
+The hotplug scripts, along with the fxload utility, must also be installed.
|
|
|
|
+These scripts can be obtained from <http://linux-hotplug.sourceforge.net/>.
|
|
|
|
+Hotplugging is used for loading firmware into the Cypruss EZ-USB chip using
|
|
|
|
+fxload and for loading firmware into the driver using the firmware agent.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ 2. COMPILING AND INSTALLING THE DRIVER
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+Most users should be able to compile the driver by simply running:
|
|
|
|
+
|
|
|
|
+ $ make
|
|
|
|
+
|
|
|
|
+in the top-level directory of the driver kit. First the kernel modules
|
|
|
|
+will be built, followed by the example applications.
|
|
|
|
+
|
|
|
|
+If the build system is unable to locate the kernel source tree for the
|
|
|
|
+currently-running kernel, or if the module should be built for a kernel
|
|
|
|
+other than the currently-running kernel, an additional parameter will need
|
|
|
|
+to be passed to make to specify the appropriate kernel source directory:
|
|
|
|
+
|
|
|
|
+ $ make KERNELSRC=/usr/src/linux-2.6.10-custom3
|
|
|
|
+
|
|
|
|
+Once the compile completes, the driver and firmware files should be
|
|
|
|
+installed by running:
|
|
|
|
+
|
|
|
|
+ $ make install
|
|
|
|
+
|
|
|
|
+The kernel modules will be placed in "/lib/modules/<KERNEL VERSION>/extra"
|
|
|
|
+and the firmware files will be placed in the appropriate hotplug firmware
|
|
|
|
+directory, usually /lib/firmware. In addition, USB maps and scripts will
|
|
|
|
+be placed in /etc/hotplug/usb to enable fxload to initialize the EZ-USB
|
|
|
|
+control chip when the device is connected.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ 3. PAL/SECAM TUNER CONFIGURATION (TV402U-EU only)
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+The PAL model of the Plextor ConvertX TV402U may require additional
|
|
|
|
+configuration to correctly select the appropriate TV frequency band and
|
|
|
|
+audio subchannel.
|
|
|
|
+
|
|
|
|
+Users with a device other than the Plextor ConvertX TV402U-EU should skip
|
|
|
|
+this section.
|
|
|
|
+
|
|
|
|
+The wide variety of PAL TV systems used in Europe requires that additional
|
|
|
|
+information about the local TV standards be passed to the driver in order
|
|
|
|
+to properly tune TV channels. The two necessary parameters are (a) the PAL
|
|
|
|
+TV band, and (b) the audio subchannel format in use.
|
|
|
|
+
|
|
|
|
+In many cases, the appropriate TV band selection is passed to the driver
|
|
|
|
+from applications. However, in some cases, the application only specifies
|
|
|
|
+that the driver should use PAL but not the specific information about the
|
|
|
|
+appropriate TV band. To work around this issue, the correct TV band may be
|
|
|
|
+specified in the "force_band" parameter to the wis-sony-tuner module:
|
|
|
|
+
|
|
|
|
+ TV band force_band
|
|
|
|
+ ------- ----------
|
|
|
|
+ PAL B/G B
|
|
|
|
+ PAL I I
|
|
|
|
+ PAL D/K D
|
|
|
|
+ SECAM L L
|
|
|
|
+
|
|
|
|
+If the "force_band" parameter is specified, the driver will ignore any TV
|
|
|
|
+band specified by applications and will always use the band provided in the
|
|
|
|
+module parameter.
|
|
|
|
+
|
|
|
|
+The other parameter that can be specified is the audio subchannel format.
|
|
|
|
+There are several stereo audio carrier systems in use, including NICAM and
|
|
|
|
+three varieties of A2. To receive audio broadcast on one of these stereo
|
|
|
|
+carriers, the "force_mpx_mode" parameter must be specified to the
|
|
|
|
+wis-sony-tuner module.
|
|
|
|
+
|
|
|
|
+ TV band Audio subcarrier force_mpx_mode
|
|
|
|
+ ------- ---------------- --------------
|
|
|
|
+ PAL B/G Mono (default) 1
|
|
|
|
+ PAL B/G A2 2
|
|
|
|
+ PAL B/G NICAM 3
|
|
|
|
+ PAL I Mono (default) 4
|
|
|
|
+ PAL I NICAM 5
|
|
|
|
+ PAL D/K Mono (default) 6
|
|
|
|
+ PAL D/K A2 (1) 7
|
|
|
|
+ PAL D/K A2 (2) 8
|
|
|
|
+ PAL D/K A2 (3) 9
|
|
|
|
+ PAL D/K NICAM 10
|
|
|
|
+ SECAM L Mono (default) 11
|
|
|
|
+ SECAM L NICAM 12
|
|
|
|
+
|
|
|
|
+If the "force_mpx_mode" parameter is not specified, the correct mono-only
|
|
|
|
+mode will be chosen based on the TV band. However, the tuner will not
|
|
|
|
+receive stereo audio or bilingual broadcasts correctly.
|
|
|
|
+
|
|
|
|
+To pass the "force_band" or "force_mpx_mode" parameters to the
|
|
|
|
+wis-sony-tuner module, the following line must be added to the modprobe
|
|
|
|
+configuration file, which varies from one Linux distribution to another.
|
|
|
|
+
|
|
|
|
+ options wis-sony-tuner force_band=B force_mpx_mode=2
|
|
|
|
+
|
|
|
|
+The above example would force the tuner to the PAL B/G TV band and receive
|
|
|
|
+stereo audio broadcasts on the A2 carrier.
|
|
|
|
+
|
|
|
|
+To verify that the configuration has been placed in the correct location,
|
|
|
|
+execute:
|
|
|
|
+
|
|
|
|
+ $ modprobe -c | grep wis-sony-tuner
|
|
|
|
+
|
|
|
|
+If the configuration line appears, then modprobe will pass the parameters
|
|
|
|
+correctly the next time the wis-sony-tuner module is loaded into the
|
|
|
|
+kernel.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ 4. TESTING THE DRIVER
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+Because few Linux applications are able to correctly capture from
|
|
|
|
+Video4Linux2 devices with only compressed formats supported, the new driver
|
|
|
|
+should be tested with the "gorecord" application in the apps/ directory.
|
|
|
|
+
|
|
|
|
+First connect a video source to the device, such as a DVD player or VCR.
|
|
|
|
+This will be captured to a file for testing the driver. If an input source
|
|
|
|
+is unavailable, a test file can still be captured, but the video will be
|
|
|
|
+black and the audio will be silent.
|
|
|
|
+
|
|
|
|
+This application will auto-detect the V4L2 and ALSA/OSS device names of the
|
|
|
|
+hardware and will record video and audio to an AVI file for a specified
|
|
|
|
+number of seconds. For example:
|
|
|
|
+
|
|
|
|
+ $ apps/gorecord -duration 60 capture.avi
|
|
|
|
+
|
|
|
|
+If this application does not successfully record an AVI file, the error
|
|
|
|
+messages produced by gorecord and recorded in the system log (usually in
|
|
|
|
+/var/log/messages) should provide information to help resolve the problem.
|
|
|
|
+
|
|
|
|
+Supplying no parameters to gorecord will cause it to probe the available
|
|
|
|
+devices and exit. Use the -help flag for usage information.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ 5. USING THE DRIVER
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+The V4L2 device implemented by the driver provides a standard compressed
|
|
|
|
+format API, within the following criteria:
|
|
|
|
+
|
|
|
|
+ * Applications that only support the original Video4Linux1 API will not
|
|
|
|
+ be able to communicate with this driver at all.
|
|
|
|
+
|
|
|
|
+ * No raw video modes are supported, so applications like xawtv that
|
|
|
|
+ expect only uncompressed video will not function.
|
|
|
|
+
|
|
|
|
+ * Supported compression formats are: Motion-JPEG, MPEG1, MPEG2 and MPEG4.
|
|
|
|
+
|
|
|
|
+ * MPEG video formats are delivered as Video Elementary Streams only.
|
|
|
|
+ Program Stream (PS), Transport Stream (TS) and Packetized Elementary
|
|
|
|
+ Stream (PES) formats are not supported.
|
|
|
|
+
|
|
|
|
+ * Video parameters such as format and input port may not be changed while
|
|
|
|
+ the encoder is active.
|
|
|
|
+
|
|
|
|
+ * The audio capture device only functions when the video encoder is
|
|
|
|
+ actively capturing video. Attempts to read from the audio device when
|
|
|
|
+ the encoder is inactive will result in an I/O error.
|
|
|
|
+
|
|
|
|
+ * The native format of the audio device is 48Khz 2-channel 16-bit
|
|
|
|
+ little-endian PCM, delivered through the ALSA system. No audio
|
|
|
|
+ compression is implemented in the hardware. ALSA may convert to other
|
|
|
|
+ uncompressed formats on the fly.
|
|
|
|
+
|
|
|
|
+The include/ directory contains a C header file describing non-standard
|
|
|
|
+features of the GO7007SB encoder, which are described below:
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ GO7007IOC_S_COMP_PARAMS, GO7007IOC_G_COMP_PARAMS
|
|
|
|
+
|
|
|
|
+ These ioctls are used to negotiate general compression parameters.
|
|
|
|
+
|
|
|
|
+ To query the current parameters, call the GO7007IOC_G_COMP_PARAMS ioctl
|
|
|
|
+ with a pointer to a struct go7007_comp_params. If the driver is not
|
|
|
|
+ set to MPEG format, the EINVAL error code will be returned.
|
|
|
|
+
|
|
|
|
+ To change the current parameters, initialize all fields of a struct
|
|
|
|
+ go7007_comp_params and call the GO7007_IOC_S_COMP_PARAMS ioctl with a
|
|
|
|
+ pointer to this structure. The driver will return the current
|
|
|
|
+ parameters with any necessary changes to conform to the limitations of
|
|
|
|
+ the hardware or current compression mode. Any or all fields can be set
|
|
|
|
+ to zero to request a reasonable default value. If the driver is not
|
|
|
|
+ set to MPEG format, the EINVAL error code will be returned. When I/O
|
|
|
|
+ is in progress, the EBUSY error code will be returned.
|
|
|
|
+
|
|
|
|
+ Fields in struct go7007_comp_params:
|
|
|
|
+
|
|
|
|
+ __u32 The maximum number of frames in each
|
|
|
|
+ gop_size Group Of Pictures; i.e. the maximum
|
|
|
|
+ number of frames minus one between
|
|
|
|
+ each key frame.
|
|
|
|
+
|
|
|
|
+ __u32 The maximum number of sequential
|
|
|
|
+ max_b_frames bidirectionally-predicted frames.
|
|
|
|
+ (B-frames are not yet supported.)
|
|
|
|
+
|
|
|
|
+ enum go7007_aspect_ratio The aspect ratio to be encoded in the
|
|
|
|
+ aspect_ratio meta-data of the compressed format.
|
|
|
|
+
|
|
|
|
+ Choices are:
|
|
|
|
+ GO7007_ASPECT_RATIO_1_1
|
|
|
|
+ GO7007_ASPECT_RATIO_4_3_NTSC
|
|
|
|
+ GO7007_ASPECT_RATIO_4_3_PAL
|
|
|
|
+ GO7007_ASPECT_RATIO_16_9_NTSC
|
|
|
|
+ GO7007_ASPECT_RATIO_16_9_PAL
|
|
|
|
+
|
|
|
|
+ __u32 Bit-wise OR of control flags (below)
|
|
|
|
+ flags
|
|
|
|
+
|
|
|
|
+ Flags in struct go7007_comp_params:
|
|
|
|
+
|
|
|
|
+ GO7007_COMP_CLOSED_GOP Only produce self-contained GOPs, used
|
|
|
|
+ to produce streams appropriate for
|
|
|
|
+ random seeking.
|
|
|
|
+
|
|
|
|
+ GO7007_COMP_OMIT_SEQ_HEADER Omit the stream sequence header.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ GO7007IOC_S_MPEG_PARAMS, GO7007IOC_G_MPEG_PARAMS
|
|
|
|
+
|
|
|
|
+ These ioctls are used to negotiate MPEG-specific stream parameters when
|
|
|
|
+ the pixelformat has been set to V4L2_PIX_FMT_MPEG.
|
|
|
|
+
|
|
|
|
+ To query the current parameters, call the GO7007IOC_G_MPEG_PARAMS ioctl
|
|
|
|
+ with a pointer to a struct go7007_mpeg_params. If the driver is not
|
|
|
|
+ set to MPEG format, the EINVAL error code will be returned.
|
|
|
|
+
|
|
|
|
+ To change the current parameters, initialize all fields of a struct
|
|
|
|
+ go7007_mpeg_params and call the GO7007_IOC_S_MPEG_PARAMS ioctl with a
|
|
|
|
+ pointer to this structure. The driver will return the current
|
|
|
|
+ parameters with any necessary changes to conform to the limitations of
|
|
|
|
+ the hardware or selected MPEG mode. Any or all fields can be set to
|
|
|
|
+ zero to request a reasonable default value. If the driver is not set
|
|
|
|
+ to MPEG format, the EINVAL error code will be returned. When I/O is in
|
|
|
|
+ progress, the EBUSY error code will be returned.
|
|
|
|
+
|
|
|
|
+ Fields in struct go7007_mpeg_params:
|
|
|
|
+
|
|
|
|
+ enum go7007_mpeg_video_standard
|
|
|
|
+ mpeg_video_standard The MPEG video standard in which to
|
|
|
|
+ compress the video.
|
|
|
|
+
|
|
|
|
+ Choices are:
|
|
|
|
+ GO7007_MPEG_VIDEO_MPEG1
|
|
|
|
+ GO7007_MPEG_VIDEO_MPEG2
|
|
|
|
+ GO7007_MPEG_VIDEO_MPEG4
|
|
|
|
+
|
|
|
|
+ __u32 Bit-wise OR of control flags (below)
|
|
|
|
+ flags
|
|
|
|
+
|
|
|
|
+ __u32 The profile and level indication to be
|
|
|
|
+ pali stored in the sequence header. This
|
|
|
|
+ is only used as an indicator to the
|
|
|
|
+ decoder, and does not affect the MPEG
|
|
|
|
+ features used in the video stream.
|
|
|
|
+ Not valid for MPEG1.
|
|
|
|
+
|
|
|
|
+ Choices for MPEG2 are:
|
|
|
|
+ GO7007_MPEG2_PROFILE_MAIN_MAIN
|
|
|
|
+
|
|
|
|
+ Choices for MPEG4 are:
|
|
|
|
+ GO7007_MPEG4_PROFILE_S_L0
|
|
|
|
+ GO7007_MPEG4_PROFILE_S_L1
|
|
|
|
+ GO7007_MPEG4_PROFILE_S_L2
|
|
|
|
+ GO7007_MPEG4_PROFILE_S_L3
|
|
|
|
+ GO7007_MPEG4_PROFILE_ARTS_L1
|
|
|
|
+ GO7007_MPEG4_PROFILE_ARTS_L2
|
|
|
|
+ GO7007_MPEG4_PROFILE_ARTS_L3
|
|
|
|
+ GO7007_MPEG4_PROFILE_ARTS_L4
|
|
|
|
+ GO7007_MPEG4_PROFILE_AS_L0
|
|
|
|
+ GO7007_MPEG4_PROFILE_AS_L1
|
|
|
|
+ GO7007_MPEG4_PROFILE_AS_L2
|
|
|
|
+ GO7007_MPEG4_PROFILE_AS_L3
|
|
|
|
+ GO7007_MPEG4_PROFILE_AS_L4
|
|
|
|
+ GO7007_MPEG4_PROFILE_AS_L5
|
|
|
|
+
|
|
|
|
+ Flags in struct go7007_mpeg_params:
|
|
|
|
+
|
|
|
|
+ GO7007_MPEG_FORCE_DVD_MODE Force all compression parameters and
|
|
|
|
+ bitrate control settings to comply
|
|
|
|
+ with DVD MPEG2 stream requirements.
|
|
|
|
+ This overrides most compression and
|
|
|
|
+ bitrate settings!
|
|
|
|
+
|
|
|
|
+ GO7007_MPEG_OMIT_GOP_HEADER Omit the GOP header.
|
|
|
|
+
|
|
|
|
+ GO7007_MPEG_REPEAT_SEQHEADER Repeat the MPEG sequence header at
|
|
|
|
+ the start of each GOP.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ GO7007IOC_S_BITRATE, GO7007IOC_G_BITRATE
|
|
|
|
+
|
|
|
|
+ These ioctls are used to set and query the target bitrate value for the
|
|
|
|
+ compressed video stream. The bitrate may be selected by storing the
|
|
|
|
+ target bits per second in an int and calling GO7007IOC_S_BITRATE with a
|
|
|
|
+ pointer to the int. The bitrate may be queried by calling
|
|
|
|
+ GO7007IOC_G_BITRATE with a pointer to an int where the current bitrate
|
|
|
|
+ will be stored.
|
|
|
|
+
|
|
|
|
+ Note that this is the primary means of controlling the video quality
|
|
|
|
+ for all compression modes, including V4L2_PIX_FMT_MJPEG. The
|
|
|
|
+ VIDIOC_S_JPEGCOMP ioctl is not supported.
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+----------------------------------------------------------------------------
|
|
|
|
+ Installing the WIS PCI Voyager Driver
|
|
|
|
+---------------------------------------------------------------------------
|
|
|
|
+
|
|
|
|
+The WIS PCI Voyager driver requires several patches to the Linux 2.6.11.x
|
|
|
|
+kernel source tree before compiling the driver. These patches update the
|
|
|
|
+in-kernel SAA7134 driver to the newest development version and patch bugs
|
|
|
|
+in the TDA8290/TDA8275 tuner driver.
|
|
|
|
+
|
|
|
|
+The following patches must be downloaded from Gerd Knorr's website and
|
|
|
|
+applied in the order listed:
|
|
|
|
+
|
|
|
|
+ http://dl.bytesex.org/patches/2.6.11-2/i2c-tuner
|
|
|
|
+ http://dl.bytesex.org/patches/2.6.11-2/i2c-tuner2
|
|
|
|
+ http://dl.bytesex.org/patches/2.6.11-2/v4l2-api-mpeg
|
|
|
|
+ http://dl.bytesex.org/patches/2.6.11-2/saa7134-update
|
|
|
|
+
|
|
|
|
+The following patches are included with this SDK and can be applied in any
|
|
|
|
+order:
|
|
|
|
+
|
|
|
|
+ patches/2.6.11/saa7134-voyager.diff
|
|
|
|
+ patches/2.6.11/tda8275-newaddr.diff
|
|
|
|
+ patches/2.6.11/tda8290-ntsc.diff
|
|
|
|
+
|
|
|
|
+Check to make sure the CONFIG_VIDEO_SAA7134 option is enabled in the kernel
|
|
|
|
+configuration, and build and install the kernel.
|
|
|
|
+
|
|
|
|
+After rebooting into the new kernel, the GO7007 driver can be compiled and
|
|
|
|
+installed:
|
|
|
|
+
|
|
|
|
+ $ make SAA7134_BUILD=y
|
|
|
|
+ $ make install
|
|
|
|
+ $ modprobe saa7134-go7007
|
|
|
|
+
|
|
|
|
+There will be two V4L video devices associated with the PCI Voyager. The
|
|
|
|
+first device (most likely /dev/video0) provides access to the raw video
|
|
|
|
+capture mode of the SAA7133 device and is used to configure the source
|
|
|
|
+video parameters and tune the TV tuner. This device can be used with xawtv
|
|
|
|
+or other V4L(2) video software as a standard uncompressed device.
|
|
|
|
+
|
|
|
|
+The second device (most likely /dev/video1) provides access to the
|
|
|
|
+compression functions of the GO7007. It can be tested using the gorecord
|
|
|
|
+application in the apps/ directory of this SDK:
|
|
|
|
+
|
|
|
|
+ $ apps/gorecord -vdevice /dev/video1 -noaudio test.avi
|
|
|
|
+
|
|
|
|
+Currently the frame resolution is fixed at 720x480 (NTSC) or 720x576 (PAL),
|
|
|
|
+and the video standard must be specified to both the raw and the compressed
|
|
|
|
+video devices (xawtv and gorecord, for example).
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+--------------------------------------------------------------------------
|
|
|
|
+RELEASE NOTES FOR WIS GO7007SB LINUX DRIVER
|
|
|
|
+---------------------------------------------------------------------------
|
|
|
|
+
|
|
|
|
+Last updated: 5 November 2005
|
|
|
|
+
|
|
|
|
+ - Release 0.9.7 includes new support for using udev to run fxload. The
|
|
|
|
+ install script should automatically detect whether the old hotplug
|
|
|
|
+ scripts or the new udev rules should be used. To force the use of
|
|
|
|
+ hotplug, run "make install USE_UDEV=n". To force the use of udev, run
|
|
|
|
+ "make install USE_UDEV=y".
|
|
|
|
+
|
|
|
|
+ - Motion detection is supported but undocumented. Try the `modet` app
|
|
|
|
+ for a demonstration of how to use the facility.
|
|
|
|
+
|
|
|
|
+ - Using USB2.0 devices such as the TV402U with USB1.1 HCDs or hubs can
|
|
|
|
+ cause buffer overruns and frame drops, even at low framerates, due to
|
|
|
|
+ inconsistency in the bitrate control mechanism.
|
|
|
|
+
|
|
|
|
+ - On devices with an SAA7115, including the Plextor ConvertX, video height
|
|
|
|
+ values of 96, 128, 160, 192, 256, 320, and 384 do not work in NTSC mode.
|
|
|
|
+ All valid heights up to 512 work correctly in PAL mode.
|
|
|
|
+
|
|
|
|
+ - The WIS Star Trek and PCI Voyager boards have no support yet for audio
|
|
|
|
+ or the TV tuner.
|