pvrusb2-dvb.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. /*
  2. * pvrusb2-dvb.c - linux-dvb api interface to the pvrusb2 driver.
  3. *
  4. * Copyright (C) 2007, 2008 Michael Krufky <mkrufky@linuxtv.org>
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  18. *
  19. */
  20. #include "dvbdev.h"
  21. #include "pvrusb2-hdw-internal.h"
  22. #include "pvrusb2-hdw.h"
  23. #include "pvrusb2-dvb.h"
  24. DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
  25. static int pvr2_dvb_start_feed(struct dvb_demux_feed *dvbdmxfeed)
  26. {
  27. printk(KERN_DEBUG "start pid: 0x%04x, feedtype: %d\n",
  28. dvbdmxfeed->pid, dvbdmxfeed->type);
  29. return 0; /* FIXME: pvr2_dvb_ctrl_feed(dvbdmxfeed, 1); */
  30. }
  31. static int pvr2_dvb_stop_feed(struct dvb_demux_feed *dvbdmxfeed)
  32. {
  33. printk(KERN_DEBUG "stop pid: 0x%04x, feedtype: %d\n",
  34. dvbdmxfeed->pid, dvbdmxfeed->type);
  35. return 0; /* FIXME: pvr2_dvb_ctrl_feed(dvbdmxfeed, 0); */
  36. }
  37. static int pvr2_dvb_adapter_init(struct pvr2_dvb_adapter *adap)
  38. {
  39. int ret;
  40. ret = dvb_register_adapter(&adap->dvb_adap, "pvrusb2-dvb",
  41. THIS_MODULE/*&hdw->usb_dev->owner*/,
  42. &adap->pvr->hdw->usb_dev->dev,
  43. adapter_nr);
  44. if (ret < 0) {
  45. err("dvb_register_adapter failed: error %d", ret);
  46. goto err;
  47. }
  48. adap->dvb_adap.priv = adap;
  49. adap->demux.dmx.capabilities = DMX_TS_FILTERING |
  50. DMX_SECTION_FILTERING |
  51. DMX_MEMORY_BASED_FILTERING;
  52. adap->demux.priv = adap;
  53. adap->demux.filternum = 256;
  54. adap->demux.feednum = 256;
  55. adap->demux.start_feed = pvr2_dvb_start_feed;
  56. adap->demux.stop_feed = pvr2_dvb_stop_feed;
  57. adap->demux.write_to_decoder = NULL;
  58. ret = dvb_dmx_init(&adap->demux);
  59. if (ret < 0) {
  60. err("dvb_dmx_init failed: error %d", ret);
  61. goto err_dmx;
  62. }
  63. adap->dmxdev.filternum = adap->demux.filternum;
  64. adap->dmxdev.demux = &adap->demux.dmx;
  65. adap->dmxdev.capabilities = 0;
  66. ret = dvb_dmxdev_init(&adap->dmxdev, &adap->dvb_adap);
  67. if (ret < 0) {
  68. err("dvb_dmxdev_init failed: error %d", ret);
  69. goto err_dmx_dev;
  70. }
  71. dvb_net_init(&adap->dvb_adap, &adap->dvb_net, &adap->demux.dmx);
  72. adap->digital_up = 1;
  73. return 0;
  74. err_dmx_dev:
  75. dvb_dmx_release(&adap->demux);
  76. err_dmx:
  77. dvb_unregister_adapter(&adap->dvb_adap);
  78. err:
  79. return ret;
  80. }
  81. static int pvr2_dvb_adapter_exit(struct pvr2_dvb_adapter *adap)
  82. {
  83. if (adap->digital_up) {
  84. printk(KERN_DEBUG "unregistering DVB devices\n");
  85. dvb_net_release(&adap->dvb_net);
  86. adap->demux.dmx.close(&adap->demux.dmx);
  87. dvb_dmxdev_release(&adap->dmxdev);
  88. dvb_dmx_release(&adap->demux);
  89. dvb_unregister_adapter(&adap->dvb_adap);
  90. adap->digital_up = 0;
  91. }
  92. return 0;
  93. }
  94. static int pvr2_dvb_frontend_init(struct pvr2_dvb_adapter *adap)
  95. {
  96. struct pvr2_dvb_props *dvb_props = adap->pvr->hdw->hdw_desc->dvb_props;
  97. if (dvb_props == NULL) {
  98. err("fe_props not defined!");
  99. return -EINVAL;
  100. }
  101. if (dvb_props->frontend_attach == NULL) {
  102. err("frontend_attach not defined!");
  103. return -EINVAL;
  104. }
  105. if ((dvb_props->frontend_attach(adap) == 0) && (adap->fe)) {
  106. if (dvb_register_frontend(&adap->dvb_adap, adap->fe)) {
  107. err("frontend registration failed!");
  108. dvb_frontend_detach(adap->fe);
  109. adap->fe = NULL;
  110. return -ENODEV;
  111. }
  112. if (dvb_props->tuner_attach)
  113. dvb_props->tuner_attach(adap);
  114. if (adap->fe->ops.analog_ops.standby)
  115. adap->fe->ops.analog_ops.standby(adap->fe);
  116. } else {
  117. err("no frontend was attached!");
  118. return -ENODEV;
  119. }
  120. return 0;
  121. }
  122. static int pvr2_dvb_frontend_exit(struct pvr2_dvb_adapter *adap)
  123. {
  124. if (adap->fe != NULL) {
  125. dvb_unregister_frontend(adap->fe);
  126. dvb_frontend_detach(adap->fe);
  127. }
  128. return 0;
  129. }
  130. int pvr2_dvb_init(struct pvr2_context *pvr)
  131. {
  132. int ret = 0;
  133. pvr->hdw->dvb.pvr = pvr;
  134. ret = pvr2_dvb_adapter_init(&pvr->hdw->dvb);
  135. if (ret < 0)
  136. goto fail;
  137. ret = pvr2_dvb_frontend_init(&pvr->hdw->dvb);
  138. fail:
  139. return ret;
  140. }
  141. int pvr2_dvb_exit(struct pvr2_context *pvr)
  142. {
  143. pvr2_dvb_frontend_exit(&pvr->hdw->dvb);
  144. pvr2_dvb_adapter_exit(&pvr->hdw->dvb);
  145. pvr->hdw->dvb.pvr = NULL;
  146. return 0;
  147. }