2 * stradis.c - stradis 4:2:2 mpeg decoder driver
4 * Stradis 4:2:2 MPEG-2 Decoder Driver
5 * Copyright (C) 1999 Nathan Laredo <laredo@gnu.org>
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 #include <linux/module.h>
23 #include <linux/delay.h>
24 #include <linux/errno.h>
26 #include <linux/kernel.h>
27 #include <linux/major.h>
28 #include <linux/slab.h>
30 #include <linux/init.h>
31 #include <linux/poll.h>
32 #include <linux/pci.h>
33 #include <linux/signal.h>
35 #include <linux/ioport.h>
36 #include <asm/pgtable.h>
38 #include <linux/sched.h>
39 #include <asm/types.h>
40 #include <linux/types.h>
41 #include <linux/interrupt.h>
42 #include <asm/uaccess.h>
43 #include <linux/vmalloc.h>
44 #include <linux/videodev.h>
47 #include "saa7146reg.h"
52 #define DEBUG(x) /* debug driver */
53 #undef IDEBUG /* debug irq handler */
54 #undef MDEBUG /* debug memory management */
58 static struct saa7146 saa7146s
[SAA7146_MAX
];
60 static int saa_num
= 0; /* number of SAA7146s in use */
62 static int video_nr
= -1;
63 module_param(video_nr
, int, 0);
64 MODULE_LICENSE("GPL");
66 #define nDebNormal 0x00480000
67 #define nDebNoInc 0x00480000
68 #define nDebVideo 0xd0480000
69 #define nDebAudio 0xd0400000
70 #define nDebDMA 0x02c80000
72 #define oDebNormal 0x13c80000
73 #define oDebNoInc 0x13c80000
74 #define oDebVideo 0xd1080000
75 #define oDebAudio 0xd1080000
76 #define oDebDMA 0x03080000
78 #define NewCard (saa->boardcfg[3])
79 #define ChipControl (saa->boardcfg[1])
80 #define NTSCFirstActive (saa->boardcfg[4])
81 #define PALFirstActive (saa->boardcfg[5])
82 #define NTSCLastActive (saa->boardcfg[54])
83 #define PALLastActive (saa->boardcfg[55])
84 #define Have2MB (saa->boardcfg[18] & 0x40)
85 #define HaveCS8420 (saa->boardcfg[18] & 0x04)
86 #define IBMMPEGCD20 (saa->boardcfg[18] & 0x20)
87 #define HaveCS3310 (saa->boardcfg[18] & 0x01)
88 #define CS3310MaxLvl ((saa->boardcfg[30] << 8) | saa->boardcfg[31])
89 #define HaveCS4341 (saa->boardcfg[40] == 2)
90 #define SDIType (saa->boardcfg[27])
91 #define CurrentMode (saa->boardcfg[2])
93 #define debNormal (NewCard ? nDebNormal : oDebNormal)
94 #define debNoInc (NewCard ? nDebNoInc : oDebNoInc)
95 #define debVideo (NewCard ? nDebVideo : oDebVideo)
96 #define debAudio (NewCard ? nDebAudio : oDebAudio)
97 #define debDMA (NewCard ? nDebDMA : oDebDMA)
99 #ifdef USE_RESCUE_EEPROM_SDM275
100 static unsigned char rescue_eeprom
[64] = {
101 0x00, 0x01, 0x04, 0x13, 0x26, 0x0f, 0x10, 0x00, 0x00, 0x00, 0x43, 0x63,
102 0x22, 0x01, 0x29, 0x15, 0x73, 0x00, 0x1f, 'd', 'e', 'c', 'x', 'l',
103 'd', 'v', 'a', 0x02, 0x00, 0x01, 0x00, 0xcc, 0xa4, 0x63, 0x09, 0xe2,
104 0x10, 0x00, 0x0a, 0x00, 0x02, 0x02, 'd', 'e', 'c', 'x', 'l', 'a',
105 0x00, 0x00, 0x42, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
106 0x00, 0x00, 0x00, 0x00,
110 /* ----------------------------------------------------------------------- */
111 /* Hardware I2C functions */
112 static void I2CWipe(struct saa7146
*saa
)
115 /* set i2c to ~=100kHz, abort transfer, clear busy */
116 saawrite(0x600 | SAA7146_I2C_ABORT
, SAA7146_I2C_STATUS
);
117 saawrite((SAA7146_MC2_UPLD_I2C
<< 16) |
118 SAA7146_MC2_UPLD_I2C
, SAA7146_MC2
);
119 /* wait for i2c registers to be programmed */
120 for (i
= 0; i
< 1000 &&
121 !(saaread(SAA7146_MC2
) & SAA7146_MC2_UPLD_I2C
); i
++)
123 saawrite(0x600, SAA7146_I2C_STATUS
);
124 saawrite((SAA7146_MC2_UPLD_I2C
<< 16) |
125 SAA7146_MC2_UPLD_I2C
, SAA7146_MC2
);
126 /* wait for i2c registers to be programmed */
127 for (i
= 0; i
< 1000 &&
128 !(saaread(SAA7146_MC2
) & SAA7146_MC2_UPLD_I2C
); i
++)
130 saawrite(0x600, SAA7146_I2C_STATUS
);
131 saawrite((SAA7146_MC2_UPLD_I2C
<< 16) |
132 SAA7146_MC2_UPLD_I2C
, SAA7146_MC2
);
133 /* wait for i2c registers to be programmed */
134 for (i
= 0; i
< 1000 &&
135 !(saaread(SAA7146_MC2
) & SAA7146_MC2_UPLD_I2C
); i
++)
140 static int I2CRead(struct saa7146
*saa
, unsigned char addr
,
141 unsigned char subaddr
, int dosub
)
145 if (saaread(SAA7146_I2C_STATUS
) & 0x3c)
148 i
< 1000 && (saaread(SAA7146_I2C_STATUS
) & SAA7146_I2C_BUSY
);
154 saawrite(((addr
& 0xfe) << 24) | (((addr
| 1) & 0xff) << 8) |
155 ((subaddr
& 0xff) << 16) | 0xed, SAA7146_I2C_TRANSFER
);
157 saawrite(((addr
& 0xfe) << 24) | (((addr
| 1) & 0xff) << 16) |
158 0xf1, SAA7146_I2C_TRANSFER
);
159 saawrite((SAA7146_MC2_UPLD_I2C
<< 16) |
160 SAA7146_MC2_UPLD_I2C
, SAA7146_MC2
);
161 /* wait for i2c registers to be programmed */
162 for (i
= 0; i
< 1000 &&
163 !(saaread(SAA7146_MC2
) & SAA7146_MC2_UPLD_I2C
); i
++)
165 /* wait for valid data */
166 for (i
= 0; i
< 1000 &&
167 (saaread(SAA7146_I2C_STATUS
) & SAA7146_I2C_BUSY
); i
++)
169 if (saaread(SAA7146_I2C_STATUS
) & SAA7146_I2C_ERR
)
172 printk("i2c setup read timeout\n");
173 saawrite(0x41, SAA7146_I2C_TRANSFER
);
174 saawrite((SAA7146_MC2_UPLD_I2C
<< 16) |
175 SAA7146_MC2_UPLD_I2C
, SAA7146_MC2
);
176 /* wait for i2c registers to be programmed */
177 for (i
= 0; i
< 1000 &&
178 !(saaread(SAA7146_MC2
) & SAA7146_MC2_UPLD_I2C
); i
++)
180 /* wait for valid data */
181 for (i
= 0; i
< 1000 &&
182 (saaread(SAA7146_I2C_TRANSFER
) & SAA7146_I2C_BUSY
); i
++)
184 if (saaread(SAA7146_I2C_TRANSFER
) & SAA7146_I2C_ERR
)
187 printk("i2c read timeout\n");
188 return ((saaread(SAA7146_I2C_TRANSFER
) >> 24) & 0xff);
191 /* set both to write both bytes, reset it to write only b1 */
193 static int I2CWrite(struct saa7146
*saa
, unsigned char addr
, unsigned char b1
,
194 unsigned char b2
, int both
)
199 if (saaread(SAA7146_I2C_STATUS
) & 0x3c)
201 for (i
= 0; i
< 1000 &&
202 (saaread(SAA7146_I2C_STATUS
) & SAA7146_I2C_BUSY
); i
++)
206 data
= ((addr
& 0xfe) << 24) | ((b1
& 0xff) << 16);
208 data
|= ((b2
& 0xff) << 8) | 0xe5;
211 saawrite(data
, SAA7146_I2C_TRANSFER
);
212 saawrite((SAA7146_MC2_UPLD_I2C
<< 16) | SAA7146_MC2_UPLD_I2C
,
217 static void attach_inform(struct saa7146
*saa
, int id
)
221 DEBUG(printk(KERN_DEBUG
"stradis%d: i2c: device found=%02x\n", saa
->nr
,
223 if (id
== 0xa0) { /* we have rev2 or later board, fill in info */
224 for (i
= 0; i
< 64; i
++)
225 saa
->boardcfg
[i
] = I2CRead(saa
, 0xa0, i
, 1);
226 #ifdef USE_RESCUE_EEPROM_SDM275
227 if (saa
->boardcfg
[0] != 0) {
228 printk("stradis%d: WARNING: EEPROM STORED VALUES HAVE "
229 "BEEN IGNORED\n", saa
->nr
);
230 for (i
= 0; i
< 64; i
++)
231 saa
->boardcfg
[i
] = rescue_eeprom
[i
];
234 printk("stradis%d: config =", saa
->nr
);
235 for (i
= 0; i
< 51; i
++) {
236 printk(" %02x", saa
->boardcfg
[i
]);
242 static void I2CBusScan(struct saa7146
*saa
)
245 for (i
= 0; i
< 0xff; i
+= 2)
246 if ((I2CRead(saa
, i
, 0, 0)) >= 0)
247 attach_inform(saa
, i
);
250 static int debiwait_maxwait
= 0;
252 static int wait_for_debi_done(struct saa7146
*saa
)
256 /* wait for registers to be programmed */
257 for (i
= 0; i
< 100000 &&
258 !(saaread(SAA7146_MC2
) & SAA7146_MC2_UPLD_DEBI
); i
++)
259 saaread(SAA7146_MC2
);
260 /* wait for transfer to complete */
261 for (i
= 0; i
< 500000 &&
262 (saaread(SAA7146_PSR
) & SAA7146_PSR_DEBI_S
); i
++)
263 saaread(SAA7146_MC2
);
265 if (i
> debiwait_maxwait
)
266 printk("wait-for-debi-done maxwait: %d\n",
267 debiwait_maxwait
= i
);
275 static int debiwrite(struct saa7146
*saa
, u32 config
, int addr
,
279 if (count
<= 0 || count
> 32764)
281 if (wait_for_debi_done(saa
) < 0)
283 saawrite(config
, SAA7146_DEBI_CONFIG
);
284 if (count
<= 4) /* immediate transfer */
285 saawrite(val
, SAA7146_DEBI_AD
);
286 else /* block transfer */
287 saawrite(virt_to_bus(saa
->dmadebi
), SAA7146_DEBI_AD
);
288 saawrite((cmd
= (count
<< 17) | (addr
& 0xffff)), SAA7146_DEBI_COMMAND
);
289 saawrite((SAA7146_MC2_UPLD_DEBI
<< 16) | SAA7146_MC2_UPLD_DEBI
,
294 static u32
debiread(struct saa7146
*saa
, u32 config
, int addr
, int count
)
298 if (count
> 32764 || count
<= 0)
300 if (wait_for_debi_done(saa
) < 0)
302 saawrite(virt_to_bus(saa
->dmadebi
), SAA7146_DEBI_AD
);
303 saawrite((count
<< 17) | 0x10000 | (addr
& 0xffff),
304 SAA7146_DEBI_COMMAND
);
305 saawrite(config
, SAA7146_DEBI_CONFIG
);
306 saawrite((SAA7146_MC2_UPLD_DEBI
<< 16) | SAA7146_MC2_UPLD_DEBI
,
308 if (count
> 4) /* not an immediate transfer */
310 wait_for_debi_done(saa
);
311 result
= saaread(SAA7146_DEBI_AD
);
321 static void do_irq_send_data(struct saa7146
*saa
)
323 int split
, audbytes
, vidbytes
;
325 saawrite(SAA7146_PSR_PIN1
, SAA7146_IER
);
326 /* if special feature mode in effect, disable audio sending */
327 if (saa
->playmode
!= VID_PLAY_NORMAL
)
328 saa
->audtail
= saa
->audhead
= 0;
329 if (saa
->audhead
<= saa
->audtail
)
330 audbytes
= saa
->audtail
- saa
->audhead
;
332 audbytes
= 65536 - (saa
->audhead
- saa
->audtail
);
333 if (saa
->vidhead
<= saa
->vidtail
)
334 vidbytes
= saa
->vidtail
- saa
->vidhead
;
336 vidbytes
= 524288 - (saa
->vidhead
- saa
->vidtail
);
337 if (audbytes
== 0 && vidbytes
== 0 && saa
->osdtail
== saa
->osdhead
) {
338 saawrite(0, SAA7146_IER
);
341 /* if at least 1 block audio waiting and audio fifo isn't full */
342 if (audbytes
>= 2048 && (debiread(saa
, debNormal
, IBM_MP2_AUD_FIFO
, 2)
344 if (saa
->audhead
> saa
->audtail
)
345 split
= 65536 - saa
->audhead
;
349 if (split
> 0 && split
< 2048) {
350 memcpy(saa
->dmadebi
, saa
->audbuf
+ saa
->audhead
, split
);
355 memcpy(saa
->dmadebi
+ split
, saa
->audbuf
+ saa
->audhead
,
357 saa
->audhead
+= audbytes
;
358 saa
->audhead
&= 0xffff;
359 debiwrite(saa
, debAudio
, (NewCard
? IBM_MP2_AUD_FIFO
:
360 IBM_MP2_AUD_FIFOW
), 0, 2048);
361 wake_up_interruptible(&saa
->audq
);
362 /* if at least 1 block video waiting and video fifo isn't full */
363 } else if (vidbytes
>= 30720 && (debiread(saa
, debNormal
,
364 IBM_MP2_FIFO
, 2)) < 16384) {
365 if (saa
->vidhead
> saa
->vidtail
)
366 split
= 524288 - saa
->vidhead
;
370 if (split
> 0 && split
< 30720) {
371 memcpy(saa
->dmadebi
, saa
->vidbuf
+ saa
->vidhead
, split
);
376 memcpy(saa
->dmadebi
+ split
, saa
->vidbuf
+ saa
->vidhead
,
378 saa
->vidhead
+= vidbytes
;
379 saa
->vidhead
&= 0x7ffff;
380 debiwrite(saa
, debVideo
, (NewCard
? IBM_MP2_FIFO
:
381 IBM_MP2_FIFOW
), 0, 30720);
382 wake_up_interruptible(&saa
->vidq
);
384 saawrite(SAA7146_PSR_DEBI_S
| SAA7146_PSR_PIN1
, SAA7146_IER
);
387 static void send_osd_data(struct saa7146
*saa
)
389 int size
= saa
->osdtail
- saa
->osdhead
;
392 /* ensure some multiple of 8 bytes is transferred */
393 size
= 8 * ((size
+ 8) >> 3);
395 debiwrite(saa
, debNormal
, IBM_MP2_OSD_ADDR
,
396 (saa
->osdhead
>> 3), 2);
397 memcpy(saa
->dmadebi
, &saa
->osdbuf
[saa
->osdhead
], size
);
398 saa
->osdhead
+= size
;
399 /* block transfer of next 8 bytes to ~32k bytes */
400 debiwrite(saa
, debNormal
, IBM_MP2_OSD_DATA
, 0, size
);
402 if (saa
->osdhead
>= saa
->osdtail
) {
403 saa
->osdhead
= saa
->osdtail
= 0;
404 debiwrite(saa
, debNormal
, IBM_MP2_MASK0
, 0xc00c, 2);
408 static irqreturn_t
saa7146_irq(int irq
, void *dev_id
, struct pt_regs
*regs
)
410 struct saa7146
*saa
= dev_id
;
417 /* get/clear interrupt status bits */
418 stat
= saaread(SAA7146_ISR
);
419 astat
= stat
& saaread(SAA7146_IER
);
423 saawrite(astat
, SAA7146_ISR
);
424 if (astat
& SAA7146_PSR_DEBI_S
) {
425 do_irq_send_data(saa
);
427 if (astat
& SAA7146_PSR_PIN1
) {
429 /* the following read will trigger DEBI_S */
430 istat
= debiread(saa
, debNormal
, IBM_MP2_HOST_INT
, 2);
432 saawrite(0, SAA7146_IER
);
434 saawrite(SAA7146_PSR_DEBI_S
|
435 SAA7146_PSR_PIN1
, SAA7146_IER
);
437 if (istat
& 0x20) { /* Video Start */
438 saa
->vidinfo
.frame_count
++;
440 if (istat
& 0x400) { /* Picture Start */
441 /* update temporal reference */
443 if (istat
& 0x200) { /* Picture Resolution Change */
444 /* read new resolution */
446 if (istat
& 0x100) { /* New User Data found */
447 /* read new user data */
449 if (istat
& 0x1000) { /* new GOP/SMPTE */
452 if (istat
& 0x8000) { /* Sequence Start Code */
453 /* reset frame counter, load sizes */
454 saa
->vidinfo
.frame_count
= 0;
455 saa
->vidinfo
.h_size
= 704;
456 saa
->vidinfo
.v_size
= 480;
458 if (saa
->endmarkhead
!= saa
->endmarktail
) {
460 saa
->endmark
[saa
->endmarkhead
];
462 if (saa
->endmarkhead
>= MAX_MARKS
)
463 saa
->endmarkhead
= 0;
467 if (istat
& 0x4000) { /* Sequence Error Code */
468 if (saa
->endmarkhead
!= saa
->endmarktail
) {
470 saa
->endmark
[saa
->endmarkhead
];
472 if (saa
->endmarkhead
>= MAX_MARKS
)
473 saa
->endmarkhead
= 0;
478 if (astat
& SAA7146_PSR_PPEF
) {
479 IDEBUG(printk("stradis%d irq: PPEF\n", saa
->nr
));
481 if (astat
& SAA7146_PSR_PABO
) {
482 IDEBUG(printk("stradis%d irq: PABO\n", saa
->nr
));
484 if (astat
& SAA7146_PSR_PPED
) {
485 IDEBUG(printk("stradis%d irq: PPED\n", saa
->nr
));
487 if (astat
& SAA7146_PSR_RPS_I1
) {
488 IDEBUG(printk("stradis%d irq: RPS_I1\n", saa
->nr
));
490 if (astat
& SAA7146_PSR_RPS_I0
) {
491 IDEBUG(printk("stradis%d irq: RPS_I0\n", saa
->nr
));
493 if (astat
& SAA7146_PSR_RPS_LATE1
) {
494 IDEBUG(printk("stradis%d irq: RPS_LATE1\n", saa
->nr
));
496 if (astat
& SAA7146_PSR_RPS_LATE0
) {
497 IDEBUG(printk("stradis%d irq: RPS_LATE0\n", saa
->nr
));
499 if (astat
& SAA7146_PSR_RPS_E1
) {
500 IDEBUG(printk("stradis%d irq: RPS_E1\n", saa
->nr
));
502 if (astat
& SAA7146_PSR_RPS_E0
) {
503 IDEBUG(printk("stradis%d irq: RPS_E0\n", saa
->nr
));
505 if (astat
& SAA7146_PSR_RPS_TO1
) {
506 IDEBUG(printk("stradis%d irq: RPS_TO1\n", saa
->nr
));
508 if (astat
& SAA7146_PSR_RPS_TO0
) {
509 IDEBUG(printk("stradis%d irq: RPS_TO0\n", saa
->nr
));
511 if (astat
& SAA7146_PSR_UPLD
) {
512 IDEBUG(printk("stradis%d irq: UPLD\n", saa
->nr
));
514 if (astat
& SAA7146_PSR_DEBI_E
) {
515 IDEBUG(printk("stradis%d irq: DEBI_E\n", saa
->nr
));
517 if (astat
& SAA7146_PSR_I2C_S
) {
518 IDEBUG(printk("stradis%d irq: I2C_S\n", saa
->nr
));
520 if (astat
& SAA7146_PSR_I2C_E
) {
521 IDEBUG(printk("stradis%d irq: I2C_E\n", saa
->nr
));
523 if (astat
& SAA7146_PSR_A2_IN
) {
524 IDEBUG(printk("stradis%d irq: A2_IN\n", saa
->nr
));
526 if (astat
& SAA7146_PSR_A2_OUT
) {
527 IDEBUG(printk("stradis%d irq: A2_OUT\n", saa
->nr
));
529 if (astat
& SAA7146_PSR_A1_IN
) {
530 IDEBUG(printk("stradis%d irq: A1_IN\n", saa
->nr
));
532 if (astat
& SAA7146_PSR_A1_OUT
) {
533 IDEBUG(printk("stradis%d irq: A1_OUT\n", saa
->nr
));
535 if (astat
& SAA7146_PSR_AFOU
) {
536 IDEBUG(printk("stradis%d irq: AFOU\n", saa
->nr
));
538 if (astat
& SAA7146_PSR_V_PE
) {
539 IDEBUG(printk("stradis%d irq: V_PE\n", saa
->nr
));
541 if (astat
& SAA7146_PSR_VFOU
) {
542 IDEBUG(printk("stradis%d irq: VFOU\n", saa
->nr
));
544 if (astat
& SAA7146_PSR_FIDA
) {
545 IDEBUG(printk("stradis%d irq: FIDA\n", saa
->nr
));
547 if (astat
& SAA7146_PSR_FIDB
) {
548 IDEBUG(printk("stradis%d irq: FIDB\n", saa
->nr
));
550 if (astat
& SAA7146_PSR_PIN3
) {
551 IDEBUG(printk("stradis%d irq: PIN3\n", saa
->nr
));
553 if (astat
& SAA7146_PSR_PIN2
) {
554 IDEBUG(printk("stradis%d irq: PIN2\n", saa
->nr
));
556 if (astat
& SAA7146_PSR_PIN0
) {
557 IDEBUG(printk("stradis%d irq: PIN0\n", saa
->nr
));
559 if (astat
& SAA7146_PSR_ECS
) {
560 IDEBUG(printk("stradis%d irq: ECS\n", saa
->nr
));
562 if (astat
& SAA7146_PSR_EC3S
) {
563 IDEBUG(printk("stradis%d irq: EC3S\n", saa
->nr
));
565 if (astat
& SAA7146_PSR_EC0S
) {
566 IDEBUG(printk("stradis%d irq: EC0S\n", saa
->nr
));
571 printk(KERN_WARNING
"stradis%d: irq loop %d\n",
574 saawrite(0, SAA7146_IER
);
576 "stradis%d: IRQ loop cleared\n", saa
->nr
);
579 return IRQ_RETVAL(handled
);
582 static int ibm_send_command(struct saa7146
*saa
,
583 int command
, int data
, int chain
)
588 debiwrite(saa
, debNormal
, IBM_MP2_COMMAND
, (command
<< 1)| 1,2);
590 debiwrite(saa
, debNormal
, IBM_MP2_COMMAND
, command
<< 1, 2);
591 debiwrite(saa
, debNormal
, IBM_MP2_CMD_DATA
, data
, 2);
592 debiwrite(saa
, debNormal
, IBM_MP2_CMD_STAT
, 1, 2);
593 for (i
= 0; i
< 100 &&
594 (debiread(saa
, debNormal
, IBM_MP2_CMD_STAT
, 2) & 1); i
++)
601 static void cs4341_setlevel(struct saa7146
*saa
, int left
, int right
)
603 I2CWrite(saa
, 0x22, 0x03, left
> 94 ? 94 : left
, 2);
604 I2CWrite(saa
, 0x22, 0x04, right
> 94 ? 94 : right
, 2);
607 static void initialize_cs4341(struct saa7146
*saa
)
610 for (i
= 0; i
< 200; i
++) {
611 /* auto mute off, power on, no de-emphasis */
612 /* I2S data up to 24-bit 64xFs internal SCLK */
613 I2CWrite(saa
, 0x22, 0x01, 0x11, 2);
614 /* ATAPI mixer settings */
615 I2CWrite(saa
, 0x22, 0x02, 0x49, 2);
616 /* attenuation left 3db */
617 I2CWrite(saa
, 0x22, 0x03, 0x00, 2);
618 /* attenuation right 3db */
619 I2CWrite(saa
, 0x22, 0x04, 0x00, 2);
620 I2CWrite(saa
, 0x22, 0x01, 0x10, 2);
621 if (I2CRead(saa
, 0x22, 0x02, 1) == 0x49)
625 printk("stradis%d: CS4341 initialized (%d)\n", saa
->nr
, i
);
629 static void initialize_cs8420(struct saa7146
*saa
, int pro
)
634 sequence
= mode8420pro
;
636 sequence
= mode8420con
;
637 for (i
= 0; i
< INIT8420LEN
; i
++)
638 I2CWrite(saa
, 0x20, init8420
[i
* 2], init8420
[i
* 2 + 1], 2);
639 for (i
= 0; i
< MODE8420LEN
; i
++)
640 I2CWrite(saa
, 0x20, sequence
[i
* 2], sequence
[i
* 2 + 1], 2);
641 printk("stradis%d: CS8420 initialized\n", saa
->nr
);
644 static void initialize_saa7121(struct saa7146
*saa
, int dopal
)
649 sequence
= init7121pal
;
651 sequence
= init7121ntsc
;
652 mod
= saaread(SAA7146_PSR
) & 0x08;
653 /* initialize PAL/NTSC video encoder */
654 for (i
= 0; i
< INIT7121LEN
; i
++) {
655 if (NewCard
) { /* handle new card encoder differences */
656 if (sequence
[i
* 2] == 0x3a)
657 I2CWrite(saa
, 0x88, 0x3a, 0x13, 2);
658 else if (sequence
[i
* 2] == 0x6b)
659 I2CWrite(saa
, 0x88, 0x6b, 0x20, 2);
660 else if (sequence
[i
* 2] == 0x6c)
661 I2CWrite(saa
, 0x88, 0x6c,
662 dopal
? 0x09 : 0xf5, 2);
663 else if (sequence
[i
* 2] == 0x6d)
664 I2CWrite(saa
, 0x88, 0x6d,
665 dopal
? 0x20 : 0x00, 2);
666 else if (sequence
[i
* 2] == 0x7a)
667 I2CWrite(saa
, 0x88, 0x7a,
668 dopal
? (PALFirstActive
- 1) :
669 (NTSCFirstActive
- 4), 2);
670 else if (sequence
[i
* 2] == 0x7b)
671 I2CWrite(saa
, 0x88, 0x7b,
672 dopal
? PALLastActive
:
675 I2CWrite(saa
, 0x88, sequence
[i
* 2],
676 sequence
[i
* 2 + 1], 2);
678 if (sequence
[i
* 2] == 0x6b && mod
)
679 I2CWrite(saa
, 0x88, 0x6b,
680 (sequence
[i
* 2 + 1] ^ 0x09), 2);
681 else if (sequence
[i
* 2] == 0x7a)
682 I2CWrite(saa
, 0x88, 0x7a,
683 dopal
? (PALFirstActive
- 1) :
684 (NTSCFirstActive
- 4), 2);
685 else if (sequence
[i
* 2] == 0x7b)
686 I2CWrite(saa
, 0x88, 0x7b,
687 dopal
? PALLastActive
:
690 I2CWrite(saa
, 0x88, sequence
[i
* 2],
691 sequence
[i
* 2 + 1], 2);
696 static void set_genlock_offset(struct saa7146
*saa
, int noffset
)
699 int PixelsPerLine
= 858;
700 if (CurrentMode
== VIDEO_MODE_PAL
)
704 else if (noffset
< -500)
706 nCode
= noffset
+ 0x100;
710 nCode
= 0x400 + PixelsPerLine
+ nCode
;
711 debiwrite(saa
, debNormal
, XILINX_GLDELAY
, nCode
, 2);
714 static void set_out_format(struct saa7146
*saa
, int mode
)
716 initialize_saa7121(saa
, (mode
== VIDEO_MODE_NTSC
? 0 : 1));
717 saa
->boardcfg
[2] = mode
;
718 /* do not adjust analog video parameters here, use saa7121 init */
719 /* you will affect the SDI output on the new card */
720 if (mode
== VIDEO_MODE_PAL
) { /* PAL */
721 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x0808, 2);
723 saawrite(0x012002c0, SAA7146_NUM_LINE_BYTE1
);
725 debiwrite(saa
, debNormal
, IBM_MP2_DISP_MODE
, 0xe100, 2);
728 debiwrite(saa
, debNormal
, IBM_MP2_DISP_MODE
,
729 NewCard
? 0xe500 : 0x6500, 2);
730 debiwrite(saa
, debNormal
, IBM_MP2_DISP_DLY
,
732 (NewCard
? PALFirstActive
: PALFirstActive
- 6), 2);
734 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x0800, 2);
736 saawrite(0x00f002c0, SAA7146_NUM_LINE_BYTE1
);
737 debiwrite(saa
, debNormal
, IBM_MP2_DISP_MODE
,
738 NewCard
? 0xe100 : 0x6100, 2);
739 debiwrite(saa
, debNormal
, IBM_MP2_DISP_DLY
,
741 (NewCard
? NTSCFirstActive
: NTSCFirstActive
- 6), 2);
745 /* Intialize bitmangler to map from a byte value to the mangled word that
746 * must be output to program the Xilinx part through the DEBI port.
747 * Xilinx Data Bit->DEBI Bit: 0->15 1->7 2->6 3->12 4->11 5->2 6->1 7->0
748 * transfer FPGA code, init IBM chip, transfer IBM microcode
749 * rev2 card mangles: 0->7 1->6 2->5 3->4 4->3 5->2 6->1 7->0
751 static u16 bitmangler
[256];
753 static int initialize_fpga(struct video_code
*bitdata
)
755 int i
, num
, startindex
, failure
= 0, loadtwo
, loadfile
= 0;
760 /* verify fpga code */
761 for (startindex
= 0; startindex
< bitdata
->datasize
; startindex
++)
762 if (bitdata
->data
[startindex
] == 255)
764 if (startindex
== bitdata
->datasize
) {
765 printk(KERN_INFO
"stradis: bad fpga code\n");
768 /* initialize all detected cards */
769 for (num
= 0; num
< saa_num
; num
++) {
770 saa
= &saa7146s
[num
];
771 if (saa
->boardcfg
[0] > 20)
772 continue; /* card was programmed */
773 loadtwo
= (saa
->boardcfg
[18] & 0x10);
774 if (!NewCard
) /* we have an old board */
775 for (i
= 0; i
< 256; i
++)
776 bitmangler
[i
] = ((i
& 0x01) << 15) |
777 ((i
& 0x02) << 6) | ((i
& 0x04) << 4) |
778 ((i
& 0x08) << 9) | ((i
& 0x10) << 7) |
779 ((i
& 0x20) >> 3) | ((i
& 0x40) >> 5) |
781 else /* else we have a new board */
782 for (i
= 0; i
< 256; i
++)
783 bitmangler
[i
] = ((i
& 0x01) << 7) |
784 ((i
& 0x02) << 5) | ((i
& 0x04) << 3) |
785 ((i
& 0x08) << 1) | ((i
& 0x10) >> 1) |
786 ((i
& 0x20) >> 3) | ((i
& 0x40) >> 5) |
789 dmabuf
= (u16
*) saa
->dmadebi
;
790 newdma
= (u8
*) saa
->dmadebi
;
791 if (NewCard
) { /* SDM2xxx */
792 if (!strncmp(bitdata
->loadwhat
, "decoder2", 8))
793 continue; /* fpga not for this card */
794 if (!strncmp(&saa
->boardcfg
[42], bitdata
->loadwhat
, 8))
796 else if (loadtwo
&& !strncmp(&saa
->boardcfg
[19],
797 bitdata
->loadwhat
, 8))
799 else if (!saa
->boardcfg
[42] && !strncmp("decxl",
800 bitdata
->loadwhat
, 8))
801 loadfile
= 1; /* special */
803 continue; /* fpga not for this card */
804 if (loadfile
!= 1 && loadfile
!= 2)
805 continue; /* skip to next card */
806 if (saa
->boardcfg
[0] && loadfile
== 1)
807 continue; /* skip to next card */
808 if (saa
->boardcfg
[0] != 1 && loadfile
== 2)
809 continue; /* skip to next card */
810 saa
->boardcfg
[0]++; /* mark fpga handled */
811 printk("stradis%d: loading %s\n", saa
->nr
,
813 if (loadtwo
&& loadfile
== 2)
814 goto send_fpga_stuff
;
815 /* turn on the Audio interface to set PROG low */
816 saawrite(0x00400040, SAA7146_GPIO_CTRL
);
817 saaread(SAA7146_PSR
); /* ensure posted write */
818 /* wait for everyone to reset */
820 saawrite(0x00400000, SAA7146_GPIO_CTRL
);
821 } else { /* original card */
822 if (strncmp(bitdata
->loadwhat
, "decoder2", 8))
823 continue; /* fpga not for this card */
824 /* Pull the Xilinx PROG signal WS3 low */
825 saawrite(0x02000200, SAA7146_MC1
);
826 /* Turn on the Audio interface so can set PROG low */
827 saawrite(0x000000c0, SAA7146_ACON1
);
828 /* Pull the Xilinx INIT signal (GPIO2) low */
829 saawrite(0x00400000, SAA7146_GPIO_CTRL
);
830 /* Make sure everybody resets */
831 saaread(SAA7146_PSR
); /* ensure posted write */
833 /* Release the Xilinx PROG signal */
834 saawrite(0x00000000, SAA7146_ACON1
);
835 /* Turn off the Audio interface */
836 saawrite(0x02000000, SAA7146_MC1
);
838 /* Release Xilinx INIT signal (WS2) */
839 saawrite(0x00000000, SAA7146_GPIO_CTRL
);
840 /* Wait for the INIT to go High */
842 i
< 10000 && !(saaread(SAA7146_PSR
) & SAA7146_PSR_PIN2
);
846 printk(KERN_INFO
"stradis%d: no fpga INIT\n", saa
->nr
);
851 for (i
= startindex
; i
< bitdata
->datasize
; i
++)
852 newdma
[i
- startindex
] =
853 bitmangler
[bitdata
->data
[i
]];
854 debiwrite(saa
, 0x01420000, 0, 0,
855 ((bitdata
->datasize
- startindex
) + 5));
856 if (loadtwo
&& loadfile
== 1) {
857 printk("stradis%d: awaiting 2nd FPGA bitfile\n",
859 continue; /* skip to next card */
862 for (i
= startindex
; i
< bitdata
->datasize
; i
++)
863 dmabuf
[i
- startindex
] =
864 bitmangler
[bitdata
->data
[i
]];
865 debiwrite(saa
, 0x014a0000, 0, 0,
866 ((bitdata
->datasize
- startindex
) + 5) * 2);
869 i
< 1000 && !(saaread(SAA7146_PSR
) & SAA7146_PSR_PIN2
);
873 printk(KERN_INFO
"stradis%d: FPGA load failed\n",
879 /* Pull the Xilinx INIT signal (GPIO2) low */
880 saawrite(0x00400000, SAA7146_GPIO_CTRL
);
881 saaread(SAA7146_PSR
); /* ensure posted write */
883 saawrite(0x00000000, SAA7146_GPIO_CTRL
);
886 printk(KERN_INFO
"stradis%d: FPGA Loaded\n", saa
->nr
);
887 saa
->boardcfg
[0] = 26; /* mark fpga programmed */
888 /* set VXCO to its lowest frequency */
889 debiwrite(saa
, debNormal
, XILINX_PWM
, 0, 2);
893 debiwrite(saa
, debNormal
, XILINX_CS3310_CMPLT
,
895 /* set VXCO to PWM mode, release reset, blank on */
896 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0xffc4, 2);
900 debiwrite(saa
, debNormal
, XILINX_CTL0
,
903 /* set source Black */
904 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x1707, 2);
905 saa
->boardcfg
[4] = 22; /* set NTSC First Active Line */
906 saa
->boardcfg
[5] = 23; /* set PAL First Active Line */
907 saa
->boardcfg
[54] = 2; /* set NTSC Last Active Line - 256 */
908 saa
->boardcfg
[55] = 54; /* set PAL Last Active Line - 256 */
909 set_out_format(saa
, VIDEO_MODE_NTSC
);
911 /* begin IBM chip init */
912 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, 4, 2);
913 saaread(SAA7146_PSR
); /* wait for reset */
915 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, 0, 2);
916 debiread(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, 2);
917 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, 0x10, 2);
918 debiwrite(saa
, debNormal
, IBM_MP2_CMD_ADDR
, 0, 2);
919 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_MODE
, 0x2e, 2);
922 /* set i2s rate converter to 48KHz */
923 debiwrite(saa
, debNormal
, 0x80c0, 6, 2);
924 /* we must init CS8420 first since rev b pulls i2s */
925 /* master clock low and CS4341 needs i2s master to */
926 /* run the i2c port. */
928 /* 0=consumer, 1=pro */
929 initialize_cs8420(saa
, 0);
933 initialize_cs4341(saa
);
935 debiwrite(saa
, debNormal
, IBM_MP2_INFC_CTL
, 0x48, 2);
936 debiwrite(saa
, debNormal
, IBM_MP2_BEEP_CTL
, 0xa000, 2);
937 debiwrite(saa
, debNormal
, IBM_MP2_DISP_LBOR
, 0, 2);
938 debiwrite(saa
, debNormal
, IBM_MP2_DISP_TBOR
, 0, 2);
940 set_genlock_offset(saa
, 0);
941 debiwrite(saa
, debNormal
, IBM_MP2_FRNT_ATTEN
, 0, 2);
944 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x8000, 2);
946 /* disable genlock */
947 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x8080, 2);
954 static int do_ibm_reset(struct saa7146
*saa
)
956 /* failure if decoder not previously programmed */
957 if (saa
->boardcfg
[0] < 37)
961 debiwrite(saa
, debNormal
, XILINX_CS3310_CMPLT
, 0, 2);
962 /* disable interrupts */
963 saawrite(0, SAA7146_IER
);
964 saa
->audhead
= saa
->audtail
= 0;
965 saa
->vidhead
= saa
->vidtail
= 0;
966 /* tristate debi bus, disable debi transfers */
967 saawrite(0x00880000, SAA7146_MC1
);
968 /* ensure posted write */
969 saaread(SAA7146_MC1
);
971 /* re-enable debi transfers */
972 saawrite(0x00880088, SAA7146_MC1
);
973 /* set source Black */
974 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x1707, 2);
975 /* begin IBM chip init */
976 set_out_format(saa
, CurrentMode
);
977 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, 4, 2);
978 saaread(SAA7146_PSR
); /* wait for reset */
980 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, 0, 2);
981 debiread(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, 2);
982 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, ChipControl
, 2);
983 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_MODE
, 0x2e, 2);
986 /* set i2s rate converter to 48KHz */
987 debiwrite(saa
, debNormal
, 0x80c0, 6, 2);
988 /* we must init CS8420 first since rev b pulls i2s */
989 /* master clock low and CS4341 needs i2s master to */
990 /* run the i2c port. */
992 /* 0=consumer, 1=pro */
993 initialize_cs8420(saa
, 1);
997 initialize_cs4341(saa
);
999 debiwrite(saa
, debNormal
, IBM_MP2_INFC_CTL
, 0x48, 2);
1000 debiwrite(saa
, debNormal
, IBM_MP2_BEEP_CTL
, 0xa000, 2);
1001 debiwrite(saa
, debNormal
, IBM_MP2_DISP_LBOR
, 0, 2);
1002 debiwrite(saa
, debNormal
, IBM_MP2_DISP_TBOR
, 0, 2);
1004 set_genlock_offset(saa
, 0);
1005 debiwrite(saa
, debNormal
, IBM_MP2_FRNT_ATTEN
, 0, 2);
1006 debiwrite(saa
, debNormal
, IBM_MP2_OSD_SIZE
, 0x2000, 2);
1007 debiwrite(saa
, debNormal
, IBM_MP2_AUD_CTL
, 0x4552, 2);
1008 if (ibm_send_command(saa
, IBM_MP2_CONFIG_DECODER
,
1009 (ChipControl
== 0x43 ? 0xe800 : 0xe000), 1)) {
1010 printk(KERN_ERR
"stradis%d: IBM config failed\n", saa
->nr
);
1013 int i
= CS3310MaxLvl
;
1014 debiwrite(saa
, debNormal
, XILINX_CS3310_CMPLT
, ((i
<< 8)| i
),2);
1016 /* start video decoder */
1017 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
, ChipControl
, 2);
1018 /* 256k vid, 3520 bytes aud */
1019 debiwrite(saa
, debNormal
, IBM_MP2_RB_THRESHOLD
, 0x4037, 2);
1020 debiwrite(saa
, debNormal
, IBM_MP2_AUD_CTL
, 0x4573, 2);
1021 ibm_send_command(saa
, IBM_MP2_PLAY
, 0, 0);
1022 /* enable buffer threshold irq */
1023 debiwrite(saa
, debNormal
, IBM_MP2_MASK0
, 0xc00c, 2);
1024 /* clear pending interrupts */
1025 debiread(saa
, debNormal
, IBM_MP2_HOST_INT
, 2);
1026 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x1711, 2);
1031 /* load the decoder microcode */
1032 static int initialize_ibmmpeg2(struct video_code
*microcode
)
1035 struct saa7146
*saa
;
1037 for (num
= 0; num
< saa_num
; num
++) {
1038 saa
= &saa7146s
[num
];
1039 /* check that FPGA is loaded */
1040 debiwrite(saa
, debNormal
, IBM_MP2_OSD_SIZE
, 0xa55a, 2);
1041 i
= debiread(saa
, debNormal
, IBM_MP2_OSD_SIZE
, 2);
1043 printk(KERN_INFO
"stradis%d: %04x != 0xa55a\n",
1049 if (!strncmp(microcode
->loadwhat
, "decoder.vid", 11)) {
1050 if (saa
->boardcfg
[0] > 27)
1051 continue; /* skip to next card */
1052 /* load video control store */
1053 saa
->boardcfg
[1] = 0x13; /* no-sync default */
1054 debiwrite(saa
, debNormal
, IBM_MP2_WR_PROT
, 1, 2);
1055 debiwrite(saa
, debNormal
, IBM_MP2_PROC_IADDR
, 0, 2);
1056 for (i
= 0; i
< microcode
->datasize
/ 2; i
++)
1057 debiwrite(saa
, debNormal
, IBM_MP2_PROC_IDATA
,
1058 (microcode
->data
[i
* 2] << 8) |
1059 microcode
->data
[i
* 2 + 1], 2);
1060 debiwrite(saa
, debNormal
, IBM_MP2_PROC_IADDR
, 0, 2);
1061 debiwrite(saa
, debNormal
, IBM_MP2_WR_PROT
, 0, 2);
1062 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
,
1064 saa
->boardcfg
[0] = 28;
1066 if (!strncmp(microcode
->loadwhat
, "decoder.aud", 11)) {
1067 if (saa
->boardcfg
[0] > 35)
1068 continue; /* skip to next card */
1069 /* load audio control store */
1070 debiwrite(saa
, debNormal
, IBM_MP2_WR_PROT
, 1, 2);
1071 debiwrite(saa
, debNormal
, IBM_MP2_AUD_IADDR
, 0, 2);
1072 for (i
= 0; i
< microcode
->datasize
; i
++)
1073 debiwrite(saa
, debNormal
, IBM_MP2_AUD_IDATA
,
1074 microcode
->data
[i
], 1);
1075 debiwrite(saa
, debNormal
, IBM_MP2_AUD_IADDR
, 0, 2);
1076 debiwrite(saa
, debNormal
, IBM_MP2_WR_PROT
, 0, 2);
1077 debiwrite(saa
, debNormal
, IBM_MP2_OSD_SIZE
, 0x2000, 2);
1078 debiwrite(saa
, debNormal
, IBM_MP2_AUD_CTL
, 0x4552, 2);
1079 if (ibm_send_command(saa
, IBM_MP2_CONFIG_DECODER
,
1081 printk(KERN_ERR
"stradis%d: IBM config "
1082 "failed\n", saa
->nr
);
1085 /* set PWM to center value */
1087 debiwrite(saa
, debNormal
, XILINX_PWM
,
1089 (saa
->boardcfg
[13] << 8), 2);
1091 debiwrite(saa
, debNormal
, XILINX_PWM
, 0x46, 2);
1095 debiwrite(saa
, debNormal
, XILINX_CS3310_CMPLT
,
1098 printk(KERN_INFO
"stradis%d: IBM MPEGCD%d Inited\n",
1099 saa
->nr
, 18 + (debiread(saa
, debNormal
,
1100 IBM_MP2_CHIP_CONTROL
, 2) >> 12));
1101 /* start video decoder */
1102 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
,
1104 debiwrite(saa
, debNormal
, IBM_MP2_RB_THRESHOLD
, 0x4037,
1105 2); /* 256k vid, 3520 bytes aud */
1106 debiwrite(saa
, debNormal
, IBM_MP2_AUD_CTL
, 0x4573, 2);
1107 ibm_send_command(saa
, IBM_MP2_PLAY
, 0, 0);
1108 /* enable buffer threshold irq */
1109 debiwrite(saa
, debNormal
, IBM_MP2_MASK0
, 0xc00c, 2);
1110 debiread(saa
, debNormal
, IBM_MP2_HOST_INT
, 2);
1111 /* enable gpio irq */
1112 saawrite(0x00002000, SAA7146_GPIO_CTRL
);
1113 /* enable decoder output to HPS */
1114 debiwrite(saa
, debNormal
, XILINX_CTL0
, 0x1711, 2);
1115 saa
->boardcfg
[0] = 37;
1122 static u32 palette2fmt
[] = { /* some of these YUV translations are wrong */
1123 0xffffffff, 0x86000000, 0x87000000, 0x80000000, 0x8100000, 0x82000000,
1124 0x83000000, 0x00000000, 0x03000000, 0x03000000, 0x0a00000, 0x03000000,
1125 0x06000000, 0x00000000, 0x03000000, 0x0a000000, 0x0300000
1127 static int bpp2fmt
[4] = {
1128 VIDEO_PALETTE_HI240
, VIDEO_PALETTE_RGB565
, VIDEO_PALETTE_RGB24
,
1132 /* I wish I could find a formula to calculate these... */
1133 static u32 h_prescale
[64] = {
1134 0x10000000, 0x18040202, 0x18080000, 0x380c0606, 0x38100204, 0x38140808,
1135 0x38180000, 0x381c0000, 0x3820161c, 0x38242a3b, 0x38281230, 0x382c4460,
1136 0x38301040, 0x38340080, 0x38380000, 0x383c0000, 0x3840fefe, 0x3844ee9f,
1137 0x3848ee9f, 0x384cee9f, 0x3850ee9f, 0x38542a3b, 0x38581230, 0x385c0000,
1138 0x38600000, 0x38640000, 0x38680000, 0x386c0000, 0x38700000, 0x38740000,
1139 0x38780000, 0x387c0000, 0x30800000, 0x38840000, 0x38880000, 0x388c0000,
1140 0x38900000, 0x38940000, 0x38980000, 0x389c0000, 0x38a00000, 0x38a40000,
1141 0x38a80000, 0x38ac0000, 0x38b00000, 0x38b40000, 0x38b80000, 0x38bc0000,
1142 0x38c00000, 0x38c40000, 0x38c80000, 0x38cc0000, 0x38d00000, 0x38d40000,
1143 0x38d80000, 0x38dc0000, 0x38e00000, 0x38e40000, 0x38e80000, 0x38ec0000,
1144 0x38f00000, 0x38f40000, 0x38f80000, 0x38fc0000,
1146 static u32 v_gain
[64] = {
1147 0x016000ff, 0x016100ff, 0x016100ff, 0x016200ff, 0x016200ff, 0x016200ff,
1148 0x016200ff, 0x016300ff, 0x016300ff, 0x016300ff, 0x016300ff, 0x016300ff,
1149 0x016300ff, 0x016300ff, 0x016300ff, 0x016400ff, 0x016400ff, 0x016400ff,
1150 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1151 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1152 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1153 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1154 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1155 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1156 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1157 0x016400ff, 0x016400ff, 0x016400ff, 0x016400ff,
1160 static void saa7146_set_winsize(struct saa7146
*saa
)
1163 int offset
, yacl
, ysci
;
1164 saa
->win
.color_fmt
= format
=
1165 (saa
->win
.depth
== 15) ? palette2fmt
[VIDEO_PALETTE_RGB555
] :
1166 palette2fmt
[bpp2fmt
[(saa
->win
.bpp
- 1) & 3]];
1167 offset
= saa
->win
.x
* saa
->win
.bpp
+ saa
->win
.y
* saa
->win
.bpl
;
1168 saawrite(saa
->win
.vidadr
+ offset
, SAA7146_BASE_EVEN1
);
1169 saawrite(saa
->win
.vidadr
+ offset
+ saa
->win
.bpl
, SAA7146_BASE_ODD1
);
1170 saawrite(saa
->win
.bpl
* 2, SAA7146_PITCH1
);
1171 saawrite(saa
->win
.vidadr
+ saa
->win
.bpl
* saa
->win
.sheight
,
1172 SAA7146_PROT_ADDR1
);
1173 saawrite(0, SAA7146_PAGE1
);
1174 saawrite(format
| 0x60, SAA7146_CLIP_FORMAT_CTRL
);
1175 offset
= (704 / (saa
->win
.width
- 1)) & 0x3f;
1176 saawrite(h_prescale
[offset
], SAA7146_HPS_H_PRESCALE
);
1177 offset
= (720896 / saa
->win
.width
) / (offset
+ 1);
1178 saawrite((offset
<< 12) | 0x0c, SAA7146_HPS_H_SCALE
);
1179 if (CurrentMode
== VIDEO_MODE_NTSC
) {
1180 yacl
= /*(480 / saa->win.height - 1) & 0x3f */ 0;
1181 ysci
= 1024 - (saa
->win
.height
* 1024 / 480);
1183 yacl
= /*(576 / saa->win.height - 1) & 0x3f */ 0;
1184 ysci
= 1024 - (saa
->win
.height
* 1024 / 576);
1186 saawrite((1 << 31) | (ysci
<< 21) | (yacl
<< 15), SAA7146_HPS_V_SCALE
);
1187 saawrite(v_gain
[yacl
], SAA7146_HPS_V_GAIN
);
1188 saawrite(((SAA7146_MC2_UPLD_DMA1
| SAA7146_MC2_UPLD_HPS_V
|
1189 SAA7146_MC2_UPLD_HPS_H
) << 16) | (SAA7146_MC2_UPLD_DMA1
|
1190 SAA7146_MC2_UPLD_HPS_V
| SAA7146_MC2_UPLD_HPS_H
), SAA7146_MC2
);
1193 /* clip_draw_rectangle(cm,x,y,w,h) -- handle clipping an area
1194 * bitmap is fixed width, 128 bytes (1024 pixels represented)
1195 * arranged most-sigificant-bit-left in 32-bit words
1196 * based on saa7146 clipping hardware, it swaps bytes if LE
1197 * much of this makes up for egcs brain damage -- so if you
1198 * are wondering "why did he do this?" it is because the C
1199 * was adjusted to generate the optimal asm output without
1200 * writing non-portable __asm__ directives.
1203 static void clip_draw_rectangle(u32
*clipmap
, int x
, int y
, int w
, int h
)
1205 register int startword
, endword
;
1206 register u32 bitsleft
, bitsright
;
1216 if (w
<= 0 || h
<= 0 || x
> 1023 || y
> 639)
1217 return; /* throw away bad clips */
1222 startword
= (x
>> 5);
1223 endword
= ((x
+ w
) >> 5);
1224 bitsleft
= (0xffffffff >> (x
& 31));
1225 bitsright
= (0xffffffff << (~((x
+ w
) - (endword
<< 5))));
1226 temp
= &clipmap
[(y
<< 5) + startword
];
1227 w
= endword
- startword
;
1229 bitsleft
|= bitsright
;
1230 for (y
= 0; y
< h
; y
++) {
1235 for (y
= 0; y
< h
; y
++) {
1236 *temp
++ |= bitsleft
;
1237 for (x
= 1; x
< w
; x
++)
1238 *temp
++ = 0xffffffff;
1245 static void make_clip_tab(struct saa7146
*saa
, struct video_clip
*cr
, int ncr
)
1247 int i
, width
, height
;
1250 clipmap
= saa
->dmavid2
;
1251 if ((width
= saa
->win
.width
) > 1023)
1252 width
= 1023; /* sanity check */
1253 if ((height
= saa
->win
.height
) > 640)
1254 height
= 639; /* sanity check */
1255 if (ncr
> 0) { /* rectangles pased */
1256 /* convert rectangular clips to a bitmap */
1257 memset(clipmap
, 0, VIDEO_CLIPMAP_SIZE
); /* clear map */
1258 for (i
= 0; i
< ncr
; i
++)
1259 clip_draw_rectangle(clipmap
, cr
[i
].x
, cr
[i
].y
,
1260 cr
[i
].width
, cr
[i
].height
);
1262 /* clip against viewing window AND screen
1263 so we do not have to rely on the user program
1265 clip_draw_rectangle(clipmap
, (saa
->win
.x
+ width
> saa
->win
.swidth
) ?
1266 (saa
->win
.swidth
- saa
->win
.x
) : width
, 0, 1024, 768);
1267 clip_draw_rectangle(clipmap
, 0,
1268 (saa
->win
.y
+ height
> saa
->win
.sheight
) ?
1269 (saa
->win
.sheight
- saa
->win
.y
) : height
, 1024, 768);
1271 clip_draw_rectangle(clipmap
, 0, 0, -saa
->win
.x
, 768);
1273 clip_draw_rectangle(clipmap
, 0, 0, 1024, -saa
->win
.y
);
1276 static int saa_ioctl(struct inode
*inode
, struct file
*file
,
1277 unsigned int cmd
, unsigned long argl
)
1279 struct saa7146
*saa
= file
->private_data
;
1280 void __user
*arg
= (void __user
*)argl
;
1285 struct video_capability b
;
1286 strcpy(b
.name
, saa
->video_dev
.name
);
1287 b
.type
= VID_TYPE_CAPTURE
| VID_TYPE_OVERLAY
|
1288 VID_TYPE_CLIPPING
| VID_TYPE_FRAMERAM
|
1296 if (copy_to_user(arg
, &b
, sizeof(b
)))
1302 struct video_picture p
= saa
->picture
;
1303 if (saa
->win
.depth
== 8)
1304 p
.palette
= VIDEO_PALETTE_HI240
;
1305 if (saa
->win
.depth
== 15)
1306 p
.palette
= VIDEO_PALETTE_RGB555
;
1307 if (saa
->win
.depth
== 16)
1308 p
.palette
= VIDEO_PALETTE_RGB565
;
1309 if (saa
->win
.depth
== 24)
1310 p
.palette
= VIDEO_PALETTE_RGB24
;
1311 if (saa
->win
.depth
== 32)
1312 p
.palette
= VIDEO_PALETTE_RGB32
;
1313 if (copy_to_user(arg
, &p
, sizeof(p
)))
1319 struct video_picture p
;
1321 if (copy_from_user(&p
, arg
, sizeof(p
)))
1323 if (p
.palette
< sizeof(palette2fmt
) / sizeof(u32
)) {
1324 format
= palette2fmt
[p
.palette
];
1325 saa
->win
.color_fmt
= format
;
1326 saawrite(format
| 0x60,
1327 SAA7146_CLIP_FORMAT_CTRL
);
1329 saawrite(((p
.brightness
& 0xff00) << 16) |
1330 ((p
.contrast
& 0xfe00) << 7) |
1331 ((p
.colour
& 0xfe00) >> 9), SAA7146_BCS_CTRL
);
1333 /* upload changed registers */
1334 saawrite(((SAA7146_MC2_UPLD_HPS_H
|
1335 SAA7146_MC2_UPLD_HPS_V
) << 16) |
1336 SAA7146_MC2_UPLD_HPS_H
|
1337 SAA7146_MC2_UPLD_HPS_V
, SAA7146_MC2
);
1342 struct video_window vw
;
1343 struct video_clip
*vcp
= NULL
;
1345 if (copy_from_user(&vw
, arg
, sizeof(vw
)))
1349 if (vw
.flags
|| vw
.width
< 16 || vw
.height
< 16) {
1350 saawrite((SAA7146_MC1_TR_E_1
<< 16),
1354 /* 32-bit align start and adjust width */
1355 if (saa
->win
.bpp
< 4) {
1357 vw
.x
= (vw
.x
+ 3) & ~3;
1363 saa
->win
.width
= vw
.width
;
1364 if (saa
->win
.width
> 768)
1365 saa
->win
.width
= 768;
1366 saa
->win
.height
= vw
.height
;
1367 if (CurrentMode
== VIDEO_MODE_NTSC
) {
1368 if (saa
->win
.height
> 480)
1369 saa
->win
.height
= 480;
1371 if (saa
->win
.height
> 576)
1372 saa
->win
.height
= 576;
1376 saawrite((SAA7146_MC1_TR_E_1
<< 16), SAA7146_MC1
);
1377 saa7146_set_winsize(saa
);
1382 if (vw
.clipcount
< 0) {
1383 if (copy_from_user(saa
->dmavid2
, vw
.clips
,
1384 VIDEO_CLIPMAP_SIZE
))
1386 } else if (vw
.clipcount
> 16384) {
1388 } else if (vw
.clipcount
> 0) {
1389 vcp
= vmalloc(sizeof(struct video_clip
) *
1393 if (copy_from_user(vcp
, vw
.clips
,
1394 sizeof(struct video_clip
) *
1399 } else /* nothing clipped */
1400 memset(saa
->dmavid2
, 0, VIDEO_CLIPMAP_SIZE
);
1402 make_clip_tab(saa
, vcp
, vw
.clipcount
);
1403 if (vw
.clipcount
> 0)
1406 /* start capture & clip dma if we have an address */
1407 if ((saa
->cap
& 3) && saa
->win
.vidadr
!= 0)
1408 saawrite(((SAA7146_MC1_TR_E_1
|
1409 SAA7146_MC1_TR_E_2
) << 16) | 0xffff,
1415 struct video_window vw
;
1418 vw
.width
= saa
->win
.width
;
1419 vw
.height
= saa
->win
.height
;
1422 if (copy_to_user(arg
, &vw
, sizeof(vw
)))
1429 if (copy_from_user(&v
, arg
, sizeof(v
)))
1433 saawrite((SAA7146_MC1_TR_E_1
<< 16),
1436 if (saa
->win
.vidadr
== 0 || saa
->win
.width
== 0
1437 || saa
->win
.height
== 0)
1440 saawrite((SAA7146_MC1_TR_E_1
<< 16) | 0xffff,
1447 struct video_buffer v
;
1448 v
.base
= (void *)saa
->win
.vidadr
;
1449 v
.height
= saa
->win
.sheight
;
1450 v
.width
= saa
->win
.swidth
;
1451 v
.depth
= saa
->win
.depth
;
1452 v
.bytesperline
= saa
->win
.bpl
;
1453 if (copy_to_user(arg
, &v
, sizeof(v
)))
1460 struct video_buffer v
;
1461 if (!capable(CAP_SYS_ADMIN
))
1463 if (copy_from_user(&v
, arg
, sizeof(v
)))
1465 if (v
.depth
!= 8 && v
.depth
!= 15 && v
.depth
!= 16 &&
1466 v
.depth
!= 24 && v
.depth
!= 32 && v
.width
> 16 &&
1467 v
.height
> 16 && v
.bytesperline
> 16)
1470 saa
->win
.vidadr
= (unsigned long)v
.base
;
1471 saa
->win
.sheight
= v
.height
;
1472 saa
->win
.swidth
= v
.width
;
1473 saa
->win
.bpp
= ((v
.depth
+ 7) & 0x38) / 8;
1474 saa
->win
.depth
= v
.depth
;
1475 saa
->win
.bpl
= v
.bytesperline
;
1477 DEBUG(printk("Display at %p is %d by %d, bytedepth %d, "
1478 "bpl %d\n", v
.base
, v
.width
, v
.height
,
1479 saa
->win
.bpp
, saa
->win
.bpl
));
1480 saa7146_set_winsize(saa
);
1485 /* Will be handled higher up .. */
1491 struct video_audio v
;
1493 v
.flags
&= ~(VIDEO_AUDIO_MUTE
| VIDEO_AUDIO_MUTABLE
);
1494 v
.flags
|= VIDEO_AUDIO_MUTABLE
| VIDEO_AUDIO_VOLUME
;
1495 strcpy(v
.name
, "MPEG");
1496 v
.mode
= VIDEO_SOUND_STEREO
;
1497 if (copy_to_user(arg
, &v
, sizeof(v
)))
1503 struct video_audio v
;
1505 if (copy_from_user(&v
, arg
, sizeof(v
)))
1507 i
= (~(v
.volume
>> 8)) & 0xff;
1509 if (v
.flags
& VIDEO_AUDIO_MUTE
)
1510 debiwrite(saa
, debNormal
,
1511 IBM_MP2_FRNT_ATTEN
, 0xffff, 2);
1512 if (!(v
.flags
& VIDEO_AUDIO_MUTE
))
1513 debiwrite(saa
, debNormal
,
1514 IBM_MP2_FRNT_ATTEN
, 0x0000, 2);
1515 if (v
.flags
& VIDEO_AUDIO_VOLUME
)
1516 debiwrite(saa
, debNormal
,
1520 if (v
.flags
& VIDEO_AUDIO_MUTE
)
1521 cs4341_setlevel(saa
, 0xff, 0xff);
1522 if (!(v
.flags
& VIDEO_AUDIO_MUTE
))
1523 cs4341_setlevel(saa
, 0, 0);
1524 if (v
.flags
& VIDEO_AUDIO_VOLUME
)
1525 cs4341_setlevel(saa
, i
, i
);
1533 struct video_unit vu
;
1534 vu
.video
= saa
->video_dev
.minor
;
1535 vu
.vbi
= VIDEO_NO_UNIT
;
1536 vu
.radio
= VIDEO_NO_UNIT
;
1537 vu
.audio
= VIDEO_NO_UNIT
;
1538 vu
.teletext
= VIDEO_NO_UNIT
;
1539 if (copy_to_user(arg
, &vu
, sizeof(vu
)))
1543 case VIDIOCSPLAYMODE
:
1545 struct video_play_mode pmode
;
1546 if (copy_from_user((void *)&pmode
, arg
,
1547 sizeof(struct video_play_mode
)))
1549 switch (pmode
.mode
) {
1550 case VID_PLAY_VID_OUT_MODE
:
1551 if (pmode
.p1
!= VIDEO_MODE_NTSC
&&
1552 pmode
.p1
!= VIDEO_MODE_PAL
)
1554 set_out_format(saa
, pmode
.p1
);
1556 case VID_PLAY_GENLOCK
:
1557 debiwrite(saa
, debNormal
, XILINX_CTL0
,
1558 pmode
.p1
? 0x8000 : 0x8080, 2);
1560 set_genlock_offset(saa
, pmode
.p2
);
1562 case VID_PLAY_NORMAL
:
1563 debiwrite(saa
, debNormal
,
1564 IBM_MP2_CHIP_CONTROL
, ChipControl
, 2);
1565 ibm_send_command(saa
, IBM_MP2_PLAY
, 0, 0);
1566 saa
->playmode
= pmode
.mode
;
1568 case VID_PLAY_PAUSE
:
1569 /* IBM removed the PAUSE command */
1570 /* they say use SINGLE_FRAME now */
1571 case VID_PLAY_SINGLE_FRAME
:
1572 ibm_send_command(saa
, IBM_MP2_SINGLE_FRAME
,0,0);
1573 if (saa
->playmode
== pmode
.mode
) {
1574 debiwrite(saa
, debNormal
,
1575 IBM_MP2_CHIP_CONTROL
,
1578 saa
->playmode
= pmode
.mode
;
1580 case VID_PLAY_FAST_FORWARD
:
1581 ibm_send_command(saa
, IBM_MP2_FAST_FORWARD
,0,0);
1582 saa
->playmode
= pmode
.mode
;
1584 case VID_PLAY_SLOW_MOTION
:
1585 ibm_send_command(saa
, IBM_MP2_SLOW_MOTION
,
1587 saa
->playmode
= pmode
.mode
;
1589 case VID_PLAY_IMMEDIATE_NORMAL
:
1590 /* ensure transfers resume */
1591 debiwrite(saa
, debNormal
,
1592 IBM_MP2_CHIP_CONTROL
, ChipControl
, 2);
1593 ibm_send_command(saa
, IBM_MP2_IMED_NORM_PLAY
,
1595 saa
->playmode
= VID_PLAY_NORMAL
;
1597 case VID_PLAY_SWITCH_CHANNELS
:
1598 saa
->audhead
= saa
->audtail
= 0;
1599 saa
->vidhead
= saa
->vidtail
= 0;
1600 ibm_send_command(saa
, IBM_MP2_FREEZE_FRAME
,0,1);
1601 ibm_send_command(saa
, IBM_MP2_RESET_AUD_RATE
,
1603 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
,
1605 ibm_send_command(saa
, IBM_MP2_CHANNEL_SWITCH
,
1607 debiwrite(saa
, debNormal
, IBM_MP2_CHIP_CONTROL
,
1609 ibm_send_command(saa
, IBM_MP2_PLAY
, 0, 0);
1610 saa
->playmode
= VID_PLAY_NORMAL
;
1612 case VID_PLAY_FREEZE_FRAME
:
1613 ibm_send_command(saa
, IBM_MP2_FREEZE_FRAME
,0,0);
1614 saa
->playmode
= pmode
.mode
;
1616 case VID_PLAY_STILL_MODE
:
1617 ibm_send_command(saa
, IBM_MP2_SET_STILL_MODE
,
1619 saa
->playmode
= pmode
.mode
;
1621 case VID_PLAY_MASTER_MODE
:
1622 if (pmode
.p1
== VID_PLAY_MASTER_NONE
)
1623 saa
->boardcfg
[1] = 0x13;
1624 else if (pmode
.p1
== VID_PLAY_MASTER_VIDEO
)
1625 saa
->boardcfg
[1] = 0x23;
1626 else if (pmode
.p1
== VID_PLAY_MASTER_AUDIO
)
1627 saa
->boardcfg
[1] = 0x43;
1630 debiwrite(saa
, debNormal
,
1631 IBM_MP2_CHIP_CONTROL
, ChipControl
, 2);
1633 case VID_PLAY_ACTIVE_SCANLINES
:
1634 if (CurrentMode
== VIDEO_MODE_PAL
) {
1635 if (pmode
.p1
< 1 || pmode
.p2
> 625)
1637 saa
->boardcfg
[5] = pmode
.p1
;
1638 saa
->boardcfg
[55] = (pmode
.p1
+
1639 (pmode
.p2
/ 2) - 1) & 0xff;
1641 if (pmode
.p1
< 4 || pmode
.p2
> 525)
1643 saa
->boardcfg
[4] = pmode
.p1
;
1644 saa
->boardcfg
[54] = (pmode
.p1
+
1645 (pmode
.p2
/ 2) - 4) & 0xff;
1647 set_out_format(saa
, CurrentMode
);
1648 case VID_PLAY_RESET
:
1649 return do_ibm_reset(saa
);
1650 case VID_PLAY_END_MARK
:
1651 if (saa
->endmarktail
< saa
->endmarkhead
) {
1652 if (saa
->endmarkhead
-
1653 saa
->endmarktail
< 2)
1655 } else if (saa
->endmarkhead
<=saa
->endmarktail
){
1656 if (saa
->endmarktail
- saa
->endmarkhead
1661 saa
->endmark
[saa
->endmarktail
] = saa
->audtail
;
1663 if (saa
->endmarktail
>= MAX_MARKS
)
1664 saa
->endmarktail
= 0;
1668 case VIDIOCSWRITEMODE
:
1671 if (copy_from_user((void *)&mode
, arg
, sizeof(int)))
1673 if (mode
== VID_WRITE_MPEG_AUD
||
1674 mode
== VID_WRITE_MPEG_VID
||
1675 mode
== VID_WRITE_CC
||
1676 mode
== VID_WRITE_TTX
||
1677 mode
== VID_WRITE_OSD
) {
1678 saa
->writemode
= mode
;
1683 case VIDIOCSMICROCODE
:
1685 struct video_code ucode
;
1688 if (copy_from_user(&ucode
, arg
, sizeof(ucode
)))
1690 if (ucode
.datasize
> 65536 || ucode
.datasize
< 1024 ||
1691 strncmp(ucode
.loadwhat
, "dec", 3))
1693 if ((udata
= vmalloc(ucode
.datasize
)) == NULL
)
1695 if (copy_from_user(udata
, ucode
.data
, ucode
.datasize
)) {
1700 if (!strncmp(ucode
.loadwhat
, "decoder.aud", 11) ||
1701 !strncmp(ucode
.loadwhat
, "decoder.vid", 11))
1702 i
= initialize_ibmmpeg2(&ucode
);
1704 i
= initialize_fpga(&ucode
);
1711 case VIDIOCGCHAN
: /* this makes xawtv happy */
1713 struct video_channel v
;
1714 if (copy_from_user(&v
, arg
, sizeof(v
)))
1716 v
.flags
= VIDEO_VC_AUDIO
;
1718 v
.type
= VID_TYPE_MPEG_DECODER
;
1719 v
.norm
= CurrentMode
;
1720 strcpy(v
.name
, "MPEG2");
1721 if (copy_to_user(arg
, &v
, sizeof(v
)))
1725 case VIDIOCSCHAN
: /* this makes xawtv happy */
1727 struct video_channel v
;
1728 if (copy_from_user(&v
, arg
, sizeof(v
)))
1734 return -ENOIOCTLCMD
;
1739 static int saa_mmap(struct file
*file
, struct vm_area_struct
*vma
)
1741 struct saa7146
*saa
= file
->private_data
;
1742 printk(KERN_DEBUG
"stradis%d: saa_mmap called\n", saa
->nr
);
1746 static ssize_t
saa_read(struct file
*file
, char __user
* buf
,
1747 size_t count
, loff_t
* ppos
)
1752 static ssize_t
saa_write(struct file
*file
, const char __user
* buf
,
1753 size_t count
, loff_t
* ppos
)
1755 struct saa7146
*saa
= file
->private_data
;
1756 unsigned long todo
= count
;
1757 int blocksize
, split
;
1758 unsigned long flags
;
1761 if (saa
->writemode
== VID_WRITE_MPEG_AUD
) {
1762 spin_lock_irqsave(&saa
->lock
, flags
);
1763 if (saa
->audhead
<= saa
->audtail
)
1765 (saa
->audtail
- saa
->audhead
);
1767 blocksize
= saa
->audhead
- saa
->audtail
;
1768 spin_unlock_irqrestore(&saa
->lock
, flags
);
1769 if (blocksize
< 16384) {
1770 saawrite(SAA7146_PSR_DEBI_S
|
1771 SAA7146_PSR_PIN1
, SAA7146_IER
);
1772 saawrite(SAA7146_PSR_PIN1
, SAA7146_PSR
);
1773 /* wait for buffer space to open */
1774 interruptible_sleep_on(&saa
->audq
);
1776 spin_lock_irqsave(&saa
->lock
, flags
);
1777 if (saa
->audhead
<= saa
->audtail
) {
1779 (saa
->audtail
- saa
->audhead
);
1780 split
= 65536 - saa
->audtail
;
1782 blocksize
= saa
->audhead
- saa
->audtail
;
1785 spin_unlock_irqrestore(&saa
->lock
, flags
);
1787 if (blocksize
> todo
)
1789 /* double check that we really have space */
1792 if (split
< blocksize
) {
1793 if (copy_from_user(saa
->audbuf
+
1794 saa
->audtail
, buf
, split
))
1801 if (copy_from_user(saa
->audbuf
+ saa
->audtail
, buf
,
1804 saa
->audtail
+= blocksize
;
1807 saa
->audtail
&= 0xffff;
1808 } else if (saa
->writemode
== VID_WRITE_MPEG_VID
) {
1809 spin_lock_irqsave(&saa
->lock
, flags
);
1810 if (saa
->vidhead
<= saa
->vidtail
)
1811 blocksize
= 524288 -
1812 (saa
->vidtail
- saa
->vidhead
);
1814 blocksize
= saa
->vidhead
- saa
->vidtail
;
1815 spin_unlock_irqrestore(&saa
->lock
, flags
);
1816 if (blocksize
< 65536) {
1817 saawrite(SAA7146_PSR_DEBI_S
|
1818 SAA7146_PSR_PIN1
, SAA7146_IER
);
1819 saawrite(SAA7146_PSR_PIN1
, SAA7146_PSR
);
1820 /* wait for buffer space to open */
1821 interruptible_sleep_on(&saa
->vidq
);
1823 spin_lock_irqsave(&saa
->lock
, flags
);
1824 if (saa
->vidhead
<= saa
->vidtail
) {
1825 blocksize
= 524288 -
1826 (saa
->vidtail
- saa
->vidhead
);
1827 split
= 524288 - saa
->vidtail
;
1829 blocksize
= saa
->vidhead
- saa
->vidtail
;
1832 spin_unlock_irqrestore(&saa
->lock
, flags
);
1834 if (blocksize
> todo
)
1836 /* double check that we really have space */
1839 if (split
< blocksize
) {
1840 if (copy_from_user(saa
->vidbuf
+
1841 saa
->vidtail
, buf
, split
))
1848 if (copy_from_user(saa
->vidbuf
+ saa
->vidtail
, buf
,
1851 saa
->vidtail
+= blocksize
;
1854 saa
->vidtail
&= 0x7ffff;
1855 } else if (saa
->writemode
== VID_WRITE_OSD
) {
1858 if (copy_from_user(saa
->osdbuf
, buf
, count
))
1862 saa
->osdtail
= count
;
1863 debiwrite(saa
, debNormal
, IBM_MP2_OSD_ADDR
, 0, 2);
1864 debiwrite(saa
, debNormal
, IBM_MP2_OSD_LINK_ADDR
, 0, 2);
1865 debiwrite(saa
, debNormal
, IBM_MP2_MASK0
, 0xc00d, 2);
1866 debiwrite(saa
, debNormal
, IBM_MP2_DISP_MODE
,
1867 debiread(saa
, debNormal
,
1868 IBM_MP2_DISP_MODE
, 2) | 1, 2);
1869 /* trigger osd data transfer */
1870 saawrite(SAA7146_PSR_DEBI_S
|
1871 SAA7146_PSR_PIN1
, SAA7146_IER
);
1872 saawrite(SAA7146_PSR_PIN1
, SAA7146_PSR
);
1878 static int saa_open(struct inode
*inode
, struct file
*file
)
1880 struct video_device
*vdev
= video_devdata(file
);
1881 struct saa7146
*saa
= container_of(vdev
, struct saa7146
, video_dev
);
1883 file
->private_data
= saa
;
1887 return 0; /* device open already, don't reset */
1888 saa
->writemode
= VID_WRITE_MPEG_VID
; /* default to video */
1892 static int saa_release(struct inode
*inode
, struct file
*file
)
1894 struct saa7146
*saa
= file
->private_data
;
1897 if (saa
->user
> 0) /* still someone using device */
1899 saawrite(0x007f0000, SAA7146_MC1
); /* stop all overlay dma */
1903 static struct file_operations saa_fops
= {
1904 .owner
= THIS_MODULE
,
1906 .release
= saa_release
,
1908 .compat_ioctl
= v4l_compat_ioctl32
,
1910 .llseek
= no_llseek
,
1915 /* template for video_device-structure */
1916 static struct video_device saa_template
= {
1918 .type
= VID_TYPE_CAPTURE
| VID_TYPE_OVERLAY
,
1919 .hardware
= VID_HARDWARE_SAA7146
,
1924 static int __devinit
configure_saa7146(struct pci_dev
*pdev
, int num
)
1927 struct saa7146
*saa
= pci_get_drvdata(pdev
);
1929 saa
->endmarkhead
= saa
->endmarktail
= 0;
1930 saa
->win
.x
= saa
->win
.y
= 0;
1931 saa
->win
.width
= saa
->win
.cropwidth
= 720;
1932 saa
->win
.height
= saa
->win
.cropheight
= 480;
1933 saa
->win
.cropx
= saa
->win
.cropy
= 0;
1935 saa
->win
.depth
= 16;
1936 saa
->win
.color_fmt
= palette2fmt
[VIDEO_PALETTE_RGB565
];
1937 saa
->win
.bpl
= 1024 * saa
->win
.bpp
;
1938 saa
->win
.swidth
= 1024;
1939 saa
->win
.sheight
= 768;
1940 saa
->picture
.brightness
= 32768;
1941 saa
->picture
.contrast
= 38768;
1942 saa
->picture
.colour
= 32768;
1945 saa
->playmode
= VID_PLAY_NORMAL
;
1946 memset(saa
->boardcfg
, 0, 64); /* clear board config area */
1947 saa
->saa7146_mem
= NULL
;
1948 saa
->dmavid1
= saa
->dmavid2
= saa
->dmavid3
= saa
->dmaa1in
=
1949 saa
->dmaa1out
= saa
->dmaa2in
= saa
->dmaa2out
=
1950 saa
->pagevid1
= saa
->pagevid2
= saa
->pagevid3
= saa
->pagea1in
=
1951 saa
->pagea1out
= saa
->pagea2in
= saa
->pagea2out
=
1952 saa
->pagedebi
= saa
->dmaRPS1
= saa
->dmaRPS2
= saa
->pageRPS1
=
1953 saa
->pageRPS2
= NULL
;
1954 saa
->audbuf
= saa
->vidbuf
= saa
->osdbuf
= saa
->dmadebi
= NULL
;
1955 saa
->audhead
= saa
->vidtail
= 0;
1957 init_waitqueue_head(&saa
->i2cq
);
1958 init_waitqueue_head(&saa
->audq
);
1959 init_waitqueue_head(&saa
->debiq
);
1960 init_waitqueue_head(&saa
->vidq
);
1961 spin_lock_init(&saa
->lock
);
1963 retval
= pci_enable_device(pdev
);
1965 dev_err(&pdev
->dev
, "%d: pci_enable_device failed!\n", num
);
1969 saa
->id
= pdev
->device
;
1970 saa
->irq
= pdev
->irq
;
1971 saa
->video_dev
.minor
= -1;
1972 saa
->saa7146_adr
= pci_resource_start(pdev
, 0);
1973 pci_read_config_byte(pdev
, PCI_CLASS_REVISION
, &saa
->revision
);
1975 saa
->saa7146_mem
= ioremap(saa
->saa7146_adr
, 0x200);
1976 if (saa
->saa7146_mem
== NULL
) {
1977 dev_err(&pdev
->dev
, "%d: ioremap failed!\n", num
);
1982 memcpy(&saa
->video_dev
, &saa_template
, sizeof(saa_template
));
1983 saawrite(0, SAA7146_IER
); /* turn off all interrupts */
1985 retval
= request_irq(saa
->irq
, saa7146_irq
, SA_SHIRQ
| SA_INTERRUPT
,
1987 if (retval
== -EINVAL
)
1988 dev_err(&pdev
->dev
, "%d: Bad irq number or handler\n", num
);
1989 else if (retval
== -EBUSY
)
1990 dev_err(&pdev
->dev
, "%d: IRQ %ld busy, change your PnP config "
1991 "in BIOS\n", num
, saa
->irq
);
1995 pci_set_master(pdev
);
1996 retval
= video_register_device(&saa
->video_dev
, VFL_TYPE_GRABBER
,
1999 dev_err(&pdev
->dev
, "%d: error in registering video device!\n",
2006 iounmap(saa
->saa7146_mem
);
2011 static int __devinit
init_saa7146(struct pci_dev
*pdev
)
2013 struct saa7146
*saa
= pci_get_drvdata(pdev
);
2016 /* reset the saa7146 */
2017 saawrite(0xffff0000, SAA7146_MC1
);
2019 /* enable debi and i2c transfers and pins */
2020 saawrite(((SAA7146_MC1_EDP
| SAA7146_MC1_EI2C
|
2021 SAA7146_MC1_TR_E_DEBI
) << 16) | 0xffff, SAA7146_MC1
);
2022 /* ensure proper state of chip */
2023 saawrite(0x00000000, SAA7146_PAGE1
);
2024 saawrite(0x00f302c0, SAA7146_NUM_LINE_BYTE1
);
2025 saawrite(0x00000000, SAA7146_PAGE2
);
2026 saawrite(0x01400080, SAA7146_NUM_LINE_BYTE2
);
2027 saawrite(0x00000000, SAA7146_DD1_INIT
);
2028 saawrite(0x00000000, SAA7146_DD1_STREAM_B
);
2029 saawrite(0x00000000, SAA7146_DD1_STREAM_A
);
2030 saawrite(0x00000000, SAA7146_BRS_CTRL
);
2031 saawrite(0x80400040, SAA7146_BCS_CTRL
);
2032 saawrite(0x0000e000 /*| (1<<29) */ , SAA7146_HPS_CTRL
);
2033 saawrite(0x00000060, SAA7146_CLIP_FORMAT_CTRL
);
2034 saawrite(0x00000000, SAA7146_ACON1
);
2035 saawrite(0x00000000, SAA7146_ACON2
);
2036 saawrite(0x00000600, SAA7146_I2C_STATUS
);
2037 saawrite(((SAA7146_MC2_UPLD_D1_B
| SAA7146_MC2_UPLD_D1_A
|
2038 SAA7146_MC2_UPLD_BRS
| SAA7146_MC2_UPLD_HPS_H
|
2039 SAA7146_MC2_UPLD_HPS_V
| SAA7146_MC2_UPLD_DMA2
|
2040 SAA7146_MC2_UPLD_DMA1
| SAA7146_MC2_UPLD_I2C
) << 16) | 0xffff,
2042 /* setup arbitration control registers */
2043 saawrite(0x1412121a, SAA7146_PCI_BT_V1
);
2045 /* allocate 32k dma buffer + 4k for page table */
2046 if ((saa
->dmadebi
= kmalloc(32768 + 4096, GFP_KERNEL
)) == NULL
) {
2047 dev_err(&pdev
->dev
, "%d: debi kmalloc failed\n", saa
->nr
);
2051 saa
->pagedebi
= saa
->dmadebi
+ 32768; /* top 4k is for mmu */
2052 saawrite(virt_to_bus(saa
->pagedebi
) /*|0x800 */ , SAA7146_DEBI_PAGE
);
2053 for (i
= 0; i
< 12; i
++) /* setup mmu page table */
2054 saa
->pagedebi
[i
] = virt_to_bus((saa
->dmadebi
+ i
* 4096));
2056 saa
->audhead
= saa
->vidhead
= saa
->osdhead
= 0;
2057 saa
->audtail
= saa
->vidtail
= saa
->osdtail
= 0;
2058 if (saa
->vidbuf
== NULL
&& (saa
->vidbuf
= vmalloc(524288)) == NULL
) {
2059 dev_err(&pdev
->dev
, "%d: malloc failed\n", saa
->nr
);
2062 if (saa
->audbuf
== NULL
&& (saa
->audbuf
= vmalloc(65536)) == NULL
) {
2063 dev_err(&pdev
->dev
, "%d: malloc failed\n", saa
->nr
);
2066 if (saa
->osdbuf
== NULL
&& (saa
->osdbuf
= vmalloc(131072)) == NULL
) {
2067 dev_err(&pdev
->dev
, "%d: malloc failed\n", saa
->nr
);
2070 /* allocate 81920 byte buffer for clipping */
2071 if ((saa
->dmavid2
= kzalloc(VIDEO_CLIPMAP_SIZE
, GFP_KERNEL
)) == NULL
) {
2072 dev_err(&pdev
->dev
, "%d: clip kmalloc failed\n", saa
->nr
);
2075 /* setup clipping registers */
2076 saawrite(virt_to_bus(saa
->dmavid2
), SAA7146_BASE_EVEN2
);
2077 saawrite(virt_to_bus(saa
->dmavid2
) + 128, SAA7146_BASE_ODD2
);
2078 saawrite(virt_to_bus(saa
->dmavid2
) + VIDEO_CLIPMAP_SIZE
,
2079 SAA7146_PROT_ADDR2
);
2080 saawrite(256, SAA7146_PITCH2
);
2081 saawrite(4, SAA7146_PAGE2
); /* dma direction: read, no byteswap */
2082 saawrite(((SAA7146_MC2_UPLD_DMA2
) << 16) | SAA7146_MC2_UPLD_DMA2
,
2091 saa
->audbuf
= saa
->osdbuf
= saa
->vidbuf
= NULL
;
2096 static void stradis_release_saa(struct pci_dev
*pdev
)
2099 struct saa7146
*saa
= pci_get_drvdata(pdev
);
2101 /* turn off all capturing, DMA and IRQs */
2102 saawrite(0xffff0000, SAA7146_MC1
); /* reset chip */
2103 saawrite(0, SAA7146_MC2
);
2104 saawrite(0, SAA7146_IER
);
2105 saawrite(0xffffffffUL
, SAA7146_ISR
);
2107 /* disable PCI bus-mastering */
2108 pci_read_config_byte(pdev
, PCI_COMMAND
, &command
);
2109 command
&= ~PCI_COMMAND_MASTER
;
2110 pci_write_config_byte(pdev
, PCI_COMMAND
, command
);
2112 /* unmap and free memory */
2113 saa
->audhead
= saa
->audtail
= saa
->osdhead
= 0;
2114 saa
->vidhead
= saa
->vidtail
= saa
->osdtail
= 0;
2118 kfree(saa
->dmavid2
);
2119 saa
->audbuf
= saa
->vidbuf
= saa
->osdbuf
= NULL
;
2120 saa
->dmavid2
= NULL
;
2121 kfree(saa
->dmadebi
);
2122 kfree(saa
->dmavid1
);
2123 kfree(saa
->dmavid3
);
2124 kfree(saa
->dmaa1in
);
2125 kfree(saa
->dmaa1out
);
2126 kfree(saa
->dmaa2in
);
2127 kfree(saa
->dmaa2out
);
2128 kfree(saa
->dmaRPS1
);
2129 kfree(saa
->dmaRPS2
);
2130 free_irq(saa
->irq
, saa
);
2131 if (saa
->saa7146_mem
)
2132 iounmap(saa
->saa7146_mem
);
2133 if (saa
->video_dev
.minor
!= -1)
2134 video_unregister_device(&saa
->video_dev
);
2137 static int __devinit
stradis_probe(struct pci_dev
*pdev
,
2138 const struct pci_device_id
*ent
)
2140 int retval
= -EINVAL
;
2142 if (saa_num
>= SAA7146_MAX
)
2145 if (!pdev
->subsystem_vendor
)
2146 dev_info(&pdev
->dev
, "%d: rev1 decoder\n", saa_num
);
2148 dev_info(&pdev
->dev
, "%d: SDM2xx found\n", saa_num
);
2150 pci_set_drvdata(pdev
, &saa7146s
[saa_num
]);
2152 retval
= configure_saa7146(pdev
, saa_num
);
2154 dev_err(&pdev
->dev
, "%d: error in configuring\n", saa_num
);
2158 if (init_saa7146(pdev
) < 0) {
2159 dev_err(&pdev
->dev
, "%d: error in initialization\n", saa_num
);
2168 stradis_release_saa(pdev
);
2173 static void __devexit
stradis_remove(struct pci_dev
*pdev
)
2175 stradis_release_saa(pdev
);
2178 static struct pci_device_id stradis_pci_tbl
[] = {
2179 { PCI_DEVICE(PCI_VENDOR_ID_PHILIPS
, PCI_DEVICE_ID_PHILIPS_SAA7146
) },
2183 MODULE_DEVICE_TABLE(pci
, stradis_pci_tbl
);
2185 static struct pci_driver stradis_driver
= {
2187 .id_table
= stradis_pci_tbl
,
2188 .probe
= stradis_probe
,
2189 .remove
= __devexit_p(stradis_remove
)
2192 int __init
stradis_init(void)
2198 retval
= pci_register_driver(&stradis_driver
);
2200 printk(KERN_ERR
"stradis: Unable to register pci driver.\n");
2205 void __exit
stradis_exit(void)
2207 pci_unregister_driver(&stradis_driver
);
2208 printk(KERN_INFO
"stradis: module cleanup complete\n");
2211 module_init(stradis_init
);
2212 module_exit(stradis_exit
);