提交 2cc3b6bf 编写于 作者: M Mike Isely 提交者: Mauro Carvalho Chehab

V4L/DVB (10258): pvrusb2: Issue VIDIOC_INT_INIT to v4l2 modules when they first attach

It appears that various v4l-dvb drivers are changing to require
explicit initialization before use.  This change to the pvrusb2 driver
implements an automatic issuance of VIDIOC_INT_INIT when a module is
bound to the driver, thus conforming to the new behavior.
Signed-off-by: NMike Isely <isely@pobox.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 8ed06fd4
...@@ -31,17 +31,19 @@ ...@@ -31,17 +31,19 @@
#define trace_i2c(...) pvr2_trace(PVR2_TRACE_I2C,__VA_ARGS__) #define trace_i2c(...) pvr2_trace(PVR2_TRACE_I2C,__VA_ARGS__)
#define OP_STANDARD 0 #define OP_INIT 0 /* MUST come first so it is run first */
#define OP_AUDIOMODE 1 #define OP_STANDARD 1
#define OP_BCSH 2 #define OP_AUDIOMODE 2
#define OP_VOLUME 3 #define OP_BCSH 3
#define OP_FREQ 4 #define OP_VOLUME 4
#define OP_AUDIORATE 5 #define OP_FREQ 5
#define OP_CROP 6 #define OP_AUDIORATE 6
#define OP_SIZE 7 #define OP_CROP 7
#define OP_LOG 8 #define OP_SIZE 8
#define OP_LOG 9
static const struct pvr2_i2c_op * const ops[] = { static const struct pvr2_i2c_op * const ops[] = {
[OP_INIT] = &pvr2_i2c_op_v4l2_init,
[OP_STANDARD] = &pvr2_i2c_op_v4l2_standard, [OP_STANDARD] = &pvr2_i2c_op_v4l2_standard,
[OP_AUDIOMODE] = &pvr2_i2c_op_v4l2_audiomode, [OP_AUDIOMODE] = &pvr2_i2c_op_v4l2_audiomode,
[OP_BCSH] = &pvr2_i2c_op_v4l2_bcsh, [OP_BCSH] = &pvr2_i2c_op_v4l2_bcsh,
...@@ -56,7 +58,8 @@ void pvr2_i2c_probe(struct pvr2_hdw *hdw,struct pvr2_i2c_client *cp) ...@@ -56,7 +58,8 @@ void pvr2_i2c_probe(struct pvr2_hdw *hdw,struct pvr2_i2c_client *cp)
{ {
int id; int id;
id = cp->client->driver->id; id = cp->client->driver->id;
cp->ctl_mask = ((1 << OP_STANDARD) | cp->ctl_mask = ((1 << OP_INIT) |
(1 << OP_STANDARD) |
(1 << OP_AUDIOMODE) | (1 << OP_AUDIOMODE) |
(1 << OP_BCSH) | (1 << OP_BCSH) |
(1 << OP_VOLUME) | (1 << OP_VOLUME) |
......
...@@ -25,6 +25,20 @@ ...@@ -25,6 +25,20 @@
#include <linux/videodev2.h> #include <linux/videodev2.h>
#include <media/v4l2-common.h> #include <media/v4l2-common.h>
static void execute_init(struct pvr2_hdw *hdw)
{
u32 dummy = 0;
pvr2_trace(PVR2_TRACE_CHIPS, "i2c v4l2 init");
pvr2_i2c_core_cmd(hdw, VIDIOC_INT_INIT, &dummy);
}
const struct pvr2_i2c_op pvr2_i2c_op_v4l2_init = {
.update = execute_init,
.name = "v4l2_init",
};
static void set_standard(struct pvr2_hdw *hdw) static void set_standard(struct pvr2_hdw *hdw)
{ {
pvr2_trace(PVR2_TRACE_CHIPS,"i2c v4l2 set_standard"); pvr2_trace(PVR2_TRACE_CHIPS,"i2c v4l2 set_standard");
......
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include "pvrusb2-i2c-core.h" #include "pvrusb2-i2c-core.h"
extern const struct pvr2_i2c_op pvr2_i2c_op_v4l2_init;
extern const struct pvr2_i2c_op pvr2_i2c_op_v4l2_standard; extern const struct pvr2_i2c_op pvr2_i2c_op_v4l2_standard;
extern const struct pvr2_i2c_op pvr2_i2c_op_v4l2_radio; extern const struct pvr2_i2c_op pvr2_i2c_op_v4l2_radio;
extern const struct pvr2_i2c_op pvr2_i2c_op_v4l2_bcsh; extern const struct pvr2_i2c_op pvr2_i2c_op_v4l2_bcsh;
......
...@@ -763,7 +763,7 @@ int pvr2_i2c_core_check_stale(struct pvr2_hdw *hdw) ...@@ -763,7 +763,7 @@ int pvr2_i2c_core_check_stale(struct pvr2_hdw *hdw)
if (!(msk & pm)) continue; if (!(msk & pm)) continue;
pm &= ~msk; pm &= ~msk;
opf = pvr2_i2c_get_op(idx); opf = pvr2_i2c_get_op(idx);
if (!opf) continue; if (!(opf && opf->check)) continue;
if (opf->check(hdw)) { if (opf->check(hdw)) {
sm |= msk; sm |= msk;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册