diff options
author | Anton Khirnov <anton@khirnov.net> | 2013-05-28 09:33:43 +0200 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2013-05-28 17:47:59 +0200 |
commit | 794ca87d2bff2513118de8b97595b3e23070e67d (patch) | |
tree | 86e1ad824e087fa2e7c23dc8df5bf5a310fb7108 /libavformat/wv.h | |
parent | 0a1a94450a28eef854162f859e79ecfb9f97915b (diff) | |
download | ffmpeg-794ca87d2bff2513118de8b97595b3e23070e67d.tar.gz |
wvdec: split block header parsing into a separate file
It will be reused by other muxers and demuxers.
Diffstat (limited to 'libavformat/wv.h')
-rw-r--r-- | libavformat/wv.h | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/libavformat/wv.h b/libavformat/wv.h new file mode 100644 index 0000000000..ef285d2ebc --- /dev/null +++ b/libavformat/wv.h @@ -0,0 +1,56 @@ +/* + * WavPack shared functions + * + * This file is part of Libav. + * + * Libav is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * Libav is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with Libav; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#ifndef AVFORMAT_WV_H +#define AVFORMAT_WV_H + +#include <stdint.h> + +#define WV_HEADER_SIZE 32 + +#define WV_FLAG_INITIAL_BLOCK (1 << 11) +#define WV_FLAG_FINAL_BLOCK (1 << 12) + +// specs say that maximum block size is 1Mb +#define WV_BLOCK_LIMIT 1048576 + +typedef struct WvHeader { + uint32_t blocksize; //< size of the block data (excluding the header) + uint16_t version; //< bitstream version + uint32_t total_samples; //< total number of samples in the stream + uint32_t block_idx; //< index of the first sample in this block + uint32_t samples; //< number of samples in this block + uint32_t flags; + uint32_t crc; + + int initial, final; +} WvHeader; + +/** + * Parse a WavPack block header. + * + * @param wv this struct will be filled with parse header information + * @param data header data, must be WV_HEADER_SIZE bytes long + * + * @return 0 on success, a negative AVERROR code on failure + */ +int ff_wv_parse_header(WvHeader *wv, const uint8_t *data); + +#endif /* AVFORMAT_WV_H */ |