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.

386 lines
12KB

  1. /*
  2. * MXF muxer
  3. * Copyright (c) 2008 GUCAS, Zhentan Feng <spyfeng at gmail dot com>
  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. * References
  23. * SMPTE 336M KLV Data Encoding Protocol Using Key-Length-Value
  24. * SMPTE 377M MXF File Format Specifications
  25. * SMPTE 379M MXF Generic Container
  26. * SMPTE 381M Mapping MPEG Streams into the MXF Generic Container
  27. * SMPTE RP210: SMPTE Metadata Dictionary
  28. * SMPTE RP224: Registry of SMPTE Universal Labels
  29. */
  30. //#define DEBUG
  31. #include "mxf.h"
  32. typedef struct {
  33. int local_tag;
  34. UID uid;
  35. } MXFLocalTagPair;
  36. typedef struct {
  37. UID track_essence_element_key;
  38. } MXFStreamContext;
  39. typedef struct MXFContext {
  40. int64_t header_byte_count;
  41. int64_t header_byte_count_offset;
  42. int64_t header_footer_partition_offset;
  43. int essence_container_count;
  44. } MXFContext;
  45. typedef struct {
  46. const UID key;
  47. int (*write)();
  48. enum CodecType type;
  49. } MXFDescriptorWriteTableEntry;
  50. static const uint8_t uuid_base[] = { 0xAD,0xAB,0x44,0x24,0x2f,0x25,0x4d,0xc7,0x92,0xff,0x29,0xbd };
  51. static const uint8_t umid_base[] = { 0x06,0x0A,0x2B,0x34,0x01,0x01,0x01,0x01,0x01,0x01,0x0F,0x00,0x13,0x00,0x00,0x00 };
  52. /**
  53. * complete key for operation pattern, partitions, and primer pack
  54. */
  55. static const uint8_t op1a_ul[] = { 0x06,0x0E,0x2B,0x34,0x04,0x01,0x01,0x01,0x0D,0x01,0x02,0x01,0x01,0x01,0x01,0x00 };
  56. static const uint8_t header_partition_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x05,0x01,0x01,0x0D,0x01,0x02,0x01,0x01,0x02,0x04,0x00 }; // ClosedComplete
  57. static const uint8_t footer_partition_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x05,0x01,0x01,0x0D,0x01,0x02,0x01,0x01,0x04,0x04,0x00 }; // ClosedComplete
  58. static const uint8_t primer_pack_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x05,0x01,0x01,0x0D,0x01,0x02,0x01,0x01,0x05,0x01,0x00 };
  59. /**
  60. * partial key for header metadata
  61. */
  62. static const uint8_t header_metadata_key[] = { 0x06,0x0E,0x2B,0x34,0x02,0x53,0x01,0x01,0x0D,0x01,0x01,0x01,0x01 };
  63. static const MXFCodecUL mxf_essence_element_key[] = {
  64. { { 0x06,0x0E,0x2B,0x34,0x01,0x02,0x01,0x01,0x0D,0x01,0x03,0x01,0x15,0x01,0x05,0x00 }, 14, CODEC_ID_MPEG2VIDEO},
  65. { { 0x06,0x0E,0x2B,0x34,0x01,0x02,0x01,0x01,0x0D,0x01,0x03,0x01,0x16,0x01,0x01,0x00 }, 14, CODEC_ID_PCM_S16LE},
  66. { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, 0, CODEC_ID_NONE},
  67. };
  68. static const uint8_t multiple_desc_ul[] = { 0x06,0x0E,0x2B,0x34,0x04,0x01,0x01,0x03,0x0D,0x01,0x03,0x01,0x02,0x7F,0x01,0x00 };
  69. static void mxf_write_uuid(ByteIOContext *pb, enum CodecID type, int value)
  70. {
  71. put_buffer(pb, uuid_base, 12);
  72. put_be16(pb, type);
  73. put_be16(pb, value);
  74. }
  75. static void mxf_write_umid(ByteIOContext *pb, enum CodecID type, int value)
  76. {
  77. put_buffer(pb, umid_base, 16);
  78. mxf_write_uuid(pb, type, value);
  79. }
  80. static void mxf_write_refs_count(ByteIOContext *pb, int ref_count)
  81. {
  82. put_be32(pb, ref_count);
  83. put_be32(pb, 16);
  84. }
  85. static int klv_encode_ber_length(ByteIOContext *pb, uint64_t len)
  86. {
  87. // Determine the best BER size
  88. int size;
  89. if (len < 128) {
  90. //short form
  91. put_byte(pb, len);
  92. return 1;
  93. }
  94. size = (av_log2(len) >> 3) + 1;
  95. // long form
  96. put_byte(pb, 0x80 + size);
  97. while(size) {
  98. size --;
  99. put_byte(pb, len >> 8 * size & 0xff);
  100. }
  101. return 0;
  102. }
  103. static const MXFCodecUL *mxf_get_essence_container_ul(enum CodecID type)
  104. {
  105. const MXFCodecUL *uls = ff_mxf_essence_container_uls;
  106. while (uls->id != CODEC_ID_NONE) {
  107. if (uls->id == type)
  108. break;
  109. uls++;
  110. }
  111. return uls;
  112. }
  113. static int mxf_write_primer_pack(AVFormatContext *s)
  114. {
  115. ByteIOContext *pb = s->pb;
  116. int local_tag_number, i = 0;
  117. local_tag_number = sizeof(mxf_local_tag_batch) / sizeof(MXFLocalTagPair);
  118. put_buffer(pb, primer_pack_key, 16);
  119. klv_encode_ber_length(pb, local_tag_number * 18 + 8);
  120. put_be32(pb, local_tag_number); // local_tag num
  121. put_be32(pb, 18); // item size, always 18 according to the specs
  122. for (i = 0; i < local_tag_number; i++) {
  123. put_be16(pb, mxf_local_tag_batch[i].local_tag);
  124. put_buffer(pb, mxf_local_tag_batch[i].uid, 16);
  125. }
  126. return 0;
  127. }
  128. static void mxf_write_local_tag(ByteIOContext *pb, int value_size, int tag)
  129. {
  130. put_be16(pb, tag);
  131. put_be16(pb, value_size);
  132. }
  133. static void mxf_write_metadata_key(ByteIOContext *pb, unsigned int value)
  134. {
  135. put_buffer(pb, header_metadata_key, 13);
  136. put_be24(pb, value);
  137. }
  138. static void mxf_free(AVFormatContext *s)
  139. {
  140. AVStream *st;
  141. int i;
  142. for (i = 0; i < s->nb_streams; i++) {
  143. st = s->streams[i];
  144. av_freep(&st->priv_data);
  145. }
  146. }
  147. static const MXFDataDefinitionUL *mxf_get_data_definition_ul(enum CodecType type)
  148. {
  149. const MXFDataDefinitionUL *uls = ff_mxf_data_definition_uls;
  150. while (uls->type != CODEC_TYPE_DATA) {
  151. if (type == uls->type)
  152. break;
  153. uls ++;
  154. }
  155. return uls;
  156. }
  157. static void mxf_write_common_fields( ByteIOContext *pb, AVStream *st)
  158. {
  159. const MXFDataDefinitionUL * data_def_ul;
  160. // find data define uls
  161. data_def_ul = mxf_get_data_definition_ul(st->codec->codec_type);
  162. mxf_write_local_tag(pb, 16, 0x0201);
  163. put_buffer(pb, data_def_ul->uid, 16);
  164. // write duration
  165. mxf_write_local_tag(pb, 8, 0x0202);
  166. put_be64(pb, st->duration);
  167. }
  168. static int mux_write_packet(AVFormatContext *s, AVPacket *pkt)
  169. {
  170. ByteIOContext *pb = s->pb;
  171. AVStream *st = s->streams[pkt->stream_index];
  172. MXFStreamContext *sc = st->priv_data;
  173. put_buffer(pb, sc->track_essence_element_key, 16); // write key
  174. klv_encode_ber_length(pb, pkt->size); // write length
  175. put_buffer(pb, pkt->data, pkt->size); // write value
  176. put_flush_packet(pb);
  177. return 0;
  178. }
  179. static void mxf_write_header_desc(ByteIOContext *pb, const MXFDescriptorWriteTableEntry *desc_tbl, AVStream *st)
  180. {
  181. const MXFCodecUL *codec_ul;
  182. put_buffer(pb, desc_tbl->key, 16);
  183. klv_encode_ber_length(pb, 96);
  184. mxf_write_local_tag(pb, 16, 0x3C0A);
  185. mxf_write_uuid(pb, SubDescriptor, st->index);
  186. mxf_write_local_tag(pb, 4, 0x3006);
  187. put_be32(pb, st->index);
  188. codec_ul = mxf_get_essence_container_ul(st->codec->codec_id);
  189. mxf_write_local_tag(pb, 16, 0x3004);
  190. put_buffer(pb, codec_ul->uid, 16);
  191. }
  192. static int mxf_write_mpeg_video_desc(AVFormatContext *s, const MXFDescriptorWriteTableEntry *desc_tbl, int stream_index)
  193. {
  194. ByteIOContext *pb = s->pb;
  195. AVStream *st;
  196. st = s->streams[stream_index];
  197. mxf_write_header_desc(pb, desc_tbl, st);
  198. mxf_write_local_tag(pb, 4, 0x3203);
  199. put_be32(pb, st->codec->width);
  200. mxf_write_local_tag(pb, 4, 0x3202);
  201. put_be32(pb, st->codec->height);
  202. mxf_write_local_tag(pb, 8, 0x320E);
  203. put_be32(pb, st->codec->height * st->codec->sample_aspect_ratio.den);
  204. put_be32(pb, st->codec->width * st->codec->sample_aspect_ratio.num);
  205. // tmp write, will modified later
  206. mxf_write_local_tag(pb, 16, 0x3201);
  207. put_buffer(pb, ff_mxf_codec_uls->uid, 16);
  208. return 0;
  209. }
  210. static int mxf_write_wav_desc(AVFormatContext *s, const MXFDescriptorWriteTableEntry *desc_tbl, int stream_index)
  211. {
  212. ByteIOContext *pb = s->pb;
  213. AVStream *st;
  214. st = s->streams[stream_index];
  215. mxf_write_header_desc(pb, desc_tbl, st);
  216. // write audio sampling rate
  217. mxf_write_local_tag(pb, 8, 0x3D03);
  218. put_be32(pb, st->codec->sample_rate);
  219. put_be32(pb, 1);
  220. mxf_write_local_tag(pb, 4, 0x3D07);
  221. put_be32(pb, st->codec->channels);
  222. mxf_write_local_tag(pb, 4, 0x3D01);
  223. put_be32(pb, st->codec->bits_per_sample);
  224. // tmp write, will modified later
  225. mxf_write_local_tag(pb, 16, 0x3201);
  226. put_buffer(pb, (ff_mxf_codec_uls + 8) ->uid, 16);
  227. return 0;
  228. }
  229. static const MXFDescriptorWriteTableEntry mxf_descriptor_write_table[] = {
  230. { { 0x06,0x0E,0x2B,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x51,0x00 }, mxf_write_mpeg_video_desc, CODEC_ID_MPEG2VIDEO},
  231. { { 0x06,0x0E,0x2B,0x34,0x02,0x53,0x01,0x01,0x0d,0x01,0x01,0x01,0x01,0x01,0x48,0x00 }, mxf_write_wav_desc, CODEC_ID_PCM_S16LE},
  232. { { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }, NULL, CODEC_ID_NONE},
  233. };
  234. static int mxf_build_structural_metadata(AVFormatContext *s, enum MXFMetadataSetType type)
  235. {
  236. int i;
  237. const MXFDescriptorWriteTableEntry *desc = NULL;
  238. int track_number_sign[sizeof(mxf_essence_element_key)/sizeof(MXFCodecUL)] = { 0 };
  239. if (mxf_write_package(s, type) < 0)
  240. return -1;
  241. if (type == SourcePackage) {
  242. if (mxf_write_multi_descriptor(s) < 0)
  243. return -1;
  244. }
  245. for (i = 0;i < s->nb_streams; i++) {
  246. if ( mxf_write_track(s, i, type, track_number_sign) < 0)
  247. return -1;
  248. if ( mxf_write_sequence(s, i, type) < 0)
  249. return -1;
  250. if ( mxf_write_structural_component(s, i, type) < 0)
  251. return -1;
  252. if (type == SourcePackage) {
  253. for (desc = mxf_descriptor_write_table; desc->write; desc++) {
  254. if (s->streams[i]->codec->codec_id == desc->type) {
  255. if ( desc->write(s, desc, i) < 0) {
  256. av_log(s, AV_LOG_ERROR, "error writing descriptor\n");
  257. return -1;
  258. }
  259. break;
  260. }
  261. }
  262. }
  263. }
  264. return 0;
  265. }
  266. static int mxf_write_header_metadata_sets(AVFormatContext *s)
  267. {
  268. AVStream *st;
  269. MXFStreamContext *sc = NULL;
  270. int i;
  271. if (mxf_write_preface(s) < 0)
  272. return -1;
  273. if (mxf_write_identification(s) < 0)
  274. return -1;
  275. if (mxf_write_content_storage(s) < 0)
  276. return -1;
  277. for (i = 0; i < s->nb_streams; i++) {
  278. st = s->streams[i];
  279. sc = av_mallocz(sizeof(MXFStreamContext));
  280. if (!sc)
  281. return AVERROR(ENOMEM);
  282. st->priv_data = sc;
  283. // set pts information
  284. if (st->codec->codec_type == CODEC_TYPE_VIDEO) {
  285. av_set_pts_info(st, 64, 1, st->codec->time_base.den);
  286. } else if (st->codec->codec_type == CODEC_TYPE_AUDIO) {
  287. av_set_pts_info(st, 64, 1, st->codec->sample_rate);
  288. }
  289. }
  290. if (mxf_build_structural_metadata(s, MaterialPackage) < 0)
  291. return -1;
  292. if (mxf_build_structural_metadata(s, SourcePackage) < 0)
  293. return -1;
  294. return 0;
  295. }
  296. static int mxf_update_header_partition(AVFormatContext *s, int64_t footer_partition_offset)
  297. {
  298. MXFContext *mxf = s->priv_data;
  299. ByteIOContext *pb = s->pb;
  300. url_fseek(pb, mxf->header_byte_count_offset, SEEK_SET);
  301. put_be64(pb, mxf->header_byte_count);
  302. put_flush_packet(pb);
  303. url_fseek(pb, mxf->header_footer_partition_offset, SEEK_SET);
  304. put_be64(pb, footer_partition_offset);
  305. put_flush_packet(pb);
  306. return 0;
  307. }
  308. AVOutputFormat mxf_muxer = {
  309. "mxf",
  310. NULL_IF_CONFIG_SMALL("Material eXchange Format"),
  311. NULL,
  312. "mxf",
  313. sizeof(MXFContext),
  314. CODEC_ID_PCM_S16LE,
  315. CODEC_ID_MPEG2VIDEO,
  316. mux_write_header,
  317. mux_write_packet,
  318. mux_write_footer,
  319. };