1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* Common header-file of the Linux driver for the TwinhanDTV Alpha/MagicBoxII 3*4882a593Smuzhiyun * USB2.0 DVB-T receiver. 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2004-5 Patrick Boettcher (patrick.boettcher@posteo.de) 6*4882a593Smuzhiyun * 7*4882a593Smuzhiyun * Thanks to Twinhan who kindly provided hardware and information. 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * see Documentation/driver-api/media/drivers/dvb-usb.rst for more information 10*4882a593Smuzhiyun */ 11*4882a593Smuzhiyun #ifndef _DVB_USB_VP7045_H_ 12*4882a593Smuzhiyun #define _DVB_USB_VP7045_H_ 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun #define DVB_USB_LOG_PREFIX "vp7045" 15*4882a593Smuzhiyun #include "dvb-usb.h" 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun /* vp7045 commands */ 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun /* Twinhan Vendor requests */ 20*4882a593Smuzhiyun #define TH_COMMAND_IN 0xC0 21*4882a593Smuzhiyun #define TH_COMMAND_OUT 0xC1 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun /* command bytes */ 24*4882a593Smuzhiyun #define TUNER_REG_READ 0x03 25*4882a593Smuzhiyun #define TUNER_REG_WRITE 0x04 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun #define RC_VAL_READ 0x05 28*4882a593Smuzhiyun #define RC_NO_KEY 0x44 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun #define SET_TUNER_POWER 0x06 31*4882a593Smuzhiyun #define CHECK_TUNER_POWER 0x12 32*4882a593Smuzhiyun #define Tuner_Power_ON 1 33*4882a593Smuzhiyun #define Tuner_Power_OFF 0 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun #define GET_USB_SPEED 0x07 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun #define LOCK_TUNER_COMMAND 0x09 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun #define TUNER_SIGNAL_READ 0x0A 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun /* FX2 eeprom */ 42*4882a593Smuzhiyun #define SET_EE_VALUE 0x10 43*4882a593Smuzhiyun #define GET_EE_VALUE 0x11 44*4882a593Smuzhiyun #define FX2_ID_ADDR 0x00 45*4882a593Smuzhiyun #define VID_MSB_ADDR 0x02 46*4882a593Smuzhiyun #define VID_LSB_ADDR 0x01 47*4882a593Smuzhiyun #define PID_MSB_ADDR 0x04 48*4882a593Smuzhiyun #define PID_LSB_ADDR 0x03 49*4882a593Smuzhiyun #define MAC_0_ADDR 0x07 50*4882a593Smuzhiyun #define MAC_1_ADDR 0x08 51*4882a593Smuzhiyun #define MAC_2_ADDR 0x09 52*4882a593Smuzhiyun #define MAC_3_ADDR 0x0a 53*4882a593Smuzhiyun #define MAC_4_ADDR 0x0b 54*4882a593Smuzhiyun #define MAC_5_ADDR 0x0c 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun #define RESET_FX2 0x13 57*4882a593Smuzhiyun 58*4882a593Smuzhiyun #define FW_VERSION_READ 0x0B 59*4882a593Smuzhiyun #define VENDOR_STRING_READ 0x0C 60*4882a593Smuzhiyun #define PRODUCT_STRING_READ 0x0D 61*4882a593Smuzhiyun #define FW_BCD_VERSION_READ 0x14 62*4882a593Smuzhiyun 63*4882a593Smuzhiyun extern struct dvb_frontend * vp7045_fe_attach(struct dvb_usb_device *d); 64*4882a593Smuzhiyun extern int vp7045_usb_op(struct dvb_usb_device *d, u8 cmd, u8 *out, int outlen, u8 *in, int inlen,int msec); 65*4882a593Smuzhiyun extern u8 vp7045_read_reg(struct dvb_usb_device *d, u8 reg); 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun #endif 68