1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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>
39
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>
55
56
57#include <linux/dvb/frontend.h>
58
59#include "dvb_frontend.h"
60
61#include "ttpci-eeprom.h"
62#include "av7110.h"
63#include "av7110_hw.h"
64#include "av7110_av.h"
65#include "av7110_ca.h"
66#include "av7110_ipack.h"
67
68#include "bsbe1.h"
69#include "lnbp21.h"
70#include "bsru6.h"
71
72#define TS_WIDTH 376
73#define TS_HEIGHT 512
74#define TS_BUFLEN (TS_WIDTH*TS_HEIGHT)
75#define TS_MAX_PACKETS (TS_BUFLEN/TS_SIZE)
76
77
78int av7110_debug;
79
80static int vidmode = CVBS_RGB_OUT;
81static int pids_off;
82static int adac = DVB_ADAC_TI;
83static int hw_sections;
84static int rgb_on;
85static int volume = 255;
86static int budgetpatch;
87static int wss_cfg_4_3 = 0x4008;
88static int wss_cfg_16_9 = 0x0007;
89static int tv_standard;
90static int full_ts;
91
92module_param_named(debug, av7110_debug, int, 0644);
93MODULE_PARM_DESC(debug, "debug level (bitmask, default 0)");
94module_param(vidmode, int, 0444);
95MODULE_PARM_DESC(vidmode,"analog video out: 0 off, 1 CVBS+RGB (default), 2 CVBS+YC, 3 YC");
96module_param(pids_off, int, 0444);
97MODULE_PARM_DESC(pids_off,"clear video/audio/PCR PID filters when demux is closed");
98module_param(adac, int, 0444);
99MODULE_PARM_DESC(adac,"audio DAC type: 0 TI, 1 CRYSTAL, 2 MSP (use if autodetection fails)");
100module_param(hw_sections, int, 0444);
101MODULE_PARM_DESC(hw_sections, "0 use software section filter, 1 use hardware");
102module_param(rgb_on, int, 0444);
103MODULE_PARM_DESC(rgb_on, "For Siemens DVB-C cards only: Enable RGB control"
104 " signal on SCART pin 16 to switch SCART video mode from CVBS to RGB");
105module_param(volume, int, 0444);
106MODULE_PARM_DESC(volume, "initial volume: default 255 (range 0-255)");
107module_param(budgetpatch, int, 0444);
108MODULE_PARM_DESC(budgetpatch, "use budget-patch hardware modification: default 0 (0 no, 1 autodetect, 2 always)");
109module_param(full_ts, int, 0444);
110MODULE_PARM_DESC(full_ts, "enable code for full-ts hardware modification: 0 disable (default), 1 enable");
111module_param(wss_cfg_4_3, int, 0444);
112MODULE_PARM_DESC(wss_cfg_4_3, "WSS 4:3 - default 0x4008 - bit 15: disable, 14: burst mode, 13..0: wss data");
113module_param(wss_cfg_16_9, int, 0444);
114MODULE_PARM_DESC(wss_cfg_16_9, "WSS 16:9 - default 0x0007 - bit 15: disable, 14: burst mode, 13..0: wss data");
115module_param(tv_standard, int, 0444);
116MODULE_PARM_DESC(tv_standard, "TV standard: 0 PAL (default), 1 NTSC");
117
118DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
119
120static void restart_feeds(struct av7110 *av7110);
121static int budget_start_feed(struct dvb_demux_feed *feed);
122static int budget_stop_feed(struct dvb_demux_feed *feed);
123
124static int av7110_num;
125
126#define FE_FUNC_OVERRIDE(fe_func, av7110_copy, av7110_func) \
127{\
128 if (fe_func != NULL) { \
129 av7110_copy = fe_func; \
130 fe_func = av7110_func; \
131 } \
132}
133
134
135static void init_av7110_av(struct av7110 *av7110)
136{
137 int ret;
138 struct saa7146_dev *dev = av7110->dev;
139
140
141 av7110->adac_type = DVB_ADAC_TI;
142 ret = av7110_set_volume(av7110, av7110->mixer.volume_left, av7110->mixer.volume_right);
143 if (ret < 0)
144 printk("dvb-ttpci:cannot set internal volume to maximum:%d\n",ret);
145
146 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetMonitorType,
147 1, (u16) av7110->display_ar);
148 if (ret < 0)
149 printk("dvb-ttpci: unable to set aspect ratio\n");
150 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetPanScanType,
151 1, av7110->display_panscan);
152 if (ret < 0)
153 printk("dvb-ttpci: unable to set pan scan\n");
154
155 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetWSSConfig, 2, 2, wss_cfg_4_3);
156 if (ret < 0)
157 printk("dvb-ttpci: unable to configure 4:3 wss\n");
158 ret = av7110_fw_cmd(av7110, COMTYPE_ENCODER, SetWSSConfig, 2, 3, wss_cfg_16_9);
159 if (ret < 0)
160 printk("dvb-ttpci: unable to configure 16:9 wss\n");
161
162 ret = av7710_set_video_mode(av7110, vidmode);
163 if (ret < 0)
164 printk("dvb-ttpci:cannot set video mode:%d\n",ret);
165
166
167
168 av7110->analog_tuner_flags = 0;
169 av7110->current_input = 0;
170 if (dev->pci->subsystem_vendor == 0x13c2 && dev->pci->subsystem_device == 0x000a)
171 av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, ADSwitch, 1, 0);
172 if (i2c_writereg(av7110, 0x20, 0x00, 0x00) == 1) {
173 printk ("dvb-ttpci: Crystal audio DAC @ card %d detected\n",
174 av7110->dvb_adapter.num);
175 av7110->adac_type = DVB_ADAC_CRYSTAL;
176 i2c_writereg(av7110, 0x20, 0x01, 0xd2);
177 i2c_writereg(av7110, 0x20, 0x02, 0x49);
178 i2c_writereg(av7110, 0x20, 0x03, 0x00);
179 i2c_writereg(av7110, 0x20, 0x04, 0x00);
180
181
182
183
184 } else if (0 == av7110_init_analog_module(av7110)) {
185
186 }
187 else if (dev->pci->subsystem_vendor == 0x110a) {
188 printk("dvb-ttpci: DVB-C w/o analog module @ card %d detected\n",
189 av7110->dvb_adapter.num);
190 av7110->adac_type = DVB_ADAC_NONE;
191 }
192 else {
193 av7110->adac_type = adac;
194 printk("dvb-ttpci: adac type set to %d @ card %d\n",
195 av7110->adac_type, av7110->dvb_adapter.num);
196 }
197
198 if (av7110->adac_type == DVB_ADAC_NONE || av7110->adac_type == DVB_ADAC_MSP34x0) {
199
200 ret = av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, MainSwitch, 1, 0);
201 if (ret < 0)
202 printk("dvb-ttpci:cannot switch on SCART(Main):%d\n",ret);
203 ret = av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, ADSwitch, 1, 1);
204 if (ret < 0)
205 printk("dvb-ttpci:cannot switch on SCART(AD):%d\n",ret);
206 if (rgb_on &&
207 ((av7110->dev->pci->subsystem_vendor == 0x110a) ||
208 (av7110->dev->pci->subsystem_vendor == 0x13c2)) &&
209 (av7110->dev->pci->subsystem_device == 0x0000)) {
210 saa7146_setgpio(dev, 1, SAA7146_GPIO_OUTHI);
211
212 }
213 }
214
215 if (dev->pci->subsystem_vendor == 0x13c2 && dev->pci->subsystem_device == 0x000e)
216 av7110_fw_cmd(av7110, COMTYPE_AUDIODAC, SpdifSwitch, 1, 0);
217
218 ret = av7110_set_volume(av7110, av7110->mixer.volume_left, av7110->mixer.volume_right);
219 if (ret < 0)
220 printk("dvb-ttpci:cannot set volume :%d\n",ret);
221}
222
223static void recover_arm(struct av7110 *av7110)
224{
225 dprintk(4, "%p\n",av7110);
226
227 av7110_bootarm(av7110);
228 msleep(100);
229
230 init_av7110_av(av7110);
231
232
233 if (av7110->recover)
234 av7110->recover(av7110);
235
236 restart_feeds(av7110);
237
238#if IS_ENABLED(CONFIG_DVB_AV7110_IR)
239 av7110_check_ir_config(av7110, true);
240#endif
241}
242
243static void av7110_arm_sync(struct av7110 *av7110)
244{
245 if (av7110->arm_thread)
246 kthread_stop(av7110->arm_thread);
247
248 av7110->arm_thread = NULL;
249}
250
251static int arm_thread(void *data)
252{
253 struct av7110 *av7110 = data;
254 u16 newloops = 0;
255 int timeout;
256
257 dprintk(4, "%p\n",av7110);
258
259 for (;;) {
260 timeout = wait_event_interruptible_timeout(av7110->arm_wait,
261 kthread_should_stop(), 5 * HZ);
262
263 if (-ERESTARTSYS == timeout || kthread_should_stop()) {
264
265 break;
266 }
267
268 if (!av7110->arm_ready)
269 continue;
270
271#if IS_ENABLED(CONFIG_DVB_AV7110_IR)
272 av7110_check_ir_config(av7110, false);
273#endif
274
275 if (mutex_lock_interruptible(&av7110->dcomlock))
276 break;
277 newloops = rdebi(av7110, DEBINOSWAP, STATUS_LOOPS, 0, 2);
278 mutex_unlock(&av7110->dcomlock);
279
280 if (newloops == av7110->arm_loops || av7110->arm_errors > 3) {
281 printk(KERN_ERR "dvb-ttpci: ARM crashed @ card %d\n",
282 av7110->dvb_adapter.num);
283
284 recover_arm(av7110);
285
286 if (mutex_lock_interruptible(&av7110->dcomlock))
287 break;
288 newloops = rdebi(av7110, DEBINOSWAP, STATUS_LOOPS, 0, 2) - 1;
289 mutex_unlock(&av7110->dcomlock);
290 }
291 av7110->arm_loops = newloops;
292 av7110->arm_errors = 0;
293 }
294
295 return 0;
296}
297
298
299
300
301
302
303static int DvbDmxFilterCallback(u8 *buffer1, size_t buffer1_len,
304 u8 *buffer2, size_t buffer2_len,
305 struct dvb_demux_filter *dvbdmxfilter,
306 struct av7110 *av7110)
307{
308 if (!dvbdmxfilter->feed->demux->dmx.frontend)
309 return 0;
310 if (dvbdmxfilter->feed->demux->dmx.frontend->source == DMX_MEMORY_FE)
311 return 0;
312
313 switch (dvbdmxfilter->type) {
314 case DMX_TYPE_SEC:
315 if ((((buffer1[1] << 8) | buffer1[2]) & 0xfff) + 3 != buffer1_len)
316 return 0;
317 if (dvbdmxfilter->doneq) {
318 struct dmx_section_filter *filter = &dvbdmxfilter->filter;
319 int i;
320 u8 xor, neq = 0;
321
322 for (i = 0; i < DVB_DEMUX_MASK_MAX; i++) {
323 xor = filter->filter_value[i] ^ buffer1[i];
324 neq |= dvbdmxfilter->maskandnotmode[i] & xor;
325 }
326 if (!neq)
327 return 0;
328 }
329 return dvbdmxfilter->feed->cb.sec(buffer1, buffer1_len,
330 buffer2, buffer2_len,
331 &dvbdmxfilter->filter);
332 case DMX_TYPE_TS:
333 if (!(dvbdmxfilter->feed->ts_type & TS_PACKET))
334 return 0;
335 if (dvbdmxfilter->feed->ts_type & TS_PAYLOAD_ONLY)
336 return dvbdmxfilter->feed->cb.ts(buffer1, buffer1_len,
337 buffer2, buffer2_len,
338 &dvbdmxfilter->feed->feed.ts);
339 else
340 av7110_p2t_write(buffer1, buffer1_len,
341 dvbdmxfilter->feed->pid,
342 &av7110->p2t_filter[dvbdmxfilter->index]);
343 default:
344 return 0;
345 }
346}
347
348
349
350static inline void print_time(char *s)
351{
352#ifdef DEBUG_TIMING
353 struct timeval tv;
354 do_gettimeofday(&tv);
355 printk("%s: %d.%d\n", s, (int)tv.tv_sec, (int)tv.tv_usec);
356#endif
357}
358
359#define DEBI_READ 0
360#define DEBI_WRITE 1
361static inline void start_debi_dma(struct av7110 *av7110, int dir,
362 unsigned long addr, unsigned int len)
363{
364 dprintk(8, "%c %08lx %u\n", dir == DEBI_READ ? 'R' : 'W', addr, len);
365 if (saa7146_wait_for_debi_done(av7110->dev, 0)) {
366 printk(KERN_ERR "%s: saa7146_wait_for_debi_done timed out\n", __func__);
367 return;
368 }
369
370 SAA7146_ISR_CLEAR(av7110->dev, MASK_19);
371 SAA7146_IER_ENABLE(av7110->dev, MASK_19);
372 if (len < 5)
373 len = 5;
374 if (dir == DEBI_WRITE)
375 iwdebi(av7110, DEBISWAB, addr, 0, (len + 3) & ~3);
376 else
377 irdebi(av7110, DEBISWAB, addr, 0, len);
378}
379
380static void debiirq(unsigned long cookie)
381{
382 struct av7110 *av7110 = (struct av7110 *)cookie;
383 int type = av7110->debitype;
384 int handle = (type >> 8) & 0x1f;
385 unsigned int xfer = 0;
386
387 print_time("debi");
388 dprintk(4, "type 0x%04x\n", type);
389
390 if (type == -1) {
391 printk("DEBI irq oops @ %ld, psr:0x%08x, ssr:0x%08x\n",
392 jiffies, saa7146_read(av7110->dev, PSR),
393 saa7146_read(av7110->dev, SSR));
394 goto debi_done;
395 }
396 av7110->debitype = -1;
397
398 switch (type & 0xff) {
399
400 case DATA_TS_RECORD:
401 dvb_dmx_swfilter_packets(&av7110->demux,
402 (const u8 *) av7110->debi_virt,
403 av7110->debilen / 188);
404 xfer = RX_BUFF;
405 break;
406
407 case DATA_PES_RECORD:
408 if (av7110->demux.recording)
409 av7110_record_cb(&av7110->p2t[handle],
410 (u8 *) av7110->debi_virt,
411 av7110->debilen);
412 xfer = RX_BUFF;
413 break;
414
415 case DATA_IPMPE:
416 case DATA_FSECTION:
417 case DATA_PIPING:
418 if (av7110->handle2filter[handle])
419 DvbDmxFilterCallback((u8 *)av7110->debi_virt,
420 av7110->debilen, NULL, 0,
421 av7110->handle2filter[handle],
422 av7110);
423 xfer = RX_BUFF;
424 break;
425
426 case DATA_CI_GET:
427 {
428 u8 *data = av7110->debi_virt;
429
430 if ((data[0] < 2) && data[2] == 0xff) {
431 int flags = 0;
432 if (data[5] > 0)
433 flags |= CA_CI_MODULE_PRESENT;
434 if (data[5] > 5)
435 flags |= CA_CI_MODULE_READY;
436 av7110->ci_slot[data[0]].flags = flags;
437 } else
438 ci_get_data(&av7110->ci_rbuffer,
439 av7110->debi_virt,
440 av7110->debilen);
441 xfer = RX_BUFF;
442 break;
443 }
444
445 case DATA_COMMON_INTERFACE:
446 CI_handle(av7110, (u8 *)av7110->debi_virt, av7110->debilen);
447#if 0
448 {
449 int i;
450
451 printk("av7110%d: ", av7110->num);
452 printk("%02x ", *(u8 *)av7110->debi_virt);
453 printk("%02x ", *(1+(u8 *)av7110->debi_virt));
454 for (i = 2; i < av7110->debilen; i++)
455 printk("%02x ", (*(i+(unsigned char *)av7110->debi_virt)));
456 for (i = 2; i < av7110->debilen; i++)
457 printk("%c", chtrans(*(i+(unsigned char *)av7110->debi_virt)));
458
459 printk("\n");
460 }
461#endif
462 xfer = RX_BUFF;
463 break;
464
465 case DATA_DEBUG_MESSAGE:
466 ((s8*)av7110->debi_virt)[Reserved_SIZE - 1] = 0;
467 printk("%s\n", (s8 *) av7110->debi_virt);
468 xfer = RX_BUFF;
469 break;
470
471 case DATA_CI_PUT:
472 dprintk(4, "debi DATA_CI_PUT\n");
473 case DATA_MPEG_PLAY:
474 dprintk(4, "debi DATA_MPEG_PLAY\n");
475 case DATA_BMP_LOAD:
476 dprintk(4, "debi DATA_BMP_LOAD\n");
477 xfer = TX_BUFF;
478 break;
479 default:
480 break;
481 }
482debi_done:
483 spin_lock(&av7110->debilock);
484 if (xfer)
485 iwdebi(av7110, DEBINOSWAP, xfer, 0, 2);
486 ARM_ClearMailBox(av7110);
487 spin_unlock(&av7110->debilock);
488}
489
490
491static void gpioirq(unsigned long cookie)
492{
493 struct av7110 *av7110 = (struct av7110 *)cookie;
494 u32 rxbuf, txbuf;
495 int len;
496
497 if (av7110->debitype != -1)
498
499 printk("dvb-ttpci: GPIO0 irq oops @ %ld, psr:0x%08x, ssr:0x%08x\n",
500 jiffies, saa7146_read(av7110->dev, PSR),
501 saa7146_read(av7110->dev, SSR));
502
503 if (saa7146_wait_for_debi_done(av7110->dev, 0)) {
504 printk(KERN_ERR "%s: saa7146_wait_for_debi_done timed out\n", __func__);
505 BUG();
506 }
507
508 spin_lock(&av7110->debilock);
509 ARM_ClearIrq(av7110);
510
511
512 av7110->debitype = irdebi(av7110, DEBINOSWAP, IRQ_STATE, 0, 2);
513 av7110->debilen = irdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
514 rxbuf = irdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
515 txbuf = irdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
516 len = (av7110->debilen + 3) & ~3;
517
518 print_time("gpio");
519 dprintk(8, "GPIO0 irq 0x%04x %d\n", av7110->debitype, av7110->debilen);
520
521 switch (av7110->debitype & 0xff) {
522
523 case DATA_TS_PLAY:
524 case DATA_PES_PLAY:
525 break;
526
527 case DATA_MPEG_VIDEO_EVENT:
528 {
529 u32 h_ar;
530 struct video_event event;
531
532 av7110->video_size.w = irdebi(av7110, DEBINOSWAP, STATUS_MPEG_WIDTH, 0, 2);
533 h_ar = irdebi(av7110, DEBINOSWAP, STATUS_MPEG_HEIGHT_AR, 0, 2);
534
535 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
536 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
537
538 av7110->video_size.h = h_ar & 0xfff;
539
540 event.type = VIDEO_EVENT_SIZE_CHANGED;
541 event.u.size.w = av7110->video_size.w;
542 event.u.size.h = av7110->video_size.h;
543 switch ((h_ar >> 12) & 0xf)
544 {
545 case 3:
546 av7110->video_size.aspect_ratio = VIDEO_FORMAT_16_9;
547 event.u.size.aspect_ratio = VIDEO_FORMAT_16_9;
548 av7110->videostate.video_format = VIDEO_FORMAT_16_9;
549 break;
550 case 4:
551 av7110->video_size.aspect_ratio = VIDEO_FORMAT_221_1;
552 event.u.size.aspect_ratio = VIDEO_FORMAT_221_1;
553 av7110->videostate.video_format = VIDEO_FORMAT_221_1;
554 break;
555 default:
556 av7110->video_size.aspect_ratio = VIDEO_FORMAT_4_3;
557 event.u.size.aspect_ratio = VIDEO_FORMAT_4_3;
558 av7110->videostate.video_format = VIDEO_FORMAT_4_3;
559 }
560
561 dprintk(8, "GPIO0 irq: DATA_MPEG_VIDEO_EVENT: w/h/ar = %u/%u/%u\n",
562 av7110->video_size.w, av7110->video_size.h,
563 av7110->video_size.aspect_ratio);
564
565 dvb_video_add_event(av7110, &event);
566 break;
567 }
568
569 case DATA_CI_PUT:
570 {
571 int avail;
572 struct dvb_ringbuffer *cibuf = &av7110->ci_wbuffer;
573
574 avail = dvb_ringbuffer_avail(cibuf);
575 if (avail <= 2) {
576 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
577 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
578 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
579 break;
580 }
581 len = DVB_RINGBUFFER_PEEK(cibuf, 0) << 8;
582 len |= DVB_RINGBUFFER_PEEK(cibuf, 1);
583 if (avail < len + 2) {
584 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
585 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
586 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
587 break;
588 }
589 DVB_RINGBUFFER_SKIP(cibuf, 2);
590
591 dvb_ringbuffer_read(cibuf, av7110->debi_virt, len);
592
593 iwdebi(av7110, DEBINOSWAP, TX_LEN, len, 2);
594 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, len, 2);
595 dprintk(8, "DMA: CI\n");
596 start_debi_dma(av7110, DEBI_WRITE, DPRAM_BASE + txbuf, len);
597 spin_unlock(&av7110->debilock);
598 wake_up(&cibuf->queue);
599 return;
600 }
601
602 case DATA_MPEG_PLAY:
603 if (!av7110->playing) {
604 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
605 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
606 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
607 break;
608 }
609 len = 0;
610 if (av7110->debitype & 0x100) {
611 spin_lock(&av7110->aout.lock);
612 len = av7110_pes_play(av7110->debi_virt, &av7110->aout, 2048);
613 spin_unlock(&av7110->aout.lock);
614 }
615 if (len <= 0 && (av7110->debitype & 0x200)
616 &&av7110->videostate.play_state != VIDEO_FREEZED) {
617 spin_lock(&av7110->avout.lock);
618 len = av7110_pes_play(av7110->debi_virt, &av7110->avout, 2048);
619 spin_unlock(&av7110->avout.lock);
620 }
621 if (len <= 0) {
622 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
623 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
624 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
625 break;
626 }
627 dprintk(8, "GPIO0 PES_PLAY len=%04x\n", len);
628 iwdebi(av7110, DEBINOSWAP, TX_LEN, len, 2);
629 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, len, 2);
630 dprintk(8, "DMA: MPEG_PLAY\n");
631 start_debi_dma(av7110, DEBI_WRITE, DPRAM_BASE + txbuf, len);
632 spin_unlock(&av7110->debilock);
633 return;
634
635 case DATA_BMP_LOAD:
636 len = av7110->debilen;
637 dprintk(8, "gpio DATA_BMP_LOAD len %d\n", len);
638 if (!len) {
639 av7110->bmp_state = BMP_LOADED;
640 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, 0, 2);
641 iwdebi(av7110, DEBINOSWAP, TX_LEN, 0, 2);
642 iwdebi(av7110, DEBINOSWAP, TX_BUFF, 0, 2);
643 wake_up(&av7110->bmpq);
644 dprintk(8, "gpio DATA_BMP_LOAD done\n");
645 break;
646 }
647 if (len > av7110->bmplen)
648 len = av7110->bmplen;
649 if (len > 2 * 1024)
650 len = 2 * 1024;
651 iwdebi(av7110, DEBINOSWAP, TX_LEN, len, 2);
652 iwdebi(av7110, DEBINOSWAP, IRQ_STATE_EXT, len, 2);
653 memcpy(av7110->debi_virt, av7110->bmpbuf+av7110->bmpp, len);
654 av7110->bmpp += len;
655 av7110->bmplen -= len;
656 dprintk(8, "gpio DATA_BMP_LOAD DMA len %d\n", len);
657 start_debi_dma(av7110, DEBI_WRITE, DPRAM_BASE+txbuf, len);
658 spin_unlock(&av7110->debilock);
659 return;
660
661 case DATA_CI_GET:
662 case DATA_COMMON_INTERFACE:
663 case DATA_FSECTION:
664 case DATA_IPMPE:
665 case DATA_PIPING:
666 if (!len || len > 4 * 1024) {
667 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
668 break;
669 }
670
671
672 case DATA_TS_RECORD:
673 case DATA_PES_RECORD:
674 dprintk(8, "DMA: TS_REC etc.\n");
675 start_debi_dma(av7110, DEBI_READ, DPRAM_BASE+rxbuf, len);
676 spin_unlock(&av7110->debilock);
677 return;
678
679 case DATA_DEBUG_MESSAGE:
680 if (!len || len > 0xff) {
681 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
682 break;
683 }
684 start_debi_dma(av7110, DEBI_READ, Reserved, len);
685 spin_unlock(&av7110->debilock);
686 return;
687
688 case DATA_IRCOMMAND:
689 if (av7110->ir.ir_handler)
690 av7110->ir.ir_handler(av7110,
691 swahw32(irdebi(av7110, DEBINOSWAP, Reserved, 0, 4)));
692 iwdebi(av7110, DEBINOSWAP, RX_BUFF, 0, 2);
693 break;
694
695 default:
696 printk("dvb-ttpci: gpioirq unknown type=%d len=%d\n",
697 av7110->debitype, av7110->debilen);
698 break;
699 }
700 av7110->debitype = -1;
701 ARM_ClearMailBox(av7110);
702 spin_unlock(&av7110->debilock);
703}
704
705
706#ifdef CONFIG_DVB_AV7110_OSD
707static int dvb_osd_ioctl(struct file *file,
708 unsigned int cmd, void *parg)
709{
710 struct dvb_device *dvbdev = file->private_data;
711 struct av7110 *av7110 = dvbdev->priv;
712
713 dprintk(4, "%p\n", av7110);
714
715 if (cmd == OSD_SEND_CMD)
716 return av7110_osd_cmd(av7110, (osd_cmd_t *) parg);
717 if (cmd == OSD_GET_CAPABILITY)
718 return av7110_osd_capability(av7110, (osd_cap_t *) parg);
719
720 return -EINVAL;
721}
722
723
724static const struct file_operations dvb_osd_fops = {
725 .owner = THIS_MODULE,
726 .unlocked_ioctl = dvb_generic_ioctl,
727 .open = dvb_generic_open,
728 .release = dvb_generic_release,
729 .llseek = noop_llseek,
730};
731
732static struct dvb_device dvbdev_osd = {
733 .priv = NULL,
734 .users = 1,
735 .writers = 1,
736 .fops = &dvb_osd_fops,
737 .kernel_ioctl = dvb_osd_ioctl,
738};
739#endif
740
741
742static inline int SetPIDs(struct av7110 *av7110, u16 vpid, u16 apid, u16 ttpid,
743 u16 subpid, u16 pcrpid)
744{
745 u16 aflags = 0;
746
747 dprintk(4, "%p\n", av7110);
748
749 if (vpid == 0x1fff || apid == 0x1fff ||
750 ttpid == 0x1fff || subpid == 0x1fff || pcrpid == 0x1fff) {
751 vpid = apid = ttpid = subpid = pcrpid = 0;
752 av7110->pids[DMX_PES_VIDEO] = 0;
753 av7110->pids[DMX_PES_AUDIO] = 0;
754 av7110->pids[DMX_PES_TELETEXT] = 0;
755 av7110->pids[DMX_PES_PCR] = 0;
756 }
757
758 if (av7110->audiostate.bypass_mode)
759 aflags |= 0x8000;
760
761 return av7110_fw_cmd(av7110, COMTYPE_PIDFILTER, MultiPID, 6,
762 pcrpid, vpid, apid, ttpid, subpid, aflags);
763}
764
765int ChangePIDs(struct av7110 *av7110, u16 vpid, u16 apid, u16 ttpid,
766 u16 subpid, u16 pcrpid)
767{
768 int ret = 0;
769 dprintk(4, "%p\n", av7110);
770
771 if (mutex_lock_interruptible(&av7110->pid_mutex))
772 return -ERESTARTSYS;
773
774 if (!(vpid & 0x8000))
775 av7110->pids[DMX_PES_VIDEO] = vpid;
776 if (!(apid & 0x8000))
777 av7110->pids[DMX_PES_AUDIO] = apid;
778 if (!(ttpid & 0x8000))
779 av7110->pids[DMX_PES_TELETEXT] = ttpid;
780 if (!(pcrpid & 0x8000))
781 av7110->pids[DMX_PES_PCR] = pcrpid;
782
783 av7110->pids[DMX_PES_SUBTITLE] = 0;
784
785 if (av7110->fe_synced) {
786 pcrpid = av7110->pids[DMX_PES_PCR];
787 ret = SetPIDs(av7110, vpid, apid, ttpid, subpid, pcrpid);
788 }
789
790 mutex_unlock(&av7110->pid_mutex);
791 return ret;
792}
793
794
795
796
797
798
799static int StartHWFilter(struct dvb_demux_filter *dvbdmxfilter)
800{
801 struct dvb_demux_feed *dvbdmxfeed = dvbdmxfilter->feed;
802 struct av7110 *av7110 = dvbdmxfeed->demux->priv;
803 u16 buf[20];
804 int ret, i;
805 u16 handle;
806
807 u16 mode = 0xb96a;
808
809 dprintk(4, "%p\n", av7110);
810
811 if (av7110->full_ts)
812 return 0;
813
814 if (dvbdmxfilter->type == DMX_TYPE_SEC) {
815 if (hw_sections) {
816 buf[4] = (dvbdmxfilter->filter.filter_value[0] << 8) |
817 dvbdmxfilter->maskandmode[0];
818 for (i = 3; i < 18; i++)
819 buf[i + 4 - 2] =
820 (dvbdmxfilter->filter.filter_value[i] << 8) |
821 dvbdmxfilter->maskandmode[i];
822 mode = 4;
823 }
824 } else if ((dvbdmxfeed->ts_type & TS_PACKET) &&
825 !(dvbdmxfeed->ts_type & TS_PAYLOAD_ONLY)) {
826 av7110_p2t_init(&av7110->p2t_filter[dvbdmxfilter->index], dvbdmxfeed);
827 }
828
829 buf[0] = (COMTYPE_PID_FILTER << 8) + AddPIDFilter;
830 buf[1] = 16;
831 buf[2] = dvbdmxfeed->pid;
832 buf[3] = mode;
833
834 ret = av7110_fw_request(av7110, buf, 20, &handle, 1);
835 if (ret != 0 || handle >= 32) {
836 printk("dvb-ttpci: %s error buf %04x %04x %04x %04x "
837 "ret %d handle %04x\n",
838 __func__, buf[0], buf[1], buf[2], buf[3],
839 ret, handle);
840 dvbdmxfilter->hw_handle = 0xffff;
841 if (!ret)
842 ret = -1;
843 return ret;
844 }
845
846 av7110->handle2filter[handle] = dvbdmxfilter;
847 dvbdmxfilter->hw_handle = handle;
848
849 return ret;
850}
851
852static int StopHWFilter(struct dvb_demux_filter *dvbdmxfilter)
853{
854 struct av7110 *av7110 = dvbdmxfilter->feed->demux->priv;
855 u16 buf[3];
856 u16 answ[2];
857 int ret;
858 u16 handle;
859
860 dprintk(4, "%p\n", av7110);
861
862 if (av7110->full_ts)
863 return 0;
864
865 handle = dvbdmxfilter->hw_handle;
866 if (handle >= 32) {
867 printk("%s tried to stop invalid filter %04x, filter type = %x\n",
868 __func__, handle, dvbdmxfilter->type);
869 return -EINVAL;
870 }
871
872 av7110->handle2filter[handle] = NULL;
873
874 buf[0] = (COMTYPE_PID_FILTER << 8) + DelPIDFilter;
875 buf[1] = 1;
876 buf[2] = handle;
877 ret = av7110_fw_request(av7110, buf, 3, answ, 2);
878 if (ret != 0 || answ[1] != handle) {
879 printk("dvb-ttpci: %s error cmd %04x %04x %04x ret %x "
880 "resp %04x %04x pid %d\n",
881 __func__, buf[0], buf[1], buf[2], ret,
882 answ[0], answ[1], dvbdmxfilter->feed->pid);
883 if (!ret)
884 ret = -1;
885 }
886 return ret;
887}
888
889
890static int dvb_feed_start_pid(struct dvb_demux_feed *dvbdmxfeed)
891{
892 struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
893 struct av7110 *av7110 = dvbdmx->priv;
894 u16 *pid = dvbdmx->pids, npids[5];
895 int i;
896 int ret = 0;
897
898 dprintk(4, "%p\n", av7110);
899
900 npids[0] = npids[1] = npids[2] = npids[3] = npids[4] = 0xffff;
901 i = dvbdmxfeed->pes_type;
902 npids[i] = (pid[i]&0x8000) ? 0 : pid[i];
903 if ((i == 2) && npids[i] && (dvbdmxfeed->ts_type & TS_PACKET)) {
904 npids[i] = 0;
905 ret = ChangePIDs(av7110, npids[1], npids[0], npids[2], npids[3], npids[4]);
906 if (!ret)
907 ret = StartHWFilter(dvbdmxfeed->filter);
908 return ret;
909 }
910 if (dvbdmxfeed->pes_type <= 2 || dvbdmxfeed->pes_type == 4) {
911 ret = ChangePIDs(av7110, npids[1], npids[0], npids[2], npids[3], npids[4]);
912 if (ret)
913 return ret;
914 }
915
916 if (dvbdmxfeed->pes_type < 2 && npids[0])
917 if (av7110->fe_synced)
918 {
919 ret = av7110_fw_cmd(av7110, COMTYPE_PIDFILTER, Scan, 0);
920 if (ret)
921 return ret;
922 }
923
924 if ((dvbdmxfeed->ts_type & TS_PACKET) && !av7110->full_ts) {
925 if (dvbdmxfeed->pes_type == 0 && !(dvbdmx->pids[0] & 0x8000))
926 ret = av7110_av_start_record(av7110, RP_AUDIO, dvbdmxfeed);
927 if (dvbdmxfeed->pes_type == 1 && !(dvbdmx->pids[1] & 0x8000))
928 ret = av7110_av_start_record(av7110, RP_VIDEO, dvbdmxfeed);
929 }
930 return ret;
931}
932
933static int dvb_feed_stop_pid(struct dvb_demux_feed *dvbdmxfeed)
934{
935 struct dvb_demux *dvbdmx = dvbdmxfeed->demux;
936 struct av7110 *av7110 = dvbdmx->priv;
937 u16 *pid = dvbdmx->pids, npids[5];
938 int i;
939
940 int ret = 0;
941
942 dprintk(4, "%p\n", av7110);
943
944 if (dvbdmxfeed->pes_type <= 1) {
945 ret = av7110_av_stop(av7110, dvbdmxfeed->pes_type ? RP_VIDEO : RP_AUDIO);
946 if (ret)
947 return ret;
948 if (!av7110->rec_mode)
949 dvbdmx->recording = 0;
950 if (!av7110->playing)
951 dvbdmx->playing = 0;
952 }
953 npids[0] = npids[1] = npids[2] = npids[3] = npids[4] = 0xffff;
954 i = dvbdmxfeed->pes_type;
955 switch (i) {
956 case 2:
957 if (dvbdmxfeed->ts_type & TS_PACKET)
958 ret = StopHWFilter(dvbdmxfeed->filter);
959 npids[2] = 0;
960 break;
961 case 0:
962 case 1:
963 case 4:
964 if (!pids_off)
965 return 0;
966 npids[i] = (pid[i]&0x8000) ? 0 : pid[i];
967 break;
968 }
969 if (!ret)
970 ret = ChangePIDs(av7110, npids[1], npids[0], npids[2], npids[3], npids[4]);
971 return ret;
972}
973
974static int av7110_start_feed(struct dvb_demux_feed *feed)
975{
976 struct dvb_demux *demux = feed->demux;
977 struct av7110 *av7110 = demux->priv;
978 int ret = 0;
979
980 dprintk(4, "%p\n", av7110);
981
982 if (!demux->dmx.frontend)
983 return -EINVAL;
984
985 if (!av7110->full_ts && feed->pid > 0x1fff)
986 return -EINVAL;
987
988 if (feed->type == DMX_TYPE_TS) {
989 if ((feed->ts_type & TS_DECODER) &&
990 (feed->pes_type <= DMX_PES_PCR)) {
991 switch (demux->dmx.frontend->source) {
992 case DMX_MEMORY_FE:
993 if (feed->ts_type & TS_DECODER)
994 if (feed->pes_type < 2 &&
995 !(demux->pids[0] & 0x8000) &&
996 !(demux->pids[1] & 0x8000)) {
997 dvb_ringbuffer_flush_spinlock_wakeup(&av7110->avout);
998 dvb_ringbuffer_flush_spinlock_wakeup(&av7110->aout);
999 ret = av7110_av_start_play(av7110,RP_AV);
1000 if (!ret)
1001 demux->playing = 1;
1002 }
1003 break;
1004 default:
1005 ret = dvb_feed_start_pid(feed);
1006 break;
1007 }
1008 } else if ((feed->ts_type & TS_PACKET) &&
1009 (demux->dmx.frontend->source != DMX_MEMORY_FE)) {
1010 ret = StartHWFilter(feed->filter);
1011 }
1012 }
1013
1014 if (av7110->full_ts) {
1015 budget_start_feed(feed);
1016 return ret;
1017 }
1018
1019 if (feed->type == DMX_TYPE_SEC) {
1020 int i;
1021
1022 for (i = 0; i < demux->filternum; i++) {
1023 if (demux->filter[i].state != DMX_STATE_READY)
1024 continue;
1025 if (demux->filter[i].type != DMX_TYPE_SEC)
1026 continue;
1027 if (demux->filter[i].filter.parent != &feed->feed.sec)
1028 continue;
1029 demux->filter[i].state = DMX_STATE_GO;
1030 if (demux->dmx.frontend->source != DMX_MEMORY_FE) {
1031 ret = StartHWFilter(&demux->filter[i]);
1032 if (ret)
1033 break;
1034 }
1035 }
1036 }
1037
1038 return ret;
1039}
1040
1041
1042static int av7110_stop_feed(struct dvb_demux_feed *feed)
1043{
1044 struct dvb_demux *demux = feed->demux;
1045 struct av7110 *av7110 = demux->priv;
1046 int i, rc, ret = 0;
1047 dprintk(4, "%p\n", av7110);
1048
1049 if (feed->type == DMX_TYPE_TS) {
1050 if (feed->ts_type & TS_DECODER) {
1051 if (feed->pes_type >= DMX_PES_OTHER ||
1052 !demux->pesfilter[feed->pes_type])
1053 return -EINVAL;
1054 demux->pids[feed->pes_type] |= 0x8000;
1055 demux->pesfilter[feed->pes_type] = NULL;
1056 }
1057 if (feed->ts_type & TS_DECODER &&
1058 feed->pes_type < DMX_PES_OTHER) {
1059 ret = dvb_feed_stop_pid(feed);
1060 } else
1061 if ((feed->ts_type & TS_PACKET) &&
1062 (demux->dmx.frontend->source != DMX_MEMORY_FE))
1063 ret = StopHWFilter(feed->filter);
1064 }
1065
1066 if (av7110->full_ts) {
1067 budget_stop_feed(feed);
1068 return ret;
1069 }
1070
1071 if (feed->type == DMX_TYPE_SEC) {
1072 for (i = 0; i<demux->filternum; i++) {
1073 if (demux->filter[i].state == DMX_STATE_GO &&
1074 demux->filter[i].filter.parent == &feed->feed.sec) {
1075 demux->filter[i].state = DMX_STATE_READY;
1076 if (demux->dmx.frontend->source != DMX_MEMORY_FE) {
1077 rc = StopHWFilter(&demux->filter[i]);
1078 if (!ret)
1079 ret = rc;
1080
1081 }
1082 }
1083 }
1084 }
1085
1086 return ret;
1087}
1088
1089
1090static void restart_feeds(struct av7110 *av7110)
1091{
1092 struct dvb_demux *dvbdmx = &av7110->demux;
1093 struct dvb_demux_feed *feed;
1094 int mode;
1095 int feeding;
1096 int i, j;
1097
1098 dprintk(4, "%p\n", av7110);
1099
1100 mode = av7110->playing;
1101 av7110->playing = 0;
1102 av7110->rec_mode = 0;
1103
1104 feeding = av7110->feeding1;
1105
1106 for (i = 0; i < dvbdmx->feednum; i++) {
1107 feed = &dvbdmx->feed[i];
1108 if (feed->state == DMX_STATE_GO) {
1109 if (feed->type == DMX_TYPE_SEC) {
1110 for (j = 0; j < dvbdmx->filternum; j++) {
1111 if (dvbdmx->filter[j].type != DMX_TYPE_SEC)
1112 continue;
1113 if (dvbdmx->filter[j].filter.parent != &feed->feed.sec)
1114 continue;
1115 if (dvbdmx->filter[j].state == DMX_STATE_GO)
1116 dvbdmx->filter[j].state = DMX_STATE_READY;
1117 }
1118 }
1119 av7110_start_feed(feed);
1120 }
1121 }
1122
1123 av7110->feeding1 = feeding;
1124
1125 if (mode)
1126 av7110_av_start_play(av7110, mode);
1127}
1128
1129static int dvb_get_stc(struct dmx_demux *demux, unsigned int num,
1130 uint64_t *stc, unsigned int *base)
1131{
1132 int ret;
1133 u16 fwstc[4];
1134 u16 tag = ((COMTYPE_REQUEST << 8) + ReqSTC);
1135 struct dvb_demux *dvbdemux;
1136 struct av7110 *av7110;
1137
1138
1139 BUG_ON(!demux);
1140 dvbdemux = demux->priv;
1141 BUG_ON(!dvbdemux);
1142 av7110 = dvbdemux->priv;
1143
1144 dprintk(4, "%p\n", av7110);
1145
1146 if (num != 0)
1147 return -EINVAL;
1148
1149 ret = av7110_fw_request(av7110, &tag, 0, fwstc, 4);
1150 if (ret) {
1151 printk(KERN_ERR "%s: av7110_fw_request error\n", __func__);
1152 return ret;
1153 }
1154 dprintk(2, "fwstc = %04hx %04hx %04hx %04hx\n",
1155 fwstc[0], fwstc[1], fwstc[2], fwstc[3]);
1156
1157 *stc = (((uint64_t) ((fwstc[3] & 0x8000) >> 15)) << 32) |
1158 (((uint64_t) fwstc[1]) << 16) | ((uint64_t) fwstc[0]);
1159 *base = 1;
1160
1161 dprintk(4, "stc = %lu\n", (unsigned long)*stc);
1162
1163 return 0;
1164}
1165
1166
1167
1168
1169
1170
1171
1172static int av7110_set_tone(struct dvb_frontend *fe, enum fe_sec_tone_mode tone)
1173{
1174 struct av7110* av7110 = fe->dvb->priv;
1175
1176 switch (tone) {
1177 case SEC_TONE_ON:
1178 return Set22K(av7110, 1);
1179
1180 case SEC_TONE_OFF:
1181 return Set22K(av7110, 0);
1182
1183 default:
1184 return -EINVAL;
1185 }
1186}
1187
1188static int av7110_diseqc_send_master_cmd(struct dvb_frontend* fe,
1189 struct dvb_diseqc_master_cmd* cmd)
1190{
1191 struct av7110* av7110 = fe->dvb->priv;
1192
1193 return av7110_diseqc_send(av7110, cmd->msg_len, cmd->msg, -1);
1194}
1195
1196static int av7110_diseqc_send_burst(struct dvb_frontend* fe,
1197 enum fe_sec_mini_cmd minicmd)
1198{
1199 struct av7110* av7110 = fe->dvb->priv;
1200
1201 return av7110_diseqc_send(av7110, 0, NULL, minicmd);
1202}
1203
1204
1205static int stop_ts_capture(struct av7110 *budget)
1206{
1207 dprintk(2, "budget: %p\n", budget);
1208
1209 if (--budget->feeding1)
1210 return budget->feeding1;
1211 saa7146_write(budget->dev, MC1, MASK_20);
1212 SAA7146_IER_DISABLE(budget->dev, MASK_10);
1213 SAA7146_ISR_CLEAR(budget->dev, MASK_10);
1214 return 0;
1215}
1216
1217static int start_ts_capture(struct av7110 *budget)
1218{
1219 unsigned y;
1220
1221 dprintk(2, "budget: %p\n", budget);
1222
1223 if (budget->feeding1)
1224 return ++budget->feeding1;
1225 for (y = 0; y < TS_HEIGHT; y++)
1226 memset(budget->grabbing + y * TS_WIDTH, 0x00, TS_WIDTH);
1227 budget->ttbp = 0;
1228 SAA7146_ISR_CLEAR(budget->dev, MASK_10);
1229 SAA7146_IER_ENABLE(budget->dev, MASK_10);
1230 saa7146_write(budget->dev, MC1, (MASK_04 | MASK_20));
1231 return ++budget->feeding1;
1232}
1233
1234static int budget_start_feed(struct dvb_demux_feed *feed)
1235{
1236 struct dvb_demux *demux = feed->demux;
1237 struct av7110 *budget = demux->priv;
1238 int status;
1239
1240 dprintk(2, "av7110: %p\n", budget);
1241
1242 spin_lock(&budget->feedlock1);
1243 feed->pusi_seen = 0;
1244 status = start_ts_capture(budget);
1245 spin_unlock(&budget->feedlock1);
1246 return status;
1247}
1248
1249static int budget_stop_feed(struct dvb_demux_feed *feed)
1250{
1251 struct dvb_demux *demux = feed->demux;
1252 struct av7110 *budget = demux->priv;
1253 int status;
1254
1255 dprintk(2, "budget: %p\n", budget);
1256
1257 spin_lock(&budget->feedlock1);
1258 status = stop_ts_capture(budget);
1259 spin_unlock(&budget->feedlock1);
1260 return status;
1261}
1262
1263static void vpeirq(unsigned long cookie)
1264{
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;
1270
1271
1272 newdma -= newdma % 188;
1273
1274 if (newdma >= TS_BUFLEN)
1275 return;
1276
1277 budget->ttbp = newdma;
1278
1279 if (!budget->feeding1 || (newdma == olddma))
1280 return;
1281
1282
1283 pci_dma_sync_sg_for_cpu(budget->dev->pci, budget->pt.slist, budget->pt.nents, PCI_DMA_FROMDEVICE);
1284
1285#if 0
1286
1287 printk("vpeirq: %02x Event Counter 1 0x%04x\n",
1288 mem[olddma],
1289 saa7146_read(budget->dev, EC1R) & 0x3fff);
1290#endif
1291
1292 if (newdma > olddma)
1293
1294 dvb_dmx_swfilter_packets(demux, mem + olddma, (newdma - olddma) / 188);
1295 else {
1296
1297 dvb_dmx_swfilter_packets(demux, mem + olddma, (TS_BUFLEN - olddma) / 188);
1298 dvb_dmx_swfilter_packets(demux, mem, newdma / 188);
1299 }
1300}
1301
1302static int av7110_register(struct av7110 *av7110)
1303{
1304 int ret, i;
1305 struct dvb_demux *dvbdemux = &av7110->demux;
1306 struct dvb_demux *dvbdemux1 = &av7110->demux1;
1307
1308 dprintk(4, "%p\n", av7110);
1309
1310 if (av7110->registered)
1311 return -1;
1312
1313 av7110->registered = 1;
1314
1315 dvbdemux->priv = (void *) av7110;
1316
1317 for (i = 0; i < 32; i++)
1318 av7110->handle2filter[i] = NULL;
1319
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);
1327
1328 dvb_dmx_init(&av7110->demux);
1329 av7110->demux.dmx.get_stc = dvb_get_stc;
1330
1331 av7110->dmxdev.filternum = (av7110->full_ts) ? 256 : 32;
1332 av7110->dmxdev.demux = &dvbdemux->dmx;
1333 av7110->dmxdev.capabilities = 0;
1334
1335 dvb_dmxdev_init(&av7110->dmxdev, &av7110->dvb_adapter);
1336
1337 av7110->hw_frontend.source = DMX_FRONTEND_0;
1338
1339 ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &av7110->hw_frontend);
1340
1341 if (ret < 0)
1342 return ret;
1343
1344 av7110->mem_frontend.source = DMX_MEMORY_FE;
1345
1346 ret = dvbdemux->dmx.add_frontend(&dvbdemux->dmx, &av7110->mem_frontend);
1347
1348 if (ret < 0)
1349 return ret;
1350
1351 ret = dvbdemux->dmx.connect_frontend(&dvbdemux->dmx,
1352 &av7110->hw_frontend);
1353 if (ret < 0)
1354 return ret;
1355
1356 av7110_av_register(av7110);
1357 av7110_ca_register(av7110);
1358
1359#ifdef CONFIG_DVB_AV7110_OSD
1360 dvb_register_device(&av7110->dvb_adapter, &av7110->osd_dev,
1361 &dvbdev_osd, av7110, DVB_DEVICE_OSD, 0);
1362#endif
1363
1364 dvb_net_init(&av7110->dvb_adapter, &av7110->dvb_net, &dvbdemux->dmx);
1365
1366 if (budgetpatch) {
1367
1368
1369
1370 dvbdemux1->priv = (void *) av7110;
1371
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;
1377
1378 dvbdemux1->dmx.capabilities = (DMX_TS_FILTERING | DMX_SECTION_FILTERING |
1379 DMX_MEMORY_BASED_FILTERING);
1380
1381 dvb_dmx_init(&av7110->demux1);
1382
1383 av7110->dmxdev1.filternum = 256;
1384 av7110->dmxdev1.demux = &dvbdemux1->dmx;
1385 av7110->dmxdev1.capabilities = 0;
1386
1387 dvb_dmxdev_init(&av7110->dmxdev1, &av7110->dvb_adapter);
1388
1389 dvb_net_init(&av7110->dvb_adapter, &av7110->dvb_net1, &dvbdemux1->dmx);
1390 printk("dvb-ttpci: additional demux1 for budget-patch registered\n");
1391 }
1392 return 0;
1393}
1394
1395
1396static void dvb_unregister(struct av7110 *av7110)
1397{
1398 struct dvb_demux *dvbdemux = &av7110->demux;
1399 struct dvb_demux *dvbdemux1 = &av7110->demux1;
1400
1401 dprintk(4, "%p\n", av7110);
1402
1403 if (!av7110->registered)
1404 return;
1405
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);
1411 }
1412
1413 dvb_net_release(&av7110->dvb_net);
1414
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);
1418
1419 dvb_dmxdev_release(&av7110->dmxdev);
1420 dvb_dmx_release(&av7110->demux);
1421
1422 if (av7110->fe != NULL) {
1423 dvb_unregister_frontend(av7110->fe);
1424 dvb_frontend_detach(av7110->fe);
1425 }
1426 dvb_unregister_device(av7110->osd_dev);
1427 av7110_av_unregister(av7110);
1428 av7110_ca_unregister(av7110);
1429}
1430
1431
1432
1433
1434
1435
1436int i2c_writereg(struct av7110 *av7110, u8 id, u8 reg, u8 val)
1437{
1438 u8 msg[2] = { reg, val };
1439 struct i2c_msg msgs;
1440
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);
1446}
1447
1448u8 i2c_readreg(struct av7110 *av7110, u8 id, u8 reg)
1449{
1450 u8 mm1[] = {0x00};
1451 u8 mm2[] = {0x00};
1452 struct i2c_msg msgs[2];
1453
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);
1461
1462 return mm2[0];
1463}
1464
1465
1466
1467
1468
1469
1470static int check_firmware(struct av7110* av7110)
1471{
1472 u32 crc = 0, len = 0;
1473 unsigned char *ptr;
1474
1475
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;
1481 }
1482 ptr += 4;
1483
1484
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;
1492 }
1493 if (crc != crc32_le(0, ptr, len)) {
1494 printk("dvb-ttpci: crc32 of dpram file does not match.\n");
1495 return -EINVAL;
1496 }
1497 av7110->bin_dpram = ptr;
1498 av7110->size_dpram = len;
1499 ptr += len;
1500
1501
1502 crc = get_unaligned_be32(ptr);
1503 ptr += 4;
1504 len = get_unaligned_be32(ptr);
1505 ptr += 4;
1506
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;
1511 }
1512 if( crc != crc32_le(0, ptr, len)) {
1513 printk("dvb-ttpci: crc32 of root file does not match.\n");
1514 return -EINVAL;
1515 }
1516 av7110->bin_root = ptr;
1517 av7110->size_root = len;
1518 return 0;
1519}
1520
1521static void put_firmware(struct av7110* av7110)
1522{
1523 vfree(av7110->bin_fw);
1524}
1525
1526static int get_firmware(struct av7110* av7110)
1527{
1528 int ret;
1529 const struct firmware *fw;
1530
1531
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 " https://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;
1545 }
1546
1547 if (fw->size <= 200000) {
1548 printk("dvb-ttpci: this firmware is way too small.\n");
1549 release_firmware(fw);
1550 return -EINVAL;
1551 }
1552
1553
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;
1559 }
1560
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);
1565
1566 release_firmware(fw);
1567 return ret;
1568}
1569
1570static int alps_bsrv2_tuner_set_params(struct dvb_frontend *fe)
1571{
1572 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
1573 struct av7110* av7110 = fe->dvb->priv;
1574 u8 pwr = 0;
1575 u8 buf[4];
1576 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = buf, .len = sizeof(buf) };
1577 u32 div = (p->frequency + 479500) / 125;
1578
1579 if (p->frequency > 2000000)
1580 pwr = 3;
1581 else if (p->frequency > 1800000)
1582 pwr = 2;
1583 else if (p->frequency > 1600000)
1584 pwr = 1;
1585 else if (p->frequency > 1200000)
1586 pwr = 0;
1587 else if (p->frequency >= 1100000)
1588 pwr = 1;
1589 else
1590 pwr = 2;
1591
1592 buf[0] = (div >> 8) & 0x7f;
1593 buf[1] = div & 0xff;
1594 buf[2] = ((div & 0x18000) >> 10) | 0x95;
1595 buf[3] = (pwr << 6) | 0x30;
1596
1597
1598
1599
1600 if (fe->ops.i2c_gate_ctrl)
1601 fe->ops.i2c_gate_ctrl(fe, 1);
1602 if (i2c_transfer (&av7110->i2c_adap, &msg, 1) != 1)
1603 return -EIO;
1604 return 0;
1605}
1606
1607static struct ves1x93_config alps_bsrv2_config = {
1608 .demod_address = 0x08,
1609 .xin = 90100000UL,
1610 .invert_pwm = 0,
1611};
1612
1613static int alps_tdbe2_tuner_set_params(struct dvb_frontend *fe)
1614{
1615 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
1616 struct av7110* av7110 = fe->dvb->priv;
1617 u32 div;
1618 u8 data[4];
1619 struct i2c_msg msg = { .addr = 0x62, .flags = 0, .buf = data, .len = sizeof(data) };
1620
1621 div = (p->frequency + 35937500 + 31250) / 62500;
1622
1623 data[0] = (div >> 8) & 0x7f;
1624 data[1] = div & 0xff;
1625 data[2] = 0x85 | ((div >> 10) & 0x60);
1626 data[3] = (p->frequency < 174000000 ? 0x88 : p->frequency < 470000000 ? 0x84 : 0x81);
1627
1628 if (fe->ops.i2c_gate_ctrl)
1629 fe->ops.i2c_gate_ctrl(fe, 1);
1630 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1631 return -EIO;
1632 return 0;
1633}
1634
1635static struct ves1820_config alps_tdbe2_config = {
1636 .demod_address = 0x09,
1637 .xin = 57840000UL,
1638 .invert = 1,
1639 .selagc = VES1820_SELAGC_SIGNAMPERR,
1640};
1641
1642
1643
1644
1645static int grundig_29504_451_tuner_set_params(struct dvb_frontend *fe)
1646{
1647 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
1648 struct av7110* av7110 = fe->dvb->priv;
1649 u32 div;
1650 u8 data[4];
1651 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = data, .len = sizeof(data) };
1652
1653 div = p->frequency / 125;
1654 data[0] = (div >> 8) & 0x7f;
1655 data[1] = div & 0xff;
1656 data[2] = 0x8e;
1657 data[3] = 0x00;
1658
1659 if (fe->ops.i2c_gate_ctrl)
1660 fe->ops.i2c_gate_ctrl(fe, 1);
1661 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1662 return -EIO;
1663 return 0;
1664}
1665
1666static struct tda8083_config grundig_29504_451_config = {
1667 .demod_address = 0x68,
1668};
1669
1670
1671
1672static int philips_cd1516_tuner_set_params(struct dvb_frontend *fe)
1673{
1674 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
1675 struct av7110* av7110 = fe->dvb->priv;
1676 u32 div;
1677 u32 f = p->frequency;
1678 u8 data[4];
1679 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = data, .len = sizeof(data) };
1680
1681 div = (f + 36125000 + 31250) / 62500;
1682
1683 data[0] = (div >> 8) & 0x7f;
1684 data[1] = div & 0xff;
1685 data[2] = 0x8e;
1686 data[3] = (f < 174000000 ? 0xa1 : f < 470000000 ? 0x92 : 0x34);
1687
1688 if (fe->ops.i2c_gate_ctrl)
1689 fe->ops.i2c_gate_ctrl(fe, 1);
1690 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1691 return -EIO;
1692 return 0;
1693}
1694
1695static struct ves1820_config philips_cd1516_config = {
1696 .demod_address = 0x09,
1697 .xin = 57840000UL,
1698 .invert = 1,
1699 .selagc = VES1820_SELAGC_SIGNAMPERR,
1700};
1701
1702
1703
1704static int alps_tdlb7_tuner_set_params(struct dvb_frontend *fe)
1705{
1706 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
1707 struct av7110* av7110 = fe->dvb->priv;
1708 u32 div, pwr;
1709 u8 data[4];
1710 struct i2c_msg msg = { .addr = 0x60, .flags = 0, .buf = data, .len = sizeof(data) };
1711
1712 div = (p->frequency + 36200000) / 166666;
1713
1714 if (p->frequency <= 782000000)
1715 pwr = 1;
1716 else
1717 pwr = 2;
1718
1719 data[0] = (div >> 8) & 0x7f;
1720 data[1] = div & 0xff;
1721 data[2] = 0x85;
1722 data[3] = pwr << 6;
1723
1724 if (fe->ops.i2c_gate_ctrl)
1725 fe->ops.i2c_gate_ctrl(fe, 1);
1726 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1)
1727 return -EIO;
1728 return 0;
1729}
1730
1731static int alps_tdlb7_request_firmware(struct dvb_frontend* fe, const struct firmware **fw, char* name)
1732{
1733#if IS_ENABLED(CONFIG_DVB_SP8870)
1734 struct av7110* av7110 = fe->dvb->priv;
1735
1736 return request_firmware(fw, name, &av7110->dev->pci->dev);
1737#else
1738 return -EINVAL;
1739#endif
1740}
1741
1742static const struct sp8870_config alps_tdlb7_config = {
1743
1744 .demod_address = 0x71,
1745 .request_firmware = alps_tdlb7_request_firmware,
1746};
1747
1748
1749static u8 nexusca_stv0297_inittab[] = {
1750 0x80, 0x01,
1751 0x80, 0x00,
1752 0x81, 0x01,
1753 0x81, 0x00,
1754 0x00, 0x09,
1755 0x01, 0x69,
1756 0x03, 0x00,
1757 0x04, 0x00,
1758 0x07, 0x00,
1759 0x08, 0x00,
1760 0x20, 0x00,
1761 0x21, 0x40,
1762 0x22, 0x00,
1763 0x23, 0x00,
1764 0x24, 0x40,
1765 0x25, 0x88,
1766 0x30, 0xff,
1767 0x31, 0x00,
1768 0x32, 0xff,
1769 0x33, 0x00,
1770 0x34, 0x50,
1771 0x35, 0x7f,
1772 0x36, 0x00,
1773 0x37, 0x20,
1774 0x38, 0x00,
1775 0x40, 0x1c,
1776 0x41, 0xff,
1777 0x42, 0x29,
1778 0x43, 0x00,
1779 0x44, 0xff,
1780 0x45, 0x00,
1781 0x46, 0x00,
1782 0x49, 0x04,
1783 0x4a, 0x00,
1784 0x4b, 0x7b,
1785 0x52, 0x30,
1786 0x55, 0xae,
1787 0x56, 0x47,
1788 0x57, 0xe1,
1789 0x58, 0x3a,
1790 0x5a, 0x1e,
1791 0x5b, 0x34,
1792 0x60, 0x00,
1793 0x63, 0x00,
1794 0x64, 0x00,
1795 0x65, 0x00,
1796 0x66, 0x00,
1797 0x67, 0x00,
1798 0x68, 0x00,
1799 0x69, 0x00,
1800 0x6a, 0x02,
1801 0x6b, 0x00,
1802 0x70, 0xff,
1803 0x71, 0x00,
1804 0x72, 0x00,
1805 0x73, 0x00,
1806 0x74, 0x0c,
1807 0x80, 0x00,
1808 0x81, 0x00,
1809 0x82, 0x00,
1810 0x83, 0x00,
1811 0x84, 0x04,
1812 0x85, 0x80,
1813 0x86, 0x24,
1814 0x87, 0x78,
1815 0x88, 0x10,
1816 0x89, 0x00,
1817 0x90, 0x01,
1818 0x91, 0x01,
1819 0xa0, 0x04,
1820 0xa1, 0x00,
1821 0xa2, 0x00,
1822 0xb0, 0x91,
1823 0xb1, 0x0b,
1824 0xc0, 0x53,
1825 0xc1, 0x70,
1826 0xc2, 0x12,
1827 0xd0, 0x00,
1828 0xd1, 0x00,
1829 0xd2, 0x00,
1830 0xd3, 0x00,
1831 0xd4, 0x00,
1832 0xd5, 0x00,
1833 0xde, 0x00,
1834 0xdf, 0x00,
1835 0x61, 0x49,
1836 0x62, 0x0b,
1837 0x53, 0x08,
1838 0x59, 0x08,
1839 0xff, 0xff,
1840};
1841
1842static int nexusca_stv0297_tuner_set_params(struct dvb_frontend *fe)
1843{
1844 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
1845 struct av7110* av7110 = fe->dvb->priv;
1846 u32 div;
1847 u8 data[4];
1848 struct i2c_msg msg = { .addr = 0x63, .flags = 0, .buf = data, .len = sizeof(data) };
1849 struct i2c_msg readmsg = { .addr = 0x63, .flags = I2C_M_RD, .buf = data, .len = 1 };
1850 int i;
1851
1852 div = (p->frequency + 36150000 + 31250) / 62500;
1853
1854 data[0] = (div >> 8) & 0x7f;
1855 data[1] = div & 0xff;
1856 data[2] = 0xce;
1857
1858 if (p->frequency < 45000000)
1859 return -EINVAL;
1860 else if (p->frequency < 137000000)
1861 data[3] = 0x01;
1862 else if (p->frequency < 403000000)
1863 data[3] = 0x02;
1864 else if (p->frequency < 860000000)
1865 data[3] = 0x04;
1866 else
1867 return -EINVAL;
1868
1869 if (fe->ops.i2c_gate_ctrl)
1870 fe->ops.i2c_gate_ctrl(fe, 1);
1871 if (i2c_transfer(&av7110->i2c_adap, &msg, 1) != 1) {
1872 printk("nexusca: pll transfer failed!\n");
1873 return -EIO;
1874 }
1875
1876
1877 for(i = 0; i < 20; i++) {
1878 if (fe->ops.i2c_gate_ctrl)
1879 fe->ops.i2c_gate_ctrl(fe, 1);
1880 if (i2c_transfer(&av7110->i2c_adap, &readmsg, 1) == 1)
1881 if (data[0] & 0x40) break;
1882 msleep(10);
1883 }
1884
1885 return 0;
1886}
1887
1888static struct stv0297_config nexusca_stv0297_config = {
1889
1890 .demod_address = 0x1C,
1891 .inittab = nexusca_stv0297_inittab,
1892 .invert = 1,
1893 .stop_during_read = 1,
1894};
1895
1896
1897
1898static int grundig_29504_401_tuner_set_params(struct dvb_frontend *fe)
1899{
1900 struct dtv_frontend_properties *p = &fe->dtv_property_cache;
1901 struct av7110* av7110 = fe->dvb->priv;
1902 u32 div;
1903 u8 cfg, cpump, band_select;
1904 u8 data[4];
1905 struct i2c_msg msg = { .addr = 0x61, .flags = 0, .buf = data, .len = sizeof(data) };
1906
1907 div = (36125000 + p->frequency) / 166666;
1908
1909 cfg = 0x88;
1910
1911 if (p->frequency < 175000000)
1912 cpump = 2;
1913 else if (p->frequency < 390000000)
1914 cpump = 1;
1915 else if (p->frequency < 470000000)
1916 cpump = 2;
1917 else if (p->frequency < 750000000)
1918 cpump = 1;
1919 else
1920 cpump = 3;
1921
1922 if (p->frequency < 175000000)
1923 band_select = 0x0e;
1924 else if (p->frequency < 470000000)
1925 band_select = 0x05;
1926 else
1927 band_select = 0x03;
1928
1929 data[0] = (div >> 8) & 0x7f;
1930 data[1] = div & 0xff;
1931 data[2] = ((div >> 10) & 0x60) | cfg;
1932 data[3] = (cpump << 6) | band_select;
1933
1934 if (fe->ops.i2c_gate_ctrl)
1935 fe->ops.i2c_gate_ctrl(fe, 1);
1936 if (i2c_transfer (&av7110->i2c_adap, &msg, 1) != 1) return -EIO;
1937 return 0;
1938}
1939
1940static struct l64781_config grundig_29504_401_config = {
1941 .demod_address = 0x55,
1942};
1943
1944
1945
1946static int av7110_fe_lock_fix(struct av7110 *av7110, enum fe_status status)
1947{
1948 int ret = 0;
1949 int synced = (status & FE_HAS_LOCK) ? 1 : 0;
1950
1951 av7110->fe_status = status;
1952
1953 if (av7110->fe_synced == synced)
1954 return 0;
1955
1956 if (av7110->playing) {
1957 av7110->fe_synced = synced;
1958 return 0;
1959 }
1960
1961 if (mutex_lock_interruptible(&av7110->pid_mutex))
1962 return -ERESTARTSYS;
1963
1964 if (synced) {
1965 ret = SetPIDs(av7110, av7110->pids[DMX_PES_VIDEO],
1966 av7110->pids[DMX_PES_AUDIO],
1967 av7110->pids[DMX_PES_TELETEXT], 0,
1968 av7110->pids[DMX_PES_PCR]);
1969 if (!ret)
1970 ret = av7110_fw_cmd(av7110, COMTYPE_PIDFILTER, Scan, 0);
1971 } else {
1972 ret = SetPIDs(av7110, 0, 0, 0, 0, 0);
1973 if (!ret) {
1974 ret = av7110_fw_cmd(av7110, COMTYPE_PID_FILTER, FlushTSQueue, 0);
1975 if (!ret)
1976 ret = av7110_wait_msgstate(av7110, GPMQBusy);
1977 }
1978 }
1979
1980 if (!ret)
1981 av7110->fe_synced = synced;
1982
1983 mutex_unlock(&av7110->pid_mutex);
1984 return ret;
1985}
1986
1987static int av7110_fe_set_frontend(struct dvb_frontend *fe)
1988{
1989 struct av7110* av7110 = fe->dvb->priv;
1990
1991 int ret = av7110_fe_lock_fix(av7110, 0);
1992 if (!ret)
1993 ret = av7110->fe_set_frontend(fe);
1994
1995 return ret;
1996}
1997
1998static int av7110_fe_init(struct dvb_frontend* fe)
1999{
2000 struct av7110* av7110 = fe->dvb->priv;
2001
2002 int ret = av7110_fe_lock_fix(av7110, 0);
2003 if (!ret)
2004 ret = av7110->fe_init(fe);
2005 return ret;
2006}
2007
2008static int av7110_fe_read_status(struct dvb_frontend *fe,
2009 enum fe_status *status)
2010{
2011 struct av7110* av7110 = fe->dvb->priv;
2012
2013
2014 int ret = av7110->fe_read_status(fe, status);
2015 if (!ret)
2016 if (((*status ^ av7110->fe_status) & FE_HAS_LOCK) && (*status & FE_HAS_LOCK))
2017 ret = av7110_fe_lock_fix(av7110, *status);
2018 return ret;
2019}
2020
2021static int av7110_fe_diseqc_reset_overload(struct dvb_frontend* fe)
2022{
2023 struct av7110* av7110 = fe->dvb->priv;
2024
2025 int ret = av7110_fe_lock_fix(av7110, 0);
2026 if (!ret)
2027 ret = av7110->fe_diseqc_reset_overload(fe);
2028 return ret;
2029}
2030
2031static int av7110_fe_diseqc_send_master_cmd(struct dvb_frontend* fe,
2032 struct dvb_diseqc_master_cmd* cmd)
2033{
2034 struct av7110* av7110 = fe->dvb->priv;
2035
2036 int ret = av7110_fe_lock_fix(av7110, 0);
2037 if (!ret) {
2038 av7110->saved_master_cmd = *cmd;
2039 ret = av7110->fe_diseqc_send_master_cmd(fe, cmd);
2040 }
2041 return ret;
2042}
2043
2044static int av7110_fe_diseqc_send_burst(struct dvb_frontend *fe,
2045 enum fe_sec_mini_cmd minicmd)
2046{
2047 struct av7110* av7110 = fe->dvb->priv;
2048
2049 int ret = av7110_fe_lock_fix(av7110, 0);
2050 if (!ret) {
2051 av7110->saved_minicmd = minicmd;
2052 ret = av7110->fe_diseqc_send_burst(fe, minicmd);
2053 }
2054 return ret;
2055}
2056
2057static int av7110_fe_set_tone(struct dvb_frontend *fe,
2058 enum fe_sec_tone_mode tone)
2059{
2060 struct av7110* av7110 = fe->dvb->priv;
2061
2062 int ret = av7110_fe_lock_fix(av7110, 0);
2063 if (!ret) {
2064 av7110->saved_tone = tone;
2065 ret = av7110->fe_set_tone(fe, tone);
2066 }
2067 return ret;
2068}
2069
2070static int av7110_fe_set_voltage(struct dvb_frontend *fe,
2071 enum fe_sec_voltage voltage)
2072{
2073 struct av7110* av7110 = fe->dvb->priv;
2074
2075 int ret = av7110_fe_lock_fix(av7110, 0);
2076 if (!ret) {
2077 av7110->saved_voltage = voltage;
2078 ret = av7110->fe_set_voltage(fe, voltage);
2079 }
2080 return ret;
2081}
2082
2083static int av7110_fe_dishnetwork_send_legacy_command(struct dvb_frontend* fe, unsigned long cmd)
2084{
2085 struct av7110* av7110 = fe->dvb->priv;
2086
2087 int ret = av7110_fe_lock_fix(av7110, 0);
2088 if (!ret)
2089 ret = av7110->fe_dishnetwork_send_legacy_command(fe, cmd);
2090 return ret;
2091}
2092
2093static void dvb_s_recover(struct av7110* av7110)
2094{
2095 av7110_fe_init(av7110->fe);
2096
2097 av7110_fe_set_voltage(av7110->fe, av7110->saved_voltage);
2098 if (av7110->saved_master_cmd.msg_len) {
2099 msleep(20);
2100 av7110_fe_diseqc_send_master_cmd(av7110->fe, &av7110->saved_master_cmd);
2101 }
2102 msleep(20);
2103 av7110_fe_diseqc_send_burst(av7110->fe, av7110->saved_minicmd);
2104 msleep(20);
2105 av7110_fe_set_tone(av7110->fe, av7110->saved_tone);
2106
2107 av7110_fe_set_frontend(av7110->fe);
2108}
2109
2110static u8 read_pwm(struct av7110* av7110)
2111{
2112 u8 b = 0xff;
2113 u8 pwm;
2114 struct i2c_msg msg[] = { { .addr = 0x50,.flags = 0,.buf = &b,.len = 1 },
2115 { .addr = 0x50,.flags = I2C_M_RD,.buf = &pwm,.len = 1} };
2116
2117 if ((i2c_transfer(&av7110->i2c_adap, msg, 2) != 2) || (pwm == 0xff))
2118 pwm = 0x48;
2119
2120 return pwm;
2121}
2122
2123static int frontend_init(struct av7110 *av7110)
2124{
2125 int ret;
2126
2127 if (av7110->dev->pci->subsystem_vendor == 0x110a) {
2128 switch(av7110->dev->pci->subsystem_device) {
2129 case 0x0000:
2130 av7110->fe = dvb_attach(ves1820_attach, &philips_cd1516_config,
2131 &av7110->i2c_adap, read_pwm(av7110));
2132 if (av7110->fe) {
2133 av7110->fe->ops.tuner_ops.set_params = philips_cd1516_tuner_set_params;
2134 }
2135 break;
2136 }
2137
2138 } else if (av7110->dev->pci->subsystem_vendor == 0x13c2) {
2139 switch(av7110->dev->pci->subsystem_device) {
2140 case 0x0000:
2141 case 0x0003:
2142 case 0x1002:
2143
2144
2145 av7110->fe = dvb_attach(ves1x93_attach, &alps_bsrv2_config, &av7110->i2c_adap);
2146 if (av7110->fe) {
2147 av7110->fe->ops.tuner_ops.set_params = alps_bsrv2_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;
2153 }
2154
2155
2156 av7110->fe = dvb_attach(stv0299_attach, &alps_bsru6_config, &av7110->i2c_adap);
2157 if (av7110->fe) {
2158 av7110->fe->ops.tuner_ops.set_params = alps_bsru6_tuner_set_params;
2159 av7110->fe->tuner_priv = &av7110->i2c_adap;
2160
2161 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2162 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2163 av7110->fe->ops.set_tone = av7110_set_tone;
2164 av7110->recover = dvb_s_recover;
2165 break;
2166 }
2167
2168
2169 av7110->fe = dvb_attach(tda8083_attach, &grundig_29504_451_config, &av7110->i2c_adap);
2170 if (av7110->fe) {
2171 av7110->fe->ops.tuner_ops.set_params = grundig_29504_451_tuner_set_params;
2172 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2173 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2174 av7110->fe->ops.set_tone = av7110_set_tone;
2175 av7110->recover = dvb_s_recover;
2176 break;
2177 }
2178
2179
2180 switch(av7110->dev->pci->subsystem_device) {
2181 case 0x0000:
2182
2183 av7110->fe = dvb_attach(ves1820_attach, &philips_cd1516_config, &av7110->i2c_adap,
2184 read_pwm(av7110));
2185 if (av7110->fe) {
2186 av7110->fe->ops.tuner_ops.set_params = philips_cd1516_tuner_set_params;
2187 }
2188 break;
2189 case 0x0003:
2190
2191 av7110->fe = dvb_attach(ves1820_attach, &alps_tdbe2_config, &av7110->i2c_adap,
2192 read_pwm(av7110));
2193 if (av7110->fe) {
2194 av7110->fe->ops.tuner_ops.set_params = alps_tdbe2_tuner_set_params;
2195 }
2196 break;
2197 }
2198 break;
2199
2200 case 0x0001:
2201 {
2202 struct dvb_frontend *fe;
2203
2204
2205 fe = dvb_attach(sp8870_attach, &alps_tdlb7_config, &av7110->i2c_adap);
2206 if (fe) {
2207 fe->ops.tuner_ops.set_params = alps_tdlb7_tuner_set_params;
2208 av7110->fe = fe;
2209 break;
2210 }
2211 }
2212
2213
2214 case 0x0008:
2215
2216 av7110->fe = dvb_attach(l64781_attach, &grundig_29504_401_config, &av7110->i2c_adap);
2217 if (av7110->fe)
2218 av7110->fe->ops.tuner_ops.set_params = grundig_29504_401_tuner_set_params;
2219 break;
2220
2221 case 0x0002:
2222
2223 av7110->fe = dvb_attach(ves1820_attach, &alps_tdbe2_config, &av7110->i2c_adap, read_pwm(av7110));
2224 if (av7110->fe) {
2225 av7110->fe->ops.tuner_ops.set_params = alps_tdbe2_tuner_set_params;
2226 }
2227 break;
2228
2229 case 0x0004:
2230
2231 av7110->fe = dvb_attach(ves1x93_attach, &alps_bsrv2_config, &av7110->i2c_adap);
2232 if (av7110->fe) {
2233 av7110->fe->ops.tuner_ops.set_params = alps_bsrv2_tuner_set_params;
2234 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2235 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2236 av7110->fe->ops.set_tone = av7110_set_tone;
2237 av7110->recover = dvb_s_recover;
2238 }
2239 break;
2240
2241 case 0x0006:
2242
2243 av7110->fe = dvb_attach(tda8083_attach, &grundig_29504_451_config, &av7110->i2c_adap);
2244 if (av7110->fe) {
2245 av7110->fe->ops.tuner_ops.set_params = grundig_29504_451_tuner_set_params;
2246 av7110->fe->ops.diseqc_send_master_cmd = av7110_diseqc_send_master_cmd;
2247 av7110->fe->ops.diseqc_send_burst = av7110_diseqc_send_burst;
2248 av7110->fe->ops.set_tone = av7110_set_tone;
2249 av7110->recover = dvb_s_recover;
2250 }
2251 break;
2252
2253 case 0x000A:
2254
2255 av7110->fe = dvb_attach(stv0297_attach, &nexusca_stv0297_config, &av7110->i2c_adap);
2256 if (av7110->fe) {
2257 av7110->fe->ops.tuner_ops.set_params = nexusca_stv0297_tuner_set_params;
2258
2259
2260 saa7146_setgpio(av7110->dev, 1, SAA7146_GPIO_OUTLO);
2261 saa7146_setgpio(av7110->dev, 3, SAA7146_GPIO_OUTLO);
2262
2263
2264 av7110->dev->i2c_bitrate = SAA7146_I2C_BUS_BIT_RATE_240;
2265 break;
2266 }
2267 break;
2268
2269 case 0x000E:
2270
2271 av7110->fe = dvb_attach(stv0299_attach, &alps_bsbe1_config, &av7110->i2c_adap);
2272 if (av7110->fe) {
2273 av7110->fe->ops.tuner_ops.set_params = alps_bsbe1_tuner_set_params;
2274 av7110->fe->tuner_priv = &av7110->i2c_adap;
2275
2276 if (dvb_attach(lnbp21_attach, av7110->fe, &av7110->i2c_adap, 0, 0) == NULL) {
2277 printk("dvb-ttpci: LNBP21 not found!\n");
2278 if (av7110->fe->ops.release)
2279 av7110->fe->ops.release(av7110->fe);
2280 av7110->fe = NULL;
2281 } else {
2282 av7110->fe->ops.dishnetwork_send_legacy_command = NULL;
2283 av7110->recover = dvb_s_recover;
2284 }
2285 }
2286 break;
2287 }
2288 }
2289
2290 if (!av7110->fe) {
2291
2292 ret = -ENOMEM;
2293 printk("dvb-ttpci: A frontend driver was not found for device [%04x:%04x] subsystem [%04x:%04x]\n",
2294 av7110->dev->pci->vendor,
2295 av7110->dev->pci->device,
2296 av7110->dev->pci->subsystem_vendor,
2297 av7110->dev->pci->subsystem_device);
2298 } else {
2299 FE_FUNC_OVERRIDE(av7110->fe->ops.init, av7110->fe_init, av7110_fe_init);
2300 FE_FUNC_OVERRIDE(av7110->fe->ops.read_status, av7110->fe_read_status, av7110_fe_read_status);
2301 FE_FUNC_OVERRIDE(av7110->fe->ops.diseqc_reset_overload, av7110->fe_diseqc_reset_overload, av7110_fe_diseqc_reset_overload);
2302 FE_FUNC_OVERRIDE(av7110->fe->ops.diseqc_send_master_cmd, av7110->fe_diseqc_send_master_cmd, av7110_fe_diseqc_send_master_cmd);
2303 FE_FUNC_OVERRIDE(av7110->fe->ops.diseqc_send_burst, av7110->fe_diseqc_send_burst, av7110_fe_diseqc_send_burst);
2304 FE_FUNC_OVERRIDE(av7110->fe->ops.set_tone, av7110->fe_set_tone, av7110_fe_set_tone);
2305 FE_FUNC_OVERRIDE(av7110->fe->ops.set_voltage, av7110->fe_set_voltage, av7110_fe_set_voltage);
2306 FE_FUNC_OVERRIDE(av7110->fe->ops.dishnetwork_send_legacy_command, av7110->fe_dishnetwork_send_legacy_command, av7110_fe_dishnetwork_send_legacy_command);
2307 FE_FUNC_OVERRIDE(av7110->fe->ops.set_frontend, av7110->fe_set_frontend, av7110_fe_set_frontend);
2308
2309 ret = dvb_register_frontend(&av7110->dvb_adapter, av7110->fe);
2310 if (ret < 0) {
2311 printk("av7110: Frontend registration failed!\n");
2312 dvb_frontend_detach(av7110->fe);
2313 av7110->fe = NULL;
2314 }
2315 }
2316 return ret;
2317}
2318
2319
2320
2321
2322
2323
2324
2325
2326
2327
2328
2329
2330
2331
2332
2333
2334
2335
2336
2337
2338
2339
2340
2341
2342
2343
2344
2345
2346
2347
2348
2349
2350
2351
2352
2353
2354
2355
2356
2357
2358
2359
2360
2361
2362
2363
2364
2365
2366
2367
2368
2369
2370
2371
2372
2373
2374
2375
2376
2377
2378
2379static int av7110_attach(struct saa7146_dev* dev,
2380 struct saa7146_pci_extension_data *pci_ext)
2381{
2382 const int length = TS_WIDTH * TS_HEIGHT;
2383 struct pci_dev *pdev = dev->pci;
2384 struct av7110 *av7110;
2385 struct task_struct *thread;
2386 int ret, count = 0;
2387
2388 dprintk(4, "dev: %p\n", dev);
2389
2390
2391
2392
2393#define RPS_IRQ 0
2394
2395 if (budgetpatch == 1) {
2396 budgetpatch = 0;
2397
2398
2399
2400
2401
2402
2403
2404
2405
2406
2407
2408
2409 saa7146_write(dev, MC1, MASK_31);
2410
2411
2412
2413 saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO);
2414
2415 saa7146_write(dev, DD1_STREAM_B, 0);
2416
2417 saa7146_write(dev, DD1_INIT, 0x00000200);
2418 saa7146_write(dev, BRS_CTRL, 0x00000000);
2419 saa7146_write(dev, MC2,
2420 1 * (MASK_08 | MASK_24) |
2421 0 * (MASK_09 | MASK_25) |
2422 1 * (MASK_10 | MASK_26) |
2423 0 * (MASK_06 | MASK_22) |
2424 0 * (MASK_05 | MASK_21) |
2425 0 * (MASK_01 | MASK_15)
2426 );
2427
2428
2429 count = 0;
2430
2431 saa7146_write(dev, MC1, MASK_29);
2432
2433 saa7146_write(dev, RPS_TOV1, 0);
2434 WRITE_RPS1(CMD_PAUSE | EVT_VBI_B);
2435 WRITE_RPS1(CMD_WR_REG_MASK | (GPIO_CTRL>>2));
2436 WRITE_RPS1(GPIO3_MSK);
2437 WRITE_RPS1(SAA7146_GPIO_OUTLO<<24);
2438#if RPS_IRQ
2439
2440 WRITE_RPS1(CMD_INTERRUPT);
2441#endif
2442 WRITE_RPS1(CMD_STOP);
2443
2444 WRITE_RPS1(CMD_JUMP);
2445 WRITE_RPS1(dev->d_rps1.dma_handle);
2446
2447#if RPS_IRQ
2448
2449
2450
2451
2452 saa7146_write(dev, EC1SSR, (0x03<<2) | 3 );
2453
2454 saa7146_write(dev, ECT1R, 0x3fff );
2455#endif
2456
2457 saa7146_write(dev, RPS_ADDR1, dev->d_rps1.dma_handle);
2458
2459 saa7146_write(dev, MC1, (MASK_13 | MASK_29 ));
2460
2461 mdelay(10);
2462
2463 saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTHI);
2464 mdelay(10);
2465
2466
2467
2468 if ((saa7146_read(dev, GPIO_CTRL) & 0x10000000) == 0) {
2469 budgetpatch = 1;
2470 printk("dvb-ttpci: BUDGET-PATCH DETECTED.\n");
2471 }
2472
2473 saa7146_write(dev, MC1, ( MASK_29 ));
2474#if RPS_IRQ
2475 printk("dvb-ttpci: Event Counter 1 0x%04x\n", saa7146_read(dev, EC1R) & 0x3fff );
2476#endif
2477 }
2478
2479
2480 av7110 = kzalloc(sizeof(struct av7110), GFP_KERNEL);
2481 if (!av7110) {
2482 dprintk(1, "out of memory\n");
2483 return -ENOMEM;
2484 }
2485
2486 av7110->card_name = (char*) pci_ext->ext_priv;
2487 av7110->dev = dev;
2488 dev->ext_priv = av7110;
2489
2490 ret = get_firmware(av7110);
2491 if (ret < 0)
2492 goto err_kfree_0;
2493
2494 ret = dvb_register_adapter(&av7110->dvb_adapter, av7110->card_name,
2495 THIS_MODULE, &dev->pci->dev, adapter_nr);
2496 if (ret < 0)
2497 goto err_put_firmware_1;
2498
2499
2500
2501 saa7146_write(dev, GPIO_CTRL, 0x500000);
2502
2503 strlcpy(av7110->i2c_adap.name, pci_ext->ext_priv, sizeof(av7110->i2c_adap.name));
2504
2505 saa7146_i2c_adapter_prepare(dev, &av7110->i2c_adap, SAA7146_I2C_BUS_BIT_RATE_120);
2506
2507 ret = i2c_add_adapter(&av7110->i2c_adap);
2508 if (ret < 0)
2509 goto err_dvb_unregister_adapter_2;
2510
2511 ttpci_eeprom_parse_mac(&av7110->i2c_adap,
2512 av7110->dvb_adapter.proposed_mac);
2513 ret = -ENOMEM;
2514
2515
2516 if (full_ts)
2517 av7110->full_ts = true;
2518
2519
2520 if (i2c_readreg(av7110, 0xaa, 0) == 0x4f && i2c_readreg(av7110, 0xaa, 1) == 0x45) {
2521 u8 flags = i2c_readreg(av7110, 0xaa, 2);
2522 if (flags != 0xff && (flags & 0x01))
2523 av7110->full_ts = true;
2524 }
2525
2526 if (av7110->full_ts) {
2527 printk(KERN_INFO "dvb-ttpci: full-ts mode enabled for saa7146 port B\n");
2528 spin_lock_init(&av7110->feedlock1);
2529 av7110->grabbing = saa7146_vmalloc_build_pgtable(pdev, length,
2530 &av7110->pt);
2531 if (!av7110->grabbing)
2532 goto err_i2c_del_3;
2533
2534 saa7146_write(dev, DD1_STREAM_B, 0x00000000);
2535 saa7146_write(dev, MC2, (MASK_10 | MASK_26));
2536
2537 saa7146_write(dev, DD1_INIT, 0x00000600);
2538 saa7146_write(dev, MC2, (MASK_09 | MASK_25 | MASK_10 | MASK_26));
2539
2540 saa7146_write(dev, BRS_CTRL, 0x60000000);
2541 saa7146_write(dev, MC2, MASK_08 | MASK_24);
2542
2543
2544 saa7146_write(dev, PCI_BT_V1, 0x001c0000 | (saa7146_read(dev, PCI_BT_V1) & ~0x001f0000));
2545 saa7146_write(dev, BASE_ODD3, 0);
2546 saa7146_write(dev, BASE_EVEN3, 0);
2547 saa7146_write(dev, PROT_ADDR3, TS_WIDTH * TS_HEIGHT);
2548 saa7146_write(dev, PITCH3, TS_WIDTH);
2549 saa7146_write(dev, BASE_PAGE3, av7110->pt.dma | ME1 | 0x90);
2550 saa7146_write(dev, NUM_LINE_BYTE3, (TS_HEIGHT << 16) | TS_WIDTH);
2551 saa7146_write(dev, MC2, MASK_04 | MASK_20);
2552
2553 tasklet_init(&av7110->vpe_tasklet, vpeirq, (unsigned long) av7110);
2554
2555 } else if (budgetpatch) {
2556 spin_lock_init(&av7110->feedlock1);
2557 av7110->grabbing = saa7146_vmalloc_build_pgtable(pdev, length,
2558 &av7110->pt);
2559 if (!av7110->grabbing)
2560 goto err_i2c_del_3;
2561
2562 saa7146_write(dev, PCI_BT_V1, 0x1c1f101f);
2563 saa7146_write(dev, BCS_CTRL, 0x80400040);
2564
2565 saa7146_write(dev, DD1_STREAM_B, 0x00000000);
2566 saa7146_write(dev, DD1_INIT, 0x03000200);
2567 saa7146_write(dev, MC2, (MASK_09 | MASK_25 | MASK_10 | MASK_26));
2568 saa7146_write(dev, BRS_CTRL, 0x60000000);
2569 saa7146_write(dev, BASE_ODD3, 0);
2570 saa7146_write(dev, BASE_EVEN3, 0);
2571 saa7146_write(dev, PROT_ADDR3, TS_WIDTH * TS_HEIGHT);
2572 saa7146_write(dev, BASE_PAGE3, av7110->pt.dma | ME1 | 0x90);
2573
2574 saa7146_write(dev, PITCH3, TS_WIDTH);
2575 saa7146_write(dev, NUM_LINE_BYTE3, (TS_HEIGHT << 16) | TS_WIDTH);
2576
2577
2578 saa7146_write(dev, MC2, 0x077c077c);
2579 saa7146_write(dev, GPIO_CTRL, 0x000000);
2580#if RPS_IRQ
2581
2582
2583
2584
2585 saa7146_write(dev, EC1SSR, (0x03<<2) | 3 );
2586
2587 saa7146_write(dev, ECT1R, 0x3fff );
2588#endif
2589
2590 count = 0;
2591
2592
2593 WRITE_RPS1(CMD_PAUSE | EVT_HS);
2594
2595 WRITE_RPS1(CMD_WR_REG_MASK | (GPIO_CTRL>>2));
2596 WRITE_RPS1(GPIO3_MSK);
2597 WRITE_RPS1(SAA7146_GPIO_OUTHI<<24);
2598#if RPS_IRQ
2599
2600 WRITE_RPS1(CMD_INTERRUPT);
2601#endif
2602
2603 WRITE_RPS1(CMD_PAUSE | RPS_INV | EVT_HS);
2604
2605 WRITE_RPS1(CMD_WR_REG_MASK | (GPIO_CTRL>>2));
2606 WRITE_RPS1(GPIO3_MSK);
2607 WRITE_RPS1(SAA7146_GPIO_OUTLO<<24);
2608#if RPS_IRQ
2609
2610 WRITE_RPS1(CMD_INTERRUPT);
2611#endif
2612
2613 WRITE_RPS1(CMD_JUMP);
2614 WRITE_RPS1(dev->d_rps1.dma_handle);
2615
2616
2617 saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO);
2618
2619 saa7146_write(dev, RPS_ADDR1, dev->d_rps1.dma_handle);
2620
2621
2622
2623
2624
2625
2626
2627
2628 saa7146_write(dev, RPS_THRESH1, (TS_HEIGHT*1) | MASK_12 );
2629
2630
2631 saa7146_write(dev, MC1, (MASK_13 | MASK_29));
2632
2633
2634 tasklet_init (&av7110->vpe_tasklet, vpeirq, (unsigned long) av7110);
2635 } else {
2636 saa7146_write(dev, PCI_BT_V1, 0x1c00101f);
2637 saa7146_write(dev, BCS_CTRL, 0x80400040);
2638
2639
2640 saa7146_write(dev, DD1_STREAM_B, 0x00000000);
2641 saa7146_write(dev, DD1_INIT, 0x03000000);
2642 saa7146_write(dev, MC2, (MASK_09 | MASK_25 | MASK_10 | MASK_26));
2643
2644
2645 saa7146_write(dev, MC2, 0x077c077c);
2646 saa7146_write(dev, GPIO_CTRL, 0x000000);
2647 }
2648
2649 tasklet_init (&av7110->debi_tasklet, debiirq, (unsigned long) av7110);
2650 tasklet_init (&av7110->gpio_tasklet, gpioirq, (unsigned long) av7110);
2651
2652 mutex_init(&av7110->pid_mutex);
2653
2654
2655 spin_lock_init(&av7110->debilock);
2656 mutex_init(&av7110->dcomlock);
2657 av7110->debitype = -1;
2658
2659
2660 av7110->osdwin = 1;
2661 mutex_init(&av7110->osd_mutex);
2662
2663
2664 av7110->vidmode = tv_standard == 1 ? AV7110_VIDEO_MODE_NTSC
2665 : AV7110_VIDEO_MODE_PAL;
2666
2667
2668 init_waitqueue_head(&av7110->arm_wait);
2669 av7110->arm_thread = NULL;
2670
2671
2672 av7110->debi_virt = pci_alloc_consistent(pdev, 8192, &av7110->debi_bus);
2673 if (!av7110->debi_virt)
2674 goto err_saa71466_vfree_4;
2675
2676
2677 av7110->iobuf = vmalloc(AVOUTLEN+AOUTLEN+BMPLEN+4*IPACKS);
2678 if (!av7110->iobuf)
2679 goto err_pci_free_5;
2680
2681 ret = av7110_av_init(av7110);
2682 if (ret < 0)
2683 goto err_iobuf_vfree_6;
2684
2685
2686 av7110->bmpbuf = av7110->iobuf+AVOUTLEN+AOUTLEN;
2687 init_waitqueue_head(&av7110->bmpq);
2688
2689 ret = av7110_ca_init(av7110);
2690 if (ret < 0)
2691 goto err_av7110_av_exit_7;
2692
2693
2694 ret = av7110_bootarm(av7110);
2695 if (ret < 0)
2696 goto err_av7110_ca_exit_8;
2697
2698 ret = av7110_firmversion(av7110);
2699 if (ret < 0)
2700 goto err_stop_arm_9;
2701
2702 if (FW_VERSION(av7110->arm_app)<0x2501)
2703 printk ("dvb-ttpci: Warning, firmware version 0x%04x is too old. "
2704 "System might be unstable!\n", FW_VERSION(av7110->arm_app));
2705
2706 thread = kthread_run(arm_thread, (void *) av7110, "arm_mon");
2707 if (IS_ERR(thread)) {
2708 ret = PTR_ERR(thread);
2709 goto err_stop_arm_9;
2710 }
2711 av7110->arm_thread = thread;
2712
2713
2714 av7110->mixer.volume_left = volume;
2715 av7110->mixer.volume_right = volume;
2716
2717 ret = av7110_register(av7110);
2718 if (ret < 0)
2719 goto err_arm_thread_stop_10;
2720
2721 init_av7110_av(av7110);
2722
2723
2724
2725
2726 ret = av7110_init_v4l(av7110);
2727 if (ret < 0)
2728 goto err_av7110_unregister_11;
2729
2730 av7110->dvb_adapter.priv = av7110;
2731 ret = frontend_init(av7110);
2732 if (ret < 0)
2733 goto err_av7110_exit_v4l_12;
2734
2735 mutex_init(&av7110->ioctl_mutex);
2736
2737#if IS_ENABLED(CONFIG_DVB_AV7110_IR)
2738 av7110_ir_init(av7110);
2739#endif
2740 printk(KERN_INFO "dvb-ttpci: found av7110-%d.\n", av7110_num);
2741 av7110_num++;
2742out:
2743 return ret;
2744
2745err_av7110_exit_v4l_12:
2746 av7110_exit_v4l(av7110);
2747err_av7110_unregister_11:
2748 dvb_unregister(av7110);
2749err_arm_thread_stop_10:
2750 av7110_arm_sync(av7110);
2751err_stop_arm_9:
2752
2753err_av7110_ca_exit_8:
2754 av7110_ca_exit(av7110);
2755err_av7110_av_exit_7:
2756 av7110_av_exit(av7110);
2757err_iobuf_vfree_6:
2758 vfree(av7110->iobuf);
2759err_pci_free_5:
2760 pci_free_consistent(pdev, 8192, av7110->debi_virt, av7110->debi_bus);
2761err_saa71466_vfree_4:
2762 if (av7110->grabbing)
2763 saa7146_vfree_destroy_pgtable(pdev, av7110->grabbing, &av7110->pt);
2764err_i2c_del_3:
2765 i2c_del_adapter(&av7110->i2c_adap);
2766err_dvb_unregister_adapter_2:
2767 dvb_unregister_adapter(&av7110->dvb_adapter);
2768err_put_firmware_1:
2769 put_firmware(av7110);
2770err_kfree_0:
2771 kfree(av7110);
2772 goto out;
2773}
2774
2775static int av7110_detach(struct saa7146_dev* saa)
2776{
2777 struct av7110 *av7110 = saa->ext_priv;
2778 dprintk(4, "%p\n", av7110);
2779
2780#if IS_ENABLED(CONFIG_DVB_AV7110_IR)
2781 av7110_ir_exit(av7110);
2782#endif
2783 if (budgetpatch || av7110->full_ts) {
2784 if (budgetpatch) {
2785
2786 saa7146_write(saa, MC1, MASK_29);
2787
2788 saa7146_setgpio(saa, 3, SAA7146_GPIO_OUTLO);
2789 }
2790 saa7146_write(saa, MC1, MASK_20);
2791 SAA7146_IER_DISABLE(saa, MASK_10);
2792 SAA7146_ISR_CLEAR(saa, MASK_10);
2793 msleep(50);
2794 tasklet_kill(&av7110->vpe_tasklet);
2795 saa7146_vfree_destroy_pgtable(saa->pci, av7110->grabbing, &av7110->pt);
2796 }
2797 av7110_exit_v4l(av7110);
2798
2799 av7110_arm_sync(av7110);
2800
2801 tasklet_kill(&av7110->debi_tasklet);
2802 tasklet_kill(&av7110->gpio_tasklet);
2803
2804 dvb_unregister(av7110);
2805
2806 SAA7146_IER_DISABLE(saa, MASK_19 | MASK_03);
2807 SAA7146_ISR_CLEAR(saa, MASK_19 | MASK_03);
2808
2809 av7110_ca_exit(av7110);
2810 av7110_av_exit(av7110);
2811
2812 vfree(av7110->iobuf);
2813 pci_free_consistent(saa->pci, 8192, av7110->debi_virt,
2814 av7110->debi_bus);
2815
2816 i2c_del_adapter(&av7110->i2c_adap);
2817
2818 dvb_unregister_adapter (&av7110->dvb_adapter);
2819
2820 av7110_num--;
2821
2822 put_firmware(av7110);
2823
2824 kfree(av7110);
2825
2826 saa->ext_priv = NULL;
2827
2828 return 0;
2829}
2830
2831
2832static void av7110_irq(struct saa7146_dev* dev, u32 *isr)
2833{
2834 struct av7110 *av7110 = dev->ext_priv;
2835
2836
2837
2838
2839
2840
2841
2842 if (*isr & MASK_19) {
2843
2844
2845
2846
2847
2848
2849
2850
2851
2852
2853
2854
2855
2856
2857
2858
2859 SAA7146_IER_DISABLE(av7110->dev, MASK_19);
2860 SAA7146_ISR_CLEAR(av7110->dev, MASK_19);
2861 tasklet_schedule(&av7110->debi_tasklet);
2862 }
2863
2864 if (*isr & MASK_03) {
2865
2866 tasklet_schedule(&av7110->gpio_tasklet);
2867 }
2868
2869 if (*isr & MASK_10)
2870 tasklet_schedule(&av7110->vpe_tasklet);
2871}
2872
2873
2874static struct saa7146_extension av7110_extension_driver;
2875
2876#define MAKE_AV7110_INFO(x_var,x_name) \
2877static struct saa7146_pci_extension_data x_var = { \
2878 .ext_priv = x_name, \
2879 .ext = &av7110_extension_driver }
2880
2881MAKE_AV7110_INFO(tts_1_X_fsc,"Technotrend/Hauppauge WinTV DVB-S rev1.X or Fujitsu Siemens DVB-C");
2882MAKE_AV7110_INFO(ttt_1_X, "Technotrend/Hauppauge WinTV DVB-T rev1.X");
2883MAKE_AV7110_INFO(ttc_1_X, "Technotrend/Hauppauge WinTV Nexus-CA rev1.X");
2884MAKE_AV7110_INFO(ttc_2_X, "Technotrend/Hauppauge WinTV DVB-C rev2.X");
2885MAKE_AV7110_INFO(tts_2_X, "Technotrend/Hauppauge WinTV Nexus-S rev2.X");
2886MAKE_AV7110_INFO(tts_2_3, "Technotrend/Hauppauge WinTV Nexus-S rev2.3");
2887MAKE_AV7110_INFO(tts_1_3se, "Technotrend/Hauppauge WinTV DVB-S rev1.3 SE");
2888MAKE_AV7110_INFO(ttt, "Technotrend/Hauppauge DVB-T");
2889MAKE_AV7110_INFO(fsc, "Fujitsu Siemens DVB-C");
2890MAKE_AV7110_INFO(fss, "Fujitsu Siemens DVB-S rev1.6");
2891MAKE_AV7110_INFO(gxs_1_3, "Galaxis DVB-S rev1.3");
2892
2893static struct pci_device_id pci_tbl[] = {
2894 MAKE_EXTENSION_PCI(fsc, 0x110a, 0x0000),
2895 MAKE_EXTENSION_PCI(tts_1_X_fsc, 0x13c2, 0x0000),
2896 MAKE_EXTENSION_PCI(ttt_1_X, 0x13c2, 0x0001),
2897 MAKE_EXTENSION_PCI(ttc_2_X, 0x13c2, 0x0002),
2898 MAKE_EXTENSION_PCI(tts_2_X, 0x13c2, 0x0003),
2899 MAKE_EXTENSION_PCI(gxs_1_3, 0x13c2, 0x0004),
2900 MAKE_EXTENSION_PCI(fss, 0x13c2, 0x0006),
2901 MAKE_EXTENSION_PCI(ttt, 0x13c2, 0x0008),
2902 MAKE_EXTENSION_PCI(ttc_1_X, 0x13c2, 0x000a),
2903 MAKE_EXTENSION_PCI(tts_2_3, 0x13c2, 0x000e),
2904 MAKE_EXTENSION_PCI(tts_1_3se, 0x13c2, 0x1002),
2905
2906
2907
2908
2909 {
2910 .vendor = 0,
2911 }
2912};
2913
2914MODULE_DEVICE_TABLE(pci, pci_tbl);
2915
2916
2917static struct saa7146_extension av7110_extension_driver = {
2918 .name = "av7110",
2919 .flags = SAA7146_USE_I2C_IRQ,
2920
2921 .module = THIS_MODULE,
2922 .pci_tbl = &pci_tbl[0],
2923 .attach = av7110_attach,
2924 .detach = av7110_detach,
2925
2926 .irq_mask = MASK_19 | MASK_03 | MASK_10,
2927 .irq_func = av7110_irq,
2928};
2929
2930
2931static int __init av7110_init(void)
2932{
2933 int retval;
2934 retval = saa7146_register_extension(&av7110_extension_driver);
2935 return retval;
2936}
2937
2938
2939static void __exit av7110_exit(void)
2940{
2941 saa7146_unregister_extension(&av7110_extension_driver);
2942}
2943
2944module_init(av7110_init);
2945module_exit(av7110_exit);
2946
2947MODULE_DESCRIPTION("driver for the SAA7146 based AV110 PCI DVB cards by "
2948 "Siemens, Technotrend, Hauppauge");
2949MODULE_AUTHOR("Ralph Metzler, Marcus Metzler, others");
2950MODULE_LICENSE("GPL");
2951