2008-04-23 01:42:03 +08:00
|
|
|
/*
|
|
|
|
* camera image capture (abstract) bus driver header
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006, Sascha Hauer, Pengutronix
|
|
|
|
* Copyright (C) 2008, Guennadi Liakhovetski <kernel@pengutronix.de>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SOC_CAMERA_H
|
|
|
|
#define SOC_CAMERA_H
|
|
|
|
|
|
|
|
#include <linux/videodev2.h>
|
2008-07-12 07:50:31 +08:00
|
|
|
#include <media/videobuf-core.h>
|
2008-08-02 07:14:50 +08:00
|
|
|
#include <linux/pm.h>
|
2008-04-23 01:42:03 +08:00
|
|
|
|
|
|
|
struct soc_camera_device {
|
|
|
|
struct list_head list;
|
|
|
|
struct device dev;
|
|
|
|
struct device *control;
|
|
|
|
unsigned short width; /* Current window */
|
|
|
|
unsigned short height; /* sizes */
|
|
|
|
unsigned short x_min; /* Camera capabilities */
|
|
|
|
unsigned short y_min;
|
|
|
|
unsigned short x_current; /* Current window location */
|
|
|
|
unsigned short y_current;
|
|
|
|
unsigned short width_min;
|
|
|
|
unsigned short width_max;
|
|
|
|
unsigned short height_min;
|
|
|
|
unsigned short height_max;
|
|
|
|
unsigned short y_skip_top; /* Lines to skip at the top */
|
|
|
|
unsigned short gain;
|
|
|
|
unsigned short exposure;
|
|
|
|
unsigned char iface; /* Host number */
|
|
|
|
unsigned char devnum; /* Device number per host */
|
2008-03-08 08:57:18 +08:00
|
|
|
unsigned char buswidth; /* See comment in .c */
|
2008-04-23 01:42:03 +08:00
|
|
|
struct soc_camera_ops *ops;
|
|
|
|
struct video_device *vdev;
|
|
|
|
const struct soc_camera_data_format *current_fmt;
|
2008-03-24 23:18:36 +08:00
|
|
|
const struct soc_camera_data_format *formats;
|
|
|
|
int num_formats;
|
2008-12-01 20:45:27 +08:00
|
|
|
struct soc_camera_format_xlate *user_formats;
|
|
|
|
int num_user_formats;
|
2008-04-23 01:42:03 +08:00
|
|
|
struct module *owner;
|
2008-12-01 20:45:24 +08:00
|
|
|
void *host_priv; /* per-device host private data */
|
2008-04-23 01:45:32 +08:00
|
|
|
/* soc_camera.c private count. Only accessed with video_lock held */
|
|
|
|
int use_count;
|
2008-04-23 01:42:03 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct soc_camera_file {
|
|
|
|
struct soc_camera_device *icd;
|
|
|
|
struct videobuf_queue vb_vidq;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct soc_camera_host {
|
|
|
|
struct list_head list;
|
|
|
|
struct device dev;
|
|
|
|
unsigned char nr; /* Host number */
|
|
|
|
void *priv;
|
V4L/DVB (9521): V4L: struct device - replace bus_id with dev_name(), dev_set_name()
This patch is part of a larger patch series which will remove
the "char bus_id[20]" name string from struct device. The device
name is managed in the kobject anyway, and without any size
limitation, and just needlessly copied into "struct device".
To set and read the device name dev_name(dev) and dev_set_name(dev)
must be used. If your code uses static kobjects, which it shouldn't
do, "const char *init_name" can be used to statically provide the
name the registered device should have. At registration time, the
init_name field is cleared, to enforce the use of dev_name(dev) to
access the device name at a later time.
We need to get rid of all occurrences of bus_id in the entire tree
to be able to enable the new interface. Please apply this patch,
and possibly convert any remaining remaining occurrences of bus_id.
We want to submit a patch to -next, which will remove bus_id from
"struct device", to find the remaining pieces to convert, and finally
switch over to the new api, which will remove the 20 bytes array
and does no longer have a size limitation.
Thanks,
Kay
Signed-off-by: Kay Sievers <kay.sievers@vrfy.org>
Acked-by: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2008-10-30 11:51:46 +08:00
|
|
|
const char *drv_name;
|
2008-04-05 00:41:25 +08:00
|
|
|
struct soc_camera_host_ops *ops;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct soc_camera_host_ops {
|
|
|
|
struct module *owner;
|
2008-04-23 01:42:03 +08:00
|
|
|
int (*add)(struct soc_camera_device *);
|
|
|
|
void (*remove)(struct soc_camera_device *);
|
2008-12-01 20:45:27 +08:00
|
|
|
int (*suspend)(struct soc_camera_device *, pm_message_t);
|
2008-08-02 07:14:50 +08:00
|
|
|
int (*resume)(struct soc_camera_device *);
|
2008-12-01 20:45:27 +08:00
|
|
|
int (*get_formats)(struct soc_camera_device *, int,
|
|
|
|
struct soc_camera_format_xlate *);
|
2008-12-01 20:45:21 +08:00
|
|
|
int (*set_fmt)(struct soc_camera_device *, __u32, struct v4l2_rect *);
|
|
|
|
int (*try_fmt)(struct soc_camera_device *, struct v4l2_format *);
|
2008-07-12 07:59:34 +08:00
|
|
|
void (*init_videobuf)(struct videobuf_queue *,
|
2008-07-12 07:50:31 +08:00
|
|
|
struct soc_camera_device *);
|
2008-04-23 01:42:03 +08:00
|
|
|
int (*reqbufs)(struct soc_camera_file *, struct v4l2_requestbuffers *);
|
|
|
|
int (*querycap)(struct soc_camera_host *, struct v4l2_capability *);
|
2008-03-08 08:57:18 +08:00
|
|
|
int (*set_bus_param)(struct soc_camera_device *, __u32);
|
2008-04-23 01:42:03 +08:00
|
|
|
unsigned int (*poll)(struct file *, poll_table *);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct soc_camera_link {
|
|
|
|
/* Camera bus id, used to match a camera and a bus */
|
|
|
|
int bus_id;
|
|
|
|
/* GPIO number to switch between 8 and 10 bit modes */
|
|
|
|
unsigned int gpio;
|
2008-08-14 23:04:11 +08:00
|
|
|
/* Optional callbacks to power on or off and reset the sensor */
|
|
|
|
int (*power)(struct device *, int);
|
|
|
|
int (*reset)(struct device *);
|
2008-04-23 01:42:03 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct soc_camera_device *to_soc_camera_dev(struct device *dev)
|
|
|
|
{
|
|
|
|
return container_of(dev, struct soc_camera_device, dev);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct soc_camera_host *to_soc_camera_host(struct device *dev)
|
|
|
|
{
|
|
|
|
return container_of(dev, struct soc_camera_host, dev);
|
|
|
|
}
|
|
|
|
|
2008-04-05 00:41:25 +08:00
|
|
|
extern int soc_camera_host_register(struct soc_camera_host *ici);
|
2008-04-23 01:42:03 +08:00
|
|
|
extern void soc_camera_host_unregister(struct soc_camera_host *ici);
|
|
|
|
extern int soc_camera_device_register(struct soc_camera_device *icd);
|
|
|
|
extern void soc_camera_device_unregister(struct soc_camera_device *icd);
|
|
|
|
|
|
|
|
extern int soc_camera_video_start(struct soc_camera_device *icd);
|
|
|
|
extern void soc_camera_video_stop(struct soc_camera_device *icd);
|
|
|
|
|
2008-12-01 20:44:59 +08:00
|
|
|
extern const struct soc_camera_data_format *soc_camera_format_by_fourcc(
|
|
|
|
struct soc_camera_device *icd, unsigned int fourcc);
|
2008-12-01 20:45:27 +08:00
|
|
|
extern const struct soc_camera_format_xlate *soc_camera_xlate_by_fourcc(
|
|
|
|
struct soc_camera_device *icd, unsigned int fourcc);
|
2008-12-01 20:44:59 +08:00
|
|
|
|
2008-04-23 01:42:03 +08:00
|
|
|
struct soc_camera_data_format {
|
V4L/DVB (9521): V4L: struct device - replace bus_id with dev_name(), dev_set_name()
This patch is part of a larger patch series which will remove
the "char bus_id[20]" name string from struct device. The device
name is managed in the kobject anyway, and without any size
limitation, and just needlessly copied into "struct device".
To set and read the device name dev_name(dev) and dev_set_name(dev)
must be used. If your code uses static kobjects, which it shouldn't
do, "const char *init_name" can be used to statically provide the
name the registered device should have. At registration time, the
init_name field is cleared, to enforce the use of dev_name(dev) to
access the device name at a later time.
We need to get rid of all occurrences of bus_id in the entire tree
to be able to enable the new interface. Please apply this patch,
and possibly convert any remaining remaining occurrences of bus_id.
We want to submit a patch to -next, which will remove bus_id from
"struct device", to find the remaining pieces to convert, and finally
switch over to the new api, which will remove the 20 bytes array
and does no longer have a size limitation.
Thanks,
Kay
Signed-off-by: Kay Sievers <kay.sievers@vrfy.org>
Acked-by: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2008-10-30 11:51:46 +08:00
|
|
|
const char *name;
|
2008-04-23 01:42:03 +08:00
|
|
|
unsigned int depth;
|
|
|
|
__u32 fourcc;
|
|
|
|
enum v4l2_colorspace colorspace;
|
|
|
|
};
|
|
|
|
|
2008-12-01 20:45:27 +08:00
|
|
|
/**
|
|
|
|
* struct soc_camera_format_xlate - match between host and sensor formats
|
|
|
|
* @cam_fmt: sensor format provided by the sensor
|
|
|
|
* @host_fmt: host format after host translation from cam_fmt
|
|
|
|
* @buswidth: bus width for this format
|
|
|
|
*
|
|
|
|
* Host and sensor translation structure. Used in table of host and sensor
|
|
|
|
* formats matchings in soc_camera_device. A host can override the generic list
|
|
|
|
* generation by implementing get_formats(), and use it for format checks and
|
|
|
|
* format setup.
|
|
|
|
*/
|
|
|
|
struct soc_camera_format_xlate {
|
|
|
|
const struct soc_camera_data_format *cam_fmt;
|
|
|
|
const struct soc_camera_data_format *host_fmt;
|
|
|
|
unsigned char buswidth;
|
|
|
|
};
|
|
|
|
|
2008-04-23 01:42:03 +08:00
|
|
|
struct soc_camera_ops {
|
|
|
|
struct module *owner;
|
2008-03-24 23:18:36 +08:00
|
|
|
int (*probe)(struct soc_camera_device *);
|
|
|
|
void (*remove)(struct soc_camera_device *);
|
2008-08-02 07:14:50 +08:00
|
|
|
int (*suspend)(struct soc_camera_device *, pm_message_t state);
|
|
|
|
int (*resume)(struct soc_camera_device *);
|
2008-04-23 01:42:03 +08:00
|
|
|
int (*init)(struct soc_camera_device *);
|
|
|
|
int (*release)(struct soc_camera_device *);
|
|
|
|
int (*start_capture)(struct soc_camera_device *);
|
|
|
|
int (*stop_capture)(struct soc_camera_device *);
|
2008-12-01 20:45:21 +08:00
|
|
|
int (*set_fmt)(struct soc_camera_device *, __u32, struct v4l2_rect *);
|
|
|
|
int (*try_fmt)(struct soc_camera_device *, struct v4l2_format *);
|
2008-03-08 08:57:18 +08:00
|
|
|
unsigned long (*query_bus_param)(struct soc_camera_device *);
|
|
|
|
int (*set_bus_param)(struct soc_camera_device *, unsigned long);
|
2008-04-23 01:42:03 +08:00
|
|
|
int (*get_chip_id)(struct soc_camera_device *,
|
|
|
|
struct v4l2_chip_ident *);
|
|
|
|
#ifdef CONFIG_VIDEO_ADV_DEBUG
|
|
|
|
int (*get_register)(struct soc_camera_device *, struct v4l2_register *);
|
|
|
|
int (*set_register)(struct soc_camera_device *, struct v4l2_register *);
|
|
|
|
#endif
|
|
|
|
int (*get_control)(struct soc_camera_device *, struct v4l2_control *);
|
|
|
|
int (*set_control)(struct soc_camera_device *, struct v4l2_control *);
|
|
|
|
const struct v4l2_queryctrl *controls;
|
|
|
|
int num_controls;
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct v4l2_queryctrl const *soc_camera_find_qctrl(
|
|
|
|
struct soc_camera_ops *ops, int id)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < ops->num_controls; i++)
|
|
|
|
if (ops->controls[i].id == id)
|
|
|
|
return &ops->controls[i];
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2008-03-08 08:57:18 +08:00
|
|
|
#define SOCAM_MASTER (1 << 0)
|
|
|
|
#define SOCAM_SLAVE (1 << 1)
|
|
|
|
#define SOCAM_HSYNC_ACTIVE_HIGH (1 << 2)
|
|
|
|
#define SOCAM_HSYNC_ACTIVE_LOW (1 << 3)
|
|
|
|
#define SOCAM_VSYNC_ACTIVE_HIGH (1 << 4)
|
|
|
|
#define SOCAM_VSYNC_ACTIVE_LOW (1 << 5)
|
|
|
|
#define SOCAM_DATAWIDTH_8 (1 << 6)
|
|
|
|
#define SOCAM_DATAWIDTH_9 (1 << 7)
|
|
|
|
#define SOCAM_DATAWIDTH_10 (1 << 8)
|
2008-07-12 08:03:25 +08:00
|
|
|
#define SOCAM_DATAWIDTH_16 (1 << 9)
|
|
|
|
#define SOCAM_PCLK_SAMPLE_RISING (1 << 10)
|
|
|
|
#define SOCAM_PCLK_SAMPLE_FALLING (1 << 11)
|
2008-03-08 08:57:18 +08:00
|
|
|
|
|
|
|
#define SOCAM_DATAWIDTH_MASK (SOCAM_DATAWIDTH_8 | SOCAM_DATAWIDTH_9 | \
|
2008-07-12 08:03:25 +08:00
|
|
|
SOCAM_DATAWIDTH_10 | SOCAM_DATAWIDTH_16)
|
2008-03-08 08:57:18 +08:00
|
|
|
|
|
|
|
static inline unsigned long soc_camera_bus_param_compatible(
|
|
|
|
unsigned long camera_flags, unsigned long bus_flags)
|
|
|
|
{
|
|
|
|
unsigned long common_flags, hsync, vsync, pclk;
|
|
|
|
|
|
|
|
common_flags = camera_flags & bus_flags;
|
|
|
|
|
|
|
|
hsync = common_flags & (SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_HSYNC_ACTIVE_LOW);
|
|
|
|
vsync = common_flags & (SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_LOW);
|
|
|
|
pclk = common_flags & (SOCAM_PCLK_SAMPLE_RISING | SOCAM_PCLK_SAMPLE_FALLING);
|
|
|
|
|
|
|
|
return (!hsync || !vsync || !pclk) ? 0 : common_flags;
|
|
|
|
}
|
2008-04-23 01:42:03 +08:00
|
|
|
|
|
|
|
#endif
|