SyntekUSBVideoCamera
Functions
stk11xx-dev-6a33.c File Reference

Driver for Syntek USB video camera. More...

#include <linux/module.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/version.h>
#include <linux/errno.h>
#include <linux/slab.h>
#include <linux/kref.h>
#include <linux/usb.h>
#include <media/v4l2-common.h>
#include <media/v4l2-ioctl.h>
#include "stk11xx.h"
#include "stk11xx-dev.h"

Go to the source code of this file.

Functions

int dev_stk6a33_initialize_device (struct usb_stk11xx *dev)
 This function permits to initialize the device.
int dev_stk6a33_configure_device (struct usb_stk11xx *dev, int step)
 This function permits to configure the device.
int dev_stk6a33_camera_asleep (struct usb_stk11xx *dev)
 Wake-up the camera.
int dev_stk6a33_init_camera (struct usb_stk11xx *dev)
 This function initializes the device for the stream.
int dev_stk6a33_sensor_settings (struct usb_stk11xx *dev)
 This function permits to set default sensor settings.
int dev_stk6a33_camera_settings (struct usb_stk11xx *dev)
 This function permits to modify the settings of the camera.
int dev_stk6a33_set_camera_quality (struct usb_stk11xx *dev)
 This function permits to modify the settings of the camera.
int dev_stk6a33_set_camera_fps (struct usb_stk11xx *dev)
 This function permits to modify the settings of the camera.
int dev_stk6a33_start_stream (struct usb_stk11xx *dev)
 This function sets the device to start the stream.
int dev_stk6a33_reconf_camera (struct usb_stk11xx *dev)
 Reconfigure the camera before the stream.
int dev_stk6a33_stop_stream (struct usb_stk11xx *dev)
 This function sets the device to stop the stream.

Detailed Description

Driver for Syntek USB video camera.

Author:
Nicolas VIVIEN
Date:
2006-10-23
Version:
v2.0.x
Note:
Copyright (C) Nicolas VIVIEN
Licences

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 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

SubVersion
Date:
2009-03-25 15:13:05 +0100 (mer 25 mar 2009)
Revision:
84
Author:
nicklas79
HeadURL:
https://syntekdriver.svn.sourceforge.net/svnroot/syntekdriver/tags/2.1.0/stk11xx-dev-6a33.c

Definition in file stk11xx-dev-6a33.c.


Function Documentation

int dev_stk6a33_camera_asleep ( struct usb_stk11xx dev)

Wake-up the camera.

Parameters:
devDevice structure
Returns:
0 if all is OK

This function permits to wake-up the device.

Definition at line 652 of file stk11xx-dev-6a33.c.

References usb_stk11xx_read_registry(), and usb_stk11xx_write_registry().

Referenced by dev_stk11xx_camera_asleep(), dev_stk6a33_init_camera(), and dev_stk6a33_initialize_device().

int dev_stk6a33_camera_settings ( struct usb_stk11xx dev)

This function permits to modify the settings of the camera.

Parameters:
devDevice structure
Returns:
0 if all is OK

This functions permits to modify the settings :

  • brightness
  • contrast
  • white balance
  • ...

Definition at line 821 of file stk11xx-dev-6a33.c.

References dev_stk11xx_check_device(), usb_stk11xx_read_registry(), and usb_stk11xx_write_registry().

Referenced by dev_stk11xx_camera_settings().

int dev_stk6a33_configure_device ( struct usb_stk11xx dev,
int  step 
)

This function permits to configure the device.

Parameters:
devDevice structure
stepThe step of configuration [0-11]
Returns:
0 if all is OK

The configuration of device is composed of 11 steps. This function is called by the initialization process.

We don't know the meaning of these steps ! We only replay the USB log.

The steps 0 to 9 are called during the initialization. Then, the driver choose the last step : 10 : for a resolution from 80x60 to 640x480 11 : for a resolution from 800x600 to 1280x1024

Definition at line 368 of file stk11xx-dev-6a33.c.

References dev_stk6a33_sensor_settings(), STK_DEBUG, usb_stk11xx_read_registry(), and usb_stk11xx_write_registry().

Referenced by dev_stk6a33_init_camera(), dev_stk6a33_initialize_device(), and dev_stk6a33_reconf_camera().

int dev_stk6a33_init_camera ( struct usb_stk11xx dev)

This function initializes the device for the stream.

Parameters:
devDevice structure
Returns:
0 if all is OK

It's the start. This function has to be called at first, before enabling the video stream.

Definition at line 682 of file stk11xx-dev-6a33.c.

References dev_stk11xx_camera_off(), dev_stk6a33_camera_asleep(), dev_stk6a33_configure_device(), usb_stk11xx_set_feature(), and usb_stk11xx_write_registry().

Referenced by dev_stk11xx_init_camera().

int dev_stk6a33_initialize_device ( struct usb_stk11xx dev)

This function permits to initialize the device.

Parameters:
devDevice structure
Returns:
0 if all is OK

This function must be called at first. It's the start of the initialization process. After this process, the device is completly initalized and it's ready.

This function is written from the USB log.

Definition at line 70 of file stk11xx-dev-6a33.c.

References dev_stk11xx_check_device(), dev_stk6a33_camera_asleep(), dev_stk6a33_configure_device(), STK_DEBUG, STK_INFO, usb_stk11xx_read_registry(), usb_stk11xx_set_feature(), and usb_stk11xx_write_registry().

Referenced by dev_stk11xx_initialize_device().

int dev_stk6a33_reconf_camera ( struct usb_stk11xx dev)

Reconfigure the camera before the stream.

Parameters:
devDevice structure
Returns:
0 if all is OK

Before enabling the video stream, you have to reconfigure the device.

Definition at line 967 of file stk11xx-dev-6a33.c.

References dev_stk11xx_camera_settings(), and dev_stk6a33_configure_device().

Referenced by dev_stk11xx_reconf_camera().

int dev_stk6a33_sensor_settings ( struct usb_stk11xx dev)

This function permits to set default sensor settings.

Parameters:
devDevice structure
Returns:
0 if all is OK

We set some registers in using a I2C bus. WARNING, the sensor settings can be different following the situation.

Definition at line 711 of file stk11xx-dev-6a33.c.

References dev_stk11xx_check_device(), STK_ERROR, usb_stk11xx_read_registry(), and usb_stk11xx_write_registry().

Referenced by dev_stk6a33_configure_device().

int dev_stk6a33_set_camera_fps ( struct usb_stk11xx dev)

This function permits to modify the settings of the camera.

Parameters:
devDevice structure
Returns:
0 if all is OK

This functions permits to modify the frame rate per second.

0x204 = 0x2e : Fps MSB (by default 0x01) 0x204 = 0x2d : Fps LSB (by default 0x00)

0x2e | 0x2d | Nbr fps -----+------+-------- 0x00 | 0x00 | 30 0x01 | 0x00 | 20 0x02 | 0x00 | 15 0x03 | 0x00 | 12 0x04 | 0x00 | 10

Definition at line 918 of file stk11xx-dev-6a33.c.

Referenced by dev_stk11xx_set_camera_fps().

int dev_stk6a33_set_camera_quality ( struct usb_stk11xx dev)

This function permits to modify the settings of the camera.

Parameters:
devDevice structure
Returns:
0 if all is OK

This functions permits to modify the settings :

  • brightness
  • contrast
  • white balance
  • ...

0x204 = 0xa1 : unkown (by default 0x00) 0x204 = 0x10 : contrast (by default 0x7c) 0x204 = 0x04 : Mode (unknown) (by default 0x00) (=> already looked 0x01 and 0x02) 0x204 = 0x00 : brightness / white balance (by default 0x00)

Definition at line 873 of file stk11xx-dev-6a33.c.

References stk11xx_video::brightness, stk11xx_video::colour, stk11xx_video::contrast, dev_stk11xx_check_device(), STK_DEBUG, usb_stk11xx_read_registry(), usb_stk11xx_write_registry(), usb_stk11xx::vsettings, and stk11xx_video::whiteness.

Referenced by dev_stk11xx_set_camera_quality().

int dev_stk6a33_start_stream ( struct usb_stk11xx dev)

This function sets the device to start the stream.

Parameters:
devDevice structure
Returns:
0 if all is OK

After the initialization of the device and the initialization of the video stream, this function permits to enable the stream.

Definition at line 934 of file stk11xx-dev-6a33.c.

References usb_stk11xx_read_registry(), and usb_stk11xx_write_registry().

Referenced by dev_stk11xx_start_stream().

int dev_stk6a33_stop_stream ( struct usb_stk11xx dev)

This function sets the device to stop the stream.

Parameters:
devDevice structure
Returns:
0 if all is OK

You use the function start_stream to enable the video stream. So you have to use the function stop_strem to disable the video stream.

Definition at line 987 of file stk11xx-dev-6a33.c.

References usb_stk11xx_read_registry(), and usb_stk11xx_write_registry().

Referenced by dev_stk11xx_stop_stream().