1 /*
2 * Copyright (c) 2008 Jaikrishnan Menon <realityman@gmx.net>
3 * Copyright (c) 2010 Peter Ross <pross@xvid.org>
4 * Copyright (c) 2010 Sebastian Vater <cdgs.basty@googlemail.com>
5 *
6 * This file is part of FFmpeg.
7 *
8 * FFmpeg is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
12 *
13 * FFmpeg is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
17 *
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with FFmpeg; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 */
22
23 /**
24 * @file
25 * IFF file demuxer
26 * by Jaikrishnan Menon
27 * for more information on the .iff file format, visit:
28 * http://wiki.multimedia.cx/index.php?title=IFF
29 */
30
31 #include <inttypes.h>
32
41
42 #define ID_8SVX MKTAG('8','S','V','X')
43 #define ID_16SV MKTAG('1','6','S','V')
44 #define ID_MAUD MKTAG('M','A','U','D')
45 #define ID_MHDR MKTAG('M','H','D','R')
46 #define ID_MDAT MKTAG('M','D','A','T')
47 #define ID_VHDR MKTAG('V','H','D','R')
48 #define ID_ATAK MKTAG('A','T','A','K')
49 #define ID_RLSE MKTAG('R','L','S','E')
50 #define ID_CHAN MKTAG('C','H','A','N')
51 #define ID_PBM MKTAG('P','B','M',' ')
52 #define ID_ILBM MKTAG('I','L','B','M')
53 #define ID_BMHD MKTAG('B','M','H','D')
54 #define ID_DGBL MKTAG('D','G','B','L')
55 #define ID_CAMG MKTAG('C','A','M','G')
56 #define ID_CMAP MKTAG('C','M','A','P')
57 #define ID_ACBM MKTAG('A','C','B','M')
58 #define ID_DEEP MKTAG('D','E','E','P')
59 #define ID_RGB8 MKTAG('R','G','B','8')
60 #define ID_RGBN MKTAG('R','G','B','N')
61 #define ID_DSD MKTAG('D','S','D',' ')
62 #define ID_ANIM MKTAG('A','N','I','M')
63
64 #define ID_FORM MKTAG('F','O','R','M')
65 #define ID_FRM8 MKTAG('F','R','M','8')
66 #define ID_ANNO MKTAG('A','N','N','O')
67 #define ID_AUTH MKTAG('A','U','T','H')
68 #define ID_CHRS MKTAG('C','H','R','S')
69 #define ID_COPYRIGHT MKTAG('(','c',')',' ')
70 #define ID_CSET MKTAG('C','S','E','T')
71 #define ID_FVER MKTAG('F','V','E','R')
72 #define ID_NAME MKTAG('N','A','M','E')
73 #define ID_TEXT MKTAG('T','E','X','T')
74 #define ID_ABIT MKTAG('A','B','I','T')
75 #define ID_BODY MKTAG('B','O','D','Y')
76 #define ID_DBOD MKTAG('D','B','O','D')
77 #define ID_DPEL MKTAG('D','P','E','L')
78 #define ID_DLOC MKTAG('D','L','O','C')
79 #define ID_TVDC MKTAG('T','V','D','C')
80
84
85 /**
86 * This number of bytes if added at the beginning of each AVPacket
87 * which contain additional information about video properties
88 * which has to be shared between demuxer and decoder.
89 * This number may change between frames, e.g. the demuxer might
90 * set it to smallest possible size of 2 to indicate that there's
91 * no extradata changing in this frame.
92 */
93 #define IFF_EXTRA_VIDEO_SIZE 41
94
100
110 unsigned bpp;
///< bits per plane to decode (differs from bits_per_coded_sample if HAM)
111 unsigned ham;
///< 0 if non-HAM or number of hold bits (6 for bpp > 6, 4 otherwise)
112 unsigned flags;
///< 1 for EHB, 0 is no extra half darkening
117
118 /* Metadata string read */
120 const char *
const tag,
121 const unsigned data_size)
122 {
124
125 if (!buf)
127
128 if (
avio_read(s->
pb, buf, data_size) != data_size) {
131 }
132 buf[data_size] = 0;
134 return 0;
135 }
136
138 {
140
155 return 0;
156 }
157
161 };
162
163
164 #define DSD_SLFT MKTAG('S','L','F','T')
165 #define DSD_SRGT MKTAG('S','R','G','T')
166 #define DSD_MLFT MKTAG('M','L','F','T')
167 #define DSD_MRGT MKTAG('M','R','G','T')
168 #define DSD_C MKTAG('C',' ',' ',' ')
169 #define DSD_LS MKTAG('L','S',' ',' ')
170 #define DSD_RS MKTAG('R','S',' ',' ')
171 #define DSD_LFE MKTAG('L','F','E',' ')
172
176
181
186 };
187
190 0, 0,
192 };
193
195 "dsd_source_comment",
196 "analogue_source_comment",
197 "pcm_source_comment",
198 };
199
201 "general_remark",
202 "operator_name",
203 "creating_machine",
204 "timezone",
205 "file_revision"
206 };
207
209 {
211
216 const char * metadata_tag =
NULL;
217
218 switch(tag) {
219 case MKTAG(
'D',
'I',
'A',
'R'): metadata_tag =
"artist";
break;
220 case MKTAG(
'D',
'I',
'T',
'I'): metadata_tag =
"title";
break;
221 }
222
223 if (metadata_tag && size > 4) {
226 if (ret < 0) {
229 }
230 }
231
233 }
234
235 return 0;
236 }
237
239 {
241 char abss[24];
243 int dsd_layout[6];
245
250
251 switch(tag) {
252 case MKTAG(
'A',
'B',
'S',
'S'):
253 if (size < 8)
258 snprintf(abss,
sizeof(abss),
"%02dh:%02dm:%02ds:%d", hour, min, sec,
avio_rb32(pb));
260 break;
261
262 case MKTAG(
'C',
'H',
'N',
'L'):
263 if (size < 2)
271 break;
272 }
280 break;
281 }
282 }
283 break;
284
285 case MKTAG(
'C',
'M',
'P',
'R'):
286 if (size < 4)
292 tag&0xFF, (tag>>8)&0xFF, (tag>>16)&0xFF, (tag>>24)&0xFF);
294 }
295 break;
296
297 case MKTAG(
'F',
'S',
' ',
' '):
298 if (size < 4)
301 break;
302
303 case MKTAG(
'I',
'D',
'3',
' '):
304 id3v2_extra_meta =
NULL;
306 if (id3v2_extra_meta) {
310 }
312 }
313
317 }
318 break;
319
320 case MKTAG(
'L',
'S',
'C',
'O'):
321 if (size < 2)
324 if (config != 0xFFFF) {
329 }
330 break;
331 }
332
334 }
335
336 return 0;
337 }
338
339 static const uint8_t deep_rgb24[] = {0, 0, 0, 3, 0, 1, 0, 8, 0, 2, 0, 8, 0, 3, 0, 8};
340 static const uint8_t deep_rgba[] = {0, 0, 0, 4, 0, 1, 0, 8, 0, 2, 0, 8, 0, 3, 0, 8};
341 static const uint8_t deep_bgra[] = {0, 0, 0, 4, 0, 3, 0, 8, 0, 2, 0, 8, 0, 1, 0, 8};
342 static const uint8_t deep_argb[] = {0, 0, 0, 4, 0,17, 0, 8, 0, 1, 0, 8, 0, 2, 0, 8};
343 static const uint8_t deep_abgr[] = {0, 0, 0, 4, 0,17, 0, 8, 0, 3, 0, 8, 0, 2, 0, 8};
344
346 {
351 uint32_t chunk_id;
352 uint64_t data_size;
353 uint32_t screenmode = 0, num, den;
354 unsigned transparency = 0;
355 unsigned masking = 0; // no mask
357 int fmt_size;
358
360 if (!st)
362
367 // codec_tag used by ByteRun1 decoder to distinguish progressive (PBM) and interlaced (ILBM) content
372 }
377
379 uint64_t orig_pos;
380 int res;
381 const char *metadata_tag =
NULL;
386
387 switch(chunk_id) {
390
391 if (data_size < 14)
395 if (data_size >= 16) {
398 }
399 break;
400
403
404 if (data_size < 32)
411 if (!den)
421 break;
422
431 break;
432
434 if (data_size < 4)
439 } else {
442 }
443 break;
444
446 if (data_size < 4)
449 break;
450
452 if (data_size < 3 || data_size > 768 || data_size % 3) {
454 data_size);
456 }
463 break;
464
467 if (data_size <= 8)
473 if (data_size >= 10)
475 if (data_size >= 11)
477 if (data_size >= 14) {
480 }
481 if (data_size >= 16) {
484 }
485 break;
486
488 if (data_size < 4 || (data_size & 3))
490 if ((fmt_size =
avio_read(pb, fmt,
sizeof(fmt))) < 0)
491 return fmt_size;
502 else {
505 }
506 break;
507
510 if (data_size < 8)
518 break;
519
521 if (data_size < 4)
525 break;
526
528 if (data_size <
sizeof(iff->
tvdc))
531 if (res < 0)
532 return res;
533 break;
534
536 case ID_TEXT: metadata_tag =
"comment";
break;
537 case ID_AUTH: metadata_tag =
"artist";
break;
539 case ID_NAME: metadata_tag =
"title";
break;
540
541 /* DSD tags */
542
543 case MKTAG(
'F',
'V',
'E',
'R'):
544 if (data_size < 4)
547 av_log(s,
AV_LOG_DEBUG,
"DSIFF v%d.%d.%d.%d\n",version >> 24, (version >> 16) & 0xFF, (version >> 8) & 0xFF, version & 0xFF);
549 break;
550
551 case MKTAG(
'D',
'I',
'I',
'N'):
553 if (res < 0)
554 return res;
555 break;
556
557 case MKTAG(
'P',
'R',
'O',
'P'):
558 if (data_size < 4)
562 break;
563 }
565 if (res < 0)
566 return res;
567 break;
568
569 case MKTAG(
'C',
'O',
'M',
'T'):
570 if (data_size < 2)
573 for (i = 0; i < nb_comments; i++) {
574 int year, mon, day, hour,
min,
type, ref;
575 char tmp[24];
577 int metadata_size;
578
584 snprintf(tmp,
sizeof(tmp),
"%04d-%02d-%02d %02d:%02d", year, mon, day, hour, min);
586
589 switch (type) {
590 case 1:
591 if (!i)
592 tag = "channel_comment";
593 else {
594 snprintf(tmp,
sizeof(tmp),
"channel%d_comment", ref);
595 tag = tmp;
596 }
597 break;
598 case 2:
600 break;
601 case 3:
603 break;
604 default:
605 tag = "comment";
606 }
607
611 return res;
612 }
613
614 if (metadata_size & 1)
616 }
617 break;
618 }
619
620 if (metadata_tag) {
621 if ((res =
get_metadata(s, metadata_tag, data_size)) < 0) {
623 return res;
624 }
625 }
627 }
628
630
634
646 } else {
649 }
654 break;
657 break;
660 break;
661 default:
664 return -1;
665 }
666 }
667
671 break;
672
675 if ((screenmode & 0x800
/* Hold And Modify */) && iff->
bpp <= 8) {
676 iff->
ham = iff->
bpp > 6 ? 6 : 4;
678 }
679 iff->
flags = (screenmode & 0x80
/* Extra HalfBrite */) && iff->
bpp <= 8;
682
688 }
693 bytestream_put_byte(&buf, iff->
bpp);
694 bytestream_put_byte(&buf, iff->
ham);
695 bytestream_put_byte(&buf, iff->
flags);
697 bytestream_put_byte(&buf, iff->
masking);
700 break;
701 default:
702 return -1;
703 }
704
705 return 0;
706 }
707
710 {
716
719
723 } else {
725 }
728
731 }
732
734 bytestream_put_be16(&buf, 2);
736 if (ret<0) {
738 } else if (ret < iff->body_size)
740 } else {
742 }
743
746 if (ret < 0)
750 }
751
760 };