annotate ffmpeg/libavcodec/tak.h @ 13:844d341cf643 tip

Back up before ISMIR
author Yading Song <yading.song@eecs.qmul.ac.uk>
date Thu, 31 Oct 2013 13:17:06 +0000
parents 6840f77b83aa
children
rev   line source
yading@10 1 /*
yading@10 2 * TAK decoder/demuxer common code
yading@10 3 * Copyright (c) 2012 Paul B Mahol
yading@10 4 *
yading@10 5 * This file is part of FFmpeg.
yading@10 6 *
yading@10 7 * FFmpeg is free software; you can redistribute it and/or
yading@10 8 * modify it under the terms of the GNU Lesser General Public
yading@10 9 * License as published by the Free Software Foundation; either
yading@10 10 * version 2.1 of the License, or (at your option) any later version.
yading@10 11 *
yading@10 12 * FFmpeg is distributed in the hope that it will be useful,
yading@10 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
yading@10 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
yading@10 15 * Lesser General Public License for more details.
yading@10 16 *
yading@10 17 * You should have received a copy of the GNU Lesser General Public
yading@10 18 * License along with FFmpeg; if not, write to the Free Software
yading@10 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
yading@10 20 */
yading@10 21
yading@10 22 /**
yading@10 23 * @file
yading@10 24 * TAK (Tom's lossless Audio Kompressor) decoder/demuxer common functions
yading@10 25 */
yading@10 26
yading@10 27 #ifndef AVCODEC_TAK_H
yading@10 28 #define AVCODEC_TAK_H
yading@10 29
yading@10 30 #include <stdint.h>
yading@10 31
yading@10 32 #define BITSTREAM_READER_LE
yading@10 33 #include "get_bits.h"
yading@10 34 #include "avcodec.h"
yading@10 35
yading@10 36 #define TAK_FORMAT_DATA_TYPE_BITS 3
yading@10 37 #define TAK_FORMAT_SAMPLE_RATE_BITS 18
yading@10 38 #define TAK_FORMAT_BPS_BITS 5
yading@10 39 #define TAK_FORMAT_CHANNEL_BITS 4
yading@10 40 #define TAK_FORMAT_VALID_BITS 5
yading@10 41 #define TAK_FORMAT_CH_LAYOUT_BITS 6
yading@10 42 #define TAK_SIZE_FRAME_DURATION_BITS 4
yading@10 43 #define TAK_SIZE_SAMPLES_NUM_BITS 35
yading@10 44 #define TAK_LAST_FRAME_POS_BITS 40
yading@10 45 #define TAK_LAST_FRAME_SIZE_BITS 24
yading@10 46 #define TAK_ENCODER_CODEC_BITS 6
yading@10 47 #define TAK_ENCODER_PROFILE_BITS 4
yading@10 48 #define TAK_ENCODER_VERSION_BITS 24
yading@10 49 #define TAK_SAMPLE_RATE_MIN 6000
yading@10 50 #define TAK_CHANNELS_MIN 1
yading@10 51 #define TAK_BPS_MIN 8
yading@10 52 #define TAK_FRAME_HEADER_FLAGS_BITS 3
yading@10 53 #define TAK_FRAME_HEADER_SYNC_ID 0xA0FF
yading@10 54 #define TAK_FRAME_HEADER_SYNC_ID_BITS 16
yading@10 55 #define TAK_FRAME_HEADER_SAMPLE_COUNT_BITS 14
yading@10 56 #define TAK_FRAME_HEADER_NO_BITS 21
yading@10 57 #define TAK_FRAME_DURATION_QUANT_SHIFT 5
yading@10 58 #define TAK_CRC24_BITS 24
yading@10 59
yading@10 60
yading@10 61 #define TAK_FRAME_FLAG_IS_LAST 0x1
yading@10 62 #define TAK_FRAME_FLAG_HAS_INFO 0x2
yading@10 63 #define TAK_FRAME_FLAG_HAS_METADATA 0x4
yading@10 64
yading@10 65 #define TAK_MAX_CHANNELS (1 << TAK_FORMAT_CHANNEL_BITS)
yading@10 66
yading@10 67 #define TAK_MIN_FRAME_HEADER_BITS (TAK_FRAME_HEADER_SYNC_ID_BITS + \
yading@10 68 TAK_FRAME_HEADER_FLAGS_BITS + \
yading@10 69 TAK_FRAME_HEADER_NO_BITS + \
yading@10 70 TAK_CRC24_BITS)
yading@10 71
yading@10 72 #define TAK_MIN_FRAME_HEADER_LAST_BITS (TAK_MIN_FRAME_HEADER_BITS + 2 + \
yading@10 73 TAK_FRAME_HEADER_SAMPLE_COUNT_BITS)
yading@10 74
yading@10 75 #define TAK_ENCODER_BITS (TAK_ENCODER_CODEC_BITS + \
yading@10 76 TAK_ENCODER_PROFILE_BITS)
yading@10 77
yading@10 78 #define TAK_SIZE_BITS (TAK_SIZE_SAMPLES_NUM_BITS + \
yading@10 79 TAK_SIZE_FRAME_DURATION_BITS)
yading@10 80
yading@10 81 #define TAK_FORMAT_BITS (TAK_FORMAT_DATA_TYPE_BITS + \
yading@10 82 TAK_FORMAT_SAMPLE_RATE_BITS + \
yading@10 83 TAK_FORMAT_BPS_BITS + \
yading@10 84 TAK_FORMAT_CHANNEL_BITS + 1 + \
yading@10 85 TAK_FORMAT_VALID_BITS + 1 + \
yading@10 86 TAK_FORMAT_CH_LAYOUT_BITS * \
yading@10 87 TAK_MAX_CHANNELS)
yading@10 88
yading@10 89 #define TAK_STREAMINFO_BITS (TAK_ENCODER_BITS + \
yading@10 90 TAK_SIZE_BITS + \
yading@10 91 TAK_FORMAT_BITS)
yading@10 92
yading@10 93 #define TAK_MAX_FRAME_HEADER_BITS (TAK_MIN_FRAME_HEADER_LAST_BITS + \
yading@10 94 TAK_STREAMINFO_BITS + 31)
yading@10 95
yading@10 96 #define TAK_STREAMINFO_BYTES ((TAK_STREAMINFO_BITS + 7) / 8)
yading@10 97 #define TAK_MAX_FRAME_HEADER_BYTES ((TAK_MAX_FRAME_HEADER_BITS + 7) / 8)
yading@10 98 #define TAK_MIN_FRAME_HEADER_BYTES ((TAK_MIN_FRAME_HEADER_BITS + 7) / 8)
yading@10 99
yading@10 100 enum TAKCodecType {
yading@10 101 TAK_CODEC_MONO_STEREO = 2,
yading@10 102 TAK_CODEC_MULTICHANNEL = 4,
yading@10 103 };
yading@10 104
yading@10 105 enum TAKMetaDataType {
yading@10 106 TAK_METADATA_END = 0,
yading@10 107 TAK_METADATA_STREAMINFO,
yading@10 108 TAK_METADATA_SEEKTABLE,
yading@10 109 TAK_METADATA_SIMPLE_WAVE_DATA,
yading@10 110 TAK_METADATA_ENCODER,
yading@10 111 TAK_METADATA_PADDING,
yading@10 112 TAK_METADATA_MD5,
yading@10 113 TAK_METADATA_LAST_FRAME,
yading@10 114 };
yading@10 115
yading@10 116 enum TAKFrameSizeType {
yading@10 117 TAK_FST_94ms = 0,
yading@10 118 TAK_FST_125ms,
yading@10 119 TAK_FST_188ms,
yading@10 120 TAK_FST_250ms,
yading@10 121 TAK_FST_4096,
yading@10 122 TAK_FST_8192,
yading@10 123 TAK_FST_16384,
yading@10 124 TAK_FST_512,
yading@10 125 TAK_FST_1024,
yading@10 126 TAK_FST_2048,
yading@10 127 };
yading@10 128
yading@10 129 typedef struct TAKStreamInfo {
yading@10 130 int flags;
yading@10 131 enum TAKCodecType codec;
yading@10 132 int data_type;
yading@10 133 int sample_rate;
yading@10 134 int channels;
yading@10 135 int bps;
yading@10 136 int frame_num;
yading@10 137 int frame_samples;
yading@10 138 int last_frame_samples;
yading@10 139 uint64_t ch_layout;
yading@10 140 int64_t samples;
yading@10 141 } TAKStreamInfo;
yading@10 142
yading@10 143 void ff_tak_init_crc(void);
yading@10 144
yading@10 145 int ff_tak_check_crc(const uint8_t *buf, unsigned int buf_size);
yading@10 146
yading@10 147 /**
yading@10 148 * Parse the Streaminfo metadata block.
yading@10 149 * @param[in] gb pointer to GetBitContext
yading@10 150 * @param[out] s storage for parsed information
yading@10 151 */
yading@10 152 void avpriv_tak_parse_streaminfo(GetBitContext *gb, TAKStreamInfo *s);
yading@10 153
yading@10 154 /**
yading@10 155 * Validate and decode a frame header.
yading@10 156 * @param avctx AVCodecContext to use as av_log() context
yading@10 157 * @param[in] gb GetBitContext from which to read frame header
yading@10 158 * @param[out] s frame information
yading@10 159 * @param log_level_offset log level offset, can be used to silence
yading@10 160 * error messages.
yading@10 161 * @return non-zero on error, 0 if OK
yading@10 162 */
yading@10 163 int ff_tak_decode_frame_header(AVCodecContext *avctx, GetBitContext *gb,
yading@10 164 TAKStreamInfo *s, int log_level_offset);
yading@10 165 #endif /* AVCODEC_TAK_H */