annotate dvenc.c @ 6105:c0336d3528e9 libavformat

matroska: move LFG state from muxer context to local variable The LFG is only used in one place, so there is no need to keep it in the context.
author mru
date Tue, 08 Jun 2010 10:44:27 +0000
parents 9fef9c7acf03
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
1 /*
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
2 * General DV muxer/demuxer
933
diego
parents: 903
diff changeset
3 * Copyright (c) 2003 Roman Shaposhnik
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
4 *
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
5 * Many thanks to Dan Dennedy <dan@dennedy.org> for providing wealth
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
6 * of DV technical info.
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
7 *
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
8 * Raw DV format
4251
77e0c7511d41 cosmetics: Remove pointless period after copyright statement non-sentences.
diego
parents: 4206
diff changeset
9 * Copyright (c) 2002 Fabrice Bellard
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
10 *
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
11 * 50 Mbps (DVCPRO50) support
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
12 * Copyright (c) 2006 Daniel Maas <dmaas@maasdigital.com>
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
13 *
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1322
diff changeset
14 * This file is part of FFmpeg.
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1322
diff changeset
15 *
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1322
diff changeset
16 * FFmpeg is free software; you can redistribute it and/or
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
17 * modify it under the terms of the GNU Lesser General Public
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
18 * License as published by the Free Software Foundation; either
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1322
diff changeset
19 * version 2.1 of the License, or (at your option) any later version.
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
20 *
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1322
diff changeset
21 * FFmpeg is distributed in the hope that it will be useful,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
24 * Lesser General Public License for more details.
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
25 *
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
26 * You should have received a copy of the GNU Lesser General Public
1358
0899bfe4105c Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 1322
diff changeset
27 * License along with FFmpeg; if not, write to the Free Software
896
edbe5c3717f9 Update licensing information: The FSF changed postal address.
diego
parents: 887
diff changeset
28 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
29 */
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
30 #include <time.h>
1656
184229324f14 * Fixing a bug with incorrect bits set in AAUX source pack
romansh
parents: 1466
diff changeset
31 #include <stdarg.h>
5968
9fef9c7acf03 Add missing internal.h #include for brktimegm(), fixes the warning:
diego
parents: 5910
diff changeset
32
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
33 #include "avformat.h"
5968
9fef9c7acf03 Add missing internal.h #include for brktimegm(), fixes the warning:
diego
parents: 5910
diff changeset
34 #include "internal.h"
3286
6f61c3b36632 Use full path for #includes from another directory.
diego
parents: 2771
diff changeset
35 #include "libavcodec/dvdata.h"
296
252946de6d3f * DV demuxer is now capable of decoding auxilary audio stream. So,
romansh
parents: 288
diff changeset
36 #include "dv.h"
3286
6f61c3b36632 Use full path for #includes from another directory.
diego
parents: 2771
diff changeset
37 #include "libavutil/fifo.h"
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
38
296
252946de6d3f * DV demuxer is now capable of decoding auxilary audio stream. So,
romansh
parents: 288
diff changeset
39 struct DVMuxContext {
4007
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
40 const DVprofile* sys; /* current DV profile, e.g.: 525/60, 625/50 */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
41 int n_ast; /* number of stereo audio streams (up to 2) */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
42 AVStream *ast[2]; /* stereo audio streams */
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
43 AVFifoBuffer *audio_data[2]; /* FIFO for storing excessive amounts of PCM */
4007
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
44 int frames; /* current frame number */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
45 time_t start_time; /* recording start time */
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
46 int has_audio; /* frame under contruction has audio */
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
47 int has_video; /* frame under contruction has video */
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
48 uint8_t frame_buf[DV_MAX_FRAME_SIZE]; /* frame under contruction */
296
252946de6d3f * DV demuxer is now capable of decoding auxilary audio stream. So,
romansh
parents: 288
diff changeset
49 };
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
50
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
51 static const int dv_aaux_packs_dist[12][9] = {
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
52 { 0xff, 0xff, 0xff, 0x50, 0x51, 0x52, 0x53, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
53 { 0x50, 0x51, 0x52, 0x53, 0xff, 0xff, 0xff, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
54 { 0xff, 0xff, 0xff, 0x50, 0x51, 0x52, 0x53, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
55 { 0x50, 0x51, 0x52, 0x53, 0xff, 0xff, 0xff, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
56 { 0xff, 0xff, 0xff, 0x50, 0x51, 0x52, 0x53, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
57 { 0x50, 0x51, 0x52, 0x53, 0xff, 0xff, 0xff, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
58 { 0xff, 0xff, 0xff, 0x50, 0x51, 0x52, 0x53, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
59 { 0x50, 0x51, 0x52, 0x53, 0xff, 0xff, 0xff, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
60 { 0xff, 0xff, 0xff, 0x50, 0x51, 0x52, 0x53, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
61 { 0x50, 0x51, 0x52, 0x53, 0xff, 0xff, 0xff, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
62 { 0xff, 0xff, 0xff, 0x50, 0x51, 0x52, 0x53, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
63 { 0x50, 0x51, 0x52, 0x53, 0xff, 0xff, 0xff, 0xff, 0xff },
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
64 };
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
65
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
66 static int dv_audio_frame_size(const DVprofile* sys, int frame)
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
67 {
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
68 return sys->audio_samples_dist[frame % (sizeof(sys->audio_samples_dist) /
887
d70e50f1495f COSMETICS: tabs --> spaces, some prettyprinting
diego
parents: 885
diff changeset
69 sizeof(sys->audio_samples_dist[0]))];
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
70 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
71
1656
184229324f14 * Fixing a bug with incorrect bits set in AAUX source pack
romansh
parents: 1466
diff changeset
72 static int dv_write_pack(enum dv_pack_type pack_id, DVMuxContext *c, uint8_t* buf, ...)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
73 {
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
74 struct tm tc;
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
75 time_t ct;
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
76 int ltc_frame;
1656
184229324f14 * Fixing a bug with incorrect bits set in AAUX source pack
romansh
parents: 1466
diff changeset
77 va_list ap;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
78
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
79 buf[0] = (uint8_t)pack_id;
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
80 switch (pack_id) {
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
81 case dv_timecode:
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
82 ct = (time_t)av_rescale_rnd(c->frames, c->sys->time_base.num,
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
83 c->sys->time_base.den, AV_ROUND_DOWN);
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
84 brktimegm(ct, &tc);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
85 /*
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
86 * LTC drop-frame frame counter drops two frames (0 and 1) every
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
87 * minute, unless it is exactly divisible by 10
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
88 */
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
89 ltc_frame = (c->frames + 2 * ct / 60 - 2 * ct / 600) % c->sys->ltc_divisor;
4007
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
90 buf[1] = (0 << 7) | /* color frame: 0 - unsync; 1 - sync mode */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
91 (1 << 6) | /* drop frame timecode: 0 - nondrop; 1 - drop */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
92 ((ltc_frame / 10) << 4) | /* tens of frames */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
93 (ltc_frame % 10); /* units of frames */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
94 buf[2] = (1 << 7) | /* biphase mark polarity correction: 0 - even; 1 - odd */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
95 ((tc.tm_sec / 10) << 4) | /* tens of seconds */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
96 (tc.tm_sec % 10); /* units of seconds */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
97 buf[3] = (1 << 7) | /* binary group flag BGF0 */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
98 ((tc.tm_min / 10) << 4) | /* tens of minutes */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
99 (tc.tm_min % 10); /* units of minutes */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
100 buf[4] = (1 << 7) | /* binary group flag BGF2 */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
101 (1 << 6) | /* binary group flag BGF1 */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
102 ((tc.tm_hour / 10) << 4) | /* tens of hours */
d5eb96f97305 spelling cosmetics
diego
parents: 3992
diff changeset
103 (tc.tm_hour % 10); /* units of hours */
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
104 break;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
105 case dv_audio_source: /* AAUX source pack */
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
106 va_start(ap, buf);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
107 buf[1] = (1 << 7) | /* locked mode -- SMPTE only supports locked mode */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
108 (1 << 6) | /* reserved -- always 1 */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
109 (dv_audio_frame_size(c->sys, c->frames) -
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
110 c->sys->audio_min_samples[0]);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
111 /* # of samples */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
112 buf[2] = (0 << 7) | /* multi-stereo */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
113 (0 << 5) | /* #of audio channels per block: 0 -- 1 channel */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
114 (0 << 4) | /* pair bit: 0 -- one pair of channels */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
115 !!va_arg(ap, int); /* audio mode */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
116 buf[3] = (1 << 7) | /* res */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
117 (1 << 6) | /* multi-language flag */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
118 (c->sys->dsf << 5) | /* system: 60fields/50fields */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
119 (c->sys->n_difchan & 2); /* definition: 0 -- 25Mbps, 2 -- 50Mbps */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
120 buf[4] = (1 << 7) | /* emphasis: 1 -- off */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
121 (0 << 6) | /* emphasis time constant: 0 -- reserved */
3968
bf1b4748cd2e spelling cosmetics
diego
parents: 3871
diff changeset
122 (0 << 3) | /* frequency: 0 -- 48kHz, 1 -- 44,1kHz, 2 -- 32kHz */
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
123 0; /* quantization: 0 -- 16bit linear, 1 -- 12bit nonlinear */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
124 va_end(ap);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
125 break;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
126 case dv_audio_control:
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
127 buf[1] = (0 << 6) | /* copy protection: 0 -- unrestricted */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
128 (1 << 4) | /* input source: 1 -- digital input */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
129 (3 << 2) | /* compression: 3 -- no information */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
130 0; /* misc. info/SMPTE emphasis off */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
131 buf[2] = (1 << 7) | /* recording start point: 1 -- no */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
132 (1 << 6) | /* recording end point: 1 -- no */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
133 (1 << 3) | /* recording mode: 1 -- original */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
134 7;
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
135 buf[3] = (1 << 7) | /* direction: 1 -- forward */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
136 (c->sys->pix_fmt == PIX_FMT_YUV420P ? 0x20 : /* speed */
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
137 c->sys->ltc_divisor * 4);
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
138 buf[4] = (1 << 7) | /* reserved -- always 1 */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
139 0x7f; /* genre category */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
140 break;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
141 case dv_audio_recdate:
848
928cc1de1256 typo: viedo --> video
diego
parents: 845
diff changeset
142 case dv_video_recdate: /* VAUX recording date */
3992
36f92f77c85e replacing frame_rate and frame_rate_base with an AVRational time_base
romansh
parents: 3968
diff changeset
143 ct = c->start_time + av_rescale_rnd(c->frames, c->sys->time_base.num,
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
144 c->sys->time_base.den, AV_ROUND_DOWN);
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
145 brktimegm(ct, &tc);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
146 buf[1] = 0xff; /* ds, tm, tens of time zone, units of time zone */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
147 /* 0xff is very likely to be "unknown" */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
148 buf[2] = (3 << 6) | /* reserved -- always 1 */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
149 ((tc.tm_mday / 10) << 4) | /* Tens of day */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
150 (tc.tm_mday % 10); /* Units of day */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
151 buf[3] = /* we set high 4 bits to 0, shouldn't we set them to week? */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
152 ((tc.tm_mon / 10) << 4) | /* Tens of month */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
153 (tc.tm_mon % 10); /* Units of month */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
154 buf[4] = (((tc.tm_year % 100) / 10) << 4) | /* Tens of year */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
155 (tc.tm_year % 10); /* Units of year */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
156 break;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
157 case dv_audio_rectime: /* AAUX recording time */
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
158 case dv_video_rectime: /* VAUX recording time */
3992
36f92f77c85e replacing frame_rate and frame_rate_base with an AVRational time_base
romansh
parents: 3968
diff changeset
159 ct = c->start_time + av_rescale_rnd(c->frames, c->sys->time_base.num,
36f92f77c85e replacing frame_rate and frame_rate_base with an AVRational time_base
romansh
parents: 3968
diff changeset
160 c->sys->time_base.den, AV_ROUND_DOWN);
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
161 brktimegm(ct, &tc);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
162 buf[1] = (3 << 6) | /* reserved -- always 1 */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
163 0x3f; /* tens of frame, units of frame: 0x3f - "unknown" ? */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
164 buf[2] = (1 << 7) | /* reserved -- always 1 */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
165 ((tc.tm_sec / 10) << 4) | /* Tens of seconds */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
166 (tc.tm_sec % 10); /* Units of seconds */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
167 buf[3] = (1 << 7) | /* reserved -- always 1 */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
168 ((tc.tm_min / 10) << 4) | /* Tens of minutes */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
169 (tc.tm_min % 10); /* Units of minutes */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
170 buf[4] = (3 << 6) | /* reserved -- always 1 */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
171 ((tc.tm_hour / 10) << 4) | /* Tens of hours */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
172 (tc.tm_hour % 10); /* Units of hours */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
173 break;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
174 default:
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
175 buf[1] = buf[2] = buf[3] = buf[4] = 0xff;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
176 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
177 return 5;
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
178 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
179
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
180 static void dv_inject_audio(DVMuxContext *c, int channel, uint8_t* frame_ptr)
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
181 {
504
cb0b5994f3e0 * fixing a small quirk with DV audio muxing
romansh
parents: 482
diff changeset
182 int i, j, d, of, size;
cb0b5994f3e0 * fixing a small quirk with DV audio muxing
romansh
parents: 482
diff changeset
183 size = 4 * dv_audio_frame_size(c->sys, c->frames);
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
184 frame_ptr += channel * c->sys->difseg_size * 150 * 80;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
185 for (i = 0; i < c->sys->difseg_size; i++) {
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
186 frame_ptr += 6 * 80; /* skip DIF segment header */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
187 for (j = 0; j < 9; j++) {
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
188 dv_write_pack(dv_aaux_packs_dist[i][j], c, &frame_ptr[3], i >= c->sys->difseg_size/2);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
189 for (d = 8; d < 80; d+=2) {
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
190 of = c->sys->audio_shuffle[i][j] + (d - 8)/2 * c->sys->audio_stride;
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
191 if (of*2 >= size)
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
192 continue;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
193
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
194 frame_ptr[d] = av_fifo_peek(c->audio_data[channel], of*2+1); // FIXME: maybe we have to admit
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
195 frame_ptr[d+1] = av_fifo_peek(c->audio_data[channel], of*2); // that DV is a big-endian PCM
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
196 }
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
197 frame_ptr += 16 * 80; /* 15 Video DIFs + 1 Audio DIF */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
198 }
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
199 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
200 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
201
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
202 static void dv_inject_metadata(DVMuxContext *c, uint8_t* frame)
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
203 {
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
204 int j, k;
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
205 uint8_t* buf;
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
206
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
207 for (buf = frame; buf < frame + c->sys->frame_size; buf += 150 * 80) {
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
208 /* DV subcode: 2nd and 3d DIFs */
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
209 for (j = 80; j < 80 * 3; j += 80) {
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
210 for (k = 6; k < 6 * 8; k += 8)
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
211 dv_write_pack(dv_timecode, c, &buf[j+k]);
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
212
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
213 if (((long)(buf-frame)/(c->sys->frame_size/(c->sys->difseg_size*c->sys->n_difchan))%c->sys->difseg_size) > 5) { /* FIXME: is this really needed ? */
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
214 dv_write_pack(dv_video_recdate, c, &buf[j+14]);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
215 dv_write_pack(dv_video_rectime, c, &buf[j+22]);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
216 dv_write_pack(dv_video_recdate, c, &buf[j+38]);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
217 dv_write_pack(dv_video_rectime, c, &buf[j+46]);
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
218 }
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
219 }
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
220
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
221 /* DV VAUX: 4th, 5th and 6th 3DIFs */
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
222 for (j = 80*3 + 3; j < 80*6; j += 80) {
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
223 dv_write_pack(dv_video_recdate, c, &buf[j+5*2]);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
224 dv_write_pack(dv_video_rectime, c, &buf[j+5*3]);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
225 dv_write_pack(dv_video_recdate, c, &buf[j+5*11]);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
226 dv_write_pack(dv_video_rectime, c, &buf[j+5*12]);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
227 }
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
228 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
229 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
230
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
231 /*
1317
132206560fe6 Split the DV demuxer and muxer into separate files (as suggested by Diego
takis
parents: 1289
diff changeset
232 * The following 3 functions constitute our interface to the world
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
233 */
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
234
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
235 int dv_assemble_frame(DVMuxContext *c, AVStream* st,
4162
d9dede8fe890 Remove inappropriate const qualifier from function argument, fixes the warning:
diego
parents: 4008
diff changeset
236 uint8_t* data, int data_size, uint8_t** frame)
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
237 {
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
238 int i, reqasize;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
239
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
240 *frame = &c->frame_buf[0];
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
241 reqasize = 4 * dv_audio_frame_size(c->sys, c->frames);
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
242
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
243 switch (st->codec->codec_type) {
5910
536e5527c1e0 Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents: 5288
diff changeset
244 case AVMEDIA_TYPE_VIDEO:
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
245 /* FIXME: we have to have more sensible approach than this one */
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
246 if (c->has_video)
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
247 av_log(st->codec, AV_LOG_ERROR, "Can't process DV frame #%d. Insufficient audio data or severe sync problem.\n", c->frames);
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
248
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
249 memcpy(*frame, data, c->sys->frame_size);
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
250 c->has_video = 1;
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
251 break;
5910
536e5527c1e0 Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents: 5288
diff changeset
252 case AVMEDIA_TYPE_AUDIO:
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
253 for (i = 0; i < c->n_ast && st != c->ast[i]; i++);
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
254
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
255 /* FIXME: we have to have more sensible approach than this one */
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
256 if (av_fifo_size(c->audio_data[i]) + data_size >= 100*AVCODEC_MAX_AUDIO_FRAME_SIZE)
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
257 av_log(st->codec, AV_LOG_ERROR, "Can't process DV frame #%d. Insufficient video data or severe sync problem.\n", c->frames);
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
258 av_fifo_generic_write(c->audio_data[i], data, data_size, NULL);
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
259
3596
1b3a50077124 cosmetics: Fix two common typos: wont --> will not, lets --> let us.
diego
parents: 3424
diff changeset
260 /* Let us see if we've got enough audio for one DV frame. */
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
261 c->has_audio |= ((reqasize <= av_fifo_size(c->audio_data[i])) << i);
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
262
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
263 break;
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
264 default:
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
265 break;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
266 }
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
267
3596
1b3a50077124 cosmetics: Fix two common typos: wont --> will not, lets --> let us.
diego
parents: 3424
diff changeset
268 /* Let us see if we have enough data to construct one DV frame. */
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
269 if (c->has_video == 1 && c->has_audio + 1 == 1 << c->n_ast) {
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
270 dv_inject_metadata(c, *frame);
2086
0cd7cfbee2e8 Don't forget about audio remaining in buffer, in case there is enough
corey
parents: 2006
diff changeset
271 c->has_audio = 0;
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
272 for (i=0; i < c->n_ast; i++) {
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
273 dv_inject_audio(c, i, *frame);
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
274 av_fifo_drain(c->audio_data[i], reqasize);
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
275 c->has_audio |= ((reqasize <= av_fifo_size(c->audio_data[i])) << i);
887
d70e50f1495f COSMETICS: tabs --> spaces, some prettyprinting
diego
parents: 885
diff changeset
276 }
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
277
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
278 c->has_video = 0;
2086
0cd7cfbee2e8 Don't forget about audio remaining in buffer, in case there is enough
corey
parents: 2006
diff changeset
279
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
280 c->frames++;
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
281
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
282 return c->sys->frame_size;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
283 }
1289
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
284
6db39fb15d60 * Restructuring the division of labor between DV codec and DV format
romansh
parents: 1169
diff changeset
285 return 0;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
286 }
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
287
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
288 DVMuxContext* dv_init_mux(AVFormatContext* s)
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
289 {
2006
2f0154760e5f Get rid of unnecessary pointer casts.
diego
parents: 1656
diff changeset
290 DVMuxContext *c = s->priv_data;
531
2af447b91329 * let DV muxer generate audioless DV streams. This might not be 100%
romansh
parents: 528
diff changeset
291 AVStream *vst = NULL;
2af447b91329 * let DV muxer generate audioless DV streams. This might not be 100%
romansh
parents: 528
diff changeset
292 int i;
2af447b91329 * let DV muxer generate audioless DV streams. This might not be 100%
romansh
parents: 528
diff changeset
293
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
294 /* we support at most 1 video and 2 audio streams */
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
295 if (s->nb_streams > 3)
531
2af447b91329 * let DV muxer generate audioless DV streams. This might not be 100%
romansh
parents: 528
diff changeset
296 return NULL;
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
297
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
298 c->n_ast = 0;
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
299 c->ast[0] = c->ast[1] = NULL;
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
300
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
301 /* We have to sort out where audio and where video stream is */
531
2af447b91329 * let DV muxer generate audioless DV streams. This might not be 100%
romansh
parents: 528
diff changeset
302 for (i=0; i<s->nb_streams; i++) {
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
303 switch (s->streams[i]->codec->codec_type) {
5910
536e5527c1e0 Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents: 5288
diff changeset
304 case AVMEDIA_TYPE_VIDEO:
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
305 if (vst) return NULL;
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
306 vst = s->streams[i];
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
307 break;
5910
536e5527c1e0 Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents: 5288
diff changeset
308 case AVMEDIA_TYPE_AUDIO:
2192
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
309 if (c->n_ast > 1) return NULL;
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
310 c->ast[c->n_ast++] = s->streams[i];
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
311 break;
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
312 default:
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
313 goto bail_out;
c97fab0f9803 Cosmetics: use consistent indentation by four spaces
reimar
parents: 2191
diff changeset
314 }
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
315 }
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
316
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
317 /* Some checks -- DV format is very picky about its incoming streams */
820
feca73904e67 changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents: 764
diff changeset
318 if (!vst || vst->codec->codec_id != CODEC_ID_DVVIDEO)
531
2af447b91329 * let DV muxer generate audioless DV streams. This might not be 100%
romansh
parents: 528
diff changeset
319 goto bail_out;
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
320 for (i=0; i<c->n_ast; i++) {
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
321 if (c->ast[i] && (c->ast[i]->codec->codec_id != CODEC_ID_PCM_S16LE ||
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
322 c->ast[i]->codec->sample_rate != 48000 ||
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
323 c->ast[i]->codec->channels != 2))
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
324 goto bail_out;
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
325 }
5288
15f34b5059ed Split parts of dvdata.h into dvdata.c, this ensures that things like
reimar
parents: 4669
diff changeset
326 c->sys = ff_dv_codec_profile(vst->codec);
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
327 if (!c->sys)
887
d70e50f1495f COSMETICS: tabs --> spaces, some prettyprinting
diego
parents: 885
diff changeset
328 goto bail_out;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
329
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
330 if ((c->n_ast > 1) && (c->sys->n_difchan < 2)) {
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
331 /* only 1 stereo pair is allowed in 25Mbps mode */
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
332 goto bail_out;
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
333 }
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
334
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
335 /* Ok, everything seems to be in working order */
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
336 c->frames = 0;
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
337 c->has_audio = 0;
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
338 c->has_video = 0;
420
e440fb884442 * making it possible to specify recording date and time in a stream
romansh
parents: 417
diff changeset
339 c->start_time = (time_t)s->timestamp;
37
8f76666c71c2 DV audio decoder by Roman Shaposhnick
bellard
parents: 28
diff changeset
340
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
341 for (i=0; i < c->n_ast; i++) {
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
342 if (c->ast[i] && !(c->audio_data[i]=av_fifo_alloc(100*AVCODEC_MAX_AUDIO_FRAME_SIZE))) {
4008
8af7a177b17d prettyprinting cosmetics
diego
parents: 4007
diff changeset
343 while (i > 0) {
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
344 i--;
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
345 av_fifo_free(c->audio_data[i]);
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
346 }
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
347 goto bail_out;
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
348 }
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
349 }
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
350
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
351 return c;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
352
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
353 bail_out:
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
354 return NULL;
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
355 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
356
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
357 void dv_delete_mux(DVMuxContext *c)
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
358 {
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
359 int i;
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
360 for (i=0; i < c->n_ast; i++)
4669
d6eb19c43e99 Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents: 4251
diff changeset
361 av_fifo_free(c->audio_data[i]);
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
362 }
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
363
4206
c3102b189cb6 Change semantic of CONFIG_*, HAVE_* and ARCH_*.
aurel
parents: 4162
diff changeset
364 #if CONFIG_DV_MUXER
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
365 static int dv_write_header(AVFormatContext *s)
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
366 {
1466
340d1fe645d3 * fixing a memory leak in DV format.
romansh
parents: 1394
diff changeset
367 if (!dv_init_mux(s)) {
370
845f9de2c883 av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 363
diff changeset
368 av_log(s, AV_LOG_ERROR, "Can't initialize DV format!\n"
887
d70e50f1495f COSMETICS: tabs --> spaces, some prettyprinting
diego
parents: 885
diff changeset
369 "Make sure that you supply exactly two streams:\n"
3968
bf1b4748cd2e spelling cosmetics
diego
parents: 3871
diff changeset
370 " video: 25fps or 29.97fps, audio: 2ch/48kHz/PCM\n"
995
c459e0d4b0b9 DVCPRO50 support.
romansh
parents: 933
diff changeset
371 " (50Mbps allows an optional second audio stream)\n");
887
d70e50f1495f COSMETICS: tabs --> spaces, some prettyprinting
diego
parents: 885
diff changeset
372 return -1;
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
373 }
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
374 return 0;
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
375 }
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
376
468
60f897e8dd2d pass AVPacket into av_write_frame()
michael
parents: 462
diff changeset
377 static int dv_write_packet(struct AVFormatContext *s, AVPacket *pkt)
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
378 {
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
379 uint8_t* frame;
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
380 int fsize;
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
381
2006
2f0154760e5f Get rid of unnecessary pointer casts.
diego
parents: 1656
diff changeset
382 fsize = dv_assemble_frame(s->priv_data, s->streams[pkt->stream_index],
468
60f897e8dd2d pass AVPacket into av_write_frame()
michael
parents: 462
diff changeset
383 pkt->data, pkt->size, &frame);
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
384 if (fsize > 0) {
2771
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2192
diff changeset
385 put_buffer(s->pb, frame, fsize);
d52c718e83f9 Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents: 2192
diff changeset
386 put_flush_packet(s->pb);
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
387 }
363
efd9dfe4f504 * turns out write_packet is supposed to return 0 on success, not
romansh
parents: 296
diff changeset
388 return 0;
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
389 }
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
390
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
391 /*
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
392 * We might end up with some extra A/V data without matching counterpart.
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
393 * E.g. video data without enough audio to write the complete frame.
885
da1d5db0ce5c COSMETICS: Remove all trailing whitespace.
diego
parents: 848
diff changeset
394 * Currently we simply drop the last frame. I don't know whether this
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
395 * is the best strategy of all
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
396 */
262
f174d9c00bce * DV handling was streamlined for both muxing/demuxing and
romansh
parents: 241
diff changeset
397 static int dv_write_trailer(struct AVFormatContext *s)
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
398 {
2006
2f0154760e5f Get rid of unnecessary pointer casts.
diego
parents: 1656
diff changeset
399 dv_delete_mux(s->priv_data);
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
400 return 0;
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
401 }
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
402
1169
d18cc9a1fd02 allow individual selection of muxers and demuxers
mru
parents: 1167
diff changeset
403 AVOutputFormat dv_muxer = {
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
404 "dv",
3424
7a0230981402 Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents: 3392
diff changeset
405 NULL_IF_CONFIG_SMALL("DV video format"),
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
406 NULL,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
407 "dv",
203
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
408 sizeof(DVMuxContext),
184d22d04c84 * Phase 1 for DV encoding support. Muxing/demuxing of DV streams is now
romansh
parents: 119
diff changeset
409 CODEC_ID_PCM_S16LE,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
410 CODEC_ID_DVVIDEO,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
411 dv_write_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
412 dv_write_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
413 dv_write_trailer,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
414 };
3871
e6aeb2733e34 Replace generic CONFIG_MUXERS preprocessor conditionals by more specific
diego
parents: 3596
diff changeset
415 #endif /* CONFIG_DV_MUXER */