V4L/DVB (5921): ivtv: add missing composite input line for ivtv_pci_pg600v2
[GitHub/mt8127/android_kernel_alcatel_ttab.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
839e4a4a
MCC
27extern int cx25840_debug;
28
a8bbf12a
HV
29/* ENABLE_PVR150_WORKAROUND activates a workaround for a hardware bug that is
30 present in Hauppauge PVR-150 (and possibly PVR-500) cards that have
31 certain NTSC tuners (tveeprom tuner model numbers 85, 99 and 112). The
f95006f8
HV
32 audio autodetect fails on some channels for these models and the workaround
33 is to select the audio standard explicitly. Many thanks to Hauppauge for
34 providing this information. */
a8bbf12a
HV
35#define CX25840_CID_ENABLE_PVR150_WORKAROUND (V4L2_CID_PRIVATE_BASE+0)
36
bd985160 37struct cx25840_state {
e2b8cf4c 38 struct i2c_client c;
a8bbf12a 39 int pvr150_workaround;
3faeeae4 40 int radio;
a8bbf12a
HV
41 enum cx25840_video_input vid_input;
42 enum cx25840_audio_input aud_input;
3578d3dd 43 u32 audclk_freq;
8a4b275f 44 int audmode;
3e3bf277 45 int vbi_line_offset;
3434eb7e
HV
46 u32 id;
47 u32 rev;
e2b8cf4c 48 int is_cx25836;
bd985160
HV
49};
50
51/* ----------------------------------------------------------------------- */
52/* cx25850-core.c */
53int cx25840_write(struct i2c_client *client, u16 addr, u8 value);
54int cx25840_write4(struct i2c_client *client, u16 addr, u32 value);
55u8 cx25840_read(struct i2c_client *client, u16 addr);
56u32 cx25840_read4(struct i2c_client *client, u16 addr);
e2b8cf4c 57int cx25840_and_or(struct i2c_client *client, u16 addr, unsigned mask, u8 value);
bd985160
HV
58v4l2_std_id cx25840_get_v4lstd(struct i2c_client *client);
59
60/* ----------------------------------------------------------------------- */
61/* cx25850-firmware.c */
62int cx25840_loadfw(struct i2c_client *client);
63
64/* ----------------------------------------------------------------------- */
65/* cx25850-audio.c */
66int cx25840_audio(struct i2c_client *client, unsigned int cmd, void *arg);
a8bbf12a 67void cx25840_audio_set_path(struct i2c_client *client);
bd985160
HV
68
69/* ----------------------------------------------------------------------- */
70/* cx25850-vbi.c */
71void cx25840_vbi_setup(struct i2c_client *client);
72int cx25840_vbi(struct i2c_client *client, unsigned int cmd, void *arg);
73
74#endif