|  | /* | 
|  | * Copyright (c) 2016, Alliance for Open Media. All rights reserved | 
|  | * | 
|  | * 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. | 
|  | */ | 
|  |  | 
|  | #ifndef AOM_AOM_SCALE_YV12CONFIG_H_ | 
|  | #define AOM_AOM_SCALE_YV12CONFIG_H_ | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | extern "C" { | 
|  | #endif | 
|  |  | 
|  | #include "config/aom_config.h" | 
|  |  | 
|  | #include "aom/aom_codec.h" | 
|  | #include "aom/aom_frame_buffer.h" | 
|  | #include "aom/aom_integer.h" | 
|  |  | 
|  | #define AOMINNERBORDERINPIXELS 160 | 
|  | #define AOM_INTERP_EXTEND 4 | 
|  |  | 
|  | // TODO(jingning): Use unified inter predictor for encoder and | 
|  | // decoder during the development process. Revisit the frame border | 
|  | // to improve the decoder performance. | 
|  | #if CONFIG_REDUCED_ENCODER_BORDER | 
|  | #define AOM_BORDER_IN_PIXELS 160 | 
|  | #else | 
|  | #define AOM_BORDER_IN_PIXELS 288 | 
|  | #endif  // CONFIG_REDUCED_ENCODER_BORDER | 
|  |  | 
|  | typedef struct yv12_buffer_config { | 
|  | union { | 
|  | struct { | 
|  | int y_width; | 
|  | int uv_width; | 
|  | }; | 
|  | int widths[2]; | 
|  | }; | 
|  | union { | 
|  | struct { | 
|  | int y_height; | 
|  | int uv_height; | 
|  | }; | 
|  | int heights[2]; | 
|  | }; | 
|  | union { | 
|  | struct { | 
|  | int y_crop_width; | 
|  | int uv_crop_width; | 
|  | }; | 
|  | int crop_widths[2]; | 
|  | }; | 
|  | union { | 
|  | struct { | 
|  | int y_crop_height; | 
|  | int uv_crop_height; | 
|  | }; | 
|  | int crop_heights[2]; | 
|  | }; | 
|  | union { | 
|  | struct { | 
|  | int y_stride; | 
|  | int uv_stride; | 
|  | }; | 
|  | int strides[2]; | 
|  | }; | 
|  | union { | 
|  | struct { | 
|  | uint8_t *y_buffer; | 
|  | uint8_t *u_buffer; | 
|  | uint8_t *v_buffer; | 
|  | }; | 
|  | uint8_t *buffers[3]; | 
|  | }; | 
|  |  | 
|  | // Indicate whether y_buffer, u_buffer, and v_buffer points to the internally | 
|  | // allocated memory or external buffers. | 
|  | int use_external_reference_buffers; | 
|  | // This is needed to store y_buffer, u_buffer, and v_buffer when set reference | 
|  | // uses an external refernece, and restore those buffer pointers after the | 
|  | // external reference frame is no longer used. | 
|  | uint8_t *store_buf_adr[3]; | 
|  |  | 
|  | // If the frame is stored in a 16-bit buffer, this stores an 8-bit version | 
|  | // for use in global motion detection. It is allocated on-demand. | 
|  | uint8_t *y_buffer_8bit; | 
|  | int buf_8bit_valid; | 
|  |  | 
|  | uint8_t *buffer_alloc; | 
|  | size_t buffer_alloc_sz; | 
|  | int border; | 
|  | size_t frame_size; | 
|  | int subsampling_x; | 
|  | int subsampling_y; | 
|  | unsigned int bit_depth; | 
|  | aom_color_primaries_t color_primaries; | 
|  | aom_transfer_characteristics_t transfer_characteristics; | 
|  | aom_matrix_coefficients_t matrix_coefficients; | 
|  | int monochrome; | 
|  | aom_chroma_sample_position_t chroma_sample_position; | 
|  | aom_color_range_t color_range; | 
|  | int render_width; | 
|  | int render_height; | 
|  |  | 
|  | int corrupted; | 
|  | int flags; | 
|  | } YV12_BUFFER_CONFIG; | 
|  |  | 
|  | #define YV12_FLAG_HIGHBITDEPTH 8 | 
|  |  | 
|  | int aom_alloc_frame_buffer(YV12_BUFFER_CONFIG *ybf, int width, int height, | 
|  | int ss_x, int ss_y, int use_highbitdepth, int border, | 
|  | int byte_alignment); | 
|  |  | 
|  | // Updates the yv12 buffer config with the frame buffer. |byte_alignment| must | 
|  | // be a power of 2, from 32 to 1024. 0 sets legacy alignment. If cb is not | 
|  | // NULL, then libaom is using the frame buffer callbacks to handle memory. | 
|  | // If cb is not NULL, libaom will call cb with minimum size in bytes needed | 
|  | // to decode the current frame. If cb is NULL, libaom will allocate memory | 
|  | // internally to decode the current frame. Returns 0 on success. Returns < 0 | 
|  | // on failure. | 
|  | int aom_realloc_frame_buffer(YV12_BUFFER_CONFIG *ybf, int width, int height, | 
|  | int ss_x, int ss_y, int use_highbitdepth, | 
|  | int border, int byte_alignment, | 
|  | aom_codec_frame_buffer_t *fb, | 
|  | aom_get_frame_buffer_cb_fn_t cb, void *cb_priv); | 
|  | int aom_free_frame_buffer(YV12_BUFFER_CONFIG *ybf); | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | } | 
|  | #endif | 
|  |  | 
|  | #endif  // AOM_AOM_SCALE_YV12CONFIG_H_ |