]> pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - drivers/media/dvb/bt8xx/dst.c
V4L/DVB (4170): ATSC typecheck bugfix
[linux-2.6-omap-h63xx.git] / drivers / media / dvb / bt8xx / dst.c
index abed03a5a156e7fbeeaee36f0e8c1fe7d22b77dc..97d6c632542a050fd1c96e488d8eb21e83bf7ac1 100644 (file)
@@ -590,28 +590,116 @@ static int dst_type_print(u8 type)
 
 struct tuner_types tuner_list[] = {
        {
-               .tuner_type = 2,
+               .tuner_type = TUNER_TYPE_L64724,
                .tuner_name = "L 64724",
-               .board_name = " "
+               .board_name = "UNKNOWN",
+               .fw_name    = "UNKNOWN"
        },
 
        {
-               .tuner_type = 4,
+               .tuner_type = TUNER_TYPE_STV0299,
                .tuner_name = "STV 0299",
-               .board_name = "VP1030"
+               .board_name = "VP1020",
+               .fw_name    = "DST-MOT"
        },
 
        {
-               .tuner_type = 8,
+               .tuner_type = TUNER_TYPE_STV0299,
+               .tuner_name = "STV 0299",
+               .board_name = "VP1020",
+               .fw_name    = "DST-03T"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_MB86A15,
                .tuner_name = "MB 86A15",
-               .board_name = "VP1025"
+               .board_name = "VP1022",
+               .fw_name    = "DST-03T"
        },
 
        {
-               .tuner_type = 16,
-               .tuner_name = "NXT 200x",
-               .board_name = "VP3250"
-       }
+               .tuner_type = TUNER_TYPE_MB86A15,
+               .tuner_name = "MB 86A15",
+               .board_name = "VP1025",
+               .fw_name    = "DST-03T"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_STV0299,
+               .tuner_name = "STV 0299",
+               .board_name = "VP1030",
+               .fw_name    = "DST-CI"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_STV0299,
+               .tuner_name = "STV 0299",
+               .board_name = "VP1030",
+               .fw_name    = "DSTMCI"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_UNKNOWN,
+               .tuner_name = "UNKNOWN",
+               .board_name = "VP2030",
+               .fw_name    = "DCT-CI"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_UNKNOWN,
+               .tuner_name = "UNKNOWN",
+               .board_name = "VP2031",
+               .fw_name    = "DCT-CI"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_UNKNOWN,
+               .tuner_name = "UNKNOWN",
+               .board_name = "VP2040",
+               .fw_name    = "DCT-CI"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_UNKNOWN,
+               .tuner_name = "UNKNOWN",
+               .board_name = "VP3020",
+               .fw_name    = "DTTFTA"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_UNKNOWN,
+               .tuner_name = "UNKNOWN",
+               .board_name = "VP3021",
+               .fw_name    = "DTTFTA"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_TDA10046,
+               .tuner_name = "TDA10046",
+               .board_name = "VP3040",
+               .fw_name    = "DTT-CI"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_UNKNOWN,
+               .tuner_name = "UNKNOWN",
+               .board_name = "VP3051",
+               .fw_name    = "DTTNXT"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_NXT200x,
+               .tuner_name = "NXT200x",
+               .board_name = "VP3220",
+               .fw_name    = "ATSCDI"
+       },
+
+       {
+               .tuner_type = TUNER_TYPE_NXT200x,
+               .tuner_name = "NXT200x",
+               .board_name = "VP3250",
+               .fw_name    = "ATSCAD"
+       },
 };
 
 /*
@@ -912,11 +1000,11 @@ static int dst_get_tuner_info(struct dst_state *state)
 //             if (state->type_flags & DST_TYPE_HAS_TS204)
 //                     state->type_flags &= ~DST_TYPE_HAS_TS204;
 //             state->type_flags |= DST_TYPE_HAS_NEWTUNE;
-               if (!(state->type_flags & DST_TYPE_IS_ATSC)) {
+               if (state->type_flags != DST_TYPE_IS_ATSC))
                        state->type_flags |= DST_TYPE_HAS_NEWTUNE;
-               } else {
+               else
                        state->type_flags |= DST_TYPE_HAS_NEWTUNE_2;
-               }
+
                dprintk(verbose, DST_INFO, 1, "DST type has TS=188, Daughterboard=[%d]", state->board_info[1]);
 
        } else if (state->board_info[0] == 0xcc) {