annotate libmpdemux/muxer.c @ 34799:b1b974133fa1

Avoid repeating mixer error messages from ao. This avoids continuous printing of e.g. "[AO_ALSA] Unable to find simple control 'PCM',0." even after MPlayer switched to software volume control.
author reimar
date Sun, 06 May 2012 09:08:12 +0000
parents 277ec491a8a7
children 1e56eab1f210
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
29238
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
1 /*
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
2 * This file is part of MPlayer.
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
3 *
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
4 * MPlayer is free software; you can redistribute it and/or modify
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
5 * it under the terms of the GNU General Public License as published by
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
6 * the Free Software Foundation; either version 2 of the License, or
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
7 * (at your option) any later version.
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
8 *
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
9 * MPlayer is distributed in the hope that it will be useful,
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
12 * GNU General Public License for more details.
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
13 *
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
14 * You should have received a copy of the GNU General Public License along
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
15 * with MPlayer; if not, write to the Free Software Foundation, Inc.,
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
d643e4643313 Add standard license header to all files in libmpdemux.
diego
parents: 27341
diff changeset
17 */
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
18
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
19 #include <stdio.h>
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
20 #include <stdlib.h>
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
21 #include <string.h>
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
22 #include <inttypes.h>
8591
35bfd508bf5f FreeBSD fix
nexus
parents: 8585
diff changeset
23 #include <unistd.h>
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
24
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
25 #include "config.h"
12341
0db4a3a5b01d removed loader/ dependancy, imported some files from g2, also used patches from Dominik Mierzejewski
alex
parents: 12016
diff changeset
26 #include "aviheader.h"
0db4a3a5b01d removed loader/ dependancy, imported some files from g2, also used patches from Dominik Mierzejewski
alex
parents: 12016
diff changeset
27 #include "ms_hdr.h"
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
28
22605
4d81dbdf46b9 Add explicit location for headers from the stream/ directory.
diego
parents: 21660
diff changeset
29 #include "stream/stream.h"
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
30 #include "muxer.h"
14753
70c446099f40 new mpeg muxer compatible with dvd/[s]vcd; small changes in the muxer layer (sanity checks in the muxer_init functions)
nicodvb
parents: 12341
diff changeset
31 #include "demuxer.h"
70c446099f40 new mpeg muxer compatible with dvd/[s]vcd; small changes in the muxer layer (sanity checks in the muxer_init functions)
nicodvb
parents: 12341
diff changeset
32 #include "mp_msg.h"
70c446099f40 new mpeg muxer compatible with dvd/[s]vcd; small changes in the muxer layer (sanity checks in the muxer_init functions)
nicodvb
parents: 12341
diff changeset
33 #include "help_mp.h"
70c446099f40 new mpeg muxer compatible with dvd/[s]vcd; small changes in the muxer layer (sanity checks in the muxer_init functions)
nicodvb
parents: 12341
diff changeset
34 #include "stheader.h"
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
35
21660
ca9da45d13e9 muxers now write to output muxer->stream rather than to muxer->file
nicodvb
parents: 18558
diff changeset
36 muxer_t *muxer_new_muxer(int type,stream_t *stream){
17839
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
37 muxer_t* muxer=calloc(1,sizeof(muxer_t));
17831
f36966ddbf77 exit if calloc() fails; free(muxer) before returning NULL if muxer_init() fails (to avoid memleak). Fixes cid 173
nicodvb
parents: 17487
diff changeset
38 if(!muxer)
f36966ddbf77 exit if calloc() fails; free(muxer) before returning NULL if muxer_init() fails (to avoid memleak). Fixes cid 173
nicodvb
parents: 17487
diff changeset
39 return NULL;
21660
ca9da45d13e9 muxers now write to output muxer->stream rather than to muxer->file
nicodvb
parents: 18558
diff changeset
40 muxer->stream = stream;
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
41 switch (type) {
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
42 case MUXER_TYPE_MPEG:
14753
70c446099f40 new mpeg muxer compatible with dvd/[s]vcd; small changes in the muxer layer (sanity checks in the muxer_init functions)
nicodvb
parents: 12341
diff changeset
43 if(! muxer_init_muxer_mpeg(muxer))
17839
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
44 goto fail;
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
45 break;
12016
b962aaad2940 rawvideo muxer patch by John Earl <jwe21@cam.ac.uk>
ranma
parents: 9007
diff changeset
46 case MUXER_TYPE_RAWVIDEO:
14753
70c446099f40 new mpeg muxer compatible with dvd/[s]vcd; small changes in the muxer layer (sanity checks in the muxer_init functions)
nicodvb
parents: 12341
diff changeset
47 if(! muxer_init_muxer_rawvideo(muxer))
17839
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
48 goto fail;
12016
b962aaad2940 rawvideo muxer patch by John Earl <jwe21@cam.ac.uk>
ranma
parents: 9007
diff changeset
49 break;
15794
59e8dcea6d9e messed up ordering of cases, special delivery of Cola to Tobias
henry
parents: 15754
diff changeset
50 case MUXER_TYPE_RAWAUDIO:
59e8dcea6d9e messed up ordering of cases, special delivery of Cola to Tobias
henry
parents: 15754
diff changeset
51 if(! muxer_init_muxer_rawaudio(muxer))
17839
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
52 goto fail;
15794
59e8dcea6d9e messed up ordering of cases, special delivery of Cola to Tobias
henry
parents: 15754
diff changeset
53 break;
32142
4614728cab25 build system: Merge all FFmpeg library checks into a single FFmpeg check.
diego
parents: 30633
diff changeset
54 #ifdef CONFIG_FFMPEG
14757
7a2adc5e8928 initial, extremely experimental, libavformat muxer; don't expect anything to work yet
nicodvb
parents: 14753
diff changeset
55 case MUXER_TYPE_LAVF:
7a2adc5e8928 initial, extremely experimental, libavformat muxer; don't expect anything to work yet
nicodvb
parents: 14753
diff changeset
56 if(! muxer_init_muxer_lavf(muxer))
17839
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
57 goto fail;
14757
7a2adc5e8928 initial, extremely experimental, libavformat muxer; don't expect anything to work yet
nicodvb
parents: 14753
diff changeset
58 break;
7a2adc5e8928 initial, extremely experimental, libavformat muxer; don't expect anything to work yet
nicodvb
parents: 14753
diff changeset
59 #endif
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
60 case MUXER_TYPE_AVI:
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
61 default:
14753
70c446099f40 new mpeg muxer compatible with dvd/[s]vcd; small changes in the muxer layer (sanity checks in the muxer_init functions)
nicodvb
parents: 12341
diff changeset
62 if(! muxer_init_muxer_avi(muxer))
17839
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
63 goto fail;
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
64 }
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
65 return muxer;
17839
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
66
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
67 fail:
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
68 free(muxer);
e5dbddb8d3f6 unified failure case in muxer_new_muxer()
nicodvb
parents: 17831
diff changeset
69 return NULL;
8585
27da710563c2 the long-waited MUXER layer, and new MPEG-PS muxer
arpi
parents:
diff changeset
70 }
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
71
32795
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
72 /* Flush the internal muxer buffer.
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
73 * This is normally called from muxer_write_chunk() once all streams
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
74 * have seen frames. */
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
75 void muxer_flush(muxer_t *m) {
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
76 int num;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
77
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
78 if (!m->muxbuf)
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
79 return;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
80
33827
277ec491a8a7 Do not translate console messages of verbosity level MSGL_V and above.
diego
parents: 33645
diff changeset
81 mp_msg(MSGT_MUXER, MSGL_V, "Muxer frame buffer sending %d frame(s) to the muxer.\n", m->muxbuf_num);
32795
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
82
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
83 /* fix parameters for all streams */
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
84 for (num = 0; m->streams[num]; ++num) {
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
85 muxer_stream_t *str = m->streams[num];
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
86 if(str->muxer->fix_stream_parameters)
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
87 muxer_stream_fix_parameters(str->muxer, str);
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
88 }
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
89
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
90 /* write header */
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
91 if (m->cont_write_header)
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
92 muxer_write_header(m);
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
93
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
94 /* send all buffered frames to muxer */
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
95 for (num = 0; num < m->muxbuf_num; ++num) {
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
96 muxbuf_t tmp_buf;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
97 muxbuf_t *buf;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
98 muxer_stream_t *s;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
99 buf = m->muxbuf + num;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
100 s = buf->stream;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
101
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
102 /* 1. save timer and buffer (might have changed by now) */
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
103 tmp_buf.dts = s->timer;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
104 tmp_buf.buffer = s->buffer;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
105
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
106 /* 2. move stored timer and buffer into stream and mux it */
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
107 s->timer = buf->dts;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
108 s->buffer = buf->buffer;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
109 m->cont_write_chunk(s, buf->len, buf->flags, buf->dts, buf->pts);
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
110 free(buf->buffer);
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
111 buf->buffer = NULL;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
112
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
113 /* 3. restore saved timer and buffer */
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
114 s->timer = tmp_buf.dts;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
115 s->buffer = tmp_buf.buffer;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
116 }
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
117
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
118 free(m->muxbuf);
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
119 m->muxbuf = NULL;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
120 m->muxbuf_num = 0;
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
121 }
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
122
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
123 /* buffer frames until we either:
33645
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
124 * (a) have at least one non-empty frame from each stream
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
125 * (b) run out of memory */
17487
fa17424b4c7b change muxer_write_chunk() so that pts/dts _could_ be passed from encoder to muxer
michael
parents: 17354
diff changeset
126 void muxer_write_chunk(muxer_stream_t *s, size_t len, unsigned int flags, double dts, double pts) {
fa17424b4c7b change muxer_write_chunk() so that pts/dts _could_ be passed from encoder to muxer
michael
parents: 17354
diff changeset
127 if(dts == MP_NOPTS_VALUE) dts= s->timer;
fa17424b4c7b change muxer_write_chunk() so that pts/dts _could_ be passed from encoder to muxer
michael
parents: 17354
diff changeset
128 if(pts == MP_NOPTS_VALUE) pts= s->timer; // this is wrong
fa17424b4c7b change muxer_write_chunk() so that pts/dts _could_ be passed from encoder to muxer
michael
parents: 17354
diff changeset
129
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
130 if (s->muxer->muxbuf_skip_buffer) {
17487
fa17424b4c7b change muxer_write_chunk() so that pts/dts _could_ be passed from encoder to muxer
michael
parents: 17354
diff changeset
131 s->muxer->cont_write_chunk(s, len, flags, dts, pts);
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
132 }
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
133 else {
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
134 int num = s->muxer->muxbuf_num++;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
135 muxbuf_t *buf, *tmp;
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29238
diff changeset
136
18558
4928dd61f136 Fix potential integer overflows in memory allocation.
rtogni
parents: 18366
diff changeset
137 tmp = realloc_struct(s->muxer->muxbuf, (num+1), sizeof(muxbuf_t));
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
138 if(!tmp) {
17065
cf6bfdf41143 Clean up some muxer messages, patch by Corey Hickey bugfood-ml AT -fatooh/org- , small fixes by me
reynaldo
parents: 17023
diff changeset
139 mp_msg(MSGT_MUXER, MSGL_FATAL, MSGTR_MuxbufReallocErr);
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
140 return;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
141 }
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
142 s->muxer->muxbuf = tmp;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
143 buf = s->muxer->muxbuf + num;
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29238
diff changeset
144
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
145 /* buffer this frame */
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
146 buf->stream = s;
17487
fa17424b4c7b change muxer_write_chunk() so that pts/dts _could_ be passed from encoder to muxer
michael
parents: 17354
diff changeset
147 buf->dts= dts;
fa17424b4c7b change muxer_write_chunk() so that pts/dts _could_ be passed from encoder to muxer
michael
parents: 17354
diff changeset
148 buf->pts= pts;
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
149 buf->len = len;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
150 buf->flags = flags;
18366
d18fc000093d 100000l to the fools who don't know C
rfelker
parents: 17839
diff changeset
151 buf->buffer = malloc(len);
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
152 if (!buf->buffer) {
17065
cf6bfdf41143 Clean up some muxer messages, patch by Corey Hickey bugfood-ml AT -fatooh/org- , small fixes by me
reynaldo
parents: 17023
diff changeset
153 mp_msg(MSGT_MUXER, MSGL_FATAL, MSGTR_MuxbufMallocErr);
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
154 return;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
155 }
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
156 memcpy(buf->buffer, s->buffer, buf->len);
33645
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
157
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
158 /* If mencoder inserts "repeat last frame" chunks with len == 0
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
159 * before the encoder is configured and first real frame is output
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
160 * or a broken file starts a stream with such frames, then muxer
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
161 * won't find needed info for writing initial header.
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
162 * Wait until the first real frame is seen. */
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
163 if (len > 0)
4c3bee76ef3b The muxer prebuffers packets until each stream has been seen so a proper header
ranma
parents: 32795
diff changeset
164 s->muxbuf_seen = 1;
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
165
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
166 /* see if we need to keep buffering */
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
167 s->muxer->muxbuf_skip_buffer = 1;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
168 for (num = 0; s->muxer->streams[num]; ++num)
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
169 if (!s->muxer->streams[num]->muxbuf_seen)
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
170 s->muxer->muxbuf_skip_buffer = 0;
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29238
diff changeset
171
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
172 /* see if we can flush buffer now */
32795
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
173 if (s->muxer->muxbuf_skip_buffer)
801dc49c6f33 Fix muxer memory leak.
ranma
parents: 32670
diff changeset
174 muxer_flush(s->muxer);
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
175 }
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29238
diff changeset
176
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
177 /* this code moved directly from muxer_avi.c */
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
178 // alter counters:
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
179 if(s->h.dwSampleSize){
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
180 // CBR
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
181 s->h.dwLength+=len/s->h.dwSampleSize;
17065
cf6bfdf41143 Clean up some muxer messages, patch by Corey Hickey bugfood-ml AT -fatooh/org- , small fixes by me
reynaldo
parents: 17023
diff changeset
182 if(len%s->h.dwSampleSize) mp_msg(MSGT_MUXER, MSGL_WARN, MSGTR_WarningLenIsntDivisible);
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
183 } else {
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
184 // VBR
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
185 s->h.dwLength++;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
186 }
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
187 s->timer=(double)s->h.dwLength*s->h.dwScale/s->h.dwRate;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
188 s->size+=len;
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29238
diff changeset
189
17023
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
190 return;
dd5be8f8d16d buffering in the muxer layer; patch by Corey Hickey (bugfood-ml ad fatooh punctum org) plus small fixes by me
nicodvb
parents: 17012
diff changeset
191 }