framecrcenc.c
Go to the documentation of this file.
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 
22 #include "libavutil/adler32.h"
23 #include "libavutil/avstring.h"
24 #include "avformat.h"
25 #include "internal.h"
26 
28 {
29  uint32_t crc = av_adler32_update(0, pkt->data, pkt->size);
30  char buf[256];
31 
32  snprintf(buf, sizeof(buf), "%d, %10"PRId64", %10"PRId64", %8d, %8d, 0x%08x",
33  pkt->stream_index, pkt->dts, pkt->pts, pkt->duration, pkt->size, crc);
34  if (pkt->flags != AV_PKT_FLAG_KEY)
35  av_strlcatf(buf, sizeof(buf), ", F=0x%0X", pkt->flags);
36  if (pkt->side_data_elems) {
37  int i;
38  av_strlcatf(buf, sizeof(buf), ", S=%d", pkt->side_data_elems);
39 
40  for (i=0; i<pkt->side_data_elems; i++) {
41  uint32_t side_data_crc = av_adler32_update(0,
42  pkt->side_data[i].data,
43  pkt->side_data[i].size);
44  av_strlcatf(buf, sizeof(buf), ", %8d, 0x%08x", pkt->side_data[i].size, side_data_crc);
45  }
46  }
47  av_strlcatf(buf, sizeof(buf), "\n");
48  avio_write(s->pb, buf, strlen(buf));
49  return 0;
50 }
51 
53  .name = "framecrc",
54  .long_name = NULL_IF_CONFIG_SMALL("framecrc testing"),
55  .audio_codec = AV_CODEC_ID_PCM_S16LE,
56  .video_codec = AV_CODEC_ID_RAWVIDEO,
57  .write_header = ff_framehash_write_header,
58  .write_packet = framecrc_write_packet,
60 };
const char * s
Definition: avisynth_c.h:668
#define AVFMT_TS_NONSTRICT
Format does not require strictly increasing timestamps, but they must still be monotonic.
Definition: avformat.h:363
Format I/O context.
Definition: avformat.h:944
static int framecrc_write_packet(struct AVFormatContext *s, AVPacket *pkt)
Definition: framecrcenc.c:27
static AVPacket pkt
Definition: demuxing.c:56
uint8_t * data
unsigned long av_adler32_update(unsigned long adler, const uint8_t *buf, unsigned int len)
Calculate the Adler32 checksum of a buffer.
Definition: adler32.c:35
void avio_write(AVIOContext *s, const unsigned char *buf, int size)
Definition: aviobuf.c:173
int duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
int flags
A combination of AV_PKT_FLAG values.
const char * name
Definition: avformat.h:378
int ff_framehash_write_header(AVFormatContext *s)
Set the timebase for each stream from the corresponding codec timebase and print it.
Definition: framehash.c:23
AVIOContext * pb
I/O context.
Definition: avformat.h:977
void * buf
Definition: avisynth_c.h:594
synthesis window for stochastic i
size_t av_strlcatf(char *dst, size_t size, const char *fmt,...)
Definition: avstring.c:100
#define snprintf
Definition: snprintf.h:34
Main libavformat public API header.
AVOutputFormat ff_framecrc_muxer
Definition: framecrcenc.c:52
#define AVFMT_VARIABLE_FPS
Format allows variable fps.
Definition: avformat.h:355
struct AVPacket::@35 * side_data
Additional packet data that can be provided by the container.
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed...
This structure stores compressed data.
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...