28 #define MAX_FORMATS 1000
35 #define AV_READ_TIME(x) 0
42 void *fmt_opaque =
NULL;
57 "Failure of %s probing code with score=%d type=%d p=%X size=%d\n",
70 void *fmt_opaque =
NULL;
76 fprintf(stderr,
"%12"PRIu64
" cycles, %12s\n",
88 ret = strtol(
arg, &
arg, 0);
94 int main(
int argc,
char **argv)
100 int retry_count= 4097;
101 int max_size = 65537;
104 for (j =
i = 1;
i<argc;
i++) {
107 }
else if (
read_int(argv[
i])>0 && j == 1) {
110 }
else if (
read_int(argv[
i])>0 && j == 2) {
114 fprintf(stderr,
"probetest [-f <input format>] [<retry_count> [<max_size>]]\n");
119 if (max_size > 1000000000U/8) {
120 fprintf(stderr,
"max_size out of bounds\n");
124 if (retry_count > 1000000000U) {
125 fprintf(stderr,
"retry_count out of bounds\n");
138 fprintf(stderr,
"out of memory\n");
144 fprintf(stderr,
"testing size=%d\n",
size);
146 for (retry = 0; retry < retry_count; retry +=
FFMAX(
size, 32)) {
148 for (p = 0; p < 4096; p++) {
157 for (
i = 0;
i <
size * 8;
i++) {
158 unsigned int p2 = hist ? p & 0x3F : (p >> 6);
165 for (
i = 0;
i <
size * 8;
i++) {
166 unsigned int p2 = (p >> (hist * 3)) & 7;
169 hist = (2 * hist + v) & 3;
177 if (
c >=
'a' &&
c <=
'z' && (p & 1))
179 else if (
c >=
'A' &&
c <=
'Z' && (p & 2))
181 else if (
c >=
'0' &&
c <=
'9' && (p & 4))
183 else if (
c ==
' ' && (p & 8))
185 else if (
c == 0 && (p & 16))
187 else if (
c == 1 && (p & 32))
const AVInputFormat * av_demuxer_iterate(void **opaque)
Iterate over all registered demuxers.
void * av_realloc(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory.
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
av_cold void av_lfg_init(AVLFG *c, unsigned int seed)
static unsigned int av_lfg_get(AVLFG *c)
Get the next random unsigned 32-bit number using an ALFG.
static const char * single_format
static void print_times(void)
static int64_t time_array[MAX_FORMATS]
int main(int argc, char **argv)
static void probe(AVProbeData *pd, int type, int p, int size)
static int read_int(char *arg)
static int score_array[MAX_FORMATS]
static void init_put_bits(PutBitContext *s, uint8_t *buffer, int buffer_size)
Initialize the PutBitContext s.
static void flush_put_bits(PutBitContext *s)
Pad the end of the output stream with zeros.
Context structure for the Lagged Fibonacci PRNG.
This structure contains the data a format has to probe a file.
int buf_size
Size of buf except extra allocated bytes.
unsigned char * buf
Buffer must have AVPROBE_PADDING_SIZE of extra allocated bytes filled with zero.
high precision timer, useful to profile code