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