xref: /OK3568_Linux_fs/kernel/drivers/media/usb/dvb-usb/cxusb.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun #ifndef _DVB_USB_CXUSB_H_
3*4882a593Smuzhiyun #define _DVB_USB_CXUSB_H_
4*4882a593Smuzhiyun 
5*4882a593Smuzhiyun #include <linux/completion.h>
6*4882a593Smuzhiyun #include <linux/i2c.h>
7*4882a593Smuzhiyun #include <linux/list.h>
8*4882a593Smuzhiyun #include <linux/mutex.h>
9*4882a593Smuzhiyun #include <linux/usb.h>
10*4882a593Smuzhiyun #include <linux/workqueue.h>
11*4882a593Smuzhiyun #include <media/v4l2-common.h>
12*4882a593Smuzhiyun #include <media/v4l2-dev.h>
13*4882a593Smuzhiyun #include <media/v4l2-device.h>
14*4882a593Smuzhiyun #include <media/videobuf2-core.h>
15*4882a593Smuzhiyun #include <media/videobuf2-v4l2.h>
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #define DVB_USB_LOG_PREFIX "cxusb"
18*4882a593Smuzhiyun #include "dvb-usb.h"
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun #define CXUSB_VIDEO_URBS (5)
21*4882a593Smuzhiyun #define CXUSB_VIDEO_URB_MAX_SIZE (512 * 1024)
22*4882a593Smuzhiyun 
23*4882a593Smuzhiyun #define CXUSB_VIDEO_PKT_SIZE 3030
24*4882a593Smuzhiyun #define CXUSB_VIDEO_MAX_FRAME_PKTS 346
25*4882a593Smuzhiyun #define CXUSB_VIDEO_MAX_FRAME_SIZE (CXUSB_VIDEO_MAX_FRAME_PKTS * \
26*4882a593Smuzhiyun 					CXUSB_VIDEO_PKT_SIZE)
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun /* usb commands - some of it are guesses, don't have a reference yet */
29*4882a593Smuzhiyun #define CMD_BLUEBIRD_GPIO_RW 0x05
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun #define CMD_I2C_WRITE     0x08
32*4882a593Smuzhiyun #define CMD_I2C_READ      0x09
33*4882a593Smuzhiyun 
34*4882a593Smuzhiyun #define CMD_GPIO_READ     0x0d
35*4882a593Smuzhiyun #define CMD_GPIO_WRITE    0x0e
36*4882a593Smuzhiyun #define     GPIO_TUNER         0x02
37*4882a593Smuzhiyun 
38*4882a593Smuzhiyun #define CMD_POWER_OFF     0xdc
39*4882a593Smuzhiyun #define CMD_POWER_ON      0xde
40*4882a593Smuzhiyun 
41*4882a593Smuzhiyun #define CMD_STREAMING_ON  0x36
42*4882a593Smuzhiyun #define CMD_STREAMING_OFF 0x37
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun #define CMD_AVER_STREAM_ON  0x18
45*4882a593Smuzhiyun #define CMD_AVER_STREAM_OFF 0x19
46*4882a593Smuzhiyun 
47*4882a593Smuzhiyun #define CMD_GET_IR_CODE   0x47
48*4882a593Smuzhiyun 
49*4882a593Smuzhiyun #define CMD_ANALOG        0x50
50*4882a593Smuzhiyun #define CMD_DIGITAL       0x51
51*4882a593Smuzhiyun 
52*4882a593Smuzhiyun #define CXUSB_BT656_PREAMBLE ((const u8 *)"\xff\x00\x00")
53*4882a593Smuzhiyun 
54*4882a593Smuzhiyun #define CXUSB_BT656_FIELD_MASK BIT(6)
55*4882a593Smuzhiyun #define CXUSB_BT656_FIELD_1 0
56*4882a593Smuzhiyun #define CXUSB_BT656_FIELD_2 BIT(6)
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun #define CXUSB_BT656_VBI_MASK BIT(5)
59*4882a593Smuzhiyun #define CXUSB_BT656_VBI_ON BIT(5)
60*4882a593Smuzhiyun #define CXUSB_BT656_VBI_OFF 0
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun #define CXUSB_BT656_SEAV_MASK BIT(4)
63*4882a593Smuzhiyun #define CXUSB_BT656_SEAV_EAV BIT(4)
64*4882a593Smuzhiyun #define CXUSB_BT656_SEAV_SAV 0
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun /* Max transfer size done by I2C transfer functions */
67*4882a593Smuzhiyun #define MAX_XFER_SIZE  80
68*4882a593Smuzhiyun 
69*4882a593Smuzhiyun struct cxusb_state {
70*4882a593Smuzhiyun 	u8 gpio_write_state[3];
71*4882a593Smuzhiyun 	bool gpio_write_refresh[3];
72*4882a593Smuzhiyun 	struct i2c_client *i2c_client_demod;
73*4882a593Smuzhiyun 	struct i2c_client *i2c_client_tuner;
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun 	unsigned char data[MAX_XFER_SIZE];
76*4882a593Smuzhiyun 
77*4882a593Smuzhiyun 	struct mutex stream_mutex;
78*4882a593Smuzhiyun 	u8 last_lock;
79*4882a593Smuzhiyun 	int (*fe_read_status)(struct dvb_frontend *fe,
80*4882a593Smuzhiyun 			      enum fe_status *status);
81*4882a593Smuzhiyun };
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun enum cxusb_open_type {
84*4882a593Smuzhiyun 	CXUSB_OPEN_INIT,
85*4882a593Smuzhiyun 	CXUSB_OPEN_NONE,
86*4882a593Smuzhiyun 	CXUSB_OPEN_ANALOG,
87*4882a593Smuzhiyun 	CXUSB_OPEN_DIGITAL
88*4882a593Smuzhiyun };
89*4882a593Smuzhiyun 
90*4882a593Smuzhiyun struct cxusb_medion_auxbuf {
91*4882a593Smuzhiyun 	u8 *buf;
92*4882a593Smuzhiyun 	unsigned int len;
93*4882a593Smuzhiyun 	unsigned int paylen;
94*4882a593Smuzhiyun };
95*4882a593Smuzhiyun 
96*4882a593Smuzhiyun enum cxusb_bt656_mode {
97*4882a593Smuzhiyun 	NEW_FRAME, FIRST_FIELD, SECOND_FIELD
98*4882a593Smuzhiyun };
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun enum cxusb_bt656_fmode {
101*4882a593Smuzhiyun 	START_SEARCH, LINE_SAMPLES, VBI_SAMPLES
102*4882a593Smuzhiyun };
103*4882a593Smuzhiyun 
104*4882a593Smuzhiyun struct cxusb_bt656_params {
105*4882a593Smuzhiyun 	enum cxusb_bt656_mode mode;
106*4882a593Smuzhiyun 	enum cxusb_bt656_fmode fmode;
107*4882a593Smuzhiyun 	unsigned int pos;
108*4882a593Smuzhiyun 	unsigned int line;
109*4882a593Smuzhiyun 	unsigned int linesamples;
110*4882a593Smuzhiyun 	u8 *buf;
111*4882a593Smuzhiyun };
112*4882a593Smuzhiyun 
113*4882a593Smuzhiyun struct cxusb_medion_dev {
114*4882a593Smuzhiyun 	/* has to be the first one */
115*4882a593Smuzhiyun 	struct cxusb_state state;
116*4882a593Smuzhiyun 
117*4882a593Smuzhiyun 	struct dvb_usb_device *dvbdev;
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun 	enum cxusb_open_type open_type;
120*4882a593Smuzhiyun 	unsigned int open_ctr;
121*4882a593Smuzhiyun 	struct mutex open_lock;
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun #ifdef CONFIG_DVB_USB_CXUSB_ANALOG
124*4882a593Smuzhiyun 	struct v4l2_device v4l2dev;
125*4882a593Smuzhiyun 	struct v4l2_subdev *cx25840;
126*4882a593Smuzhiyun 	struct v4l2_subdev *tuner;
127*4882a593Smuzhiyun 	struct v4l2_subdev *tda9887;
128*4882a593Smuzhiyun 	struct video_device *videodev, *radiodev;
129*4882a593Smuzhiyun 	struct mutex dev_lock;
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun 	struct vb2_queue videoqueue;
132*4882a593Smuzhiyun 	u32 input;
133*4882a593Smuzhiyun 	bool stop_streaming;
134*4882a593Smuzhiyun 	u32 width, height;
135*4882a593Smuzhiyun 	u32 field_order;
136*4882a593Smuzhiyun 	struct cxusb_medion_auxbuf auxbuf;
137*4882a593Smuzhiyun 	v4l2_std_id norm;
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun 	struct urb *streamurbs[CXUSB_VIDEO_URBS];
140*4882a593Smuzhiyun 	unsigned long urbcomplete;
141*4882a593Smuzhiyun 	struct work_struct urbwork;
142*4882a593Smuzhiyun 	unsigned int nexturb;
143*4882a593Smuzhiyun 
144*4882a593Smuzhiyun 	struct cxusb_bt656_params bt656;
145*4882a593Smuzhiyun 	struct cxusb_medion_vbuffer *vbuf;
146*4882a593Smuzhiyun 	__u32 vbuf_sequence;
147*4882a593Smuzhiyun 
148*4882a593Smuzhiyun 	struct list_head buflist;
149*4882a593Smuzhiyun 
150*4882a593Smuzhiyun 	struct completion v4l2_release;
151*4882a593Smuzhiyun #endif
152*4882a593Smuzhiyun };
153*4882a593Smuzhiyun 
154*4882a593Smuzhiyun struct cxusb_medion_vbuffer {
155*4882a593Smuzhiyun 	struct vb2_v4l2_buffer vb2;
156*4882a593Smuzhiyun 	struct list_head list;
157*4882a593Smuzhiyun };
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun /* defines for "debug" module parameter */
160*4882a593Smuzhiyun #define CXUSB_DBG_RC BIT(0)
161*4882a593Smuzhiyun #define CXUSB_DBG_I2C BIT(1)
162*4882a593Smuzhiyun #define CXUSB_DBG_MISC BIT(2)
163*4882a593Smuzhiyun #define CXUSB_DBG_BT656 BIT(3)
164*4882a593Smuzhiyun #define CXUSB_DBG_URB BIT(4)
165*4882a593Smuzhiyun #define CXUSB_DBG_OPS BIT(5)
166*4882a593Smuzhiyun #define CXUSB_DBG_AUXB BIT(6)
167*4882a593Smuzhiyun 
168*4882a593Smuzhiyun extern int dvb_usb_cxusb_debug;
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun #define cxusb_vprintk(dvbdev, lvl, ...) do {				\
171*4882a593Smuzhiyun 		struct cxusb_medion_dev *_cxdev = (dvbdev)->priv;	\
172*4882a593Smuzhiyun 		if (dvb_usb_cxusb_debug & CXUSB_DBG_##lvl)		\
173*4882a593Smuzhiyun 			v4l2_printk(KERN_DEBUG,			\
174*4882a593Smuzhiyun 				    &_cxdev->v4l2dev, __VA_ARGS__);	\
175*4882a593Smuzhiyun 	} while (0)
176*4882a593Smuzhiyun 
177*4882a593Smuzhiyun int cxusb_ctrl_msg(struct dvb_usb_device *d,
178*4882a593Smuzhiyun 		   u8 cmd, const u8 *wbuf, int wlen, u8 *rbuf, int rlen);
179*4882a593Smuzhiyun 
180*4882a593Smuzhiyun #ifdef CONFIG_DVB_USB_CXUSB_ANALOG
181*4882a593Smuzhiyun int cxusb_medion_analog_init(struct dvb_usb_device *dvbdev);
182*4882a593Smuzhiyun int cxusb_medion_register_analog(struct dvb_usb_device *dvbdev);
183*4882a593Smuzhiyun void cxusb_medion_unregister_analog(struct dvb_usb_device *dvbdev);
184*4882a593Smuzhiyun #else
cxusb_medion_analog_init(struct dvb_usb_device * dvbdev)185*4882a593Smuzhiyun static inline int cxusb_medion_analog_init(struct dvb_usb_device *dvbdev)
186*4882a593Smuzhiyun {
187*4882a593Smuzhiyun 	return -EINVAL;
188*4882a593Smuzhiyun }
189*4882a593Smuzhiyun 
cxusb_medion_register_analog(struct dvb_usb_device * dvbdev)190*4882a593Smuzhiyun static inline int cxusb_medion_register_analog(struct dvb_usb_device *dvbdev)
191*4882a593Smuzhiyun {
192*4882a593Smuzhiyun 	return 0;
193*4882a593Smuzhiyun }
194*4882a593Smuzhiyun 
cxusb_medion_unregister_analog(struct dvb_usb_device * dvbdev)195*4882a593Smuzhiyun static inline void cxusb_medion_unregister_analog(struct dvb_usb_device *dvbdev)
196*4882a593Smuzhiyun {
197*4882a593Smuzhiyun }
198*4882a593Smuzhiyun #endif
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun int cxusb_medion_get(struct dvb_usb_device *dvbdev,
201*4882a593Smuzhiyun 		     enum cxusb_open_type open_type);
202*4882a593Smuzhiyun void cxusb_medion_put(struct dvb_usb_device *dvbdev);
203*4882a593Smuzhiyun 
204*4882a593Smuzhiyun #endif
205