tools_common.h 3.57 KB
Newer Older
John Koleszar's avatar
John Koleszar committed
1
2
3
4
5
6
7
8
9
/*
 *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
 *
 *  Use of this source code is governed by a BSD-style license
 *  that can be found in the LICENSE file in the root of the source
 *  tree. An additional intellectual property rights grant can be found
 *  in the file PATENTS.  All contributing project authors may
 *  be found in the AUTHORS file in the root of the source tree.
 */
10
11
12
13
14
#ifndef TOOLS_COMMON_H_
#define TOOLS_COMMON_H_

#include <stdio.h>

15
#include "./vpx_config.h"
16
#include "vpx/vpx_codec.h"
17
18
19
20
21
22
#include "vpx/vpx_image.h"
#include "vpx/vpx_integer.h"

#if CONFIG_ENCODERS
#include "./y4minput.h"
#endif
23
24

#if defined(_MSC_VER)
25
/* MSVS uses _f{seek,tell}i64. */
26
27
28
#define fseeko _fseeki64
#define ftello _ftelli64
#elif defined(_WIN32)
James Zern's avatar
James Zern committed
29
/* MinGW uses f{seek,tell}o64 for large files. */
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#define fseeko fseeko64
#define ftello ftello64
#endif  /* _WIN32 */

#if CONFIG_OS_SUPPORT
#if defined(_MSC_VER)
#include <io.h>  /* NOLINT */
#define snprintf _snprintf
#define isatty   _isatty
#define fileno   _fileno
#else
#include <unistd.h>  /* NOLINT */
#endif  /* _MSC_VER */
#endif  /* CONFIG_OS_SUPPORT */

/* Use 32-bit file operations in WebM file format when building ARM
 * executables (.axf) with RVCT. */
#if !CONFIG_OS_SUPPORT
#define fseeko fseek
#define ftello ftell
#endif  /* CONFIG_OS_SUPPORT */

#define LITERALU64(hi, lo) ((((uint64_t)hi) << 32) | lo)

#ifndef PATH_MAX
#define PATH_MAX 512
#endif

58
59
60
61
62
#define IVF_FRAME_HDR_SZ (4 + 8)  /* 4 byte size + 8 byte timestamp */
#define IVF_FILE_HDR_SZ 32

#define RAW_FRAME_HDR_SZ sizeof(uint32_t)

63
64
#define VP8_FOURCC 0x30385056
#define VP9_FOURCC 0x30395056
John Koleszar's avatar
John Koleszar committed
65

66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
enum VideoFileType {
  FILE_TYPE_RAW,
  FILE_TYPE_IVF,
  FILE_TYPE_Y4M,
  FILE_TYPE_WEBM
};

struct FileTypeDetectionBuffer {
  char buf[4];
  size_t buf_read;
  size_t position;
};

struct VpxRational {
  int numerator;
  int denominator;
};

struct VpxInputContext {
  const char *filename;
  FILE *file;
James Zern's avatar
James Zern committed
87
  int64_t length;
88
89
  struct FileTypeDetectionBuffer detect;
  enum VideoFileType file_type;
90
91
  uint32_t width;
  uint32_t height;
92
  vpx_img_fmt_t fmt;
93
  vpx_bit_depth_t bit_depth;
94
  int only_i420;
95
  uint32_t fourcc;
96
97
98
99
100
101
102
103
104
105
  struct VpxRational framerate;
#if CONFIG_ENCODERS
  y4m_input y4m;
#endif
};

#ifdef __cplusplus
extern "C" {
#endif

John Koleszar's avatar
John Koleszar committed
106
/* Sets a stdio stream into binary mode */
John Koleszar's avatar
John Koleszar committed
107
FILE *set_binary_mode(FILE *stream);
John Koleszar's avatar
John Koleszar committed
108

109
110
111
112
void die(const char *fmt, ...);
void fatal(const char *fmt, ...);
void warn(const char *fmt, ...);

113
114
void die_codec(vpx_codec_ctx_t *ctx, const char *s);

115
116
117
/* The tool including this file must define usage_exit() */
void usage_exit();

118
119
int read_yuv_frame(struct VpxInputContext *input_ctx, vpx_image_t *yuv_frame);

120
121
122
typedef struct VpxInterface {
  const char *const name;
  const uint32_t fourcc;
123
  vpx_codec_iface_t *(*const codec_interface)();
124
125
126
127
128
129
130
131
132
133
} VpxInterface;

int get_vpx_encoder_count();
const VpxInterface *get_vpx_encoder_by_index(int i);
const VpxInterface *get_vpx_encoder_by_name(const char *name);

int get_vpx_decoder_count();
const VpxInterface *get_vpx_decoder_by_index(int i);
const VpxInterface *get_vpx_decoder_by_name(const char *name);
const VpxInterface *get_vpx_decoder_by_fourcc(uint32_t fourcc);
134
135
136

// TODO(dkovalev): move this function to vpx_image.{c, h}, so it will be part
// of vpx_image_t support
137
138
int vpx_img_plane_width(const vpx_image_t *img, int plane);
int vpx_img_plane_height(const vpx_image_t *img, int plane);
139
void vpx_img_write(const vpx_image_t *img, FILE *file);
140
141
int vpx_img_read(vpx_image_t *img, FILE *file);

142
143
double sse_to_psnr(double samples, double peak, double mse);

144
145
146
147
#ifdef __cplusplus
}  /* extern "C" */
#endif

148
#endif  // TOOLS_COMMON_H_