aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/dvb/bt8xx
diff options
context:
space:
mode:
authorManu Abraham <abraham.manu@gmail.com>2006-06-21 10:27:53 -0300
committerMauro Carvalho Chehab <mchehab@infradead.org>2006-06-25 02:05:16 -0300
commitb633c6d6a39a1cb78091fb04f093b16bdf8cbf59 (patch)
tree94c75cbf9df9cabc8a3099b621b72b7114055991 /drivers/media/dvb/bt8xx
parent396cffd63ed460ae2544d62745fabd22296af99a (diff)
downloadkernel_samsung_smdk4412-b633c6d6a39a1cb78091fb04f093b16bdf8cbf59.tar.gz
kernel_samsung_smdk4412-b633c6d6a39a1cb78091fb04f093b16bdf8cbf59.tar.bz2
kernel_samsung_smdk4412-b633c6d6a39a1cb78091fb04f093b16bdf8cbf59.zip
V4L/DVB (4165): Add in tuner names
Signed-off-by: Manu Abraham <manu@linuxtv.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/dvb/bt8xx')
-rw-r--r--drivers/media/dvb/bt8xx/dst.c33
-rw-r--r--drivers/media/dvb/bt8xx/dst_common.h6
2 files changed, 37 insertions, 2 deletions
diff --git a/drivers/media/dvb/bt8xx/dst.c b/drivers/media/dvb/bt8xx/dst.c
index d2a7e413e9e..52cbe150077 100644
--- a/drivers/media/dvb/bt8xx/dst.c
+++ b/drivers/media/dvb/bt8xx/dst.c
@@ -586,6 +586,23 @@ static int dst_type_print(u8 type)
return 0;
}
+struct tuner_types tuner_list[] = {
+ {
+ .tuner_type = 2,
+ .tuner_name = "L 64724"
+ },
+
+ {
+ .tuner_type = 4,
+ .tuner_name = "STV 0299"
+ },
+
+ {
+ .tuner_type = 8,
+ .tuner_name = "MB 86A15"
+ },
+};
+
/*
Known cards list
Satellite
@@ -656,7 +673,7 @@ static struct dst_types dst_tlist[] = {
.type_flags = DST_TYPE_HAS_SYMDIV | DST_TYPE_HAS_TS204 | DST_TYPE_HAS_FW_2,
.dst_feature = DST_TYPE_HAS_DISEQC3 | DST_TYPE_HAS_DISEQC4 | DST_TYPE_HAS_DISEQC5
| DST_TYPE_HAS_MAC | DST_TYPE_HAS_MOTO,
- .tuner_type = TUNER_TYPE_STV0299
+ .tuner_type = TUNER_TYPE_MULTI
},
{
@@ -890,8 +907,10 @@ static int dst_get_device_id(struct dst_state *state)
{
u8 reply;
- int i;
+ int i, j;
struct dst_types *p_dst_type;
+ struct tuner_types *p_tuner_list;
+
u8 use_dst_type = 0;
u32 use_type_flags = 0;
@@ -930,6 +949,16 @@ static int dst_get_device_id(struct dst_state *state)
state->dst_hw_cap = p_dst_type->dst_feature;
dprintk(verbose, DST_ERROR, 1, "Recognise [%s]\n", p_dst_type->device_id);
+ if (p_dst_type->tuner_type != TUNER_TYPE_MULTI) {
+ state->tuner_type = p_dst_type->tuner_type;
+
+ for (j = 0, p_tuner_list = tuner_list; j < ARRAY_SIZE(tuner_list); j++, p_tuner_list++) {
+ if (p_dst_type->tuner_type == p_tuner_list->tuner_type) {
+ state->tuner_name = p_tuner_list->tuner_name;
+ dprintk(verbose, DST_ERROR, 1, "DST has a [%s] based tuner\n", state->tuner_name);
+ }
+ }
+ }
break;
}
}
diff --git a/drivers/media/dvb/bt8xx/dst_common.h b/drivers/media/dvb/bt8xx/dst_common.h
index 3908c5b8c72..19449592fd9 100644
--- a/drivers/media/dvb/bt8xx/dst_common.h
+++ b/drivers/media/dvb/bt8xx/dst_common.h
@@ -125,9 +125,15 @@ struct dst_state {
u8 vendor[8];
u8 board_info[8];
u32 tuner_type;
+ char *tuner_name;
struct mutex dst_mutex;
};
+struct tuner_types {
+ u32 tuner_type;
+ char *tuner_name;
+};
+
struct dst_types {
char *device_id;
int offset;