205 lines
4.7 KiB
C
205 lines
4.7 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
#ifndef _DVB_USB_CXUSB_H_
|
||
|
#define _DVB_USB_CXUSB_H_
|
||
|
|
||
|
#include <linux/completion.h>
|
||
|
#include <linux/i2c.h>
|
||
|
#include <linux/list.h>
|
||
|
#include <linux/mutex.h>
|
||
|
#include <linux/usb.h>
|
||
|
#include <linux/workqueue.h>
|
||
|
#include <media/v4l2-common.h>
|
||
|
#include <media/v4l2-dev.h>
|
||
|
#include <media/v4l2-device.h>
|
||
|
#include <media/videobuf2-core.h>
|
||
|
#include <media/videobuf2-v4l2.h>
|
||
|
|
||
|
#define DVB_USB_LOG_PREFIX "cxusb"
|
||
|
#include "dvb-usb.h"
|
||
|
|
||
|
#define CXUSB_VIDEO_URBS (5)
|
||
|
#define CXUSB_VIDEO_URB_MAX_SIZE (512 * 1024)
|
||
|
|
||
|
#define CXUSB_VIDEO_PKT_SIZE 3030
|
||
|
#define CXUSB_VIDEO_MAX_FRAME_PKTS 346
|
||
|
#define CXUSB_VIDEO_MAX_FRAME_SIZE (CXUSB_VIDEO_MAX_FRAME_PKTS * \
|
||
|
CXUSB_VIDEO_PKT_SIZE)
|
||
|
|
||
|
/* usb commands - some of it are guesses, don't have a reference yet */
|
||
|
#define CMD_BLUEBIRD_GPIO_RW 0x05
|
||
|
|
||
|
#define CMD_I2C_WRITE 0x08
|
||
|
#define CMD_I2C_READ 0x09
|
||
|
|
||
|
#define CMD_GPIO_READ 0x0d
|
||
|
#define CMD_GPIO_WRITE 0x0e
|
||
|
#define GPIO_TUNER 0x02
|
||
|
|
||
|
#define CMD_POWER_OFF 0xdc
|
||
|
#define CMD_POWER_ON 0xde
|
||
|
|
||
|
#define CMD_STREAMING_ON 0x36
|
||
|
#define CMD_STREAMING_OFF 0x37
|
||
|
|
||
|
#define CMD_AVER_STREAM_ON 0x18
|
||
|
#define CMD_AVER_STREAM_OFF 0x19
|
||
|
|
||
|
#define CMD_GET_IR_CODE 0x47
|
||
|
|
||
|
#define CMD_ANALOG 0x50
|
||
|
#define CMD_DIGITAL 0x51
|
||
|
|
||
|
#define CXUSB_BT656_PREAMBLE ((const u8 *)"\xff\x00\x00")
|
||
|
|
||
|
#define CXUSB_BT656_FIELD_MASK BIT(6)
|
||
|
#define CXUSB_BT656_FIELD_1 0
|
||
|
#define CXUSB_BT656_FIELD_2 BIT(6)
|
||
|
|
||
|
#define CXUSB_BT656_VBI_MASK BIT(5)
|
||
|
#define CXUSB_BT656_VBI_ON BIT(5)
|
||
|
#define CXUSB_BT656_VBI_OFF 0
|
||
|
|
||
|
#define CXUSB_BT656_SEAV_MASK BIT(4)
|
||
|
#define CXUSB_BT656_SEAV_EAV BIT(4)
|
||
|
#define CXUSB_BT656_SEAV_SAV 0
|
||
|
|
||
|
/* Max transfer size done by I2C transfer functions */
|
||
|
#define MAX_XFER_SIZE 80
|
||
|
|
||
|
struct cxusb_state {
|
||
|
u8 gpio_write_state[3];
|
||
|
bool gpio_write_refresh[3];
|
||
|
struct i2c_client *i2c_client_demod;
|
||
|
struct i2c_client *i2c_client_tuner;
|
||
|
|
||
|
unsigned char data[MAX_XFER_SIZE];
|
||
|
|
||
|
struct mutex stream_mutex;
|
||
|
u8 last_lock;
|
||
|
int (*fe_read_status)(struct dvb_frontend *fe,
|
||
|
enum fe_status *status);
|
||
|
};
|
||
|
|
||
|
enum cxusb_open_type {
|
||
|
CXUSB_OPEN_INIT,
|
||
|
CXUSB_OPEN_NONE,
|
||
|
CXUSB_OPEN_ANALOG,
|
||
|
CXUSB_OPEN_DIGITAL
|
||
|
};
|
||
|
|
||
|
struct cxusb_medion_auxbuf {
|
||
|
u8 *buf;
|
||
|
unsigned int len;
|
||
|
unsigned int paylen;
|
||
|
};
|
||
|
|
||
|
enum cxusb_bt656_mode {
|
||
|
NEW_FRAME, FIRST_FIELD, SECOND_FIELD
|
||
|
};
|
||
|
|
||
|
enum cxusb_bt656_fmode {
|
||
|
START_SEARCH, LINE_SAMPLES, VBI_SAMPLES
|
||
|
};
|
||
|
|
||
|
struct cxusb_bt656_params {
|
||
|
enum cxusb_bt656_mode mode;
|
||
|
enum cxusb_bt656_fmode fmode;
|
||
|
unsigned int pos;
|
||
|
unsigned int line;
|
||
|
unsigned int linesamples;
|
||
|
u8 *buf;
|
||
|
};
|
||
|
|
||
|
struct cxusb_medion_dev {
|
||
|
/* has to be the first one */
|
||
|
struct cxusb_state state;
|
||
|
|
||
|
struct dvb_usb_device *dvbdev;
|
||
|
|
||
|
enum cxusb_open_type open_type;
|
||
|
unsigned int open_ctr;
|
||
|
struct mutex open_lock;
|
||
|
|
||
|
#ifdef CONFIG_DVB_USB_CXUSB_ANALOG
|
||
|
struct v4l2_device v4l2dev;
|
||
|
struct v4l2_subdev *cx25840;
|
||
|
struct v4l2_subdev *tuner;
|
||
|
struct v4l2_subdev *tda9887;
|
||
|
struct video_device *videodev, *radiodev;
|
||
|
struct mutex dev_lock;
|
||
|
|
||
|
struct vb2_queue videoqueue;
|
||
|
u32 input;
|
||
|
bool stop_streaming;
|
||
|
u32 width, height;
|
||
|
u32 field_order;
|
||
|
struct cxusb_medion_auxbuf auxbuf;
|
||
|
v4l2_std_id norm;
|
||
|
|
||
|
struct urb *streamurbs[CXUSB_VIDEO_URBS];
|
||
|
unsigned long urbcomplete;
|
||
|
struct work_struct urbwork;
|
||
|
unsigned int nexturb;
|
||
|
|
||
|
struct cxusb_bt656_params bt656;
|
||
|
struct cxusb_medion_vbuffer *vbuf;
|
||
|
__u32 vbuf_sequence;
|
||
|
|
||
|
struct list_head buflist;
|
||
|
|
||
|
struct completion v4l2_release;
|
||
|
#endif
|
||
|
};
|
||
|
|
||
|
struct cxusb_medion_vbuffer {
|
||
|
struct vb2_v4l2_buffer vb2;
|
||
|
struct list_head list;
|
||
|
};
|
||
|
|
||
|
/* defines for "debug" module parameter */
|
||
|
#define CXUSB_DBG_RC BIT(0)
|
||
|
#define CXUSB_DBG_I2C BIT(1)
|
||
|
#define CXUSB_DBG_MISC BIT(2)
|
||
|
#define CXUSB_DBG_BT656 BIT(3)
|
||
|
#define CXUSB_DBG_URB BIT(4)
|
||
|
#define CXUSB_DBG_OPS BIT(5)
|
||
|
#define CXUSB_DBG_AUXB BIT(6)
|
||
|
|
||
|
extern int dvb_usb_cxusb_debug;
|
||
|
|
||
|
#define cxusb_vprintk(dvbdev, lvl, ...) do { \
|
||
|
struct cxusb_medion_dev *_cxdev = (dvbdev)->priv; \
|
||
|
if (dvb_usb_cxusb_debug & CXUSB_DBG_##lvl) \
|
||
|
v4l2_printk(KERN_DEBUG, \
|
||
|
&_cxdev->v4l2dev, __VA_ARGS__); \
|
||
|
} while (0)
|
||
|
|
||
|
int cxusb_ctrl_msg(struct dvb_usb_device *d,
|
||
|
u8 cmd, const u8 *wbuf, int wlen, u8 *rbuf, int rlen);
|
||
|
|
||
|
#ifdef CONFIG_DVB_USB_CXUSB_ANALOG
|
||
|
int cxusb_medion_analog_init(struct dvb_usb_device *dvbdev);
|
||
|
int cxusb_medion_register_analog(struct dvb_usb_device *dvbdev);
|
||
|
void cxusb_medion_unregister_analog(struct dvb_usb_device *dvbdev);
|
||
|
#else
|
||
|
static inline int cxusb_medion_analog_init(struct dvb_usb_device *dvbdev)
|
||
|
{
|
||
|
return -EINVAL;
|
||
|
}
|
||
|
|
||
|
static inline int cxusb_medion_register_analog(struct dvb_usb_device *dvbdev)
|
||
|
{
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static inline void cxusb_medion_unregister_analog(struct dvb_usb_device *dvbdev)
|
||
|
{
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
int cxusb_medion_get(struct dvb_usb_device *dvbdev,
|
||
|
enum cxusb_open_type open_type);
|
||
|
void cxusb_medion_put(struct dvb_usb_device *dvbdev);
|
||
|
|
||
|
#endif
|