2006-04-24 17:29:46 +04:00
# ifndef PWC_IOCTL_H
# define PWC_IOCTL_H
/* (C) 2001-2004 Nemosoft Unv.
( C ) 2004 - 2006 Luc Saillard ( luc @ saillard . org )
NOTE : this version of pwc is an unofficial ( modified ) release of pwc & pcwx
driver and thus may have bugs that are not present in the original version .
Please send bug reports and support requests to < luc @ saillard . org > .
The decompression routines have been implemented by reverse - engineering the
Nemosoft binary pwcx module . Caveat emptor .
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 . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
/* This is pwc-ioctl.h belonging to PWC 10.0.10
It contains structures and defines to communicate from user space
directly to the driver .
*/
/*
Changes
2001 / 08 / 03 Alvarado Added ioctl constants to access methods for
changing white balance and red / blue gains
2002 / 12 / 15 G . H . Fernandez - Toribio VIDIOCGREALSIZE
2003 / 12 / 13 Nemosft Unv . Some modifications to make interfacing to
PWCX easier
2006 / 01 / 01 Luc Saillard Add raw format definition
*/
/* These are private ioctl() commands, specific for the Philips webcams.
They contain functions not found in other webcams , and settings not
specified in the Video4Linux API .
The # define names are built up like follows :
VIDIOC VIDeo IOCtl prefix
PWC Philps WebCam
G optional : Get
S optional : Set
. . . the function
*/
# include <linux/types.h>
2008-07-18 07:50:58 +04:00
/* Enumeration of image sizes */
2006-04-24 17:29:46 +04:00
# define PSZ_SQCIF 0x00
# define PSZ_QSIF 0x01
# define PSZ_QCIF 0x02
# define PSZ_SIF 0x03
# define PSZ_CIF 0x04
# define PSZ_VGA 0x05
# define PSZ_MAX 6
/* The frame rate is encoded in the video_window.flags parameter using
the upper 16 bits , since some flags are defined nowadays . The following
defines provide a mask and shift to filter out this value .
This value can also be passing using the private flag when using v4l2 and
VIDIOC_S_FMT ioctl .
In ' Snapshot ' mode the camera freezes its automatic exposure and colour
balance controls .
*/
# define PWC_FPS_SHIFT 16
# define PWC_FPS_MASK 0x00FF0000
# define PWC_FPS_FRMASK 0x003F0000
# define PWC_FPS_SNAPSHOT 0x00400000
# define PWC_QLT_MASK 0x03000000
# define PWC_QLT_SHIFT 24
/* structure for transferring x & y coordinates */
struct pwc_coord
{
int x , y ; /* guess what */
int size ; /* size, or offset */
} ;
/* Used with VIDIOCPWCPROBE */
struct pwc_probe
{
char name [ 32 ] ;
int type ;
} ;
struct pwc_serial
{
char serial [ 30 ] ; /* String with serial number. Contains terminating 0 */
} ;
/* pwc_whitebalance.mode values */
# define PWC_WB_INDOOR 0
# define PWC_WB_OUTDOOR 1
# define PWC_WB_FL 2
# define PWC_WB_MANUAL 3
# define PWC_WB_AUTO 4
/* Used with VIDIOCPWC[SG]AWB (Auto White Balance).
Set mode to one of the PWC_WB_ * values above .
* red and * blue are the respective gains of these colour components inside
the camera ; range 0. .65535
When ' mode ' = = PWC_WB_MANUAL , ' manual_red ' and ' manual_blue ' are set or read ;
otherwise undefined .
' read_red ' and ' read_blue ' are read - only .
*/
struct pwc_whitebalance
{
int mode ;
int manual_red , manual_blue ; /* R/W */
int read_red , read_blue ; /* R/O */
} ;
/*
' control_speed ' and ' control_delay ' are used in automatic whitebalance mode ,
and tell the camera how fast it should react to changes in lighting , and
with how much delay . Valid values are 0. .65535 .
*/
struct pwc_wb_speed
{
int control_speed ;
int control_delay ;
} ;
/* Used with VIDIOCPWC[SG]LED */
struct pwc_leds
{
int led_on ; /* Led on-time; range = 0..25000 */
int led_off ; /* Led off-time; range = 0..25000 */
} ;
/* Image size (used with GREALSIZE) */
struct pwc_imagesize
{
int width ;
int height ;
} ;
/* Defines and structures for Motorized Pan & Tilt */
# define PWC_MPT_PAN 0x01
# define PWC_MPT_TILT 0x02
# define PWC_MPT_TIMEOUT 0x04 /* for status */
/* Set angles; when absolute != 0, the angle is absolute and the
driver calculates the relative offset for you . This can only
be used with VIDIOCPWCSANGLE ; VIDIOCPWCGANGLE always returns
absolute angles .
*/
struct pwc_mpt_angles
{
int absolute ; /* write-only */
int pan ; /* degrees * 100 */
int tilt ; /* degress * 100 */
} ;
/* Range of angles of the camera, both horizontally and vertically.
*/
struct pwc_mpt_range
{
int pan_min , pan_max ; /* degrees * 100 */
int tilt_min , tilt_max ;
} ;
struct pwc_mpt_status
{
int status ;
int time_pan ;
int time_tilt ;
} ;
/* This is used for out-of-kernel decompression. With it, you can get
all the necessary information to initialize and use the decompressor
routines in standalone applications .
*/
struct pwc_video_command
{
int type ; /* camera type (645, 675, 730, etc.) */
int release ; /* release number */
int size ; /* one of PSZ_* */
int alternate ;
int command_len ; /* length of USB video command */
unsigned char command_buf [ 13 ] ; /* Actual USB video command */
int bandlength ; /* >0 = compressed */
int frame_size ; /* Size of one (un)compressed frame */
} ;
/* Flags for PWCX subroutines. Not all modules honour all flags. */
# define PWCX_FLAG_PLANAR 0x0001
# define PWCX_FLAG_BAYER 0x0008
/* IOCTL definitions */
/* Restore user settings */
# define VIDIOCPWCRUSER _IO('v', 192)
/* Save user settings */
# define VIDIOCPWCSUSER _IO('v', 193)
/* Restore factory settings */
# define VIDIOCPWCFACTORY _IO('v', 194)
/* You can manipulate the compression factor. A compression preference of 0
means use uncompressed modes when available ; 1 is low compression , 2 is
medium and 3 is high compression preferred . Of course , the higher the
compression , the lower the bandwidth used but more chance of artefacts
in the image . The driver automatically chooses a higher compression when
the preferred mode is not available .
*/
/* Set preferred compression quality (0 = uncompressed, 3 = highest compression) */
# define VIDIOCPWCSCQUAL _IOW('v', 195, int)
/* Get preferred compression quality */
# define VIDIOCPWCGCQUAL _IOR('v', 195, int)
/* Retrieve serial number of camera */
# define VIDIOCPWCGSERIAL _IOR('v', 198, struct pwc_serial)
/* This is a probe function; since so many devices are supported, it
becomes difficult to include all the names in programs that want to
check for the enhanced Philips stuff . So in stead , try this PROBE ;
it returns a structure with the original name , and the corresponding
Philips type .
To use , fill the structure with zeroes , call PROBE and if that succeeds ,
compare the name with that returned from VIDIOCGCAP ; they should be the
same . If so , you can be assured it is a Philips ( OEM ) cam and the type
is valid .
*/
# define VIDIOCPWCPROBE _IOR('v', 199, struct pwc_probe)
/* Set AGC (Automatic Gain Control); int < 0 = auto, 0..65535 = fixed */
# define VIDIOCPWCSAGC _IOW('v', 200, int)
/* Get AGC; int < 0 = auto; >= 0 = fixed, range 0..65535 */
# define VIDIOCPWCGAGC _IOR('v', 200, int)
/* Set shutter speed; int < 0 = auto; >= 0 = fixed, range 0..65535 */
# define VIDIOCPWCSSHUTTER _IOW('v', 201, int)
/* Color compensation (Auto White Balance) */
# define VIDIOCPWCSAWB _IOW('v', 202, struct pwc_whitebalance)
# define VIDIOCPWCGAWB _IOR('v', 202, struct pwc_whitebalance)
/* Auto WB speed */
# define VIDIOCPWCSAWBSPEED _IOW('v', 203, struct pwc_wb_speed)
# define VIDIOCPWCGAWBSPEED _IOR('v', 203, struct pwc_wb_speed)
/* LEDs on/off/blink; int range 0..65535 */
# define VIDIOCPWCSLED _IOW('v', 205, struct pwc_leds)
# define VIDIOCPWCGLED _IOR('v', 205, struct pwc_leds)
/* Contour (sharpness); int < 0 = auto, 0..65536 = fixed */
# define VIDIOCPWCSCONTOUR _IOW('v', 206, int)
# define VIDIOCPWCGCONTOUR _IOR('v', 206, int)
/* Backlight compensation; 0 = off, otherwise on */
# define VIDIOCPWCSBACKLIGHT _IOW('v', 207, int)
# define VIDIOCPWCGBACKLIGHT _IOR('v', 207, int)
/* Flickerless mode; = 0 off, otherwise on */
# define VIDIOCPWCSFLICKER _IOW('v', 208, int)
# define VIDIOCPWCGFLICKER _IOR('v', 208, int)
/* Dynamic noise reduction; 0 off, 3 = high noise reduction */
# define VIDIOCPWCSDYNNOISE _IOW('v', 209, int)
# define VIDIOCPWCGDYNNOISE _IOR('v', 209, int)
/* Real image size as used by the camera; tells you whether or not there's a gray border around the image */
# define VIDIOCPWCGREALSIZE _IOR('v', 210, struct pwc_imagesize)
/* Motorized pan & tilt functions */
# define VIDIOCPWCMPTRESET _IOW('v', 211, int)
# define VIDIOCPWCMPTGRANGE _IOR('v', 211, struct pwc_mpt_range)
# define VIDIOCPWCMPTSANGLE _IOW('v', 212, struct pwc_mpt_angles)
# define VIDIOCPWCMPTGANGLE _IOR('v', 212, struct pwc_mpt_angles)
# define VIDIOCPWCMPTSTATUS _IOR('v', 213, struct pwc_mpt_status)
/* Get the USB set-video command; needed for initializing libpwcx */
# define VIDIOCPWCGVIDCMD _IOR('v', 215, struct pwc_video_command)
struct pwc_table_init_buffer {
int len ;
char * buffer ;
} ;
# define VIDIOCPWCGVIDTABLE _IOR('v', 216, struct pwc_table_init_buffer)
/*
* This is private command used when communicating with v4l2 .
* In the future all private ioctl will be remove / replace to
* use interface offer by v4l2 .
*/
# define V4L2_CID_PRIVATE_SAVE_USER (V4L2_CID_PRIVATE_BASE + 0)
# define V4L2_CID_PRIVATE_RESTORE_USER (V4L2_CID_PRIVATE_BASE + 1)
# define V4L2_CID_PRIVATE_RESTORE_FACTORY (V4L2_CID_PRIVATE_BASE + 2)
# define V4L2_CID_PRIVATE_COLOUR_MODE (V4L2_CID_PRIVATE_BASE + 3)
# define V4L2_CID_PRIVATE_AUTOCONTOUR (V4L2_CID_PRIVATE_BASE + 4)
# define V4L2_CID_PRIVATE_CONTOUR (V4L2_CID_PRIVATE_BASE + 5)
# define V4L2_CID_PRIVATE_BACKLIGHT (V4L2_CID_PRIVATE_BASE + 6)
# define V4L2_CID_PRIVATE_FLICKERLESS (V4L2_CID_PRIVATE_BASE + 7)
# define V4L2_CID_PRIVATE_NOISE_REDUCTION (V4L2_CID_PRIVATE_BASE + 8)
struct pwc_raw_frame {
__le16 type ; /* type of the webcam */
__le16 vbandlength ; /* Size of 4lines compressed (used by the decompressor) */
__u8 cmd [ 4 ] ; /* the four byte of the command (in case of nala,
only the first 3 bytes is filled ) */
__u8 rawframe [ 0 ] ; /* frame_size = H/4*vbandlength */
} __attribute__ ( ( packed ) ) ;
# endif