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.

136 lines
4.6KB

  1. /*
  2. * "NUT" Container Format (de)muxer
  3. * Copyright (c) 2006 Michael Niedermayer
  4. *
  5. * This file is part of Libav.
  6. *
  7. * Libav 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. * Libav 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 Libav; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. */
  21. #ifndef AVFORMAT_NUT_H
  22. #define AVFORMAT_NUT_H
  23. #include "avformat.h"
  24. #include "internal.h"
  25. #include "metadata.h"
  26. #define MAIN_STARTCODE (0x7A561F5F04ADULL + (((uint64_t)('N'<<8) + 'M')<<48))
  27. #define STREAM_STARTCODE (0x11405BF2F9DBULL + (((uint64_t)('N'<<8) + 'S')<<48))
  28. #define SYNCPOINT_STARTCODE (0xE4ADEECA4569ULL + (((uint64_t)('N'<<8) + 'K')<<48))
  29. #define INDEX_STARTCODE (0xDD672F23E64EULL + (((uint64_t)('N'<<8) + 'X')<<48))
  30. #define INFO_STARTCODE (0xAB68B596BA78ULL + (((uint64_t)('N'<<8) + 'I')<<48))
  31. #define ID_STRING "nut/multimedia container\0"
  32. #define MAX_DISTANCE (1024*32-1)
  33. #define NUT_MAX_VERSION 4
  34. #define NUT_STABLE_VERSION 3
  35. #define NUT_MIN_VERSION 2
  36. typedef enum{
  37. FLAG_KEY = 1, // if set, frame is keyframe
  38. FLAG_EOR = 2, // if set, stream has no relevance on presentation. (EOR)
  39. FLAG_CODED_PTS = 8, // if set, coded_pts is in the frame header
  40. FLAG_STREAM_ID = 16, // if set, stream_id is coded in the frame header
  41. FLAG_SIZE_MSB = 32, // if set, data_size_msb is at frame header, otherwise data_size_msb is 0
  42. FLAG_CHECKSUM = 64, // if set, the frame header contains a checksum
  43. FLAG_RESERVED = 128, // if set, reserved_count is coded in the frame header
  44. FLAG_HEADER_IDX =1024, // If set, header_idx is coded in the frame header.
  45. FLAG_MATCH_TIME =2048, // If set, match_time_delta is coded in the frame header
  46. FLAG_CODED =4096, // if set, coded_flags are stored in the frame header
  47. FLAG_INVALID =8192, // if set, frame_code is invalid
  48. } Flag;
  49. typedef struct Syncpoint {
  50. uint64_t pos;
  51. uint64_t back_ptr;
  52. // uint64_t global_key_pts;
  53. int64_t ts;
  54. } Syncpoint;
  55. typedef struct FrameCode {
  56. uint16_t flags;
  57. uint8_t stream_id;
  58. uint16_t size_mul;
  59. uint16_t size_lsb;
  60. int16_t pts_delta;
  61. uint8_t reserved_count;
  62. uint8_t header_idx;
  63. } FrameCode;
  64. typedef struct StreamContext {
  65. int last_flags;
  66. int skip_until_key_frame;
  67. int64_t last_pts;
  68. int time_base_id;
  69. AVRational *time_base;
  70. int msb_pts_shift;
  71. int max_pts_distance;
  72. int decode_delay; //FIXME duplicate of has_b_frames
  73. } StreamContext;
  74. typedef struct ChapterContext {
  75. AVRational *time_base;
  76. } ChapterContext;
  77. typedef struct NUTContext {
  78. const AVClass *av_class;
  79. AVFormatContext *avf;
  80. // int written_packet_size;
  81. // int64_t packet_start;
  82. FrameCode frame_code[256];
  83. uint8_t header_len[128];
  84. const uint8_t *header[128];
  85. uint64_t next_startcode; // stores the next startcode if it has already been parsed but the stream is not seekable
  86. StreamContext *stream;
  87. ChapterContext *chapter;
  88. unsigned int max_distance;
  89. unsigned int time_base_count;
  90. int64_t last_syncpoint_pos;
  91. int header_count;
  92. AVRational *time_base;
  93. struct AVTreeNode *syncpoints;
  94. #define NUT_BROADCAST 1 // use extended syncpoints
  95. #define NUT_PIPE 2 // do not write syncpoints
  96. int flags;
  97. int version; // version currently in use
  98. } NUTContext;
  99. extern const AVCodecTag ff_nut_subtitle_tags[];
  100. extern const AVCodecTag ff_nut_video_tags[];
  101. extern const AVCodecTag ff_nut_audio_tags[];
  102. extern const AVCodecTag ff_nut_data_tags[];
  103. extern const AVCodecTag * const ff_nut_codec_tags[];
  104. typedef struct Dispositions {
  105. char str[9];
  106. int flag;
  107. } Dispositions;
  108. void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val);
  109. int64_t ff_lsb2full(StreamContext *stream, int64_t lsb);
  110. int ff_nut_sp_pos_cmp(const Syncpoint *a, const Syncpoint *b);
  111. int ff_nut_sp_pts_cmp(const Syncpoint *a, const Syncpoint *b);
  112. int ff_nut_add_sp(NUTContext *nut, int64_t pos, int64_t back_ptr, int64_t ts);
  113. void ff_nut_free_sp(NUTContext *nut);
  114. extern const Dispositions ff_nut_dispositions[];
  115. extern const AVMetadataConv ff_nut_metadata_conv[];
  116. #endif /* AVFORMAT_NUT_H */