Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 65889
b: refs/heads/master
c: 098c645
h: refs/heads/master
i:
  65887: 52c0c52
v: v3
  • Loading branch information
Sakari Ailus authored and Mauro Carvalho Chehab committed Oct 10, 2007
1 parent d3a6516 commit 3ec05af
Show file tree
Hide file tree
Showing 3 changed files with 81 additions and 55 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 588005e1008f2cea61b7a1ae2a86c531e99b8c9c
refs/heads/master: 098c645e39e10dc580763b5ea4bd4fb390013474
4 changes: 2 additions & 2 deletions trunk/drivers/media/video/v4l2-int-device.c
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,7 @@ int v4l2_int_ioctl_0(struct v4l2_int_device *d, int cmd)
{
return ((v4l2_int_ioctl_func_0 *)
find_ioctl(d->u.slave, cmd,
(v4l2_int_ioctl_func *)&no_such_ioctl_0))(d);
(v4l2_int_ioctl_func *)no_such_ioctl_0))(d);
}

static int no_such_ioctl_1(struct v4l2_int_device *d, void *arg)
Expand All @@ -162,5 +162,5 @@ int v4l2_int_ioctl_1(struct v4l2_int_device *d, int cmd, void *arg)
{
return ((v4l2_int_ioctl_func_1 *)
find_ioctl(d->u.slave, cmd,
(v4l2_int_ioctl_func *)&no_such_ioctl_1))(d, arg);
(v4l2_int_ioctl_func *)no_such_ioctl_1))(d, arg);
}
130 changes: 78 additions & 52 deletions trunk/include/media/v4l2-int-device.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,11 +30,84 @@

#define V4L2NAMESIZE 32

/*
*
* The internal V4L2 device interface core.
*
*/

enum v4l2_int_type {
v4l2_int_type_master = 1,
v4l2_int_type_slave
};

struct v4l2_int_device;

struct v4l2_int_master {
int (*attach)(struct v4l2_int_device *master,
struct v4l2_int_device *slave);
void (*detach)(struct v4l2_int_device *master);
};

typedef int (v4l2_int_ioctl_func)(struct v4l2_int_device *);
typedef int (v4l2_int_ioctl_func_0)(struct v4l2_int_device *);
typedef int (v4l2_int_ioctl_func_1)(struct v4l2_int_device *, void *);

struct v4l2_int_ioctl_desc {
int num;
v4l2_int_ioctl_func *func;
};

struct v4l2_int_slave {
/* Don't touch master. */
struct v4l2_int_device *master;

char attach_to[V4L2NAMESIZE];

int num_ioctls;
struct v4l2_int_ioctl_desc *ioctls;
};

struct v4l2_int_device {
/* Don't touch head. */
struct list_head head;

struct module *module;

char name[V4L2NAMESIZE];

enum v4l2_int_type type;
union {
struct v4l2_int_master *master;
struct v4l2_int_slave *slave;
} u;

void *priv;
};

int v4l2_int_device_register(struct v4l2_int_device *d);
void v4l2_int_device_unregister(struct v4l2_int_device *d);

int v4l2_int_ioctl_0(struct v4l2_int_device *d, int cmd);
int v4l2_int_ioctl_1(struct v4l2_int_device *d, int cmd, void *arg);

/*
*
* Types and definitions for IOCTL commands.
*
*/

/* Slave interface type. */
enum v4l2_if_type {
};

struct v4l2_ifparm {
enum v4l2_if_type if_type;
union {
} u;
};

/* IOCTL command numbers. */
enum v4l2_int_ioctl_num {
/*
*
Expand Down Expand Up @@ -62,10 +135,12 @@ enum v4l2_int_ioctl_num {
vidioc_int_dev_exit_num,
/* Set device power state: 0 is off, non-zero is on. */
vidioc_int_s_power_num,
/* Get parallel interface clock speed for current settings. */
/* Get slave interface parameters. */
vidioc_int_g_ifparm_num,
/* Get external clock speed for current slave settings. */
vidioc_int_g_ext_clk_num,
/*
* Tell what the parallel interface clock speed actually is.
* Tell what the generated interface clock speed actually is.
*/
vidioc_int_s_ext_clk_num,
/* Does the slave need to be reset after VIDIOC_DQBUF? */
Expand All @@ -91,56 +166,6 @@ enum v4l2_int_ioctl_num {
vidioc_int_priv_start_num = 2000,
};

struct v4l2_int_device;

struct v4l2_int_master {
int (*attach)(struct v4l2_int_device *master,
struct v4l2_int_device *slave);
void (*detach)(struct v4l2_int_device *master);
};

typedef int (v4l2_int_ioctl_func)(struct v4l2_int_device *);
typedef int (v4l2_int_ioctl_func_0)(struct v4l2_int_device *);
typedef int (v4l2_int_ioctl_func_1)(struct v4l2_int_device *, void *);

struct v4l2_int_ioctl_desc {
int num;
v4l2_int_ioctl_func *func;
};

struct v4l2_int_slave {
/* Don't touch master. */
struct v4l2_int_device *master;

char attach_to[V4L2NAMESIZE];

int num_ioctls;
struct v4l2_int_ioctl_desc *ioctls;
};

struct v4l2_int_device {
/* Don't touch head. */
struct list_head head;

struct module *module;

char name[V4L2NAMESIZE];

enum v4l2_int_type type;
union {
struct v4l2_int_master *master;
struct v4l2_int_slave *slave;
} u;

void *priv;
};

int v4l2_int_device_register(struct v4l2_int_device *d);
void v4l2_int_device_unregister(struct v4l2_int_device *d);

int v4l2_int_ioctl_0(struct v4l2_int_device *d, int cmd);
int v4l2_int_ioctl_1(struct v4l2_int_device *d, int cmd, void *arg);

/*
*
* IOCTL wrapper functions for better type checking.
Expand Down Expand Up @@ -199,6 +224,7 @@ V4L2_INT_WRAPPER_1(s_parm, struct v4l2_streamparm, *);
V4L2_INT_WRAPPER_0(dev_init);
V4L2_INT_WRAPPER_0(dev_exit);
V4L2_INT_WRAPPER_1(s_power, int, );
V4L2_INT_WRAPPER_1(g_ifparm, struct v4l2_ifparm, *);
V4L2_INT_WRAPPER_1(s_ext_clk, u32, );
V4L2_INT_WRAPPER_1(g_ext_clk, u32, *);
V4L2_INT_WRAPPER_1(g_needs_reset, void, *);
Expand Down

0 comments on commit 3ec05af

Please sign in to comment.