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.

73 lines
2.8KB

  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_packet(struct AVFormatContext *s, AVPacket *pkt)
  27. {
  28. uint32_t crc = av_adler32_update(0, pkt->data, pkt->size);
  29. char buf[256];
  30. snprintf(buf, sizeof(buf), "%d, %10"PRId64", %10"PRId64", %8d, %8d, 0x%08"PRIx32,
  31. pkt->stream_index, pkt->dts, pkt->pts, pkt->duration, pkt->size, crc);
  32. if (pkt->flags != AV_PKT_FLAG_KEY)
  33. av_strlcatf(buf, sizeof(buf), ", F=0x%0X", pkt->flags);
  34. if (pkt->side_data_elems) {
  35. int i, j;
  36. av_strlcatf(buf, sizeof(buf), ", S=%d", pkt->side_data_elems);
  37. for (i=0; i<pkt->side_data_elems; i++) {
  38. uint32_t side_data_crc = 0;
  39. if (HAVE_BIGENDIAN && AV_PKT_DATA_PALETTE == pkt->side_data[i].type) {
  40. for (j=0; j<pkt->side_data[i].size; j++) {
  41. side_data_crc = av_adler32_update(side_data_crc,
  42. pkt->side_data[i].data + (j^3),
  43. 1);
  44. }
  45. } else {
  46. side_data_crc = av_adler32_update(0,
  47. pkt->side_data[i].data,
  48. pkt->side_data[i].size);
  49. }
  50. av_strlcatf(buf, sizeof(buf), ", %8d, 0x%08x", pkt->side_data[i].size, side_data_crc);
  51. }
  52. }
  53. av_strlcatf(buf, sizeof(buf), "\n");
  54. avio_write(s->pb, buf, strlen(buf));
  55. return 0;
  56. }
  57. AVOutputFormat ff_framecrc_muxer = {
  58. .name = "framecrc",
  59. .long_name = NULL_IF_CONFIG_SMALL("framecrc testing"),
  60. .audio_codec = AV_CODEC_ID_PCM_S16LE,
  61. .video_codec = AV_CODEC_ID_RAWVIDEO,
  62. .write_header = ff_framehash_write_header,
  63. .write_packet = framecrc_write_packet,
  64. .flags = AVFMT_VARIABLE_FPS | AVFMT_TS_NONSTRICT |
  65. AVFMT_TS_NEGATIVE,
  66. };