forked from Minki/linux
0b23498aac
Some conditions required for DVB mmap support to work are reversed. Also, the logic is not too clear. So, improve the logic, making it easier to be handled. PS.: I'm pretty sure that I fixed it while testing, but, somehow, the change got lost. Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
215 lines
5.9 KiB
C
215 lines
5.9 KiB
C
/*
|
|
* 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_ */
|