blob: a1ae036b44ec9cd362d452697122f06e0db83dee [file] [log] [blame]
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001/*
2 *
3 * i2c tv tuner chip device type database.
4 *
5 */
6
7#include <linux/i2c.h>
8#include <media/tuner.h>
9#include <media/tuner-types.h>
10
11/* ---------------------------------------------------------------------- */
12
13/*
14 * The floats in the tuner struct are computed at compile time
15 * by gcc and cast back to integers. Thus we don't violate the
16 * "no float in kernel" rule.
17 *
18 * A tuner_range may be referenced by multiple tuner_params structs.
19 * There are many duplicates in here. Reusing tuner_range structs,
20 * rather than defining new ones for each tuner, will cut down on
21 * memory usage, and is preferred when possible.
22 *
23 * Each tuner_params array may contain one or more elements, one
24 * for each video standard.
25 *
Michael Krufky99d33d52006-02-07 06:25:36 -020026 * FIXME: tuner_params struct contains an element, tda988x. We must
27 * set this for all tuners that contain a tda988x chip, and then we
28 * can remove this setting from the various card structs.
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020029 *
Michael Krufky99d33d52006-02-07 06:25:36 -020030 * FIXME: Right now, all tuners are using the first tuner_params[]
31 * array element for analog mode. In the future, we will be merging
32 * similar tuner definitions together, such that each tuner definition
33 * will have a tuner_params struct for each available video standard.
34 * At that point, the tuner_params[] array element will be chosen
35 * based on the video standard in use.
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020036 */
37
38/* 0-9 */
39/* ------------ TUNER_TEMIC_PAL - TEMIC PAL ------------ */
40
41static struct tuner_range tuner_temic_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -020042 { 16 * 140.25 /*MHz*/, 0x8e, 0x02, },
43 { 16 * 463.25 /*MHz*/, 0x8e, 0x04, },
44 { 16 * 999.99 , 0x8e, 0x01, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020045};
46
47static struct tuner_params tuner_temic_pal_params[] = {
48 {
49 .type = TUNER_PARAM_TYPE_PAL,
50 .ranges = tuner_temic_pal_ranges,
51 .count = ARRAY_SIZE(tuner_temic_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020052 },
53};
54
55/* ------------ TUNER_PHILIPS_PAL_I - Philips PAL_I ------------ */
56
57static struct tuner_range tuner_philips_pal_i_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -020058 { 16 * 140.25 /*MHz*/, 0x8e, 0xa0, },
59 { 16 * 463.25 /*MHz*/, 0x8e, 0x90, },
60 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020061};
62
63static struct tuner_params tuner_philips_pal_i_params[] = {
64 {
65 .type = TUNER_PARAM_TYPE_PAL,
66 .ranges = tuner_philips_pal_i_ranges,
67 .count = ARRAY_SIZE(tuner_philips_pal_i_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020068 },
69};
70
71/* ------------ TUNER_PHILIPS_NTSC - Philips NTSC ------------ */
72
73static struct tuner_range tuner_philips_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -020074 { 16 * 157.25 /*MHz*/, 0x8e, 0xa0, },
75 { 16 * 451.25 /*MHz*/, 0x8e, 0x90, },
76 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020077};
78
79static struct tuner_params tuner_philips_ntsc_params[] = {
80 {
81 .type = TUNER_PARAM_TYPE_NTSC,
82 .ranges = tuner_philips_ntsc_ranges,
83 .count = ARRAY_SIZE(tuner_philips_ntsc_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -020084 .cb_first_if_lower_freq = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020085 },
86};
87
88/* ------------ TUNER_PHILIPS_SECAM - Philips SECAM ------------ */
89
90static struct tuner_range tuner_philips_secam_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -020091 { 16 * 168.25 /*MHz*/, 0x8e, 0xa7, },
92 { 16 * 447.25 /*MHz*/, 0x8e, 0x97, },
93 { 16 * 999.99 , 0x8e, 0x37, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -020094};
95
96static struct tuner_params tuner_philips_secam_params[] = {
97 {
98 .type = TUNER_PARAM_TYPE_SECAM,
99 .ranges = tuner_philips_secam_ranges,
100 .count = ARRAY_SIZE(tuner_philips_secam_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200101 .cb_first_if_lower_freq = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200102 },
103};
104
105/* ------------ TUNER_PHILIPS_PAL - Philips PAL ------------ */
106
107static struct tuner_range tuner_philips_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200108 { 16 * 168.25 /*MHz*/, 0x8e, 0xa0, },
109 { 16 * 447.25 /*MHz*/, 0x8e, 0x90, },
110 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200111};
112
113static struct tuner_params tuner_philips_pal_params[] = {
114 {
115 .type = TUNER_PARAM_TYPE_PAL,
116 .ranges = tuner_philips_pal_ranges,
117 .count = ARRAY_SIZE(tuner_philips_pal_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200118 .cb_first_if_lower_freq = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200119 },
120};
121
122/* ------------ TUNER_TEMIC_NTSC - TEMIC NTSC ------------ */
123
124static struct tuner_range tuner_temic_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200125 { 16 * 157.25 /*MHz*/, 0x8e, 0x02, },
126 { 16 * 463.25 /*MHz*/, 0x8e, 0x04, },
127 { 16 * 999.99 , 0x8e, 0x01, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200128};
129
130static struct tuner_params tuner_temic_ntsc_params[] = {
131 {
132 .type = TUNER_PARAM_TYPE_NTSC,
133 .ranges = tuner_temic_ntsc_ranges,
134 .count = ARRAY_SIZE(tuner_temic_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200135 },
136};
137
138/* ------------ TUNER_TEMIC_PAL_I - TEMIC PAL_I ------------ */
139
140static struct tuner_range tuner_temic_pal_i_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200141 { 16 * 170.00 /*MHz*/, 0x8e, 0x02, },
142 { 16 * 450.00 /*MHz*/, 0x8e, 0x04, },
143 { 16 * 999.99 , 0x8e, 0x01, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200144};
145
146static struct tuner_params tuner_temic_pal_i_params[] = {
147 {
148 .type = TUNER_PARAM_TYPE_PAL,
149 .ranges = tuner_temic_pal_i_ranges,
150 .count = ARRAY_SIZE(tuner_temic_pal_i_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200151 },
152};
153
154/* ------------ TUNER_TEMIC_4036FY5_NTSC - TEMIC NTSC ------------ */
155
156static struct tuner_range tuner_temic_4036fy5_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200157 { 16 * 157.25 /*MHz*/, 0x8e, 0xa0, },
158 { 16 * 463.25 /*MHz*/, 0x8e, 0x90, },
159 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200160};
161
162static struct tuner_params tuner_temic_4036fy5_ntsc_params[] = {
163 {
164 .type = TUNER_PARAM_TYPE_NTSC,
165 .ranges = tuner_temic_4036fy5_ntsc_ranges,
166 .count = ARRAY_SIZE(tuner_temic_4036fy5_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200167 },
168};
169
170/* ------------ TUNER_ALPS_TSBH1_NTSC - TEMIC NTSC ------------ */
171
172static struct tuner_range tuner_alps_tsb_1_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200173 { 16 * 137.25 /*MHz*/, 0x8e, 0x01, },
174 { 16 * 385.25 /*MHz*/, 0x8e, 0x02, },
175 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200176};
177
178static struct tuner_params tuner_alps_tsbh1_ntsc_params[] = {
179 {
180 .type = TUNER_PARAM_TYPE_NTSC,
181 .ranges = tuner_alps_tsb_1_ranges,
182 .count = ARRAY_SIZE(tuner_alps_tsb_1_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200183 },
184};
185
186/* 10-19 */
187/* ------------ TUNER_ALPS_TSBE1_PAL - TEMIC PAL ------------ */
188
189static struct tuner_params tuner_alps_tsb_1_params[] = {
190 {
191 .type = TUNER_PARAM_TYPE_PAL,
192 .ranges = tuner_alps_tsb_1_ranges,
193 .count = ARRAY_SIZE(tuner_alps_tsb_1_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200194 },
195};
196
197/* ------------ TUNER_ALPS_TSBB5_PAL_I - Alps PAL_I ------------ */
198
199static struct tuner_range tuner_alps_tsb_5_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200200 { 16 * 133.25 /*MHz*/, 0x8e, 0x01, },
201 { 16 * 351.25 /*MHz*/, 0x8e, 0x02, },
202 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200203};
204
205static struct tuner_params tuner_alps_tsbb5_params[] = {
206 {
207 .type = TUNER_PARAM_TYPE_PAL,
208 .ranges = tuner_alps_tsb_5_pal_ranges,
209 .count = ARRAY_SIZE(tuner_alps_tsb_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200210 },
211};
212
213/* ------------ TUNER_ALPS_TSBE5_PAL - Alps PAL ------------ */
214
215static struct tuner_params tuner_alps_tsbe5_params[] = {
216 {
217 .type = TUNER_PARAM_TYPE_PAL,
218 .ranges = tuner_alps_tsb_5_pal_ranges,
219 .count = ARRAY_SIZE(tuner_alps_tsb_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200220 },
221};
222
223/* ------------ TUNER_ALPS_TSBC5_PAL - Alps PAL ------------ */
224
225static struct tuner_params tuner_alps_tsbc5_params[] = {
226 {
227 .type = TUNER_PARAM_TYPE_PAL,
228 .ranges = tuner_alps_tsb_5_pal_ranges,
229 .count = ARRAY_SIZE(tuner_alps_tsb_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200230 },
231};
232
233/* ------------ TUNER_TEMIC_4006FH5_PAL - TEMIC PAL ------------ */
234
Michael Krufkycc925bb2006-01-23 17:11:11 -0200235static struct tuner_range tuner_lg_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200236 { 16 * 170.00 /*MHz*/, 0x8e, 0xa0, },
237 { 16 * 450.00 /*MHz*/, 0x8e, 0x90, },
238 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200239};
240
241static struct tuner_params tuner_temic_4006fh5_params[] = {
242 {
243 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200244 .ranges = tuner_lg_pal_ranges,
245 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200246 },
247};
248
249/* ------------ TUNER_ALPS_TSHC6_NTSC - Alps NTSC ------------ */
250
251static struct tuner_range tuner_alps_tshc6_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200252 { 16 * 137.25 /*MHz*/, 0x8e, 0x14, },
253 { 16 * 385.25 /*MHz*/, 0x8e, 0x12, },
254 { 16 * 999.99 , 0x8e, 0x11, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200255};
256
257static struct tuner_params tuner_alps_tshc6_params[] = {
258 {
259 .type = TUNER_PARAM_TYPE_NTSC,
260 .ranges = tuner_alps_tshc6_ntsc_ranges,
261 .count = ARRAY_SIZE(tuner_alps_tshc6_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200262 },
263};
264
265/* ------------ TUNER_TEMIC_PAL_DK - TEMIC PAL ------------ */
266
267static struct tuner_range tuner_temic_pal_dk_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200268 { 16 * 168.25 /*MHz*/, 0x8e, 0xa0, },
269 { 16 * 456.25 /*MHz*/, 0x8e, 0x90, },
270 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200271};
272
273static struct tuner_params tuner_temic_pal_dk_params[] = {
274 {
275 .type = TUNER_PARAM_TYPE_PAL,
276 .ranges = tuner_temic_pal_dk_ranges,
277 .count = ARRAY_SIZE(tuner_temic_pal_dk_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200278 },
279};
280
281/* ------------ TUNER_PHILIPS_NTSC_M - Philips NTSC ------------ */
282
283static struct tuner_range tuner_philips_ntsc_m_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200284 { 16 * 160.00 /*MHz*/, 0x8e, 0xa0, },
285 { 16 * 454.00 /*MHz*/, 0x8e, 0x90, },
286 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200287};
288
289static struct tuner_params tuner_philips_ntsc_m_params[] = {
290 {
291 .type = TUNER_PARAM_TYPE_NTSC,
292 .ranges = tuner_philips_ntsc_m_ranges,
293 .count = ARRAY_SIZE(tuner_philips_ntsc_m_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200294 },
295};
296
297/* ------------ TUNER_TEMIC_4066FY5_PAL_I - TEMIC PAL_I ------------ */
298
299static struct tuner_range tuner_temic_40x6f_5_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200300 { 16 * 169.00 /*MHz*/, 0x8e, 0xa0, },
301 { 16 * 454.00 /*MHz*/, 0x8e, 0x90, },
302 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200303};
304
305static struct tuner_params tuner_temic_4066fy5_pal_i_params[] = {
306 {
307 .type = TUNER_PARAM_TYPE_PAL,
308 .ranges = tuner_temic_40x6f_5_pal_ranges,
309 .count = ARRAY_SIZE(tuner_temic_40x6f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200310 },
311};
312
313/* ------------ TUNER_TEMIC_4006FN5_MULTI_PAL - TEMIC PAL ------------ */
314
315static struct tuner_params tuner_temic_4006fn5_multi_params[] = {
316 {
317 .type = TUNER_PARAM_TYPE_PAL,
318 .ranges = tuner_temic_40x6f_5_pal_ranges,
319 .count = ARRAY_SIZE(tuner_temic_40x6f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200320 },
321};
322
323/* 20-29 */
324/* ------------ TUNER_TEMIC_4009FR5_PAL - TEMIC PAL ------------ */
325
326static struct tuner_range tuner_temic_4009f_5_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200327 { 16 * 141.00 /*MHz*/, 0x8e, 0xa0, },
328 { 16 * 464.00 /*MHz*/, 0x8e, 0x90, },
329 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200330};
331
332static struct tuner_params tuner_temic_4009f_5_params[] = {
333 {
334 .type = TUNER_PARAM_TYPE_PAL,
335 .ranges = tuner_temic_4009f_5_pal_ranges,
336 .count = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200337 },
338};
339
340/* ------------ TUNER_TEMIC_4039FR5_NTSC - TEMIC NTSC ------------ */
341
Michael Krufkycc925bb2006-01-23 17:11:11 -0200342static struct tuner_range tuner_temic_4x3x_f_5_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200343 { 16 * 158.00 /*MHz*/, 0x8e, 0xa0, },
344 { 16 * 453.00 /*MHz*/, 0x8e, 0x90, },
345 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200346};
347
348static struct tuner_params tuner_temic_4039fr5_params[] = {
349 {
350 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200351 .ranges = tuner_temic_4x3x_f_5_ntsc_ranges,
352 .count = ARRAY_SIZE(tuner_temic_4x3x_f_5_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200353 },
354};
355
356/* ------------ TUNER_TEMIC_4046FM5 - TEMIC PAL ------------ */
357
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200358static struct tuner_params tuner_temic_4046fm5_params[] = {
359 {
360 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200361 .ranges = tuner_temic_40x6f_5_pal_ranges,
362 .count = ARRAY_SIZE(tuner_temic_40x6f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200363 },
364};
365
366/* ------------ TUNER_PHILIPS_PAL_DK - Philips PAL ------------ */
367
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200368static struct tuner_params tuner_philips_pal_dk_params[] = {
369 {
370 .type = TUNER_PARAM_TYPE_PAL,
371 .ranges = tuner_lg_pal_ranges,
372 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200373 },
374};
375
376/* ------------ TUNER_PHILIPS_FQ1216ME - Philips PAL ------------ */
377
378static struct tuner_params tuner_philips_fq1216me_params[] = {
379 {
380 .type = TUNER_PARAM_TYPE_PAL,
381 .ranges = tuner_lg_pal_ranges,
382 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200383 },
384};
385
386/* ------------ TUNER_LG_PAL_I_FM - LGINNOTEK PAL_I ------------ */
387
388static struct tuner_params tuner_lg_pal_i_fm_params[] = {
389 {
390 .type = TUNER_PARAM_TYPE_PAL,
391 .ranges = tuner_lg_pal_ranges,
392 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200393 },
394};
395
396/* ------------ TUNER_LG_PAL_I - LGINNOTEK PAL_I ------------ */
397
398static struct tuner_params tuner_lg_pal_i_params[] = {
399 {
400 .type = TUNER_PARAM_TYPE_PAL,
401 .ranges = tuner_lg_pal_ranges,
402 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200403 },
404};
405
406/* ------------ TUNER_LG_NTSC_FM - LGINNOTEK NTSC ------------ */
407
408static struct tuner_range tuner_lg_ntsc_fm_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200409 { 16 * 210.00 /*MHz*/, 0x8e, 0xa0, },
410 { 16 * 497.00 /*MHz*/, 0x8e, 0x90, },
411 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200412};
413
414static struct tuner_params tuner_lg_ntsc_fm_params[] = {
415 {
416 .type = TUNER_PARAM_TYPE_NTSC,
417 .ranges = tuner_lg_ntsc_fm_ranges,
418 .count = ARRAY_SIZE(tuner_lg_ntsc_fm_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200419 },
420};
421
422/* ------------ TUNER_LG_PAL_FM - LGINNOTEK PAL ------------ */
423
424static struct tuner_params tuner_lg_pal_fm_params[] = {
425 {
426 .type = TUNER_PARAM_TYPE_PAL,
427 .ranges = tuner_lg_pal_ranges,
428 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200429 },
430};
431
432/* ------------ TUNER_LG_PAL - LGINNOTEK PAL ------------ */
433
434static struct tuner_params tuner_lg_pal_params[] = {
435 {
436 .type = TUNER_PARAM_TYPE_PAL,
437 .ranges = tuner_lg_pal_ranges,
438 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200439 },
440};
441
442/* 30-39 */
443/* ------------ TUNER_TEMIC_4009FN5_MULTI_PAL_FM - TEMIC PAL ------------ */
444
445static struct tuner_params tuner_temic_4009_fn5_multi_pal_fm_params[] = {
446 {
447 .type = TUNER_PARAM_TYPE_PAL,
448 .ranges = tuner_temic_4009f_5_pal_ranges,
449 .count = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200450 },
451};
452
453/* ------------ TUNER_SHARP_2U5JF5540_NTSC - SHARP NTSC ------------ */
454
455static struct tuner_range tuner_sharp_2u5jf5540_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200456 { 16 * 137.25 /*MHz*/, 0x8e, 0x01, },
457 { 16 * 317.25 /*MHz*/, 0x8e, 0x02, },
458 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200459};
460
461static struct tuner_params tuner_sharp_2u5jf5540_params[] = {
462 {
463 .type = TUNER_PARAM_TYPE_NTSC,
464 .ranges = tuner_sharp_2u5jf5540_ntsc_ranges,
465 .count = ARRAY_SIZE(tuner_sharp_2u5jf5540_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200466 },
467};
468
469/* ------------ TUNER_Samsung_PAL_TCPM9091PD27 - Samsung PAL ------------ */
470
471static struct tuner_range tuner_samsung_pal_tcpm9091pd27_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200472 { 16 * 169 /*MHz*/, 0x8e, 0xa0, },
473 { 16 * 464 /*MHz*/, 0x8e, 0x90, },
474 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200475};
476
477static struct tuner_params tuner_samsung_pal_tcpm9091pd27_params[] = {
478 {
479 .type = TUNER_PARAM_TYPE_PAL,
480 .ranges = tuner_samsung_pal_tcpm9091pd27_ranges,
481 .count = ARRAY_SIZE(tuner_samsung_pal_tcpm9091pd27_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200482 },
483};
484
485/* ------------ TUNER_TEMIC_4106FH5 - TEMIC PAL ------------ */
486
487static struct tuner_params tuner_temic_4106fh5_params[] = {
488 {
489 .type = TUNER_PARAM_TYPE_PAL,
490 .ranges = tuner_temic_4009f_5_pal_ranges,
491 .count = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200492 },
493};
494
495/* ------------ TUNER_TEMIC_4012FY5 - TEMIC PAL ------------ */
496
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200497static struct tuner_params tuner_temic_4012fy5_params[] = {
498 {
499 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200500 .ranges = tuner_temic_pal_ranges,
501 .count = ARRAY_SIZE(tuner_temic_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200502 },
503};
504
505/* ------------ TUNER_TEMIC_4136FY5 - TEMIC NTSC ------------ */
506
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200507static struct tuner_params tuner_temic_4136_fy5_params[] = {
508 {
509 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200510 .ranges = tuner_temic_4x3x_f_5_ntsc_ranges,
511 .count = ARRAY_SIZE(tuner_temic_4x3x_f_5_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200512 },
513};
514
515/* ------------ TUNER_LG_PAL_NEW_TAPC - LGINNOTEK PAL ------------ */
516
517static struct tuner_range tuner_lg_new_tapc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200518 { 16 * 170.00 /*MHz*/, 0x8e, 0x01, },
519 { 16 * 450.00 /*MHz*/, 0x8e, 0x02, },
520 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200521};
522
523static struct tuner_params tuner_lg_pal_new_tapc_params[] = {
524 {
525 .type = TUNER_PARAM_TYPE_PAL,
526 .ranges = tuner_lg_new_tapc_ranges,
527 .count = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200528 },
529};
530
531/* ------------ TUNER_PHILIPS_FM1216ME_MK3 - Philips PAL ------------ */
532
533static struct tuner_range tuner_fm1216me_mk3_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200534 { 16 * 158.00 /*MHz*/, 0x8e, 0x01, },
535 { 16 * 442.00 /*MHz*/, 0x8e, 0x02, },
536 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200537};
538
539static struct tuner_params tuner_fm1216me_mk3_params[] = {
540 {
541 .type = TUNER_PARAM_TYPE_PAL,
542 .ranges = tuner_fm1216me_mk3_pal_ranges,
543 .count = ARRAY_SIZE(tuner_fm1216me_mk3_pal_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200544 .cb_first_if_lower_freq = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200545 },
546};
547
548/* ------------ TUNER_LG_NTSC_NEW_TAPC - LGINNOTEK NTSC ------------ */
549
550static struct tuner_params tuner_lg_ntsc_new_tapc_params[] = {
551 {
552 .type = TUNER_PARAM_TYPE_NTSC,
553 .ranges = tuner_lg_new_tapc_ranges,
554 .count = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200555 },
556};
557
558/* 40-49 */
559/* ------------ TUNER_HITACHI_NTSC - HITACHI NTSC ------------ */
560
561static struct tuner_params tuner_hitachi_ntsc_params[] = {
562 {
563 .type = TUNER_PARAM_TYPE_NTSC,
564 .ranges = tuner_lg_new_tapc_ranges,
565 .count = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200566 },
567};
568
569/* ------------ TUNER_PHILIPS_PAL_MK - Philips PAL ------------ */
570
571static struct tuner_range tuner_philips_pal_mk_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200572 { 16 * 140.25 /*MHz*/, 0x8e, 0x01, },
573 { 16 * 463.25 /*MHz*/, 0x8e, 0xc2, },
574 { 16 * 999.99 , 0x8e, 0xcf, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200575};
576
577static struct tuner_params tuner_philips_pal_mk_params[] = {
578 {
579 .type = TUNER_PARAM_TYPE_PAL,
580 .ranges = tuner_philips_pal_mk_pal_ranges,
581 .count = ARRAY_SIZE(tuner_philips_pal_mk_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200582 },
583};
584
585/* ------------ TUNER_PHILIPS_ATSC - Philips ATSC ------------ */
586
587static struct tuner_range tuner_philips_atsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200588 { 16 * 157.25 /*MHz*/, 0x8e, 0xa0, },
589 { 16 * 454.00 /*MHz*/, 0x8e, 0x90, },
590 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200591};
592
593static struct tuner_params tuner_philips_atsc_params[] = {
594 {
595 .type = TUNER_PARAM_TYPE_NTSC,
596 .ranges = tuner_philips_atsc_ranges,
597 .count = ARRAY_SIZE(tuner_philips_atsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200598 },
599};
600
601/* ------------ TUNER_PHILIPS_FM1236_MK3 - Philips NTSC ------------ */
602
603static struct tuner_range tuner_fm1236_mk3_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200604 { 16 * 160.00 /*MHz*/, 0x8e, 0x01, },
605 { 16 * 442.00 /*MHz*/, 0x8e, 0x02, },
606 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200607};
608
609static struct tuner_params tuner_fm1236_mk3_params[] = {
610 {
611 .type = TUNER_PARAM_TYPE_NTSC,
612 .ranges = tuner_fm1236_mk3_ntsc_ranges,
613 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200614 .cb_first_if_lower_freq = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200615 },
616};
617
618/* ------------ TUNER_PHILIPS_4IN1 - Philips NTSC ------------ */
619
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200620static struct tuner_params tuner_philips_4in1_params[] = {
621 {
622 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200623 .ranges = tuner_fm1236_mk3_ntsc_ranges,
624 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200625 },
626};
627
628/* ------------ TUNER_MICROTUNE_4049FM5 - Microtune PAL ------------ */
629
630static struct tuner_params tuner_microtune_4049_fm5_params[] = {
631 {
632 .type = TUNER_PARAM_TYPE_PAL,
633 .ranges = tuner_temic_4009f_5_pal_ranges,
634 .count = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200635 },
636};
637
638/* ------------ TUNER_PANASONIC_VP27 - Panasonic NTSC ------------ */
639
640static struct tuner_range tuner_panasonic_vp27_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200641 { 16 * 160.00 /*MHz*/, 0xce, 0x01, },
642 { 16 * 454.00 /*MHz*/, 0xce, 0x02, },
643 { 16 * 999.99 , 0xce, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200644};
645
646static struct tuner_params tuner_panasonic_vp27_params[] = {
647 {
648 .type = TUNER_PARAM_TYPE_NTSC,
649 .ranges = tuner_panasonic_vp27_ntsc_ranges,
650 .count = ARRAY_SIZE(tuner_panasonic_vp27_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200651 },
652};
653
654/* ------------ TUNER_LG_NTSC_TAPE - LGINNOTEK NTSC ------------ */
655
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200656static struct tuner_params tuner_lg_ntsc_tape_params[] = {
657 {
658 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200659 .ranges = tuner_fm1236_mk3_ntsc_ranges,
660 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200661 },
662};
663
664/* ------------ TUNER_TNF_8831BGFF - Philips PAL ------------ */
665
666static struct tuner_range tuner_tnf_8831bgff_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200667 { 16 * 161.25 /*MHz*/, 0x8e, 0xa0, },
668 { 16 * 463.25 /*MHz*/, 0x8e, 0x90, },
669 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200670};
671
672static struct tuner_params tuner_tnf_8831bgff_params[] = {
673 {
674 .type = TUNER_PARAM_TYPE_PAL,
675 .ranges = tuner_tnf_8831bgff_pal_ranges,
676 .count = ARRAY_SIZE(tuner_tnf_8831bgff_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200677 },
678};
679
680/* ------------ TUNER_MICROTUNE_4042FI5 - Microtune NTSC ------------ */
681
682static struct tuner_range tuner_microtune_4042fi5_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200683 { 16 * 162.00 /*MHz*/, 0x8e, 0xa2, },
684 { 16 * 457.00 /*MHz*/, 0x8e, 0x94, },
685 { 16 * 999.99 , 0x8e, 0x31, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200686};
687
688static struct tuner_params tuner_microtune_4042fi5_params[] = {
689 {
690 .type = TUNER_PARAM_TYPE_NTSC,
691 .ranges = tuner_microtune_4042fi5_ntsc_ranges,
692 .count = ARRAY_SIZE(tuner_microtune_4042fi5_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200693 },
694};
695
696/* 50-59 */
697/* ------------ TUNER_TCL_2002N - TCL NTSC ------------ */
698
699static struct tuner_range tuner_tcl_2002n_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200700 { 16 * 172.00 /*MHz*/, 0x8e, 0x01, },
701 { 16 * 448.00 /*MHz*/, 0x8e, 0x02, },
702 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200703};
704
705static struct tuner_params tuner_tcl_2002n_params[] = {
706 {
707 .type = TUNER_PARAM_TYPE_NTSC,
708 .ranges = tuner_tcl_2002n_ntsc_ranges,
709 .count = ARRAY_SIZE(tuner_tcl_2002n_ntsc_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200710 .cb_first_if_lower_freq = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200711 },
712};
713
714/* ------------ TUNER_PHILIPS_FM1256_IH3 - Philips PAL ------------ */
715
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200716static struct tuner_params tuner_philips_fm1256_ih3_params[] = {
717 {
718 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200719 .ranges = tuner_fm1236_mk3_ntsc_ranges,
720 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200721 },
722};
723
724/* ------------ TUNER_THOMSON_DTT7610 - THOMSON ATSC ------------ */
725
726static struct tuner_range tuner_thomson_dtt7610_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200727 { 16 * 157.25 /*MHz*/, 0x8e, 0x39, },
728 { 16 * 454.00 /*MHz*/, 0x8e, 0x3a, },
729 { 16 * 999.99 , 0x8e, 0x3c, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200730};
731
732static struct tuner_params tuner_thomson_dtt7610_params[] = {
733 {
734 .type = TUNER_PARAM_TYPE_NTSC,
735 .ranges = tuner_thomson_dtt7610_ntsc_ranges,
736 .count = ARRAY_SIZE(tuner_thomson_dtt7610_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200737 },
738};
739
740/* ------------ TUNER_PHILIPS_FQ1286 - Philips NTSC ------------ */
741
742static struct tuner_range tuner_philips_fq1286_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200743 { 16 * 160.00 /*MHz*/, 0x8e, 0x41, },
744 { 16 * 454.00 /*MHz*/, 0x8e, 0x42, },
745 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200746};
747
748static struct tuner_params tuner_philips_fq1286_params[] = {
749 {
750 .type = TUNER_PARAM_TYPE_NTSC,
751 .ranges = tuner_philips_fq1286_ntsc_ranges,
752 .count = ARRAY_SIZE(tuner_philips_fq1286_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200753 },
754};
755
756/* ------------ TUNER_TCL_2002MB - TCL PAL ------------ */
757
758static struct tuner_range tuner_tcl_2002mb_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200759 { 16 * 170.00 /*MHz*/, 0xce, 0x01, },
760 { 16 * 450.00 /*MHz*/, 0xce, 0x02, },
761 { 16 * 999.99 , 0xce, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200762};
763
764static struct tuner_params tuner_tcl_2002mb_params[] = {
765 {
766 .type = TUNER_PARAM_TYPE_PAL,
767 .ranges = tuner_tcl_2002mb_pal_ranges,
768 .count = ARRAY_SIZE(tuner_tcl_2002mb_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200769 },
770};
771
772/* ------------ TUNER_PHILIPS_FQ1216AME_MK4 - Philips PAL ------------ */
773
Michael Krufky3fc46d32006-01-23 17:11:11 -0200774static struct tuner_range tuner_philips_fq12_6a___mk4_pal_ranges[] = {
775 { 16 * 160.00 /*MHz*/, 0xce, 0x01, },
776 { 16 * 442.00 /*MHz*/, 0xce, 0x02, },
777 { 16 * 999.99 , 0xce, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200778};
779
780static struct tuner_params tuner_philips_fq1216ame_mk4_params[] = {
781 {
782 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufky3fc46d32006-01-23 17:11:11 -0200783 .ranges = tuner_philips_fq12_6a___mk4_pal_ranges,
784 .count = ARRAY_SIZE(tuner_philips_fq12_6a___mk4_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200785 },
786};
787
788/* ------------ TUNER_PHILIPS_FQ1236A_MK4 - Philips NTSC ------------ */
789
790static struct tuner_params tuner_philips_fq1236a_mk4_params[] = {
791 {
792 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200793 .ranges = tuner_fm1236_mk3_ntsc_ranges,
794 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200795 },
796};
797
798/* ------------ TUNER_YMEC_TVF_8531MF - Philips NTSC ------------ */
799
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200800static struct tuner_params tuner_ymec_tvf_8531mf_params[] = {
801 {
802 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200803 .ranges = tuner_philips_ntsc_m_ranges,
804 .count = ARRAY_SIZE(tuner_philips_ntsc_m_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200805 },
806};
807
808/* ------------ TUNER_YMEC_TVF_5533MF - Philips NTSC ------------ */
809
810static struct tuner_range tuner_ymec_tvf_5533mf_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200811 { 16 * 160.00 /*MHz*/, 0x8e, 0x01, },
812 { 16 * 454.00 /*MHz*/, 0x8e, 0x02, },
813 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200814};
815
816static struct tuner_params tuner_ymec_tvf_5533mf_params[] = {
817 {
818 .type = TUNER_PARAM_TYPE_NTSC,
819 .ranges = tuner_ymec_tvf_5533mf_ntsc_ranges,
820 .count = ARRAY_SIZE(tuner_ymec_tvf_5533mf_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200821 },
822};
823
824/* 60-69 */
825/* ------------ TUNER_THOMSON_DTT761X - THOMSON ATSC ------------ */
826/* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
827
828static struct tuner_range tuner_thomson_dtt761x_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200829 { 16 * 145.25 /*MHz*/, 0x8e, 0x39, },
830 { 16 * 415.25 /*MHz*/, 0x8e, 0x3a, },
831 { 16 * 999.99 , 0x8e, 0x3c, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200832};
833
834
835static struct tuner_params tuner_thomson_dtt761x_params[] = {
836 {
837 .type = TUNER_PARAM_TYPE_NTSC,
838 .ranges = tuner_thomson_dtt761x_ntsc_ranges,
839 .count = ARRAY_SIZE(tuner_thomson_dtt761x_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200840 },
841};
842
843/* ------------ TUNER_TENA_9533_DI - Philips PAL ------------ */
844
Michael Krufkycc925bb2006-01-23 17:11:11 -0200845static struct tuner_range tuner_tena_9533_di_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200846 { 16 * 160.25 /*MHz*/, 0x8e, 0x01, },
847 { 16 * 464.25 /*MHz*/, 0x8e, 0x02, },
848 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200849};
850
851static struct tuner_params tuner_tena_9533_di_params[] = {
852 {
853 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200854 .ranges = tuner_tena_9533_di_pal_ranges,
855 .count = ARRAY_SIZE(tuner_tena_9533_di_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200856 },
857};
858
859/* ------------ TUNER_PHILIPS_FMD1216ME_MK3 - Philips PAL ------------ */
860
861static struct tuner_range tuner_philips_fmd1216me_mk3_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200862 { 16 * 160.00 /*MHz*/, 0x86, 0x51, },
863 { 16 * 442.00 /*MHz*/, 0x86, 0x52, },
864 { 16 * 999.99 , 0x86, 0x54, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200865};
866
867
Michael Krufkycc925bb2006-01-23 17:11:11 -0200868static struct tuner_params tuner_philips_fmd1216me_mk3_params[] = {
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200869 {
870 .type = TUNER_PARAM_TYPE_PAL,
871 .ranges = tuner_philips_fmd1216me_mk3_pal_ranges,
872 .count = ARRAY_SIZE(tuner_philips_fmd1216me_mk3_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200873 },
874};
875
876
877/* ------------ TUNER_LG_TDVS_H062F - INFINEON ATSC ------------ */
878
879static struct tuner_range tuner_tua6034_ntsc_ranges[] = {
Rusty Scottdd31d5ac2006-04-22 16:15:07 -0300880 { 16 * 165.00 /*MHz*/, 0x8e, 0x01 },
881 { 16 * 450.00 /*MHz*/, 0x8e, 0x02 },
Michael Krufky3fc46d32006-01-23 17:11:11 -0200882 { 16 * 999.99 , 0x8e, 0x04 },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200883};
884
885
886static struct tuner_params tuner_tua6034_params[] = {
887 {
888 .type = TUNER_PARAM_TYPE_NTSC,
889 .ranges = tuner_tua6034_ntsc_ranges,
890 .count = ARRAY_SIZE(tuner_tua6034_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200891 },
892};
893
894/* ------------ TUNER_YMEC_TVF66T5_B_DFF - Philips PAL ------------ */
895
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200896static struct tuner_params tuner_ymec_tvf66t5_b_dff_params[] = {
897 {
898 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200899 .ranges = tuner_tena_9533_di_pal_ranges,
900 .count = ARRAY_SIZE(tuner_tena_9533_di_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200901 },
902};
903
904/* ------------ TUNER_LG_NTSC_TALN_MINI - LGINNOTEK NTSC ------------ */
905
Michael Krufkyf3629be2006-03-11 17:02:01 -0300906static struct tuner_range tuner_lg_taln_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200907 { 16 * 137.25 /*MHz*/, 0x8e, 0x01, },
908 { 16 * 373.25 /*MHz*/, 0x8e, 0x02, },
909 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200910};
911
Michael Krufkyf3629be2006-03-11 17:02:01 -0300912static struct tuner_range tuner_lg_taln_pal_secam_ranges[] = {
913 { 16 * 150.00 /*MHz*/, 0x8e, 0x01, },
914 { 16 * 425.00 /*MHz*/, 0x8e, 0x02, },
915 { 16 * 999.99 , 0x8e, 0x08, },
916};
917
918static struct tuner_params tuner_lg_taln_params[] = {
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200919 {
920 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkyf3629be2006-03-11 17:02:01 -0300921 .ranges = tuner_lg_taln_ntsc_ranges,
922 .count = ARRAY_SIZE(tuner_lg_taln_ntsc_ranges),
923 },{
924 .type = TUNER_PARAM_TYPE_PAL,
925 .ranges = tuner_lg_taln_pal_secam_ranges,
926 .count = ARRAY_SIZE(tuner_lg_taln_pal_secam_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200927 },
928};
929
930/* ------------ TUNER_PHILIPS_TD1316 - Philips PAL ------------ */
931
932static struct tuner_range tuner_philips_td1316_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200933 { 16 * 160.00 /*MHz*/, 0xc8, 0xa1, },
934 { 16 * 442.00 /*MHz*/, 0xc8, 0xa2, },
935 { 16 * 999.99 , 0xc8, 0xa4, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200936};
937
938static struct tuner_params tuner_philips_td1316_params[] = {
939 {
940 .type = TUNER_PARAM_TYPE_PAL,
941 .ranges = tuner_philips_td1316_pal_ranges,
942 .count = ARRAY_SIZE(tuner_philips_td1316_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200943 },
944};
945
946/* ------------ TUNER_PHILIPS_TUV1236D - Philips ATSC ------------ */
947
948static struct tuner_range tuner_tuv1236d_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200949 { 16 * 157.25 /*MHz*/, 0xce, 0x01, },
950 { 16 * 454.00 /*MHz*/, 0xce, 0x02, },
951 { 16 * 999.99 , 0xce, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200952};
953
954
Michael Krufkycc925bb2006-01-23 17:11:11 -0200955static struct tuner_params tuner_tuv1236d_params[] = {
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200956 {
957 .type = TUNER_PARAM_TYPE_NTSC,
958 .ranges = tuner_tuv1236d_ntsc_ranges,
959 .count = ARRAY_SIZE(tuner_tuv1236d_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200960 },
961};
962
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -0300963/* ------------ TUNER_TNF_xxx5 - Texas Instruments--------- */
964/* This is known to work with Tenna TVF58t5-MFF and TVF5835 MFF
965 * but it is expected to work also with other Tenna/Ymec
966 * models based on TI SN 761677 chip on both PAL and NTSC
967 */
968
969static struct tuner_range tuner_tnf_5335_d_if_pal_ranges[] = {
970 { 16 * 168.25 /*MHz*/, 0x8e, 0x01, },
Mauro Carvalho Chehab7947a222006-03-09 16:09:20 -0300971 { 16 * 471.25 /*MHz*/, 0x8e, 0x02, },
972 { 16 * 999.99 , 0x8e, 0x08, },
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -0300973};
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200974
975static struct tuner_range tuner_tnf_5335mf_ntsc_ranges[] = {
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -0300976 { 16 * 169.25 /*MHz*/, 0x8e, 0x01, },
977 { 16 * 469.25 /*MHz*/, 0x8e, 0x02, },
978 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200979};
980
981static struct tuner_params tuner_tnf_5335mf_params[] = {
982 {
983 .type = TUNER_PARAM_TYPE_NTSC,
984 .ranges = tuner_tnf_5335mf_ntsc_ranges,
985 .count = ARRAY_SIZE(tuner_tnf_5335mf_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200986 },
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -0300987 {
988 .type = TUNER_PARAM_TYPE_PAL,
989 .ranges = tuner_tnf_5335_d_if_pal_ranges,
990 .count = ARRAY_SIZE(tuner_tnf_5335_d_if_pal_ranges),
991 },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200992};
993
Hans Verkuilb3d37042006-01-13 14:10:25 -0200994/* 70-79 */
995/* ------------ TUNER_SAMSUNG_TCPN_2121P30A - Samsung NTSC ------------ */
996
997static struct tuner_range tuner_samsung_tcpn_2121p30a_ntsc_ranges[] = {
Hans Verkuildf821f72006-02-06 23:52:24 +0200998 { 16 * 130.00 /*MHz*/, 0xce, 0x01, },
999 { 16 * 364.50 /*MHz*/, 0xce, 0x02, },
Michael Krufky3fc46d32006-01-23 17:11:11 -02001000 { 16 * 999.99 , 0xce, 0x08, },
Hans Verkuilb3d37042006-01-13 14:10:25 -02001001};
1002
1003static struct tuner_params tuner_samsung_tcpn_2121p30a_params[] = {
1004 {
1005 .type = TUNER_PARAM_TYPE_NTSC,
1006 .ranges = tuner_samsung_tcpn_2121p30a_ntsc_ranges,
1007 .count = ARRAY_SIZE(tuner_samsung_tcpn_2121p30a_ntsc_ranges),
Hans Verkuilb3d37042006-01-13 14:10:25 -02001008 },
1009};
1010
Michael Krufky91ae3292006-03-01 00:04:42 -03001011/* ------------ TUNER_THOMSON_FE6600 - DViCO Hybrid PAL ------------ */
Chris Pascoe780dfef2006-02-28 08:34:59 -03001012
Michael Krufky91ae3292006-03-01 00:04:42 -03001013static struct tuner_range tuner_thomson_fe6600_ranges[] = {
Chris Pascoe780dfef2006-02-28 08:34:59 -03001014 { 16 * 160.00 /*MHz*/, 0xfe, 0x11, },
1015 { 16 * 442.00 /*MHz*/, 0xf6, 0x12, },
1016 { 16 * 999.99 , 0xf6, 0x18, },
1017};
1018
Michael Krufky91ae3292006-03-01 00:04:42 -03001019static struct tuner_params tuner_thomson_fe6600_params[] = {
Chris Pascoe780dfef2006-02-28 08:34:59 -03001020 {
1021 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufky91ae3292006-03-01 00:04:42 -03001022 .ranges = tuner_thomson_fe6600_ranges,
1023 .count = ARRAY_SIZE(tuner_thomson_fe6600_ranges),
Chris Pascoe780dfef2006-02-28 08:34:59 -03001024 },
1025};
1026
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001027/* --------------------------------------------------------------------- */
1028
1029struct tunertype tuners[] = {
1030 /* 0-9 */
1031 [TUNER_TEMIC_PAL] = { /* TEMIC PAL */
1032 .name = "Temic PAL (4002 FH5)",
1033 .params = tuner_temic_pal_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001034 .count = ARRAY_SIZE(tuner_temic_pal_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001035 },
1036 [TUNER_PHILIPS_PAL_I] = { /* Philips PAL_I */
1037 .name = "Philips PAL_I (FI1246 and compatibles)",
1038 .params = tuner_philips_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001039 .count = ARRAY_SIZE(tuner_philips_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001040 },
1041 [TUNER_PHILIPS_NTSC] = { /* Philips NTSC */
1042 .name = "Philips NTSC (FI1236,FM1236 and compatibles)",
1043 .params = tuner_philips_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001044 .count = ARRAY_SIZE(tuner_philips_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001045 },
1046 [TUNER_PHILIPS_SECAM] = { /* Philips SECAM */
1047 .name = "Philips (SECAM+PAL_BG) (FI1216MF, FM1216MF, FR1216MF)",
1048 .params = tuner_philips_secam_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001049 .count = ARRAY_SIZE(tuner_philips_secam_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001050 },
1051 [TUNER_ABSENT] = { /* Tuner Absent */
1052 .name = "NoTuner",
1053 },
1054 [TUNER_PHILIPS_PAL] = { /* Philips PAL */
1055 .name = "Philips PAL_BG (FI1216 and compatibles)",
1056 .params = tuner_philips_pal_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001057 .count = ARRAY_SIZE(tuner_philips_pal_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001058 },
1059 [TUNER_TEMIC_NTSC] = { /* TEMIC NTSC */
1060 .name = "Temic NTSC (4032 FY5)",
1061 .params = tuner_temic_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001062 .count = ARRAY_SIZE(tuner_temic_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001063 },
1064 [TUNER_TEMIC_PAL_I] = { /* TEMIC PAL_I */
1065 .name = "Temic PAL_I (4062 FY5)",
1066 .params = tuner_temic_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001067 .count = ARRAY_SIZE(tuner_temic_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001068 },
1069 [TUNER_TEMIC_4036FY5_NTSC] = { /* TEMIC NTSC */
1070 .name = "Temic NTSC (4036 FY5)",
1071 .params = tuner_temic_4036fy5_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001072 .count = ARRAY_SIZE(tuner_temic_4036fy5_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001073 },
1074 [TUNER_ALPS_TSBH1_NTSC] = { /* TEMIC NTSC */
1075 .name = "Alps HSBH1",
1076 .params = tuner_alps_tsbh1_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001077 .count = ARRAY_SIZE(tuner_alps_tsbh1_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001078 },
1079
1080 /* 10-19 */
1081 [TUNER_ALPS_TSBE1_PAL] = { /* TEMIC PAL */
1082 .name = "Alps TSBE1",
1083 .params = tuner_alps_tsb_1_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001084 .count = ARRAY_SIZE(tuner_alps_tsb_1_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001085 },
1086 [TUNER_ALPS_TSBB5_PAL_I] = { /* Alps PAL_I */
1087 .name = "Alps TSBB5",
1088 .params = tuner_alps_tsbb5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001089 .count = ARRAY_SIZE(tuner_alps_tsbb5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001090 },
1091 [TUNER_ALPS_TSBE5_PAL] = { /* Alps PAL */
1092 .name = "Alps TSBE5",
1093 .params = tuner_alps_tsbe5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001094 .count = ARRAY_SIZE(tuner_alps_tsbe5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001095 },
1096 [TUNER_ALPS_TSBC5_PAL] = { /* Alps PAL */
1097 .name = "Alps TSBC5",
1098 .params = tuner_alps_tsbc5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001099 .count = ARRAY_SIZE(tuner_alps_tsbc5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001100 },
1101 [TUNER_TEMIC_4006FH5_PAL] = { /* TEMIC PAL */
1102 .name = "Temic PAL_BG (4006FH5)",
1103 .params = tuner_temic_4006fh5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001104 .count = ARRAY_SIZE(tuner_temic_4006fh5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001105 },
1106 [TUNER_ALPS_TSHC6_NTSC] = { /* Alps NTSC */
1107 .name = "Alps TSCH6",
1108 .params = tuner_alps_tshc6_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001109 .count = ARRAY_SIZE(tuner_alps_tshc6_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001110 },
1111 [TUNER_TEMIC_PAL_DK] = { /* TEMIC PAL */
1112 .name = "Temic PAL_DK (4016 FY5)",
1113 .params = tuner_temic_pal_dk_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001114 .count = ARRAY_SIZE(tuner_temic_pal_dk_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001115 },
1116 [TUNER_PHILIPS_NTSC_M] = { /* Philips NTSC */
1117 .name = "Philips NTSC_M (MK2)",
1118 .params = tuner_philips_ntsc_m_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001119 .count = ARRAY_SIZE(tuner_philips_ntsc_m_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001120 },
1121 [TUNER_TEMIC_4066FY5_PAL_I] = { /* TEMIC PAL_I */
1122 .name = "Temic PAL_I (4066 FY5)",
1123 .params = tuner_temic_4066fy5_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001124 .count = ARRAY_SIZE(tuner_temic_4066fy5_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001125 },
1126 [TUNER_TEMIC_4006FN5_MULTI_PAL] = { /* TEMIC PAL */
1127 .name = "Temic PAL* auto (4006 FN5)",
1128 .params = tuner_temic_4006fn5_multi_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001129 .count = ARRAY_SIZE(tuner_temic_4006fn5_multi_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001130 },
1131
1132 /* 20-29 */
1133 [TUNER_TEMIC_4009FR5_PAL] = { /* TEMIC PAL */
1134 .name = "Temic PAL_BG (4009 FR5) or PAL_I (4069 FR5)",
1135 .params = tuner_temic_4009f_5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001136 .count = ARRAY_SIZE(tuner_temic_4009f_5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001137 },
1138 [TUNER_TEMIC_4039FR5_NTSC] = { /* TEMIC NTSC */
1139 .name = "Temic NTSC (4039 FR5)",
1140 .params = tuner_temic_4039fr5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001141 .count = ARRAY_SIZE(tuner_temic_4039fr5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001142 },
1143 [TUNER_TEMIC_4046FM5] = { /* TEMIC PAL */
1144 .name = "Temic PAL/SECAM multi (4046 FM5)",
1145 .params = tuner_temic_4046fm5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001146 .count = ARRAY_SIZE(tuner_temic_4046fm5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001147 },
1148 [TUNER_PHILIPS_PAL_DK] = { /* Philips PAL */
1149 .name = "Philips PAL_DK (FI1256 and compatibles)",
1150 .params = tuner_philips_pal_dk_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001151 .count = ARRAY_SIZE(tuner_philips_pal_dk_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001152 },
1153 [TUNER_PHILIPS_FQ1216ME] = { /* Philips PAL */
1154 .name = "Philips PAL/SECAM multi (FQ1216ME)",
1155 .params = tuner_philips_fq1216me_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001156 .count = ARRAY_SIZE(tuner_philips_fq1216me_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001157 },
1158 [TUNER_LG_PAL_I_FM] = { /* LGINNOTEK PAL_I */
1159 .name = "LG PAL_I+FM (TAPC-I001D)",
1160 .params = tuner_lg_pal_i_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001161 .count = ARRAY_SIZE(tuner_lg_pal_i_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001162 },
1163 [TUNER_LG_PAL_I] = { /* LGINNOTEK PAL_I */
1164 .name = "LG PAL_I (TAPC-I701D)",
1165 .params = tuner_lg_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001166 .count = ARRAY_SIZE(tuner_lg_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001167 },
1168 [TUNER_LG_NTSC_FM] = { /* LGINNOTEK NTSC */
1169 .name = "LG NTSC+FM (TPI8NSR01F)",
1170 .params = tuner_lg_ntsc_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001171 .count = ARRAY_SIZE(tuner_lg_ntsc_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001172 },
1173 [TUNER_LG_PAL_FM] = { /* LGINNOTEK PAL */
1174 .name = "LG PAL_BG+FM (TPI8PSB01D)",
1175 .params = tuner_lg_pal_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001176 .count = ARRAY_SIZE(tuner_lg_pal_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001177 },
1178 [TUNER_LG_PAL] = { /* LGINNOTEK PAL */
1179 .name = "LG PAL_BG (TPI8PSB11D)",
1180 .params = tuner_lg_pal_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001181 .count = ARRAY_SIZE(tuner_lg_pal_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001182 },
1183
1184 /* 30-39 */
1185 [TUNER_TEMIC_4009FN5_MULTI_PAL_FM] = { /* TEMIC PAL */
1186 .name = "Temic PAL* auto + FM (4009 FN5)",
1187 .params = tuner_temic_4009_fn5_multi_pal_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001188 .count = ARRAY_SIZE(tuner_temic_4009_fn5_multi_pal_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001189 },
1190 [TUNER_SHARP_2U5JF5540_NTSC] = { /* SHARP NTSC */
1191 .name = "SHARP NTSC_JP (2U5JF5540)",
1192 .params = tuner_sharp_2u5jf5540_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001193 .count = ARRAY_SIZE(tuner_sharp_2u5jf5540_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001194 },
1195 [TUNER_Samsung_PAL_TCPM9091PD27] = { /* Samsung PAL */
1196 .name = "Samsung PAL TCPM9091PD27",
1197 .params = tuner_samsung_pal_tcpm9091pd27_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001198 .count = ARRAY_SIZE(tuner_samsung_pal_tcpm9091pd27_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001199 },
1200 [TUNER_MT2032] = { /* Microtune PAL|NTSC */
1201 .name = "MT20xx universal",
1202 /* see mt20xx.c for details */ },
1203 [TUNER_TEMIC_4106FH5] = { /* TEMIC PAL */
1204 .name = "Temic PAL_BG (4106 FH5)",
1205 .params = tuner_temic_4106fh5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001206 .count = ARRAY_SIZE(tuner_temic_4106fh5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001207 },
1208 [TUNER_TEMIC_4012FY5] = { /* TEMIC PAL */
1209 .name = "Temic PAL_DK/SECAM_L (4012 FY5)",
1210 .params = tuner_temic_4012fy5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001211 .count = ARRAY_SIZE(tuner_temic_4012fy5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001212 },
1213 [TUNER_TEMIC_4136FY5] = { /* TEMIC NTSC */
1214 .name = "Temic NTSC (4136 FY5)",
1215 .params = tuner_temic_4136_fy5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001216 .count = ARRAY_SIZE(tuner_temic_4136_fy5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001217 },
1218 [TUNER_LG_PAL_NEW_TAPC] = { /* LGINNOTEK PAL */
1219 .name = "LG PAL (newer TAPC series)",
1220 .params = tuner_lg_pal_new_tapc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001221 .count = ARRAY_SIZE(tuner_lg_pal_new_tapc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001222 },
1223 [TUNER_PHILIPS_FM1216ME_MK3] = { /* Philips PAL */
1224 .name = "Philips PAL/SECAM multi (FM1216ME MK3)",
1225 .params = tuner_fm1216me_mk3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001226 .count = ARRAY_SIZE(tuner_fm1216me_mk3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001227 },
1228 [TUNER_LG_NTSC_NEW_TAPC] = { /* LGINNOTEK NTSC */
1229 .name = "LG NTSC (newer TAPC series)",
1230 .params = tuner_lg_ntsc_new_tapc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001231 .count = ARRAY_SIZE(tuner_lg_ntsc_new_tapc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001232 },
1233
1234 /* 40-49 */
1235 [TUNER_HITACHI_NTSC] = { /* HITACHI NTSC */
1236 .name = "HITACHI V7-J180AT",
1237 .params = tuner_hitachi_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001238 .count = ARRAY_SIZE(tuner_hitachi_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001239 },
1240 [TUNER_PHILIPS_PAL_MK] = { /* Philips PAL */
1241 .name = "Philips PAL_MK (FI1216 MK)",
1242 .params = tuner_philips_pal_mk_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001243 .count = ARRAY_SIZE(tuner_philips_pal_mk_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001244 },
1245 [TUNER_PHILIPS_ATSC] = { /* Philips ATSC */
1246 .name = "Philips 1236D ATSC/NTSC dual in",
1247 .params = tuner_philips_atsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001248 .count = ARRAY_SIZE(tuner_philips_atsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001249 },
1250 [TUNER_PHILIPS_FM1236_MK3] = { /* Philips NTSC */
1251 .name = "Philips NTSC MK3 (FM1236MK3 or FM1236/F)",
1252 .params = tuner_fm1236_mk3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001253 .count = ARRAY_SIZE(tuner_fm1236_mk3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001254 },
1255 [TUNER_PHILIPS_4IN1] = { /* Philips NTSC */
1256 .name = "Philips 4 in 1 (ATI TV Wonder Pro/Conexant)",
1257 .params = tuner_philips_4in1_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001258 .count = ARRAY_SIZE(tuner_philips_4in1_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001259 },
1260 [TUNER_MICROTUNE_4049FM5] = { /* Microtune PAL */
1261 .name = "Microtune 4049 FM5",
1262 .params = tuner_microtune_4049_fm5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001263 .count = ARRAY_SIZE(tuner_microtune_4049_fm5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001264 },
1265 [TUNER_PANASONIC_VP27] = { /* Panasonic NTSC */
1266 .name = "Panasonic VP27s/ENGE4324D",
1267 .params = tuner_panasonic_vp27_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001268 .count = ARRAY_SIZE(tuner_panasonic_vp27_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001269 },
1270 [TUNER_LG_NTSC_TAPE] = { /* LGINNOTEK NTSC */
1271 .name = "LG NTSC (TAPE series)",
1272 .params = tuner_lg_ntsc_tape_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001273 .count = ARRAY_SIZE(tuner_lg_ntsc_tape_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001274 },
1275 [TUNER_TNF_8831BGFF] = { /* Philips PAL */
1276 .name = "Tenna TNF 8831 BGFF)",
1277 .params = tuner_tnf_8831bgff_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001278 .count = ARRAY_SIZE(tuner_tnf_8831bgff_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001279 },
1280 [TUNER_MICROTUNE_4042FI5] = { /* Microtune NTSC */
1281 .name = "Microtune 4042 FI5 ATSC/NTSC dual in",
1282 .params = tuner_microtune_4042fi5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001283 .count = ARRAY_SIZE(tuner_microtune_4042fi5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001284 },
1285
1286 /* 50-59 */
1287 [TUNER_TCL_2002N] = { /* TCL NTSC */
1288 .name = "TCL 2002N",
1289 .params = tuner_tcl_2002n_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001290 .count = ARRAY_SIZE(tuner_tcl_2002n_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001291 },
1292 [TUNER_PHILIPS_FM1256_IH3] = { /* Philips PAL */
1293 .name = "Philips PAL/SECAM_D (FM 1256 I-H3)",
1294 .params = tuner_philips_fm1256_ih3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001295 .count = ARRAY_SIZE(tuner_philips_fm1256_ih3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001296 },
1297 [TUNER_THOMSON_DTT7610] = { /* THOMSON ATSC */
1298 .name = "Thomson DTT 7610 (ATSC/NTSC)",
1299 .params = tuner_thomson_dtt7610_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001300 .count = ARRAY_SIZE(tuner_thomson_dtt7610_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001301 },
1302 [TUNER_PHILIPS_FQ1286] = { /* Philips NTSC */
1303 .name = "Philips FQ1286",
1304 .params = tuner_philips_fq1286_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001305 .count = ARRAY_SIZE(tuner_philips_fq1286_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001306 },
1307 [TUNER_PHILIPS_TDA8290] = { /* Philips PAL|NTSC */
1308 .name = "tda8290+75",
1309 /* see tda8290.c for details */ },
1310 [TUNER_TCL_2002MB] = { /* TCL PAL */
1311 .name = "TCL 2002MB",
1312 .params = tuner_tcl_2002mb_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001313 .count = ARRAY_SIZE(tuner_tcl_2002mb_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001314 },
1315 [TUNER_PHILIPS_FQ1216AME_MK4] = { /* Philips PAL */
1316 .name = "Philips PAL/SECAM multi (FQ1216AME MK4)",
1317 .params = tuner_philips_fq1216ame_mk4_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001318 .count = ARRAY_SIZE(tuner_philips_fq1216ame_mk4_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001319 },
1320 [TUNER_PHILIPS_FQ1236A_MK4] = { /* Philips NTSC */
1321 .name = "Philips FQ1236A MK4",
1322 .params = tuner_philips_fq1236a_mk4_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001323 .count = ARRAY_SIZE(tuner_philips_fq1236a_mk4_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001324 },
1325 [TUNER_YMEC_TVF_8531MF] = { /* Philips NTSC */
1326 .name = "Ymec TVision TVF-8531MF/8831MF/8731MF",
1327 .params = tuner_ymec_tvf_8531mf_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001328 .count = ARRAY_SIZE(tuner_ymec_tvf_8531mf_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001329 },
1330 [TUNER_YMEC_TVF_5533MF] = { /* Philips NTSC */
1331 .name = "Ymec TVision TVF-5533MF",
1332 .params = tuner_ymec_tvf_5533mf_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001333 .count = ARRAY_SIZE(tuner_ymec_tvf_5533mf_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001334 },
1335
1336 /* 60-69 */
1337 [TUNER_THOMSON_DTT761X] = { /* THOMSON ATSC */
1338 /* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
1339 .name = "Thomson DTT 761X (ATSC/NTSC)",
1340 .params = tuner_thomson_dtt761x_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001341 .count = ARRAY_SIZE(tuner_thomson_dtt761x_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001342 },
1343 [TUNER_TENA_9533_DI] = { /* Philips PAL */
1344 .name = "Tena TNF9533-D/IF/TNF9533-B/DF",
1345 .params = tuner_tena_9533_di_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001346 .count = ARRAY_SIZE(tuner_tena_9533_di_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001347 },
1348 [TUNER_TEA5767] = { /* Philips RADIO */
1349 .name = "Philips TEA5767HN FM Radio",
1350 /* see tea5767.c for details */
1351 },
1352 [TUNER_PHILIPS_FMD1216ME_MK3] = { /* Philips PAL */
1353 .name = "Philips FMD1216ME MK3 Hybrid Tuner",
Michael Krufkycc925bb2006-01-23 17:11:11 -02001354 .params = tuner_philips_fmd1216me_mk3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001355 .count = ARRAY_SIZE(tuner_philips_fmd1216me_mk3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001356 },
1357 [TUNER_LG_TDVS_H062F] = { /* LGINNOTEK ATSC */
1358 .name = "LG TDVS-H062F/TUA6034",
1359 .params = tuner_tua6034_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001360 .count = ARRAY_SIZE(tuner_tua6034_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001361 },
1362 [TUNER_YMEC_TVF66T5_B_DFF] = { /* Philips PAL */
1363 .name = "Ymec TVF66T5-B/DFF",
1364 .params = tuner_ymec_tvf66t5_b_dff_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001365 .count = ARRAY_SIZE(tuner_ymec_tvf66t5_b_dff_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001366 },
Michael Krufkyf3629be2006-03-11 17:02:01 -03001367 [TUNER_LG_TALN] = { /* LGINNOTEK NTSC / PAL / SECAM */
1368 .name = "LG TALN series",
1369 .params = tuner_lg_taln_params,
1370 .count = ARRAY_SIZE(tuner_lg_taln_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001371 },
1372 [TUNER_PHILIPS_TD1316] = { /* Philips PAL */
1373 .name = "Philips TD1316 Hybrid Tuner",
1374 .params = tuner_philips_td1316_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001375 .count = ARRAY_SIZE(tuner_philips_td1316_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001376 },
1377 [TUNER_PHILIPS_TUV1236D] = { /* Philips ATSC */
1378 .name = "Philips TUV1236D ATSC/NTSC dual in",
Michael Krufkycc925bb2006-01-23 17:11:11 -02001379 .params = tuner_tuv1236d_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001380 .count = ARRAY_SIZE(tuner_tuv1236d_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001381 },
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -03001382 [TUNER_TNF_5335MF] = { /* Tenna PAL/NTSC */
1383 .name = "Tena TNF 5335 and similar models",
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001384 .params = tuner_tnf_5335mf_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001385 .count = ARRAY_SIZE(tuner_tnf_5335mf_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001386 },
Hans Verkuilb3d37042006-01-13 14:10:25 -02001387
1388 /* 70-79 */
1389 [TUNER_SAMSUNG_TCPN_2121P30A] = { /* Samsung NTSC */
1390 .name = "Samsung TCPN 2121P30A",
1391 .params = tuner_samsung_tcpn_2121p30a_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001392 .count = ARRAY_SIZE(tuner_samsung_tcpn_2121p30a_params),
Hans Verkuilb3d37042006-01-13 14:10:25 -02001393 },
Markus Rechberger0004fd52006-02-27 00:07:27 -03001394 [TUNER_XCEIVE_XC3028] = { /* Xceive 3028 */
1395 .name = "Xceive xc3028",
Mauro Carvalho Chehabcfcd7182006-02-27 00:07:37 -03001396 /* see xc3028.c for details */
Markus Rechberger0004fd52006-02-27 00:07:27 -03001397 },
Michael Krufky91ae3292006-03-01 00:04:42 -03001398 [TUNER_THOMSON_FE6600] = { /* Thomson PAL / DVB-T */
1399 .name = "Thomson FE6600",
1400 .params = tuner_thomson_fe6600_params,
Michael Krufkyb1b168e2006-03-11 16:12:35 -03001401 .count = ARRAY_SIZE(tuner_thomson_fe6600_params),
Chris Pascoe780dfef2006-02-28 08:34:59 -03001402 },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001403};
1404
1405unsigned const int tuner_count = ARRAY_SIZE(tuners);