~ubuntu-branches/ubuntu/trusty/libav/trusty

« back to all changes in this revision

Viewing changes to libavformat/iff.c

  • Committer: Bazaar Package Importer
  • Author(s): Reinhard Tartler
  • Date: 2011-04-19 15:04:55 UTC
  • mfrom: (1.2.1 upstream)
  • mto: (1.3.4 sid)
  • mto: This revision was merged to the branch mainline in revision 3.
  • Revision ID: james.westby@ubuntu.com-20110419150455-c1nac6gjm3t2aa4n
Tags: 4:0.7~b1-1
* New upstream version
* bump SONAME and SHLIBS
* configure flags --disable-stripping was removed upstream
* the MAINTAINERS file was removed upstream
* remove patch disable-configuration-warning.patch
* drop avfilter confflags, it is enable by default in 0.7
* libfaad wrapper has been removed upstream
* also update the *contents* of the lintian overrides

Show diffs side-by-side

added added

removed removed

Lines of Context:
4
4
 * Copyright (c) 2010 Peter Ross <pross@xvid.org>
5
5
 * Copyright (c) 2010 Sebastian Vater <cdgs.basty@googlemail.com>
6
6
 *
7
 
 * This file is part of FFmpeg.
 
7
 * This file is part of Libav.
8
8
 *
9
 
 * FFmpeg is free software; you can redistribute it and/or
 
9
 * Libav is free software; you can redistribute it and/or
10
10
 * modify it under the terms of the GNU Lesser General Public
11
11
 * License as published by the Free Software Foundation; either
12
12
 * version 2.1 of the License, or (at your option) any later version.
13
13
 *
14
 
 * FFmpeg is distributed in the hope that it will be useful,
 
14
 * Libav is distributed in the hope that it will be useful,
15
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
17
17
 * Lesser General Public License for more details.
18
18
 *
19
19
 * You should have received a copy of the GNU Lesser General Public
20
 
 * License along with FFmpeg; if not, write to the Free Software
 
20
 * License along with Libav; if not, write to the Free Software
21
21
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22
22
 */
23
23
 
30
30
 */
31
31
 
32
32
#include "libavutil/intreadwrite.h"
33
 
#include "libavcodec/iff.h"
34
33
#include "avformat.h"
35
34
 
36
35
#define ID_8SVX       MKTAG('8','S','V','X')
92
91
    }
93
92
}
94
93
 
 
94
/* Metadata string read */
 
95
static int get_metadata(AVFormatContext *s,
 
96
                        const char *const tag,
 
97
                        const unsigned data_size)
 
98
{
 
99
    uint8_t *buf = ((data_size + 1) == 0) ? NULL : av_malloc(data_size + 1);
 
100
 
 
101
    if (!buf)
 
102
        return AVERROR(ENOMEM);
 
103
 
 
104
    if (avio_read(s->pb, buf, data_size) < 0) {
 
105
        av_free(buf);
 
106
        return AVERROR(EIO);
 
107
    }
 
108
    buf[data_size] = 0;
 
109
    av_metadata_set2(&s->metadata, tag, buf, AV_METADATA_DONT_STRDUP_VAL);
 
110
    return 0;
 
111
}
 
112
 
95
113
static int iff_probe(AVProbeData *p)
96
114
{
97
115
    const uint8_t *d = p->buf;
106
124
                           AVFormatParameters *ap)
107
125
{
108
126
    IffDemuxContext *iff = s->priv_data;
109
 
    ByteIOContext *pb = s->pb;
 
127
    AVIOContext *pb = s->pb;
110
128
    AVStream *st;
111
129
    uint32_t chunk_id, data_size;
112
130
    int compression = -1;
113
 
    char *buf;
114
131
 
115
132
    st = av_new_stream(s, 0);
116
133
    if (!st)
117
134
        return AVERROR(ENOMEM);
118
135
 
119
136
    st->codec->channels = 1;
120
 
    url_fskip(pb, 8);
 
137
    avio_skip(pb, 8);
121
138
    // codec_tag used by ByteRun1 decoder to distinguish progressive (PBM) and interlaced (ILBM) content
122
 
    st->codec->codec_tag = get_le32(pb);
 
139
    st->codec->codec_tag = avio_rl32(pb);
123
140
 
124
 
    while(!url_feof(pb)) {
 
141
    while(!pb->eof_reached) {
125
142
        uint64_t orig_pos;
126
 
        chunk_id = get_le32(pb);
127
 
        data_size = get_be32(pb);
128
 
        orig_pos = url_ftell(pb);
 
143
        int res;
 
144
        const char *metadata_tag = NULL;
 
145
        chunk_id = avio_rl32(pb);
 
146
        data_size = avio_rb32(pb);
 
147
        orig_pos = avio_tell(pb);
129
148
 
130
149
        switch(chunk_id) {
131
150
        case ID_VHDR:
133
152
 
134
153
            if (data_size < 14)
135
154
                return AVERROR_INVALIDDATA;
136
 
            url_fskip(pb, 12);
137
 
            st->codec->sample_rate = get_be16(pb);
 
155
            avio_skip(pb, 12);
 
156
            st->codec->sample_rate = avio_rb16(pb);
138
157
            if (data_size >= 16) {
139
 
                url_fskip(pb, 1);
140
 
                compression        = get_byte(pb);
 
158
                avio_skip(pb, 1);
 
159
                compression        = avio_r8(pb);
141
160
            }
142
161
            break;
143
162
 
144
163
        case ID_BODY:
145
 
            iff->body_pos = url_ftell(pb);
 
164
            iff->body_pos = avio_tell(pb);
146
165
            iff->body_size = data_size;
147
166
            break;
148
167
 
149
168
        case ID_CHAN:
150
169
            if (data_size < 4)
151
170
                return AVERROR_INVALIDDATA;
152
 
            st->codec->channels = (get_be32(pb) < 6) ? 1 : 2;
 
171
            st->codec->channels = (avio_rb32(pb) < 6) ? 1 : 2;
153
172
            break;
154
173
 
155
174
        case ID_CMAP:
157
176
            st->codec->extradata      = av_malloc(data_size);
158
177
            if (!st->codec->extradata)
159
178
                return AVERROR(ENOMEM);
160
 
            if (get_buffer(pb, st->codec->extradata, data_size) < 0)
 
179
            if (avio_read(pb, st->codec->extradata, data_size) < 0)
161
180
                return AVERROR(EIO);
162
181
            break;
163
182
 
165
184
            st->codec->codec_type            = AVMEDIA_TYPE_VIDEO;
166
185
            if (data_size <= 8)
167
186
                return AVERROR_INVALIDDATA;
168
 
            st->codec->width                 = get_be16(pb);
169
 
            st->codec->height                = get_be16(pb);
170
 
            url_fskip(pb, 4); // x, y offset
171
 
            st->codec->bits_per_coded_sample = get_byte(pb);
 
187
            st->codec->width                 = avio_rb16(pb);
 
188
            st->codec->height                = avio_rb16(pb);
 
189
            avio_skip(pb, 4); // x, y offset
 
190
            st->codec->bits_per_coded_sample = avio_r8(pb);
172
191
            if (data_size >= 11) {
173
 
                url_fskip(pb, 1); // masking
174
 
                compression                  = get_byte(pb);
 
192
                avio_skip(pb, 1); // masking
 
193
                compression                  = avio_r8(pb);
175
194
            }
176
195
            if (data_size >= 16) {
177
 
                url_fskip(pb, 3); // paddding, transparent
178
 
                st->sample_aspect_ratio.num  = get_byte(pb);
179
 
                st->sample_aspect_ratio.den  = get_byte(pb);
 
196
                avio_skip(pb, 3); // paddding, transparent
 
197
                st->sample_aspect_ratio.num  = avio_r8(pb);
 
198
                st->sample_aspect_ratio.den  = avio_r8(pb);
180
199
            }
181
200
            break;
182
201
 
183
202
        case ID_ANNO:
184
 
            buf = av_malloc(data_size + 1);
185
 
            if (!buf)
186
 
                break;
187
 
            get_buffer(pb, buf, data_size);
188
 
            buf[data_size] = 0;
189
 
            av_metadata_set2(&s->metadata, "comment", buf, AV_METADATA_DONT_STRDUP_VAL);
190
 
            break;
191
 
        }
192
 
 
193
 
        url_fskip(pb, data_size - (url_ftell(pb) - orig_pos) + (data_size & 1));
 
203
        case ID_TEXT:
 
204
            metadata_tag = "comment";
 
205
            break;
 
206
 
 
207
        case ID_AUTH:
 
208
            metadata_tag = "artist";
 
209
            break;
 
210
 
 
211
        case ID_COPYRIGHT:
 
212
            metadata_tag = "copyright";
 
213
            break;
 
214
 
 
215
        case ID_NAME:
 
216
            metadata_tag = "title";
 
217
            break;
 
218
        }
 
219
 
 
220
        if (metadata_tag) {
 
221
            if ((res = get_metadata(s, metadata_tag, data_size)) < 0) {
 
222
                av_log(s, AV_LOG_ERROR, "cannot allocate metadata tag %s!", metadata_tag);
 
223
                return res;
 
224
            }
 
225
        }
 
226
        avio_skip(pb, data_size - (avio_tell(pb) - orig_pos) + (data_size & 1));
194
227
    }
195
228
 
196
 
    url_fseek(pb, iff->body_pos, SEEK_SET);
 
229
    avio_seek(pb, iff->body_pos, SEEK_SET);
197
230
 
198
231
    switch(st->codec->codec_type) {
199
232
    case AVMEDIA_TYPE_AUDIO:
210
243
            st->codec->codec_id = CODEC_ID_8SVX_EXP;
211
244
            break;
212
245
        default:
213
 
            av_log(s, AV_LOG_ERROR, "iff: unknown compression method\n");
 
246
            av_log(s, AV_LOG_ERROR, "unknown compression method\n");
214
247
            return -1;
215
248
        }
216
249
 
222
255
    case AVMEDIA_TYPE_VIDEO:
223
256
        switch (compression) {
224
257
        case BITMAP_RAW:
225
 
            if (st->codec->codec_tag == ID_ILBM) {
226
 
                st->codec->codec_id = CODEC_ID_IFF_ILBM;
227
 
            } else {
228
 
                st->codec->codec_id = CODEC_ID_RAWVIDEO;
229
 
                st->codec->pix_fmt  = PIX_FMT_PAL8;
230
 
                st->codec->codec_tag = 0;
231
 
            }
 
258
            st->codec->codec_id = CODEC_ID_IFF_ILBM;
232
259
            break;
233
260
        case BITMAP_BYTERUN1:
234
261
            st->codec->codec_id = CODEC_ID_IFF_BYTERUN1;
249
276
                           AVPacket *pkt)
250
277
{
251
278
    IffDemuxContext *iff = s->priv_data;
252
 
    ByteIOContext *pb = s->pb;
 
279
    AVIOContext *pb = s->pb;
253
280
    AVStream *st = s->streams[0];
254
281
    int ret;
255
282
 
256
283
    if(iff->sent_bytes >= iff->body_size)
257
284
        return AVERROR(EIO);
258
285
 
259
 
    if(s->streams[0]->codec->channels == 2) {
 
286
    if(st->codec->channels == 2) {
260
287
        uint8_t sample_buffer[PACKET_SIZE];
261
288
 
262
 
        ret = get_buffer(pb, sample_buffer, PACKET_SIZE);
 
289
        ret = avio_read(pb, sample_buffer, PACKET_SIZE);
263
290
        if(av_new_packet(pkt, PACKET_SIZE) < 0) {
264
 
            av_log(s, AV_LOG_ERROR, "iff: cannot allocate packet \n");
 
291
            av_log(s, AV_LOG_ERROR, "cannot allocate packet\n");
265
292
            return AVERROR(ENOMEM);
266
293
        }
267
294
        interleave_stereo(sample_buffer, pkt->data, PACKET_SIZE);
268
 
    } else if (s->streams[0]->codec->codec_id == CODEC_ID_RAWVIDEO) {
269
 
        if(av_new_packet(pkt, iff->body_size + AVPALETTE_SIZE) < 0) {
270
 
            return AVERROR(ENOMEM);
271
 
        }
272
 
 
273
 
        ret = ff_cmap_read_palette(st->codec, (uint32_t*)(pkt->data + iff->body_size));
274
 
        if (ret < 0)
275
 
            return ret;
276
 
        av_freep(&st->codec->extradata);
277
 
        st->codec->extradata_size = 0;
278
 
 
279
 
        ret = get_buffer(pb, pkt->data, iff->body_size);
280
 
    } else if (s->streams[0]->codec->codec_type == AVMEDIA_TYPE_VIDEO) {
 
295
    } else if (st->codec->codec_type == AVMEDIA_TYPE_VIDEO) {
281
296
        ret = av_get_packet(pb, pkt, iff->body_size);
282
297
    } else {
283
298
        ret = av_get_packet(pb, pkt, PACKET_SIZE);
286
301
    if(iff->sent_bytes == 0)
287
302
        pkt->flags |= AV_PKT_FLAG_KEY;
288
303
 
289
 
    if(s->streams[0]->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
 
304
    if(st->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
290
305
        iff->sent_bytes += PACKET_SIZE;
291
306
    } else {
292
307
        iff->sent_bytes = iff->body_size;
293
308
    }
294
309
    pkt->stream_index = 0;
295
 
    if(s->streams[0]->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
 
310
    if(st->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
296
311
        pkt->pts = iff->audio_frame_count;
297
 
        iff->audio_frame_count += ret / s->streams[0]->codec->channels;
 
312
        iff->audio_frame_count += ret / st->codec->channels;
298
313
    }
299
314
    return ret;
300
315
}
301
316
 
302
 
AVInputFormat iff_demuxer = {
 
317
AVInputFormat ff_iff_demuxer = {
303
318
    "IFF",
304
319
    NULL_IF_CONFIG_SMALL("IFF format"),
305
320
    sizeof(IffDemuxContext),