dib0070.h 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /*
  2. * Linux-DVB Driver for DiBcom's DiB0070 base-band RF Tuner.
  3. *
  4. * Copyright (C) 2005-7 DiBcom (http://www.dibcom.fr/)
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public License as
  8. * published by the Free Software Foundation, version 2.
  9. */
  10. #ifndef DIB0070_H
  11. #define DIB0070_H
  12. struct dvb_frontend;
  13. struct i2c_adapter;
  14. #define DEFAULT_DIB0070_I2C_ADDRESS 0x60
  15. struct dib0070_wbd_gain_cfg {
  16. u16 freq;
  17. u16 wbd_gain_val;
  18. };
  19. struct dib0070_config {
  20. u8 i2c_address;
  21. /* tuner pins controlled externally */
  22. int (*reset) (struct dvb_frontend *, int);
  23. int (*sleep) (struct dvb_frontend *, int);
  24. /* offset in kHz */
  25. int freq_offset_khz_uhf;
  26. int freq_offset_khz_vhf;
  27. u8 osc_buffer_state; /* 0= normal, 1= tri-state */
  28. u32 clock_khz;
  29. u8 clock_pad_drive; /* (Drive + 1) * 2mA */
  30. u8 invert_iq; /* invert Q - in case I or Q is inverted on the board */
  31. u8 force_crystal_mode; /* if == 0 -> decision is made in the driver default: <24 -> 2, >=24 -> 1 */
  32. u8 flip_chip;
  33. u8 enable_third_order_filter;
  34. u8 charge_pump;
  35. const struct dib0070_wbd_gain_cfg *wbd_gain;
  36. u8 vga_filter;
  37. };
  38. #if IS_REACHABLE(CONFIG_DVB_TUNER_DIB0070)
  39. extern struct dvb_frontend *dib0070_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c, struct dib0070_config *cfg);
  40. extern u16 dib0070_wbd_offset(struct dvb_frontend *);
  41. extern void dib0070_ctrl_agc_filter(struct dvb_frontend *, u8 open);
  42. extern u8 dib0070_get_rf_output(struct dvb_frontend *fe);
  43. extern int dib0070_set_rf_output(struct dvb_frontend *fe, u8 no);
  44. #else
  45. static inline struct dvb_frontend *dib0070_attach(struct dvb_frontend *fe, struct i2c_adapter *i2c, struct dib0070_config *cfg)
  46. {
  47. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  48. return NULL;
  49. }
  50. static inline u16 dib0070_wbd_offset(struct dvb_frontend *fe)
  51. {
  52. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  53. return 0;
  54. }
  55. static inline void dib0070_ctrl_agc_filter(struct dvb_frontend *fe, u8 open)
  56. {
  57. printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
  58. }
  59. #endif
  60. #endif