blob: bb0d95fe64f9a33460d100a83b41b1c721544e73 [file] [log] [blame]
Johannes Stezenbach2add87a2005-05-16 21:54:10 -07001/*
Uwe Bugla1589a992009-03-29 07:46:58 -03002 * Linux driver for digital TV devices equipped with B2C2 FlexcopII(b)/III
3 * flexcop-misc.c - miscellaneous functions
4 * see flexcop.c for copyright information
Johannes Stezenbach2add87a2005-05-16 21:54:10 -07005 */
6#include "flexcop.h"
7
8void flexcop_determine_revision(struct flexcop_device *fc)
9{
10 flexcop_ibi_value v = fc->read_ibi_reg(fc,misc_204);
11
12 switch (v.misc_204.Rev_N_sig_revision_hi) {
Uwe Bugla1589a992009-03-29 07:46:58 -030013 case 0x2:
14 deb_info("found a FlexCopII.\n");
15 fc->rev = FLEXCOP_II;
16 break;
17 case 0x3:
18 deb_info("found a FlexCopIIb.\n");
19 fc->rev = FLEXCOP_IIB;
20 break;
21 case 0x0:
22 deb_info("found a FlexCopIII.\n");
23 fc->rev = FLEXCOP_III;
24 break;
25 default:
Mauro Carvalho Chehabd9942ad2016-10-18 17:44:00 -020026 err("unknown FlexCop Revision: %x. Please report this to linux-dvb@linuxtv.org.",
Uwe Bugla1589a992009-03-29 07:46:58 -030027 v.misc_204.Rev_N_sig_revision_hi);
28 break;
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070029 }
30
31 if ((fc->has_32_hw_pid_filter = v.misc_204.Rev_N_sig_caps))
Mauro Carvalho Chehabd9942ad2016-10-18 17:44:00 -020032 deb_info("this FlexCop has the additional 32 hardware pid filter.\n");
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070033 else
Mauro Carvalho Chehabd9942ad2016-10-18 17:44:00 -020034 deb_info("this FlexCop has the 6 basic main hardware pid filter.\n");
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070035 /* bus parts have to decide if hw pid filtering is used or not. */
36}
37
Adrian Bunka22a68652006-01-23 09:58:17 -020038static const char *flexcop_revision_names[] = {
Uwe Bugla1589a992009-03-29 07:46:58 -030039 "Unknown chip",
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070040 "FlexCopII",
41 "FlexCopIIb",
42 "FlexCopIII",
43};
44
Adrian Bunka22a68652006-01-23 09:58:17 -020045static const char *flexcop_device_names[] = {
Matthias Schwarzott1c905a42009-05-22 07:19:14 -030046 [FC_UNK] = "Unknown device",
47 [FC_CABLE] = "Cable2PC/CableStar 2 DVB-C",
48 [FC_AIR_DVBT] = "Air2PC/AirStar 2 DVB-T",
49 [FC_AIR_ATSC1] = "Air2PC/AirStar 2 ATSC 1st generation",
50 [FC_AIR_ATSC2] = "Air2PC/AirStar 2 ATSC 2nd generation",
51 [FC_AIR_ATSC3] = "Air2PC/AirStar 2 ATSC 3rd generation (HD5000)",
52 [FC_SKY_REV23] = "Sky2PC/SkyStar 2 DVB-S rev 2.3 (old version)",
53 [FC_SKY_REV26] = "Sky2PC/SkyStar 2 DVB-S rev 2.6",
54 [FC_SKY_REV27] = "Sky2PC/SkyStar 2 DVB-S rev 2.7a/u",
55 [FC_SKY_REV28] = "Sky2PC/SkyStar 2 DVB-S rev 2.8",
Jemma Denson5afc9a22015-04-14 09:04:50 -030056 [FC_SKYS2_REV33] = "Sky2PC/SkyStar S2 DVB-S/S2 rev 3.3",
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070057};
58
Adrian Bunka22a68652006-01-23 09:58:17 -020059static const char *flexcop_bus_names[] = {
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070060 "USB",
61 "PCI",
62};
63
Uwe Bugla1589a992009-03-29 07:46:58 -030064void flexcop_device_name(struct flexcop_device *fc,
65 const char *prefix, const char *suffix)
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070066{
Uwe Bugla1589a992009-03-29 07:46:58 -030067 info("%s '%s' at the '%s' bus controlled by a '%s' %s",
68 prefix, flexcop_device_names[fc->dev_type],
69 flexcop_bus_names[fc->bus_type],
70 flexcop_revision_names[fc->rev], suffix);
Johannes Stezenbach2add87a2005-05-16 21:54:10 -070071}
Patrick Boettcher64221be2005-07-07 17:57:49 -070072
Uwe Bugla1589a992009-03-29 07:46:58 -030073void flexcop_dump_reg(struct flexcop_device *fc,
74 flexcop_ibi_register reg, int num)
Patrick Boettcher64221be2005-07-07 17:57:49 -070075{
76 flexcop_ibi_value v;
77 int i;
78 for (i = 0; i < num; i++) {
Uwe Bugla1589a992009-03-29 07:46:58 -030079 v = fc->read_ibi_reg(fc, reg+4*i);
80 deb_rdump("0x%03x: %08x, ", reg+4*i, v.raw);
Patrick Boettcher64221be2005-07-07 17:57:49 -070081 }
82 deb_rdump("\n");
83}
84EXPORT_SYMBOL(flexcop_dump_reg);