dib8000.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. #ifndef DIB8000_H
  2. #define DIB8000_H
  3. #include "dibx000_common.h"
  4. struct dib8000_config {
  5. u8 output_mpeg2_in_188_bytes;
  6. u8 hostbus_diversity;
  7. u8 tuner_is_baseband;
  8. int (*update_lna) (struct dvb_frontend *, u16 agc_global);
  9. u8 agc_config_count;
  10. struct dibx000_agc_config *agc;
  11. struct dibx000_bandwidth_config *pll;
  12. #define DIB8000_GPIO_DEFAULT_DIRECTIONS 0xffff
  13. u16 gpio_dir;
  14. #define DIB8000_GPIO_DEFAULT_VALUES 0x0000
  15. u16 gpio_val;
  16. #define DIB8000_GPIO_PWM_POS0(v) ((v & 0xf) << 12)
  17. #define DIB8000_GPIO_PWM_POS1(v) ((v & 0xf) << 8 )
  18. #define DIB8000_GPIO_PWM_POS2(v) ((v & 0xf) << 4 )
  19. #define DIB8000_GPIO_PWM_POS3(v) (v & 0xf)
  20. #define DIB8000_GPIO_DEFAULT_PWM_POS 0xffff
  21. u16 gpio_pwm_pos;
  22. u16 pwm_freq_div;
  23. void (*agc_control) (struct dvb_frontend *, u8 before);
  24. u16 drives;
  25. u16 diversity_delay;
  26. u8 div_cfg;
  27. u8 output_mode;
  28. u8 refclksel;
  29. };
  30. #define DEFAULT_DIB8000_I2C_ADDRESS 18
  31. #if defined(CONFIG_DVB_DIB8000) || (defined(CONFIG_DVB_DIB8000_MODULE) && defined(MODULE))
  32. extern struct dvb_frontend *dib8000_attach(struct i2c_adapter *i2c_adap, u8 i2c_addr, struct dib8000_config *cfg);
  33. extern struct i2c_adapter *dib8000_get_i2c_master(struct dvb_frontend *, enum dibx000_i2c_interface, int);
  34. extern int dib8000_i2c_enumeration(struct i2c_adapter *host, int no_of_demods, u8 default_addr, u8 first_addr);
  35. extern int dib8000_set_gpio(struct dvb_frontend *, u8 num, u8 dir, u8 val);
  36. extern int dib8000_set_wbd_ref(struct dvb_frontend *, u16 value);
  37. extern int dib8000_pid_filter_ctrl(struct dvb_frontend *, u8 onoff);
  38. extern int dib8000_pid_filter(struct dvb_frontend *, u8 id, u16 pid, u8 onoff);
  39. extern int dib8000_set_tune_state(struct dvb_frontend *fe, enum frontend_tune_state tune_state);
  40. extern enum frontend_tune_state dib8000_get_tune_state(struct dvb_frontend *fe);
  41. extern void dib8000_pwm_agc_reset(struct dvb_frontend *fe);
  42. extern s32 dib8000_get_adc_power(struct dvb_frontend *fe, u8 mode);
  43. extern int dib8000_set_slave_frontend(struct dvb_frontend *fe, struct dvb_frontend *fe_slave);
  44. extern int dib8000_remove_slave_frontend(struct dvb_frontend *fe);
  45. extern struct dvb_frontend *dib8000_get_slave_frontend(struct dvb_frontend *fe, int slave_index);
  46. #else
  47. static inline struct dvb_frontend *dib8000_attach(struct i2c_adapter *i2c_adap, u8 i2c_addr, struct dib8000_config *cfg)
  48. {
  49. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  50. return NULL;
  51. }
  52. static inline struct i2c_adapter *dib8000_get_i2c_master(struct dvb_frontend *fe, enum dibx000_i2c_interface i, int x)
  53. {
  54. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  55. return NULL;
  56. }
  57. static inline int dib8000_i2c_enumeration(struct i2c_adapter *host, int no_of_demods, u8 default_addr, u8 first_addr)
  58. {
  59. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  60. return -ENODEV;
  61. }
  62. static inline int dib8000_set_gpio(struct dvb_frontend *fe, u8 num, u8 dir, u8 val)
  63. {
  64. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  65. return -ENODEV;
  66. }
  67. static inline int dib8000_set_wbd_ref(struct dvb_frontend *fe, u16 value)
  68. {
  69. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  70. return -ENODEV;
  71. }
  72. static inline int dib8000_pid_filter_ctrl(struct dvb_frontend *fe, u8 onoff)
  73. {
  74. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  75. return -ENODEV;
  76. }
  77. static inline int dib8000_pid_filter(struct dvb_frontend *fe, u8 id, u16 pid, u8 onoff)
  78. {
  79. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  80. return -ENODEV;
  81. }
  82. static inline int dib8000_set_tune_state(struct dvb_frontend *fe, enum frontend_tune_state tune_state)
  83. {
  84. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  85. return -ENODEV;
  86. }
  87. static inline enum frontend_tune_state dib8000_get_tune_state(struct dvb_frontend *fe)
  88. {
  89. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  90. return CT_SHUTDOWN;
  91. }
  92. static inline void dib8000_pwm_agc_reset(struct dvb_frontend *fe)
  93. {
  94. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  95. }
  96. static inline s32 dib8000_get_adc_power(struct dvb_frontend *fe, u8 mode)
  97. {
  98. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  99. return 0;
  100. }
  101. static inline int dib8000_set_slave_frontend(struct dvb_frontend *fe, struct dvb_frontend *fe_slave)
  102. {
  103. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  104. return -ENODEV;
  105. }
  106. int dib8000_remove_slave_frontend(struct dvb_frontend *fe)
  107. {
  108. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  109. return -ENODEV;
  110. }
  111. static inline struct dvb_frontend *dib8000_get_slave_frontend(struct dvb_frontend *fe, int slave_index)
  112. {
  113. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  114. return NULL;
  115. }
  116. #endif
  117. #endif