Mercurial > libavformat.hg
annotate grab_bktr.c @ 1133:554cc16341da libavformat
10l: don't allocate a new buffer quite so often
author | mru |
---|---|
date | Sun, 25 Jun 2006 12:23:54 +0000 |
parents | 5dbdfa87d0d8 |
children | d89d7ef290da |
rev | line source |
---|---|
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
1 /* |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
2 * *BSD video grab interface |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
3 * Copyright (c) 2002 Steve O'Hara-Smith |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
4 * based on |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
5 * Linux video grab interface |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
6 * Copyright (c) 2000,2001 Gerard Lantau. |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
7 * and |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
8 * simple_grab.c Copyright (c) 1999 Roger Hardiman |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
9 * |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
10 * This library is free software; you can redistribute it and/or |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
11 * modify it under the terms of the GNU Lesser General Public |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
12 * License as published by the Free Software Foundation; either |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
13 * version 2 of the License, or (at your option) any later version. |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
14 * |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
15 * This library is distributed in the hope that it will be useful, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
18 * Lesser General Public License for more details. |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
19 * |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
20 * You should have received a copy of the GNU Lesser General Public |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
21 * License along with this library; if not, write to the Free Software |
896
edbe5c3717f9
Update licensing information: The FSF changed postal address.
diego
parents:
885
diff
changeset
|
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
23 */ |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
24 #include "avformat.h" |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
25 #if defined(__FreeBSD__) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
26 # if __FreeBSD__ >= 502100 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
27 # include <dev/bktr/ioctl_meteor.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
28 # include <dev/bktr/ioctl_bt848.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
29 # else |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
30 # include <machine/ioctl_meteor.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
31 # include <machine/ioctl_bt848.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
32 # endif |
1108 | 33 #elif defined(__FreeBSD_kernel__) |
34 # include <dev/bktr/ioctl_meteor.h> | |
35 # include <dev/bktr/ioctl_bt848.h> | |
836
8d9d16641fe0
'#elseif' needs to be '#elif' patch by ("Steven M. Schultz": sms, 2BSD COM)
michael
parents:
833
diff
changeset
|
36 #elif defined(__DragonFly__) |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
37 # include <dev/video/meteor/ioctl_meteor.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
38 # include <dev/video/bktr/ioctl_bt848.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
39 #else |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
40 # include <dev/ic/bt8xx.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
41 #endif |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
42 #include <unistd.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
43 #include <fcntl.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
44 #include <sys/ioctl.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
45 #include <sys/mman.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
46 #include <sys/time.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
47 #include <signal.h> |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
48 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
49 typedef struct { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
50 int video_fd; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
51 int tuner_fd; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
52 int width, height; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
53 int frame_rate; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
54 int frame_rate_base; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
55 u_int64_t per_frame; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
56 } VideoData; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
57 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
58 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
59 #define PAL 1 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
60 #define PALBDGHI 1 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
61 #define NTSC 2 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
62 #define NTSCM 2 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
63 #define SECAM 3 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
64 #define PALN 4 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
65 #define PALM 5 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
66 #define NTSCJ 6 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
67 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
68 /* PAL is 768 x 576. NTSC is 640 x 480 */ |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
69 #define PAL_HEIGHT 576 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
70 #define SECAM_HEIGHT 576 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
71 #define NTSC_HEIGHT 480 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
72 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
73 #ifndef VIDEO_FORMAT |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
74 #define VIDEO_FORMAT NTSC |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
75 #endif |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
76 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
77 static int bktr_dev[] = { METEOR_DEV0, METEOR_DEV1, METEOR_DEV2, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
78 METEOR_DEV3, METEOR_DEV_SVIDEO }; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
79 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
80 uint8_t *video_buf; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
81 size_t video_buf_size; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
82 u_int64_t last_frame_time; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
83 volatile sig_atomic_t nsignals; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
84 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
85 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
86 static void catchsignal(int signal) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
87 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
88 nsignals++; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
89 return; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
90 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
91 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
92 static int bktr_init(const char *video_device, int width, int height, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
93 int format, int *video_fd, int *tuner_fd, int idev, double frequency) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
94 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
95 struct meteor_geomet geo; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
96 int h_max; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
97 long ioctl_frequency; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
98 char *arg; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
99 int c; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
100 struct sigaction act, old; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
101 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
102 if (idev < 0 || idev > 4) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
103 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
104 arg = getenv ("BKTR_DEV"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
105 if (arg) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
106 idev = atoi (arg); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
107 if (idev < 0 || idev > 4) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
108 idev = 1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
109 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
110 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
111 if (format < 1 || format > 6) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
112 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
113 arg = getenv ("BKTR_FORMAT"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
114 if (arg) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
115 format = atoi (arg); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
116 if (format < 1 || format > 6) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
117 format = VIDEO_FORMAT; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
118 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
119 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
120 if (frequency <= 0) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
121 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
122 arg = getenv ("BKTR_FREQUENCY"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
123 if (arg) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
124 frequency = atof (arg); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
125 if (frequency <= 0) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
126 frequency = 0.0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
127 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
128 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
129 memset(&act, 0, sizeof(act)); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
130 sigemptyset(&act.sa_mask); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
131 act.sa_handler = catchsignal; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
132 sigaction(SIGUSR1, &act, &old); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
133 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
134 *tuner_fd = open("/dev/tuner0", O_RDONLY); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
135 if (*tuner_fd < 0) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
136 perror("Warning: Tuner not opened, continuing"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
137 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
138 *video_fd = open(video_device, O_RDONLY); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
139 if (*video_fd < 0) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
140 perror(video_device); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
141 return -1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
142 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
143 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
144 geo.rows = height; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
145 geo.columns = width; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
146 geo.frames = 1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
147 geo.oformat = METEOR_GEO_YUV_422 | METEOR_GEO_YUV_12; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
148 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
149 switch (format) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
150 case PAL: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALBDGHI; break; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
151 case PALN: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALN; break; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
152 case PALM: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALM; break; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
153 case SECAM: h_max = SECAM_HEIGHT; c = BT848_IFORM_F_SECAM; break; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
154 case NTSC: h_max = NTSC_HEIGHT; c = BT848_IFORM_F_NTSCM; break; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
155 case NTSCJ: h_max = NTSC_HEIGHT; c = BT848_IFORM_F_NTSCJ; break; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
156 default: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALBDGHI; break; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
157 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
158 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
159 if (height <= h_max / 2) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
160 geo.oformat |= METEOR_GEO_EVEN_ONLY; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
161 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
162 if (ioctl(*video_fd, METEORSETGEO, &geo) < 0) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
163 perror("METEORSETGEO"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
164 return -1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
165 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
166 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
167 if (ioctl(*video_fd, BT848SFMT, &c) < 0) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
168 perror("BT848SFMT"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
169 return -1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
170 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
171 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
172 c = bktr_dev[idev]; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
173 if (ioctl(*video_fd, METEORSINPUT, &c) < 0) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
174 perror("METEORSINPUT"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
175 return -1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
176 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
177 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
178 video_buf_size = width * height * 12 / 8; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
179 |
885 | 180 video_buf = (uint8_t *)mmap((caddr_t)0, video_buf_size, |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
181 PROT_READ, MAP_SHARED, *video_fd, (off_t)0); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
182 if (video_buf == MAP_FAILED) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
183 perror("mmap"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
184 return -1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
185 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
186 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
187 if (frequency != 0.0) { |
885 | 188 ioctl_frequency = (unsigned long)(frequency*16); |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
189 if (ioctl(*tuner_fd, TVTUNER_SETFREQ, &ioctl_frequency) < 0) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
190 perror("TVTUNER_SETFREQ"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
191 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
192 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
193 c = AUDIO_UNMUTE; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
194 if (ioctl(*tuner_fd, BT848_SAUDIO, &c) < 0) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
195 perror("TVTUNER_SAUDIO"); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
196 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
197 c = METEOR_CAP_CONTINOUS; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
198 ioctl(*video_fd, METEORCAPTUR, &c); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
199 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
200 c = SIGUSR1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
201 ioctl(*video_fd, METEORSSIGNAL, &c); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
202 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
203 return 0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
204 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
205 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
206 static void bktr_getframe(u_int64_t per_frame) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
207 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
208 u_int64_t curtime; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
209 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
210 curtime = av_gettime(); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
211 if (!last_frame_time |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
212 || ((last_frame_time + per_frame) > curtime)) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
213 if (!usleep(last_frame_time + per_frame + per_frame / 8 - curtime)) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
214 if (!nsignals) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
215 av_log(NULL, AV_LOG_INFO, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
216 "SLEPT NO signals - %d microseconds late\n", |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
217 (int)(av_gettime() - last_frame_time - per_frame)); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
218 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
219 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
220 nsignals = 0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
221 last_frame_time = curtime; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
222 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
223 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
224 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
225 /* note: we support only one picture read at a time */ |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
226 static int grab_read_packet(AVFormatContext *s1, AVPacket *pkt) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
227 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
228 VideoData *s = s1->priv_data; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
229 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
230 if (av_new_packet(pkt, video_buf_size) < 0) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
231 return -EIO; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
232 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
233 bktr_getframe(s->per_frame); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
234 |
921 | 235 pkt->pts = av_gettime(); |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
236 memcpy(pkt->data, video_buf, video_buf_size); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
237 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
238 return video_buf_size; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
239 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
240 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
241 static int grab_read_header(AVFormatContext *s1, AVFormatParameters *ap) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
242 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
243 VideoData *s = s1->priv_data; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
244 AVStream *st; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
245 int width, height; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
246 int frame_rate; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
247 int frame_rate_base; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
248 int format = -1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
249 const char *video_device; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
250 |
1003 | 251 if (ap->width <= 0 || ap->height <= 0 || ap->time_base.den <= 0) |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
252 return -1; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
253 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
254 width = ap->width; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
255 height = ap->height; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
256 frame_rate = ap->time_base.den; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
257 frame_rate_base = ap->time_base.num; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
258 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
259 video_device = ap->device; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
260 if (!video_device) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
261 video_device = "/dev/bktr0"; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
262 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
263 st = av_new_stream(s1, 0); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
264 if (!st) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
265 return -ENOMEM; |
921 | 266 av_set_pts_info(st, 64, 1, 1000000); /* 64 bits pts in use */ |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
267 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
268 s->width = width; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
269 s->height = height; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
270 s->frame_rate = frame_rate; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
271 s->frame_rate_base = frame_rate_base; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
272 s->per_frame = ((u_int64_t)1000000 * s->frame_rate_base) / s->frame_rate; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
273 |
833 | 274 st->codec->codec_type = CODEC_TYPE_VIDEO; |
275 st->codec->pix_fmt = PIX_FMT_YUV420P; | |
276 st->codec->codec_id = CODEC_ID_RAWVIDEO; | |
277 st->codec->width = width; | |
278 st->codec->height = height; | |
279 st->codec->time_base.den = frame_rate; | |
280 st->codec->time_base.num = frame_rate_base; | |
795
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
281 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
282 if (ap->standard) { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
283 if (!strcasecmp(ap->standard, "pal")) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
284 format = PAL; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
285 else if (!strcasecmp(ap->standard, "secam")) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
286 format = SECAM; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
287 else if (!strcasecmp(ap->standard, "ntsc")) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
288 format = NTSC; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
289 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
290 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
291 if (bktr_init(video_device, width, height, format, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
292 &(s->video_fd), &(s->tuner_fd), -1, 0.0) < 0) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
293 return -EIO; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
294 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
295 nsignals = 0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
296 last_frame_time = 0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
297 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
298 return 0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
299 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
300 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
301 static int grab_read_close(AVFormatContext *s1) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
302 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
303 VideoData *s = s1->priv_data; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
304 int c; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
305 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
306 c = METEOR_CAP_STOP_CONT; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
307 ioctl(s->video_fd, METEORCAPTUR, &c); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
308 close(s->video_fd); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
309 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
310 c = AUDIO_MUTE; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
311 ioctl(s->tuner_fd, BT848_SAUDIO, &c); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
312 close(s->tuner_fd); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
313 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
314 munmap((caddr_t)video_buf, video_buf_size); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
315 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
316 return 0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
317 } |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
318 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
319 AVInputFormat video_grab_device_format = { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
320 "bktr", |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
321 "video grab", |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
322 sizeof(VideoData), |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
323 NULL, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
324 grab_read_header, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
325 grab_read_packet, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
326 grab_read_close, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
327 .flags = AVFMT_NOFILE, |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
328 }; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
329 |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
330 int video_grab_init(void) |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
331 { |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
332 av_register_input_format(&video_grab_device_format); |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
333 return 0; |
391669d461d4
*BSD bktr grab support by (Jacob Meuser: jakemsr, jakemsr com)
michael
parents:
diff
changeset
|
334 } |