Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^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