Thu, 15 Jan 2015 15:59:08 +0100
Implement a real Private Browsing Mode condition by changing the API/ABI;
This solves Tor bug #9701, complying with disk avoidance documented in
https://www.torproject.org/projects/torbrowser/design/#disk-avoidance.
1 /*
2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved.
3 *
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.
9 */
10 #ifndef VPX_DECODER_H
11 #define VPX_DECODER_H
13 /*!\defgroup decoder Decoder Algorithm Interface
14 * \ingroup codec
15 * This abstraction allows applications using this decoder to easily support
16 * multiple video formats with minimal code duplication. This section describes
17 * the interface common to all decoders.
18 * @{
19 */
21 /*!\file
22 * \brief Describes the decoder algorithm interface to applications.
23 *
24 * This file describes the interface between an application and a
25 * video decoder algorithm.
26 *
27 */
28 #ifdef __cplusplus
29 extern "C" {
30 #endif
32 #include "vpx_codec.h"
34 /*!\brief Current ABI version number
35 *
36 * \internal
37 * If this file is altered in any way that changes the ABI, this value
38 * must be bumped. Examples include, but are not limited to, changing
39 * types, removing or reassigning enums, adding/removing/rearranging
40 * fields to structures
41 */
42 #define VPX_DECODER_ABI_VERSION (2 + VPX_CODEC_ABI_VERSION) /**<\hideinitializer*/
44 /*! \brief Decoder capabilities bitfield
45 *
46 * Each decoder advertises the capabilities it supports as part of its
47 * ::vpx_codec_iface_t interface structure. Capabilities are extra interfaces
48 * or functionality, and are not required to be supported by a decoder.
49 *
50 * The available flags are specified by VPX_CODEC_CAP_* defines.
51 */
52 #define VPX_CODEC_CAP_PUT_SLICE 0x10000 /**< Will issue put_slice callbacks */
53 #define VPX_CODEC_CAP_PUT_FRAME 0x20000 /**< Will issue put_frame callbacks */
54 #define VPX_CODEC_CAP_POSTPROC 0x40000 /**< Can postprocess decoded frame */
55 #define VPX_CODEC_CAP_ERROR_CONCEALMENT 0x80000 /**< Can conceal errors due to
56 packet loss */
57 #define VPX_CODEC_CAP_INPUT_FRAGMENTS 0x100000 /**< Can receive encoded frames
58 one fragment at a time */
60 /*! \brief Initialization-time Feature Enabling
61 *
62 * Certain codec features must be known at initialization time, to allow for
63 * proper memory allocation.
64 *
65 * The available flags are specified by VPX_CODEC_USE_* defines.
66 */
67 #define VPX_CODEC_CAP_FRAME_THREADING 0x200000 /**< Can support frame-based
68 multi-threading */
70 #define VPX_CODEC_USE_POSTPROC 0x10000 /**< Postprocess decoded frame */
71 #define VPX_CODEC_USE_ERROR_CONCEALMENT 0x20000 /**< Conceal errors in decoded
72 frames */
73 #define VPX_CODEC_USE_INPUT_FRAGMENTS 0x40000 /**< The input frame should be
74 passed to the decoder one
75 fragment at a time */
76 #define VPX_CODEC_USE_FRAME_THREADING 0x80000 /**< Enable frame-based
77 multi-threading */
79 /*!\brief Stream properties
80 *
81 * This structure is used to query or set properties of the decoded
82 * stream. Algorithms may extend this structure with data specific
83 * to their bitstream by setting the sz member appropriately.
84 */
85 typedef struct vpx_codec_stream_info {
86 unsigned int sz; /**< Size of this structure */
87 unsigned int w; /**< Width (or 0 for unknown/default) */
88 unsigned int h; /**< Height (or 0 for unknown/default) */
89 unsigned int is_kf; /**< Current frame is a keyframe */
90 } vpx_codec_stream_info_t;
92 /* REQUIRED FUNCTIONS
93 *
94 * The following functions are required to be implemented for all decoders.
95 * They represent the base case functionality expected of all decoders.
96 */
99 /*!\brief Initialization Configurations
100 *
101 * This structure is used to pass init time configuration options to the
102 * decoder.
103 */
104 typedef struct vpx_codec_dec_cfg {
105 unsigned int threads; /**< Maximum number of threads to use, default 1 */
106 unsigned int w; /**< Width */
107 unsigned int h; /**< Height */
108 } vpx_codec_dec_cfg_t; /**< alias for struct vpx_codec_dec_cfg */
111 /*!\brief Initialize a decoder instance
112 *
113 * Initializes a decoder context using the given interface. Applications
114 * should call the vpx_codec_dec_init convenience macro instead of this
115 * function directly, to ensure that the ABI version number parameter
116 * is properly initialized.
117 *
118 * If the library was configured with --disable-multithread, this call
119 * is not thread safe and should be guarded with a lock if being used
120 * in a multithreaded context.
121 *
122 * In XMA mode (activated by setting VPX_CODEC_USE_XMA in the flags
123 * parameter), the storage pointed to by the cfg parameter must be
124 * kept readable and stable until all memory maps have been set.
125 *
126 * \param[in] ctx Pointer to this instance's context.
127 * \param[in] iface Pointer to the algorithm interface to use.
128 * \param[in] cfg Configuration to use, if known. May be NULL.
129 * \param[in] flags Bitfield of VPX_CODEC_USE_* flags
130 * \param[in] ver ABI version number. Must be set to
131 * VPX_DECODER_ABI_VERSION
132 * \retval #VPX_CODEC_OK
133 * The decoder algorithm initialized.
134 * \retval #VPX_CODEC_MEM_ERROR
135 * Memory allocation failed.
136 */
137 vpx_codec_err_t vpx_codec_dec_init_ver(vpx_codec_ctx_t *ctx,
138 vpx_codec_iface_t *iface,
139 vpx_codec_dec_cfg_t *cfg,
140 vpx_codec_flags_t flags,
141 int ver);
143 /*!\brief Convenience macro for vpx_codec_dec_init_ver()
144 *
145 * Ensures the ABI version parameter is properly set.
146 */
147 #define vpx_codec_dec_init(ctx, iface, cfg, flags) \
148 vpx_codec_dec_init_ver(ctx, iface, cfg, flags, VPX_DECODER_ABI_VERSION)
151 /*!\brief Parse stream info from a buffer
152 *
153 * Performs high level parsing of the bitstream. Construction of a decoder
154 * context is not necessary. Can be used to determine if the bitstream is
155 * of the proper format, and to extract information from the stream.
156 *
157 * \param[in] iface Pointer to the algorithm interface
158 * \param[in] data Pointer to a block of data to parse
159 * \param[in] data_sz Size of the data buffer
160 * \param[in,out] si Pointer to stream info to update. The size member
161 * \ref MUST be properly initialized, but \ref MAY be
162 * clobbered by the algorithm. This parameter \ref MAY
163 * be NULL.
164 *
165 * \retval #VPX_CODEC_OK
166 * Bitstream is parsable and stream information updated
167 */
168 vpx_codec_err_t vpx_codec_peek_stream_info(vpx_codec_iface_t *iface,
169 const uint8_t *data,
170 unsigned int data_sz,
171 vpx_codec_stream_info_t *si);
174 /*!\brief Return information about the current stream.
175 *
176 * Returns information about the stream that has been parsed during decoding.
177 *
178 * \param[in] ctx Pointer to this instance's context
179 * \param[in,out] si Pointer to stream info to update. The size member
180 * \ref MUST be properly initialized, but \ref MAY be
181 * clobbered by the algorithm. This parameter \ref MAY
182 * be NULL.
183 *
184 * \retval #VPX_CODEC_OK
185 * Bitstream is parsable and stream information updated
186 */
187 vpx_codec_err_t vpx_codec_get_stream_info(vpx_codec_ctx_t *ctx,
188 vpx_codec_stream_info_t *si);
191 /*!\brief Decode data
192 *
193 * Processes a buffer of coded data. If the processing results in a new
194 * decoded frame becoming available, PUT_SLICE and PUT_FRAME events may be
195 * generated, as appropriate. Encoded data \ref MUST be passed in DTS (decode
196 * time stamp) order. Frames produced will always be in PTS (presentation
197 * time stamp) order.
198 * If the decoder is configured with VPX_CODEC_USE_INPUT_FRAGMENTS enabled,
199 * data and data_sz can contain a fragment of the encoded frame. Fragment
200 * \#n must contain at least partition \#n, but can also contain subsequent
201 * partitions (\#n+1 - \#n+i), and if so, fragments \#n+1, .., \#n+i must
202 * be empty. When no more data is available, this function should be called
203 * with NULL as data and 0 as data_sz. The memory passed to this function
204 * must be available until the frame has been decoded.
205 *
206 * \param[in] ctx Pointer to this instance's context
207 * \param[in] data Pointer to this block of new coded data. If
208 * NULL, a VPX_CODEC_CB_PUT_FRAME event is posted
209 * for the previously decoded frame.
210 * \param[in] data_sz Size of the coded data, in bytes.
211 * \param[in] user_priv Application specific data to associate with
212 * this frame.
213 * \param[in] deadline Soft deadline the decoder should attempt to meet,
214 * in us. Set to zero for unlimited.
215 *
216 * \return Returns #VPX_CODEC_OK if the coded data was processed completely
217 * and future pictures can be decoded without error. Otherwise,
218 * see the descriptions of the other error codes in ::vpx_codec_err_t
219 * for recoverability capabilities.
220 */
221 vpx_codec_err_t vpx_codec_decode(vpx_codec_ctx_t *ctx,
222 const uint8_t *data,
223 unsigned int data_sz,
224 void *user_priv,
225 long deadline);
228 /*!\brief Decoded frames iterator
229 *
230 * Iterates over a list of the frames available for display. The iterator
231 * storage should be initialized to NULL to start the iteration. Iteration is
232 * complete when this function returns NULL.
233 *
234 * The list of available frames becomes valid upon completion of the
235 * vpx_codec_decode call, and remains valid until the next call to vpx_codec_decode.
236 *
237 * \param[in] ctx Pointer to this instance's context
238 * \param[in,out] iter Iterator storage, initialized to NULL
239 *
240 * \return Returns a pointer to an image, if one is ready for display. Frames
241 * produced will always be in PTS (presentation time stamp) order.
242 */
243 vpx_image_t *vpx_codec_get_frame(vpx_codec_ctx_t *ctx,
244 vpx_codec_iter_t *iter);
247 /*!\defgroup cap_put_frame Frame-Based Decoding Functions
248 *
249 * The following functions are required to be implemented for all decoders
250 * that advertise the VPX_CODEC_CAP_PUT_FRAME capability. Calling these functions
251 * for codecs that don't advertise this capability will result in an error
252 * code being returned, usually VPX_CODEC_ERROR
253 * @{
254 */
256 /*!\brief put frame callback prototype
257 *
258 * This callback is invoked by the decoder to notify the application of
259 * the availability of decoded image data.
260 */
261 typedef void (*vpx_codec_put_frame_cb_fn_t)(void *user_priv,
262 const vpx_image_t *img);
265 /*!\brief Register for notification of frame completion.
266 *
267 * Registers a given function to be called when a decoded frame is
268 * available.
269 *
270 * \param[in] ctx Pointer to this instance's context
271 * \param[in] cb Pointer to the callback function
272 * \param[in] user_priv User's private data
273 *
274 * \retval #VPX_CODEC_OK
275 * Callback successfully registered.
276 * \retval #VPX_CODEC_ERROR
277 * Decoder context not initialized, or algorithm not capable of
278 * posting slice completion.
279 */
280 vpx_codec_err_t vpx_codec_register_put_frame_cb(vpx_codec_ctx_t *ctx,
281 vpx_codec_put_frame_cb_fn_t cb,
282 void *user_priv);
285 /*!@} - end defgroup cap_put_frame */
287 /*!\defgroup cap_put_slice Slice-Based Decoding Functions
288 *
289 * The following functions are required to be implemented for all decoders
290 * that advertise the VPX_CODEC_CAP_PUT_SLICE capability. Calling these functions
291 * for codecs that don't advertise this capability will result in an error
292 * code being returned, usually VPX_CODEC_ERROR
293 * @{
294 */
296 /*!\brief put slice callback prototype
297 *
298 * This callback is invoked by the decoder to notify the application of
299 * the availability of partially decoded image data. The
300 */
301 typedef void (*vpx_codec_put_slice_cb_fn_t)(void *user_priv,
302 const vpx_image_t *img,
303 const vpx_image_rect_t *valid,
304 const vpx_image_rect_t *update);
307 /*!\brief Register for notification of slice completion.
308 *
309 * Registers a given function to be called when a decoded slice is
310 * available.
311 *
312 * \param[in] ctx Pointer to this instance's context
313 * \param[in] cb Pointer to the callback function
314 * \param[in] user_priv User's private data
315 *
316 * \retval #VPX_CODEC_OK
317 * Callback successfully registered.
318 * \retval #VPX_CODEC_ERROR
319 * Decoder context not initialized, or algorithm not capable of
320 * posting slice completion.
321 */
322 vpx_codec_err_t vpx_codec_register_put_slice_cb(vpx_codec_ctx_t *ctx,
323 vpx_codec_put_slice_cb_fn_t cb,
324 void *user_priv);
327 /*!@} - end defgroup cap_put_slice*/
329 /*!@} - end defgroup decoder*/
330 #ifdef __cplusplus
331 }
332 #endif
333 #endif