2010-11-02 16:11:57 +03:00
|
|
|
/*
|
2016-09-02 00:32:49 +03:00
|
|
|
* Copyright (c) 2016, Alliance for Open Media. All rights reserved
|
2010-11-02 16:11:57 +03:00
|
|
|
*
|
2016-09-02 00:32:49 +03:00
|
|
|
* This source code is subject to the terms of the BSD 2 Clause License and
|
|
|
|
* the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
|
|
|
|
* was not distributed with this source code in the LICENSE file, you can
|
|
|
|
* obtain it at www.aomedia.org/license/software. If the Alliance for Open
|
|
|
|
* Media Patent License 1.0 was not distributed with this source code in the
|
|
|
|
* PATENTS file, you can obtain it at www.aomedia.org/license/patent.
|
2010-11-02 16:11:57 +03:00
|
|
|
*/
|
2013-11-05 22:02:18 +04:00
|
|
|
#ifndef TOOLS_COMMON_H_
|
|
|
|
#define TOOLS_COMMON_H_
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
#include "./aom_config.h"
|
|
|
|
#include "aom/aom_codec.h"
|
|
|
|
#include "aom/aom_image.h"
|
|
|
|
#include "aom/aom_integer.h"
|
2016-08-23 02:08:15 +03:00
|
|
|
#include "aom_ports/msvc.h"
|
2013-11-15 00:37:42 +04:00
|
|
|
|
|
|
|
#if CONFIG_ENCODERS
|
|
|
|
#include "./y4minput.h"
|
|
|
|
#endif
|
2013-11-11 18:48:18 +04:00
|
|
|
|
|
|
|
#if defined(_MSC_VER)
|
2014-04-03 07:06:07 +04:00
|
|
|
/* MSVS uses _f{seek,tell}i64. */
|
2013-11-11 18:48:18 +04:00
|
|
|
#define fseeko _fseeki64
|
|
|
|
#define ftello _ftelli64
|
2017-01-15 01:18:01 +03:00
|
|
|
typedef int64_t FileOffset;
|
2013-11-11 18:48:18 +04:00
|
|
|
#elif defined(_WIN32)
|
2017-01-15 01:18:01 +03:00
|
|
|
#include <sys/types.h> /* NOLINT*/
|
2014-04-17 21:47:08 +04:00
|
|
|
/* MinGW uses f{seek,tell}o64 for large files. */
|
2013-11-11 18:48:18 +04:00
|
|
|
#define fseeko fseeko64
|
|
|
|
#define ftello ftello64
|
2017-01-15 01:18:01 +03:00
|
|
|
typedef off64_t FileOffset;
|
|
|
|
#elif CONFIG_OS_SUPPORT
|
|
|
|
#include <sys/types.h> /* NOLINT*/
|
|
|
|
typedef off_t FileOffset;
|
|
|
|
/* Use 32-bit file operations in WebM file format when building ARM
|
|
|
|
* executables (.axf) with RVCT. */
|
|
|
|
#else
|
|
|
|
#define fseeko fseek
|
|
|
|
#define ftello ftell
|
2017-01-20 01:39:04 +03:00
|
|
|
typedef long FileOffset; /* NOLINT */
|
2017-01-15 01:18:01 +03:00
|
|
|
#endif /* CONFIG_OS_SUPPORT */
|
2013-11-11 18:48:18 +04:00
|
|
|
|
|
|
|
#if CONFIG_OS_SUPPORT
|
|
|
|
#if defined(_MSC_VER)
|
2016-08-09 05:03:30 +03:00
|
|
|
#include <io.h> /* NOLINT */
|
|
|
|
#define isatty _isatty
|
|
|
|
#define fileno _fileno
|
2013-11-11 18:48:18 +04:00
|
|
|
#else
|
2016-08-09 05:03:30 +03:00
|
|
|
#include <unistd.h> /* NOLINT */
|
|
|
|
#endif /* _MSC_VER */
|
|
|
|
#endif /* CONFIG_OS_SUPPORT */
|
2013-11-11 18:48:18 +04:00
|
|
|
|
|
|
|
#define LITERALU64(hi, lo) ((((uint64_t)hi) << 32) | lo)
|
|
|
|
|
|
|
|
#ifndef PATH_MAX
|
|
|
|
#define PATH_MAX 512
|
|
|
|
#endif
|
|
|
|
|
2016-08-09 05:03:30 +03:00
|
|
|
#define IVF_FRAME_HDR_SZ (4 + 8) /* 4 byte size + 8 byte timestamp */
|
2013-11-15 00:37:42 +04:00
|
|
|
#define IVF_FILE_HDR_SZ 32
|
|
|
|
|
|
|
|
#define RAW_FRAME_HDR_SZ sizeof(uint32_t)
|
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
#define AV1_FOURCC 0x31305641
|
2010-11-02 16:11:57 +03:00
|
|
|
|
2013-11-15 00:37:42 +04:00
|
|
|
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;
|
|
|
|
};
|
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
struct AvxRational {
|
2013-11-15 00:37:42 +04:00
|
|
|
int numerator;
|
|
|
|
int denominator;
|
|
|
|
};
|
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
struct AvxInputContext {
|
2013-11-15 00:37:42 +04:00
|
|
|
const char *filename;
|
|
|
|
FILE *file;
|
2014-04-17 21:47:08 +04:00
|
|
|
int64_t length;
|
2013-11-15 00:37:42 +04:00
|
|
|
struct FileTypeDetectionBuffer detect;
|
|
|
|
enum VideoFileType file_type;
|
2013-11-19 02:39:51 +04:00
|
|
|
uint32_t width;
|
|
|
|
uint32_t height;
|
2016-08-31 00:01:10 +03:00
|
|
|
struct AvxRational pixel_aspect_ratio;
|
|
|
|
aom_img_fmt_t fmt;
|
|
|
|
aom_bit_depth_t bit_depth;
|
2013-11-15 00:37:42 +04:00
|
|
|
int only_i420;
|
2013-11-19 02:39:51 +04:00
|
|
|
uint32_t fourcc;
|
2016-08-31 00:01:10 +03:00
|
|
|
struct AvxRational framerate;
|
2013-11-15 00:37:42 +04:00
|
|
|
#if CONFIG_ENCODERS
|
|
|
|
y4m_input y4m;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-08-21 22:43:36 +04:00
|
|
|
#if defined(__GNUC__)
|
2016-08-31 00:01:10 +03:00
|
|
|
#define AOM_NO_RETURN __attribute__((noreturn))
|
2014-08-21 22:43:36 +04:00
|
|
|
#else
|
2016-08-31 00:01:10 +03:00
|
|
|
#define AOM_NO_RETURN
|
2014-08-21 22:43:36 +04:00
|
|
|
#endif
|
|
|
|
|
2010-11-02 16:11:57 +03:00
|
|
|
/* Sets a stdio stream into binary mode */
|
2012-07-14 02:21:29 +04:00
|
|
|
FILE *set_binary_mode(FILE *stream);
|
2010-11-02 16:11:57 +03:00
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
void die(const char *fmt, ...) AOM_NO_RETURN;
|
|
|
|
void fatal(const char *fmt, ...) AOM_NO_RETURN;
|
2013-11-05 22:02:18 +04:00
|
|
|
void warn(const char *fmt, ...);
|
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
void die_codec(aom_codec_ctx_t *ctx, const char *s) AOM_NO_RETURN;
|
2014-01-28 01:40:29 +04:00
|
|
|
|
2013-11-05 22:02:18 +04:00
|
|
|
/* The tool including this file must define usage_exit() */
|
2016-08-31 00:01:10 +03:00
|
|
|
void usage_exit(void) AOM_NO_RETURN;
|
2014-08-21 22:43:36 +04:00
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
#undef AOM_NO_RETURN
|
2013-11-05 22:02:18 +04:00
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
int read_yuv_frame(struct AvxInputContext *input_ctx, aom_image_t *yuv_frame);
|
2013-11-15 00:37:42 +04:00
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
typedef struct AvxInterface {
|
2014-02-12 09:12:23 +04:00
|
|
|
const char *const name;
|
|
|
|
const uint32_t fourcc;
|
2016-08-31 00:01:10 +03:00
|
|
|
aom_codec_iface_t *(*const codec_interface)();
|
|
|
|
} AvxInterface;
|
2014-02-12 09:12:23 +04:00
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
int get_aom_encoder_count(void);
|
|
|
|
const AvxInterface *get_aom_encoder_by_index(int i);
|
|
|
|
const AvxInterface *get_aom_encoder_by_name(const char *name);
|
2014-02-12 09:12:23 +04:00
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
int get_aom_decoder_count(void);
|
|
|
|
const AvxInterface *get_aom_decoder_by_index(int i);
|
|
|
|
const AvxInterface *get_aom_decoder_by_name(const char *name);
|
|
|
|
const AvxInterface *get_aom_decoder_by_fourcc(uint32_t fourcc);
|
2014-01-28 01:40:29 +04:00
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
// TODO(dkovalev): move this function to aom_image.{c, h}, so it will be part
|
|
|
|
// of aom_image_t support
|
|
|
|
int aom_img_plane_width(const aom_image_t *img, int plane);
|
|
|
|
int aom_img_plane_height(const aom_image_t *img, int plane);
|
|
|
|
void aom_img_write(const aom_image_t *img, FILE *file);
|
|
|
|
int aom_img_read(aom_image_t *img, FILE *file);
|
2014-02-07 23:37:39 +04:00
|
|
|
|
2014-02-28 02:00:41 +04:00
|
|
|
double sse_to_psnr(double samples, double peak, double mse);
|
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
#if CONFIG_AOM_HIGHBITDEPTH
|
|
|
|
void aom_img_upshift(aom_image_t *dst, aom_image_t *src, int input_shift);
|
|
|
|
void aom_img_downshift(aom_image_t *dst, aom_image_t *src, int down_shift);
|
|
|
|
void aom_img_truncate_16_to_8(aom_image_t *dst, aom_image_t *src);
|
2014-10-07 07:46:11 +04:00
|
|
|
#endif
|
|
|
|
|
2013-11-15 00:37:42 +04:00
|
|
|
#ifdef __cplusplus
|
2016-08-09 05:03:30 +03:00
|
|
|
} /* extern "C" */
|
2013-11-15 00:37:42 +04:00
|
|
|
#endif
|
|
|
|
|
2013-11-05 22:02:18 +04:00
|
|
|
#endif // TOOLS_COMMON_H_
|