You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

97 lines
3.3KB

  1. /*
  2. * FLAC (Free Lossless Audio Codec) decoder/demuxer common functions
  3. * Copyright (c) 2008 Justin Ruggles
  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. * @file libavcodec/flac.h
  23. * FLAC (Free Lossless Audio Codec) decoder/demuxer common functions
  24. */
  25. #ifndef AVCODEC_FLAC_H
  26. #define AVCODEC_FLAC_H
  27. #include "avcodec.h"
  28. #define FLAC_STREAMINFO_SIZE 34
  29. enum {
  30. FLAC_METADATA_TYPE_STREAMINFO = 0,
  31. FLAC_METADATA_TYPE_PADDING,
  32. FLAC_METADATA_TYPE_APPLICATION,
  33. FLAC_METADATA_TYPE_SEEKTABLE,
  34. FLAC_METADATA_TYPE_VORBIS_COMMENT,
  35. FLAC_METADATA_TYPE_CUESHEET,
  36. FLAC_METADATA_TYPE_PICTURE,
  37. FLAC_METADATA_TYPE_INVALID = 127
  38. };
  39. enum FLACExtradataFormat {
  40. FLAC_EXTRADATA_FORMAT_STREAMINFO = 0,
  41. FLAC_EXTRADATA_FORMAT_FULL_HEADER = 1
  42. };
  43. /**
  44. * Data needed from the Streaminfo header for use by the raw FLAC demuxer
  45. * and/or the FLAC decoder.
  46. */
  47. #define FLACSTREAMINFO \
  48. int max_blocksize; /**< maximum block size, in samples */\
  49. int max_framesize; /**< maximum frame size, in bytes */\
  50. int samplerate; /**< sample rate */\
  51. int channels; /**< number of channels */\
  52. int bps; /**< bits-per-sample */\
  53. int64_t samples; /**< total number of samples */\
  54. typedef struct FLACStreaminfo {
  55. FLACSTREAMINFO
  56. } FLACStreaminfo;
  57. /**
  58. * Parse the Streaminfo metadata block
  59. * @param[out] avctx codec context to set basic stream parameters
  60. * @param[out] s where parsed information is stored
  61. * @param[in] buffer pointer to start of 34-byte streaminfo data
  62. */
  63. void ff_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s,
  64. const uint8_t *buffer);
  65. /**
  66. * Validate the FLAC extradata.
  67. * @param[in] avctx codec context containing the extradata.
  68. * @param[out] format extradata format.
  69. * @param[out] streaminfo_start pointer to start of 34-byte STREAMINFO data.
  70. * @return 1 if valid, 0 if not valid.
  71. */
  72. int ff_flac_is_extradata_valid(AVCodecContext *avctx,
  73. enum FLACExtradataFormat *format,
  74. uint8_t **streaminfo_start);
  75. /**
  76. * Parse the metadata block parameters from the header.
  77. * @param[in] block_header header data, at least 4 bytes
  78. * @param[out] last indicator for last metadata block
  79. * @param[out] type metadata block type
  80. * @param[out] size metadata block size
  81. */
  82. void ff_flac_parse_block_header(const uint8_t *block_header,
  83. int *last, int *type, int *size);
  84. #endif /* AVCODEC_FLAC_H */