1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * cx18 driver initialization and card probing
5 * Derived from ivtv-driver.c
7 * Copyright (C) 2007 Hans Verkuil <hverkuil@xs4all.nl>
8 * Copyright (C) 2008 Andy Walls <awalls@md.metrocast.net>
11 #include "cx18-driver.h"
13 #include "cx18-version.h"
14 #include "cx18-cards.h"
17 #include "cx18-gpio.h"
18 #include "cx18-firmware.h"
19 #include "cx18-queue.h"
20 #include "cx18-streams.h"
21 #include "cx18-av-core.h"
23 #include "cx18-mailbox.h"
24 #include "cx18-ioctl.h"
25 #include "cx18-controls.h"
27 #include <linux/dma-mapping.h>
28 #include <media/tveeprom.h>
30 /* If you have already X v4l cards, then set this to X. This way
31 the device numbers stay matched. Example: you have a WinTV card
32 without radio and a Compro H900 with. Normally this would give a
33 video1 device together with a radio0 device for the Compro. By
34 setting this to 1 you ensure that radio0 is now also radio1. */
37 /* Callback for registering extensions */
38 int (*cx18_ext_init
)(struct cx18
*);
39 EXPORT_SYMBOL(cx18_ext_init
);
41 /* add your revision and whatnot here */
42 static const struct pci_device_id cx18_pci_tbl
[] = {
43 {PCI_VENDOR_ID_CX
, PCI_DEVICE_ID_CX23418
,
44 PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, 0},
48 MODULE_DEVICE_TABLE(pci
, cx18_pci_tbl
);
50 static atomic_t cx18_instance
= ATOMIC_INIT(0);
52 /* Parameter declarations */
53 static int cardtype
[CX18_MAX_CARDS
];
54 static int tuner
[CX18_MAX_CARDS
] = { -1, -1, -1, -1, -1, -1, -1, -1,
55 -1, -1, -1, -1, -1, -1, -1, -1,
56 -1, -1, -1, -1, -1, -1, -1, -1,
57 -1, -1, -1, -1, -1, -1, -1, -1 };
58 static int radio
[CX18_MAX_CARDS
] = { -1, -1, -1, -1, -1, -1, -1, -1,
59 -1, -1, -1, -1, -1, -1, -1, -1,
60 -1, -1, -1, -1, -1, -1, -1, -1,
61 -1, -1, -1, -1, -1, -1, -1, -1 };
62 static unsigned cardtype_c
= 1;
63 static unsigned tuner_c
= 1;
64 static unsigned radio_c
= 1;
65 static char pal
[] = "--";
66 static char secam
[] = "--";
67 static char ntsc
[] = "-";
70 static int enc_ts_buffers
= CX18_DEFAULT_ENC_TS_BUFFERS
;
71 static int enc_mpg_buffers
= CX18_DEFAULT_ENC_MPG_BUFFERS
;
72 static int enc_idx_buffers
= CX18_DEFAULT_ENC_IDX_BUFFERS
;
73 static int enc_yuv_buffers
= CX18_DEFAULT_ENC_YUV_BUFFERS
;
74 static int enc_vbi_buffers
= CX18_DEFAULT_ENC_VBI_BUFFERS
;
75 static int enc_pcm_buffers
= CX18_DEFAULT_ENC_PCM_BUFFERS
;
77 static int enc_ts_bufsize
= CX18_DEFAULT_ENC_TS_BUFSIZE
;
78 static int enc_mpg_bufsize
= CX18_DEFAULT_ENC_MPG_BUFSIZE
;
79 static int enc_idx_bufsize
= CX18_DEFAULT_ENC_IDX_BUFSIZE
;
80 static int enc_yuv_bufsize
= CX18_DEFAULT_ENC_YUV_BUFSIZE
;
81 static int enc_pcm_bufsize
= CX18_DEFAULT_ENC_PCM_BUFSIZE
;
83 static int enc_ts_bufs
= -1;
84 static int enc_mpg_bufs
= -1;
85 static int enc_idx_bufs
= CX18_MAX_FW_MDLS_PER_STREAM
;
86 static int enc_yuv_bufs
= -1;
87 static int enc_vbi_bufs
= -1;
88 static int enc_pcm_bufs
= -1;
91 static int cx18_pci_latency
= 1;
93 static int mmio_ndelay
;
94 static int retry_mmio
= 1;
98 module_param_array(tuner
, int, &tuner_c
, 0644);
99 module_param_array(radio
, int, &radio_c
, 0644);
100 module_param_array(cardtype
, int, &cardtype_c
, 0644);
101 module_param_string(pal
, pal
, sizeof(pal
), 0644);
102 module_param_string(secam
, secam
, sizeof(secam
), 0644);
103 module_param_string(ntsc
, ntsc
, sizeof(ntsc
), 0644);
104 module_param_named(debug
, cx18_debug
, int, 0644);
105 module_param(mmio_ndelay
, int, 0644);
106 module_param(retry_mmio
, int, 0644);
107 module_param(cx18_pci_latency
, int, 0644);
108 module_param(cx18_first_minor
, int, 0644);
110 module_param(enc_ts_buffers
, int, 0644);
111 module_param(enc_mpg_buffers
, int, 0644);
112 module_param(enc_idx_buffers
, int, 0644);
113 module_param(enc_yuv_buffers
, int, 0644);
114 module_param(enc_vbi_buffers
, int, 0644);
115 module_param(enc_pcm_buffers
, int, 0644);
117 module_param(enc_ts_bufsize
, int, 0644);
118 module_param(enc_mpg_bufsize
, int, 0644);
119 module_param(enc_idx_bufsize
, int, 0644);
120 module_param(enc_yuv_bufsize
, int, 0644);
121 module_param(enc_pcm_bufsize
, int, 0644);
123 module_param(enc_ts_bufs
, int, 0644);
124 module_param(enc_mpg_bufs
, int, 0644);
125 module_param(enc_idx_bufs
, int, 0644);
126 module_param(enc_yuv_bufs
, int, 0644);
127 module_param(enc_vbi_bufs
, int, 0644);
128 module_param(enc_pcm_bufs
, int, 0644);
130 MODULE_PARM_DESC(tuner
, "Tuner type selection,\n"
131 "\t\t\tsee tuner.h for values");
132 MODULE_PARM_DESC(radio
,
133 "Enable or disable the radio. Use only if autodetection\n"
134 "\t\t\tfails. 0 = disable, 1 = enable");
135 MODULE_PARM_DESC(cardtype
,
136 "Only use this option if your card is not detected properly.\n"
137 "\t\tSpecify card type:\n"
138 "\t\t\t 1 = Hauppauge HVR 1600 (ESMT memory)\n"
139 "\t\t\t 2 = Hauppauge HVR 1600 (Samsung memory)\n"
140 "\t\t\t 3 = Compro VideoMate H900\n"
141 "\t\t\t 4 = Yuan MPC718\n"
142 "\t\t\t 5 = Conexant Raptor PAL/SECAM\n"
143 "\t\t\t 6 = Toshiba Qosmio DVB-T/Analog\n"
144 "\t\t\t 7 = Leadtek WinFast PVR2100\n"
145 "\t\t\t 8 = Leadtek WinFast DVR3100 H\n"
146 "\t\t\t 9 = GoTView PCI DVD3 Hybrid\n"
147 "\t\t\t 10 = Hauppauge HVR 1600 (S5H1411)\n"
148 "\t\t\t 0 = Autodetect (default)\n"
149 "\t\t\t-1 = Ignore this card\n\t\t");
150 MODULE_PARM_DESC(pal
, "Set PAL standard: B, G, H, D, K, I, M, N, Nc, 60");
151 MODULE_PARM_DESC(secam
, "Set SECAM standard: B, G, H, D, K, L, LC");
152 MODULE_PARM_DESC(ntsc
, "Set NTSC standard: M, J, K");
153 MODULE_PARM_DESC(debug
,
154 "Debug level (bitmask). Default: 0\n"
155 "\t\t\t 1/0x0001: warning\n"
156 "\t\t\t 2/0x0002: info\n"
157 "\t\t\t 4/0x0004: mailbox\n"
158 "\t\t\t 8/0x0008: dma\n"
159 "\t\t\t 16/0x0010: ioctl\n"
160 "\t\t\t 32/0x0020: file\n"
161 "\t\t\t 64/0x0040: i2c\n"
162 "\t\t\t128/0x0080: irq\n"
163 "\t\t\t256/0x0100: high volume\n");
164 MODULE_PARM_DESC(cx18_pci_latency
,
165 "Change the PCI latency to 64 if lower: 0 = No, 1 = Yes,\n"
166 "\t\t\tDefault: Yes");
167 MODULE_PARM_DESC(retry_mmio
,
168 "(Deprecated) MMIO writes are now always checked and retried\n"
169 "\t\t\tEffectively: 1 [Yes]");
170 MODULE_PARM_DESC(mmio_ndelay
,
171 "(Deprecated) MMIO accesses are now never purposely delayed\n"
172 "\t\t\tEffectively: 0 ns");
173 MODULE_PARM_DESC(enc_ts_buffers
,
174 "Encoder TS buffer memory (MB). (enc_ts_bufs can override)\n"
175 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_TS_BUFFERS
));
176 MODULE_PARM_DESC(enc_ts_bufsize
,
177 "Size of an encoder TS buffer (kB)\n"
178 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_TS_BUFSIZE
));
179 MODULE_PARM_DESC(enc_ts_bufs
,
180 "Number of encoder TS buffers\n"
181 "\t\t\tDefault is computed from other enc_ts_* parameters");
182 MODULE_PARM_DESC(enc_mpg_buffers
,
183 "Encoder MPG buffer memory (MB). (enc_mpg_bufs can override)\n"
184 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_MPG_BUFFERS
));
185 MODULE_PARM_DESC(enc_mpg_bufsize
,
186 "Size of an encoder MPG buffer (kB)\n"
187 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_MPG_BUFSIZE
));
188 MODULE_PARM_DESC(enc_mpg_bufs
,
189 "Number of encoder MPG buffers\n"
190 "\t\t\tDefault is computed from other enc_mpg_* parameters");
191 MODULE_PARM_DESC(enc_idx_buffers
,
192 "(Deprecated) Encoder IDX buffer memory (MB)\n"
193 "\t\t\tIgnored, except 0 disables IDX buffer allocations\n"
194 "\t\t\tDefault: 1 [Enabled]");
195 MODULE_PARM_DESC(enc_idx_bufsize
,
196 "Size of an encoder IDX buffer (kB)\n"
197 "\t\t\tAllowed values are multiples of 1.5 kB rounded up\n"
198 "\t\t\t(multiples of size required for 64 index entries)\n"
200 MODULE_PARM_DESC(enc_idx_bufs
,
201 "Number of encoder IDX buffers\n"
202 "\t\t\tDefault: " __stringify(CX18_MAX_FW_MDLS_PER_STREAM
));
203 MODULE_PARM_DESC(enc_yuv_buffers
,
204 "Encoder YUV buffer memory (MB). (enc_yuv_bufs can override)\n"
205 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_YUV_BUFFERS
));
206 MODULE_PARM_DESC(enc_yuv_bufsize
,
207 "Size of an encoder YUV buffer (kB)\n"
208 "\t\t\tAllowed values are multiples of 33.75 kB rounded up\n"
209 "\t\t\t(multiples of size required for 32 screen lines)\n"
210 "\t\t\tDefault: 102");
211 MODULE_PARM_DESC(enc_yuv_bufs
,
212 "Number of encoder YUV buffers\n"
213 "\t\t\tDefault is computed from other enc_yuv_* parameters");
214 MODULE_PARM_DESC(enc_vbi_buffers
,
215 "Encoder VBI buffer memory (MB). (enc_vbi_bufs can override)\n"
216 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_VBI_BUFFERS
));
217 MODULE_PARM_DESC(enc_vbi_bufs
,
218 "Number of encoder VBI buffers\n"
219 "\t\t\tDefault is computed from enc_vbi_buffers");
220 MODULE_PARM_DESC(enc_pcm_buffers
,
221 "Encoder PCM buffer memory (MB). (enc_pcm_bufs can override)\n"
222 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_PCM_BUFFERS
));
223 MODULE_PARM_DESC(enc_pcm_bufsize
,
224 "Size of an encoder PCM buffer (kB)\n"
225 "\t\t\tDefault: " __stringify(CX18_DEFAULT_ENC_PCM_BUFSIZE
));
226 MODULE_PARM_DESC(enc_pcm_bufs
,
227 "Number of encoder PCM buffers\n"
228 "\t\t\tDefault is computed from other enc_pcm_* parameters");
230 MODULE_PARM_DESC(cx18_first_minor
,
231 "Set device node number assigned to first card");
233 MODULE_AUTHOR("Hans Verkuil");
234 MODULE_DESCRIPTION("CX23418 driver");
235 MODULE_LICENSE("GPL");
237 MODULE_VERSION(CX18_VERSION
);
239 #if defined(CONFIG_MODULES) && defined(MODULE)
240 static void request_module_async(struct work_struct
*work
)
242 struct cx18
*dev
= container_of(work
, struct cx18
, request_module_wk
);
244 /* Make sure cx18-alsa module is loaded */
245 request_module("cx18-alsa");
247 /* Initialize cx18-alsa for this instance of the cx18 device */
252 static void request_modules(struct cx18
*dev
)
254 INIT_WORK(&dev
->request_module_wk
, request_module_async
);
255 schedule_work(&dev
->request_module_wk
);
258 static void flush_request_modules(struct cx18
*dev
)
260 flush_work(&dev
->request_module_wk
);
263 #define request_modules(dev)
264 #define flush_request_modules(dev)
265 #endif /* CONFIG_MODULES */
267 /* Generic utility functions */
268 int cx18_msleep_timeout(unsigned int msecs
, int intr
)
270 long int timeout
= msecs_to_jiffies(msecs
);
274 set_current_state(intr
? TASK_INTERRUPTIBLE
: TASK_UNINTERRUPTIBLE
);
275 timeout
= schedule_timeout(timeout
);
276 sig
= intr
? signal_pending(current
) : 0;
277 } while (!sig
&& timeout
);
281 /* Release ioremapped memory */
282 static void cx18_iounmap(struct cx18
*cx
)
287 /* Release io memory */
289 CX18_DEBUG_INFO("releasing enc_mem\n");
290 iounmap(cx
->enc_mem
);
295 static void cx18_eeprom_dump(struct cx18
*cx
, unsigned char *eedata
, int len
)
299 CX18_INFO("eeprom dump:\n");
300 for (i
= 0; i
< len
; i
++) {
302 CX18_INFO("eeprom %02x:", i
);
303 printk(KERN_CONT
" %02x", eedata
[i
]);
305 printk(KERN_CONT
"\n");
309 /* Hauppauge card? get values from tveeprom */
310 void cx18_read_eeprom(struct cx18
*cx
, struct tveeprom
*tv
)
312 struct i2c_client
*c
;
315 memset(tv
, 0, sizeof(*tv
));
317 c
= kzalloc(sizeof(*c
), GFP_KERNEL
);
321 strscpy(c
->name
, "cx18 tveeprom tmp", sizeof(c
->name
));
322 c
->adapter
= &cx
->i2c_adap
[0];
325 if (tveeprom_read(c
, eedata
, sizeof(eedata
)))
328 switch (cx
->card
->type
) {
329 case CX18_CARD_HVR_1600_ESMT
:
330 case CX18_CARD_HVR_1600_SAMSUNG
:
331 case CX18_CARD_HVR_1600_S5H1411
:
332 tveeprom_hauppauge_analog(tv
, eedata
);
334 case CX18_CARD_YUAN_MPC718
:
335 case CX18_CARD_GOTVIEW_PCI_DVD3
:
337 cx18_eeprom_dump(cx
, eedata
, sizeof(eedata
));
338 CX18_INFO("eeprom PCI ID: %02x%02x:%02x%02x\n",
339 eedata
[2], eedata
[1], eedata
[4], eedata
[3]);
342 tv
->model
= 0xffffffff;
343 cx18_eeprom_dump(cx
, eedata
, sizeof(eedata
));
351 static void cx18_process_eeprom(struct cx18
*cx
)
355 cx18_read_eeprom(cx
, &tv
);
357 /* Many thanks to Steven Toth from Hauppauge for providing the
359 /* Note: the Samsung memory models cannot be reliably determined
360 from the model number. Use the cardtype module option if you
361 have one of these preproduction models. */
363 case 74301: /* Retail models */
365 case 74351: /* OEM models */
367 /* Digital side is s5h1411/tda18271 */
368 cx
->card
= cx18_get_card(CX18_CARD_HVR_1600_S5H1411
);
370 case 74021: /* Retail models */
374 case 74541: /* OEM models */
381 /* Digital side is s5h1409/mxl5005s */
382 cx
->card
= cx18_get_card(CX18_CARD_HVR_1600_ESMT
);
387 CX18_INFO("Unknown EEPROM encoding\n");
390 CX18_ERR("Invalid EEPROM\n");
393 CX18_ERR("Unknown model %d, defaulting to original HVR-1600 (cardtype=1)\n",
395 cx
->card
= cx18_get_card(CX18_CARD_HVR_1600_ESMT
);
399 cx
->v4l2_cap
= cx
->card
->v4l2_capabilities
;
400 cx
->card_name
= cx
->card
->name
;
401 cx
->card_i2c
= cx
->card
->i2c
;
403 CX18_INFO("Autodetected %s\n", cx
->card_name
);
405 if (tv
.tuner_type
== TUNER_ABSENT
)
406 CX18_ERR("tveeprom cannot autodetect tuner!\n");
408 if (cx
->options
.tuner
== -1)
409 cx
->options
.tuner
= tv
.tuner_type
;
410 if (cx
->options
.radio
== -1)
411 cx
->options
.radio
= (tv
.has_radio
!= 0);
414 /* user specified tuner standard */
417 /* autodetect tuner standard */
418 #define TVEEPROM_TUNER_FORMAT_ALL (V4L2_STD_B | V4L2_STD_GH | \
421 V4L2_STD_SECAM_L | V4L2_STD_SECAM_LC | \
423 if ((tv
.tuner_formats
& TVEEPROM_TUNER_FORMAT_ALL
)
424 == TVEEPROM_TUNER_FORMAT_ALL
) {
425 CX18_DEBUG_INFO("Worldwide tuner detected\n");
426 cx
->std
= V4L2_STD_ALL
;
427 } else if (tv
.tuner_formats
& V4L2_STD_PAL
) {
428 CX18_DEBUG_INFO("PAL tuner detected\n");
429 cx
->std
|= V4L2_STD_PAL_BG
| V4L2_STD_PAL_H
;
430 } else if (tv
.tuner_formats
& V4L2_STD_NTSC
) {
431 CX18_DEBUG_INFO("NTSC tuner detected\n");
432 cx
->std
|= V4L2_STD_NTSC_M
;
433 } else if (tv
.tuner_formats
& V4L2_STD_SECAM
) {
434 CX18_DEBUG_INFO("SECAM tuner detected\n");
435 cx
->std
|= V4L2_STD_SECAM_L
;
437 CX18_INFO("No tuner detected, default to NTSC-M\n");
438 cx
->std
|= V4L2_STD_NTSC_M
;
442 static v4l2_std_id
cx18_parse_std(struct cx18
*cx
)
446 return V4L2_STD_PAL_60
;
451 return V4L2_STD_PAL_BG
;
454 return V4L2_STD_PAL_H
;
457 if (pal
[1] == 'c' || pal
[1] == 'C')
458 return V4L2_STD_PAL_Nc
;
459 return V4L2_STD_PAL_N
;
462 return V4L2_STD_PAL_I
;
467 return V4L2_STD_PAL_DK
;
470 return V4L2_STD_PAL_M
;
474 CX18_WARN("pal= argument not recognised\n");
485 return V4L2_STD_SECAM_B
| V4L2_STD_SECAM_G
| V4L2_STD_SECAM_H
;
490 return V4L2_STD_SECAM_DK
;
493 if (secam
[1] == 'C' || secam
[1] == 'c')
494 return V4L2_STD_SECAM_LC
;
495 return V4L2_STD_SECAM_L
;
499 CX18_WARN("secam= argument not recognised\n");
506 return V4L2_STD_NTSC_M
;
509 return V4L2_STD_NTSC_M_JP
;
512 return V4L2_STD_NTSC_M_KR
;
516 CX18_WARN("ntsc= argument not recognised\n");
524 static void cx18_process_options(struct cx18
*cx
)
528 cx
->options
.megabytes
[CX18_ENC_STREAM_TYPE_TS
] = enc_ts_buffers
;
529 cx
->options
.megabytes
[CX18_ENC_STREAM_TYPE_MPG
] = enc_mpg_buffers
;
530 cx
->options
.megabytes
[CX18_ENC_STREAM_TYPE_IDX
] = enc_idx_buffers
;
531 cx
->options
.megabytes
[CX18_ENC_STREAM_TYPE_YUV
] = enc_yuv_buffers
;
532 cx
->options
.megabytes
[CX18_ENC_STREAM_TYPE_VBI
] = enc_vbi_buffers
;
533 cx
->options
.megabytes
[CX18_ENC_STREAM_TYPE_PCM
] = enc_pcm_buffers
;
534 cx
->options
.megabytes
[CX18_ENC_STREAM_TYPE_RAD
] = 0; /* control only */
536 cx
->stream_buffers
[CX18_ENC_STREAM_TYPE_TS
] = enc_ts_bufs
;
537 cx
->stream_buffers
[CX18_ENC_STREAM_TYPE_MPG
] = enc_mpg_bufs
;
538 cx
->stream_buffers
[CX18_ENC_STREAM_TYPE_IDX
] = enc_idx_bufs
;
539 cx
->stream_buffers
[CX18_ENC_STREAM_TYPE_YUV
] = enc_yuv_bufs
;
540 cx
->stream_buffers
[CX18_ENC_STREAM_TYPE_VBI
] = enc_vbi_bufs
;
541 cx
->stream_buffers
[CX18_ENC_STREAM_TYPE_PCM
] = enc_pcm_bufs
;
542 cx
->stream_buffers
[CX18_ENC_STREAM_TYPE_RAD
] = 0; /* control, no data */
544 cx
->stream_buf_size
[CX18_ENC_STREAM_TYPE_TS
] = enc_ts_bufsize
;
545 cx
->stream_buf_size
[CX18_ENC_STREAM_TYPE_MPG
] = enc_mpg_bufsize
;
546 cx
->stream_buf_size
[CX18_ENC_STREAM_TYPE_IDX
] = enc_idx_bufsize
;
547 cx
->stream_buf_size
[CX18_ENC_STREAM_TYPE_YUV
] = enc_yuv_bufsize
;
548 cx
->stream_buf_size
[CX18_ENC_STREAM_TYPE_VBI
] = VBI_ACTIVE_SAMPLES
* 36;
549 cx
->stream_buf_size
[CX18_ENC_STREAM_TYPE_PCM
] = enc_pcm_bufsize
;
550 cx
->stream_buf_size
[CX18_ENC_STREAM_TYPE_RAD
] = 0; /* control no data */
552 /* Ensure stream_buffers & stream_buf_size are valid */
553 for (i
= 0; i
< CX18_MAX_STREAMS
; i
++) {
554 if (cx
->stream_buffers
[i
] == 0 || /* User said 0 buffers */
555 cx
->options
.megabytes
[i
] <= 0 || /* User said 0 MB total */
556 cx
->stream_buf_size
[i
] <= 0) { /* User said buf size 0 */
557 cx
->options
.megabytes
[i
] = 0;
558 cx
->stream_buffers
[i
] = 0;
559 cx
->stream_buf_size
[i
] = 0;
563 * YUV is a special case where the stream_buf_size needs to be
564 * an integral multiple of 33.75 kB (storage for 32 screens
565 * lines to maintain alignment in case of lost buffers).
567 * IDX is a special case where the stream_buf_size should be
568 * an integral multiple of 1.5 kB (storage for 64 index entries
569 * to maintain alignment in case of lost buffers).
572 if (i
== CX18_ENC_STREAM_TYPE_YUV
) {
573 cx
->stream_buf_size
[i
] *= 1024;
574 cx
->stream_buf_size
[i
] -=
575 (cx
->stream_buf_size
[i
] % CX18_UNIT_ENC_YUV_BUFSIZE
);
577 if (cx
->stream_buf_size
[i
] < CX18_UNIT_ENC_YUV_BUFSIZE
)
578 cx
->stream_buf_size
[i
] =
579 CX18_UNIT_ENC_YUV_BUFSIZE
;
580 } else if (i
== CX18_ENC_STREAM_TYPE_IDX
) {
581 cx
->stream_buf_size
[i
] *= 1024;
582 cx
->stream_buf_size
[i
] -=
583 (cx
->stream_buf_size
[i
] % CX18_UNIT_ENC_IDX_BUFSIZE
);
585 if (cx
->stream_buf_size
[i
] < CX18_UNIT_ENC_IDX_BUFSIZE
)
586 cx
->stream_buf_size
[i
] =
587 CX18_UNIT_ENC_IDX_BUFSIZE
;
590 * YUV and IDX are special cases where the stream_buf_size is
592 * VBI is a special case where the stream_buf_size is fixed
593 * and already in bytes
595 if (i
== CX18_ENC_STREAM_TYPE_VBI
||
596 i
== CX18_ENC_STREAM_TYPE_YUV
||
597 i
== CX18_ENC_STREAM_TYPE_IDX
) {
598 if (cx
->stream_buffers
[i
] < 0) {
599 cx
->stream_buffers
[i
] =
600 cx
->options
.megabytes
[i
] * 1024 * 1024
601 / cx
->stream_buf_size
[i
];
603 /* N.B. This might round down to 0 */
604 cx
->options
.megabytes
[i
] =
605 cx
->stream_buffers
[i
]
606 * cx
->stream_buf_size
[i
]/(1024 * 1024);
609 /* All other streams have stream_buf_size in kB here */
610 if (cx
->stream_buffers
[i
] < 0) {
611 cx
->stream_buffers
[i
] =
612 cx
->options
.megabytes
[i
] * 1024
613 / cx
->stream_buf_size
[i
];
615 /* N.B. This might round down to 0 */
616 cx
->options
.megabytes
[i
] =
617 cx
->stream_buffers
[i
]
618 * cx
->stream_buf_size
[i
] / 1024;
620 /* convert from kB to bytes */
621 cx
->stream_buf_size
[i
] *= 1024;
623 CX18_DEBUG_INFO("Stream type %d options: %d MB, %d buffers, %d bytes\n",
624 i
, cx
->options
.megabytes
[i
],
625 cx
->stream_buffers
[i
], cx
->stream_buf_size
[i
]);
628 cx
->options
.cardtype
= cardtype
[cx
->instance
];
629 cx
->options
.tuner
= tuner
[cx
->instance
];
630 cx
->options
.radio
= radio
[cx
->instance
];
632 cx
->std
= cx18_parse_std(cx
);
633 if (cx
->options
.cardtype
== -1) {
634 CX18_INFO("Ignore card\n");
637 cx
->card
= cx18_get_card(cx
->options
.cardtype
- 1);
639 CX18_INFO("User specified %s card\n", cx
->card
->name
);
640 else if (cx
->options
.cardtype
!= 0)
641 CX18_ERR("Unknown user specified type, trying to autodetect card\n");
643 if (cx
->pci_dev
->subsystem_vendor
== CX18_PCI_ID_HAUPPAUGE
) {
644 cx
->card
= cx18_get_card(CX18_CARD_HVR_1600_ESMT
);
645 CX18_INFO("Autodetected Hauppauge card\n");
649 for (i
= 0; (cx
->card
= cx18_get_card(i
)); i
++) {
650 if (!cx
->card
->pci_list
)
652 for (j
= 0; cx
->card
->pci_list
[j
].device
; j
++) {
653 if (cx
->pci_dev
->device
!=
654 cx
->card
->pci_list
[j
].device
)
656 if (cx
->pci_dev
->subsystem_vendor
!=
657 cx
->card
->pci_list
[j
].subsystem_vendor
)
659 if (cx
->pci_dev
->subsystem_device
!=
660 cx
->card
->pci_list
[j
].subsystem_device
)
662 CX18_INFO("Autodetected %s card\n", cx
->card
->name
);
670 cx
->card
= cx18_get_card(CX18_CARD_HVR_1600_ESMT
);
671 CX18_ERR("Unknown card: vendor/device: [%04x:%04x]\n",
672 cx
->pci_dev
->vendor
, cx
->pci_dev
->device
);
673 CX18_ERR(" subsystem vendor/device: [%04x:%04x]\n",
674 cx
->pci_dev
->subsystem_vendor
,
675 cx
->pci_dev
->subsystem_device
);
676 CX18_ERR("Defaulting to %s card\n", cx
->card
->name
);
677 CX18_ERR("Please mail the vendor/device and subsystem vendor/device IDs and what kind of\n");
678 CX18_ERR("card you have to the linux-media mailinglist (www.linuxtv.org)\n");
679 CX18_ERR("Prefix your subject line with [UNKNOWN CX18 CARD].\n");
681 cx
->v4l2_cap
= cx
->card
->v4l2_capabilities
;
682 cx
->card_name
= cx
->card
->name
;
683 cx
->card_i2c
= cx
->card
->i2c
;
686 static int cx18_create_in_workq(struct cx18
*cx
)
688 snprintf(cx
->in_workq_name
, sizeof(cx
->in_workq_name
), "%s-in",
690 cx
->in_work_queue
= alloc_ordered_workqueue("%s", 0, cx
->in_workq_name
);
691 if (!cx
->in_work_queue
) {
692 CX18_ERR("Unable to create incoming mailbox handler thread\n");
698 static void cx18_init_in_work_orders(struct cx18
*cx
)
701 for (i
= 0; i
< CX18_MAX_IN_WORK_ORDERS
; i
++) {
702 cx
->in_work_order
[i
].cx
= cx
;
703 cx
->in_work_order
[i
].str
= cx
->epu_debug_str
;
704 INIT_WORK(&cx
->in_work_order
[i
].work
, cx18_in_work_handler
);
708 /* Precondition: the cx18 structure has been memset to 0. Only
709 the dev and instance fields have been filled in.
710 No assumptions on the card type may be made here (see cx18_init_struct2
713 static int cx18_init_struct1(struct cx18
*cx
)
717 cx
->base_addr
= pci_resource_start(cx
->pci_dev
, 0);
719 mutex_init(&cx
->serialize_lock
);
720 mutex_init(&cx
->gpio_lock
);
721 mutex_init(&cx
->epu2apu_mb_lock
);
722 mutex_init(&cx
->epu2cpu_mb_lock
);
724 ret
= cx18_create_in_workq(cx
);
728 cx18_init_in_work_orders(cx
);
730 /* start counting open_id at 1 */
733 /* Initial settings */
734 cx
->cxhdl
.port
= CX2341X_PORT_MEMORY
;
735 cx
->cxhdl
.capabilities
= CX2341X_CAP_HAS_TS
| CX2341X_CAP_HAS_SLICED_VBI
;
736 cx
->cxhdl
.ops
= &cx18_cxhdl_ops
;
737 cx
->cxhdl
.func
= cx18_api_func
;
738 cx
->cxhdl
.priv
= &cx
->streams
[CX18_ENC_STREAM_TYPE_MPG
];
739 ret
= cx2341x_handler_init(&cx
->cxhdl
, 50);
742 cx
->v4l2_dev
.ctrl_handler
= &cx
->cxhdl
.hdl
;
744 cx
->temporal_strength
= cx
->cxhdl
.video_temporal_filter
->cur
.val
;
745 cx
->spatial_strength
= cx
->cxhdl
.video_spatial_filter
->cur
.val
;
746 cx
->filter_mode
= cx
->cxhdl
.video_spatial_filter_mode
->cur
.val
|
747 (cx
->cxhdl
.video_temporal_filter_mode
->cur
.val
<< 1) |
748 (cx
->cxhdl
.video_median_filter_type
->cur
.val
<< 2);
750 init_waitqueue_head(&cx
->cap_w
);
751 init_waitqueue_head(&cx
->mb_apu_waitq
);
752 init_waitqueue_head(&cx
->mb_cpu_waitq
);
753 init_waitqueue_head(&cx
->dma_waitq
);
756 cx
->vbi
.in
.type
= V4L2_BUF_TYPE_VBI_CAPTURE
;
757 cx
->vbi
.sliced_in
= &cx
->vbi
.in
.fmt
.sliced
;
759 /* IVTV style VBI insertion into MPEG streams */
760 INIT_LIST_HEAD(&cx
->vbi
.sliced_mpeg_buf
.list
);
761 INIT_LIST_HEAD(&cx
->vbi
.sliced_mpeg_mdl
.list
);
762 INIT_LIST_HEAD(&cx
->vbi
.sliced_mpeg_mdl
.buf_list
);
763 list_add(&cx
->vbi
.sliced_mpeg_buf
.list
,
764 &cx
->vbi
.sliced_mpeg_mdl
.buf_list
);
768 /* Second initialization part. Here the card type has been
770 static void cx18_init_struct2(struct cx18
*cx
)
774 for (i
= 0; i
< CX18_CARD_MAX_VIDEO_INPUTS
; i
++)
775 if (cx
->card
->video_inputs
[i
].video_type
== 0)
778 for (i
= 0; i
< CX18_CARD_MAX_AUDIO_INPUTS
; i
++)
779 if (cx
->card
->audio_inputs
[i
].audio_type
== 0)
781 cx
->nof_audio_inputs
= i
;
783 /* Find tuner input */
784 for (i
= 0; i
< cx
->nof_inputs
; i
++) {
785 if (cx
->card
->video_inputs
[i
].video_type
==
786 CX18_CARD_INPUT_VID_TUNER
)
789 if (i
== cx
->nof_inputs
)
791 cx
->active_input
= i
;
792 cx
->audio_input
= cx
->card
->video_inputs
[i
].audio_index
;
795 static int cx18_setup_pci(struct cx18
*cx
, struct pci_dev
*pci_dev
,
796 const struct pci_device_id
*pci_id
)
799 unsigned char pci_latency
;
801 CX18_DEBUG_INFO("Enabling pci device\n");
803 if (pci_enable_device(pci_dev
)) {
804 CX18_ERR("Can't enable device %d!\n", cx
->instance
);
807 if (dma_set_mask(&pci_dev
->dev
, DMA_BIT_MASK(32))) {
808 CX18_ERR("No suitable DMA available, card %d\n", cx
->instance
);
811 if (!request_mem_region(cx
->base_addr
, CX18_MEM_SIZE
, "cx18 encoder")) {
812 CX18_ERR("Cannot request encoder memory region, card %d\n",
817 /* Enable bus mastering and memory mapped IO for the CX23418 */
818 pci_read_config_word(pci_dev
, PCI_COMMAND
, &cmd
);
819 cmd
|= PCI_COMMAND_MEMORY
| PCI_COMMAND_MASTER
;
820 pci_write_config_word(pci_dev
, PCI_COMMAND
, cmd
);
822 cx
->card_rev
= pci_dev
->revision
;
823 pci_read_config_byte(pci_dev
, PCI_LATENCY_TIMER
, &pci_latency
);
825 if (pci_latency
< 64 && cx18_pci_latency
) {
826 CX18_INFO("Unreasonably low latency timer, setting to 64 (was %d)\n",
828 pci_write_config_byte(pci_dev
, PCI_LATENCY_TIMER
, 64);
829 pci_read_config_byte(pci_dev
, PCI_LATENCY_TIMER
, &pci_latency
);
832 CX18_DEBUG_INFO("cx%d (rev %d) at %02x:%02x.%x, irq: %d, latency: %d, memory: 0x%llx\n",
833 cx
->pci_dev
->device
, cx
->card_rev
, pci_dev
->bus
->number
,
834 PCI_SLOT(pci_dev
->devfn
), PCI_FUNC(pci_dev
->devfn
),
835 cx
->pci_dev
->irq
, pci_latency
, (u64
)cx
->base_addr
);
840 static void cx18_init_subdevs(struct cx18
*cx
)
842 u32 hw
= cx
->card
->hw_all
;
846 for (i
= 0, device
= 1; i
< 32; i
++, device
<<= 1) {
853 case CX18_HW_TVEEPROM
:
854 /* These subordinate devices do not use probing */
855 cx
->hw_flags
|= device
;
858 /* The A/V decoder gets probed earlier to set PLLs */
859 /* Just note that the card uses it (i.e. has analog) */
860 cx
->hw_flags
|= device
;
862 case CX18_HW_GPIO_RESET_CTRL
:
864 * The Reset Controller gets probed and added to
865 * hw_flags earlier for i2c adapter/bus initialization
868 case CX18_HW_GPIO_MUX
:
869 if (cx18_gpio_register(cx
, device
) == 0)
870 cx
->hw_flags
|= device
;
873 if (cx18_i2c_register(cx
, i
) == 0)
874 cx
->hw_flags
|= device
;
879 if (cx
->hw_flags
& CX18_HW_418_AV
)
880 cx
->sd_av
= cx18_find_hw(cx
, CX18_HW_418_AV
);
882 if (cx
->card
->hw_muxer
!= 0)
883 cx
->sd_extmux
= cx18_find_hw(cx
, cx
->card
->hw_muxer
);
886 static int cx18_probe(struct pci_dev
*pci_dev
,
887 const struct pci_device_id
*pci_id
)
894 /* FIXME - module parameter arrays constrain max instances */
895 i
= atomic_inc_return(&cx18_instance
) - 1;
896 if (i
>= CX18_MAX_CARDS
) {
897 printk(KERN_ERR
"cx18: cannot manage card %d, driver has a limit of 0 - %d\n",
898 i
, CX18_MAX_CARDS
- 1);
902 cx
= kzalloc(sizeof(*cx
), GFP_KERNEL
);
906 cx
->pci_dev
= pci_dev
;
909 retval
= v4l2_device_register(&pci_dev
->dev
, &cx
->v4l2_dev
);
911 printk(KERN_ERR
"cx18: v4l2_device_register of card %d failed\n",
916 snprintf(cx
->v4l2_dev
.name
, sizeof(cx
->v4l2_dev
.name
), "cx18-%d",
918 CX18_INFO("Initializing card %d\n", cx
->instance
);
920 cx18_process_options(cx
);
921 if (cx
->options
.cardtype
== -1) {
926 retval
= cx18_init_struct1(cx
);
930 CX18_DEBUG_INFO("base addr: 0x%llx\n", (u64
)cx
->base_addr
);
932 /* PCI Device Setup */
933 retval
= cx18_setup_pci(cx
, pci_dev
, pci_id
);
935 goto free_workqueues
;
938 CX18_DEBUG_INFO("attempting ioremap at 0x%llx len 0x%08x\n",
939 (u64
)cx
->base_addr
+ CX18_MEM_OFFSET
, CX18_MEM_SIZE
);
940 cx
->enc_mem
= ioremap(cx
->base_addr
+ CX18_MEM_OFFSET
,
943 CX18_ERR("ioremap failed. Can't get a window into CX23418 memory and register space\n");
944 CX18_ERR("Each capture card with a CX23418 needs 64 MB of vmalloc address space for the window\n");
945 CX18_ERR("Check the output of 'grep Vmalloc /proc/meminfo'\n");
946 CX18_ERR("Use the vmalloc= kernel command line option to set VmallocTotal to a larger value\n");
950 cx
->reg_mem
= cx
->enc_mem
+ CX18_REG_OFFSET
;
951 devtype
= cx18_read_reg(cx
, 0xC72028);
952 switch (devtype
& 0xff000000) {
954 CX18_INFO("cx23418 revision %08x (A)\n", devtype
);
957 CX18_INFO("cx23418 revision %08x (B)\n", devtype
);
960 CX18_INFO("cx23418 revision %08x (Unknown)\n", devtype
);
964 cx18_init_power(cx
, 1);
965 cx18_init_memory(cx
);
967 cx
->scb
= (struct cx18_scb __iomem
*)(cx
->enc_mem
+ SCB_OFFSET
);
972 /* Initialize integrated A/V decoder early to set PLLs, just in case */
973 retval
= cx18_av_probe(cx
);
975 CX18_ERR("Could not register A/V decoder subdevice\n");
979 /* Initialize GPIO Reset Controller to do chip resets during i2c init */
980 if (cx
->card
->hw_all
& CX18_HW_GPIO_RESET_CTRL
) {
981 if (cx18_gpio_register(cx
, CX18_HW_GPIO_RESET_CTRL
) != 0)
982 CX18_WARN("Could not register GPIO reset controllersubdevice; proceeding anyway.\n");
984 cx
->hw_flags
|= CX18_HW_GPIO_RESET_CTRL
;
988 CX18_DEBUG_INFO("activating i2c...\n");
989 retval
= init_cx18_i2c(cx
);
991 CX18_ERR("Could not initialize i2c\n");
995 if (cx
->card
->hw_all
& CX18_HW_TVEEPROM
) {
996 /* Based on the model number the cardtype may be changed.
997 The PCI IDs are not always reliable. */
998 const struct cx18_card
*orig_card
= cx
->card
;
999 cx18_process_eeprom(cx
);
1001 if (cx
->card
!= orig_card
) {
1002 /* Changed the cardtype; re-reset the I2C chips */
1004 cx18_call_hw(cx
, CX18_HW_GPIO_RESET_CTRL
,
1005 core
, reset
, (u32
) CX18_GPIO_RESET_I2C
);
1008 if (cx
->card
->comment
)
1009 CX18_INFO("%s", cx
->card
->comment
);
1010 if (cx
->card
->v4l2_capabilities
== 0) {
1014 cx18_init_memory(cx
);
1018 retval
= request_irq(cx
->pci_dev
->irq
, cx18_irq_handler
,
1019 IRQF_SHARED
, cx
->v4l2_dev
.name
, (void *)cx
);
1021 CX18_ERR("Failed to register irq %d\n", retval
);
1026 cx
->std
= V4L2_STD_NTSC_M
;
1028 if (cx
->options
.tuner
== -1) {
1029 for (i
= 0; i
< CX18_CARD_MAX_TUNERS
; i
++) {
1030 if ((cx
->std
& cx
->card
->tuners
[i
].std
) == 0)
1032 cx
->options
.tuner
= cx
->card
->tuners
[i
].tuner
;
1036 /* if no tuner was found, then pick the first tuner in the card list */
1037 if (cx
->options
.tuner
== -1 && cx
->card
->tuners
[0].std
) {
1038 cx
->std
= cx
->card
->tuners
[0].std
;
1039 if (cx
->std
& V4L2_STD_PAL
)
1040 cx
->std
= V4L2_STD_PAL_BG
| V4L2_STD_PAL_H
;
1041 else if (cx
->std
& V4L2_STD_NTSC
)
1042 cx
->std
= V4L2_STD_NTSC_M
;
1043 else if (cx
->std
& V4L2_STD_SECAM
)
1044 cx
->std
= V4L2_STD_SECAM_L
;
1045 cx
->options
.tuner
= cx
->card
->tuners
[0].tuner
;
1047 if (cx
->options
.radio
== -1)
1048 cx
->options
.radio
= (cx
->card
->radio_input
.audio_type
!= 0);
1050 /* The card is now fully identified, continue with card-specific
1052 cx18_init_struct2(cx
);
1054 cx18_init_subdevs(cx
);
1056 if (cx
->std
& V4L2_STD_525_60
)
1061 cx2341x_handler_set_50hz(&cx
->cxhdl
, !cx
->is_60hz
);
1063 if (cx
->options
.radio
> 0)
1064 cx
->v4l2_cap
|= V4L2_CAP_RADIO
;
1066 if (cx
->options
.tuner
> -1) {
1067 struct tuner_setup setup
;
1069 setup
.addr
= ADDR_UNSET
;
1070 setup
.type
= cx
->options
.tuner
;
1071 setup
.mode_mask
= T_ANALOG_TV
; /* matches TV tuners */
1072 setup
.config
= NULL
;
1073 if (cx
->options
.radio
> 0)
1074 setup
.mode_mask
|= T_RADIO
;
1075 setup
.tuner_callback
= (setup
.type
== TUNER_XC2028
) ?
1076 cx18_reset_tuner_gpio
: NULL
;
1077 cx18_call_all(cx
, tuner
, s_type_addr
, &setup
);
1078 if (setup
.type
== TUNER_XC2028
) {
1079 static struct xc2028_ctrl ctrl
= {
1080 .fname
= XC2028_DEFAULT_FIRMWARE
,
1083 struct v4l2_priv_tun_config cfg
= {
1084 .tuner
= cx
->options
.tuner
,
1087 cx18_call_all(cx
, tuner
, s_config
, &cfg
);
1091 /* The tuner is fixed to the standard. The other inputs (e.g. S-Video)
1093 cx
->tuner_std
= cx
->std
;
1094 if (cx
->std
== V4L2_STD_ALL
)
1095 cx
->std
= V4L2_STD_NTSC_M
;
1097 retval
= cx18_streams_setup(cx
);
1099 CX18_ERR("Error %d setting up streams\n", retval
);
1102 retval
= cx18_streams_register(cx
);
1104 CX18_ERR("Error %d registering devices\n", retval
);
1108 CX18_INFO("Initialized card: %s\n", cx
->card_name
);
1110 /* Load cx18 submodules (cx18-alsa) */
1111 request_modules(cx
);
1115 cx18_streams_cleanup(cx
, 1);
1117 free_irq(cx
->pci_dev
->irq
, (void *)cx
);
1123 release_mem_region(cx
->base_addr
, CX18_MEM_SIZE
);
1125 destroy_workqueue(cx
->in_work_queue
);
1127 CX18_ERR("Error %d on initialization\n", retval
);
1129 v4l2_device_unregister(&cx
->v4l2_dev
);
1134 int cx18_init_on_first_open(struct cx18
*cx
)
1137 int fw_retry_count
= 3;
1138 struct v4l2_frequency vf
;
1139 struct cx18_open_id fh
;
1144 if (test_bit(CX18_F_I_FAILED
, &cx
->i_flags
))
1147 if (test_and_set_bit(CX18_F_I_INITED
, &cx
->i_flags
))
1150 while (--fw_retry_count
> 0) {
1152 if (cx18_firmware_init(cx
) == 0)
1154 if (fw_retry_count
> 1)
1155 CX18_WARN("Retry loading firmware\n");
1158 if (fw_retry_count
== 0) {
1159 set_bit(CX18_F_I_FAILED
, &cx
->i_flags
);
1162 set_bit(CX18_F_I_LOADED_FW
, &cx
->i_flags
);
1165 * Init the firmware twice to work around a silicon bug
1166 * with the digital TS.
1168 * The second firmware load requires us to normalize the APU state,
1169 * or the audio for the first analog capture will be badly incorrect.
1171 * I can't seem to call APU_RESETAI and have it succeed without the
1172 * APU capturing audio, so we start and stop it here to do the reset
1175 /* MPEG Encoding, 224 kbps, MPEG Layer II, 48 ksps */
1176 cx18_vapi(cx
, CX18_APU_START
, 2, CX18_APU_ENCODING_METHOD_MPEG
|0xb9, 0);
1177 cx18_vapi(cx
, CX18_APU_RESETAI
, 0);
1178 cx18_vapi(cx
, CX18_APU_STOP
, 1, CX18_APU_ENCODING_METHOD_MPEG
);
1181 while (--fw_retry_count
> 0) {
1183 if (cx18_firmware_init(cx
) == 0)
1185 if (fw_retry_count
> 1)
1186 CX18_WARN("Retry loading firmware\n");
1189 if (fw_retry_count
== 0) {
1190 set_bit(CX18_F_I_FAILED
, &cx
->i_flags
);
1195 * The second firmware load requires us to normalize the APU state,
1196 * or the audio for the first analog capture will be badly incorrect.
1198 * I can't seem to call APU_RESETAI and have it succeed without the
1199 * APU capturing audio, so we start and stop it here to do the reset
1202 /* MPEG Encoding, 224 kbps, MPEG Layer II, 48 ksps */
1203 cx18_vapi(cx
, CX18_APU_START
, 2, CX18_APU_ENCODING_METHOD_MPEG
|0xb9, 0);
1204 cx18_vapi(cx
, CX18_APU_RESETAI
, 0);
1205 cx18_vapi(cx
, CX18_APU_STOP
, 1, CX18_APU_ENCODING_METHOD_MPEG
);
1207 /* Init the A/V decoder, if it hasn't been already */
1208 v4l2_subdev_call(cx
->sd_av
, core
, load_fw
);
1211 vf
.type
= V4L2_TUNER_ANALOG_TV
;
1212 vf
.frequency
= 6400; /* the tuner 'baseline' frequency */
1214 /* Set initial frequency. For PAL/SECAM broadcasts no
1215 'default' channel exists AFAIK. */
1216 if (cx
->std
== V4L2_STD_NTSC_M_JP
)
1217 vf
.frequency
= 1460; /* ch. 1 91250*16/1000 */
1218 else if (cx
->std
& V4L2_STD_NTSC_M
)
1219 vf
.frequency
= 1076; /* ch. 4 67250*16/1000 */
1221 video_input
= cx
->active_input
;
1222 cx
->active_input
++; /* Force update of input */
1223 cx18_s_input(NULL
, &fh
, video_input
);
1225 /* Let the VIDIOC_S_STD ioctl do all the work, keeps the code
1227 cx
->std
++; /* Force full standard initialization */
1228 std
= (cx
->tuner_std
== V4L2_STD_ALL
) ? V4L2_STD_NTSC_M
: cx
->tuner_std
;
1229 cx18_s_std(NULL
, &fh
, std
);
1230 cx18_s_frequency(NULL
, &fh
, &vf
);
1234 static void cx18_cancel_in_work_orders(struct cx18
*cx
)
1237 for (i
= 0; i
< CX18_MAX_IN_WORK_ORDERS
; i
++)
1238 cancel_work_sync(&cx
->in_work_order
[i
].work
);
1241 static void cx18_cancel_out_work_orders(struct cx18
*cx
)
1244 for (i
= 0; i
< CX18_MAX_STREAMS
; i
++)
1245 if (cx
->streams
[i
].video_dev
.v4l2_dev
)
1246 cancel_work_sync(&cx
->streams
[i
].out_work_order
);
1249 static void cx18_remove(struct pci_dev
*pci_dev
)
1251 struct v4l2_device
*v4l2_dev
= pci_get_drvdata(pci_dev
);
1252 struct cx18
*cx
= to_cx18(v4l2_dev
);
1255 CX18_DEBUG_INFO("Removing Card\n");
1257 flush_request_modules(cx
);
1259 /* Stop all captures */
1260 CX18_DEBUG_INFO("Stopping all streams\n");
1261 if (atomic_read(&cx
->tot_capturing
) > 0)
1262 cx18_stop_all_captures(cx
);
1264 /* Stop interrupts that cause incoming work to be queued */
1265 cx18_sw1_irq_disable(cx
, IRQ_CPU_TO_EPU
| IRQ_APU_TO_EPU
);
1267 /* Incoming work can cause outgoing work, so clean up incoming first */
1268 cx18_cancel_in_work_orders(cx
);
1269 cx18_cancel_out_work_orders(cx
);
1271 /* Stop ack interrupts that may have been needed for work to finish */
1272 cx18_sw2_irq_disable(cx
, IRQ_CPU_TO_EPU_ACK
| IRQ_APU_TO_EPU_ACK
);
1274 cx18_halt_firmware(cx
);
1276 destroy_workqueue(cx
->in_work_queue
);
1278 cx18_streams_cleanup(cx
, 1);
1282 free_irq(cx
->pci_dev
->irq
, (void *)cx
);
1286 release_mem_region(cx
->base_addr
, CX18_MEM_SIZE
);
1288 pci_disable_device(cx
->pci_dev
);
1290 if (cx
->vbi
.sliced_mpeg_data
[0])
1291 for (i
= 0; i
< CX18_VBI_FRAMES
; i
++)
1292 kfree(cx
->vbi
.sliced_mpeg_data
[i
]);
1294 v4l2_ctrl_handler_free(&cx
->av_state
.hdl
);
1296 CX18_INFO("Removed %s\n", cx
->card_name
);
1298 v4l2_device_unregister(v4l2_dev
);
1303 /* define a pci_driver for card detection */
1304 static struct pci_driver cx18_pci_driver
= {
1306 .id_table
= cx18_pci_tbl
,
1307 .probe
= cx18_probe
,
1308 .remove
= cx18_remove
,
1311 static int __init
module_start(void)
1313 printk(KERN_INFO
"cx18: Start initialization, version %s\n",
1316 /* Validate parameters */
1317 if (cx18_first_minor
< 0 || cx18_first_minor
>= CX18_MAX_CARDS
) {
1318 printk(KERN_ERR
"cx18: Exiting, cx18_first_minor must be between 0 and %d\n",
1319 CX18_MAX_CARDS
- 1);
1323 if (cx18_debug
< 0 || cx18_debug
> 511) {
1325 printk(KERN_INFO
"cx18: Debug value must be >= 0 and <= 511!\n");
1328 if (pci_register_driver(&cx18_pci_driver
)) {
1329 printk(KERN_ERR
"cx18: Error detecting PCI card\n");
1332 printk(KERN_INFO
"cx18: End initialization\n");
1336 static void __exit
module_cleanup(void)
1338 pci_unregister_driver(&cx18_pci_driver
);
1341 module_init(module_start
);
1342 module_exit(module_cleanup
);
1343 MODULE_FIRMWARE(XC2028_DEFAULT_FIRMWARE
);