Go to the documentation of this file.
33 #if HAVE_DEV_BKTR_IOCTL_METEOR_H && HAVE_DEV_BKTR_IOCTL_BT848_H
34 # include <dev/bktr/ioctl_meteor.h>
35 # include <dev/bktr/ioctl_bt848.h>
36 #elif HAVE_MACHINE_IOCTL_METEOR_H && HAVE_MACHINE_IOCTL_BT848_H
37 # include <machine/ioctl_meteor.h>
38 # include <machine/ioctl_bt848.h>
39 #elif HAVE_DEV_VIDEO_METEOR_IOCTL_METEOR_H && HAVE_DEV_VIDEO_BKTR_IOCTL_BT848_H
40 # include <dev/video/meteor/ioctl_meteor.h>
41 # include <dev/video/bktr/ioctl_bt848.h>
42 #elif HAVE_DEV_IC_BT8XX_H
43 # include <dev/ic/bt8xx.h>
47 #include <sys/ioctl.h>
75 #define PAL_HEIGHT 576
76 #define SECAM_HEIGHT 576
77 #define NTSC_HEIGHT 480
80 #define VIDEO_FORMAT NTSC
83 static const int bktr_dev[] = { METEOR_DEV0, METEOR_DEV1, METEOR_DEV2,
84 METEOR_DEV3, METEOR_DEV_SVIDEO };
99 int format,
int *video_fd,
int *tuner_fd,
int idev,
double frequency)
101 struct meteor_geomet geo;
103 long ioctl_frequency;
106 struct sigaction act, old;
110 if (idev < 0 || idev > 4)
112 arg = getenv (
"BKTR_DEV");
115 if (idev < 0 || idev > 4)
119 if (format < 1 || format > 6)
121 arg = getenv (
"BKTR_FORMAT");
124 if (format < 1 || format > 6)
130 arg = getenv (
"BKTR_FREQUENCY");
132 frequency = atof (
arg);
137 memset(&act, 0,
sizeof(act));
138 sigemptyset(&act.sa_mask);
140 sigaction(SIGUSR1, &act, &old);
157 geo.oformat = METEOR_GEO_YUV_422 | METEOR_GEO_YUV_12;
166 default: h_max =
PAL_HEIGHT;
c = BT848_IFORM_F_PALBDGHI;
break;
170 geo.oformat |= METEOR_GEO_EVEN_ONLY;
172 if (ioctl(*video_fd, METEORSETGEO, &geo) < 0) {
179 if (ioctl(*video_fd, BT848SFMT, &
c) < 0) {
187 if (ioctl(*video_fd, METEORSINPUT, &
c) < 0) {
197 PROT_READ, MAP_SHARED, *video_fd, (off_t)0);
205 if (frequency != 0.0) {
206 ioctl_frequency = (
unsigned long)(frequency*16);
207 if (ioctl(*tuner_fd, TVTUNER_SETFREQ, &ioctl_frequency) < 0)
212 if (ioctl(*tuner_fd, BT848_SAUDIO, &
c) < 0)
215 c = METEOR_CAP_CONTINOUS;
216 ioctl(*video_fd, METEORCAPTUR, &
c);
219 ioctl(*video_fd, METEORSSIGNAL, &
c);
234 "SLEPT NO signals - %d microseconds late\n",
267 switch (
s->standard) {
298 &
s->video_fd, &
s->tuner_fd, -1, 0.0) < 0) {
315 c = METEOR_CAP_STOP_CONT;
316 ioctl(
s->video_fd, METEORCAPTUR, &
c);
320 ioctl(
s->tuner_fd, BT848_SAUDIO, &
c);
328 #define OFFSET(x) offsetof(VideoData, x)
329 #define DEC AV_OPT_FLAG_DECODING_PARAM
331 {
"standard",
"", offsetof(
VideoData, standard),
AV_OPT_TYPE_INT, {.i64 =
VIDEO_FORMAT},
PAL,
NTSCJ,
AV_OPT_FLAG_DECODING_PARAM,
"standard" },
static const AVClass bktr_class
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file.
enum AVMediaType codec_type
General type of the encoded data.
static const AVOption options[]
AVRational avg_frame_rate
Average framerate.
int av_strerror(int errnum, char *errbuf, size_t errbuf_size)
Put a description of the AVERROR code errnum in errbuf.
static av_cold int bktr_init(const char *video_device, int width, int height, int format, int *video_fd, int *tuner_fd, int idev, double frequency)
static av_cold int read_close(AVFormatContext *ctx)
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
int av_new_packet(AVPacket *pkt, int size)
Allocate the payload of a packet and initialize its fields with default values.
int avpriv_open(const char *filename, int flags,...)
A wrapper for open() setting O_CLOEXEC.
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample format(the sample packing is implied by the sample format) and sample rate. The lists are not just lists
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
static const int bktr_dev[]
static int grab_read_packet(AVFormatContext *s1, AVPacket *pkt)
AVCodecParameters * codecpar
Codec parameters associated with this stream.
#define LIBAVUTIL_VERSION_INT
static int read_header(FFV1Context *f)
Describe the class of an AVClass context structure.
Rational number (pair of numerator and denominator).
@ AV_OPT_TYPE_IMAGE_SIZE
offset must point to two consecutive integers
const char * av_default_item_name(void *ptr)
Return the context name.
@ AV_CLASS_CATEGORY_DEVICE_VIDEO_INPUT
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
static int grab_read_header(AVFormatContext *s1)
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
#define AV_LOG_INFO
Standard information.
int av_parse_video_rate(AVRational *rate, const char *arg)
Parse str and store the detected values in *rate.
char * framerate
Set by a private option.
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
#define AV_OPT_FLAG_DECODING_PARAM
a generic parameter which can be set by the user for demuxing or decoding
static void bktr_getframe(uint64_t per_frame)
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
static void catchsignal(int signal)
int64_t av_gettime(void)
Get the current time in microseconds.
char * av_strdup(const char *s)
Duplicate a string.
static int grab_read_close(AVFormatContext *s1)
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
This structure stores compressed data.
#define flags(name, subs,...)
volatile sig_atomic_t nsignals
AVInputFormat ff_bktr_demuxer