|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "libavutil/intreadwrite.h" |
|
#include "avformat.h" |
|
#include "avio_internal.h" |
|
#include "internal.h" |
|
#include "mux.h" |
|
#include "rawenc.h" |
|
#include "ircam.h" |
|
|
|
static int ircam_write_header(AVFormatContext *s) |
|
{ |
|
AVCodecParameters *par = s->streams[0]->codecpar; |
|
uint32_t tag; |
|
|
|
if (s->nb_streams != 1) { |
|
av_log(s, AV_LOG_ERROR, "only one stream is supported\n"); |
|
return AVERROR(EINVAL); |
|
} |
|
|
|
tag = ff_codec_get_tag(ff_codec_ircam_le_tags, par->codec_id); |
|
if (!tag) { |
|
av_log(s, AV_LOG_ERROR, "unsupported codec\n"); |
|
return AVERROR(EINVAL); |
|
} |
|
|
|
avio_wl32(s->pb, 0x0001A364); |
|
avio_wl32(s->pb, av_q2intfloat((AVRational){par->sample_rate, 1})); |
|
avio_wl32(s->pb, par->ch_layout.nb_channels); |
|
avio_wl32(s->pb, tag); |
|
ffio_fill(s->pb, 0, 1008); |
|
return 0; |
|
} |
|
|
|
const FFOutputFormat ff_ircam_muxer = { |
|
.p.name = "ircam", |
|
.p.extensions = "sf,ircam", |
|
.p.long_name = NULL_IF_CONFIG_SMALL("Berkeley/IRCAM/CARL Sound Format"), |
|
.p.audio_codec = AV_CODEC_ID_PCM_S16LE, |
|
.p.video_codec = AV_CODEC_ID_NONE, |
|
.write_header = ircam_write_header, |
|
.write_packet = ff_raw_write_packet, |
|
.p.codec_tag = (const AVCodecTag *const []){ ff_codec_ircam_le_tags, 0 }, |
|
}; |
|
|