2019-05-27 09:55:06 +03:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2006-03-25 16:26:09 +03:00
/* cx25840 internal API header
2005-11-14 03:07:56 +03:00
*
* Copyright ( C ) 2003 - 2004 Chris Kennedy
*/
2006-03-25 16:26:09 +03:00
# ifndef _CX25840_CORE_H_
# define _CX25840_CORE_H_
2005-11-14 03:07:56 +03:00
# include <linux/videodev2.h>
2008-11-29 18:50:06 +03:00
# include <media/v4l2-device.h>
2010-08-06 17:55:39 +04:00
# include <media/v4l2-ctrls.h>
2005-11-14 03:07:56 +03:00
# include <linux/i2c.h>
2010-07-19 05:08:03 +04:00
struct cx25840_ir_state ;
2013-05-29 13:59:52 +04:00
enum cx25840_model {
CX23885_AV ,
CX23887_AV ,
CX23888_AV ,
CX2310X_AV ,
CX25840 ,
CX25841 ,
CX25842 ,
CX25843 ,
CX25836 ,
CX25837 ,
} ;
2015-02-20 00:44:51 +03:00
enum cx25840_media_pads {
CX25840_PAD_INPUT ,
CX25840_PAD_VID_OUT ,
CX25840_NUM_PADS
} ;
2018-07-03 00:23:22 +03:00
/**
* struct cx25840_state - a device instance private data
* @ c : i2c_client struct representing this device
* @ sd : our V4L2 sub - device
* @ hdl : our V4L2 control handler
* @ volume : audio volume V4L2 control ( non - cx2583x devices only )
* @ mute : audio mute V4L2 control ( non - cx2583x devices only )
* @ pvr150_workaround : whether we enable workaround for Hauppauge PVR150
* hardware bug ( audio dropping out )
2019-04-29 19:16:55 +03:00
* @ generic_mode : whether we disable ivtv - specific hacks
* this mode gets turned on when the bridge driver calls
* cx25840 subdevice init core op
2018-07-03 00:23:22 +03:00
* @ radio : set if we are currently in the radio mode , otherwise
* the current mode is non - radio ( that is , video )
* @ std : currently set video standard
* @ vid_input : currently set video input
2019-04-29 19:16:55 +03:00
* @ vid_config : currently set video output configuration
* only used in the generic mode
2018-07-03 00:23:22 +03:00
* @ aud_input : currently set audio input
* @ audclk_freq : currently set audio sample rate
* @ audmode : currently set audio mode ( when in non - radio mode )
* @ vbi_line_offset : vbi line number offset
* @ id : exact device model
* @ rev : raw device id read from the chip
* @ is_initialized : whether we have already loaded firmware into the chip
* and initialized it
* @ vbi_regs_offset : offset of vbi regs
2019-02-18 22:28:58 +03:00
* @ fw_wait : wait queue to wake an initialization function up when
2018-07-03 00:23:22 +03:00
* firmware loading ( on a separate workqueue ) finishes
* @ fw_work : a work that actually loads the firmware on a separate
* workqueue
* @ ir_state : a pointer to chip IR controller private data
* @ pads : array of supported chip pads ( currently only a stub )
*/
2005-11-14 03:07:56 +03:00
struct cx25840_state {
2007-08-26 17:53:16 +04:00
struct i2c_client * c ;
2008-11-29 18:50:06 +03:00
struct v4l2_subdev sd ;
2010-08-06 17:55:39 +04:00
struct v4l2_ctrl_handler hdl ;
struct {
/* volume cluster */
struct v4l2_ctrl * volume ;
struct v4l2_ctrl * mute ;
} ;
2006-01-09 20:25:42 +03:00
int pvr150_workaround ;
2019-04-29 19:16:55 +03:00
bool generic_mode ;
2006-01-09 20:25:44 +03:00
int radio ;
2008-04-22 21:45:51 +04:00
v4l2_std_id std ;
2006-01-09 20:25:42 +03:00
enum cx25840_video_input vid_input ;
2019-04-29 19:16:55 +03:00
u32 vid_config ;
2006-01-09 20:25:42 +03:00
enum cx25840_audio_input aud_input ;
2006-01-09 20:25:41 +03:00
u32 audclk_freq ;
2006-01-23 22:11:09 +03:00
int audmode ;
2006-05-24 17:16:45 +04:00
int vbi_line_offset ;
2013-05-29 13:59:52 +04:00
enum cx25840_model id ;
2007-04-27 19:31:08 +04:00
u32 rev ;
2007-07-22 19:52:40 +04:00
int is_initialized ;
2019-05-29 00:42:56 +03:00
unsigned int vbi_regs_offset ;
2018-07-03 00:23:22 +03:00
wait_queue_head_t fw_wait ;
struct work_struct fw_work ;
2010-07-19 05:08:03 +04:00
struct cx25840_ir_state * ir_state ;
2015-01-03 19:10:08 +03:00
# if defined(CONFIG_MEDIA_CONTROLLER)
2015-02-20 00:44:51 +03:00
struct media_pad pads [ CX25840_NUM_PADS ] ;
2015-01-03 19:10:08 +03:00
# endif
2005-11-14 03:07:56 +03:00
} ;
2008-11-29 18:50:06 +03:00
static inline struct cx25840_state * to_state ( struct v4l2_subdev * sd )
{
return container_of ( sd , struct cx25840_state , sd ) ;
}
2010-08-06 17:55:39 +04:00
static inline struct v4l2_subdev * to_sd ( struct v4l2_ctrl * ctrl )
{
return & container_of ( ctrl - > handler , struct cx25840_state , hdl ) - > sd ;
}
2009-09-27 06:47:21 +04:00
static inline bool is_cx2583x ( struct cx25840_state * state )
{
2013-05-29 13:59:52 +04:00
return state - > id = = CX25836 | |
state - > id = = CX25837 ;
2009-09-27 06:47:21 +04:00
}
2019-04-29 19:16:55 +03:00
static inline bool is_cx2584x ( struct cx25840_state * state )
{
return state - > id = = CX25840 | |
state - > id = = CX25841 | |
state - > id = = CX25842 | |
state - > id = = CX25843 ;
}
2009-09-27 06:47:21 +04:00
static inline bool is_cx231xx ( struct cx25840_state * state )
{
2013-05-29 13:59:52 +04:00
return state - > id = = CX2310X_AV ;
2009-09-27 06:47:21 +04:00
}
static inline bool is_cx2388x ( struct cx25840_state * state )
{
2013-05-29 13:59:52 +04:00
return state - > id = = CX23885_AV | |
state - > id = = CX23887_AV | |
state - > id = = CX23888_AV ;
2009-09-27 06:47:21 +04:00
}
2010-07-19 05:08:03 +04:00
static inline bool is_cx23885 ( struct cx25840_state * state )
{
2013-05-29 13:59:52 +04:00
return state - > id = = CX23885_AV ;
2010-07-19 05:08:03 +04:00
}
static inline bool is_cx23887 ( struct cx25840_state * state )
{
2013-05-29 13:59:52 +04:00
return state - > id = = CX23887_AV ;
2010-07-19 05:08:03 +04:00
}
static inline bool is_cx23888 ( struct cx25840_state * state )
{
2013-05-29 13:59:52 +04:00
return state - > id = = CX23888_AV ;
2010-07-19 05:08:03 +04:00
}
2005-11-14 03:07:56 +03:00
/* ----------------------------------------------------------------------- */
2018-01-04 21:08:56 +03:00
/* cx25850-core.c */
2005-11-14 03:07:56 +03:00
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 ) ;
2019-05-29 00:42:56 +03:00
int cx25840_and_or ( struct i2c_client * client , u16 addr , unsigned int mask ,
u8 value ) ;
2010-07-19 05:08:03 +04:00
int cx25840_and_or4 ( struct i2c_client * client , u16 addr , u32 and_mask ,
u32 or_value ) ;
2008-07-17 18:08:40 +04:00
void cx25840_std_setup ( struct i2c_client * client ) ;
2005-11-14 03:07:56 +03:00
/* ----------------------------------------------------------------------- */
/* cx25850-firmware.c */
int cx25840_loadfw ( struct i2c_client * client ) ;
/* ----------------------------------------------------------------------- */
/* cx25850-audio.c */
2006-01-09 20:25:42 +03:00
void cx25840_audio_set_path ( struct i2c_client * client ) ;
2009-03-30 13:26:40 +04:00
int cx25840_s_clock_freq ( struct v4l2_subdev * sd , u32 freq ) ;
2010-08-06 17:55:39 +04:00
extern const struct v4l2_ctrl_ops cx25840_audio_ctrl_ops ;
2005-11-14 03:07:56 +03:00
/* ----------------------------------------------------------------------- */
/* cx25850-vbi.c */
2010-03-14 16:16:46 +03:00
int cx25840_s_raw_fmt ( struct v4l2_subdev * sd , struct v4l2_vbi_format * fmt ) ;
2019-05-29 00:42:56 +03:00
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 ) ;
int cx25840_decode_vbi_line ( struct v4l2_subdev * sd ,
struct v4l2_decode_vbi_line * vbi ) ;
2005-11-14 03:07:56 +03:00
2010-07-19 05:08:03 +04:00
/* ----------------------------------------------------------------------- */
/* cx25850-ir.c */
extern const struct v4l2_subdev_ir_ops cx25840_ir_ops ;
int cx25840_ir_log_status ( struct v4l2_subdev * sd ) ;
int cx25840_ir_irq_handler ( struct v4l2_subdev * sd , u32 status , bool * handled ) ;
int cx25840_ir_probe ( struct v4l2_subdev * sd ) ;
int cx25840_ir_remove ( struct v4l2_subdev * sd ) ;
2005-11-14 03:07:56 +03:00
# endif