xref: /openbmc/linux/drivers/media/usb/dvb-usb/vp702x.h (revision 786baecf)
1786baecfSMauro Carvalho Chehab #ifndef _DVB_USB_VP7021_H_
2786baecfSMauro Carvalho Chehab #define _DVB_USB_VP7021_H_
3786baecfSMauro Carvalho Chehab 
4786baecfSMauro Carvalho Chehab #define DVB_USB_LOG_PREFIX "vp702x"
5786baecfSMauro Carvalho Chehab #include "dvb-usb.h"
6786baecfSMauro Carvalho Chehab 
7786baecfSMauro Carvalho Chehab extern int dvb_usb_vp702x_debug;
8786baecfSMauro Carvalho Chehab #define deb_info(args...) dprintk(dvb_usb_vp702x_debug,0x01,args)
9786baecfSMauro Carvalho Chehab #define deb_xfer(args...) dprintk(dvb_usb_vp702x_debug,0x02,args)
10786baecfSMauro Carvalho Chehab #define deb_rc(args...)   dprintk(dvb_usb_vp702x_debug,0x04,args)
11786baecfSMauro Carvalho Chehab #define deb_fe(args...)   dprintk(dvb_usb_vp702x_debug,0x08,args)
12786baecfSMauro Carvalho Chehab 
13786baecfSMauro Carvalho Chehab /* commands are read and written with USB control messages */
14786baecfSMauro Carvalho Chehab 
15786baecfSMauro Carvalho Chehab /* consecutive read/write operation */
16786baecfSMauro Carvalho Chehab #define REQUEST_OUT		0xB2
17786baecfSMauro Carvalho Chehab #define REQUEST_IN		0xB3
18786baecfSMauro Carvalho Chehab 
19786baecfSMauro Carvalho Chehab /* the out-buffer of these consecutive operations contain sub-commands when b[0] = 0
20786baecfSMauro Carvalho Chehab  * request: 0xB2; i: 0; v: 0; b[0] = 0, b[1] = subcmd, additional buffer
21786baecfSMauro Carvalho Chehab  * the returning buffer looks as follows
22786baecfSMauro Carvalho Chehab  * request: 0xB3; i: 0; v: 0; b[0] = 0xB3, additional buffer */
23786baecfSMauro Carvalho Chehab 
24786baecfSMauro Carvalho Chehab #define GET_TUNER_STATUS	0x05
25786baecfSMauro Carvalho Chehab /* additional in buffer:
26786baecfSMauro Carvalho Chehab  * 0   1   2    3              4   5   6               7       8
27786baecfSMauro Carvalho Chehab  * N/A N/A 0x05 signal-quality N/A N/A signal-strength lock==0 N/A */
28786baecfSMauro Carvalho Chehab 
29786baecfSMauro Carvalho Chehab #define GET_SYSTEM_STRING	0x06
30786baecfSMauro Carvalho Chehab /* additional in buffer:
31786baecfSMauro Carvalho Chehab  * 0   1   2   3   4   5   6   7   8
32786baecfSMauro Carvalho Chehab  * N/A 'U' 'S' 'B' '7' '0' '2' 'X' N/A */
33786baecfSMauro Carvalho Chehab 
34786baecfSMauro Carvalho Chehab #define SET_DISEQC_CMD		0x08
35786baecfSMauro Carvalho Chehab /* additional out buffer:
36786baecfSMauro Carvalho Chehab  * 0    1  2  3  4
37786baecfSMauro Carvalho Chehab  * len  X1 X2 X3 X4
38786baecfSMauro Carvalho Chehab  * additional in buffer:
39786baecfSMauro Carvalho Chehab  * 0   1 2
40786baecfSMauro Carvalho Chehab  * N/A 0 0   b[1] == b[2] == 0 -> success, failure otherwise */
41786baecfSMauro Carvalho Chehab 
42786baecfSMauro Carvalho Chehab #define SET_LNB_POWER		0x09
43786baecfSMauro Carvalho Chehab /* additional out buffer:
44786baecfSMauro Carvalho Chehab  * 0    1    2
45786baecfSMauro Carvalho Chehab  * 0x00 0xff 1 = on, 0 = off
46786baecfSMauro Carvalho Chehab  * additional in buffer:
47786baecfSMauro Carvalho Chehab  * 0   1 2
48786baecfSMauro Carvalho Chehab  * N/A 0 0   b[1] == b[2] == 0 -> success failure otherwise */
49786baecfSMauro Carvalho Chehab 
50786baecfSMauro Carvalho Chehab #define GET_MAC_ADDRESS		0x0A
51786baecfSMauro Carvalho Chehab /* #define GET_MAC_ADDRESS   0x0B */
52786baecfSMauro Carvalho Chehab /* additional in buffer:
53786baecfSMauro Carvalho Chehab  * 0   1   2            3    4    5    6    7    8
54786baecfSMauro Carvalho Chehab  * N/A N/A 0x0A or 0x0B MAC0 MAC1 MAC2 MAC3 MAC4 MAC5 */
55786baecfSMauro Carvalho Chehab 
56786baecfSMauro Carvalho Chehab #define SET_PID_FILTER		0x11
57786baecfSMauro Carvalho Chehab /* additional in buffer:
58786baecfSMauro Carvalho Chehab  * 0        1        ... 14       15       16
59786baecfSMauro Carvalho Chehab  * PID0_MSB PID0_LSB ... PID7_MSB PID7_LSB PID_active (bits) */
60786baecfSMauro Carvalho Chehab 
61786baecfSMauro Carvalho Chehab /* request: 0xB2; i: 0; v: 0;
62786baecfSMauro Carvalho Chehab  * b[0] != 0 -> tune and lock a channel
63786baecfSMauro Carvalho Chehab  * 0     1     2       3      4      5      6    7
64786baecfSMauro Carvalho Chehab  * freq0 freq1 divstep srate0 srate1 srate2 flag chksum
65786baecfSMauro Carvalho Chehab  */
66786baecfSMauro Carvalho Chehab 
67786baecfSMauro Carvalho Chehab /* one direction requests */
68786baecfSMauro Carvalho Chehab #define READ_REMOTE_REQ		0xB4
69786baecfSMauro Carvalho Chehab /* IN  i: 0; v: 0; b[0] == request, b[1] == key */
70786baecfSMauro Carvalho Chehab 
71786baecfSMauro Carvalho Chehab #define READ_PID_NUMBER_REQ	0xB5
72786baecfSMauro Carvalho Chehab /* IN  i: 0; v: 0; b[0] == request, b[1] == 0, b[2] = pid number */
73786baecfSMauro Carvalho Chehab 
74786baecfSMauro Carvalho Chehab #define WRITE_EEPROM_REQ	0xB6
75786baecfSMauro Carvalho Chehab /* OUT i: offset; v: value to write; no extra buffer */
76786baecfSMauro Carvalho Chehab 
77786baecfSMauro Carvalho Chehab #define READ_EEPROM_REQ		0xB7
78786baecfSMauro Carvalho Chehab /* IN  i: bufferlen; v: offset; buffer with bufferlen bytes */
79786baecfSMauro Carvalho Chehab 
80786baecfSMauro Carvalho Chehab #define READ_STATUS		0xB8
81786baecfSMauro Carvalho Chehab /* IN  i: 0; v: 0; bufferlen 10 */
82786baecfSMauro Carvalho Chehab 
83786baecfSMauro Carvalho Chehab #define READ_TUNER_REG_REQ	0xB9
84786baecfSMauro Carvalho Chehab /* IN  i: 0; v: register; b[0] = value */
85786baecfSMauro Carvalho Chehab 
86786baecfSMauro Carvalho Chehab #define READ_FX2_REG_REQ	0xBA
87786baecfSMauro Carvalho Chehab /* IN  i: offset; v: 0; b[0] = value */
88786baecfSMauro Carvalho Chehab 
89786baecfSMauro Carvalho Chehab #define WRITE_FX2_REG_REQ	0xBB
90786baecfSMauro Carvalho Chehab /* OUT i: offset; v: value to write; 1 byte extra buffer */
91786baecfSMauro Carvalho Chehab 
92786baecfSMauro Carvalho Chehab #define SET_TUNER_POWER_REQ	0xBC
93786baecfSMauro Carvalho Chehab /* IN  i: 0 = power off, 1 = power on */
94786baecfSMauro Carvalho Chehab 
95786baecfSMauro Carvalho Chehab #define WRITE_TUNER_REG_REQ	0xBD
96786baecfSMauro Carvalho Chehab /* IN  i: register, v: value to write, no extra buffer */
97786baecfSMauro Carvalho Chehab 
98786baecfSMauro Carvalho Chehab #define RESET_TUNER		0xBE
99786baecfSMauro Carvalho Chehab /* IN  i: 0, v: 0, no extra buffer */
100786baecfSMauro Carvalho Chehab 
101786baecfSMauro Carvalho Chehab struct vp702x_device_state {
102786baecfSMauro Carvalho Chehab 	struct mutex buf_mutex;
103786baecfSMauro Carvalho Chehab 	int buf_len;
104786baecfSMauro Carvalho Chehab 	u8 *buf;
105786baecfSMauro Carvalho Chehab };
106786baecfSMauro Carvalho Chehab 
107786baecfSMauro Carvalho Chehab 
108786baecfSMauro Carvalho Chehab extern struct dvb_frontend * vp702x_fe_attach(struct dvb_usb_device *d);
109786baecfSMauro Carvalho Chehab 
110786baecfSMauro Carvalho Chehab extern int vp702x_usb_inout_op(struct dvb_usb_device *d, u8 *o, int olen, u8 *i, int ilen, int msec);
111786baecfSMauro Carvalho Chehab extern int vp702x_usb_in_op(struct dvb_usb_device *d, u8 req, u16 value, u16 index, u8 *b, int blen);
112786baecfSMauro Carvalho Chehab 
113786baecfSMauro Carvalho Chehab #endif
114