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
 |