]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - drivers/media/video/cx25840/cx25840-core.h
V4L/DVB (9822): cs53l32a: convert to v4l2_subdev.
[mirror_ubuntu-artful-kernel.git] / drivers / media / video / cx25840 / cx25840-core.h
CommitLineData
31bc09b5 1/* cx25840 internal API header
bd985160
HV
2 *
3 * Copyright (C) 2003-2004 Chris Kennedy
4 *
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public License
7 * as published by the Free Software Foundation; either version 2
8 * of the License, or (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 */
19
31bc09b5
HV
20#ifndef _CX25840_CORE_H_
21#define _CX25840_CORE_H_
bd985160 22
cab462f7 23
bd985160
HV
24#include <linux/videodev2.h>
25#include <linux/i2c.h>
26
a8bbf12a
HV
27/* ENABLE_PVR150_WORKAROUND activates a workaround for a hardware bug that is
28 present in Hauppauge PVR-150 (and possibly PVR-500) cards that have
29 certain NTSC tuners (tveeprom tuner model numbers 85, 99 and 112). The
f95006f8
HV
30 audio autodetect fails on some channels for these models and the workaround
31 is to select the audio standard explicitly. Many thanks to Hauppauge for
32 providing this information. */
a8bbf12a
HV
33#define CX25840_CID_ENABLE_PVR150_WORKAROUND (V4L2_CID_PRIVATE_BASE+0)
34
bd985160 35struct cx25840_state {
21340ae0 36 struct i2c_client *c;
a8bbf12a 37 int pvr150_workaround;
3faeeae4 38 int radio;
081b496a 39 v4l2_std_id std;
a8bbf12a
HV
40 enum cx25840_video_input vid_input;
41 enum cx25840_audio_input aud_input;
3578d3dd 42 u32 audclk_freq;
8a4b275f 43 int audmode;
87410dab 44 int unmute_volume; /* -1 if not muted */
ca130eef 45 int default_volume;
3e3bf277 46 int vbi_line_offset;
3434eb7e
HV
47 u32 id;
48 u32 rev;
e2b8cf4c 49 int is_cx25836;
f234081b 50 int is_cx23885;
c976bc82 51 int is_initialized;
21340ae0
HV
52 wait_queue_head_t fw_wait; /* wake up when the fw load is finished */
53 struct work_struct fw_work; /* work entry for fw load */
bd985160
HV
54};
55
56/* ----------------------------------------------------------------------- */
57/* cx25850-core.c */
58int cx25840_write(struct i2c_client *client, u16 addr, u8 value);
59int cx25840_write4(struct i2c_client *client, u16 addr, u32 value);
60u8 cx25840_read(struct i2c_client *client, u16 addr);
61u32 cx25840_read4(struct i2c_client *client, u16 addr);
e2b8cf4c 62int cx25840_and_or(struct i2c_client *client, u16 addr, unsigned mask, u8 value);
cb5aa1c6 63void cx25840_std_setup(struct i2c_client *client);
bd985160
HV
64
65/* ----------------------------------------------------------------------- */
66/* cx25850-firmware.c */
67int cx25840_loadfw(struct i2c_client *client);
68
69/* ----------------------------------------------------------------------- */
70/* cx25850-audio.c */
71int cx25840_audio(struct i2c_client *client, unsigned int cmd, void *arg);
a8bbf12a 72void cx25840_audio_set_path(struct i2c_client *client);
bd985160
HV
73
74/* ----------------------------------------------------------------------- */
75/* cx25850-vbi.c */
bd985160
HV
76int cx25840_vbi(struct i2c_client *client, unsigned int cmd, void *arg);
77
78#endif