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;
 
  160     case PAL:   h_max = 
PAL_HEIGHT;   c = BT848_IFORM_F_PALBDGHI; 
break;
 
  166     default:    h_max = 
PAL_HEIGHT;   c = BT848_IFORM_F_PALBDGHI; 
break;
 
  169     if (height <= h_max / 2)
 
  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",
 
  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" },
 
  359     .priv_class     = &bktr_class,
 
static const char * format[]
int av_parse_video_rate(AVRational *rate, const char *arg)
Parse str and store the detected values in *rate. 
#define LIBAVUTIL_VERSION_INT
enum AVCodecID codec_id
Specific type of the encoded data (the codec used). 
const char * av_default_item_name(void *ptr)
Return the context name. 
AVInputFormat ff_bktr_demuxer
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 bktr_getframe(uint64_t per_frame)
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file. 
int avpriv_open(const char *filename, int flags,...)
A wrapper for open() setting O_CLOEXEC. 
static av_cold int read_close(AVFormatContext *ctx)
char * framerate
Set by a private option. 
volatile sig_atomic_t nsignals
Main libavdevice API header. 
int av_new_packet(AVPacket *pkt, int size)
Allocate the payload of a packet and initialize its fields with default values. 
static const AVClass bktr_class
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered. 
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
char * url
input or output URL. 
enum AVMediaType codec_type
General type of the encoded data. 
static void catchsignal(int signal)
AVRational avg_frame_rate
Average framerate. 
common internal API header 
static int read_header(FFV1Context *f)
int64_t av_gettime(void)
Get the current time in microseconds. 
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
static int grab_read_packet(AVFormatContext *s1, AVPacket *pkt)
#define AV_LOG_INFO
Standard information. 
char * av_strdup(const char *s)
Duplicate a string. 
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)
Describe the class of an AVClass context structure. 
Rational number (pair of numerator and denominator). 
#define AV_OPT_FLAG_DECODING_PARAM
a generic parameter which can be set by the user for demuxing or decoding 
static int grab_read_header(AVFormatContext *s1)
offset must point to two consecutive integers 
static const AVOption options[]
#define flags(name, subs,...)
int av_strerror(int errnum, char *errbuf, size_t errbuf_size)
Put a description of the AVERROR code errnum in errbuf. 
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples) 
void * priv_data
Format private data. 
static const int bktr_dev[]
AVCodecParameters * codecpar
Codec parameters associated with this stream. 
static int grab_read_close(AVFormatContext *s1)
This structure stores compressed data. 
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...