blob: 16fa075a1eecd230dac4aa3c9aa4b11c203099c1 [file] [log] [blame]
Mike Iselyd8554972006-06-26 20:58:46 -03001/*
2 *
3 * $Id$
4 *
5 * Copyright (C) 2005 Mike Isely <isely@pobox.com>
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 *
20 */
21
Randy Dunlapab9caf92006-09-28 14:03:26 -030022#include <linux/kernel.h>
Mike Iselyd8554972006-06-26 20:58:46 -030023#include "pvrusb2-i2c-core.h"
24#include "pvrusb2-hdw-internal.h"
25#include "pvrusb2-debug.h"
26#include "pvrusb2-i2c-cmd-v4l2.h"
27#include "pvrusb2-audio.h"
28#include "pvrusb2-tuner.h"
Mike Iselyd8554972006-06-26 20:58:46 -030029#include "pvrusb2-video-v4l.h"
Mike Iselyd8554972006-06-26 20:58:46 -030030#include "pvrusb2-cx2584x-v4l.h"
31#include "pvrusb2-wm8775.h"
Mike Iselyd8554972006-06-26 20:58:46 -030032
33#define trace_i2c(...) pvr2_trace(PVR2_TRACE_I2C,__VA_ARGS__)
34
35#define OP_STANDARD 0
36#define OP_BCSH 1
37#define OP_VOLUME 2
38#define OP_FREQ 3
39#define OP_AUDIORATE 4
40#define OP_SIZE 5
41#define OP_LOG 6
42
43static const struct pvr2_i2c_op * const ops[] = {
44 [OP_STANDARD] = &pvr2_i2c_op_v4l2_standard,
45 [OP_BCSH] = &pvr2_i2c_op_v4l2_bcsh,
46 [OP_VOLUME] = &pvr2_i2c_op_v4l2_volume,
47 [OP_FREQ] = &pvr2_i2c_op_v4l2_frequency,
48 [OP_SIZE] = &pvr2_i2c_op_v4l2_size,
49 [OP_LOG] = &pvr2_i2c_op_v4l2_log,
50};
51
52void pvr2_i2c_probe(struct pvr2_hdw *hdw,struct pvr2_i2c_client *cp)
53{
54 int id;
55 id = cp->client->driver->id;
56 cp->ctl_mask = ((1 << OP_STANDARD) |
57 (1 << OP_BCSH) |
58 (1 << OP_VOLUME) |
59 (1 << OP_FREQ) |
60 (1 << OP_SIZE) |
Mike Iselyf5156b02006-12-27 23:14:54 -030061 (1 << OP_LOG));
Mike Isely18103c52007-01-20 00:09:47 -030062 cp->status_poll = pvr2_v4l2_cmd_status_poll;
Mike Iselyd8554972006-06-26 20:58:46 -030063
64 if (id == I2C_DRIVERID_MSP3400) {
65 if (pvr2_i2c_msp3400_setup(hdw,cp)) {
66 return;
67 }
68 }
69 if (id == I2C_DRIVERID_TUNER) {
70 if (pvr2_i2c_tuner_setup(hdw,cp)) {
71 return;
72 }
73 }
Mike Iselyd8554972006-06-26 20:58:46 -030074 if (id == I2C_DRIVERID_CX25840) {
75 if (pvr2_i2c_cx2584x_v4l_setup(hdw,cp)) {
76 return;
77 }
78 }
79 if (id == I2C_DRIVERID_WM8775) {
80 if (pvr2_i2c_wm8775_setup(hdw,cp)) {
81 return;
82 }
83 }
Mike Iselyd8554972006-06-26 20:58:46 -030084 if (id == I2C_DRIVERID_SAA711X) {
85 if (pvr2_i2c_decoder_v4l_setup(hdw,cp)) {
86 return;
87 }
88 }
Mike Iselyd8554972006-06-26 20:58:46 -030089}
90
91
92const struct pvr2_i2c_op *pvr2_i2c_get_op(unsigned int idx)
93{
Randy Dunlapab9caf92006-09-28 14:03:26 -030094 if (idx >= ARRAY_SIZE(ops))
95 return NULL;
Mike Iselyd8554972006-06-26 20:58:46 -030096 return ops[idx];
97}
98
99
100/*
101 Stuff for Emacs to see, in order to encourage consistent editing style:
102 *** Local Variables: ***
103 *** mode: c ***
104 *** fill-column: 75 ***
105 *** tab-width: 8 ***
106 *** c-basic-offset: 8 ***
107 *** End: ***
108 */