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.

89 lines
3.3KB

  1. /*
  2. * frame CRC encoder (for codec/format testing)
  3. * Copyright (c) 2002 Fabrice Bellard
  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. #include <inttypes.h>
  22. #include "libavutil/adler32.h"
  23. #include "libavutil/avstring.h"
  24. #include "avformat.h"
  25. #include "internal.h"
  26. static int framecrc_write_header(struct AVFormatContext *s)
  27. {
  28. int i;
  29. for (i = 0; i < s->nb_streams; i++) {
  30. AVStream *st = s->streams[i];
  31. AVCodecContext *avctx = st->codec;
  32. if (avctx->extradata) {
  33. uint32_t crc = av_adler32_update(0, avctx->extradata, avctx->extradata_size);
  34. avio_printf(s->pb, "#extradata %d: %8d, 0x%08"PRIx32"\n",
  35. i, avctx->extradata_size, crc);
  36. }
  37. }
  38. return ff_framehash_write_header(s);
  39. }
  40. static int framecrc_write_packet(struct AVFormatContext *s, AVPacket *pkt)
  41. {
  42. uint32_t crc = av_adler32_update(0, pkt->data, pkt->size);
  43. char buf[256];
  44. snprintf(buf, sizeof(buf), "%d, %10"PRId64", %10"PRId64", %8d, %8d, 0x%08"PRIx32,
  45. pkt->stream_index, pkt->dts, pkt->pts, pkt->duration, pkt->size, crc);
  46. if (pkt->flags != AV_PKT_FLAG_KEY)
  47. av_strlcatf(buf, sizeof(buf), ", F=0x%0X", pkt->flags);
  48. if (pkt->side_data_elems) {
  49. int i, j;
  50. av_strlcatf(buf, sizeof(buf), ", S=%d", pkt->side_data_elems);
  51. for (i=0; i<pkt->side_data_elems; i++) {
  52. uint32_t side_data_crc = 0;
  53. if (HAVE_BIGENDIAN && AV_PKT_DATA_PALETTE == pkt->side_data[i].type) {
  54. for (j=0; j<pkt->side_data[i].size; j++) {
  55. side_data_crc = av_adler32_update(side_data_crc,
  56. pkt->side_data[i].data + (j^3),
  57. 1);
  58. }
  59. } else {
  60. side_data_crc = av_adler32_update(0,
  61. pkt->side_data[i].data,
  62. pkt->side_data[i].size);
  63. }
  64. av_strlcatf(buf, sizeof(buf), ", %8d, 0x%08x", pkt->side_data[i].size, side_data_crc);
  65. }
  66. }
  67. av_strlcatf(buf, sizeof(buf), "\n");
  68. avio_write(s->pb, buf, strlen(buf));
  69. return 0;
  70. }
  71. AVOutputFormat ff_framecrc_muxer = {
  72. .name = "framecrc",
  73. .long_name = NULL_IF_CONFIG_SMALL("framecrc testing"),
  74. .audio_codec = AV_CODEC_ID_PCM_S16LE,
  75. .video_codec = AV_CODEC_ID_RAWVIDEO,
  76. .write_header = framecrc_write_header,
  77. .write_packet = framecrc_write_packet,
  78. .flags = AVFMT_VARIABLE_FPS | AVFMT_TS_NONSTRICT |
  79. AVFMT_TS_NEGATIVE,
  80. };