2006-03-25 13:26:09 +00:00
|
|
|
/* cx25840 internal API header
|
2005-11-14 00:07:56 +00:00
|
|
|
*
|
|
|
|
* Copyright (C) 2003-2004 Chris Kennedy
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2006-03-25 13:26:09 +00:00
|
|
|
#ifndef _CX25840_CORE_H_
|
|
|
|
#define _CX25840_CORE_H_
|
2005-11-14 00:07:56 +00:00
|
|
|
|
2006-01-09 17:53:26 +00:00
|
|
|
|
2005-11-14 00:07:56 +00:00
|
|
|
#include <linux/videodev2.h>
|
2008-11-29 15:50:06 +00:00
|
|
|
#include <media/v4l2-device.h>
|
2009-09-27 02:47:21 +00:00
|
|
|
#include <media/v4l2-chip-ident.h>
|
2005-11-14 00:07:56 +00:00
|
|
|
#include <linux/i2c.h>
|
|
|
|
|
2006-01-09 17:25:42 +00:00
|
|
|
/* ENABLE_PVR150_WORKAROUND activates a workaround for a hardware bug that is
|
|
|
|
present in Hauppauge PVR-150 (and possibly PVR-500) cards that have
|
|
|
|
certain NTSC tuners (tveeprom tuner model numbers 85, 99 and 112). The
|
2005-12-01 08:51:42 +00:00
|
|
|
audio autodetect fails on some channels for these models and the workaround
|
|
|
|
is to select the audio standard explicitly. Many thanks to Hauppauge for
|
|
|
|
providing this information. */
|
2006-01-09 17:25:42 +00:00
|
|
|
#define CX25840_CID_ENABLE_PVR150_WORKAROUND (V4L2_CID_PRIVATE_BASE+0)
|
|
|
|
|
2005-11-14 00:07:56 +00:00
|
|
|
struct cx25840_state {
|
2007-08-26 13:53:16 +00:00
|
|
|
struct i2c_client *c;
|
2008-11-29 15:50:06 +00:00
|
|
|
struct v4l2_subdev sd;
|
2006-01-09 17:25:42 +00:00
|
|
|
int pvr150_workaround;
|
2006-01-09 17:25:44 +00:00
|
|
|
int radio;
|
2008-04-22 17:45:51 +00:00
|
|
|
v4l2_std_id std;
|
2006-01-09 17:25:42 +00:00
|
|
|
enum cx25840_video_input vid_input;
|
|
|
|
enum cx25840_audio_input aud_input;
|
2006-01-09 17:25:41 +00:00
|
|
|
u32 audclk_freq;
|
2006-01-23 19:11:09 +00:00
|
|
|
int audmode;
|
2007-08-05 11:00:36 +00:00
|
|
|
int unmute_volume; /* -1 if not muted */
|
2008-07-17 15:26:45 +00:00
|
|
|
int default_volume;
|
2006-05-24 13:16:45 +00:00
|
|
|
int vbi_line_offset;
|
2007-04-27 15:31:08 +00:00
|
|
|
u32 id;
|
|
|
|
u32 rev;
|
2007-07-22 15:52:40 +00:00
|
|
|
int is_initialized;
|
2007-08-26 13:53:16 +00:00
|
|
|
wait_queue_head_t fw_wait; /* wake up when the fw load is finished */
|
|
|
|
struct work_struct fw_work; /* work entry for fw load */
|
2005-11-14 00:07:56 +00:00
|
|
|
};
|
|
|
|
|
2008-11-29 15:50:06 +00:00
|
|
|
static inline struct cx25840_state *to_state(struct v4l2_subdev *sd)
|
|
|
|
{
|
|
|
|
return container_of(sd, struct cx25840_state, sd);
|
|
|
|
}
|
|
|
|
|
2009-09-27 02:47:21 +00:00
|
|
|
static inline bool is_cx2583x(struct cx25840_state *state)
|
|
|
|
{
|
|
|
|
return state->id == V4L2_IDENT_CX25836 ||
|
|
|
|
state->id == V4L2_IDENT_CX25837;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool is_cx231xx(struct cx25840_state *state)
|
|
|
|
{
|
|
|
|
return state->id == V4L2_IDENT_CX2310X_AV;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool is_cx2388x(struct cx25840_state *state)
|
|
|
|
{
|
|
|
|
return state->id == V4L2_IDENT_CX23885_AV ||
|
|
|
|
state->id == V4L2_IDENT_CX23887_AV ||
|
|
|
|
state->id == V4L2_IDENT_CX23888_AV;
|
|
|
|
}
|
|
|
|
|
2005-11-14 00:07:56 +00:00
|
|
|
/* ----------------------------------------------------------------------- */
|
|
|
|
/* cx25850-core.c */
|
|
|
|
int cx25840_write(struct i2c_client *client, u16 addr, u8 value);
|
|
|
|
int cx25840_write4(struct i2c_client *client, u16 addr, u32 value);
|
|
|
|
u8 cx25840_read(struct i2c_client *client, u16 addr);
|
|
|
|
u32 cx25840_read4(struct i2c_client *client, u16 addr);
|
2006-04-22 13:22:46 +00:00
|
|
|
int cx25840_and_or(struct i2c_client *client, u16 addr, unsigned mask, u8 value);
|
2008-07-17 14:08:40 +00:00
|
|
|
void cx25840_std_setup(struct i2c_client *client);
|
2005-11-14 00:07:56 +00:00
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------- */
|
|
|
|
/* cx25850-firmware.c */
|
|
|
|
int cx25840_loadfw(struct i2c_client *client);
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------- */
|
|
|
|
/* cx25850-audio.c */
|
2006-01-09 17:25:42 +00:00
|
|
|
void cx25840_audio_set_path(struct i2c_client *client);
|
2009-03-30 09:26:40 +00:00
|
|
|
int cx25840_s_clock_freq(struct v4l2_subdev *sd, u32 freq);
|
|
|
|
int cx25840_audio_g_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl);
|
|
|
|
int cx25840_audio_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl);
|
2005-11-14 00:07:56 +00:00
|
|
|
|
|
|
|
/* ----------------------------------------------------------------------- */
|
|
|
|
/* cx25850-vbi.c */
|
2010-03-14 13:16:46 +00:00
|
|
|
int cx25840_s_raw_fmt(struct v4l2_subdev *sd, struct v4l2_vbi_format *fmt);
|
|
|
|
int cx25840_s_sliced_fmt(struct v4l2_subdev *sd, struct v4l2_sliced_vbi_format *fmt);
|
|
|
|
int cx25840_g_sliced_fmt(struct v4l2_subdev *sd, struct v4l2_sliced_vbi_format *fmt);
|
2009-03-30 09:26:40 +00:00
|
|
|
int cx25840_decode_vbi_line(struct v4l2_subdev *sd, struct v4l2_decode_vbi_line *vbi);
|
2005-11-14 00:07:56 +00:00
|
|
|
|
|
|
|
#endif
|