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.

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