2005-04-16 15:20:36 -07:00
/*
* dvbdev . h
*
* Copyright ( C ) 2000 Ralph Metzler & Marcus Metzler
* for convergence integrated media GmbH
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Lesser Public License
* as published by the Free Software Foundation ; either version 2.1
* of the License , or ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place - Suite 330 , Boston , MA 02111 - 1307 , USA .
*
*/
# ifndef _DVBDEV_H_
# define _DVBDEV_H_
# include <linux/types.h>
# include <linux/poll.h>
# include <linux/fs.h>
# include <linux/list.h>
2015-01-02 12:19:51 -03:00
# include <media/media-device.h>
2005-04-16 15:20:36 -07:00
# define DVB_MAJOR 212
2009-09-01 19:15:39 -03:00
# if defined(CONFIG_DVB_MAX_ADAPTERS) && CONFIG_DVB_MAX_ADAPTERS > 0
2009-09-19 09:45:22 -03:00
# define DVB_MAX_ADAPTERS CONFIG_DVB_MAX_ADAPTERS
2009-09-01 19:15:39 -03:00
# else
2009-09-19 09:45:22 -03:00
# define DVB_MAX_ADAPTERS 8
2009-09-01 19:15:39 -03:00
# endif
2008-04-09 19:13:13 -03:00
# define DVB_UNSET (-1)
2005-04-16 15:20:36 -07:00
# define DVB_DEVICE_VIDEO 0
# define DVB_DEVICE_AUDIO 1
# define DVB_DEVICE_SEC 2
# define DVB_DEVICE_FRONTEND 3
# define DVB_DEVICE_DEMUX 4
# define DVB_DEVICE_DVR 5
# define DVB_DEVICE_CA 6
# define DVB_DEVICE_NET 7
# define DVB_DEVICE_OSD 8
2008-04-09 19:13:13 -03:00
# define DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr) \
static short adapter_nr [ ] = \
{ [ 0 . . . ( DVB_MAX_ADAPTERS - 1 ) ] = DVB_UNSET } ; \
module_param_array ( adapter_nr , short , NULL , 0444 ) ; \
MODULE_PARM_DESC ( adapter_nr , " DVB adapter numbers " )
2005-04-16 15:20:36 -07:00
2009-05-23 18:00:59 -03:00
struct dvb_frontend ;
2015-08-22 19:39:38 -03:00
/**
* struct dvb_adapter - represents a Digital TV adapter using Linux DVB API
*
* @ num : Number of the adapter
* @ list_head : List with the DVB adapters
* @ device_list : List with the DVB devices
* @ name : Name of the adapter
* @ proposed_mac : proposed MAC address for the adapter
* @ priv : private data
* @ device : pointer to struct device
* @ module : pointer to struct module
* @ mfe_shared : mfe shared : indicates mutually exclusive frontends
* Thie usage of this flag is currently deprecated
* @ mfe_dvbdev : Frontend device in use , in the case of MFE
* @ mfe_lock : Lock to prevent using the other frontends when MFE is
* used .
* @ mdev : pointer to struct media_device , used when the media
* controller is used .
*/
2005-04-16 15:20:36 -07:00
struct dvb_adapter {
int num ;
struct list_head list_head ;
struct list_head device_list ;
const char * name ;
u8 proposed_mac [ 6 ] ;
void * priv ;
2006-04-10 09:27:37 -03:00
struct device * device ;
2005-04-16 15:20:36 -07:00
struct module * module ;
2008-10-11 11:44:05 -03:00
int mfe_shared ; /* indicates mutually exclusive frontends */
struct dvb_device * mfe_dvbdev ; /* frontend device in use */
struct mutex mfe_lock ; /* access lock for thread creation */
2015-01-02 12:19:51 -03:00
# if defined(CONFIG_MEDIA_CONTROLLER_DVB)
struct media_device * mdev ;
# endif
2005-04-16 15:20:36 -07:00
} ;
2015-08-22 19:39:38 -03:00
/**
* struct dvb_device - represents a DVB device node
*
* @ list_head : List head with all DVB devices
* @ fops : pointer to struct file_operations
* @ adapter : pointer to the adapter that holds this device node
* @ type : type of the device : DVB_DEVICE_SEC , DVB_DEVICE_FRONTEND ,
* DVB_DEVICE_DEMUX , DVB_DEVICE_DVR , DVB_DEVICE_CA , DVB_DEVICE_NET
* @ minor : devnode minor number . Major number is always DVB_MAJOR .
* @ id : device ID number , inside the adapter
* @ readers : Initialized by the caller . Each call to open ( ) in Read Only mode
* decreases this counter by one .
* @ writers : Initialized by the caller . Each call to open ( ) in Read / Write
* mode decreases this counter by one .
* @ users : Initialized by the caller . Each call to open ( ) in any mode
* decreases this counter by one .
* @ wait_queue : wait queue , used to wait for certain events inside one of
* the DVB API callers
* @ kernel_ioctl : callback function used to handle ioctl calls from userspace .
* @ name : Name to be used for the device at the Media Controller
* @ entity : pointer to struct media_entity associated with the device node
* @ pads : pointer to struct media_pad associated with @ entity ;
* @ priv : private data
*
* This structure is used by the DVB core ( frontend , CA , net , demux ) in
* order to create the device nodes . Usually , driver should not initialize
* this struct diretly .
*/
2005-04-16 15:20:36 -07:00
struct dvb_device {
struct list_head list_head ;
2009-01-11 06:12:43 -03:00
const struct file_operations * fops ;
2005-04-16 15:20:36 -07:00
struct dvb_adapter * adapter ;
int type ;
2008-10-23 12:11:19 -03:00
int minor ;
2005-04-16 15:20:36 -07:00
u32 id ;
/* in theory, 'users' can vanish now,
but I don ' t want to change too much now . . . */
int readers ;
int writers ;
int users ;
2007-04-14 10:18:58 -03:00
wait_queue_head_t wait_queue ;
2005-12-12 00:37:27 -08:00
/* don't really need those !? -- FIXME: use video_usercopy */
2010-04-27 00:24:00 +02:00
int ( * kernel_ioctl ) ( struct file * file , unsigned int cmd , void * arg ) ;
2005-04-16 15:20:36 -07:00
2015-01-02 12:19:51 -03:00
/* Needed for media controller register/unregister */
# if defined(CONFIG_MEDIA_CONTROLLER_DVB)
const char * name ;
2015-01-03 01:59:53 -03:00
/* Allocated and filled inside dvbdev.c */
2015-08-21 08:20:22 -03:00
struct media_intf_devnode * intf_devnode ;
2015-08-21 16:18:18 -03:00
unsigned tsout_num_entities ;
struct media_entity * entity , * tsout_entity ;
struct media_pad * pads , * tsout_pads ;
2015-01-02 12:19:51 -03:00
# endif
2005-04-16 15:20:36 -07:00
void * priv ;
} ;
2015-08-22 19:39:38 -03:00
/**
* dvb_register_adapter - Registers a new DVB adapter
*
* @ adap : pointer to struct dvb_adapter
* @ name : Adapter ' s name
* @ module : initialized with THIS_MODULE at the caller
* @ device : pointer to struct device that corresponds to the device driver
* @ adapter_nums : Array with a list of the numbers for @ dvb_register_adapter ;
* to select among them . Typically , initialized with :
* DVB_DEFINE_MOD_OPT_ADAPTER_NR ( adapter_nums )
*/
int dvb_register_adapter ( struct dvb_adapter * adap , const char * name ,
struct module * module , struct device * device ,
short * adapter_nums ) ;
2005-04-16 15:20:36 -07:00
2015-08-22 19:39:38 -03:00
/**
* dvb_unregister_adapter - Unregisters a DVB adapter
*
* @ adap : pointer to struct dvb_adapter
*/
int dvb_unregister_adapter ( struct dvb_adapter * adap ) ;
2005-04-16 15:20:36 -07:00
2015-08-22 19:39:38 -03:00
/**
* dvb_register_device - Registers a new DVB device
*
* @ adap : pointer to struct dvb_adapter
* @ pdvbdev : pointer to the place where the new struct dvb_device will be
* stored
* @ template : Template used to create & pdvbdev ;
* @ priv : private data
* @ type : type of the device : DVB_DEVICE_SEC , DVB_DEVICE_FRONTEND ,
* DVB_DEVICE_DEMUX , DVB_DEVICE_DVR , DVB_DEVICE_CA , DVB_DEVICE_NET
*/
int dvb_register_device ( struct dvb_adapter * adap ,
struct dvb_device * * pdvbdev ,
const struct dvb_device * template ,
void * priv ,
2015-08-21 16:18:18 -03:00
int type ,
int demux_sink_pads ) ;
2015-08-22 19:39:38 -03:00
/**
* dvb_unregister_device - Unregisters a DVB device
*
* @ dvbdev : pointer to struct dvb_device
*/
void dvb_unregister_device ( struct dvb_device * dvbdev ) ;
2015-03-02 10:49:04 -03:00
# ifdef CONFIG_MEDIA_CONTROLLER_DVB
void dvb_create_media_graph ( struct dvb_adapter * adap ) ;
2015-03-02 11:26:14 -03:00
static inline void dvb_register_media_controller ( struct dvb_adapter * adap ,
struct media_device * mdev )
{
adap - > mdev = mdev ;
}
2015-03-02 10:49:04 -03:00
# else
static inline void dvb_create_media_graph ( struct dvb_adapter * adap ) { }
2015-03-02 11:26:14 -03:00
# define dvb_register_media_controller(a, b) {}
2015-03-02 10:49:04 -03:00
# endif
2005-04-16 15:20:36 -07:00
2015-08-22 19:39:38 -03:00
int dvb_generic_open ( struct inode * inode , struct file * file ) ;
int dvb_generic_release ( struct inode * inode , struct file * file ) ;
long dvb_generic_ioctl ( struct file * file ,
2005-04-16 15:20:36 -07:00
unsigned int cmd , unsigned long arg ) ;
/* we don't mess with video_usercopy() any more,
we simply define out own dvb_usercopy ( ) , which will hopefully become
generic_usercopy ( ) someday . . . */
2015-08-22 19:39:38 -03:00
int dvb_usercopy ( struct file * file , unsigned int cmd , unsigned long arg ,
int ( * func ) ( struct file * file , unsigned int cmd , void * arg ) ) ;
2005-04-16 15:20:36 -07:00
2006-08-08 09:10:08 -03:00
/** generic DVB attach function. */
2008-04-29 21:38:46 -03:00
# ifdef CONFIG_MEDIA_ATTACH
2006-08-08 09:10:08 -03:00
# define dvb_attach(FUNCTION, ARGS...) ({ \
void * __r = NULL ; \
typeof ( & FUNCTION ) __a = symbol_request ( FUNCTION ) ; \
if ( __a ) { \
__r = ( void * ) __a ( ARGS ) ; \
if ( __r = = NULL ) \
symbol_put ( FUNCTION ) ; \
} else { \
printk ( KERN_ERR " DVB: Unable to find symbol " # FUNCTION " () \n " ) ; \
} \
__r ; \
} )
2014-05-29 09:20:13 -03:00
# define dvb_detach(FUNC) symbol_put_addr(FUNC)
2006-08-08 09:10:08 -03:00
# else
# define dvb_attach(FUNCTION, ARGS...) ({ \
FUNCTION ( ARGS ) ; \
} )
2014-05-29 09:20:13 -03:00
# define dvb_detach(FUNC) {}
2006-08-08 09:10:08 -03:00
# endif
2005-04-16 15:20:36 -07:00
# endif /* #ifndef _DVBDEV_H_ */