1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Card-specific functions for the Siano SMS1xxx USB dongle 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (c) 2008 Michael Krufky <mkrufky@linuxtv.org> 6*4882a593Smuzhiyun */ 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #ifndef __SMS_CARDS_H__ 9*4882a593Smuzhiyun #define __SMS_CARDS_H__ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #include "smscoreapi.h" 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #include <linux/usb.h> 14*4882a593Smuzhiyun #include "smsir.h" 15*4882a593Smuzhiyun 16*4882a593Smuzhiyun #define SMS_BOARD_UNKNOWN 0 17*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_STELLAR 1 18*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_NOVA_A 2 19*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_NOVA_B 3 20*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_VEGA 4 21*4882a593Smuzhiyun #define SMS1XXX_BOARD_HAUPPAUGE_CATAMOUNT 5 22*4882a593Smuzhiyun #define SMS1XXX_BOARD_HAUPPAUGE_OKEMO_A 6 23*4882a593Smuzhiyun #define SMS1XXX_BOARD_HAUPPAUGE_OKEMO_B 7 24*4882a593Smuzhiyun #define SMS1XXX_BOARD_HAUPPAUGE_WINDHAM 8 25*4882a593Smuzhiyun #define SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD 9 26*4882a593Smuzhiyun #define SMS1XXX_BOARD_HAUPPAUGE_TIGER_MINICARD_R2 10 27*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_NICE 11 28*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_VENICE 12 29*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_STELLAR_ROM 13 30*4882a593Smuzhiyun #define SMS1XXX_BOARD_ZTE_DVB_DATA_CARD 14 31*4882a593Smuzhiyun #define SMS1XXX_BOARD_ONDA_MDTV_DATA_CARD 15 32*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_MING 16 33*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_PELE 17 34*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_RIO 18 35*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_DENVER_1530 19 36*4882a593Smuzhiyun #define SMS1XXX_BOARD_SIANO_DENVER_2160 20 37*4882a593Smuzhiyun #define SMS1XXX_BOARD_PCTV_77E 21 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun struct sms_board_gpio_cfg { 40*4882a593Smuzhiyun int lna_vhf_exist; 41*4882a593Smuzhiyun int lna_vhf_ctrl; 42*4882a593Smuzhiyun int lna_uhf_exist; 43*4882a593Smuzhiyun int lna_uhf_ctrl; 44*4882a593Smuzhiyun int lna_uhf_d_ctrl; 45*4882a593Smuzhiyun int lna_sband_exist; 46*4882a593Smuzhiyun int lna_sband_ctrl; 47*4882a593Smuzhiyun int lna_sband_d_ctrl; 48*4882a593Smuzhiyun int foreign_lna0_ctrl; 49*4882a593Smuzhiyun int foreign_lna1_ctrl; 50*4882a593Smuzhiyun int foreign_lna2_ctrl; 51*4882a593Smuzhiyun int rf_switch_vhf; 52*4882a593Smuzhiyun int rf_switch_uhf; 53*4882a593Smuzhiyun int rf_switch_sband; 54*4882a593Smuzhiyun int leds_power; 55*4882a593Smuzhiyun int led0; 56*4882a593Smuzhiyun int led1; 57*4882a593Smuzhiyun int led2; 58*4882a593Smuzhiyun int led3; 59*4882a593Smuzhiyun int led4; 60*4882a593Smuzhiyun int ir; 61*4882a593Smuzhiyun int eeprom_wp; 62*4882a593Smuzhiyun int mrc_sense; 63*4882a593Smuzhiyun int mrc_pdn_resetn; 64*4882a593Smuzhiyun int mrc_gp0; /* mrcs spi int */ 65*4882a593Smuzhiyun int mrc_gp1; 66*4882a593Smuzhiyun int mrc_gp2; 67*4882a593Smuzhiyun int mrc_gp3; 68*4882a593Smuzhiyun int mrc_gp4; 69*4882a593Smuzhiyun int host_spi_gsp_ts_int; 70*4882a593Smuzhiyun }; 71*4882a593Smuzhiyun 72*4882a593Smuzhiyun struct sms_board { 73*4882a593Smuzhiyun enum sms_device_type_st type; 74*4882a593Smuzhiyun char *name, *fw[DEVICE_MODE_MAX]; 75*4882a593Smuzhiyun struct sms_board_gpio_cfg board_cfg; 76*4882a593Smuzhiyun char *rc_codes; /* Name of IR codes table */ 77*4882a593Smuzhiyun 78*4882a593Smuzhiyun /* gpios */ 79*4882a593Smuzhiyun int led_power, led_hi, led_lo, lna_ctrl, rf_switch; 80*4882a593Smuzhiyun 81*4882a593Smuzhiyun char intf_num; 82*4882a593Smuzhiyun int default_mode; 83*4882a593Smuzhiyun unsigned int mtu; 84*4882a593Smuzhiyun unsigned int crystal; 85*4882a593Smuzhiyun struct sms_antenna_config_ST *antenna_config; 86*4882a593Smuzhiyun }; 87*4882a593Smuzhiyun 88*4882a593Smuzhiyun struct sms_board *sms_get_board(unsigned id); 89*4882a593Smuzhiyun 90*4882a593Smuzhiyun extern struct smscore_device_t *coredev; 91*4882a593Smuzhiyun 92*4882a593Smuzhiyun enum SMS_BOARD_EVENTS { 93*4882a593Smuzhiyun BOARD_EVENT_POWER_INIT, 94*4882a593Smuzhiyun BOARD_EVENT_POWER_SUSPEND, 95*4882a593Smuzhiyun BOARD_EVENT_POWER_RESUME, 96*4882a593Smuzhiyun BOARD_EVENT_BIND, 97*4882a593Smuzhiyun BOARD_EVENT_SCAN_PROG, 98*4882a593Smuzhiyun BOARD_EVENT_SCAN_COMP, 99*4882a593Smuzhiyun BOARD_EVENT_EMERGENCY_WARNING_SIGNAL, 100*4882a593Smuzhiyun BOARD_EVENT_FE_LOCK, 101*4882a593Smuzhiyun BOARD_EVENT_FE_UNLOCK, 102*4882a593Smuzhiyun BOARD_EVENT_DEMOD_LOCK, 103*4882a593Smuzhiyun BOARD_EVENT_DEMOD_UNLOCK, 104*4882a593Smuzhiyun BOARD_EVENT_RECEPTION_MAX_4, 105*4882a593Smuzhiyun BOARD_EVENT_RECEPTION_3, 106*4882a593Smuzhiyun BOARD_EVENT_RECEPTION_2, 107*4882a593Smuzhiyun BOARD_EVENT_RECEPTION_1, 108*4882a593Smuzhiyun BOARD_EVENT_RECEPTION_LOST_0, 109*4882a593Smuzhiyun BOARD_EVENT_MULTIPLEX_OK, 110*4882a593Smuzhiyun BOARD_EVENT_MULTIPLEX_ERRORS 111*4882a593Smuzhiyun }; 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun int sms_board_event(struct smscore_device_t *coredev, 114*4882a593Smuzhiyun enum SMS_BOARD_EVENTS gevent); 115*4882a593Smuzhiyun 116*4882a593Smuzhiyun int sms_board_setup(struct smscore_device_t *coredev); 117*4882a593Smuzhiyun 118*4882a593Smuzhiyun #define SMS_LED_OFF 0 119*4882a593Smuzhiyun #define SMS_LED_LO 1 120*4882a593Smuzhiyun #define SMS_LED_HI 2 121*4882a593Smuzhiyun int sms_board_led_feedback(struct smscore_device_t *coredev, int led); 122*4882a593Smuzhiyun int sms_board_power(struct smscore_device_t *coredev, int onoff); 123*4882a593Smuzhiyun int sms_board_lna_control(struct smscore_device_t *coredev, int onoff); 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun extern int sms_board_load_modules(int id); 126*4882a593Smuzhiyun 127*4882a593Smuzhiyun #endif /* __SMS_CARDS_H__ */ 128