xref: /aosp_15_r20/external/libvpx/vpxstats.c (revision fb1b10ab9aebc7c7068eedab379b749d7e3900be)
1*fb1b10abSAndroid Build Coastguard Worker /*
2*fb1b10abSAndroid Build Coastguard Worker  *  Copyright (c) 2013 The WebM project authors. All Rights Reserved.
3*fb1b10abSAndroid Build Coastguard Worker  *
4*fb1b10abSAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*fb1b10abSAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*fb1b10abSAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*fb1b10abSAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*fb1b10abSAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*fb1b10abSAndroid Build Coastguard Worker  */
10*fb1b10abSAndroid Build Coastguard Worker 
11*fb1b10abSAndroid Build Coastguard Worker #include "./vpxstats.h"
12*fb1b10abSAndroid Build Coastguard Worker 
13*fb1b10abSAndroid Build Coastguard Worker #include <math.h>
14*fb1b10abSAndroid Build Coastguard Worker #include <stdlib.h>
15*fb1b10abSAndroid Build Coastguard Worker #include <string.h>
16*fb1b10abSAndroid Build Coastguard Worker 
17*fb1b10abSAndroid Build Coastguard Worker #include "./tools_common.h"
18*fb1b10abSAndroid Build Coastguard Worker 
stats_open_file(stats_io_t * stats,const char * fpf,int pass)19*fb1b10abSAndroid Build Coastguard Worker int stats_open_file(stats_io_t *stats, const char *fpf, int pass) {
20*fb1b10abSAndroid Build Coastguard Worker   int res;
21*fb1b10abSAndroid Build Coastguard Worker   stats->pass = pass;
22*fb1b10abSAndroid Build Coastguard Worker 
23*fb1b10abSAndroid Build Coastguard Worker   if (pass == 0) {
24*fb1b10abSAndroid Build Coastguard Worker     stats->file = fopen(fpf, "wb");
25*fb1b10abSAndroid Build Coastguard Worker     stats->buf.sz = 0;
26*fb1b10abSAndroid Build Coastguard Worker     stats->buf.buf = NULL;
27*fb1b10abSAndroid Build Coastguard Worker     res = (stats->file != NULL);
28*fb1b10abSAndroid Build Coastguard Worker   } else {
29*fb1b10abSAndroid Build Coastguard Worker     size_t nbytes;
30*fb1b10abSAndroid Build Coastguard Worker 
31*fb1b10abSAndroid Build Coastguard Worker     stats->file = fopen(fpf, "rb");
32*fb1b10abSAndroid Build Coastguard Worker 
33*fb1b10abSAndroid Build Coastguard Worker     if (stats->file == NULL) fatal("First-pass stats file does not exist!");
34*fb1b10abSAndroid Build Coastguard Worker 
35*fb1b10abSAndroid Build Coastguard Worker     if (fseek(stats->file, 0, SEEK_END))
36*fb1b10abSAndroid Build Coastguard Worker       fatal("First-pass stats file must be seekable!");
37*fb1b10abSAndroid Build Coastguard Worker 
38*fb1b10abSAndroid Build Coastguard Worker     stats->buf.sz = stats->buf_alloc_sz = ftell(stats->file);
39*fb1b10abSAndroid Build Coastguard Worker     rewind(stats->file);
40*fb1b10abSAndroid Build Coastguard Worker 
41*fb1b10abSAndroid Build Coastguard Worker     stats->buf.buf = malloc(stats->buf_alloc_sz);
42*fb1b10abSAndroid Build Coastguard Worker 
43*fb1b10abSAndroid Build Coastguard Worker     if (!stats->buf.buf)
44*fb1b10abSAndroid Build Coastguard Worker       fatal("Failed to allocate first-pass stats buffer (%u bytes)",
45*fb1b10abSAndroid Build Coastguard Worker             (unsigned int)stats->buf_alloc_sz);
46*fb1b10abSAndroid Build Coastguard Worker 
47*fb1b10abSAndroid Build Coastguard Worker     nbytes = fread(stats->buf.buf, 1, stats->buf.sz, stats->file);
48*fb1b10abSAndroid Build Coastguard Worker     res = (nbytes == stats->buf.sz);
49*fb1b10abSAndroid Build Coastguard Worker   }
50*fb1b10abSAndroid Build Coastguard Worker 
51*fb1b10abSAndroid Build Coastguard Worker   return res;
52*fb1b10abSAndroid Build Coastguard Worker }
53*fb1b10abSAndroid Build Coastguard Worker 
stats_open_mem(stats_io_t * stats,int pass)54*fb1b10abSAndroid Build Coastguard Worker int stats_open_mem(stats_io_t *stats, int pass) {
55*fb1b10abSAndroid Build Coastguard Worker   int res;
56*fb1b10abSAndroid Build Coastguard Worker   stats->pass = pass;
57*fb1b10abSAndroid Build Coastguard Worker 
58*fb1b10abSAndroid Build Coastguard Worker   if (!pass) {
59*fb1b10abSAndroid Build Coastguard Worker     stats->buf.sz = 0;
60*fb1b10abSAndroid Build Coastguard Worker     stats->buf_alloc_sz = 64 * 1024;
61*fb1b10abSAndroid Build Coastguard Worker     stats->buf.buf = malloc(stats->buf_alloc_sz);
62*fb1b10abSAndroid Build Coastguard Worker   }
63*fb1b10abSAndroid Build Coastguard Worker 
64*fb1b10abSAndroid Build Coastguard Worker   stats->buf_ptr = stats->buf.buf;
65*fb1b10abSAndroid Build Coastguard Worker   res = (stats->buf.buf != NULL);
66*fb1b10abSAndroid Build Coastguard Worker   return res;
67*fb1b10abSAndroid Build Coastguard Worker }
68*fb1b10abSAndroid Build Coastguard Worker 
stats_close(stats_io_t * stats,int last_pass)69*fb1b10abSAndroid Build Coastguard Worker void stats_close(stats_io_t *stats, int last_pass) {
70*fb1b10abSAndroid Build Coastguard Worker   if (stats->file) {
71*fb1b10abSAndroid Build Coastguard Worker     if (stats->pass == last_pass) {
72*fb1b10abSAndroid Build Coastguard Worker       free(stats->buf.buf);
73*fb1b10abSAndroid Build Coastguard Worker     }
74*fb1b10abSAndroid Build Coastguard Worker 
75*fb1b10abSAndroid Build Coastguard Worker     fclose(stats->file);
76*fb1b10abSAndroid Build Coastguard Worker     stats->file = NULL;
77*fb1b10abSAndroid Build Coastguard Worker   } else {
78*fb1b10abSAndroid Build Coastguard Worker     if (stats->pass == last_pass) free(stats->buf.buf);
79*fb1b10abSAndroid Build Coastguard Worker   }
80*fb1b10abSAndroid Build Coastguard Worker }
81*fb1b10abSAndroid Build Coastguard Worker 
stats_write(stats_io_t * stats,const void * pkt,size_t len)82*fb1b10abSAndroid Build Coastguard Worker void stats_write(stats_io_t *stats, const void *pkt, size_t len) {
83*fb1b10abSAndroid Build Coastguard Worker   if (stats->file) {
84*fb1b10abSAndroid Build Coastguard Worker     (void)fwrite(pkt, 1, len, stats->file);
85*fb1b10abSAndroid Build Coastguard Worker   } else {
86*fb1b10abSAndroid Build Coastguard Worker     if (stats->buf.sz + len > stats->buf_alloc_sz) {
87*fb1b10abSAndroid Build Coastguard Worker       size_t new_sz = stats->buf_alloc_sz + 64 * 1024;
88*fb1b10abSAndroid Build Coastguard Worker       char *new_ptr = realloc(stats->buf.buf, new_sz);
89*fb1b10abSAndroid Build Coastguard Worker 
90*fb1b10abSAndroid Build Coastguard Worker       if (new_ptr) {
91*fb1b10abSAndroid Build Coastguard Worker         stats->buf_ptr = new_ptr + (stats->buf_ptr - (char *)stats->buf.buf);
92*fb1b10abSAndroid Build Coastguard Worker         stats->buf.buf = new_ptr;
93*fb1b10abSAndroid Build Coastguard Worker         stats->buf_alloc_sz = new_sz;
94*fb1b10abSAndroid Build Coastguard Worker       } else {
95*fb1b10abSAndroid Build Coastguard Worker         fatal("Failed to realloc firstpass stats buffer.");
96*fb1b10abSAndroid Build Coastguard Worker       }
97*fb1b10abSAndroid Build Coastguard Worker     }
98*fb1b10abSAndroid Build Coastguard Worker 
99*fb1b10abSAndroid Build Coastguard Worker     memcpy(stats->buf_ptr, pkt, len);
100*fb1b10abSAndroid Build Coastguard Worker     stats->buf.sz += len;
101*fb1b10abSAndroid Build Coastguard Worker     stats->buf_ptr += len;
102*fb1b10abSAndroid Build Coastguard Worker   }
103*fb1b10abSAndroid Build Coastguard Worker }
104*fb1b10abSAndroid Build Coastguard Worker 
stats_get(stats_io_t * stats)105*fb1b10abSAndroid Build Coastguard Worker vpx_fixed_buf_t stats_get(stats_io_t *stats) { return stats->buf; }
106