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.

417 lines
13KB

  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. return 0;
  39. }
  40. /* Note: Do not forget to add new entries to the Makefile as well. */
  41. #if CONFIG_AC3_MUXER
  42. AVOutputFormat ff_ac3_muxer = {
  43. .name = "ac3",
  44. .long_name = NULL_IF_CONFIG_SMALL("raw AC-3"),
  45. .mime_type = "audio/x-ac3",
  46. .extensions = "ac3",
  47. .audio_codec = AV_CODEC_ID_AC3,
  48. .video_codec = AV_CODEC_ID_NONE,
  49. .write_header = force_one_stream,
  50. .write_packet = ff_raw_write_packet,
  51. .flags = AVFMT_NOTIMESTAMPS,
  52. };
  53. #endif
  54. #if CONFIG_ADX_MUXER
  55. static int adx_write_trailer(AVFormatContext *s)
  56. {
  57. AVIOContext *pb = s->pb;
  58. AVCodecParameters *par = s->streams[0]->codecpar;
  59. if (pb->seekable) {
  60. int64_t file_size = avio_tell(pb);
  61. uint64_t sample_count = (file_size - 36) / par->channels / 18 * 32;
  62. if (sample_count <= UINT32_MAX) {
  63. avio_seek(pb, 12, SEEK_SET);
  64. avio_wb32(pb, sample_count);
  65. avio_seek(pb, file_size, SEEK_SET);
  66. }
  67. }
  68. return 0;
  69. }
  70. AVOutputFormat ff_adx_muxer = {
  71. .name = "adx",
  72. .long_name = NULL_IF_CONFIG_SMALL("CRI ADX"),
  73. .extensions = "adx",
  74. .audio_codec = AV_CODEC_ID_ADPCM_ADX,
  75. .video_codec = AV_CODEC_ID_NONE,
  76. .write_header = force_one_stream,
  77. .write_packet = ff_raw_write_packet,
  78. .write_trailer = adx_write_trailer,
  79. .flags = AVFMT_NOTIMESTAMPS,
  80. };
  81. #endif
  82. #if CONFIG_CAVSVIDEO_MUXER
  83. AVOutputFormat ff_cavsvideo_muxer = {
  84. .name = "cavsvideo",
  85. .long_name = NULL_IF_CONFIG_SMALL("raw Chinese AVS (Audio Video Standard) video"),
  86. .extensions = "cavs",
  87. .audio_codec = AV_CODEC_ID_NONE,
  88. .video_codec = AV_CODEC_ID_CAVS,
  89. .write_header = force_one_stream,
  90. .write_packet = ff_raw_write_packet,
  91. .flags = AVFMT_NOTIMESTAMPS,
  92. };
  93. #endif
  94. #if CONFIG_DATA_MUXER
  95. AVOutputFormat ff_data_muxer = {
  96. .name = "data",
  97. .long_name = NULL_IF_CONFIG_SMALL("raw data"),
  98. .write_header = force_one_stream,
  99. .write_packet = ff_raw_write_packet,
  100. .flags = AVFMT_NOTIMESTAMPS,
  101. };
  102. #endif
  103. #if CONFIG_DIRAC_MUXER
  104. AVOutputFormat ff_dirac_muxer = {
  105. .name = "dirac",
  106. .long_name = NULL_IF_CONFIG_SMALL("raw Dirac"),
  107. .extensions = "drc,vc2",
  108. .audio_codec = AV_CODEC_ID_NONE,
  109. .video_codec = AV_CODEC_ID_DIRAC,
  110. .write_header = force_one_stream,
  111. .write_packet = ff_raw_write_packet,
  112. .flags = AVFMT_NOTIMESTAMPS,
  113. };
  114. #endif
  115. #if CONFIG_DNXHD_MUXER
  116. AVOutputFormat ff_dnxhd_muxer = {
  117. .name = "dnxhd",
  118. .long_name = NULL_IF_CONFIG_SMALL("raw DNxHD (SMPTE VC-3)"),
  119. .extensions = "dnxhd,dnxhr",
  120. .audio_codec = AV_CODEC_ID_NONE,
  121. .video_codec = AV_CODEC_ID_DNXHD,
  122. .write_header = force_one_stream,
  123. .write_packet = ff_raw_write_packet,
  124. .flags = AVFMT_NOTIMESTAMPS,
  125. };
  126. #endif
  127. #if CONFIG_DTS_MUXER
  128. AVOutputFormat ff_dts_muxer = {
  129. .name = "dts",
  130. .long_name = NULL_IF_CONFIG_SMALL("raw DTS"),
  131. .mime_type = "audio/x-dca",
  132. .extensions = "dts",
  133. .audio_codec = AV_CODEC_ID_DTS,
  134. .video_codec = AV_CODEC_ID_NONE,
  135. .write_header = force_one_stream,
  136. .write_packet = ff_raw_write_packet,
  137. .flags = AVFMT_NOTIMESTAMPS,
  138. };
  139. #endif
  140. #if CONFIG_EAC3_MUXER
  141. AVOutputFormat ff_eac3_muxer = {
  142. .name = "eac3",
  143. .long_name = NULL_IF_CONFIG_SMALL("raw E-AC-3"),
  144. .mime_type = "audio/x-eac3",
  145. .extensions = "eac3",
  146. .audio_codec = AV_CODEC_ID_EAC3,
  147. .video_codec = AV_CODEC_ID_NONE,
  148. .write_header = force_one_stream,
  149. .write_packet = ff_raw_write_packet,
  150. .flags = AVFMT_NOTIMESTAMPS,
  151. };
  152. #endif
  153. #if CONFIG_G722_MUXER
  154. AVOutputFormat ff_g722_muxer = {
  155. .name = "g722",
  156. .long_name = NULL_IF_CONFIG_SMALL("raw G.722"),
  157. .mime_type = "audio/G722",
  158. .extensions = "g722",
  159. .audio_codec = AV_CODEC_ID_ADPCM_G722,
  160. .video_codec = AV_CODEC_ID_NONE,
  161. .write_header = force_one_stream,
  162. .write_packet = ff_raw_write_packet,
  163. .flags = AVFMT_NOTIMESTAMPS,
  164. };
  165. #endif
  166. #if CONFIG_G723_1_MUXER
  167. AVOutputFormat ff_g723_1_muxer = {
  168. .name = "g723_1",
  169. .long_name = NULL_IF_CONFIG_SMALL("raw G.723.1"),
  170. .mime_type = "audio/g723",
  171. .extensions = "tco,rco",
  172. .audio_codec = AV_CODEC_ID_G723_1,
  173. .video_codec = AV_CODEC_ID_NONE,
  174. .write_header = force_one_stream,
  175. .write_packet = ff_raw_write_packet,
  176. .flags = AVFMT_NOTIMESTAMPS,
  177. };
  178. #endif
  179. #if CONFIG_GSM_MUXER
  180. AVOutputFormat ff_gsm_muxer = {
  181. .name = "gsm",
  182. .long_name = NULL_IF_CONFIG_SMALL("raw GSM"),
  183. .mime_type = "audio/x-gsm",
  184. .extensions = "gsm",
  185. .audio_codec = AV_CODEC_ID_GSM,
  186. .video_codec = AV_CODEC_ID_NONE,
  187. .write_header = force_one_stream,
  188. .write_packet = ff_raw_write_packet,
  189. .flags = AVFMT_NOTIMESTAMPS,
  190. };
  191. #endif
  192. #if CONFIG_H261_MUXER
  193. AVOutputFormat ff_h261_muxer = {
  194. .name = "h261",
  195. .long_name = NULL_IF_CONFIG_SMALL("raw H.261"),
  196. .mime_type = "video/x-h261",
  197. .extensions = "h261",
  198. .audio_codec = AV_CODEC_ID_NONE,
  199. .video_codec = AV_CODEC_ID_H261,
  200. .write_header = force_one_stream,
  201. .write_packet = ff_raw_write_packet,
  202. .flags = AVFMT_NOTIMESTAMPS,
  203. };
  204. #endif
  205. #if CONFIG_H263_MUXER
  206. AVOutputFormat ff_h263_muxer = {
  207. .name = "h263",
  208. .long_name = NULL_IF_CONFIG_SMALL("raw H.263"),
  209. .mime_type = "video/x-h263",
  210. .extensions = "h263",
  211. .audio_codec = AV_CODEC_ID_NONE,
  212. .video_codec = AV_CODEC_ID_H263,
  213. .write_header = force_one_stream,
  214. .write_packet = ff_raw_write_packet,
  215. .flags = AVFMT_NOTIMESTAMPS,
  216. };
  217. #endif
  218. #if CONFIG_H264_MUXER
  219. static int h264_check_bitstream(struct AVFormatContext *s, const AVPacket *pkt)
  220. {
  221. AVStream *st = s->streams[0];
  222. if (pkt->size >= 5 && AV_RB32(pkt->data) != 0x0000001 &&
  223. AV_RB24(pkt->data) != 0x000001)
  224. return ff_stream_add_bitstream_filter(st, "h264_mp4toannexb", NULL);
  225. return 1;
  226. }
  227. AVOutputFormat ff_h264_muxer = {
  228. .name = "h264",
  229. .long_name = NULL_IF_CONFIG_SMALL("raw H.264 video"),
  230. .extensions = "h264,264",
  231. .audio_codec = AV_CODEC_ID_NONE,
  232. .video_codec = AV_CODEC_ID_H264,
  233. .write_header = force_one_stream,
  234. .write_packet = ff_raw_write_packet,
  235. .check_bitstream = h264_check_bitstream,
  236. .flags = AVFMT_NOTIMESTAMPS,
  237. };
  238. #endif
  239. #if CONFIG_HEVC_MUXER
  240. static int hevc_check_bitstream(struct AVFormatContext *s, const AVPacket *pkt)
  241. {
  242. AVStream *st = s->streams[0];
  243. if (pkt->size >= 5 && AV_RB32(pkt->data) != 0x0000001 &&
  244. AV_RB24(pkt->data) != 0x000001)
  245. return ff_stream_add_bitstream_filter(st, "hevc_mp4toannexb", NULL);
  246. return 1;
  247. }
  248. AVOutputFormat ff_hevc_muxer = {
  249. .name = "hevc",
  250. .long_name = NULL_IF_CONFIG_SMALL("raw HEVC video"),
  251. .extensions = "hevc,h265,265",
  252. .audio_codec = AV_CODEC_ID_NONE,
  253. .video_codec = AV_CODEC_ID_HEVC,
  254. .write_header = force_one_stream,
  255. .write_packet = ff_raw_write_packet,
  256. .check_bitstream = hevc_check_bitstream,
  257. .flags = AVFMT_NOTIMESTAMPS,
  258. };
  259. #endif
  260. #if CONFIG_M4V_MUXER
  261. AVOutputFormat ff_m4v_muxer = {
  262. .name = "m4v",
  263. .long_name = NULL_IF_CONFIG_SMALL("raw MPEG-4 video"),
  264. .extensions = "m4v",
  265. .audio_codec = AV_CODEC_ID_NONE,
  266. .video_codec = AV_CODEC_ID_MPEG4,
  267. .write_header = force_one_stream,
  268. .write_packet = ff_raw_write_packet,
  269. .flags = AVFMT_NOTIMESTAMPS,
  270. };
  271. #endif
  272. #if CONFIG_MJPEG_MUXER
  273. AVOutputFormat ff_mjpeg_muxer = {
  274. .name = "mjpeg",
  275. .long_name = NULL_IF_CONFIG_SMALL("raw MJPEG video"),
  276. .mime_type = "video/x-mjpeg",
  277. .extensions = "mjpg,mjpeg",
  278. .audio_codec = AV_CODEC_ID_NONE,
  279. .video_codec = AV_CODEC_ID_MJPEG,
  280. .write_header = force_one_stream,
  281. .write_packet = ff_raw_write_packet,
  282. .flags = AVFMT_NOTIMESTAMPS,
  283. };
  284. #endif
  285. #if CONFIG_SINGLEJPEG_MUXER
  286. AVOutputFormat ff_singlejpeg_muxer = {
  287. .name = "singlejpeg",
  288. .long_name = NULL_IF_CONFIG_SMALL("JPEG single image"),
  289. .mime_type = "image/jpeg",
  290. .audio_codec = AV_CODEC_ID_NONE,
  291. .video_codec = AV_CODEC_ID_MJPEG,
  292. .write_packet = ff_raw_write_packet,
  293. .flags = AVFMT_NOTIMESTAMPS,
  294. .write_header = force_one_stream,
  295. };
  296. #endif
  297. #if CONFIG_MLP_MUXER
  298. AVOutputFormat ff_mlp_muxer = {
  299. .name = "mlp",
  300. .long_name = NULL_IF_CONFIG_SMALL("raw MLP"),
  301. .extensions = "mlp",
  302. .audio_codec = AV_CODEC_ID_MLP,
  303. .video_codec = AV_CODEC_ID_NONE,
  304. .write_header = force_one_stream,
  305. .write_packet = ff_raw_write_packet,
  306. .flags = AVFMT_NOTIMESTAMPS,
  307. };
  308. #endif
  309. #if CONFIG_MP2_MUXER
  310. AVOutputFormat ff_mp2_muxer = {
  311. .name = "mp2",
  312. .long_name = NULL_IF_CONFIG_SMALL("MP2 (MPEG audio layer 2)"),
  313. .mime_type = "audio/mpeg",
  314. .extensions = "mp2,m2a,mpa",
  315. .audio_codec = AV_CODEC_ID_MP2,
  316. .video_codec = AV_CODEC_ID_NONE,
  317. .write_packet = ff_raw_write_packet,
  318. .flags = AVFMT_NOTIMESTAMPS,
  319. };
  320. #endif
  321. #if CONFIG_MPEG1VIDEO_MUXER
  322. AVOutputFormat ff_mpeg1video_muxer = {
  323. .name = "mpeg1video",
  324. .long_name = NULL_IF_CONFIG_SMALL("raw MPEG-1 video"),
  325. .mime_type = "video/mpeg",
  326. .extensions = "mpg,mpeg,m1v",
  327. .audio_codec = AV_CODEC_ID_NONE,
  328. .video_codec = AV_CODEC_ID_MPEG1VIDEO,
  329. .write_header = force_one_stream,
  330. .write_packet = ff_raw_write_packet,
  331. .flags = AVFMT_NOTIMESTAMPS,
  332. };
  333. #endif
  334. #if CONFIG_MPEG2VIDEO_MUXER
  335. AVOutputFormat ff_mpeg2video_muxer = {
  336. .name = "mpeg2video",
  337. .long_name = NULL_IF_CONFIG_SMALL("raw MPEG-2 video"),
  338. .extensions = "m2v",
  339. .audio_codec = AV_CODEC_ID_NONE,
  340. .video_codec = AV_CODEC_ID_MPEG2VIDEO,
  341. .write_header = force_one_stream,
  342. .write_packet = ff_raw_write_packet,
  343. .flags = AVFMT_NOTIMESTAMPS,
  344. };
  345. #endif
  346. #if CONFIG_RAWVIDEO_MUXER
  347. AVOutputFormat ff_rawvideo_muxer = {
  348. .name = "rawvideo",
  349. .long_name = NULL_IF_CONFIG_SMALL("raw video"),
  350. .extensions = "yuv,rgb",
  351. .audio_codec = AV_CODEC_ID_NONE,
  352. .video_codec = AV_CODEC_ID_RAWVIDEO,
  353. .write_packet = ff_raw_write_packet,
  354. .flags = AVFMT_NOTIMESTAMPS,
  355. };
  356. #endif
  357. #if CONFIG_TRUEHD_MUXER
  358. AVOutputFormat ff_truehd_muxer = {
  359. .name = "truehd",
  360. .long_name = NULL_IF_CONFIG_SMALL("raw TrueHD"),
  361. .extensions = "thd",
  362. .audio_codec = AV_CODEC_ID_TRUEHD,
  363. .video_codec = AV_CODEC_ID_NONE,
  364. .write_header = force_one_stream,
  365. .write_packet = ff_raw_write_packet,
  366. .flags = AVFMT_NOTIMESTAMPS,
  367. };
  368. #endif
  369. #if CONFIG_VC1_MUXER
  370. AVOutputFormat ff_vc1_muxer = {
  371. .name = "vc1",
  372. .long_name = NULL_IF_CONFIG_SMALL("raw VC-1 video"),
  373. .extensions = "vc1",
  374. .audio_codec = AV_CODEC_ID_NONE,
  375. .video_codec = AV_CODEC_ID_VC1,
  376. .write_header = force_one_stream,
  377. .write_packet = ff_raw_write_packet,
  378. .flags = AVFMT_NOTIMESTAMPS,
  379. };
  380. #endif