]> git.sesse.net Git - ffmpeg/blob - libavformat/raw.c
add support for some MS DIB formats for avisynth
[ffmpeg] / libavformat / raw.c
1 /*
2  * RAW encoder and decoder
3  * Copyright (c) 2001 Fabrice Bellard.
4  * Copyright (c) 2005 Alex Beregszaszi
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 #include "avformat.h"
21
22 #ifdef CONFIG_MUXERS
23 /* simple formats */
24 static int raw_write_header(struct AVFormatContext *s)
25 {
26     return 0;
27 }
28
29 static int flac_write_header(struct AVFormatContext *s)
30 {
31     static const uint8_t header[8] = {
32         0x66, 0x4C, 0x61, 0x43, 0x80, 0x00, 0x00, 0x22
33     };
34     uint8_t *streaminfo = s->streams[0]->codec->extradata;
35     int len = s->streams[0]->codec->extradata_size;
36     if(streaminfo != NULL && len > 0) {
37         put_buffer(&s->pb, header, 8);
38         put_buffer(&s->pb, streaminfo, len);
39     }
40     return 0;
41 }
42
43 static int raw_write_packet(struct AVFormatContext *s, AVPacket *pkt)
44 {
45     put_buffer(&s->pb, pkt->data, pkt->size);
46     put_flush_packet(&s->pb);
47     return 0;
48 }
49
50 static int raw_write_trailer(struct AVFormatContext *s)
51 {
52     return 0;
53 }
54 #endif //CONFIG_MUXERS
55
56 /* raw input */
57 static int raw_read_header(AVFormatContext *s, AVFormatParameters *ap)
58 {
59     AVStream *st;
60     int id;
61
62     st = av_new_stream(s, 0);
63     if (!st)
64         return AVERROR_NOMEM;
65
66         id = s->iformat->value;
67         if (id == CODEC_ID_RAWVIDEO) {
68             st->codec->codec_type = CODEC_TYPE_VIDEO;
69         } else {
70             st->codec->codec_type = CODEC_TYPE_AUDIO;
71         }
72         st->codec->codec_id = id;
73
74         switch(st->codec->codec_type) {
75         case CODEC_TYPE_AUDIO:
76             st->codec->sample_rate = ap->sample_rate;
77             st->codec->channels = ap->channels;
78             av_set_pts_info(st, 64, 1, st->codec->sample_rate);
79             break;
80         case CODEC_TYPE_VIDEO:
81             av_set_pts_info(st, 64, ap->time_base.num, ap->time_base.den);
82             st->codec->width = ap->width;
83             st->codec->height = ap->height;
84             st->codec->pix_fmt = ap->pix_fmt;
85             if(st->codec->pix_fmt == PIX_FMT_NONE)
86                 st->codec->pix_fmt= PIX_FMT_YUV420P;
87             break;
88         default:
89             return -1;
90         }
91     return 0;
92 }
93
94 #define RAW_PACKET_SIZE 1024
95
96 static int raw_read_packet(AVFormatContext *s, AVPacket *pkt)
97 {
98     int ret, size;
99     //    AVStream *st = s->streams[0];
100
101     size= RAW_PACKET_SIZE;
102
103     ret= av_get_packet(&s->pb, pkt, size);
104
105     pkt->stream_index = 0;
106     if (ret <= 0) {
107         return AVERROR_IO;
108     }
109     /* note: we need to modify the packet size here to handle the last
110        packet */
111     pkt->size = ret;
112     return ret;
113 }
114
115 static int raw_read_partial_packet(AVFormatContext *s, AVPacket *pkt)
116 {
117     int ret, size;
118
119     size = RAW_PACKET_SIZE;
120
121     if (av_new_packet(pkt, size) < 0)
122         return AVERROR_IO;
123
124     pkt->pos= url_ftell(&s->pb);
125     pkt->stream_index = 0;
126     ret = get_partial_buffer(&s->pb, pkt->data, size);
127     if (ret <= 0) {
128         av_free_packet(pkt);
129         return AVERROR_IO;
130     }
131     pkt->size = ret;
132     return ret;
133 }
134
135 // http://www.artificis.hu/files/texts/ingenient.txt
136 static int ingenient_read_packet(AVFormatContext *s, AVPacket *pkt)
137 {
138     int ret, size, w, h, unk1, unk2;
139
140     if (get_le32(&s->pb) != MKTAG('M', 'J', 'P', 'G'))
141         return AVERROR_IO; // FIXME
142
143     size = get_le32(&s->pb);
144
145     w = get_le16(&s->pb);
146     h = get_le16(&s->pb);
147
148     url_fskip(&s->pb, 8); // zero + size (padded?)
149     url_fskip(&s->pb, 2);
150     unk1 = get_le16(&s->pb);
151     unk2 = get_le16(&s->pb);
152     url_fskip(&s->pb, 22); // ascii timestamp
153
154     av_log(NULL, AV_LOG_DEBUG, "Ingenient packet: size=%d, width=%d, height=%d, unk1=%d unk2=%d\n",
155         size, w, h, unk1, unk2);
156
157     if (av_new_packet(pkt, size) < 0)
158         return AVERROR_IO;
159
160     pkt->pos = url_ftell(&s->pb);
161     pkt->stream_index = 0;
162     ret = get_buffer(&s->pb, pkt->data, size);
163     if (ret <= 0) {
164         av_free_packet(pkt);
165         return AVERROR_IO;
166     }
167     pkt->size = ret;
168     return ret;
169 }
170
171 static int raw_read_close(AVFormatContext *s)
172 {
173     return 0;
174 }
175
176 int pcm_read_seek(AVFormatContext *s,
177                   int stream_index, int64_t timestamp, int flags)
178 {
179     AVStream *st;
180     int block_align, byte_rate;
181     int64_t pos;
182
183     st = s->streams[0];
184     switch(st->codec->codec_id) {
185     case CODEC_ID_PCM_S16LE:
186     case CODEC_ID_PCM_S16BE:
187     case CODEC_ID_PCM_U16LE:
188     case CODEC_ID_PCM_U16BE:
189         block_align = 2 * st->codec->channels;
190         byte_rate = block_align * st->codec->sample_rate;
191         break;
192     case CODEC_ID_PCM_S8:
193     case CODEC_ID_PCM_U8:
194     case CODEC_ID_PCM_MULAW:
195     case CODEC_ID_PCM_ALAW:
196         block_align = st->codec->channels;
197         byte_rate = block_align * st->codec->sample_rate;
198         break;
199     default:
200         block_align = st->codec->block_align;
201         byte_rate = st->codec->bit_rate / 8;
202         break;
203     }
204
205     if (block_align <= 0 || byte_rate <= 0)
206         return -1;
207
208     /* compute the position by aligning it to block_align */
209     pos = av_rescale_rnd(timestamp * byte_rate,
210                          st->time_base.num,
211                          st->time_base.den * (int64_t)block_align,
212                          (flags & AVSEEK_FLAG_BACKWARD) ? AV_ROUND_DOWN : AV_ROUND_UP);
213     pos *= block_align;
214
215     /* recompute exact position */
216     st->cur_dts = av_rescale(pos, st->time_base.den, byte_rate * (int64_t)st->time_base.num);
217     url_fseek(&s->pb, pos + s->data_offset, SEEK_SET);
218     return 0;
219 }
220
221 /* ac3 read */
222 static int ac3_read_header(AVFormatContext *s,
223                            AVFormatParameters *ap)
224 {
225     AVStream *st;
226
227     st = av_new_stream(s, 0);
228     if (!st)
229         return AVERROR_NOMEM;
230
231     st->codec->codec_type = CODEC_TYPE_AUDIO;
232     st->codec->codec_id = CODEC_ID_AC3;
233     st->need_parsing = 1;
234     /* the parameters will be extracted from the compressed bitstream */
235     return 0;
236 }
237
238 static int shorten_read_header(AVFormatContext *s,
239                                AVFormatParameters *ap)
240 {
241     AVStream *st;
242
243     st = av_new_stream(s, 0);
244     if (!st)
245         return AVERROR_NOMEM;
246     st->codec->codec_type = CODEC_TYPE_AUDIO;
247     st->codec->codec_id = CODEC_ID_SHORTEN;
248     st->need_parsing = 1;
249     /* the parameters will be extracted from the compressed bitstream */
250     return 0;
251 }
252
253 /* flac read */
254 static int flac_read_header(AVFormatContext *s,
255                             AVFormatParameters *ap)
256 {
257     AVStream *st;
258
259     st = av_new_stream(s, 0);
260     if (!st)
261         return AVERROR_NOMEM;
262     st->codec->codec_type = CODEC_TYPE_AUDIO;
263     st->codec->codec_id = CODEC_ID_FLAC;
264     st->need_parsing = 1;
265     /* the parameters will be extracted from the compressed bitstream */
266     return 0;
267 }
268
269 /* dts read */
270 static int dts_read_header(AVFormatContext *s,
271                            AVFormatParameters *ap)
272 {
273     AVStream *st;
274
275     st = av_new_stream(s, 0);
276     if (!st)
277         return AVERROR_NOMEM;
278
279     st->codec->codec_type = CODEC_TYPE_AUDIO;
280     st->codec->codec_id = CODEC_ID_DTS;
281     st->need_parsing = 1;
282     /* the parameters will be extracted from the compressed bitstream */
283     return 0;
284 }
285
286 /* aac read */
287 static int aac_read_header(AVFormatContext *s,
288                            AVFormatParameters *ap)
289 {
290     AVStream *st;
291
292     st = av_new_stream(s, 0);
293     if (!st)
294         return AVERROR_NOMEM;
295
296     st->codec->codec_type = CODEC_TYPE_AUDIO;
297     st->codec->codec_id = CODEC_ID_AAC;
298     st->need_parsing = 1;
299     /* the parameters will be extracted from the compressed bitstream */
300     return 0;
301 }
302
303 /* mpeg1/h263 input */
304 static int video_read_header(AVFormatContext *s,
305                              AVFormatParameters *ap)
306 {
307     AVStream *st;
308
309     st = av_new_stream(s, 0);
310     if (!st)
311         return AVERROR_NOMEM;
312
313     st->codec->codec_type = CODEC_TYPE_VIDEO;
314     st->codec->codec_id = s->iformat->value;
315     st->need_parsing = 1;
316
317     /* for mjpeg, specify frame rate */
318     /* for mpeg4 specify it too (most mpeg4 streams dont have the fixed_vop_rate set ...)*/
319     if (ap->time_base.num) {
320         av_set_pts_info(st, 64, ap->time_base.num, ap->time_base.den);
321     } else if ( st->codec->codec_id == CODEC_ID_MJPEG ||
322                 st->codec->codec_id == CODEC_ID_MPEG4 ||
323                 st->codec->codec_id == CODEC_ID_H264) {
324         av_set_pts_info(st, 64, 1, 25);
325     }
326
327     return 0;
328 }
329
330 #define SEQ_START_CODE          0x000001b3
331 #define GOP_START_CODE          0x000001b8
332 #define PICTURE_START_CODE      0x00000100
333 #define SLICE_START_CODE        0x00000101
334 #define PACK_START_CODE         0x000001ba
335 #define VIDEO_ID                0x000001e0
336 #define AUDIO_ID                0x000001c0
337
338 static int mpegvideo_probe(AVProbeData *p)
339 {
340     uint32_t code= -1;
341     int pic=0, seq=0, slice=0, pspack=0, pes=0;
342     int i;
343
344     for(i=0; i<p->buf_size; i++){
345         code = (code<<8) + p->buf[i];
346         if ((code & 0xffffff00) == 0x100) {
347             switch(code){
348             case     SEQ_START_CODE:   seq++; break;
349             case PICTURE_START_CODE:   pic++; break;
350             case   SLICE_START_CODE: slice++; break;
351             case    PACK_START_CODE: pspack++; break;
352             case           VIDEO_ID:
353             case           AUDIO_ID:   pes++; break;
354             }
355         }
356     }
357     if(seq && seq*9<=pic*10 && pic*9<=slice*10 && !pspack && !pes)
358         return AVPROBE_SCORE_MAX/2+1; // +1 for .mpg
359     return 0;
360 }
361
362 static int h263_probe(AVProbeData *p)
363 {
364     int code;
365     const uint8_t *d;
366
367     if (p->buf_size < 6)
368         return 0;
369     d = p->buf;
370     code = (d[0] << 14) | (d[1] << 6) | (d[2] >> 2);
371     if (code == 0x20) {
372         return 50;
373     }
374     return 0;
375 }
376
377 static int h261_probe(AVProbeData *p)
378 {
379     int code;
380     const uint8_t *d;
381
382     if (p->buf_size < 6)
383         return 0;
384     d = p->buf;
385     code = (d[0] << 12) | (d[1] << 4) | (d[2] >> 4);
386     if (code == 0x10) {
387         return 50;
388     }
389     return 0;
390 }
391
392 AVInputFormat shorten_demuxer = {
393     "shn",
394     "raw shorten",
395     0,
396     NULL,
397     shorten_read_header,
398     raw_read_partial_packet,
399     raw_read_close,
400     .extensions = "shn",
401 };
402
403 AVInputFormat flac_demuxer = {
404     "flac",
405     "raw flac",
406     0,
407     NULL,
408     flac_read_header,
409     raw_read_partial_packet,
410     raw_read_close,
411     .extensions = "flac",
412 };
413
414 #ifdef CONFIG_MUXERS
415 AVOutputFormat flac_muxer = {
416     "flac",
417     "raw flac",
418     "audio/x-flac",
419     "flac",
420     0,
421     CODEC_ID_FLAC,
422     0,
423     flac_write_header,
424     raw_write_packet,
425     raw_write_trailer,
426     .flags= AVFMT_NOTIMESTAMPS,
427 };
428 #endif //CONFIG_MUXERS
429
430 AVInputFormat ac3_demuxer = {
431     "ac3",
432     "raw ac3",
433     0,
434     NULL,
435     ac3_read_header,
436     raw_read_partial_packet,
437     raw_read_close,
438     .extensions = "ac3",
439 };
440
441 #ifdef CONFIG_MUXERS
442 AVOutputFormat ac3_muxer = {
443     "ac3",
444     "raw ac3",
445     "audio/x-ac3",
446     "ac3",
447     0,
448     CODEC_ID_AC3,
449     0,
450     raw_write_header,
451     raw_write_packet,
452     raw_write_trailer,
453     .flags= AVFMT_NOTIMESTAMPS,
454 };
455 #endif //CONFIG_MUXERS
456
457 AVInputFormat dts_demuxer = {
458     "dts",
459     "raw dts",
460     0,
461     NULL,
462     dts_read_header,
463     raw_read_partial_packet,
464     raw_read_close,
465     .extensions = "dts",
466 };
467
468 AVInputFormat aac_demuxer = {
469     "aac",
470     "ADTS AAC",
471     0,
472     NULL,
473     aac_read_header,
474     raw_read_partial_packet,
475     raw_read_close,
476     .extensions = "aac",
477 };
478
479 AVInputFormat h261_demuxer = {
480     "h261",
481     "raw h261",
482     0,
483     h261_probe,
484     video_read_header,
485     raw_read_partial_packet,
486     raw_read_close,
487     .extensions = "h261",
488     .value = CODEC_ID_H261,
489 };
490
491 #ifdef CONFIG_MUXERS
492 AVOutputFormat h261_muxer = {
493     "h261",
494     "raw h261",
495     "video/x-h261",
496     "h261",
497     0,
498     0,
499     CODEC_ID_H261,
500     raw_write_header,
501     raw_write_packet,
502     raw_write_trailer,
503     .flags= AVFMT_NOTIMESTAMPS,
504 };
505 #endif //CONFIG_MUXERS
506
507 AVInputFormat h263_demuxer = {
508     "h263",
509     "raw h263",
510     0,
511     h263_probe,
512     video_read_header,
513     raw_read_partial_packet,
514     raw_read_close,
515 //    .extensions = "h263", //FIXME remove after writing mpeg4_probe
516     .value = CODEC_ID_H263,
517 };
518
519 #ifdef CONFIG_MUXERS
520 AVOutputFormat h263_muxer = {
521     "h263",
522     "raw h263",
523     "video/x-h263",
524     "h263",
525     0,
526     0,
527     CODEC_ID_H263,
528     raw_write_header,
529     raw_write_packet,
530     raw_write_trailer,
531     .flags= AVFMT_NOTIMESTAMPS,
532 };
533 #endif //CONFIG_MUXERS
534
535 AVInputFormat m4v_demuxer = {
536     "m4v",
537     "raw MPEG4 video format",
538     0,
539     NULL /*mpegvideo_probe*/,
540     video_read_header,
541     raw_read_partial_packet,
542     raw_read_close,
543     .extensions = "m4v", //FIXME remove after writing mpeg4_probe
544     .value = CODEC_ID_MPEG4,
545 };
546
547 #ifdef CONFIG_MUXERS
548 AVOutputFormat m4v_muxer = {
549     "m4v",
550     "raw MPEG4 video format",
551     NULL,
552     "m4v",
553     0,
554     CODEC_ID_NONE,
555     CODEC_ID_MPEG4,
556     raw_write_header,
557     raw_write_packet,
558     raw_write_trailer,
559     .flags= AVFMT_NOTIMESTAMPS,
560 };
561 #endif //CONFIG_MUXERS
562
563 AVInputFormat h264_demuxer = {
564     "h264",
565     "raw H264 video format",
566     0,
567     NULL /*mpegvideo_probe*/,
568     video_read_header,
569     raw_read_partial_packet,
570     raw_read_close,
571     .extensions = "h26l,h264,264", //FIXME remove after writing mpeg4_probe
572     .value = CODEC_ID_H264,
573 };
574
575 #ifdef CONFIG_MUXERS
576 AVOutputFormat h264_muxer = {
577     "h264",
578     "raw H264 video format",
579     NULL,
580     "h264",
581     0,
582     CODEC_ID_NONE,
583     CODEC_ID_H264,
584     raw_write_header,
585     raw_write_packet,
586     raw_write_trailer,
587     .flags= AVFMT_NOTIMESTAMPS,
588 };
589 #endif //CONFIG_MUXERS
590
591 AVInputFormat mpegvideo_demuxer = {
592     "mpegvideo",
593     "MPEG video",
594     0,
595     mpegvideo_probe,
596     video_read_header,
597     raw_read_partial_packet,
598     raw_read_close,
599     .value = CODEC_ID_MPEG1VIDEO,
600 };
601
602 #ifdef CONFIG_MUXERS
603 AVOutputFormat mpeg1video_muxer = {
604     "mpeg1video",
605     "MPEG video",
606     "video/x-mpeg",
607     "mpg,mpeg,m1v",
608     0,
609     0,
610     CODEC_ID_MPEG1VIDEO,
611     raw_write_header,
612     raw_write_packet,
613     raw_write_trailer,
614     .flags= AVFMT_NOTIMESTAMPS,
615 };
616 #endif //CONFIG_MUXERS
617
618 #ifdef CONFIG_MUXERS
619 AVOutputFormat mpeg2video_muxer = {
620     "mpeg2video",
621     "MPEG2 video",
622     NULL,
623     "m2v",
624     0,
625     0,
626     CODEC_ID_MPEG2VIDEO,
627     raw_write_header,
628     raw_write_packet,
629     raw_write_trailer,
630     .flags= AVFMT_NOTIMESTAMPS,
631 };
632 #endif //CONFIG_MUXERS
633
634 AVInputFormat mjpeg_demuxer = {
635     "mjpeg",
636     "MJPEG video",
637     0,
638     NULL,
639     video_read_header,
640     raw_read_partial_packet,
641     raw_read_close,
642     .extensions = "mjpg,mjpeg",
643     .value = CODEC_ID_MJPEG,
644 };
645
646 AVInputFormat ingenient_demuxer = {
647     "ingenient",
648     "Ingenient MJPEG",
649     0,
650     NULL,
651     video_read_header,
652     ingenient_read_packet,
653     raw_read_close,
654     .extensions = "cgi", // FIXME
655     .value = CODEC_ID_MJPEG,
656 };
657
658 #ifdef CONFIG_MUXERS
659 AVOutputFormat mjpeg_muxer = {
660     "mjpeg",
661     "MJPEG video",
662     "video/x-mjpeg",
663     "mjpg,mjpeg",
664     0,
665     0,
666     CODEC_ID_MJPEG,
667     raw_write_header,
668     raw_write_packet,
669     raw_write_trailer,
670     .flags= AVFMT_NOTIMESTAMPS,
671 };
672 #endif //CONFIG_MUXERS
673
674 /* pcm formats */
675
676 #define PCMINPUTDEF(name, long_name, ext, codec) \
677 AVInputFormat pcm_ ## name ## _demuxer = {\
678     #name,\
679     long_name,\
680     0,\
681     NULL,\
682     raw_read_header,\
683     raw_read_packet,\
684     raw_read_close,\
685     pcm_read_seek,\
686     .extensions = ext,\
687     .value = codec,\
688 };
689
690 #define PCMOUTPUTDEF(name, long_name, ext, codec) \
691 AVOutputFormat pcm_ ## name ## _muxer = {\
692     #name,\
693     long_name,\
694     NULL,\
695     ext,\
696     0,\
697     codec,\
698     0,\
699     raw_write_header,\
700     raw_write_packet,\
701     raw_write_trailer,\
702     .flags= AVFMT_NOTIMESTAMPS,\
703 };
704
705
706 #if !defined(CONFIG_MUXERS) && defined(CONFIG_DEMUXERS)
707 #define PCMDEF(name, long_name, ext, codec) \
708         PCMINPUTDEF(name, long_name, ext, codec)
709 #elif defined(CONFIG_MUXERS) && !defined(CONFIG_DEMUXERS)
710 #define PCMDEF(name, long_name, ext, codec) \
711         PCMOUTPUTDEF(name, long_name, ext, codec)
712 #elif defined(CONFIG_MUXERS) && defined(CONFIG_DEMUXERS)
713 #define PCMDEF(name, long_name, ext, codec) \
714         PCMINPUTDEF(name, long_name, ext, codec)\
715         PCMOUTPUTDEF(name, long_name, ext, codec)
716 #else
717 #define PCMDEF(name, long_name, ext, codec)
718 #endif
719
720 #ifdef WORDS_BIGENDIAN
721 #define BE_DEF(s) s
722 #define LE_DEF(s) NULL
723 #else
724 #define BE_DEF(s) NULL
725 #define LE_DEF(s) s
726 #endif
727
728
729 PCMDEF(s16le, "pcm signed 16 bit little endian format",
730        LE_DEF("sw"), CODEC_ID_PCM_S16LE)
731
732 PCMDEF(s16be, "pcm signed 16 bit big endian format",
733        BE_DEF("sw"), CODEC_ID_PCM_S16BE)
734
735 PCMDEF(u16le, "pcm unsigned 16 bit little endian format",
736        LE_DEF("uw"), CODEC_ID_PCM_U16LE)
737
738 PCMDEF(u16be, "pcm unsigned 16 bit big endian format",
739        BE_DEF("uw"), CODEC_ID_PCM_U16BE)
740
741 PCMDEF(s8, "pcm signed 8 bit format",
742        "sb", CODEC_ID_PCM_S8)
743
744 PCMDEF(u8, "pcm unsigned 8 bit format",
745        "ub", CODEC_ID_PCM_U8)
746
747 PCMDEF(mulaw, "pcm mu law format",
748        "ul", CODEC_ID_PCM_MULAW)
749
750 PCMDEF(alaw, "pcm A law format",
751        "al", CODEC_ID_PCM_ALAW)
752
753 static int rawvideo_read_packet(AVFormatContext *s, AVPacket *pkt)
754 {
755     int packet_size, ret, width, height;
756     AVStream *st = s->streams[0];
757
758     width = st->codec->width;
759     height = st->codec->height;
760
761     packet_size = avpicture_get_size(st->codec->pix_fmt, width, height);
762     if (packet_size < 0)
763         return -1;
764
765     ret= av_get_packet(&s->pb, pkt, packet_size);
766
767     pkt->stream_index = 0;
768     if (ret != packet_size) {
769         return AVERROR_IO;
770     } else {
771         return 0;
772     }
773 }
774
775 AVInputFormat rawvideo_demuxer = {
776     "rawvideo",
777     "raw video format",
778     0,
779     NULL,
780     raw_read_header,
781     rawvideo_read_packet,
782     raw_read_close,
783     .extensions = "yuv,cif,qcif",
784     .value = CODEC_ID_RAWVIDEO,
785 };
786
787 #ifdef CONFIG_MUXERS
788 AVOutputFormat rawvideo_muxer = {
789     "rawvideo",
790     "raw video format",
791     NULL,
792     "yuv",
793     0,
794     CODEC_ID_NONE,
795     CODEC_ID_RAWVIDEO,
796     raw_write_header,
797     raw_write_packet,
798     raw_write_trailer,
799     .flags= AVFMT_NOTIMESTAMPS,
800 };
801 #endif //CONFIG_MUXERS
802
803 #ifdef CONFIG_MUXERS
804 static int null_write_packet(struct AVFormatContext *s, AVPacket *pkt)
805 {
806     return 0;
807 }
808
809 AVOutputFormat null_muxer = {
810     "null",
811     "null video format",
812     NULL,
813     NULL,
814     0,
815 #ifdef WORDS_BIGENDIAN
816     CODEC_ID_PCM_S16BE,
817 #else
818     CODEC_ID_PCM_S16LE,
819 #endif
820     CODEC_ID_RAWVIDEO,
821     raw_write_header,
822     null_write_packet,
823     raw_write_trailer,
824     .flags = AVFMT_NOFILE | AVFMT_RAWPICTURE | AVFMT_NOTIMESTAMPS,
825 };
826 #endif //CONFIG_MUXERS