| /* | 
 |  * dmxdev.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 Lesser General 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. | 
 |  * | 
 |  */ | 
 |  | 
 | #ifndef _DMXDEV_H_ | 
 | #define _DMXDEV_H_ | 
 |  | 
 | #include <linux/types.h> | 
 | #include <linux/spinlock.h> | 
 | #include <linux/kernel.h> | 
 | #include <linux/time.h> | 
 | #include <linux/timer.h> | 
 | #include <linux/wait.h> | 
 | #include <linux/fs.h> | 
 | #include <linux/string.h> | 
 | #include <linux/mutex.h> | 
 | #include <linux/slab.h> | 
 |  | 
 | #include <linux/dvb/dmx.h> | 
 |  | 
 | #include <media/dvbdev.h> | 
 | #include <media/demux.h> | 
 | #include <media/dvb_ringbuffer.h> | 
 | #include <media/dvb_vb2.h> | 
 |  | 
 | /** | 
 |  * enum dmxdev_type - type of demux filter type. | 
 |  * | 
 |  * @DMXDEV_TYPE_NONE:	no filter set. | 
 |  * @DMXDEV_TYPE_SEC:	section filter. | 
 |  * @DMXDEV_TYPE_PES:	Program Elementary Stream (PES) filter. | 
 |  */ | 
 | enum dmxdev_type { | 
 | 	DMXDEV_TYPE_NONE, | 
 | 	DMXDEV_TYPE_SEC, | 
 | 	DMXDEV_TYPE_PES, | 
 | }; | 
 |  | 
 | /** | 
 |  * enum dmxdev_state - state machine for the dmxdev. | 
 |  * | 
 |  * @DMXDEV_STATE_FREE:		indicates that the filter is freed. | 
 |  * @DMXDEV_STATE_ALLOCATED:	indicates that the filter was allocated | 
 |  *				to be used. | 
 |  * @DMXDEV_STATE_SET:		indicates that the filter parameters are set. | 
 |  * @DMXDEV_STATE_GO:		indicates that the filter is running. | 
 |  * @DMXDEV_STATE_DONE:		indicates that a packet was already filtered | 
 |  *				and the filter is now disabled. | 
 |  *				Set only if %DMX_ONESHOT. See | 
 |  *				&dmx_sct_filter_params. | 
 |  * @DMXDEV_STATE_TIMEDOUT:	Indicates a timeout condition. | 
 |  */ | 
 | enum dmxdev_state { | 
 | 	DMXDEV_STATE_FREE, | 
 | 	DMXDEV_STATE_ALLOCATED, | 
 | 	DMXDEV_STATE_SET, | 
 | 	DMXDEV_STATE_GO, | 
 | 	DMXDEV_STATE_DONE, | 
 | 	DMXDEV_STATE_TIMEDOUT | 
 | }; | 
 |  | 
 | /** | 
 |  * struct dmxdev_feed - digital TV dmxdev feed | 
 |  * | 
 |  * @pid:	Program ID to be filtered | 
 |  * @ts:		pointer to &struct dmx_ts_feed | 
 |  * @next:	&struct list_head pointing to the next feed. | 
 |  */ | 
 |  | 
 | struct dmxdev_feed { | 
 | 	u16 pid; | 
 | 	struct dmx_ts_feed *ts; | 
 | 	struct list_head next; | 
 | }; | 
 |  | 
 | /** | 
 |  * struct dmxdev_filter - digital TV dmxdev filter | 
 |  * | 
 |  * @filter:	a union describing a dmxdev filter. | 
 |  *		Currently used only for section filters. | 
 |  * @filter.sec: a &struct dmx_section_filter pointer. | 
 |  *		For section filter only. | 
 |  * @feed:	a union describing a dmxdev feed. | 
 |  *		Depending on the filter type, it can be either | 
 |  *		@feed.ts or @feed.sec. | 
 |  * @feed.ts:	a &struct list_head list. | 
 |  *		For TS and PES feeds. | 
 |  * @feed.sec:	a &struct dmx_section_feed pointer. | 
 |  *		For section feed only. | 
 |  * @params:	a union describing dmxdev filter parameters. | 
 |  *		Depending on the filter type, it can be either | 
 |  *		@params.sec or @params.pes. | 
 |  * @params.sec:	a &struct dmx_sct_filter_params embedded struct. | 
 |  *		For section filter only. | 
 |  * @params.pes:	a &struct dmx_pes_filter_params embedded struct. | 
 |  *		For PES filter only. | 
 |  * @type:	type of the dmxdev filter, as defined by &enum dmxdev_type. | 
 |  * @state:	state of the dmxdev filter, as defined by &enum dmxdev_state. | 
 |  * @dev:	pointer to &struct dmxdev. | 
 |  * @buffer:	an embedded &struct dvb_ringbuffer buffer. | 
 |  * @vb2_ctx:	control struct for VB2 handler | 
 |  * @mutex:	protects the access to &struct dmxdev_filter. | 
 |  * @timer:	&struct timer_list embedded timer, used to check for | 
 |  *		feed timeouts. | 
 |  *		Only for section filter. | 
 |  * @todo:	index for the @secheader. | 
 |  *		Only for section filter. | 
 |  * @secheader:	buffer cache to parse the section header. | 
 |  *		Only for section filter. | 
 |  */ | 
 | struct dmxdev_filter { | 
 | 	union { | 
 | 		struct dmx_section_filter *sec; | 
 | 	} filter; | 
 |  | 
 | 	union { | 
 | 		/* list of TS and PES feeds (struct dmxdev_feed) */ | 
 | 		struct list_head ts; | 
 | 		struct dmx_section_feed *sec; | 
 | 	} feed; | 
 |  | 
 | 	union { | 
 | 		struct dmx_sct_filter_params sec; | 
 | 		struct dmx_pes_filter_params pes; | 
 | 	} params; | 
 |  | 
 | 	enum dmxdev_type type; | 
 | 	enum dmxdev_state state; | 
 | 	struct dmxdev *dev; | 
 | 	struct dvb_ringbuffer buffer; | 
 | 	struct dvb_vb2_ctx vb2_ctx; | 
 |  | 
 | 	struct mutex mutex; | 
 |  | 
 | 	/* only for sections */ | 
 | 	struct timer_list timer; | 
 | 	int todo; | 
 | 	u8 secheader[3]; | 
 | }; | 
 |  | 
 | /** | 
 |  * struct dmxdev - Describes a digital TV demux device. | 
 |  * | 
 |  * @dvbdev:		pointer to &struct dvb_device associated with | 
 |  *			the demux device node. | 
 |  * @dvr_dvbdev:		pointer to &struct dvb_device associated with | 
 |  *			the dvr device node. | 
 |  * @filter:		pointer to &struct dmxdev_filter. | 
 |  * @demux:		pointer to &struct dmx_demux. | 
 |  * @filternum:		number of filters. | 
 |  * @capabilities:	demux capabilities as defined by &enum dmx_demux_caps. | 
 |  * @may_do_mmap:	flag used to indicate if the device may do mmap. | 
 |  * @exit:		flag to indicate that the demux is being released. | 
 |  * @dvr_orig_fe:	pointer to &struct dmx_frontend. | 
 |  * @dvr_buffer:		embedded &struct dvb_ringbuffer for DVB output. | 
 |  * @dvr_vb2_ctx:	control struct for VB2 handler | 
 |  * @mutex:		protects the usage of this structure. | 
 |  * @lock:		protects access to &dmxdev->filter->data. | 
 |  */ | 
 | struct dmxdev { | 
 | 	struct dvb_device *dvbdev; | 
 | 	struct dvb_device *dvr_dvbdev; | 
 |  | 
 | 	struct dmxdev_filter *filter; | 
 | 	struct dmx_demux *demux; | 
 |  | 
 | 	int filternum; | 
 | 	int capabilities; | 
 |  | 
 | 	unsigned int may_do_mmap:1; | 
 | 	unsigned int exit:1; | 
 | #define DMXDEV_CAP_DUPLEX 1 | 
 | 	struct dmx_frontend *dvr_orig_fe; | 
 |  | 
 | 	struct dvb_ringbuffer dvr_buffer; | 
 | #define DVR_BUFFER_SIZE (10*188*1024) | 
 |  | 
 | 	struct dvb_vb2_ctx dvr_vb2_ctx; | 
 |  | 
 | 	struct mutex mutex; | 
 | 	spinlock_t lock; | 
 | }; | 
 |  | 
 | /** | 
 |  * dvb_dmxdev_init - initializes a digital TV demux and registers both demux | 
 |  *	and DVR devices. | 
 |  * | 
 |  * @dmxdev: pointer to &struct dmxdev. | 
 |  * @adap: pointer to &struct dvb_adapter. | 
 |  */ | 
 | int dvb_dmxdev_init(struct dmxdev *dmxdev, struct dvb_adapter *adap); | 
 |  | 
 | /** | 
 |  * dvb_dmxdev_release - releases a digital TV demux and unregisters it. | 
 |  * | 
 |  * @dmxdev: pointer to &struct dmxdev. | 
 |  */ | 
 | void dvb_dmxdev_release(struct dmxdev *dmxdev); | 
 |  | 
 | #endif /* _DMXDEV_H_ */ |