2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved.
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
10 #ifndef VPX_TOOLS_COMMON_H_
11 #define VPX_TOOLS_COMMON_H_
15 #include "./vpx_config.h"
16 #include "vpx/vpx_codec.h"
17 #include "vpx/vpx_image.h"
18 #include "vpx/vpx_integer.h"
19 #include "vpx_ports/msvc.h"
22 #include "./y4minput.h"
26 /* MSVS uses _f{seek,tell}i64. */
27 #define fseeko _fseeki64
28 #define ftello _ftelli64
29 typedef int64_t FileOffset;
31 /* MinGW uses f{seek,tell}o64 for large files. */
32 #define fseeko fseeko64
33 #define ftello ftello64
34 typedef off64_t FileOffset;
35 #elif CONFIG_OS_SUPPORT
36 typedef off_t FileOffset;
37 /* Use 32-bit file operations in WebM file format when building ARM
38 * executables (.axf) with RVCT. */
42 typedef long FileOffset; /* NOLINT */
43 #endif /* CONFIG_OS_SUPPORT */
47 #include <io.h> /* NOLINT */
48 #define isatty _isatty
49 #define fileno _fileno
51 #include <unistd.h> /* NOLINT */
53 #endif /* CONFIG_OS_SUPPORT */
55 #define LITERALU64(hi, lo) ((((uint64_t)hi) << 32) | lo)
61 #define IVF_FRAME_HDR_SZ (4 + 8) /* 4 byte size + 8 byte timestamp */
62 #define IVF_FILE_HDR_SZ 32
64 #define RAW_FRAME_HDR_SZ sizeof(uint32_t)
66 #define VP8_FOURCC 0x30385056
67 #define VP9_FOURCC 0x30395056
76 struct FileTypeDetectionBuffer {
87 struct VpxInputContext {
91 struct FileTypeDetectionBuffer detect;
92 enum VideoFileType file_type;
95 struct VpxRational pixel_aspect_ratio;
97 vpx_bit_depth_t bit_depth;
100 struct VpxRational framerate;
110 #if defined(__GNUC__)
111 #define VPX_NO_RETURN __attribute__((noreturn))
113 #define VPX_NO_RETURN
116 /* Sets a stdio stream into binary mode */
117 FILE *set_binary_mode(FILE *stream);
119 void die(const char *fmt, ...) VPX_NO_RETURN;
120 void fatal(const char *fmt, ...) VPX_NO_RETURN;
121 void warn(const char *fmt, ...);
123 void die_codec(vpx_codec_ctx_t *ctx, const char *s) VPX_NO_RETURN;
125 /* The tool including this file must define usage_exit() */
126 void usage_exit(void) VPX_NO_RETURN;
130 int read_yuv_frame(struct VpxInputContext *input_ctx, vpx_image_t *yuv_frame);
132 typedef struct VpxInterface {
133 const char *const name;
134 const uint32_t fourcc;
135 vpx_codec_iface_t *(*const codec_interface)();
138 int get_vpx_encoder_count(void);
139 const VpxInterface *get_vpx_encoder_by_index(int i);
140 const VpxInterface *get_vpx_encoder_by_name(const char *name);
142 int get_vpx_decoder_count(void);
143 const VpxInterface *get_vpx_decoder_by_index(int i);
144 const VpxInterface *get_vpx_decoder_by_name(const char *name);
145 const VpxInterface *get_vpx_decoder_by_fourcc(uint32_t fourcc);
147 // TODO(dkovalev): move this function to vpx_image.{c, h}, so it will be part
148 // of vpx_image_t support
149 int vpx_img_plane_width(const vpx_image_t *img, int plane);
150 int vpx_img_plane_height(const vpx_image_t *img, int plane);
151 void vpx_img_write(const vpx_image_t *img, FILE *file);
152 int vpx_img_read(vpx_image_t *img, FILE *file);
154 double sse_to_psnr(double samples, double peak, double mse);
156 #if CONFIG_VP9_HIGHBITDEPTH
157 void vpx_img_upshift(vpx_image_t *dst, vpx_image_t *src, int input_shift);
158 void vpx_img_downshift(vpx_image_t *dst, vpx_image_t *src, int down_shift);
159 void vpx_img_truncate_16_to_8(vpx_image_t *dst, vpx_image_t *src);
166 #endif // VPX_TOOLS_COMMON_H_