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.

89 lines
3.1KB

  1. /*
  2. * This file is part of Libav.
  3. *
  4. * Libav is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2.1 of the License, or (at your option) any later version.
  8. *
  9. * Libav is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with Libav; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. #ifndef AVCODEC_CBS_INTERNAL_H
  19. #define AVCODEC_CBS_INTERNAL_H
  20. #include "avcodec.h"
  21. #include "bitstream.h"
  22. #include "cbs.h"
  23. #include "put_bits.h"
  24. typedef struct CodedBitstreamType {
  25. enum AVCodecID codec_id;
  26. size_t priv_data_size;
  27. // Split frag->data into coded bitstream units, creating the
  28. // frag->units array. Fill data but not content on each unit.
  29. // The header argument should be set if the fragment came from
  30. // a header block, which may require different parsing for some
  31. // codecs (e.g. the AVCC header in H.264).
  32. int (*split_fragment)(CodedBitstreamContext *ctx,
  33. CodedBitstreamFragment *frag,
  34. int header);
  35. // Read the unit->data bitstream and decompose it, creating
  36. // unit->content.
  37. int (*read_unit)(CodedBitstreamContext *ctx,
  38. CodedBitstreamUnit *unit);
  39. // Write the unit->data bitstream from unit->content.
  40. int (*write_unit)(CodedBitstreamContext *ctx,
  41. CodedBitstreamUnit *unit);
  42. // Read the data from all of frag->units and assemble it into
  43. // a bitstream for the whole fragment.
  44. int (*assemble_fragment)(CodedBitstreamContext *ctx,
  45. CodedBitstreamFragment *frag);
  46. // Free the codec internal state.
  47. void (*close)(CodedBitstreamContext *ctx);
  48. } CodedBitstreamType;
  49. // Helper functions for trace output.
  50. void ff_cbs_trace_header(CodedBitstreamContext *ctx,
  51. const char *name);
  52. void ff_cbs_trace_syntax_element(CodedBitstreamContext *ctx,
  53. int position, const char *name,
  54. const char *bitstring, int64_t value);
  55. // Helper functions for read/write of common bitstream elements, including
  56. // generation of trace output.
  57. int ff_cbs_read_unsigned(CodedBitstreamContext *ctx, BitstreamContext *bc,
  58. int width, const char *name, uint32_t *write_to,
  59. uint32_t range_min, uint32_t range_max);
  60. int ff_cbs_write_unsigned(CodedBitstreamContext *ctx, PutBitContext *pbc,
  61. int width, const char *name, uint32_t value,
  62. uint32_t range_min, uint32_t range_max);
  63. extern const CodedBitstreamType ff_cbs_type_h264;
  64. extern const CodedBitstreamType ff_cbs_type_h265;
  65. extern const CodedBitstreamType ff_cbs_type_mpeg2;
  66. #endif /* AVCODEC_CBS_INTERNAL_H */