^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) #ifndef _DVB_USB_VP7021_H_
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) #define _DVB_USB_VP7021_H_
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) #define DVB_USB_LOG_PREFIX "vp702x"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) #include "dvb-usb.h"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) extern int dvb_usb_vp702x_debug;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) #define deb_info(args...) dprintk(dvb_usb_vp702x_debug,0x01,args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) #define deb_xfer(args...) dprintk(dvb_usb_vp702x_debug,0x02,args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) #define deb_rc(args...) dprintk(dvb_usb_vp702x_debug,0x04,args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #define deb_fe(args...) dprintk(dvb_usb_vp702x_debug,0x08,args)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) /* commands are read and written with USB control messages */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) /* consecutive read/write operation */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #define REQUEST_OUT 0xB2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) #define REQUEST_IN 0xB3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) /* the out-buffer of these consecutive operations contain sub-commands when b[0] = 0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) * request: 0xB2; i: 0; v: 0; b[0] = 0, b[1] = subcmd, additional buffer
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) * the returning buffer looks as follows
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) * request: 0xB3; i: 0; v: 0; b[0] = 0xB3, additional buffer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) #define GET_TUNER_STATUS 0x05
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) /* additional in buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) * 0 1 2 3 4 5 6 7 8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) * N/A N/A 0x05 signal-quality N/A N/A signal-strength lock==0 N/A */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) #define GET_SYSTEM_STRING 0x06
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) /* additional in buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) * 0 1 2 3 4 5 6 7 8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) * N/A 'U' 'S' 'B' '7' '0' '2' 'X' N/A */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) #define SET_DISEQC_CMD 0x08
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) /* additional out buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) * 0 1 2 3 4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) * len X1 X2 X3 X4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) * additional in buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) * 0 1 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) * N/A 0 0 b[1] == b[2] == 0 -> success, failure otherwise */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) #define SET_LNB_POWER 0x09
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) /* additional out buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) * 0 1 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) * 0x00 0xff 1 = on, 0 = off
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) * additional in buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) * 0 1 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) * N/A 0 0 b[1] == b[2] == 0 -> success failure otherwise */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) #define GET_MAC_ADDRESS 0x0A
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) /* #define GET_MAC_ADDRESS 0x0B */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) /* additional in buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) * 0 1 2 3 4 5 6 7 8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) * N/A N/A 0x0A or 0x0B MAC0 MAC1 MAC2 MAC3 MAC4 MAC5 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) #define SET_PID_FILTER 0x11
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) /* additional in buffer:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) * 0 1 ... 14 15 16
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) * PID0_MSB PID0_LSB ... PID7_MSB PID7_LSB PID_active (bits) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) /* request: 0xB2; i: 0; v: 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) * b[0] != 0 -> tune and lock a channel
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) * 0 1 2 3 4 5 6 7
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) * freq0 freq1 divstep srate0 srate1 srate2 flag chksum
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) /* one direction requests */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) #define READ_REMOTE_REQ 0xB4
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) /* IN i: 0; v: 0; b[0] == request, b[1] == key */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) #define READ_PID_NUMBER_REQ 0xB5
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73) /* IN i: 0; v: 0; b[0] == request, b[1] == 0, b[2] = pid number */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) #define WRITE_EEPROM_REQ 0xB6
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76) /* OUT i: offset; v: value to write; no extra buffer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78) #define READ_EEPROM_REQ 0xB7
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79) /* IN i: bufferlen; v: offset; buffer with bufferlen bytes */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81) #define READ_STATUS 0xB8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82) /* IN i: 0; v: 0; bufferlen 10 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 84) #define READ_TUNER_REG_REQ 0xB9
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 85) /* IN i: 0; v: register; b[0] = value */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 86)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 87) #define READ_FX2_REG_REQ 0xBA
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 88) /* IN i: offset; v: 0; b[0] = value */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 89)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 90) #define WRITE_FX2_REG_REQ 0xBB
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 91) /* OUT i: offset; v: value to write; 1 byte extra buffer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 92)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 93) #define SET_TUNER_POWER_REQ 0xBC
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 94) /* IN i: 0 = power off, 1 = power on */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 95)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 96) #define WRITE_TUNER_REG_REQ 0xBD
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 97) /* IN i: register, v: value to write, no extra buffer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 98)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 99) #define RESET_TUNER 0xBE
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 100) /* IN i: 0, v: 0, no extra buffer */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 101)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 102) struct vp702x_device_state {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 103) struct mutex buf_mutex;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 104) int buf_len;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 105) u8 *buf;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 106) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 107)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 108)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 109) extern struct dvb_frontend * vp702x_fe_attach(struct dvb_usb_device *d);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 110)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 111) extern int vp702x_usb_inout_op(struct dvb_usb_device *d, u8 *o, int olen, u8 *i, int ilen, int msec);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 112) extern int vp702x_usb_in_op(struct dvb_usb_device *d, u8 req, u16 value, u16 index, u8 *b, int blen);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 113)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 114) #endif