Merge branch 'for-linus' of git://oss.sgi.com/xfs/xfs
[linux/fpc-iii.git] / drivers / media / dvb / ttpci / av7110.c
bloba6be529eec5ca72e3dd8f965e334b956b4911557
1 /*
2 * driver for the SAA7146 based AV110 cards (like the Fujitsu-Siemens DVB)
3 * av7110.c: initialization and demux stuff
5 * Copyright (C) 1999-2002 Ralph Metzler
6 * & Marcus Metzler for convergence integrated media GmbH
8 * originally based on code by:
9 * Copyright (C) 1998,1999 Christian Theiss <mistert@rz.fh-augsburg.de>
11 * This program is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License
13 * as published by the Free Software Foundation; either version 2
14 * of the License, or (at your option) any later version.
17 * This program is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
23 * You should have received a copy of the GNU General Public License
24 * along with this program; if not, write to the Free Software
25 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
26 * Or, point your browser to http://www.gnu.org/copyleft/gpl.html
29 * the project's page is at http://www.linuxtv.org/dvb/
33 #include <linux/module.h>
34 #include <linux/kmod.h>
35 #include <linux/delay.h>
36 #include <linux/fs.h>
37 #include <linux/timer.h>
38 #include <linux/poll.h>
40 #include <linux/kernel.h>
41 #include <linux/sched.h>
42 #include <linux/types.h>
43 #include <linux/fcntl.h>
44 #include <linux/interrupt.h>
45 #include <linux/string.h>
46 #include <linux/pci.h>
47 #include <linux/vmalloc.h>
48 #include <linux/firmware.h>
49 #include <linux/crc32.h>
50 #include <linux/i2c.h>
51 #include <linux/kthread.h>
52 #include <linux/slab.h>
53 #include <asm/unaligned.h>
54 #include <asm/byteorder.h>
56 #include <asm/system.h>
58 #include <linux/dvb/frontend.h>
60 #include "dvb_frontend.h"
62 #include "ttpci-eeprom.h"
63 #include "av7110.h"
64 #include "av7110_hw.h"
65 #include "av7110_av.h"
66 #include "av7110_ca.h"
67 #include "av7110_ipack.h"
69 #include "bsbe1.h"
70 #include "lnbp21.h"
71 #include "bsru6.h"
73 #define TS_WIDTH 376
74 #define TS_HEIGHT 512
75 #define TS_BUFLEN (TS_WIDTH*TS_HEIGHT)
76 #define TS_MAX_PACKETS (TS_BUFLEN/TS_SIZE)
79 int av7110_debug;
81 static int vidmode = CVBS_RGB_OUT;
82 static int pids_off;
83 static int adac = DVB_ADAC_TI;
84 static int hw_sections;
85 static int rgb_on;
86 static int volume = 255;
87 static int budgetpatch;
88 static int wss_cfg_4_3 = 0x4008;
89 static int wss_cfg_16_9 = 0x0007;
90 static int tv_standard;
91 static int full_ts;
93 module_param_named(debug, av7110_debug, int, 0644);
94 MODULE_PARM_DESC(debug, "debug level (bitmask, default 0)");
95 module_param(vidmode, int, 0444);
96 MODULE_PARM_DESC(vidmode,"analog video out: 0 off, 1 CVBS+RGB (default), 2 CVBS+YC, 3 YC");
97 module_param(pids_off, int, 0444);
98 MODULE_PARM_DESC(pids_off,"clear video/audio/PCR PID filters when demux is closed");
99 module_param(adac, int, 0444);
100 MODULE_PARM_DESC(adac,"audio DAC type: 0 TI, 1 CRYSTAL, 2 MSP (use if autodetection fails)");
101 module_param(hw_sections, int, 0444);
102 MODULE_PARM_DESC(hw_sections, "0 use software section filter, 1 use hardware");
103 module_param(rgb_on, int, 0444);
104 MODULE_PARM_DESC(rgb_on, "For Siemens DVB-C cards only: Enable RGB control"
105 " signal on SCART pin 16 to switch SCART video mode from CVBS to RGB");
106 module_param(volume, int, 0444);
107 MODULE_PARM_DESC(volume, "initial volume: default 255 (range 0-255)");
108 module_param(budgetpatch, int, 0444);
109 MODULE_PARM_DESC(budgetpatch, "use budget-patch hardware modification: default 0 (0 no, 1 autodetect, 2 always)");
110 module_param(full_ts, int, 0444);
111 MODULE_PARM_DESC(full_ts, "enable code for full-ts hardware modification: 0 disable (default), 1 enable");
112 module_param(wss_cfg_4_3, int, 0444);
113 MODULE_PARM_DESC(wss_cfg_4_3, "WSS 4:3 - default 0x4008 - bit 15: disable, 14: burst mode, 13..0: wss data");
114 module_param(wss_cfg_16_9, int, 0444);
115 MODULE_PARM_DESC(wss_cfg_16_9, "WSS 16:9 - default 0x0007 - bit 15: disable, 14: burst mode, 13..0: wss data");
116 module_param(tv_standard, int, 0444);
117 MODULE_PARM_DESC(tv_standard, "TV standard: 0 PAL (default), 1 NTSC");
119 DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
121 static void restart_feeds(struct av7110 *av7110);
122 static int budget_start_feed(struct dvb_demux_feed *feed);
123 static int budget_stop_feed(struct dvb_demux_feed *feed);
125 static int av7110_num;
127 #define FE_FUNC_OVERRIDE(fe_func, av7110_copy, av7110_func) \
129 if (fe_func != NULL) { \
130 av7110_copy = fe_func; \
131 fe_func = av7110_func; \
136 static void init_av7110_av(struct av7110 *av7110)
138 int ret;
139 struct saa7146_dev *dev = av7110->dev;
141 /* set internal volume control to maximum */
142 av7110->adac_type = DVB_ADAC_TI;
143 ret = av7110_set_volume(av7110, av7110->mixer.volume_left, av7110->mixer.volume_right);
144 if (ret < 0)
145 printk("dvb-ttpci:cannot set internal volume to maximum:%d\n",ret);
147 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetMonitorType,
148 1, (u16) av7110->display_ar);
149 if (ret < 0)
150 printk("dvb-ttpci: unable to set aspect ratio\n");
151 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetPanScanType,
152 1, av7110->display_panscan);
153 if (ret < 0)
154 printk("dvb-ttpci: unable to set pan scan\n");
156 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetWSSConfig, 2, 2, wss_cfg_4_3);
157 if (ret < 0)
158 printk("dvb-ttpci: unable to configure 4:3 wss\n");
159 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetWSSConfig, 2, 3, wss_cfg_16_9);
160 if (ret < 0)
161 printk("dvb-ttpci: unable to configure 16:9 wss\n");
163 ret = av7710_set_video_mode(av7110, vidmode);
164 if (ret < 0)
165 printk("dvb-ttpci:cannot set video mode:%d\n",ret);
167 /* handle different card types */
168 /* remaining inits according to card and frontend type */
169 av7110->analog_tuner_flags = 0;
170 av7110->current_input = 0;
171 if (dev->pci->subsystem_vendor == 0x13c2 && dev->pci->subsystem_device == 0x000a)
172 av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, ADSwitch, 1, 0); // SPDIF on
173 if (i2c_writereg(av7110, 0x20, 0x00, 0x00) == 1) {
174 printk ("dvb-ttpci: Crystal audio DAC @ card %d detected\n",
175 av7110->dvb_adapter.num);
176 av7110->adac_type = DVB_ADAC_CRYSTAL;
177 i2c_writereg(av7110, 0x20, 0x01, 0xd2);
178 i2c_writereg(av7110, 0x20, 0x02, 0x49);
179 i2c_writereg(av7110, 0x20, 0x03, 0x00);
180 i2c_writereg(av7110, 0x20, 0x04, 0x00);
183 * some special handling for the Siemens DVB-C cards...
185 } else if (0 == av7110_init_analog_module(av7110)) {
186 /* done. */
188 else if (dev->pci->subsystem_vendor == 0x110a) {
189 printk("dvb-ttpci: DVB-C w/o analog module @ card %d detected\n",
190 av7110->dvb_adapter.num);
191 av7110->adac_type = DVB_ADAC_NONE;
193 else {
194 av7110->adac_type = adac;
195 printk("dvb-ttpci: adac type set to %d @ card %d\n",
196 av7110->adac_type, av7110->dvb_adapter.num);
199 if (av7110->adac_type == DVB_ADAC_NONE || av7110->adac_type == DVB_ADAC_MSP34x0) {
200 // switch DVB SCART on
201 ret = av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, MainSwitch, 1, 0);
202 if (ret < 0)
203 printk("dvb-ttpci:cannot switch on SCART(Main):%d\n",ret);
204 ret = av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, ADSwitch, 1, 1);
205 if (ret < 0)
206 printk("dvb-ttpci:cannot switch on SCART(AD):%d\n",ret);
207 if (rgb_on &&
208 ((av7110->dev->pci->subsystem_vendor == 0x110a) ||
209 (av7110->dev->pci->subsystem_vendor == 0x13c2)) &&
210 (av7110->dev->pci->subsystem_device == 0x0000)) {
211 saa7146_setgpio(dev, 1, SAA7146_GPIO_OUTHI); // RGB on, SCART pin 16
212 //saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO); // SCARTpin 8
216 if (dev->pci->subsystem_vendor == 0x13c2 && dev->pci->subsystem_device == 0x000e)
217 av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, SpdifSwitch, 1, 0); // SPDIF on
219 ret = av7110_set_volume(av7110, av7110->mixer.volume_left, av7110->mixer.volume_right);
220 if (ret < 0)
221 printk("dvb-ttpci:cannot set volume :%d\n",ret);
224 static void recover_arm(struct av7110 *av7110)
226 dprintk(4, "%p\n",av7110);
228 av7110_bootarm(av7110);
229 msleep(100);
231 init_av7110_av(av7110);
233 /* card-specific recovery */
234 if (av7110->recover)
235 av7110->recover(av7110);
237 restart_feeds(av7110);
239 #if defined(CONFIG_INPUT_EVDEV) || defined(CONFIG_INPUT_EVDEV_MODULE)
240 av7110_check_ir_config(av7110, true);
241 #endif
244 static void av7110_arm_sync(struct av7110 *av7110)
246 if (av7110->arm_thread)
247 kthread_stop(av7110->arm_thread);
249 av7110->arm_thread = NULL;
252 static int arm_thread(void *data)
254 struct av7110 *av7110 = data;
255 u16 newloops = 0;
256 int timeout;
258 dprintk(4, "%p\n",av7110);
260 for (;;) {
261 timeout = wait_event_interruptible_timeout(av7110->arm_wait,
262 kthread_should_stop(), 5 * HZ);
264 if (-ERESTARTSYS == timeout || kthread_should_stop()) {
265 /* got signal or told to quit*/
266 break;
269 if (!av7110->arm_ready)
270 continue;
272 #if defined(CONFIG_INPUT_EVDEV) || defined(CONFIG_INPUT_EVDEV_MODULE)
273 av7110_check_ir_config(av7110, false);
274 #endif
276 if (mutex_lock_interruptible(&av7110->dcomlock))
277 break;
278 newloops = rdebi(av7110, DEBINOSWAP, STATUS_LOOPS, 0, 2);
279 mutex_unlock(&av7110->dcomlock);
281 if (newloops == av7110->arm_loops || av7110->arm_errors > 3) {
282 printk(KERN_ERR "dvb-ttpci: ARM crashed @ card %d\n",
283 av7110->dvb_adapter.num);
285 recover_arm(av7110);
287 if (mutex_lock_interruptible(&av7110->dcomlock))
288 break;
289 newloops = rdebi(av7110, DEBINOSWAP, STATUS_LOOPS, 0, 2) - 1;
290 mutex_unlock(&av7110->dcomlock);
292 av7110->arm_loops = newloops;
293 av7110->arm_errors = 0;
296 return 0;
300 /****************************************************************************
301 * IRQ handling
302 ****************************************************************************/
304 static int DvbDmxFilterCallback(u8 *buffer1, size_t buffer1_len,
305 u8 *buffer2, size_t buffer2_len,
306 struct dvb_demux_filter *dvbdmxfilter,
307 enum dmx_success success,
308 struct av7110 *av7110)
310 if (!dvbdmxfilter->feed->demux->dmx.frontend)
311 return 0;
312 if (dvbdmxfilter->feed->demux->dmx.frontend->source == DMX_MEMORY_FE)
313 return 0;
315 switch (dvbdmxfilter->type) {
316 case DMX_TYPE_SEC:
317 if ((((buffer1[1] << 8) | buffer1[2]) & 0xfff) + 3 != buffer1_len)
318 return 0;
319 if (dvbdmxfilter->doneq) {
320 struct dmx_section_filter *filter = &dvbdmxfilter->filter;
321 int i;
322 u8 xor, neq = 0;
324 for (i = 0; i < DVB_DEMUX_MASK_MAX; i++) {
325 xor = filter->filter_value[i] ^ buffer1[i];
326 neq |= dvbdmxfilter->maskandnotmode[i] & xor;
328 if (!neq)
329 return 0;
331 return dvbdmxfilter->feed->cb.sec(buffer1, buffer1_len,
332 buffer2, buffer2_len,
333 &dvbdmxfilter->filter,
334 DMX_OK);
335 case DMX_TYPE_TS:
336 if (!(dvbdmxfilter->feed->ts_type & TS_PACKET))
337 return 0;
338 if (dvbdmxfilter->feed->ts_type & TS_PAYLOAD_ONLY)
339 return dvbdmxfilter->feed->cb.ts(buffer1, buffer1_len,
340 buffer2, buffer2_len,
341 &dvbdmxfilter->feed->feed.ts,
342 DMX_OK);
343 else
344 av7110_p2t_write(buffer1, buffer1_len,
345 dvbdmxfilter->feed->pid,
346 &av7110->p2t_filter[dvbdmxfilter->index]);
347 default:
348 return 0;
353 //#define DEBUG_TIMING
354 static inline void print_time(char *s)
356 #ifdef DEBUG_TIMING
357 struct timeval tv;
358 do_gettimeofday(&tv);
359 printk("%s: %d.%d\n", s, (int)tv.tv_sec, (int)tv.tv_usec);
360 #endif
363 #define DEBI_READ 0
364 #define DEBI_WRITE 1
365 static inline void start_debi_dma(struct av7110 *av7110, int dir,
366 unsigned long addr, unsigned int len)
368 dprintk(8, "%c %08lx %u\n", dir == DEBI_READ ? 'R' : 'W', addr, len);
369 if (saa7146_wait_for_debi_done(av7110->dev, 0)) {
370 printk(KERN_ERR "%s: saa7146_wait_for_debi_done timed out\n", __func__);
371 return;
374 SAA7146_ISR_CLEAR(av7110->dev, MASK_19); /* for good measure */
375 SAA7146_IER_ENABLE(av7110->dev, MASK_19);
376 if (len < 5)
377 len = 5; /* we want a real DEBI DMA */
378 if (dir == DEBI_WRITE)
379 iwdebi(av7110, DEBISWAB, addr, 0, (len + 3) & ~3);
380 else
381 irdebi(av7110, DEBISWAB, addr, 0, len);
384 static void debiirq(unsigned long cookie)
386 struct av7110 *av7110 = (struct av7110 *)cookie;
387 int type = av7110->debitype;
388 int handle = (type >> 8) & 0x1f;
389 unsigned int xfer = 0;
391 print_time("debi");
392 dprintk(4, "type 0x%04x\n", type);
394 if (type == -1) {
395 printk("DEBI irq oops @ %ld, psr:0x%08x, ssr:0x%08x\n",
396 jiffies, saa7146_read(av7110->dev, PSR),
397 saa7146_read(av7110->dev, SSR));
398 goto debi_done;
400 av7110->debitype = -1;
402 switch (type & 0xff) {
404 case DATA_TS_RECORD:
405 dvb_dmx_swfilter_packets(&av7110->demux,
406 (const u8 *) av7110->debi_virt,
407 av7110->debilen / 188);
408 xfer = RX_BUFF;
409 break;
411 case DATA_PES_RECORD:
412 if (av7110->demux.recording)
413 av7110_record_cb(&av7110->p2t[handle],
414 (u8 *) av7110->debi_virt,
415 av7110->debilen);
416 xfer = RX_BUFF;
417 break;
419 case DATA_IPMPE:
420 case DATA_FSECTION:
421 case DATA_PIPING:
422 if (av7110->handle2filter[handle])
423 DvbDmxFilterCallback((u8 *)av7110->debi_virt,
424 av7110->debilen, NULL, 0,
425 av7110->handle2filter[handle],
426 DMX_OK, av7110);
427 xfer = RX_BUFF;
428 break;
430 case DATA_CI_GET:
432 u8 *data = av7110->debi_virt;
434 if ((data[0] < 2) && data[2] == 0xff) {
435 int flags = 0;
436 if (data[5] > 0)
437 flags |= CA_CI_MODULE_PRESENT;
438 if (data[5] > 5)
439 flags |= CA_CI_MODULE_READY;
440 av7110->ci_slot[data[0]].flags = flags;
441 } else
442 ci_get_data(&av7110->ci_rbuffer,
443 av7110->debi_virt,
444 av7110->debilen);
445 xfer = RX_BUFF;
446 break;
449 case DATA_COMMON_INTERFACE:
450 CI_handle(av7110, (u8 *)av7110->debi_virt, av7110->debilen);
451 #if 0
453 int i;
455 printk("av7110%d: ", av7110->num);
456 printk("%02x ", *(u8 *)av7110->debi_virt);
457 printk("%02x ", *(1+(u8 *)av7110->debi_virt));
458 for (i = 2; i < av7110->debilen; i++)
459 printk("%02x ", (*(i+(unsigned char *)av7110->debi_virt)));
460 for (i = 2; i < av7110->debilen; i++)
461 printk("%c", chtrans(*(i+(unsigned char *)av7110->debi_virt)));
463 printk("\n");
465 #endif
466 xfer = RX_BUFF;
467 break;
469 case DATA_DEBUG_MESSAGE:
470 ((s8*)av7110->debi_virt)[Reserved_SIZE - 1] = 0;
471 printk("%s\n", (s8 *) av7110->debi_virt);
472 xfer = RX_BUFF;
473 break;
475 case DATA_CI_PUT:
476 dprintk(4, "debi DATA_CI_PUT\n");
477 case DATA_MPEG_PLAY:
478 dprintk(4, "debi DATA_MPEG_PLAY\n");
479 case DATA_BMP_LOAD:
480 dprintk(4, "debi DATA_BMP_LOAD\n");
481 xfer = TX_BUFF;
482 break;
483 default:
484 break;
486 debi_done:
487 spin_lock(&av7110->debilock);
488 if (xfer)
489 iwdebi(av7110, DEBINOSWAP, xfer, 0, 2);
490 ARM_ClearMailBox(av7110);
491 spin_unlock(&av7110->debilock);
494 /* irq from av7110 firmware writing the mailbox register in the DPRAM */
495 static void gpioirq(unsigned long cookie)
497 struct av7110 *av7110 = (struct av7110 *)cookie;
498 u32 rxbuf, txbuf;
499 int len;
501 if (av7110->debitype != -1)
502 /* we shouldn't get any irq while a debi xfer is running */
503 printk("dvb-ttpci: GPIO0 irq oops @ %ld, psr:0x%08x, ssr:0x%08x\n",
504 jiffies, saa7146_read(av7110->dev, PSR),
505 saa7146_read(av7110->dev, SSR));
507 if (saa7146_wait_for_debi_done(av7110->dev, 0)) {
508 printk(KERN_ERR "%s: saa7146_wait_for_debi_done timed out\n", __func__);
509 BUG(); /* maybe we should try resetting the debi? */
512 spin_lock(&av7110->debilock);
513 ARM_ClearIrq(av7110);
515 /* see what the av7110 wants */
516 av7110->debitype = irdebi(av7110, DEBINOSWAP, IRQ_STATE, 0, 2);
517 av7110->debilen = irdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
518 rxbuf = irdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
519 txbuf = irdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
520 len = (av7110->debilen + 3) & ~3;
522 print_time("gpio");
523 dprintk(8, "GPIO0 irq 0x%04x %d\n", av7110->debitype, av7110->debilen);
525 switch (av7110->debitype & 0xff) {
527 case DATA_TS_PLAY:
528 case DATA_PES_PLAY:
529 break;
531 case DATA_MPEG_VIDEO_EVENT:
533 u32 h_ar;
534 struct video_event event;
536 av7110->video_size.w = irdebi(av7110, DEBINOSWAP, STATUS_MPEG_WIDTH, 0, 2);
537 h_ar = irdebi(av7110, DEBINOSWAP, STATUS_MPEG_HEIGHT_AR, 0, 2);
539 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
540 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
542 av7110->video_size.h = h_ar & 0xfff;
544 event.type = VIDEO_EVENT_SIZE_CHANGED;
545 event.u.size.w = av7110->video_size.w;
546 event.u.size.h = av7110->video_size.h;
547 switch ((h_ar >> 12) & 0xf)
549 case 3:
550 av7110->video_size.aspect_ratio = VIDEO_FORMAT_16_9;
551 event.u.size.aspect_ratio = VIDEO_FORMAT_16_9;
552 av7110->videostate.video_format = VIDEO_FORMAT_16_9;
553 break;
554 case 4:
555 av7110->video_size.aspect_ratio = VIDEO_FORMAT_221_1;
556 event.u.size.aspect_ratio = VIDEO_FORMAT_221_1;
557 av7110->videostate.video_format = VIDEO_FORMAT_221_1;
558 break;
559 default:
560 av7110->video_size.aspect_ratio = VIDEO_FORMAT_4_3;
561 event.u.size.aspect_ratio = VIDEO_FORMAT_4_3;
562 av7110->videostate.video_format = VIDEO_FORMAT_4_3;
565 dprintk(8, "GPIO0 irq: DATA_MPEG_VIDEO_EVENT: w/h/ar = %u/%u/%u\n",
566 av7110->video_size.w, av7110->video_size.h,
567 av7110->video_size.aspect_ratio);
569 dvb_video_add_event(av7110, &event);
570 break;
573 case DATA_CI_PUT:
575 int avail;
576 struct dvb_ringbuffer *cibuf = &av7110->ci_wbuffer;
578 avail = dvb_ringbuffer_avail(cibuf);
579 if (avail <= 2) {
580 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
581 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
582 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
583 break;
585 len = DVB_RINGBUFFER_PEEK(cibuf, 0) << 8;
586 len |= DVB_RINGBUFFER_PEEK(cibuf, 1);
587 if (avail < len + 2) {
588 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
589 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
590 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
591 break;
593 DVB_RINGBUFFER_SKIP(cibuf, 2);
595 dvb_ringbuffer_read(cibuf, av7110->debi_virt, len);
597 iwdebi(av7110, DEBINOSWAP, TX_LEN, len, 2);
598 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, len, 2);
599 dprintk(8, "DMA: CI\n");
600 start_debi_dma(av7110, DEBI_WRITE, DPRAM_BASE + txbuf, len);
601 spin_unlock(&av7110->debilock);
602 wake_up(&cibuf->queue);
603 return;
606 case DATA_MPEG_PLAY:
607 if (!av7110->playing) {
608 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
609 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
610 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
611 break;
613 len = 0;
614 if (av7110->debitype & 0x100) {
615 spin_lock(&av7110->aout.lock);
616 len = av7110_pes_play(av7110->debi_virt, &av7110->aout, 2048);
617 spin_unlock(&av7110->aout.lock);
619 if (len <= 0 && (av7110->debitype & 0x200)
620 &&av7110->videostate.play_state != VIDEO_FREEZED) {
621 spin_lock(&av7110->avout.lock);
622 len = av7110_pes_play(av7110->debi_virt, &av7110->avout, 2048);
623 spin_unlock(&av7110->avout.lock);
625 if (len <= 0) {
626 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
627 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
628 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
629 break;
631 dprintk(8, "GPIO0 PES_PLAY len=%04x\n", len);
632 iwdebi(av7110, DEBINOSWAP, TX_LEN, len, 2);
633 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, len, 2);
634 dprintk(8, "DMA: MPEG_PLAY\n");
635 start_debi_dma(av7110, DEBI_WRITE, DPRAM_BASE + txbuf, len);
636 spin_unlock(&av7110->debilock);
637 return;
639 case DATA_BMP_LOAD:
640 len = av7110->debilen;
641 dprintk(8, "gpio DATA_BMP_LOAD len %d\n", len);
642 if (!len) {
643 av7110->bmp_state = BMP_LOADED;
644 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
645 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
646 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
647 wake_up(&av7110->bmpq);
648 dprintk(8, "gpio DATA_BMP_LOAD done\n");
649 break;
651 if (len > av7110->bmplen)
652 len = av7110->bmplen;
653 if (len > 2 * 1024)
654 len = 2 * 1024;
655 iwdebi(av7110, DEBINOSWAP, TX_LEN, len, 2);
656 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, len, 2);
657 memcpy(av7110->debi_virt, av7110->bmpbuf+av7110->bmpp, len);
658 av7110->bmpp += len;
659 av7110->bmplen -= len;
660 dprintk(8, "gpio DATA_BMP_LOAD DMA len %d\n", len);
661 start_debi_dma(av7110, DEBI_WRITE, DPRAM_BASE+txbuf, len);
662 spin_unlock(&av7110->debilock);
663 return;
665 case DATA_CI_GET:
666 case DATA_COMMON_INTERFACE:
667 case DATA_FSECTION:
668 case DATA_IPMPE:
669 case DATA_PIPING:
670 if (!len || len > 4 * 1024) {
671 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
672 break;
674 /* fall through */
676 case DATA_TS_RECORD:
677 case DATA_PES_RECORD:
678 dprintk(8, "DMA: TS_REC etc.\n");
679 start_debi_dma(av7110, DEBI_READ, DPRAM_BASE+rxbuf, len);
680 spin_unlock(&av7110->debilock);
681 return;
683 case DATA_DEBUG_MESSAGE:
684 if (!len || len > 0xff) {
685 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
686 break;
688 start_debi_dma(av7110, DEBI_READ, Reserved, len);
689 spin_unlock(&av7110->debilock);
690 return;
692 case DATA_IRCOMMAND:
693 if (av7110->ir.ir_handler)
694 av7110->ir.ir_handler(av7110,
695 swahw32(irdebi(av7110, DEBINOSWAP, Reserved, 0, 4)));
696 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
697 break;
699 default:
700 printk("dvb-ttpci: gpioirq unknown type=%d len=%d\n",
701 av7110->debitype, av7110->debilen);
702 break;
704 av7110->debitype = -1;
705 ARM_ClearMailBox(av7110);
706 spin_unlock(&av7110->debilock);
710 #ifdef CONFIG_DVB_AV7110_OSD
711 static int dvb_osd_ioctl(struct file *file,
712 unsigned int cmd, void *parg)
714 struct dvb_device *dvbdev = file->private_data;
715 struct av7110 *av7110 = dvbdev->priv;
717 dprintk(4, "%p\n", av7110);
719 if (cmd == OSD_SEND_CMD)
720 return av7110_osd_cmd(av7110, (osd_cmd_t *) parg);
721 if (cmd == OSD_GET_CAPABILITY)
722 return av7110_osd_capability(av7110, (osd_cap_t *) parg);
724 return -EINVAL;
728 static const struct file_operations dvb_osd_fops = {
729 .owner = THIS_MODULE,
730 .unlocked_ioctl = dvb_generic_ioctl,
731 .open = dvb_generic_open,
732 .release = dvb_generic_release,
735 static struct dvb_device dvbdev_osd = {
736 .priv = NULL,
737 .users = 1,
738 .writers = 1,
739 .fops = &dvb_osd_fops,
740 .kernel_ioctl = dvb_osd_ioctl,
742 #endif /* CONFIG_DVB_AV7110_OSD */
745 static inline int SetPIDs(struct av7110 *av7110, u16 vpid, u16 apid, u16 ttpid,
746 u16 subpid, u16 pcrpid)
748 u16 aflags = 0;
750 dprintk(4, "%p\n", av7110);
752 if (vpid == 0x1fff || apid == 0x1fff ||
753 ttpid == 0x1fff || subpid == 0x1fff || pcrpid == 0x1fff) {
754 vpid = apid = ttpid = subpid = pcrpid = 0;
755 av7110->pids[DMX_PES_VIDEO] = 0;
756 av7110->pids[DMX_PES_AUDIO] = 0;
757 av7110->pids[DMX_PES_TELETEXT] = 0;
758 av7110->pids[DMX_PES_PCR] = 0;
761 if (av7110->audiostate.bypass_mode)
762 aflags |= 0x8000;
764 return av7110_fw_cmd(av7110, COMTYPE_PIDFILTER, MultiPID, 6,
765 pcrpid, vpid, apid, ttpid, subpid, aflags);
768 int ChangePIDs(struct av7110 *av7110, u16 vpid, u16 apid, u16 ttpid,
769 u16 subpid, u16 pcrpid)
771 int ret = 0;
772 dprintk(4, "%p\n", av7110);
774 if (mutex_lock_interruptible(&av7110->pid_mutex))
775 return -ERESTARTSYS;
777 if (!(vpid & 0x8000))
778 av7110->pids[DMX_PES_VIDEO] = vpid;
779 if (!(apid & 0x8000))
780 av7110->pids[DMX_PES_AUDIO] = apid;
781 if (!(ttpid & 0x8000))
782 av7110->pids[DMX_PES_TELETEXT] = ttpid;
783 if (!(pcrpid & 0x8000))
784 av7110->pids[DMX_PES_PCR] = pcrpid;
786 av7110->pids[DMX_PES_SUBTITLE] = 0;
788 if (av7110->fe_synced) {
789 pcrpid = av7110->pids[DMX_PES_PCR];
790 ret = SetPIDs(av7110, vpid, apid, ttpid, subpid, pcrpid);
793 mutex_unlock(&av7110->pid_mutex);
794 return ret;
798 /******************************************************************************
799 * hardware filter functions
800 ******************************************************************************/
802 static int StartHWFilter(struct dvb_demux_filter *dvbdmxfilter)
804 struct dvb_demux_feed *dvbdmxfeed = dvbdmxfilter->feed;
805 struct av7110 *av7110 = dvbdmxfeed->demux->priv;
806 u16 buf[20];
807 int ret, i;
808 u16 handle;
809 // u16 mode = 0x0320;
810 u16 mode = 0xb96a;
812 dprintk(4, "%p\n", av7110);
814 if (av7110->full_ts)
815 return 0;
817 if (dvbdmxfilter->type == DMX_TYPE_SEC) {
818 if (hw_sections) {
819 buf[4] = (dvbdmxfilter->filter.filter_value[0] << 8) |
820 dvbdmxfilter->maskandmode[0];
821 for (i = 3; i < 18; i++)
822 buf[i + 4 - 2] =
823 (dvbdmxfilter->filter.filter_value[i] << 8) |
824 dvbdmxfilter->maskandmode[i];
825 mode = 4;
827 } else if ((dvbdmxfeed->ts_type & TS_PACKET) &&
828 !(dvbdmxfeed->ts_type & TS_PAYLOAD_ONLY)) {
829 av7110_p2t_init(&av7110->p2t_filter[dvbdmxfilter->index], dvbdmxfeed);
832 buf[0] = (COMTYPE_PID_FILTER << 8) + AddPIDFilter;
833 buf[1] = 16;
834 buf[2] = dvbdmxfeed->pid;
835 buf[3] = mode;
837 ret = av7110_fw_request(av7110, buf, 20, &handle, 1);
838 if (ret != 0 || handle >= 32) {
839 printk("dvb-ttpci: %s error buf %04x %04x %04x %04x "
840 "ret %d handle %04x\n",
841 __func__, buf[0], buf[1], buf[2], buf[3],
842 ret, handle);
843 dvbdmxfilter->hw_handle = 0xffff;
844 if (!ret)
845 ret = -1;
846 return ret;
849 av7110->handle2filter[handle] = dvbdmxfilter;
850 dvbdmxfilter->hw_handle = handle;
852 return ret;
855 static int StopHWFilter(struct dvb_demux_filter *dvbdmxfilter)
857 struct av7110 *av7110 = dvbdmxfilter->feed->demux->priv;
858 u16 buf[3];
859 u16 answ[2];
860 int ret;
861 u16 handle;
863 dprintk(4, "%p\n", av7110);
865 if (av7110->full_ts)
866 return 0;
868 handle = dvbdmxfilter->hw_handle;
869 if (handle >= 32) {
870 printk("%s tried to stop invalid filter %04x, filter type = %x\n",
871 __func__, handle, dvbdmxfilter->type);
872 return -EINVAL;
875 av7110->handle2filter[handle] = NULL;
877 buf[0] = (COMTYPE_PID_FILTER << 8) + DelPIDFilter;
878 buf[1] = 1;
879 buf[2] = handle;
880 ret = av7110_fw_request(av7110, buf, 3, answ, 2);
881 if (ret != 0 || answ[1] != handle) {
882 printk("dvb-ttpci: %s error cmd %04x %04x %04x ret %x "
883 "resp %04x %04x pid %d\n",
884 __func__, buf[0], buf[1], buf[2], ret,
885 answ[0], answ[1], dvbdmxfilter->feed->pid);
886 if (!ret)
887 ret = -1;
889 return ret;
893 static int dvb_feed_start_pid(struct dvb_demux_feed *dvbdmxfeed)
895 struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
896 struct av7110 *av7110 = dvbdmx->priv;
897 u16 *pid = dvbdmx->pids, npids[5];
898 int i;
899 int ret = 0;
901 dprintk(4, "%p\n", av7110);
903 npids[0] = npids[1] = npids[2] = npids[3] = npids[4] = 0xffff;
904 i = dvbdmxfeed->pes_type;
905 npids[i] = (pid[i]&0x8000) ? 0 : pid[i];
906 if ((i == 2) && npids[i] && (dvbdmxfeed->ts_type & TS_PACKET)) {
907 npids[i] = 0;
908 ret = ChangePIDs(av7110, npids[1], npids[0], npids[2], npids[3], npids[4]);
909 if (!ret)
910 ret = StartHWFilter(dvbdmxfeed->filter);
911 return ret;
913 if (dvbdmxfeed->pes_type <= 2 || dvbdmxfeed->pes_type == 4) {
914 ret = ChangePIDs(av7110, npids[1], npids[0], npids[2], npids[3], npids[4]);
915 if (ret)
916 return ret;
919 if (dvbdmxfeed->pes_type < 2 && npids[0])
920 if (av7110->fe_synced)
922 ret = av7110_fw_cmd(av7110, COMTYPE_PIDFILTER, Scan, 0);
923 if (ret)
924 return ret;
927 if ((dvbdmxfeed->ts_type & TS_PACKET) && !av7110->full_ts) {
928 if (dvbdmxfeed->pes_type == 0 && !(dvbdmx->pids[0] & 0x8000))
929 ret = av7110_av_start_record(av7110, RP_AUDIO, dvbdmxfeed);
930 if (dvbdmxfeed->pes_type == 1 && !(dvbdmx->pids[1] & 0x8000))
931 ret = av7110_av_start_record(av7110, RP_VIDEO, dvbdmxfeed);
933 return ret;
936 static int dvb_feed_stop_pid(struct dvb_demux_feed *dvbdmxfeed)
938 struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
939 struct av7110 *av7110 = dvbdmx->priv;
940 u16 *pid = dvbdmx->pids, npids[5];
941 int i;
943 int ret = 0;
945 dprintk(4, "%p\n", av7110);
947 if (dvbdmxfeed->pes_type <= 1) {
948 ret = av7110_av_stop(av7110, dvbdmxfeed->pes_type ? RP_VIDEO : RP_AUDIO);
949 if (ret)
950 return ret;
951 if (!av7110->rec_mode)
952 dvbdmx->recording = 0;
953 if (!av7110->playing)
954 dvbdmx->playing = 0;
956 npids[0] = npids[1] = npids[2] = npids[3] = npids[4] = 0xffff;
957 i = dvbdmxfeed->pes_type;
958 switch (i) {
959 case 2: //teletext
960 if (dvbdmxfeed->ts_type & TS_PACKET)
961 ret = StopHWFilter(dvbdmxfeed->filter);
962 npids[2] = 0;
963 break;
964 case 0:
965 case 1:
966 case 4:
967 if (!pids_off)
968 return 0;
969 npids[i] = (pid[i]&0x8000) ? 0 : pid[i];
970 break;
972 if (!ret)
973 ret = ChangePIDs(av7110, npids[1], npids[0], npids[2], npids[3], npids[4]);
974 return ret;
977 static int av7110_start_feed(struct dvb_demux_feed *feed)
979 struct dvb_demux *demux = feed->demux;
980 struct av7110 *av7110 = demux->priv;
981 int ret = 0;
983 dprintk(4, "%p\n", av7110);
985 if (!demux->dmx.frontend)
986 return -EINVAL;
988 if (!av7110->full_ts && feed->pid > 0x1fff)
989 return -EINVAL;
991 if (feed->type == DMX_TYPE_TS) {
992 if ((feed->ts_type & TS_DECODER) &&
993 (feed->pes_type < DMX_TS_PES_OTHER)) {
994 switch (demux->dmx.frontend->source) {
995 case DMX_MEMORY_FE:
996 if (feed->ts_type & TS_DECODER)
997 if (feed->pes_type < 2 &&
998 !(demux->pids[0] & 0x8000) &&
999 !(demux->pids[1] & 0x8000)) {
1000 dvb_ringbuffer_flush_spinlock_wakeup(&av7110->avout);
1001 dvb_ringbuffer_flush_spinlock_wakeup(&av7110->aout);
1002 ret = av7110_av_start_play(av7110,RP_AV);
1003 if (!ret)
1004 demux->playing = 1;
1006 break;
1007 default:
1008 ret = dvb_feed_start_pid(feed);
1009 break;
1011 } else if ((feed->ts_type & TS_PACKET) &&
1012 (demux->dmx.frontend->source != DMX_MEMORY_FE)) {
1013 ret = StartHWFilter(feed->filter);
1017 if (av7110->full_ts) {
1018 budget_start_feed(feed);
1019 return ret;
1022 if (feed->type == DMX_TYPE_SEC) {
1023 int i;
1025 for (i = 0; i < demux->filternum; i++) {
1026 if (demux->filter[i].state != DMX_STATE_READY)
1027 continue;
1028 if (demux->filter[i].type != DMX_TYPE_SEC)
1029 continue;
1030 if (demux->filter[i].filter.parent != &feed->feed.sec)
1031 continue;
1032 demux->filter[i].state = DMX_STATE_GO;
1033 if (demux->dmx.frontend->source != DMX_MEMORY_FE) {
1034 ret = StartHWFilter(&demux->filter[i]);
1035 if (ret)
1036 break;
1041 return ret;
1045 static int av7110_stop_feed(struct dvb_demux_feed *feed)
1047 struct dvb_demux *demux = feed->demux;
1048 struct av7110 *av7110 = demux->priv;
1049 int i, rc, ret = 0;
1050 dprintk(4, "%p\n", av7110);
1052 if (feed->type == DMX_TYPE_TS) {
1053 if (feed->ts_type & TS_DECODER) {
1054 if (feed->pes_type >= DMX_TS_PES_OTHER ||
1055 !demux->pesfilter[feed->pes_type])
1056 return -EINVAL;
1057 demux->pids[feed->pes_type] |= 0x8000;
1058 demux->pesfilter[feed->pes_type] = NULL;
1060 if (feed->ts_type & TS_DECODER &&
1061 feed->pes_type < DMX_TS_PES_OTHER) {
1062 ret = dvb_feed_stop_pid(feed);
1063 } else
1064 if ((feed->ts_type & TS_PACKET) &&
1065 (demux->dmx.frontend->source != DMX_MEMORY_FE))
1066 ret = StopHWFilter(feed->filter);
1069 if (av7110->full_ts) {
1070 budget_stop_feed(feed);
1071 return ret;
1074 if (feed->type == DMX_TYPE_SEC) {
1075 for (i = 0; i<demux->filternum; i++) {
1076 if (demux->filter[i].state == DMX_STATE_GO &&
1077 demux->filter[i].filter.parent == &feed->feed.sec) {
1078 demux->filter[i].state = DMX_STATE_READY;
1079 if (demux->dmx.frontend->source != DMX_MEMORY_FE) {
1080 rc = StopHWFilter(&demux->filter[i]);
1081 if (!ret)
1082 ret = rc;
1083 /* keep going, stop as many filters as possible */
1089 return ret;
1093 static void restart_feeds(struct av7110 *av7110)
1095 struct dvb_demux *dvbdmx = &av7110->demux;
1096 struct dvb_demux_feed *feed;
1097 int mode;
1098 int feeding;
1099 int i, j;
1101 dprintk(4, "%p\n", av7110);
1103 mode = av7110->playing;
1104 av7110->playing = 0;
1105 av7110->rec_mode = 0;
1107 feeding = av7110->feeding1; /* full_ts mod */
1109 for (i = 0; i < dvbdmx->feednum; i++) {
1110 feed = &dvbdmx->feed[i];
1111 if (feed->state == DMX_STATE_GO) {
1112 if (feed->type == DMX_TYPE_SEC) {
1113 for (j = 0; j < dvbdmx->filternum; j++) {
1114 if (dvbdmx->filter[j].type != DMX_TYPE_SEC)
1115 continue;
1116 if (dvbdmx->filter[j].filter.parent != &feed->feed.sec)
1117 continue;
1118 if (dvbdmx->filter[j].state == DMX_STATE_GO)
1119 dvbdmx->filter[j].state = DMX_STATE_READY;
1122 av7110_start_feed(feed);
1126 av7110->feeding1 = feeding; /* full_ts mod */
1128 if (mode)
1129 av7110_av_start_play(av7110, mode);
1132 static int dvb_get_stc(struct dmx_demux *demux, unsigned int num,
1133 uint64_t *stc, unsigned int *base)
1135 int ret;
1136 u16 fwstc[4];
1137 u16 tag = ((COMTYPE_REQUEST << 8) + ReqSTC);
1138 struct dvb_demux *dvbdemux;
1139 struct av7110 *av7110;
1141 /* pointer casting paranoia... */
1142 BUG_ON(!demux);
1143 dvbdemux = demux->priv;
1144 BUG_ON(!dvbdemux);
1145 av7110 = dvbdemux->priv;
1147 dprintk(4, "%p\n", av7110);
1149 if (num != 0)
1150 return -EINVAL;
1152 ret = av7110_fw_request(av7110, &tag, 0, fwstc, 4);
1153 if (ret) {
1154 printk(KERN_ERR "%s: av7110_fw_request error\n", __func__);
1155 return ret;
1157 dprintk(2, "fwstc = %04hx %04hx %04hx %04hx\n",
1158 fwstc[0], fwstc[1], fwstc[2], fwstc[3]);
1160 *stc = (((uint64_t) ((fwstc[3] & 0x8000) >> 15)) << 32) |
1161 (((uint64_t) fwstc[1]) << 16) | ((uint64_t) fwstc[0]);
1162 *base = 1;
1164 dprintk(4, "stc = %lu\n", (unsigned long)*stc);
1166 return 0;
1170 /******************************************************************************
1171 * SEC device file operations
1172 ******************************************************************************/
1175 static int av7110_set_tone(struct dvb_frontend* fe, fe_sec_tone_mode_t tone)
1177 struct av7110* av7110 = fe->dvb->priv;
1179 switch (tone) {
1180 case SEC_TONE_ON:
1181 return Set22K(av7110, 1);
1183 case SEC_TONE_OFF:
1184 return Set22K(av7110, 0);
1186 default:
1187 return -EINVAL;
1191 static int av7110_diseqc_send_master_cmd(struct dvb_frontend* fe,
1192 struct dvb_diseqc_master_cmd* cmd)
1194 struct av7110* av7110 = fe->dvb->priv;
1196 return av7110_diseqc_send(av7110, cmd->msg_len, cmd->msg, -1);
1199 static int av7110_diseqc_send_burst(struct dvb_frontend* fe,
1200 fe_sec_mini_cmd_t minicmd)
1202 struct av7110* av7110 = fe->dvb->priv;
1204 return av7110_diseqc_send(av7110, 0, NULL, minicmd);
1207 /* simplified code from budget-core.c */
1208 static int stop_ts_capture(struct av7110 *budget)
1210 dprintk(2, "budget: %p\n", budget);
1212 if (--budget->feeding1)
1213 return budget->feeding1;
1214 saa7146_write(budget->dev, MC1, MASK_20); /* DMA3 off */
1215 SAA7146_IER_DISABLE(budget->dev, MASK_10);
1216 SAA7146_ISR_CLEAR(budget->dev, MASK_10);
1217 return 0;
1220 static int start_ts_capture(struct av7110 *budget)
1222 dprintk(2, "budget: %p\n", budget);
1224 if (budget->feeding1)
1225 return ++budget->feeding1;
1226 memset(budget->grabbing, 0x00, TS_BUFLEN);
1227 budget->ttbp = 0;
1228 SAA7146_ISR_CLEAR(budget->dev, MASK_10); /* VPE */
1229 SAA7146_IER_ENABLE(budget->dev, MASK_10); /* VPE */
1230 saa7146_write(budget->dev, MC1, (MASK_04 | MASK_20)); /* DMA3 on */
1231 return ++budget->feeding1;
1234 static int budget_start_feed(struct dvb_demux_feed *feed)
1236 struct dvb_demux *demux = feed->demux;
1237 struct av7110 *budget = demux->priv;
1238 int status;
1240 dprintk(2, "av7110: %p\n", budget);
1242 spin_lock(&budget->feedlock1);
1243 feed->pusi_seen = 0; /* have a clean section start */
1244 status = start_ts_capture(budget);
1245 spin_unlock(&budget->feedlock1);
1246 return status;
1249 static int budget_stop_feed(struct dvb_demux_feed *feed)
1251 struct dvb_demux *demux = feed->demux;
1252 struct av7110 *budget = demux->priv;
1253 int status;
1255 dprintk(2, "budget: %p\n", budget);
1257 spin_lock(&budget->feedlock1);
1258 status = stop_ts_capture(budget);
1259 spin_unlock(&budget->feedlock1);
1260 return status;
1263 static void vpeirq(unsigned long cookie)
1265 struct av7110 *budget = (struct av7110 *)cookie;
1266 u8 *mem = (u8 *) (budget->grabbing);
1267 u32 olddma = budget->ttbp;
1268 u32 newdma = saa7146_read(budget->dev, PCI_VDP3);
1269 struct dvb_demux *demux = budget->full_ts ? &budget->demux : &budget->demux1;
1271 /* nearest lower position divisible by 188 */
1272 newdma -= newdma % 188;
1274 if (newdma >= TS_BUFLEN)
1275 return;
1277 budget->ttbp = newdma;
1279 if (!budget->feeding1 || (newdma == olddma))
1280 return;
1282 /* Ensure streamed PCI data is synced to CPU */
1283 pci_dma_sync_sg_for_cpu(budget->dev->pci, budget->pt.slist, budget->pt.nents, PCI_DMA_FROMDEVICE);
1285 #if 0
1286 /* track rps1 activity */
1287 printk("vpeirq: %02x Event Counter 1 0x%04x\n",
1288 mem[olddma],
1289 saa7146_read(budget->dev, EC1R) & 0x3fff);
1290 #endif
1292 if (newdma > olddma)
1293 /* no wraparound, dump olddma..newdma */
1294 dvb_dmx_swfilter_packets(demux, mem + olddma, (newdma - olddma) / 188);
1295 else {
1296 /* wraparound, dump olddma..buflen and 0..newdma */
1297 dvb_dmx_swfilter_packets(demux, mem + olddma, (TS_BUFLEN - olddma) / 188);
1298 dvb_dmx_swfilter_packets(demux, mem, newdma / 188);
1302 static int av7110_register(struct av7110 *av7110)
1304 int ret, i;
1305 struct dvb_demux *dvbdemux = &av7110->demux;
1306 struct dvb_demux *dvbdemux1 = &av7110->demux1;
1308 dprintk(4, "%p\n", av7110);
1310 if (av7110->registered)
1311 return -1;
1313 av7110->registered = 1;
1315 dvbdemux->priv = (void *) av7110;
1317 for (i = 0; i < 32; i++)
1318 av7110->handle2filter[i] = NULL;
1320 dvbdemux->filternum = (av7110->full_ts) ? 256 : 32;
1321 dvbdemux->feednum = (av7110->full_ts) ? 256 : 32;
1322 dvbdemux->start_feed = av7110_start_feed;
1323 dvbdemux->stop_feed = av7110_stop_feed;
1324 dvbdemux->write_to_decoder = av7110_write_to_decoder;
1325 dvbdemux->dmx.capabilities = (DMX_TS_FILTERING | DMX_SECTION_FILTERING |
1326 DMX_MEMORY_BASED_FILTERING);
1328 dvb_dmx_init(&av7110->demux);
1329 av7110->demux.dmx.get_stc = dvb_get_stc;
1331 av7110->dmxdev.filternum = (av7110->full_ts) ? 256 : 32;
1332 av7110->dmxdev.demux = &dvbdemux->dmx;
1333 av7110->dmxdev.capabilities = 0;
1335 dvb_dmxdev_init(&av7110->dmxdev, &av7110->dvb_adapter);
1337 av7110->hw_frontend.source = DMX_FRONTEND_0;
1339 ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &av7110->hw_frontend);
1341 if (ret < 0)
1342 return ret;
1344 av7110->mem_frontend.source = DMX_MEMORY_FE;
1346 ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &av7110->mem_frontend);
1348 if (ret < 0)
1349 return ret;
1351 ret = dvbdemux->dmx.connect_frontend(&dvbdemux->dmx,
1352 &av7110->hw_frontend);
1353 if (ret < 0)
1354 return ret;
1356 av7110_av_register(av7110);
1357 av7110_ca_register(av7110);
1359 #ifdef CONFIG_DVB_AV7110_OSD
1360 dvb_register_device(&av7110->dvb_adapter, &av7110->osd_dev,
1361 &dvbdev_osd, av7110, DVB_DEVICE_OSD);
1362 #endif
1364 dvb_net_init(&av7110->dvb_adapter, &av7110->dvb_net, &dvbdemux->dmx);
1366 if (budgetpatch) {
1367 /* initialize software demux1 without its own frontend
1368 * demux1 hardware is connected to frontend0 of demux0
1370 dvbdemux1->priv = (void *) av7110;
1372 dvbdemux1->filternum = 256;
1373 dvbdemux1->feednum = 256;
1374 dvbdemux1->start_feed = budget_start_feed;
1375 dvbdemux1->stop_feed = budget_stop_feed;
1376 dvbdemux1->write_to_decoder = NULL;
1378 dvbdemux1->dmx.capabilities = (DMX_TS_FILTERING | DMX_SECTION_FILTERING |
1379 DMX_MEMORY_BASED_FILTERING);
1381 dvb_dmx_init(&av7110->demux1);
1383 av7110->dmxdev1.filternum = 256;
1384 av7110->dmxdev1.demux = &dvbdemux1->dmx;
1385 av7110->dmxdev1.capabilities = 0;
1387 dvb_dmxdev_init(&av7110->dmxdev1, &av7110->dvb_adapter);
1389 dvb_net_init(&av7110->dvb_adapter, &av7110->dvb_net1, &dvbdemux1->dmx);
1390 printk("dvb-ttpci: additional demux1 for budget-patch registered\n");
1392 return 0;
1396 static void dvb_unregister(struct av7110 *av7110)
1398 struct dvb_demux *dvbdemux = &av7110->demux;
1399 struct dvb_demux *dvbdemux1 = &av7110->demux1;
1401 dprintk(4, "%p\n", av7110);
1403 if (!av7110->registered)
1404 return;
1406 if (budgetpatch) {
1407 dvb_net_release(&av7110->dvb_net1);
1408 dvbdemux->dmx.close(&dvbdemux1->dmx);
1409 dvb_dmxdev_release(&av7110->dmxdev1);
1410 dvb_dmx_release(&av7110->demux1);
1413 dvb_net_release(&av7110->dvb_net);
1415 dvbdemux->dmx.close(&dvbdemux->dmx);
1416 dvbdemux->dmx.remove_frontend(&dvbdemux->dmx, &av7110->hw_frontend);
1417 dvbdemux->dmx.remove_frontend(&dvbdemux->dmx, &av7110->mem_frontend);
1419 dvb_dmxdev_release(&av7110->dmxdev);
1420 dvb_dmx_release(&av7110->demux);
1422 if (av7110->fe != NULL) {
1423 dvb_unregister_frontend(av7110->fe);
1424 dvb_frontend_detach(av7110->fe);
1426 dvb_unregister_device(av7110->osd_dev);
1427 av7110_av_unregister(av7110);
1428 av7110_ca_unregister(av7110);
1432 /****************************************************************************
1433 * I2C client commands
1434 ****************************************************************************/
1436 int i2c_writereg(struct av7110 *av7110, u8 id, u8 reg, u8 val)
1438 u8 msg[2] = { reg, val };
1439 struct i2c_msg msgs;
1441 msgs.flags = 0;
1442 msgs.addr = id / 2;
1443 msgs.len = 2;
1444 msgs.buf = msg;
1445 return i2c_transfer(&av7110->i2c_adap, &msgs, 1);
1448 u8 i2c_readreg(struct av7110 *av7110, u8 id, u8 reg)
1450 u8 mm1[] = {0x00};
1451 u8 mm2[] = {0x00};
1452 struct i2c_msg msgs[2];
1454 msgs[0].flags = 0;
1455 msgs[1].flags = I2C_M_RD;
1456 msgs[0].addr = msgs[1].addr = id / 2;
1457 mm1[0] = reg;
1458 msgs[0].len = 1; msgs[1].len = 1;
1459 msgs[0].buf = mm1; msgs[1].buf = mm2;
1460 i2c_transfer(&av7110->i2c_adap, msgs, 2);
1462 return mm2[0];
1465 /****************************************************************************
1466 * INITIALIZATION
1467 ****************************************************************************/
1470 static int check_firmware(struct av7110* av7110)
1472 u32 crc = 0, len = 0;
1473 unsigned char *ptr;
1475 /* check for firmware magic */
1476 ptr = av7110->bin_fw;
1477 if (ptr[0] != 'A' || ptr[1] != 'V' ||
1478 ptr[2] != 'F' || ptr[3] != 'W') {
1479 printk("dvb-ttpci: this is not an av7110 firmware\n");
1480 return -EINVAL;
1482 ptr += 4;
1484 /* check dpram file */
1485 crc = get_unaligned_be32(ptr);
1486 ptr += 4;
1487 len = get_unaligned_be32(ptr);
1488 ptr += 4;
1489 if (len >= 512) {
1490 printk("dvb-ttpci: dpram file is way too big.\n");
1491 return -EINVAL;
1493 if (crc != crc32_le(0, ptr, len)) {
1494 printk("dvb-ttpci: crc32 of dpram file does not match.\n");
1495 return -EINVAL;
1497 av7110->bin_dpram = ptr;
1498 av7110->size_dpram = len;
1499 ptr += len;
1501 /* check root file */
1502 crc = get_unaligned_be32(ptr);
1503 ptr += 4;
1504 len = get_unaligned_be32(ptr);
1505 ptr += 4;
1507 if (len <= 200000 || len >= 300000 ||
1508 len > ((av7110->bin_fw + av7110->size_fw) - ptr)) {
1509 printk("dvb-ttpci: root file has strange size (%d). aborting.\n", len);
1510 return -EINVAL;
1512 if( crc != crc32_le(0, ptr, len)) {
1513 printk("dvb-ttpci: crc32 of root file does not match.\n");
1514 return -EINVAL;
1516 av7110->bin_root = ptr;
1517 av7110->size_root = len;
1518 return 0;
1521 static void put_firmware(struct av7110* av7110)
1523 vfree(av7110->bin_fw);
1526 static int get_firmware(struct av7110* av7110)
1528 int ret;
1529 const struct firmware *fw;
1531 /* request the av7110 firmware, this will block until someone uploads it */
1532 ret = request_firmware(&fw, "dvb-ttpci-01.fw", &av7110->dev->pci->dev);
1533 if (ret) {
1534 if (ret == -ENOENT) {
1535 printk(KERN_ERR "dvb-ttpci: could not load firmware,"
1536 " file not found: dvb-ttpci-01.fw\n");
1537 printk(KERN_ERR "dvb-ttpci: usually this should be in "
1538 "/usr/lib/hotplug/firmware or /lib/firmware\n");
1539 printk(KERN_ERR "dvb-ttpci: and can be downloaded from"
1540 " http://www.linuxtv.org/download/dvb/firmware/\n");
1541 } else
1542 printk(KERN_ERR "dvb-ttpci: cannot request firmware"
1543 " (error %i)\n", ret);
1544 return -EINVAL;
1547 if (fw->size <= 200000) {
1548 printk("dvb-ttpci: this firmware is way too small.\n");
1549 release_firmware(fw);
1550 return -EINVAL;
1553 /* check if the firmware is available */
1554 av7110->bin_fw = vmalloc(fw->size);
1555 if (NULL == av7110->bin_fw) {
1556 dprintk(1, "out of memory\n");
1557 release_firmware(fw);
1558 return -ENOMEM;
1561 memcpy(av7110->bin_fw, fw->data, fw->size);
1562 av7110->size_fw = fw->size;
1563 if ((ret = check_firmware(av7110)))
1564 vfree(av7110->bin_fw);
1566 release_firmware(fw);
1567 return ret;
1570 static int alps_bsrv2_tuner_set_params(struct dvb_frontend* fe, struct dvb_frontend_parameters *params)
1572 struct av7110* av7110 = fe->dvb->priv;
1573 u8 pwr = 0;
1574 u8 buf[4];
1575 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = buf, .len = sizeof(buf) };
1576 u32 div = (params->frequency + 479500) / 125;
1578 if (params->frequency > 2000000) pwr = 3;
1579 else if (params->frequency > 1800000) pwr = 2;
1580 else if (params->frequency > 1600000) pwr = 1;
1581 else if (params->frequency > 1200000) pwr = 0;
1582 else if (params->frequency >= 1100000) pwr = 1;
1583 else pwr = 2;
1585 buf[0] = (div >> 8) & 0x7f;
1586 buf[1] = div & 0xff;
1587 buf[2] = ((div & 0x18000) >> 10) | 0x95;
1588 buf[3] = (pwr << 6) | 0x30;
1590 // NOTE: since we're using a prescaler of 2, we set the
1591 // divisor frequency to 62.5kHz and divide by 125 above
1593 if (fe->ops.i2c_gate_ctrl)
1594 fe->ops.i2c_gate_ctrl(fe, 1);
1595 if (i2c_transfer (&av7110->i2c_adap, &msg, 1) != 1)
1596 return -EIO;
1597 return 0;
1600 static struct ves1x93_config alps_bsrv2_config = {
1601 .demod_address = 0x08,
1602 .xin = 90100000UL,
1603 .invert_pwm = 0,
1606 static int alps_tdbe2_tuner_set_params(struct dvb_frontend* fe, struct dvb_frontend_parameters *params)
1608 struct av7110* av7110 = fe->dvb->priv;
1609 u32 div;
1610 u8 data[4];
1611 struct i2c_msg msg = { .addr = 0x62, .flags = 0, .buf = data, .len = sizeof(data) };
1613 div = (params->frequency + 35937500 + 31250) / 62500;
1615 data[0] = (div >> 8) & 0x7f;
1616 data[1] = div & 0xff;
1617 data[2] = 0x85 | ((div >> 10) & 0x60);
1618 data[3] = (params->frequency < 174000000 ? 0x88 : params->frequency < 470000000 ? 0x84 : 0x81);
1620 if (fe->ops.i2c_gate_ctrl)
1621 fe->ops.i2c_gate_ctrl(fe, 1);
1622 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1623 return -EIO;
1624 return 0;
1627 static struct ves1820_config alps_tdbe2_config = {
1628 .demod_address = 0x09,
1629 .xin = 57840000UL,
1630 .invert = 1,
1631 .selagc = VES1820_SELAGC_SIGNAMPERR,
1637 static int grundig_29504_451_tuner_set_params(struct dvb_frontend* fe, struct dvb_frontend_parameters *params)
1639 struct av7110* av7110 = fe->dvb->priv;
1640 u32 div;
1641 u8 data[4];
1642 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = data, .len = sizeof(data) };
1644 div = params->frequency / 125;
1645 data[0] = (div >> 8) & 0x7f;
1646 data[1] = div & 0xff;
1647 data[2] = 0x8e;
1648 data[3] = 0x00;
1650 if (fe->ops.i2c_gate_ctrl)
1651 fe->ops.i2c_gate_ctrl(fe, 1);
1652 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1653 return -EIO;
1654 return 0;
1657 static struct tda8083_config grundig_29504_451_config = {
1658 .demod_address = 0x68,
1663 static int philips_cd1516_tuner_set_params(struct dvb_frontend* fe, struct dvb_frontend_parameters *params)
1665 struct av7110* av7110 = fe->dvb->priv;
1666 u32 div;
1667 u32 f = params->frequency;
1668 u8 data[4];
1669 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = data, .len = sizeof(data) };
1671 div = (f + 36125000 + 31250) / 62500;
1673 data[0] = (div >> 8) & 0x7f;
1674 data[1] = div & 0xff;
1675 data[2] = 0x8e;
1676 data[3] = (f < 174000000 ? 0xa1 : f < 470000000 ? 0x92 : 0x34);
1678 if (fe->ops.i2c_gate_ctrl)
1679 fe->ops.i2c_gate_ctrl(fe, 1);
1680 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1681 return -EIO;
1682 return 0;
1685 static struct ves1820_config philips_cd1516_config = {
1686 .demod_address = 0x09,
1687 .xin = 57840000UL,
1688 .invert = 1,
1689 .selagc = VES1820_SELAGC_SIGNAMPERR,
1694 static int alps_tdlb7_tuner_set_params(struct dvb_frontend* fe, struct dvb_frontend_parameters *params)
1696 struct av7110* av7110 = fe->dvb->priv;
1697 u32 div, pwr;
1698 u8 data[4];
1699 struct i2c_msg msg = { .addr = 0x60, .flags = 0, .buf = data, .len = sizeof(data) };
1701 div = (params->frequency + 36200000) / 166666;
1703 if (params->frequency <= 782000000)
1704 pwr = 1;
1705 else
1706 pwr = 2;
1708 data[0] = (div >> 8) & 0x7f;
1709 data[1] = div & 0xff;
1710 data[2] = 0x85;
1711 data[3] = pwr << 6;
1713 if (fe->ops.i2c_gate_ctrl)
1714 fe->ops.i2c_gate_ctrl(fe, 1);
1715 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1716 return -EIO;
1717 return 0;
1720 static int alps_tdlb7_request_firmware(struct dvb_frontend* fe, const struct firmware **fw, char* name)
1722 #if defined(CONFIG_DVB_SP8870) || defined(CONFIG_DVB_SP8870_MODULE)
1723 struct av7110* av7110 = fe->dvb->priv;
1725 return request_firmware(fw, name, &av7110->dev->pci->dev);
1726 #else
1727 return -EINVAL;
1728 #endif
1731 static struct sp8870_config alps_tdlb7_config = {
1733 .demod_address = 0x71,
1734 .request_firmware = alps_tdlb7_request_firmware,
1738 static u8 nexusca_stv0297_inittab[] = {
1739 0x80, 0x01,
1740 0x80, 0x00,
1741 0x81, 0x01,
1742 0x81, 0x00,
1743 0x00, 0x09,
1744 0x01, 0x69,
1745 0x03, 0x00,
1746 0x04, 0x00,
1747 0x07, 0x00,
1748 0x08, 0x00,
1749 0x20, 0x00,
1750 0x21, 0x40,
1751 0x22, 0x00,
1752 0x23, 0x00,
1753 0x24, 0x40,
1754 0x25, 0x88,
1755 0x30, 0xff,
1756 0x31, 0x00,
1757 0x32, 0xff,
1758 0x33, 0x00,
1759 0x34, 0x50,
1760 0x35, 0x7f,
1761 0x36, 0x00,
1762 0x37, 0x20,
1763 0x38, 0x00,
1764 0x40, 0x1c,
1765 0x41, 0xff,
1766 0x42, 0x29,
1767 0x43, 0x00,
1768 0x44, 0xff,
1769 0x45, 0x00,
1770 0x46, 0x00,
1771 0x49, 0x04,
1772 0x4a, 0x00,
1773 0x4b, 0x7b,
1774 0x52, 0x30,
1775 0x55, 0xae,
1776 0x56, 0x47,
1777 0x57, 0xe1,
1778 0x58, 0x3a,
1779 0x5a, 0x1e,
1780 0x5b, 0x34,
1781 0x60, 0x00,
1782 0x63, 0x00,
1783 0x64, 0x00,
1784 0x65, 0x00,
1785 0x66, 0x00,
1786 0x67, 0x00,
1787 0x68, 0x00,
1788 0x69, 0x00,
1789 0x6a, 0x02,
1790 0x6b, 0x00,
1791 0x70, 0xff,
1792 0x71, 0x00,
1793 0x72, 0x00,
1794 0x73, 0x00,
1795 0x74, 0x0c,
1796 0x80, 0x00,
1797 0x81, 0x00,
1798 0x82, 0x00,
1799 0x83, 0x00,
1800 0x84, 0x04,
1801 0x85, 0x80,
1802 0x86, 0x24,
1803 0x87, 0x78,
1804 0x88, 0x10,
1805 0x89, 0x00,
1806 0x90, 0x01,
1807 0x91, 0x01,
1808 0xa0, 0x04,
1809 0xa1, 0x00,
1810 0xa2, 0x00,
1811 0xb0, 0x91,
1812 0xb1, 0x0b,
1813 0xc0, 0x53,
1814 0xc1, 0x70,
1815 0xc2, 0x12,
1816 0xd0, 0x00,
1817 0xd1, 0x00,
1818 0xd2, 0x00,
1819 0xd3, 0x00,
1820 0xd4, 0x00,
1821 0xd5, 0x00,
1822 0xde, 0x00,
1823 0xdf, 0x00,
1824 0x61, 0x49,
1825 0x62, 0x0b,
1826 0x53, 0x08,
1827 0x59, 0x08,
1828 0xff, 0xff,
1831 static int nexusca_stv0297_tuner_set_params(struct dvb_frontend* fe, struct dvb_frontend_parameters *params)
1833 struct av7110* av7110 = fe->dvb->priv;
1834 u32 div;
1835 u8 data[4];
1836 struct i2c_msg msg = { .addr = 0x63, .flags = 0, .buf = data, .len = sizeof(data) };
1837 struct i2c_msg readmsg = { .addr = 0x63, .flags = I2C_M_RD, .buf = data, .len = 1 };
1838 int i;
1840 div = (params->frequency + 36150000 + 31250) / 62500;
1842 data[0] = (div >> 8) & 0x7f;
1843 data[1] = div & 0xff;
1844 data[2] = 0xce;
1846 if (params->frequency < 45000000)
1847 return -EINVAL;
1848 else if (params->frequency < 137000000)
1849 data[3] = 0x01;
1850 else if (params->frequency < 403000000)
1851 data[3] = 0x02;
1852 else if (params->frequency < 860000000)
1853 data[3] = 0x04;
1854 else
1855 return -EINVAL;
1857 if (fe->ops.i2c_gate_ctrl)
1858 fe->ops.i2c_gate_ctrl(fe, 1);
1859 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1) {
1860 printk("nexusca: pll transfer failed!\n");
1861 return -EIO;
1864 // wait for PLL lock
1865 for(i = 0; i < 20; i++) {
1866 if (fe->ops.i2c_gate_ctrl)
1867 fe->ops.i2c_gate_ctrl(fe, 1);
1868 if (i2c_transfer(&av7110->i2c_adap, &readmsg, 1) == 1)
1869 if (data[0] & 0x40) break;
1870 msleep(10);
1873 return 0;
1876 static struct stv0297_config nexusca_stv0297_config = {
1878 .demod_address = 0x1C,
1879 .inittab = nexusca_stv0297_inittab,
1880 .invert = 1,
1881 .stop_during_read = 1,
1886 static int grundig_29504_401_tuner_set_params(struct dvb_frontend* fe, struct dvb_frontend_parameters *params)
1888 struct av7110* av7110 = fe->dvb->priv;
1889 u32 div;
1890 u8 cfg, cpump, band_select;
1891 u8 data[4];
1892 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = data, .len = sizeof(data) };
1894 div = (36125000 + params->frequency) / 166666;
1896 cfg = 0x88;
1898 if (params->frequency < 175000000) cpump = 2;
1899 else if (params->frequency < 390000000) cpump = 1;
1900 else if (params->frequency < 470000000) cpump = 2;
1901 else if (params->frequency < 750000000) cpump = 1;
1902 else cpump = 3;
1904 if (params->frequency < 175000000) band_select = 0x0e;
1905 else if (params->frequency < 470000000) band_select = 0x05;
1906 else band_select = 0x03;
1908 data[0] = (div >> 8) & 0x7f;
1909 data[1] = div & 0xff;
1910 data[2] = ((div >> 10) & 0x60) | cfg;
1911 data[3] = (cpump << 6) | band_select;
1913 if (fe->ops.i2c_gate_ctrl)
1914 fe->ops.i2c_gate_ctrl(fe, 1);
1915 if (i2c_transfer (&av7110->i2c_adap, &msg, 1) != 1) return -EIO;
1916 return 0;
1919 static struct l64781_config grundig_29504_401_config = {
1920 .demod_address = 0x55,
1925 static int av7110_fe_lock_fix(struct av7110* av7110, fe_status_t status)
1927 int ret = 0;
1928 int synced = (status & FE_HAS_LOCK) ? 1 : 0;
1930 av7110->fe_status = status;
1932 if (av7110->fe_synced == synced)
1933 return 0;
1935 if (av7110->playing) {
1936 av7110->fe_synced = synced;
1937 return 0;
1940 if (mutex_lock_interruptible(&av7110->pid_mutex))
1941 return -ERESTARTSYS;
1943 if (synced) {
1944 ret = SetPIDs(av7110, av7110->pids[DMX_PES_VIDEO],
1945 av7110->pids[DMX_PES_AUDIO],
1946 av7110->pids[DMX_PES_TELETEXT], 0,
1947 av7110->pids[DMX_PES_PCR]);
1948 if (!ret)
1949 ret = av7110_fw_cmd(av7110, COMTYPE_PIDFILTER, Scan, 0);
1950 } else {
1951 ret = SetPIDs(av7110, 0, 0, 0, 0, 0);
1952 if (!ret) {
1953 ret = av7110_fw_cmd(av7110, COMTYPE_PID_FILTER, FlushTSQueue, 0);
1954 if (!ret)
1955 ret = av7110_wait_msgstate(av7110, GPMQBusy);
1959 if (!ret)
1960 av7110->fe_synced = synced;
1962 mutex_unlock(&av7110->pid_mutex);
1963 return ret;
1966 static int av7110_fe_set_frontend(struct dvb_frontend* fe, struct dvb_frontend_parameters* params)
1968 struct av7110* av7110 = fe->dvb->priv;
1970 int ret = av7110_fe_lock_fix(av7110, 0);
1971 if (!ret) {
1972 av7110->saved_fe_params = *params;
1973 ret = av7110->fe_set_frontend(fe, params);
1975 return ret;
1978 static int av7110_fe_init(struct dvb_frontend* fe)
1980 struct av7110* av7110 = fe->dvb->priv;
1982 int ret = av7110_fe_lock_fix(av7110, 0);
1983 if (!ret)
1984 ret = av7110->fe_init(fe);
1985 return ret;
1988 static int av7110_fe_read_status(struct dvb_frontend* fe, fe_status_t* status)
1990 struct av7110* av7110 = fe->dvb->priv;
1992 /* call the real implementation */
1993 int ret = av7110->fe_read_status(fe, status);
1994 if (!ret)
1995 if (((*status ^ av7110->fe_status) & FE_HAS_LOCK) && (*status & FE_HAS_LOCK))
1996 ret = av7110_fe_lock_fix(av7110, *status);
1997 return ret;
2000 static int av7110_fe_diseqc_reset_overload(struct dvb_frontend* fe)
2002 struct av7110* av7110 = fe->dvb->priv;
2004 int ret = av7110_fe_lock_fix(av7110, 0);
2005 if (!ret)
2006 ret = av7110->fe_diseqc_reset_overload(fe);
2007 return ret;
2010 static int av7110_fe_diseqc_send_master_cmd(struct dvb_frontend* fe,
2011 struct dvb_diseqc_master_cmd* cmd)
2013 struct av7110* av7110 = fe->dvb->priv;
2015 int ret = av7110_fe_lock_fix(av7110, 0);
2016 if (!ret) {
2017 av7110->saved_master_cmd = *cmd;
2018 ret = av7110->fe_diseqc_send_master_cmd(fe, cmd);
2020 return ret;
2023 static int av7110_fe_diseqc_send_burst(struct dvb_frontend* fe, fe_sec_mini_cmd_t minicmd)
2025 struct av7110* av7110 = fe->dvb->priv;
2027 int ret = av7110_fe_lock_fix(av7110, 0);
2028 if (!ret) {
2029 av7110->saved_minicmd = minicmd;
2030 ret = av7110->fe_diseqc_send_burst(fe, minicmd);
2032 return ret;
2035 static int av7110_fe_set_tone(struct dvb_frontend* fe, fe_sec_tone_mode_t tone)
2037 struct av7110* av7110 = fe->dvb->priv;
2039 int ret = av7110_fe_lock_fix(av7110, 0);
2040 if (!ret) {
2041 av7110->saved_tone = tone;
2042 ret = av7110->fe_set_tone(fe, tone);
2044 return ret;
2047 static int av7110_fe_set_voltage(struct dvb_frontend* fe, fe_sec_voltage_t voltage)
2049 struct av7110* av7110 = fe->dvb->priv;
2051 int ret = av7110_fe_lock_fix(av7110, 0);
2052 if (!ret) {
2053 av7110->saved_voltage = voltage;
2054 ret = av7110->fe_set_voltage(fe, voltage);
2056 return ret;
2059 static int av7110_fe_dishnetwork_send_legacy_command(struct dvb_frontend* fe, unsigned long cmd)
2061 struct av7110* av7110 = fe->dvb->priv;
2063 int ret = av7110_fe_lock_fix(av7110, 0);
2064 if (!ret)
2065 ret = av7110->fe_dishnetwork_send_legacy_command(fe, cmd);
2066 return ret;
2069 static void dvb_s_recover(struct av7110* av7110)
2071 av7110_fe_init(av7110->fe);
2073 av7110_fe_set_voltage(av7110->fe, av7110->saved_voltage);
2074 if (av7110->saved_master_cmd.msg_len) {
2075 msleep(20);
2076 av7110_fe_diseqc_send_master_cmd(av7110->fe, &av7110->saved_master_cmd);
2078 msleep(20);
2079 av7110_fe_diseqc_send_burst(av7110->fe, av7110->saved_minicmd);
2080 msleep(20);
2081 av7110_fe_set_tone(av7110->fe, av7110->saved_tone);
2083 av7110_fe_set_frontend(av7110->fe, &av7110->saved_fe_params);
2086 static u8 read_pwm(struct av7110* av7110)
2088 u8 b = 0xff;
2089 u8 pwm;
2090 struct i2c_msg msg[] = { { .addr = 0x50,.flags = 0,.buf = &b,.len = 1 },
2091 { .addr = 0x50,.flags = I2C_M_RD,.buf = &pwm,.len = 1} };
2093 if ((i2c_transfer(&av7110->i2c_adap, msg, 2) != 2) || (pwm == 0xff))
2094 pwm = 0x48;
2096 return pwm;
2099 static int frontend_init(struct av7110 *av7110)
2101 int ret;
2103 if (av7110->dev->pci->subsystem_vendor == 0x110a) {
2104 switch(av7110->dev->pci->subsystem_device) {
2105 case 0x0000: // Fujitsu/Siemens DVB-Cable (ves1820/Philips CD1516(??))
2106 av7110->fe = dvb_attach(ves1820_attach, &philips_cd1516_config,
2107 &av7110->i2c_adap, read_pwm(av7110));
2108 if (av7110->fe) {
2109 av7110->fe->ops.tuner_ops.set_params = philips_cd1516_tuner_set_params;
2111 break;
2114 } else if (av7110->dev->pci->subsystem_vendor == 0x13c2) {
2115 switch(av7110->dev->pci->subsystem_device) {
2116 case 0x0000: // Hauppauge/TT WinTV DVB-S rev1.X
2117 case 0x0003: // Hauppauge/TT WinTV Nexus-S Rev 2.X
2118 case 0x1002: // Hauppauge/TT WinTV DVB-S rev1.3SE
2120 // try the ALPS BSRV2 first of all
2121 av7110->fe = dvb_attach(ves1x93_attach, &alps_bsrv2_config, &av7110->i2c_adap);
2122 if (av7110->fe) {
2123 av7110->fe->ops.tuner_ops.set_params = alps_bsrv2_tuner_set_params;
2124 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2125 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2126 av7110->fe->ops.set_tone = av7110_set_tone;
2127 av7110->recover = dvb_s_recover;
2128 break;
2131 // try the ALPS BSRU6 now
2132 av7110->fe = dvb_attach(stv0299_attach, &alps_bsru6_config, &av7110->i2c_adap);
2133 if (av7110->fe) {
2134 av7110->fe->ops.tuner_ops.set_params = alps_bsru6_tuner_set_params;
2135 av7110->fe->tuner_priv = &av7110->i2c_adap;
2137 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2138 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2139 av7110->fe->ops.set_tone = av7110_set_tone;
2140 av7110->recover = dvb_s_recover;
2141 break;
2144 // Try the grundig 29504-451
2145 av7110->fe = dvb_attach(tda8083_attach, &grundig_29504_451_config, &av7110->i2c_adap);
2146 if (av7110->fe) {
2147 av7110->fe->ops.tuner_ops.set_params = grundig_29504_451_tuner_set_params;
2148 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2149 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2150 av7110->fe->ops.set_tone = av7110_set_tone;
2151 av7110->recover = dvb_s_recover;
2152 break;
2155 /* Try DVB-C cards */
2156 switch(av7110->dev->pci->subsystem_device) {
2157 case 0x0000:
2158 /* Siemens DVB-C (full-length card) VES1820/Philips CD1516 */
2159 av7110->fe = dvb_attach(ves1820_attach, &philips_cd1516_config, &av7110->i2c_adap,
2160 read_pwm(av7110));
2161 if (av7110->fe) {
2162 av7110->fe->ops.tuner_ops.set_params = philips_cd1516_tuner_set_params;
2164 break;
2165 case 0x0003:
2166 /* Hauppauge DVB-C 2.1 VES1820/ALPS TDBE2 */
2167 av7110->fe = dvb_attach(ves1820_attach, &alps_tdbe2_config, &av7110->i2c_adap,
2168 read_pwm(av7110));
2169 if (av7110->fe) {
2170 av7110->fe->ops.tuner_ops.set_params = alps_tdbe2_tuner_set_params;
2172 break;
2174 break;
2176 case 0x0001: // Hauppauge/TT Nexus-T premium rev1.X
2177 // try ALPS TDLB7 first, then Grundig 29504-401
2178 av7110->fe = dvb_attach(sp8870_attach, &alps_tdlb7_config, &av7110->i2c_adap);
2179 if (av7110->fe) {
2180 av7110->fe->ops.tuner_ops.set_params = alps_tdlb7_tuner_set_params;
2181 break;
2183 /* fall-thru */
2185 case 0x0008: // Hauppauge/TT DVB-T
2186 // Grundig 29504-401
2187 av7110->fe = dvb_attach(l64781_attach, &grundig_29504_401_config, &av7110->i2c_adap);
2188 if (av7110->fe)
2189 av7110->fe->ops.tuner_ops.set_params = grundig_29504_401_tuner_set_params;
2190 break;
2192 case 0x0002: // Hauppauge/TT DVB-C premium rev2.X
2194 av7110->fe = dvb_attach(ves1820_attach, &alps_tdbe2_config, &av7110->i2c_adap, read_pwm(av7110));
2195 if (av7110->fe) {
2196 av7110->fe->ops.tuner_ops.set_params = alps_tdbe2_tuner_set_params;
2198 break;
2200 case 0x0004: // Galaxis DVB-S rev1.3
2201 /* ALPS BSRV2 */
2202 av7110->fe = dvb_attach(ves1x93_attach, &alps_bsrv2_config, &av7110->i2c_adap);
2203 if (av7110->fe) {
2204 av7110->fe->ops.tuner_ops.set_params = alps_bsrv2_tuner_set_params;
2205 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2206 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2207 av7110->fe->ops.set_tone = av7110_set_tone;
2208 av7110->recover = dvb_s_recover;
2210 break;
2212 case 0x0006: /* Fujitsu-Siemens DVB-S rev 1.6 */
2213 /* Grundig 29504-451 */
2214 av7110->fe = dvb_attach(tda8083_attach, &grundig_29504_451_config, &av7110->i2c_adap);
2215 if (av7110->fe) {
2216 av7110->fe->ops.tuner_ops.set_params = grundig_29504_451_tuner_set_params;
2217 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2218 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2219 av7110->fe->ops.set_tone = av7110_set_tone;
2220 av7110->recover = dvb_s_recover;
2222 break;
2224 case 0x000A: // Hauppauge/TT Nexus-CA rev1.X
2226 av7110->fe = dvb_attach(stv0297_attach, &nexusca_stv0297_config, &av7110->i2c_adap);
2227 if (av7110->fe) {
2228 av7110->fe->ops.tuner_ops.set_params = nexusca_stv0297_tuner_set_params;
2230 /* set TDA9819 into DVB mode */
2231 saa7146_setgpio(av7110->dev, 1, SAA7146_GPIO_OUTLO); // TDA9819 pin9(STD)
2232 saa7146_setgpio(av7110->dev, 3, SAA7146_GPIO_OUTLO); // TDA9819 pin30(VIF)
2234 /* tuner on this needs a slower i2c bus speed */
2235 av7110->dev->i2c_bitrate = SAA7146_I2C_BUS_BIT_RATE_240;
2236 break;
2238 break;
2240 case 0x000E: /* Hauppauge/TT Nexus-S rev 2.3 */
2241 /* ALPS BSBE1 */
2242 av7110->fe = dvb_attach(stv0299_attach, &alps_bsbe1_config, &av7110->i2c_adap);
2243 if (av7110->fe) {
2244 av7110->fe->ops.tuner_ops.set_params = alps_bsbe1_tuner_set_params;
2245 av7110->fe->tuner_priv = &av7110->i2c_adap;
2247 if (dvb_attach(lnbp21_attach, av7110->fe, &av7110->i2c_adap, 0, 0) == NULL) {
2248 printk("dvb-ttpci: LNBP21 not found!\n");
2249 if (av7110->fe->ops.release)
2250 av7110->fe->ops.release(av7110->fe);
2251 av7110->fe = NULL;
2252 } else {
2253 av7110->fe->ops.dishnetwork_send_legacy_command = NULL;
2254 av7110->recover = dvb_s_recover;
2257 break;
2261 if (!av7110->fe) {
2262 /* FIXME: propagate the failure code from the lower layers */
2263 ret = -ENOMEM;
2264 printk("dvb-ttpci: A frontend driver was not found for device [%04x:%04x] subsystem [%04x:%04x]\n",
2265 av7110->dev->pci->vendor,
2266 av7110->dev->pci->device,
2267 av7110->dev->pci->subsystem_vendor,
2268 av7110->dev->pci->subsystem_device);
2269 } else {
2270 FE_FUNC_OVERRIDE(av7110->fe->ops.init, av7110->fe_init, av7110_fe_init);
2271 FE_FUNC_OVERRIDE(av7110->fe->ops.read_status, av7110->fe_read_status, av7110_fe_read_status);
2272 FE_FUNC_OVERRIDE(av7110->fe->ops.diseqc_reset_overload, av7110->fe_diseqc_reset_overload, av7110_fe_diseqc_reset_overload);
2273 FE_FUNC_OVERRIDE(av7110->fe->ops.diseqc_send_master_cmd, av7110->fe_diseqc_send_master_cmd, av7110_fe_diseqc_send_master_cmd);
2274 FE_FUNC_OVERRIDE(av7110->fe->ops.diseqc_send_burst, av7110->fe_diseqc_send_burst, av7110_fe_diseqc_send_burst);
2275 FE_FUNC_OVERRIDE(av7110->fe->ops.set_tone, av7110->fe_set_tone, av7110_fe_set_tone);
2276 FE_FUNC_OVERRIDE(av7110->fe->ops.set_voltage, av7110->fe_set_voltage, av7110_fe_set_voltage);
2277 FE_FUNC_OVERRIDE(av7110->fe->ops.dishnetwork_send_legacy_command, av7110->fe_dishnetwork_send_legacy_command, av7110_fe_dishnetwork_send_legacy_command);
2278 FE_FUNC_OVERRIDE(av7110->fe->ops.set_frontend, av7110->fe_set_frontend, av7110_fe_set_frontend);
2280 ret = dvb_register_frontend(&av7110->dvb_adapter, av7110->fe);
2281 if (ret < 0) {
2282 printk("av7110: Frontend registration failed!\n");
2283 dvb_frontend_detach(av7110->fe);
2284 av7110->fe = NULL;
2287 return ret;
2290 /* Budgetpatch note:
2291 * Original hardware design by Roberto Deza:
2292 * There is a DVB_Wiki at
2293 * http://212.227.36.83/linuxtv/wiki/index.php/Main_Page
2294 * where is described this 'DVB TT Budget Patch', on Card Modding:
2295 * http://212.227.36.83/linuxtv/wiki/index.php/DVB_TT_Budget_Patch
2296 * On the short description there is also a link to a external file,
2297 * with more details:
2298 * http://perso.wanadoo.es/jesussolano/Ttf_tsc1.zip
2300 * New software triggering design by Emard that works on
2301 * original Roberto Deza's hardware:
2303 * rps1 code for budgetpatch will copy internal HS event to GPIO3 pin.
2304 * GPIO3 is in budget-patch hardware connectd to port B VSYNC
2305 * HS is an internal event of 7146, accessible with RPS
2306 * and temporarily raised high every n lines
2307 * (n in defined in the RPS_THRESH1 counter threshold)
2308 * I think HS is raised high on the beginning of the n-th line
2309 * and remains high until this n-th line that triggered
2310 * it is completely received. When the receiption of n-th line
2311 * ends, HS is lowered.
2313 * To transmit data over DMA, 7146 needs changing state at
2314 * port B VSYNC pin. Any changing of port B VSYNC will
2315 * cause some DMA data transfer, with more or less packets loss.
2316 * It depends on the phase and frequency of VSYNC and
2317 * the way of 7146 is instructed to trigger on port B (defined
2318 * in DD1_INIT register, 3rd nibble from the right valid
2319 * numbers are 0-7, see datasheet)
2321 * The correct triggering can minimize packet loss,
2322 * dvbtraffic should give this stable bandwidths:
2323 * 22k transponder = 33814 kbit/s
2324 * 27.5k transponder = 38045 kbit/s
2325 * by experiment it is found that the best results
2326 * (stable bandwidths and almost no packet loss)
2327 * are obtained using DD1_INIT triggering number 2
2328 * (Va at rising edge of VS Fa = HS x VS-failing forced toggle)
2329 * and a VSYNC phase that occurs in the middle of DMA transfer
2330 * (about byte 188*512=96256 in the DMA window).
2332 * Phase of HS is still not clear to me how to control,
2333 * It just happens to be so. It can be seen if one enables
2334 * RPS_IRQ and print Event Counter 1 in vpeirq(). Every
2335 * time RPS_INTERRUPT is called, the Event Counter 1 will
2336 * increment. That's how the 7146 is programmed to do event
2337 * counting in this budget-patch.c
2338 * I *think* HPS setting has something to do with the phase
2339 * of HS but I cant be 100% sure in that.
2341 * hardware debug note: a working budget card (including budget patch)
2342 * with vpeirq() interrupt setup in mode "0x90" (every 64K) will
2343 * generate 3 interrupts per 25-Hz DMA frame of 2*188*512 bytes
2344 * and that means 3*25=75 Hz of interrupt freqency, as seen by
2345 * watch cat /proc/interrupts
2347 * If this frequency is 3x lower (and data received in the DMA
2348 * buffer don't start with 0x47, but in the middle of packets,
2349 * whose lengths appear to be like 188 292 188 104 etc.
2350 * this means VSYNC line is not connected in the hardware.
2351 * (check soldering pcb and pins)
2352 * The same behaviour of missing VSYNC can be duplicated on budget
2353 * cards, by seting DD1_INIT trigger mode 7 in 3rd nibble.
2355 static int __devinit av7110_attach(struct saa7146_dev* dev,
2356 struct saa7146_pci_extension_data *pci_ext)
2358 const int length = TS_WIDTH * TS_HEIGHT;
2359 struct pci_dev *pdev = dev->pci;
2360 struct av7110 *av7110;
2361 struct task_struct *thread;
2362 int ret, count = 0;
2364 dprintk(4, "dev: %p\n", dev);
2366 /* Set RPS_IRQ to 1 to track rps1 activity.
2367 * Enabling this won't send any interrupt to PC CPU.
2369 #define RPS_IRQ 0
2371 if (budgetpatch == 1) {
2372 budgetpatch = 0;
2373 /* autodetect the presence of budget patch
2374 * this only works if saa7146 has been recently
2375 * reset with with MASK_31 to MC1
2377 * will wait for VBI_B event (vertical blank at port B)
2378 * and will reset GPIO3 after VBI_B is detected.
2379 * (GPIO3 should be raised high by CPU to
2380 * test if GPIO3 will generate vertical blank signal
2381 * in budget patch GPIO3 is connected to VSYNC_B
2384 /* RESET SAA7146 */
2385 saa7146_write(dev, MC1, MASK_31);
2386 /* autodetection success seems to be time-dependend after reset */
2388 /* Fix VSYNC level */
2389 saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO);
2390 /* set vsync_b triggering */
2391 saa7146_write(dev, DD1_STREAM_B, 0);
2392 /* port B VSYNC at rising edge */
2393 saa7146_write(dev, DD1_INIT, 0x00000200);
2394 saa7146_write(dev, BRS_CTRL, 0x00000000); // VBI
2395 saa7146_write(dev, MC2,
2396 1 * (MASK_08 | MASK_24) | // BRS control
2397 0 * (MASK_09 | MASK_25) | // a
2398 1 * (MASK_10 | MASK_26) | // b
2399 0 * (MASK_06 | MASK_22) | // HPS_CTRL1
2400 0 * (MASK_05 | MASK_21) | // HPS_CTRL2
2401 0 * (MASK_01 | MASK_15) // DEBI
2404 /* start writing RPS1 code from beginning */
2405 count = 0;
2406 /* Disable RPS1 */
2407 saa7146_write(dev, MC1, MASK_29);
2408 /* RPS1 timeout disable */
2409 saa7146_write(dev, RPS_TOV1, 0);
2410 WRITE_RPS1(CMD_PAUSE | EVT_VBI_B);
2411 WRITE_RPS1(CMD_WR_REG_MASK | (GPIO_CTRL>>2));
2412 WRITE_RPS1(GPIO3_MSK);
2413 WRITE_RPS1(SAA7146_GPIO_OUTLO<<24);
2414 #if RPS_IRQ
2415 /* issue RPS1 interrupt to increment counter */
2416 WRITE_RPS1(CMD_INTERRUPT);
2417 #endif
2418 WRITE_RPS1(CMD_STOP);
2419 /* Jump to begin of RPS program as safety measure (p37) */
2420 WRITE_RPS1(CMD_JUMP);
2421 WRITE_RPS1(dev->d_rps1.dma_handle);
2423 #if RPS_IRQ
2424 /* set event counter 1 source as RPS1 interrupt (0x03) (rE4 p53)
2425 * use 0x03 to track RPS1 interrupts - increase by 1 every gpio3 is toggled
2426 * use 0x15 to track VPE interrupts - increase by 1 every vpeirq() is called
2428 saa7146_write(dev, EC1SSR, (0x03<<2) | 3 );
2429 /* set event counter 1 threshold to maximum allowed value (rEC p55) */
2430 saa7146_write(dev, ECT1R, 0x3fff );
2431 #endif
2432 /* Set RPS1 Address register to point to RPS code (r108 p42) */
2433 saa7146_write(dev, RPS_ADDR1, dev->d_rps1.dma_handle);
2434 /* Enable RPS1, (rFC p33) */
2435 saa7146_write(dev, MC1, (MASK_13 | MASK_29 ));
2437 mdelay(10);
2438 /* now send VSYNC_B to rps1 by rising GPIO3 */
2439 saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTHI);
2440 mdelay(10);
2441 /* if rps1 responded by lowering the GPIO3,
2442 * then we have budgetpatch hardware
2444 if ((saa7146_read(dev, GPIO_CTRL) & 0x10000000) == 0) {
2445 budgetpatch = 1;
2446 printk("dvb-ttpci: BUDGET-PATCH DETECTED.\n");
2448 /* Disable RPS1 */
2449 saa7146_write(dev, MC1, ( MASK_29 ));
2450 #if RPS_IRQ
2451 printk("dvb-ttpci: Event Counter 1 0x%04x\n", saa7146_read(dev, EC1R) & 0x3fff );
2452 #endif
2455 /* prepare the av7110 device struct */
2456 av7110 = kzalloc(sizeof(struct av7110), GFP_KERNEL);
2457 if (!av7110) {
2458 dprintk(1, "out of memory\n");
2459 return -ENOMEM;
2462 av7110->card_name = (char*) pci_ext->ext_priv;
2463 av7110->dev = dev;
2464 dev->ext_priv = av7110;
2466 ret = get_firmware(av7110);
2467 if (ret < 0)
2468 goto err_kfree_0;
2470 ret = dvb_register_adapter(&av7110->dvb_adapter, av7110->card_name,
2471 THIS_MODULE, &dev->pci->dev, adapter_nr);
2472 if (ret < 0)
2473 goto err_put_firmware_1;
2475 /* the Siemens DVB needs this if you want to have the i2c chips
2476 get recognized before the main driver is fully loaded */
2477 saa7146_write(dev, GPIO_CTRL, 0x500000);
2479 av7110->i2c_adap.class = I2C_CLASS_TV_DIGITAL;
2480 strlcpy(av7110->i2c_adap.name, pci_ext->ext_priv, sizeof(av7110->i2c_adap.name));
2482 saa7146_i2c_adapter_prepare(dev, &av7110->i2c_adap, SAA7146_I2C_BUS_BIT_RATE_120); /* 275 kHz */
2484 ret = i2c_add_adapter(&av7110->i2c_adap);
2485 if (ret < 0)
2486 goto err_dvb_unregister_adapter_2;
2488 ttpci_eeprom_parse_mac(&av7110->i2c_adap,
2489 av7110->dvb_adapter.proposed_mac);
2490 ret = -ENOMEM;
2492 /* full-ts mod? */
2493 if (full_ts)
2494 av7110->full_ts = true;
2496 /* check for full-ts flag in eeprom */
2497 if (i2c_readreg(av7110, 0xaa, 0) == 0x4f && i2c_readreg(av7110, 0xaa, 1) == 0x45) {
2498 u8 flags = i2c_readreg(av7110, 0xaa, 2);
2499 if (flags != 0xff && (flags & 0x01))
2500 av7110->full_ts = true;
2503 if (av7110->full_ts) {
2504 printk(KERN_INFO "dvb-ttpci: full-ts mode enabled for saa7146 port B\n");
2505 spin_lock_init(&av7110->feedlock1);
2506 av7110->grabbing = saa7146_vmalloc_build_pgtable(pdev, length,
2507 &av7110->pt);
2508 if (!av7110->grabbing)
2509 goto err_i2c_del_3;
2511 saa7146_write(dev, DD1_STREAM_B, 0x00000000);
2512 saa7146_write(dev, MC2, (MASK_10 | MASK_26));
2514 saa7146_write(dev, DD1_INIT, 0x00000600);
2515 saa7146_write(dev, MC2, (MASK_09 | MASK_25 | MASK_10 | MASK_26));
2517 saa7146_write(dev, BRS_CTRL, 0x60000000);
2518 saa7146_write(dev, MC2, MASK_08 | MASK_24);
2520 /* dma3 */
2521 saa7146_write(dev, PCI_BT_V1, 0x001c0000 | (saa7146_read(dev, PCI_BT_V1) & ~0x001f0000));
2522 saa7146_write(dev, BASE_ODD3, 0);
2523 saa7146_write(dev, BASE_EVEN3, 0);
2524 saa7146_write(dev, PROT_ADDR3, TS_WIDTH * TS_HEIGHT);
2525 saa7146_write(dev, PITCH3, TS_WIDTH);
2526 saa7146_write(dev, BASE_PAGE3, av7110->pt.dma | ME1 | 0x90);
2527 saa7146_write(dev, NUM_LINE_BYTE3, (TS_HEIGHT << 16) | TS_WIDTH);
2528 saa7146_write(dev, MC2, MASK_04 | MASK_20);
2530 tasklet_init(&av7110->vpe_tasklet, vpeirq, (unsigned long) av7110);
2532 } else if (budgetpatch) {
2533 spin_lock_init(&av7110->feedlock1);
2534 av7110->grabbing = saa7146_vmalloc_build_pgtable(pdev, length,
2535 &av7110->pt);
2536 if (!av7110->grabbing)
2537 goto err_i2c_del_3;
2539 saa7146_write(dev, PCI_BT_V1, 0x1c1f101f);
2540 saa7146_write(dev, BCS_CTRL, 0x80400040);
2541 /* set dd1 stream a & b */
2542 saa7146_write(dev, DD1_STREAM_B, 0x00000000);
2543 saa7146_write(dev, DD1_INIT, 0x03000200);
2544 saa7146_write(dev, MC2, (MASK_09 | MASK_25 | MASK_10 | MASK_26));
2545 saa7146_write(dev, BRS_CTRL, 0x60000000);
2546 saa7146_write(dev, BASE_ODD3, 0);
2547 saa7146_write(dev, BASE_EVEN3, 0);
2548 saa7146_write(dev, PROT_ADDR3, TS_WIDTH * TS_HEIGHT);
2549 saa7146_write(dev, BASE_PAGE3, av7110->pt.dma | ME1 | 0x90);
2551 saa7146_write(dev, PITCH3, TS_WIDTH);
2552 saa7146_write(dev, NUM_LINE_BYTE3, (TS_HEIGHT << 16) | TS_WIDTH);
2554 /* upload all */
2555 saa7146_write(dev, MC2, 0x077c077c);
2556 saa7146_write(dev, GPIO_CTRL, 0x000000);
2557 #if RPS_IRQ
2558 /* set event counter 1 source as RPS1 interrupt (0x03) (rE4 p53)
2559 * use 0x03 to track RPS1 interrupts - increase by 1 every gpio3 is toggled
2560 * use 0x15 to track VPE interrupts - increase by 1 every vpeirq() is called
2562 saa7146_write(dev, EC1SSR, (0x03<<2) | 3 );
2563 /* set event counter 1 threshold to maximum allowed value (rEC p55) */
2564 saa7146_write(dev, ECT1R, 0x3fff );
2565 #endif
2566 /* Setup BUDGETPATCH MAIN RPS1 "program" (p35) */
2567 count = 0;
2569 /* Wait Source Line Counter Threshold (p36) */
2570 WRITE_RPS1(CMD_PAUSE | EVT_HS);
2571 /* Set GPIO3=1 (p42) */
2572 WRITE_RPS1(CMD_WR_REG_MASK | (GPIO_CTRL>>2));
2573 WRITE_RPS1(GPIO3_MSK);
2574 WRITE_RPS1(SAA7146_GPIO_OUTHI<<24);
2575 #if RPS_IRQ
2576 /* issue RPS1 interrupt */
2577 WRITE_RPS1(CMD_INTERRUPT);
2578 #endif
2579 /* Wait reset Source Line Counter Threshold (p36) */
2580 WRITE_RPS1(CMD_PAUSE | RPS_INV | EVT_HS);
2581 /* Set GPIO3=0 (p42) */
2582 WRITE_RPS1(CMD_WR_REG_MASK | (GPIO_CTRL>>2));
2583 WRITE_RPS1(GPIO3_MSK);
2584 WRITE_RPS1(SAA7146_GPIO_OUTLO<<24);
2585 #if RPS_IRQ
2586 /* issue RPS1 interrupt */
2587 WRITE_RPS1(CMD_INTERRUPT);
2588 #endif
2589 /* Jump to begin of RPS program (p37) */
2590 WRITE_RPS1(CMD_JUMP);
2591 WRITE_RPS1(dev->d_rps1.dma_handle);
2593 /* Fix VSYNC level */
2594 saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO);
2595 /* Set RPS1 Address register to point to RPS code (r108 p42) */
2596 saa7146_write(dev, RPS_ADDR1, dev->d_rps1.dma_handle);
2597 /* Set Source Line Counter Threshold, using BRS (rCC p43)
2598 * It generates HS event every TS_HEIGHT lines
2599 * this is related to TS_WIDTH set in register
2600 * NUM_LINE_BYTE3. If NUM_LINE_BYTE low 16 bits
2601 * are set to TS_WIDTH bytes (TS_WIDTH=2*188),
2602 * then RPS_THRESH1 should be set to trigger
2603 * every TS_HEIGHT (512) lines.
2605 saa7146_write(dev, RPS_THRESH1, (TS_HEIGHT*1) | MASK_12 );
2607 /* Enable RPS1 (rFC p33) */
2608 saa7146_write(dev, MC1, (MASK_13 | MASK_29));
2610 /* end of budgetpatch register initialization */
2611 tasklet_init (&av7110->vpe_tasklet, vpeirq, (unsigned long) av7110);
2612 } else {
2613 saa7146_write(dev, PCI_BT_V1, 0x1c00101f);
2614 saa7146_write(dev, BCS_CTRL, 0x80400040);
2616 /* set dd1 stream a & b */
2617 saa7146_write(dev, DD1_STREAM_B, 0x00000000);
2618 saa7146_write(dev, DD1_INIT, 0x03000000);
2619 saa7146_write(dev, MC2, (MASK_09 | MASK_25 | MASK_10 | MASK_26));
2621 /* upload all */
2622 saa7146_write(dev, MC2, 0x077c077c);
2623 saa7146_write(dev, GPIO_CTRL, 0x000000);
2626 tasklet_init (&av7110->debi_tasklet, debiirq, (unsigned long) av7110);
2627 tasklet_init (&av7110->gpio_tasklet, gpioirq, (unsigned long) av7110);
2629 mutex_init(&av7110->pid_mutex);
2631 /* locks for data transfers from/to AV7110 */
2632 spin_lock_init(&av7110->debilock);
2633 mutex_init(&av7110->dcomlock);
2634 av7110->debitype = -1;
2636 /* default OSD window */
2637 av7110->osdwin = 1;
2638 mutex_init(&av7110->osd_mutex);
2640 /* TV standard */
2641 av7110->vidmode = tv_standard == 1 ? AV7110_VIDEO_MODE_NTSC
2642 : AV7110_VIDEO_MODE_PAL;
2644 /* ARM "watchdog" */
2645 init_waitqueue_head(&av7110->arm_wait);
2646 av7110->arm_thread = NULL;
2648 /* allocate and init buffers */
2649 av7110->debi_virt = pci_alloc_consistent(pdev, 8192, &av7110->debi_bus);
2650 if (!av7110->debi_virt)
2651 goto err_saa71466_vfree_4;
2654 av7110->iobuf = vmalloc(AVOUTLEN+AOUTLEN+BMPLEN+4*IPACKS);
2655 if (!av7110->iobuf)
2656 goto err_pci_free_5;
2658 ret = av7110_av_init(av7110);
2659 if (ret < 0)
2660 goto err_iobuf_vfree_6;
2662 /* init BMP buffer */
2663 av7110->bmpbuf = av7110->iobuf+AVOUTLEN+AOUTLEN;
2664 init_waitqueue_head(&av7110->bmpq);
2666 ret = av7110_ca_init(av7110);
2667 if (ret < 0)
2668 goto err_av7110_av_exit_7;
2670 /* load firmware into AV7110 cards */
2671 ret = av7110_bootarm(av7110);
2672 if (ret < 0)
2673 goto err_av7110_ca_exit_8;
2675 ret = av7110_firmversion(av7110);
2676 if (ret < 0)
2677 goto err_stop_arm_9;
2679 if (FW_VERSION(av7110->arm_app)<0x2501)
2680 printk ("dvb-ttpci: Warning, firmware version 0x%04x is too old. "
2681 "System might be unstable!\n", FW_VERSION(av7110->arm_app));
2683 thread = kthread_run(arm_thread, (void *) av7110, "arm_mon");
2684 if (IS_ERR(thread)) {
2685 ret = PTR_ERR(thread);
2686 goto err_stop_arm_9;
2688 av7110->arm_thread = thread;
2690 /* set initial volume in mixer struct */
2691 av7110->mixer.volume_left = volume;
2692 av7110->mixer.volume_right = volume;
2694 ret = av7110_register(av7110);
2695 if (ret < 0)
2696 goto err_arm_thread_stop_10;
2698 init_av7110_av(av7110);
2700 /* special case DVB-C: these cards have an analog tuner
2701 plus need some special handling, so we have separate
2702 saa7146_ext_vv data for these... */
2703 ret = av7110_init_v4l(av7110);
2704 if (ret < 0)
2705 goto err_av7110_unregister_11;
2707 av7110->dvb_adapter.priv = av7110;
2708 ret = frontend_init(av7110);
2709 if (ret < 0)
2710 goto err_av7110_exit_v4l_12;
2712 #if defined(CONFIG_INPUT_EVDEV) || defined(CONFIG_INPUT_EVDEV_MODULE)
2713 av7110_ir_init(av7110);
2714 #endif
2715 printk(KERN_INFO "dvb-ttpci: found av7110-%d.\n", av7110_num);
2716 av7110_num++;
2717 out:
2718 return ret;
2720 err_av7110_exit_v4l_12:
2721 av7110_exit_v4l(av7110);
2722 err_av7110_unregister_11:
2723 dvb_unregister(av7110);
2724 err_arm_thread_stop_10:
2725 av7110_arm_sync(av7110);
2726 err_stop_arm_9:
2727 /* Nothing to do. Rejoice. */
2728 err_av7110_ca_exit_8:
2729 av7110_ca_exit(av7110);
2730 err_av7110_av_exit_7:
2731 av7110_av_exit(av7110);
2732 err_iobuf_vfree_6:
2733 vfree(av7110->iobuf);
2734 err_pci_free_5:
2735 pci_free_consistent(pdev, 8192, av7110->debi_virt, av7110->debi_bus);
2736 err_saa71466_vfree_4:
2737 if (av7110->grabbing)
2738 saa7146_vfree_destroy_pgtable(pdev, av7110->grabbing, &av7110->pt);
2739 err_i2c_del_3:
2740 i2c_del_adapter(&av7110->i2c_adap);
2741 err_dvb_unregister_adapter_2:
2742 dvb_unregister_adapter(&av7110->dvb_adapter);
2743 err_put_firmware_1:
2744 put_firmware(av7110);
2745 err_kfree_0:
2746 kfree(av7110);
2747 goto out;
2750 static int __devexit av7110_detach(struct saa7146_dev* saa)
2752 struct av7110 *av7110 = saa->ext_priv;
2753 dprintk(4, "%p\n", av7110);
2755 #if defined(CONFIG_INPUT_EVDEV) || defined(CONFIG_INPUT_EVDEV_MODULE)
2756 av7110_ir_exit(av7110);
2757 #endif
2758 if (budgetpatch || av7110->full_ts) {
2759 if (budgetpatch) {
2760 /* Disable RPS1 */
2761 saa7146_write(saa, MC1, MASK_29);
2762 /* VSYNC LOW (inactive) */
2763 saa7146_setgpio(saa, 3, SAA7146_GPIO_OUTLO);
2765 saa7146_write(saa, MC1, MASK_20); /* DMA3 off */
2766 SAA7146_IER_DISABLE(saa, MASK_10);
2767 SAA7146_ISR_CLEAR(saa, MASK_10);
2768 msleep(50);
2769 tasklet_kill(&av7110->vpe_tasklet);
2770 saa7146_vfree_destroy_pgtable(saa->pci, av7110->grabbing, &av7110->pt);
2772 av7110_exit_v4l(av7110);
2774 av7110_arm_sync(av7110);
2776 tasklet_kill(&av7110->debi_tasklet);
2777 tasklet_kill(&av7110->gpio_tasklet);
2779 dvb_unregister(av7110);
2781 SAA7146_IER_DISABLE(saa, MASK_19 | MASK_03);
2782 SAA7146_ISR_CLEAR(saa, MASK_19 | MASK_03);
2784 av7110_ca_exit(av7110);
2785 av7110_av_exit(av7110);
2787 vfree(av7110->iobuf);
2788 pci_free_consistent(saa->pci, 8192, av7110->debi_virt,
2789 av7110->debi_bus);
2791 i2c_del_adapter(&av7110->i2c_adap);
2793 dvb_unregister_adapter (&av7110->dvb_adapter);
2795 av7110_num--;
2797 put_firmware(av7110);
2799 kfree(av7110);
2801 saa->ext_priv = NULL;
2803 return 0;
2807 static void av7110_irq(struct saa7146_dev* dev, u32 *isr)
2809 struct av7110 *av7110 = dev->ext_priv;
2811 //print_time("av7110_irq");
2813 /* Note: Don't try to handle the DEBI error irq (MASK_18), in
2814 * intel mode the timeout is asserted all the time...
2817 if (*isr & MASK_19) {
2818 //printk("av7110_irq: DEBI\n");
2819 /* Note 1: The DEBI irq is level triggered: We must enable it
2820 * only after we started a DMA xfer, and disable it here
2821 * immediately, or it will be signalled all the time while
2822 * DEBI is idle.
2823 * Note 2: You would think that an irq which is masked is
2824 * not signalled by the hardware. Not so for the SAA7146:
2825 * An irq is signalled as long as the corresponding bit
2826 * in the ISR is set, and disabling irqs just prevents the
2827 * hardware from setting the ISR bit. This means a) that we
2828 * must clear the ISR *after* disabling the irq (which is why
2829 * we must do it here even though saa7146_core did it already),
2830 * and b) that if we were to disable an edge triggered irq
2831 * (like the gpio irqs sadly are) temporarily we would likely
2832 * loose some. This sucks :-(
2834 SAA7146_IER_DISABLE(av7110->dev, MASK_19);
2835 SAA7146_ISR_CLEAR(av7110->dev, MASK_19);
2836 tasklet_schedule(&av7110->debi_tasklet);
2839 if (*isr & MASK_03) {
2840 //printk("av7110_irq: GPIO\n");
2841 tasklet_schedule(&av7110->gpio_tasklet);
2844 if (*isr & MASK_10)
2845 tasklet_schedule(&av7110->vpe_tasklet);
2849 static struct saa7146_extension av7110_extension_driver;
2851 #define MAKE_AV7110_INFO(x_var,x_name) \
2852 static struct saa7146_pci_extension_data x_var = { \
2853 .ext_priv = x_name, \
2854 .ext = &av7110_extension_driver }
2856 MAKE_AV7110_INFO(tts_1_X_fsc,"Technotrend/Hauppauge WinTV DVB-S rev1.X or Fujitsu Siemens DVB-C");
2857 MAKE_AV7110_INFO(ttt_1_X, "Technotrend/Hauppauge WinTV DVB-T rev1.X");
2858 MAKE_AV7110_INFO(ttc_1_X, "Technotrend/Hauppauge WinTV Nexus-CA rev1.X");
2859 MAKE_AV7110_INFO(ttc_2_X, "Technotrend/Hauppauge WinTV DVB-C rev2.X");
2860 MAKE_AV7110_INFO(tts_2_X, "Technotrend/Hauppauge WinTV Nexus-S rev2.X");
2861 MAKE_AV7110_INFO(tts_2_3, "Technotrend/Hauppauge WinTV Nexus-S rev2.3");
2862 MAKE_AV7110_INFO(tts_1_3se, "Technotrend/Hauppauge WinTV DVB-S rev1.3 SE");
2863 MAKE_AV7110_INFO(ttt, "Technotrend/Hauppauge DVB-T");
2864 MAKE_AV7110_INFO(fsc, "Fujitsu Siemens DVB-C");
2865 MAKE_AV7110_INFO(fss, "Fujitsu Siemens DVB-S rev1.6");
2866 MAKE_AV7110_INFO(gxs_1_3, "Galaxis DVB-S rev1.3");
2868 static struct pci_device_id pci_tbl[] = {
2869 MAKE_EXTENSION_PCI(fsc, 0x110a, 0x0000),
2870 MAKE_EXTENSION_PCI(tts_1_X_fsc, 0x13c2, 0x0000),
2871 MAKE_EXTENSION_PCI(ttt_1_X, 0x13c2, 0x0001),
2872 MAKE_EXTENSION_PCI(ttc_2_X, 0x13c2, 0x0002),
2873 MAKE_EXTENSION_PCI(tts_2_X, 0x13c2, 0x0003),
2874 MAKE_EXTENSION_PCI(gxs_1_3, 0x13c2, 0x0004),
2875 MAKE_EXTENSION_PCI(fss, 0x13c2, 0x0006),
2876 MAKE_EXTENSION_PCI(ttt, 0x13c2, 0x0008),
2877 MAKE_EXTENSION_PCI(ttc_1_X, 0x13c2, 0x000a),
2878 MAKE_EXTENSION_PCI(tts_2_3, 0x13c2, 0x000e),
2879 MAKE_EXTENSION_PCI(tts_1_3se, 0x13c2, 0x1002),
2881 /* MAKE_EXTENSION_PCI(???, 0x13c2, 0x0005), UNDEFINED CARD */ // Technisat SkyStar1
2882 /* MAKE_EXTENSION_PCI(???, 0x13c2, 0x0009), UNDEFINED CARD */ // TT/Hauppauge WinTV Nexus-CA v????
2885 .vendor = 0,
2889 MODULE_DEVICE_TABLE(pci, pci_tbl);
2892 static struct saa7146_extension av7110_extension_driver = {
2893 .name = "dvb",
2894 .flags = SAA7146_USE_I2C_IRQ,
2896 .module = THIS_MODULE,
2897 .pci_tbl = &pci_tbl[0],
2898 .attach = av7110_attach,
2899 .detach = __devexit_p(av7110_detach),
2901 .irq_mask = MASK_19 | MASK_03 | MASK_10,
2902 .irq_func = av7110_irq,
2906 static int __init av7110_init(void)
2908 int retval;
2909 retval = saa7146_register_extension(&av7110_extension_driver);
2910 return retval;
2914 static void __exit av7110_exit(void)
2916 saa7146_unregister_extension(&av7110_extension_driver);
2919 module_init(av7110_init);
2920 module_exit(av7110_exit);
2922 MODULE_DESCRIPTION("driver for the SAA7146 based AV110 PCI DVB cards by "
2923 "Siemens, Technotrend, Hauppauge");
2924 MODULE_AUTHOR("Ralph Metzler, Marcus Metzler, others");
2925 MODULE_LICENSE("GPL");