aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/pvrusb2/pvrusb2-hdw.c
diff options
context:
space:
mode:
authorMike Isely <isely@pobox.com>2009-03-06 23:48:42 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2009-03-30 11:43:38 -0400
commit75212a02734155de3d25c91344a9083d7bf2aef1 (patch)
treeb8dcc2d5926c96539b776f99fcfb08ddaa528244 /drivers/media/video/pvrusb2/pvrusb2-hdw.c
parentb481880bff1f98085a9f57362393463e6e3a3157 (diff)
V4L/DVB (11190): pvrusb2: Broadcast tuner type change to sub-devices
The tuner sub-device isn't going to work very well unless we tell it the correct tuner type to use... Signed-off-by: Mike Isely <isely@pobox.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/pvrusb2/pvrusb2-hdw.c')
-rw-r--r--drivers/media/video/pvrusb2/pvrusb2-hdw.c18
1 files changed, 17 insertions, 1 deletions
diff --git a/drivers/media/video/pvrusb2/pvrusb2-hdw.c b/drivers/media/video/pvrusb2/pvrusb2-hdw.c
index 029cdf411df0..8be5392e979b 100644
--- a/drivers/media/video/pvrusb2/pvrusb2-hdw.c
+++ b/drivers/media/video/pvrusb2/pvrusb2-hdw.c
@@ -24,6 +24,7 @@
24#include <linux/firmware.h> 24#include <linux/firmware.h>
25#include <linux/videodev2.h> 25#include <linux/videodev2.h>
26#include <media/v4l2-common.h> 26#include <media/v4l2-common.h>
27#include <media/tuner.h>
27#include "pvrusb2.h" 28#include "pvrusb2.h"
28#include "pvrusb2-std.h" 29#include "pvrusb2-std.h"
29#include "pvrusb2-util.h" 30#include "pvrusb2-util.h"
@@ -2261,7 +2262,6 @@ static void pvr2_hdw_setup_low(struct pvr2_hdw *hdw)
2261 } 2262 }
2262 2263
2263 pvr2_i2c_core_check_stale(hdw); 2264 pvr2_i2c_core_check_stale(hdw);
2264 hdw->tuner_updated = 0;
2265 2265
2266 if (!pvr2_hdw_dev_ok(hdw)) return; 2266 if (!pvr2_hdw_dev_ok(hdw)) return;
2267 2267
@@ -2944,6 +2944,21 @@ static void pvr2_subdev_update(struct pvr2_hdw *hdw)
2944 unsigned int id; 2944 unsigned int id;
2945 pvr2_subdev_update_func fp; 2945 pvr2_subdev_update_func fp;
2946 2946
2947 pvr2_trace(PVR2_TRACE_CHIPS, "subdev update...");
2948
2949 if (hdw->tuner_updated) {
2950 struct tuner_setup setup;
2951 pvr2_trace(PVR2_TRACE_CHIPS, "subdev tuner set_type(%d)",
2952 hdw->tuner_type);
2953 if (((int)(hdw->tuner_type)) >= 0) {
2954 setup.addr = ADDR_UNSET;
2955 setup.type = hdw->tuner_type;
2956 setup.mode_mask = T_RADIO | T_ANALOG_TV;
2957 v4l2_device_call_all(&hdw->v4l2_dev, 0,
2958 tuner, s_type_addr, &setup);
2959 }
2960 }
2961
2947 if (hdw->input_dirty || hdw->std_dirty) { 2962 if (hdw->input_dirty || hdw->std_dirty) {
2948 pvr2_trace(PVR2_TRACE_CHIPS, "subdev v4l2 set_standard"); 2963 pvr2_trace(PVR2_TRACE_CHIPS, "subdev v4l2 set_standard");
2949 if (hdw->input_val == PVR2_CVAL_INPUT_RADIO) { 2964 if (hdw->input_val == PVR2_CVAL_INPUT_RADIO) {
@@ -3241,6 +3256,7 @@ static int pvr2_hdw_commit_execute(struct pvr2_hdw *hdw)
3241 /* Check and update state for all sub-devices. */ 3256 /* Check and update state for all sub-devices. */
3242 pvr2_subdev_update(hdw); 3257 pvr2_subdev_update(hdw);
3243 3258
3259 hdw->tuner_updated = 0;
3244 for (idx = 0; idx < hdw->control_cnt; idx++) { 3260 for (idx = 0; idx < hdw->control_cnt; idx++) {
3245 cptr = hdw->controls + idx; 3261 cptr = hdw->controls + idx;
3246 if (!cptr->info->clear_dirty) continue; 3262 if (!cptr->info->clear_dirty) continue;