FFmpeg  4.0
ircamdec.c
Go to the documentation of this file.
1 /*
2  * IRCAM demuxer
3  * Copyright (c) 2012 Paul B Mahol
4  *
5  * This file is part of FFmpeg.
6  *
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.
11  *
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.
16  *
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
20  */
21 
22 #include "libavutil/intreadwrite.h"
23 #include "libavcodec/internal.h"
24 #include "avformat.h"
25 #include "internal.h"
26 #include "pcm.h"
27 #include "ircam.h"
28 
29 static int ircam_probe(AVProbeData *p)
30 {
31  if ((p->buf[0] == 0x64 && p->buf[1] == 0xA3 && p->buf[3] == 0x00 &&
32  p->buf[2] >= 1 && p->buf[2] <= 4) ||
33  (p->buf[3] == 0x64 && p->buf[2] == 0xA3 && p->buf[0] == 0x00 &&
34  p->buf[1] >= 1 && p->buf[1] <= 3) &&
35  AV_RN32(p->buf + 4) && AV_RN32(p->buf + 8))
36  return AVPROBE_SCORE_MAX / 4 * 3;
37  return 0;
38 }
39 
40 static const struct endianess {
41  uint32_t magic;
42  int is_le;
43 } table[] = {
44  { 0x64A30100, 0 },
45  { 0x64A30200, 1 },
46  { 0x64A30300, 0 },
47  { 0x64A30400, 1 },
48  { 0x0001A364, 1 },
49  { 0x0002A364, 0 },
50  { 0x0003A364, 1 },
51 };
52 
54 {
55  uint32_t magic, sample_rate, channels, tag;
56  const AVCodecTag *tags;
57  int le = -1, i;
58  AVStream *st;
59 
60  magic = avio_rl32(s->pb);
61  for (i = 0; i < 7; i++) {
62  if (magic == table[i].magic) {
63  le = table[i].is_le;
64  break;
65  }
66  }
67 
68  if (le == 1) {
69  sample_rate = av_int2float(avio_rl32(s->pb));
70  channels = avio_rl32(s->pb);
71  tag = avio_rl32(s->pb);
73  } else if (le == 0) {
74  sample_rate = av_int2float(avio_rb32(s->pb));
75  channels = avio_rb32(s->pb);
76  tag = avio_rb32(s->pb);
78  } else {
79  return AVERROR_INVALIDDATA;
80  }
81 
82  if (!channels || !sample_rate)
83  return AVERROR_INVALIDDATA;
84 
85  st = avformat_new_stream(s, NULL);
86  if (!st)
87  return AVERROR(ENOMEM);
88 
90  st->codecpar->channels = channels;
92  return AVERROR(ENOSYS);
94 
95  st->codecpar->codec_id = ff_codec_get_id(tags, tag);
96  if (st->codecpar->codec_id == AV_CODEC_ID_NONE) {
97  av_log(s, AV_LOG_ERROR, "unknown tag %"PRIx32"\n", tag);
98  return AVERROR_INVALIDDATA;
99  }
100 
103  avpriv_set_pts_info(st, 64, 1, st->codecpar->sample_rate);
104  avio_skip(s->pb, 1008);
105 
106  return 0;
107 }
108 
110  .name = "ircam",
111  .long_name = NULL_IF_CONFIG_SMALL("Berkeley/IRCAM/CARL Sound Format"),
112  .read_probe = ircam_probe,
113  .read_header = ircam_read_header,
114  .read_packet = ff_pcm_read_packet,
115  .read_seek = ff_pcm_read_seek,
116  .extensions = "sf,ircam",
117  .flags = AVFMT_GENERIC_INDEX,
118 };
#define FF_SANE_NB_CHANNELS
Definition: internal.h:86
AVInputFormat ff_ircam_demuxer
Definition: ircamdec.c:109
#define NULL
Definition: coverity.c:32
const char * s
Definition: avisynth_c.h:768
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:59
const AVCodecTag ff_codec_ircam_be_tags[]
Definition: ircam.c:37
enum AVCodecID ff_codec_get_id(const AVCodecTag *tags, unsigned int tag)
Definition: utils.c:3108
void avpriv_set_pts_info(AVStream *s, int pts_wrap_bits, unsigned int pts_num, unsigned int pts_den)
Set the time base and wrapping info for a given stream.
Definition: utils.c:4811
static av_always_inline float av_int2float(uint32_t i)
Reinterpret a 32-bit integer as a float.
Definition: intfloat.h:40
channels
Definition: aptx.c:30
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: avcodec.h:3884
int64_t avio_skip(AVIOContext *s, int64_t offset)
Skip given number of bytes forward.
Definition: aviobuf.c:331
static int ircam_read_header(AVFormatContext *s)
Definition: ircamdec.c:53
Format I/O context.
Definition: avformat.h:1342
unsigned int avio_rb32(AVIOContext *s)
Definition: aviobuf.c:801
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file.
Definition: utils.c:4441
uint32_t tag
Definition: movenc.c:1455
#define av_log(a,...)
const AVCodecTag ff_codec_ircam_le_tags[]
Definition: ircam.c:25
uint32_t magic
Definition: ircamdec.c:41
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:176
int av_get_bits_per_sample(enum AVCodecID codec_id)
Return codec bits per sample.
Definition: utils.c:1495
unsigned int avio_rl32(AVIOContext *s)
Definition: aviobuf.c:770
#define AVERROR(e)
Definition: error.h:43
static const struct endianess table[]
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
Definition: internal.h:186
enum AVMediaType codec_type
General type of the encoded data.
Definition: avcodec.h:3880
static int ircam_probe(AVProbeData *p)
Definition: ircamdec.c:29
unsigned char * buf
Buffer must have AVPROBE_PADDING_SIZE of extra allocated bytes filled with zero.
Definition: avformat.h:450
int block_align
Audio only.
Definition: avcodec.h:4001
int ff_pcm_read_seek(AVFormatContext *s, int stream_index, int64_t timestamp, int flags)
Definition: pcm.c:52
Stream structure.
Definition: avformat.h:873
int ff_pcm_read_packet(AVFormatContext *s, AVPacket *pkt)
Definition: pcm.c:29
sample_rate
AVIOContext * pb
I/O context.
Definition: avformat.h:1384
#define AVFMT_GENERIC_INDEX
Use generic index building code.
Definition: avformat.h:470
This structure contains the data a format has to probe a file.
Definition: avformat.h:448
#define AV_RN32(p)
Definition: intreadwrite.h:364
int sample_rate
Audio only.
Definition: avcodec.h:3994
#define AVPROBE_SCORE_MAX
maximum score
Definition: avformat.h:460
Main libavformat public API header.
common internal api header.
int is_le
Definition: ircamdec.c:42
int bits_per_coded_sample
The number of bits per sample in the codedwords.
Definition: avcodec.h:3926
int channels
Audio only.
Definition: avcodec.h:3990
const char * name
A comma separated list of short names for the format.
Definition: avformat.h:647
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:1020