Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame^] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | #include <dvbdev.h> |
| 3 | #include <dmxdev.h> |
| 4 | #include <dvb_demux.h> |
| 5 | #include <dvb_net.h> |
| 6 | #include <dvb_frontend.h> |
| 7 | |
Hans Petter Selasky | 5d8f290 | 2011-05-23 12:10:40 -0300 | [diff] [blame] | 8 | #ifndef _VIDEOBUF_DVB_H_ |
| 9 | #define _VIDEOBUF_DVB_H_ |
| 10 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 | struct videobuf_dvb { |
| 12 | /* filling that the job of the driver */ |
| 13 | char *name; |
| 14 | struct dvb_frontend *frontend; |
| 15 | struct videobuf_queue dvbq; |
| 16 | |
| 17 | /* video-buf-dvb state info */ |
Ingo Molnar | 3593cab | 2006-02-07 06:49:14 -0200 | [diff] [blame] | 18 | struct mutex lock; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | struct task_struct *thread; |
| 20 | int nfeeds; |
| 21 | |
| 22 | /* videobuf_dvb_(un)register manges this */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 23 | struct dvb_demux demux; |
| 24 | struct dmxdev dmxdev; |
| 25 | struct dmx_frontend fe_hw; |
| 26 | struct dmx_frontend fe_mem; |
| 27 | struct dvb_net net; |
| 28 | }; |
| 29 | |
Steven Toth | 363c35f | 2008-10-11 11:05:50 -0300 | [diff] [blame] | 30 | struct videobuf_dvb_frontend { |
Steven Toth | 363c35f | 2008-10-11 11:05:50 -0300 | [diff] [blame] | 31 | struct list_head felist; |
| 32 | int id; |
| 33 | struct videobuf_dvb dvb; |
| 34 | }; |
| 35 | |
| 36 | struct videobuf_dvb_frontends { |
Darron Broad | 7bdf84f | 2008-10-15 13:43:41 -0300 | [diff] [blame] | 37 | struct list_head felist; |
Steven Toth | 363c35f | 2008-10-11 11:05:50 -0300 | [diff] [blame] | 38 | struct mutex lock; |
| 39 | struct dvb_adapter adapter; |
| 40 | int active_fe_id; /* Indicates which frontend in the felist is in use */ |
Darron Broad | 8e73909 | 2008-10-11 11:31:41 -0300 | [diff] [blame] | 41 | int gate; /* Frontend with gate control 0=!MFE,1=fe0,2=fe1 etc */ |
Steven Toth | 363c35f | 2008-10-11 11:05:50 -0300 | [diff] [blame] | 42 | }; |
| 43 | |
| 44 | int videobuf_dvb_register_bus(struct videobuf_dvb_frontends *f, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 | struct module *module, |
Andrew de Quincey | d09dbf9 | 2006-04-10 09:27:37 -0300 | [diff] [blame] | 46 | void *adapter_priv, |
Janne Grunau | 78e92006 | 2008-04-09 19:13:13 -0300 | [diff] [blame] | 47 | struct device *device, |
Darron Broad | 59b1842 | 2008-10-11 11:44:05 -0300 | [diff] [blame] | 48 | short *adapter_nr, |
Mauro Carvalho Chehab | 9adf613 | 2012-08-05 14:16:30 -0300 | [diff] [blame] | 49 | int mfe_shared); |
Steven Toth | 363c35f | 2008-10-11 11:05:50 -0300 | [diff] [blame] | 50 | |
| 51 | void videobuf_dvb_unregister_bus(struct videobuf_dvb_frontends *f); |
| 52 | |
Darron Broad | 96b7a1a | 2008-10-15 20:26:34 -0300 | [diff] [blame] | 53 | struct videobuf_dvb_frontend * videobuf_dvb_alloc_frontend(struct videobuf_dvb_frontends *f, int id); |
Darron Broad | 878595f | 2008-10-21 11:28:46 -0300 | [diff] [blame] | 54 | void videobuf_dvb_dealloc_frontends(struct videobuf_dvb_frontends *f); |
Steven Toth | 363c35f | 2008-10-11 11:05:50 -0300 | [diff] [blame] | 55 | |
| 56 | struct videobuf_dvb_frontend * videobuf_dvb_get_frontend(struct videobuf_dvb_frontends *f, int id); |
| 57 | int videobuf_dvb_find_frontend(struct videobuf_dvb_frontends *f, struct dvb_frontend *p); |
| 58 | |
Hans Petter Selasky | 5d8f290 | 2011-05-23 12:10:40 -0300 | [diff] [blame] | 59 | #endif /* _VIDEOBUF_DVB_H_ */ |