dvb-usb-i2c.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. /* dvb-usb-i2c.c is part of the DVB USB library.
  2. *
  3. * Copyright (C) 2004-5 Patrick Boettcher (patrick.boettcher@desy.de)
  4. * see dvb-usb-init.c for copyright information.
  5. *
  6. * This file contains functions for (de-)initializing an I2C adapter.
  7. */
  8. #include "dvb-usb-common.h"
  9. int dvb_usb_i2c_init(struct dvb_usb_device *d)
  10. {
  11. int ret = 0;
  12. if (!(d->props.caps & DVB_USB_IS_AN_I2C_ADAPTER))
  13. return 0;
  14. if (d->props.i2c_algo == NULL) {
  15. err("no i2c algorithm specified");
  16. return -EINVAL;
  17. }
  18. strncpy(d->i2c_adap.name,d->desc->name,I2C_NAME_SIZE);
  19. #ifdef I2C_ADAP_CLASS_TV_DIGITAL
  20. d->i2c_adap.class = I2C_ADAP_CLASS_TV_DIGITAL,
  21. #else
  22. d->i2c_adap.class = I2C_CLASS_TV_DIGITAL,
  23. #endif
  24. d->i2c_adap.algo = d->props.i2c_algo;
  25. d->i2c_adap.algo_data = NULL;
  26. d->i2c_adap.id = I2C_ALGO_BIT;
  27. i2c_set_adapdata(&d->i2c_adap, d);
  28. if ((ret = i2c_add_adapter(&d->i2c_adap)) < 0)
  29. err("could not add i2c adapter");
  30. d->state |= DVB_USB_STATE_I2C;
  31. return ret;
  32. }
  33. int dvb_usb_i2c_exit(struct dvb_usb_device *d)
  34. {
  35. if (d->state & DVB_USB_STATE_I2C)
  36. i2c_del_adapter(&d->i2c_adap);
  37. d->state &= ~DVB_USB_STATE_I2C;
  38. return 0;
  39. }
  40. int dvb_usb_pll_init_i2c(struct dvb_frontend *fe)
  41. {
  42. struct dvb_usb_device *d = fe->dvb->priv;
  43. struct i2c_msg msg = { .addr = d->pll_addr, .flags = 0, .buf = d->pll_init, .len = 4 };
  44. int ret = 0;
  45. /* if there is nothing to initialize */
  46. if (d->pll_init[0] == 0x00 && d->pll_init[1] == 0x00 &&
  47. d->pll_init[2] == 0x00 && d->pll_init[3] == 0x00)
  48. return 0;
  49. if (d->tuner_pass_ctrl)
  50. d->tuner_pass_ctrl(fe,1,d->pll_addr);
  51. deb_pll("pll init: %x\n",d->pll_addr);
  52. deb_pll("pll-buf: %x %x %x %x\n",d->pll_init[0],d->pll_init[1],
  53. d->pll_init[2],d->pll_init[3]);
  54. if (i2c_transfer (&d->i2c_adap, &msg, 1) != 1) {
  55. err("tuner i2c write failed for pll_init.");
  56. ret = -EREMOTEIO;
  57. }
  58. msleep(1);
  59. if (d->tuner_pass_ctrl)
  60. d->tuner_pass_ctrl(fe,0,d->pll_addr);
  61. return ret;
  62. }
  63. EXPORT_SYMBOL(dvb_usb_pll_init_i2c);
  64. int dvb_usb_pll_set(struct dvb_frontend *fe, struct dvb_frontend_parameters *fep, u8 b[5])
  65. {
  66. struct dvb_usb_device *d = fe->dvb->priv;
  67. deb_pll("pll addr: %x, freq: %d %p\n",d->pll_addr,fep->frequency,d->pll_desc);
  68. b[0] = d->pll_addr << 1;
  69. dvb_pll_configure(d->pll_desc,&b[1],fep->frequency,fep->u.ofdm.bandwidth);
  70. deb_pll("pll-buf: %x %x %x %x %x\n",b[0],b[1],b[2],b[3],b[4]);
  71. return 0;
  72. }
  73. EXPORT_SYMBOL(dvb_usb_pll_set);
  74. int dvb_usb_pll_set_i2c(struct dvb_frontend *fe, struct dvb_frontend_parameters *fep)
  75. {
  76. struct dvb_usb_device *d = fe->dvb->priv;
  77. int ret = 0;
  78. u8 b[5];
  79. struct i2c_msg msg = { .addr = d->pll_addr, .flags = 0, .buf = &b[1], .len = 4 };
  80. dvb_usb_pll_set(fe,fep,b);
  81. if (d->tuner_pass_ctrl)
  82. d->tuner_pass_ctrl(fe,1,d->pll_addr);
  83. if (i2c_transfer (&d->i2c_adap, &msg, 1) != 1) {
  84. err("tuner i2c write failed for pll_set.");
  85. ret = -EREMOTEIO;
  86. }
  87. msleep(1);
  88. if (d->tuner_pass_ctrl)
  89. d->tuner_pass_ctrl(fe,0,d->pll_addr);
  90. return ret;
  91. }
  92. EXPORT_SYMBOL(dvb_usb_pll_set_i2c);