1 #include <dvbdev.h> 2 #include <dmxdev.h> 3 #include <dvb_demux.h> 4 #include <dvb_net.h> 5 #include <dvb_frontend.h> 6 7 #ifndef _VIDEOBUF_DVB_H_ 8 #define _VIDEOBUF_DVB_H_ 9 10 struct videobuf_dvb { 11 /* filling that the job of the driver */ 12 char *name; 13 struct dvb_frontend *frontend; 14 struct videobuf_queue dvbq; 15 16 /* video-buf-dvb state info */ 17 struct mutex lock; 18 struct task_struct *thread; 19 int nfeeds; 20 21 /* videobuf_dvb_(un)register manges this */ 22 struct dvb_demux demux; 23 struct dmxdev dmxdev; 24 struct dmx_frontend fe_hw; 25 struct dmx_frontend fe_mem; 26 struct dvb_net net; 27 }; 28 29 struct videobuf_dvb_frontend { 30 struct list_head felist; 31 int id; 32 struct videobuf_dvb dvb; 33 }; 34 35 struct videobuf_dvb_frontends { 36 struct list_head felist; 37 struct mutex lock; 38 struct dvb_adapter adapter; 39 int active_fe_id; /* Indicates which frontend in the felist is in use */ 40 int gate; /* Frontend with gate control 0=!MFE,1=fe0,2=fe1 etc */ 41 }; 42 43 int videobuf_dvb_register_bus(struct videobuf_dvb_frontends *f, 44 struct module *module, 45 void *adapter_priv, 46 struct device *device, 47 short *adapter_nr, 48 int mfe_shared, 49 int (*fe_ioctl_override)(struct dvb_frontend *, 50 unsigned int, void *, unsigned int)); 51 52 void videobuf_dvb_unregister_bus(struct videobuf_dvb_frontends *f); 53 54 struct videobuf_dvb_frontend * videobuf_dvb_alloc_frontend(struct videobuf_dvb_frontends *f, int id); 55 void videobuf_dvb_dealloc_frontends(struct videobuf_dvb_frontends *f); 56 57 struct videobuf_dvb_frontend * videobuf_dvb_get_frontend(struct videobuf_dvb_frontends *f, int id); 58 int videobuf_dvb_find_frontend(struct videobuf_dvb_frontends *f, struct dvb_frontend *p); 59 60 #endif /* _VIDEOBUF_DVB_H_ */ 61 62 /* 63 * Local variables: 64 * c-basic-offset: 8 65 * End: 66 */ 67