blob: 74c3e6f96f1a7b0846b93d57938c3d1788e7011e [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),
Hans Verkuilba8fc392006-06-25 15:34:39 -0300383 .has_tda9887 = 1,
384 .port1_active = 1,
385 .port2_active = 1,
386 .port2_invert_for_secam_lc = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200387 },
388};
389
390/* ------------ TUNER_LG_PAL_I_FM - LGINNOTEK PAL_I ------------ */
391
392static struct tuner_params tuner_lg_pal_i_fm_params[] = {
393 {
394 .type = TUNER_PARAM_TYPE_PAL,
395 .ranges = tuner_lg_pal_ranges,
396 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200397 },
398};
399
400/* ------------ TUNER_LG_PAL_I - LGINNOTEK PAL_I ------------ */
401
402static struct tuner_params tuner_lg_pal_i_params[] = {
403 {
404 .type = TUNER_PARAM_TYPE_PAL,
405 .ranges = tuner_lg_pal_ranges,
406 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200407 },
408};
409
410/* ------------ TUNER_LG_NTSC_FM - LGINNOTEK NTSC ------------ */
411
412static struct tuner_range tuner_lg_ntsc_fm_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200413 { 16 * 210.00 /*MHz*/, 0x8e, 0xa0, },
414 { 16 * 497.00 /*MHz*/, 0x8e, 0x90, },
415 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200416};
417
418static struct tuner_params tuner_lg_ntsc_fm_params[] = {
419 {
420 .type = TUNER_PARAM_TYPE_NTSC,
421 .ranges = tuner_lg_ntsc_fm_ranges,
422 .count = ARRAY_SIZE(tuner_lg_ntsc_fm_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200423 },
424};
425
426/* ------------ TUNER_LG_PAL_FM - LGINNOTEK PAL ------------ */
427
428static struct tuner_params tuner_lg_pal_fm_params[] = {
429 {
430 .type = TUNER_PARAM_TYPE_PAL,
431 .ranges = tuner_lg_pal_ranges,
432 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200433 },
434};
435
436/* ------------ TUNER_LG_PAL - LGINNOTEK PAL ------------ */
437
438static struct tuner_params tuner_lg_pal_params[] = {
439 {
440 .type = TUNER_PARAM_TYPE_PAL,
441 .ranges = tuner_lg_pal_ranges,
442 .count = ARRAY_SIZE(tuner_lg_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200443 },
444};
445
446/* 30-39 */
447/* ------------ TUNER_TEMIC_4009FN5_MULTI_PAL_FM - TEMIC PAL ------------ */
448
449static struct tuner_params tuner_temic_4009_fn5_multi_pal_fm_params[] = {
450 {
451 .type = TUNER_PARAM_TYPE_PAL,
452 .ranges = tuner_temic_4009f_5_pal_ranges,
453 .count = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200454 },
455};
456
457/* ------------ TUNER_SHARP_2U5JF5540_NTSC - SHARP NTSC ------------ */
458
459static struct tuner_range tuner_sharp_2u5jf5540_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200460 { 16 * 137.25 /*MHz*/, 0x8e, 0x01, },
461 { 16 * 317.25 /*MHz*/, 0x8e, 0x02, },
462 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200463};
464
465static struct tuner_params tuner_sharp_2u5jf5540_params[] = {
466 {
467 .type = TUNER_PARAM_TYPE_NTSC,
468 .ranges = tuner_sharp_2u5jf5540_ntsc_ranges,
469 .count = ARRAY_SIZE(tuner_sharp_2u5jf5540_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200470 },
471};
472
473/* ------------ TUNER_Samsung_PAL_TCPM9091PD27 - Samsung PAL ------------ */
474
475static struct tuner_range tuner_samsung_pal_tcpm9091pd27_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200476 { 16 * 169 /*MHz*/, 0x8e, 0xa0, },
477 { 16 * 464 /*MHz*/, 0x8e, 0x90, },
478 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200479};
480
481static struct tuner_params tuner_samsung_pal_tcpm9091pd27_params[] = {
482 {
483 .type = TUNER_PARAM_TYPE_PAL,
484 .ranges = tuner_samsung_pal_tcpm9091pd27_ranges,
485 .count = ARRAY_SIZE(tuner_samsung_pal_tcpm9091pd27_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200486 },
487};
488
489/* ------------ TUNER_TEMIC_4106FH5 - TEMIC PAL ------------ */
490
491static struct tuner_params tuner_temic_4106fh5_params[] = {
492 {
493 .type = TUNER_PARAM_TYPE_PAL,
494 .ranges = tuner_temic_4009f_5_pal_ranges,
495 .count = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200496 },
497};
498
499/* ------------ TUNER_TEMIC_4012FY5 - TEMIC PAL ------------ */
500
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200501static struct tuner_params tuner_temic_4012fy5_params[] = {
502 {
503 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200504 .ranges = tuner_temic_pal_ranges,
505 .count = ARRAY_SIZE(tuner_temic_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200506 },
507};
508
509/* ------------ TUNER_TEMIC_4136FY5 - TEMIC NTSC ------------ */
510
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200511static struct tuner_params tuner_temic_4136_fy5_params[] = {
512 {
513 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200514 .ranges = tuner_temic_4x3x_f_5_ntsc_ranges,
515 .count = ARRAY_SIZE(tuner_temic_4x3x_f_5_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200516 },
517};
518
519/* ------------ TUNER_LG_PAL_NEW_TAPC - LGINNOTEK PAL ------------ */
520
521static struct tuner_range tuner_lg_new_tapc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200522 { 16 * 170.00 /*MHz*/, 0x8e, 0x01, },
523 { 16 * 450.00 /*MHz*/, 0x8e, 0x02, },
524 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200525};
526
527static struct tuner_params tuner_lg_pal_new_tapc_params[] = {
528 {
529 .type = TUNER_PARAM_TYPE_PAL,
530 .ranges = tuner_lg_new_tapc_ranges,
531 .count = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200532 },
533};
534
535/* ------------ TUNER_PHILIPS_FM1216ME_MK3 - Philips PAL ------------ */
536
537static struct tuner_range tuner_fm1216me_mk3_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200538 { 16 * 158.00 /*MHz*/, 0x8e, 0x01, },
539 { 16 * 442.00 /*MHz*/, 0x8e, 0x02, },
540 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200541};
542
543static struct tuner_params tuner_fm1216me_mk3_params[] = {
544 {
545 .type = TUNER_PARAM_TYPE_PAL,
546 .ranges = tuner_fm1216me_mk3_pal_ranges,
547 .count = ARRAY_SIZE(tuner_fm1216me_mk3_pal_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200548 .cb_first_if_lower_freq = 1,
Hans Verkuilba8fc392006-06-25 15:34:39 -0300549 .has_tda9887 = 1,
550 .port1_active = 1,
551 .port2_active = 1,
552 .port2_invert_for_secam_lc = 1,
553 .port1_fm_high_sensitivity = 1,
554 .default_top_mid = -2,
555 .default_top_secam_mid = -2,
556 .default_top_secam_high = -2,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200557 },
558};
559
560/* ------------ TUNER_LG_NTSC_NEW_TAPC - LGINNOTEK NTSC ------------ */
561
562static struct tuner_params tuner_lg_ntsc_new_tapc_params[] = {
563 {
564 .type = TUNER_PARAM_TYPE_NTSC,
565 .ranges = tuner_lg_new_tapc_ranges,
566 .count = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200567 },
568};
569
570/* 40-49 */
571/* ------------ TUNER_HITACHI_NTSC - HITACHI NTSC ------------ */
572
573static struct tuner_params tuner_hitachi_ntsc_params[] = {
574 {
575 .type = TUNER_PARAM_TYPE_NTSC,
576 .ranges = tuner_lg_new_tapc_ranges,
577 .count = ARRAY_SIZE(tuner_lg_new_tapc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200578 },
579};
580
581/* ------------ TUNER_PHILIPS_PAL_MK - Philips PAL ------------ */
582
583static struct tuner_range tuner_philips_pal_mk_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200584 { 16 * 140.25 /*MHz*/, 0x8e, 0x01, },
585 { 16 * 463.25 /*MHz*/, 0x8e, 0xc2, },
586 { 16 * 999.99 , 0x8e, 0xcf, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200587};
588
589static struct tuner_params tuner_philips_pal_mk_params[] = {
590 {
591 .type = TUNER_PARAM_TYPE_PAL,
592 .ranges = tuner_philips_pal_mk_pal_ranges,
593 .count = ARRAY_SIZE(tuner_philips_pal_mk_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200594 },
595};
596
597/* ------------ TUNER_PHILIPS_ATSC - Philips ATSC ------------ */
598
599static struct tuner_range tuner_philips_atsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200600 { 16 * 157.25 /*MHz*/, 0x8e, 0xa0, },
601 { 16 * 454.00 /*MHz*/, 0x8e, 0x90, },
602 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200603};
604
605static struct tuner_params tuner_philips_atsc_params[] = {
606 {
607 .type = TUNER_PARAM_TYPE_NTSC,
608 .ranges = tuner_philips_atsc_ranges,
609 .count = ARRAY_SIZE(tuner_philips_atsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200610 },
611};
612
613/* ------------ TUNER_PHILIPS_FM1236_MK3 - Philips NTSC ------------ */
614
615static struct tuner_range tuner_fm1236_mk3_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200616 { 16 * 160.00 /*MHz*/, 0x8e, 0x01, },
617 { 16 * 442.00 /*MHz*/, 0x8e, 0x02, },
618 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200619};
620
621static struct tuner_params tuner_fm1236_mk3_params[] = {
622 {
623 .type = TUNER_PARAM_TYPE_NTSC,
624 .ranges = tuner_fm1236_mk3_ntsc_ranges,
625 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200626 .cb_first_if_lower_freq = 1,
Hans Verkuilba8fc392006-06-25 15:34:39 -0300627 .has_tda9887 = 1,
628 .port1_active = 1,
629 .port2_active = 1,
630 .port1_fm_high_sensitivity = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200631 },
632};
633
634/* ------------ TUNER_PHILIPS_4IN1 - Philips NTSC ------------ */
635
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200636static struct tuner_params tuner_philips_4in1_params[] = {
637 {
638 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200639 .ranges = tuner_fm1236_mk3_ntsc_ranges,
640 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200641 },
642};
643
644/* ------------ TUNER_MICROTUNE_4049FM5 - Microtune PAL ------------ */
645
646static struct tuner_params tuner_microtune_4049_fm5_params[] = {
647 {
648 .type = TUNER_PARAM_TYPE_PAL,
649 .ranges = tuner_temic_4009f_5_pal_ranges,
650 .count = ARRAY_SIZE(tuner_temic_4009f_5_pal_ranges),
Hans Verkuilba8fc392006-06-25 15:34:39 -0300651 .has_tda9887 = 1,
652 .port1_invert_for_secam_lc = 1,
Trent Piephod7304de2006-08-24 22:43:45 -0300653 .default_pll_gating_18 = 1,
Thierry MERLEd8159a32006-12-04 08:31:42 -0300654 .fm_gain_normal=1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200655 },
656};
657
658/* ------------ TUNER_PANASONIC_VP27 - Panasonic NTSC ------------ */
659
660static struct tuner_range tuner_panasonic_vp27_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200661 { 16 * 160.00 /*MHz*/, 0xce, 0x01, },
662 { 16 * 454.00 /*MHz*/, 0xce, 0x02, },
663 { 16 * 999.99 , 0xce, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200664};
665
666static struct tuner_params tuner_panasonic_vp27_params[] = {
667 {
668 .type = TUNER_PARAM_TYPE_NTSC,
669 .ranges = tuner_panasonic_vp27_ntsc_ranges,
670 .count = ARRAY_SIZE(tuner_panasonic_vp27_ntsc_ranges),
Hans Verkuilba8fc392006-06-25 15:34:39 -0300671 .has_tda9887 = 1,
672 .intercarrier_mode = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200673 },
674};
675
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200676/* ------------ TUNER_TNF_8831BGFF - Philips PAL ------------ */
677
678static struct tuner_range tuner_tnf_8831bgff_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200679 { 16 * 161.25 /*MHz*/, 0x8e, 0xa0, },
680 { 16 * 463.25 /*MHz*/, 0x8e, 0x90, },
681 { 16 * 999.99 , 0x8e, 0x30, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200682};
683
684static struct tuner_params tuner_tnf_8831bgff_params[] = {
685 {
686 .type = TUNER_PARAM_TYPE_PAL,
687 .ranges = tuner_tnf_8831bgff_pal_ranges,
688 .count = ARRAY_SIZE(tuner_tnf_8831bgff_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200689 },
690};
691
692/* ------------ TUNER_MICROTUNE_4042FI5 - Microtune NTSC ------------ */
693
694static struct tuner_range tuner_microtune_4042fi5_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200695 { 16 * 162.00 /*MHz*/, 0x8e, 0xa2, },
696 { 16 * 457.00 /*MHz*/, 0x8e, 0x94, },
697 { 16 * 999.99 , 0x8e, 0x31, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200698};
699
700static struct tuner_params tuner_microtune_4042fi5_params[] = {
701 {
702 .type = TUNER_PARAM_TYPE_NTSC,
703 .ranges = tuner_microtune_4042fi5_ntsc_ranges,
704 .count = ARRAY_SIZE(tuner_microtune_4042fi5_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200705 },
706};
707
708/* 50-59 */
709/* ------------ TUNER_TCL_2002N - TCL NTSC ------------ */
710
711static struct tuner_range tuner_tcl_2002n_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200712 { 16 * 172.00 /*MHz*/, 0x8e, 0x01, },
713 { 16 * 448.00 /*MHz*/, 0x8e, 0x02, },
714 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200715};
716
717static struct tuner_params tuner_tcl_2002n_params[] = {
718 {
719 .type = TUNER_PARAM_TYPE_NTSC,
720 .ranges = tuner_tcl_2002n_ntsc_ranges,
721 .count = ARRAY_SIZE(tuner_tcl_2002n_ntsc_ranges),
Hans Verkuil27487d42006-01-15 15:04:52 -0200722 .cb_first_if_lower_freq = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200723 },
724};
725
726/* ------------ TUNER_PHILIPS_FM1256_IH3 - Philips PAL ------------ */
727
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200728static struct tuner_params tuner_philips_fm1256_ih3_params[] = {
729 {
730 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200731 .ranges = tuner_fm1236_mk3_ntsc_ranges,
732 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200733 },
734};
735
736/* ------------ TUNER_THOMSON_DTT7610 - THOMSON ATSC ------------ */
737
738static struct tuner_range tuner_thomson_dtt7610_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200739 { 16 * 157.25 /*MHz*/, 0x8e, 0x39, },
740 { 16 * 454.00 /*MHz*/, 0x8e, 0x3a, },
741 { 16 * 999.99 , 0x8e, 0x3c, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200742};
743
744static struct tuner_params tuner_thomson_dtt7610_params[] = {
745 {
746 .type = TUNER_PARAM_TYPE_NTSC,
747 .ranges = tuner_thomson_dtt7610_ntsc_ranges,
748 .count = ARRAY_SIZE(tuner_thomson_dtt7610_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200749 },
750};
751
752/* ------------ TUNER_PHILIPS_FQ1286 - Philips NTSC ------------ */
753
754static struct tuner_range tuner_philips_fq1286_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200755 { 16 * 160.00 /*MHz*/, 0x8e, 0x41, },
756 { 16 * 454.00 /*MHz*/, 0x8e, 0x42, },
757 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200758};
759
760static struct tuner_params tuner_philips_fq1286_params[] = {
761 {
762 .type = TUNER_PARAM_TYPE_NTSC,
763 .ranges = tuner_philips_fq1286_ntsc_ranges,
764 .count = ARRAY_SIZE(tuner_philips_fq1286_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200765 },
766};
767
768/* ------------ TUNER_TCL_2002MB - TCL PAL ------------ */
769
770static struct tuner_range tuner_tcl_2002mb_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200771 { 16 * 170.00 /*MHz*/, 0xce, 0x01, },
772 { 16 * 450.00 /*MHz*/, 0xce, 0x02, },
773 { 16 * 999.99 , 0xce, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200774};
775
776static struct tuner_params tuner_tcl_2002mb_params[] = {
777 {
778 .type = TUNER_PARAM_TYPE_PAL,
779 .ranges = tuner_tcl_2002mb_pal_ranges,
780 .count = ARRAY_SIZE(tuner_tcl_2002mb_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200781 },
782};
783
784/* ------------ TUNER_PHILIPS_FQ1216AME_MK4 - Philips PAL ------------ */
785
Michael Krufky3fc46d32006-01-23 17:11:11 -0200786static struct tuner_range tuner_philips_fq12_6a___mk4_pal_ranges[] = {
787 { 16 * 160.00 /*MHz*/, 0xce, 0x01, },
788 { 16 * 442.00 /*MHz*/, 0xce, 0x02, },
789 { 16 * 999.99 , 0xce, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200790};
791
792static struct tuner_params tuner_philips_fq1216ame_mk4_params[] = {
793 {
794 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufky3fc46d32006-01-23 17:11:11 -0200795 .ranges = tuner_philips_fq12_6a___mk4_pal_ranges,
796 .count = ARRAY_SIZE(tuner_philips_fq12_6a___mk4_pal_ranges),
Hans Verkuilba8fc392006-06-25 15:34:39 -0300797 .has_tda9887 = 1,
798 .port1_active = 1,
799 .port2_invert_for_secam_lc = 1,
800 .default_top_mid = -2,
801 .default_top_secam_low = -2,
802 .default_top_secam_mid = -2,
803 .default_top_secam_high = -2,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200804 },
805};
806
807/* ------------ TUNER_PHILIPS_FQ1236A_MK4 - Philips NTSC ------------ */
808
809static struct tuner_params tuner_philips_fq1236a_mk4_params[] = {
810 {
811 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200812 .ranges = tuner_fm1236_mk3_ntsc_ranges,
813 .count = ARRAY_SIZE(tuner_fm1236_mk3_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200814 },
815};
816
817/* ------------ TUNER_YMEC_TVF_8531MF - Philips NTSC ------------ */
818
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200819static struct tuner_params tuner_ymec_tvf_8531mf_params[] = {
820 {
821 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200822 .ranges = tuner_philips_ntsc_m_ranges,
823 .count = ARRAY_SIZE(tuner_philips_ntsc_m_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200824 },
825};
826
827/* ------------ TUNER_YMEC_TVF_5533MF - Philips NTSC ------------ */
828
829static struct tuner_range tuner_ymec_tvf_5533mf_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200830 { 16 * 160.00 /*MHz*/, 0x8e, 0x01, },
831 { 16 * 454.00 /*MHz*/, 0x8e, 0x02, },
832 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200833};
834
835static struct tuner_params tuner_ymec_tvf_5533mf_params[] = {
836 {
837 .type = TUNER_PARAM_TYPE_NTSC,
838 .ranges = tuner_ymec_tvf_5533mf_ntsc_ranges,
839 .count = ARRAY_SIZE(tuner_ymec_tvf_5533mf_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200840 },
841};
842
843/* 60-69 */
844/* ------------ TUNER_THOMSON_DTT761X - THOMSON ATSC ------------ */
845/* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
846
847static struct tuner_range tuner_thomson_dtt761x_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200848 { 16 * 145.25 /*MHz*/, 0x8e, 0x39, },
849 { 16 * 415.25 /*MHz*/, 0x8e, 0x3a, },
850 { 16 * 999.99 , 0x8e, 0x3c, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200851};
852
853
854static struct tuner_params tuner_thomson_dtt761x_params[] = {
855 {
856 .type = TUNER_PARAM_TYPE_NTSC,
857 .ranges = tuner_thomson_dtt761x_ntsc_ranges,
858 .count = ARRAY_SIZE(tuner_thomson_dtt761x_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200859 },
860};
861
862/* ------------ TUNER_TENA_9533_DI - Philips PAL ------------ */
863
Michael Krufkycc925bb2006-01-23 17:11:11 -0200864static struct tuner_range tuner_tena_9533_di_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200865 { 16 * 160.25 /*MHz*/, 0x8e, 0x01, },
866 { 16 * 464.25 /*MHz*/, 0x8e, 0x02, },
867 { 16 * 999.99 , 0x8e, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200868};
869
870static struct tuner_params tuner_tena_9533_di_params[] = {
871 {
872 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufkycc925bb2006-01-23 17:11:11 -0200873 .ranges = tuner_tena_9533_di_pal_ranges,
874 .count = ARRAY_SIZE(tuner_tena_9533_di_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200875 },
876};
877
878/* ------------ TUNER_PHILIPS_FMD1216ME_MK3 - Philips PAL ------------ */
879
880static struct tuner_range tuner_philips_fmd1216me_mk3_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200881 { 16 * 160.00 /*MHz*/, 0x86, 0x51, },
882 { 16 * 442.00 /*MHz*/, 0x86, 0x52, },
883 { 16 * 999.99 , 0x86, 0x54, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200884};
885
886
Michael Krufkycc925bb2006-01-23 17:11:11 -0200887static struct tuner_params tuner_philips_fmd1216me_mk3_params[] = {
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200888 {
889 .type = TUNER_PARAM_TYPE_PAL,
890 .ranges = tuner_philips_fmd1216me_mk3_pal_ranges,
891 .count = ARRAY_SIZE(tuner_philips_fmd1216me_mk3_pal_ranges),
Hans Verkuilba8fc392006-06-25 15:34:39 -0300892 .has_tda9887 = 1,
893 .port1_active = 1,
894 .port2_active = 1,
895 .port2_fm_high_sensitivity = 1,
896 .port2_invert_for_secam_lc = 1,
897 .port1_set_for_fm_mono = 1,
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200898 },
899};
900
901
Michael Krufky9c26c8b2006-04-27 01:29:17 -0300902/* ------ TUNER_LG_TDVS_H06XF - LG INNOTEK / INFINEON ATSC ----- */
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200903
904static struct tuner_range tuner_tua6034_ntsc_ranges[] = {
Rusty Scottdd31d5ac2006-04-22 16:15:07 -0300905 { 16 * 165.00 /*MHz*/, 0x8e, 0x01 },
906 { 16 * 450.00 /*MHz*/, 0x8e, 0x02 },
Michael Krufky3fc46d32006-01-23 17:11:11 -0200907 { 16 * 999.99 , 0x8e, 0x04 },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200908};
909
910
Michael Krufky9c26c8b2006-04-27 01:29:17 -0300911static struct tuner_params tuner_lg_tdvs_h06xf_params[] = {
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200912 {
913 .type = TUNER_PARAM_TYPE_NTSC,
914 .ranges = tuner_tua6034_ntsc_ranges,
915 .count = ARRAY_SIZE(tuner_tua6034_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200916 },
917};
918
919/* ------------ TUNER_YMEC_TVF66T5_B_DFF - Philips PAL ------------ */
920
Hermann Pittonc2d19232006-08-21 14:14:33 -0300921static struct tuner_range tuner_ymec_tvf66t5_b_dff_pal_ranges[] = {
922 { 16 * 160.25 /*MHz*/, 0x8e, 0x01, },
923 { 16 * 464.25 /*MHz*/, 0x8e, 0x02, },
924 { 16 * 999.99 , 0x8e, 0x08, },
925};
926
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200927static struct tuner_params tuner_ymec_tvf66t5_b_dff_params[] = {
928 {
929 .type = TUNER_PARAM_TYPE_PAL,
Hermann Pittonc2d19232006-08-21 14:14:33 -0300930 .ranges = tuner_ymec_tvf66t5_b_dff_pal_ranges,
931 .count = ARRAY_SIZE(tuner_ymec_tvf66t5_b_dff_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200932 },
933};
934
935/* ------------ TUNER_LG_NTSC_TALN_MINI - LGINNOTEK NTSC ------------ */
936
Michael Krufkyf3629be2006-03-11 17:02:01 -0300937static struct tuner_range tuner_lg_taln_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200938 { 16 * 137.25 /*MHz*/, 0x8e, 0x01, },
939 { 16 * 373.25 /*MHz*/, 0x8e, 0x02, },
940 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200941};
942
Michael Krufkyf3629be2006-03-11 17:02:01 -0300943static struct tuner_range tuner_lg_taln_pal_secam_ranges[] = {
944 { 16 * 150.00 /*MHz*/, 0x8e, 0x01, },
945 { 16 * 425.00 /*MHz*/, 0x8e, 0x02, },
946 { 16 * 999.99 , 0x8e, 0x08, },
947};
948
949static struct tuner_params tuner_lg_taln_params[] = {
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200950 {
951 .type = TUNER_PARAM_TYPE_NTSC,
Michael Krufkyf3629be2006-03-11 17:02:01 -0300952 .ranges = tuner_lg_taln_ntsc_ranges,
953 .count = ARRAY_SIZE(tuner_lg_taln_ntsc_ranges),
954 },{
955 .type = TUNER_PARAM_TYPE_PAL,
956 .ranges = tuner_lg_taln_pal_secam_ranges,
957 .count = ARRAY_SIZE(tuner_lg_taln_pal_secam_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200958 },
959};
960
961/* ------------ TUNER_PHILIPS_TD1316 - Philips PAL ------------ */
962
963static struct tuner_range tuner_philips_td1316_pal_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200964 { 16 * 160.00 /*MHz*/, 0xc8, 0xa1, },
965 { 16 * 442.00 /*MHz*/, 0xc8, 0xa2, },
966 { 16 * 999.99 , 0xc8, 0xa4, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200967};
968
969static struct tuner_params tuner_philips_td1316_params[] = {
970 {
971 .type = TUNER_PARAM_TYPE_PAL,
972 .ranges = tuner_philips_td1316_pal_ranges,
973 .count = ARRAY_SIZE(tuner_philips_td1316_pal_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200974 },
975};
976
977/* ------------ TUNER_PHILIPS_TUV1236D - Philips ATSC ------------ */
978
979static struct tuner_range tuner_tuv1236d_ntsc_ranges[] = {
Michael Krufky3fc46d32006-01-23 17:11:11 -0200980 { 16 * 157.25 /*MHz*/, 0xce, 0x01, },
981 { 16 * 454.00 /*MHz*/, 0xce, 0x02, },
982 { 16 * 999.99 , 0xce, 0x04, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200983};
984
985
Michael Krufkycc925bb2006-01-23 17:11:11 -0200986static struct tuner_params tuner_tuv1236d_params[] = {
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200987 {
988 .type = TUNER_PARAM_TYPE_NTSC,
989 .ranges = tuner_tuv1236d_ntsc_ranges,
990 .count = ARRAY_SIZE(tuner_tuv1236d_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -0200991 },
992};
993
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -0300994/* ------------ TUNER_TNF_xxx5 - Texas Instruments--------- */
995/* This is known to work with Tenna TVF58t5-MFF and TVF5835 MFF
996 * but it is expected to work also with other Tenna/Ymec
997 * models based on TI SN 761677 chip on both PAL and NTSC
998 */
999
1000static struct tuner_range tuner_tnf_5335_d_if_pal_ranges[] = {
1001 { 16 * 168.25 /*MHz*/, 0x8e, 0x01, },
Mauro Carvalho Chehab7947a222006-03-09 16:09:20 -03001002 { 16 * 471.25 /*MHz*/, 0x8e, 0x02, },
1003 { 16 * 999.99 , 0x8e, 0x08, },
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -03001004};
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001005
1006static struct tuner_range tuner_tnf_5335mf_ntsc_ranges[] = {
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -03001007 { 16 * 169.25 /*MHz*/, 0x8e, 0x01, },
1008 { 16 * 469.25 /*MHz*/, 0x8e, 0x02, },
1009 { 16 * 999.99 , 0x8e, 0x08, },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001010};
1011
1012static struct tuner_params tuner_tnf_5335mf_params[] = {
1013 {
1014 .type = TUNER_PARAM_TYPE_NTSC,
1015 .ranges = tuner_tnf_5335mf_ntsc_ranges,
1016 .count = ARRAY_SIZE(tuner_tnf_5335mf_ntsc_ranges),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001017 },
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -03001018 {
1019 .type = TUNER_PARAM_TYPE_PAL,
1020 .ranges = tuner_tnf_5335_d_if_pal_ranges,
1021 .count = ARRAY_SIZE(tuner_tnf_5335_d_if_pal_ranges),
1022 },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001023};
1024
Hans Verkuilb3d37042006-01-13 14:10:25 -02001025/* 70-79 */
1026/* ------------ TUNER_SAMSUNG_TCPN_2121P30A - Samsung NTSC ------------ */
1027
Hans Verkuil43c560f2006-08-08 09:10:15 -03001028/* '+ 4' turns on the Low Noise Amplifier */
Hans Verkuilb3d37042006-01-13 14:10:25 -02001029static struct tuner_range tuner_samsung_tcpn_2121p30a_ntsc_ranges[] = {
Hans Verkuil43c560f2006-08-08 09:10:15 -03001030 { 16 * 130.00 /*MHz*/, 0xce, 0x01 + 4, },
1031 { 16 * 364.50 /*MHz*/, 0xce, 0x02 + 4, },
1032 { 16 * 999.99 , 0xce, 0x08 + 4, },
Hans Verkuilb3d37042006-01-13 14:10:25 -02001033};
1034
1035static struct tuner_params tuner_samsung_tcpn_2121p30a_params[] = {
1036 {
1037 .type = TUNER_PARAM_TYPE_NTSC,
1038 .ranges = tuner_samsung_tcpn_2121p30a_ntsc_ranges,
1039 .count = ARRAY_SIZE(tuner_samsung_tcpn_2121p30a_ntsc_ranges),
Hans Verkuilb3d37042006-01-13 14:10:25 -02001040 },
1041};
1042
Michael Krufky91ae3292006-03-01 00:04:42 -03001043/* ------------ TUNER_THOMSON_FE6600 - DViCO Hybrid PAL ------------ */
Chris Pascoe780dfef2006-02-28 08:34:59 -03001044
Michael Krufky91ae3292006-03-01 00:04:42 -03001045static struct tuner_range tuner_thomson_fe6600_ranges[] = {
Chris Pascoe780dfef2006-02-28 08:34:59 -03001046 { 16 * 160.00 /*MHz*/, 0xfe, 0x11, },
1047 { 16 * 442.00 /*MHz*/, 0xf6, 0x12, },
1048 { 16 * 999.99 , 0xf6, 0x18, },
1049};
1050
Michael Krufky91ae3292006-03-01 00:04:42 -03001051static struct tuner_params tuner_thomson_fe6600_params[] = {
Chris Pascoe780dfef2006-02-28 08:34:59 -03001052 {
1053 .type = TUNER_PARAM_TYPE_PAL,
Michael Krufky91ae3292006-03-01 00:04:42 -03001054 .ranges = tuner_thomson_fe6600_ranges,
1055 .count = ARRAY_SIZE(tuner_thomson_fe6600_ranges),
Chris Pascoe780dfef2006-02-28 08:34:59 -03001056 },
1057};
1058
Hans Verkuilc3449332006-04-19 18:50:35 -03001059/* ------------ TUNER_SAMSUNG_TCPG_6121P30A - Samsung PAL ------------ */
1060
Hans Verkuil43c560f2006-08-08 09:10:15 -03001061/* '+ 4' turns on the Low Noise Amplifier */
Hans Verkuilc3449332006-04-19 18:50:35 -03001062static struct tuner_range tuner_samsung_tcpg_6121p30a_pal_ranges[] = {
Hans Verkuil43c560f2006-08-08 09:10:15 -03001063 { 16 * 146.25 /*MHz*/, 0xce, 0x01 + 4, },
1064 { 16 * 428.50 /*MHz*/, 0xce, 0x02 + 4, },
1065 { 16 * 999.99 , 0xce, 0x08 + 4, },
Hans Verkuilc3449332006-04-19 18:50:35 -03001066};
1067
1068static struct tuner_params tuner_samsung_tcpg_6121p30a_params[] = {
1069 {
1070 .type = TUNER_PARAM_TYPE_PAL,
1071 .ranges = tuner_samsung_tcpg_6121p30a_pal_ranges,
1072 .count = ARRAY_SIZE(tuner_samsung_tcpg_6121p30a_pal_ranges),
Hans Verkuilba8fc392006-06-25 15:34:39 -03001073 .has_tda9887 = 1,
1074 .port1_active = 1,
1075 .port2_active = 1,
1076 .port2_invert_for_secam_lc = 1,
Hans Verkuilc3449332006-04-19 18:50:35 -03001077 },
1078};
1079
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001080/* --------------------------------------------------------------------- */
1081
1082struct tunertype tuners[] = {
1083 /* 0-9 */
1084 [TUNER_TEMIC_PAL] = { /* TEMIC PAL */
1085 .name = "Temic PAL (4002 FH5)",
1086 .params = tuner_temic_pal_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001087 .count = ARRAY_SIZE(tuner_temic_pal_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001088 },
1089 [TUNER_PHILIPS_PAL_I] = { /* Philips PAL_I */
1090 .name = "Philips PAL_I (FI1246 and compatibles)",
1091 .params = tuner_philips_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001092 .count = ARRAY_SIZE(tuner_philips_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001093 },
1094 [TUNER_PHILIPS_NTSC] = { /* Philips NTSC */
1095 .name = "Philips NTSC (FI1236,FM1236 and compatibles)",
1096 .params = tuner_philips_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001097 .count = ARRAY_SIZE(tuner_philips_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001098 },
1099 [TUNER_PHILIPS_SECAM] = { /* Philips SECAM */
1100 .name = "Philips (SECAM+PAL_BG) (FI1216MF, FM1216MF, FR1216MF)",
1101 .params = tuner_philips_secam_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001102 .count = ARRAY_SIZE(tuner_philips_secam_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001103 },
1104 [TUNER_ABSENT] = { /* Tuner Absent */
1105 .name = "NoTuner",
1106 },
1107 [TUNER_PHILIPS_PAL] = { /* Philips PAL */
1108 .name = "Philips PAL_BG (FI1216 and compatibles)",
1109 .params = tuner_philips_pal_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001110 .count = ARRAY_SIZE(tuner_philips_pal_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001111 },
1112 [TUNER_TEMIC_NTSC] = { /* TEMIC NTSC */
1113 .name = "Temic NTSC (4032 FY5)",
1114 .params = tuner_temic_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001115 .count = ARRAY_SIZE(tuner_temic_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001116 },
1117 [TUNER_TEMIC_PAL_I] = { /* TEMIC PAL_I */
1118 .name = "Temic PAL_I (4062 FY5)",
1119 .params = tuner_temic_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001120 .count = ARRAY_SIZE(tuner_temic_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001121 },
1122 [TUNER_TEMIC_4036FY5_NTSC] = { /* TEMIC NTSC */
1123 .name = "Temic NTSC (4036 FY5)",
1124 .params = tuner_temic_4036fy5_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001125 .count = ARRAY_SIZE(tuner_temic_4036fy5_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001126 },
1127 [TUNER_ALPS_TSBH1_NTSC] = { /* TEMIC NTSC */
1128 .name = "Alps HSBH1",
1129 .params = tuner_alps_tsbh1_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001130 .count = ARRAY_SIZE(tuner_alps_tsbh1_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001131 },
1132
1133 /* 10-19 */
1134 [TUNER_ALPS_TSBE1_PAL] = { /* TEMIC PAL */
1135 .name = "Alps TSBE1",
1136 .params = tuner_alps_tsb_1_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001137 .count = ARRAY_SIZE(tuner_alps_tsb_1_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001138 },
1139 [TUNER_ALPS_TSBB5_PAL_I] = { /* Alps PAL_I */
1140 .name = "Alps TSBB5",
1141 .params = tuner_alps_tsbb5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001142 .count = ARRAY_SIZE(tuner_alps_tsbb5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001143 },
1144 [TUNER_ALPS_TSBE5_PAL] = { /* Alps PAL */
1145 .name = "Alps TSBE5",
1146 .params = tuner_alps_tsbe5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001147 .count = ARRAY_SIZE(tuner_alps_tsbe5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001148 },
1149 [TUNER_ALPS_TSBC5_PAL] = { /* Alps PAL */
1150 .name = "Alps TSBC5",
1151 .params = tuner_alps_tsbc5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001152 .count = ARRAY_SIZE(tuner_alps_tsbc5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001153 },
1154 [TUNER_TEMIC_4006FH5_PAL] = { /* TEMIC PAL */
1155 .name = "Temic PAL_BG (4006FH5)",
1156 .params = tuner_temic_4006fh5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001157 .count = ARRAY_SIZE(tuner_temic_4006fh5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001158 },
1159 [TUNER_ALPS_TSHC6_NTSC] = { /* Alps NTSC */
1160 .name = "Alps TSCH6",
1161 .params = tuner_alps_tshc6_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001162 .count = ARRAY_SIZE(tuner_alps_tshc6_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001163 },
1164 [TUNER_TEMIC_PAL_DK] = { /* TEMIC PAL */
1165 .name = "Temic PAL_DK (4016 FY5)",
1166 .params = tuner_temic_pal_dk_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001167 .count = ARRAY_SIZE(tuner_temic_pal_dk_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001168 },
1169 [TUNER_PHILIPS_NTSC_M] = { /* Philips NTSC */
1170 .name = "Philips NTSC_M (MK2)",
1171 .params = tuner_philips_ntsc_m_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001172 .count = ARRAY_SIZE(tuner_philips_ntsc_m_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001173 },
1174 [TUNER_TEMIC_4066FY5_PAL_I] = { /* TEMIC PAL_I */
1175 .name = "Temic PAL_I (4066 FY5)",
1176 .params = tuner_temic_4066fy5_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001177 .count = ARRAY_SIZE(tuner_temic_4066fy5_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001178 },
1179 [TUNER_TEMIC_4006FN5_MULTI_PAL] = { /* TEMIC PAL */
1180 .name = "Temic PAL* auto (4006 FN5)",
1181 .params = tuner_temic_4006fn5_multi_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001182 .count = ARRAY_SIZE(tuner_temic_4006fn5_multi_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001183 },
1184
1185 /* 20-29 */
1186 [TUNER_TEMIC_4009FR5_PAL] = { /* TEMIC PAL */
1187 .name = "Temic PAL_BG (4009 FR5) or PAL_I (4069 FR5)",
1188 .params = tuner_temic_4009f_5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001189 .count = ARRAY_SIZE(tuner_temic_4009f_5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001190 },
1191 [TUNER_TEMIC_4039FR5_NTSC] = { /* TEMIC NTSC */
1192 .name = "Temic NTSC (4039 FR5)",
1193 .params = tuner_temic_4039fr5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001194 .count = ARRAY_SIZE(tuner_temic_4039fr5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001195 },
1196 [TUNER_TEMIC_4046FM5] = { /* TEMIC PAL */
1197 .name = "Temic PAL/SECAM multi (4046 FM5)",
1198 .params = tuner_temic_4046fm5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001199 .count = ARRAY_SIZE(tuner_temic_4046fm5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001200 },
1201 [TUNER_PHILIPS_PAL_DK] = { /* Philips PAL */
1202 .name = "Philips PAL_DK (FI1256 and compatibles)",
1203 .params = tuner_philips_pal_dk_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001204 .count = ARRAY_SIZE(tuner_philips_pal_dk_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001205 },
1206 [TUNER_PHILIPS_FQ1216ME] = { /* Philips PAL */
1207 .name = "Philips PAL/SECAM multi (FQ1216ME)",
1208 .params = tuner_philips_fq1216me_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001209 .count = ARRAY_SIZE(tuner_philips_fq1216me_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001210 },
1211 [TUNER_LG_PAL_I_FM] = { /* LGINNOTEK PAL_I */
1212 .name = "LG PAL_I+FM (TAPC-I001D)",
1213 .params = tuner_lg_pal_i_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001214 .count = ARRAY_SIZE(tuner_lg_pal_i_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001215 },
1216 [TUNER_LG_PAL_I] = { /* LGINNOTEK PAL_I */
1217 .name = "LG PAL_I (TAPC-I701D)",
1218 .params = tuner_lg_pal_i_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001219 .count = ARRAY_SIZE(tuner_lg_pal_i_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001220 },
1221 [TUNER_LG_NTSC_FM] = { /* LGINNOTEK NTSC */
1222 .name = "LG NTSC+FM (TPI8NSR01F)",
1223 .params = tuner_lg_ntsc_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001224 .count = ARRAY_SIZE(tuner_lg_ntsc_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001225 },
1226 [TUNER_LG_PAL_FM] = { /* LGINNOTEK PAL */
1227 .name = "LG PAL_BG+FM (TPI8PSB01D)",
1228 .params = tuner_lg_pal_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001229 .count = ARRAY_SIZE(tuner_lg_pal_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001230 },
1231 [TUNER_LG_PAL] = { /* LGINNOTEK PAL */
1232 .name = "LG PAL_BG (TPI8PSB11D)",
1233 .params = tuner_lg_pal_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001234 .count = ARRAY_SIZE(tuner_lg_pal_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001235 },
1236
1237 /* 30-39 */
1238 [TUNER_TEMIC_4009FN5_MULTI_PAL_FM] = { /* TEMIC PAL */
1239 .name = "Temic PAL* auto + FM (4009 FN5)",
1240 .params = tuner_temic_4009_fn5_multi_pal_fm_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001241 .count = ARRAY_SIZE(tuner_temic_4009_fn5_multi_pal_fm_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001242 },
1243 [TUNER_SHARP_2U5JF5540_NTSC] = { /* SHARP NTSC */
1244 .name = "SHARP NTSC_JP (2U5JF5540)",
1245 .params = tuner_sharp_2u5jf5540_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001246 .count = ARRAY_SIZE(tuner_sharp_2u5jf5540_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001247 },
1248 [TUNER_Samsung_PAL_TCPM9091PD27] = { /* Samsung PAL */
1249 .name = "Samsung PAL TCPM9091PD27",
1250 .params = tuner_samsung_pal_tcpm9091pd27_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001251 .count = ARRAY_SIZE(tuner_samsung_pal_tcpm9091pd27_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001252 },
1253 [TUNER_MT2032] = { /* Microtune PAL|NTSC */
1254 .name = "MT20xx universal",
1255 /* see mt20xx.c for details */ },
1256 [TUNER_TEMIC_4106FH5] = { /* TEMIC PAL */
1257 .name = "Temic PAL_BG (4106 FH5)",
1258 .params = tuner_temic_4106fh5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001259 .count = ARRAY_SIZE(tuner_temic_4106fh5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001260 },
1261 [TUNER_TEMIC_4012FY5] = { /* TEMIC PAL */
1262 .name = "Temic PAL_DK/SECAM_L (4012 FY5)",
1263 .params = tuner_temic_4012fy5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001264 .count = ARRAY_SIZE(tuner_temic_4012fy5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001265 },
1266 [TUNER_TEMIC_4136FY5] = { /* TEMIC NTSC */
1267 .name = "Temic NTSC (4136 FY5)",
1268 .params = tuner_temic_4136_fy5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001269 .count = ARRAY_SIZE(tuner_temic_4136_fy5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001270 },
1271 [TUNER_LG_PAL_NEW_TAPC] = { /* LGINNOTEK PAL */
1272 .name = "LG PAL (newer TAPC series)",
1273 .params = tuner_lg_pal_new_tapc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001274 .count = ARRAY_SIZE(tuner_lg_pal_new_tapc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001275 },
1276 [TUNER_PHILIPS_FM1216ME_MK3] = { /* Philips PAL */
1277 .name = "Philips PAL/SECAM multi (FM1216ME MK3)",
1278 .params = tuner_fm1216me_mk3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001279 .count = ARRAY_SIZE(tuner_fm1216me_mk3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001280 },
1281 [TUNER_LG_NTSC_NEW_TAPC] = { /* LGINNOTEK NTSC */
1282 .name = "LG NTSC (newer TAPC series)",
1283 .params = tuner_lg_ntsc_new_tapc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001284 .count = ARRAY_SIZE(tuner_lg_ntsc_new_tapc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001285 },
1286
1287 /* 40-49 */
1288 [TUNER_HITACHI_NTSC] = { /* HITACHI NTSC */
1289 .name = "HITACHI V7-J180AT",
1290 .params = tuner_hitachi_ntsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001291 .count = ARRAY_SIZE(tuner_hitachi_ntsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001292 },
1293 [TUNER_PHILIPS_PAL_MK] = { /* Philips PAL */
1294 .name = "Philips PAL_MK (FI1216 MK)",
1295 .params = tuner_philips_pal_mk_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001296 .count = ARRAY_SIZE(tuner_philips_pal_mk_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001297 },
1298 [TUNER_PHILIPS_ATSC] = { /* Philips ATSC */
1299 .name = "Philips 1236D ATSC/NTSC dual in",
1300 .params = tuner_philips_atsc_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001301 .count = ARRAY_SIZE(tuner_philips_atsc_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001302 },
1303 [TUNER_PHILIPS_FM1236_MK3] = { /* Philips NTSC */
1304 .name = "Philips NTSC MK3 (FM1236MK3 or FM1236/F)",
1305 .params = tuner_fm1236_mk3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001306 .count = ARRAY_SIZE(tuner_fm1236_mk3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001307 },
1308 [TUNER_PHILIPS_4IN1] = { /* Philips NTSC */
1309 .name = "Philips 4 in 1 (ATI TV Wonder Pro/Conexant)",
1310 .params = tuner_philips_4in1_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001311 .count = ARRAY_SIZE(tuner_philips_4in1_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001312 },
1313 [TUNER_MICROTUNE_4049FM5] = { /* Microtune PAL */
1314 .name = "Microtune 4049 FM5",
1315 .params = tuner_microtune_4049_fm5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001316 .count = ARRAY_SIZE(tuner_microtune_4049_fm5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001317 },
1318 [TUNER_PANASONIC_VP27] = { /* Panasonic NTSC */
1319 .name = "Panasonic VP27s/ENGE4324D",
1320 .params = tuner_panasonic_vp27_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001321 .count = ARRAY_SIZE(tuner_panasonic_vp27_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001322 },
1323 [TUNER_LG_NTSC_TAPE] = { /* LGINNOTEK NTSC */
1324 .name = "LG NTSC (TAPE series)",
Hans Verkuil122b5db2006-12-03 06:45:07 -03001325 .params = tuner_fm1236_mk3_params,
1326 .count = ARRAY_SIZE(tuner_fm1236_mk3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001327 },
1328 [TUNER_TNF_8831BGFF] = { /* Philips PAL */
1329 .name = "Tenna TNF 8831 BGFF)",
1330 .params = tuner_tnf_8831bgff_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001331 .count = ARRAY_SIZE(tuner_tnf_8831bgff_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001332 },
1333 [TUNER_MICROTUNE_4042FI5] = { /* Microtune NTSC */
1334 .name = "Microtune 4042 FI5 ATSC/NTSC dual in",
1335 .params = tuner_microtune_4042fi5_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001336 .count = ARRAY_SIZE(tuner_microtune_4042fi5_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001337 },
1338
1339 /* 50-59 */
1340 [TUNER_TCL_2002N] = { /* TCL NTSC */
1341 .name = "TCL 2002N",
1342 .params = tuner_tcl_2002n_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001343 .count = ARRAY_SIZE(tuner_tcl_2002n_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001344 },
1345 [TUNER_PHILIPS_FM1256_IH3] = { /* Philips PAL */
1346 .name = "Philips PAL/SECAM_D (FM 1256 I-H3)",
1347 .params = tuner_philips_fm1256_ih3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001348 .count = ARRAY_SIZE(tuner_philips_fm1256_ih3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001349 },
1350 [TUNER_THOMSON_DTT7610] = { /* THOMSON ATSC */
1351 .name = "Thomson DTT 7610 (ATSC/NTSC)",
1352 .params = tuner_thomson_dtt7610_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001353 .count = ARRAY_SIZE(tuner_thomson_dtt7610_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001354 },
1355 [TUNER_PHILIPS_FQ1286] = { /* Philips NTSC */
1356 .name = "Philips FQ1286",
1357 .params = tuner_philips_fq1286_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001358 .count = ARRAY_SIZE(tuner_philips_fq1286_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001359 },
1360 [TUNER_PHILIPS_TDA8290] = { /* Philips PAL|NTSC */
1361 .name = "tda8290+75",
1362 /* see tda8290.c for details */ },
1363 [TUNER_TCL_2002MB] = { /* TCL PAL */
1364 .name = "TCL 2002MB",
1365 .params = tuner_tcl_2002mb_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001366 .count = ARRAY_SIZE(tuner_tcl_2002mb_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001367 },
1368 [TUNER_PHILIPS_FQ1216AME_MK4] = { /* Philips PAL */
1369 .name = "Philips PAL/SECAM multi (FQ1216AME MK4)",
1370 .params = tuner_philips_fq1216ame_mk4_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001371 .count = ARRAY_SIZE(tuner_philips_fq1216ame_mk4_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001372 },
1373 [TUNER_PHILIPS_FQ1236A_MK4] = { /* Philips NTSC */
1374 .name = "Philips FQ1236A MK4",
1375 .params = tuner_philips_fq1236a_mk4_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001376 .count = ARRAY_SIZE(tuner_philips_fq1236a_mk4_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001377 },
1378 [TUNER_YMEC_TVF_8531MF] = { /* Philips NTSC */
1379 .name = "Ymec TVision TVF-8531MF/8831MF/8731MF",
1380 .params = tuner_ymec_tvf_8531mf_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001381 .count = ARRAY_SIZE(tuner_ymec_tvf_8531mf_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001382 },
1383 [TUNER_YMEC_TVF_5533MF] = { /* Philips NTSC */
1384 .name = "Ymec TVision TVF-5533MF",
1385 .params = tuner_ymec_tvf_5533mf_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001386 .count = ARRAY_SIZE(tuner_ymec_tvf_5533mf_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001387 },
1388
1389 /* 60-69 */
1390 [TUNER_THOMSON_DTT761X] = { /* THOMSON ATSC */
1391 /* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
1392 .name = "Thomson DTT 761X (ATSC/NTSC)",
1393 .params = tuner_thomson_dtt761x_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001394 .count = ARRAY_SIZE(tuner_thomson_dtt761x_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001395 },
1396 [TUNER_TENA_9533_DI] = { /* Philips PAL */
1397 .name = "Tena TNF9533-D/IF/TNF9533-B/DF",
1398 .params = tuner_tena_9533_di_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001399 .count = ARRAY_SIZE(tuner_tena_9533_di_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001400 },
1401 [TUNER_TEA5767] = { /* Philips RADIO */
1402 .name = "Philips TEA5767HN FM Radio",
1403 /* see tea5767.c for details */
1404 },
1405 [TUNER_PHILIPS_FMD1216ME_MK3] = { /* Philips PAL */
1406 .name = "Philips FMD1216ME MK3 Hybrid Tuner",
Michael Krufkycc925bb2006-01-23 17:11:11 -02001407 .params = tuner_philips_fmd1216me_mk3_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001408 .count = ARRAY_SIZE(tuner_philips_fmd1216me_mk3_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001409 },
Michael Krufky9c26c8b2006-04-27 01:29:17 -03001410 [TUNER_LG_TDVS_H06XF] = { /* LGINNOTEK ATSC */
Michael Krufkyd9e12f22006-04-22 16:15:11 -03001411 .name = "LG TDVS-H06xF", /* H061F, H062F & H064F */
Michael Krufky9c26c8b2006-04-27 01:29:17 -03001412 .params = tuner_lg_tdvs_h06xf_params,
1413 .count = ARRAY_SIZE(tuner_lg_tdvs_h06xf_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001414 },
1415 [TUNER_YMEC_TVF66T5_B_DFF] = { /* Philips PAL */
1416 .name = "Ymec TVF66T5-B/DFF",
1417 .params = tuner_ymec_tvf66t5_b_dff_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001418 .count = ARRAY_SIZE(tuner_ymec_tvf66t5_b_dff_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001419 },
Michael Krufkyf3629be2006-03-11 17:02:01 -03001420 [TUNER_LG_TALN] = { /* LGINNOTEK NTSC / PAL / SECAM */
1421 .name = "LG TALN series",
1422 .params = tuner_lg_taln_params,
1423 .count = ARRAY_SIZE(tuner_lg_taln_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001424 },
1425 [TUNER_PHILIPS_TD1316] = { /* Philips PAL */
1426 .name = "Philips TD1316 Hybrid Tuner",
1427 .params = tuner_philips_td1316_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001428 .count = ARRAY_SIZE(tuner_philips_td1316_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001429 },
1430 [TUNER_PHILIPS_TUV1236D] = { /* Philips ATSC */
1431 .name = "Philips TUV1236D ATSC/NTSC dual in",
Michael Krufkycc925bb2006-01-23 17:11:11 -02001432 .params = tuner_tuv1236d_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001433 .count = ARRAY_SIZE(tuner_tuv1236d_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001434 },
Mauro Carvalho Chehabefcf55c2006-03-09 11:17:43 -03001435 [TUNER_TNF_5335MF] = { /* Tenna PAL/NTSC */
1436 .name = "Tena TNF 5335 and similar models",
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001437 .params = tuner_tnf_5335mf_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001438 .count = ARRAY_SIZE(tuner_tnf_5335mf_params),
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001439 },
Hans Verkuilb3d37042006-01-13 14:10:25 -02001440
1441 /* 70-79 */
1442 [TUNER_SAMSUNG_TCPN_2121P30A] = { /* Samsung NTSC */
1443 .name = "Samsung TCPN 2121P30A",
1444 .params = tuner_samsung_tcpn_2121p30a_params,
Michael Krufkybbab6fd2006-02-06 09:15:11 -02001445 .count = ARRAY_SIZE(tuner_samsung_tcpn_2121p30a_params),
Hans Verkuilb3d37042006-01-13 14:10:25 -02001446 },
Markus Rechberger0004fd52006-02-27 00:07:27 -03001447 [TUNER_XCEIVE_XC3028] = { /* Xceive 3028 */
1448 .name = "Xceive xc3028",
Mauro Carvalho Chehabcfcd7182006-02-27 00:07:37 -03001449 /* see xc3028.c for details */
Markus Rechberger0004fd52006-02-27 00:07:27 -03001450 },
Michael Krufky91ae3292006-03-01 00:04:42 -03001451 [TUNER_THOMSON_FE6600] = { /* Thomson PAL / DVB-T */
1452 .name = "Thomson FE6600",
1453 .params = tuner_thomson_fe6600_params,
Michael Krufkyb1b168e2006-03-11 16:12:35 -03001454 .count = ARRAY_SIZE(tuner_thomson_fe6600_params),
Chris Pascoe780dfef2006-02-28 08:34:59 -03001455 },
Hans Verkuilc3449332006-04-19 18:50:35 -03001456 [TUNER_SAMSUNG_TCPG_6121P30A] = { /* Samsung PAL */
1457 .name = "Samsung TCPG 6121P30A",
1458 .params = tuner_samsung_tcpg_6121p30a_params,
1459 .count = ARRAY_SIZE(tuner_samsung_tcpg_6121p30a_params),
1460 },
Mauro Carvalho Chehab15396232006-06-23 16:13:56 -03001461 [TUNER_TDA9887] = { /* Philips TDA 9887 IF PLL Demodulator.
1462 This chip is part of some modern tuners */
1463 .name = "Philips TDA988[5,6,7] IF PLL Demodulator",
1464 /* see tda9887.c for details */
1465 },
Michael Krufky7b0ac9c2006-01-13 14:10:25 -02001466};
1467
1468unsigned const int tuner_count = ARRAY_SIZE(tuners);