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.

505 lines
16KB

  1. /*
  2. * RAW muxers
  3. * Copyright (c) 2001 Fabrice Bellard
  4. * Copyright (c) 2005 Alex Beregszaszi
  5. *
  6. * This file is part of FFmpeg.
  7. *
  8. * FFmpeg is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU Lesser General Public
  10. * License as published by the Free Software Foundation; either
  11. * version 2.1 of the License, or (at your option) any later version.
  12. *
  13. * FFmpeg is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * Lesser General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public
  19. * License along with FFmpeg; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  21. */
  22. #include "libavutil/intreadwrite.h"
  23. #include "avformat.h"
  24. #include "rawenc.h"
  25. #include "internal.h"
  26. int ff_raw_write_packet(AVFormatContext *s, AVPacket *pkt)
  27. {
  28. avio_write(s->pb, pkt->data, pkt->size);
  29. return 0;
  30. }
  31. static int force_one_stream(AVFormatContext *s)
  32. {
  33. if (s->nb_streams != 1) {
  34. av_log(s, AV_LOG_ERROR, "%s files have exactly one stream\n",
  35. s->oformat->name);
  36. return AVERROR(EINVAL);
  37. }
  38. if ( s->oformat->audio_codec != AV_CODEC_ID_NONE
  39. && s->streams[0]->codecpar->codec_type != AVMEDIA_TYPE_AUDIO) {
  40. av_log(s, AV_LOG_ERROR, "%s files have exactly one audio stream\n",
  41. s->oformat->name);
  42. return AVERROR(EINVAL);
  43. }
  44. if ( s->oformat->video_codec != AV_CODEC_ID_NONE
  45. && s->streams[0]->codecpar->codec_type != AVMEDIA_TYPE_VIDEO) {
  46. av_log(s, AV_LOG_ERROR, "%s files have exactly one video stream\n",
  47. s->oformat->name);
  48. return AVERROR(EINVAL);
  49. }
  50. return 0;
  51. }
  52. /* Note: Do not forget to add new entries to the Makefile as well. */
  53. #if CONFIG_AC3_MUXER
  54. AVOutputFormat ff_ac3_muxer = {
  55. .name = "ac3",
  56. .long_name = NULL_IF_CONFIG_SMALL("raw AC-3"),
  57. .mime_type = "audio/x-ac3",
  58. .extensions = "ac3",
  59. .audio_codec = AV_CODEC_ID_AC3,
  60. .video_codec = AV_CODEC_ID_NONE,
  61. .write_header = force_one_stream,
  62. .write_packet = ff_raw_write_packet,
  63. .flags = AVFMT_NOTIMESTAMPS,
  64. };
  65. #endif
  66. #if CONFIG_ADX_MUXER
  67. static int adx_write_trailer(AVFormatContext *s)
  68. {
  69. AVIOContext *pb = s->pb;
  70. AVCodecParameters *par = s->streams[0]->codecpar;
  71. if (pb->seekable & AVIO_SEEKABLE_NORMAL) {
  72. int64_t file_size = avio_tell(pb);
  73. uint64_t sample_count = (file_size - 36) / par->channels / 18 * 32;
  74. if (sample_count <= UINT32_MAX) {
  75. avio_seek(pb, 12, SEEK_SET);
  76. avio_wb32(pb, sample_count);
  77. avio_seek(pb, file_size, SEEK_SET);
  78. }
  79. }
  80. return 0;
  81. }
  82. AVOutputFormat ff_adx_muxer = {
  83. .name = "adx",
  84. .long_name = NULL_IF_CONFIG_SMALL("CRI ADX"),
  85. .extensions = "adx",
  86. .audio_codec = AV_CODEC_ID_ADPCM_ADX,
  87. .video_codec = AV_CODEC_ID_NONE,
  88. .write_header = force_one_stream,
  89. .write_packet = ff_raw_write_packet,
  90. .write_trailer = adx_write_trailer,
  91. .flags = AVFMT_NOTIMESTAMPS,
  92. };
  93. #endif
  94. #if CONFIG_APTX_MUXER
  95. AVOutputFormat ff_aptx_muxer = {
  96. .name = "aptx",
  97. .long_name = NULL_IF_CONFIG_SMALL("raw aptX (Audio Processing Technology for Bluetooth)"),
  98. .extensions = "aptx",
  99. .audio_codec = AV_CODEC_ID_APTX,
  100. .video_codec = AV_CODEC_ID_NONE,
  101. .write_header = force_one_stream,
  102. .write_packet = ff_raw_write_packet,
  103. .flags = AVFMT_NOTIMESTAMPS,
  104. };
  105. #endif
  106. #if CONFIG_APTX_HD_MUXER
  107. AVOutputFormat ff_aptx_hd_muxer = {
  108. .name = "aptx_hd",
  109. .long_name = NULL_IF_CONFIG_SMALL("raw aptX HD (Audio Processing Technology for Bluetooth)"),
  110. .extensions = "aptxhd",
  111. .audio_codec = AV_CODEC_ID_APTX_HD,
  112. .video_codec = AV_CODEC_ID_NONE,
  113. .write_header = force_one_stream,
  114. .write_packet = ff_raw_write_packet,
  115. .flags = AVFMT_NOTIMESTAMPS,
  116. };
  117. #endif
  118. #if CONFIG_CAVSVIDEO_MUXER
  119. AVOutputFormat ff_cavsvideo_muxer = {
  120. .name = "cavsvideo",
  121. .long_name = NULL_IF_CONFIG_SMALL("raw Chinese AVS (Audio Video Standard) video"),
  122. .extensions = "cavs",
  123. .audio_codec = AV_CODEC_ID_NONE,
  124. .video_codec = AV_CODEC_ID_CAVS,
  125. .write_header = force_one_stream,
  126. .write_packet = ff_raw_write_packet,
  127. .flags = AVFMT_NOTIMESTAMPS,
  128. };
  129. #endif
  130. #if CONFIG_CODEC2RAW_MUXER
  131. AVOutputFormat ff_codec2raw_muxer = {
  132. .name = "codec2raw",
  133. .long_name = NULL_IF_CONFIG_SMALL("raw codec2 muxer"),
  134. .audio_codec = AV_CODEC_ID_CODEC2,
  135. .video_codec = AV_CODEC_ID_NONE,
  136. .write_header = force_one_stream,
  137. .write_packet = ff_raw_write_packet,
  138. .flags = AVFMT_NOTIMESTAMPS,
  139. };
  140. #endif
  141. #if CONFIG_DATA_MUXER
  142. AVOutputFormat ff_data_muxer = {
  143. .name = "data",
  144. .long_name = NULL_IF_CONFIG_SMALL("raw data"),
  145. .write_header = force_one_stream,
  146. .write_packet = ff_raw_write_packet,
  147. .flags = AVFMT_NOTIMESTAMPS,
  148. };
  149. #endif
  150. #if CONFIG_DIRAC_MUXER
  151. AVOutputFormat ff_dirac_muxer = {
  152. .name = "dirac",
  153. .long_name = NULL_IF_CONFIG_SMALL("raw Dirac"),
  154. .extensions = "drc,vc2",
  155. .audio_codec = AV_CODEC_ID_NONE,
  156. .video_codec = AV_CODEC_ID_DIRAC,
  157. .write_header = force_one_stream,
  158. .write_packet = ff_raw_write_packet,
  159. .flags = AVFMT_NOTIMESTAMPS,
  160. };
  161. #endif
  162. #if CONFIG_DNXHD_MUXER
  163. AVOutputFormat ff_dnxhd_muxer = {
  164. .name = "dnxhd",
  165. .long_name = NULL_IF_CONFIG_SMALL("raw DNxHD (SMPTE VC-3)"),
  166. .extensions = "dnxhd,dnxhr",
  167. .audio_codec = AV_CODEC_ID_NONE,
  168. .video_codec = AV_CODEC_ID_DNXHD,
  169. .write_header = force_one_stream,
  170. .write_packet = ff_raw_write_packet,
  171. .flags = AVFMT_NOTIMESTAMPS,
  172. };
  173. #endif
  174. #if CONFIG_DTS_MUXER
  175. AVOutputFormat ff_dts_muxer = {
  176. .name = "dts",
  177. .long_name = NULL_IF_CONFIG_SMALL("raw DTS"),
  178. .mime_type = "audio/x-dca",
  179. .extensions = "dts",
  180. .audio_codec = AV_CODEC_ID_DTS,
  181. .video_codec = AV_CODEC_ID_NONE,
  182. .write_header = force_one_stream,
  183. .write_packet = ff_raw_write_packet,
  184. .flags = AVFMT_NOTIMESTAMPS,
  185. };
  186. #endif
  187. #if CONFIG_EAC3_MUXER
  188. AVOutputFormat ff_eac3_muxer = {
  189. .name = "eac3",
  190. .long_name = NULL_IF_CONFIG_SMALL("raw E-AC-3"),
  191. .mime_type = "audio/x-eac3",
  192. .extensions = "eac3",
  193. .audio_codec = AV_CODEC_ID_EAC3,
  194. .video_codec = AV_CODEC_ID_NONE,
  195. .write_header = force_one_stream,
  196. .write_packet = ff_raw_write_packet,
  197. .flags = AVFMT_NOTIMESTAMPS,
  198. };
  199. #endif
  200. #if CONFIG_G722_MUXER
  201. AVOutputFormat ff_g722_muxer = {
  202. .name = "g722",
  203. .long_name = NULL_IF_CONFIG_SMALL("raw G.722"),
  204. .mime_type = "audio/G722",
  205. .extensions = "g722",
  206. .audio_codec = AV_CODEC_ID_ADPCM_G722,
  207. .video_codec = AV_CODEC_ID_NONE,
  208. .write_header = force_one_stream,
  209. .write_packet = ff_raw_write_packet,
  210. .flags = AVFMT_NOTIMESTAMPS,
  211. };
  212. #endif
  213. #if CONFIG_G723_1_MUXER
  214. AVOutputFormat ff_g723_1_muxer = {
  215. .name = "g723_1",
  216. .long_name = NULL_IF_CONFIG_SMALL("raw G.723.1"),
  217. .mime_type = "audio/g723",
  218. .extensions = "tco,rco",
  219. .audio_codec = AV_CODEC_ID_G723_1,
  220. .video_codec = AV_CODEC_ID_NONE,
  221. .write_header = force_one_stream,
  222. .write_packet = ff_raw_write_packet,
  223. .flags = AVFMT_NOTIMESTAMPS,
  224. };
  225. #endif
  226. #if CONFIG_G726_MUXER
  227. AVOutputFormat ff_g726_muxer = {
  228. .name = "g726",
  229. .long_name = NULL_IF_CONFIG_SMALL("raw big-endian G.726 (\"left-justified\")"),
  230. .audio_codec = AV_CODEC_ID_ADPCM_G726,
  231. .video_codec = AV_CODEC_ID_NONE,
  232. .write_header = force_one_stream,
  233. .write_packet = ff_raw_write_packet,
  234. .flags = AVFMT_NOTIMESTAMPS,
  235. };
  236. #endif
  237. #if CONFIG_G726LE_MUXER
  238. AVOutputFormat ff_g726le_muxer = {
  239. .name = "g726le",
  240. .long_name = NULL_IF_CONFIG_SMALL("raw little-endian G.726 (\"right-justified\")"),
  241. .audio_codec = AV_CODEC_ID_ADPCM_G726LE,
  242. .video_codec = AV_CODEC_ID_NONE,
  243. .write_header = force_one_stream,
  244. .write_packet = ff_raw_write_packet,
  245. .flags = AVFMT_NOTIMESTAMPS,
  246. };
  247. #endif
  248. #if CONFIG_GSM_MUXER
  249. AVOutputFormat ff_gsm_muxer = {
  250. .name = "gsm",
  251. .long_name = NULL_IF_CONFIG_SMALL("raw GSM"),
  252. .mime_type = "audio/x-gsm",
  253. .extensions = "gsm",
  254. .audio_codec = AV_CODEC_ID_GSM,
  255. .video_codec = AV_CODEC_ID_NONE,
  256. .write_header = force_one_stream,
  257. .write_packet = ff_raw_write_packet,
  258. .flags = AVFMT_NOTIMESTAMPS,
  259. };
  260. #endif
  261. #if CONFIG_H261_MUXER
  262. AVOutputFormat ff_h261_muxer = {
  263. .name = "h261",
  264. .long_name = NULL_IF_CONFIG_SMALL("raw H.261"),
  265. .mime_type = "video/x-h261",
  266. .extensions = "h261",
  267. .audio_codec = AV_CODEC_ID_NONE,
  268. .video_codec = AV_CODEC_ID_H261,
  269. .write_header = force_one_stream,
  270. .write_packet = ff_raw_write_packet,
  271. .flags = AVFMT_NOTIMESTAMPS,
  272. };
  273. #endif
  274. #if CONFIG_H263_MUXER
  275. AVOutputFormat ff_h263_muxer = {
  276. .name = "h263",
  277. .long_name = NULL_IF_CONFIG_SMALL("raw H.263"),
  278. .mime_type = "video/x-h263",
  279. .extensions = "h263",
  280. .audio_codec = AV_CODEC_ID_NONE,
  281. .video_codec = AV_CODEC_ID_H263,
  282. .write_header = force_one_stream,
  283. .write_packet = ff_raw_write_packet,
  284. .flags = AVFMT_NOTIMESTAMPS,
  285. };
  286. #endif
  287. #if CONFIG_H264_MUXER
  288. static int h264_check_bitstream(struct AVFormatContext *s, const AVPacket *pkt)
  289. {
  290. AVStream *st = s->streams[0];
  291. if (pkt->size >= 5 && AV_RB32(pkt->data) != 0x0000001 &&
  292. AV_RB24(pkt->data) != 0x000001)
  293. return ff_stream_add_bitstream_filter(st, "h264_mp4toannexb", NULL);
  294. return 1;
  295. }
  296. AVOutputFormat ff_h264_muxer = {
  297. .name = "h264",
  298. .long_name = NULL_IF_CONFIG_SMALL("raw H.264 video"),
  299. .extensions = "h264,264",
  300. .audio_codec = AV_CODEC_ID_NONE,
  301. .video_codec = AV_CODEC_ID_H264,
  302. .write_header = force_one_stream,
  303. .write_packet = ff_raw_write_packet,
  304. .check_bitstream = h264_check_bitstream,
  305. .flags = AVFMT_NOTIMESTAMPS,
  306. };
  307. #endif
  308. #if CONFIG_HEVC_MUXER
  309. static int hevc_check_bitstream(struct AVFormatContext *s, const AVPacket *pkt)
  310. {
  311. AVStream *st = s->streams[0];
  312. if (pkt->size >= 5 && AV_RB32(pkt->data) != 0x0000001 &&
  313. AV_RB24(pkt->data) != 0x000001)
  314. return ff_stream_add_bitstream_filter(st, "hevc_mp4toannexb", NULL);
  315. return 1;
  316. }
  317. AVOutputFormat ff_hevc_muxer = {
  318. .name = "hevc",
  319. .long_name = NULL_IF_CONFIG_SMALL("raw HEVC video"),
  320. .extensions = "hevc,h265,265",
  321. .audio_codec = AV_CODEC_ID_NONE,
  322. .video_codec = AV_CODEC_ID_HEVC,
  323. .write_header = force_one_stream,
  324. .write_packet = ff_raw_write_packet,
  325. .check_bitstream = hevc_check_bitstream,
  326. .flags = AVFMT_NOTIMESTAMPS,
  327. };
  328. #endif
  329. #if CONFIG_M4V_MUXER
  330. AVOutputFormat ff_m4v_muxer = {
  331. .name = "m4v",
  332. .long_name = NULL_IF_CONFIG_SMALL("raw MPEG-4 video"),
  333. .extensions = "m4v",
  334. .audio_codec = AV_CODEC_ID_NONE,
  335. .video_codec = AV_CODEC_ID_MPEG4,
  336. .write_header = force_one_stream,
  337. .write_packet = ff_raw_write_packet,
  338. .flags = AVFMT_NOTIMESTAMPS,
  339. };
  340. #endif
  341. #if CONFIG_MJPEG_MUXER
  342. AVOutputFormat ff_mjpeg_muxer = {
  343. .name = "mjpeg",
  344. .long_name = NULL_IF_CONFIG_SMALL("raw MJPEG video"),
  345. .mime_type = "video/x-mjpeg",
  346. .extensions = "mjpg,mjpeg",
  347. .audio_codec = AV_CODEC_ID_NONE,
  348. .video_codec = AV_CODEC_ID_MJPEG,
  349. .write_header = force_one_stream,
  350. .write_packet = ff_raw_write_packet,
  351. .flags = AVFMT_NOTIMESTAMPS,
  352. };
  353. #endif
  354. #if CONFIG_SINGLEJPEG_MUXER
  355. AVOutputFormat ff_singlejpeg_muxer = {
  356. .name = "singlejpeg",
  357. .long_name = NULL_IF_CONFIG_SMALL("JPEG single image"),
  358. .mime_type = "image/jpeg",
  359. .audio_codec = AV_CODEC_ID_NONE,
  360. .video_codec = AV_CODEC_ID_MJPEG,
  361. .write_packet = ff_raw_write_packet,
  362. .flags = AVFMT_NOTIMESTAMPS,
  363. .write_header = force_one_stream,
  364. };
  365. #endif
  366. #if CONFIG_MLP_MUXER
  367. AVOutputFormat ff_mlp_muxer = {
  368. .name = "mlp",
  369. .long_name = NULL_IF_CONFIG_SMALL("raw MLP"),
  370. .extensions = "mlp",
  371. .audio_codec = AV_CODEC_ID_MLP,
  372. .video_codec = AV_CODEC_ID_NONE,
  373. .write_header = force_one_stream,
  374. .write_packet = ff_raw_write_packet,
  375. .flags = AVFMT_NOTIMESTAMPS,
  376. };
  377. #endif
  378. #if CONFIG_MP2_MUXER
  379. AVOutputFormat ff_mp2_muxer = {
  380. .name = "mp2",
  381. .long_name = NULL_IF_CONFIG_SMALL("MP2 (MPEG audio layer 2)"),
  382. .mime_type = "audio/mpeg",
  383. .extensions = "mp2,m2a,mpa",
  384. .audio_codec = AV_CODEC_ID_MP2,
  385. .video_codec = AV_CODEC_ID_NONE,
  386. .write_packet = ff_raw_write_packet,
  387. .flags = AVFMT_NOTIMESTAMPS,
  388. };
  389. #endif
  390. #if CONFIG_MPEG1VIDEO_MUXER
  391. AVOutputFormat ff_mpeg1video_muxer = {
  392. .name = "mpeg1video",
  393. .long_name = NULL_IF_CONFIG_SMALL("raw MPEG-1 video"),
  394. .mime_type = "video/mpeg",
  395. .extensions = "mpg,mpeg,m1v",
  396. .audio_codec = AV_CODEC_ID_NONE,
  397. .video_codec = AV_CODEC_ID_MPEG1VIDEO,
  398. .write_header = force_one_stream,
  399. .write_packet = ff_raw_write_packet,
  400. .flags = AVFMT_NOTIMESTAMPS,
  401. };
  402. #endif
  403. #if CONFIG_MPEG2VIDEO_MUXER
  404. AVOutputFormat ff_mpeg2video_muxer = {
  405. .name = "mpeg2video",
  406. .long_name = NULL_IF_CONFIG_SMALL("raw MPEG-2 video"),
  407. .extensions = "m2v",
  408. .audio_codec = AV_CODEC_ID_NONE,
  409. .video_codec = AV_CODEC_ID_MPEG2VIDEO,
  410. .write_header = force_one_stream,
  411. .write_packet = ff_raw_write_packet,
  412. .flags = AVFMT_NOTIMESTAMPS,
  413. };
  414. #endif
  415. #if CONFIG_RAWVIDEO_MUXER
  416. AVOutputFormat ff_rawvideo_muxer = {
  417. .name = "rawvideo",
  418. .long_name = NULL_IF_CONFIG_SMALL("raw video"),
  419. .extensions = "yuv,rgb",
  420. .audio_codec = AV_CODEC_ID_NONE,
  421. .video_codec = AV_CODEC_ID_RAWVIDEO,
  422. .write_packet = ff_raw_write_packet,
  423. .flags = AVFMT_NOTIMESTAMPS,
  424. };
  425. #endif
  426. #if CONFIG_SBC_MUXER
  427. AVOutputFormat ff_sbc_muxer = {
  428. .name = "sbc",
  429. .long_name = NULL_IF_CONFIG_SMALL("raw SBC"),
  430. .mime_type = "audio/x-sbc",
  431. .extensions = "sbc,msbc",
  432. .audio_codec = AV_CODEC_ID_SBC,
  433. .write_header = force_one_stream,
  434. .write_packet = ff_raw_write_packet,
  435. .flags = AVFMT_NOTIMESTAMPS,
  436. };
  437. #endif
  438. #if CONFIG_TRUEHD_MUXER
  439. AVOutputFormat ff_truehd_muxer = {
  440. .name = "truehd",
  441. .long_name = NULL_IF_CONFIG_SMALL("raw TrueHD"),
  442. .extensions = "thd",
  443. .audio_codec = AV_CODEC_ID_TRUEHD,
  444. .video_codec = AV_CODEC_ID_NONE,
  445. .write_header = force_one_stream,
  446. .write_packet = ff_raw_write_packet,
  447. .flags = AVFMT_NOTIMESTAMPS,
  448. };
  449. #endif
  450. #if CONFIG_VC1_MUXER
  451. AVOutputFormat ff_vc1_muxer = {
  452. .name = "vc1",
  453. .long_name = NULL_IF_CONFIG_SMALL("raw VC-1 video"),
  454. .extensions = "vc1",
  455. .audio_codec = AV_CODEC_ID_NONE,
  456. .video_codec = AV_CODEC_ID_VC1,
  457. .write_header = force_one_stream,
  458. .write_packet = ff_raw_write_packet,
  459. .flags = AVFMT_NOTIMESTAMPS,
  460. };
  461. #endif