diff options
author | Jeff Garzik <jeff@garzik.org> | 2006-04-04 08:41:29 -0400 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2006-04-04 08:41:29 -0400 |
commit | c16226a1c75042bfdc50bd2921d5919f6267ba51 (patch) | |
tree | f7f6081aab45d598fa44b9e588722ed38c299b8e /drivers/media/dvb/ttpci | |
parent | af64371ada9452632c349563d688d30d94e918ba (diff) | |
parent | 6246b6128bbe34d0752f119cf7c5111c85fe481d (diff) |
Merge branch 'master'
Diffstat (limited to 'drivers/media/dvb/ttpci')
-rw-r--r-- | drivers/media/dvb/ttpci/av7110.c | 8 | ||||
-rw-r--r-- | drivers/media/dvb/ttpci/av7110_av.c | 2 | ||||
-rw-r--r-- | drivers/media/dvb/ttpci/budget-av.c | 13 | ||||
-rw-r--r-- | drivers/media/dvb/ttpci/budget-core.c | 78 | ||||
-rw-r--r-- | drivers/media/dvb/ttpci/budget-patch.c | 24 | ||||
-rw-r--r-- | drivers/media/dvb/ttpci/budget.h | 13 |
6 files changed, 97 insertions, 41 deletions
diff --git a/drivers/media/dvb/ttpci/av7110.c b/drivers/media/dvb/ttpci/av7110.c index 840efec32cb6..d028245c8eed 100644 --- a/drivers/media/dvb/ttpci/av7110.c +++ b/drivers/media/dvb/ttpci/av7110.c | |||
@@ -87,6 +87,7 @@ static int volume = 255; | |||
87 | static int budgetpatch; | 87 | static int budgetpatch; |
88 | static int wss_cfg_4_3 = 0x4008; | 88 | static int wss_cfg_4_3 = 0x4008; |
89 | static int wss_cfg_16_9 = 0x0007; | 89 | static int wss_cfg_16_9 = 0x0007; |
90 | static int tv_standard; | ||
90 | 91 | ||
91 | module_param_named(debug, av7110_debug, int, 0644); | 92 | module_param_named(debug, av7110_debug, int, 0644); |
92 | MODULE_PARM_DESC(debug, "debug level (bitmask, default 0)"); | 93 | MODULE_PARM_DESC(debug, "debug level (bitmask, default 0)"); |
@@ -109,6 +110,8 @@ module_param(wss_cfg_4_3, int, 0444); | |||
109 | MODULE_PARM_DESC(wss_cfg_4_3, "WSS 4:3 - default 0x4008 - bit 15: disable, 14: burst mode, 13..0: wss data"); | 110 | MODULE_PARM_DESC(wss_cfg_4_3, "WSS 4:3 - default 0x4008 - bit 15: disable, 14: burst mode, 13..0: wss data"); |
110 | module_param(wss_cfg_16_9, int, 0444); | 111 | module_param(wss_cfg_16_9, int, 0444); |
111 | MODULE_PARM_DESC(wss_cfg_16_9, "WSS 16:9 - default 0x0007 - bit 15: disable, 14: burst mode, 13..0: wss data"); | 112 | MODULE_PARM_DESC(wss_cfg_16_9, "WSS 16:9 - default 0x0007 - bit 15: disable, 14: burst mode, 13..0: wss data"); |
113 | module_param(tv_standard, int, 0444); | ||
114 | MODULE_PARM_DESC(tv_standard, "TV standard: 0 PAL (default), 1 NTSC"); | ||
112 | 115 | ||
113 | static void restart_feeds(struct av7110 *av7110); | 116 | static void restart_feeds(struct av7110 *av7110); |
114 | 117 | ||
@@ -2123,7 +2126,7 @@ static int frontend_init(struct av7110 *av7110) | |||
2123 | read_pwm(av7110)); | 2126 | read_pwm(av7110)); |
2124 | break; | 2127 | break; |
2125 | case 0x0003: | 2128 | case 0x0003: |
2126 | /* Haupauge DVB-C 2.1 VES1820/ALPS TDBE2 */ | 2129 | /* Hauppauge DVB-C 2.1 VES1820/ALPS TDBE2 */ |
2127 | av7110->fe = ves1820_attach(&alps_tdbe2_config, &av7110->i2c_adap, | 2130 | av7110->fe = ves1820_attach(&alps_tdbe2_config, &av7110->i2c_adap, |
2128 | read_pwm(av7110)); | 2131 | read_pwm(av7110)); |
2129 | break; | 2132 | break; |
@@ -2543,6 +2546,9 @@ static int __devinit av7110_attach(struct saa7146_dev* dev, | |||
2543 | av7110->osdwin = 1; | 2546 | av7110->osdwin = 1; |
2544 | mutex_init(&av7110->osd_mutex); | 2547 | mutex_init(&av7110->osd_mutex); |
2545 | 2548 | ||
2549 | /* TV standard */ | ||
2550 | av7110->vidmode = tv_standard == 1 ? VIDEO_MODE_NTSC : VIDEO_MODE_PAL; | ||
2551 | |||
2546 | /* ARM "watchdog" */ | 2552 | /* ARM "watchdog" */ |
2547 | init_waitqueue_head(&av7110->arm_wait); | 2553 | init_waitqueue_head(&av7110->arm_wait); |
2548 | av7110->arm_thread = NULL; | 2554 | av7110->arm_thread = NULL; |
diff --git a/drivers/media/dvb/ttpci/av7110_av.c b/drivers/media/dvb/ttpci/av7110_av.c index 400facec7407..2eff09f638d3 100644 --- a/drivers/media/dvb/ttpci/av7110_av.c +++ b/drivers/media/dvb/ttpci/av7110_av.c | |||
@@ -1479,8 +1479,6 @@ int av7110_av_init(struct av7110 *av7110) | |||
1479 | void (*play[])(u8 *, int, void *) = { play_audio_cb, play_video_cb }; | 1479 | void (*play[])(u8 *, int, void *) = { play_audio_cb, play_video_cb }; |
1480 | int i, ret; | 1480 | int i, ret; |
1481 | 1481 | ||
1482 | av7110->vidmode = VIDEO_MODE_PAL; | ||
1483 | |||
1484 | for (i = 0; i < 2; i++) { | 1482 | for (i = 0; i < 2; i++) { |
1485 | struct ipack *ipack = av7110->ipack + i; | 1483 | struct ipack *ipack = av7110->ipack + i; |
1486 | 1484 | ||
diff --git a/drivers/media/dvb/ttpci/budget-av.c b/drivers/media/dvb/ttpci/budget-av.c index 9dd4745f5312..8efe3ce5f66c 100644 --- a/drivers/media/dvb/ttpci/budget-av.c +++ b/drivers/media/dvb/ttpci/budget-av.c | |||
@@ -60,11 +60,11 @@ struct budget_av { | |||
60 | struct dvb_ca_en50221 ca; | 60 | struct dvb_ca_en50221 ca; |
61 | }; | 61 | }; |
62 | 62 | ||
63 | /* GPIO CI Connections: | 63 | /* GPIO Connections: |
64 | * 0 - Vcc/Reset (Reset is controlled by capacitor) | 64 | * 0 - Vcc/Reset (Reset is controlled by capacitor). Resets the frontend *AS WELL*! |
65 | * 1 - Attribute Memory | 65 | * 1 - CI memory select 0=>IO memory, 1=>Attribute Memory |
66 | * 2 - Card Enable (Active Low) | 66 | * 2 - CI Card Enable (Active Low) |
67 | * 3 - Card Detect | 67 | * 3 - CI Card Detect |
68 | */ | 68 | */ |
69 | 69 | ||
70 | /**************************************************************************** | 70 | /**************************************************************************** |
@@ -214,6 +214,9 @@ static int ciintf_slot_reset(struct dvb_ca_en50221 *ca, int slot) | |||
214 | while (--timeout > 0 && ciintf_read_attribute_mem(ca, slot, 0) != 0x1d) | 214 | while (--timeout > 0 && ciintf_read_attribute_mem(ca, slot, 0) != 0x1d) |
215 | msleep(100); | 215 | msleep(100); |
216 | 216 | ||
217 | /* reinitialise the frontend */ | ||
218 | dvb_frontend_reinitialise(budget_av->budget.dvb_frontend); | ||
219 | |||
217 | if (timeout <= 0) | 220 | if (timeout <= 0) |
218 | { | 221 | { |
219 | printk(KERN_ERR "budget-av: cam reset failed (timeout).\n"); | 222 | printk(KERN_ERR "budget-av: cam reset failed (timeout).\n"); |
diff --git a/drivers/media/dvb/ttpci/budget-core.c b/drivers/media/dvb/ttpci/budget-core.c index 633e68c341c8..ea2066d461fc 100644 --- a/drivers/media/dvb/ttpci/budget-core.c +++ b/drivers/media/dvb/ttpci/budget-core.c | |||
@@ -39,9 +39,21 @@ | |||
39 | #include "budget.h" | 39 | #include "budget.h" |
40 | #include "ttpci-eeprom.h" | 40 | #include "ttpci-eeprom.h" |
41 | 41 | ||
42 | #define TS_WIDTH (2 * TS_SIZE) | ||
43 | #define TS_WIDTH_ACTIVY TS_SIZE | ||
44 | #define TS_HEIGHT_MASK 0xf00 | ||
45 | #define TS_HEIGHT_MASK_ACTIVY 0xc00 | ||
46 | #define TS_MIN_BUFSIZE_K 188 | ||
47 | #define TS_MAX_BUFSIZE_K 1410 | ||
48 | #define TS_MAX_BUFSIZE_K_ACTIVY 564 | ||
49 | #define BUFFER_WARNING_WAIT (30*HZ) | ||
50 | |||
42 | int budget_debug; | 51 | int budget_debug; |
52 | static int dma_buffer_size = TS_MIN_BUFSIZE_K; | ||
43 | module_param_named(debug, budget_debug, int, 0644); | 53 | module_param_named(debug, budget_debug, int, 0644); |
54 | module_param_named(bufsize, dma_buffer_size, int, 0444); | ||
44 | MODULE_PARM_DESC(debug, "Turn on/off budget debugging (default:off)."); | 55 | MODULE_PARM_DESC(debug, "Turn on/off budget debugging (default:off)."); |
56 | MODULE_PARM_DESC(bufsize, "DMA buffer size in KB, default: 188, min: 188, max: 1410 (Activy: 564)"); | ||
45 | 57 | ||
46 | /**************************************************************************** | 58 | /**************************************************************************** |
47 | * TT budget / WinTV Nova | 59 | * TT budget / WinTV Nova |
@@ -70,11 +82,10 @@ static int start_ts_capture(struct budget *budget) | |||
70 | 82 | ||
71 | saa7146_write(dev, MC1, MASK_20); // DMA3 off | 83 | saa7146_write(dev, MC1, MASK_20); // DMA3 off |
72 | 84 | ||
73 | memset(budget->grabbing, 0x00, TS_HEIGHT * TS_WIDTH); | 85 | memset(budget->grabbing, 0x00, budget->buffer_size); |
74 | 86 | ||
75 | saa7146_write(dev, PCI_BT_V1, 0x001c0000 | (saa7146_read(dev, PCI_BT_V1) & ~0x001f0000)); | 87 | saa7146_write(dev, PCI_BT_V1, 0x001c0000 | (saa7146_read(dev, PCI_BT_V1) & ~0x001f0000)); |
76 | 88 | ||
77 | budget->tsf = 0xff; | ||
78 | budget->ttbp = 0; | 89 | budget->ttbp = 0; |
79 | 90 | ||
80 | /* | 91 | /* |
@@ -115,16 +126,12 @@ static int start_ts_capture(struct budget *budget) | |||
115 | 126 | ||
116 | saa7146_write(dev, BASE_ODD3, 0); | 127 | saa7146_write(dev, BASE_ODD3, 0); |
117 | saa7146_write(dev, BASE_EVEN3, 0); | 128 | saa7146_write(dev, BASE_EVEN3, 0); |
118 | saa7146_write(dev, PROT_ADDR3, TS_WIDTH * TS_HEIGHT); | 129 | saa7146_write(dev, PROT_ADDR3, budget->buffer_size); |
119 | saa7146_write(dev, BASE_PAGE3, budget->pt.dma | ME1 | 0x90); | 130 | saa7146_write(dev, BASE_PAGE3, budget->pt.dma | ME1 | 0x90); |
120 | 131 | ||
121 | if (budget->card->type == BUDGET_FS_ACTIVY) { | 132 | saa7146_write(dev, PITCH3, budget->buffer_width); |
122 | saa7146_write(dev, PITCH3, TS_WIDTH / 2); | 133 | saa7146_write(dev, NUM_LINE_BYTE3, |
123 | saa7146_write(dev, NUM_LINE_BYTE3, ((TS_HEIGHT * 2) << 16) | (TS_WIDTH / 2)); | 134 | (budget->buffer_height << 16) | budget->buffer_width); |
124 | } else { | ||
125 | saa7146_write(dev, PITCH3, TS_WIDTH); | ||
126 | saa7146_write(dev, NUM_LINE_BYTE3, (TS_HEIGHT << 16) | TS_WIDTH); | ||
127 | } | ||
128 | 135 | ||
129 | saa7146_write(dev, MC2, (MASK_04 | MASK_20)); | 136 | saa7146_write(dev, MC2, (MASK_04 | MASK_20)); |
130 | 137 | ||
@@ -141,11 +148,12 @@ static void vpeirq(unsigned long data) | |||
141 | u8 *mem = (u8 *) (budget->grabbing); | 148 | u8 *mem = (u8 *) (budget->grabbing); |
142 | u32 olddma = budget->ttbp; | 149 | u32 olddma = budget->ttbp; |
143 | u32 newdma = saa7146_read(budget->dev, PCI_VDP3); | 150 | u32 newdma = saa7146_read(budget->dev, PCI_VDP3); |
151 | u32 count; | ||
144 | 152 | ||
145 | /* nearest lower position divisible by 188 */ | 153 | /* nearest lower position divisible by 188 */ |
146 | newdma -= newdma % 188; | 154 | newdma -= newdma % 188; |
147 | 155 | ||
148 | if (newdma >= TS_BUFLEN) | 156 | if (newdma >= budget->buffer_size) |
149 | return; | 157 | return; |
150 | 158 | ||
151 | budget->ttbp = newdma; | 159 | budget->ttbp = newdma; |
@@ -154,11 +162,24 @@ static void vpeirq(unsigned long data) | |||
154 | return; | 162 | return; |
155 | 163 | ||
156 | if (newdma > olddma) { /* no wraparound, dump olddma..newdma */ | 164 | if (newdma > olddma) { /* no wraparound, dump olddma..newdma */ |
157 | dvb_dmx_swfilter_packets(&budget->demux, mem + olddma, (newdma - olddma) / 188); | 165 | count = newdma - olddma; |
166 | dvb_dmx_swfilter_packets(&budget->demux, mem + olddma, count / 188); | ||
158 | } else { /* wraparound, dump olddma..buflen and 0..newdma */ | 167 | } else { /* wraparound, dump olddma..buflen and 0..newdma */ |
159 | dvb_dmx_swfilter_packets(&budget->demux, mem + olddma, (TS_BUFLEN - olddma) / 188); | 168 | count = budget->buffer_size - olddma; |
169 | dvb_dmx_swfilter_packets(&budget->demux, mem + olddma, count / 188); | ||
170 | count += newdma; | ||
160 | dvb_dmx_swfilter_packets(&budget->demux, mem, newdma / 188); | 171 | dvb_dmx_swfilter_packets(&budget->demux, mem, newdma / 188); |
161 | } | 172 | } |
173 | |||
174 | if (count > budget->buffer_warning_threshold) | ||
175 | budget->buffer_warnings++; | ||
176 | |||
177 | if (budget->buffer_warnings && time_after(jiffies, budget->buffer_warning_time)) { | ||
178 | printk("%s %s: used %d times >80%% of buffer (%u bytes now)\n", | ||
179 | budget->dev->name, __FUNCTION__, budget->buffer_warnings, count); | ||
180 | budget->buffer_warning_time = jiffies + BUFFER_WARNING_WAIT; | ||
181 | budget->buffer_warnings = 0; | ||
182 | } | ||
162 | } | 183 | } |
163 | 184 | ||
164 | 185 | ||
@@ -341,9 +362,10 @@ int ttpci_budget_init(struct budget *budget, struct saa7146_dev *dev, | |||
341 | struct saa7146_pci_extension_data *info, | 362 | struct saa7146_pci_extension_data *info, |
342 | struct module *owner) | 363 | struct module *owner) |
343 | { | 364 | { |
344 | int length = TS_WIDTH * TS_HEIGHT; | ||
345 | int ret = 0; | 365 | int ret = 0; |
346 | struct budget_info *bi = info->ext_priv; | 366 | struct budget_info *bi = info->ext_priv; |
367 | int max_bufsize; | ||
368 | int height_mask; | ||
347 | 369 | ||
348 | memset(budget, 0, sizeof(struct budget)); | 370 | memset(budget, 0, sizeof(struct budget)); |
349 | 371 | ||
@@ -352,6 +374,32 @@ int ttpci_budget_init(struct budget *budget, struct saa7146_dev *dev, | |||
352 | budget->card = bi; | 374 | budget->card = bi; |
353 | budget->dev = (struct saa7146_dev *) dev; | 375 | budget->dev = (struct saa7146_dev *) dev; |
354 | 376 | ||
377 | if (budget->card->type == BUDGET_FS_ACTIVY) { | ||
378 | budget->buffer_width = TS_WIDTH_ACTIVY; | ||
379 | max_bufsize = TS_MAX_BUFSIZE_K_ACTIVY; | ||
380 | height_mask = TS_HEIGHT_MASK_ACTIVY; | ||
381 | } else { | ||
382 | budget->buffer_width = TS_WIDTH; | ||
383 | max_bufsize = TS_MAX_BUFSIZE_K; | ||
384 | height_mask = TS_HEIGHT_MASK; | ||
385 | } | ||
386 | |||
387 | if (dma_buffer_size < TS_MIN_BUFSIZE_K) | ||
388 | dma_buffer_size = TS_MIN_BUFSIZE_K; | ||
389 | else if (dma_buffer_size > max_bufsize) | ||
390 | dma_buffer_size = max_bufsize; | ||
391 | |||
392 | budget->buffer_height = dma_buffer_size * 1024 / budget->buffer_width; | ||
393 | budget->buffer_height &= height_mask; | ||
394 | budget->buffer_size = budget->buffer_height * budget->buffer_width; | ||
395 | budget->buffer_warning_threshold = budget->buffer_size * 80/100; | ||
396 | budget->buffer_warnings = 0; | ||
397 | budget->buffer_warning_time = jiffies; | ||
398 | |||
399 | dprintk(2, "%s: width = %d, height = %d\n", | ||
400 | budget->dev->name, budget->buffer_width, budget->buffer_height); | ||
401 | printk("%s: dma buffer size %u\n", budget->dev->name, budget->buffer_size); | ||
402 | |||
355 | dvb_register_adapter(&budget->dvb_adapter, budget->card->name, owner); | 403 | dvb_register_adapter(&budget->dvb_adapter, budget->card->name, owner); |
356 | 404 | ||
357 | /* set dd1 stream a & b */ | 405 | /* set dd1 stream a & b */ |
@@ -392,7 +440,7 @@ int ttpci_budget_init(struct budget *budget, struct saa7146_dev *dev, | |||
392 | ttpci_eeprom_parse_mac(&budget->i2c_adap, budget->dvb_adapter.proposed_mac); | 440 | ttpci_eeprom_parse_mac(&budget->i2c_adap, budget->dvb_adapter.proposed_mac); |
393 | 441 | ||
394 | if (NULL == | 442 | if (NULL == |
395 | (budget->grabbing = saa7146_vmalloc_build_pgtable(dev->pci, length, &budget->pt))) { | 443 | (budget->grabbing = saa7146_vmalloc_build_pgtable(dev->pci, budget->buffer_size, &budget->pt))) { |
396 | ret = -ENOMEM; | 444 | ret = -ENOMEM; |
397 | goto err; | 445 | goto err; |
398 | } | 446 | } |
diff --git a/drivers/media/dvb/ttpci/budget-patch.c b/drivers/media/dvb/ttpci/budget-patch.c index 9fc9185a8426..1b3aaac5e763 100644 --- a/drivers/media/dvb/ttpci/budget-patch.c +++ b/drivers/media/dvb/ttpci/budget-patch.c | |||
@@ -577,6 +577,17 @@ static int budget_patch_attach (struct saa7146_dev* dev, struct saa7146_pci_exte | |||
577 | saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO); | 577 | saa7146_setgpio(dev, 3, SAA7146_GPIO_OUTLO); |
578 | // Set RPS1 Address register to point to RPS code (r108 p42) | 578 | // Set RPS1 Address register to point to RPS code (r108 p42) |
579 | saa7146_write(dev, RPS_ADDR1, dev->d_rps1.dma_handle); | 579 | saa7146_write(dev, RPS_ADDR1, dev->d_rps1.dma_handle); |
580 | |||
581 | if (!(budget = kmalloc (sizeof(struct budget_patch), GFP_KERNEL))) | ||
582 | return -ENOMEM; | ||
583 | |||
584 | dprintk(2, "budget: %p\n", budget); | ||
585 | |||
586 | if ((err = ttpci_budget_init (budget, dev, info, THIS_MODULE))) { | ||
587 | kfree (budget); | ||
588 | return err; | ||
589 | } | ||
590 | |||
580 | // Set Source Line Counter Threshold, using BRS (rCC p43) | 591 | // Set Source Line Counter Threshold, using BRS (rCC p43) |
581 | // It generates HS event every TS_HEIGHT lines | 592 | // It generates HS event every TS_HEIGHT lines |
582 | // this is related to TS_WIDTH set in register | 593 | // this is related to TS_WIDTH set in register |
@@ -585,24 +596,13 @@ static int budget_patch_attach (struct saa7146_dev* dev, struct saa7146_pci_exte | |||
585 | //,then RPS_THRESH1 | 596 | //,then RPS_THRESH1 |
586 | // should be set to trigger every TS_HEIGHT (512) lines. | 597 | // should be set to trigger every TS_HEIGHT (512) lines. |
587 | // | 598 | // |
588 | saa7146_write(dev, RPS_THRESH1, (TS_HEIGHT*1) | MASK_12 ); | 599 | saa7146_write(dev, RPS_THRESH1, budget->buffer_height | MASK_12 ); |
589 | 600 | ||
590 | // saa7146_write(dev, RPS_THRESH0, ((TS_HEIGHT/2)<<16) |MASK_28| (TS_HEIGHT/2) |MASK_12 ); | 601 | // saa7146_write(dev, RPS_THRESH0, ((TS_HEIGHT/2)<<16) |MASK_28| (TS_HEIGHT/2) |MASK_12 ); |
591 | // Enable RPS1 (rFC p33) | 602 | // Enable RPS1 (rFC p33) |
592 | saa7146_write(dev, MC1, (MASK_13 | MASK_29)); | 603 | saa7146_write(dev, MC1, (MASK_13 | MASK_29)); |
593 | 604 | ||
594 | 605 | ||
595 | if (!(budget = kmalloc (sizeof(struct budget_patch), GFP_KERNEL))) | ||
596 | return -ENOMEM; | ||
597 | |||
598 | dprintk(2, "budget: %p\n", budget); | ||
599 | |||
600 | if ((err = ttpci_budget_init (budget, dev, info, THIS_MODULE))) { | ||
601 | kfree (budget); | ||
602 | return err; | ||
603 | } | ||
604 | |||
605 | |||
606 | dev->ext_priv = budget; | 606 | dev->ext_priv = budget; |
607 | 607 | ||
608 | budget->dvb_adapter.priv = budget; | 608 | budget->dvb_adapter.priv = budget; |
diff --git a/drivers/media/dvb/ttpci/budget.h b/drivers/media/dvb/ttpci/budget.h index 4ac0f4d08025..ecea3a13030e 100644 --- a/drivers/media/dvb/ttpci/budget.h +++ b/drivers/media/dvb/ttpci/budget.h | |||
@@ -58,7 +58,13 @@ struct budget { | |||
58 | int ci_present; | 58 | int ci_present; |
59 | int video_port; | 59 | int video_port; |
60 | 60 | ||
61 | u8 tsf; | 61 | u32 buffer_width; |
62 | u32 buffer_height; | ||
63 | u32 buffer_size; | ||
64 | u32 buffer_warning_threshold; | ||
65 | u32 buffer_warnings; | ||
66 | unsigned long buffer_warning_time; | ||
67 | |||
62 | u32 ttbp; | 68 | u32 ttbp; |
63 | int feeding; | 69 | int feeding; |
64 | 70 | ||
@@ -79,11 +85,6 @@ static struct saa7146_pci_extension_data x_var = { \ | |||
79 | .ext_priv = &x_var ## _info, \ | 85 | .ext_priv = &x_var ## _info, \ |
80 | .ext = &budget_extension }; | 86 | .ext = &budget_extension }; |
81 | 87 | ||
82 | #define TS_WIDTH (376) | ||
83 | #define TS_HEIGHT (512) | ||
84 | #define TS_BUFLEN (TS_WIDTH*TS_HEIGHT) | ||
85 | #define TS_MAX_PACKETS (TS_BUFLEN/TS_SIZE) | ||
86 | |||
87 | #define BUDGET_TT 0 | 88 | #define BUDGET_TT 0 |
88 | #define BUDGET_TT_HW_DISEQC 1 | 89 | #define BUDGET_TT_HW_DISEQC 1 |
89 | #define BUDGET_PATCH 3 | 90 | #define BUDGET_PATCH 3 |