aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/video/tuner-xc2028.c58
1 files changed, 36 insertions, 22 deletions
diff --git a/drivers/media/video/tuner-xc2028.c b/drivers/media/video/tuner-xc2028.c
index 2bb695490ab2..838db8187a9c 100644
--- a/drivers/media/video/tuner-xc2028.c
+++ b/drivers/media/video/tuner-xc2028.c
@@ -24,15 +24,19 @@
24#define V4L2_STD_DTV_8MHZ ((v4l2_std_id)0x10000000) 24#define V4L2_STD_DTV_8MHZ ((v4l2_std_id)0x10000000)
25 25
26/* Firmwares used on tm5600/tm6000 + xc2028/xc3028 */ 26/* Firmwares used on tm5600/tm6000 + xc2028/xc3028 */
27static const char *firmware_6M = "tm6000_xc3028_DTV_6M.fw"; 27
28// static const char *firmware_78M = "tm6000_xc3028_78M.fw"; 28/* Generic firmwares */
29static const char *firmware_7M = "tm6000_xc3028_7M.fw"; 29static const char *firmware_INIT0 = "tm_xc3028_MTS_init0.fw";
30static const char *firmware_8M = "tm6000_xc3028_8M.fw"; 30static const char *firmware_8MHZ_INIT0 = "tm_xc3028_8M_MTS_init0.fw";
31static const char *firmware_B = "tm6000_xc3028_B_PAL.fw"; 31static const char *firmware_INIT1 = "tm_xc3028_68M_MTS_init1.fw";
32static const char *firmware_DK = "tm6000_xc3028_DK_PAL_MTS.fw"; 32
33static const char *firmware_MN = "tm6000_xc3028_MN_BTSC.fw"; 33/* Standard-specific firmwares */
34static const char *firmware_INIT0 = "tm6000_xc3028_INIT0.fw"; 34static const char *firmware_6M = "tm_xc3028_DTV_6M.fw";
35static const char *firmware_8MHZ_INIT0 = "tm6000_xc3028_8MHZ_INIT0.fw"; 35static const char *firmware_7M = "tm_xc3028_7M.fw";
36static const char *firmware_8M = "tm_xc3028_8M.fw";
37static const char *firmware_B = "tm_xc3028_B_PAL.fw";
38static const char *firmware_DK = "tm_xc3028_DK_PAL_MTS.fw";
39static const char *firmware_MN = "tm_xc3028_MN_BTSC.fw";
36 40
37struct xc2028_data { 41struct xc2028_data {
38 v4l2_std_id firm_type; /* video stds supported 42 v4l2_std_id firm_type; /* video stds supported
@@ -79,13 +83,6 @@ static int xc2028_get_reg(struct i2c_client *c, u16 reg)
79 if (rc<0) 83 if (rc<0)
80 return rc; 84 return rc;
81 85
82 if (t->tuner_callback) {
83 rc = t->tuner_callback( c->adapter->algo_data,
84 XC2028_RESET_CLK, 0);
85 if (rc<0)
86 return rc;
87 }
88
89 i2c_rcv(rc, c, buf, 2); 86 i2c_rcv(rc, c, buf, 2);
90 if (rc<0) 87 if (rc<0)
91 return rc; 88 return rc;
@@ -104,7 +101,11 @@ static int load_firmware (struct i2c_client *c, const char *name)
104 tuner_info("xc2028: Loading firmware %s\n", name); 101 tuner_info("xc2028: Loading firmware %s\n", name);
105 rc = request_firmware(&fw, name, &c->dev); 102 rc = request_firmware(&fw, name, &c->dev);
106 if (rc < 0) { 103 if (rc < 0) {
107 tuner_info("Error %d while requesting firmware\n", rc); 104 if (rc==-ENOENT)
105 tuner_info("Error: firmware %s not found.\n", name);
106 else
107 tuner_info("Error %d while requesting firmware %s \n", rc, name);
108
108 return rc; 109 return rc;
109 } 110 }
110 p=fw->data; 111 p=fw->data;
@@ -204,10 +205,11 @@ static int check_firmware(struct i2c_client *c, enum tuner_mode new_mode,
204 bandwidth); 205 bandwidth);
205 206
206 if (xc2028->need_load_generic) { 207 if (xc2028->need_load_generic) {
207 if (xc2028->bandwidth==6) 208 if (xc2028->bandwidth==8)
208 name = firmware_INIT0;
209 else
210 name = firmware_8MHZ_INIT0; 209 name = firmware_8MHZ_INIT0;
210 else
211 name = firmware_INIT0;
212
211 /* Reset is needed before loading firmware */ 213 /* Reset is needed before loading firmware */
212 rc = t->tuner_callback(c->adapter->algo_data, 214 rc = t->tuner_callback(c->adapter->algo_data,
213 XC2028_TUNER_RESET, 0); 215 XC2028_TUNER_RESET, 0);
@@ -248,9 +250,12 @@ static int check_firmware(struct i2c_client *c, enum tuner_mode new_mode,
248 xc2028->bandwidth = bandwidth; 250 xc2028->bandwidth = bandwidth;
249 } 251 }
250 252
251 if (xc2028->firm_type & t->std) 253 if (xc2028->firm_type & t->std) {
254 tuner_info("xc3028: no need to load a std-specific firmware.\n");
252 return 0; 255 return 0;
256 }
253 257
258 rc = load_firmware(c,firmware_INIT1);
254 259
255 if (t->std & V4L2_STD_MN) 260 if (t->std & V4L2_STD_MN)
256 name=firmware_MN; 261 name=firmware_MN;
@@ -266,7 +271,6 @@ static int check_firmware(struct i2c_client *c, enum tuner_mode new_mode,
266 name=firmware_DK; 271 name=firmware_DK;
267 272
268 tuner_info("xc2028: loading firmware named %s.\n", name); 273 tuner_info("xc2028: loading firmware named %s.\n", name);
269
270 rc = load_firmware(c, name); 274 rc = load_firmware(c, name);
271 if (rc<0) 275 if (rc<0)
272 return rc; 276 return rc;
@@ -342,6 +346,16 @@ static void generic_set_tv_freq(struct i2c_client *c, u32 freq /* in Hz */,
342 } 346 }
343 msleep(10); 347 msleep(10);
344 348
349 char *name;
350
351 rc = load_firmware(c,firmware_INIT1);
352
353 if (t->std & V4L2_STD_MN)
354 name=firmware_MN;
355 else
356 name=firmware_DK;
357
358 rc = load_firmware(c,name);
345 /* CMD= Set frequency */ 359 /* CMD= Set frequency */
346 send_seq(c, {0x00, 0x02, 0x00, 0x00}); 360 send_seq(c, {0x00, 0x02, 0x00, 0x00});
347 if (t->tuner_callback) { 361 if (t->tuner_callback) {