2 * FFM (ffserver live feed) muxer
3 * Copyright (c) 2001 Fabrice Bellard
5 * This file is part of FFmpeg.
7 * FFmpeg is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * FFmpeg is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with FFmpeg; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 #include "libavutil/intreadwrite.h"
26 static void flush_packet(AVFormatContext
*s
)
28 FFMContext
*ffm
= s
->priv_data
;
30 ByteIOContext
*pb
= s
->pb
;
32 fill_size
= ffm
->packet_end
- ffm
->packet_ptr
;
33 memset(ffm
->packet_ptr
, 0, fill_size
);
35 if (url_ftell(pb
) % ffm
->packet_size
)
39 put_be16(pb
, PACKET_ID
);
40 put_be16(pb
, fill_size
);
41 put_be64(pb
, ffm
->dts
);
42 h
= ffm
->frame_offset
;
43 if (ffm
->first_packet
)
46 put_buffer(pb
, ffm
->packet
, ffm
->packet_end
- ffm
->packet
);
49 /* prepare next packet */
50 ffm
->frame_offset
= 0; /* no key frame */
51 ffm
->packet_ptr
= ffm
->packet
;
52 ffm
->first_packet
= 0;
55 /* 'first' is true if first data of a frame */
56 static void ffm_write_data(AVFormatContext
*s
,
57 const uint8_t *buf
, int size
,
58 int64_t dts
, int header
)
60 FFMContext
*ffm
= s
->priv_data
;
63 if (header
&& ffm
->frame_offset
== 0) {
64 ffm
->frame_offset
= ffm
->packet_ptr
- ffm
->packet
+ FFM_HEADER_SIZE
;
68 /* write as many packets as needed */
70 len
= ffm
->packet_end
- ffm
->packet_ptr
;
73 memcpy(ffm
->packet_ptr
, buf
, len
);
75 ffm
->packet_ptr
+= len
;
78 if (ffm
->packet_ptr
>= ffm
->packet_end
)
83 static int ffm_write_header(AVFormatContext
*s
)
85 FFMContext
*ffm
= s
->priv_data
;
87 ByteIOContext
*pb
= s
->pb
;
88 AVCodecContext
*codec
;
91 ffm
->packet_size
= FFM_PACKET_SIZE
;
94 put_le32(pb
, MKTAG('F', 'F', 'M', '1'));
95 put_be32(pb
, ffm
->packet_size
);
96 put_be64(pb
, 0); /* current write position */
98 put_be32(pb
, s
->nb_streams
);
100 for(i
=0;i
<s
->nb_streams
;i
++) {
102 bit_rate
+= st
->codec
->bit_rate
;
104 put_be32(pb
, bit_rate
);
106 /* list of streams */
107 for(i
=0;i
<s
->nb_streams
;i
++) {
109 av_set_pts_info(st
, 64, 1, 1000000);
113 put_be32(pb
, codec
->codec_id
);
114 put_byte(pb
, codec
->codec_type
);
115 put_be32(pb
, codec
->bit_rate
);
116 put_be32(pb
, st
->quality
);
117 put_be32(pb
, codec
->flags
);
118 put_be32(pb
, codec
->flags2
);
119 put_be32(pb
, codec
->debug
);
121 switch(codec
->codec_type
) {
122 case CODEC_TYPE_VIDEO
:
123 put_be32(pb
, codec
->time_base
.num
);
124 put_be32(pb
, codec
->time_base
.den
);
125 put_be16(pb
, codec
->width
);
126 put_be16(pb
, codec
->height
);
127 put_be16(pb
, codec
->gop_size
);
128 put_be32(pb
, codec
->pix_fmt
);
129 put_byte(pb
, codec
->qmin
);
130 put_byte(pb
, codec
->qmax
);
131 put_byte(pb
, codec
->max_qdiff
);
132 put_be16(pb
, (int) (codec
->qcompress
* 10000.0));
133 put_be16(pb
, (int) (codec
->qblur
* 10000.0));
134 put_be32(pb
, codec
->bit_rate_tolerance
);
135 put_strz(pb
, codec
->rc_eq
? codec
->rc_eq
: "tex^qComp");
136 put_be32(pb
, codec
->rc_max_rate
);
137 put_be32(pb
, codec
->rc_min_rate
);
138 put_be32(pb
, codec
->rc_buffer_size
);
139 put_be64(pb
, av_dbl2int(codec
->i_quant_factor
));
140 put_be64(pb
, av_dbl2int(codec
->b_quant_factor
));
141 put_be64(pb
, av_dbl2int(codec
->i_quant_offset
));
142 put_be64(pb
, av_dbl2int(codec
->b_quant_offset
));
143 put_be32(pb
, codec
->dct_algo
);
144 put_be32(pb
, codec
->strict_std_compliance
);
145 put_be32(pb
, codec
->max_b_frames
);
146 put_be32(pb
, codec
->luma_elim_threshold
);
147 put_be32(pb
, codec
->chroma_elim_threshold
);
148 put_be32(pb
, codec
->mpeg_quant
);
149 put_be32(pb
, codec
->intra_dc_precision
);
150 put_be32(pb
, codec
->me_method
);
151 put_be32(pb
, codec
->mb_decision
);
152 put_be32(pb
, codec
->nsse_weight
);
153 put_be32(pb
, codec
->frame_skip_cmp
);
154 put_be64(pb
, av_dbl2int(codec
->rc_buffer_aggressivity
));
155 put_be32(pb
, codec
->codec_tag
);
156 put_byte(pb
, codec
->thread_count
);
158 case CODEC_TYPE_AUDIO
:
159 put_be32(pb
, codec
->sample_rate
);
160 put_le16(pb
, codec
->channels
);
161 put_le16(pb
, codec
->frame_size
);
166 if (codec
->flags
& CODEC_FLAG_GLOBAL_HEADER
) {
167 put_be32(pb
, codec
->extradata_size
);
168 put_buffer(pb
, codec
->extradata
, codec
->extradata_size
);
172 /* flush until end of block reached */
173 while ((url_ftell(pb
) % ffm
->packet_size
) != 0)
176 put_flush_packet(pb
);
178 /* init packet mux */
179 ffm
->packet_ptr
= ffm
->packet
;
180 ffm
->packet_end
= ffm
->packet
+ ffm
->packet_size
- FFM_HEADER_SIZE
;
181 assert(ffm
->packet_end
>= ffm
->packet
);
182 ffm
->frame_offset
= 0;
184 ffm
->first_packet
= 1;
189 static int ffm_write_packet(AVFormatContext
*s
, AVPacket
*pkt
)
192 uint8_t header
[FRAME_HEADER_SIZE
+4];
193 int header_size
= FRAME_HEADER_SIZE
;
195 dts
= s
->timestamp
+ pkt
->dts
;
196 /* packet size & key_frame */
197 header
[0] = pkt
->stream_index
;
199 if (pkt
->flags
& PKT_FLAG_KEY
)
200 header
[1] |= FLAG_KEY_FRAME
;
201 AV_WB24(header
+2, pkt
->size
);
202 AV_WB24(header
+5, pkt
->duration
);
203 AV_WB64(header
+8, s
->timestamp
+ pkt
->pts
);
204 if (pkt
->pts
!= pkt
->dts
) {
205 header
[1] |= FLAG_DTS
;
206 AV_WB32(header
+16, pkt
->pts
- pkt
->dts
);
209 ffm_write_data(s
, header
, header_size
, dts
, 1);
210 ffm_write_data(s
, pkt
->data
, pkt
->size
, dts
, 0);
215 static int ffm_write_trailer(AVFormatContext
*s
)
217 ByteIOContext
*pb
= s
->pb
;
218 FFMContext
*ffm
= s
->priv_data
;
221 if (ffm
->packet_ptr
> ffm
->packet
)
224 put_flush_packet(pb
);
229 AVOutputFormat ffm_muxer
= {
231 NULL_IF_CONFIG_SMALL("FFM (FFserver live feed) format"),
235 /* not really used */