blob: 7504c0e127cc00656edcd2bbb26f1e35a34d28bb [file] [log] [blame]
John Koleszar0ea50ce2010-05-18 11:58:33 -04001/*
John Koleszarc2140b82010-09-09 08:16:39 -04002 * Copyright (c) 2010 The WebM project authors. All Rights Reserved.
John Koleszar0ea50ce2010-05-18 11:58:33 -04003 *
John Koleszar94c52e42010-06-18 12:39:21 -04004 * Use of this source code is governed by a BSD-style license
John Koleszar09202d82010-06-04 16:19:40 -04005 * 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
John Koleszar94c52e42010-06-18 12:39:21 -04007 * in the file PATENTS. All contributing project authors may
John Koleszar09202d82010-06-04 16:19:40 -04008 * be found in the AUTHORS file in the root of the source tree.
John Koleszar0ea50ce2010-05-18 11:58:33 -04009 */
James Zern7386bde2013-12-15 18:26:15 -080010#ifndef VPX_VP8CX_H_
11#define VPX_VP8CX_H_
John Koleszar0ea50ce2010-05-18 11:58:33 -040012
Yaowu Xuf5bbe242015-01-15 14:32:42 -080013/*!\defgroup vp8_encoder WebM VP8/VP9 Encoder
John Koleszar0ea50ce2010-05-18 11:58:33 -040014 * \ingroup vp8
15 *
16 * @{
17 */
Johanne883c742013-12-16 13:15:26 -080018#include "./vp8.h"
James Zern7999c072015-03-23 16:07:21 -070019#include "./vpx_encoder.h"
John Koleszar0ea50ce2010-05-18 11:58:33 -040020
James Zernf42d52e2011-02-16 17:54:49 -080021/*!\file
Yaowu Xuf5bbe242015-01-15 14:32:42 -080022 * \brief Provides definitions for using VP8 or VP9 encoder algorithm within the
John Koleszar0ea50ce2010-05-18 11:58:33 -040023 * vpx Codec Interface.
24 */
Dmitry Kovaleve288c602013-09-29 18:00:15 -070025
26#ifdef __cplusplus
27extern "C" {
28#endif
John Koleszar0ea50ce2010-05-18 11:58:33 -040029
James Zern8e17e822011-02-24 14:12:57 -080030/*!\name Algorithm interface for VP8
John Koleszar0ea50ce2010-05-18 11:58:33 -040031 *
Yaowu Xuf5bbe242015-01-15 14:32:42 -080032 * This interface provides the capability to encode raw VP8 streams.
James Zern8e17e822011-02-24 14:12:57 -080033 * @{
John Koleszar0ea50ce2010-05-18 11:58:33 -040034 */
John Koleszarfa7a55b2010-09-21 10:35:52 -040035extern vpx_codec_iface_t vpx_codec_vp8_cx_algo;
John Koleszarc6b90392012-07-13 15:21:29 -070036extern vpx_codec_iface_t *vpx_codec_vp8_cx(void);
Yaowu Xuf5bbe242015-01-15 14:32:42 -080037/*!@} - end algorithm interface member group*/
John Koleszar0ea50ce2010-05-18 11:58:33 -040038
Yaowu Xuf5bbe242015-01-15 14:32:42 -080039/*!\name Algorithm interface for VP9
40 *
41 * This interface provides the capability to encode raw VP9 streams.
42 * @{
43 */
John Koleszara9c75972012-11-08 17:09:30 -080044extern vpx_codec_iface_t vpx_codec_vp9_cx_algo;
45extern vpx_codec_iface_t *vpx_codec_vp9_cx(void);
John Koleszar83b1d902012-11-05 12:37:14 -080046/*!@} - end algorithm interface member group*/
John Koleszar0952acb2010-06-01 11:14:25 -040047
Jingning Han3ee6db62015-08-05 19:00:31 -070048/*!\name Algorithm interface for VP10
49 *
50 * This interface provides the capability to encode raw VP9 streams.
51 * @{
52 */
53extern vpx_codec_iface_t vpx_codec_vp10_cx_algo;
54extern vpx_codec_iface_t *vpx_codec_vp10_cx(void);
55/*!@} - end algorithm interface member group*/
John Koleszar0952acb2010-06-01 11:14:25 -040056
John Koleszar0ea50ce2010-05-18 11:58:33 -040057/*
58 * Algorithm Flags
59 */
60
61/*!\brief Don't reference the last frame
62 *
63 * When this flag is set, the encoder will not use the last frame as a
64 * predictor. When not set, the encoder will choose whether to use the
65 * last frame or not automatically.
66 */
67#define VP8_EFLAG_NO_REF_LAST (1<<16)
68
69
70/*!\brief Don't reference the golden frame
71 *
72 * When this flag is set, the encoder will not use the golden frame as a
73 * predictor. When not set, the encoder will choose whether to use the
74 * golden frame or not automatically.
75 */
76#define VP8_EFLAG_NO_REF_GF (1<<17)
77
78
79/*!\brief Don't reference the alternate reference frame
80 *
81 * When this flag is set, the encoder will not use the alt ref frame as a
82 * predictor. When not set, the encoder will choose whether to use the
83 * alt ref frame or not automatically.
84 */
85#define VP8_EFLAG_NO_REF_ARF (1<<21)
86
87
88/*!\brief Don't update the last frame
89 *
90 * When this flag is set, the encoder will not update the last frame with
91 * the contents of the current frame.
92 */
93#define VP8_EFLAG_NO_UPD_LAST (1<<18)
94
95
96/*!\brief Don't update the golden frame
97 *
98 * When this flag is set, the encoder will not update the golden frame with
99 * the contents of the current frame.
100 */
101#define VP8_EFLAG_NO_UPD_GF (1<<22)
102
103
104/*!\brief Don't update the alternate reference frame
105 *
106 * When this flag is set, the encoder will not update the alt ref frame with
107 * the contents of the current frame.
108 */
109#define VP8_EFLAG_NO_UPD_ARF (1<<23)
110
111
112/*!\brief Force golden frame update
113 *
114 * When this flag is set, the encoder copy the contents of the current frame
115 * to the golden frame buffer.
116 */
117#define VP8_EFLAG_FORCE_GF (1<<19)
118
119
120/*!\brief Force alternate reference frame update
121 *
122 * When this flag is set, the encoder copy the contents of the current frame
123 * to the alternate reference frame buffer.
124 */
125#define VP8_EFLAG_FORCE_ARF (1<<24)
126
127
128/*!\brief Disable entropy update
129 *
130 * When this flag is set, the encoder will not update its internal entropy
131 * model based on the entropy of this frame.
132 */
133#define VP8_EFLAG_NO_UPD_ENTROPY (1<<20)
134
135
Yaowu Xu41652902015-03-12 17:59:18 -0700136/*!\brief VPx encoder control functions
John Koleszar0ea50ce2010-05-18 11:58:33 -0400137 *
Yaowu Xu41652902015-03-12 17:59:18 -0700138 * This set of macros define the control functions available for VPx
James Zern8e17e822011-02-24 14:12:57 -0800139 * encoder interface.
140 *
141 * \sa #vpx_codec_control
John Koleszar0ea50ce2010-05-18 11:58:33 -0400142 */
John Koleszarc6b90392012-07-13 15:21:29 -0700143enum vp8e_enc_control_id {
Yaowu Xu268f1062015-03-13 09:42:57 -0700144 /*!\brief Codec control function to pass an ROI map to encoder.
145 *
146 * Supported in codecs: VP8, VP9
147 */
James Zerna046f562015-10-16 16:47:38 -0700148 VP8E_SET_ROI_MAP = 8,
Yaowu Xu268f1062015-03-13 09:42:57 -0700149
150 /*!\brief Codec control function to pass an Active map to encoder.
151 *
152 * Supported in codecs: VP8, VP9
153 */
154 VP8E_SET_ACTIVEMAP,
155
156 /*!\brief Codec control function to set encoder scaling mode.
157 *
158 * Supported in codecs: VP8, VP9
159 */
160 VP8E_SET_SCALEMODE = 11,
161
162 /*!\brief Codec control function to set encoder internal speed settings.
John Koleszarc6b90392012-07-13 15:21:29 -0700163 *
164 * Changes in this value influences, among others, the encoder's selection
165 * of motion estimation methods. Values greater than 0 will increase encoder
166 * speed at the expense of quality.
John Koleszarc6b90392012-07-13 15:21:29 -0700167 *
Yaowu Xu268f1062015-03-13 09:42:57 -0700168 * \note Valid range for VP8: -16..16
169 * \note Valid range for VP9: -8..8
170 *
171 * Supported in codecs: VP8, VP9
John Koleszarc6b90392012-07-13 15:21:29 -0700172 */
173 VP8E_SET_CPUUSED = 13,
Yaowu Xu268f1062015-03-13 09:42:57 -0700174
175 /*!\brief Codec control function to enable automatic set and use alf frames.
176 *
177 * Supported in codecs: VP8, VP9
178 */
179 VP8E_SET_ENABLEAUTOALTREF,
180
JackyChenbb1a2362014-09-12 11:48:44 -0700181 /*!\brief control function to set noise sensitivity
182 *
183 * 0: off, 1: OnYOnly, 2: OnYUV,
184 * 3: OnYUVAggressive, 4: Adaptive
Yaowu Xu268f1062015-03-13 09:42:57 -0700185 *
186 * Supported in codecs: VP8
JackyChenbb1a2362014-09-12 11:48:44 -0700187 */
188 VP8E_SET_NOISE_SENSITIVITY,
Adrian Grangea7657052014-05-05 11:31:55 -0700189
Yaowu Xu268f1062015-03-13 09:42:57 -0700190 /*!\brief Codec control function to set sharpness.
191 *
192 * Supported in codecs: VP8, VP9
193 */
194 VP8E_SET_SHARPNESS,
195
196 /*!\brief Codec control function to set the threshold for MBs treated static.
197 *
198 * Supported in codecs: VP8, VP9
199 */
200 VP8E_SET_STATIC_THRESHOLD,
201
202 /*!\brief Codec control function to set the number of token partitions.
203 *
204 * Supported in codecs: VP8
205 */
206 VP8E_SET_TOKEN_PARTITIONS,
207
208 /*!\brief Codec control function to get last quantizer chosen by the encoder.
209 *
210 * Return value uses internal quantizer scale defined by the codec.
211 *
212 * Supported in codecs: VP8, VP9
213 */
214 VP8E_GET_LAST_QUANTIZER,
215
216 /*!\brief Codec control function to get last quantizer chosen by the encoder.
217 *
218 * Return value uses the 0..63 scale as used by the rc_*_quantizer config
219 * parameters.
220 *
221 * Supported in codecs: VP8, VP9
222 */
223 VP8E_GET_LAST_QUANTIZER_64,
224
225 /*!\brief Codec control function to set the max no of frames to create arf.
226 *
227 * Supported in codecs: VP8, VP9
228 */
229 VP8E_SET_ARNR_MAXFRAMES,
230
231 /*!\brief Codec control function to set the filter strength for the arf.
232 *
233 * Supported in codecs: VP8, VP9
234 */
235 VP8E_SET_ARNR_STRENGTH,
236
237 /*!\deprecated control function to set the filter type to use for the arf. */
Adrian Grangea7657052014-05-05 11:31:55 -0700238 VP8E_SET_ARNR_TYPE,
239
Yaowu Xu268f1062015-03-13 09:42:57 -0700240 /*!\brief Codec control function to set visual tuning.
241 *
242 * Supported in codecs: VP8, VP9
243 */
244 VP8E_SET_TUNING,
245
246 /*!\brief Codec control function to set constrained quality level.
John Koleszarc6b90392012-07-13 15:21:29 -0700247 *
248 * \attention For this value to be used vpx_codec_enc_cfg_t::g_usage must be
249 * set to #VPX_CQ.
250 * \note Valid range: 0..63
Yaowu Xu268f1062015-03-13 09:42:57 -0700251 *
252 * Supported in codecs: VP8, VP9
John Koleszarc6b90392012-07-13 15:21:29 -0700253 */
254 VP8E_SET_CQ_LEVEL,
John Koleszar1654ae92011-07-28 09:17:32 -0400255
Yaowu Xu268f1062015-03-13 09:42:57 -0700256 /*!\brief Codec control function to set Max data rate for Intra frames.
John Koleszarc6b90392012-07-13 15:21:29 -0700257 *
258 * This value controls additional clamping on the maximum size of a
259 * keyframe. It is expressed as a percentage of the average
260 * per-frame bitrate, with the special (and default) value 0 meaning
261 * unlimited, or no additional clamping beyond the codec's built-in
262 * algorithm.
263 *
264 * For example, to allocate no more than 4.5 frames worth of bitrate
265 * to a keyframe, set this to 450.
266 *
Yaowu Xu268f1062015-03-13 09:42:57 -0700267 * Supported in codecs: VP8, VP9
John Koleszarc6b90392012-07-13 15:21:29 -0700268 */
269 VP8E_SET_MAX_INTRA_BITRATE_PCT,
John Koleszar83b1d902012-11-05 12:37:14 -0800270
Yaowu Xu268f1062015-03-13 09:42:57 -0700271 /*!\brief Codec control function to set reference and update frame flags.
272 *
273 * Supported in codecs: VP8
274 */
275 VP8E_SET_FRAME_FLAGS,
276
277 /*!\brief Codec control function to set max data rate for Inter frames.
Yaowu Xu636099f2014-10-24 09:31:16 -0700278 *
279 * This value controls additional clamping on the maximum size of an
280 * inter frame. It is expressed as a percentage of the average
281 * per-frame bitrate, with the special (and default) value 0 meaning
282 * unlimited, or no additional clamping beyond the codec's built-in
283 * algorithm.
284 *
285 * For example, to allow no more than 4.5 frames worth of bitrate
286 * to an inter frame, set this to 450.
287 *
Yaowu Xu268f1062015-03-13 09:42:57 -0700288 * Supported in codecs: VP9
Yaowu Xu636099f2014-10-24 09:31:16 -0700289 */
Yaowu Xu268f1062015-03-13 09:42:57 -0700290 VP9E_SET_MAX_INTER_BITRATE_PCT,
Yaowu Xu636099f2014-10-24 09:31:16 -0700291
Yaowu Xu268f1062015-03-13 09:42:57 -0700292 /*!\brief Boost percentage for Golden Frame in CBR mode.
Yaowu Xu03a60b72014-10-27 13:13:14 -0700293 *
294 * This value controls the amount of boost given to Golden Frame in
295 * CBR mode. It is expressed as a percentage of the average
296 * per-frame bitrate, with the special (and default) value 0 meaning
297 * the feature is off, i.e., no golden frame boost in CBR mode and
298 * average bitrate target is used.
299 *
300 * For example, to allow 100% more bits, i.e, 2X, in a golden frame
301 * than average frame, set this to 100.
302 *
Yaowu Xu41652902015-03-12 17:59:18 -0700303 * Supported in codecs: VP9
Yaowu Xu03a60b72014-10-27 13:13:14 -0700304 */
Yaowu Xu41652902015-03-12 17:59:18 -0700305 VP9E_SET_GF_CBR_BOOST_PCT,
John Koleszar83b1d902012-11-05 12:37:14 -0800306
Yaowu Xu268f1062015-03-13 09:42:57 -0700307 /*!\brief Codec control function to set the temporal layer id.
Marcoaf898b52014-11-10 13:07:05 -0800308 *
309 * For temporal scalability: this control allows the application to set the
310 * layer id for each frame to be encoded. Note that this control must be set
311 * for every frame prior to encoding. The usage of this control function
312 * supersedes the internal temporal pattern counter, which is now deprecated.
Yaowu Xu268f1062015-03-13 09:42:57 -0700313 *
314 * Supported in codecs: VP8
Marcoaf898b52014-11-10 13:07:05 -0800315 */
316 VP8E_SET_TEMPORAL_LAYER_ID,
317
Yaowu Xu268f1062015-03-13 09:42:57 -0700318 /*!\brief Codec control function to set encoder screen content mode.
319 *
Marco976f7f42015-04-28 08:29:48 -0700320 * 0: off, 1: On, 2: On with more aggressive rate control.
321 *
Yaowu Xu268f1062015-03-13 09:42:57 -0700322 * Supported in codecs: VP8
323 */
324 VP8E_SET_SCREEN_CONTENT_MODE,
Marcoaf898b52014-11-10 13:07:05 -0800325
Yaowu Xu268f1062015-03-13 09:42:57 -0700326 /*!\brief Codec control function to set lossless encoding mode.
Yaowu Xu87c436f2015-01-13 12:39:42 -0800327 *
328 * VP9 can operate in lossless encoding mode, in which the bitstream
329 * produced will be able to decode and reconstruct a perfect copy of
330 * input source. This control function provides a mean to switch encoder
331 * into lossless coding mode(1) or normal coding mode(0) that may be lossy.
332 * 0 = lossy coding mode
333 * 1 = lossless coding mode
334 *
335 * By default, encoder operates in normal coding mode (maybe lossy).
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700336 *
337 * Supported in codecs: VP9
Yaowu Xu87c436f2015-01-13 12:39:42 -0800338 */
Ronald S. Bultje1407bdc2013-02-01 09:35:28 -0800339 VP9E_SET_LOSSLESS,
Yaowu Xu87c436f2015-01-13 12:39:42 -0800340
Yaowu Xu268f1062015-03-13 09:42:57 -0700341 /*!\brief Codec control function to set number of tile columns.
Yaowu Xu87c436f2015-01-13 12:39:42 -0800342 *
343 * In encoding and decoding, VP9 allows an input image frame be partitioned
344 * into separated vertical tile columns, which can be encoded or decoded
345 * independently. This enables easy implementation of parallel encoding and
346 * decoding. This control requests the encoder to use column tiles in
347 * encoding an input frame, with number of tile columns (in Log2 unit) as
348 * the parameter:
349 * 0 = 1 tile column
350 * 1 = 2 tile columns
351 * 2 = 4 tile columns
352 * .....
353 * n = 2**n tile columns
354 * The requested tile columns will be capped by encoder based on image size
355 * limitation (The minimum width of a tile column is 256 pixel, the maximum
356 * is 4096).
357 *
358 * By default, the value is 0, i.e. one single column tile for entire image.
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700359 *
360 * Supported in codecs: VP9
Yaowu Xu87c436f2015-01-13 12:39:42 -0800361 */
Ronald S. Bultje89a206e2013-02-08 11:33:11 -0800362 VP9E_SET_TILE_COLUMNS,
Yaowu Xu87c436f2015-01-13 12:39:42 -0800363
Yaowu Xu268f1062015-03-13 09:42:57 -0700364 /*!\brief Codec control function to set number of tile rows.
Yaowu Xu87c436f2015-01-13 12:39:42 -0800365 *
366 * In encoding and decoding, VP9 allows an input image frame be partitioned
367 * into separated horizontal tile rows. Tile rows are encoded or decoded
368 * sequentially. Even though encoding/decoding of later tile rows depends on
369 * earlier ones, this allows the encoder to output data packets for tile rows
370 * prior to completely processing all tile rows in a frame, thereby reducing
371 * the latency in processing between input and output. The parameter
372 * for this control describes the number of tile rows, which has a valid
373 * range [0, 2]:
374 * 0 = 1 tile row
375 * 1 = 2 tile rows
376 * 2 = 4 tile rows
377 *
378 * By default, the value is 0, i.e. one single row tile for entire image.
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700379 *
380 * Supported in codecs: VP9
Yaowu Xu87c436f2015-01-13 12:39:42 -0800381 */
Ronald S. Bultje89a206e2013-02-08 11:33:11 -0800382 VP9E_SET_TILE_ROWS,
Yaowu Xu87c436f2015-01-13 12:39:42 -0800383
Yaowu Xu268f1062015-03-13 09:42:57 -0700384 /*!\brief Codec control function to enable frame parallel decoding feature.
Yaowu Xu87c436f2015-01-13 12:39:42 -0800385 *
386 * VP9 has a bitstream feature to reduce decoding dependency between frames
387 * by turning off backward update of probability context used in encoding
388 * and decoding. This allows staged parallel processing of more than one
389 * video frames in the decoder. This control function provides a mean to
390 * turn this feature on or off for bitstreams produced by encoder.
391 *
392 * By default, this feature is off.
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700393 *
394 * Supported in codecs: VP9
Yaowu Xu87c436f2015-01-13 12:39:42 -0800395 */
Ivan Maltz01b35c32013-09-05 08:55:47 -0700396 VP9E_SET_FRAME_PARALLEL_DECODING,
Yaowu Xu87c436f2015-01-13 12:39:42 -0800397
Yaowu Xu268f1062015-03-13 09:42:57 -0700398 /*!\brief Codec control function to set adaptive quantization mode.
Yaowu Xu87c436f2015-01-13 12:39:42 -0800399 *
400 * VP9 has a segment based feature that allows encoder to adaptively change
401 * quantization parameter for each segment within a frame to improve the
402 * subjective quality. This control makes encoder operate in one of the
403 * several AQ_modes supported.
404 *
405 * By default, encoder operates with AQ_Mode 0(adaptive quantization off).
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700406 *
407 * Supported in codecs: VP9
Yaowu Xu87c436f2015-01-13 12:39:42 -0800408 */
Guillaume Martres17084652013-11-14 19:23:57 +0100409 VP9E_SET_AQ_MODE,
Yaowu Xu4ab39e12015-01-14 09:07:02 -0800410
Yaowu Xu268f1062015-03-13 09:42:57 -0700411 /*!\brief Codec control function to enable/disable periodic Q boost.
Yaowu Xu4ab39e12015-01-14 09:07:02 -0800412 *
413 * One VP9 encoder speed feature is to enable quality boost by lowering
414 * frame level Q periodically. This control function provides a mean to
415 * turn on/off this feature.
416 * 0 = off
417 * 1 = on
418 *
419 * By default, the encoder is allowed to use this feature for appropriate
420 * encoding modes.
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700421 *
422 * Supported in codecs: VP9
Yaowu Xu4ab39e12015-01-14 09:07:02 -0800423 */
Marco Paniconi0eb88c92014-04-03 15:49:03 -0700424 VP9E_SET_FRAME_PERIODIC_BOOST,
Yaowu Xu4ab39e12015-01-14 09:07:02 -0800425
Yaowu Xu268f1062015-03-13 09:42:57 -0700426 /*!\brief Codec control function to set noise sensitivity.
JackyChenbb1a2362014-09-12 11:48:44 -0700427 *
Yaowu Xu268f1062015-03-13 09:42:57 -0700428 * 0: off, 1: On(YOnly)
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700429 *
430 * Supported in codecs: VP9
JackyChenbb1a2362014-09-12 11:48:44 -0700431 */
432 VP9E_SET_NOISE_SENSITIVITY,
Ivan Maltz01b35c32013-09-05 08:55:47 -0700433
Yaowu Xu268f1062015-03-13 09:42:57 -0700434 /*!\brief Codec control function to turn on/off SVC in encoder.
Yaowu Xu3ca15a82015-01-14 12:02:46 -0800435 * \note Return value is VPX_CODEC_INVALID_PARAM if the encoder does not
436 * support SVC in its current encoding mode
437 * 0: off, 1: on
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700438 *
439 * Supported in codecs: VP9
Yaowu Xu3ca15a82015-01-14 12:02:46 -0800440 */
Ivan Maltz01b35c32013-09-05 08:55:47 -0700441 VP9E_SET_SVC,
Yaowu Xu3ca15a82015-01-14 12:02:46 -0800442
Yaowu Xu268f1062015-03-13 09:42:57 -0700443 /*!\brief Codec control function to set parameters for SVC.
Yaowu Xu3ca15a82015-01-14 12:02:46 -0800444 * \note Parameters contain min_q, max_q, scaling factor for each of the
445 * SVC layers.
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700446 *
447 * Supported in codecs: VP9
Yaowu Xu3ca15a82015-01-14 12:02:46 -0800448 */
Marco Paniconi4864ab22014-02-06 09:23:17 -0800449 VP9E_SET_SVC_PARAMETERS,
Deb Mukherjee0ba15422014-11-07 11:01:53 -0800450
Yaowu Xu268f1062015-03-13 09:42:57 -0700451 /*!\brief Codec control function to set svc layer for spatial and temporal.
James Zern53a11c92014-02-20 20:36:28 -0800452 * \note Valid ranges: 0..#vpx_codec_enc_cfg::ss_number_layers for spatial
453 * layer and 0..#vpx_codec_enc_cfg::ts_number_layers for
454 * temporal layer.
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700455 *
456 * Supported in codecs: VP9
James Zern53a11c92014-02-20 20:36:28 -0800457 */
Alex Converse572de922014-07-31 08:27:32 -0700458 VP9E_SET_SVC_LAYER_ID,
Yaowu Xudc08b202015-01-14 11:17:09 -0800459
Yaowu Xu268f1062015-03-13 09:42:57 -0700460 /*!\brief Codec control function to set content type.
Yaowu Xudc08b202015-01-14 11:17:09 -0800461 * \note Valid parameter range:
462 * VP9E_CONTENT_DEFAULT = Regular video content (Default)
463 * VP9E_CONTENT_SCREEN = Screen capture content
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700464 *
465 * Supported in codecs: VP9
Yaowu Xudc08b202015-01-14 11:17:09 -0800466 */
Deb Mukherjee0ba15422014-11-07 11:01:53 -0800467 VP9E_SET_TUNE_CONTENT,
Yaowu Xu193ca4b2015-01-14 11:48:29 -0800468
Yaowu Xu268f1062015-03-13 09:42:57 -0700469 /*!\brief Codec control function to get svc layer ID.
Yaowu Xu193ca4b2015-01-14 11:48:29 -0800470 * \note The layer ID returned is for the data packet from the registered
471 * callback function.
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700472 *
473 * Supported in codecs: VP9
Yaowu Xu193ca4b2015-01-14 11:48:29 -0800474 */
Deb Mukherjee0ba15422014-11-07 11:01:53 -0800475 VP9E_GET_SVC_LAYER_ID,
Yaowu Xu193ca4b2015-01-14 11:48:29 -0800476
Yaowu Xu268f1062015-03-13 09:42:57 -0700477 /*!\brief Codec control function to register callback to get per layer packet.
Yaowu Xu193ca4b2015-01-14 11:48:29 -0800478 * \note Parameter for this control function is a structure with a callback
479 * function and a pointer to private data used by the callback.
Yaowu Xu268f1062015-03-13 09:42:57 -0700480 *
481 * Supported in codecs: VP9
Yaowu Xu193ca4b2015-01-14 11:48:29 -0800482 */
Deb Mukherjee0ba15422014-11-07 11:01:53 -0800483 VP9E_REGISTER_CX_CALLBACK,
Yaowu Xue94b4152015-01-13 10:07:20 -0800484
Yaowu Xu268f1062015-03-13 09:42:57 -0700485 /*!\brief Codec control function to set color space info.
Yaowu Xue94b4152015-01-13 10:07:20 -0800486 * \note Valid ranges: 0..7, default is "UNKNOWN".
487 * 0 = UNKNOWN,
488 * 1 = BT_601
489 * 2 = BT_709
490 * 3 = SMPTE_170
491 * 4 = SMPTE_240
492 * 5 = BT_2020
493 * 6 = RESERVED
494 * 7 = SRGB
Yaowu Xu5dd146c2015-03-12 18:14:43 -0700495 *
496 * Supported in codecs: VP9
Yaowu Xue94b4152015-01-13 10:07:20 -0800497 */
498 VP9E_SET_COLOR_SPACE,
Alex Converse4dcb8392015-03-20 14:55:43 -0700499
Marcoc139b812015-05-21 16:15:37 -0700500 /*!\brief Codec control function to set temporal layering mode.
501 * \note Valid ranges: 0..3, default is "0" (VP9E_TEMPORAL_LAYERING_MODE_NOLAYERING).
502 * 0 = VP9E_TEMPORAL_LAYERING_MODE_NOLAYERING
503 * 1 = VP9E_TEMPORAL_LAYERING_MODE_BYPASS
504 * 2 = VP9E_TEMPORAL_LAYERING_MODE_0101
505 * 3 = VP9E_TEMPORAL_LAYERING_MODE_0212
506 *
507 * Supported in codecs: VP9
508 */
509 VP9E_SET_TEMPORAL_LAYERING_MODE,
510
Debargha Mukherjee98526432015-04-01 16:39:06 -0700511 /*!\brief Codec control function to set minimum interval between GF/ARF frames
512 *
513 * By default the value is set as 4.
514 *
515 * Supported in codecs: VP9
516 */
517 VP9E_SET_MIN_GF_INTERVAL,
518
519 /*!\brief Codec control function to set minimum interval between GF/ARF frames
520 *
521 * By default the value is set as 16.
522 *
523 * Supported in codecs: VP9
524 */
525 VP9E_SET_MAX_GF_INTERVAL,
526
Alex Converse4dcb8392015-03-20 14:55:43 -0700527 /*!\brief Codec control function to get an Active map back from the encoder.
528 *
529 * Supported in codecs: VP9
530 */
531 VP9E_GET_ACTIVEMAP,
Ronald S. Bultjeeeb5ef02015-09-15 21:56:51 -0400532
533 /*!\brief Codec control function to set color range bit.
534 * \note Valid ranges: 0..1, default is 0
535 * 0 = Limited range (16..235 or HBD equivalent)
536 * 1 = Full range (0..255 or HBD equivalent)
537 *
538 * Supported in codecs: VP9
539 */
540 VP9E_SET_COLOR_RANGE,
Yaowu Xu7c514e22015-09-28 15:55:46 -0700541
542 /*!\brief Codec control function to set the frame flags and buffer indices
543 * for spatial layers. The frame flags and buffer indices are set using the
544 * struct #vpx_svc_ref_frame_config defined below.
545 *
546 * Supported in codecs: VP9
547 */
548 VP9E_SET_SVC_REF_FRAME_CONFIG,
549
550 /*!\brief Codec control function to set intended rendering image size.
551 *
552 * By default, this is identical to the image size in pixels.
553 *
554 * Supported in codecs: VP9
555 */
556 VP9E_SET_RENDER_SIZE,
John Koleszarb0da9b32010-12-17 09:43:39 -0500557};
John Koleszar0ea50ce2010-05-18 11:58:33 -0400558
559/*!\brief vpx 1-D scaling mode
560 *
561 * This set of constants define 1-D vpx scaling modes
562 */
John Koleszarc6b90392012-07-13 15:21:29 -0700563typedef enum vpx_scaling_mode_1d {
564 VP8E_NORMAL = 0,
565 VP8E_FOURFIVE = 1,
566 VP8E_THREEFIVE = 2,
567 VP8E_ONETWO = 3
John Koleszar0ea50ce2010-05-18 11:58:33 -0400568} VPX_SCALING_MODE;
569
Marcoc139b812015-05-21 16:15:37 -0700570/*!\brief Temporal layering mode enum for VP9 SVC.
571 *
572 * This set of macros define the different temporal layering modes.
573 * Supported codecs: VP9 (in SVC mode)
574 *
575 */
576typedef enum vp9e_temporal_layering_mode {
577 /*!\brief No temporal layering.
578 * Used when only spatial layering is used.
579 */
580 VP9E_TEMPORAL_LAYERING_MODE_NOLAYERING = 0,
581
582 /*!\brief Bypass mode.
583 * Used when application needs to control temporal layering.
584 * This will only work when the number of spatial layers equals 1.
585 */
586 VP9E_TEMPORAL_LAYERING_MODE_BYPASS = 1,
587
588 /*!\brief 0-1-0-1... temporal layering scheme with two temporal layers.
589 */
590 VP9E_TEMPORAL_LAYERING_MODE_0101 = 2,
591
592 /*!\brief 0-2-1-2... temporal layering scheme with three temporal layers.
593 */
594 VP9E_TEMPORAL_LAYERING_MODE_0212 = 3
595} VP9E_TEMPORAL_LAYERING_MODE;
John Koleszar0ea50ce2010-05-18 11:58:33 -0400596
597/*!\brief vpx region of interest map
598 *
599 * These defines the data structures for the region of interest map
600 *
601 */
602
John Koleszarc6b90392012-07-13 15:21:29 -0700603typedef struct vpx_roi_map {
Adrian Grangef58eca92013-10-24 15:11:36 -0700604 /*! An id between 0 and 3 for each 16x16 region within a frame. */
605 unsigned char *roi_map;
606 unsigned int rows; /**< Number of rows. */
607 unsigned int cols; /**< Number of columns. */
Paul Wilkins31ee1932013-04-24 13:04:45 +0100608 // TODO(paulwilkins): broken for VP9 which has 8 segments
609 // q and loop filter deltas for each segment
610 // (see MAX_MB_SEGMENTS)
Adrian Grangef58eca92013-10-24 15:11:36 -0700611 int delta_q[4]; /**< Quantizer deltas. */
612 int delta_lf[4]; /**< Loop filter deltas. */
613 /*! Static breakout threshold for each segment. */
614 unsigned int static_threshold[4];
John Koleszar0ea50ce2010-05-18 11:58:33 -0400615} vpx_roi_map_t;
616
617/*!\brief vpx active region map
618 *
619 * These defines the data structures for active region map
620 *
621 */
622
623
John Koleszarc6b90392012-07-13 15:21:29 -0700624typedef struct vpx_active_map {
625 unsigned char *active_map; /**< specify an on (1) or off (0) each 16x16 region within a frame */
626 unsigned int rows; /**< number of rows */
627 unsigned int cols; /**< number of cols */
John Koleszar0ea50ce2010-05-18 11:58:33 -0400628} vpx_active_map_t;
629
630/*!\brief vpx image scaling mode
631 *
632 * This defines the data structure for image scaling mode
633 *
634 */
John Koleszarc6b90392012-07-13 15:21:29 -0700635typedef struct vpx_scaling_mode {
636 VPX_SCALING_MODE h_scaling_mode; /**< horizontal scaling mode */
637 VPX_SCALING_MODE v_scaling_mode; /**< vertical scaling mode */
John Koleszar0ea50ce2010-05-18 11:58:33 -0400638} vpx_scaling_mode_t;
639
John Koleszar0ea50ce2010-05-18 11:58:33 -0400640/*!\brief VP8 token partition mode
641 *
642 * This defines VP8 partitioning mode for compressed data, i.e., the number of
Dmitry Kovalev116e0a12013-12-27 14:01:12 -0800643 * sub-streams in the bitstream. Used for parallelized decoding.
John Koleszar0ea50ce2010-05-18 11:58:33 -0400644 *
645 */
646
John Koleszarc6b90392012-07-13 15:21:29 -0700647typedef enum {
648 VP8_ONE_TOKENPARTITION = 0,
649 VP8_TWO_TOKENPARTITION = 1,
650 VP8_FOUR_TOKENPARTITION = 2,
John Koleszar83b1d902012-11-05 12:37:14 -0800651 VP8_EIGHT_TOKENPARTITION = 3
John Koleszar0ea50ce2010-05-18 11:58:33 -0400652} vp8e_token_partitions;
653
Alex Converse572de922014-07-31 08:27:32 -0700654/*!brief VP9 encoder content type */
655typedef enum {
656 VP9E_CONTENT_DEFAULT,
657 VP9E_CONTENT_SCREEN,
658 VP9E_CONTENT_INVALID
659} vp9e_tune_content;
John Koleszar0ea50ce2010-05-18 11:58:33 -0400660
John Koleszarb0da9b32010-12-17 09:43:39 -0500661/*!\brief VP8 model tuning parameters
662 *
663 * Changes the encoder to tune for certain types of input material.
664 *
665 */
John Koleszarc6b90392012-07-13 15:21:29 -0700666typedef enum {
667 VP8_TUNE_PSNR,
668 VP8_TUNE_SSIM
John Koleszarb0da9b32010-12-17 09:43:39 -0500669} vp8e_tuning;
670
Marco Paniconi89ec9902014-02-18 17:31:57 -0800671/*!\brief vp9 svc layer parameters
672 *
673 * This defines the spatial and temporal layer id numbers for svc encoding.
674 * This is used with the #VP9E_SET_SVC_LAYER_ID control to set the spatial and
675 * temporal layer id for the current frame.
676 *
677 */
Marco Paniconi4864ab22014-02-06 09:23:17 -0800678typedef struct vpx_svc_layer_id {
Marco Paniconi89ec9902014-02-18 17:31:57 -0800679 int spatial_layer_id; /**< Spatial layer id number. */
680 int temporal_layer_id; /**< Temporal layer id number. */
Marco Paniconi4864ab22014-02-06 09:23:17 -0800681} vpx_svc_layer_id_t;
682
Yaowu Xu7c514e22015-09-28 15:55:46 -0700683/*!\brief vp9 svc frame flag parameters.
684 *
685 * This defines the frame flags and buffer indices for each spatial layer for
686 * svc encoding.
687 * This is used with the #VP9E_SET_SVC_REF_FRAME_CONFIG control to set frame
688 * flags and buffer indices for each spatial layer for the current (super)frame.
689 *
690 */
691typedef struct vpx_svc_ref_frame_config {
692 int frame_flags[VPX_TS_MAX_LAYERS]; /**< Frame flags. */
693 int lst_fb_idx[VPX_TS_MAX_LAYERS]; /**< Last buffer index. */
694 int gld_fb_idx[VPX_TS_MAX_LAYERS]; /**< Golden buffer index. */
695 int alt_fb_idx[VPX_TS_MAX_LAYERS]; /**< Altref buffer index. */
696} vpx_svc_ref_frame_config_t;
697
James Zern7dd7a7d2015-10-09 16:31:17 -0700698/*!\cond */
John Koleszar0ea50ce2010-05-18 11:58:33 -0400699/*!\brief VP8 encoder control function parameter type
700 *
701 * Defines the data types that VP8E control functions take. Note that
702 * additional common controls are defined in vp8.h
703 *
704 */
705
Marcoaf898b52014-11-10 13:07:05 -0800706VPX_CTRL_USE_TYPE(VP8E_SET_FRAME_FLAGS, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700707#define VPX_CTRL_VP8E_SET_FRAME_FLAGS
Marcoaf898b52014-11-10 13:07:05 -0800708VPX_CTRL_USE_TYPE(VP8E_SET_TEMPORAL_LAYER_ID, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700709#define VPX_CTRL_VP8E_SET_TEMPORAL_LAYER_ID
John Koleszar0ea50ce2010-05-18 11:58:33 -0400710VPX_CTRL_USE_TYPE(VP8E_SET_ROI_MAP, vpx_roi_map_t *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700711#define VPX_CTRL_VP8E_SET_ROI_MAP
John Koleszar0ea50ce2010-05-18 11:58:33 -0400712VPX_CTRL_USE_TYPE(VP8E_SET_ACTIVEMAP, vpx_active_map_t *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700713#define VPX_CTRL_VP8E_SET_ACTIVEMAP
John Koleszar0ea50ce2010-05-18 11:58:33 -0400714VPX_CTRL_USE_TYPE(VP8E_SET_SCALEMODE, vpx_scaling_mode_t *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700715#define VPX_CTRL_VP8E_SET_SCALEMODE
John Koleszar0ea50ce2010-05-18 11:58:33 -0400716
Ivan Maltz01b35c32013-09-05 08:55:47 -0700717VPX_CTRL_USE_TYPE(VP9E_SET_SVC, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700718#define VPX_CTRL_VP9E_SET_SVC
Minghai Shang209ee122014-09-18 18:05:07 -0700719VPX_CTRL_USE_TYPE(VP9E_SET_SVC_PARAMETERS, void *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700720#define VPX_CTRL_VP9E_SET_SVC_PARAMETERS
Deb Mukherjee0ba15422014-11-07 11:01:53 -0800721VPX_CTRL_USE_TYPE(VP9E_REGISTER_CX_CALLBACK, void *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700722#define VPX_CTRL_VP9E_REGISTER_CX_CALLBACK
Marco Paniconi4864ab22014-02-06 09:23:17 -0800723VPX_CTRL_USE_TYPE(VP9E_SET_SVC_LAYER_ID, vpx_svc_layer_id_t *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700724#define VPX_CTRL_VP9E_SET_SVC_LAYER_ID
Ivan Maltz01b35c32013-09-05 08:55:47 -0700725
John Koleszar0ea50ce2010-05-18 11:58:33 -0400726VPX_CTRL_USE_TYPE(VP8E_SET_CPUUSED, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700727#define VPX_CTRL_VP8E_SET_CPUUSED
John Koleszar0ea50ce2010-05-18 11:58:33 -0400728VPX_CTRL_USE_TYPE(VP8E_SET_ENABLEAUTOALTREF, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700729#define VPX_CTRL_VP8E_SET_ENABLEAUTOALTREF
John Koleszar0ea50ce2010-05-18 11:58:33 -0400730VPX_CTRL_USE_TYPE(VP8E_SET_NOISE_SENSITIVITY, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700731#define VPX_CTRL_VP8E_SET_NOISE_SENSITIVITY
John Koleszar0ea50ce2010-05-18 11:58:33 -0400732VPX_CTRL_USE_TYPE(VP8E_SET_SHARPNESS, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700733#define VPX_CTRL_VP8E_SET_SHARPNESS
John Koleszar0ea50ce2010-05-18 11:58:33 -0400734VPX_CTRL_USE_TYPE(VP8E_SET_STATIC_THRESHOLD, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700735#define VPX_CTRL_VP8E_SET_STATIC_THRESHOLD
John Koleszar83b1d902012-11-05 12:37:14 -0800736VPX_CTRL_USE_TYPE(VP8E_SET_TOKEN_PARTITIONS, int) /* vp8e_token_partitions */
James Zern7dd7a7d2015-10-09 16:31:17 -0700737#define VPX_CTRL_VP8E_SET_TOKEN_PARTITIONS
John Koleszar0ea50ce2010-05-18 11:58:33 -0400738
739VPX_CTRL_USE_TYPE(VP8E_SET_ARNR_MAXFRAMES, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700740#define VPX_CTRL_VP8E_SET_ARNR_MAXFRAMES
John Koleszarc6b90392012-07-13 15:21:29 -0700741VPX_CTRL_USE_TYPE(VP8E_SET_ARNR_STRENGTH, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700742#define VPX_CTRL_VP8E_SET_ARNR_STRENGTH
Adrian Grangea7657052014-05-05 11:31:55 -0700743VPX_CTRL_USE_TYPE_DEPRECATED(VP8E_SET_ARNR_TYPE, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700744#define VPX_CTRL_VP8E_SET_ARNR_TYPE
John Koleszar83b1d902012-11-05 12:37:14 -0800745VPX_CTRL_USE_TYPE(VP8E_SET_TUNING, int) /* vp8e_tuning */
James Zern7dd7a7d2015-10-09 16:31:17 -0700746#define VPX_CTRL_VP8E_SET_TUNING
John Koleszarc6b90392012-07-13 15:21:29 -0700747VPX_CTRL_USE_TYPE(VP8E_SET_CQ_LEVEL, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700748#define VPX_CTRL_VP8E_SET_CQ_LEVEL
John Koleszar0ea50ce2010-05-18 11:58:33 -0400749
Ronald S. Bultje1407bdc2013-02-01 09:35:28 -0800750VPX_CTRL_USE_TYPE(VP9E_SET_TILE_COLUMNS, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700751#define VPX_CTRL_VP9E_SET_TILE_COLUMNS
Ronald S. Bultje89a206e2013-02-08 11:33:11 -0800752VPX_CTRL_USE_TYPE(VP9E_SET_TILE_ROWS, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700753#define VPX_CTRL_VP9E_SET_TILE_ROWS
Ronald S. Bultje1407bdc2013-02-01 09:35:28 -0800754
John Koleszar0ea50ce2010-05-18 11:58:33 -0400755VPX_CTRL_USE_TYPE(VP8E_GET_LAST_QUANTIZER, int *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700756#define VPX_CTRL_VP8E_GET_LAST_QUANTIZER
John Koleszar0ea50ce2010-05-18 11:58:33 -0400757VPX_CTRL_USE_TYPE(VP8E_GET_LAST_QUANTIZER_64, int *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700758#define VPX_CTRL_VP8E_GET_LAST_QUANTIZER_64
Deb Mukherjee0ba15422014-11-07 11:01:53 -0800759VPX_CTRL_USE_TYPE(VP9E_GET_SVC_LAYER_ID, vpx_svc_layer_id_t *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700760#define VPX_CTRL_VP9E_GET_SVC_LAYER_ID
John Koleszar0ea50ce2010-05-18 11:58:33 -0400761
John Koleszar1654ae92011-07-28 09:17:32 -0400762VPX_CTRL_USE_TYPE(VP8E_SET_MAX_INTRA_BITRATE_PCT, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700763#define VPX_CTRL_VP8E_SET_MAX_INTRA_BITRATE_PCT
Yaowu Xu636099f2014-10-24 09:31:16 -0700764VPX_CTRL_USE_TYPE(VP8E_SET_MAX_INTER_BITRATE_PCT, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700765#define VPX_CTRL_VP8E_SET_MAX_INTER_BITRATE_PCT
John Koleszar1654ae92011-07-28 09:17:32 -0400766
Marcoaf898b52014-11-10 13:07:05 -0800767VPX_CTRL_USE_TYPE(VP8E_SET_SCREEN_CONTENT_MODE, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700768#define VPX_CTRL_VP8E_SET_SCREEN_CONTENT_MODE
Marcoaf898b52014-11-10 13:07:05 -0800769
Yaowu Xu41652902015-03-12 17:59:18 -0700770VPX_CTRL_USE_TYPE(VP9E_SET_GF_CBR_BOOST_PCT, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700771#define VPX_CTRL_VP9E_SET_GF_CBR_BOOST_PCT
Yaowu Xu41652902015-03-12 17:59:18 -0700772
John Koleszar83b1d902012-11-05 12:37:14 -0800773VPX_CTRL_USE_TYPE(VP9E_SET_LOSSLESS, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700774#define VPX_CTRL_VP9E_SET_LOSSLESS
John Koleszar1654ae92011-07-28 09:17:32 -0400775
John Koleszar81708cc2013-03-27 11:07:26 -0700776VPX_CTRL_USE_TYPE(VP9E_SET_FRAME_PARALLEL_DECODING, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700777#define VPX_CTRL_VP9E_SET_FRAME_PARALLEL_DECODING
Ivan Maltz01b35c32013-09-05 08:55:47 -0700778
Guillaume Martres17084652013-11-14 19:23:57 +0100779VPX_CTRL_USE_TYPE(VP9E_SET_AQ_MODE, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700780#define VPX_CTRL_VP9E_SET_AQ_MODE
Guillaume Martres17084652013-11-14 19:23:57 +0100781
Marco Paniconi0eb88c92014-04-03 15:49:03 -0700782VPX_CTRL_USE_TYPE(VP9E_SET_FRAME_PERIODIC_BOOST, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700783#define VPX_CTRL_VP9E_SET_FRAME_PERIODIC_BOOST
Marco Paniconi0eb88c92014-04-03 15:49:03 -0700784
JackyChenbb1a2362014-09-12 11:48:44 -0700785VPX_CTRL_USE_TYPE(VP9E_SET_NOISE_SENSITIVITY, unsigned int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700786#define VPX_CTRL_VP9E_SET_NOISE_SENSITIVITY
JackyChenbb1a2362014-09-12 11:48:44 -0700787
Alex Converse572de922014-07-31 08:27:32 -0700788VPX_CTRL_USE_TYPE(VP9E_SET_TUNE_CONTENT, int) /* vp9e_tune_content */
James Zern7dd7a7d2015-10-09 16:31:17 -0700789#define VPX_CTRL_VP9E_SET_TUNE_CONTENT
Yaowu Xue94b4152015-01-13 10:07:20 -0800790
791VPX_CTRL_USE_TYPE(VP9E_SET_COLOR_SPACE, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700792#define VPX_CTRL_VP9E_SET_COLOR_SPACE
Alex Converse4dcb8392015-03-20 14:55:43 -0700793
Debargha Mukherjee98526432015-04-01 16:39:06 -0700794VPX_CTRL_USE_TYPE(VP9E_SET_MIN_GF_INTERVAL, unsigned int)
Debargha Mukherjeee8a3abe2015-07-06 16:07:53 -0700795#define VPX_CTRL_VP9E_SET_MIN_GF_INTERVAL
Debargha Mukherjee98526432015-04-01 16:39:06 -0700796
797VPX_CTRL_USE_TYPE(VP9E_SET_MAX_GF_INTERVAL, unsigned int)
Debargha Mukherjeee8a3abe2015-07-06 16:07:53 -0700798#define VPX_CTRL_VP9E_SET_MAX_GF_INTERVAL
Debargha Mukherjee98526432015-04-01 16:39:06 -0700799
Alex Converse4dcb8392015-03-20 14:55:43 -0700800VPX_CTRL_USE_TYPE(VP9E_GET_ACTIVEMAP, vpx_active_map_t *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700801#define VPX_CTRL_VP9E_GET_ACTIVEMAP
Ronald S. Bultjeeeb5ef02015-09-15 21:56:51 -0400802
Ronald S. Bultjeeeb5ef02015-09-15 21:56:51 -0400803VPX_CTRL_USE_TYPE(VP9E_SET_COLOR_RANGE, int)
James Zern7dd7a7d2015-10-09 16:31:17 -0700804#define VPX_CTRL_VP9E_SET_COLOR_RANGE
Yaowu Xu7c514e22015-09-28 15:55:46 -0700805
806VPX_CTRL_USE_TYPE(VP9E_SET_SVC_REF_FRAME_CONFIG, vpx_svc_ref_frame_config_t *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700807#define VPX_CTRL_VP9E_SET_SVC_REF_FRAME_CONFIG
Yaowu Xu7c514e22015-09-28 15:55:46 -0700808
809/*!\brief
810 *
811 * TODO(rbultje) : add support of the control in ffmpeg
812 */
813#define VPX_CTRL_VP9E_SET_RENDER_SIZE
814VPX_CTRL_USE_TYPE(VP9E_SET_RENDER_SIZE, int *)
James Zern7dd7a7d2015-10-09 16:31:17 -0700815/*!\endcond */
John Koleszar0ea50ce2010-05-18 11:58:33 -0400816/*! @} - end defgroup vp8_encoder */
Dmitry Kovaleve288c602013-09-29 18:00:15 -0700817#ifdef __cplusplus
818} // extern "C"
819#endif
820
James Zern7386bde2013-12-15 18:26:15 -0800821#endif // VPX_VP8CX_H_