annotate xvmc.h @ 8852:ff1b704b1f8f libavcodec

doxygen style comments
author iive
date Sat, 14 Feb 2009 17:56:51 +0000
parents a8fdc730936d
children b0292c878f9d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
1 /*
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
2 * Copyright (C) 2003 Ivan Kalvachev
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
3 *
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
4 * This file is part of FFmpeg.
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
5 *
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
6 * FFmpeg is free software; you can redistribute it and/or
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
8 * License as published by the Free Software Foundation; either
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
9 * version 2.1 of the License, or (at your option) any later version.
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
10 *
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
11 * FFmpeg is distributed in the hope that it will be useful,
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
14 * Lesser General Public License for more details.
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
15 *
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
17 * License along with FFmpeg; if not, write to the Free Software
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
19 */
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
20
8843
00c1d62c3852 Update multiple inclusion guards to match filename.
diego
parents: 8841
diff changeset
21 #ifndef AVCODEC_XVMC_H
00c1d62c3852 Update multiple inclusion guards to match filename.
diego
parents: 8841
diff changeset
22 #define AVCODEC_XVMC_H
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
23
8851
a8fdc730936d Replace useless X11 #includes by the one that actually provides the required
diego
parents: 8850
diff changeset
24 #include <X11/extensions/XvMC.h>
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
25
8848
0a382f53863b Add avcodec.h #include so that LIBAVCODEC_VERSION_MAJOR is not undefined.
diego
parents: 8847
diff changeset
26 #include "avcodec.h"
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
27
8852
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
28 /**the surface should be shown, the video driver manipulates this*/
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
29 #define AV_XVMC_STATE_DISPLAY_PENDING 1
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
30 /**the surface is needed for prediction, the codec manipulates this*/
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
31 #define AV_XVMC_STATE_PREDICTION 2
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
32 /**this surface is needed for subpicture rendering*/
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
33 #define AV_XVMC_STATE_OSD_SOURCE 4
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
34 /**<magic value to ensure that regular pixel routines haven't corrupted the struct*/
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
35 // 1337 IDCT MCo
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
36 #define AV_XVMC_RENDER_MAGIC 0x1DC711C0
8846
9e3956a4fd28 Rename xvmc flags to follow ffmpeg AV_ notion.
iive
parents: 8845
diff changeset
37
9e3956a4fd28 Rename xvmc flags to follow ffmpeg AV_ notion.
iive
parents: 8845
diff changeset
38 #if LIBAVCODEC_VERSION_MAJOR < 53
9e3956a4fd28 Rename xvmc flags to follow ffmpeg AV_ notion.
iive
parents: 8845
diff changeset
39 #define MP_XVMC_STATE_DISPLAY_PENDING AV_XVMC_STATE_DISPLAY_PENDING
9e3956a4fd28 Rename xvmc flags to follow ffmpeg AV_ notion.
iive
parents: 8845
diff changeset
40 #define MP_XVMC_STATE_PREDICTION AV_XVMC_STATE_PREDICTION
9e3956a4fd28 Rename xvmc flags to follow ffmpeg AV_ notion.
iive
parents: 8845
diff changeset
41 #define MP_XVMC_STATE_OSD_SOURCE AV_XVMC_STATE_OSD_SOURCE
9e3956a4fd28 Rename xvmc flags to follow ffmpeg AV_ notion.
iive
parents: 8845
diff changeset
42 #define MP_XVMC_RENDER_MAGIC AV_XVMC_RENDER_MAGIC
9e3956a4fd28 Rename xvmc flags to follow ffmpeg AV_ notion.
iive
parents: 8845
diff changeset
43 #endif
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
44
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
45 struct xvmc_render_state {
8852
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
46 /** these are not changed by the decoder! */
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
47 //@{
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
48 int magic; ///< used as check for memory corruption by regular pixel routines
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
49
8850
73b84757dc05 whitespace cosmetics: vertical alignment
diego
parents: 8849
diff changeset
50 short* data_blocks;
73b84757dc05 whitespace cosmetics: vertical alignment
diego
parents: 8849
diff changeset
51 XvMCMacroBlock* mv_blocks;
73b84757dc05 whitespace cosmetics: vertical alignment
diego
parents: 8849
diff changeset
52 int total_number_of_mv_blocks;
73b84757dc05 whitespace cosmetics: vertical alignment
diego
parents: 8849
diff changeset
53 int total_number_of_data_blocks;
8852
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
54 int mc_type; ///<XVMC_MPEG1/2/4,XVMC_H263 without XVMC_IDCT
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
55 int idct; ///< indicate that IDCT acceleration level is used
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
56 int chroma_format; ///< XVMC_CHROMA_FORMAT_420/422/444
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
57 int unsigned_intra; ///<+-128 for intra pictures after clipping
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
58 XvMCSurface* p_surface; ///<pointer to rendered surface, never changed
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
59 //}@
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
60
8852
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
61 /** these are changed by the decoder
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
62 //used by the XvMCRenderSurface function */
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
63 //@{
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
64 XvMCSurface* p_past_surface; ///<pointer to the past surface
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
65 XvMCSurface* p_future_surface; ///<pointer to the future prediction surface
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
66
8852
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
67 unsigned int picture_structure; ///<top/bottom fields or frame!
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
68 unsigned int flags; ///<XVMC_SECOND_FIELD - 1st or 2nd field in the sequence
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
69 unsigned int display_flags; ///<1,2 or 1+2 fields for XvMCPutSurface
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
70 //}@
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
71
8852
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
72 /** these are for internal communication */
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
73 //@{
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
74 int state; ///<0 - free, 1 - waiting to display, 2 - waiting for prediction
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
75 int start_mv_blocks_num; ///<offset in the array for the current slice, updated by vo
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
76 int filled_mv_blocks_num; ///<processed mv block in this slice, changed by decoder
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
77
8852
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
78 int next_free_data_block_num; ///<used in add_mv_block, pointer to next free block
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
79 //}@
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
80 /**extensions*/
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
81 //@{
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
82 void * p_osd_target_surface_render; ///<pointer to the surface where subpicture is rendered
ff1b704b1f8f doxygen style comments
iive
parents: 8851
diff changeset
83 //}@
8808
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
84
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
85 };
36f2dabd58c9 Rename xvmc_render.h --> xvmc_pixfmt.h and vdpau.h --> vdpau_pixfmt.h as
diego
parents:
diff changeset
86
8843
00c1d62c3852 Update multiple inclusion guards to match filename.
diego
parents: 8841
diff changeset
87 #endif /* AVCODEC_XVMC_H */