tools_common.h 4.08 KB
Newer Older
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
#include "vpx/vpx_image.h"
#include "vpx/vpx_integer.h"
19
#include "vpx_ports/msvc.h"
20 21 22 23

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

#if defined(_MSC_VER)
26
/* MSVS uses _f{seek,tell}i64. */
27 28 29
#define fseeko _fseeki64
#define ftello _ftelli64
#elif defined(_WIN32)
30
/* MinGW uses f{seek,tell}o64 for large files. */
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 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
65
#define VP10_FOURCC 0x303a5056
66

67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
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;
88
  int64_t length;
89 90
  struct FileTypeDetectionBuffer detect;
  enum VideoFileType file_type;
91 92
  uint32_t width;
  uint32_t height;
93
  struct VpxRational pixel_aspect_ratio;
94
  vpx_img_fmt_t fmt;
95
  vpx_bit_depth_t bit_depth;
96
  int only_i420;
97
  uint32_t fourcc;
98 99 100 101 102 103 104 105 106 107
  struct VpxRational framerate;
#if CONFIG_ENCODERS
  y4m_input y4m;
#endif
};

#ifdef __cplusplus
extern "C" {
#endif

108 109 110 111 112 113
#if defined(__GNUC__)
#define VPX_NO_RETURN __attribute__((noreturn))
#else
#define VPX_NO_RETURN
#endif

114
/* Sets a stdio stream into binary mode */
John Koleszar's avatar
John Koleszar committed
115
FILE *set_binary_mode(FILE *stream);
116

117 118
void die(const char *fmt, ...) VPX_NO_RETURN;
void fatal(const char *fmt, ...) VPX_NO_RETURN;
119 120
void warn(const char *fmt, ...);

121
void die_codec(vpx_codec_ctx_t *ctx, const char *s) VPX_NO_RETURN;
122

123
/* The tool including this file must define usage_exit() */
124
void usage_exit(void) VPX_NO_RETURN;
125 126

#undef VPX_NO_RETURN
127

128 129
int read_yuv_frame(struct VpxInputContext *input_ctx, vpx_image_t *yuv_frame);

130 131 132
typedef struct VpxInterface {
  const char *const name;
  const uint32_t fourcc;
133
  vpx_codec_iface_t *(*const codec_interface)();
134 135
} VpxInterface;

136
int get_vpx_encoder_count(void);
137 138 139
const VpxInterface *get_vpx_encoder_by_index(int i);
const VpxInterface *get_vpx_encoder_by_name(const char *name);

140
int get_vpx_decoder_count(void);
141 142 143
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);
144 145 146

// TODO(dkovalev): move this function to vpx_image.{c, h}, so it will be part
// of vpx_image_t support
147 148
int vpx_img_plane_width(const vpx_image_t *img, int plane);
int vpx_img_plane_height(const vpx_image_t *img, int plane);
149
void vpx_img_write(const vpx_image_t *img, FILE *file);
150 151
int vpx_img_read(vpx_image_t *img, FILE *file);

152 153
double sse_to_psnr(double samples, double peak, double mse);

154
#if CONFIG_VP9_HIGHBITDEPTH
155 156 157 158 159
void vpx_img_upshift(vpx_image_t *dst, vpx_image_t *src, int input_shift);
void vpx_img_downshift(vpx_image_t *dst, vpx_image_t *src, int down_shift);
void vpx_img_truncate_16_to_8(vpx_image_t *dst, vpx_image_t *src);
#endif

160 161 162 163
#ifdef __cplusplus
}  /* extern "C" */
#endif

164
#endif  // TOOLS_COMMON_H_