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.

98 lines
3.6KB

  1. /*
  2. * This file is part of FFmpeg.
  3. *
  4. * FFmpeg 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. * FFmpeg 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 FFmpeg; 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 "cbs.h"
  22. #include "get_bits.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, int position,
  53. const char *name, const int *subscripts,
  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, GetBitContext *gbc,
  58. int width, const char *name,
  59. const int *subscripts, uint32_t *write_to,
  60. uint32_t range_min, uint32_t range_max);
  61. int ff_cbs_write_unsigned(CodedBitstreamContext *ctx, PutBitContext *pbc,
  62. int width, const char *name,
  63. const int *subscripts, uint32_t value,
  64. uint32_t range_min, uint32_t range_max);
  65. // The largest value representable in N bits, suitable for use as
  66. // range_max in the above functions.
  67. #define MAX_UINT_BITS(length) ((UINT64_C(1) << (length)) - 1)
  68. extern const CodedBitstreamType ff_cbs_type_av1;
  69. extern const CodedBitstreamType ff_cbs_type_h264;
  70. extern const CodedBitstreamType ff_cbs_type_h265;
  71. extern const CodedBitstreamType ff_cbs_type_jpeg;
  72. extern const CodedBitstreamType ff_cbs_type_mpeg2;
  73. extern const CodedBitstreamType ff_cbs_type_vp9;
  74. #endif /* AVCODEC_CBS_INTERNAL_H */