X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavformat%2Fmmf.c;h=61f1d7adf429ed88194ea29a40da2a2873c2ac18;hb=e73d26bbd65f1ac5fc73ef3fd24cab1bed8ba2e2;hp=d4247544c2ea26ce1bb10fbcefda28c7d8189231;hpb=2912e87a6c9264d556734e2bf94a99c64cf9b102;p=ffmpeg diff --git a/libavformat/mmf.c b/libavformat/mmf.c index d4247544c2e..61f1d7adf42 100644 --- a/libavformat/mmf.c +++ b/libavformat/mmf.c @@ -18,8 +18,11 @@ * License along with Libav; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ + +#include "libavutil/channel_layout.h" #include "avformat.h" #include "avio_internal.h" +#include "internal.h" #include "pcm.h" #include "riff.h" @@ -32,7 +35,7 @@ static const int mmf_rates[] = { 4000, 8000, 11025, 22050, 44100 }; static int mmf_rate(int code) { - if((code < 0) || (code > 4)) + if ((code < 0) || (code > 4)) return -1; return mmf_rates[code]; } @@ -41,8 +44,8 @@ static int mmf_rate(int code) static int mmf_rate_code(int rate) { int i; - for(i = 0; i < 5; i++) - if(mmf_rates[i] == rate) + for (i = 0; i < 5; i++) + if (mmf_rates[i] == rate) return i; return -1; } @@ -66,8 +69,9 @@ static int mmf_write_header(AVFormatContext *s) int rate; rate = mmf_rate_code(s->streams[0]->codec->sample_rate); - if(rate < 0) { - av_log(s, AV_LOG_ERROR, "Unsupported sample rate %d\n", s->streams[0]->codec->sample_rate); + if (rate < 0) { + av_log(s, AV_LOG_ERROR, "Unsupported sample rate %d\n", + s->streams[0]->codec->sample_rate); return -1; } @@ -79,6 +83,9 @@ static int mmf_write_header(AVFormatContext *s) avio_w8(pb, 0); /* code type */ avio_w8(pb, 0); /* status */ avio_w8(pb, 0); /* counts */ + end_tag_be(pb, pos); + + pos = ff_start_tag(pb, "OPDA"); avio_write(pb, "VN:libavcodec,", sizeof("VN:libavcodec,") -1); /* metadata ("ST:songtitle,VN:version,...") */ end_tag_be(pb, pos); @@ -100,7 +107,7 @@ static int mmf_write_header(AVFormatContext *s) mmf->awapos = ff_start_tag(pb, "Awa\x01"); - av_set_pts_info(s->streams[0], 64, 1, s->streams[0]->codec->sample_rate); + avpriv_set_pts_info(s->streams[0], 64, 1, s->streams[0]->codec->sample_rate); avio_flush(pb); @@ -117,7 +124,7 @@ static int mmf_write_packet(AVFormatContext *s, AVPacket *pkt) /* Write a variable-length symbol */ static void put_varlength(AVIOContext *pb, int val) { - if(val < 128) + if (val < 128) avio_w8(pb, val); else { val -= 128; @@ -133,13 +140,13 @@ static int mmf_write_trailer(AVFormatContext *s) int64_t pos, size; int gatetime; - if (!url_is_streamed(s->pb)) { + if (s->pb->seekable) { /* Fill in length fields */ end_tag_be(pb, mmf->awapos); end_tag_be(pb, mmf->atrpos); end_tag_be(pb, 8); - pos = avio_tell(pb); + pos = avio_tell(pb); size = pos - mmf->awapos; /* Fill Atsq chunk */ @@ -179,27 +186,28 @@ static int mmf_probe(AVProbeData *p) } /* mmf input */ -static int mmf_read_header(AVFormatContext *s, - AVFormatParameters *ap) +static int mmf_read_header(AVFormatContext *s) { MMFContext *mmf = s->priv_data; unsigned int tag; AVIOContext *pb = s->pb; AVStream *st; - int64_t file_size, size; + int64_t size; int rate, params; tag = avio_rl32(pb); if (tag != MKTAG('M', 'M', 'M', 'D')) return -1; - file_size = avio_rb32(pb); + avio_skip(pb, 4); /* file_size */ /* Skip some unused chunks that may or may not be present */ - for(;; avio_skip(pb, size)) { - tag = avio_rl32(pb); + for (;; avio_skip(pb, size)) { + tag = avio_rl32(pb); size = avio_rb32(pb); - if(tag == MKTAG('C','N','T','I')) continue; - if(tag == MKTAG('O','P','D','A')) continue; + if (tag == MKTAG('C', 'N', 'T', 'I')) + continue; + if (tag == MKTAG('O', 'P', 'D', 'A')) + continue; break; } @@ -216,8 +224,8 @@ static int mmf_read_header(AVFormatContext *s, avio_r8(pb); /* format type */ avio_r8(pb); /* sequence type */ params = avio_r8(pb); /* (channel << 7) | (format << 4) | rate */ - rate = mmf_rate(params & 0x0f); - if(rate < 0) { + rate = mmf_rate(params & 0x0f); + if (rate < 0) { av_log(s, AV_LOG_ERROR, "Invalid sample rate\n"); return -1; } @@ -226,11 +234,13 @@ static int mmf_read_header(AVFormatContext *s, avio_r8(pb); /* time base g */ /* Skip some unused chunks that may or may not be present */ - for(;; avio_skip(pb, size)) { - tag = avio_rl32(pb); + for (;; avio_skip(pb, size)) { + tag = avio_rl32(pb); size = avio_rb32(pb); - if(tag == MKTAG('A','t','s','q')) continue; - if(tag == MKTAG('A','s','p','I')) continue; + if (tag == MKTAG('A', 't', 's', 'q')) + continue; + if (tag == MKTAG('A', 's', 'p', 'I')) + continue; break; } @@ -241,40 +251,39 @@ static int mmf_read_header(AVFormatContext *s, } mmf->data_size = size; - st = av_new_stream(s, 0); + st = avformat_new_stream(s, NULL); if (!st) return AVERROR(ENOMEM); - st->codec->codec_type = AVMEDIA_TYPE_AUDIO; - st->codec->codec_id = CODEC_ID_ADPCM_YAMAHA; - st->codec->sample_rate = rate; - st->codec->channels = 1; + st->codec->codec_type = AVMEDIA_TYPE_AUDIO; + st->codec->codec_id = AV_CODEC_ID_ADPCM_YAMAHA; + st->codec->sample_rate = rate; + st->codec->channels = 1; + st->codec->channel_layout = AV_CH_LAYOUT_MONO; st->codec->bits_per_coded_sample = 4; - st->codec->bit_rate = st->codec->sample_rate * st->codec->bits_per_coded_sample; + st->codec->bit_rate = st->codec->sample_rate * + st->codec->bits_per_coded_sample; - av_set_pts_info(st, 64, 1, st->codec->sample_rate); + avpriv_set_pts_info(st, 64, 1, st->codec->sample_rate); return 0; } #define MAX_SIZE 4096 -static int mmf_read_packet(AVFormatContext *s, - AVPacket *pkt) +static int mmf_read_packet(AVFormatContext *s, AVPacket *pkt) { MMFContext *mmf = s->priv_data; - AVStream *st; int ret, size; if (s->pb->eof_reached) return AVERROR(EIO); - st = s->streams[0]; size = MAX_SIZE; - if(size > mmf->data_size) + if (size > mmf->data_size) size = mmf->data_size; - if(!size) + if (!size) return AVERROR(EIO); if (av_new_packet(pkt, size)) @@ -293,27 +302,27 @@ static int mmf_read_packet(AVFormatContext *s, #if CONFIG_MMF_DEMUXER AVInputFormat ff_mmf_demuxer = { - "mmf", - NULL_IF_CONFIG_SMALL("Yamaha SMAF"), - sizeof(MMFContext), - mmf_probe, - mmf_read_header, - mmf_read_packet, - NULL, - pcm_read_seek, + .name = "mmf", + .long_name = NULL_IF_CONFIG_SMALL("Yamaha SMAF"), + .priv_data_size = sizeof(MMFContext), + .read_probe = mmf_probe, + .read_header = mmf_read_header, + .read_packet = mmf_read_packet, + .read_seek = ff_pcm_read_seek, }; #endif + #if CONFIG_MMF_MUXER AVOutputFormat ff_mmf_muxer = { - "mmf", - NULL_IF_CONFIG_SMALL("Yamaha SMAF"), - "application/vnd.smaf", - "mmf", - sizeof(MMFContext), - CODEC_ID_ADPCM_YAMAHA, - CODEC_ID_NONE, - mmf_write_header, - mmf_write_packet, - mmf_write_trailer, + .name = "mmf", + .long_name = NULL_IF_CONFIG_SMALL("Yamaha SMAF"), + .mime_type = "application/vnd.smaf", + .extensions = "mmf", + .priv_data_size = sizeof(MMFContext), + .audio_codec = AV_CODEC_ID_ADPCM_YAMAHA, + .video_codec = AV_CODEC_ID_NONE, + .write_header = mmf_write_header, + .write_packet = mmf_write_packet, + .write_trailer = mmf_write_trailer, }; #endif