mirror of
https://github.com/AetherDroid/android_kernel_samsung_on5xelte.git
synced 2025-10-30 15:48:52 +01:00
Fixed MTP to work with TWRP
This commit is contained in:
commit
f6dfaef42e
50820 changed files with 20846062 additions and 0 deletions
236
drivers/media/usb/pwc/philips.txt
Normal file
236
drivers/media/usb/pwc/philips.txt
Normal file
|
|
@ -0,0 +1,236 @@
|
|||
This file contains some additional information for the Philips and OEM webcams.
|
||||
E-mail: webcam@smcc.demon.nl Last updated: 2004-01-19
|
||||
Site: http://www.smcc.demon.nl/webcam/
|
||||
|
||||
As of this moment, the following cameras are supported:
|
||||
* Philips PCA645
|
||||
* Philips PCA646
|
||||
* Philips PCVC675
|
||||
* Philips PCVC680
|
||||
* Philips PCVC690
|
||||
* Philips PCVC720/40
|
||||
* Philips PCVC730
|
||||
* Philips PCVC740
|
||||
* Philips PCVC750
|
||||
* Askey VC010
|
||||
* Creative Labs Webcam 5
|
||||
* Creative Labs Webcam Pro Ex
|
||||
* Logitech QuickCam 3000 Pro
|
||||
* Logitech QuickCam 4000 Pro
|
||||
* Logitech QuickCam Notebook Pro
|
||||
* Logitech QuickCam Zoom
|
||||
* Logitech QuickCam Orbit
|
||||
* Logitech QuickCam Sphere
|
||||
* Samsung MPC-C10
|
||||
* Samsung MPC-C30
|
||||
* Sotec Afina Eye
|
||||
* AME CU-001
|
||||
* Visionite VCS-UM100
|
||||
* Visionite VCS-UC300
|
||||
|
||||
The main webpage for the Philips driver is at the address above. It contains
|
||||
a lot of extra information, a FAQ, and the binary plugin 'PWCX'. This plugin
|
||||
contains decompression routines that allow you to use higher image sizes and
|
||||
framerates; in addition the webcam uses less bandwidth on the USB bus (handy
|
||||
if you want to run more than 1 camera simultaneously). These routines fall
|
||||
under a NDA, and may therefore not be distributed as source; however, its use
|
||||
is completely optional.
|
||||
|
||||
You can build this code either into your kernel, or as a module. I recommend
|
||||
the latter, since it makes troubleshooting a lot easier. The built-in
|
||||
microphone is supported through the USB Audio class.
|
||||
|
||||
When you load the module you can set some default settings for the
|
||||
camera; some programs depend on a particular image-size or -format and
|
||||
don't know how to set it properly in the driver. The options are:
|
||||
|
||||
size
|
||||
Can be one of 'sqcif', 'qsif', 'qcif', 'sif', 'cif' or
|
||||
'vga', for an image size of resp. 128x96, 160x120, 176x144,
|
||||
320x240, 352x288 and 640x480 (of course, only for those cameras that
|
||||
support these resolutions).
|
||||
|
||||
fps
|
||||
Specifies the desired framerate. Is an integer in the range of 4-30.
|
||||
|
||||
fbufs
|
||||
This parameter specifies the number of internal buffers to use for storing
|
||||
frames from the cam. This will help if the process that reads images from
|
||||
the cam is a bit slow or momentarily busy. However, on slow machines it
|
||||
only introduces lag, so choose carefully. The default is 3, which is
|
||||
reasonable. You can set it between 2 and 5.
|
||||
|
||||
mbufs
|
||||
This is an integer between 1 and 10. It will tell the module the number of
|
||||
buffers to reserve for mmap(), VIDIOCCGMBUF, VIDIOCMCAPTURE and friends.
|
||||
The default is 2, which is adequate for most applications (double
|
||||
buffering).
|
||||
|
||||
Should you experience a lot of 'Dumping frame...' messages during
|
||||
grabbing with a tool that uses mmap(), you might want to increase if.
|
||||
However, it doesn't really buffer images, it just gives you a bit more
|
||||
slack when your program is behind. But you need a multi-threaded or
|
||||
forked program to really take advantage of these buffers.
|
||||
|
||||
The absolute maximum is 10, but don't set it too high! Every buffer takes
|
||||
up 460 KB of RAM, so unless you have a lot of memory setting this to
|
||||
something more than 4 is an absolute waste. This memory is only
|
||||
allocated during open(), so nothing is wasted when the camera is not in
|
||||
use.
|
||||
|
||||
power_save
|
||||
When power_save is enabled (set to 1), the module will try to shut down
|
||||
the cam on close() and re-activate on open(). This will save power and
|
||||
turn off the LED. Not all cameras support this though (the 645 and 646
|
||||
don't have power saving at all), and some models don't work either (they
|
||||
will shut down, but never wake up). Consider this experimental. By
|
||||
default this option is disabled.
|
||||
|
||||
compression (only useful with the plugin)
|
||||
With this option you can control the compression factor that the camera
|
||||
uses to squeeze the image through the USB bus. You can set the
|
||||
parameter between 0 and 3:
|
||||
0 = prefer uncompressed images; if the requested mode is not available
|
||||
in an uncompressed format, the driver will silently switch to low
|
||||
compression.
|
||||
1 = low compression.
|
||||
2 = medium compression.
|
||||
3 = high compression.
|
||||
|
||||
High compression takes less bandwidth of course, but it could also
|
||||
introduce some unwanted artefacts. The default is 2, medium compression.
|
||||
See the FAQ on the website for an overview of which modes require
|
||||
compression.
|
||||
|
||||
The compression parameter does not apply to the 645 and 646 cameras
|
||||
and OEM models derived from those (only a few). Most cams honour this
|
||||
parameter.
|
||||
|
||||
leds
|
||||
This settings takes 2 integers, that define the on/off time for the LED
|
||||
(in milliseconds). One of the interesting things that you can do with
|
||||
this is let the LED blink while the camera is in use. This:
|
||||
|
||||
leds=500,500
|
||||
|
||||
will blink the LED once every second. But with:
|
||||
|
||||
leds=0,0
|
||||
|
||||
the LED never goes on, making it suitable for silent surveillance.
|
||||
|
||||
By default the camera's LED is on solid while in use, and turned off
|
||||
when the camera is not used anymore.
|
||||
|
||||
This parameter works only with the ToUCam range of cameras (720, 730, 740,
|
||||
750) and OEMs. For other cameras this command is silently ignored, and
|
||||
the LED cannot be controlled.
|
||||
|
||||
Finally: this parameters does not take effect UNTIL the first time you
|
||||
open the camera device. Until then, the LED remains on.
|
||||
|
||||
dev_hint
|
||||
A long standing problem with USB devices is their dynamic nature: you
|
||||
never know what device a camera gets assigned; it depends on module load
|
||||
order, the hub configuration, the order in which devices are plugged in,
|
||||
and the phase of the moon (i.e. it can be random). With this option you
|
||||
can give the driver a hint as to what video device node (/dev/videoX) it
|
||||
should use with a specific camera. This is also handy if you have two
|
||||
cameras of the same model.
|
||||
|
||||
A camera is specified by its type (the number from the camera model,
|
||||
like PCA645, PCVC750VC, etc) and optionally the serial number (visible
|
||||
in /proc/bus/usb/devices). A hint consists of a string with the following
|
||||
format:
|
||||
|
||||
[type[.serialnumber]:]node
|
||||
|
||||
The square brackets mean that both the type and the serialnumber are
|
||||
optional, but a serialnumber cannot be specified without a type (which
|
||||
would be rather pointless). The serialnumber is separated from the type
|
||||
by a '.'; the node number by a ':'.
|
||||
|
||||
This somewhat cryptic syntax is best explained by a few examples:
|
||||
|
||||
dev_hint=3,5 The first detected cam gets assigned
|
||||
/dev/video3, the second /dev/video5. Any
|
||||
other cameras will get the first free
|
||||
available slot (see below).
|
||||
|
||||
dev_hint=645:1,680:2 The PCA645 camera will get /dev/video1,
|
||||
and a PCVC680 /dev/video2.
|
||||
|
||||
dev_hint=645.0123:3,645.4567:0 The PCA645 camera with serialnumber
|
||||
0123 goes to /dev/video3, the same
|
||||
camera model with the 4567 serial
|
||||
gets /dev/video0.
|
||||
|
||||
dev_hint=750:1,4,5,6 The PCVC750 camera will get /dev/video1, the
|
||||
next 3 Philips cams will use /dev/video4
|
||||
through /dev/video6.
|
||||
|
||||
Some points worth knowing:
|
||||
- Serialnumbers are case sensitive and must be written full, including
|
||||
leading zeroes (it's treated as a string).
|
||||
- If a device node is already occupied, registration will fail and
|
||||
the webcam is not available.
|
||||
- You can have up to 64 video devices; be sure to make enough device
|
||||
nodes in /dev if you want to spread the numbers.
|
||||
After /dev/video9 comes /dev/video10 (not /dev/videoA).
|
||||
- If a camera does not match any dev_hint, it will simply get assigned
|
||||
the first available device node, just as it used to be.
|
||||
|
||||
trace
|
||||
In order to better detect problems, it is now possible to turn on a
|
||||
'trace' of some of the calls the module makes; it logs all items in your
|
||||
kernel log at debug level.
|
||||
|
||||
The trace variable is a bitmask; each bit represents a certain feature.
|
||||
If you want to trace something, look up the bit value(s) in the table
|
||||
below, add the values together and supply that to the trace variable.
|
||||
|
||||
Value Value Description Default
|
||||
(dec) (hex)
|
||||
1 0x1 Module initialization; this will log messages On
|
||||
while loading and unloading the module
|
||||
|
||||
2 0x2 probe() and disconnect() traces On
|
||||
|
||||
4 0x4 Trace open() and close() calls Off
|
||||
|
||||
8 0x8 read(), mmap() and associated ioctl() calls Off
|
||||
|
||||
16 0x10 Memory allocation of buffers, etc. Off
|
||||
|
||||
32 0x20 Showing underflow, overflow and Dumping frame On
|
||||
messages
|
||||
|
||||
64 0x40 Show viewport and image sizes Off
|
||||
|
||||
128 0x80 PWCX debugging Off
|
||||
|
||||
For example, to trace the open() & read() functions, sum 8 + 4 = 12,
|
||||
so you would supply trace=12 during insmod or modprobe. If
|
||||
you want to turn the initialization and probing tracing off, set trace=0.
|
||||
The default value for trace is 35 (0x23).
|
||||
|
||||
|
||||
|
||||
Example:
|
||||
|
||||
# modprobe pwc size=cif fps=15 power_save=1
|
||||
|
||||
The fbufs, mbufs and trace parameters are global and apply to all connected
|
||||
cameras. Each camera has its own set of buffers.
|
||||
|
||||
size and fps only specify defaults when you open() the device; this is to
|
||||
accommodate some tools that don't set the size. You can change these
|
||||
settings after open() with the Video4Linux ioctl() calls. The default of
|
||||
defaults is QCIF size at 10 fps.
|
||||
|
||||
The compression parameter is semiglobal; it sets the initial compression
|
||||
preference for all camera's, but this parameter can be set per camera with
|
||||
the VIDIOCPWCSCQUAL ioctl() call.
|
||||
|
||||
All parameters are optional.
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue